Documentation ¶
Overview ¶
Package godet implements a client to interact with an instance of Chrome via the Remote Debugging Protocol.
See https://developer.chrome.com/devtools/docs/debugger-protocol
Index ¶
- Constants
- Variables
- func Budget(budget int) setVirtualTimerPolicyOption
- func InitialVirtualTime(t time.Time) setVirtualTimerPolicyOption
- func MaxVirtualTimeTaskStarvationCount(max int) setVirtualTimerPolicyOption
- func WaitForNavigation(wait bool) setVirtualTimerPolicyOption
- type ConnectOption
- type Cookie
- type Domain
- type DownloadBehavior
- type ErrorReason
- type EvaluateError
- type EvaluateOption
- type EventCallback
- type FetchRequestPattern
- type IdType
- type InterceptionStage
- type KeyModifier
- type MouseEvent
- type MouseOption
- type NavigationEntry
- type NavigationError
- type NavigationResponse
- type Params
- type PrintToPDFOption
- func Dimensions(width, height float64) PrintToPDFOption
- func DisplayHeaderFooter() PrintToPDFOption
- func LandscapeMode() PrintToPDFOption
- func Margins(top, bottom, left, right float64) PrintToPDFOption
- func PageRanges(ranges string) PrintToPDFOption
- func PortraitMode() PrintToPDFOption
- func PrintBackground() PrintToPDFOption
- func Scale(n float64) PrintToPDFOption
- type Profile
- type ProfileNode
- type RemoteDebugger
- func (remote *RemoteDebugger) ActivateTab(tab *Tab) error
- func (remote *RemoteDebugger) AllEvents(enable bool) error
- func (remote *RemoteDebugger) AttachToTarget(targetId string) (string, error)
- func (remote *RemoteDebugger) CallbackEvent(method string, cb EventCallback)
- func (remote *RemoteDebugger) CaptureScreenshot(format string, quality int, fromSurface bool) ([]byte, error)
- func (remote *RemoteDebugger) ClearBrowserCache() error
- func (remote *RemoteDebugger) ClearBrowserCookies() error
- func (remote *RemoteDebugger) Close() (err error)
- func (remote *RemoteDebugger) CloseBrowser()
- func (remote *RemoteDebugger) CloseTab(tab *Tab) error
- func (remote *RemoteDebugger) ContinueInterceptedRequest(interceptionID string, errorReason ErrorReason, rawResponse string, url string, ...) errordeprecated
- func (remote *RemoteDebugger) ContinueRequest(requestID string, url string, method string, postData string, ...) error
- func (remote *RemoteDebugger) DOMEvents(enable bool) error
- func (remote *RemoteDebugger) DebuggerEvents(enable bool) error
- func (remote *RemoteDebugger) DebuggerPause() error
- func (remote *RemoteDebugger) DebuggerResume(terminateOnResume bool) error
- func (remote *RemoteDebugger) DebuggerSetBreakpointsActive(active bool) error
- func (remote *RemoteDebugger) DebuggerSkipAllPauses(skip bool) error
- func (remote *RemoteDebugger) DeleteCookies(name, url, domain, path string) error
- func (remote *RemoteDebugger) DomainEvents(domain string, enable bool) error
- func (remote *RemoteDebugger) EmulationEvents(enable bool) error
- func (remote *RemoteDebugger) EnableRequestInterception(enabled bool) error
- func (remote *RemoteDebugger) EnableRequestPaused(enable bool, patterns ...FetchRequestPattern) error
- func (remote *RemoteDebugger) Evaluate(expr string, options ...EvaluateOption) (interface{}, error)
- func (remote *RemoteDebugger) EvaluateWrap(expr string, options ...EvaluateOption) (interface{}, error)
- func (remote *RemoteDebugger) FailRequest(requestID string, errorReason ErrorReason) error
- func (remote *RemoteDebugger) FetchResponseBody(requestId string) ([]byte, error)
- func (remote *RemoteDebugger) Focus(nodeID int) error
- func (remote *RemoteDebugger) FulfillRequest(requestID string, responseCode int, responsePhrase string, ...) error
- func (remote *RemoteDebugger) GetAllCookies() ([]Cookie, error)
- func (remote *RemoteDebugger) GetBoxModel(nodeID int) (map[string]interface{}, error)
- func (remote *RemoteDebugger) GetCertificate(origin string) ([]string, error)
- func (remote *RemoteDebugger) GetComputedStyleForNode(nodeID int) (map[string]interface{}, error)
- func (remote *RemoteDebugger) GetCookies(urls []string) ([]Cookie, error)
- func (remote *RemoteDebugger) GetDocument() (map[string]interface{}, error)
- func (remote *RemoteDebugger) GetDomains() ([]Domain, error)deprecated
- func (remote *RemoteDebugger) GetNavigationHistory() (int, []NavigationEntry, error)
- func (remote *RemoteDebugger) GetOuterHTML(nodeID int) (string, error)
- func (remote *RemoteDebugger) GetPreciseCoverage(precise bool) ([]interface{}, error)
- func (remote *RemoteDebugger) GetResponseBody(req string) ([]byte, error)
- func (remote *RemoteDebugger) GetResponseBodyForInterception(iid string) ([]byte, error)
- func (remote *RemoteDebugger) GetScriptSource(id string) (string, error)
- func (remote *RemoteDebugger) GetTargets() (map[string]interface{}, error)
- func (remote *RemoteDebugger) HandleJavaScriptDialog(accept bool, promptText string) error
- func (remote *RemoteDebugger) LogEvents(enable bool) error
- func (remote *RemoteDebugger) MouseEvent(ev MouseEvent, x, y int, options ...MouseOption) error
- func (remote *RemoteDebugger) Navigate(url string) (string, error)
- func (remote *RemoteDebugger) NavigateTransition(url string, trans TransitionType) (string, error)
- func (remote *RemoteDebugger) NetworkEvents(enable bool) error
- func (remote *RemoteDebugger) NewTab(url string) (*Tab, error)
- func (remote *RemoteDebugger) PageEvents(enable bool) error
- func (remote *RemoteDebugger) PrintToPDF(options ...PrintToPDFOption) ([]byte, error)
- func (remote *RemoteDebugger) ProcessNavigation(navigationID int, navigation NavigationResponse) error
- func (remote *RemoteDebugger) ProfilerEvents(enable bool) error
- func (remote *RemoteDebugger) Protocol() (map[string]interface{}, error)
- func (remote *RemoteDebugger) QuerySelector(nodeID int, selector string) (map[string]interface{}, error)
- func (remote *RemoteDebugger) QuerySelectorAll(nodeID int, selector string) (map[string]interface{}, error)
- func (remote *RemoteDebugger) Reload() error
- func (remote *RemoteDebugger) RequestNode(nodeID int) error
- func (remote *RemoteDebugger) ResolveNode(nodeID int) (map[string]interface{}, error)
- func (remote *RemoteDebugger) RuntimeEvents(enable bool) error
- func (remote *RemoteDebugger) SavePDF(filename string, perm os.FileMode, options ...PrintToPDFOption) error
- func (remote *RemoteDebugger) SaveScreenshot(filename string, perm os.FileMode, quality int, fromSurface bool) error
- func (remote *RemoteDebugger) SendRequest(method string, params Params) (map[string]interface{}, error)
- func (remote *RemoteDebugger) SendRune(c rune) error
- func (remote *RemoteDebugger) ServiceWorkerEvents(enable bool) error
- func (remote *RemoteDebugger) SetAttributeValue(nodeID int, name, value string) error
- func (remote *RemoteDebugger) SetAutoAttach(autoAttach bool) error
- func (remote *RemoteDebugger) SetBlockedURLs(urls ...string) error
- func (remote *RemoteDebugger) SetBypassServiceWorker(bypass bool) error
- func (remote *RemoteDebugger) SetCacheDisabled(disabled bool) error
- func (remote *RemoteDebugger) SetControlNavigations(enabled bool) error
- func (remote *RemoteDebugger) SetCookie(cookie Cookie) bool
- func (remote *RemoteDebugger) SetCookies(cookies []Cookie) error
- func (remote *RemoteDebugger) SetDeviceMetricsOverride(width int, height int, deviceScaleFactor float64, mobile bool, fitWindow bool) error
- func (remote *RemoteDebugger) SetDiscoverTargets(discover bool) error
- func (remote *RemoteDebugger) SetDownloadBehavior(behavior DownloadBehavior, downloadPath string) error
- func (remote *RemoteDebugger) SetFileInputFiles(id int, files []string, idType IdType) error
- func (remote *RemoteDebugger) SetInputFiles(nodeID int, files []string) error
- func (remote *RemoteDebugger) SetOuterHTML(nodeID int, outerHTML string) error
- func (remote *RemoteDebugger) SetProfilerSamplingInterval(n int64) error
- func (remote *RemoteDebugger) SetRequestInterception(patterns ...RequestPattern) errordeprecated
- func (remote *RemoteDebugger) SetScriptSource(id, source string) error
- func (remote *RemoteDebugger) SetUserAgent(userAgent string) error
- func (remote *RemoteDebugger) SetVirtualTimePolicy(policy VirtualTimePolicy, budget int, options ...setVirtualTimerPolicyOption) error
- func (remote *RemoteDebugger) SetVisibleSize(width, height int) errordeprecated
- func (remote *RemoteDebugger) StartPreciseCoverage(callCount, detailed bool) error
- func (remote *RemoteDebugger) StartProfiler() error
- func (remote *RemoteDebugger) StopPreciseCoverage() error
- func (remote *RemoteDebugger) StopProfiler() (p Profile, err error)
- func (remote *RemoteDebugger) TabList(filter string) ([]*Tab, error)
- func (remote *RemoteDebugger) TargetEvents(enable bool) error
- func (remote *RemoteDebugger) Verbose(v bool)
- func (remote *RemoteDebugger) Version() (*Version, error)
- type RequestPattern
- type RequestStage
- type ResourceType
- type Tab
- type TransitionType
- type Version
- type VirtualTimePolicy
Constants ¶
const ( // EventClosed represents the "RemoteDebugger.closed" event. // It is emitted when RemoteDebugger.Close() is called. EventClosed = "RemoteDebugger.closed" // EventClosed represents the "RemoteDebugger.disconnected" event. // It is emitted when we lose connection with the debugger and we stop reading events EventDisconnect = "RemoteDebugger.disconnected" NavigationProceed = NavigationResponse("Proceed") NavigationCancel = NavigationResponse("Cancel") NavigationCancelAndIgnore = NavigationResponse("CancelAndIgnore") ErrorReasonFailed = ErrorReason("Failed") ErrorReasonAborted = ErrorReason("Aborted") ErrorReasonTimedOut = ErrorReason("TimedOut") ErrorReasonAccessDenied = ErrorReason("AccessDenied") ErrorReasonConnectionClosed = ErrorReason("ConnectionClosed") ErrorReasonConnectionReset = ErrorReason("ConnectionReset") ErrorReasonConnectionRefused = ErrorReason("ConnectionRefused") ErrorReasonConnectionAborted = ErrorReason("ConnectionAborted") ErrorReasonConnectionFailed = ErrorReason("ConnectionFailed") ErrorReasonNameNotResolved = ErrorReason("NameNotResolved") ErrorReasonInternetDisconnected = ErrorReason("InternetDisconnected") ErrorReasonAddressUnreachable = ErrorReason("AddressUnreachable") ErrorReasonBlockedByClient = ErrorReason("BlockedByClient") ErrorReasonBlockedByResponse = ErrorReason("BlockedByResponse") // VirtualTimePolicyAdvance specifies that if the scheduler runs out of immediate work, the virtual time base may fast forward to allow the next delayed task (if any) to run VirtualTimePolicyAdvance = VirtualTimePolicy("advance") // VirtualTimePolicyPause specifies that the virtual time base may not advance VirtualTimePolicyPause = VirtualTimePolicy("pause") // VirtualTimePolicyPauseIfNetworkFetchesPending specifies that the virtual time base may not advance if there are any pending resource fetches. VirtualTimePolicyPauseIfNetworkFetchesPending = VirtualTimePolicy("pauseIfNetworkFetchesPending") AllowDownload = DownloadBehavior("allow") NameDownload = DownloadBehavior("allowAndName") DenyDownload = DownloadBehavior("deny") DefaultDownload = DownloadBehavior("default") )
const ( NoTransition = TransitionType("") Reload = TransitionType("reload") )
const ( ResourceTypeDocument = ResourceType("Document") ResourceTypeStylesheet = ResourceType("Stylesheet") ResourceTypeImage = ResourceType("Image") ResourceTypeMedia = ResourceType("Media") ResourceTypeFont = ResourceType("Font") ResourceTypeScript = ResourceType("Script") ResourceTypeTextTrack = ResourceType("TextTrack") ResourceTypeXHR = ResourceType("XHR") ResourceTypeFetch = ResourceType("Fetch") ResourceTypeEventSource = ResourceType("EventSource") ResourceTypeWebSocket = ResourceType("WebSocket") ResourceTypeManifest = ResourceType("Manifest") ResourceTypeSignedExchange = ResourceType("SignedExchange") ResourceTypePing = ResourceType("Ping") ResourceTypeCSPViolationReport = ResourceType("CSPViolationReport") ResourceTypeOther = ResourceType("Other") )
const ( StageRequest = InterceptionStage("Request") StageHeadersReceived = InterceptionStage("HeadersReceived") RequestStageRequest = RequestStage("Request") RequestStageResponse = RequestStage("Response") )
const ( MouseMove MouseEvent = "mouseMoved" MousePress MouseEvent = "mousePressed" MouseRelease MouseEvent = "mouseReleased" NoModifier KeyModifier = 0 AltKey KeyModifier = 1 CtrlKey KeyModifier = 2 MetaKey KeyModifier = 4 CommandKey KeyModifier = 4 ShiftKey KeyModifier = 8 )
Variables ¶
var ( // ErrorNoActiveTab is returned if there are no active tabs (of type "page") ErrorNoActiveTab = errors.New("no active tab") // ErrorNoWsURL is returned if the active tab has no websocket URL ErrorNoWsURL = errors.New("no websocket URL") // ErrorNoResponse is returned if a method was expecting a response but got nil instead ErrorNoResponse = errors.New("no response") // ErrorClose is returned if a method is called after the connection has been close ErrorClose = errors.New("closed") MaxReadBufferSize = 0 // default gorilla/websocket buffer size MaxWriteBufferSize = 100 * 1024 // this should be large enough to send large scripts )
Functions ¶
func Budget ¶
func Budget(budget int) setVirtualTimerPolicyOption
If set, after this many virtual milliseconds have elapsed virtual time will be paused and a\nvirtualTimeBudgetExpired event is sent.
func InitialVirtualTime ¶
If set, base::Time::Now will be overriden to initially return this value.
func MaxVirtualTimeTaskStarvationCount ¶
func MaxVirtualTimeTaskStarvationCount(max int) setVirtualTimerPolicyOption
If set this specifies the maximum number of tasks that can be run before virtual is forced\nforwards to prevent deadlock.
func WaitForNavigation ¶
func WaitForNavigation(wait bool) setVirtualTimerPolicyOption
If set the virtual time policy change should be deferred until any frame starts navigating.\nNote any previous deferred policy change is superseded.
Types ¶
type ConnectOption ¶
type ConnectOption func(c *httpclient.HttpClient)
func Headers ¶
func Headers(headers map[string]string) ConnectOption
Headers set specified HTTP headers
type Cookie ¶
type Cookie struct { Name string `json:"name"` Value string `json:"value"` Domain string `json:"domain"` Path string `json:"path"` Size int `json:"size"` Expires float64 `json:"expires"` HttpOnly bool `json:"httpOnly"` Secure bool `json:"secure"` Session bool `json:"session"` SameSite string `json:"sameSite"` }
type DownloadBehavior ¶
type DownloadBehavior string
DownloadBehaviour defines the type for Page.SetDownloadBehavior
type ErrorReason ¶
type ErrorReason string
ErrorReason defines what error should be generated to abort a request in ContinueInterceptedRequest
type EvaluateError ¶
type EvaluateError struct { ErrorDetails map[string]interface{} ExceptionDetails map[string]interface{} }
EvaluateError is returned by Evaluate in case of expression errors.
func (EvaluateError) Error ¶
func (err EvaluateError) Error() string
type EvaluateOption ¶
type EvaluateOption func(params Params)
func GeneratePreview ¶
func GeneratePreview(enable bool) EvaluateOption
func IncludeCommandLineAPI ¶
func IncludeCommandLineAPI(enable bool) EvaluateOption
func ReturnByValue ¶
func ReturnByValue(enable bool) EvaluateOption
func Silent ¶
func Silent(enable bool) EvaluateOption
func ThrowOnSideEffect ¶
func ThrowOnSideEffect(enable bool) EvaluateOption
func UserGesture ¶
func UserGesture(enable bool) EvaluateOption
type EventCallback ¶
type EventCallback func(params Params)
EventCallback represents a callback event, associated with a method.
func ConsoleAPICallback ¶
func ConsoleAPICallback(cb func([]interface{})) EventCallback
ConsoleAPICallback processes the Runtime.consolAPICalled event and returns printable info
type FetchRequestPattern ¶
type FetchRequestPattern struct { UrlPattern string `json:"urlPattern,omitempty"` ResourceType ResourceType `json:"resourceType,omitempty"` RequestStage RequestStage `json:"requestStage,omitempty"` }
type InterceptionStage ¶
type InterceptionStage string
type KeyModifier ¶
type KeyModifier int
type MouseEvent ¶
type MouseEvent string
type MouseOption ¶
type MouseOption func(p Params)
func Clicks ¶
func Clicks(c int) MouseOption
func LeftButton ¶
func LeftButton() MouseOption
func MiddleButton ¶
func MiddleButton() MouseOption
func Modifiers ¶
func Modifiers(m KeyModifier) MouseOption
func RightButton ¶
func RightButton() MouseOption
type NavigationEntry ¶
type NavigationEntry struct {}
NavigationEntry represent a navigation history entry.
type NavigationError ¶
type NavigationError string
func (NavigationError) Error ¶
func (err NavigationError) Error() string
type NavigationResponse ¶
type NavigationResponse string
NavigationResponse defines the type for ProcessNavigation `response`
type Params ¶
type Params map[string]interface{}
Params is a type alias for the event params structure.
type PrintToPDFOption ¶
type PrintToPDFOption func(map[string]interface{})
PrintToPDFOption defines the functional option for PrintToPDF
func Dimensions ¶
func Dimensions(width, height float64) PrintToPDFOption
Dimensions sets the current page dimensions for PrintToPDF
func DisplayHeaderFooter ¶
func DisplayHeaderFooter() PrintToPDFOption
DisplayHeaderFooter instructs PrintToPDF to print headers/footers or not
func LandscapeMode ¶
func LandscapeMode() PrintToPDFOption
LandscapeMode instructs PrintToPDF to print pages in landscape mode
func Margins ¶
func Margins(top, bottom, left, right float64) PrintToPDFOption
Margins sets the margin sizes for PrintToPDF
func PageRanges ¶
func PageRanges(ranges string) PrintToPDFOption
PageRanges instructs PrintToPDF to print only the specified range of pages
func PortraitMode ¶
func PortraitMode() PrintToPDFOption
PortraitMode instructs PrintToPDF to print pages in portrait mode
func PrintBackground ¶
func PrintBackground() PrintToPDFOption
printBackground instructs PrintToPDF to print background graphics
func Scale ¶
func Scale(n float64) PrintToPDFOption
Scale instructs PrintToPDF to scale the pages (1.0 is current scale)
type Profile ¶
type Profile struct { Nodes []ProfileNode `json:"nodes"` StartTime int64 `json:"startTime"` EndTime int64 `json:"endTime"` Samples []int64 `json:"samples"` TimeDeltas []int64 `json:"timeDeltas"` }
Profile represents a profile data structure.
type ProfileNode ¶
type ProfileNode struct { ID int64 `json:"id"` CallFrame json.RawMessage `json:"callFrame"` HitCount int64 `json:"hitCount"` Children []int64 `json:"children"` DeoptReason string `json:"deoptReason"` PositionTicks json.RawMessage `json:"positionTicks"` }
ProfileNode represents a profile node data structure. The experimental fields are kept as json.RawMessage, so you may decode them with your own code, see: https://chromedevtools.github.io/debugger-protocol-viewer/tot/Profiler/
type RemoteDebugger ¶
RemoteDebugger implements an interface for Chrome DevTools.
func Connect ¶
func Connect(port string, verbose bool, options ...ConnectOption) (*RemoteDebugger, error)
Connect to the remote debugger and return `RemoteDebugger` object.
func (*RemoteDebugger) ActivateTab ¶
func (remote *RemoteDebugger) ActivateTab(tab *Tab) error
ActivateTab activates the specified tab.
func (*RemoteDebugger) AllEvents ¶
func (remote *RemoteDebugger) AllEvents(enable bool) error
AllEvents enables event listening for all domains.
func (*RemoteDebugger) AttachToTarget ¶
func (remote *RemoteDebugger) AttachToTarget(targetId string) (string, error)
Attaches to the target with given id.
func (*RemoteDebugger) CallbackEvent ¶
func (remote *RemoteDebugger) CallbackEvent(method string, cb EventCallback)
CallbackEvent sets a callback for the specified event.
func (*RemoteDebugger) CaptureScreenshot ¶
func (remote *RemoteDebugger) CaptureScreenshot(format string, quality int, fromSurface bool) ([]byte, error)
CaptureScreenshot takes a screenshot, uses "png" as default format.
func (*RemoteDebugger) ClearBrowserCache ¶
func (remote *RemoteDebugger) ClearBrowserCache() error
func (*RemoteDebugger) ClearBrowserCookies ¶
func (remote *RemoteDebugger) ClearBrowserCookies() error
func (*RemoteDebugger) Close ¶
func (remote *RemoteDebugger) Close() (err error)
Close the RemoteDebugger connection.
func (*RemoteDebugger) CloseBrowser ¶
func (remote *RemoteDebugger) CloseBrowser()
CloseBrowser gracefully closes the browser we are connected to
func (*RemoteDebugger) CloseTab ¶
func (remote *RemoteDebugger) CloseTab(tab *Tab) error
CloseTab closes the specified tab.
func (*RemoteDebugger) ContinueInterceptedRequest
deprecated
func (remote *RemoteDebugger) ContinueInterceptedRequest(interceptionID string, errorReason ErrorReason, rawResponse string, url string, method string, postData string, headers map[string]string) error
ContinueInterceptedRequest is the response to Network.requestIntercepted which either modifies the request to continue with any modifications, or blocks it, or completes it with the provided response bytes.
If a network fetch occurs as a result which encounters a redirect an additional Network.requestIntercepted event will be sent with the same InterceptionId.
Parameters:
errorReason ErrorReason - if set this causes the request to fail with the given reason. rawResponse string - if set the requests completes using with the provided base64 encoded raw response, including HTTP status line and headers etc... url string - if set the request url will be modified in a way that's not observable by page. method string - if set this allows the request method to be overridden. postData string - if set this allows postData to be set. headers Headers - if set this allows the request headers to be changed.
Deprecated: use ContinueRequest, FulfillRequest and FailRequest instead.
func (*RemoteDebugger) ContinueRequest ¶
func (remote *RemoteDebugger) ContinueRequest(requestID string, url string, method string, postData string, headers map[string]string) error
ContinueRequest is the response to Fetch.requestPaused which either modifies the request to continue with any modifications, or blocks it, or completes it with the provided response bytes.
Parameters:
url string - if set the request url will be modified in a way that's not observable by page. method string - if set this allows the request method to be overridden. postData string - if set this allows postData to be set. headers Headers - if set this allows the request headers to be changed.
func (*RemoteDebugger) DOMEvents ¶
func (remote *RemoteDebugger) DOMEvents(enable bool) error
DOMEvents enables DOM events listening.
func (*RemoteDebugger) DebuggerEvents ¶
func (remote *RemoteDebugger) DebuggerEvents(enable bool) error
DebuggerEvents enables DebugLog events listening.
func (*RemoteDebugger) DebuggerPause ¶
func (remote *RemoteDebugger) DebuggerPause() error
func (*RemoteDebugger) DebuggerResume ¶
func (remote *RemoteDebugger) DebuggerResume(terminateOnResume bool) error
func (*RemoteDebugger) DebuggerSetBreakpointsActive ¶
func (remote *RemoteDebugger) DebuggerSetBreakpointsActive(active bool) error
func (*RemoteDebugger) DebuggerSkipAllPauses ¶
func (remote *RemoteDebugger) DebuggerSkipAllPauses(skip bool) error
func (*RemoteDebugger) DeleteCookies ¶
func (remote *RemoteDebugger) DeleteCookies(name, url, domain, path string) error
Deletes browser cookies with matching name and url or domain/path pair.
Parameters:
name string: Name of the cookies to remove. url string: If specified, deletes all the cookies with the given name where domain and path match provided URL. domain string: If specified, deletes only cookies with the exact domain. path string: If specified, deletes only cookies with the exact path.
func (*RemoteDebugger) DomainEvents ¶
func (remote *RemoteDebugger) DomainEvents(domain string, enable bool) error
DomainEvents enables event listening in the specified domain.
func (*RemoteDebugger) EmulationEvents ¶
func (remote *RemoteDebugger) EmulationEvents(enable bool) error
EmulationEvents enables Emulation events listening.
func (*RemoteDebugger) EnableRequestInterception ¶
func (remote *RemoteDebugger) EnableRequestInterception(enabled bool) error
EnableRequestInterception enables interception, modification or cancellation of network requests
func (*RemoteDebugger) EnableRequestPaused ¶
func (remote *RemoteDebugger) EnableRequestPaused(enable bool, patterns ...FetchRequestPattern) error
EnableRequestPaused enables issuing of requestPaused events. A request will be paused until client calls one of failRequest, fulfillRequest or continueRequest/continueWithAuth.
If patterns is specified, only requests matching any of these patterns will produce fetchRequested event and will be paused until clients response. If not set,all requests will be affected.
func (*RemoteDebugger) Evaluate ¶
func (remote *RemoteDebugger) Evaluate(expr string, options ...EvaluateOption) (interface{}, error)
Evaluate evalutes a Javascript function in the context of the current page.
func (*RemoteDebugger) EvaluateWrap ¶
func (remote *RemoteDebugger) EvaluateWrap(expr string, options ...EvaluateOption) (interface{}, error)
EvaluateWrap evaluates a list of expressions, EvaluateWrap wraps them in `(function(){ ... })()`. Use a return statement to return a value.
func (*RemoteDebugger) FailRequest ¶
func (remote *RemoteDebugger) FailRequest(requestID string, errorReason ErrorReason) error
FailRequest causes the request to fail with specified reason.
func (*RemoteDebugger) FetchResponseBody ¶
func (remote *RemoteDebugger) FetchResponseBody(requestId string) ([]byte, error)
func (*RemoteDebugger) Focus ¶
func (remote *RemoteDebugger) Focus(nodeID int) error
Focus sets focus on a specified node.
func (*RemoteDebugger) FulfillRequest ¶
func (remote *RemoteDebugger) FulfillRequest(requestID string, responseCode int, responsePhrase string, headers map[string]string, body []byte) error
FulfillRequest provides a response to the request.
func (*RemoteDebugger) GetAllCookies ¶
func (remote *RemoteDebugger) GetAllCookies() ([]Cookie, error)
GetAllCookies returns all browser cookies. Depending on the backend support, will return detailed cookie information in the `cookies` field.
func (*RemoteDebugger) GetBoxModel ¶
func (remote *RemoteDebugger) GetBoxModel(nodeID int) (map[string]interface{}, error)
GetBoxModel returns boxes for a DOM node identified by nodeId.
func (*RemoteDebugger) GetCertificate ¶
func (remote *RemoteDebugger) GetCertificate(origin string) ([]string, error)
func (*RemoteDebugger) GetComputedStyleForNode ¶
func (remote *RemoteDebugger) GetComputedStyleForNode(nodeID int) (map[string]interface{}, error)
GetComputedStyleForNode returns the computed style for a DOM node identified by nodeId.
func (*RemoteDebugger) GetCookies ¶
func (remote *RemoteDebugger) GetCookies(urls []string) ([]Cookie, error)
GetCookies returns all browser cookies for the current URL. Depending on the backend support, will return detailed cookie information in the `cookies` field.
func (*RemoteDebugger) GetDocument ¶
func (remote *RemoteDebugger) GetDocument() (map[string]interface{}, error)
GetDocument gets the "Document" object as a DevTool node.
func (*RemoteDebugger) GetDomains
deprecated
func (remote *RemoteDebugger) GetDomains() ([]Domain, error)
GetDomains lists the available DevTools domains.
Deprecated: The Schema domain is now deprecated.
func (*RemoteDebugger) GetNavigationHistory ¶
func (remote *RemoteDebugger) GetNavigationHistory() (int, []NavigationEntry, error)
GetNavigationHistory returns navigation history for the current page.
func (*RemoteDebugger) GetOuterHTML ¶
func (remote *RemoteDebugger) GetOuterHTML(nodeID int) (string, error)
GetOuterHTML returns node's HTML markup.
func (*RemoteDebugger) GetPreciseCoverage ¶
func (remote *RemoteDebugger) GetPreciseCoverage(precise bool) ([]interface{}, error)
GetPreciseCoverage collects coverage data for the current isolate and resets execution counters.
func (*RemoteDebugger) GetResponseBody ¶
func (remote *RemoteDebugger) GetResponseBody(req string) ([]byte, error)
GetResponseBody returns the response body of a given requestId (from the Network.responseReceived payload).
func (*RemoteDebugger) GetResponseBodyForInterception ¶
func (remote *RemoteDebugger) GetResponseBodyForInterception(iid string) ([]byte, error)
func (*RemoteDebugger) GetScriptSource ¶
func (remote *RemoteDebugger) GetScriptSource(id string) (string, error)
func (*RemoteDebugger) GetTargets ¶
func (remote *RemoteDebugger) GetTargets() (map[string]interface{}, error)
Retrieves a list of available targets.
func (*RemoteDebugger) HandleJavaScriptDialog ¶
func (remote *RemoteDebugger) HandleJavaScriptDialog(accept bool, promptText string) error
HandleJavaScriptDialog accepts or dismisses a Javascript initiated dialog.
func (*RemoteDebugger) LogEvents ¶
func (remote *RemoteDebugger) LogEvents(enable bool) error
LogEvents enables Log events listening.
func (*RemoteDebugger) MouseEvent ¶
func (remote *RemoteDebugger) MouseEvent(ev MouseEvent, x, y int, options ...MouseOption) error
MouseEvent dispatches a mouse event to the page. An event can be MouseMove, MousePressed and MouseReleased. An event always requires mouse coordinates, while other parameters are optional.
To simulate mouse button presses, pass LeftButton()/RightButton()/MiddleButton() options and possibily key modifiers. It is also possible to pass the number of clicks (2 for double clicks, etc.).
func (*RemoteDebugger) Navigate ¶
func (remote *RemoteDebugger) Navigate(url string) (string, error)
Navigate navigates to the specified URL.
func (*RemoteDebugger) NavigateTransition ¶
func (remote *RemoteDebugger) NavigateTransition(url string, trans TransitionType) (string, error)
func (*RemoteDebugger) NetworkEvents ¶
func (remote *RemoteDebugger) NetworkEvents(enable bool) error
NetworkEvents enables Network events listening.
func (*RemoteDebugger) NewTab ¶
func (remote *RemoteDebugger) NewTab(url string) (*Tab, error)
NewTab creates a new tab.
func (*RemoteDebugger) PageEvents ¶
func (remote *RemoteDebugger) PageEvents(enable bool) error
PageEvents enables Page events listening.
func (*RemoteDebugger) PrintToPDF ¶
func (remote *RemoteDebugger) PrintToPDF(options ...PrintToPDFOption) ([]byte, error)
PrintToPDF print the current page as PDF.
func (*RemoteDebugger) ProcessNavigation ¶
func (remote *RemoteDebugger) ProcessNavigation(navigationID int, navigation NavigationResponse) error
ProcessNavigation should be sent in response to a navigationRequested or a redirectRequested event, telling the browser how to handle the navigation.
func (*RemoteDebugger) ProfilerEvents ¶
func (remote *RemoteDebugger) ProfilerEvents(enable bool) error
ProfilerEvents enables Profiler events listening.
func (*RemoteDebugger) Protocol ¶
func (remote *RemoteDebugger) Protocol() (map[string]interface{}, error)
Protocol returns the DevTools protocol specification
func (*RemoteDebugger) QuerySelector ¶
func (remote *RemoteDebugger) QuerySelector(nodeID int, selector string) (map[string]interface{}, error)
QuerySelector gets the nodeId for a specified selector.
func (*RemoteDebugger) QuerySelectorAll ¶
func (remote *RemoteDebugger) QuerySelectorAll(nodeID int, selector string) (map[string]interface{}, error)
QuerySelectorAll gets a list of nodeId for the specified selectors.
func (*RemoteDebugger) Reload ¶
func (remote *RemoteDebugger) Reload() error
Reload reloads the current page.
func (*RemoteDebugger) RequestNode ¶
func (remote *RemoteDebugger) RequestNode(nodeID int) error
RequestNode requests a node, the response is generated as a DOM.setChildNodes event.
func (*RemoteDebugger) ResolveNode ¶
func (remote *RemoteDebugger) ResolveNode(nodeID int) (map[string]interface{}, error)
ResolveNode returns some information about the node.
func (*RemoteDebugger) RuntimeEvents ¶
func (remote *RemoteDebugger) RuntimeEvents(enable bool) error
RuntimeEvents enables Runtime events listening.
func (*RemoteDebugger) SavePDF ¶
func (remote *RemoteDebugger) SavePDF(filename string, perm os.FileMode, options ...PrintToPDFOption) error
SavePDF print current page as PDF and save to file
func (*RemoteDebugger) SaveScreenshot ¶
func (remote *RemoteDebugger) SaveScreenshot(filename string, perm os.FileMode, quality int, fromSurface bool) error
SaveScreenshot takes a screenshot and saves it to a file.
func (*RemoteDebugger) SendRequest ¶
func (remote *RemoteDebugger) SendRequest(method string, params Params) (map[string]interface{}, error)
SendRequest sends a request and returns the reply as a a map.
func (*RemoteDebugger) SendRune ¶
func (remote *RemoteDebugger) SendRune(c rune) error
SendRune sends a character as keyboard input.
func (*RemoteDebugger) ServiceWorkerEvents ¶
func (remote *RemoteDebugger) ServiceWorkerEvents(enable bool) error
ServiceWorkerEvents enables ServiceWorker events listening.
func (*RemoteDebugger) SetAttributeValue ¶
func (remote *RemoteDebugger) SetAttributeValue(nodeID int, name, value string) error
SetAttributeValue sets the value for a specified attribute.
func (*RemoteDebugger) SetAutoAttach ¶
func (remote *RemoteDebugger) SetAutoAttach(autoAttach bool) error
Controls whether to automatically attach to new targets which are considered to be related to this one. When turned on, attaches to all existing related targets as well. When turned off, automatically detaches from all currently attached targets. This also clears all targets added by `autoAttachRelated` from the list of targets to watch for creation of related targets.",
func (*RemoteDebugger) SetBlockedURLs ¶
func (remote *RemoteDebugger) SetBlockedURLs(urls ...string) error
SetBlockedURLs blocks URLs from loading (wildcards '*' are allowed)
func (*RemoteDebugger) SetBypassServiceWorker ¶
func (remote *RemoteDebugger) SetBypassServiceWorker(bypass bool) error
SetBypassServiceWorker toggles ignoring of service worker for each request
func (*RemoteDebugger) SetCacheDisabled ¶
func (remote *RemoteDebugger) SetCacheDisabled(disabled bool) error
SetCacheDisabled toggles ignoring cache for each request. If `true`, cache will not be used.
func (*RemoteDebugger) SetControlNavigations ¶
func (remote *RemoteDebugger) SetControlNavigations(enabled bool) error
SetControlNavigations toggles navigation throttling which allows programatic control over navigation and redirect response.
func (*RemoteDebugger) SetCookie ¶
func (remote *RemoteDebugger) SetCookie(cookie Cookie) bool
Set browser cookie
func (*RemoteDebugger) SetCookies ¶
func (remote *RemoteDebugger) SetCookies(cookies []Cookie) error
Set browser cookies.
func (*RemoteDebugger) SetDeviceMetricsOverride ¶
func (remote *RemoteDebugger) SetDeviceMetricsOverride(width int, height int, deviceScaleFactor float64, mobile bool, fitWindow bool) error
SetDeviceMetricsOverride sets mobile and fitWindow on top of device dimensions Can be used to produce screenshots of mobile viewports.
func (*RemoteDebugger) SetDiscoverTargets ¶
func (remote *RemoteDebugger) SetDiscoverTargets(discover bool) error
Controls whether to discover available targets and notify via `targetCreated/targetInfoChanged/targetDestroyed` events."
func (*RemoteDebugger) SetDownloadBehavior ¶
func (remote *RemoteDebugger) SetDownloadBehavior(behavior DownloadBehavior, downloadPath string) error
SetDownloadBehaviour enable/disable downloads.
func (*RemoteDebugger) SetFileInputFiles ¶
func (remote *RemoteDebugger) SetFileInputFiles(id int, files []string, idType IdType) error
SetFileInputFiles sets files for the given file input element.
func (*RemoteDebugger) SetInputFiles ¶
func (remote *RemoteDebugger) SetInputFiles(nodeID int, files []string) error
SetInputFiles attaches input files to a specified node (an input[type=file] element?). Note: this has been renamed SetFileInputFiles
func (*RemoteDebugger) SetOuterHTML ¶
func (remote *RemoteDebugger) SetOuterHTML(nodeID int, outerHTML string) error
SetOuterHTML sets node HTML markup.
func (*RemoteDebugger) SetProfilerSamplingInterval ¶
func (remote *RemoteDebugger) SetProfilerSamplingInterval(n int64) error
SetProfilerSamplingInterval sets the profiler sampling interval in microseconds, must be called before StartProfiler.
func (*RemoteDebugger) SetRequestInterception
deprecated
func (remote *RemoteDebugger) SetRequestInterception(patterns ...RequestPattern) error
SetRequestInterception sets the requests to intercept that match the provided patterns and optionally resource types.
Deprecated: use EnableRequestPaused instead.
func (*RemoteDebugger) SetScriptSource ¶
func (remote *RemoteDebugger) SetScriptSource(id, source string) error
func (*RemoteDebugger) SetUserAgent ¶
func (remote *RemoteDebugger) SetUserAgent(userAgent string) error
SetUserAgent overrides the default user agent.
func (*RemoteDebugger) SetVirtualTimePolicy ¶
func (remote *RemoteDebugger) SetVirtualTimePolicy(policy VirtualTimePolicy, budget int, options ...setVirtualTimerPolicyOption) error
SetVirtualTimePolicy turns on virtual time for all frames (replacing real-time with a synthetic time source) and sets the current virtual time policy. Note this supersedes any previous time budget.
func (*RemoteDebugger) SetVisibleSize
deprecated
func (remote *RemoteDebugger) SetVisibleSize(width, height int) error
SetVisibleSize resizes the frame/viewport of the page. Note that this does not affect the frame's container (e.g. browser window). Can be used to produce screenshots of the specified size.
Deprecated: Emulation.setVisibleSize is now deprecated.
func (*RemoteDebugger) StartPreciseCoverage ¶
func (remote *RemoteDebugger) StartPreciseCoverage(callCount, detailed bool) error
StartPreciseCoverage enable precise code coverage.
func (*RemoteDebugger) StartProfiler ¶
func (remote *RemoteDebugger) StartProfiler() error
StartProfiler starts the profiler.
func (*RemoteDebugger) StopPreciseCoverage ¶
func (remote *RemoteDebugger) StopPreciseCoverage() error
StopPreciseCoverage disable precise code coverage.
func (*RemoteDebugger) StopProfiler ¶
func (remote *RemoteDebugger) StopProfiler() (p Profile, err error)
StopProfiler stops the profiler. Returns a Profile data structure, as specified here: https://chromedevtools.github.io/debugger-protocol-viewer/tot/Profiler/#type-Profile
func (*RemoteDebugger) TabList ¶
func (remote *RemoteDebugger) TabList(filter string) ([]*Tab, error)
TabList returns a list of opened tabs/pages. If filter is not empty, only tabs of the specified type are returned (i.e. "page").
Note that tabs are ordered by activitiy time (most recently used first) so the current tab is the first one of type "page".
func (*RemoteDebugger) TargetEvents ¶
func (remote *RemoteDebugger) TargetEvents(enable bool) error
TargetEvents enables Target events listening.
func (*RemoteDebugger) Verbose ¶
func (remote *RemoteDebugger) Verbose(v bool)
func (*RemoteDebugger) Version ¶
func (remote *RemoteDebugger) Version() (*Version, error)
Version returns version information (protocol, browser, etc.).
type RequestPattern ¶
type RequestPattern struct { UrlPattern string `json:"urlPattern,omitempty"` ResourceType ResourceType `json:"resourceType,omitempty"` InterceptionStage InterceptionStage `json:"interceptionStage,omitempty"` }
type RequestStage ¶
type RequestStage string
type ResourceType ¶
type ResourceType string
type Tab ¶
type Tab struct { ID string `json:"id"` Type string `json:"type"` Description string `json:"description"` Title string `json:"title"` URL string `json:"url"` WsURL string `json:"webSocketDebuggerUrl"` DevURL string `json:"devtoolsFrontendUrl"` }
Tab represents an opened tab/page.
type TransitionType ¶
type TransitionType string
type Version ¶
type Version struct { Browser string `json:"Browser"` ProtocolVersion string `json:"Protocol-Version"` UserAgent string `json:"User-Agent"` V8Version string `json:"V8-Version"` WebKitVersion string `json:"WebKit-Version"` }
Version holds the DevTools version information.
type VirtualTimePolicy ¶
type VirtualTimePolicy string
VirtualTimePolicy defines the type for Emulation.SetVirtualTimePolicy