2022-10-19 07:06:31 +00:00
|
|
|
/**
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
2023-09-15 11:00:20 +00:00
|
|
|
import {EventEmitter, type EventType} from '../common/EventEmitter.js';
|
2023-09-18 18:11:55 +00:00
|
|
|
import {debugError} from '../common/util.js';
|
2023-09-19 16:13:51 +00:00
|
|
|
import {asyncDisposeSymbol, disposeSymbol} from '../util/disposable.js';
|
2023-02-15 23:09:31 +00:00
|
|
|
|
2023-10-11 08:11:22 +00:00
|
|
|
import type {Browser, Permission, WaitForTargetOptions} from './Browser.js';
|
2023-09-26 16:24:24 +00:00
|
|
|
import type {Page} from './Page.js';
|
2023-07-21 07:04:14 +00:00
|
|
|
import type {Target} from './Target.js';
|
2022-10-19 07:06:31 +00:00
|
|
|
|
2023-09-13 13:47:55 +00:00
|
|
|
/**
|
|
|
|
* @public
|
|
|
|
*/
|
|
|
|
export const enum BrowserContextEvent {
|
|
|
|
/**
|
|
|
|
* Emitted when the url of a target inside the browser context changes.
|
|
|
|
* Contains a {@link Target} instance.
|
|
|
|
*/
|
|
|
|
TargetChanged = 'targetchanged',
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Emitted when a target is created within the browser context, for example
|
|
|
|
* when a new page is opened by
|
|
|
|
* {@link https://developer.mozilla.org/en-US/docs/Web/API/Window/open | window.open}
|
|
|
|
* or by {@link BrowserContext.newPage | browserContext.newPage}
|
|
|
|
*
|
|
|
|
* Contains a {@link Target} instance.
|
|
|
|
*/
|
|
|
|
TargetCreated = 'targetcreated',
|
|
|
|
/**
|
|
|
|
* Emitted when a target is destroyed within the browser context, for example
|
|
|
|
* when a page is closed. Contains a {@link Target} instance.
|
|
|
|
*/
|
|
|
|
TargetDestroyed = 'targetdestroyed',
|
|
|
|
}
|
|
|
|
|
|
|
|
export {
|
|
|
|
/**
|
|
|
|
* @deprecated Use {@link BrowserContextEvent}
|
|
|
|
*/
|
|
|
|
BrowserContextEvent as BrowserContextEmittedEvents,
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @public
|
|
|
|
*/
|
|
|
|
export interface BrowserContextEvents extends Record<EventType, unknown> {
|
|
|
|
[BrowserContextEvent.TargetChanged]: Target;
|
|
|
|
[BrowserContextEvent.TargetCreated]: Target;
|
|
|
|
[BrowserContextEvent.TargetDestroyed]: Target;
|
|
|
|
}
|
|
|
|
|
2022-10-19 07:06:31 +00:00
|
|
|
/**
|
2023-09-18 18:11:55 +00:00
|
|
|
* {@link BrowserContext} represents individual sessions within a
|
|
|
|
* {@link Browser | browser}.
|
2022-10-19 07:06:31 +00:00
|
|
|
*
|
2023-09-18 18:11:55 +00:00
|
|
|
* When a {@link Browser | browser} is launched, it has a single
|
|
|
|
* {@link BrowserContext | browser context} by default. Others can be created
|
|
|
|
* using {@link Browser.createIncognitoBrowserContext}.
|
2022-10-19 07:06:31 +00:00
|
|
|
*
|
2023-09-18 18:11:55 +00:00
|
|
|
* {@link BrowserContext} {@link EventEmitter | emits} various events which are
|
|
|
|
* documented in the {@link BrowserContextEvent} enum.
|
2022-10-19 07:06:31 +00:00
|
|
|
*
|
2023-09-18 18:11:55 +00:00
|
|
|
* If a {@link Page | page} opens another {@link Page | page}, e.g. using
|
|
|
|
* `window.open`, the popup will belong to the parent {@link Page.browserContext
|
|
|
|
* | page's browser context}.
|
2022-10-19 07:06:31 +00:00
|
|
|
*
|
2023-09-18 18:11:55 +00:00
|
|
|
* @example Creating an incognito {@link BrowserContext | browser context}:
|
2022-10-19 07:06:31 +00:00
|
|
|
*
|
|
|
|
* ```ts
|
|
|
|
* // Create a new incognito browser context
|
|
|
|
* const context = await browser.createIncognitoBrowserContext();
|
|
|
|
* // Create a new page inside context.
|
|
|
|
* const page = await context.newPage();
|
|
|
|
* // ... do stuff with page ...
|
|
|
|
* await page.goto('https://example.com');
|
|
|
|
* // Dispose context once it's no longer needed.
|
|
|
|
* await context.close();
|
|
|
|
* ```
|
|
|
|
*
|
|
|
|
* @public
|
|
|
|
*/
|
|
|
|
|
2023-09-18 18:11:55 +00:00
|
|
|
export abstract class BrowserContext extends EventEmitter<BrowserContextEvents> {
|
2022-10-19 07:06:31 +00:00
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
constructor() {
|
|
|
|
super();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2023-09-18 18:11:55 +00:00
|
|
|
* Gets all active {@link Target | targets} inside this
|
|
|
|
* {@link BrowserContext | browser context}.
|
2022-10-19 07:06:31 +00:00
|
|
|
*/
|
2023-11-09 12:57:33 +00:00
|
|
|
abstract targets(): Target[];
|
2022-10-19 07:06:31 +00:00
|
|
|
|
|
|
|
/**
|
2023-09-18 18:11:55 +00:00
|
|
|
* Waits until a {@link Target | target} matching the given `predicate`
|
|
|
|
* appears and returns it.
|
|
|
|
*
|
|
|
|
* This will look all open {@link BrowserContext | browser contexts}.
|
2022-10-19 07:06:31 +00:00
|
|
|
*
|
2023-09-18 18:11:55 +00:00
|
|
|
* @example Finding a target for a page opened via `window.open`:
|
2022-10-19 07:06:31 +00:00
|
|
|
*
|
|
|
|
* ```ts
|
|
|
|
* await page.evaluate(() => window.open('https://www.example.com/'));
|
|
|
|
* const newWindowTarget = await browserContext.waitForTarget(
|
|
|
|
* target => target.url() === 'https://www.example.com/'
|
|
|
|
* );
|
|
|
|
* ```
|
2023-09-18 18:11:55 +00:00
|
|
|
*/
|
|
|
|
abstract waitForTarget(
|
2022-10-19 07:06:31 +00:00
|
|
|
predicate: (x: Target) => boolean | Promise<boolean>,
|
2023-10-11 08:11:22 +00:00
|
|
|
options?: WaitForTargetOptions
|
2022-10-19 07:06:31 +00:00
|
|
|
): Promise<Target>;
|
|
|
|
|
|
|
|
/**
|
2023-09-18 18:11:55 +00:00
|
|
|
* Gets a list of all open {@link Page | pages} inside this
|
|
|
|
* {@link BrowserContext | browser context}.
|
2022-10-19 07:06:31 +00:00
|
|
|
*
|
2023-09-18 18:11:55 +00:00
|
|
|
* @remarks Non-visible {@link Page | pages}, such as `"background_page"`,
|
|
|
|
* will not be listed here. You can find them using {@link Target.page}.
|
2022-10-19 07:06:31 +00:00
|
|
|
*/
|
2023-09-18 18:11:55 +00:00
|
|
|
abstract pages(): Promise<Page[]>;
|
2022-10-19 07:06:31 +00:00
|
|
|
|
|
|
|
/**
|
2023-09-18 18:11:55 +00:00
|
|
|
* Whether this {@link BrowserContext | browser context} is incognito.
|
2022-10-19 07:06:31 +00:00
|
|
|
*
|
2023-09-18 18:11:55 +00:00
|
|
|
* The {@link Browser.defaultBrowserContext | default browser context} is the
|
|
|
|
* only non-incognito browser context.
|
2022-10-19 07:06:31 +00:00
|
|
|
*/
|
2023-09-18 18:11:55 +00:00
|
|
|
abstract isIncognito(): boolean;
|
2022-10-19 07:06:31 +00:00
|
|
|
|
|
|
|
/**
|
2023-09-18 18:11:55 +00:00
|
|
|
* Grants this {@link BrowserContext | browser context} the given
|
|
|
|
* `permissions` within the given `origin`.
|
|
|
|
*
|
|
|
|
* @example Overriding permissions in the
|
|
|
|
* {@link Browser.defaultBrowserContext | default browser context}:
|
2022-10-19 07:06:31 +00:00
|
|
|
*
|
|
|
|
* ```ts
|
|
|
|
* const context = browser.defaultBrowserContext();
|
|
|
|
* await context.overridePermissions('https://html5demos.com', [
|
|
|
|
* 'geolocation',
|
|
|
|
* ]);
|
|
|
|
* ```
|
|
|
|
*
|
2023-09-18 18:11:55 +00:00
|
|
|
* @param origin - The origin to grant permissions to, e.g.
|
|
|
|
* "https://example.com".
|
|
|
|
* @param permissions - An array of permissions to grant. All permissions that
|
|
|
|
* are not listed here will be automatically denied.
|
2023-11-16 07:22:32 +00:00
|
|
|
*
|
|
|
|
* @privateRemarks BiDi
|
2023-11-16 20:53:04 +00:00
|
|
|
* {@link PROTOCOL_GET_STARTED_LINK_TEMPLATE | CDP}: Supported
|
|
|
|
*
|
|
|
|
* {@link PROTOCOL_GET_STARTED_LINK_TEMPLATE | BiDi}: Unsupported
|
2022-10-19 07:06:31 +00:00
|
|
|
*/
|
2023-11-09 12:57:33 +00:00
|
|
|
abstract overridePermissions(
|
|
|
|
origin: string,
|
|
|
|
permissions: Permission[]
|
|
|
|
): Promise<void>;
|
2022-10-19 07:06:31 +00:00
|
|
|
|
|
|
|
/**
|
2023-09-18 18:11:55 +00:00
|
|
|
* Clears all permission overrides for this
|
|
|
|
* {@link BrowserContext | browser context}.
|
2022-10-19 07:06:31 +00:00
|
|
|
*
|
2023-09-18 18:11:55 +00:00
|
|
|
* @example Clearing overridden permissions in the
|
|
|
|
* {@link Browser.defaultBrowserContext | default browser context}:
|
2022-10-19 07:06:31 +00:00
|
|
|
*
|
|
|
|
* ```ts
|
|
|
|
* const context = browser.defaultBrowserContext();
|
|
|
|
* context.overridePermissions('https://example.com', ['clipboard-read']);
|
|
|
|
* // do stuff ..
|
|
|
|
* context.clearPermissionOverrides();
|
|
|
|
* ```
|
2023-11-16 07:22:32 +00:00
|
|
|
*
|
|
|
|
* @privateRemarks BiDi
|
2023-11-16 20:53:04 +00:00
|
|
|
* {@link PROTOCOL_GET_STARTED_LINK_TEMPLATE | CDP}: Supported
|
|
|
|
*
|
|
|
|
* {@link PROTOCOL_GET_STARTED_LINK_TEMPLATE | BiDi}: Unsupported
|
2022-10-19 07:06:31 +00:00
|
|
|
*/
|
2023-11-09 12:57:33 +00:00
|
|
|
abstract clearPermissionOverrides(): Promise<void>;
|
2022-10-19 07:06:31 +00:00
|
|
|
|
|
|
|
/**
|
2023-09-18 18:11:55 +00:00
|
|
|
* Creates a new {@link Page | page} in this
|
|
|
|
* {@link BrowserContext | browser context}.
|
2022-10-19 07:06:31 +00:00
|
|
|
*/
|
2023-09-18 18:11:55 +00:00
|
|
|
abstract newPage(): Promise<Page>;
|
2022-10-19 07:06:31 +00:00
|
|
|
|
|
|
|
/**
|
2023-09-18 18:11:55 +00:00
|
|
|
* Gets the {@link Browser | browser} associated with this
|
|
|
|
* {@link BrowserContext | browser context}.
|
2022-10-19 07:06:31 +00:00
|
|
|
*/
|
2023-09-18 18:11:55 +00:00
|
|
|
abstract browser(): Browser;
|
2022-10-19 07:06:31 +00:00
|
|
|
|
|
|
|
/**
|
2023-09-18 18:11:55 +00:00
|
|
|
* Closes this {@link BrowserContext | browser context} and all associated
|
|
|
|
* {@link Page | pages}.
|
2022-10-19 07:06:31 +00:00
|
|
|
*
|
2023-09-18 18:11:55 +00:00
|
|
|
* @remarks The
|
|
|
|
* {@link Browser.defaultBrowserContext | default browser context} cannot be
|
|
|
|
* closed.
|
2022-10-19 07:06:31 +00:00
|
|
|
*/
|
2023-09-18 18:11:55 +00:00
|
|
|
abstract close(): Promise<void>;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether this {@link BrowserContext | browser context} is closed.
|
|
|
|
*/
|
|
|
|
get closed(): boolean {
|
|
|
|
return !this.browser().browserContexts().includes(this);
|
2022-10-19 07:06:31 +00:00
|
|
|
}
|
2022-10-19 08:30:57 +00:00
|
|
|
|
2023-09-18 18:11:55 +00:00
|
|
|
/**
|
|
|
|
* Identifier for this {@link BrowserContext | browser context}.
|
|
|
|
*/
|
2022-10-19 08:30:57 +00:00
|
|
|
get id(): string | undefined {
|
|
|
|
return undefined;
|
|
|
|
}
|
2023-09-18 18:11:55 +00:00
|
|
|
|
|
|
|
/** @internal */
|
2023-09-19 16:13:51 +00:00
|
|
|
[disposeSymbol](): void {
|
2023-09-18 18:11:55 +00:00
|
|
|
return void this.close().catch(debugError);
|
|
|
|
}
|
|
|
|
|
|
|
|
/** @internal */
|
2023-09-19 16:13:51 +00:00
|
|
|
[asyncDisposeSymbol](): Promise<void> {
|
2023-09-18 18:11:55 +00:00
|
|
|
return this.close();
|
|
|
|
}
|
2022-10-19 07:06:31 +00:00
|
|
|
}
|