Files
plan-tools/node_modules/chromium-bidi/lib/cjs/bidiMapper/modules/browser/ContextConfig.js
Taylor Eernisse e7882b917b Add Brave CDP automation, replace Oracle browser mode
Connects to user's running Brave via Chrome DevTools Protocol
to automate ChatGPT interaction. Uses puppeteer-core to open a
tab, send the prompt, wait for response, and extract the result.

No cookies, no separate profiles, no copy/paste. Just connects
to the browser where the user is already logged in.

One-time setup: relaunch Brave with --remote-debugging-port=9222

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-07 16:16:41 -05:00

74 lines
2.5 KiB
JavaScript

"use strict";
/**
* Copyright 2025 Google LLC.
* Copyright (c) Microsoft Corporation.
*
* 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.
*/
Object.defineProperty(exports, "__esModule", { value: true });
exports.ContextConfig = void 0;
/**
* Represents a context configurations. It can be global, per User Context, or per
* Browsing Context. The undefined value means the config will be taken from the upstream
* config. `null` values means the value should be default regardless of the upstream.
*/
class ContextConfig {
// keep-sorted start block=yes
acceptInsecureCerts;
clientHints;
devicePixelRatio;
disableNetworkDurableMessages;
downloadBehavior;
emulatedNetworkConditions;
// Extra headers are kept in CDP format.
extraHeaders;
geolocation;
locale;
maxTouchPoints;
prerenderingDisabled;
screenArea;
screenOrientation;
scriptingEnabled;
// Timezone is kept in CDP format with GMT prefix for offset values.
timezone;
userAgent;
userPromptHandler;
viewport;
// keep-sorted end
/**
* Merges multiple `ContextConfig` objects. The configs are merged in the order they are
* provided. For each property, the value from the last config that defines it will be
* used. The final result will not contain any `undefined` or `null` properties.
* `undefined` values are ignored. `null` values remove the already set value.
*/
static merge(...configs) {
const result = new ContextConfig();
for (const config of configs) {
if (!config) {
continue;
}
for (const key in config) {
const value = config[key];
if (value === null) {
delete result[key];
}
else if (value !== undefined) {
result[key] = value;
}
}
}
return result;
}
}
exports.ContextConfig = ContextConfig;
//# sourceMappingURL=ContextConfig.js.map