2022-07-21 18:50:46 +00:00
|
|
|
/**
|
|
|
|
* Copyright 2022 Google Inc. All rights reserved.
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2023-01-17 11:34:57 +00:00
|
|
|
import {Protocol} from 'devtools-protocol';
|
2023-02-15 23:09:31 +00:00
|
|
|
|
2022-07-21 18:50:46 +00:00
|
|
|
import {CDPSession} from './Connection.js';
|
|
|
|
import {EventEmitter} from './EventEmitter.js';
|
2023-07-21 07:04:14 +00:00
|
|
|
import {CDPTarget} from './Target.js';
|
2022-07-21 18:50:46 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
export type TargetFactory = (
|
|
|
|
targetInfo: Protocol.Target.TargetInfo,
|
|
|
|
session?: CDPSession
|
2023-07-21 07:04:14 +00:00
|
|
|
) => CDPTarget;
|
2022-07-21 18:50:46 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
export type TargetInterceptor = (
|
2023-07-21 07:04:14 +00:00
|
|
|
createdTarget: CDPTarget,
|
|
|
|
parentTarget: CDPTarget | null
|
2022-12-17 17:47:21 +00:00
|
|
|
) => void;
|
2022-07-21 18:50:46 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* TargetManager encapsulates all interactions with CDP targets and is
|
|
|
|
* responsible for coordinating the configuration of targets with the rest of
|
|
|
|
* Puppeteer. Code outside of this class should not subscribe `Target.*` events
|
|
|
|
* and only use the TargetManager events.
|
|
|
|
*
|
|
|
|
* There are two implementations: one for Chrome that uses CDP's auto-attach
|
|
|
|
* mechanism and one for Firefox because Firefox does not support auto-attach.
|
|
|
|
*
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
export interface TargetManager extends EventEmitter {
|
2023-07-21 07:04:14 +00:00
|
|
|
getAvailableTargets(): Map<string, CDPTarget>;
|
2022-07-21 18:50:46 +00:00
|
|
|
initialize(): Promise<void>;
|
|
|
|
dispose(): void;
|
|
|
|
addTargetInterceptor(
|
|
|
|
session: CDPSession,
|
|
|
|
interceptor: TargetInterceptor
|
|
|
|
): void;
|
|
|
|
removeTargetInterceptor(
|
|
|
|
session: CDPSession,
|
|
|
|
interceptor: TargetInterceptor
|
|
|
|
): void;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
export const enum TargetManagerEmittedEvents {
|
|
|
|
TargetDiscovered = 'targetDiscovered',
|
|
|
|
TargetAvailable = 'targetAvailable',
|
|
|
|
TargetGone = 'targetGone',
|
2023-05-16 11:34:10 +00:00
|
|
|
/**
|
|
|
|
* Emitted after a target has been initialized and whenever its URL changes.
|
|
|
|
*/
|
2022-07-21 18:50:46 +00:00
|
|
|
TargetChanged = 'targetChanged',
|
|
|
|
}
|