puppeteer/packages/puppeteer-core/src/common/Puppeteer.ts

138 lines
3.3 KiB
TypeScript
Raw Normal View History

/**
* Copyright 2017 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.
*/
import {Browser} from '../api/Browser.js';
import {
BrowserConnectOptions,
_connectToCDPBrowser,
} from './BrowserConnector.js';
2022-06-27 07:24:23 +00:00
import {ConnectionTransport} from './ConnectionTransport.js';
import {
2022-06-27 07:24:23 +00:00
clearCustomQueryHandlers,
CustomQueryHandler,
2022-06-27 07:24:23 +00:00
customQueryHandlerNames,
registerCustomQueryHandler,
unregisterCustomQueryHandler,
} from './QueryHandler.js';
/**
2022-02-07 13:03:54 +00:00
* Settings that are common to the Puppeteer class, regardless of environment.
2022-06-13 09:16:25 +00:00
*
* @internal
*/
export interface CommonPuppeteerSettings {
isPuppeteerCore: boolean;
}
/**
* @public
*/
export interface ConnectOptions extends BrowserConnectOptions {
browserWSEndpoint?: string;
browserURL?: string;
transport?: ConnectionTransport;
}
/**
* The main Puppeteer class.
*
* IMPORTANT: if you are using Puppeteer in a Node environment, you will get an
* instance of {@link PuppeteerNode} when you import or require `puppeteer`.
* That class extends `Puppeteer`, so has all the methods documented below as
* well as all that are defined on {@link PuppeteerNode}.
* @public
*/
export class Puppeteer {
/**
* @internal
*/
protected _isPuppeteerCore: boolean;
/**
* @internal
*/
protected _changedProduct = false;
/**
* @internal
*/
constructor(settings: CommonPuppeteerSettings) {
this._isPuppeteerCore = settings.isPuppeteerCore;
2022-06-09 17:00:50 +00:00
this.connect = this.connect.bind(this);
}
/**
* This method attaches Puppeteer to an existing browser instance.
*
* @remarks
*
* @param options - Set of configurable options to set on the browser.
* @returns Promise which resolves to browser instance.
*/
connect(options: ConnectOptions): Promise<Browser> {
return _connectToCDPBrowser(options);
}
/**
2022-06-27 07:24:23 +00:00
* @deprecated Import directly puppeteer.
* @example
*
2022-06-27 07:24:23 +00:00
* ```ts
* import {registerCustomQueryHandler} from 'puppeteer';
* ```
*/
2020-10-23 14:28:38 +00:00
registerCustomQueryHandler(
2020-05-07 10:54:55 +00:00
name: string,
queryHandler: CustomQueryHandler
2020-05-07 10:54:55 +00:00
): void {
2022-06-27 07:24:23 +00:00
return registerCustomQueryHandler(name, queryHandler);
}
/**
2022-06-27 07:24:23 +00:00
* @deprecated Import directly puppeteer.
* @example
*
2022-06-27 07:24:23 +00:00
* ```ts
* import {unregisterCustomQueryHandler} from 'puppeteer';
2022-06-27 07:24:23 +00:00
* ```
*/
2020-10-23 14:28:38 +00:00
unregisterCustomQueryHandler(name: string): void {
2022-06-27 07:24:23 +00:00
return unregisterCustomQueryHandler(name);
}
/**
2022-06-27 07:24:23 +00:00
* @deprecated Import directly puppeteer.
* @example
*
2022-06-27 07:24:23 +00:00
* ```ts
* import {customQueryHandlerNames} from 'puppeteer';
2022-06-27 07:24:23 +00:00
* ```
*/
2020-10-23 14:28:38 +00:00
customQueryHandlerNames(): string[] {
2022-06-27 07:24:23 +00:00
return customQueryHandlerNames();
}
/**
2022-06-27 07:24:23 +00:00
* @deprecated Import directly puppeteer.
* @example
*
2022-06-27 07:24:23 +00:00
* ```ts
* import {clearCustomQueryHandlers} from 'puppeteer';
2022-06-27 07:24:23 +00:00
* ```
*/
2020-10-23 14:28:38 +00:00
clearCustomQueryHandlers(): void {
2022-06-27 07:24:23 +00:00
return clearCustomQueryHandlers();
}
}