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-09-26 16:24:24 +00:00
|
|
|
import type {Protocol} from 'devtools-protocol';
|
2023-02-15 23:09:31 +00:00
|
|
|
|
2023-09-26 16:24:24 +00:00
|
|
|
import type {CDPSession} from '../api/CDPSession.js';
|
|
|
|
import type {EventEmitter, EventType} from '../common/EventEmitter.js';
|
2023-09-13 13:47:55 +00:00
|
|
|
|
2023-09-26 16:24:24 +00:00
|
|
|
import type {CdpTarget} from './Target.js';
|
2022-07-21 18:50:46 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
export type TargetFactory = (
|
|
|
|
targetInfo: Protocol.Target.TargetInfo,
|
2023-08-28 06:20:57 +00:00
|
|
|
session?: CDPSession,
|
|
|
|
parentSession?: CDPSession
|
2023-09-13 19:57:26 +00:00
|
|
|
) => CdpTarget;
|
2022-07-21 18:50:46 +00:00
|
|
|
|
2023-09-13 13:47:55 +00:00
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
export const enum TargetManagerEvent {
|
|
|
|
TargetDiscovered = 'targetDiscovered',
|
|
|
|
TargetAvailable = 'targetAvailable',
|
|
|
|
TargetGone = 'targetGone',
|
|
|
|
/**
|
|
|
|
* Emitted after a target has been initialized and whenever its URL changes.
|
|
|
|
*/
|
|
|
|
TargetChanged = 'targetChanged',
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
export interface TargetManagerEvents extends Record<EventType, unknown> {
|
2023-09-13 19:57:26 +00:00
|
|
|
[TargetManagerEvent.TargetAvailable]: CdpTarget;
|
2023-09-13 13:47:55 +00:00
|
|
|
[TargetManagerEvent.TargetDiscovered]: Protocol.Target.TargetInfo;
|
2023-09-13 19:57:26 +00:00
|
|
|
[TargetManagerEvent.TargetGone]: CdpTarget;
|
2023-09-13 13:47:55 +00:00
|
|
|
[TargetManagerEvent.TargetChanged]: {
|
2023-09-13 19:57:26 +00:00
|
|
|
target: CdpTarget;
|
2023-09-13 13:47:55 +00:00
|
|
|
wasInitialized: true;
|
|
|
|
previousURL: string;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
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
|
|
|
|
*/
|
2023-09-13 13:47:55 +00:00
|
|
|
export interface TargetManager extends EventEmitter<TargetManagerEvents> {
|
2023-10-12 10:15:06 +00:00
|
|
|
getAvailableTargets(): ReadonlyMap<string, CdpTarget>;
|
2022-07-21 18:50:46 +00:00
|
|
|
initialize(): Promise<void>;
|
|
|
|
dispose(): void;
|
|
|
|
}
|