@andrewting19/oracle 0.9.2 → 0.9.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/remote/server.js +53 -0
- package/package.json +1 -1
|
@@ -12,6 +12,7 @@ import { CHATGPT_URL } from "../browser/constants.js";
|
|
|
12
12
|
import { getCliVersion } from "../version.js";
|
|
13
13
|
import { cleanupStaleProfileState, readDevToolsPort, verifyDevToolsReachable, writeChromePid, writeDevToolsActivePort, } from "../browser/profileState.js";
|
|
14
14
|
import { normalizeChatgptUrl } from "../browser/utils.js";
|
|
15
|
+
import { launchChrome, connectToChrome } from "../browser/chromeLifecycle.js";
|
|
15
16
|
async function findAvailablePort() {
|
|
16
17
|
return await new Promise((resolve, reject) => {
|
|
17
18
|
const srv = net.createServer();
|
|
@@ -151,6 +152,10 @@ export async function createRemoteServer(options = {}, deps = {}) {
|
|
|
151
152
|
else {
|
|
152
153
|
payload.browserConfig = {};
|
|
153
154
|
}
|
|
155
|
+
// Route through shared Chrome instance (each run gets its own isolated tab).
|
|
156
|
+
if (options.sharedChrome) {
|
|
157
|
+
payload.browserConfig.remoteChrome = options.sharedChrome;
|
|
158
|
+
}
|
|
154
159
|
// Enforce manual-login profile when cookie sync is unavailable (e.g., Windows/WSL).
|
|
155
160
|
if (options.manualLoginDefault) {
|
|
156
161
|
payload.browserConfig.manualLogin = true;
|
|
@@ -264,10 +269,58 @@ export async function serveRemote(options = {}) {
|
|
|
264
269
|
else {
|
|
265
270
|
console.log(`Detected ${cookies.length} ChatGPT cookies on this host; runs will reuse this session.`);
|
|
266
271
|
}
|
|
272
|
+
// Launch a shared Chrome instance for concurrent tab-based runs.
|
|
273
|
+
let sharedChrome;
|
|
274
|
+
if (!preferManualLogin) {
|
|
275
|
+
try {
|
|
276
|
+
const userDataDir = await mkdtemp(path.join(os.tmpdir(), "oracle-serve-chrome-"));
|
|
277
|
+
const chrome = await launchChrome({ headless: false, hideWindow: true }, userDataDir, console.log);
|
|
278
|
+
sharedChrome = { host: "127.0.0.1", port: chrome.port };
|
|
279
|
+
console.log(`Shared Chrome launched (pid ${chrome.pid}, port ${chrome.port}). Concurrent runs will use isolated tabs.`);
|
|
280
|
+
// Sync ChatGPT cookies into the shared Chrome so all tabs are authenticated.
|
|
281
|
+
// Uses syncCookies which reads from the host's Chrome profile and injects via CDP.
|
|
282
|
+
try {
|
|
283
|
+
const { syncCookies } = await import("../browser/cookies.js");
|
|
284
|
+
const client = await connectToChrome(chrome.port, console.log);
|
|
285
|
+
const { Network } = client;
|
|
286
|
+
await Network.enable({});
|
|
287
|
+
const syncLogger = ((msg) => { if (msg)
|
|
288
|
+
console.log(`[shared-chrome] ${msg}`); });
|
|
289
|
+
syncLogger.verbose = false;
|
|
290
|
+
const count = await syncCookies(Network, CHATGPT_URL, "Default", syncLogger, {
|
|
291
|
+
allowErrors: true,
|
|
292
|
+
});
|
|
293
|
+
console.log(`Synced ${count} ChatGPT cookies into shared Chrome.`);
|
|
294
|
+
await client.close();
|
|
295
|
+
}
|
|
296
|
+
catch (cookieErr) {
|
|
297
|
+
const msg = cookieErr instanceof Error ? cookieErr.message : String(cookieErr);
|
|
298
|
+
console.log(`Warning: failed to sync cookies into shared Chrome (${msg}). Runs may need to authenticate.`);
|
|
299
|
+
}
|
|
300
|
+
// Clean up Chrome on process exit
|
|
301
|
+
const killChrome = async () => {
|
|
302
|
+
try {
|
|
303
|
+
await chrome.kill();
|
|
304
|
+
}
|
|
305
|
+
catch { }
|
|
306
|
+
try {
|
|
307
|
+
await rm(userDataDir, { recursive: true, force: true });
|
|
308
|
+
}
|
|
309
|
+
catch { }
|
|
310
|
+
};
|
|
311
|
+
process.on("SIGINT", () => void killChrome());
|
|
312
|
+
process.on("SIGTERM", () => void killChrome());
|
|
313
|
+
}
|
|
314
|
+
catch (error) {
|
|
315
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
316
|
+
console.log(`Warning: failed to launch shared Chrome (${message}). Runs will each launch their own Chrome.`);
|
|
317
|
+
}
|
|
318
|
+
}
|
|
267
319
|
const server = await createRemoteServer({
|
|
268
320
|
...options,
|
|
269
321
|
manualLoginDefault: preferManualLogin,
|
|
270
322
|
manualLoginProfileDir: manualProfileDir,
|
|
323
|
+
sharedChrome,
|
|
271
324
|
});
|
|
272
325
|
await new Promise((resolve) => {
|
|
273
326
|
const shutdown = () => {
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@andrewting19/oracle",
|
|
3
|
-
"version": "0.9.
|
|
3
|
+
"version": "0.9.4",
|
|
4
4
|
"description": "CLI wrapper around OpenAI Responses API with GPT-5.4 Pro, GPT-5.4, GPT-5.2, GPT-5.1, and GPT-5.1 Codex high reasoning modes.",
|
|
5
5
|
"keywords": [],
|
|
6
6
|
"homepage": "https://github.com/steipete/oracle#readme",
|