diff --git a/built-in-ai-extension/eslint.config.js b/built-in-ai-extension/eslint.config.js
new file mode 100644
index 0000000..e9acf6a
--- /dev/null
+++ b/built-in-ai-extension/eslint.config.js
@@ -0,0 +1,33 @@
+import js from '@eslint/js';
+import google from 'eslint-config-google';
+import prettier from 'eslint-config-prettier';
+import globals from 'globals';
+
+export default [
+ js.configs.recommended,
+ {
+ rules: {
+ ...google.rules,
+ ...prettier.rules,
+ 'require-jsdoc': 'off',
+ 'valid-jsdoc': 'off',
+ 'max-len': ['warn', { code: 100, ignoreUrls: true }],
+ 'no-unused-vars': 'warn',
+ 'no-undef': 'error',
+ },
+ },
+ {
+ languageOptions: {
+ ecmaVersion: 'latest',
+ sourceType: 'module',
+ globals: {
+ ...globals.browser,
+ ...globals.webextensions,
+ chrome: 'readonly',
+ },
+ },
+ },
+ {
+ ignores: ['dist/**', 'node_modules/**'],
+ },
+];
diff --git a/built-in-ai-extension/offscreen/offscreen.js b/built-in-ai-extension/offscreen/offscreen.js
index 4a3bfc3..8b18258 100644
--- a/built-in-ai-extension/offscreen/offscreen.js
+++ b/built-in-ai-extension/offscreen/offscreen.js
@@ -5,15 +5,61 @@
// offscreen/offscreen.js
-let sessions = new Map(); // requestId -> session instance
-let controllers = new Map(); // callId -> AbortController
+const sessions = new Map(); // requestId -> session instance
+const controllers = new Map(); // callId -> AbortController
chrome.runtime.onMessage.addListener((message, sender, sendResponse) => {
if (message.target !== 'offscreen') return;
(async () => {
+ let processedMessage;
try {
- if (message.type === 'create-session') {
+ // Recursively find and process blobURLs into Blobs
+ const processBlobURLs = async (obj) => {
+ if (!obj || typeof obj !== 'object') return obj;
+
+ // More robust identification for the specific bridge descriptor
+ if (obj.__extension_blob_url__) {
+ const url = obj.__extension_blob_url__;
+ try {
+ const response = await fetch(url);
+ const blob = await response.blob();
+ URL.revokeObjectURL(url);
+ return blob;
+ } catch (e) {
+ console.error(`[Offscreen] Failed to fetch blobURL (${url}):`, e);
+ URL.revokeObjectURL(url);
+ throw e;
+ }
+ }
+
+ // Avoid recursing into Blobs, ArrayBuffers, or other special objects
+ const constructorName = obj.constructor?.name;
+ if (
+ constructorName === 'Blob' ||
+ constructorName === 'File' ||
+ constructorName === 'ArrayBuffer' ||
+ ArrayBuffer.isView(obj)
+ ) {
+ return obj;
+ }
+
+ if (Array.isArray(obj)) {
+ for (let i = 0; i < obj.length; i++) {
+ obj[i] = await processBlobURLs(obj[i]);
+ }
+ } else {
+ for (const key of Object.keys(obj)) {
+ obj[key] = await processBlobURLs(obj[key]);
+ }
+ }
+ return obj;
+ };
+
+ processedMessage = await processBlobURLs(message);
+ const { type } = processedMessage;
+
+ if (type === 'create-session') {
const {
config,
options,
@@ -23,16 +69,14 @@ chrome.runtime.onMessage.addListener((message, sender, sendResponse) => {
backend,
senderTabId,
senderFrameId,
- } = message;
+ } = processedMessage;
// Apply external configuration to globals for the polyfills to find.
setupConfigs(backend, config);
- const [promptApiModule] = await Promise.all([
- import('prompt-api-polyfill'),
- ]);
+ const promptApiModule = await import('prompt-api-polyfill');
- const ApiClass = getApiClass(promptApiModule, apiType, config);
+ const ApiClass = getApiClass(promptApiModule, apiType, config, backend);
if (!ApiClass) {
throw new Error(
@@ -101,20 +145,18 @@ chrome.runtime.onMessage.addListener((message, sender, sendResponse) => {
} finally {
if (callId) controllers.delete(callId);
}
- } else if (message.type === 'availability') {
- const { config, backend, apiType, options } = message;
+ } else if (processedMessage.type === 'availability') {
+ const { config, backend, apiType, options } = processedMessage;
setupConfigs(backend, config);
- const [promptApiModule] = await Promise.all([
- import('prompt-api-polyfill'),
- ]);
+ const promptApiModule = await import('prompt-api-polyfill');
- const ApiClass = getApiClass(promptApiModule, apiType, config);
+ const ApiClass = getApiClass(promptApiModule, apiType, config, backend);
const result = await ApiClass.availability(options);
sendResponse({ success: true, result });
- } else if (message.type === 'clone-session') {
+ } else if (processedMessage.type === 'clone-session') {
const {
sourceRequestId,
requestId,
@@ -122,7 +164,7 @@ chrome.runtime.onMessage.addListener((message, sender, sendResponse) => {
options,
senderTabId,
senderFrameId,
- } = message;
+ } = processedMessage;
const sourceSession = sessions.get(sourceRequestId);
if (!sourceSession) {
throw new Error(
@@ -174,7 +216,7 @@ chrome.runtime.onMessage.addListener((message, sender, sendResponse) => {
} finally {
if (callId) controllers.delete(callId);
}
- } else if (message.type === 'list-models') {
+ } else if (processedMessage.type === 'list-models') {
const cache = await caches.open('transformers-cache');
const keys = await cache.keys();
const models = new Set();
@@ -184,8 +226,8 @@ chrome.runtime.onMessage.addListener((message, sender, sendResponse) => {
if (match) models.add(match[1]);
}
sendResponse({ success: true, models: Array.from(models) });
- } else if (message.type === 'delete-model') {
- const { modelName } = message;
+ } else if (processedMessage.type === 'delete-model') {
+ const { modelName } = processedMessage;
const cache = await caches.open('transformers-cache');
const keys = await cache.keys();
let deletedCount = 0;
@@ -208,19 +250,12 @@ chrome.runtime.onMessage.addListener((message, sender, sendResponse) => {
keysToRemove.forEach((k) => localStorage.removeItem(k));
sendResponse({ success: true, deletedCount });
} else if (
- message.type === 'prompt' ||
- message.type === 'execute' ||
- message.type === 'append'
+ processedMessage.type === 'prompt' ||
+ processedMessage.type === 'execute' ||
+ processedMessage.type === 'append'
) {
- const {
- requestId,
- callId,
- text,
- method,
- options,
- senderTabId,
- senderFrameId,
- } = message;
+ const { requestId, callId, text, method, options } = processedMessage;
+
const session = sessions.get(requestId);
if (!session)
throw new Error('No active session for requestId: ' + requestId);
@@ -228,7 +263,7 @@ chrome.runtime.onMessage.addListener((message, sender, sendResponse) => {
const controller = new AbortController();
if (callId) controllers.set(callId, controller);
try {
- const result = await session[method || message.type](text, {
+ const result = await session[method || processedMessage.type](text, {
...options,
signal: controller.signal,
});
@@ -244,8 +279,8 @@ chrome.runtime.onMessage.addListener((message, sender, sendResponse) => {
if (callId) controllers.delete(callId);
}
} else if (
- message.type === 'prompt-streaming' ||
- message.type === 'execute-streaming'
+ processedMessage.type === 'prompt-streaming' ||
+ processedMessage.type === 'execute-streaming'
) {
const {
requestId,
@@ -255,7 +290,7 @@ chrome.runtime.onMessage.addListener((message, sender, sendResponse) => {
options,
senderTabId,
senderFrameId,
- } = message;
+ } = processedMessage;
const session = sessions.get(requestId);
if (!session)
throw new Error('No active session for requestId: ' + requestId);
@@ -323,14 +358,14 @@ chrome.runtime.onMessage.addListener((message, sender, sendResponse) => {
contextWindow: session.contextWindow,
},
});
- } else if (message.type === 'destroy-session') {
- const { requestId } = message;
+ } else if (processedMessage.type === 'destroy-session') {
+ const { requestId } = processedMessage;
const session = sessions.get(requestId);
if (session && session.destroy) session.destroy();
sessions.delete(requestId);
sendResponse({ success: true });
- } else if (message.type === 'abort-request') {
- const { callId } = message;
+ } else if (processedMessage.type === 'abort-request') {
+ const { callId } = processedMessage;
const controller = controllers.get(callId);
if (controller) {
controller.abort();
@@ -340,7 +375,14 @@ chrome.runtime.onMessage.addListener((message, sender, sendResponse) => {
}
} catch (err) {
console.error('Offscreen execution error:', err);
- sendResponse({ success: false, error: err.message, name: err.name });
+ // Use message instead of processedMessage here because processedMessage
+ // might be undefined if processBlobURLs failed
+ const apiType = processedMessage?.apiType ?? message.apiType;
+ const errorMsg =
+ apiType && !err.message.includes(apiType)
+ ? `[${apiType}] ${err.message}`
+ : err.message;
+ sendResponse({ success: false, error: errorMsg, name: err.name });
}
})();
@@ -397,7 +439,7 @@ function setupConfigs(backend, config) {
}
}
-function getApiClass(promptApiModule, apiType, config) {
+function getApiClass(promptApiModule, apiType, config, backend) {
const nativeClass = window[apiType || 'LanguageModel'];
const ApiClass =
@@ -406,9 +448,11 @@ function getApiClass(promptApiModule, apiType, config) {
promptApiModule.default ||
nativeClass;
- // If forceInjection is false and we have a native class, prefer it
+ // If forceInjection is false and we have a native class, prefer it,
+ // BUT only if the requested backend is 'native'.
if (
!config.forceInjection &&
+ backend === 'native' &&
nativeClass &&
typeof nativeClass.create === 'function'
) {
diff --git a/built-in-ai-extension/options/options.js b/built-in-ai-extension/options/options.js
index 3ce6113..7c94132 100644
--- a/built-in-ai-extension/options/options.js
+++ b/built-in-ai-extension/options/options.js
@@ -8,7 +8,6 @@
document.addEventListener('DOMContentLoaded', async () => {
const backendSelect = document.getElementById('backend');
const panes = document.querySelectorAll('.config-pane');
- const saveBtn = document.getElementById('save');
const statusSpan = document.getElementById('status');
const forceInjectionCheckbox = document.getElementById('forceInjection');
@@ -108,41 +107,39 @@ document.addEventListener('DOMContentLoaded', async () => {
// Model Management Logic
const refreshModels = async () => {
- chrome.runtime.sendMessage(
- { target: 'offscreen', type: 'list-models' },
- (response) => {
- if (response && response.success) {
- if (response.models.length === 0) {
- modelList.innerHTML = '
No models cached.';
- return;
- }
- modelList.innerHTML = '';
- response.models.forEach((model) => {
- const li = document.createElement('li');
- li.innerHTML = `
- ${model}
-
- `;
- modelList.appendChild(li);
-
- li.querySelector('.btn-delete').addEventListener(
- 'click',
- async () => {
- const modelName = model;
- if (confirm(`Delete cached files for ${modelName}?`)) {
- chrome.runtime.sendMessage(
- { target: 'offscreen', type: 'delete-model', modelName },
- () => refreshModels()
- );
- }
- }
- );
- });
- } else {
- modelList.innerHTML = 'Failed to load models.';
- }
+ const response = await chrome.runtime.sendMessage({
+ target: 'offscreen',
+ type: 'list-models',
+ });
+ if (response && response.success) {
+ if (response.models.length === 0) {
+ modelList.innerHTML = 'No models cached.';
+ return;
}
- );
+ modelList.innerHTML = '';
+ response.models.forEach((model) => {
+ const li = document.createElement('li');
+ li.innerHTML = `
+ ${model}
+
+ `;
+ modelList.appendChild(li);
+
+ li.querySelector('.btn-delete').addEventListener('click', async () => {
+ const modelName = model;
+ if (confirm(`Delete cached files for ${modelName}?`)) {
+ await chrome.runtime.sendMessage({
+ target: 'offscreen',
+ type: 'delete-model',
+ modelName,
+ });
+ refreshModels();
+ }
+ });
+ });
+ } else {
+ modelList.innerHTML = 'Failed to load models.';
+ }
};
// Initial load of models
@@ -159,32 +156,28 @@ document.addEventListener('DOMContentLoaded', async () => {
progressBar.style.width = '0%';
progressText.textContent = 'Checking model...';
- chrome.runtime.sendMessage(
- {
- target: 'offscreen',
- type: 'create-session',
- config: {
- apiKey: 'dummy',
- modelName: modelName,
- device: document.getElementById('transformersDevice').value,
- dtype: document.getElementById('transformersDtype').value,
- },
- options: {},
+ const response = await chrome.runtime.sendMessage({
+ target: 'offscreen',
+ type: 'create-session',
+ config: {
+ apiKey: 'dummy',
+ modelName: modelName,
+ device: document.getElementById('transformersDevice').value,
+ dtype: document.getElementById('transformersDtype').value,
},
- (response) => {
- if (response && response.success) {
- progressText.textContent = 'Model ready!';
- progressBar.style.width = '100%';
- refreshModels();
- setTimeout(() => progressContainer.classList.add('hidden'), 10000);
- } else {
- alert(
- 'Download failed: ' + (response ? response.error : 'Unknown error')
- );
- progressContainer.classList.add('hidden');
- }
- }
- );
+ options: {},
+ });
+ if (response && response.success) {
+ progressText.textContent = 'Model ready!';
+ progressBar.style.width = '100%';
+ refreshModels();
+ setTimeout(() => progressContainer.classList.add('hidden'), 10000);
+ } else {
+ alert(
+ 'Download failed: ' + (response ? response.error : 'Unknown error')
+ );
+ progressContainer.classList.add('hidden');
+ }
});
// Listen for progress messages
diff --git a/built-in-ai-extension/package-lock.json b/built-in-ai-extension/package-lock.json
index 190f0ed..a61de79 100644
--- a/built-in-ai-extension/package-lock.json
+++ b/built-in-ai-extension/package-lock.json
@@ -1,18 +1,23 @@
{
"name": "built-in-ai-extension",
- "version": "1.2.0",
+ "version": "1.4.0",
"lockfileVersion": 3,
"requires": true,
"packages": {
"": {
"name": "built-in-ai-extension",
- "version": "1.2.0",
+ "version": "1.4.0",
"license": "Apache-2.0",
"dependencies": {
"built-in-ai-task-apis-polyfills": "^1.4.0",
- "prompt-api-polyfill": "^1.4.0"
+ "prompt-api-polyfill": "^1.10.0"
},
"devDependencies": {
+ "@eslint/js": "^10.0.1",
+ "eslint": "^10.0.2",
+ "eslint-config-google": "^0.14.0",
+ "eslint-config-prettier": "^10.1.8",
+ "globals": "^17.3.0",
"node-addon-api": "^8.5.0",
"node-gyp": "^12.2.0",
"prettier": "^3.8.1",
@@ -471,6 +476,150 @@
"node": ">=18"
}
},
+ "node_modules/@eslint-community/eslint-utils": {
+ "version": "4.9.1",
+ "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.9.1.tgz",
+ "integrity": "sha512-phrYmNiYppR7znFEdqgfWHXR6NCkZEK7hwWDHZUjit/2/U0r6XvkDl0SYnoM51Hq7FhCGdLDT6zxCCOY1hexsQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "eslint-visitor-keys": "^3.4.3"
+ },
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ },
+ "peerDependencies": {
+ "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0"
+ }
+ },
+ "node_modules/@eslint-community/eslint-utils/node_modules/eslint-visitor-keys": {
+ "version": "3.4.3",
+ "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz",
+ "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/@eslint-community/regexpp": {
+ "version": "4.12.2",
+ "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.12.2.tgz",
+ "integrity": "sha512-EriSTlt5OC9/7SXkRSCAhfSxxoSUgBm33OH+IkwbdpgoqsSsUg7y3uh+IICI/Qg4BBWr3U2i39RpmycbxMq4ew==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": "^12.0.0 || ^14.0.0 || >=16.0.0"
+ }
+ },
+ "node_modules/@eslint/config-array": {
+ "version": "0.23.2",
+ "resolved": "https://registry.npmjs.org/@eslint/config-array/-/config-array-0.23.2.tgz",
+ "integrity": "sha512-YF+fE6LV4v5MGWRGj7G404/OZzGNepVF8fxk7jqmqo3lrza7a0uUcDnROGRBG1WFC1omYUS/Wp1f42i0M+3Q3A==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "@eslint/object-schema": "^3.0.2",
+ "debug": "^4.3.1",
+ "minimatch": "^10.2.1"
+ },
+ "engines": {
+ "node": "^20.19.0 || ^22.13.0 || >=24"
+ }
+ },
+ "node_modules/@eslint/config-array/node_modules/minimatch": {
+ "version": "10.2.4",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-10.2.4.tgz",
+ "integrity": "sha512-oRjTw/97aTBN0RHbYCdtF1MQfvusSIBQM0IZEgzl6426+8jSC0nF1a/GmnVLpfB9yyr6g6FTqWqiZVbxrtaCIg==",
+ "dev": true,
+ "license": "BlueOak-1.0.0",
+ "dependencies": {
+ "brace-expansion": "^5.0.2"
+ },
+ "engines": {
+ "node": "18 || 20 || >=22"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/@eslint/config-helpers": {
+ "version": "0.5.2",
+ "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.5.2.tgz",
+ "integrity": "sha512-a5MxrdDXEvqnIq+LisyCX6tQMPF/dSJpCfBgBauY+pNZ28yCtSsTvyTYrMhaI+LK26bVyCJfJkT0u8KIj2i1dQ==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "@eslint/core": "^1.1.0"
+ },
+ "engines": {
+ "node": "^20.19.0 || ^22.13.0 || >=24"
+ }
+ },
+ "node_modules/@eslint/core": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/@eslint/core/-/core-1.1.0.tgz",
+ "integrity": "sha512-/nr9K9wkr3P1EzFTdFdMoLuo1PmIxjmwvPozwoSodjNBdefGujXQUF93u1DDZpEaTuDvMsIQddsd35BwtrW9Xw==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "@types/json-schema": "^7.0.15"
+ },
+ "engines": {
+ "node": "^20.19.0 || ^22.13.0 || >=24"
+ }
+ },
+ "node_modules/@eslint/js": {
+ "version": "10.0.1",
+ "resolved": "https://registry.npmjs.org/@eslint/js/-/js-10.0.1.tgz",
+ "integrity": "sha512-zeR9k5pd4gxjZ0abRoIaxdc7I3nDktoXZk2qOv9gCNWx3mVwEn32VRhyLaRsDiJjTs0xq/T8mfPtyuXu7GWBcA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": "^20.19.0 || ^22.13.0 || >=24"
+ },
+ "funding": {
+ "url": "https://eslint.org/donate"
+ },
+ "peerDependencies": {
+ "eslint": "^10.0.0"
+ },
+ "peerDependenciesMeta": {
+ "eslint": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@eslint/object-schema": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/@eslint/object-schema/-/object-schema-3.0.2.tgz",
+ "integrity": "sha512-HOy56KJt48Bx8KmJ+XGQNSUMT/6dZee/M54XyUyuvTvPXJmsERRvBchsUVx1UMe1WwIH49XLAczNC7V2INsuUw==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "engines": {
+ "node": "^20.19.0 || ^22.13.0 || >=24"
+ }
+ },
+ "node_modules/@eslint/plugin-kit": {
+ "version": "0.6.0",
+ "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.6.0.tgz",
+ "integrity": "sha512-bIZEUzOI1jkhviX2cp5vNyXQc6olzb2ohewQubuYlMXZ2Q/XjBO0x0XhGPvc9fjSIiUN0vw+0hq53BJ4eQSJKQ==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "@eslint/core": "^1.1.0",
+ "levn": "^0.4.1"
+ },
+ "engines": {
+ "node": "^20.19.0 || ^22.13.0 || >=24"
+ }
+ },
"node_modules/@firebase/ai": {
"version": "2.8.0",
"resolved": "https://registry.npmjs.org/@firebase/ai/-/ai-2.8.0.tgz",
@@ -1084,9 +1233,9 @@
"license": "Apache-2.0"
},
"node_modules/@google/genai": {
- "version": "1.42.0",
- "resolved": "https://registry.npmjs.org/@google/genai/-/genai-1.42.0.tgz",
- "integrity": "sha512-+3nlMTcrQufbQ8IumGkOphxD5Pd5kKyJOzLcnY0/1IuE8upJk5aLmoexZ2BJhBp1zAjRJMEB4a2CJwKI9e2EYw==",
+ "version": "1.43.0",
+ "resolved": "https://registry.npmjs.org/@google/genai/-/genai-1.43.0.tgz",
+ "integrity": "sha512-hklCsJNdMlDM1IwcCVcGQFBg2izY0+t5BIGbRsxi2UnKi6AGKL7pqJqmBDNRbw0bYCs4y3NA7TB+fkKfP/Nrdw==",
"license": "Apache-2.0",
"dependencies": {
"google-auth-library": "^10.3.0",
@@ -1158,6 +1307,58 @@
"sharp": "^0.34.1"
}
},
+ "node_modules/@humanfs/core": {
+ "version": "0.19.1",
+ "resolved": "https://registry.npmjs.org/@humanfs/core/-/core-0.19.1.tgz",
+ "integrity": "sha512-5DyQ4+1JEUzejeK1JGICcideyfUbGixgS9jNgex5nqkW+cY7WZhxBigmieN5Qnw9ZosSNVC9KQKyb+GUaGyKUA==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "engines": {
+ "node": ">=18.18.0"
+ }
+ },
+ "node_modules/@humanfs/node": {
+ "version": "0.16.7",
+ "resolved": "https://registry.npmjs.org/@humanfs/node/-/node-0.16.7.tgz",
+ "integrity": "sha512-/zUx+yOsIrG4Y43Eh2peDeKCxlRt/gET6aHfaKpuq267qXdYDFViVHfMaLyygZOnl0kGWxFIgsBy8QFuTLUXEQ==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "dependencies": {
+ "@humanfs/core": "^0.19.1",
+ "@humanwhocodes/retry": "^0.4.0"
+ },
+ "engines": {
+ "node": ">=18.18.0"
+ }
+ },
+ "node_modules/@humanwhocodes/module-importer": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz",
+ "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "engines": {
+ "node": ">=12.22"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/nzakas"
+ }
+ },
+ "node_modules/@humanwhocodes/retry": {
+ "version": "0.4.3",
+ "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.4.3.tgz",
+ "integrity": "sha512-bV0Tgo9K4hfPCek+aMAn81RppFKv2ySDQeMoSZuvTASywNTnVJCArCZE2FWqpvIatKu7VMRLWlR1EazvVhDyhQ==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "engines": {
+ "node": ">=18.18"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/nzakas"
+ }
+ },
"node_modules/@img/colour": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/@img/colour/-/colour-1.0.0.tgz",
@@ -1767,9 +1968,9 @@
"license": "BSD-3-Clause"
},
"node_modules/@rollup/rollup-android-arm-eabi": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.57.1.tgz",
- "integrity": "sha512-A6ehUVSiSaaliTxai040ZpZ2zTevHYbvu/lDoeAteHI8QnaosIzm4qwtezfRg1jOYaUmnzLX1AOD6Z+UJjtifg==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.59.0.tgz",
+ "integrity": "sha512-upnNBkA6ZH2VKGcBj9Fyl9IGNPULcjXRlg0LLeaioQWueH30p6IXtJEbKAgvyv+mJaMxSm1l6xwDXYjpEMiLMg==",
"cpu": [
"arm"
],
@@ -1781,9 +1982,9 @@
]
},
"node_modules/@rollup/rollup-android-arm64": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.57.1.tgz",
- "integrity": "sha512-dQaAddCY9YgkFHZcFNS/606Exo8vcLHwArFZ7vxXq4rigo2bb494/xKMMwRRQW6ug7Js6yXmBZhSBRuBvCCQ3w==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.59.0.tgz",
+ "integrity": "sha512-hZ+Zxj3SySm4A/DylsDKZAeVg0mvi++0PYVceVyX7hemkw7OreKdCvW2oQ3T1FMZvCaQXqOTHb8qmBShoqk69Q==",
"cpu": [
"arm64"
],
@@ -1795,9 +1996,9 @@
]
},
"node_modules/@rollup/rollup-darwin-arm64": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.57.1.tgz",
- "integrity": "sha512-crNPrwJOrRxagUYeMn/DZwqN88SDmwaJ8Cvi/TN1HnWBU7GwknckyosC2gd0IqYRsHDEnXf328o9/HC6OkPgOg==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.59.0.tgz",
+ "integrity": "sha512-W2Psnbh1J8ZJw0xKAd8zdNgF9HRLkdWwwdWqubSVk0pUuQkoHnv7rx4GiF9rT4t5DIZGAsConRE3AxCdJ4m8rg==",
"cpu": [
"arm64"
],
@@ -1809,9 +2010,9 @@
]
},
"node_modules/@rollup/rollup-darwin-x64": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.57.1.tgz",
- "integrity": "sha512-Ji8g8ChVbKrhFtig5QBV7iMaJrGtpHelkB3lsaKzadFBe58gmjfGXAOfI5FV0lYMH8wiqsxKQ1C9B0YTRXVy4w==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.59.0.tgz",
+ "integrity": "sha512-ZW2KkwlS4lwTv7ZVsYDiARfFCnSGhzYPdiOU4IM2fDbL+QGlyAbjgSFuqNRbSthybLbIJ915UtZBtmuLrQAT/w==",
"cpu": [
"x64"
],
@@ -1823,9 +2024,9 @@
]
},
"node_modules/@rollup/rollup-freebsd-arm64": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-arm64/-/rollup-freebsd-arm64-4.57.1.tgz",
- "integrity": "sha512-R+/WwhsjmwodAcz65guCGFRkMb4gKWTcIeLy60JJQbXrJ97BOXHxnkPFrP+YwFlaS0m+uWJTstrUA9o+UchFug==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-arm64/-/rollup-freebsd-arm64-4.59.0.tgz",
+ "integrity": "sha512-EsKaJ5ytAu9jI3lonzn3BgG8iRBjV4LxZexygcQbpiU0wU0ATxhNVEpXKfUa0pS05gTcSDMKpn3Sx+QB9RlTTA==",
"cpu": [
"arm64"
],
@@ -1837,9 +2038,9 @@
]
},
"node_modules/@rollup/rollup-freebsd-x64": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-x64/-/rollup-freebsd-x64-4.57.1.tgz",
- "integrity": "sha512-IEQTCHeiTOnAUC3IDQdzRAGj3jOAYNr9kBguI7MQAAZK3caezRrg0GxAb6Hchg4lxdZEI5Oq3iov/w/hnFWY9Q==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-x64/-/rollup-freebsd-x64-4.59.0.tgz",
+ "integrity": "sha512-d3DuZi2KzTMjImrxoHIAODUZYoUUMsuUiY4SRRcJy6NJoZ6iIqWnJu9IScV9jXysyGMVuW+KNzZvBLOcpdl3Vg==",
"cpu": [
"x64"
],
@@ -1851,9 +2052,9 @@
]
},
"node_modules/@rollup/rollup-linux-arm-gnueabihf": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.57.1.tgz",
- "integrity": "sha512-F8sWbhZ7tyuEfsmOxwc2giKDQzN3+kuBLPwwZGyVkLlKGdV1nvnNwYD0fKQ8+XS6hp9nY7B+ZeK01EBUE7aHaw==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.59.0.tgz",
+ "integrity": "sha512-t4ONHboXi/3E0rT6OZl1pKbl2Vgxf9vJfWgmUoCEVQVxhW6Cw/c8I6hbbu7DAvgp82RKiH7TpLwxnJeKv2pbsw==",
"cpu": [
"arm"
],
@@ -1865,9 +2066,9 @@
]
},
"node_modules/@rollup/rollup-linux-arm-musleabihf": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.57.1.tgz",
- "integrity": "sha512-rGfNUfn0GIeXtBP1wL5MnzSj98+PZe/AXaGBCRmT0ts80lU5CATYGxXukeTX39XBKsxzFpEeK+Mrp9faXOlmrw==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.59.0.tgz",
+ "integrity": "sha512-CikFT7aYPA2ufMD086cVORBYGHffBo4K8MQ4uPS/ZnY54GKj36i196u8U+aDVT2LX4eSMbyHtyOh7D7Zvk2VvA==",
"cpu": [
"arm"
],
@@ -1879,9 +2080,9 @@
]
},
"node_modules/@rollup/rollup-linux-arm64-gnu": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.57.1.tgz",
- "integrity": "sha512-MMtej3YHWeg/0klK2Qodf3yrNzz6CGjo2UntLvk2RSPlhzgLvYEB3frRvbEF2wRKh1Z2fDIg9KRPe1fawv7C+g==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.59.0.tgz",
+ "integrity": "sha512-jYgUGk5aLd1nUb1CtQ8E+t5JhLc9x5WdBKew9ZgAXg7DBk0ZHErLHdXM24rfX+bKrFe+Xp5YuJo54I5HFjGDAA==",
"cpu": [
"arm64"
],
@@ -1893,9 +2094,9 @@
]
},
"node_modules/@rollup/rollup-linux-arm64-musl": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.57.1.tgz",
- "integrity": "sha512-1a/qhaaOXhqXGpMFMET9VqwZakkljWHLmZOX48R0I/YLbhdxr1m4gtG1Hq7++VhVUmf+L3sTAf9op4JlhQ5u1Q==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.59.0.tgz",
+ "integrity": "sha512-peZRVEdnFWZ5Bh2KeumKG9ty7aCXzzEsHShOZEFiCQlDEepP1dpUl/SrUNXNg13UmZl+gzVDPsiCwnV1uI0RUA==",
"cpu": [
"arm64"
],
@@ -1907,9 +2108,9 @@
]
},
"node_modules/@rollup/rollup-linux-loong64-gnu": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-loong64-gnu/-/rollup-linux-loong64-gnu-4.57.1.tgz",
- "integrity": "sha512-QWO6RQTZ/cqYtJMtxhkRkidoNGXc7ERPbZN7dVW5SdURuLeVU7lwKMpo18XdcmpWYd0qsP1bwKPf7DNSUinhvA==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-loong64-gnu/-/rollup-linux-loong64-gnu-4.59.0.tgz",
+ "integrity": "sha512-gbUSW/97f7+r4gHy3Jlup8zDG190AuodsWnNiXErp9mT90iCy9NKKU0Xwx5k8VlRAIV2uU9CsMnEFg/xXaOfXg==",
"cpu": [
"loong64"
],
@@ -1921,9 +2122,9 @@
]
},
"node_modules/@rollup/rollup-linux-loong64-musl": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-loong64-musl/-/rollup-linux-loong64-musl-4.57.1.tgz",
- "integrity": "sha512-xpObYIf+8gprgWaPP32xiN5RVTi/s5FCR+XMXSKmhfoJjrpRAjCuuqQXyxUa/eJTdAE6eJ+KDKaoEqjZQxh3Gw==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-loong64-musl/-/rollup-linux-loong64-musl-4.59.0.tgz",
+ "integrity": "sha512-yTRONe79E+o0FWFijasoTjtzG9EBedFXJMl888NBEDCDV9I2wGbFFfJQQe63OijbFCUZqxpHz1GzpbtSFikJ4Q==",
"cpu": [
"loong64"
],
@@ -1935,9 +2136,9 @@
]
},
"node_modules/@rollup/rollup-linux-ppc64-gnu": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-ppc64-gnu/-/rollup-linux-ppc64-gnu-4.57.1.tgz",
- "integrity": "sha512-4BrCgrpZo4hvzMDKRqEaW1zeecScDCR+2nZ86ATLhAoJ5FQ+lbHVD3ttKe74/c7tNT9c6F2viwB3ufwp01Oh2w==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-ppc64-gnu/-/rollup-linux-ppc64-gnu-4.59.0.tgz",
+ "integrity": "sha512-sw1o3tfyk12k3OEpRddF68a1unZ5VCN7zoTNtSn2KndUE+ea3m3ROOKRCZxEpmT9nsGnogpFP9x6mnLTCaoLkA==",
"cpu": [
"ppc64"
],
@@ -1949,9 +2150,9 @@
]
},
"node_modules/@rollup/rollup-linux-ppc64-musl": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-ppc64-musl/-/rollup-linux-ppc64-musl-4.57.1.tgz",
- "integrity": "sha512-NOlUuzesGauESAyEYFSe3QTUguL+lvrN1HtwEEsU2rOwdUDeTMJdO5dUYl/2hKf9jWydJrO9OL/XSSf65R5+Xw==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-ppc64-musl/-/rollup-linux-ppc64-musl-4.59.0.tgz",
+ "integrity": "sha512-+2kLtQ4xT3AiIxkzFVFXfsmlZiG5FXYW7ZyIIvGA7Bdeuh9Z0aN4hVyXS/G1E9bTP/vqszNIN/pUKCk/BTHsKA==",
"cpu": [
"ppc64"
],
@@ -1963,9 +2164,9 @@
]
},
"node_modules/@rollup/rollup-linux-riscv64-gnu": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.57.1.tgz",
- "integrity": "sha512-ptA88htVp0AwUUqhVghwDIKlvJMD/fmL/wrQj99PRHFRAG6Z5nbWoWG4o81Nt9FT+IuqUQi+L31ZKAFeJ5Is+A==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.59.0.tgz",
+ "integrity": "sha512-NDYMpsXYJJaj+I7UdwIuHHNxXZ/b/N2hR15NyH3m2qAtb/hHPA4g4SuuvrdxetTdndfj9b1WOmy73kcPRoERUg==",
"cpu": [
"riscv64"
],
@@ -1977,9 +2178,9 @@
]
},
"node_modules/@rollup/rollup-linux-riscv64-musl": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-musl/-/rollup-linux-riscv64-musl-4.57.1.tgz",
- "integrity": "sha512-S51t7aMMTNdmAMPpBg7OOsTdn4tySRQvklmL3RpDRyknk87+Sp3xaumlatU+ppQ+5raY7sSTcC2beGgvhENfuw==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-musl/-/rollup-linux-riscv64-musl-4.59.0.tgz",
+ "integrity": "sha512-nLckB8WOqHIf1bhymk+oHxvM9D3tyPndZH8i8+35p/1YiVoVswPid2yLzgX7ZJP0KQvnkhM4H6QZ5m0LzbyIAg==",
"cpu": [
"riscv64"
],
@@ -1991,9 +2192,9 @@
]
},
"node_modules/@rollup/rollup-linux-s390x-gnu": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.57.1.tgz",
- "integrity": "sha512-Bl00OFnVFkL82FHbEqy3k5CUCKH6OEJL54KCyx2oqsmZnFTR8IoNqBF+mjQVcRCT5sB6yOvK8A37LNm/kPJiZg==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.59.0.tgz",
+ "integrity": "sha512-oF87Ie3uAIvORFBpwnCvUzdeYUqi2wY6jRFWJAy1qus/udHFYIkplYRW+wo+GRUP4sKzYdmE1Y3+rY5Gc4ZO+w==",
"cpu": [
"s390x"
],
@@ -2005,9 +2206,9 @@
]
},
"node_modules/@rollup/rollup-linux-x64-gnu": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.57.1.tgz",
- "integrity": "sha512-ABca4ceT4N+Tv/GtotnWAeXZUZuM/9AQyCyKYyKnpk4yoA7QIAuBt6Hkgpw8kActYlew2mvckXkvx0FfoInnLg==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.59.0.tgz",
+ "integrity": "sha512-3AHmtQq/ppNuUspKAlvA8HtLybkDflkMuLK4DPo77DfthRb71V84/c4MlWJXixZz4uruIH4uaa07IqoAkG64fg==",
"cpu": [
"x64"
],
@@ -2019,9 +2220,9 @@
]
},
"node_modules/@rollup/rollup-linux-x64-musl": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.57.1.tgz",
- "integrity": "sha512-HFps0JeGtuOR2convgRRkHCekD7j+gdAuXM+/i6kGzQtFhlCtQkpwtNzkNj6QhCDp7DRJ7+qC/1Vg2jt5iSOFw==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.59.0.tgz",
+ "integrity": "sha512-2UdiwS/9cTAx7qIUZB/fWtToJwvt0Vbo0zmnYt7ED35KPg13Q0ym1g442THLC7VyI6JfYTP4PiSOWyoMdV2/xg==",
"cpu": [
"x64"
],
@@ -2033,9 +2234,9 @@
]
},
"node_modules/@rollup/rollup-openbsd-x64": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-openbsd-x64/-/rollup-openbsd-x64-4.57.1.tgz",
- "integrity": "sha512-H+hXEv9gdVQuDTgnqD+SQffoWoc0Of59AStSzTEj/feWTBAnSfSD3+Dql1ZruJQxmykT/JVY0dE8Ka7z0DH1hw==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-openbsd-x64/-/rollup-openbsd-x64-4.59.0.tgz",
+ "integrity": "sha512-M3bLRAVk6GOwFlPTIxVBSYKUaqfLrn8l0psKinkCFxl4lQvOSz8ZrKDz2gxcBwHFpci0B6rttydI4IpS4IS/jQ==",
"cpu": [
"x64"
],
@@ -2047,9 +2248,9 @@
]
},
"node_modules/@rollup/rollup-openharmony-arm64": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-openharmony-arm64/-/rollup-openharmony-arm64-4.57.1.tgz",
- "integrity": "sha512-4wYoDpNg6o/oPximyc/NG+mYUejZrCU2q+2w6YZqrAs2UcNUChIZXjtafAiiZSUc7On8v5NyNj34Kzj/Ltk6dQ==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-openharmony-arm64/-/rollup-openharmony-arm64-4.59.0.tgz",
+ "integrity": "sha512-tt9KBJqaqp5i5HUZzoafHZX8b5Q2Fe7UjYERADll83O4fGqJ49O1FsL6LpdzVFQcpwvnyd0i+K/VSwu/o/nWlA==",
"cpu": [
"arm64"
],
@@ -2061,9 +2262,9 @@
]
},
"node_modules/@rollup/rollup-win32-arm64-msvc": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.57.1.tgz",
- "integrity": "sha512-O54mtsV/6LW3P8qdTcamQmuC990HDfR71lo44oZMZlXU4tzLrbvTii87Ni9opq60ds0YzuAlEr/GNwuNluZyMQ==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.59.0.tgz",
+ "integrity": "sha512-V5B6mG7OrGTwnxaNUzZTDTjDS7F75PO1ae6MJYdiMu60sq0CqN5CVeVsbhPxalupvTX8gXVSU9gq+Rx1/hvu6A==",
"cpu": [
"arm64"
],
@@ -2075,9 +2276,9 @@
]
},
"node_modules/@rollup/rollup-win32-ia32-msvc": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.57.1.tgz",
- "integrity": "sha512-P3dLS+IerxCT/7D2q2FYcRdWRl22dNbrbBEtxdWhXrfIMPP9lQhb5h4Du04mdl5Woq05jVCDPCMF7Ub0NAjIew==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.59.0.tgz",
+ "integrity": "sha512-UKFMHPuM9R0iBegwzKF4y0C4J9u8C6MEJgFuXTBerMk7EJ92GFVFYBfOZaSGLu6COf7FxpQNqhNS4c4icUPqxA==",
"cpu": [
"ia32"
],
@@ -2089,9 +2290,9 @@
]
},
"node_modules/@rollup/rollup-win32-x64-gnu": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-gnu/-/rollup-win32-x64-gnu-4.57.1.tgz",
- "integrity": "sha512-VMBH2eOOaKGtIJYleXsi2B8CPVADrh+TyNxJ4mWPnKfLB/DBUmzW+5m1xUrcwWoMfSLagIRpjUFeW5CO5hyciQ==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-gnu/-/rollup-win32-x64-gnu-4.59.0.tgz",
+ "integrity": "sha512-laBkYlSS1n2L8fSo1thDNGrCTQMmxjYY5G0WFWjFFYZkKPjsMBsgJfGf4TLxXrF6RyhI60L8TMOjBMvXiTcxeA==",
"cpu": [
"x64"
],
@@ -2103,9 +2304,9 @@
]
},
"node_modules/@rollup/rollup-win32-x64-msvc": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.57.1.tgz",
- "integrity": "sha512-mxRFDdHIWRxg3UfIIAwCm6NzvxG0jDX/wBN6KsQFTvKFqqg9vTrWUE68qEjHt19A5wwx5X5aUi2zuZT7YR0jrA==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.59.0.tgz",
+ "integrity": "sha512-2HRCml6OztYXyJXAvdDXPKcawukWY2GpR5/nxKp4iBgiO3wcoEGkAaqctIbZcNB6KlUQBIqt8VYkNSj2397EfA==",
"cpu": [
"x64"
],
@@ -2116,6 +2317,13 @@
"win32"
]
},
+ "node_modules/@types/esrecurse": {
+ "version": "4.3.1",
+ "resolved": "https://registry.npmjs.org/@types/esrecurse/-/esrecurse-4.3.1.tgz",
+ "integrity": "sha512-xJBAbDifo5hpffDBuHl0Y8ywswbiAp/Wi7Y/GtAgSlZyIABppyurxVueOPE8LUQOxdlgi6Zqce7uoEpqNTeiUw==",
+ "dev": true,
+ "license": "MIT"
+ },
"node_modules/@types/estree": {
"version": "1.0.8",
"resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.8.tgz",
@@ -2123,6 +2331,13 @@
"dev": true,
"license": "MIT"
},
+ "node_modules/@types/json-schema": {
+ "version": "7.0.15",
+ "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz",
+ "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==",
+ "dev": true,
+ "license": "MIT"
+ },
"node_modules/@types/node": {
"version": "25.3.0",
"resolved": "https://registry.npmjs.org/@types/node/-/node-25.3.0.tgz",
@@ -2148,6 +2363,30 @@
"node": "^20.17.0 || >=22.9.0"
}
},
+ "node_modules/acorn": {
+ "version": "8.16.0",
+ "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.16.0.tgz",
+ "integrity": "sha512-UVJyE9MttOsBQIDKw1skb9nAwQuR5wuGD3+82K6JgJlm/Y+KI92oNsMNGZCYdDsVtRHSak0pcV5Dno5+4jh9sw==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "bin": {
+ "acorn": "bin/acorn"
+ },
+ "engines": {
+ "node": ">=0.4.0"
+ }
+ },
+ "node_modules/acorn-jsx": {
+ "version": "5.3.2",
+ "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz",
+ "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==",
+ "dev": true,
+ "license": "MIT",
+ "peerDependencies": {
+ "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0"
+ }
+ },
"node_modules/agent-base": {
"version": "7.1.4",
"resolved": "https://registry.npmjs.org/agent-base/-/agent-base-7.1.4.tgz",
@@ -2157,6 +2396,23 @@
"node": ">= 14"
}
},
+ "node_modules/ajv": {
+ "version": "6.14.0",
+ "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.14.0.tgz",
+ "integrity": "sha512-IWrosm/yrn43eiKqkfkHis7QioDleaXQHdDVPKg0FSwwd/DuvyX79TZnFOnYpB7dcsFAMmtFztZuXPDvSePkFw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "fast-deep-equal": "^3.1.1",
+ "fast-json-stable-stringify": "^2.0.0",
+ "json-schema-traverse": "^0.4.1",
+ "uri-js": "^4.2.2"
+ },
+ "funding": {
+ "type": "github",
+ "url": "https://github.com/sponsors/epoberezkin"
+ }
+ },
"node_modules/ansi-regex": {
"version": "6.2.2",
"resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.2.tgz",
@@ -2182,10 +2438,13 @@
}
},
"node_modules/balanced-match": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz",
- "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==",
- "license": "MIT"
+ "version": "4.0.4",
+ "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-4.0.4.tgz",
+ "integrity": "sha512-BLrgEcRTwX2o6gGxGOCNyMvGSp35YofuYzw9h1IMTRmKqttAZZVU67bdb9Pr2vUHA8+j3i2tJfjO6C6+4myGTA==",
+ "license": "MIT",
+ "engines": {
+ "node": "18 || 20 || >=22"
+ }
},
"node_modules/base64-js": {
"version": "1.5.1",
@@ -2224,12 +2483,15 @@
"license": "MIT"
},
"node_modules/brace-expansion": {
- "version": "2.0.2",
- "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.2.tgz",
- "integrity": "sha512-Jt0vHyM+jmUBqojB7E1NIYadt0vI0Qxjxd2TErW94wDz+E2LAm5vKMXXwg6ZZBTHPuUlDgQHKXvjGBdfcF1ZDQ==",
+ "version": "5.0.3",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-5.0.3.tgz",
+ "integrity": "sha512-fy6KJm2RawA5RcHkLa1z/ScpBeA762UF9KmZQxwIbDtRJrgLzM10depAiEQ+CXYcoiqW1/m96OAAoke2nE9EeA==",
"license": "MIT",
"dependencies": {
- "balanced-match": "^1.0.0"
+ "balanced-match": "^4.0.2"
+ },
+ "engines": {
+ "node": "18 || 20 || >=22"
}
},
"node_modules/buffer-equal-constant-time": {
@@ -2270,29 +2532,6 @@
"node": "^20.17.0 || >=22.9.0"
}
},
- "node_modules/cacache/node_modules/balanced-match": {
- "version": "4.0.4",
- "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-4.0.4.tgz",
- "integrity": "sha512-BLrgEcRTwX2o6gGxGOCNyMvGSp35YofuYzw9h1IMTRmKqttAZZVU67bdb9Pr2vUHA8+j3i2tJfjO6C6+4myGTA==",
- "dev": true,
- "license": "MIT",
- "engines": {
- "node": "18 || 20 || >=22"
- }
- },
- "node_modules/cacache/node_modules/brace-expansion": {
- "version": "5.0.3",
- "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-5.0.3.tgz",
- "integrity": "sha512-fy6KJm2RawA5RcHkLa1z/ScpBeA762UF9KmZQxwIbDtRJrgLzM10depAiEQ+CXYcoiqW1/m96OAAoke2nE9EeA==",
- "dev": true,
- "license": "MIT",
- "dependencies": {
- "balanced-match": "^4.0.2"
- },
- "engines": {
- "node": "18 || 20 || >=22"
- }
- },
"node_modules/cacache/node_modules/glob": {
"version": "13.0.6",
"resolved": "https://registry.npmjs.org/glob/-/glob-13.0.6.tgz",
@@ -2508,6 +2747,13 @@
}
}
},
+ "node_modules/deep-is": {
+ "version": "0.1.4",
+ "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz",
+ "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==",
+ "dev": true,
+ "license": "MIT"
+ },
"node_modules/define-data-property": {
"version": "1.1.4",
"resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz",
@@ -2693,6 +2939,204 @@
"url": "https://github.com/sponsors/sindresorhus"
}
},
+ "node_modules/eslint": {
+ "version": "10.0.2",
+ "resolved": "https://registry.npmjs.org/eslint/-/eslint-10.0.2.tgz",
+ "integrity": "sha512-uYixubwmqJZH+KLVYIVKY1JQt7tysXhtj21WSvjcSmU5SVNzMus1bgLe+pAt816yQ8opKfheVVoPLqvVMGejYw==",
+ "dev": true,
+ "license": "MIT",
+ "peer": true,
+ "dependencies": {
+ "@eslint-community/eslint-utils": "^4.8.0",
+ "@eslint-community/regexpp": "^4.12.2",
+ "@eslint/config-array": "^0.23.2",
+ "@eslint/config-helpers": "^0.5.2",
+ "@eslint/core": "^1.1.0",
+ "@eslint/plugin-kit": "^0.6.0",
+ "@humanfs/node": "^0.16.6",
+ "@humanwhocodes/module-importer": "^1.0.1",
+ "@humanwhocodes/retry": "^0.4.2",
+ "@types/estree": "^1.0.6",
+ "ajv": "^6.14.0",
+ "cross-spawn": "^7.0.6",
+ "debug": "^4.3.2",
+ "escape-string-regexp": "^4.0.0",
+ "eslint-scope": "^9.1.1",
+ "eslint-visitor-keys": "^5.0.1",
+ "espree": "^11.1.1",
+ "esquery": "^1.7.0",
+ "esutils": "^2.0.2",
+ "fast-deep-equal": "^3.1.3",
+ "file-entry-cache": "^8.0.0",
+ "find-up": "^5.0.0",
+ "glob-parent": "^6.0.2",
+ "ignore": "^5.2.0",
+ "imurmurhash": "^0.1.4",
+ "is-glob": "^4.0.0",
+ "json-stable-stringify-without-jsonify": "^1.0.1",
+ "minimatch": "^10.2.1",
+ "natural-compare": "^1.4.0",
+ "optionator": "^0.9.3"
+ },
+ "bin": {
+ "eslint": "bin/eslint.js"
+ },
+ "engines": {
+ "node": "^20.19.0 || ^22.13.0 || >=24"
+ },
+ "funding": {
+ "url": "https://eslint.org/donate"
+ },
+ "peerDependencies": {
+ "jiti": "*"
+ },
+ "peerDependenciesMeta": {
+ "jiti": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/eslint-config-google": {
+ "version": "0.14.0",
+ "resolved": "https://registry.npmjs.org/eslint-config-google/-/eslint-config-google-0.14.0.tgz",
+ "integrity": "sha512-WsbX4WbjuMvTdeVL6+J3rK1RGhCTqjsFjX7UMSMgZiyxxaNLkoJENbrGExzERFeoTpGw3F3FypTiWAP9ZXzkEw==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "engines": {
+ "node": ">=0.10.0"
+ },
+ "peerDependencies": {
+ "eslint": ">=5.16.0"
+ }
+ },
+ "node_modules/eslint-config-prettier": {
+ "version": "10.1.8",
+ "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-10.1.8.tgz",
+ "integrity": "sha512-82GZUjRS0p/jganf6q1rEO25VSoHH0hKPCTrgillPjdI/3bgBhAE1QzHrHTizjpRvy6pGAvKjDJtk2pF9NDq8w==",
+ "dev": true,
+ "license": "MIT",
+ "bin": {
+ "eslint-config-prettier": "bin/cli.js"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint-config-prettier"
+ },
+ "peerDependencies": {
+ "eslint": ">=7.0.0"
+ }
+ },
+ "node_modules/eslint-scope": {
+ "version": "9.1.1",
+ "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-9.1.1.tgz",
+ "integrity": "sha512-GaUN0sWim5qc8KVErfPBWmc31LEsOkrUJbvJZV+xuL3u2phMUK4HIvXlWAakfC8W4nzlK+chPEAkYOYb5ZScIw==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "@types/esrecurse": "^4.3.1",
+ "@types/estree": "^1.0.8",
+ "esrecurse": "^4.3.0",
+ "estraverse": "^5.2.0"
+ },
+ "engines": {
+ "node": "^20.19.0 || ^22.13.0 || >=24"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/eslint-visitor-keys": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-5.0.1.tgz",
+ "integrity": "sha512-tD40eHxA35h0PEIZNeIjkHoDR4YjjJp34biM0mDvplBe//mB+IHCqHDGV7pxF+7MklTvighcCPPZC7ynWyjdTA==",
+ "dev": true,
+ "license": "Apache-2.0",
+ "engines": {
+ "node": "^20.19.0 || ^22.13.0 || >=24"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/eslint/node_modules/minimatch": {
+ "version": "10.2.4",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-10.2.4.tgz",
+ "integrity": "sha512-oRjTw/97aTBN0RHbYCdtF1MQfvusSIBQM0IZEgzl6426+8jSC0nF1a/GmnVLpfB9yyr6g6FTqWqiZVbxrtaCIg==",
+ "dev": true,
+ "license": "BlueOak-1.0.0",
+ "dependencies": {
+ "brace-expansion": "^5.0.2"
+ },
+ "engines": {
+ "node": "18 || 20 || >=22"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/isaacs"
+ }
+ },
+ "node_modules/espree": {
+ "version": "11.1.1",
+ "resolved": "https://registry.npmjs.org/espree/-/espree-11.1.1.tgz",
+ "integrity": "sha512-AVHPqQoZYc+RUM4/3Ly5udlZY/U4LS8pIG05jEjWM2lQMU/oaZ7qshzAl2YP1tfNmXfftH3ohurfwNAug+MnsQ==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "acorn": "^8.16.0",
+ "acorn-jsx": "^5.3.2",
+ "eslint-visitor-keys": "^5.0.1"
+ },
+ "engines": {
+ "node": "^20.19.0 || ^22.13.0 || >=24"
+ },
+ "funding": {
+ "url": "https://opencollective.com/eslint"
+ }
+ },
+ "node_modules/esquery": {
+ "version": "1.7.0",
+ "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.7.0.tgz",
+ "integrity": "sha512-Ap6G0WQwcU/LHsvLwON1fAQX9Zp0A2Y6Y/cJBl9r/JbW90Zyg4/zbG6zzKa2OTALELarYHmKu0GhpM5EO+7T0g==",
+ "dev": true,
+ "license": "BSD-3-Clause",
+ "dependencies": {
+ "estraverse": "^5.1.0"
+ },
+ "engines": {
+ "node": ">=0.10"
+ }
+ },
+ "node_modules/esrecurse": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz",
+ "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "estraverse": "^5.2.0"
+ },
+ "engines": {
+ "node": ">=4.0"
+ }
+ },
+ "node_modules/estraverse": {
+ "version": "5.3.0",
+ "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz",
+ "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "engines": {
+ "node": ">=4.0"
+ }
+ },
+ "node_modules/esutils": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz",
+ "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
"node_modules/exponential-backoff": {
"version": "3.1.3",
"resolved": "https://registry.npmjs.org/exponential-backoff/-/exponential-backoff-3.1.3.tgz",
@@ -2706,6 +3150,27 @@
"integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==",
"license": "MIT"
},
+ "node_modules/fast-deep-equal": {
+ "version": "3.1.3",
+ "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
+ "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/fast-json-stable-stringify": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz",
+ "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/fast-levenshtein": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz",
+ "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==",
+ "dev": true,
+ "license": "MIT"
+ },
"node_modules/faye-websocket": {
"version": "0.11.4",
"resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.11.4.tgz",
@@ -2759,6 +3224,36 @@
"node": "^12.20 || >= 14.13"
}
},
+ "node_modules/file-entry-cache": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-8.0.0.tgz",
+ "integrity": "sha512-XXTUwCvisa5oacNGRP9SfNtYBNAMi+RPwBFmblZEF7N7swHYQS6/Zfk7SRwx4D5j3CH211YNRco1DEMNVfZCnQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "flat-cache": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=16.0.0"
+ }
+ },
+ "node_modules/find-up": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz",
+ "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "locate-path": "^6.0.0",
+ "path-exists": "^4.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
"node_modules/firebase": {
"version": "12.9.0",
"resolved": "https://registry.npmjs.org/firebase/-/firebase-12.9.0.tgz",
@@ -2795,12 +3290,33 @@
"@firebase/util": "1.13.0"
}
},
+ "node_modules/flat-cache": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-4.0.1.tgz",
+ "integrity": "sha512-f7ccFPK3SXFHpx15UIGyRJ/FJQctuKZ0zVuN3frBo4HnK3cay9VEW0R6yPYFHC0AgqhukPzKjq22t5DmAyqGyw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "flatted": "^3.2.9",
+ "keyv": "^4.5.4"
+ },
+ "engines": {
+ "node": ">=16"
+ }
+ },
"node_modules/flatbuffers": {
"version": "25.9.23",
"resolved": "https://registry.npmjs.org/flatbuffers/-/flatbuffers-25.9.23.tgz",
"integrity": "sha512-MI1qs7Lo4Syw0EOzUl0xjs2lsoeqFku44KpngfIduHBYvzm8h2+7K8YMQh1JtVVVrUvhLpNwqVi4DERegUJhPQ==",
"license": "Apache-2.0"
},
+ "node_modules/flatted": {
+ "version": "3.3.3",
+ "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.3.tgz",
+ "integrity": "sha512-GX+ysw4PBCz0PzosHDepZGANEuFCMLrnRTiEy9McGjmkCQYwRq4A/X786G/fjM/+OjsWSU1ZrY5qyARZmO/uwg==",
+ "dev": true,
+ "license": "ISC"
+ },
"node_modules/foreground-child": {
"version": "3.3.1",
"resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-3.3.1.tgz",
@@ -2916,6 +3432,19 @@
"url": "https://github.com/sponsors/isaacs"
}
},
+ "node_modules/glob-parent": {
+ "version": "6.0.2",
+ "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz",
+ "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==",
+ "dev": true,
+ "license": "ISC",
+ "dependencies": {
+ "is-glob": "^4.0.3"
+ },
+ "engines": {
+ "node": ">=10.13.0"
+ }
+ },
"node_modules/global-agent": {
"version": "3.0.0",
"resolved": "https://registry.npmjs.org/global-agent/-/global-agent-3.0.0.tgz",
@@ -2933,6 +3462,19 @@
"node": ">=10.0"
}
},
+ "node_modules/globals": {
+ "version": "17.3.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-17.3.0.tgz",
+ "integrity": "sha512-yMqGUQVVCkD4tqjOJf3TnrvaaHDMYp4VlUSObbkIiuCPe/ofdMBFIAcBbCSRFWOnos6qRiTVStDwqPLUclaxIw==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=18"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
"node_modules/globalthis": {
"version": "1.0.4",
"resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.4.tgz",
@@ -2950,17 +3492,16 @@
}
},
"node_modules/google-auth-library": {
- "version": "10.5.0",
- "resolved": "https://registry.npmjs.org/google-auth-library/-/google-auth-library-10.5.0.tgz",
- "integrity": "sha512-7ABviyMOlX5hIVD60YOfHw4/CxOfBhyduaYB+wbFWCWoni4N7SLcV46hrVRktuBbZjFC9ONyqamZITN7q3n32w==",
+ "version": "10.6.1",
+ "resolved": "https://registry.npmjs.org/google-auth-library/-/google-auth-library-10.6.1.tgz",
+ "integrity": "sha512-5awwuLrzNol+pFDmKJd0dKtZ0fPLAtoA5p7YO4ODsDu6ONJUVqbYwvv8y2ZBO5MBNp9TJXigB19710kYpBPdtA==",
"license": "Apache-2.0",
"dependencies": {
"base64-js": "^1.3.0",
"ecdsa-sig-formatter": "^1.0.11",
- "gaxios": "^7.0.0",
- "gcp-metadata": "^8.0.0",
- "google-logging-utils": "^1.0.0",
- "gtoken": "^8.0.0",
+ "gaxios": "7.1.3",
+ "gcp-metadata": "8.1.2",
+ "google-logging-utils": "1.1.3",
"jws": "^4.0.0"
},
"engines": {
@@ -2995,19 +3536,6 @@
"dev": true,
"license": "ISC"
},
- "node_modules/gtoken": {
- "version": "8.0.0",
- "resolved": "https://registry.npmjs.org/gtoken/-/gtoken-8.0.0.tgz",
- "integrity": "sha512-+CqsMbHPiSTdtSO14O51eMNlrp9N79gmeqmXeouJOhfucAedHw9noVe/n5uJk3tbKE6a+6ZCQg3RPhVhHByAIw==",
- "license": "MIT",
- "dependencies": {
- "gaxios": "^7.0.0",
- "jws": "^4.0.0"
- },
- "engines": {
- "node": ">=18"
- }
- },
"node_modules/guid-typescript": {
"version": "1.0.9",
"resolved": "https://registry.npmjs.org/guid-typescript/-/guid-typescript-1.0.9.tgz",
@@ -3086,6 +3614,16 @@
"integrity": "sha512-gchesWBzyvGHRO9W8tzUWFDycow5gwjvFKfyV9FF32Y7F50yZMp7mP+T2mJIWFx49zicqyC4uefHM17o6xKIVQ==",
"license": "ISC"
},
+ "node_modules/ignore": {
+ "version": "5.3.2",
+ "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.2.tgz",
+ "integrity": "sha512-hsBTNUqQTDwkWtcdYI2i06Y/nUBEsNEDJKjWdigLvegy8kDuJAS8uRlpkkcQpyEXL0Z/pjDy5HBmMjRCJ2gq+g==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">= 4"
+ }
+ },
"node_modules/imurmurhash": {
"version": "0.1.4",
"resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
@@ -3106,6 +3644,16 @@
"node": ">= 12"
}
},
+ "node_modules/is-extglob": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
+ "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
"node_modules/is-fullwidth-code-point": {
"version": "3.0.0",
"resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz",
@@ -3115,6 +3663,19 @@
"node": ">=8"
}
},
+ "node_modules/is-glob": {
+ "version": "4.0.3",
+ "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz",
+ "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "is-extglob": "^2.1.1"
+ },
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
"node_modules/isexe": {
"version": "2.0.0",
"resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
@@ -3145,6 +3706,27 @@
"bignumber.js": "^9.0.0"
}
},
+ "node_modules/json-buffer": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz",
+ "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/json-schema-traverse": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz",
+ "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==",
+ "dev": true,
+ "license": "MIT"
+ },
+ "node_modules/json-stable-stringify-without-jsonify": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz",
+ "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==",
+ "dev": true,
+ "license": "MIT"
+ },
"node_modules/json-stringify-safe": {
"version": "5.0.1",
"resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz",
@@ -3172,6 +3754,46 @@
"safe-buffer": "^5.0.1"
}
},
+ "node_modules/keyv": {
+ "version": "4.5.4",
+ "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz",
+ "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "json-buffer": "3.0.1"
+ }
+ },
+ "node_modules/levn": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz",
+ "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "prelude-ls": "^1.2.1",
+ "type-check": "~0.4.0"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/locate-path": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz",
+ "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "p-locate": "^5.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
"node_modules/lodash.camelcase": {
"version": "4.3.0",
"resolved": "https://registry.npmjs.org/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz",
@@ -3226,12 +3848,12 @@
}
},
"node_modules/minimatch": {
- "version": "9.0.5",
- "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz",
- "integrity": "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow==",
+ "version": "9.0.8",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.8.tgz",
+ "integrity": "sha512-reYkDYtj/b19TeqbNZCV4q9t+Yxylf/rYBsLb42SXJatTv4/ylq5lEiAmhA/IToxO7NI2UzNMghHoHuaqDkAjw==",
"license": "ISC",
"dependencies": {
- "brace-expansion": "^2.0.1"
+ "brace-expansion": "^5.0.2"
},
"engines": {
"node": ">=16 || 14 >=14.17"
@@ -3396,6 +4018,13 @@
"node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1"
}
},
+ "node_modules/natural-compare": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz",
+ "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==",
+ "dev": true,
+ "license": "MIT"
+ },
"node_modules/negotiator": {
"version": "1.0.0",
"resolved": "https://registry.npmjs.org/negotiator/-/negotiator-1.0.0.tgz",
@@ -3574,9 +4203,9 @@
"license": "MIT"
},
"node_modules/openai": {
- "version": "6.22.0",
- "resolved": "https://registry.npmjs.org/openai/-/openai-6.22.0.tgz",
- "integrity": "sha512-7Yvy17F33Bi9RutWbsaYt5hJEEJ/krRPOrwan+f9aCPuMat1WVsb2VNSII5W1EksKT6fF69TG/xj4XzodK3JZw==",
+ "version": "6.25.0",
+ "resolved": "https://registry.npmjs.org/openai/-/openai-6.25.0.tgz",
+ "integrity": "sha512-mEh6VZ2ds2AGGokWARo18aPISI1OhlgdEIC1ewhkZr8pSIT31dec0ecr9Nhxx0JlybyOgoAT1sWeKtwPZzJyww==",
"license": "Apache-2.0",
"bin": {
"openai": "bin/cli"
@@ -3594,6 +4223,56 @@
}
}
},
+ "node_modules/optionator": {
+ "version": "0.9.4",
+ "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.4.tgz",
+ "integrity": "sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "deep-is": "^0.1.3",
+ "fast-levenshtein": "^2.0.6",
+ "levn": "^0.4.1",
+ "prelude-ls": "^1.2.1",
+ "type-check": "^0.4.0",
+ "word-wrap": "^1.2.5"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
+ "node_modules/p-limit": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz",
+ "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "yocto-queue": "^0.1.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/p-locate": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz",
+ "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "p-limit": "^3.0.2"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
"node_modules/p-map": {
"version": "7.0.4",
"resolved": "https://registry.npmjs.org/p-map/-/p-map-7.0.4.tgz",
@@ -3626,6 +4305,16 @@
"integrity": "sha512-UEZIS3/by4OC8vL3P2dTXRETpebLI2NiI5vIrjaD/5UtrkFX/tNbwjTSRAGC/+7CAo2pIcBaRgWmcBBHcsaCIw==",
"license": "BlueOak-1.0.0"
},
+ "node_modules/path-exists": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz",
+ "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
"node_modules/path-key": {
"version": "3.1.1",
"resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz",
@@ -3706,6 +4395,16 @@
"node": "^10 || ^12 || >=14"
}
},
+ "node_modules/prelude-ls": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz",
+ "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
"node_modules/prettier": {
"version": "3.8.1",
"resolved": "https://registry.npmjs.org/prettier/-/prettier-3.8.1.tgz",
@@ -3757,15 +4456,15 @@
}
},
"node_modules/prompt-api-polyfill": {
- "version": "1.4.0",
- "resolved": "https://registry.npmjs.org/prompt-api-polyfill/-/prompt-api-polyfill-1.4.0.tgz",
- "integrity": "sha512-59DC8Kd/Og26Zy62XI3tWMgHRzT3A5PJnXFRW/LWv5Exyn8IXyLOZq86RRGD7YTtl6gJoag+dms6ecV506GmoQ==",
+ "version": "1.10.0",
+ "resolved": "https://registry.npmjs.org/prompt-api-polyfill/-/prompt-api-polyfill-1.10.0.tgz",
+ "integrity": "sha512-r5Zj7R7jNqO+Z9cjR39ov0Yw3hjectMteG8NUtXjpxROSJ7/zCho/QzFEFkJKryZIIwfCRfG4Gvk+49YB425hg==",
"license": "Apache-2.0",
"dependencies": {
- "@google/genai": "^1.42.0",
+ "@google/genai": "^1.43.0",
"@huggingface/transformers": "^3.8.1",
"firebase": "^12.9.0",
- "openai": "^6.22.0"
+ "openai": "^6.25.0"
}
},
"node_modules/protobufjs": {
@@ -3792,6 +4491,16 @@
"node": ">=12.0.0"
}
},
+ "node_modules/punycode": {
+ "version": "2.3.1",
+ "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz",
+ "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=6"
+ }
+ },
"node_modules/require-directory": {
"version": "2.1.1",
"resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz",
@@ -3843,9 +4552,9 @@
}
},
"node_modules/rollup": {
- "version": "4.57.1",
- "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.57.1.tgz",
- "integrity": "sha512-oQL6lgK3e2QZeQ7gcgIkS2YZPg5slw37hYufJ3edKlfQSGGm8ICoxswK15ntSzF/a8+h7ekRy7k7oWc3BQ7y8A==",
+ "version": "4.59.0",
+ "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.59.0.tgz",
+ "integrity": "sha512-2oMpl67a3zCH9H79LeMcbDhXW/UmWG/y2zuqnF2jQq5uq9TbM9TVyXvA4+t+ne2IIkBdrLpAaRQAvo7YI/Yyeg==",
"dev": true,
"license": "MIT",
"dependencies": {
@@ -3859,31 +4568,31 @@
"npm": ">=8.0.0"
},
"optionalDependencies": {
- "@rollup/rollup-android-arm-eabi": "4.57.1",
- "@rollup/rollup-android-arm64": "4.57.1",
- "@rollup/rollup-darwin-arm64": "4.57.1",
- "@rollup/rollup-darwin-x64": "4.57.1",
- "@rollup/rollup-freebsd-arm64": "4.57.1",
- "@rollup/rollup-freebsd-x64": "4.57.1",
- "@rollup/rollup-linux-arm-gnueabihf": "4.57.1",
- "@rollup/rollup-linux-arm-musleabihf": "4.57.1",
- "@rollup/rollup-linux-arm64-gnu": "4.57.1",
- "@rollup/rollup-linux-arm64-musl": "4.57.1",
- "@rollup/rollup-linux-loong64-gnu": "4.57.1",
- "@rollup/rollup-linux-loong64-musl": "4.57.1",
- "@rollup/rollup-linux-ppc64-gnu": "4.57.1",
- "@rollup/rollup-linux-ppc64-musl": "4.57.1",
- "@rollup/rollup-linux-riscv64-gnu": "4.57.1",
- "@rollup/rollup-linux-riscv64-musl": "4.57.1",
- "@rollup/rollup-linux-s390x-gnu": "4.57.1",
- "@rollup/rollup-linux-x64-gnu": "4.57.1",
- "@rollup/rollup-linux-x64-musl": "4.57.1",
- "@rollup/rollup-openbsd-x64": "4.57.1",
- "@rollup/rollup-openharmony-arm64": "4.57.1",
- "@rollup/rollup-win32-arm64-msvc": "4.57.1",
- "@rollup/rollup-win32-ia32-msvc": "4.57.1",
- "@rollup/rollup-win32-x64-gnu": "4.57.1",
- "@rollup/rollup-win32-x64-msvc": "4.57.1",
+ "@rollup/rollup-android-arm-eabi": "4.59.0",
+ "@rollup/rollup-android-arm64": "4.59.0",
+ "@rollup/rollup-darwin-arm64": "4.59.0",
+ "@rollup/rollup-darwin-x64": "4.59.0",
+ "@rollup/rollup-freebsd-arm64": "4.59.0",
+ "@rollup/rollup-freebsd-x64": "4.59.0",
+ "@rollup/rollup-linux-arm-gnueabihf": "4.59.0",
+ "@rollup/rollup-linux-arm-musleabihf": "4.59.0",
+ "@rollup/rollup-linux-arm64-gnu": "4.59.0",
+ "@rollup/rollup-linux-arm64-musl": "4.59.0",
+ "@rollup/rollup-linux-loong64-gnu": "4.59.0",
+ "@rollup/rollup-linux-loong64-musl": "4.59.0",
+ "@rollup/rollup-linux-ppc64-gnu": "4.59.0",
+ "@rollup/rollup-linux-ppc64-musl": "4.59.0",
+ "@rollup/rollup-linux-riscv64-gnu": "4.59.0",
+ "@rollup/rollup-linux-riscv64-musl": "4.59.0",
+ "@rollup/rollup-linux-s390x-gnu": "4.59.0",
+ "@rollup/rollup-linux-x64-gnu": "4.59.0",
+ "@rollup/rollup-linux-x64-musl": "4.59.0",
+ "@rollup/rollup-openbsd-x64": "4.59.0",
+ "@rollup/rollup-openharmony-arm64": "4.59.0",
+ "@rollup/rollup-win32-arm64-msvc": "4.59.0",
+ "@rollup/rollup-win32-ia32-msvc": "4.59.0",
+ "@rollup/rollup-win32-x64-gnu": "4.59.0",
+ "@rollup/rollup-win32-x64-msvc": "4.59.0",
"fsevents": "~2.3.2"
}
},
@@ -4230,6 +4939,19 @@
"integrity": "sha512-oJFu94HQb+KVduSUQL7wnpmqnfmLsOA/nAh6b6EH0wCEoK0/mPeXU6c3wKDV83MkOuHPRHtSXKKU99IBazS/2w==",
"license": "0BSD"
},
+ "node_modules/type-check": {
+ "version": "0.4.0",
+ "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz",
+ "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==",
+ "dev": true,
+ "license": "MIT",
+ "dependencies": {
+ "prelude-ls": "^1.2.1"
+ },
+ "engines": {
+ "node": ">= 0.8.0"
+ }
+ },
"node_modules/type-fest": {
"version": "0.13.1",
"resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.13.1.tgz",
@@ -4274,6 +4996,16 @@
"node": "^20.17.0 || >=22.9.0"
}
},
+ "node_modules/uri-js": {
+ "version": "4.4.1",
+ "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz",
+ "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==",
+ "dev": true,
+ "license": "BSD-2-Clause",
+ "dependencies": {
+ "punycode": "^2.1.0"
+ }
+ },
"node_modules/vite": {
"version": "7.3.1",
"resolved": "https://registry.npmjs.org/vite/-/vite-7.3.1.tgz",
@@ -4402,6 +5134,16 @@
"node": ">= 8"
}
},
+ "node_modules/word-wrap": {
+ "version": "1.2.5",
+ "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz",
+ "integrity": "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
"node_modules/wrap-ansi": {
"version": "8.1.0",
"resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz",
@@ -4599,6 +5341,19 @@
"engines": {
"node": ">=8"
}
+ },
+ "node_modules/yocto-queue": {
+ "version": "0.1.0",
+ "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz",
+ "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==",
+ "dev": true,
+ "license": "MIT",
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
}
}
}
diff --git a/built-in-ai-extension/package.json b/built-in-ai-extension/package.json
index 6789346..970e9fc 100644
--- a/built-in-ai-extension/package.json
+++ b/built-in-ai-extension/package.json
@@ -1,14 +1,14 @@
{
"name": "built-in-ai-extension",
- "version": "1.2.0",
+ "version": "1.4.0",
"description": "",
"main": "index.js",
"type": "module",
"scripts": {
"dev": "vite",
"build": "vite build",
- "fix": "prettier --write .",
- "lint": "prettier --check .",
+ "fix": "eslint . --fix && prettier --write .",
+ "lint": "eslint . && prettier --check .",
"preview": "vite preview"
},
"keywords": [],
@@ -16,12 +16,17 @@
"license": "Apache-2.0",
"dependencies": {
"built-in-ai-task-apis-polyfills": "^1.4.0",
- "prompt-api-polyfill": "^1.4.0"
+ "prompt-api-polyfill": "^1.10.0"
},
"devDependencies": {
- "prettier": "^3.8.1",
- "vite": "^7.3.1",
+ "@eslint/js": "^10.0.1",
+ "eslint": "^10.0.2",
+ "eslint-config-google": "^0.14.0",
+ "eslint-config-prettier": "^10.1.8",
+ "globals": "^17.3.0",
+ "node-addon-api": "^8.5.0",
"node-gyp": "^12.2.0",
- "node-addon-api": "^8.5.0"
+ "prettier": "^3.8.1",
+ "vite": "^7.3.1"
}
}
diff --git a/built-in-ai-extension/public/manifest.json b/built-in-ai-extension/public/manifest.json
index 24eba6d..2f6cdff 100644
--- a/built-in-ai-extension/public/manifest.json
+++ b/built-in-ai-extension/public/manifest.json
@@ -1,7 +1,7 @@
{
"manifest_version": 3,
"name": "Built-in AI",
- "version": "1.2.0",
+ "version": "1.4.0",
"description": "Polyfills for the built-in AI APIs like LanguageModel, Summarizer, and Writer.",
"permissions": ["storage", "offscreen", "tabs"],
"content_security_policy": {
diff --git a/built-in-ai-extension/src/content.js b/built-in-ai-extension/src/content.js
index f0a67b9..40237b1 100644
--- a/built-in-ai-extension/src/content.js
+++ b/built-in-ai-extension/src/content.js
@@ -52,10 +52,66 @@
(document.head || document.documentElement).appendChild(script);
script.onload = () => script.remove();
- // Listen for messages from background/offscreen and dispatch to MAIN world
+ let bridgePort = null;
+
+ // Listen for the bridge initialization from the MAIN world
+ window.addEventListener('message', (event) => {
+ if (event.data?.type === 'AI_EXTENSION_INIT_BRIDGE' && event.ports[0]) {
+ bridgePort = event.ports[0];
+ bridgePort.onmessage = async (e) => {
+ const { id, message } = e.data;
+
+ // Recursively find and process ArrayBuffers into blobURLs
+ const processArrayBuffers = async (obj) => {
+ if (!obj || typeof obj !== 'object') return obj;
+
+ // Handle the new descriptor from Main World that includes MIME type
+ if (obj.__extension_bin_data__) {
+ const { __extension_bin_data__: buffer, mimeType } = obj;
+ const blob = new Blob([buffer], { type: mimeType });
+ const blobURL = URL.createObjectURL(blob);
+ return { __extension_blob_url__: blobURL };
+ }
+
+ if (obj instanceof ArrayBuffer) {
+ const blob = new Blob([obj]);
+ const blobURL = URL.createObjectURL(blob);
+ // Return a special descriptor that the offscreen page will recognize
+ return { __extension_blob_url__: blobURL };
+ }
+
+ if (Array.isArray(obj)) {
+ for (let i = 0; i < obj.length; i++) {
+ obj[i] = await processArrayBuffers(obj[i]);
+ }
+ } else {
+ for (const key of Object.keys(obj)) {
+ obj[key] = await processArrayBuffers(obj[key]);
+ }
+ }
+ return obj;
+ };
+
+ const processedMessage = await processArrayBuffers(message);
+
+ chrome.runtime.sendMessage(processedMessage, (response) => {
+ bridgePort.postMessage({ id, response });
+ });
+ };
+ }
+ });
+
+ // Listen for messages from background/offscreen and relay to MAIN world
chrome.runtime.onMessage.addListener((message) => {
if (message.target !== 'content') return;
+ // Relay over the bridge port if available (supports binary)
+ if (bridgePort) {
+ bridgePort.postMessage({ type: 'EVENT', message });
+ return;
+ }
+
+ // Fallback/Legacy event dispatching (only if bridge is not ready)
const eventType =
message.type === 'download-progress'
? 'extension-download-progress'
@@ -72,23 +128,4 @@
});
window.dispatchEvent(event);
});
-
- // Listen for requests from the MAIN world and relay to extension
- window.addEventListener('extension-request', (event) => {
- const { detail } = event;
- if (!detail) return;
- const { bridgeId } = detail;
-
- chrome.runtime.sendMessage(detail, (response) => {
- // Send the response back to the MAIN world
- window.dispatchEvent(
- new CustomEvent('extension-response', {
- detail: {
- bridgeId,
- response,
- },
- })
- );
- });
- });
})();
diff --git a/built-in-ai-extension/src/main-world-entry.js b/built-in-ai-extension/src/main-world-entry.js
index eeaf200..04bf9db 100644
--- a/built-in-ai-extension/src/main-world-entry.js
+++ b/built-in-ai-extension/src/main-world-entry.js
@@ -23,31 +23,57 @@
Classifier: window.Classifier,
};
- // Helper to send messages to the extension via the content script bridge
- const sendMessage = (message) => {
- const bridgeId = Math.random().toString(36).slice(2);
+ // Binary Bridge setup for efficient communication with content script
+ const channel = new MessageChannel();
+ const bridgePort = channel.port1;
+ const pendingRequests = new Map();
+
+ // Listen for responses and events back from the content script bridge
+ bridgePort.onmessage = (event) => {
+ if (event.data.type === 'EVENT') {
+ const { message } = event.data;
+ const eventType =
+ message.type === 'download-progress'
+ ? 'extension-download-progress'
+ : message.type === 'stream-chunk'
+ ? 'extension-stream-chunk'
+ : message.type === 'stream-error'
+ ? 'extension-stream-error'
+ : message.type === 'context-overflow'
+ ? 'extension-context-overflow'
+ : 'extension-stream-done';
+
+ window.dispatchEvent(new CustomEvent(eventType, { detail: message }));
+ return;
+ }
+
+ const { id, response } = event.data;
+ const request = pendingRequests.get(id);
+ if (request) {
+ pendingRequests.delete(id);
+ if (response.success) {
+ request.resolve(response);
+ } else {
+ const error =
+ response.name === 'AbortError'
+ ? new DOMException(response.error || 'Aborted', 'AbortError')
+ : new Error(response.error);
+ request.reject(error);
+ }
+ }
+ };
+
+ // Initialize the bridge by sending the second port to the content script
+ window.postMessage({ type: 'AI_EXTENSION_INIT_BRIDGE' }, '*', [
+ channel.port2,
+ ]);
+
+ // Helper to send messages to the extension via the MessagePort bridge
+ const sendMessage = async (message) => {
return new Promise((resolve, reject) => {
- const listener = (event) => {
- if (event.detail.bridgeId === bridgeId) {
- window.removeEventListener('extension-response', listener);
- const response = event.detail.response;
- if (response.success) {
- resolve(response);
- } else {
- const error =
- response.name === 'AbortError'
- ? new DOMException(response.error || 'Aborted', 'AbortError')
- : new Error(response.error);
- reject(error);
- }
- }
- };
- window.addEventListener('extension-response', listener);
- window.dispatchEvent(
- new CustomEvent('extension-request', {
- detail: { ...message, bridgeId },
- })
- );
+ const id = Math.random().toString(36).slice(2);
+ pendingRequests.set(id, { resolve, reject });
+ bridgePort.postMessage({ id, message });
});
};
@@ -58,6 +84,7 @@
const apiStatuses = [];
const sanitizeOptions = (options) => {
+ // eslint-disable-next-line no-unused-vars
const { monitor, signal, ...rest } = options;
return rest;
};
@@ -81,6 +108,121 @@
);
};
+ const preprocessInput = async (input) => {
+ if (!input || typeof input !== 'object') return input;
+
+ // Detect if we're in an array or a single object (options or prompt items)
+ const items = Array.isArray(input) ? input : [input];
+
+ const processObject = async (obj) => {
+ // Basic recursive processing for objects/arrays
+ if (!obj || typeof obj !== 'object') return obj;
+
+ // Avoid recursing into binary types
+ if (
+ obj instanceof Blob ||
+ obj instanceof ArrayBuffer ||
+ ArrayBuffer.isView(obj) ||
+ (typeof ImageBitmap !== 'undefined' && obj instanceof ImageBitmap)
+ ) {
+ return obj;
+ }
+
+ if (Array.isArray(obj)) {
+ for (let i = 0; i < obj.length; i++) {
+ obj[i] = await processObject(obj[i]);
+ obj[i] = await finalizeBinary(obj[i]);
+ }
+ } else {
+ for (const key of Object.keys(obj)) {
+ const val = obj[key];
+
+ // Handle DOM elements (Canvas, Image, etc.)
+ const isDOMElement =
+ (typeof HTMLElement !== 'undefined' &&
+ val instanceof HTMLElement) ||
+ (typeof SVGElement !== 'undefined' && val instanceof SVGElement);
+
+ if (isDOMElement) {
+ try {
+ let w = val.naturalWidth || val.width || 0;
+ let h = val.naturalHeight || val.height || 0;
+ if (val instanceof HTMLCanvasElement) {
+ w = val.width;
+ h = val.height;
+ }
+
+ if (w > 0 && h > 0) {
+ const canvas = document.createElement('canvas');
+ canvas.width = w;
+ canvas.height = h;
+ const ctx = canvas.getContext('2d');
+ ctx.drawImage(val, 0, 0);
+ obj[key] = await new Promise((resolve) =>
+ canvas.toBlob(resolve, 'image/png')
+ );
+ }
+ } catch (e) {
+ console.warn(
+ `[MainWorld] Failed to pre-process ${key} element:`,
+ e
+ );
+ }
+ } else {
+ obj[key] = await processObject(val);
+ }
+
+ // Ensure any Blobs or ImageBitmaps (including those just created)
+ // are converted to ArrayBuffers for the bridge.
+ obj[key] = await finalizeBinary(obj[key]);
+ }
+ }
+ return obj;
+ };
+
+ const finalizeBinary = async (val) => {
+ if (!val || typeof val !== 'object') return val;
+
+ const isBlob =
+ val instanceof Blob ||
+ (val && val.constructor && val.constructor.name === 'Blob');
+
+ const isImageBitmap =
+ (typeof ImageBitmap !== 'undefined' && val instanceof ImageBitmap) ||
+ (val && val.constructor && val.constructor.name === 'ImageBitmap');
+
+ if (isBlob) {
+ const type = val.type || 'application/octet-stream';
+ const buffer = await val.arrayBuffer();
+ return { __extension_bin_data__: buffer, mimeType: type };
+ } else if (isImageBitmap) {
+ try {
+ const canvas = document.createElement('canvas');
+ canvas.width = val.width;
+ canvas.height = val.height;
+ if (canvas.width > 0 && canvas.height > 0) {
+ const ctx = canvas.getContext('2d');
+ ctx.drawImage(val, 0, 0);
+ const blob = await new Promise((resolve) =>
+ canvas.toBlob(resolve, 'image/png')
+ );
+ const buffer = await blob.arrayBuffer();
+ return { __extension_bin_data__: buffer, mimeType: 'image/png' };
+ }
+ } catch (e) {
+ console.warn(
+ '[MainWorld] Failed to convert ImageBitmap to ArrayBuffer:',
+ e
+ );
+ }
+ }
+ return val;
+ };
+
+ const results = await Promise.all(items.map((item) => processObject(item)));
+ return Array.isArray(input) ? results : results[0];
+ };
+
const setClassName = (cls, name) => {
Object.defineProperty(cls, 'name', { value: name, configurable: true });
if (cls.prototype) {
@@ -140,12 +282,14 @@
const callId = Math.random().toString(36).slice(2);
handleSignal(options.signal, requestId, callId);
+ const processedText = await preprocessInput(text);
+
const response = await sendMessage({
target: 'offscreen',
type: 'prompt',
requestId,
callId,
- text,
+ text: processedText,
options: sanitizeOptions(options),
});
if (response.attributes) {
@@ -162,7 +306,7 @@
handleSignal(options.signal, requestId, callId);
return new ReadableStream({
- start(controller) {
+ async start(controller) {
const chunkListener = (e) => {
if (
e.detail.requestId === requestId &&
@@ -222,12 +366,14 @@
window.addEventListener('extension-stream-done', doneListener);
window.addEventListener('extension-stream-error', errorListener);
+ const processedText = await preprocessInput(text);
+
sendMessage({
target: 'offscreen',
type: 'prompt-streaming',
requestId,
callId,
- text,
+ text: processedText,
options: sanitizeOptions(options),
})
.then((response) => {
@@ -259,12 +405,14 @@
const callId = Math.random().toString(36).slice(2);
handleSignal(options.signal, requestId, callId);
+ const processedText = await preprocessInput(text);
+
const response = await sendMessage({
target: 'offscreen',
type: 'append',
requestId,
callId,
- text,
+ text: processedText,
options: sanitizeOptions(options),
});
if (response.attributes) {
@@ -277,12 +425,14 @@
const callId = Math.random().toString(36).slice(2);
handleSignal(options.signal, requestId, callId);
+ const processedText = await preprocessInput(text);
+
const response = await sendMessage({
target: 'offscreen',
type: 'execute',
requestId,
callId,
- text,
+ text: processedText,
method: 'measureContextUsage',
options: sanitizeOptions(options),
});
diff --git a/built-in-ai-extension/vite.config.js b/built-in-ai-extension/vite.config.js
index b79ed2d..bd92133 100644
--- a/built-in-ai-extension/vite.config.js
+++ b/built-in-ai-extension/vite.config.js
@@ -4,9 +4,12 @@
*/
import { defineConfig } from 'vite';
-import { resolve } from 'path';
+import { resolve, dirname } from 'path';
+import { fileURLToPath } from 'url';
import fs from 'fs';
+const __dirname = dirname(fileURLToPath(import.meta.url));
+
export default defineConfig({
base: './',
esbuild: {
diff --git a/prompt-api-polyfill/backends-registry.js b/prompt-api-polyfill/backends-registry.js
index b6653dd..a666973 100644
--- a/prompt-api-polyfill/backends-registry.js
+++ b/prompt-api-polyfill/backends-registry.js
@@ -1,8 +1,3 @@
-/**
- * Copyright 2026 Google LLC
- * SPDX-License-Identifier: Apache-2.0
- */
-
/**
* Generated by scripts/generate-registry.js
* DO NOT EDIT MANUALLY
diff --git a/prompt-api-polyfill/multimodal-converter.js b/prompt-api-polyfill/multimodal-converter.js
index 03ddcd2..e662332 100644
--- a/prompt-api-polyfill/multimodal-converter.js
+++ b/prompt-api-polyfill/multimodal-converter.js
@@ -19,34 +19,77 @@ export default class MultimodalConverter {
static async processImage(source) {
// Blob
- if (source instanceof Blob) {
- return this.blobToInlineData(source);
+ const isBlob =
+ source instanceof Blob ||
+ (source &&
+ typeof source === 'object' &&
+ source.constructor &&
+ source.constructor.name === 'Blob');
+
+ if (isBlob) {
+ if (source.type === 'image/png' || source.type === 'image/jpeg') {
+ return this.blobToInlineData(source);
+ }
+ return this.#convertToPngPart(source);
}
// BufferSource (ArrayBuffer/View) -> Sniff or Default
- if (ArrayBuffer.isView(source) || source instanceof ArrayBuffer) {
- const u8 =
- source instanceof ArrayBuffer
- ? new Uint8Array(source)
- : new Uint8Array(source.buffer, source.byteOffset, source.byteLength);
+ const isArrayBuffer =
+ source instanceof ArrayBuffer ||
+ (source &&
+ source.constructor &&
+ source.constructor.name === 'ArrayBuffer');
+ const isView =
+ ArrayBuffer.isView(source) ||
+ (source &&
+ source.buffer &&
+ (source.buffer instanceof ArrayBuffer ||
+ source.buffer.constructor.name === 'ArrayBuffer'));
+
+ if (isArrayBuffer || isView) {
+ const u8 = isArrayBuffer
+ ? new Uint8Array(source)
+ : new Uint8Array(source.buffer, source.byteOffset, source.byteLength);
const buffer = u8.buffer.slice(
u8.byteOffset,
u8.byteOffset + u8.byteLength
);
- const base64 = this.arrayBufferToBase64(buffer);
const mimeType = this.#sniffImageMimeType(u8);
if (!mimeType) {
throw new DOMException('Invalid image data', 'InvalidStateError');
}
- return { inlineData: { data: base64, mimeType } };
+ if (mimeType === 'image/png' || mimeType === 'image/jpeg') {
+ const base64 = await this.arrayBufferToBase64(buffer);
+ return { inlineData: { data: base64, mimeType } };
+ }
+
+ const blob = new Blob([buffer], { type: mimeType });
+ return this.#convertToPngPart(blob);
}
- // ImageBitmapSource (Canvas, Image, VideoFrame, etc.)
+ // ImageBitmap/ImageDataSource (Canvas, Image, VideoFrame, etc.)
// We draw to a canvas to standardize to PNG
return this.canvasSourceToInlineData(source);
}
+ static async #convertToPngPart(blob) {
+ const url = URL.createObjectURL(blob);
+ try {
+ const img = new Image();
+ img.src = url;
+ await img.decode().catch((e) => {
+ throw new DOMException(
+ `The source image cannot be decoded: ${e.message}`,
+ 'InvalidStateError'
+ );
+ });
+ return await this.canvasSourceToInlineData(img);
+ } finally {
+ URL.revokeObjectURL(url);
+ }
+ }
+
static #sniffImageMimeType(u8) {
const len = u8.length;
if (len < 4) {
@@ -72,89 +115,36 @@ export default class MultimodalConverter {
return 'image/png';
}
- // GIF: GIF87a / GIF89a
- if (u8[0] === 0x47 && u8[1] === 0x49 && u8[2] === 0x46 && u8[3] === 0x38) {
- return 'image/gif';
- }
-
- // WebP: RIFF (offset 0) + WEBP (offset 8)
- if (
- u8[0] === 0x52 &&
- u8[1] === 0x49 &&
- u8[2] === 0x46 &&
- u8[3] === 0x46 &&
- u8[8] === 0x57 &&
- u8[9] === 0x45 &&
- u8[10] === 0x42 &&
- u8[11] === 0x50
- ) {
- return 'image/webp';
- }
-
- // BMP: BM
- if (u8[0] === 0x42 && u8[1] === 0x4d) {
- return 'image/bmp';
- }
-
- // ICO: 00 00 01 00
- if (u8[0] === 0x00 && u8[1] === 0x00 && u8[2] === 0x01 && u8[3] === 0x00) {
- return 'image/x-icon';
- }
-
- // TIFF: II* (LE) / MM* (BE)
- if (
- (u8[0] === 0x49 && u8[1] === 0x49 && u8[2] === 0x2a) ||
- (u8[0] === 0x4d && u8[1] === 0x4d && u8[2] === 0x2a)
- ) {
- return 'image/tiff';
- }
-
- // ISOBMFF (AVIF / HEIC / HEIF)
- // "ftyp" at offset 4
- if (u8[4] === 0x66 && u8[5] === 0x74 && u8[6] === 0x79 && u8[7] === 0x70) {
- const type = String.fromCharCode(u8[8], u8[9], u8[10], u8[11]);
- if (type === 'avif' || type === 'avis') {
- return 'image/avif';
- }
- if (
- type === 'heic' ||
- type === 'heix' ||
- type === 'hevc' ||
- type === 'hevx'
- ) {
- return 'image/heic';
- }
- if (type === 'mif1' || type === 'msf1') {
- return 'image/heif';
- }
- }
-
- // JPEG XL: FF 0A or container bits
- if (u8[0] === 0xff && u8[1] === 0x0a) {
- return 'image/jxl';
- }
- // Container: 00 00 00 0c 4a 58 4c 20 0d 0a 87 0a (JXL )
- if (u8[0] === 0x00 && u8[4] === 0x4a && u8[5] === 0x58 && u8[6] === 0x4c) {
- return 'image/jxl';
- }
-
- // JPEG 2000
- if (u8[0] === 0x00 && u8[4] === 0x6a && u8[5] === 0x50 && u8[6] === 0x20) {
- return 'image/jp2';
- }
-
// SVG: Check for