UNPKG

puppeteer-core

Version:

A high-level API to control headless Chrome over the DevTools Protocol

138 lines 4.76 kB
"use strict"; /** * @license * Copyright 2017 Google Inc. * SPDX-License-Identifier: Apache-2.0 */ Object.defineProperty(exports, "__esModule", { value: true }); exports.BrowserContext = void 0; const rxjs_js_1 = require("../../third_party/rxjs/rxjs.js"); const EventEmitter_js_1 = require("../common/EventEmitter.js"); const util_js_1 = require("../common/util.js"); const disposable_js_1 = require("../util/disposable.js"); const Mutex_js_1 = require("../util/Mutex.js"); /** * {@link BrowserContext} represents individual user contexts within a * {@link Browser | browser}. * * When a {@link Browser | browser} is launched, it has at least one default * {@link BrowserContext | browser context}. Others can be created * using {@link Browser.createBrowserContext}. Each context has isolated storage * (cookies/localStorage/etc.) * * {@link BrowserContext} {@link EventEmitter | emits} various events which are * documented in the {@link BrowserContextEvent} enum. * * 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}. * * @example Creating a new {@link BrowserContext | browser context}: * * ```ts * // Create a new browser context * const context = await browser.createBrowserContext(); * // 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(); * ``` * * @remarks * * In Chrome all non-default contexts are incognito, * and {@link Browser.defaultBrowserContext | default browser context} * might be incognito if you provide the `--incognito` argument when launching * the browser. * * @public */ class BrowserContext extends EventEmitter_js_1.EventEmitter { /** * @internal */ constructor() { super(); } /** * If defined, indicates an ongoing screenshot opereation. */ #pageScreenshotMutex; #screenshotOperationsCount = 0; /** * @internal */ startScreenshot() { const mutex = this.#pageScreenshotMutex || new Mutex_js_1.Mutex(); this.#pageScreenshotMutex = mutex; this.#screenshotOperationsCount++; return mutex.acquire(() => { this.#screenshotOperationsCount--; if (this.#screenshotOperationsCount === 0) { // Remove the mutex to indicate no ongoing screenshot operation. this.#pageScreenshotMutex = undefined; } }); } /** * @internal */ waitForScreenshotOperations() { return this.#pageScreenshotMutex?.acquire(); } /** * Waits until a {@link Target | target} matching the given `predicate` * appears and returns it. * * This will look all open {@link BrowserContext | browser contexts}. * * @example Finding a target for a page opened via `window.open`: * * ```ts * await page.evaluate(() => window.open('https://www.example.com/')); * const newWindowTarget = await browserContext.waitForTarget( * target => target.url() === 'https://www.example.com/', * ); * ``` */ async waitForTarget(predicate, options = {}) { const { timeout: ms = 30000 } = options; return await (0, rxjs_js_1.firstValueFrom)((0, rxjs_js_1.merge)((0, util_js_1.fromEmitterEvent)(this, "targetcreated" /* BrowserContextEvent.TargetCreated */), (0, util_js_1.fromEmitterEvent)(this, "targetchanged" /* BrowserContextEvent.TargetChanged */), (0, rxjs_js_1.from)(this.targets())).pipe((0, util_js_1.filterAsync)(predicate), (0, rxjs_js_1.raceWith)((0, util_js_1.timeout)(ms)))); } /** * Removes cookie in the browser context * @param cookies - {@link Cookie | cookie} to remove */ async deleteCookie(...cookies) { return await this.setCookie(...cookies.map(cookie => { return { ...cookie, expires: 1, }; })); } /** * Whether this {@link BrowserContext | browser context} is closed. */ get closed() { return !this.browser().browserContexts().includes(this); } /** * Identifier for this {@link BrowserContext | browser context}. */ get id() { return undefined; } /** @internal */ [disposable_js_1.disposeSymbol]() { return void this.close().catch(util_js_1.debugError); } /** @internal */ [disposable_js_1.asyncDisposeSymbol]() { return this.close(); } } exports.BrowserContext = BrowserContext; //# sourceMappingURL=BrowserContext.js.map