# DO NOT EDIT THIS FILE! # # This file is generated from the CDP specification. If you need to make # changes, edit the generator and regenerate all of the modules. # # CDP domain: Target from __future__ import annotations from .util import event_class, T_JSON_DICT from dataclasses import dataclass import enum import typing from . import browser from . import page class TargetID(str): def to_json(self) -> str: return self @classmethod def from_json(cls, json: str) -> TargetID: return cls(json) def __repr__(self): return 'TargetID({})'.format(super().__repr__()) class SessionID(str): ''' Unique identifier of attached debugging session. ''' def to_json(self) -> str: return self @classmethod def from_json(cls, json: str) -> SessionID: return cls(json) def __repr__(self): return 'SessionID({})'.format(super().__repr__()) @dataclass class TargetInfo: target_id: TargetID #: List of types: https://source.chromium.org/chromium/chromium/src/+/main:content/browser/devtools/devtools_agent_host_impl.cc?ss=chromium&q=f:devtools%20-f:out%20%22::kTypeTab%5B%5D%22 type_: str title: str url: str #: Whether the target has an attached client. attached: bool #: Whether the target has access to the originating window. can_access_opener: bool #: Opener target Id opener_id: typing.Optional[TargetID] = None #: Frame id of originating window (is only set if target has an opener). opener_frame_id: typing.Optional[page.FrameId] = None browser_context_id: typing.Optional[browser.BrowserContextID] = None #: Provides additional details for specific target types. For example, for #: the type of "page", this may be set to "prerender". subtype: typing.Optional[str] = None def to_json(self): json = dict() json['targetId'] = self.target_id.to_json() json['type'] = self.type_ json['title'] = self.title json['url'] = self.url json['attached'] = self.attached json['canAccessOpener'] = self.can_access_opener if self.opener_id is not None: json['openerId'] = self.opener_id.to_json() if self.opener_frame_id is not None: json['openerFrameId'] = self.opener_frame_id.to_json() if self.browser_context_id is not None: json['browserContextId'] = self.browser_context_id.to_json() if self.subtype is not None: json['subtype'] = self.subtype return json @classmethod def from_json(cls, json): return cls( target_id=TargetID.from_json(json['targetId']), type_=str(json['type']), title=str(json['title']), url=str(json['url']), attached=bool(json['attached']), can_access_opener=bool(json['canAccessOpener']), opener_id=TargetID.from_json(json['openerId']) if 'openerId' in json else None, opener_frame_id=page.FrameId.from_json(json['openerFrameId']) if 'openerFrameId' in json else None, browser_context_id=browser.BrowserContextID.from_json(json['browserContextId']) if 'browserContextId' in json else None, subtype=str(json['subtype']) if 'subtype' in json else None, ) @dataclass class FilterEntry: ''' A filter used by target query/discovery/auto-attach operations. ''' #: If set, causes exclusion of matching targets from the list. exclude: typing.Optional[bool] = None #: If not present, matches any type. type_: typing.Optional[str] = None def to_json(self): json = dict() if self.exclude is not None: json['exclude'] = self.exclude if self.type_ is not None: json['type'] = self.type_ return json @classmethod def from_json(cls, json): return cls( exclude=bool(json['exclude']) if 'exclude' in json else None, type_=str(json['type']) if 'type' in json else None, ) class TargetFilter(list): ''' The entries in TargetFilter are matched sequentially against targets and the first entry that matches determines if the target is included or not, depending on the value of ``exclude`` field in the entry. If filter is not specified, the one assumed is [{type: "browser", exclude: true}, {type: "tab", exclude: true}, {}] (i.e. include everything but ``browser`` and ``tab``). ''' def to_json(self) -> typing.List[FilterEntry]: return self @classmethod def from_json(cls, json: typing.List[FilterEntry]) -> TargetFilter: return cls(json) def __repr__(self): return 'TargetFilter({})'.format(super().__repr__()) @dataclass class RemoteLocation: host: str port: int def to_json(self): json = dict() json['host'] = self.host json['port'] = self.port return json @classmethod def from_json(cls, json): return cls( host=str(json['host']), port=int(json['port']), ) def activate_target( target_id: TargetID ) -> typing.Generator[T_JSON_DICT,T_JSON_DICT,None]: ''' Activates (focuses) the target. :param target_id: ''' params: T_JSON_DICT = dict() params['targetId'] = target_id.to_json() cmd_dict: T_JSON_DICT = { 'method': 'Target.activateTarget', 'params': params, } json = yield cmd_dict def attach_to_target( target_id: TargetID, flatten: typing.Optional[bool] = None ) -> typing.Generator[T_JSON_DICT,T_JSON_DICT,SessionID]: ''' Attaches to the target with given id. :param target_id: :param flatten: *(Optional)* Enables "flat" access to the session via specifying sessionId attribute in the commands. We plan to make this the default, deprecate non-flattened mode, and eventually retire it. See crbug.com/991325. :returns: Id assigned to the session. ''' params: T_JSON_DICT = dict() params['targetId'] = target_id.to_json() if flatten is not None: params['flatten'] = flatten cmd_dict: T_JSON_DICT = { 'method': 'Target.attachToTarget', 'params': params, } json = yield cmd_dict return SessionID.from_json(json['sessionId']) def attach_to_browser_target() -> typing.Generator[T_JSON_DICT,T_JSON_DICT,SessionID]: ''' Attaches to the browser target, only uses flat sessionId mode. **EXPERIMENTAL** :returns: Id assigned to the session. ''' cmd_dict: T_JSON_DICT = { 'method': 'Target.attachToBrowserTarget', } json = yield cmd_dict return SessionID.from_json(json['sessionId']) def close_target( target_id: TargetID ) -> typing.Generator[T_JSON_DICT,T_JSON_DICT,bool]: ''' Closes the target. If the target is a page that gets closed too. :param target_id: :returns: Always set to true. If an error occurs, the response indicates protocol error. ''' params: T_JSON_DICT = dict() params['targetId'] = target_id.to_json() cmd_dict: T_JSON_DICT = { 'method': 'Target.closeTarget', 'params': params, } json = yield cmd_dict return bool(json['success']) def expose_dev_tools_protocol( target_id: TargetID, binding_name: typing.Optional[str] = None ) -> typing.Generator[T_JSON_DICT,T_JSON_DICT,None]: ''' Inject object to the target's main frame that provides a communication channel with browser target. Injected object will be available as ``window[bindingName]``. The object has the following API: - ``binding.send(json)`` - a method to send messages over the remote debugging protocol - ``binding.onmessage = json => handleMessage(json)`` - a callback that will be called for the protocol notifications and command responses. **EXPERIMENTAL** :param target_id: :param binding_name: *(Optional)* Binding name, 'cdp' if not specified. ''' params: T_JSON_DICT = dict() params['targetId'] = target_id.to_json() if binding_name is not None: params['bindingName'] = binding_name cmd_dict: T_JSON_DICT = { 'method': 'Target.exposeDevToolsProtocol', 'params': params, } json = yield cmd_dict def create_browser_context( dispose_on_detach: typing.Optional[bool] = None, proxy_server: typing.Optional[str] = None, proxy_bypass_list: typing.Optional[str] = None, origins_with_universal_network_access: typing.Optional[typing.List[str]] = None ) -> typing.Generator[T_JSON_DICT,T_JSON_DICT,browser.BrowserContextID]: ''' Creates a new empty BrowserContext. Similar to an incognito profile but you can have more than one. :param dispose_on_detach: **(EXPERIMENTAL)** *(Optional)* If specified, disposes this context when debugging session disconnects. :param proxy_server: **(EXPERIMENTAL)** *(Optional)* Proxy server, similar to the one passed to --proxy-server :param proxy_bypass_list: **(EXPERIMENTAL)** *(Optional)* Proxy bypass list, similar to the one passed to --proxy-bypass-list :param origins_with_universal_network_access: **(EXPERIMENTAL)** *(Optional)* An optional list of origins to grant unlimited cross-origin access to. Parts of the URL other than those constituting origin are ignored. :returns: The id of the context created. ''' params: T_JSON_DICT = dict() if dispose_on_detach is not None: params['disposeOnDetach'] = dispose_on_detach if proxy_server is not None: params['proxyServer'] = proxy_server if proxy_bypass_list is not None: params['proxyBypassList'] = proxy_bypass_list if origins_with_universal_network_access is not None: params['originsWithUniversalNetworkAccess'] = [i for i in origins_with_universal_network_access] cmd_dict: T_JSON_DICT = { 'method': 'Target.createBrowserContext', 'params': params, } json = yield cmd_dict return browser.BrowserContextID.from_json(json['browserContextId']) def get_browser_contexts() -> typing.Generator[T_JSON_DICT,T_JSON_DICT,typing.List[browser.BrowserContextID]]: ''' Returns all browser contexts created with ``Target.createBrowserContext`` method. :returns: An array of browser context ids. ''' cmd_dict: T_JSON_DICT = { 'method': 'Target.getBrowserContexts', } json = yield cmd_dict return [browser.BrowserContextID.from_json(i) for i in json['browserContextIds']] def create_target( url: str, width: typing.Optional[int] = None, height: typing.Optional[int] = None, browser_context_id: typing.Optional[browser.BrowserContextID] = None, enable_begin_frame_control: typing.Optional[bool] = None, new_window: typing.Optional[bool] = None, background: typing.Optional[bool] = None, for_tab: typing.Optional[bool] = None ) -> typing.Generator[T_JSON_DICT,T_JSON_DICT,TargetID]: ''' Creates a new page. :param url: The initial URL the page will be navigated to. An empty string indicates about:blank. :param width: *(Optional)* Frame width in DIP (headless chrome only). :param height: *(Optional)* Frame height in DIP (headless chrome only). :param browser_context_id: **(EXPERIMENTAL)** *(Optional)* The browser context to create the page in. :param enable_begin_frame_control: **(EXPERIMENTAL)** *(Optional)* Whether BeginFrames for this target will be controlled via DevTools (headless chrome only, not supported on MacOS yet, false by default). :param new_window: *(Optional)* Whether to create a new Window or Tab (chrome-only, false by default). :param background: *(Optional)* Whether to create the target in background or foreground (chrome-only, false by default). :param for_tab: **(EXPERIMENTAL)** *(Optional)* Whether to create the target of type "tab". :returns: The id of the page opened. ''' params: T_JSON_DICT = dict() params['url'] = url if width is not None: params['width'] = width if height is not None: params['height'] = height if browser_context_id is not None: params['browserContextId'] = browser_context_id.to_json() if enable_begin_frame_control is not None: params['enableBeginFrameControl'] = enable_begin_frame_control if new_window is not None: params['newWindow'] = new_window if background is not None: params['background'] = background if for_tab is not None: params['forTab'] = for_tab cmd_dict: T_JSON_DICT = { 'method': 'Target.createTarget', 'params': params, } json = yield cmd_dict return TargetID.from_json(json['targetId']) def detach_from_target( session_id: typing.Optional[SessionID] = None, target_id: typing.Optional[TargetID] = None ) -> typing.Generator[T_JSON_DICT,T_JSON_DICT,None]: ''' Detaches session with given id. :param session_id: *(Optional)* Session to detach. :param target_id: *(Optional)* Deprecated. ''' params: T_JSON_DICT = dict() if session_id is not None: params['sessionId'] = session_id.to_json() if target_id is not None: params['targetId'] = target_id.to_json() cmd_dict: T_JSON_DICT = { 'method': 'Target.detachFromTarget', 'params': params, } json = yield cmd_dict def dispose_browser_context( browser_context_id: browser.BrowserContextID ) -> typing.Generator[T_JSON_DICT,T_JSON_DICT,None]: ''' Deletes a BrowserContext. All the belonging pages will be closed without calling their beforeunload hooks. :param browser_context_id: ''' params: T_JSON_DICT = dict() params['browserContextId'] = browser_context_id.to_json() cmd_dict: T_JSON_DICT = { 'method': 'Target.disposeBrowserContext', 'params': params, } json = yield cmd_dict def get_target_info( target_id: typing.Optional[TargetID] = None ) -> typing.Generator[T_JSON_DICT,T_JSON_DICT,TargetInfo]: ''' Returns information about a target. **EXPERIMENTAL** :param target_id: *(Optional)* :returns: ''' params: T_JSON_DICT = dict() if target_id is not None: params['targetId'] = target_id.to_json() cmd_dict: T_JSON_DICT = { 'method': 'Target.getTargetInfo', 'params': params, } json = yield cmd_dict return TargetInfo.from_json(json['targetInfo']) def get_targets( filter_: typing.Optional[TargetFilter] = None ) -> typing.Generator[T_JSON_DICT,T_JSON_DICT,typing.List[TargetInfo]]: ''' Retrieves a list of available targets. :param filter_: **(EXPERIMENTAL)** *(Optional)* Only targets matching filter will be reported. If filter is not specified and target discovery is currently enabled, a filter used for target discovery is used for consistency. :returns: The list of targets. ''' params: T_JSON_DICT = dict() if filter_ is not None: params['filter'] = filter_.to_json() cmd_dict: T_JSON_DICT = { 'method': 'Target.getTargets', 'params': params, } json = yield cmd_dict return [TargetInfo.from_json(i) for i in json['targetInfos']] def send_message_to_target( message: str, session_id: typing.Optional[SessionID] = None, target_id: typing.Optional[TargetID] = None ) -> typing.Generator[T_JSON_DICT,T_JSON_DICT,None]: ''' Sends protocol message over session with given id. Consider using flat mode instead; see commands attachToTarget, setAutoAttach, and crbug.com/991325. :param message: :param session_id: *(Optional)* Identifier of the session. :param target_id: *(Optional)* Deprecated. ''' params: T_JSON_DICT = dict() params['message'] = message if session_id is not None: params['sessionId'] = session_id.to_json() if target_id is not None: params['targetId'] = target_id.to_json() cmd_dict: T_JSON_DICT = { 'method': 'Target.sendMessageToTarget', 'params': params, } json = yield cmd_dict def set_auto_attach( auto_attach: bool, wait_for_debugger_on_start: bool, flatten: typing.Optional[bool] = None, filter_: typing.Optional[TargetFilter] = None ) -> typing.Generator[T_JSON_DICT,T_JSON_DICT,None]: ''' 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. :param auto_attach: Whether to auto-attach to related targets. :param wait_for_debugger_on_start: Whether to pause new targets when attaching to them. Use ```Runtime.runIfWaitingForDebugger``` to run paused targets. :param flatten: **(EXPERIMENTAL)** *(Optional)* Enables "flat" access to the session via specifying sessionId attribute in the commands. We plan to make this the default, deprecate non-flattened mode, and eventually retire it. See crbug.com/991325. :param filter_: **(EXPERIMENTAL)** *(Optional)* Only targets matching filter will be attached. ''' params: T_JSON_DICT = dict() params['autoAttach'] = auto_attach params['waitForDebuggerOnStart'] = wait_for_debugger_on_start if flatten is not None: params['flatten'] = flatten if filter_ is not None: params['filter'] = filter_.to_json() cmd_dict: T_JSON_DICT = { 'method': 'Target.setAutoAttach', 'params': params, } json = yield cmd_dict def auto_attach_related( target_id: TargetID, wait_for_debugger_on_start: bool, filter_: typing.Optional[TargetFilter] = None ) -> typing.Generator[T_JSON_DICT,T_JSON_DICT,None]: ''' Adds the specified target to the list of targets that will be monitored for any related target creation (such as child frames, child workers and new versions of service worker) and reported through ``attachedToTarget``. The specified target is also auto-attached. This cancels the effect of any previous ``setAutoAttach`` and is also cancelled by subsequent ``setAutoAttach``. Only available at the Browser target. **EXPERIMENTAL** :param target_id: :param wait_for_debugger_on_start: Whether to pause new targets when attaching to them. Use ```Runtime.runIfWaitingForDebugger``` to run paused targets. :param filter_: **(EXPERIMENTAL)** *(Optional)* Only targets matching filter will be attached. ''' params: T_JSON_DICT = dict() params['targetId'] = target_id.to_json() params['waitForDebuggerOnStart'] = wait_for_debugger_on_start if filter_ is not None: params['filter'] = filter_.to_json() cmd_dict: T_JSON_DICT = { 'method': 'Target.autoAttachRelated', 'params': params, } json = yield cmd_dict def set_discover_targets( discover: bool, filter_: typing.Optional[TargetFilter] = None ) -> typing.Generator[T_JSON_DICT,T_JSON_DICT,None]: ''' Controls whether to discover available targets and notify via ``targetCreated/targetInfoChanged/targetDestroyed`` events. :param discover: Whether to discover available targets. :param filter_: **(EXPERIMENTAL)** *(Optional)* Only targets matching filter will be attached. If ```discover```` is false, ````filter``` must be omitted or empty. ''' params: T_JSON_DICT = dict() params['discover'] = discover if filter_ is not None: params['filter'] = filter_.to_json() cmd_dict: T_JSON_DICT = { 'method': 'Target.setDiscoverTargets', 'params': params, } json = yield cmd_dict def set_remote_locations( locations: typing.List[RemoteLocation] ) -> typing.Generator[T_JSON_DICT,T_JSON_DICT,None]: ''' Enables target discovery for the specified locations, when ``setDiscoverTargets`` was set to ``true``. **EXPERIMENTAL** :param locations: List of remote locations. ''' params: T_JSON_DICT = dict() params['locations'] = [i.to_json() for i in locations] cmd_dict: T_JSON_DICT = { 'method': 'Target.setRemoteLocations', 'params': params, } json = yield cmd_dict @event_class('Target.attachedToTarget') @dataclass class AttachedToTarget: ''' **EXPERIMENTAL** Issued when attached to target because of auto-attach or ``attachToTarget`` command. ''' #: Identifier assigned to the session used to send/receive messages. session_id: SessionID target_info: TargetInfo waiting_for_debugger: bool @classmethod def from_json(cls, json: T_JSON_DICT) -> AttachedToTarget: return cls( session_id=SessionID.from_json(json['sessionId']), target_info=TargetInfo.from_json(json['targetInfo']), waiting_for_debugger=bool(json['waitingForDebugger']) ) @event_class('Target.detachedFromTarget') @dataclass class DetachedFromTarget: ''' **EXPERIMENTAL** Issued when detached from target for any reason (including ``detachFromTarget`` command). Can be issued multiple times per target if multiple sessions have been attached to it. ''' #: Detached session identifier. session_id: SessionID #: Deprecated. target_id: typing.Optional[TargetID] @classmethod def from_json(cls, json: T_JSON_DICT) -> DetachedFromTarget: return cls( session_id=SessionID.from_json(json['sessionId']), target_id=TargetID.from_json(json['targetId']) if 'targetId' in json else None ) @event_class('Target.receivedMessageFromTarget') @dataclass class ReceivedMessageFromTarget: ''' Notifies about a new protocol message received from the session (as reported in ``attachedToTarget`` event). ''' #: Identifier of a session which sends a message. session_id: SessionID message: str #: Deprecated. target_id: typing.Optional[TargetID] @classmethod def from_json(cls, json: T_JSON_DICT) -> ReceivedMessageFromTarget: return cls( session_id=SessionID.from_json(json['sessionId']), message=str(json['message']), target_id=TargetID.from_json(json['targetId']) if 'targetId' in json else None ) @event_class('Target.targetCreated') @dataclass class TargetCreated: ''' Issued when a possible inspection target is created. ''' target_info: TargetInfo @classmethod def from_json(cls, json: T_JSON_DICT) -> TargetCreated: return cls( target_info=TargetInfo.from_json(json['targetInfo']) ) @event_class('Target.targetDestroyed') @dataclass class TargetDestroyed: ''' Issued when a target is destroyed. ''' target_id: TargetID @classmethod def from_json(cls, json: T_JSON_DICT) -> TargetDestroyed: return cls( target_id=TargetID.from_json(json['targetId']) ) @event_class('Target.targetCrashed') @dataclass class TargetCrashed: ''' Issued when a target has crashed. ''' target_id: TargetID #: Termination status type. status: str #: Termination error code. error_code: int @classmethod def from_json(cls, json: T_JSON_DICT) -> TargetCrashed: return cls( target_id=TargetID.from_json(json['targetId']), status=str(json['status']), error_code=int(json['errorCode']) ) @event_class('Target.targetInfoChanged') @dataclass class TargetInfoChanged: ''' Issued when some information about a target has changed. This only happens between ``targetCreated`` and ``targetDestroyed``. ''' target_info: TargetInfo @classmethod def from_json(cls, json: T_JSON_DICT) -> TargetInfoChanged: return cls( target_info=TargetInfo.from_json(json['targetInfo']) )