@elizaos/cli 1.6.4-alpha.20 → 1.6.4-alpha.22

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/index.js CHANGED
@@ -4749,7 +4749,7 @@ __export(exports_version, {
4749
4749
  BUILD_TIME: () => BUILD_TIME,
4750
4750
  BUILD_ENV: () => BUILD_ENV
4751
4751
  });
4752
- var CLI_VERSION = "1.6.4-alpha.20", CLI_NAME = "@elizaos/cli", CLI_DESCRIPTION = "elizaOS CLI - Manage your AI agents and plugins", BUILD_TIME = "2025-11-05T16:03:42.775Z", BUILD_ENV = "production", version_default;
4752
+ var CLI_VERSION = "1.6.4-alpha.22", CLI_NAME = "@elizaos/cli", CLI_DESCRIPTION = "elizaOS CLI - Manage your AI agents and plugins", BUILD_TIME = "2025-11-05T18:02:43.572Z", BUILD_ENV = "production", version_default;
4753
4753
  var init_version = __esm(() => {
4754
4754
  version_default = {
4755
4755
  version: CLI_VERSION,
@@ -30437,7 +30437,7 @@ function mergeUint8Arrays(items) {
30437
30437
  }
30438
30438
 
30439
30439
  // ../../node_modules/puppeteer-core/lib/esm/puppeteer/util/version.js
30440
- var packageVersion = "24.26.1";
30440
+ var packageVersion = "24.29.0";
30441
30441
 
30442
30442
  // ../../node_modules/puppeteer-core/lib/esm/puppeteer/common/Debug.js
30443
30443
  async function importDebug() {
@@ -30866,9 +30866,9 @@ var init_Browser = __esm(() => {
30866
30866
  const { timeout: ms = 30000, signal } = options;
30867
30867
  return await firstValueFrom(merge2(fromEmitterEvent(this, "targetcreated"), fromEmitterEvent(this, "targetchanged"), from(this.targets())).pipe(filterAsync(predicate), raceWith(fromAbortSignal(signal), timeout(ms))));
30868
30868
  }
30869
- async pages() {
30869
+ async pages(includeAll = false) {
30870
30870
  const contextPages = await Promise.all(this.browserContexts().map((context2) => {
30871
- return context2.pages();
30871
+ return context2.pages(includeAll);
30872
30872
  }));
30873
30873
  return contextPages.reduce((acc, x2) => {
30874
30874
  return acc.concat(x2);
@@ -35825,8 +35825,12 @@ class Accessibility {
35825
35825
  if (!frame) {
35826
35826
  return;
35827
35827
  }
35828
- const iframeSnapshot = await frame.accessibility.snapshot(options);
35829
- root2.iframeSnapshot = iframeSnapshot ?? undefined;
35828
+ try {
35829
+ const iframeSnapshot = await frame.accessibility.snapshot(options);
35830
+ root2.iframeSnapshot = iframeSnapshot ?? undefined;
35831
+ } catch (error46) {
35832
+ debugError(error46);
35833
+ }
35830
35834
  } catch (e_1) {
35831
35835
  env_1.error = e_1;
35832
35836
  env_1.hasError = true;
@@ -36086,7 +36090,8 @@ class AXNode {
36086
36090
  } finally {
36087
36091
  __disposeResources9(env_2);
36088
36092
  }
36089
- }
36093
+ },
36094
+ backendNodeId: this.payload.backendDOMNodeId
36090
36095
  };
36091
36096
  const userStringProperties = [
36092
36097
  "name",
@@ -36220,6 +36225,7 @@ var __addDisposableResource9 = function(env3, value, async2) {
36220
36225
  return value;
36221
36226
  }, __disposeResources9;
36222
36227
  var init_Accessibility = __esm(() => {
36228
+ init_util2();
36223
36229
  __disposeResources9 = function(SuppressedError3) {
36224
36230
  return function(env3) {
36225
36231
  function fail(e2) {
@@ -36319,7 +36325,10 @@ var init_FileChooser = () => {};
36319
36325
  // ../../node_modules/puppeteer-core/lib/esm/puppeteer/common/CallbackRegistry.js
36320
36326
  class CallbackRegistry {
36321
36327
  #callbacks = new Map;
36322
- #idGenerator = idGenerator;
36328
+ #idGenerator;
36329
+ constructor(idGenerator) {
36330
+ this.#idGenerator = idGenerator;
36331
+ }
36323
36332
  create(label, timeout2, request) {
36324
36333
  const callback = new Callback(this.#idGenerator(), label, timeout2);
36325
36334
  this.#callbacks.set(callback.id, callback);
@@ -36421,12 +36430,10 @@ class Callback {
36421
36430
  return this.#label;
36422
36431
  }
36423
36432
  }
36424
- var idGenerator;
36425
36433
  var init_CallbackRegistry = __esm(() => {
36426
36434
  init_Deferred();
36427
36435
  init_Errors();
36428
36436
  init_util2();
36429
- idGenerator = createIncrementalIdGenerator();
36430
36437
  });
36431
36438
 
36432
36439
  // ../../node_modules/puppeteer-core/lib/esm/puppeteer/cdp/Coverage.js
@@ -48124,13 +48131,14 @@ var init_Connection = __esm(() => {
48124
48131
  #delay;
48125
48132
  #timeout = 0;
48126
48133
  #closed = false;
48127
- #callbacks = new CallbackRegistry;
48134
+ #callbacks;
48128
48135
  #emitters = [];
48129
- constructor(url2, transport, delay = 0, timeout2) {
48136
+ constructor(url2, transport, idGenerator, delay = 0, timeout2) {
48130
48137
  super();
48131
48138
  this.#url = url2;
48132
48139
  this.#delay = delay;
48133
48140
  this.#timeout = timeout2 ?? 180000;
48141
+ this.#callbacks = new CallbackRegistry(idGenerator);
48134
48142
  this.#transport = transport;
48135
48143
  this.#transport.onmessage = this.onMessage.bind(this);
48136
48144
  this.#transport.onclose = this.unbind.bind(this);
@@ -48248,7 +48256,7 @@ async function connectBidiOverCdp(cdp) {
48248
48256
  transportBiDi.on("bidiResponse", (message) => {
48249
48257
  pptrTransport.onmessage(JSON.stringify(message));
48250
48258
  });
48251
- const pptrBiDiConnection = new BidiConnection(cdp.url(), pptrTransport, cdp.delay, cdp.timeout);
48259
+ const pptrBiDiConnection = new BidiConnection(cdp.url(), pptrTransport, cdp._idGenerator, cdp.delay, cdp.timeout);
48252
48260
  const bidiServer = await BidiMapper.BidiServer.createAndStart(transportBiDi, cdpConnectionAdapter, cdpConnectionAdapter.browserClient(), "", undefined, bidiServerLogger);
48253
48261
  return pptrBiDiConnection;
48254
48262
  }
@@ -49305,6 +49313,7 @@ var init_BrowsingContext = __esm(() => {
49305
49313
  let _removePreloadScript_decorators;
49306
49314
  let _setGeolocationOverride_decorators;
49307
49315
  let _setTimezoneOverride_decorators;
49316
+ let _setScreenOrientationOverride_decorators;
49308
49317
  let _getCookies_decorators;
49309
49318
  let _setCookie_decorators;
49310
49319
  let _setFiles_decorators;
@@ -49340,6 +49349,7 @@ var init_BrowsingContext = __esm(() => {
49340
49349
  __esDecorate12(this, null, _removePreloadScript_decorators, { kind: "method", name: "removePreloadScript", static: false, private: false, access: { has: (obj) => ("removePreloadScript" in obj), get: (obj) => obj.removePreloadScript }, metadata: _metadata }, null, _instanceExtraInitializers);
49341
49350
  __esDecorate12(this, null, _setGeolocationOverride_decorators, { kind: "method", name: "setGeolocationOverride", static: false, private: false, access: { has: (obj) => ("setGeolocationOverride" in obj), get: (obj) => obj.setGeolocationOverride }, metadata: _metadata }, null, _instanceExtraInitializers);
49342
49351
  __esDecorate12(this, null, _setTimezoneOverride_decorators, { kind: "method", name: "setTimezoneOverride", static: false, private: false, access: { has: (obj) => ("setTimezoneOverride" in obj), get: (obj) => obj.setTimezoneOverride }, metadata: _metadata }, null, _instanceExtraInitializers);
49352
+ __esDecorate12(this, null, _setScreenOrientationOverride_decorators, { kind: "method", name: "setScreenOrientationOverride", static: false, private: false, access: { has: (obj) => ("setScreenOrientationOverride" in obj), get: (obj) => obj.setScreenOrientationOverride }, metadata: _metadata }, null, _instanceExtraInitializers);
49343
49353
  __esDecorate12(this, null, _getCookies_decorators, { kind: "method", name: "getCookies", static: false, private: false, access: { has: (obj) => ("getCookies" in obj), get: (obj) => obj.getCookies }, metadata: _metadata }, null, _instanceExtraInitializers);
49344
49354
  __esDecorate12(this, null, _setCookie_decorators, { kind: "method", name: "setCookie", static: false, private: false, access: { has: (obj) => ("setCookie" in obj), get: (obj) => obj.setCookie }, metadata: _metadata }, null, _instanceExtraInitializers);
49345
49355
  __esDecorate12(this, null, _setFiles_decorators, { kind: "method", name: "setFiles", static: false, private: false, access: { has: (obj) => ("setFiles" in obj), get: (obj) => obj.setFiles }, metadata: _metadata }, null, _instanceExtraInitializers);
@@ -49632,6 +49642,12 @@ var init_BrowsingContext = __esm(() => {
49632
49642
  contexts: [this.id]
49633
49643
  });
49634
49644
  }
49645
+ async setScreenOrientationOverride(screenOrientation) {
49646
+ await this.#session.send("emulation.setScreenOrientationOverride", {
49647
+ screenOrientation,
49648
+ contexts: [this.id]
49649
+ });
49650
+ }
49635
49651
  async getCookies(options = {}) {
49636
49652
  const { result: { cookies } } = await this.#session.send("storage.getCookies", {
49637
49653
  ...options,
@@ -49700,6 +49716,8 @@ var init_BrowsingContext = __esm(() => {
49700
49716
  return context2.#reason;
49701
49717
  })], _setTimezoneOverride_decorators = [throwIfDisposed((context2) => {
49702
49718
  return context2.#reason;
49719
+ })], _setScreenOrientationOverride_decorators = [throwIfDisposed((context2) => {
49720
+ return context2.#reason;
49703
49721
  })], _getCookies_decorators = [throwIfDisposed((context2) => {
49704
49722
  return context2.#reason;
49705
49723
  })], _setCookie_decorators = [throwIfDisposed((context2) => {
@@ -52989,6 +53007,9 @@ var init_Page2 = __esm(() => {
52989
53007
  resize(_params) {
52990
53008
  throw new Error("Method not implemented for WebDriver BiDi yet.");
52991
53009
  }
53010
+ openDevTools() {
53011
+ throw new Error("Method not implemented for WebDriver BiDi yet.");
53012
+ }
52992
53013
  async focusedFrame() {
52993
53014
  const env_1 = { stack: [], error: undefined, hasError: false };
52994
53015
  try {
@@ -53045,7 +53066,9 @@ var init_Page2 = __esm(() => {
53045
53066
  async reload(options = {}) {
53046
53067
  const [response] = await Promise.all([
53047
53068
  this.#frame.waitForNavigation(options),
53048
- this.#frame.browsingContext.reload()
53069
+ this.#frame.browsingContext.reload({
53070
+ ignoreCache: options.ignoreCache ? true : undefined
53071
+ })
53049
53072
  ]).catch(rewriteNavigationError(this.url(), options.timeout ?? this._timeoutSettings.navigationTimeout()));
53050
53073
  return response;
53051
53074
  }
@@ -53106,13 +53129,25 @@ var init_Page2 = __esm(() => {
53106
53129
  }
53107
53130
  async setViewport(viewport) {
53108
53131
  if (!this.browser().cdpSupported) {
53109
- await this.#frame.browsingContext.setViewport({
53110
- viewport: viewport?.width && viewport?.height ? {
53111
- width: viewport.width,
53112
- height: viewport.height
53113
- } : null,
53114
- devicePixelRatio: viewport?.deviceScaleFactor ? viewport.deviceScaleFactor : null
53115
- });
53132
+ const viewportSize = viewport?.width && viewport?.height ? {
53133
+ width: viewport.width,
53134
+ height: viewport.height
53135
+ } : null;
53136
+ const devicePixelRatio = viewport?.deviceScaleFactor ? viewport.deviceScaleFactor : null;
53137
+ const screenOrientation = viewport ? viewport.isLandscape ? {
53138
+ natural: "landscape",
53139
+ type: "landscape-primary"
53140
+ } : {
53141
+ natural: "portrait",
53142
+ type: "portrait-primary"
53143
+ } : null;
53144
+ await Promise.all([
53145
+ this.#frame.browsingContext.setViewport({
53146
+ viewport: viewportSize,
53147
+ devicePixelRatio
53148
+ }),
53149
+ this.#frame.browsingContext.setScreenOrientationOverride(screenOrientation)
53150
+ ]);
53116
53151
  this.#viewport = viewport;
53117
53152
  return;
53118
53153
  }
@@ -53834,11 +53869,12 @@ var init_BrowserContext2 = __esm(() => {
53834
53869
  return [target, ...frames.values()];
53835
53870
  });
53836
53871
  }
53837
- async newPage() {
53872
+ async newPage(options) {
53838
53873
  const env_1 = { stack: [], error: undefined, hasError: false };
53839
53874
  try {
53840
53875
  const _guard = __addDisposableResource18(env_1, await this.waitForScreenshotOperations(), false);
53841
- const context2 = await this.userContext.createBrowsingContext("tab");
53876
+ const type = options?.type === "window" ? "window" : "tab";
53877
+ const context2 = await this.userContext.createBrowsingContext(type);
53842
53878
  const page = this.#pages.get(context2);
53843
53879
  if (!page) {
53844
53880
  throw new Error("Page is not found");
@@ -53868,7 +53904,7 @@ var init_BrowserContext2 = __esm(() => {
53868
53904
  browser() {
53869
53905
  return this.#browser;
53870
53906
  }
53871
- async pages() {
53907
+ async pages(_includeAll = false) {
53872
53908
  return [...this.userContext.browsingContexts].map((context2) => {
53873
53909
  return this.#pages.get(context2);
53874
53910
  });
@@ -289900,8 +289936,11 @@ var parseClass = (glob, position) => {
289900
289936
  };
289901
289937
 
289902
289938
  // ../../node_modules/glob/node_modules/minimatch/dist/esm/unescape.js
289903
- var unescape2 = (s, { windowsPathsNoEscape = false } = {}) => {
289904
- return windowsPathsNoEscape ? s.replace(/\[([^\/\\])\]/g, "$1") : s.replace(/((?!\\).|^)\[([^\/\\])\]/g, "$1$2").replace(/\\([^\/])/g, "$1");
289939
+ var unescape2 = (s, { windowsPathsNoEscape = false, magicalBraces = true } = {}) => {
289940
+ if (magicalBraces) {
289941
+ return windowsPathsNoEscape ? s.replace(/\[([^\/\\])\]/g, "$1") : s.replace(/((?!\\).|^)\[([^\/\\])\]/g, "$1$2").replace(/\\([^\/])/g, "$1");
289942
+ }
289943
+ return windowsPathsNoEscape ? s.replace(/\[([^\/\\{}])\]/g, "$1") : s.replace(/((?!\\).|^)\[([^\/\\{}])\]/g, "$1$2").replace(/\\([^\/{}])/g, "$1");
289905
289944
  };
289906
289945
 
289907
289946
  // ../../node_modules/glob/node_modules/minimatch/dist/esm/ast.js
@@ -290182,7 +290221,7 @@ class AST {
290182
290221
  if (this.#root === this)
290183
290222
  this.#fillNegs();
290184
290223
  if (!this.type) {
290185
- const noEmpty = this.isStart() && this.isEnd();
290224
+ const noEmpty = this.isStart() && this.isEnd() && !this.#parts.some((s) => typeof s !== "string");
290186
290225
  const src = this.#parts.map((p2) => {
290187
290226
  const [re, _3, hasMagic, uflag] = typeof p2 === "string" ? AST.#parseGlob(p2, this.#hasMagic, noEmpty) : p2.toRegExpSource(allowDot);
290188
290227
  this.#hasMagic = this.#hasMagic || hasMagic;
@@ -290284,10 +290323,7 @@ class AST {
290284
290323
  }
290285
290324
  }
290286
290325
  if (c3 === "*") {
290287
- if (noEmpty && glob === "*")
290288
- re += starNoEmpty;
290289
- else
290290
- re += star;
290326
+ re += noEmpty && glob === "*" ? starNoEmpty : star;
290291
290327
  hasMagic = true;
290292
290328
  continue;
290293
290329
  }
@@ -290303,7 +290339,10 @@ class AST {
290303
290339
  }
290304
290340
 
290305
290341
  // ../../node_modules/glob/node_modules/minimatch/dist/esm/escape.js
290306
- var escape = (s, { windowsPathsNoEscape = false } = {}) => {
290342
+ var escape = (s, { windowsPathsNoEscape = false, magicalBraces = false } = {}) => {
290343
+ if (magicalBraces) {
290344
+ return windowsPathsNoEscape ? s.replace(/[?*()[\]{}]/g, "[$&]") : s.replace(/[?*()[\]\\{}]/g, "\\$&");
290345
+ }
290307
290346
  return windowsPathsNoEscape ? s.replace(/[?*()[\]]/g, "[$&]") : s.replace(/[?*()[\]\\]/g, "\\$&");
290308
290347
  };
290309
290348
 
@@ -290907,16 +290946,27 @@ globstar while`, file2, fr, pattern, pr, swallowee);
290907
290946
  pp[i2] = twoStar;
290908
290947
  }
290909
290948
  } else if (next === undefined) {
290910
- pp[i2 - 1] = prev + "(?:\\/|" + twoStar + ")?";
290949
+ pp[i2 - 1] = prev + "(?:\\/|\\/" + twoStar + ")?";
290911
290950
  } else if (next !== GLOBSTAR) {
290912
290951
  pp[i2 - 1] = prev + "(?:\\/|\\/" + twoStar + "\\/)" + next;
290913
290952
  pp[i2 + 1] = GLOBSTAR;
290914
290953
  }
290915
290954
  });
290916
- return pp.filter((p2) => p2 !== GLOBSTAR).join("/");
290955
+ const filtered = pp.filter((p2) => p2 !== GLOBSTAR);
290956
+ if (this.partial && filtered.length >= 1) {
290957
+ const prefixes = [];
290958
+ for (let i2 = 1;i2 <= filtered.length; i2++) {
290959
+ prefixes.push(filtered.slice(0, i2).join("/"));
290960
+ }
290961
+ return "(?:" + prefixes.join("|") + ")";
290962
+ }
290963
+ return filtered.join("/");
290917
290964
  }).join("|");
290918
290965
  const [open, close] = set2.length > 1 ? ["(?:", ")"] : ["", ""];
290919
290966
  re = "^" + open + re + close + "$";
290967
+ if (this.partial) {
290968
+ re = "^(?:\\/|" + open + re.slice(1, -1) + close + ")$";
290969
+ }
290920
290970
  if (this.negate)
290921
290971
  re = "^(?!" + re + ").+$";
290922
290972
  try {
@@ -299119,7 +299169,7 @@ init_Errors();
299119
299169
  class CdpCDPSession extends CDPSession {
299120
299170
  #sessionId;
299121
299171
  #targetType;
299122
- #callbacks = new CallbackRegistry;
299172
+ #callbacks;
299123
299173
  #connection;
299124
299174
  #parentSessionId;
299125
299175
  #target;
@@ -299129,6 +299179,7 @@ class CdpCDPSession extends CDPSession {
299129
299179
  super();
299130
299180
  this.#connection = connection;
299131
299181
  this.#targetType = targetType;
299182
+ this.#callbacks = new CallbackRegistry(connection._idGenerator);
299132
299183
  this.#sessionId = sessionId;
299133
299184
  this.#parentSessionId = parentSessionId;
299134
299185
  this.#rawErrors = rawErrors;
@@ -299216,10 +299267,12 @@ class Connection extends EventEmitter4 {
299216
299267
  #manuallyAttached = new Set;
299217
299268
  #callbacks;
299218
299269
  #rawErrors = false;
299219
- constructor(url2, transport, delay = 0, timeout2, rawErrors = false) {
299270
+ #idGenerator;
299271
+ constructor(url2, transport, delay = 0, timeout2, rawErrors = false, idGenerator = createIncrementalIdGenerator()) {
299220
299272
  super();
299221
299273
  this.#rawErrors = rawErrors;
299222
- this.#callbacks = new CallbackRegistry;
299274
+ this.#idGenerator = idGenerator;
299275
+ this.#callbacks = new CallbackRegistry(idGenerator);
299223
299276
  this.#url = url2;
299224
299277
  this.#delay = delay;
299225
299278
  this.#timeout = timeout2 ?? 180000;
@@ -299239,6 +299292,9 @@ class Connection extends EventEmitter4 {
299239
299292
  get _closed() {
299240
299293
  return this.#closed;
299241
299294
  }
299295
+ get _idGenerator() {
299296
+ return this.#idGenerator;
299297
+ }
299242
299298
  get _sessions() {
299243
299299
  return this.#sessions;
299244
299300
  }
@@ -303510,6 +303566,12 @@ class CdpPage extends Page {
303510
303566
  isJavaScriptEnabled() {
303511
303567
  return this.#emulationManager.javascriptEnabled;
303512
303568
  }
303569
+ async openDevTools() {
303570
+ const pageTargetId = this.target()._targetId;
303571
+ const browser2 = this.browser();
303572
+ const devtoolsPage = await browser2._createDevToolsPage(pageTargetId);
303573
+ return devtoolsPage;
303574
+ }
303513
303575
  async waitForFileChooser(options = {}) {
303514
303576
  const needsEnable = this.#fileChooserDeferreds.size === 0;
303515
303577
  const { timeout: timeout2 = this._timeoutSettings.timeout() } = options;
@@ -303825,7 +303887,9 @@ class CdpPage extends Page {
303825
303887
  ...options,
303826
303888
  ignoreSameDocumentNavigation: true
303827
303889
  }),
303828
- this.#primaryTargetClient.send("Page.reload")
303890
+ this.#primaryTargetClient.send("Page.reload", {
303891
+ ignoreCache: options?.ignoreCache ?? false
303892
+ })
303829
303893
  ]);
303830
303894
  return result;
303831
303895
  }
@@ -304142,9 +304206,9 @@ class CdpBrowserContext extends BrowserContext {
304142
304206
  return target.browserContext() === this;
304143
304207
  });
304144
304208
  }
304145
- async pages() {
304209
+ async pages(includeAll = false) {
304146
304210
  const pages = await Promise.all(this.targets().filter((target) => {
304147
- return target.type() === "page" || target.type() === "other" && this.#browser._getIsPageTargetCallback()?.(target);
304211
+ return target.type() === "page" || (target.type() === "other" || includeAll) && this.#browser._getIsPageTargetCallback()?.(target);
304148
304212
  }).map((target) => {
304149
304213
  return target.page();
304150
304214
  }));
@@ -304171,11 +304235,11 @@ class CdpBrowserContext extends BrowserContext {
304171
304235
  browserContextId: this.#id || undefined
304172
304236
  });
304173
304237
  }
304174
- async newPage() {
304238
+ async newPage(options) {
304175
304239
  const env_1 = { stack: [], error: undefined, hasError: false };
304176
304240
  try {
304177
304241
  const _guard = __addDisposableResource13(env_1, await this.waitForScreenshotOperations(), false);
304178
- return await this.#browser._createPageInContext(this.#id);
304242
+ return await this.#browser._createPageInContext(this.#id, options);
304179
304243
  } catch (e_1) {
304180
304244
  env_1.error = e_1;
304181
304245
  env_1.hasError = true;
@@ -304453,9 +304517,10 @@ class TargetManager extends EventEmitter4 {
304453
304517
  #attachedToTargetListenersBySession = new WeakMap;
304454
304518
  #detachedFromTargetListenersBySession = new WeakMap;
304455
304519
  #initializeDeferred = Deferred.create();
304456
- #targetsIdsForInit = new Set;
304457
304520
  #waitForInitiallyDiscoveredTargets = true;
304458
304521
  #discoveryFilter = [{}];
304522
+ #targetsIdsForInit = new Set;
304523
+ #initialAttachDone = false;
304459
304524
  constructor(connection, targetFactory, targetFilterCallback, waitForInitiallyDiscoveredTargets = true) {
304460
304525
  super();
304461
304526
  this.#connection = connection;
@@ -304468,25 +304533,11 @@ class TargetManager extends EventEmitter4 {
304468
304533
  this.#connection.on(CDPSessionEvent.SessionDetached, this.#onSessionDetached);
304469
304534
  this.#setupAttachmentListeners(this.#connection);
304470
304535
  }
304471
- #storeExistingTargetsForInit = () => {
304472
- if (!this.#waitForInitiallyDiscoveredTargets) {
304473
- return;
304474
- }
304475
- for (const [targetId, targetInfo] of this.#discoveredTargetsByTargetId.entries()) {
304476
- const targetForFilter = new CdpTarget(targetInfo, undefined, undefined, this, undefined);
304477
- const isPageOrFrame = targetInfo.type === "page" || targetInfo.type === "iframe";
304478
- const isExtension = targetInfo.url.startsWith("chrome-extension://");
304479
- if ((!this.#targetFilterCallback || this.#targetFilterCallback(targetForFilter)) && isPageOrFrame && !isExtension) {
304480
- this.#targetsIdsForInit.add(targetId);
304481
- }
304482
- }
304483
- };
304484
304536
  async initialize() {
304485
304537
  await this.#connection.send("Target.setDiscoverTargets", {
304486
304538
  discover: true,
304487
304539
  filter: this.#discoveryFilter
304488
304540
  });
304489
- this.#storeExistingTargetsForInit();
304490
304541
  await this.#connection.send("Target.setAutoAttach", {
304491
304542
  waitForDebuggerOnStart: true,
304492
304543
  flatten: true,
@@ -304499,6 +304550,7 @@ class TargetManager extends EventEmitter4 {
304499
304550
  ...this.#discoveryFilter
304500
304551
  ]
304501
304552
  });
304553
+ this.#initialAttachDone = true;
304502
304554
  this.#finishInitializationIfReady();
304503
304555
  await this.#initializeDeferred.valueOrThrow();
304504
304556
  }
@@ -304608,7 +304660,6 @@ class TargetManager extends EventEmitter4 {
304608
304660
  return;
304609
304661
  }
304610
304662
  if (targetInfo.type === "service_worker") {
304611
- this.#finishInitializationIfReady(targetInfo.targetId);
304612
304663
  await silentDetach();
304613
304664
  if (this.#attachedTargetsByTargetId.has(targetInfo.targetId)) {
304614
304665
  return;
@@ -304621,12 +304672,18 @@ class TargetManager extends EventEmitter4 {
304621
304672
  }
304622
304673
  const isExistingTarget = this.#attachedTargetsByTargetId.has(targetInfo.targetId);
304623
304674
  const target = isExistingTarget ? this.#attachedTargetsByTargetId.get(targetInfo.targetId) : this.#targetFactory(targetInfo, session2, parentSession instanceof CdpCDPSession ? parentSession : undefined);
304675
+ const parentTarget = parentSession instanceof CdpCDPSession ? parentSession.target() : null;
304624
304676
  if (this.#targetFilterCallback && !this.#targetFilterCallback(target)) {
304625
304677
  this.#ignoredTargets.add(targetInfo.targetId);
304626
- this.#finishInitializationIfReady(targetInfo.targetId);
304678
+ if (parentTarget?.type() === "tab") {
304679
+ this.#finishInitializationIfReady(parentTarget._targetId);
304680
+ }
304627
304681
  await silentDetach();
304628
304682
  return;
304629
304683
  }
304684
+ if (this.#waitForInitiallyDiscoveredTargets && event.targetInfo.type === "tab" && !this.#initialAttachDone) {
304685
+ this.#targetsIdsForInit.add(event.targetInfo.targetId);
304686
+ }
304630
304687
  this.#setupAttachmentListeners(session2);
304631
304688
  if (isExistingTarget) {
304632
304689
  session2.setTarget(target);
@@ -304636,14 +304693,14 @@ class TargetManager extends EventEmitter4 {
304636
304693
  this.#attachedTargetsByTargetId.set(targetInfo.targetId, target);
304637
304694
  this.#attachedTargetsBySessionId.set(session2.id(), target);
304638
304695
  }
304639
- const parentTarget = parentSession instanceof CDPSession ? parentSession.target() : null;
304640
304696
  parentTarget?._addChildTarget(target);
304641
304697
  parentSession.emit(CDPSessionEvent.Ready, session2);
304642
- this.#targetsIdsForInit.delete(target._targetId);
304643
304698
  if (!isExistingTarget) {
304644
304699
  this.emit("targetAvailable", target);
304645
304700
  }
304646
- this.#finishInitializationIfReady();
304701
+ if (parentTarget?.type() === "tab") {
304702
+ this.#finishInitializationIfReady(parentTarget._targetId);
304703
+ }
304647
304704
  await Promise.all([
304648
304705
  session2.send("Target.setAutoAttach", {
304649
304706
  waitForDebuggerOnStart: true,
@@ -304658,6 +304715,9 @@ class TargetManager extends EventEmitter4 {
304658
304715
  if (targetId !== undefined) {
304659
304716
  this.#targetsIdsForInit.delete(targetId);
304660
304717
  }
304718
+ if (!this.#initialAttachDone) {
304719
+ return;
304720
+ }
304661
304721
  if (this.#targetsIdsForInit.size === 0) {
304662
304722
  this.#initializeDeferred.resolve();
304663
304723
  }
@@ -304829,10 +304889,14 @@ class CdpBrowser extends Browser {
304829
304889
  async newPage() {
304830
304890
  return await this.#defaultContext.newPage();
304831
304891
  }
304832
- async _createPageInContext(contextId) {
304892
+ async _createPageInContext(contextId, options) {
304893
+ const hasTargets = this.targets().filter((t) => {
304894
+ return t.browserContext().id === contextId;
304895
+ }).length > 0;
304833
304896
  const { targetId } = await this.#connection.send("Target.createTarget", {
304834
304897
  url: "about:blank",
304835
- browserContextId: contextId || undefined
304898
+ browserContextId: contextId || undefined,
304899
+ newWindow: hasTargets && options?.type === "window" ? true : undefined
304836
304900
  });
304837
304901
  const target = await this.waitForTarget((t) => {
304838
304902
  return t._targetId === targetId;
@@ -304850,6 +304914,26 @@ class CdpBrowser extends Browser {
304850
304914
  }
304851
304915
  return page;
304852
304916
  }
304917
+ async _createDevToolsPage(pageTargetId) {
304918
+ const openDevToolsResponse = await this.#connection.send("Target.openDevTools", {
304919
+ targetId: pageTargetId
304920
+ });
304921
+ const target = await this.waitForTarget((t) => {
304922
+ return t._targetId === openDevToolsResponse.targetId;
304923
+ });
304924
+ if (!target) {
304925
+ throw new Error(`Missing target for DevTools page (id = ${pageTargetId})`);
304926
+ }
304927
+ const initialized = await target._initializedDeferred.valueOrThrow() === InitializationStatus.SUCCESS;
304928
+ if (!initialized) {
304929
+ throw new Error(`Failed to create target for DevTools page (id = ${pageTargetId})`);
304930
+ }
304931
+ const page = await target.page();
304932
+ if (!page) {
304933
+ throw new Error(`Failed to create a DevTools Page for target (id = ${pageTargetId})`);
304934
+ }
304935
+ return page;
304936
+ }
304853
304937
  async installExtension(path51) {
304854
304938
  const { id } = await this.#connection.send("Extensions.loadUnpacked", { path: path51 });
304855
304939
  return id;
@@ -304907,8 +304991,8 @@ class CdpBrowser extends Browser {
304907
304991
  // ../../node_modules/puppeteer-core/lib/esm/puppeteer/cdp/BrowserConnector.js
304908
304992
  init_util2();
304909
304993
  async function _connectToCdpBrowser(connectionTransport, url2, options) {
304910
- const { acceptInsecureCerts = false, networkEnabled = true, defaultViewport = DEFAULT_VIEWPORT, downloadBehavior, targetFilter, _isPageTarget: isPageTarget, slowMo = 0, protocolTimeout, handleDevToolsAsPage } = options;
304911
- const connection = new Connection(url2, connectionTransport, slowMo, protocolTimeout);
304994
+ const { acceptInsecureCerts = false, networkEnabled = true, defaultViewport = DEFAULT_VIEWPORT, downloadBehavior, targetFilter, _isPageTarget: isPageTarget, slowMo = 0, protocolTimeout, handleDevToolsAsPage, idGenerator = createIncrementalIdGenerator() } = options;
304995
+ const connection = new Connection(url2, connectionTransport, slowMo, protocolTimeout, false, idGenerator);
304912
304996
  const { browserContextIds } = await connection.send("Target.getBrowserContexts");
304913
304997
  const browser2 = await CdpBrowser._create(connection, browserContextIds, acceptInsecureCerts, defaultViewport, downloadBehavior, undefined, () => {
304914
304998
  return connection.send("Browser.close").catch(debugError);
@@ -304961,7 +305045,9 @@ class ExtensionTransport {
304961
305045
  });
304962
305046
  };
304963
305047
  #dispatchResponse(message) {
304964
- this.onmessage?.(JSON.stringify(message));
305048
+ setTimeout(() => {
305049
+ this.onmessage?.(JSON.stringify(message));
305050
+ }, 0);
304965
305051
  }
304966
305052
  send(message) {
304967
305053
  const parsed = JSON.parse(message);
@@ -305017,6 +305103,7 @@ class ExtensionTransport {
305017
305103
  if (parsed.sessionId === "tabTargetSessionId") {
305018
305104
  this.#dispatchResponse({
305019
305105
  method: "Target.attachedToTarget",
305106
+ sessionId: "tabTargetSessionId",
305020
305107
  params: {
305021
305108
  targetInfo: pageTargetInfo,
305022
305109
  sessionId: "pageTargetSessionId"
@@ -306720,8 +306807,8 @@ async function _connectToBiDiBrowser(connectionTransport, url2, options) {
306720
306807
  }
306721
306808
  async function getBiDiConnection(connectionTransport, url2, options) {
306722
306809
  const BiDi = await Promise.resolve().then(() => (init_bidi(), exports_bidi));
306723
- const { slowMo = 0, protocolTimeout } = options;
306724
- const pureBidiConnection = new BiDi.BidiConnection(url2, connectionTransport, slowMo, protocolTimeout);
306810
+ const { slowMo = 0, protocolTimeout, idGenerator = createIncrementalIdGenerator() } = options;
306811
+ const pureBidiConnection = new BiDi.BidiConnection(url2, connectionTransport, idGenerator, slowMo, protocolTimeout);
306725
306812
  try {
306726
306813
  const result = await pureBidiConnection.send("session.status", {});
306727
306814
  if ("type" in result && result.type === "success") {
@@ -306738,7 +306825,7 @@ async function getBiDiConnection(connectionTransport, url2, options) {
306738
306825
  }
306739
306826
  }
306740
306827
  pureBidiConnection.unbind();
306741
- const cdpConnection = new Connection(url2, connectionTransport, slowMo, protocolTimeout, true);
306828
+ const cdpConnection = new Connection(url2, connectionTransport, slowMo, protocolTimeout, true, idGenerator);
306742
306829
  const version3 = await cdpConnection.send("Browser.getVersion");
306743
306830
  if (version3.product.toLowerCase().includes("firefox")) {
306744
306831
  throw new UnsupportedOperation("Firefox is not supported in BiDi over CDP mode.");
@@ -306866,9 +306953,9 @@ init_WaitTask();
306866
306953
  init_XPathQueryHandler();
306867
306954
  // ../../node_modules/puppeteer-core/lib/esm/puppeteer/revisions.js
306868
306955
  var PUPPETEER_REVISIONS = Object.freeze({
306869
- chrome: "141.0.7390.122",
306870
- "chrome-headless-shell": "141.0.7390.122",
306871
- firefox: "stable_144.0"
306956
+ chrome: "142.0.7444.59",
306957
+ "chrome-headless-shell": "142.0.7444.59",
306958
+ firefox: "stable_144.0.2"
306872
306959
  });
306873
306960
  // ../../node_modules/puppeteer-core/lib/esm/puppeteer/util/util.js
306874
306961
  init_Deferred();
@@ -307060,8 +307147,9 @@ function relativeExecutablePath(platform2, _buildId) {
307060
307147
  return path51.join("chrome-" + folder(platform2), "chrome.exe");
307061
307148
  }
307062
307149
  }
307150
+ var baseVersionUrl = "https://googlechromelabs.github.io/chrome-for-testing";
307063
307151
  async function getLastKnownGoodReleaseForChannel(channel) {
307064
- const data = await getJSON(new URL("https://googlechromelabs.github.io/chrome-for-testing/last-known-good-versions.json"));
307152
+ const data = await getJSON(new URL(`${baseVersionUrl}/last-known-good-versions.json`));
307065
307153
  for (const channel2 of Object.keys(data.channels)) {
307066
307154
  data.channels[channel2.toLowerCase()] = data.channels[channel2];
307067
307155
  delete data.channels[channel2];
@@ -307069,11 +307157,11 @@ async function getLastKnownGoodReleaseForChannel(channel) {
307069
307157
  return data.channels[channel];
307070
307158
  }
307071
307159
  async function getLastKnownGoodReleaseForMilestone(milestone) {
307072
- const data = await getJSON(new URL("https://googlechromelabs.github.io/chrome-for-testing/latest-versions-per-milestone.json"));
307160
+ const data = await getJSON(new URL(`${baseVersionUrl}/latest-versions-per-milestone.json`));
307073
307161
  return data.milestones[milestone];
307074
307162
  }
307075
307163
  async function getLastKnownGoodReleaseForBuild(buildPrefix) {
307076
- const data = await getJSON(new URL("https://googlechromelabs.github.io/chrome-for-testing/latest-patch-versions-per-build.json"));
307164
+ const data = await getJSON(new URL(`${baseVersionUrl}/latest-patch-versions-per-build.json`));
307077
307165
  return data.builds[buildPrefix];
307078
307166
  }
307079
307167
  async function resolveBuildId(channel) {
@@ -307485,6 +307573,7 @@ var FirefoxChannel;
307485
307573
  FirefoxChannel2["BETA"] = "beta";
307486
307574
  FirefoxChannel2["NIGHTLY"] = "nightly";
307487
307575
  })(FirefoxChannel || (FirefoxChannel = {}));
307576
+ var baseVersionUrl2 = "https://product-details.mozilla.org/1.0";
307488
307577
  async function resolveBuildId3(channel = FirefoxChannel.NIGHTLY) {
307489
307578
  const channelToVersionKey = {
307490
307579
  [FirefoxChannel.ESR]: "FIREFOX_ESR",
@@ -307493,7 +307582,7 @@ async function resolveBuildId3(channel = FirefoxChannel.NIGHTLY) {
307493
307582
  [FirefoxChannel.BETA]: "FIREFOX_DEVEDITION",
307494
307583
  [FirefoxChannel.NIGHTLY]: "FIREFOX_NIGHTLY"
307495
307584
  };
307496
- const versions2 = await getJSON(new URL("https://product-details.mozilla.org/1.0/firefox_versions.json"));
307585
+ const versions2 = await getJSON(new URL(`${baseVersionUrl2}/firefox_versions.json`));
307497
307586
  const version3 = versions2[channelToVersionKey[channel]];
307498
307587
  if (!version3) {
307499
307588
  throw new Error(`Channel ${channel} is not found.`);
@@ -308666,7 +308755,7 @@ function isValidBrowser(browser2) {
308666
308755
  function isValidPlatform(platform2) {
308667
308756
  return Object.values(BrowserPlatform).includes(platform2);
308668
308757
  }
308669
- var packageVersion2 = "2.10.12";
308758
+ var packageVersion2 = "2.10.13";
308670
308759
 
308671
308760
  class CLI {
308672
308761
  #cachePath;
@@ -308997,7 +309086,7 @@ class BrowserLauncher {
308997
309086
  return this.#browser;
308998
309087
  }
308999
309088
  async launch(options = {}) {
309000
- const { dumpio = false, enableExtensions = false, env: env4 = process.env, handleSIGINT = true, handleSIGTERM = true, handleSIGHUP = true, acceptInsecureCerts = false, networkEnabled = true, defaultViewport = DEFAULT_VIEWPORT, downloadBehavior, slowMo = 0, timeout: timeout2 = 30000, waitForInitialPage = true, protocolTimeout, handleDevToolsAsPage } = options;
309089
+ const { dumpio = false, enableExtensions = false, env: env4 = process.env, handleSIGINT = true, handleSIGTERM = true, handleSIGHUP = true, acceptInsecureCerts = false, networkEnabled = true, defaultViewport = DEFAULT_VIEWPORT, downloadBehavior, slowMo = 0, timeout: timeout2 = 30000, waitForInitialPage = true, protocolTimeout, handleDevToolsAsPage, idGenerator = createIncrementalIdGenerator() } = options;
309001
309090
  let { protocol } = options;
309002
309091
  if (this.#browser === "firefox" && protocol === undefined) {
309003
309092
  protocol = "webDriverBiDi";
@@ -309050,20 +309139,23 @@ class BrowserLauncher {
309050
309139
  slowMo,
309051
309140
  defaultViewport,
309052
309141
  acceptInsecureCerts,
309053
- networkEnabled
309142
+ networkEnabled,
309143
+ idGenerator
309054
309144
  });
309055
309145
  } else {
309056
309146
  if (usePipe) {
309057
309147
  cdpConnection = await this.createCdpPipeConnection(browserProcess, {
309058
309148
  timeout: timeout2,
309059
309149
  protocolTimeout,
309060
- slowMo
309150
+ slowMo,
309151
+ idGenerator
309061
309152
  });
309062
309153
  } else {
309063
309154
  cdpConnection = await this.createCdpSocketConnection(browserProcess, {
309064
309155
  timeout: timeout2,
309065
309156
  protocolTimeout,
309066
- slowMo
309157
+ slowMo,
309158
+ idGenerator
309067
309159
  });
309068
309160
  }
309069
309161
  if (protocol === "webDriverBiDi") {
@@ -309134,12 +309226,12 @@ class BrowserLauncher {
309134
309226
  async createCdpSocketConnection(browserProcess, opts) {
309135
309227
  const browserWSEndpoint = await browserProcess.waitForLineOutput(CDP_WEBSOCKET_ENDPOINT_REGEX, opts.timeout);
309136
309228
  const transport = await NodeWebSocketTransport.create(browserWSEndpoint);
309137
- return new Connection(browserWSEndpoint, transport, opts.slowMo, opts.protocolTimeout);
309229
+ return new Connection(browserWSEndpoint, transport, opts.slowMo, opts.protocolTimeout, false, opts.idGenerator);
309138
309230
  }
309139
309231
  async createCdpPipeConnection(browserProcess, opts) {
309140
309232
  const { 3: pipeWrite, 4: pipeRead } = browserProcess.nodeProcess.stdio;
309141
309233
  const transport = new PipeTransport(pipeWrite, pipeRead);
309142
- return new Connection("", transport, opts.slowMo, opts.protocolTimeout);
309234
+ return new Connection("", transport, opts.slowMo, opts.protocolTimeout, false, opts.idGenerator);
309143
309235
  }
309144
309236
  async createBiDiOverCdpBrowser(browserProcess, cdpConnection, closeCallback, opts) {
309145
309237
  const bidiOnly = process.env["PUPPETEER_WEBDRIVER_BIDI_ONLY"] === "true";
@@ -309159,7 +309251,7 @@ class BrowserLauncher {
309159
309251
  const browserWSEndpoint = await browserProcess.waitForLineOutput(WEBDRIVER_BIDI_WEBSOCKET_ENDPOINT_REGEX, opts.timeout) + "/session";
309160
309252
  const transport = await NodeWebSocketTransport.create(browserWSEndpoint);
309161
309253
  const BiDi = await Promise.resolve().then(() => (init_bidi(), exports_bidi));
309162
- const bidiConnection = new BiDi.BidiConnection(browserWSEndpoint, transport, opts.slowMo, opts.protocolTimeout);
309254
+ const bidiConnection = new BiDi.BidiConnection(browserWSEndpoint, transport, opts.idGenerator, opts.slowMo, opts.protocolTimeout);
309163
309255
  return await BiDi.BidiBrowser.create({
309164
309256
  connection: bidiConnection,
309165
309257
  closeCallback,
@@ -310023,7 +310115,7 @@ var getConfiguration = () => {
310023
310115
  const result = import_cosmiconfig.cosmiconfigSync("puppeteer", {
310024
310116
  searchStrategy: "global"
310025
310117
  }).search();
310026
- const configuration = result ? result.config : {};
310118
+ const configuration = result ? { ...result.config } : {};
310027
310119
  configuration.logLevel = getLogLevel(process.env["PUPPETEER_LOGLEVEL"] ?? configuration.logLevel);
310028
310120
  configuration.defaultBrowser = getDefaultBrowser(process.env["PUPPETEER_BROWSER"] ?? configuration.defaultBrowser);
310029
310121
  configuration.executablePath = process.env["PUPPETEER_EXECUTABLE_PATH"] ?? configuration.executablePath;
@@ -313266,5 +313358,5 @@ main().catch((error46) => {
313266
313358
  process.exit(1);
313267
313359
  });
313268
313360
 
313269
- //# debugId=39C6579DD9D89A9164756E2164756E21
313361
+ //# debugId=E8E5CA8717BB2FE664756E2164756E21
313270
313362
  //# sourceMappingURL=index.js.map