diff --git a/.github/workflows/dev.yaml b/.github/workflows/dev.yaml index 12409733..e8d2a7eb 100644 --- a/.github/workflows/dev.yaml +++ b/.github/workflows/dev.yaml @@ -1,6 +1,3 @@ -# This workflow will do a clean install of node dependencies, build the source code and run tests across different versions of node -# For more information see: https://help.github.com/actions/language-and-framework-guides/using-nodejs-with-github-actions - name: ci on: @@ -11,37 +8,49 @@ on: workflow_dispatch: jobs: - build: + build-and-test: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - uses: actions/setup-node@v4 with: - node-version: 'lts/iron' + node-version: 'lts/jod' - uses: actions/cache@v4 id: npm-cache with: path: '**/node_modules' key: ${{ runner.os }}-modules-${{ hashFiles('**/package-lock.json') }} + + # Project Setup - name: Install dependencies if: steps.npm-cache.outputs.cache-hit != 'true' run: npm ci - - run: npm run build --if-present - name: Linting files run: npm run lint - - uses: saucelabs/sauce-connect-action@v1 + + # Start Sauce Connect tunnel for SauceLabs + - name: Start Sauce Connect + uses: saucelabs/sauce-connect-action@v2 with: username: ${{ secrets.SAUCE_USERNAME }} accessKey: ${{ secrets.SAUCE_ACCESS_KEY }} - noSSLBumpDomains: all - noProxyCaching: true tunnelIdentifier: github-action-tunnel - - run: npm test + + # Unit Tests Step + - name: Run unit tests + run: npm run test:unit:ci:pull:request env: - SAUCE_USERNAME: ${{secrets.SAUCE_USERNAME}} - SAUCE_ACCESS_KEY: ${{secrets.SAUCE_ACCESS_KEY}} + SAUCE_USERNAME: ${{ secrets.SAUCE_USERNAME }} + SAUCE_ACCESS_KEY: ${{ secrets.SAUCE_ACCESS_KEY }} + ## Coveralls down. - name: Coveralls - uses: coverallsapp/github-action@master + uses: coverallsapp/github-action@v2.3.6 with: github-token: ${{ secrets.GITHUB_TOKEN }} + path-to-lcov: ./coverage/lcov.info + + # TODO: uncomment + ## Integration Tests Step + #- name: Run integration tests + # run: npm run test:integration diff --git a/.github/workflows/npm-publish.yaml b/.github/workflows/npm-publish.yaml index 202ff4c8..345e3838 100644 --- a/.github/workflows/npm-publish.yaml +++ b/.github/workflows/npm-publish.yaml @@ -23,28 +23,35 @@ jobs: - uses: actions/checkout@v4 - uses: actions/setup-node@v4 with: - node-version: 22.x + node-version: 'lts/jod' - uses: actions/cache@v4 id: npm-cache with: path: '**/node_modules' key: ${{ runner.os }}-modules-${{ hashFiles('**/package-lock.json') }} + + # Project Setup - name: Install dependencies if: steps.npm-cache.outputs.cache-hit != 'true' run: npm ci - - uses: saucelabs/sauce-connect-action@v1 - with: - username: ${{ secrets.SAUCE_USERNAME }} - accessKey: ${{ secrets.SAUCE_ACCESS_KEY }} - noSSLBumpDomains: all - noProxyCaching: true - tunnelIdentifier: github-action-tunnel - - run: npm test - env: - SAUCE_USERNAME: ${{secrets.SAUCE_USERNAME}} - SAUCE_ACCESS_KEY: ${{secrets.SAUCE_ACCESS_KEY}} - - uses: JS-DevTools/npm-publish@v3 + - name: Linting files + run: npm run lint + + # Unit Tests Step + - name: CI Tests For Publish + run: npm run test:unit:ci:npm:publish + + # Integration Tests Step + - name: Integration Tests For Publish + run: npm run test:integration:ci:npm:publish + + # Production Build + - name: Build Production Bundle + run: npm run build:production + + # Publish to NPM + - name: Publish to NPM + uses: JS-DevTools/npm-publish@v3 with: token: ${{ secrets.ADOBE_BOT_NPM_TOKEN }} tag: ${{ github.event.inputs.tag }} - access: 'public' diff --git a/.gitignore b/.gitignore index 19075de5..f24505c4 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,7 @@ node_modules /coverage /dist +ci-scripts/setup/.env +**/.env.local +**/.env.*.local +**/.*access-token diff --git a/.husky/pre-commit b/.husky/pre-commit index a926c364..ee9ffc8a 100755 --- a/.husky/pre-commit +++ b/.husky/pre-commit @@ -1,2 +1,3 @@ #!/bin/sh npx lint-staged +node ./ci-scripts/ensure-library-builds-for-integration.js diff --git a/ci-scripts/container-utils.js b/ci-scripts/container-utils.js new file mode 100644 index 00000000..302acd10 --- /dev/null +++ b/ci-scripts/container-utils.js @@ -0,0 +1,438 @@ +/** + * Shared utilities for container generation scripts + */ + +const Reactor = require('./create-reactor-sdk'); +const path = require('path'); +const packageJson = require(path.resolve(__dirname, '..', 'package.json')); +const thisTurbineVersion = packageJson.version; +require('dotenv').config({ path: path.resolve(__dirname, 'setup', '.env') }); + +/* eslint-disable camelcase */ + +const companyId = process.env.RSDK_ADOBE_REACTOR_COMPANY_ID; + +/** + * Generate a unique human-readable version string based on UTC timestamp + * @returns {string} Human-readable version string + */ +function generateVersion() { + const now = new Date(); + const year = now.getUTCFullYear(); + const month = String(now.getUTCMonth() + 1).padStart(2, '0'); + const day = String(now.getUTCDate()).padStart(2, '0'); + const hour = String(now.getUTCHours()).padStart(2, '0'); + const minute = String(now.getUTCMinutes()).padStart(2, '0'); + const second = String(now.getUTCSeconds()).padStart(2, '0'); + + return `${year}-${month}-${day} ${hour}${minute}${second}`; +} + +/** + * Generate a unique property name with version + * @param {string} containerType - Type of container ('Sync' or 'Async') + * @returns {string} Unique property name + */ +function generatePropertyName({ containerType }) { + const version = generateVersion(); + return `Test Turbine v${thisTurbineVersion} ${containerType} Container v${version}`; +} + +/** + * Create a property with standard configuration + * @param {string} propertyName - Name for the property + * @param {Object} options - Overrides for entries at the same level as 'attributes', etc. + * @returns {Promise} Created property + */ +async function createProperty({ propertyName, options = {} }) { + try { + return await Reactor.createProperty(companyId, { + type: 'properties', + attributes: { + name: propertyName, + domains: ['testing.reactor.turbine.adobe.com'], + platform: 'web', + development: false + }, + undefined_vars_return_empty: false, + rule_component_sequencing_enabled: false, + ...options + }); + } catch (error) { + console.error('Threw error in createProperty:'); + throw error; + } +} + +/** + * Create an Akamai host for a property + * @param propertyId + * @returns {Promise} Created host + */ +async function createAkamaiHost({ propertyId }) { + return await Reactor.createHost(propertyId, { + attributes: { + name: 'Development Akamai Host', + type_of: 'akamai' + }, + type: 'hosts' + }); +} + +/** + * Create a development environment for a property + * @param {string} propertyId - Property ID + * @returns {Promise} Created environment + */ +async function createDevelopmentEnvironment({ propertyId }) { + const akamaiHost = await createAkamaiHost({ propertyId }); + const environment = await Reactor.createEnvironment(propertyId, { + type: 'environments', + attributes: { + name: 'Development Environment', + stage: 'development' + }, + relationships: { + host: { + data: { type: 'hosts', id: akamaiHost.data.id } + } + } + }); + + console.log('Created environment:', environment.data.id); + return environment; +} + +/** + * Get or install the Core extension + * @param {string} propertyId - Property ID + * @returns {Promise} Core extension + */ +async function ensureCoreExtension({ propertyId }) { + const extensions = await Reactor.listExtensionsForProperty(propertyId); + let coreExtension = extensions.data.find( + (ext) => ext.attributes.name === 'core' + ); + + console.log('✅ Core Extension was already there'); + coreExtension = { data: coreExtension }; + if (!coreExtension) { + console.log('❌ Core Extension not in the property'); + // If core extension is not installed, install it + const corePackage = await Reactor.listExtensionPackages({ + 'filter[name]': 'core' + }); + + coreExtension = await Reactor.createExtension(propertyId, { + type: 'extensions', + relationships: { + extension_package: { + data: { + id: corePackage.data[0].id, + type: 'extension_packages' + } + } + } + }); + + console.log('✅ Core Extension created for property'); + } + + return coreExtension; +} + +/** + * Create a library with specified components + * @param name - The name of the library in the publishing flow + * @param propertyId + * @param environmentId + * @param dataElementIds - Array of data element IDs for the build + * @param extensionIdsUsed - Array of extension IDs for the build + * @param ruleIds - Array of rule IDs for the build + * @returns {Promise} The created Library + */ +async function createLibrary({ + name, + propertyId, + environmentId, + dataElementIds = [], + extensionIdsUsed = [], + ruleIds = [] +}) { + const data = { + attributes: { + name + }, + relationships: { + environment: { + data: { + id: environmentId, + type: 'environments' + } + } + }, + type: 'libraries' + }; + + if (dataElementIds.length) { + const dataElements = dataElementIds.map((id) => ({ + id, + meta: { action: 'revise' }, + type: 'data_elements' + })); + + data.relationships.data_elements = { data: dataElements }; + } + if (extensionIdsUsed.length) { + const extensions = extensionIdsUsed.map((id) => ({ + id, + meta: { action: 'revise' }, + type: 'extensions' + })); + data.relationships.extensions = { data: extensions }; + } + if (ruleIds.length) { + const rules = ruleIds.map((id) => ({ + id, + meta: { action: 'revise' }, + type: 'rules' + })); + data.relationships.rules = { data: rules }; + } + + return await Reactor.createLibrary(propertyId, data); +} + +/** + * Create a rule + * @param propertyId + * @param ruleName + * @returns {Promise} The created Rule + */ +async function createRule({ propertyId, ruleName }) { + const data = { + attributes: { name: ruleName }, + type: 'rules' + }; + + return await Reactor.createRule(propertyId, data); +} + +/** + * Create a rule component + * @param propertyId + * @param extensionId + * @param ruleId + * @param settings - The settings a rule component requires (the returned object from ReactorBridge.getSettings()) + * @param delegateDescriptorId - ex: 'core::events::click' + * @param ruleComponentName - The name to be used for the rule component + * @returns {Promise} The created Rule Component + */ +async function createRuleComponent({ + propertyId, + extensionId, + ruleId, + settings, + delegateDescriptorId, + ruleComponentName +}) { + const data = { + attributes: { + name: ruleComponentName, + settings: JSON.stringify(settings), + order: 0, + delegate_descriptor_id: delegateDescriptorId + }, + relationships: { + extension: { + data: { + id: extensionId, + type: 'extensions' + } + }, + rules: { + data: [ + { + id: ruleId, + type: 'rules' + } + ] + } + }, + type: 'rule_components' + }; + + return await Reactor.createRuleComponent(propertyId, data); +} + +/** + * Create a click event rule component + * @param propertyId + * @param coreExtensionId + * @param ruleId + * @param elementSelector - null for any element, or a CSS selector string + * @returns {Promise} The created Rule Component + */ +async function createClickEvent({ + propertyId, + coreExtensionId, + ruleId, + elementSelector = null +}) { + const clickSettings = { + bubbleFireIfChildFired: true, + bubbleFireIfParent: true + }; + if (elementSelector) { + clickSettings.elementSelector = elementSelector; + } + + return await createRuleComponent({ + propertyId, + extensionId: coreExtensionId, + ruleId, + settings: clickSettings, + delegateDescriptorId: 'core::events::click', + ruleComponentName: 'click - event' + }); +} + +/** + * Create a browser condition rule component + * @param propertyId + * @param coreExtensionId + * @param ruleId + * @returns {Promise} The created Rule Component + */ +async function createBrowserCondition({ propertyId, coreExtensionId, ruleId }) { + return await createRuleComponent({ + propertyId, + extensionId: coreExtensionId, + ruleId, + settings: { browsers: ['Chrome'] }, + delegateDescriptorId: 'core::conditions::browser', + ruleComponentName: 'browser - condition' + }); +} + +async function sleepFor(milliseconds) { + return new Promise((resolve) => setTimeout(resolve, milliseconds)); +} + +/** + * Build a library and wait for completion + * @param libraryId + * @returns {Promise} The completed build + */ +async function buildLibrary({ libraryId }) { + const buildResponse = await Reactor.createBuild(libraryId); + const buildId = buildResponse.data.id; + + // wait for build to complete + const totalWait = 300000; // in milliseconds + const pollInterval = 1000; // in milliseconds + let polledBuildResponse; + for (let i = 0; i < totalWait; i += pollInterval) { + await sleepFor(pollInterval); + polledBuildResponse = await Reactor.getBuild(buildId); + console.info( + `after ${i + pollInterval} milliseconds, ${buildId} is ${ + polledBuildResponse.data.attributes.status + }` + ); + if (polledBuildResponse.data.attributes.status !== 'pending') break; + } + const status = polledBuildResponse.data.attributes.status; + if ('succeeded' !== status) { + throw new Error(`Build ${buildId} did not succeed, status is ${status}`); + } + + return polledBuildResponse; +} + +/** + * Prepare a new property containing an environment, library, and a rule to place delegates in. + * @param {boolean} ruleComponentSequencingEnabled + * @returns {Promise<{ + * propertyName: string, + * propertyId: string, + * propertyLink: string, + * environmentId: string, + * ruleId: string, + * coreExtensionId: string, + * libraryLink: string + * }>} + */ +async function prepareNewPropertyForDelegates({ + ruleComponentSequencingEnabled = false +}) { + const propertyName = generatePropertyName({ containerType: 'Sync' }); + + // 1. Create property + const property = await createProperty({ + propertyName, + attributes: { + ruleComponentSequencingEnabled: Boolean(ruleComponentSequencingEnabled) + } + }); + const propertyId = property.data.id; + const propertyLink = `/${process.env.RSDK_ADOBE_REACTOR_COMPANY_ID}/properties/${propertyId}`; + console.log(`✅ created property (${propertyId}) with name ${propertyName}`); + + // 2. Create development environment + const environment = await createDevelopmentEnvironment({ + propertyId + }); + const environmentId = environment.data.id; + console.log('✅ created an akamai environment'); + + const libraryLink = environment.data.meta.script_sources.reduce( + (acc, src) => { + return src.hosting_region === 'Standard' ? src.minified : acc; + }, + null + ); + if (libraryLink) { + console.log('✅ found the .min.js link for the library'); + } else { + throw new Error('❌ could not find .min.js link for the library'); + } + + // 3. Ensure Core extension is available + const coreExtension = await ensureCoreExtension({ + propertyId + }); + const coreExtensionId = coreExtension.data.id; + console.log(`✅ checked the core extension (${coreExtensionId})`); + + // 4. make a rule + const rule = await createRule({ + propertyId, + ruleName: 'Click Event Rule' + }); + const ruleId = rule.data.id; + console.log('✅ created a rule'); + + return { + propertyName, + propertyId, + propertyLink, + environmentId, + ruleId, + coreExtensionId, + libraryLink + }; +} + +module.exports = { + generatePropertyName, + createProperty, + createDevelopmentEnvironment, + ensureCoreExtension, + createLibrary, + buildLibrary, + createRule, + createClickEvent, + createBrowserCondition, + prepareNewPropertyForDelegates +}; diff --git a/ci-scripts/create-reactor-sdk.js b/ci-scripts/create-reactor-sdk.js new file mode 100644 index 00000000..527e50ba --- /dev/null +++ b/ci-scripts/create-reactor-sdk.js @@ -0,0 +1,25 @@ +/*************************************************************************************** + * (c) 2025 Adobe. All rights reserved. + * This file is licensed to you under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. You may obtain a copy + * of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under + * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS + * OF ANY KIND, either express or implied. See the License for the specific language + * governing permissions and limitations under the License. + ****************************************************************************************/ + +const path = require('path'); +const Reactor = require('@adobe/reactor-sdk').default; +require('dotenv').config({ path: path.resolve(__dirname, 'setup', '.env') }); +require('dotenv').config({ + path: path.resolve(__dirname, 'setup', '.env.access-token') +}); + +const reactor = new Reactor(process.env.RSDK_ACCESS_TOKEN, { + reactorUrl: process.env.RSDK_ADOBE_REACTOR_URL, + customHeaders: { 'x-gw-ims-org-id': process.env.RSDK_ADOBE_ORG_ID }, + enableLogging: false +}); +module.exports = reactor; diff --git a/ci-scripts/ensure-library-builds-for-integration.js b/ci-scripts/ensure-library-builds-for-integration.js new file mode 100755 index 00000000..6150dbab --- /dev/null +++ b/ci-scripts/ensure-library-builds-for-integration.js @@ -0,0 +1,144 @@ +#!/usr/bin/env node + +const path = require('path'); +const libraryBuildPathsFile = path.join(__dirname, 'library-build-paths.json'); + +const fs = require('fs'); +const packageJson = require(path.join(__dirname, '..', 'package.json')); +const thisTurbineVersion = packageJson.version; + +const containerTypes = { + SYNC_CONTAINER: require('./generate-sync-container'), + ASYNC_CONTAINER: require('./generate-async-container') +}; + +// Function that returns the build library URL +const buildLibrary = async (containerType) => { + console.log(`Building ${containerType}...`); + // invoke the generateContainer function. + const { success, libraryLink, error } = await containerTypes[containerType](); + + if (success) { + console.log( + `Successfully generated ${containerType} container:`, + libraryLink + ); + return libraryLink; + } else { + console.error(`Failed to generate "${containerType}" container:`, error); + throw new Error( + `Failed to generate "${containerType}" container: ${error}` + ); + } +}; + +if (!fs.existsSync(libraryBuildPathsFile)) { + console.log( + 'library-build-paths.json does not exist in ci-scripts directory. Creating it...' + ); + // Create the file with an empty object as initial content + fs.writeFileSync(libraryBuildPathsFile, JSON.stringify({}, null, 2)); + console.log( + 'library-build-paths.json has been created successfully in ci-scripts directory.' + ); +} + +console.log('Checking URLs...'); + +const libraryBuildPathJson = require('./library-build-paths.json'); +let jsonModified = false; + +// Function to check if a URL returns valid content +const checkUrl = async (url) => { + try { + const response = await fetch(url, { + method: 'GET', + signal: AbortSignal.timeout(10000) // 10 second timeout + }); + + if (response.ok) { + console.log(`✓ Successfully loaded JS file from: ${url}`); + + const text = await response.text(); + const [, libraryTurbineVersion] = text.match( + /"turbineVersion"\s*:\s*"([^"]+)"/ + ); + if (libraryTurbineVersion) { + const isValid = libraryTurbineVersion === thisTurbineVersion; + if (!isValid) { + console.log('Turbine version mismatch for', url); + console.log('This Turbine Version:', thisTurbineVersion); + console.log('Library Turbine version:', libraryTurbineVersion); + } + return isValid; + } else { + throw new Error('turbineVersion not found in JS file'); + } + } else { + throw new Error( + `Failed to load JS file at ${url}. Status code: ${response.status}` + ); + } + } catch (err) { + if (err.name === 'TimeoutError') { + throw new Error(`Request timeout for ${url}`); + } + throw new Error(`Error loading JS file at ${url}: ${err.message}`); + } +}; + +// Check all container URLs +(async () => { + const containerTypeNames = Object.keys(containerTypes); + + const setLibraryBuildPath = (type, url) => { + libraryBuildPathJson[type] = url; + jsonModified = true; + }; + + let current = 1; + for (const containerType of containerTypeNames) { + console.log( + `Processing ${containerType} (container ${current}/${containerTypeNames.length})` + ); + let url = libraryBuildPathJson[containerType]; + let isValid = false; + + // we have a prior build url, see if the url is valid + if (url) { + isValid = await checkUrl(url); + } + + if (!isValid) { + let newUrl = await buildLibrary(containerType); + if (newUrl.includes('.min.js')) { + newUrl = newUrl.replace('.min.js', '.js'); + } + const isNewBuildValid = await checkUrl(newUrl); + if (!isNewBuildValid) { + throw new Error( + `We just built a new library and the Turbine versions still do not match. New Build URL was ${newUrl}` + ); + } + setLibraryBuildPath(containerType, newUrl); + jsonModified = true; + } + + current++; + } + + // Write back to file if JSON was modified + if (jsonModified) { + fs.writeFileSync( + libraryBuildPathsFile, + JSON.stringify(libraryBuildPathJson, null, 2) + ); + console.log('Updated library-build-paths.json with new URLs'); + } else { + console.log( + 'JSON was unmodified - All container types were publicly accessible' + ); + } + + console.log('All container URLs processed successfully'); +})(); diff --git a/ci-scripts/generate-async-container.js b/ci-scripts/generate-async-container.js new file mode 100644 index 00000000..8f2a47aa --- /dev/null +++ b/ci-scripts/generate-async-container.js @@ -0,0 +1,92 @@ +#!/usr/bin/env node +/** + * Generate async container for integration testing + * + * This script handles async container generation for testing purposes. + */ + +const ReactorApi = require('./container-utils'); + +async function generateContainer() { + try { + const { + propertyId, + propertyName, + propertyLink /* /CO.../properties/PR... */, + libraryLink /* assets.adobedtm.com/.../.min.js */, + environmentId, + ruleId, + coreExtensionId + } = await ReactorApi.prepareNewPropertyForDelegates({ + ruleComponentSequencingEnabled: true + }); + + /*** make delegates ***/ + /*const clickEvent = */ + await ReactorApi.createClickEvent({ + propertyId, + coreExtensionId, + ruleId + }); + console.log('✅ created a click event'); + // const clickEventId = clickEvent.data.id; + + /*const browserCondition = */ + await ReactorApi.createBrowserCondition({ + propertyId, + coreExtensionId, + ruleId + }); + console.log('✅ created a browser condition'); + // const browserConditionId = browserCondition.data.id; + console.log('✅ finished rules/conditions/actions creations'); + /*** make delegates ***/ + + /*** create Library ***/ + const library = await ReactorApi.createLibrary({ + name: 'API Build Library', + propertyId, + environmentId, + extensionIdsUsed: [coreExtensionId], + ruleIds: [ruleId] + }); + const libraryId = library.data.id; + console.log('✅ made a library'); + + const completedBuild = await ReactorApi.buildLibrary({ libraryId }); + console.log('✅ create async build', completedBuild.data.id); + /*** create Library ***/ + + return { + success: true, + propertyLink, + libraryLink, + propertyName + }; + } catch (error) { + return { success: false, error }; + } +} + +// If this script is run directly, execute the function +if (require.main === module) { + generateContainer() + .then(({ success, propertyLink, libraryLink, propertyName, error }) => { + if (success) { + console.log('Async container generated successfully!'); + console.log(propertyName); + console.log('Property Link:', propertyLink); + console.log('Library Build:', libraryLink); + process.exit(0); + } else { + console.error('Failed to generate async container:', error); + process.exit(1); + } + }) + .catch((err) => { + console.error('Unexpected error:', err); + process.exit(1); + }); +} + +module.exports = generateContainer; diff --git a/ci-scripts/generate-sync-container.js b/ci-scripts/generate-sync-container.js new file mode 100644 index 00000000..c48b3ab9 --- /dev/null +++ b/ci-scripts/generate-sync-container.js @@ -0,0 +1,92 @@ +#!/usr/bin/env node +/** + * Generate sync container for integration testing + * + * This script handles sync container generation for testing purposes. + */ + +const ReactorApi = require('./container-utils'); + +async function generateContainer() { + try { + const { + propertyId, + propertyName, + propertyLink /* /CO.../properties/PR... */, + libraryLink /* assets.adobedtm.com/.../.min.js */, + environmentId, + ruleId, + coreExtensionId + } = await ReactorApi.prepareNewPropertyForDelegates({ + ruleComponentSequencingEnabled: false + }); + + /*** make delegates ***/ + /*const clickEvent = */ + await ReactorApi.createClickEvent({ + propertyId, + coreExtensionId, + ruleId + }); + console.log('✅ created a click event'); + // const clickEventId = clickEvent.data.id; + + /*const browserCondition = */ + await ReactorApi.createBrowserCondition({ + propertyId, + coreExtensionId, + ruleId + }); + console.log('✅ created a browser condition'); + // const browserConditionId = browserCondition.data.id; + console.log('✅ finished rules/conditions/actions creations'); + /*** make delegates ***/ + + /*** create Library ***/ + const library = await ReactorApi.createLibrary({ + name: 'API Build Library', + propertyId, + environmentId, + extensionIdsUsed: [coreExtensionId], + ruleIds: [ruleId] + }); + const libraryId = library.data.id; + console.log('✅ made a library'); + + const completedBuild = await ReactorApi.buildLibrary({ libraryId }); + console.log('✅ create sync build', completedBuild.data.id); + /*** create Library ***/ + + return { + success: true, + propertyLink, + libraryLink, + propertyName + }; + } catch (error) { + return { success: false, error }; + } +} + +// If this script is run directly, execute the function +if (require.main === module) { + generateContainer() + .then(({ success, propertyLink, libraryLink, propertyName, error }) => { + if (success) { + console.log('Sync container generated successfully!'); + console.log(propertyName); + console.log('Property Link:', propertyLink); + console.log('Library Build:', libraryLink); + process.exit(0); + } else { + console.error('Failed to generate sync container:', error); + process.exit(1); + } + }) + .catch((err) => { + console.error('Unexpected error:', err); + process.exit(1); + }); +} + +module.exports = generateContainer; diff --git a/ci-scripts/library-build-paths.json b/ci-scripts/library-build-paths.json new file mode 100644 index 00000000..c400a4bf --- /dev/null +++ b/ci-scripts/library-build-paths.json @@ -0,0 +1,4 @@ +{ + "SYNC_CONTAINER": "https://assets.adobedtm.com/staging/b83dd4cc8fed/c0217334425a/launch-6bdb18263aec-development.js", + "ASYNC_CONTAINER": "https://assets.adobedtm.com/staging/b83dd4cc8fed/fb5dc7db2a0d/launch-5862cd96f58d-development.js" +} \ No newline at end of file diff --git a/ci-scripts/setup/.env-example b/ci-scripts/setup/.env-example new file mode 100644 index 00000000..b161be4e --- /dev/null +++ b/ci-scripts/setup/.env-example @@ -0,0 +1,28 @@ +# Adobe Reactor SDK Integration Test Environment Variables +# Copy this file to .env and fill in your actual values + +# Required: Adobe I/O Client Credentials (for @adobe/auth-token) +# Get these from Adobe Developer Console when you create your integration +RSDK_ADOBE_CLIENT_ID=your_client_id_here +RSDK_ADOBE_CLIENT_SECRET=your_client_secret_here + +# Required: Adobe auth scopes (comma-separated) +# Common scopes for Reactor API access +RSDK_ADOBE_SCOPES=AdobeID,openid,read_organizations,additional_info.job_function,additional_info.projectedProductContext,additional_info.roles + +# Required: Your Adobe Organization ID +# Format: ORG123456789@AdobeOrg +RSDK_ADOBE_ORG_ID=your_org_id_here + +# Required: Your Reactor Company ID +# Format: CO1234567890abcdef1234567890abcdef +RSDK_ADOBE_REACTOR_COMPANY_ID=your_company_id_here + +# Use https://reactor.adobe.io for production +# Use https://reactor-stage.adobe.io for staging +RSDK_ADOBE_REACTOR_URL=https://reactor-stage.adobe.io + +# prod | stage +RSDK_ADOBE_ENVIRONMENT=stage + +# Note: ACCESS_TOKEN will be generated automatically using @adobe/auth-token diff --git a/ci-scripts/setup/generate-access-token.js b/ci-scripts/setup/generate-access-token.js new file mode 100644 index 00000000..d4937251 --- /dev/null +++ b/ci-scripts/setup/generate-access-token.js @@ -0,0 +1,64 @@ +/* +Copyright 2025 Adobe. All rights reserved. +This file is licensed to you under the Apache License, Version 2.0 (the "License"); +you may not use this file except in compliance with the License. You may obtain a copy +of the License at http://www.apache.org/licenses/LICENSE-2.0 + +Unless required by applicable law or agreed to in writing, software distributed under +the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS +OF ANY KIND, either express or implied. See the License for the specific language +governing permissions and limitations under the License. +*/ + +const fs = require('fs'); +const path = require('path'); +const { auth } = require('@adobe/auth-token'); + +// load main env for client id/secret, etc +require('dotenv').config({ path: path.resolve(__dirname, '.env') }); + +async function generateAccessToken() { + if ( + !process.env.RSDK_ADOBE_CLIENT_ID || + !process.env.RSDK_ADOBE_CLIENT_SECRET || + !process.env.RSDK_ADOBE_SCOPES || + !process.env.RSDK_ADOBE_ENVIRONMENT + ) { + console.error( + 'RSDK_ADOBE_CLIENT_ID, RSDK_ADOBE_CLIENT_SECRET, RSDK_ADOBE_SCOPES, and ' + + 'RSDK_ADOBE_ENVIRONMENT must be defined to generate access token' + ); + process.exit(1); + } + + try { + const config = { + clientId: process.env.RSDK_ADOBE_CLIENT_ID, + clientSecret: process.env.RSDK_ADOBE_CLIENT_SECRET, + scope: process.env.RSDK_ADOBE_SCOPES, + environment: process.env.RSDK_ADOBE_ENVIRONMENT + }; + + const { access_token: freshToken } = await auth(config); + return freshToken; + } catch (error) { + console.error('Failed to generate access token:', error.message); + process.exit(1); + } +} + +async function main() { + const accessToken = await generateAccessToken(); + const accessTokenEnvPath = path.resolve(__dirname, '.env.access-token'); + const content = `RSDK_ACCESS_TOKEN=${accessToken}\n`; + + fs.writeFileSync(accessTokenEnvPath, content, 'utf-8'); + console.log(`✅ Wrote fresh ACCESS_TOKEN to ${accessTokenEnvPath}`); + + process.exit(0); +} + +main().catch((err) => { + console.error(err); + process.exit(1); +}); diff --git a/eslint.config.mjs b/eslint.config.mjs index 498ccb14..7cd66613 100644 --- a/eslint.config.mjs +++ b/eslint.config.mjs @@ -9,6 +9,8 @@ export default [ languageOptions: { globals: { _satellite: true, + REACTOR_KARMA_CI_UNIT_TEST_MODE: true, + __satelliteLoaded: true, ...globals.browser, ...globals.jasmine, ...globals.node @@ -32,16 +34,7 @@ export default [ 'space-before-blocks': [2, 'always'], 'space-infix-ops': [2, { int32Hint: false }], quotes: [1, 'single', 'avoid-escape'], - 'max-len': [ - 2, - 100, - 4, - { - ignoreUrls: true, - ignorePattern: - '^(\\s*(var|let|const)\\s.+=\\s*require\\s*\\()|(^\\s*import)' - } - ], + 'max-len': [2, 120, 4, { ignoreUrls: true }], eqeqeq: [2, 'allow-null'], strict: [0, 'safe'], 'no-nested-ternary': [2], diff --git a/karma.integration.conf.js b/karma.integration.conf.js new file mode 100644 index 00000000..9dfe1b66 --- /dev/null +++ b/karma.integration.conf.js @@ -0,0 +1,76 @@ +/*************************************************************************************** + * (c) 2025 Adobe. All rights reserved. + * This file is licensed to you under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. You may obtain a copy + * of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under + * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS + * OF ANY KIND, either express or implied. See the License for the specific language + * governing permissions and limitations under the License. + ****************************************************************************************/ + +'use strict'; + +const path = require('path'); + +module.exports = function (config) { + config.set({ + // Test framework + frameworks: ['jasmine'], + + // Files to load in browser + files: [ + { + pattern: 'test.integrationIndex.js', + watched: false, + included: true, + served: true + }, + { + pattern: 'dist/engine.js', + watched: false, + included: false, // Don’t auto-inject it; your test loads it dynamically + served: true + } + ], + + // Preprocess with webpack + preprocessors: { + 'test.integrationIndex.js': ['webpack'] + }, + + // Webpack config + webpack: { + mode: 'development', + resolve: { + extensions: ['.js', '.jsx'] + }, + module: { + rules: [ + { + test: /\.jsx?$/, + include: path.resolve('src'), + exclude: /node_modules/, + use: { + loader: 'babel-loader', + options: { + presets: [['@babel/env', { targets: '> 0.25%, not dead' }]], + plugins: [] + } + } + } + ] + } + }, + + // Browser to run tests in + browsers: [process.env.CI ? 'ChromeHeadless' : 'Chrome'], + + // Exit after running tests + singleRun: true, + + // Logging level + logLevel: config.LOG_INFO + }); +}; diff --git a/karma.conf.js b/karma.unit.conf.js similarity index 83% rename from karma.conf.js rename to karma.unit.conf.js index 3d0d34a2..3fccd79b 100644 --- a/karma.conf.js +++ b/karma.unit.conf.js @@ -1,7 +1,20 @@ +/*************************************************************************************** + * (c) 2025 Adobe. All rights reserved. + * This file is licensed to you under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. You may obtain a copy + * of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under + * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS + * OF ANY KIND, either express or implied. See the License for the specific language + * governing permissions and limitations under the License. + ****************************************************************************************/ + 'use strict'; const path = require('path'); const yargs = require('yargs'); +const webpack = require('webpack'); const argv = yargs .array('browsers') @@ -16,7 +29,6 @@ let buildId; if (process.env.CI) { buildId = `CI #${process.env.GITHUB_RUN_NUMBER} (${process.env.GITHUB_RUN_ID})`; argv.browsers = ['SL_EDGE', 'SL_CHROME', 'SL_SAFARI']; - reporters.push('saucelabs'); } else { startConnect = true; } @@ -124,7 +136,7 @@ module.exports = function (config) { // list of files / patterns to load in the browser files: [ { - pattern: 'testIndex.js', + pattern: 'test.unitIndex.js', watched: false, included: true, served: true @@ -147,7 +159,7 @@ module.exports = function (config) { // preprocess matching files before serving them to the browser // available preprocessors: https://npmjs.org/browse/keyword/karma-preprocessor preprocessors: { - 'testIndex.js': ['webpack'] + 'test.unitIndex.js': ['webpack'] }, // web server port port: 9876, @@ -182,7 +194,12 @@ module.exports = function (config) { }, module: { rules: rules - } + }, + plugins: [ + new webpack.DefinePlugin({ + REACTOR_KARMA_CI_UNIT_TEST_MODE: JSON.stringify(true) + }) + ] }, webpackServer: { debug: false, diff --git a/package-lock.json b/package-lock.json index 8fa4a31b..4f334a41 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "@adobe/reactor-turbine", - "version": "28.2.0-beta.1", + "version": "29.0.0-beta.2", "lockfileVersion": 3, "requires": true, "packages": { "": { "name": "@adobe/reactor-turbine", - "version": "28.2.0-beta.1", + "version": "29.0.0-beta.2", "license": "Apache-2.0", "dependencies": { "@adobe/reactor-cookie": "*", @@ -16,21 +16,26 @@ "@adobe/reactor-promise": "*", "@adobe/reactor-query-string": "*", "@adobe/reactor-window": "*", - "is-plain-object": "^5.0.0" + "is-plain-object": "^5.0.0", + "lodash.clonedeep": "^4.5.0" }, "devDependencies": { + "@adobe/auth-token": "^1.0.1", + "@adobe/reactor-sdk": "^2.0.0-beta.5", "@babel/core": "^7.27.4", "@babel/preset-env": "^7.27.2", + "@playwright/test": "^1.56.1", "@rollup/plugin-commonjs": "^28.0.6", "@rollup/plugin-node-resolve": "^16.0.1", + "@rollup/plugin-replace": "^6.0.2", "babel-loader": "^10.0.0", "babel-plugin-istanbul": "^7.0.0", "camelize": "1.0.1", - "eslint": "^9.29.0", + "dotenv": "^17.2.3", + "eslint": "^9.37.0", "eslint-config-prettier": "^10.1.5", "eslint-plugin-prettier": "^5.5.0", "husky": "^9.1.7", - "inject-loader": "^4.0.1", "jasmine-core": "^5.8.0", "karma": "^6.4.4", "karma-chrome-launcher": "^3.2.0", @@ -39,19 +44,70 @@ "karma-jasmine": "^5.1.0", "karma-jasmine-matchers": "^5.0.0", "karma-safari-launcher": "^1.0.0", - "karma-sauce-launcher": "^4.3.6", "karma-webpack": "^5.0.1", "kebab-case": "2.0.2", "lint-staged": "^16.1.2", - "prettier": "3.6.0", + "prettier": "^3.6.2", "pretty-quick": "^4.2.2", - "rollup": "^4.44.0", + "rollup": "^4.52.4", + "rollup-plugin-strip-code": "^0.2.8", "uglify-js": "^3.19.3", "webpack": "^5.99.9", "yargs": "^17.7.2" }, "engines": { - "node": ">=v20.17.0" + "node": ">=v22.19.0" + } + }, + "node_modules/@adobe/auth-token": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/@adobe/auth-token/-/auth-token-1.0.1.tgz", + "integrity": "sha512-oNEQf2SFvVPPjNsp+EhVywDjnaoua7fIuY06zzuY7T1tpClK8X72Lw//l5u96YzwgZoPb09YQLkPsGTQclHOxQ==", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "chalk": "^5.3.0", + "inquirer": "^9.2.12", + "node-fetch": "^3.3.2", + "yargs": "^17.7.2" + }, + "bin": { + "auth-token": "bin/index.js" + }, + "engines": { + "node": ">=20.17.0" + } + }, + "node_modules/@adobe/auth-token/node_modules/chalk": { + "version": "5.6.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-5.6.2.tgz", + "integrity": "sha512-7NzBL0rN6fMUW+f7A6Io4h40qQlG+xGmtMxfbnH/K7TAtt8JQWVQK+6g0UXKMeVJoyV5EkkNsErQ8pVD3bLHbA==", + "dev": true, + "license": "MIT", + "engines": { + "node": "^12.17.0 || ^14.13 || >=16.0.0" + }, + "funding": { + "url": "https://github.com/chalk/chalk?sponsor=1" + } + }, + "node_modules/@adobe/auth-token/node_modules/node-fetch": { + "version": "3.3.2", + "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-3.3.2.tgz", + "integrity": "sha512-dRB78srN/l6gqWulah9SrxeYnxeddIG30+GOqK/9OlLVyLg3HPnr6SqOWTWOXKRwC2eGYCkZ59NNuSgvSrpgOA==", + "dev": true, + "license": "MIT", + "dependencies": { + "data-uri-to-buffer": "^4.0.0", + "fetch-blob": "^3.1.4", + "formdata-polyfill": "^4.0.10" + }, + "engines": { + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/node-fetch" } }, "node_modules/@adobe/reactor-cookie": { @@ -96,26 +152,27 @@ "integrity": "sha512-rGNnmKjpjA898mOHP5xU05geL50uwQDCxx6Ekh8C+l4Pem5OJIZJN/weqTgzVVxp9F+mRdPixFW5PqCEZrnTuA==", "license": "Apache-2.0" }, - "node_modules/@adobe/reactor-window": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/@adobe/reactor-window/-/reactor-window-1.0.0.tgz", - "integrity": "sha512-n6B25+2/497ES7+SAtX4ikqJ67xpbGRP6Iqwe+J+ArO274MNh35K+h7ovXH+3yTgqtcJkujO8Pt+YmiuxxcPaQ==", - "license": "Apache-2.0" - }, - "node_modules/@ampproject/remapping": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.3.0.tgz", - "integrity": "sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==", + "node_modules/@adobe/reactor-sdk": { + "version": "2.0.0-beta.5", + "resolved": "https://registry.npmjs.org/@adobe/reactor-sdk/-/reactor-sdk-2.0.0-beta.5.tgz", + "integrity": "sha512-FA6db6PFK+hrzPuAakHMd8MaZQnguNquO0RHIH4sYC7safbHu706KsrJCs2oRj5CmlT4A2PPcEQi9NoeK8Z0bA==", "dev": true, + "hasInstallScript": true, "license": "Apache-2.0", "dependencies": { - "@jridgewell/gen-mapping": "^0.3.5", - "@jridgewell/trace-mapping": "^0.3.24" + "node-fetch": "^2.6.7", + "semver": "^6.3.1" }, "engines": { - "node": ">=6.0.0" + "node": ">=v22.19.0" } }, + "node_modules/@adobe/reactor-window": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/@adobe/reactor-window/-/reactor-window-1.0.0.tgz", + "integrity": "sha512-n6B25+2/497ES7+SAtX4ikqJ67xpbGRP6Iqwe+J+ArO274MNh35K+h7ovXH+3yTgqtcJkujO8Pt+YmiuxxcPaQ==", + "license": "Apache-2.0" + }, "node_modules/@babel/code-frame": { "version": "7.27.1", "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.27.1.tgz", @@ -131,17 +188,10 @@ "node": ">=6.9.0" } }, - "node_modules/@babel/code-frame/node_modules/js-tokens": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", - "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", - "dev": true, - "license": "MIT" - }, "node_modules/@babel/compat-data": { - "version": "7.27.5", - "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.27.5.tgz", - "integrity": "sha512-KiRAp/VoJaWkkte84TvUd9qjdbZAdiqyvMxrGl1N6vzFogKmaLgoM3L1kgtLicp2HP5fBJS8JrZKLVIZGVJAVg==", + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.28.4.tgz", + "integrity": "sha512-YsmSKC29MJwf0gF8Rjjrg5LQCmyh+j/nD8/eP7f+BeoQTKYqs9RoWbjGOdy0+1Ekr68RJZMUOPVQaQisnIo4Rw==", "dev": true, "license": "MIT", "engines": { @@ -149,22 +199,22 @@ } }, "node_modules/@babel/core": { - "version": "7.27.4", - "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.27.4.tgz", - "integrity": "sha512-bXYxrXFubeYdvB0NhD/NBB3Qi6aZeV20GOWVI47t2dkecCEoneR4NPVcb7abpXDEvejgrUfFtG6vG/zxAKmg+g==", + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.28.4.tgz", + "integrity": "sha512-2BCOP7TN8M+gVDj7/ht3hsaO/B/n5oDbiAyyvnRlNOs+u1o+JWNYTQrmpuNp1/Wq2gcFrI01JAW+paEKDMx/CA==", "dev": true, "license": "MIT", "dependencies": { - "@ampproject/remapping": "^2.2.0", "@babel/code-frame": "^7.27.1", - "@babel/generator": "^7.27.3", + "@babel/generator": "^7.28.3", "@babel/helper-compilation-targets": "^7.27.2", - "@babel/helper-module-transforms": "^7.27.3", - "@babel/helpers": "^7.27.4", - "@babel/parser": "^7.27.4", + "@babel/helper-module-transforms": "^7.28.3", + "@babel/helpers": "^7.28.4", + "@babel/parser": "^7.28.4", "@babel/template": "^7.27.2", - "@babel/traverse": "^7.27.4", - "@babel/types": "^7.27.3", + "@babel/traverse": "^7.28.4", + "@babel/types": "^7.28.4", + "@jridgewell/remapping": "^2.3.5", "convert-source-map": "^2.0.0", "debug": "^4.1.0", "gensync": "^1.0.0-beta.2", @@ -179,66 +229,23 @@ "url": "https://opencollective.com/babel" } }, - "node_modules/@babel/core/node_modules/convert-source-map": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", - "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", - "dev": true, - "license": "MIT" - }, - "node_modules/@babel/core/node_modules/json5": { - "version": "2.2.3", - "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", - "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", - "dev": true, - "license": "MIT", - "bin": { - "json5": "lib/cli.js" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/@babel/core/node_modules/semver": { - "version": "6.3.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", - "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", - "dev": true, - "license": "ISC", - "bin": { - "semver": "bin/semver.js" - } - }, "node_modules/@babel/generator": { - "version": "7.27.5", - "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.27.5.tgz", - "integrity": "sha512-ZGhA37l0e/g2s1Cnzdix0O3aLYm66eF8aufiVteOgnwxgnRP8GoyMj7VWsgWnQbVKXyge7hqrFh2K2TQM6t1Hw==", + "version": "7.28.3", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.28.3.tgz", + "integrity": "sha512-3lSpxGgvnmZznmBkCRnVREPUFJv2wrv9iAoFDvADJc0ypmdOxdUtcLeBgBJ6zE0PMeTKnxeQzyk0xTBq4Ep7zw==", "dev": true, "license": "MIT", "dependencies": { - "@babel/parser": "^7.27.5", - "@babel/types": "^7.27.3", - "@jridgewell/gen-mapping": "^0.3.5", - "@jridgewell/trace-mapping": "^0.3.25", + "@babel/parser": "^7.28.3", + "@babel/types": "^7.28.2", + "@jridgewell/gen-mapping": "^0.3.12", + "@jridgewell/trace-mapping": "^0.3.28", "jsesc": "^3.0.2" }, "engines": { "node": ">=6.9.0" } }, - "node_modules/@babel/generator/node_modules/jsesc": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-3.1.0.tgz", - "integrity": "sha512-/sM3dO2FOzXjKQhJuo0Q173wf2KOo8t4I8vHy6lF9poUp7bKT0/NHE8fPX23PwfhnykfqnC2xRxOnVw5XuGIaA==", - "dev": true, - "license": "MIT", - "bin": { - "jsesc": "bin/jsesc" - }, - "engines": { - "node": ">=6" - } - }, "node_modules/@babel/helper-annotate-as-pure": { "version": "7.27.3", "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.27.3.tgz", @@ -269,29 +276,19 @@ "node": ">=6.9.0" } }, - "node_modules/@babel/helper-compilation-targets/node_modules/semver": { - "version": "6.3.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", - "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", - "dev": true, - "license": "ISC", - "bin": { - "semver": "bin/semver.js" - } - }, "node_modules/@babel/helper-create-class-features-plugin": { - "version": "7.27.1", - "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.27.1.tgz", - "integrity": "sha512-QwGAmuvM17btKU5VqXfb+Giw4JcN0hjuufz3DYnpeVDvZLAObloM77bhMXiqry3Iio+Ai4phVRDwl6WU10+r5A==", + "version": "7.28.3", + "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.28.3.tgz", + "integrity": "sha512-V9f6ZFIYSLNEbuGA/92uOvYsGCJNsuA8ESZ4ldc09bWk/j8H8TKiPw8Mk1eG6olpnO0ALHJmYfZvF4MEE4gajg==", "dev": true, "license": "MIT", "dependencies": { - "@babel/helper-annotate-as-pure": "^7.27.1", + "@babel/helper-annotate-as-pure": "^7.27.3", "@babel/helper-member-expression-to-functions": "^7.27.1", "@babel/helper-optimise-call-expression": "^7.27.1", "@babel/helper-replace-supers": "^7.27.1", "@babel/helper-skip-transparent-expression-wrappers": "^7.27.1", - "@babel/traverse": "^7.27.1", + "@babel/traverse": "^7.28.3", "semver": "^6.3.1" }, "engines": { @@ -301,16 +298,6 @@ "@babel/core": "^7.0.0" } }, - "node_modules/@babel/helper-create-class-features-plugin/node_modules/semver": { - "version": "6.3.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", - "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", - "dev": true, - "license": "ISC", - "bin": { - "semver": "bin/semver.js" - } - }, "node_modules/@babel/helper-create-regexp-features-plugin": { "version": "7.27.1", "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.27.1.tgz", @@ -329,33 +316,33 @@ "@babel/core": "^7.0.0" } }, - "node_modules/@babel/helper-create-regexp-features-plugin/node_modules/semver": { - "version": "6.3.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", - "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", - "dev": true, - "license": "ISC", - "bin": { - "semver": "bin/semver.js" - } - }, "node_modules/@babel/helper-define-polyfill-provider": { - "version": "0.6.4", - "resolved": "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.6.4.tgz", - "integrity": "sha512-jljfR1rGnXXNWnmQg2K3+bvhkxB51Rl32QRaOTuwwjviGrHzIbSc8+x9CpraDtbT7mfyjXObULP4w/adunNwAw==", + "version": "0.6.5", + "resolved": "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.6.5.tgz", + "integrity": "sha512-uJnGFcPsWQK8fvjgGP5LZUZZsYGIoPeRjSF5PGwrelYgq7Q15/Ft9NGFp1zglwgIv//W0uG4BevRuSJRyylZPg==", "dev": true, "license": "MIT", "dependencies": { - "@babel/helper-compilation-targets": "^7.22.6", - "@babel/helper-plugin-utils": "^7.22.5", - "debug": "^4.1.1", + "@babel/helper-compilation-targets": "^7.27.2", + "@babel/helper-plugin-utils": "^7.27.1", + "debug": "^4.4.1", "lodash.debounce": "^4.0.8", - "resolve": "^1.14.2" + "resolve": "^1.22.10" }, "peerDependencies": { "@babel/core": "^7.4.0 || ^8.0.0-0 <8.0.0" } }, + "node_modules/@babel/helper-globals": { + "version": "7.28.0", + "resolved": "https://registry.npmjs.org/@babel/helper-globals/-/helper-globals-7.28.0.tgz", + "integrity": "sha512-+W6cISkXFa1jXsDEdYA8HeevQT/FULhxzR99pxphltZcVaugps53THCeiWA8SguxxpSp3gKPiuYfSWopkLQ4hw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6.9.0" + } + }, "node_modules/@babel/helper-member-expression-to-functions": { "version": "7.27.1", "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.27.1.tgz", @@ -385,15 +372,15 @@ } }, "node_modules/@babel/helper-module-transforms": { - "version": "7.27.3", - "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.27.3.tgz", - "integrity": "sha512-dSOvYwvyLsWBeIRyOeHXp5vPj5l1I011r52FM1+r1jCERv+aFXYk4whgQccYEGYxK2H3ZAIA8nuPkQ0HaUo3qg==", + "version": "7.28.3", + "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.28.3.tgz", + "integrity": "sha512-gytXUbs8k2sXS9PnQptz5o0QnpLL51SwASIORY6XaBKF88nsOT0Zw9szLqlSGQDP/4TljBAD5y98p2U1fqkdsw==", "dev": true, "license": "MIT", "dependencies": { "@babel/helper-module-imports": "^7.27.1", "@babel/helper-validator-identifier": "^7.27.1", - "@babel/traverse": "^7.27.3" + "@babel/traverse": "^7.28.3" }, "engines": { "node": ">=6.9.0" @@ -506,42 +493,42 @@ } }, "node_modules/@babel/helper-wrap-function": { - "version": "7.27.1", - "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.27.1.tgz", - "integrity": "sha512-NFJK2sHUvrjo8wAU/nQTWU890/zB2jj0qBcCbZbbf+005cAsv6tMjXz31fBign6M5ov1o0Bllu+9nbqkfsjjJQ==", + "version": "7.28.3", + "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.28.3.tgz", + "integrity": "sha512-zdf983tNfLZFletc0RRXYrHrucBEg95NIFMkn6K9dbeMYnsgHaSBGcQqdsCSStG2PYwRre0Qc2NNSCXbG+xc6g==", "dev": true, "license": "MIT", "dependencies": { - "@babel/template": "^7.27.1", - "@babel/traverse": "^7.27.1", - "@babel/types": "^7.27.1" + "@babel/template": "^7.27.2", + "@babel/traverse": "^7.28.3", + "@babel/types": "^7.28.2" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helpers": { - "version": "7.27.6", - "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.27.6.tgz", - "integrity": "sha512-muE8Tt8M22638HU31A3CgfSUciwz1fhATfoVai05aPXGor//CdWDCbnlY1yvBPo07njuVOCNGCSp/GTt12lIug==", + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.28.4.tgz", + "integrity": "sha512-HFN59MmQXGHVyYadKLVumYsA9dBFun/ldYxipEjzA4196jpLZd8UjEEBLkbEkvfYreDqJhZxYAWFPtrfhNpj4w==", "dev": true, "license": "MIT", "dependencies": { "@babel/template": "^7.27.2", - "@babel/types": "^7.27.6" + "@babel/types": "^7.28.4" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/parser": { - "version": "7.27.5", - "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.27.5.tgz", - "integrity": "sha512-OsQd175SxWkGlzbny8J3K8TnnDD0N3lrIUtB92xwyRpzaenGZhxDvxN/JgU00U3CDZNj9tPuDJ5H0WS4Nt3vKg==", + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.28.4.tgz", + "integrity": "sha512-yZbBqeM6TkpP9du/I2pUZnJsRMGGvOuIrhjzC1AwHwW+6he4mni6Bp/m8ijn0iOuZuPI2BfkCoSRunpyjnrQKg==", "dev": true, "license": "MIT", "dependencies": { - "@babel/types": "^7.27.3" + "@babel/types": "^7.28.4" }, "bin": { "parser": "bin/babel-parser.js" @@ -618,14 +605,14 @@ } }, "node_modules/@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly": { - "version": "7.27.1", - "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly/-/plugin-bugfix-v8-static-class-fields-redefine-readonly-7.27.1.tgz", - "integrity": "sha512-6BpaYGDavZqkI6yT+KSPdpZFfpnd68UKXbcjI9pJ13pvHhPrCKWOOLp+ysvMeA+DxnhuPpgIaRpxRxo5A9t5jw==", + "version": "7.28.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly/-/plugin-bugfix-v8-static-class-fields-redefine-readonly-7.28.3.tgz", + "integrity": "sha512-b6YTX108evsvE4YgWyQ921ZAFFQm3Bn+CA3+ZXlNVnPhx+UfsVURoPjfGAPCjBgrqo30yX/C2nZGX96DxvR9Iw==", "dev": true, "license": "MIT", "dependencies": { "@babel/helper-plugin-utils": "^7.27.1", - "@babel/traverse": "^7.27.1" + "@babel/traverse": "^7.28.3" }, "engines": { "node": ">=6.9.0" @@ -713,15 +700,15 @@ } }, "node_modules/@babel/plugin-transform-async-generator-functions": { - "version": "7.27.1", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-generator-functions/-/plugin-transform-async-generator-functions-7.27.1.tgz", - "integrity": "sha512-eST9RrwlpaoJBDHShc+DS2SG4ATTi2MYNb4OxYkf3n+7eb49LWpnS+HSpVfW4x927qQwgk8A2hGNVaajAEw0EA==", + "version": "7.28.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-generator-functions/-/plugin-transform-async-generator-functions-7.28.0.tgz", + "integrity": "sha512-BEOdvX4+M765icNPZeidyADIvQ1m1gmunXufXxvRESy/jNNyfovIqUyE7MVgGBjWktCoJlzvFA1To2O4ymIO3Q==", "dev": true, "license": "MIT", "dependencies": { "@babel/helper-plugin-utils": "^7.27.1", "@babel/helper-remap-async-to-generator": "^7.27.1", - "@babel/traverse": "^7.27.1" + "@babel/traverse": "^7.28.0" }, "engines": { "node": ">=6.9.0" @@ -765,9 +752,9 @@ } }, "node_modules/@babel/plugin-transform-block-scoping": { - "version": "7.27.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.27.5.tgz", - "integrity": "sha512-JF6uE2s67f0y2RZcm2kpAUEbD50vH62TyWVebxwHAlbSdM49VqPz8t4a1uIjp4NIOIZ4xzLfjY5emt/RCyC7TQ==", + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.28.4.tgz", + "integrity": "sha512-1yxmvN0MJHOhPVmAsmoW5liWwoILobu/d/ShymZmj867bAdxGbehIrew1DuLpw2Ukv+qDSSPQdYW1dLNE7t11A==", "dev": true, "license": "MIT", "dependencies": { @@ -798,13 +785,13 @@ } }, "node_modules/@babel/plugin-transform-class-static-block": { - "version": "7.27.1", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-class-static-block/-/plugin-transform-class-static-block-7.27.1.tgz", - "integrity": "sha512-s734HmYU78MVzZ++joYM+NkJusItbdRcbm+AGRgJCt3iA+yux0QpD9cBVdz3tKyrjVYWRl7j0mHSmv4lhV0aoA==", + "version": "7.28.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-class-static-block/-/plugin-transform-class-static-block-7.28.3.tgz", + "integrity": "sha512-LtPXlBbRoc4Njl/oh1CeD/3jC+atytbnf/UqLoqTDcEYGUPj022+rvfkbDYieUrSj3CaV4yHDByPE+T2HwfsJg==", "dev": true, "license": "MIT", "dependencies": { - "@babel/helper-create-class-features-plugin": "^7.27.1", + "@babel/helper-create-class-features-plugin": "^7.28.3", "@babel/helper-plugin-utils": "^7.27.1" }, "engines": { @@ -815,18 +802,18 @@ } }, "node_modules/@babel/plugin-transform-classes": { - "version": "7.27.1", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.27.1.tgz", - "integrity": "sha512-7iLhfFAubmpeJe/Wo2TVuDrykh/zlWXLzPNdL0Jqn/Xu8R3QQ8h9ff8FQoISZOsw74/HFqFI7NX63HN7QFIHKA==", + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.28.4.tgz", + "integrity": "sha512-cFOlhIYPBv/iBoc+KS3M6et2XPtbT2HiCRfBXWtfpc9OAyostldxIf9YAYB6ypURBBbx+Qv6nyrLzASfJe+hBA==", "dev": true, "license": "MIT", "dependencies": { - "@babel/helper-annotate-as-pure": "^7.27.1", - "@babel/helper-compilation-targets": "^7.27.1", + "@babel/helper-annotate-as-pure": "^7.27.3", + "@babel/helper-compilation-targets": "^7.27.2", + "@babel/helper-globals": "^7.28.0", "@babel/helper-plugin-utils": "^7.27.1", "@babel/helper-replace-supers": "^7.27.1", - "@babel/traverse": "^7.27.1", - "globals": "^11.1.0" + "@babel/traverse": "^7.28.4" }, "engines": { "node": ">=6.9.0" @@ -835,16 +822,6 @@ "@babel/core": "^7.0.0-0" } }, - "node_modules/@babel/plugin-transform-classes/node_modules/globals": { - "version": "11.12.0", - "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", - "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=4" - } - }, "node_modules/@babel/plugin-transform-computed-properties": { "version": "7.27.1", "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.27.1.tgz", @@ -863,13 +840,14 @@ } }, "node_modules/@babel/plugin-transform-destructuring": { - "version": "7.27.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.27.3.tgz", - "integrity": "sha512-s4Jrok82JpiaIprtY2nHsYmrThKvvwgHwjgd7UMiYhZaN0asdXNLr0y+NjTfkA7SyQE5i2Fb7eawUOZmLvyqOA==", + "version": "7.28.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.28.0.tgz", + "integrity": "sha512-v1nrSMBiKcodhsyJ4Gf+Z0U/yawmJDBOTpEB3mcQY52r9RIyPneGyAS/yM6seP/8I+mWI3elOMtT5dB8GJVs+A==", "dev": true, "license": "MIT", "dependencies": { - "@babel/helper-plugin-utils": "^7.27.1" + "@babel/helper-plugin-utils": "^7.27.1", + "@babel/traverse": "^7.28.0" }, "engines": { "node": ">=6.9.0" @@ -944,6 +922,23 @@ "@babel/core": "^7.0.0-0" } }, + "node_modules/@babel/plugin-transform-explicit-resource-management": { + "version": "7.28.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-explicit-resource-management/-/plugin-transform-explicit-resource-management-7.28.0.tgz", + "integrity": "sha512-K8nhUcn3f6iB+P3gwCv/no7OdzOZQcKchW6N389V6PD8NUWKZHzndOd9sPDVbMoBsbmjMqlB4L9fm+fEFNVlwQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-plugin-utils": "^7.27.1", + "@babel/plugin-transform-destructuring": "^7.28.0" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, "node_modules/@babel/plugin-transform-exponentiation-operator": { "version": "7.27.1", "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.27.1.tgz", @@ -1211,16 +1206,17 @@ } }, "node_modules/@babel/plugin-transform-object-rest-spread": { - "version": "7.27.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-rest-spread/-/plugin-transform-object-rest-spread-7.27.3.tgz", - "integrity": "sha512-7ZZtznF9g4l2JCImCo5LNKFHB5eXnN39lLtLY5Tg+VkR0jwOt7TBciMckuiQIOIW7L5tkQOCh3bVGYeXgMx52Q==", + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-rest-spread/-/plugin-transform-object-rest-spread-7.28.4.tgz", + "integrity": "sha512-373KA2HQzKhQCYiRVIRr+3MjpCObqzDlyrM6u4I201wL8Mp2wHf7uB8GhDwis03k2ti8Zr65Zyyqs1xOxUF/Ew==", "dev": true, "license": "MIT", "dependencies": { "@babel/helper-compilation-targets": "^7.27.2", "@babel/helper-plugin-utils": "^7.27.1", - "@babel/plugin-transform-destructuring": "^7.27.3", - "@babel/plugin-transform-parameters": "^7.27.1" + "@babel/plugin-transform-destructuring": "^7.28.0", + "@babel/plugin-transform-parameters": "^7.27.7", + "@babel/traverse": "^7.28.4" }, "engines": { "node": ">=6.9.0" @@ -1280,9 +1276,9 @@ } }, "node_modules/@babel/plugin-transform-parameters": { - "version": "7.27.1", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.27.1.tgz", - "integrity": "sha512-018KRk76HWKeZ5l4oTj2zPpSh+NbGdt0st5S6x0pga6HgrjBOJb24mMDHorFopOOd6YHkLgOZ+zaCjZGPO4aKg==", + "version": "7.27.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.27.7.tgz", + "integrity": "sha512-qBkYTYCb76RRxUM6CcZA5KRu8K4SM8ajzVeUgVdMVO9NN9uI/GaVmBg/WKJJGnNokV9SY8FxNOVWGXzqzUidBg==", "dev": true, "license": "MIT", "dependencies": { @@ -1347,9 +1343,9 @@ } }, "node_modules/@babel/plugin-transform-regenerator": { - "version": "7.27.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.27.5.tgz", - "integrity": "sha512-uhB8yHerfe3MWnuLAhEbeQ4afVoqv8BQsPqrTv7e/jZ9y00kJL6l9a/f4OWaKxotmjzewfEyXE1vgDJenkQ2/Q==", + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.28.4.tgz", + "integrity": "sha512-+ZEdQlBoRg9m2NnzvEeLgtvBMO4tkFBw5SQIUgLICgTrumLoU7lr+Oghi6km2PFj+dbUt2u1oby2w3BDO9YQnA==", "dev": true, "license": "MIT", "dependencies": { @@ -1544,13 +1540,13 @@ } }, "node_modules/@babel/preset-env": { - "version": "7.27.2", - "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.27.2.tgz", - "integrity": "sha512-Ma4zSuYSlGNRlCLO+EAzLnCmJK2vdstgv+n7aUP+/IKZrOfWHOJVdSJtuub8RzHTj3ahD37k5OKJWvzf16TQyQ==", + "version": "7.28.3", + "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.28.3.tgz", + "integrity": "sha512-ROiDcM+GbYVPYBOeCR6uBXKkQpBExLl8k9HO1ygXEyds39j+vCCsjmj7S8GOniZQlEs81QlkdJZe76IpLSiqpg==", "dev": true, "license": "MIT", "dependencies": { - "@babel/compat-data": "^7.27.2", + "@babel/compat-data": "^7.28.0", "@babel/helper-compilation-targets": "^7.27.2", "@babel/helper-plugin-utils": "^7.27.1", "@babel/helper-validator-option": "^7.27.1", @@ -1558,25 +1554,26 @@ "@babel/plugin-bugfix-safari-class-field-initializer-scope": "^7.27.1", "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": "^7.27.1", "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": "^7.27.1", - "@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly": "^7.27.1", + "@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly": "^7.28.3", "@babel/plugin-proposal-private-property-in-object": "7.21.0-placeholder-for-preset-env.2", "@babel/plugin-syntax-import-assertions": "^7.27.1", "@babel/plugin-syntax-import-attributes": "^7.27.1", "@babel/plugin-syntax-unicode-sets-regex": "^7.18.6", "@babel/plugin-transform-arrow-functions": "^7.27.1", - "@babel/plugin-transform-async-generator-functions": "^7.27.1", + "@babel/plugin-transform-async-generator-functions": "^7.28.0", "@babel/plugin-transform-async-to-generator": "^7.27.1", "@babel/plugin-transform-block-scoped-functions": "^7.27.1", - "@babel/plugin-transform-block-scoping": "^7.27.1", + "@babel/plugin-transform-block-scoping": "^7.28.0", "@babel/plugin-transform-class-properties": "^7.27.1", - "@babel/plugin-transform-class-static-block": "^7.27.1", - "@babel/plugin-transform-classes": "^7.27.1", + "@babel/plugin-transform-class-static-block": "^7.28.3", + "@babel/plugin-transform-classes": "^7.28.3", "@babel/plugin-transform-computed-properties": "^7.27.1", - "@babel/plugin-transform-destructuring": "^7.27.1", + "@babel/plugin-transform-destructuring": "^7.28.0", "@babel/plugin-transform-dotall-regex": "^7.27.1", "@babel/plugin-transform-duplicate-keys": "^7.27.1", "@babel/plugin-transform-duplicate-named-capturing-groups-regex": "^7.27.1", "@babel/plugin-transform-dynamic-import": "^7.27.1", + "@babel/plugin-transform-explicit-resource-management": "^7.28.0", "@babel/plugin-transform-exponentiation-operator": "^7.27.1", "@babel/plugin-transform-export-namespace-from": "^7.27.1", "@babel/plugin-transform-for-of": "^7.27.1", @@ -1593,15 +1590,15 @@ "@babel/plugin-transform-new-target": "^7.27.1", "@babel/plugin-transform-nullish-coalescing-operator": "^7.27.1", "@babel/plugin-transform-numeric-separator": "^7.27.1", - "@babel/plugin-transform-object-rest-spread": "^7.27.2", + "@babel/plugin-transform-object-rest-spread": "^7.28.0", "@babel/plugin-transform-object-super": "^7.27.1", "@babel/plugin-transform-optional-catch-binding": "^7.27.1", "@babel/plugin-transform-optional-chaining": "^7.27.1", - "@babel/plugin-transform-parameters": "^7.27.1", + "@babel/plugin-transform-parameters": "^7.27.7", "@babel/plugin-transform-private-methods": "^7.27.1", "@babel/plugin-transform-private-property-in-object": "^7.27.1", "@babel/plugin-transform-property-literals": "^7.27.1", - "@babel/plugin-transform-regenerator": "^7.27.1", + "@babel/plugin-transform-regenerator": "^7.28.3", "@babel/plugin-transform-regexp-modifiers": "^7.27.1", "@babel/plugin-transform-reserved-words": "^7.27.1", "@babel/plugin-transform-shorthand-properties": "^7.27.1", @@ -1614,10 +1611,10 @@ "@babel/plugin-transform-unicode-regex": "^7.27.1", "@babel/plugin-transform-unicode-sets-regex": "^7.27.1", "@babel/preset-modules": "0.1.6-no-external-plugins", - "babel-plugin-polyfill-corejs2": "^0.4.10", - "babel-plugin-polyfill-corejs3": "^0.11.0", - "babel-plugin-polyfill-regenerator": "^0.6.1", - "core-js-compat": "^3.40.0", + "babel-plugin-polyfill-corejs2": "^0.4.14", + "babel-plugin-polyfill-corejs3": "^0.13.0", + "babel-plugin-polyfill-regenerator": "^0.6.5", + "core-js-compat": "^3.43.0", "semver": "^6.3.1" }, "engines": { @@ -1627,16 +1624,6 @@ "@babel/core": "^7.0.0-0" } }, - "node_modules/@babel/preset-env/node_modules/semver": { - "version": "6.3.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", - "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", - "dev": true, - "license": "ISC", - "bin": { - "semver": "bin/semver.js" - } - }, "node_modules/@babel/preset-modules": { "version": "0.1.6-no-external-plugins", "resolved": "https://registry.npmjs.org/@babel/preset-modules/-/preset-modules-0.1.6-no-external-plugins.tgz", @@ -1668,38 +1655,28 @@ } }, "node_modules/@babel/traverse": { - "version": "7.27.4", - "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.27.4.tgz", - "integrity": "sha512-oNcu2QbHqts9BtOWJosOVJapWjBDSxGCpFvikNR5TGDYDQf3JwpIoMzIKrvfoti93cLfPJEG4tH9SPVeyCGgdA==", + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.28.4.tgz", + "integrity": "sha512-YEzuboP2qvQavAcjgQNVgsvHIDv6ZpwXvcvjmyySP2DIMuByS/6ioU5G9pYrWHM6T2YDfc7xga9iNzYOs12CFQ==", "dev": true, "license": "MIT", "dependencies": { "@babel/code-frame": "^7.27.1", - "@babel/generator": "^7.27.3", - "@babel/parser": "^7.27.4", + "@babel/generator": "^7.28.3", + "@babel/helper-globals": "^7.28.0", + "@babel/parser": "^7.28.4", "@babel/template": "^7.27.2", - "@babel/types": "^7.27.3", - "debug": "^4.3.1", - "globals": "^11.1.0" + "@babel/types": "^7.28.4", + "debug": "^4.3.1" }, "engines": { "node": ">=6.9.0" } }, - "node_modules/@babel/traverse/node_modules/globals": { - "version": "11.12.0", - "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", - "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=4" - } - }, "node_modules/@babel/types": { - "version": "7.27.6", - "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.27.6.tgz", - "integrity": "sha512-ETyHEk2VHHvl9b9jZP5IHPavHYk57EhanlRRuae9XCpb/j5bDCbPPMOBfCWhnl/7EDJz0jEMCi/RhccCE8r1+Q==", + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.28.4.tgz", + "integrity": "sha512-bkFqkLhh3pMBUQQkpVgWDWq/lqzc2678eUyDlTBhRqhCHFguYYGM0Efga7tYk4TogG/3x0EEl66/OQ+WGbWB/Q==", "dev": true, "license": "MIT", "dependencies": { @@ -1721,9 +1698,9 @@ } }, "node_modules/@eslint-community/eslint-utils": { - "version": "4.7.0", - "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.7.0.tgz", - "integrity": "sha512-dyybb3AcajC7uha6CvhdVRJqaKyn7w2YKqKyAN37NKYgZT36w+iRb0Dymmc5qEJ549c/S31cMMSFd75bteCpCw==", + "version": "4.9.0", + "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.9.0.tgz", + "integrity": "sha512-ayVFHdtZ+hsq1t2Dy24wCmGXGe4q9Gu3smhLYALJrr473ZH27MsnSL+LKUlimp4BWJqMDMLmPpx/Q9R3OAlL4g==", "dev": true, "license": "MIT", "dependencies": { @@ -1763,9 +1740,9 @@ } }, "node_modules/@eslint/config-array": { - "version": "0.20.1", - "resolved": "https://registry.npmjs.org/@eslint/config-array/-/config-array-0.20.1.tgz", - "integrity": "sha512-OL0RJzC/CBzli0DrrR31qzj6d6i6Mm3HByuhflhl4LOBiWxN+3i6/t/ZQQNii4tjksXi8r2CRW1wMpWA2ULUEw==", + "version": "0.21.0", + "resolved": "https://registry.npmjs.org/@eslint/config-array/-/config-array-0.21.0.tgz", + "integrity": "sha512-ENIdc4iLu0d93HeYirvKmrzshzofPw6VkZRKQGe9Nv46ZnWUzcF1xV01dcvEg/1wXUR61OmmlSfyeyO7EvjLxQ==", "dev": true, "license": "Apache-2.0", "dependencies": { @@ -1778,19 +1755,22 @@ } }, "node_modules/@eslint/config-helpers": { - "version": "0.2.3", - "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.2.3.tgz", - "integrity": "sha512-u180qk2Um1le4yf0ruXH3PYFeEZeYC3p/4wCTKrr2U1CmGdzGi3KtY0nuPDH48UJxlKCC5RDzbcbh4X0XlqgHg==", + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.4.0.tgz", + "integrity": "sha512-WUFvV4WoIwW8Bv0KeKCIIEgdSiFOsulyN0xrMu+7z43q/hkOLXjvb5u7UC9jDxvRzcrbEmuZBX5yJZz1741jog==", "dev": true, "license": "Apache-2.0", + "dependencies": { + "@eslint/core": "^0.16.0" + }, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" } }, "node_modules/@eslint/core": { - "version": "0.14.0", - "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.14.0.tgz", - "integrity": "sha512-qIbV0/JZr7iSDjqAc60IqbLdsj9GDt16xQtWD+B78d/HAlvysGdZZ6rpJHGAc2T0FQx1X6thsSPdnoiGKdNtdg==", + "version": "0.16.0", + "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.16.0.tgz", + "integrity": "sha512-nmC8/totwobIiFcGkDza3GIKfAw1+hLiYVrh3I1nIomQ8PEr5cxg34jnkmGawul/ep52wGRAcyeDCNtWKSOj4Q==", "dev": true, "license": "Apache-2.0", "dependencies": { @@ -1845,9 +1825,9 @@ } }, "node_modules/@eslint/js": { - "version": "9.29.0", - "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.29.0.tgz", - "integrity": "sha512-3PIF4cBw/y+1u2EazflInpV+lYsSG0aByVIQzAgb1m1MhHFSbqTyNqtBKHgWf/9Ykud+DhILS9EGkmekVhbKoQ==", + "version": "9.37.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.37.0.tgz", + "integrity": "sha512-jaS+NJ+hximswBG6pjNX0uEJZkrT0zwpVi3BA3vX22aFGjJjmgSTSmPpZCRKmoBL5VY/M6p0xsSJx7rk7sy5gg==", "dev": true, "license": "MIT", "engines": { @@ -1868,32 +1848,19 @@ } }, "node_modules/@eslint/plugin-kit": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.3.2.tgz", - "integrity": "sha512-4SaFZCNfJqvk/kenHpI8xvN42DMaoycy4PzKc5otHxRswww1kAt82OlBuwRVLofCACCTZEcla2Ydxv8scMXaTg==", + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.4.0.tgz", + "integrity": "sha512-sB5uyeq+dwCWyPi31B2gQlVlo+j5brPlWx4yZBrEaRo/nhdDE8Xke1gsGgtiBdaBTxuTkceLVuVt/pclrasb0A==", "dev": true, "license": "Apache-2.0", "dependencies": { - "@eslint/core": "^0.15.0", + "@eslint/core": "^0.16.0", "levn": "^0.4.1" }, "engines": { "node": "^18.18.0 || ^20.9.0 || >=21.1.0" } }, - "node_modules/@eslint/plugin-kit/node_modules/@eslint/core": { - "version": "0.15.0", - "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.15.0.tgz", - "integrity": "sha512-b7ePw78tEWWkpgZCDYkbqDOP8dmM6qe+AOC6iuJqlq1R/0ahMAeH3qynpnqKFGkMltrp44ohV4ubGyvLX28tzw==", - "dev": true, - "license": "Apache-2.0", - "dependencies": { - "@types/json-schema": "^7.0.15" - }, - "engines": { - "node": "^18.18.0 || ^20.9.0 || >=21.1.0" - } - }, "node_modules/@humanfs/core": { "version": "0.19.1", "resolved": "https://registry.npmjs.org/@humanfs/core/-/core-0.19.1.tgz", @@ -1905,33 +1872,19 @@ } }, "node_modules/@humanfs/node": { - "version": "0.16.6", - "resolved": "https://registry.npmjs.org/@humanfs/node/-/node-0.16.6.tgz", - "integrity": "sha512-YuI2ZHQL78Q5HbhDiBA1X4LmYdXCKCMQIfw0pw7piHJwyREFebJUvrQN4cMssyES6x+vfUbx1CIpaQUKYdQZOw==", + "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.3.0" + "@humanwhocodes/retry": "^0.4.0" }, "engines": { "node": ">=18.18.0" } }, - "node_modules/@humanfs/node/node_modules/@humanwhocodes/retry": { - "version": "0.3.1", - "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.3.1.tgz", - "integrity": "sha512-JBxkERygn7Bv/GbN5Rv8Ul6LVknS+5Bp6RgDC/O8gEBU/yeH5Ui5C/OlWrTb6qct7LjjfT6Re2NxB0ln0yYybA==", - "dev": true, - "license": "Apache-2.0", - "engines": { - "node": ">=18.18" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/nzakas" - } - }, "node_modules/@humanwhocodes/module-importer": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", @@ -1960,6 +1913,55 @@ "url": "https://github.com/sponsors/nzakas" } }, + "node_modules/@inquirer/external-editor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/@inquirer/external-editor/-/external-editor-1.0.2.tgz", + "integrity": "sha512-yy9cOoBnx58TlsPrIxauKIFQTiyH+0MK4e97y4sV9ERbI+zDxw7i2hxHLCIEGIE/8PPvDxGhgzIOTSOWcs6/MQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "chardet": "^2.1.0", + "iconv-lite": "^0.7.0" + }, + "engines": { + "node": ">=18" + }, + "peerDependencies": { + "@types/node": ">=18" + }, + "peerDependenciesMeta": { + "@types/node": { + "optional": true + } + } + }, + "node_modules/@inquirer/external-editor/node_modules/iconv-lite": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.7.0.tgz", + "integrity": "sha512-cf6L2Ds3h57VVmkZe+Pn+5APsT7FpqJtEhhieDCvrE2MK5Qk9MyffgQyuxQTm6BChfeZNtcOLHp9IcWRVcIcBQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3.0.0" + }, + "engines": { + "node": ">=0.10.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/express" + } + }, + "node_modules/@inquirer/figures": { + "version": "1.0.14", + "resolved": "https://registry.npmjs.org/@inquirer/figures/-/figures-1.0.14.tgz", + "integrity": "sha512-DbFgdt+9/OZYFM+19dbpXOSeAstPy884FPy1KjDu4anWwymZeOYhMY1mdFri172htv6mvc/uvIAAi7b7tvjJBQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=18" + } + }, "node_modules/@istanbuljs/load-nyc-config": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz", @@ -1977,45 +1979,98 @@ "node": ">=8" } }, - "node_modules/@istanbuljs/schema": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz", - "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==", - "dev": true, - "license": "MIT", + "node_modules/@istanbuljs/load-nyc-config/node_modules/find-up": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", + "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", + "dev": true, + "license": "MIT", + "dependencies": { + "locate-path": "^5.0.0", + "path-exists": "^4.0.0" + }, "engines": { "node": ">=8" } }, - "node_modules/@jridgewell/gen-mapping": { - "version": "0.3.8", - "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.8.tgz", - "integrity": "sha512-imAbBGkb+ebQyxKgzv5Hu2nmROxoDOXHh80evxdoXNOrvAnVx7zimzc1Oo5h9RlfV4vPXaE2iM5pOFbvOCClWA==", + "node_modules/@istanbuljs/load-nyc-config/node_modules/locate-path": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", + "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", "dev": true, "license": "MIT", "dependencies": { - "@jridgewell/set-array": "^1.2.1", - "@jridgewell/sourcemap-codec": "^1.4.10", - "@jridgewell/trace-mapping": "^0.3.24" + "p-locate": "^4.1.0" }, "engines": { - "node": ">=6.0.0" + "node": ">=8" } }, - "node_modules/@jridgewell/resolve-uri": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", - "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", + "node_modules/@istanbuljs/load-nyc-config/node_modules/p-limit": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", + "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", "dev": true, "license": "MIT", + "dependencies": { + "p-try": "^2.0.0" + }, "engines": { - "node": ">=6.0.0" + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/@jridgewell/set-array": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", - "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", + "node_modules/@istanbuljs/load-nyc-config/node_modules/p-locate": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", + "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", + "dev": true, + "license": "MIT", + "dependencies": { + "p-limit": "^2.2.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/@istanbuljs/schema": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz", + "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/@jridgewell/gen-mapping": { + "version": "0.3.13", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.13.tgz", + "integrity": "sha512-2kkt/7niJ6MgEPxF0bYdQ6etZaA+fQvDcLKckhy1yIQOzaoKjBBjSj63/aLVjYE3qhRt5dvM+uUyfCg6UKCBbA==", + "dev": true, + "license": "MIT", + "dependencies": { + "@jridgewell/sourcemap-codec": "^1.5.0", + "@jridgewell/trace-mapping": "^0.3.24" + } + }, + "node_modules/@jridgewell/remapping": { + "version": "2.3.5", + "resolved": "https://registry.npmjs.org/@jridgewell/remapping/-/remapping-2.3.5.tgz", + "integrity": "sha512-LI9u/+laYG4Ds1TDKSJW2YPrIlcVYOwi2fUC6xB43lueCjgxV4lffOCZCtYFiH6TNOX+tQKXx97T4IKHbhyHEQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "@jridgewell/gen-mapping": "^0.3.5", + "@jridgewell/trace-mapping": "^0.3.24" + } + }, + "node_modules/@jridgewell/resolve-uri": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", + "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", "dev": true, "license": "MIT", "engines": { @@ -2023,9 +2078,9 @@ } }, "node_modules/@jridgewell/source-map": { - "version": "0.3.6", - "resolved": "https://registry.npmjs.org/@jridgewell/source-map/-/source-map-0.3.6.tgz", - "integrity": "sha512-1ZJTZebgqllO79ue2bm3rIGud/bOe0pP5BjSRCRxxYkEZS8STV7zN84UBbiYu7jy+eCKSnVIUgoWWE/tt+shMQ==", + "version": "0.3.11", + "resolved": "https://registry.npmjs.org/@jridgewell/source-map/-/source-map-0.3.11.tgz", + "integrity": "sha512-ZMp1V8ZFcPG5dIWnQLr3NSI1MiCU7UETdS/A0G8V/XWHvJv3ZsFqutJn1Y5RPmAPX6F3BiE397OqveU/9NCuIA==", "dev": true, "license": "MIT", "dependencies": { @@ -2034,16 +2089,16 @@ } }, "node_modules/@jridgewell/sourcemap-codec": { - "version": "1.5.0", - "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz", - "integrity": "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==", + "version": "1.5.5", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.5.tgz", + "integrity": "sha512-cYQ9310grqxueWbl+WuIUIaiUaDcj7WOq5fVhEljNVgRfOUhY9fy2zTvfoqWsnebh8Sl70VScFbICvJnLKB0Og==", "dev": true, "license": "MIT" }, "node_modules/@jridgewell/trace-mapping": { - "version": "0.3.25", - "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz", - "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==", + "version": "0.3.31", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.31.tgz", + "integrity": "sha512-zzNR+SdQSDJzc8joaeP8QQoCQr8NuYx2dIIytl1QeBEZHJ9uW6hebsrYgbz8hJwUQao3TWCMtmfV8Nu1twOLAw==", "dev": true, "license": "MIT", "dependencies": { @@ -2052,9 +2107,9 @@ } }, "node_modules/@pkgr/core": { - "version": "0.2.7", - "resolved": "https://registry.npmjs.org/@pkgr/core/-/core-0.2.7.tgz", - "integrity": "sha512-YLT9Zo3oNPJoBjBc4q8G2mjU4tqIbf5CEOORbUUr48dCD9q3umJ3IPlVqOqDakPfd2HuwccBaqlGhN4Gmr5OWg==", + "version": "0.2.9", + "resolved": "https://registry.npmjs.org/@pkgr/core/-/core-0.2.9.tgz", + "integrity": "sha512-QNqXyfVS2wm9hweSYD2O7F0G06uurj9kZ96TRQE5Y9hU7+tgdZwIkbAKc5Ocy1HxEY2kuDQa6cQ1WRs/O5LFKA==", "dev": true, "license": "MIT", "engines": { @@ -2064,6 +2119,22 @@ "url": "https://opencollective.com/pkgr" } }, + "node_modules/@playwright/test": { + "version": "1.56.1", + "resolved": "https://registry.npmjs.org/@playwright/test/-/test-1.56.1.tgz", + "integrity": "sha512-vSMYtL/zOcFpvJCW71Q/OEGQb7KYBPAdKh35WNSkaZA75JlAO8ED8UN6GUNTm3drWomcbcqRPFqQbLae8yBTdg==", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "playwright": "1.56.1" + }, + "bin": { + "playwright": "cli.js" + }, + "engines": { + "node": ">=18" + } + }, "node_modules/@rollup/plugin-commonjs": { "version": "28.0.6", "resolved": "https://registry.npmjs.org/@rollup/plugin-commonjs/-/plugin-commonjs-28.0.6.tgz", @@ -2116,10 +2187,32 @@ } } }, + "node_modules/@rollup/plugin-replace": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/@rollup/plugin-replace/-/plugin-replace-6.0.2.tgz", + "integrity": "sha512-7QaYCf8bqF04dOy7w/eHmJeNExxTYwvKAmlSAH/EaWWUzbT0h5sbF6bktFoX/0F/0qwng5/dWFMyf3gzaM8DsQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "@rollup/pluginutils": "^5.0.1", + "magic-string": "^0.30.3" + }, + "engines": { + "node": ">=14.0.0" + }, + "peerDependencies": { + "rollup": "^1.20.0||^2.0.0||^3.0.0||^4.0.0" + }, + "peerDependenciesMeta": { + "rollup": { + "optional": true + } + } + }, "node_modules/@rollup/pluginutils": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-5.2.0.tgz", - "integrity": "sha512-qWJ2ZTbmumwiLFomfzTyt5Kng4hwPi9rwCYN4SHb6eaRU1KNO4ccxINHr/VhH4GgPlt1XfSTLX2LBTme8ne4Zw==", + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-5.3.0.tgz", + "integrity": "sha512-5EdhGZtnu3V88ces7s53hhfK5KSASnJZv8Lulpc04cWO3REESroJXg73DFsOmgbU2BhwV0E20bu2IDZb3VKW4Q==", "dev": true, "license": "MIT", "dependencies": { @@ -2140,9 +2233,9 @@ } }, "node_modules/@rollup/rollup-android-arm-eabi": { - "version": "4.44.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.44.0.tgz", - "integrity": "sha512-xEiEE5oDW6tK4jXCAyliuntGR+amEMO7HLtdSshVuhFnKTYoeYMyXQK7pLouAJJj5KHdwdn87bfHAR2nSdNAUA==", + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.52.4.tgz", + "integrity": "sha512-BTm2qKNnWIQ5auf4deoetINJm2JzvihvGb9R6K/ETwKLql/Bb3Eg2H1FBp1gUb4YGbydMA3jcmQTR73q7J+GAA==", "cpu": [ "arm" ], @@ -2154,9 +2247,9 @@ ] }, "node_modules/@rollup/rollup-android-arm64": { - "version": "4.44.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.44.0.tgz", - "integrity": "sha512-uNSk/TgvMbskcHxXYHzqwiyBlJ/lGcv8DaUfcnNwict8ba9GTTNxfn3/FAoFZYgkaXXAdrAA+SLyKplyi349Jw==", + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.52.4.tgz", + "integrity": "sha512-P9LDQiC5vpgGFgz7GSM6dKPCiqR3XYN1WwJKA4/BUVDjHpYsf3iBEmVz62uyq20NGYbiGPR5cNHI7T1HqxNs2w==", "cpu": [ "arm64" ], @@ -2168,9 +2261,9 @@ ] }, "node_modules/@rollup/rollup-darwin-arm64": { - "version": "4.44.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.44.0.tgz", - "integrity": "sha512-VGF3wy0Eq1gcEIkSCr8Ke03CWT+Pm2yveKLaDvq51pPpZza3JX/ClxXOCmTYYq3us5MvEuNRTaeyFThCKRQhOA==", + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.52.4.tgz", + "integrity": "sha512-QRWSW+bVccAvZF6cbNZBJwAehmvG9NwfWHwMy4GbWi/BQIA/laTIktebT2ipVjNncqE6GLPxOok5hsECgAxGZg==", "cpu": [ "arm64" ], @@ -2182,9 +2275,9 @@ ] }, "node_modules/@rollup/rollup-darwin-x64": { - "version": "4.44.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.44.0.tgz", - "integrity": "sha512-fBkyrDhwquRvrTxSGH/qqt3/T0w5Rg0L7ZIDypvBPc1/gzjJle6acCpZ36blwuwcKD/u6oCE/sRWlUAcxLWQbQ==", + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.52.4.tgz", + "integrity": "sha512-hZgP05pResAkRJxL1b+7yxCnXPGsXU0fG9Yfd6dUaoGk+FhdPKCJ5L1Sumyxn8kvw8Qi5PvQ8ulenUbRjzeCTw==", "cpu": [ "x64" ], @@ -2196,9 +2289,9 @@ ] }, "node_modules/@rollup/rollup-freebsd-arm64": { - "version": "4.44.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-arm64/-/rollup-freebsd-arm64-4.44.0.tgz", - "integrity": "sha512-u5AZzdQJYJXByB8giQ+r4VyfZP+walV+xHWdaFx/1VxsOn6eWJhK2Vl2eElvDJFKQBo/hcYIBg/jaKS8ZmKeNQ==", + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-arm64/-/rollup-freebsd-arm64-4.52.4.tgz", + "integrity": "sha512-xmc30VshuBNUd58Xk4TKAEcRZHaXlV+tCxIXELiE9sQuK3kG8ZFgSPi57UBJt8/ogfhAF5Oz4ZSUBN77weM+mQ==", "cpu": [ "arm64" ], @@ -2210,9 +2303,9 @@ ] }, "node_modules/@rollup/rollup-freebsd-x64": { - "version": "4.44.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-x64/-/rollup-freebsd-x64-4.44.0.tgz", - "integrity": "sha512-qC0kS48c/s3EtdArkimctY7h3nHicQeEUdjJzYVJYR3ct3kWSafmn6jkNCA8InbUdge6PVx6keqjk5lVGJf99g==", + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-x64/-/rollup-freebsd-x64-4.52.4.tgz", + "integrity": "sha512-WdSLpZFjOEqNZGmHflxyifolwAiZmDQzuOzIq9L27ButpCVpD7KzTRtEG1I0wMPFyiyUdOO+4t8GvrnBLQSwpw==", "cpu": [ "x64" ], @@ -2224,9 +2317,9 @@ ] }, "node_modules/@rollup/rollup-linux-arm-gnueabihf": { - "version": "4.44.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.44.0.tgz", - "integrity": "sha512-x+e/Z9H0RAWckn4V2OZZl6EmV0L2diuX3QB0uM1r6BvhUIv6xBPL5mrAX2E3e8N8rEHVPwFfz/ETUbV4oW9+lQ==", + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.52.4.tgz", + "integrity": "sha512-xRiOu9Of1FZ4SxVbB0iEDXc4ddIcjCv2aj03dmW8UrZIW7aIQ9jVJdLBIhxBI+MaTnGAKyvMwPwQnoOEvP7FgQ==", "cpu": [ "arm" ], @@ -2238,9 +2331,9 @@ ] }, "node_modules/@rollup/rollup-linux-arm-musleabihf": { - "version": "4.44.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.44.0.tgz", - "integrity": "sha512-1exwiBFf4PU/8HvI8s80icyCcnAIB86MCBdst51fwFmH5dyeoWVPVgmQPcKrMtBQ0W5pAs7jBCWuRXgEpRzSCg==", + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.52.4.tgz", + "integrity": "sha512-FbhM2p9TJAmEIEhIgzR4soUcsW49e9veAQCziwbR+XWB2zqJ12b4i/+hel9yLiD8pLncDH4fKIPIbt5238341Q==", "cpu": [ "arm" ], @@ -2252,9 +2345,9 @@ ] }, "node_modules/@rollup/rollup-linux-arm64-gnu": { - "version": "4.44.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.44.0.tgz", - "integrity": "sha512-ZTR2mxBHb4tK4wGf9b8SYg0Y6KQPjGpR4UWwTFdnmjB4qRtoATZ5dWn3KsDwGa5Z2ZBOE7K52L36J9LueKBdOQ==", + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.52.4.tgz", + "integrity": "sha512-4n4gVwhPHR9q/g8lKCyz0yuaD0MvDf7dV4f9tHt0C73Mp8h38UCtSCSE6R9iBlTbXlmA8CjpsZoujhszefqueg==", "cpu": [ "arm64" ], @@ -2266,9 +2359,9 @@ ] }, "node_modules/@rollup/rollup-linux-arm64-musl": { - "version": "4.44.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.44.0.tgz", - "integrity": "sha512-GFWfAhVhWGd4r6UxmnKRTBwP1qmModHtd5gkraeW2G490BpFOZkFtem8yuX2NyafIP/mGpRJgTJ2PwohQkUY/Q==", + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.52.4.tgz", + "integrity": "sha512-u0n17nGA0nvi/11gcZKsjkLj1QIpAuPFQbR48Subo7SmZJnGxDpspyw2kbpuoQnyK+9pwf3pAoEXerJs/8Mi9g==", "cpu": [ "arm64" ], @@ -2279,10 +2372,10 @@ "linux" ] }, - "node_modules/@rollup/rollup-linux-loongarch64-gnu": { - "version": "4.44.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-loongarch64-gnu/-/rollup-linux-loongarch64-gnu-4.44.0.tgz", - "integrity": "sha512-xw+FTGcov/ejdusVOqKgMGW3c4+AgqrfvzWEVXcNP6zq2ue+lsYUgJ+5Rtn/OTJf7e2CbgTFvzLW2j0YAtj0Gg==", + "node_modules/@rollup/rollup-linux-loong64-gnu": { + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-loong64-gnu/-/rollup-linux-loong64-gnu-4.52.4.tgz", + "integrity": "sha512-0G2c2lpYtbTuXo8KEJkDkClE/+/2AFPdPAbmaHoE870foRFs4pBrDehilMcrSScrN/fB/1HTaWO4bqw+ewBzMQ==", "cpu": [ "loong64" ], @@ -2293,10 +2386,10 @@ "linux" ] }, - "node_modules/@rollup/rollup-linux-powerpc64le-gnu": { - "version": "4.44.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.44.0.tgz", - "integrity": "sha512-bKGibTr9IdF0zr21kMvkZT4K6NV+jjRnBoVMt2uNMG0BYWm3qOVmYnXKzx7UhwrviKnmK46IKMByMgvpdQlyJQ==", + "node_modules/@rollup/rollup-linux-ppc64-gnu": { + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-ppc64-gnu/-/rollup-linux-ppc64-gnu-4.52.4.tgz", + "integrity": "sha512-teSACug1GyZHmPDv14VNbvZFX779UqWTsd7KtTM9JIZRDI5NUwYSIS30kzI8m06gOPB//jtpqlhmraQ68b5X2g==", "cpu": [ "ppc64" ], @@ -2308,9 +2401,9 @@ ] }, "node_modules/@rollup/rollup-linux-riscv64-gnu": { - "version": "4.44.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.44.0.tgz", - "integrity": "sha512-vV3cL48U5kDaKZtXrti12YRa7TyxgKAIDoYdqSIOMOFBXqFj2XbChHAtXquEn2+n78ciFgr4KIqEbydEGPxXgA==", + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.52.4.tgz", + "integrity": "sha512-/MOEW3aHjjs1p4Pw1Xk4+3egRevx8Ji9N6HUIA1Ifh8Q+cg9dremvFCUbOX2Zebz80BwJIgCBUemjqhU5XI5Eg==", "cpu": [ "riscv64" ], @@ -2322,9 +2415,9 @@ ] }, "node_modules/@rollup/rollup-linux-riscv64-musl": { - "version": "4.44.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-musl/-/rollup-linux-riscv64-musl-4.44.0.tgz", - "integrity": "sha512-TDKO8KlHJuvTEdfw5YYFBjhFts2TR0VpZsnLLSYmB7AaohJhM8ctDSdDnUGq77hUh4m/djRafw+9zQpkOanE2Q==", + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-musl/-/rollup-linux-riscv64-musl-4.52.4.tgz", + "integrity": "sha512-1HHmsRyh845QDpEWzOFtMCph5Ts+9+yllCrREuBR/vg2RogAQGGBRC8lDPrPOMnrdOJ+mt1WLMOC2Kao/UwcvA==", "cpu": [ "riscv64" ], @@ -2336,9 +2429,9 @@ ] }, "node_modules/@rollup/rollup-linux-s390x-gnu": { - "version": "4.44.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.44.0.tgz", - "integrity": "sha512-8541GEyktXaw4lvnGp9m84KENcxInhAt6vPWJ9RodsB/iGjHoMB2Pp5MVBCiKIRxrxzJhGCxmNzdu+oDQ7kwRA==", + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.52.4.tgz", + "integrity": "sha512-seoeZp4L/6D1MUyjWkOMRU6/iLmCU2EjbMTyAG4oIOs1/I82Y5lTeaxW0KBfkUdHAWN7j25bpkt0rjnOgAcQcA==", "cpu": [ "s390x" ], @@ -2350,9 +2443,9 @@ ] }, "node_modules/@rollup/rollup-linux-x64-gnu": { - "version": "4.44.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.44.0.tgz", - "integrity": "sha512-iUVJc3c0o8l9Sa/qlDL2Z9UP92UZZW1+EmQ4xfjTc1akr0iUFZNfxrXJ/R1T90h/ILm9iXEY6+iPrmYB3pXKjw==", + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.52.4.tgz", + "integrity": "sha512-Wi6AXf0k0L7E2gteNsNHUs7UMwCIhsCTs6+tqQ5GPwVRWMaflqGec4Sd8n6+FNFDw9vGcReqk2KzBDhCa1DLYg==", "cpu": [ "x64" ], @@ -2364,9 +2457,9 @@ ] }, "node_modules/@rollup/rollup-linux-x64-musl": { - "version": "4.44.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.44.0.tgz", - "integrity": "sha512-PQUobbhLTQT5yz/SPg116VJBgz+XOtXt8D1ck+sfJJhuEsMj2jSej5yTdp8CvWBSceu+WW+ibVL6dm0ptG5fcA==", + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.52.4.tgz", + "integrity": "sha512-dtBZYjDmCQ9hW+WgEkaffvRRCKm767wWhxsFW3Lw86VXz/uJRuD438/XvbZT//B96Vs8oTA8Q4A0AfHbrxP9zw==", "cpu": [ "x64" ], @@ -2377,10 +2470,24 @@ "linux" ] }, + "node_modules/@rollup/rollup-openharmony-arm64": { + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-openharmony-arm64/-/rollup-openharmony-arm64-4.52.4.tgz", + "integrity": "sha512-1ox+GqgRWqaB1RnyZXL8PD6E5f7YyRUJYnCqKpNzxzP0TkaUh112NDrR9Tt+C8rJ4x5G9Mk8PQR3o7Ku2RKqKA==", + "cpu": [ + "arm64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "openharmony" + ] + }, "node_modules/@rollup/rollup-win32-arm64-msvc": { - "version": "4.44.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.44.0.tgz", - "integrity": "sha512-M0CpcHf8TWn+4oTxJfh7LQuTuaYeXGbk0eageVjQCKzYLsajWS/lFC94qlRqOlyC2KvRT90ZrfXULYmukeIy7w==", + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.52.4.tgz", + "integrity": "sha512-8GKr640PdFNXwzIE0IrkMWUNUomILLkfeHjXBi/nUvFlpZP+FA8BKGKpacjW6OUUHaNI6sUURxR2U2g78FOHWQ==", "cpu": [ "arm64" ], @@ -2392,9 +2499,9 @@ ] }, "node_modules/@rollup/rollup-win32-ia32-msvc": { - "version": "4.44.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.44.0.tgz", - "integrity": "sha512-3XJ0NQtMAXTWFW8FqZKcw3gOQwBtVWP/u8TpHP3CRPXD7Pd6s8lLdH3sHWh8vqKCyyiI8xW5ltJScQmBU9j7WA==", + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.52.4.tgz", + "integrity": "sha512-AIy/jdJ7WtJ/F6EcfOb2GjR9UweO0n43jNObQMb6oGxkYTfLcnN7vYYpG+CN3lLxrQkzWnMOoNSHTW54pgbVxw==", "cpu": [ "ia32" ], @@ -2405,10 +2512,10 @@ "win32" ] }, - "node_modules/@rollup/rollup-win32-x64-msvc": { - "version": "4.44.0", - "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.44.0.tgz", - "integrity": "sha512-Q2Mgwt+D8hd5FIPUuPDsvPR7Bguza6yTkJxspDGkZj7tBRn2y4KSWYuIXpftFSjBra76TbKerCV7rgFPQrn+wQ==", + "node_modules/@rollup/rollup-win32-x64-gnu": { + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-gnu/-/rollup-win32-x64-gnu-4.52.4.tgz", + "integrity": "sha512-UF9KfsH9yEam0UjTwAgdK0anlQ7c8/pWPU2yVjyWcF1I1thABt6WXE47cI71pGiZ8wGvxohBoLnxM04L/wj8mQ==", "cpu": [ "x64" ], @@ -2419,18 +2526,19 @@ "win32" ] }, - "node_modules/@sindresorhus/is": { - "version": "4.6.0", - "resolved": "https://registry.npmjs.org/@sindresorhus/is/-/is-4.6.0.tgz", - "integrity": "sha512-t09vSN3MdfsyCHoFcTRCH/iUtG7OJ0CsjzB8cjAmKc/va/kIgeDI/TxsigdncE/4be734m0cvIYwNaV4i2XqAw==", + "node_modules/@rollup/rollup-win32-x64-msvc": { + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.52.4.tgz", + "integrity": "sha512-bf9PtUa0u8IXDVxzRToFQKsNCRz9qLYfR/MpECxl4mRoWYjAeFjgxj1XdZr2M/GNVpT05p+LgQOHopYDlUu6/w==", + "cpu": [ + "x64" + ], "dev": true, "license": "MIT", - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sindresorhus/is?sponsor=1" - } + "optional": true, + "os": [ + "win32" + ] }, "node_modules/@socket.io/component-emitter": { "version": "3.1.2", @@ -2439,32 +2547,6 @@ "dev": true, "license": "MIT" }, - "node_modules/@szmarczak/http-timer": { - "version": "4.0.6", - "resolved": "https://registry.npmjs.org/@szmarczak/http-timer/-/http-timer-4.0.6.tgz", - "integrity": "sha512-4BAffykYOgO+5nzBWYwE3W90sBgLJoUPRWWcL8wlyiM8IB8ipJz3UMJ9KXQd1RKQXpKp8Tutn80HZtWsu2u76w==", - "dev": true, - "license": "MIT", - "dependencies": { - "defer-to-connect": "^2.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/@types/cacheable-request": { - "version": "6.0.3", - "resolved": "https://registry.npmjs.org/@types/cacheable-request/-/cacheable-request-6.0.3.tgz", - "integrity": "sha512-IQ3EbTzGxIigb1I3qPZc1rWJnH0BmSKv5QYTalEwweFvyBDLSAe24zP0le/hyi7ecGfZVlIVAg4BZqb8WBwKqw==", - "dev": true, - "license": "MIT", - "dependencies": { - "@types/http-cache-semantics": "*", - "@types/keyv": "^3.1.4", - "@types/node": "*", - "@types/responselike": "^1.0.0" - } - }, "node_modules/@types/cors": { "version": "2.8.19", "resolved": "https://registry.npmjs.org/@types/cors/-/cors-2.8.19.tgz", @@ -2504,13 +2586,6 @@ "dev": true, "license": "MIT" }, - "node_modules/@types/http-cache-semantics": { - "version": "4.0.4", - "resolved": "https://registry.npmjs.org/@types/http-cache-semantics/-/http-cache-semantics-4.0.4.tgz", - "integrity": "sha512-1m0bIFVc7eJWyve9S0RnuRgcQqF/Xd5QsUZAZeQFr1Q3/p9JWoQQEqmVy+DPTNpGXwhgIetAoYF8JSc33q29QA==", - "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", @@ -2518,44 +2593,14 @@ "dev": true, "license": "MIT" }, - "node_modules/@types/keyv": { - "version": "3.1.4", - "resolved": "https://registry.npmjs.org/@types/keyv/-/keyv-3.1.4.tgz", - "integrity": "sha512-BQ5aZNSCpj7D6K2ksrRCTmKRLEpnPvWDiLPfoGyhZ++8YtiK9d/3DBKPJgry359X/P1PfruyYwvnvwFjuEiEIg==", - "dev": true, - "license": "MIT", - "dependencies": { - "@types/node": "*" - } - }, "node_modules/@types/node": { - "version": "24.0.4", - "resolved": "https://registry.npmjs.org/@types/node/-/node-24.0.4.tgz", - "integrity": "sha512-ulyqAkrhnuNq9pB76DRBTkcS6YsmDALy6Ua63V8OhrOBgbcYt6IOdzpw5P1+dyRIyMerzLkeYWBeOXPpA9GMAA==", - "dev": true, - "license": "MIT", - "dependencies": { - "undici-types": "~7.8.0" - } - }, - "node_modules/@types/puppeteer": { - "version": "5.4.7", - "resolved": "https://registry.npmjs.org/@types/puppeteer/-/puppeteer-5.4.7.tgz", - "integrity": "sha512-JdGWZZYL0vKapXF4oQTC5hLVNfOgdPrqeZ1BiQnGk5cB7HeE91EWUiTdVSdQPobRN8rIcdffjiOgCYJ/S8QrnQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "@types/node": "*" - } - }, - "node_modules/@types/puppeteer-core": { - "version": "5.4.0", - "resolved": "https://registry.npmjs.org/@types/puppeteer-core/-/puppeteer-core-5.4.0.tgz", - "integrity": "sha512-yqRPuv4EFcSkTyin6Yy17pN6Qz2vwVwTCJIDYMXbE3j8vTPhv0nCQlZOl5xfi0WHUkqvQsjAR8hAfjeMCoetwg==", + "version": "24.6.2", + "resolved": "https://registry.npmjs.org/@types/node/-/node-24.6.2.tgz", + "integrity": "sha512-d2L25Y4j+W3ZlNAeMKcy7yDsK425ibcAOO2t7aPTz6gNMH0z2GThtwENCDc0d/Pw9wgyRqE5Px1wkV7naz8ang==", "dev": true, "license": "MIT", "dependencies": { - "@types/puppeteer": "*" + "undici-types": "~7.13.0" } }, "node_modules/@types/resolve": { @@ -2565,124 +2610,6 @@ "dev": true, "license": "MIT" }, - "node_modules/@types/responselike": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/@types/responselike/-/responselike-1.0.3.tgz", - "integrity": "sha512-H/+L+UkTV33uf49PH5pCAUBVPNj2nDBXTN+qS1dOwyyg24l3CcicicCA7ca+HMvJBZcFgl5r8e+RR6elsb4Lyw==", - "dev": true, - "license": "MIT", - "dependencies": { - "@types/node": "*" - } - }, - "node_modules/@types/which": { - "version": "1.3.2", - "resolved": "https://registry.npmjs.org/@types/which/-/which-1.3.2.tgz", - "integrity": "sha512-8oDqyLC7eD4HM307boe2QWKyuzdzWBj56xI/imSl2cpL+U3tCMaTAkMJ4ee5JBZ/FsOJlvRGeIShiZDAl1qERA==", - "dev": true, - "license": "MIT" - }, - "node_modules/@types/yauzl": { - "version": "2.10.3", - "resolved": "https://registry.npmjs.org/@types/yauzl/-/yauzl-2.10.3.tgz", - "integrity": "sha512-oJoftv0LSuaDZE3Le4DbKX+KS9G36NzOeSap90UIK0yMA/NhKJhqlSGtNDORNRaIbQfzjXDrQa0ytJ6mNRGz/Q==", - "dev": true, - "license": "MIT", - "optional": true, - "dependencies": { - "@types/node": "*" - } - }, - "node_modules/@wdio/config": { - "version": "6.12.1", - "resolved": "https://registry.npmjs.org/@wdio/config/-/config-6.12.1.tgz", - "integrity": "sha512-V5hTIW5FNlZ1W33smHF4Rd5BKjGW2KeYhyXDQfXHjqLCeRiirZ9fABCo9plaVQDnwWSUMWYaAaIAifV82/oJCQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "@wdio/logger": "6.10.10", - "deepmerge": "^4.0.0", - "glob": "^7.1.2" - }, - "engines": { - "node": ">=10.0.0" - } - }, - "node_modules/@wdio/logger": { - "version": "6.10.10", - "resolved": "https://registry.npmjs.org/@wdio/logger/-/logger-6.10.10.tgz", - "integrity": "sha512-2nh0hJz9HeZE0VIEMI+oPgjr/Q37ohrR9iqsl7f7GW5ik+PnKYCT9Eab5mR1GNMG60askwbskgGC1S9ygtvrSw==", - "dev": true, - "license": "MIT", - "dependencies": { - "chalk": "^4.0.0", - "loglevel": "^1.6.0", - "loglevel-plugin-prefix": "^0.8.4", - "strip-ansi": "^6.0.0" - }, - "engines": { - "node": ">=10.0.0" - } - }, - "node_modules/@wdio/logger/node_modules/ansi-regex": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", - "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=8" - } - }, - "node_modules/@wdio/logger/node_modules/strip-ansi": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", - "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", - "dev": true, - "license": "MIT", - "dependencies": { - "ansi-regex": "^5.0.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/@wdio/protocols": { - "version": "6.12.0", - "resolved": "https://registry.npmjs.org/@wdio/protocols/-/protocols-6.12.0.tgz", - "integrity": "sha512-UhTBZxClCsM3VjaiDp4DoSCnsa7D1QNmI2kqEBfIpyNkT3GcZhJb7L+nL0fTkzCwi7+/uLastb3/aOwH99gt0A==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=10.0.0" - } - }, - "node_modules/@wdio/repl": { - "version": "6.11.0", - "resolved": "https://registry.npmjs.org/@wdio/repl/-/repl-6.11.0.tgz", - "integrity": "sha512-FxrFKiTkFyELNGGVEH1uijyvNY7lUpmff6x+FGskFGZB4uSRs0rxkOMaEjxnxw7QP1zgQKr2xC7GyO03gIGRGg==", - "dev": true, - "license": "MIT", - "dependencies": { - "@wdio/utils": "6.11.0" - }, - "engines": { - "node": ">=10.0.0" - } - }, - "node_modules/@wdio/utils": { - "version": "6.11.0", - "resolved": "https://registry.npmjs.org/@wdio/utils/-/utils-6.11.0.tgz", - "integrity": "sha512-vf0sOQzd28WbI26d6/ORrQ4XKWTzSlWLm9W/K/eJO0NASKPEzR+E+Q2kaa+MJ4FKXUpjbt+Lxfo+C26TzBk7tg==", - "dev": true, - "license": "MIT", - "dependencies": { - "@wdio/logger": "6.10.10" - }, - "engines": { - "node": ">=10.0.0" - } - }, "node_modules/@webassemblyjs/ast": { "version": "1.14.1", "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.14.1.tgz", @@ -2885,6 +2812,19 @@ "node": ">=0.4.0" } }, + "node_modules/acorn-import-phases": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/acorn-import-phases/-/acorn-import-phases-1.0.4.tgz", + "integrity": "sha512-wKmbr/DDiIXzEOiWrTTUcDm24kQ2vGfZQvM2fwg2vXqR5uW6aapr7ObPtj1th32b9u90/Pf4AItvdTh42fBmVQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=10.13.0" + }, + "peerDependencies": { + "acorn": "^8.14.0" + } + }, "node_modules/acorn-jsx": { "version": "5.3.2", "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", @@ -2902,16 +2842,6 @@ "dev": true, "license": "MIT" }, - "node_modules/agent-base": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-5.1.1.tgz", - "integrity": "sha512-TMeqbNl2fMW0nMjTEPOwe3J/PRFP4vqeoNuQMG0HlMrtm5QxKqdvAkZ1pRBQ/ulIyDD5Yq0nJ7YbdD8ey0TO3g==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">= 6.0.0" - } - }, "node_modules/ajv": { "version": "6.12.6", "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", @@ -2972,9 +2902,9 @@ "license": "MIT" }, "node_modules/ansi-escapes": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-7.0.0.tgz", - "integrity": "sha512-GdYO7a61mR0fOlAsvC9/rIHf7L96sBc6dEWzeOu+KAea5bZyQRPIpojrVoI4AXGJS/ycu/fBTdLrUkA4ODrvjw==", + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-7.1.1.tgz", + "integrity": "sha512-Zhl0ErHcSRUaVfGUeUdDuLgpkEo8KIFjB4Y9uAc46ScOpdDiU1Dbyplh7qWJeJ/ZHpbyMSM26+X3BySgnIz40Q==", "dev": true, "license": "MIT", "dependencies": { @@ -2988,9 +2918,9 @@ } }, "node_modules/ansi-regex": { - "version": "6.1.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.1.0.tgz", - "integrity": "sha512-7HSX4QQb4CspciLpVFwyRe79O3xsIZDDLER21kERQ71oaPodF8jL725AgJMFAYbooIqolJoRLuM81SpeUkpkvA==", + "version": "6.2.2", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.2.2.tgz", + "integrity": "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg==", "dev": true, "license": "MIT", "engines": { @@ -3043,309 +2973,194 @@ "url": "https://github.com/sponsors/jonschlinkert" } }, - "node_modules/arch": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/arch/-/arch-2.2.0.tgz", - "integrity": "sha512-Of/R0wqp83cgHozfIYLbBMnej79U/SVGOOyuB3VVFv1NRM/PSFMK12x9KVtiYzJqmnU5WR2qp0Z5rHb7sWGnFQ==", - "dev": true, - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ], - "license": "MIT" - }, - "node_modules/archive-type": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/archive-type/-/archive-type-4.0.0.tgz", - "integrity": "sha512-zV4Ky0v1F8dBrdYElwTvQhweQ0P7Kwc1aluqJsYtOBP01jXcWCyW2IEfI1YiqsG+Iy7ZR+o5LF1N+PGECBxHWA==", + "node_modules/argparse": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", + "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", "dev": true, "license": "MIT", "dependencies": { - "file-type": "^4.2.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/archive-type/node_modules/file-type": { - "version": "4.4.0", - "resolved": "https://registry.npmjs.org/file-type/-/file-type-4.4.0.tgz", - "integrity": "sha512-f2UbFQEk7LXgWpi5ntcO86OeA/cC80fuDDDaX/fZ2ZGel+AF7leRQqBBW1eJNiiQkrZlAoM6P+VYP5P6bOlDEQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=4" + "sprintf-js": "~1.0.2" } }, - "node_modules/archiver": { - "version": "5.3.2", - "resolved": "https://registry.npmjs.org/archiver/-/archiver-5.3.2.tgz", - "integrity": "sha512-+25nxyyznAXF7Nef3y0EbBeqmGZgeN/BxHX29Rs39djAfaFalmQ89SE6CWyDCHzGL0yt/ycBtNOmGTW0FyGWNw==", + "node_modules/babel-loader": { + "version": "10.0.0", + "resolved": "https://registry.npmjs.org/babel-loader/-/babel-loader-10.0.0.tgz", + "integrity": "sha512-z8jt+EdS61AMw22nSfoNJAZ0vrtmhPRVi6ghL3rCeRZI8cdNYFiV5xeV3HbE7rlZZNmGH8BVccwWt8/ED0QOHA==", "dev": true, "license": "MIT", "dependencies": { - "archiver-utils": "^2.1.0", - "async": "^3.2.4", - "buffer-crc32": "^0.2.1", - "readable-stream": "^3.6.0", - "readdir-glob": "^1.1.2", - "tar-stream": "^2.2.0", - "zip-stream": "^4.1.0" + "find-up": "^5.0.0" }, "engines": { - "node": ">= 10" + "node": "^18.20.0 || ^20.10.0 || >=22.0.0" + }, + "peerDependencies": { + "@babel/core": "^7.12.0", + "webpack": ">=5.61.0" } }, - "node_modules/archiver-utils": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/archiver-utils/-/archiver-utils-2.1.0.tgz", - "integrity": "sha512-bEL/yUb/fNNiNTuUz979Z0Yg5L+LzLxGJz8x79lYmR54fmTIb6ob/hNQgkQnIUDWIFjZVQwl9Xs356I6BAMHfw==", + "node_modules/babel-plugin-istanbul": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-7.0.1.tgz", + "integrity": "sha512-D8Z6Qm8jCvVXtIRkBnqNHX0zJ37rQcFJ9u8WOS6tkYOsRdHBzypCstaxWiu5ZIlqQtviRYbgnRLSoCEvjqcqbA==", "dev": true, - "license": "MIT", + "license": "BSD-3-Clause", + "workspaces": [ + "test/babel-8" + ], "dependencies": { - "glob": "^7.1.4", - "graceful-fs": "^4.2.0", - "lazystream": "^1.0.0", - "lodash.defaults": "^4.2.0", - "lodash.difference": "^4.5.0", - "lodash.flatten": "^4.4.0", - "lodash.isplainobject": "^4.0.6", - "lodash.union": "^4.6.0", - "normalize-path": "^3.0.0", - "readable-stream": "^2.0.0" + "@babel/helper-plugin-utils": "^7.0.0", + "@istanbuljs/load-nyc-config": "^1.0.0", + "@istanbuljs/schema": "^0.1.3", + "istanbul-lib-instrument": "^6.0.2", + "test-exclude": "^6.0.0" }, "engines": { - "node": ">= 6" - } - }, - "node_modules/archiver/node_modules/bl": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/bl/-/bl-4.1.0.tgz", - "integrity": "sha512-1W07cM9gS6DcLperZfFSj+bWLtaPGSOHWhPiGzXmvVJbRLdG82sH/Kn8EtW1VqWVA54AKf2h5k5BbnIbwF3h6w==", - "dev": true, - "license": "MIT", - "dependencies": { - "buffer": "^5.5.0", - "inherits": "^2.0.4", - "readable-stream": "^3.4.0" + "node": ">=12" } }, - "node_modules/archiver/node_modules/readable-stream": { - "version": "3.6.2", - "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", - "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", + "node_modules/babel-plugin-polyfill-corejs2": { + "version": "0.4.14", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.4.14.tgz", + "integrity": "sha512-Co2Y9wX854ts6U8gAAPXfn0GmAyctHuK8n0Yhfjd6t30g7yvKjspvvOo9yG+z52PZRgFErt7Ka2pYnXCjLKEpg==", "dev": true, "license": "MIT", "dependencies": { - "inherits": "^2.0.3", - "string_decoder": "^1.1.1", - "util-deprecate": "^1.0.1" + "@babel/compat-data": "^7.27.7", + "@babel/helper-define-polyfill-provider": "^0.6.5", + "semver": "^6.3.1" }, - "engines": { - "node": ">= 6" + "peerDependencies": { + "@babel/core": "^7.4.0 || ^8.0.0-0 <8.0.0" } }, - "node_modules/archiver/node_modules/tar-stream": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/tar-stream/-/tar-stream-2.2.0.tgz", - "integrity": "sha512-ujeqbceABgwMZxEJnk2HDY2DlnUZ+9oEcb1KzTVfYHio0UE6dG71n60d8D2I4qNvleWrrXpmjpt7vZeF1LnMZQ==", + "node_modules/babel-plugin-polyfill-corejs3": { + "version": "0.13.0", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.13.0.tgz", + "integrity": "sha512-U+GNwMdSFgzVmfhNm8GJUX88AadB3uo9KpJqS3FaqNIPKgySuvMb+bHPsOmmuWyIcuqZj/pzt1RUIUZns4y2+A==", "dev": true, "license": "MIT", "dependencies": { - "bl": "^4.0.3", - "end-of-stream": "^1.4.1", - "fs-constants": "^1.0.0", - "inherits": "^2.0.3", - "readable-stream": "^3.1.1" + "@babel/helper-define-polyfill-provider": "^0.6.5", + "core-js-compat": "^3.43.0" }, - "engines": { - "node": ">=6" + "peerDependencies": { + "@babel/core": "^7.4.0 || ^8.0.0-0 <8.0.0" } }, - "node_modules/argparse": { - "version": "1.0.10", - "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", - "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", + "node_modules/babel-plugin-polyfill-regenerator": { + "version": "0.6.5", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.6.5.tgz", + "integrity": "sha512-ISqQ2frbiNU9vIJkzg7dlPpznPZ4jOiUQ1uSmB0fEHeowtN3COYRsXr/xexn64NpU13P06jc/L5TgiJXOgrbEg==", "dev": true, "license": "MIT", "dependencies": { - "sprintf-js": "~1.0.2" + "@babel/helper-define-polyfill-provider": "^0.6.5" + }, + "peerDependencies": { + "@babel/core": "^7.4.0 || ^8.0.0-0 <8.0.0" } }, - "node_modules/async": { - "version": "3.2.6", - "resolved": "https://registry.npmjs.org/async/-/async-3.2.6.tgz", - "integrity": "sha512-htCUDlxyyCLMgaM3xXg0C0LW2xqfuQ6p05pCEIsXuyQ+a1koYKTuBMzRNwmybfLgvJDMd0r1LTn4+E0Ti6C2AA==", + "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==", "dev": true, "license": "MIT" }, - "node_modules/asynckit": { - "version": "0.4.0", - "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", - "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==", + "node_modules/base64-js": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", + "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], "license": "MIT" }, - "node_modules/at-least-node": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/at-least-node/-/at-least-node-1.0.0.tgz", - "integrity": "sha512-+q/t7Ekv1EDY2l6Gda6LLiX14rU9TV20Wa3ofeQmwPFZbOMo9DXrLbOjFaaclkXKWidIaopwAObQDqwWtGUjqg==", + "node_modules/base64id": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/base64id/-/base64id-2.0.0.tgz", + "integrity": "sha512-lGe34o6EHj9y3Kts9R4ZYs/Gr+6N7MCaMlIFA3F1R2O5/m7K06AxfSeO5530PEERE6/WyEg3lsuyw4GHlPZHog==", "dev": true, - "license": "ISC", + "license": "MIT", "engines": { - "node": ">= 4.0.0" + "node": "^4.5.0 || >= 5.9" } }, - "node_modules/atob": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/atob/-/atob-2.1.2.tgz", - "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==", + "node_modules/baseline-browser-mapping": { + "version": "2.8.11", + "resolved": "https://registry.npmjs.org/baseline-browser-mapping/-/baseline-browser-mapping-2.8.11.tgz", + "integrity": "sha512-i+sRXGhz4+QW8aACZ3+r1GAKMt0wlFpeA8M5rOQd0HEYw9zhDrlx9Wc8uQ0IdXakjJRthzglEwfB/yqIjO6iDg==", "dev": true, - "license": "(MIT OR Apache-2.0)", + "license": "Apache-2.0", "bin": { - "atob": "bin/atob.js" - }, - "engines": { - "node": ">= 4.5.0" + "baseline-browser-mapping": "dist/cli.js" } }, - "node_modules/available-typed-arrays": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.7.tgz", - "integrity": "sha512-wvUjBtSGN7+7SjNpq/9M2Tg350UZD3q62IFZLbRAR1bSMlCo1ZaeW+BJ+D090e4hIIZLBcTDWe4Mh4jvUDajzQ==", + "node_modules/binary-extensions": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.3.0.tgz", + "integrity": "sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==", "dev": true, "license": "MIT", - "dependencies": { - "possible-typed-array-names": "^1.0.0" - }, "engines": { - "node": ">= 0.4" + "node": ">=8" }, "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/babel-code-frame": { - "version": "6.26.0", - "resolved": "https://registry.npmjs.org/babel-code-frame/-/babel-code-frame-6.26.0.tgz", - "integrity": "sha512-XqYMR2dfdGMW+hd0IUZ2PwK+fGeFkOxZJ0wY+JaQAHzt1Zx8LcvpiZD2NiGkEG8qx0CfkAOr5xt76d1e8vG90g==", - "dev": true, - "license": "MIT", - "dependencies": { - "chalk": "^1.1.3", - "esutils": "^2.0.2", - "js-tokens": "^3.0.2" - } - }, - "node_modules/babel-code-frame/node_modules/ansi-regex": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", - "integrity": "sha512-TIGnTpdo+E3+pCyAluZvtED5p5wCqLdezCyhPZzKPcxvFplEt4i+W7OONCKgeZFT3+y5NZZfOOS/Bdcanm1MYA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/babel-code-frame/node_modules/ansi-styles": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", - "integrity": "sha512-kmCevFghRiWM7HB5zTPULl4r9bVFSWjz62MhqizDGUrq2NWuNMQyuv4tHHoKJHs69M/MF64lEcHdYIocrdWQYA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" + "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/babel-code-frame/node_modules/chalk": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", - "integrity": "sha512-U3lRVLMSlsCfjqYPbLyVv11M9CPW4I728d6TCKMAOJueEeB9/8o+eSsMnxPJD+Q+K909sdESg7C+tIkoH6on1A==", + "node_modules/bl": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/bl/-/bl-4.1.0.tgz", + "integrity": "sha512-1W07cM9gS6DcLperZfFSj+bWLtaPGSOHWhPiGzXmvVJbRLdG82sH/Kn8EtW1VqWVA54AKf2h5k5BbnIbwF3h6w==", "dev": true, "license": "MIT", "dependencies": { - "ansi-styles": "^2.2.1", - "escape-string-regexp": "^1.0.2", - "has-ansi": "^2.0.0", - "strip-ansi": "^3.0.0", - "supports-color": "^2.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/babel-code-frame/node_modules/escape-string-regexp": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.8.0" + "buffer": "^5.5.0", + "inherits": "^2.0.4", + "readable-stream": "^3.4.0" } }, - "node_modules/babel-code-frame/node_modules/strip-ansi": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", - "integrity": "sha512-VhumSSbBqDTP8p2ZLKj40UjBCV4+v8bUSEpUb4KjRgWk9pbqGF4REFj6KEagidb2f/M6AzC0EmFyDNGaw9OCzg==", + "node_modules/body-parser": { + "version": "1.20.3", + "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.3.tgz", + "integrity": "sha512-7rAxByjUMqQ3/bHJy7D6OGXvx/MMc4IqBn/X0fcM1QUcAItpZrBEYhWGem+tzXH90c+G01ypMcYJBO9Y30203g==", "dev": true, "license": "MIT", "dependencies": { - "ansi-regex": "^2.0.0" + "bytes": "3.1.2", + "content-type": "~1.0.5", + "debug": "2.6.9", + "depd": "2.0.0", + "destroy": "1.2.0", + "http-errors": "2.0.0", + "iconv-lite": "0.4.24", + "on-finished": "2.4.1", + "qs": "6.13.0", + "raw-body": "2.5.2", + "type-is": "~1.6.18", + "unpipe": "1.0.0" }, "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/babel-code-frame/node_modules/supports-color": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", - "integrity": "sha512-KKNVtd6pCYgPIKU4cp2733HWYCpplQhddZLBUryaAHou723x+FRzQ5Df824Fj+IyyuiQTRoub4SnIFfIcrp70g==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.8.0" - } - }, - "node_modules/babel-core": { - "version": "6.26.3", - "resolved": "https://registry.npmjs.org/babel-core/-/babel-core-6.26.3.tgz", - "integrity": "sha512-6jyFLuDmeidKmUEb3NM+/yawG0M2bDZ9Z1qbZP59cyHLz8kYGKYwpJP0UwUKKUiTRNvxfLesJnTedqczP7cTDA==", - "dev": true, - "license": "MIT", - "dependencies": { - "babel-code-frame": "^6.26.0", - "babel-generator": "^6.26.0", - "babel-helpers": "^6.24.1", - "babel-messages": "^6.23.0", - "babel-register": "^6.26.0", - "babel-runtime": "^6.26.0", - "babel-template": "^6.26.0", - "babel-traverse": "^6.26.0", - "babel-types": "^6.26.0", - "babylon": "^6.18.0", - "convert-source-map": "^1.5.1", - "debug": "^2.6.9", - "json5": "^0.5.1", - "lodash": "^4.17.4", - "minimatch": "^3.0.4", - "path-is-absolute": "^1.0.1", - "private": "^0.1.8", - "slash": "^1.0.0", - "source-map": "^0.5.7" + "node": ">= 0.8", + "npm": "1.2.8000 || >= 1.4.16" } }, - "node_modules/babel-core/node_modules/debug": { + "node_modules/body-parser/node_modules/debug": { "version": "2.6.9", "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", @@ -3355,2124 +3170,695 @@ "ms": "2.0.0" } }, - "node_modules/babel-core/node_modules/ms": { + "node_modules/body-parser/node_modules/ms": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", "dev": true, "license": "MIT" }, - "node_modules/babel-generator": { - "version": "6.26.1", - "resolved": "https://registry.npmjs.org/babel-generator/-/babel-generator-6.26.1.tgz", - "integrity": "sha512-HyfwY6ApZj7BYTcJURpM5tznulaBvyio7/0d4zFOeMPUmfxkCjHocCuoLa2SAGzBI8AREcH3eP3758F672DppA==", + "node_modules/brace-expansion": { + "version": "1.1.12", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.12.tgz", + "integrity": "sha512-9T9UjW3r0UW5c1Q7GTwllptXwhvYmEzFhzMfZ9H7FQWt+uZePjZPjBP/W1ZEyZ1twGWom5/56TF4lPcqjnDHcg==", "dev": true, "license": "MIT", "dependencies": { - "babel-messages": "^6.23.0", - "babel-runtime": "^6.26.0", - "babel-types": "^6.26.0", - "detect-indent": "^4.0.0", - "jsesc": "^1.3.0", - "lodash": "^4.17.4", - "source-map": "^0.5.7", - "trim-right": "^1.0.1" + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" } }, - "node_modules/babel-helpers": { - "version": "6.24.1", - "resolved": "https://registry.npmjs.org/babel-helpers/-/babel-helpers-6.24.1.tgz", - "integrity": "sha512-n7pFrqQm44TCYvrCDb0MqabAF+JUBq+ijBvNMUxpkLjJaAu32faIexewMumrH5KLLJ1HDyT0PTEqRyAe/GwwuQ==", + "node_modules/braces": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", + "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", "dev": true, "license": "MIT", "dependencies": { - "babel-runtime": "^6.22.0", - "babel-template": "^6.24.1" + "fill-range": "^7.1.1" + }, + "engines": { + "node": ">=8" } }, - "node_modules/babel-loader": { - "version": "10.0.0", - "resolved": "https://registry.npmjs.org/babel-loader/-/babel-loader-10.0.0.tgz", - "integrity": "sha512-z8jt+EdS61AMw22nSfoNJAZ0vrtmhPRVi6ghL3rCeRZI8cdNYFiV5xeV3HbE7rlZZNmGH8BVccwWt8/ED0QOHA==", + "node_modules/browserslist": { + "version": "4.26.3", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.26.3.tgz", + "integrity": "sha512-lAUU+02RFBuCKQPj/P6NgjlbCnLBMp4UtgTx7vNHd3XSIJF87s9a5rA3aH2yw3GS9DqZAUbOtZdCCiZeVRqt0w==", "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/browserslist" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], "license": "MIT", "dependencies": { - "find-up": "^5.0.0" + "baseline-browser-mapping": "^2.8.9", + "caniuse-lite": "^1.0.30001746", + "electron-to-chromium": "^1.5.227", + "node-releases": "^2.0.21", + "update-browserslist-db": "^1.1.3" }, - "engines": { - "node": "^18.20.0 || ^20.10.0 || >=22.0.0" - }, - "peerDependencies": { - "@babel/core": "^7.12.0", - "webpack": ">=5.61.0" - } - }, - "node_modules/babel-loader/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/babel-loader/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/babel-loader/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/babel-loader/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/babel-messages": { - "version": "6.23.0", - "resolved": "https://registry.npmjs.org/babel-messages/-/babel-messages-6.23.0.tgz", - "integrity": "sha512-Bl3ZiA+LjqaMtNYopA9TYE9HP1tQ+E5dLxE0XrAzcIJeK2UqF0/EaqXwBn9esd4UmTfEab+P+UYQ1GnioFIb/w==", - "dev": true, - "license": "MIT", - "dependencies": { - "babel-runtime": "^6.22.0" - } - }, - "node_modules/babel-plugin-istanbul": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-7.0.0.tgz", - "integrity": "sha512-C5OzENSx/A+gt7t4VH1I2XsflxyPUmXRFPKBxt33xncdOmq7oROVM3bZv9Ysjjkv8OJYDMa+tKuKMvqU/H3xdw==", - "dev": true, - "license": "BSD-3-Clause", - "dependencies": { - "@babel/helper-plugin-utils": "^7.0.0", - "@istanbuljs/load-nyc-config": "^1.0.0", - "@istanbuljs/schema": "^0.1.3", - "istanbul-lib-instrument": "^6.0.2", - "test-exclude": "^6.0.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/babel-plugin-polyfill-corejs2": { - "version": "0.4.13", - "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.4.13.tgz", - "integrity": "sha512-3sX/eOms8kd3q2KZ6DAhKPc0dgm525Gqq5NtWKZ7QYYZEv57OQ54KtblzJzH1lQF/eQxO8KjWGIK9IPUJNus5g==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/compat-data": "^7.22.6", - "@babel/helper-define-polyfill-provider": "^0.6.4", - "semver": "^6.3.1" - }, - "peerDependencies": { - "@babel/core": "^7.4.0 || ^8.0.0-0 <8.0.0" - } - }, - "node_modules/babel-plugin-polyfill-corejs2/node_modules/semver": { - "version": "6.3.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", - "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", - "dev": true, - "license": "ISC", - "bin": { - "semver": "bin/semver.js" - } - }, - "node_modules/babel-plugin-polyfill-corejs3": { - "version": "0.11.1", - "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.11.1.tgz", - "integrity": "sha512-yGCqvBT4rwMczo28xkH/noxJ6MZ4nJfkVYdoDaC/utLtWrXxv27HVrzAeSbqR8SxDsp46n0YF47EbHoixy6rXQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/helper-define-polyfill-provider": "^0.6.3", - "core-js-compat": "^3.40.0" - }, - "peerDependencies": { - "@babel/core": "^7.4.0 || ^8.0.0-0 <8.0.0" - } - }, - "node_modules/babel-plugin-polyfill-regenerator": { - "version": "0.6.4", - "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.6.4.tgz", - "integrity": "sha512-7gD3pRadPrbjhjLyxebmx/WrFYcuSjZ0XbdUujQMZ/fcE9oeewk2U/7PCvez84UeuK3oSjmPZ0Ch0dlupQvGzw==", - "dev": true, - "license": "MIT", - "dependencies": { - "@babel/helper-define-polyfill-provider": "^0.6.4" - }, - "peerDependencies": { - "@babel/core": "^7.4.0 || ^8.0.0-0 <8.0.0" - } - }, - "node_modules/babel-register": { - "version": "6.26.0", - "resolved": "https://registry.npmjs.org/babel-register/-/babel-register-6.26.0.tgz", - "integrity": "sha512-veliHlHX06wjaeY8xNITbveXSiI+ASFnOqvne/LaIJIqOWi2Ogmj91KOugEz/hoh/fwMhXNBJPCv8Xaz5CyM4A==", - "dev": true, - "license": "MIT", - "dependencies": { - "babel-core": "^6.26.0", - "babel-runtime": "^6.26.0", - "core-js": "^2.5.0", - "home-or-tmp": "^2.0.0", - "lodash": "^4.17.4", - "mkdirp": "^0.5.1", - "source-map-support": "^0.4.15" - } - }, - "node_modules/babel-runtime": { - "version": "6.26.0", - "resolved": "https://registry.npmjs.org/babel-runtime/-/babel-runtime-6.26.0.tgz", - "integrity": "sha512-ITKNuq2wKlW1fJg9sSW52eepoYgZBggvOAHC0u/CYu/qxQ9EVzThCgR69BnSXLHjy2f7SY5zaQ4yt7H9ZVxY2g==", - "dev": true, - "license": "MIT", - "dependencies": { - "core-js": "^2.4.0", - "regenerator-runtime": "^0.11.0" - } - }, - "node_modules/babel-template": { - "version": "6.26.0", - "resolved": "https://registry.npmjs.org/babel-template/-/babel-template-6.26.0.tgz", - "integrity": "sha512-PCOcLFW7/eazGUKIoqH97sO9A2UYMahsn/yRQ7uOk37iutwjq7ODtcTNF+iFDSHNfkctqsLRjLP7URnOx0T1fg==", - "dev": true, - "license": "MIT", - "dependencies": { - "babel-runtime": "^6.26.0", - "babel-traverse": "^6.26.0", - "babel-types": "^6.26.0", - "babylon": "^6.18.0", - "lodash": "^4.17.4" - } - }, - "node_modules/babel-traverse": { - "version": "6.26.0", - "resolved": "https://registry.npmjs.org/babel-traverse/-/babel-traverse-6.26.0.tgz", - "integrity": "sha512-iSxeXx7apsjCHe9c7n8VtRXGzI2Bk1rBSOJgCCjfyXb6v1aCqE1KSEpq/8SXuVN8Ka/Rh1WDTF0MDzkvTA4MIA==", - "dev": true, - "license": "MIT", - "dependencies": { - "babel-code-frame": "^6.26.0", - "babel-messages": "^6.23.0", - "babel-runtime": "^6.26.0", - "babel-types": "^6.26.0", - "babylon": "^6.18.0", - "debug": "^2.6.8", - "globals": "^9.18.0", - "invariant": "^2.2.2", - "lodash": "^4.17.4" - } - }, - "node_modules/babel-traverse/node_modules/debug": { - "version": "2.6.9", - "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", - "dev": true, - "license": "MIT", - "dependencies": { - "ms": "2.0.0" - } - }, - "node_modules/babel-traverse/node_modules/globals": { - "version": "9.18.0", - "resolved": "https://registry.npmjs.org/globals/-/globals-9.18.0.tgz", - "integrity": "sha512-S0nG3CLEQiY/ILxqtztTWH/3iRRdyBLw6KMDxnKMchrtbj2OFmehVh0WUCfW3DUrIgx/qFrJPICrq4Z4sTR9UQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/babel-traverse/node_modules/ms": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", - "dev": true, - "license": "MIT" - }, - "node_modules/babel-types": { - "version": "6.26.0", - "resolved": "https://registry.npmjs.org/babel-types/-/babel-types-6.26.0.tgz", - "integrity": "sha512-zhe3V/26rCWsEZK8kZN+HaQj5yQ1CilTObixFzKW1UWjqG7618Twz6YEsCnjfg5gBcJh02DrpCkS9h98ZqDY+g==", - "dev": true, - "license": "MIT", - "dependencies": { - "babel-runtime": "^6.26.0", - "esutils": "^2.0.2", - "lodash": "^4.17.4", - "to-fast-properties": "^1.0.3" - } - }, - "node_modules/babylon": { - "version": "6.18.0", - "resolved": "https://registry.npmjs.org/babylon/-/babylon-6.18.0.tgz", - "integrity": "sha512-q/UEjfGJ2Cm3oKV71DJz9d25TPnq5rhBVL2Q4fA5wcC3jcrdn7+SssEybFIxwAvvP+YCsCYNKughoF33GxgycQ==", - "dev": true, - "license": "MIT", - "bin": { - "babylon": "bin/babylon.js" - } - }, - "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==", - "dev": true, - "license": "MIT" - }, - "node_modules/base64-js": { - "version": "1.5.1", - "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", - "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", - "dev": true, - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ], - "license": "MIT" - }, - "node_modules/base64id": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/base64id/-/base64id-2.0.0.tgz", - "integrity": "sha512-lGe34o6EHj9y3Kts9R4ZYs/Gr+6N7MCaMlIFA3F1R2O5/m7K06AxfSeO5530PEERE6/WyEg3lsuyw4GHlPZHog==", - "dev": true, - "license": "MIT", - "engines": { - "node": "^4.5.0 || >= 5.9" - } - }, - "node_modules/bin-check": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/bin-check/-/bin-check-4.1.0.tgz", - "integrity": "sha512-b6weQyEUKsDGFlACWSIOfveEnImkJyK/FGW6FAG42loyoquvjdtOIqO6yBFzHyqyVVhNgNkQxxx09SFLK28YnA==", - "dev": true, - "license": "MIT", - "dependencies": { - "execa": "^0.7.0", - "executable": "^4.1.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/bin-version": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/bin-version/-/bin-version-3.1.0.tgz", - "integrity": "sha512-Mkfm4iE1VFt4xd4vH+gx+0/71esbfus2LsnCGe8Pi4mndSPyT+NGES/Eg99jx8/lUGWfu3z2yuB/bt5UB+iVbQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "execa": "^1.0.0", - "find-versions": "^3.0.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/bin-version-check": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/bin-version-check/-/bin-version-check-4.0.0.tgz", - "integrity": "sha512-sR631OrhC+1f8Cvs8WyVWOA33Y8tgwjETNPyyD/myRBXLkfS/vl74FmH/lFcRl9KY3zwGh7jFhvyk9vV3/3ilQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "bin-version": "^3.0.0", - "semver": "^5.6.0", - "semver-truncate": "^1.1.2" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/bin-version-check/node_modules/semver": { - "version": "5.7.2", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", - "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", - "dev": true, - "license": "ISC", - "bin": { - "semver": "bin/semver" - } - }, - "node_modules/bin-version/node_modules/cross-spawn": { - "version": "6.0.6", - "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.6.tgz", - "integrity": "sha512-VqCUuhcd1iB+dsv8gxPttb5iZh/D0iubSP21g36KXdEuf6I5JiioesUVjpCdHV9MZRUfVFlvwtIUyPfxo5trtw==", - "dev": true, - "license": "MIT", - "dependencies": { - "nice-try": "^1.0.4", - "path-key": "^2.0.1", - "semver": "^5.5.0", - "shebang-command": "^1.2.0", - "which": "^1.2.9" - }, - "engines": { - "node": ">=4.8" - } - }, - "node_modules/bin-version/node_modules/execa": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/execa/-/execa-1.0.0.tgz", - "integrity": "sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA==", - "dev": true, - "license": "MIT", - "dependencies": { - "cross-spawn": "^6.0.0", - "get-stream": "^4.0.0", - "is-stream": "^1.1.0", - "npm-run-path": "^2.0.0", - "p-finally": "^1.0.0", - "signal-exit": "^3.0.0", - "strip-eof": "^1.0.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/bin-version/node_modules/get-stream": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", - "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", - "dev": true, - "license": "MIT", - "dependencies": { - "pump": "^3.0.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/bin-version/node_modules/path-key": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", - "integrity": "sha512-fEHGKCSmUSDPv4uoj8AlD+joPlq3peND+HRYyxFz4KPw4z926S/b8rIuFs2FYJg3BwsxJf6A9/3eIdLaYC+9Dw==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=4" - } - }, - "node_modules/bin-version/node_modules/semver": { - "version": "5.7.2", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", - "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", - "dev": true, - "license": "ISC", - "bin": { - "semver": "bin/semver" - } - }, - "node_modules/bin-version/node_modules/shebang-command": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", - "integrity": "sha512-EV3L1+UQWGor21OmnvojK36mhg+TyIKDh3iFBKBohr5xeXIhNBcx8oWdgkTEEQ+BEFFYdLRuqMfd5L84N1V5Vg==", - "dev": true, - "license": "MIT", - "dependencies": { - "shebang-regex": "^1.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/bin-version/node_modules/shebang-regex": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", - "integrity": "sha512-wpoSFAxys6b2a2wHZ1XpDSgD7N9iVjg29Ph9uV/uaP9Ex/KXlkTZTeddxDPSYQpgvzKLGJke2UU0AzoGCjNIvQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/bin-version/node_modules/signal-exit": { - "version": "3.0.7", - "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", - "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", - "dev": true, - "license": "ISC" - }, - "node_modules/bin-version/node_modules/which": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", - "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", - "dev": true, - "license": "ISC", - "dependencies": { - "isexe": "^2.0.0" - }, - "bin": { - "which": "bin/which" - } - }, - "node_modules/bin-wrapper": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/bin-wrapper/-/bin-wrapper-4.1.0.tgz", - "integrity": "sha512-hfRmo7hWIXPkbpi0ZltboCMVrU+0ClXR/JgbCKKjlDjQf6igXa7OwdqNcFWQZPZTgiY7ZpzE3+LjjkLiTN2T7Q==", - "dev": true, - "license": "MIT", - "dependencies": { - "bin-check": "^4.1.0", - "bin-version-check": "^4.0.0", - "download": "^7.1.0", - "import-lazy": "^3.1.0", - "os-filter-obj": "^2.0.0", - "pify": "^4.0.1" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/binary-extensions": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.3.0.tgz", - "integrity": "sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/bl": { - "version": "1.2.3", - "resolved": "https://registry.npmjs.org/bl/-/bl-1.2.3.tgz", - "integrity": "sha512-pvcNpa0UU69UT341rO6AYy4FVAIkUHuZXRIWbq+zHnsVcRzDDjIAhGuuYoi0d//cwIwtt4pkpKycWEfjdV+vww==", - "dev": true, - "license": "MIT", - "dependencies": { - "readable-stream": "^2.3.5", - "safe-buffer": "^5.1.1" - } - }, - "node_modules/body-parser": { - "version": "1.20.3", - "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.3.tgz", - "integrity": "sha512-7rAxByjUMqQ3/bHJy7D6OGXvx/MMc4IqBn/X0fcM1QUcAItpZrBEYhWGem+tzXH90c+G01ypMcYJBO9Y30203g==", - "dev": true, - "license": "MIT", - "dependencies": { - "bytes": "3.1.2", - "content-type": "~1.0.5", - "debug": "2.6.9", - "depd": "2.0.0", - "destroy": "1.2.0", - "http-errors": "2.0.0", - "iconv-lite": "0.4.24", - "on-finished": "2.4.1", - "qs": "6.13.0", - "raw-body": "2.5.2", - "type-is": "~1.6.18", - "unpipe": "1.0.0" - }, - "engines": { - "node": ">= 0.8", - "npm": "1.2.8000 || >= 1.4.16" - } - }, - "node_modules/body-parser/node_modules/debug": { - "version": "2.6.9", - "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", - "dev": true, - "license": "MIT", - "dependencies": { - "ms": "2.0.0" - } - }, - "node_modules/body-parser/node_modules/ms": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", - "dev": true, - "license": "MIT" - }, - "node_modules/boolean": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/boolean/-/boolean-3.2.0.tgz", - "integrity": "sha512-d0II/GO9uf9lfUHH2BQsjxzRJZBdsjgsBiW4BvhWk/3qoKwQFjIDVN19PfX8F2D/r9PCMTtLWjYVCFrpeYUzsw==", - "deprecated": "Package no longer supported. Contact Support at https://www.npmjs.com/support for more info.", - "dev": true, - "license": "MIT" - }, - "node_modules/brace-expansion": { - "version": "1.1.12", - "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.12.tgz", - "integrity": "sha512-9T9UjW3r0UW5c1Q7GTwllptXwhvYmEzFhzMfZ9H7FQWt+uZePjZPjBP/W1ZEyZ1twGWom5/56TF4lPcqjnDHcg==", - "dev": true, - "license": "MIT", - "dependencies": { - "balanced-match": "^1.0.0", - "concat-map": "0.0.1" - } - }, - "node_modules/braces": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", - "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", - "dev": true, - "license": "MIT", - "dependencies": { - "fill-range": "^7.1.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/browserslist": { - "version": "4.25.0", - "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.25.0.tgz", - "integrity": "sha512-PJ8gYKeS5e/whHBh8xrwYK+dAvEj7JXtz6uTucnMRB8OiGTsKccFekoRrjajPBHV8oOY+2tI4uxeceSimKwMFA==", - "dev": true, - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/browserslist" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/browserslist" - }, - { - "type": "github", - "url": "https://github.com/sponsors/ai" - } - ], - "license": "MIT", - "dependencies": { - "caniuse-lite": "^1.0.30001718", - "electron-to-chromium": "^1.5.160", - "node-releases": "^2.0.19", - "update-browserslist-db": "^1.1.3" - }, - "bin": { - "browserslist": "cli.js" - }, - "engines": { - "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" - } - }, - "node_modules/buffer": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz", - "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==", - "dev": true, - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ], - "license": "MIT", - "dependencies": { - "base64-js": "^1.3.1", - "ieee754": "^1.1.13" - } - }, - "node_modules/buffer-alloc": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/buffer-alloc/-/buffer-alloc-1.2.0.tgz", - "integrity": "sha512-CFsHQgjtW1UChdXgbyJGtnm+O/uLQeZdtbDo8mfUgYXCHSM1wgrVxXm6bSyrUuErEb+4sYVGCzASBRot7zyrow==", - "dev": true, - "license": "MIT", - "dependencies": { - "buffer-alloc-unsafe": "^1.1.0", - "buffer-fill": "^1.0.0" - } - }, - "node_modules/buffer-alloc-unsafe": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/buffer-alloc-unsafe/-/buffer-alloc-unsafe-1.1.0.tgz", - "integrity": "sha512-TEM2iMIEQdJ2yjPJoSIsldnleVaAk1oW3DBVUykyOLsEsFmEc9kn+SFFPz+gl54KQNxlDnAwCXosOS9Okx2xAg==", - "dev": true, - "license": "MIT" - }, - "node_modules/buffer-crc32": { - "version": "0.2.13", - "resolved": "https://registry.npmjs.org/buffer-crc32/-/buffer-crc32-0.2.13.tgz", - "integrity": "sha512-VO9Ht/+p3SN7SKWqcrgEzjGbRSJYTx+Q1pTQC0wrWqHx0vpJraQ6GtHx8tvcg1rlK1byhU5gccxgOgj7B0TDkQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": "*" - } - }, - "node_modules/buffer-fill": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/buffer-fill/-/buffer-fill-1.0.0.tgz", - "integrity": "sha512-T7zexNBwiiaCOGDg9xNX9PBmjrubblRkENuptryuI64URkXDFum9il/JGL8Lm8wYfAXpredVXXZz7eMHilimiQ==", - "dev": true, - "license": "MIT" - }, - "node_modules/buffer-from": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", - "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", - "dev": true, - "license": "MIT" - }, - "node_modules/bytes": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", - "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/cacheable-lookup": { - "version": "5.0.4", - "resolved": "https://registry.npmjs.org/cacheable-lookup/-/cacheable-lookup-5.0.4.tgz", - "integrity": "sha512-2/kNscPhpcxrOigMZzbiWF7dz8ilhb/nIHU3EyZiXWXpeq/au8qJ8VhdftMkty3n7Gj6HIGalQG8oiBNB3AJgA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=10.6.0" - } - }, - "node_modules/cacheable-request": { - "version": "7.0.4", - "resolved": "https://registry.npmjs.org/cacheable-request/-/cacheable-request-7.0.4.tgz", - "integrity": "sha512-v+p6ongsrp0yTGbJXjgxPow2+DL93DASP4kXCDKb8/bwRtt9OEF3whggkkDkGNzgcWy2XaF4a8nZglC7uElscg==", - "dev": true, - "license": "MIT", - "dependencies": { - "clone-response": "^1.0.2", - "get-stream": "^5.1.0", - "http-cache-semantics": "^4.0.0", - "keyv": "^4.0.0", - "lowercase-keys": "^2.0.0", - "normalize-url": "^6.0.1", - "responselike": "^2.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/cacheable-request/node_modules/get-stream": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz", - "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==", - "dev": true, - "license": "MIT", - "dependencies": { - "pump": "^3.0.0" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/call-bind": { - "version": "1.0.8", - "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.8.tgz", - "integrity": "sha512-oKlSFMcMwpUg2ednkhQ454wfWiU/ul3CkJe/PEHcTKuiX6RpbehUiFMXu13HalGZxfUwCQzZG747YXBn1im9ww==", - "dev": true, - "license": "MIT", - "dependencies": { - "call-bind-apply-helpers": "^1.0.0", - "es-define-property": "^1.0.0", - "get-intrinsic": "^1.2.4", - "set-function-length": "^1.2.2" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/call-bind-apply-helpers": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/call-bind-apply-helpers/-/call-bind-apply-helpers-1.0.2.tgz", - "integrity": "sha512-Sp1ablJ0ivDkSzjcaJdxEunN5/XvksFJ2sMBFfq6x0ryhQV/2b/KwFe21cMpmHtPOSij8K99/wSfoEuTObmuMQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "es-errors": "^1.3.0", - "function-bind": "^1.1.2" - }, - "engines": { - "node": ">= 0.4" - } - }, - "node_modules/call-bound": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/call-bound/-/call-bound-1.0.4.tgz", - "integrity": "sha512-+ys997U96po4Kx/ABpBCqhA9EuxJaQWDQg7295H4hBphv3IZg0boBKuwYpt4YXp6MZ5AmZQnU/tyMTlRpaSejg==", - "dev": true, - "license": "MIT", - "dependencies": { - "call-bind-apply-helpers": "^1.0.2", - "get-intrinsic": "^1.3.0" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/callsites": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", - "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=6" - } - }, - "node_modules/camel-case": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/camel-case/-/camel-case-4.1.2.tgz", - "integrity": "sha512-gxGWBrTT1JuMx6R+o5PTXMmUnhnVzLQ9SNutD4YqKtI6ap897t3tKECYla6gCWEkplXnlNybEkZg9GEGxKFCgw==", - "dev": true, - "license": "MIT", - "dependencies": { - "pascal-case": "^3.1.2", - "tslib": "^2.0.3" - } - }, - "node_modules/camelcase": { - "version": "5.3.1", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", - "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=6" - } - }, - "node_modules/camelize": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/camelize/-/camelize-1.0.1.tgz", - "integrity": "sha512-dU+Tx2fsypxTgtLoE36npi3UqcjSSMNYfkqgmoEhtZrraP5VWq0K7FkWVTYa8eMPtnU/G2txVsfdCJTn9uzpuQ==", - "dev": true, - "license": "MIT", - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/caniuse-lite": { - "version": "1.0.30001724", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001724.tgz", - "integrity": "sha512-WqJo7p0TbHDOythNTqYujmaJTvtYRZrjpP8TCvH6Vb9CYJerJNKamKzIWOM4BkQatWj9H2lYulpdAQNBe7QhNA==", - "dev": true, - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/browserslist" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/caniuse-lite" - }, - { - "type": "github", - "url": "https://github.com/sponsors/ai" - } - ], - "license": "CC-BY-4.0" - }, - "node_modules/capital-case": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/capital-case/-/capital-case-1.0.4.tgz", - "integrity": "sha512-ds37W8CytHgwnhGGTi88pcPyR15qoNkOpYwmMMfnWqqWgESapLqvDx6huFjQ5vqWSn2Z06173XNA7LtMOeUh1A==", - "dev": true, - "license": "MIT", - "dependencies": { - "no-case": "^3.0.4", - "tslib": "^2.0.3", - "upper-case-first": "^2.0.2" - } - }, - "node_modules/caw": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/caw/-/caw-2.0.1.tgz", - "integrity": "sha512-Cg8/ZSBEa8ZVY9HspcGUYaK63d/bN7rqS3CYCzEGUxuYv6UlmcjzDUz2fCFFHyTvUW5Pk0I+3hkA3iXlIj6guA==", - "dev": true, - "license": "MIT", - "dependencies": { - "get-proxy": "^2.0.0", - "isurl": "^1.0.0-alpha5", - "tunnel-agent": "^0.6.0", - "url-to-options": "^1.0.1" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "license": "MIT", - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/change-case": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/change-case/-/change-case-4.1.2.tgz", - "integrity": "sha512-bSxY2ws9OtviILG1EiY5K7NNxkqg/JnRnFxLtKQ96JaviiIxi7djMrSd0ECT9AC+lttClmYwKw53BWpOMblo7A==", - "dev": true, - "license": "MIT", - "dependencies": { - "camel-case": "^4.1.2", - "capital-case": "^1.0.4", - "constant-case": "^3.0.4", - "dot-case": "^3.0.4", - "header-case": "^2.0.4", - "no-case": "^3.0.4", - "param-case": "^3.0.4", - "pascal-case": "^3.1.2", - "path-case": "^3.0.4", - "sentence-case": "^3.0.4", - "snake-case": "^3.0.4", - "tslib": "^2.0.3" - } - }, - "node_modules/chokidar": { - "version": "3.6.0", - "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", - "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==", - "dev": true, - "license": "MIT", - "dependencies": { - "anymatch": "~3.1.2", - "braces": "~3.0.2", - "glob-parent": "~5.1.2", - "is-binary-path": "~2.1.0", - "is-glob": "~4.0.1", - "normalize-path": "~3.0.0", - "readdirp": "~3.6.0" - }, - "engines": { - "node": ">= 8.10.0" - }, - "funding": { - "url": "https://paulmillr.com/funding/" - }, - "optionalDependencies": { - "fsevents": "~2.3.2" - } - }, - "node_modules/chokidar/node_modules/glob-parent": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", - "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", - "dev": true, - "license": "ISC", - "dependencies": { - "is-glob": "^4.0.1" - }, - "engines": { - "node": ">= 6" - } - }, - "node_modules/chownr": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.4.tgz", - "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==", - "dev": true, - "license": "ISC" - }, - "node_modules/chrome-launcher": { - "version": "0.13.4", - "resolved": "https://registry.npmjs.org/chrome-launcher/-/chrome-launcher-0.13.4.tgz", - "integrity": "sha512-nnzXiDbGKjDSK6t2I+35OAPBy5Pw/39bgkb/ZAFwMhwJbdYBp6aH+vW28ZgtjdU890Q7D+3wN/tB8N66q5Gi2A==", - "dev": true, - "license": "Apache-2.0", - "dependencies": { - "@types/node": "*", - "escape-string-regexp": "^1.0.5", - "is-wsl": "^2.2.0", - "lighthouse-logger": "^1.0.0", - "mkdirp": "^0.5.3", - "rimraf": "^3.0.2" - } - }, - "node_modules/chrome-launcher/node_modules/escape-string-regexp": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.8.0" - } - }, - "node_modules/chrome-trace-event": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/chrome-trace-event/-/chrome-trace-event-1.0.4.tgz", - "integrity": "sha512-rNjApaLzuwaOTjCiT8lSDdGN1APCiqkChLMJxJPWLunPAt5fy8xgU9/jNOchV84wfIxrA0lRQB7oCT8jrn/wrQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=6.0" - } - }, - "node_modules/cli-cursor": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-5.0.0.tgz", - "integrity": "sha512-aCj4O5wKyszjMmDT4tZj93kxyydN/K5zPWSCe6/0AV/AA1pqe5ZBIw0a2ZfPQV7lL5/yb5HsUreJ6UFAF1tEQw==", - "dev": true, - "license": "MIT", - "dependencies": { - "restore-cursor": "^5.0.0" - }, - "engines": { - "node": ">=18" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/cli-truncate": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-4.0.0.tgz", - "integrity": "sha512-nPdaFdQ0h/GEigbPClz11D0v/ZJEwxmeVZGeMo3Z5StPtUTkA9o1lD6QwoirYiSDzbcwn2XcjwmCp68W1IS4TA==", - "dev": true, - "license": "MIT", - "dependencies": { - "slice-ansi": "^5.0.0", - "string-width": "^7.0.0" - }, - "engines": { - "node": ">=18" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/cliui": { - "version": "8.0.1", - "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", - "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", - "dev": true, - "license": "ISC", - "dependencies": { - "string-width": "^4.2.0", - "strip-ansi": "^6.0.1", - "wrap-ansi": "^7.0.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/cliui/node_modules/ansi-regex": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", - "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=8" - } - }, - "node_modules/cliui/node_modules/emoji-regex": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", - "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", - "dev": true, - "license": "MIT" - }, - "node_modules/cliui/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", - "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=8" - } - }, - "node_modules/cliui/node_modules/string-width": { - "version": "4.2.3", - "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", - "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", - "dev": true, - "license": "MIT", - "dependencies": { - "emoji-regex": "^8.0.0", - "is-fullwidth-code-point": "^3.0.0", - "strip-ansi": "^6.0.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/cliui/node_modules/strip-ansi": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", - "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", - "dev": true, - "license": "MIT", - "dependencies": { - "ansi-regex": "^5.0.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/cliui/node_modules/wrap-ansi": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", - "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", - "dev": true, - "license": "MIT", - "dependencies": { - "ansi-styles": "^4.0.0", - "string-width": "^4.1.0", - "strip-ansi": "^6.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/wrap-ansi?sponsor=1" - } - }, - "node_modules/clone-response": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/clone-response/-/clone-response-1.0.3.tgz", - "integrity": "sha512-ROoL94jJH2dUVML2Y/5PEDNaSHgeOdSDicUyS7izcF63G6sTc/FTjLub4b8Il9S8S0beOfYt0TaA5qvFK+w0wA==", - "dev": true, - "license": "MIT", - "dependencies": { - "mimic-response": "^1.0.0" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true, - "license": "MIT" - }, - "node_modules/colorette": { - "version": "2.0.20", - "resolved": "https://registry.npmjs.org/colorette/-/colorette-2.0.20.tgz", - "integrity": "sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w==", - "dev": true, - "license": "MIT" - }, - "node_modules/combined-stream": { - "version": "1.0.8", - "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", - "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", - "dev": true, - "license": "MIT", - "dependencies": { - "delayed-stream": "~1.0.0" - }, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/commander": { - "version": "14.0.0", - "resolved": "https://registry.npmjs.org/commander/-/commander-14.0.0.tgz", - "integrity": "sha512-2uM9rYjPvyq39NwLRqaiLtWHyDC1FvryJDa2ATTVims5YAS4PupsEQsDvP14FqhFr0P49CYDugi59xaxJlTXRA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=20" - } - }, - "node_modules/commondir": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", - "integrity": "sha512-W9pAhw0ja1Edb5GVdIF1mjZw/ASI0AlShXM83UUGe2DVr5TdAPEA1OA8m/g8zWp9x6On7gqufY+FatDbC3MDQg==", - "dev": true, - "license": "MIT" - }, - "node_modules/compress-commons": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/compress-commons/-/compress-commons-4.1.2.tgz", - "integrity": "sha512-D3uMHtGc/fcO1Gt1/L7i1e33VOvD4A9hfQLP+6ewd+BvG/gQ84Yh4oftEhAdjSMgBgwGL+jsppT7JYNpo6MHHg==", - "dev": true, - "license": "MIT", - "dependencies": { - "buffer-crc32": "^0.2.13", - "crc32-stream": "^4.0.2", - "normalize-path": "^3.0.0", - "readable-stream": "^3.6.0" - }, - "engines": { - "node": ">= 10" - } - }, - "node_modules/compress-commons/node_modules/readable-stream": { - "version": "3.6.2", - "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", - "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", - "dev": true, - "license": "MIT", - "dependencies": { - "inherits": "^2.0.3", - "string_decoder": "^1.1.1", - "util-deprecate": "^1.0.1" - }, - "engines": { - "node": ">= 6" - } - }, - "node_modules/concat-map": { - "version": "0.0.1", - "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", - "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", - "dev": true, - "license": "MIT" - }, - "node_modules/config-chain": { - "version": "1.1.13", - "resolved": "https://registry.npmjs.org/config-chain/-/config-chain-1.1.13.tgz", - "integrity": "sha512-qj+f8APARXHrM0hraqXYb2/bOVSV4PvJQlNZ/DVj0QrmNM2q2euizkeuVckQ57J+W0mRH6Hvi+k50M4Jul2VRQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "ini": "^1.3.4", - "proto-list": "~1.2.1" - } - }, - "node_modules/connect": { - "version": "3.7.0", - "resolved": "https://registry.npmjs.org/connect/-/connect-3.7.0.tgz", - "integrity": "sha512-ZqRXc+tZukToSNmh5C2iWMSoV3X1YUcPbqEM4DkEG5tNQXrQUZCNVGGv3IuicnkMtPfGf3Xtp8WCXs295iQ1pQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "debug": "2.6.9", - "finalhandler": "1.1.2", - "parseurl": "~1.3.3", - "utils-merge": "1.0.1" - }, - "engines": { - "node": ">= 0.10.0" - } - }, - "node_modules/connect/node_modules/debug": { - "version": "2.6.9", - "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", - "dev": true, - "license": "MIT", - "dependencies": { - "ms": "2.0.0" - } - }, - "node_modules/connect/node_modules/ms": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", - "dev": true, - "license": "MIT" - }, - "node_modules/constant-case": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/constant-case/-/constant-case-3.0.4.tgz", - "integrity": "sha512-I2hSBi7Vvs7BEuJDr5dDHfzb/Ruj3FyvFyh7KLilAjNQw3Be+xgqUBA2W6scVEcL0hL1dwPRtIqEPVUCKkSsyQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "no-case": "^3.0.4", - "tslib": "^2.0.3", - "upper-case": "^2.0.2" - } - }, - "node_modules/content-disposition": { - "version": "0.5.4", - "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", - "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "safe-buffer": "5.2.1" - }, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/content-type": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", - "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/convert-source-map": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", - "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", - "dev": true, - "license": "MIT" - }, - "node_modules/cookie": { - "version": "0.7.2", - "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.7.2.tgz", - "integrity": "sha512-yki5XnKuf750l50uGTllt6kKILY4nQ1eNIQatoXEByZ5dWgnKqbnqmTrBE5B4N7lrMJKQ2ytWMiTO2o0v6Ew/w==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/core-js": { - "version": "2.6.12", - "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.6.12.tgz", - "integrity": "sha512-Kb2wC0fvsWfQrgk8HU5lW6U/Lcs8+9aaYcy4ZFc6DDlo4nZ7n70dEgE5rtR0oG6ufKDUnrwfWL1mXR5ljDatrQ==", - "deprecated": "core-js@<3.23.3 is no longer maintained and not recommended for usage due to the number of issues. Because of the V8 engine whims, feature detection in old core-js versions could cause a slowdown up to 100x even if nothing is polyfilled. Some versions have web compatibility issues. Please, upgrade your dependencies to the actual version of core-js.", - "dev": true, - "hasInstallScript": true, - "license": "MIT" - }, - "node_modules/core-js-compat": { - "version": "3.43.0", - "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.43.0.tgz", - "integrity": "sha512-2GML2ZsCc5LR7hZYz4AXmjQw8zuy2T//2QntwdnpuYI7jteT6GVYJL7F6C2C57R7gSYrcqVW3lAALefdbhBLDA==", - "dev": true, - "license": "MIT", - "dependencies": { - "browserslist": "^4.25.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/core-js" - } - }, - "node_modules/core-util-is": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", - "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==", - "dev": true, - "license": "MIT" - }, - "node_modules/cors": { - "version": "2.8.5", - "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", - "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", - "dev": true, - "license": "MIT", - "dependencies": { - "object-assign": "^4", - "vary": "^1" - }, - "engines": { - "node": ">= 0.10" - } - }, - "node_modules/crc-32": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/crc-32/-/crc-32-1.2.2.tgz", - "integrity": "sha512-ROmzCKrTnOwybPcJApAA6WBWij23HVfGVNKqqrZpuyZOHqK2CwHSvpGuyt/UNNvaIjEd8X5IFGp4Mh+Ie1IHJQ==", - "dev": true, - "license": "Apache-2.0", - "bin": { - "crc32": "bin/crc32.njs" - }, - "engines": { - "node": ">=0.8" - } - }, - "node_modules/crc32-stream": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/crc32-stream/-/crc32-stream-4.0.3.tgz", - "integrity": "sha512-NT7w2JVU7DFroFdYkeq8cywxrgjPHWkdX1wjpRQXPX5Asews3tA+Ght6lddQO5Mkumffp3X7GEqku3epj2toIw==", - "dev": true, - "license": "MIT", - "dependencies": { - "crc-32": "^1.2.0", - "readable-stream": "^3.4.0" - }, - "engines": { - "node": ">= 10" - } - }, - "node_modules/crc32-stream/node_modules/readable-stream": { - "version": "3.6.2", - "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", - "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", - "dev": true, - "license": "MIT", - "dependencies": { - "inherits": "^2.0.3", - "string_decoder": "^1.1.1", - "util-deprecate": "^1.0.1" + "bin": { + "browserslist": "cli.js" }, "engines": { - "node": ">= 6" + "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" } }, - "node_modules/cross-spawn": { - "version": "7.0.6", - "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.6.tgz", - "integrity": "sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==", + "node_modules/buffer": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz", + "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==", "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], "license": "MIT", "dependencies": { - "path-key": "^3.1.0", - "shebang-command": "^2.0.0", - "which": "^2.0.1" - }, - "engines": { - "node": ">= 8" + "base64-js": "^1.3.1", + "ieee754": "^1.1.13" } }, - "node_modules/css-shorthand-properties": { + "node_modules/buffer-from": { "version": "1.1.2", - "resolved": "https://registry.npmjs.org/css-shorthand-properties/-/css-shorthand-properties-1.1.2.tgz", - "integrity": "sha512-C2AugXIpRGQTxaCW0N7n5jD/p5irUmCrwl03TrnMFBHDbdq44CFWR2zO7rK9xPN4Eo3pUxC4vQzQgbIpzrD1PQ==", - "dev": true, - "license": "MIT" - }, - "node_modules/css-value": { - "version": "0.0.1", - "resolved": "https://registry.npmjs.org/css-value/-/css-value-0.0.1.tgz", - "integrity": "sha512-FUV3xaJ63buRLgHrLQVlVgQnQdR4yqdLGaDu7g8CQcWjInDfM9plBTPI9FRfpahju1UBSaMckeb2/46ApS/V1Q==", - "dev": true - }, - "node_modules/custom-event": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/custom-event/-/custom-event-1.0.1.tgz", - "integrity": "sha512-GAj5FOq0Hd+RsCGVJxZuKaIDXDf3h6GQoNEjFgbLLI/trgtavwUbSnZ5pVfg27DVCaWjIohryS0JFwIJyT2cMg==", + "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", + "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", "dev": true, "license": "MIT" }, - "node_modules/date-format": { - "version": "4.0.14", - "resolved": "https://registry.npmjs.org/date-format/-/date-format-4.0.14.tgz", - "integrity": "sha512-39BOQLs9ZjKh0/patS9nrT8wc3ioX3/eA/zgbKNopnF2wCqJEoxywwwElATYvRsXdnOxA/OQeQoFZ3rFjVajhg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=4.0" - } - }, - "node_modules/debug": { - "version": "4.4.1", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.1.tgz", - "integrity": "sha512-KcKCqiftBJcZr++7ykoDIEwSa3XWowTfNPo92BYxjXiyYEVrUQh2aLyhxBCwww+heortUFxEJYcRzosstTEBYQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "ms": "^2.1.3" - }, - "engines": { - "node": ">=6.0" - }, - "peerDependenciesMeta": { - "supports-color": { - "optional": true - } - } - }, - "node_modules/decode-uri-component": { - "version": "0.2.2", - "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.2.tgz", - "integrity": "sha512-FqUYQ+8o158GyGTrMFJms9qh3CqTKvAqgqsTnkLI8sKu0028orqBhxNMFkFen0zGyg6epACD32pjVk58ngIErQ==", + "node_modules/bytes": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", + "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", "dev": true, "license": "MIT", "engines": { - "node": ">=0.10" + "node": ">= 0.8" } }, - "node_modules/decompress": { - "version": "4.2.1", - "resolved": "https://registry.npmjs.org/decompress/-/decompress-4.2.1.tgz", - "integrity": "sha512-e48kc2IjU+2Zw8cTb6VZcJQ3lgVbS4uuB1TfCHbiZIP/haNXm+SVyhu+87jts5/3ROpd82GSVCoNs/z8l4ZOaQ==", + "node_modules/call-bind-apply-helpers": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/call-bind-apply-helpers/-/call-bind-apply-helpers-1.0.2.tgz", + "integrity": "sha512-Sp1ablJ0ivDkSzjcaJdxEunN5/XvksFJ2sMBFfq6x0ryhQV/2b/KwFe21cMpmHtPOSij8K99/wSfoEuTObmuMQ==", "dev": true, "license": "MIT", "dependencies": { - "decompress-tar": "^4.0.0", - "decompress-tarbz2": "^4.0.0", - "decompress-targz": "^4.0.0", - "decompress-unzip": "^4.0.1", - "graceful-fs": "^4.1.10", - "make-dir": "^1.0.0", - "pify": "^2.3.0", - "strip-dirs": "^2.0.0" + "es-errors": "^1.3.0", + "function-bind": "^1.1.2" }, "engines": { - "node": ">=4" + "node": ">= 0.4" } }, - "node_modules/decompress-response": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-6.0.0.tgz", - "integrity": "sha512-aW35yZM6Bb/4oJlZncMH2LCoZtJXTRxES17vE3hoRiowU2kWHaJKFkSBDnDR+cm9J+9QhXmREyIfv0pji9ejCQ==", + "node_modules/call-bound": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/call-bound/-/call-bound-1.0.4.tgz", + "integrity": "sha512-+ys997U96po4Kx/ABpBCqhA9EuxJaQWDQg7295H4hBphv3IZg0boBKuwYpt4YXp6MZ5AmZQnU/tyMTlRpaSejg==", "dev": true, "license": "MIT", "dependencies": { - "mimic-response": "^3.1.0" + "call-bind-apply-helpers": "^1.0.2", + "get-intrinsic": "^1.3.0" }, "engines": { - "node": ">=10" + "node": ">= 0.4" }, "funding": { - "url": "https://github.com/sponsors/sindresorhus" + "url": "https://github.com/sponsors/ljharb" } }, - "node_modules/decompress-response/node_modules/mimic-response": { + "node_modules/callsites": { "version": "3.1.0", - "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-3.1.0.tgz", - "integrity": "sha512-z0yWI+4FDrrweS8Zmt4Ej5HdJmky15+L2e6Wgn3+iK5fWzb6T3fhNFq2+MeTRb064c6Wr4N/wv0DzQTjNzHNGQ==", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", "dev": true, "license": "MIT", "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" + "node": ">=6" } }, - "node_modules/decompress-tar": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/decompress-tar/-/decompress-tar-4.1.1.tgz", - "integrity": "sha512-JdJMaCrGpB5fESVyxwpCx4Jdj2AagLmv3y58Qy4GE6HMVjWz1FeVQk1Ct4Kye7PftcdOo/7U7UKzYBJgqnGeUQ==", + "node_modules/camelcase": { + "version": "5.3.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", + "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", "dev": true, "license": "MIT", - "dependencies": { - "file-type": "^5.2.0", - "is-stream": "^1.1.0", - "tar-stream": "^1.5.2" - }, "engines": { - "node": ">=4" + "node": ">=6" } }, - "node_modules/decompress-tar/node_modules/file-type": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/file-type/-/file-type-5.2.0.tgz", - "integrity": "sha512-Iq1nJ6D2+yIO4c8HHg4fyVb8mAJieo1Oloy1mLLaB2PvezNedhBVm+QU7g0qM42aiMbRXTxKKwGD17rjKNJYVQ==", + "node_modules/camelize": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/camelize/-/camelize-1.0.1.tgz", + "integrity": "sha512-dU+Tx2fsypxTgtLoE36npi3UqcjSSMNYfkqgmoEhtZrraP5VWq0K7FkWVTYa8eMPtnU/G2txVsfdCJTn9uzpuQ==", "dev": true, "license": "MIT", - "engines": { - "node": ">=4" + "funding": { + "url": "https://github.com/sponsors/ljharb" } }, - "node_modules/decompress-tarbz2": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/decompress-tarbz2/-/decompress-tarbz2-4.1.1.tgz", - "integrity": "sha512-s88xLzf1r81ICXLAVQVzaN6ZmX4A6U4z2nMbOwobxkLoIIfjVMBg7TeguTUXkKeXni795B6y5rnvDw7rxhAq9A==", + "node_modules/caniuse-lite": { + "version": "1.0.30001747", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001747.tgz", + "integrity": "sha512-mzFa2DGIhuc5490Nd/G31xN1pnBnYMadtkyTjefPI7wzypqgCEpeWu9bJr0OnDsyKrW75zA9ZAt7pbQFmwLsQg==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/caniuse-lite" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "license": "CC-BY-4.0" + }, + "node_modules/chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", "dev": true, "license": "MIT", "dependencies": { - "decompress-tar": "^4.1.0", - "file-type": "^6.1.0", - "is-stream": "^1.1.0", - "seek-bzip": "^1.0.5", - "unbzip2-stream": "^1.0.9" + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" }, "engines": { - "node": ">=4" + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/chalk?sponsor=1" } }, - "node_modules/decompress-tarbz2/node_modules/file-type": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/file-type/-/file-type-6.2.0.tgz", - "integrity": "sha512-YPcTBDV+2Tm0VqjybVd32MHdlEGAtuxS3VAYsumFokDSMG+ROT5wawGlnHDoz7bfMcMDt9hxuXvXwoKUx2fkOg==", + "node_modules/chardet": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/chardet/-/chardet-2.1.0.tgz", + "integrity": "sha512-bNFETTG/pM5ryzQ9Ad0lJOTa6HWD/YsScAR3EnCPZRPlQh77JocYktSHOUHelyhm8IARL+o4c4F1bP5KVOjiRA==", "dev": true, - "license": "MIT", - "engines": { - "node": ">=4" - } + "license": "MIT" }, - "node_modules/decompress-targz": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/decompress-targz/-/decompress-targz-4.1.1.tgz", - "integrity": "sha512-4z81Znfr6chWnRDNfFNqLwPvm4db3WuZkqV+UgXQzSngG3CEKdBkw5jrv3axjjL96glyiiKjsxJG3X6WBZwX3w==", + "node_modules/chokidar": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", + "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==", "dev": true, "license": "MIT", "dependencies": { - "decompress-tar": "^4.1.1", - "file-type": "^5.2.0", - "is-stream": "^1.1.0" + "anymatch": "~3.1.2", + "braces": "~3.0.2", + "glob-parent": "~5.1.2", + "is-binary-path": "~2.1.0", + "is-glob": "~4.0.1", + "normalize-path": "~3.0.0", + "readdirp": "~3.6.0" }, "engines": { - "node": ">=4" - } - }, - "node_modules/decompress-targz/node_modules/file-type": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/file-type/-/file-type-5.2.0.tgz", - "integrity": "sha512-Iq1nJ6D2+yIO4c8HHg4fyVb8mAJieo1Oloy1mLLaB2PvezNedhBVm+QU7g0qM42aiMbRXTxKKwGD17rjKNJYVQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=4" + "node": ">= 8.10.0" + }, + "funding": { + "url": "https://paulmillr.com/funding/" + }, + "optionalDependencies": { + "fsevents": "~2.3.2" } }, - "node_modules/decompress-unzip": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/decompress-unzip/-/decompress-unzip-4.0.1.tgz", - "integrity": "sha512-1fqeluvxgnn86MOh66u8FjbtJpAFv5wgCT9Iw8rcBqQcCo5tO8eiJw7NNTrvt9n4CRBVq7CstiS922oPgyGLrw==", + "node_modules/chokidar/node_modules/glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", + "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", "dev": true, - "license": "MIT", + "license": "ISC", "dependencies": { - "file-type": "^3.8.0", - "get-stream": "^2.2.0", - "pify": "^2.3.0", - "yauzl": "^2.4.2" + "is-glob": "^4.0.1" }, "engines": { - "node": ">=4" + "node": ">= 6" } }, - "node_modules/decompress-unzip/node_modules/file-type": { - "version": "3.9.0", - "resolved": "https://registry.npmjs.org/file-type/-/file-type-3.9.0.tgz", - "integrity": "sha512-RLoqTXE8/vPmMuTI88DAzhMYC99I8BWv7zYP4A1puo5HIjEJ5EX48ighy4ZyKMG9EDXxBgW6e++cn7d1xuFghA==", + "node_modules/chrome-trace-event": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/chrome-trace-event/-/chrome-trace-event-1.0.4.tgz", + "integrity": "sha512-rNjApaLzuwaOTjCiT8lSDdGN1APCiqkChLMJxJPWLunPAt5fy8xgU9/jNOchV84wfIxrA0lRQB7oCT8jrn/wrQ==", "dev": true, "license": "MIT", "engines": { - "node": ">=0.10.0" + "node": ">=6.0" } }, - "node_modules/decompress-unzip/node_modules/get-stream": { - "version": "2.3.1", - "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-2.3.1.tgz", - "integrity": "sha512-AUGhbbemXxrZJRD5cDvKtQxLuYaIbNtDTK8YqupCI393Q2KSTreEsLUN3ZxAWFGiKTzL6nKuzfcIvieflUX9qA==", + "node_modules/cli-cursor": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-5.0.0.tgz", + "integrity": "sha512-aCj4O5wKyszjMmDT4tZj93kxyydN/K5zPWSCe6/0AV/AA1pqe5ZBIw0a2ZfPQV7lL5/yb5HsUreJ6UFAF1tEQw==", "dev": true, "license": "MIT", "dependencies": { - "object-assign": "^4.0.1", - "pinkie-promise": "^2.0.0" + "restore-cursor": "^5.0.0" }, "engines": { - "node": ">=0.10.0" + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/decompress-unzip/node_modules/pify": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", - "integrity": "sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog==", + "node_modules/cli-spinners": { + "version": "2.9.2", + "resolved": "https://registry.npmjs.org/cli-spinners/-/cli-spinners-2.9.2.tgz", + "integrity": "sha512-ywqV+5MmyL4E7ybXgKys4DugZbX0FC6LnwrhjuykIjnK9k8OQacQ7axGKnjDXWNhns0xot3bZI5h55H8yo9cJg==", "dev": true, "license": "MIT", "engines": { - "node": ">=0.10.0" + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/decompress/node_modules/make-dir": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-1.3.0.tgz", - "integrity": "sha512-2w31R7SJtieJJnQtGc7RVL2StM2vGYVfqUOvUDxH6bC6aJTxPxTF0GnIgCyu7tjockiUWAYQRbxa7vKn34s5sQ==", + "node_modules/cli-truncate": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-5.1.0.tgz", + "integrity": "sha512-7JDGG+4Zp0CsknDCedl0DYdaeOhc46QNpXi3NLQblkZpXXgA6LncLDUUyvrjSvZeF3VRQa+KiMGomazQrC1V8g==", "dev": true, "license": "MIT", "dependencies": { - "pify": "^3.0.0" + "slice-ansi": "^7.1.0", + "string-width": "^8.0.0" }, "engines": { - "node": ">=4" - } - }, - "node_modules/decompress/node_modules/make-dir/node_modules/pify": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", - "integrity": "sha512-C3FsVNH1udSEX48gGX1xfvwTWfsYWj5U+8/uK15BGzIGrKoUpghX8hWZwa/OFnakBiiVNmBvemTJR5mcy7iPcg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=4" + "node": ">=20" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/decompress/node_modules/pify": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", - "integrity": "sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog==", + "node_modules/cli-width": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-4.1.0.tgz", + "integrity": "sha512-ouuZd4/dm2Sw5Gmqy6bGyNNNe1qt9RpmxveLSO7KcgsTnU7RXfsw+/bukWGo1abgBiMAic068rclZsO4IWmmxQ==", "dev": true, - "license": "MIT", + "license": "ISC", "engines": { - "node": ">=0.10.0" + "node": ">= 12" } - }, - "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/deepmerge": { - "version": "4.3.1", - "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.3.1.tgz", - "integrity": "sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A==", + }, + "node_modules/cliui": { + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", + "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", "dev": true, - "license": "MIT", + "license": "ISC", + "dependencies": { + "string-width": "^4.2.0", + "strip-ansi": "^6.0.1", + "wrap-ansi": "^7.0.0" + }, "engines": { - "node": ">=0.10.0" + "node": ">=12" } }, - "node_modules/defer-to-connect": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/defer-to-connect/-/defer-to-connect-2.0.1.tgz", - "integrity": "sha512-4tvttepXG1VaYGrRibk5EwJd1t4udunSOVMdLSAL6mId1ix438oPwPZMALY41FCijukO1L0twNcGsdzS7dHgDg==", + "node_modules/cliui/node_modules/ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", "dev": true, "license": "MIT", "engines": { - "node": ">=10" + "node": ">=8" } }, - "node_modules/define-data-property": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz", - "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==", + "node_modules/cliui/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", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", "dev": true, "license": "MIT", - "dependencies": { - "es-define-property": "^1.0.0", - "es-errors": "^1.3.0", - "gopd": "^1.0.1" - }, "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" + "node": ">=8" } }, - "node_modules/define-properties": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.1.tgz", - "integrity": "sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==", + "node_modules/cliui/node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", "dev": true, "license": "MIT", "dependencies": { - "define-data-property": "^1.0.1", - "has-property-descriptors": "^1.0.0", - "object-keys": "^1.1.1" + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" }, "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" + "node": ">=8" } }, - "node_modules/delayed-stream": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", - "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", + "node_modules/cliui/node_modules/strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", "dev": true, "license": "MIT", + "dependencies": { + "ansi-regex": "^5.0.1" + }, "engines": { - "node": ">=0.4.0" + "node": ">=8" } }, - "node_modules/depd": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", - "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", + "node_modules/cliui/node_modules/wrap-ansi": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", + "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", "dev": true, "license": "MIT", + "dependencies": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, "engines": { - "node": ">= 0.8" + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" } }, - "node_modules/destroy": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", - "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", + "node_modules/clone": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz", + "integrity": "sha512-JQHZ2QMW6l3aH/j6xCqQThY/9OH4D/9ls34cgkUBiEeocRTU04tHfKPBsUK1PqZCUQM7GiA0IIXJSuXHI64Kbg==", "dev": true, "license": "MIT", "engines": { - "node": ">= 0.8", - "npm": "1.2.8000 || >= 1.4.16" + "node": ">=0.8" } }, - "node_modules/detect-indent": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/detect-indent/-/detect-indent-4.0.0.tgz", - "integrity": "sha512-BDKtmHlOzwI7iRuEkhzsnPoi5ypEhWAJB5RvHWe1kMr06js3uK5B3734i3ui5Yd+wOJV1cpE4JnivPD283GU/A==", + "node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", "dev": true, "license": "MIT", "dependencies": { - "repeating": "^2.0.0" + "color-name": "~1.1.4" }, "engines": { - "node": ">=0.10.0" + "node": ">=7.0.0" } }, - "node_modules/detect-node": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/detect-node/-/detect-node-2.1.0.tgz", - "integrity": "sha512-T0NIuQpnTvFDATNuHN5roPwSBG83rFsuO+MXXH9/3N1eFbn4wcPjttvjMLEPWJ0RGUYgQE7cGgS3tNxbqCGM7g==", + "node_modules/color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", "dev": true, "license": "MIT" }, - "node_modules/devtools": { - "version": "6.12.1", - "resolved": "https://registry.npmjs.org/devtools/-/devtools-6.12.1.tgz", - "integrity": "sha512-JyG46suEiZmld7/UVeogkCWM0zYGt+2ML/TI+SkEp+bTv9cs46cDb0pKF3glYZJA7wVVL2gC07Ic0iCxyJEnCQ==", + "node_modules/colorette": { + "version": "2.0.20", + "resolved": "https://registry.npmjs.org/colorette/-/colorette-2.0.20.tgz", + "integrity": "sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w==", + "dev": true, + "license": "MIT" + }, + "node_modules/commander": { + "version": "14.0.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-14.0.1.tgz", + "integrity": "sha512-2JkV3gUZUVrbNA+1sjBOYLsMZ5cEEl8GTFP2a4AVz5hvasAMCQ1D2l2le/cX+pV4N6ZU17zjUahLpIXRrnWL8A==", "dev": true, "license": "MIT", - "dependencies": { - "@wdio/config": "6.12.1", - "@wdio/logger": "6.10.10", - "@wdio/protocols": "6.12.0", - "@wdio/utils": "6.11.0", - "chrome-launcher": "^0.13.1", - "edge-paths": "^2.1.0", - "puppeteer-core": "^5.1.0", - "ua-parser-js": "^0.7.21", - "uuid": "^8.0.0" - }, "engines": { - "node": ">=10.0.0" + "node": ">=20" } }, - "node_modules/devtools-protocol": { - "version": "0.0.818844", - "resolved": "https://registry.npmjs.org/devtools-protocol/-/devtools-protocol-0.0.818844.tgz", - "integrity": "sha512-AD1hi7iVJ8OD0aMLQU5VK0XH9LDlA1+BcPIgrAxPfaibx2DbWucuyOhc4oyQCbnvDDO68nN6/LcKfqTP343Jjg==", + "node_modules/commondir": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", + "integrity": "sha512-W9pAhw0ja1Edb5GVdIF1mjZw/ASI0AlShXM83UUGe2DVr5TdAPEA1OA8m/g8zWp9x6On7gqufY+FatDbC3MDQg==", "dev": true, - "license": "BSD-3-Clause" + "license": "MIT" }, - "node_modules/di": { + "node_modules/concat-map": { "version": "0.0.1", - "resolved": "https://registry.npmjs.org/di/-/di-0.0.1.tgz", - "integrity": "sha512-uJaamHkagcZtHPqCIHZxnFrXlunQXgBOsZSUOWwFw31QJCAbyTBoHMW75YOTur5ZNx8pIeAKgf6GWIgaqqiLhA==", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", "dev": true, "license": "MIT" }, - "node_modules/dom-serialize": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/dom-serialize/-/dom-serialize-2.2.1.tgz", - "integrity": "sha512-Yra4DbvoW7/Z6LBN560ZwXMjoNOSAN2wRsKFGc4iBeso+mpIA6qj1vfdf9HpMaKAqG6wXTy+1SYEzmNpKXOSsQ==", + "node_modules/connect": { + "version": "3.7.0", + "resolved": "https://registry.npmjs.org/connect/-/connect-3.7.0.tgz", + "integrity": "sha512-ZqRXc+tZukToSNmh5C2iWMSoV3X1YUcPbqEM4DkEG5tNQXrQUZCNVGGv3IuicnkMtPfGf3Xtp8WCXs295iQ1pQ==", "dev": true, "license": "MIT", "dependencies": { - "custom-event": "~1.0.0", - "ent": "~2.2.0", - "extend": "^3.0.0", - "void-elements": "^2.0.0" + "debug": "2.6.9", + "finalhandler": "1.1.2", + "parseurl": "~1.3.3", + "utils-merge": "1.0.1" + }, + "engines": { + "node": ">= 0.10.0" } }, - "node_modules/dot-case": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/dot-case/-/dot-case-3.0.4.tgz", - "integrity": "sha512-Kv5nKlh6yRrdrGvxeJ2e5y2eRUpkUosIW4A2AS38zwSz27zu7ufDwQPi5Jhs3XAlGNetl3bmnGhQsMtkKJnj3w==", + "node_modules/connect/node_modules/debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", "dev": true, "license": "MIT", "dependencies": { - "no-case": "^3.0.4", - "tslib": "^2.0.3" + "ms": "2.0.0" } }, - "node_modules/download": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/download/-/download-7.1.0.tgz", - "integrity": "sha512-xqnBTVd/E+GxJVrX5/eUJiLYjCGPwMpdL+jGhGU57BvtcA7wwhtHVbXBeUk51kOpW3S7Jn3BQbN9Q1R1Km2qDQ==", + "node_modules/connect/node_modules/ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", "dev": true, - "license": "MIT", - "dependencies": { - "archive-type": "^4.0.0", - "caw": "^2.0.1", - "content-disposition": "^0.5.2", - "decompress": "^4.2.0", - "ext-name": "^5.0.0", - "file-type": "^8.1.0", - "filenamify": "^2.0.0", - "get-stream": "^3.0.0", - "got": "^8.3.1", - "make-dir": "^1.2.0", - "p-event": "^2.1.0", - "pify": "^3.0.0" - }, - "engines": { - "node": ">=6" - } + "license": "MIT" }, - "node_modules/download/node_modules/@sindresorhus/is": { - "version": "0.7.0", - "resolved": "https://registry.npmjs.org/@sindresorhus/is/-/is-0.7.0.tgz", - "integrity": "sha512-ONhaKPIufzzrlNbqtWFFd+jlnemX6lJAgq9ZeiZtS7I1PIf/la7CW4m83rTXRnVnsMbW2k56pGYu7AUFJD9Pow==", + "node_modules/content-type": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", + "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", "dev": true, "license": "MIT", "engines": { - "node": ">=4" + "node": ">= 0.6" } }, - "node_modules/download/node_modules/cacheable-request": { - "version": "2.1.4", - "resolved": "https://registry.npmjs.org/cacheable-request/-/cacheable-request-2.1.4.tgz", - "integrity": "sha512-vag0O2LKZ/najSoUwDbVlnlCFvhBE/7mGTY2B5FgCBDcRD+oVV1HYTOwM6JZfMg/hIcM6IwnTZ1uQQL5/X3xIQ==", + "node_modules/convert-source-map": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", + "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", "dev": true, - "license": "MIT", - "dependencies": { - "clone-response": "1.0.2", - "get-stream": "3.0.0", - "http-cache-semantics": "3.8.1", - "keyv": "3.0.0", - "lowercase-keys": "1.0.0", - "normalize-url": "2.0.1", - "responselike": "1.0.2" - } + "license": "MIT" }, - "node_modules/download/node_modules/cacheable-request/node_modules/lowercase-keys": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.0.tgz", - "integrity": "sha512-RPlX0+PHuvxVDZ7xX+EBVAp4RsVxP/TdDSN2mJYdiq1Lc4Hz7EUSjUI7RZrKKlmrIzVhf6Jo2stj7++gVarS0A==", + "node_modules/cookie": { + "version": "0.7.2", + "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.7.2.tgz", + "integrity": "sha512-yki5XnKuf750l50uGTllt6kKILY4nQ1eNIQatoXEByZ5dWgnKqbnqmTrBE5B4N7lrMJKQ2ytWMiTO2o0v6Ew/w==", "dev": true, "license": "MIT", "engines": { - "node": ">=0.10.0" + "node": ">= 0.6" } }, - "node_modules/download/node_modules/clone-response": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/clone-response/-/clone-response-1.0.2.tgz", - "integrity": "sha512-yjLXh88P599UOyPTFX0POsd7WxnbsVsGohcwzHOLspIhhpalPw1BcqED8NblyZLKcGrL8dTgMlcaZxV2jAD41Q==", + "node_modules/core-js-compat": { + "version": "3.45.1", + "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.45.1.tgz", + "integrity": "sha512-tqTt5T4PzsMIZ430XGviK4vzYSoeNJ6CXODi6c/voxOT6IZqBht5/EKaSNnYiEjjRYxjVz7DQIsOsY0XNi8PIA==", "dev": true, "license": "MIT", "dependencies": { - "mimic-response": "^1.0.0" + "browserslist": "^4.25.3" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/core-js" } }, - "node_modules/download/node_modules/decompress-response": { - "version": "3.3.0", - "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-3.3.0.tgz", - "integrity": "sha512-BzRPQuY1ip+qDonAOz42gRm/pg9F768C+npV/4JOsxRC2sq+Rlk+Q4ZCAsOhnIaMrgarILY+RMUIvMmmX1qAEA==", + "node_modules/cors": { + "version": "2.8.5", + "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", + "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", "dev": true, "license": "MIT", "dependencies": { - "mimic-response": "^1.0.0" + "object-assign": "^4", + "vary": "^1" }, "engines": { - "node": ">=4" + "node": ">= 0.10" } }, - "node_modules/download/node_modules/got": { - "version": "8.3.2", - "resolved": "https://registry.npmjs.org/got/-/got-8.3.2.tgz", - "integrity": "sha512-qjUJ5U/hawxosMryILofZCkm3C84PLJS/0grRIpjAwu+Lkxxj5cxeCU25BG0/3mDSpXKTyZr8oh8wIgLaH0QCw==", + "node_modules/cross-spawn": { + "version": "7.0.6", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.6.tgz", + "integrity": "sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==", "dev": true, "license": "MIT", "dependencies": { - "@sindresorhus/is": "^0.7.0", - "cacheable-request": "^2.1.1", - "decompress-response": "^3.3.0", - "duplexer3": "^0.1.4", - "get-stream": "^3.0.0", - "into-stream": "^3.1.0", - "is-retry-allowed": "^1.1.0", - "isurl": "^1.0.0-alpha5", - "lowercase-keys": "^1.0.0", - "mimic-response": "^1.0.0", - "p-cancelable": "^0.4.0", - "p-timeout": "^2.0.1", - "pify": "^3.0.0", - "safe-buffer": "^5.1.1", - "timed-out": "^4.0.1", - "url-parse-lax": "^3.0.0", - "url-to-options": "^1.0.1" + "path-key": "^3.1.0", + "shebang-command": "^2.0.0", + "which": "^2.0.1" }, "engines": { - "node": ">=4" + "node": ">= 8" } }, - "node_modules/download/node_modules/http-cache-semantics": { - "version": "3.8.1", - "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-3.8.1.tgz", - "integrity": "sha512-5ai2iksyV8ZXmnZhHH4rWPoxxistEexSi5936zIQ1bnNTW5VnA85B6P/VpXiRM017IgRvb2kKo1a//y+0wSp3w==", - "dev": true, - "license": "BSD-2-Clause" - }, - "node_modules/download/node_modules/json-buffer": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.0.tgz", - "integrity": "sha512-CuUqjv0FUZIdXkHPI8MezCnFCdaTAacej1TZYulLoAg1h/PhwkdXFN4V/gzY4g+fMBCOV2xF+rp7t2XD2ns/NQ==", + "node_modules/custom-event": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/custom-event/-/custom-event-1.0.1.tgz", + "integrity": "sha512-GAj5FOq0Hd+RsCGVJxZuKaIDXDf3h6GQoNEjFgbLLI/trgtavwUbSnZ5pVfg27DVCaWjIohryS0JFwIJyT2cMg==", "dev": true, "license": "MIT" }, - "node_modules/download/node_modules/keyv": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/keyv/-/keyv-3.0.0.tgz", - "integrity": "sha512-eguHnq22OE3uVoSYG0LVWNP+4ppamWr9+zWBe1bsNcovIMy6huUJFPgy4mGwCd/rnl3vOLGW1MTlu4c57CT1xA==", + "node_modules/data-uri-to-buffer": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/data-uri-to-buffer/-/data-uri-to-buffer-4.0.1.tgz", + "integrity": "sha512-0R9ikRb668HB7QDxT1vkpuUBtqc53YyAwMwGeUFKRojY/NWKvdZ+9UYtRfGmhqNbRkTSVpMbmyhXipFFv2cb/A==", "dev": true, "license": "MIT", - "dependencies": { - "json-buffer": "3.0.0" + "engines": { + "node": ">= 12" } }, - "node_modules/download/node_modules/lowercase-keys": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz", - "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==", + "node_modules/date-format": { + "version": "4.0.14", + "resolved": "https://registry.npmjs.org/date-format/-/date-format-4.0.14.tgz", + "integrity": "sha512-39BOQLs9ZjKh0/patS9nrT8wc3ioX3/eA/zgbKNopnF2wCqJEoxywwwElATYvRsXdnOxA/OQeQoFZ3rFjVajhg==", "dev": true, "license": "MIT", "engines": { - "node": ">=0.10.0" + "node": ">=4.0" } }, - "node_modules/download/node_modules/make-dir": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-1.3.0.tgz", - "integrity": "sha512-2w31R7SJtieJJnQtGc7RVL2StM2vGYVfqUOvUDxH6bC6aJTxPxTF0GnIgCyu7tjockiUWAYQRbxa7vKn34s5sQ==", + "node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", "dev": true, "license": "MIT", "dependencies": { - "pify": "^3.0.0" + "ms": "^2.1.3" }, "engines": { - "node": ">=4" + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } } }, - "node_modules/download/node_modules/normalize-url": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-2.0.1.tgz", - "integrity": "sha512-D6MUW4K/VzoJ4rJ01JFKxDrtY1v9wrgzCX5f2qj/lzH1m/lW6MhUZFKerVsnyjOhOsYzI9Kqqak+10l4LvLpMw==", + "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/deepmerge": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.3.1.tgz", + "integrity": "sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/defaults": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/defaults/-/defaults-1.0.4.tgz", + "integrity": "sha512-eFuaLoy/Rxalv2kr+lqMlUnrDWV+3j4pljOIJgLIhI058IQfWJ7vXhyEIHu+HtC738klGALYxOKDO0bQP3tg8A==", "dev": true, "license": "MIT", "dependencies": { - "prepend-http": "^2.0.0", - "query-string": "^5.0.1", - "sort-keys": "^2.0.0" + "clone": "^1.0.2" }, - "engines": { - "node": ">=4" + "funding": { + "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/download/node_modules/p-cancelable": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/p-cancelable/-/p-cancelable-0.4.1.tgz", - "integrity": "sha512-HNa1A8LvB1kie7cERyy21VNeHb2CWJJYqyyC2o3klWFfMGlFmWv2Z7sFgZH8ZiaYL95ydToKTFVXgMV/Os0bBQ==", + "node_modules/depd": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", + "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", "dev": true, "license": "MIT", "engines": { - "node": ">=4" + "node": ">= 0.8" } }, - "node_modules/download/node_modules/pify": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", - "integrity": "sha512-C3FsVNH1udSEX48gGX1xfvwTWfsYWj5U+8/uK15BGzIGrKoUpghX8hWZwa/OFnakBiiVNmBvemTJR5mcy7iPcg==", + "node_modules/destroy": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", + "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", "dev": true, "license": "MIT", "engines": { - "node": ">=4" + "node": ">= 0.8", + "npm": "1.2.8000 || >= 1.4.16" } }, - "node_modules/download/node_modules/responselike": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/responselike/-/responselike-1.0.2.tgz", - "integrity": "sha512-/Fpe5guzJk1gPqdJLJR5u7eG/gNY4nImjbRDaVWVMRhne55TCmj2i9Q+54PBRfatRC8v/rIiv9BN0pMd9OV5EQ==", + "node_modules/di": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/di/-/di-0.0.1.tgz", + "integrity": "sha512-uJaamHkagcZtHPqCIHZxnFrXlunQXgBOsZSUOWwFw31QJCAbyTBoHMW75YOTur5ZNx8pIeAKgf6GWIgaqqiLhA==", + "dev": true, + "license": "MIT" + }, + "node_modules/dom-serialize": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/dom-serialize/-/dom-serialize-2.2.1.tgz", + "integrity": "sha512-Yra4DbvoW7/Z6LBN560ZwXMjoNOSAN2wRsKFGc4iBeso+mpIA6qj1vfdf9HpMaKAqG6wXTy+1SYEzmNpKXOSsQ==", "dev": true, "license": "MIT", "dependencies": { - "lowercase-keys": "^1.0.0" + "custom-event": "~1.0.0", + "ent": "~2.2.0", + "extend": "^3.0.0", + "void-elements": "^2.0.0" } }, - "node_modules/download/node_modules/sort-keys": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/sort-keys/-/sort-keys-2.0.0.tgz", - "integrity": "sha512-/dPCrG1s3ePpWm6yBbxZq5Be1dXGLyLn9Z791chDC3NFrpkVbWGzkBwPN1knaciexFXgRJ7hzdnwZ4stHSDmjg==", + "node_modules/dotenv": { + "version": "17.2.3", + "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-17.2.3.tgz", + "integrity": "sha512-JVUnt+DUIzu87TABbhPmNfVdBDt18BLOWjMUFJMSi/Qqg7NTYtabbvSNJGOJ7afbRuv9D/lngizHtP7QyLQ+9w==", "dev": true, - "license": "MIT", - "dependencies": { - "is-plain-obj": "^1.0.0" - }, + "license": "BSD-2-Clause", "engines": { - "node": ">=4" + "node": ">=12" + }, + "funding": { + "url": "https://dotenvx.com" } }, "node_modules/dunder-proto": { @@ -5490,24 +3876,6 @@ "node": ">= 0.4" } }, - "node_modules/duplexer3": { - "version": "0.1.5", - "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.5.tgz", - "integrity": "sha512-1A8za6ws41LQgv9HrE/66jyC5yuSjQ3L/KOpFtoBilsAK2iA2wuS5rTt1OCzIvtS2V7nVmedsUU+DGRcjBmOYA==", - "dev": true, - "license": "BSD-3-Clause" - }, - "node_modules/edge-paths": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/edge-paths/-/edge-paths-2.2.1.tgz", - "integrity": "sha512-AI5fC7dfDmCdKo3m5y7PkYE8m6bMqR6pvVpgtrZkkhcJXFLelUgkjrhk3kXXx8Kbw2cRaTT4LkOR7hqf39KJdw==", - "dev": true, - "license": "MIT", - "dependencies": { - "@types/which": "^1.3.2", - "which": "^2.0.2" - } - }, "node_modules/ee-first": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", @@ -5516,16 +3884,16 @@ "license": "MIT" }, "node_modules/electron-to-chromium": { - "version": "1.5.173", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.5.173.tgz", - "integrity": "sha512-2bFhXP2zqSfQHugjqJIDFVwa+qIxyNApenmXTp9EjaKtdPrES5Qcn9/aSFy/NaP2E+fWG/zxKu/LBvY36p5VNQ==", + "version": "1.5.230", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.5.230.tgz", + "integrity": "sha512-A6A6Fd3+gMdaed9wX83CvHYJb4UuapPD5X5SLq72VZJzxHSY0/LUweGXRWmQlh2ln7KV7iw7jnwXK7dlPoOnHQ==", "dev": true, "license": "ISC" }, "node_modules/emoji-regex": { - "version": "10.4.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.4.0.tgz", - "integrity": "sha512-EC+0oUMY1Rqm4O6LLrgjtYDvcVYTy7chDnM4Q7030tP4Kwj3u/pR6gP9ygnp2CJMK5Gq+9Q2oqmrFJAz01DXjw==", + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", "dev": true, "license": "MIT" }, @@ -5539,16 +3907,6 @@ "node": ">= 0.8" } }, - "node_modules/end-of-stream": { - "version": "1.4.5", - "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.5.tgz", - "integrity": "sha512-ooEGc6HP26xXq/N+GCGOT0JKCLDGrq2bQUZrQ7gyrJiZANJ/8YDTxTpQBXGMn+WbIQXNVpyWymm7KYVICQnyOg==", - "dev": true, - "license": "MIT", - "dependencies": { - "once": "^1.4.0" - } - }, "node_modules/engine.io": { "version": "6.6.4", "resolved": "https://registry.npmjs.org/engine.io/-/engine.io-6.6.4.tgz", @@ -5599,9 +3957,9 @@ } }, "node_modules/enhanced-resolve": { - "version": "5.18.2", - "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.18.2.tgz", - "integrity": "sha512-6Jw4sE1maoRJo3q8MsSIn2onJFbLTOjY9hlx4DZXmOKvLRd1Ok2kXmAGXaafL2+ijsJZ1ClYbl/pmqr9+k4iUQ==", + "version": "5.18.3", + "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.18.3.tgz", + "integrity": "sha512-d4lC8xfavMeBjzGr2vECC3fsGXziXZQyJxD868h2M/mBI3PwAuODxAkLkq5HYuvrPYcUtiLzsTo8U3PgX3Ocww==", "dev": true, "license": "MIT", "dependencies": { @@ -5681,29 +4039,6 @@ "node": ">= 0.4" } }, - "node_modules/es-set-tostringtag": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.1.0.tgz", - "integrity": "sha512-j6vWzfrGVfyXxge+O0x5sh6cvxAog0a/4Rdd2K36zCMV5eJ+/+tOAngRO8cODMNWbVRdVlmGZQL2YS3yR8bIUA==", - "dev": true, - "license": "MIT", - "dependencies": { - "es-errors": "^1.3.0", - "get-intrinsic": "^1.2.6", - "has-tostringtag": "^1.0.2", - "hasown": "^2.0.2" - }, - "engines": { - "node": ">= 0.4" - } - }, - "node_modules/es6-error": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/es6-error/-/es6-error-4.1.1.tgz", - "integrity": "sha512-Um/+FxMr9CISWh0bi5Zv0iOD+4cFh5qLeks1qhAopKVAJw3drgKbKySikp7wGhDL0HPeaja0P5ULZrxLkniUVg==", - "dev": true, - "license": "MIT" - }, "node_modules/escalade": { "version": "3.2.0", "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.2.0.tgz", @@ -5735,20 +4070,20 @@ } }, "node_modules/eslint": { - "version": "9.29.0", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.29.0.tgz", - "integrity": "sha512-GsGizj2Y1rCWDu6XoEekL3RLilp0voSePurjZIkxL3wlm5o5EC9VpgaP7lrCvjnkuLvzFBQWB3vWB3K5KQTveQ==", + "version": "9.37.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.37.0.tgz", + "integrity": "sha512-XyLmROnACWqSxiGYArdef1fItQd47weqB7iwtfr9JHwRrqIXZdcFMvvEcL9xHCmL0SNsOvF0c42lWyM1U5dgig==", "dev": true, "license": "MIT", "dependencies": { - "@eslint-community/eslint-utils": "^4.2.0", + "@eslint-community/eslint-utils": "^4.8.0", "@eslint-community/regexpp": "^4.12.1", - "@eslint/config-array": "^0.20.1", - "@eslint/config-helpers": "^0.2.1", - "@eslint/core": "^0.14.0", + "@eslint/config-array": "^0.21.0", + "@eslint/config-helpers": "^0.4.0", + "@eslint/core": "^0.16.0", "@eslint/eslintrc": "^3.3.1", - "@eslint/js": "9.29.0", - "@eslint/plugin-kit": "^0.3.1", + "@eslint/js": "9.37.0", + "@eslint/plugin-kit": "^0.4.0", "@humanfs/node": "^0.16.6", "@humanwhocodes/module-importer": "^1.0.1", "@humanwhocodes/retry": "^0.4.2", @@ -5796,9 +4131,9 @@ } }, "node_modules/eslint-config-prettier": { - "version": "10.1.5", - "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-10.1.5.tgz", - "integrity": "sha512-zc1UmCpNltmVY34vuLRV61r1K27sWuX39E+uyUnY8xS2Bex88VV9cugG+UZbRSRGtGyFboj+D8JODyme1plMpw==", + "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": { @@ -5812,9 +4147,9 @@ } }, "node_modules/eslint-plugin-prettier": { - "version": "5.5.0", - "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-5.5.0.tgz", - "integrity": "sha512-8qsOYwkkGrahrgoUv76NZi23koqXOGiiEzXMrT8Q7VcYaUISR+5MorIUxfWqYXN0fN/31WbSrxCxFkVQ43wwrA==", + "version": "5.5.4", + "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-5.5.4.tgz", + "integrity": "sha512-swNtI95SToIz05YINMA6Ox5R057IMAmWZ26GqPxusAp1TZzj+IdY9tXNWWD3vkF/wEqydCONcwjTFpxybBqZsg==", "dev": true, "license": "MIT", "dependencies": { @@ -5872,71 +4207,6 @@ "url": "https://opencollective.com/eslint" } }, - "node_modules/eslint/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/eslint/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/eslint/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/eslint/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/espree": { "version": "10.4.0", "resolved": "https://registry.npmjs.org/espree/-/espree-10.4.0.tgz", @@ -6036,195 +4306,16 @@ "dev": true, "license": "MIT", "engines": { - "node": ">=0.8.x" - } - }, - "node_modules/execa": { - "version": "0.7.0", - "resolved": "https://registry.npmjs.org/execa/-/execa-0.7.0.tgz", - "integrity": "sha512-RztN09XglpYI7aBBrJCPW95jEH7YF1UEPOoX9yDhUTPdp7mK+CQvnLTuD10BNXZ3byLTu2uehZ8EcKT/4CGiFw==", - "dev": true, - "license": "MIT", - "dependencies": { - "cross-spawn": "^5.0.1", - "get-stream": "^3.0.0", - "is-stream": "^1.1.0", - "npm-run-path": "^2.0.0", - "p-finally": "^1.0.0", - "signal-exit": "^3.0.0", - "strip-eof": "^1.0.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/execa/node_modules/cross-spawn": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz", - "integrity": "sha512-pTgQJ5KC0d2hcY8eyL1IzlBPYjTkyH72XRZPnLyKus2mBfNjQs3klqbJU2VILqZryAZUt9JOb3h/mWMy23/f5A==", - "dev": true, - "license": "MIT", - "dependencies": { - "lru-cache": "^4.0.1", - "shebang-command": "^1.2.0", - "which": "^1.2.9" - } - }, - "node_modules/execa/node_modules/lru-cache": { - "version": "4.1.5", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", - "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", - "dev": true, - "license": "ISC", - "dependencies": { - "pseudomap": "^1.0.2", - "yallist": "^2.1.2" - } - }, - "node_modules/execa/node_modules/shebang-command": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", - "integrity": "sha512-EV3L1+UQWGor21OmnvojK36mhg+TyIKDh3iFBKBohr5xeXIhNBcx8oWdgkTEEQ+BEFFYdLRuqMfd5L84N1V5Vg==", - "dev": true, - "license": "MIT", - "dependencies": { - "shebang-regex": "^1.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/execa/node_modules/shebang-regex": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", - "integrity": "sha512-wpoSFAxys6b2a2wHZ1XpDSgD7N9iVjg29Ph9uV/uaP9Ex/KXlkTZTeddxDPSYQpgvzKLGJke2UU0AzoGCjNIvQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/execa/node_modules/signal-exit": { - "version": "3.0.7", - "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", - "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", - "dev": true, - "license": "ISC" - }, - "node_modules/execa/node_modules/which": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", - "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", - "dev": true, - "license": "ISC", - "dependencies": { - "isexe": "^2.0.0" - }, - "bin": { - "which": "bin/which" - } - }, - "node_modules/execa/node_modules/yallist": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", - "integrity": "sha512-ncTzHV7NvsQZkYe1DW7cbDLm0YpzHmZF5r/iyP3ZnQtMiJ+pjzisCiMNI+Sj+xQF5pXhSHxSB3uDbsBTzY/c2A==", - "dev": true, - "license": "ISC" - }, - "node_modules/executable": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/executable/-/executable-4.1.1.tgz", - "integrity": "sha512-8iA79xD3uAch729dUG8xaaBBFGaEa0wdD2VkYLFHwlqosEj/jT66AzcreRDSgV7ehnNLBW2WR5jIXwGKjVdTLg==", - "dev": true, - "license": "MIT", - "dependencies": { - "pify": "^2.2.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/executable/node_modules/pify": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", - "integrity": "sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/ext-list": { - "version": "2.2.2", - "resolved": "https://registry.npmjs.org/ext-list/-/ext-list-2.2.2.tgz", - "integrity": "sha512-u+SQgsubraE6zItfVA0tBuCBhfU9ogSRnsvygI7wht9TS510oLkBRXBsqopeUG/GBOIQyKZO9wjTqIu/sf5zFA==", - "dev": true, - "license": "MIT", - "dependencies": { - "mime-db": "^1.28.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/ext-name": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/ext-name/-/ext-name-5.0.0.tgz", - "integrity": "sha512-yblEwXAbGv1VQDmow7s38W77hzAgJAO50ztBLMcUyUBfxv1HC+LGwtiEN+Co6LtlqT/5uwVOxsD4TNIilWhwdQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "ext-list": "^2.0.0", - "sort-keys-length": "^1.0.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/extend": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", - "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", - "dev": true, - "license": "MIT" - }, - "node_modules/extract-zip": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/extract-zip/-/extract-zip-2.0.1.tgz", - "integrity": "sha512-GDhU9ntwuKyGXdZBUgTIe+vXnWj0fppUEtMDL0+idd5Sta8TGpHssn/eusA9mrPr9qNDym6SxAYZjNvCn/9RBg==", - "dev": true, - "license": "BSD-2-Clause", - "dependencies": { - "debug": "^4.1.1", - "get-stream": "^5.1.0", - "yauzl": "^2.10.0" - }, - "bin": { - "extract-zip": "cli.js" - }, - "engines": { - "node": ">= 10.17.0" - }, - "optionalDependencies": { - "@types/yauzl": "^2.9.1" - } - }, - "node_modules/extract-zip/node_modules/get-stream": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz", - "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==", - "dev": true, - "license": "MIT", - "dependencies": { - "pump": "^3.0.0" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" + "node": ">=0.8.x" } }, + "node_modules/extend": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", + "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", + "dev": true, + "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", @@ -6254,9 +4345,9 @@ "license": "MIT" }, "node_modules/fast-uri": { - "version": "3.0.6", - "resolved": "https://registry.npmjs.org/fast-uri/-/fast-uri-3.0.6.tgz", - "integrity": "sha512-Atfo14OibSv5wAp4VWNsFYE1AchQRTv9cBGWET4pZWHzYshFSS9NQI6I57rdKn9croWVMbYFbLhJ+yJvmZIIHw==", + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/fast-uri/-/fast-uri-3.1.0.tgz", + "integrity": "sha512-iPeeDKJSWf4IEOasVVrknXpaBV0IApz/gp7S2bb7Z4Lljbl2MGJRqInZiUrQwV16cpzw/D3S5j5Julj/gT52AA==", "dev": true, "funding": [ { @@ -6270,22 +4361,15 @@ ], "license": "BSD-3-Clause" }, - "node_modules/fd-slicer": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/fd-slicer/-/fd-slicer-1.1.0.tgz", - "integrity": "sha512-cE1qsB/VwyQozZ+q1dGxR8LBYNZeofhEdUNGSMbQD3Gw2lAzX9Zb3uIU6Ebc/Fmyjo9AWWfnn0AUCHqtevs/8g==", - "dev": true, - "license": "MIT", - "dependencies": { - "pend": "~1.2.0" - } - }, "node_modules/fdir": { - "version": "6.4.6", - "resolved": "https://registry.npmjs.org/fdir/-/fdir-6.4.6.tgz", - "integrity": "sha512-hiFoqpyZcfNm1yc4u8oWCf9A2c4D3QjCrks3zmoVKVxpQRzmPNar1hUJcBG2RQHvEVGDN+Jm81ZheVLAQMK6+w==", + "version": "6.5.0", + "resolved": "https://registry.npmjs.org/fdir/-/fdir-6.5.0.tgz", + "integrity": "sha512-tIbYtZbucOs0BRGqPJkshJUYdL+SDH7dVM8gjy+ERp3WAUjLEFJE+02kanyHtwjWOnwrKYBiwAmM0p4kLJAnXg==", "dev": true, "license": "MIT", + "engines": { + "node": ">=12.0.0" + }, "peerDependencies": { "picomatch": "^3 || ^4" }, @@ -6295,52 +4379,41 @@ } } }, - "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==", + "node_modules/fetch-blob": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/fetch-blob/-/fetch-blob-3.2.0.tgz", + "integrity": "sha512-7yAQpD2UMJzLi1Dqv7qFYnPbaPx7ZfFK6PiIxQ4PfkGPyNyl2Ugx+a/umUonmKqjhM4DnfbMvdX6otXq83soQQ==", "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/jimmywarting" + }, + { + "type": "paypal", + "url": "https://paypal.me/jimmywarting" + } + ], "license": "MIT", "dependencies": { - "flat-cache": "^4.0.0" + "node-domexception": "^1.0.0", + "web-streams-polyfill": "^3.0.3" }, "engines": { - "node": ">=16.0.0" - } - }, - "node_modules/file-type": { - "version": "8.1.0", - "resolved": "https://registry.npmjs.org/file-type/-/file-type-8.1.0.tgz", - "integrity": "sha512-qyQ0pzAy78gVoJsmYeNgl8uH8yKhr1lVhW7JbzJmnlRi0I4R2eEDEJZVKG8agpDnLpacwNbDhLNG/LMdxHD2YQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=6" + "node": "^12.20 || >= 14.13" } }, - "node_modules/filename-reserved-regex": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/filename-reserved-regex/-/filename-reserved-regex-2.0.0.tgz", - "integrity": "sha512-lc1bnsSr4L4Bdif8Xb/qrtokGbq5zlsms/CYH8PP+WtCkGNF65DPiQY8vG3SakEdRn8Dlnm+gW/qWKKjS5sZzQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=4" - } - }, - "node_modules/filenamify": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/filenamify/-/filenamify-2.1.0.tgz", - "integrity": "sha512-ICw7NTT6RsDp2rnYKVd8Fu4cr6ITzGy3+u4vUujPkabyaz+03F24NWEX7fs5fp+kBonlaqPH8fAO2NM+SXt/JA==", + "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": { - "filename-reserved-regex": "^2.0.0", - "strip-outer": "^1.0.0", - "trim-repeated": "^1.0.0" + "flat-cache": "^4.0.0" }, "engines": { - "node": ">=4" + "node": ">=16.0.0" } }, "node_modules/fill-range": { @@ -6406,30 +4479,20 @@ } }, "node_modules/find-up": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", - "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", + "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": "^5.0.0", + "locate-path": "^6.0.0", "path-exists": "^4.0.0" }, "engines": { - "node": ">=8" - } - }, - "node_modules/find-versions": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/find-versions/-/find-versions-3.2.0.tgz", - "integrity": "sha512-P8WRou2S+oe222TOCHitLy8zj+SIsVJh52VP4lvXkaFVnOFFdoWv1H1Jjvel1aI6NCFOAaeAVm8qrI0odiLcww==", - "dev": true, - "license": "MIT", - "dependencies": { - "semver-regex": "^2.0.0" + "node": ">=10" }, - "engines": { - "node": ">=6" + "funding": { + "url": "https://github.com/sponsors/sindresorhus" } }, "node_modules/flat-cache": { @@ -6454,9 +4517,9 @@ "license": "ISC" }, "node_modules/follow-redirects": { - "version": "1.15.9", - "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.9.tgz", - "integrity": "sha512-gew4GsXizNgdoRyqmyfMHyAmXsZDk6mHkSxZFCzW9gwlbtOW44CDtYavM+y+72qD/Vq2l550kMF52DT8fOLJqQ==", + "version": "1.15.11", + "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.11.tgz", + "integrity": "sha512-deG2P0JfjrTxl50XGCDyfI97ZGVCxIpfKYmfyrQ54n5FO/0gfIES8C/Psl6kWVDolizcaaxZJnTS0QSMxvnsBQ==", "dev": true, "funding": [ { @@ -6474,56 +4537,19 @@ } } }, - "node_modules/for-each": { - "version": "0.3.5", - "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.5.tgz", - "integrity": "sha512-dKx12eRCVIzqCxFGplyFKJMPvLEWgmNtUrpTiJIR5u97zEhRG8ySrtboPHZXx7daLxQVrl643cTzbab2tkQjxg==", - "dev": true, - "license": "MIT", - "dependencies": { - "is-callable": "^1.2.7" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/form-data": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/form-data/-/form-data-3.0.3.tgz", - "integrity": "sha512-q5YBMeWy6E2Un0nMGWMgI65MAKtaylxfNJGJxpGh45YDciZB4epbWpaAfImil6CPAPTYB4sh0URQNDRIZG5F2w==", + "node_modules/formdata-polyfill": { + "version": "4.0.10", + "resolved": "https://registry.npmjs.org/formdata-polyfill/-/formdata-polyfill-4.0.10.tgz", + "integrity": "sha512-buewHzMvYL29jdeQTVILecSaZKnt/RJWjoZCF5OW60Z67/GmSLBkOFM7qh1PI3zFNtJbaZL5eQu1vLfazOwj4g==", "dev": true, "license": "MIT", "dependencies": { - "asynckit": "^0.4.0", - "combined-stream": "^1.0.8", - "es-set-tostringtag": "^2.1.0", - "mime-types": "^2.1.35" + "fetch-blob": "^3.1.2" }, "engines": { - "node": ">= 6" - } - }, - "node_modules/from2": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/from2/-/from2-2.3.0.tgz", - "integrity": "sha512-OMcX/4IC/uqEPVgGeyfN22LJk6AZrMkRZHxcHBMBvHScDGgwTm2GT2Wkgtocyd3JfZffjj2kYUDXXII0Fk9W0g==", - "dev": true, - "license": "MIT", - "dependencies": { - "inherits": "^2.0.1", - "readable-stream": "^2.0.0" + "node": ">=12.20.0" } }, - "node_modules/fs-constants": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/fs-constants/-/fs-constants-1.0.0.tgz", - "integrity": "sha512-y6OAwoSIf7FyjMIv94u+b5rdheZEjzR63GTyZJm5qh4Bi+2YgwLCcI/fPFZkL5PSixOt6ZNKm+w+Hfp/Bciwow==", - "dev": true, - "license": "MIT" - }, "node_modules/fs-extra": { "version": "8.1.0", "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz", @@ -6592,9 +4618,9 @@ } }, "node_modules/get-east-asian-width": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/get-east-asian-width/-/get-east-asian-width-1.3.0.tgz", - "integrity": "sha512-vpeMIQKxczTD/0s2CdEWHcb0eeJe6TFjxb+J5xgX7hScxqrGuyjmv4c1D4A/gelKfyox0gJJwIHF+fLjeaM8kQ==", + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/get-east-asian-width/-/get-east-asian-width-1.4.0.tgz", + "integrity": "sha512-QZjmEOC+IT1uk6Rx0sX22V6uHWVwbdbxf1faPqJ1QhLdGgsRGCZoyaQBm/piRdJy/D2um6hM1UP7ZEeQ4EkP+Q==", "dev": true, "license": "MIT", "engines": { @@ -6639,19 +4665,6 @@ "node": ">=8.0.0" } }, - "node_modules/get-port": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/get-port/-/get-port-5.1.1.tgz", - "integrity": "sha512-g/Q1aTSDOxFpchXC4i8ZWvxA1lnPqx/JHqcpIw0/LX9T8x/GBbi6YnlN5nhaKIFkT8oFsscUKgDJYxfwfS6QsQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, "node_modules/get-proto": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/get-proto/-/get-proto-1.0.1.tgz", @@ -6666,29 +4679,6 @@ "node": ">= 0.4" } }, - "node_modules/get-proxy": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/get-proxy/-/get-proxy-2.1.0.tgz", - "integrity": "sha512-zmZIaQTWnNQb4R4fJUEp/FC51eZsc6EkErspy3xtIYStaq8EB/hDIWipxsal+E8rz0qD7f2sL/NA9Xee4RInJw==", - "dev": true, - "license": "MIT", - "dependencies": { - "npm-conf": "^1.1.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/get-stream": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-3.0.0.tgz", - "integrity": "sha512-GlhdIUuVakc8SJ6kK0zAFbiGzRFzNnY4jUuEbV9UROo4Y+0Ny4fjvcZFVTeDA4odpFyOQzaw6hXukJSq/f28sQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=4" - } - }, "node_modules/glob": { "version": "7.2.3", "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", @@ -6731,37 +4721,6 @@ "dev": true, "license": "BSD-2-Clause" }, - "node_modules/global-agent": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/global-agent/-/global-agent-2.2.0.tgz", - "integrity": "sha512-+20KpaW6DDLqhG7JDiJpD1JvNvb8ts+TNl7BPOYcURqCrXqnN1Vf+XVOrkKJAFPqfX+oEhsdzOj1hLWkBTdNJg==", - "dev": true, - "license": "BSD-3-Clause", - "dependencies": { - "boolean": "^3.0.1", - "core-js": "^3.6.5", - "es6-error": "^4.1.1", - "matcher": "^3.0.0", - "roarr": "^2.15.3", - "semver": "^7.3.2", - "serialize-error": "^7.0.1" - }, - "engines": { - "node": ">=10.0" - } - }, - "node_modules/global-agent/node_modules/core-js": { - "version": "3.43.0", - "resolved": "https://registry.npmjs.org/core-js/-/core-js-3.43.0.tgz", - "integrity": "sha512-N6wEbTTZSYOY2rYAn85CuvWWkCK6QweMn7/4Nr3w+gDBeBhk/x4EJeY6FPo4QzDoJZxVTv8U7CMvgWk6pOHHqA==", - "dev": true, - "hasInstallScript": true, - "license": "MIT", - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/core-js" - } - }, "node_modules/globals": { "version": "14.0.0", "resolved": "https://registry.npmjs.org/globals/-/globals-14.0.0.tgz", @@ -6775,23 +4734,6 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/globalthis": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.4.tgz", - "integrity": "sha512-DpLKbNU4WylpxJykQujfCcwYWiV/Jhm50Goo0wrVILAv5jOr9d+H+UR3PhSCD2rCCEIg0uc+G+muBTwD54JhDQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "define-properties": "^1.2.1", - "gopd": "^1.0.1" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, "node_modules/gopd": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.2.0.tgz", @@ -6805,32 +4747,6 @@ "url": "https://github.com/sponsors/ljharb" } }, - "node_modules/got": { - "version": "11.8.6", - "resolved": "https://registry.npmjs.org/got/-/got-11.8.6.tgz", - "integrity": "sha512-6tfZ91bOr7bOXnK7PRDCGBLa1H4U080YHNaAQ2KsMGlLEzRbk44nsZF2E1IeRc3vtJHPVbKCYgdFbaGO2ljd8g==", - "dev": true, - "license": "MIT", - "dependencies": { - "@sindresorhus/is": "^4.0.0", - "@szmarczak/http-timer": "^4.0.5", - "@types/cacheable-request": "^6.0.1", - "@types/responselike": "^1.0.0", - "cacheable-lookup": "^5.0.3", - "cacheable-request": "^7.0.2", - "decompress-response": "^6.0.0", - "http2-wrapper": "^1.0.0-beta.5.2", - "lowercase-keys": "^2.0.0", - "p-cancelable": "^2.0.0", - "responselike": "^2.0.0" - }, - "engines": { - "node": ">=10.19.0" - }, - "funding": { - "url": "https://github.com/sindresorhus/got?sponsor=1" - } - }, "node_modules/graceful-fs": { "version": "4.2.11", "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", @@ -6838,36 +4754,6 @@ "dev": true, "license": "ISC" }, - "node_modules/grapheme-splitter": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/grapheme-splitter/-/grapheme-splitter-1.0.4.tgz", - "integrity": "sha512-bzh50DW9kTPM00T8y4o8vQg89Di9oLJVLW/KaOGIXJWP/iqCN6WKYkbNOF04vFLJhwcpYUh9ydh/+5vpOqV4YQ==", - "dev": true, - "license": "MIT" - }, - "node_modules/has-ansi": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", - "integrity": "sha512-C8vBJ8DwUCx19vhm7urhTuUsr4/IyP6l4VzNQDv+ryHQObW3TTTp9yB68WpYgRe2bbaGuZ/se74IqFeVnMnLZg==", - "dev": true, - "license": "MIT", - "dependencies": { - "ansi-regex": "^2.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/has-ansi/node_modules/ansi-regex": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", - "integrity": "sha512-TIGnTpdo+E3+pCyAluZvtED5p5wCqLdezCyhPZzKPcxvFplEt4i+W7OONCKgeZFT3+y5NZZfOOS/Bdcanm1MYA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", @@ -6878,29 +4764,6 @@ "node": ">=8" } }, - "node_modules/has-property-descriptors": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz", - "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==", - "dev": true, - "license": "MIT", - "dependencies": { - "es-define-property": "^1.0.0" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/has-symbol-support-x": { - "version": "1.4.2", - "resolved": "https://registry.npmjs.org/has-symbol-support-x/-/has-symbol-support-x-1.4.2.tgz", - "integrity": "sha512-3ToOva++HaW+eCpgqZrCfN51IPB+7bJNVT6CUATzueB5Heb8o6Nam0V3HG5dlDvZU1Gn5QLcbahiKw/XVk5JJw==", - "dev": true, - "license": "MIT", - "engines": { - "node": "*" - } - }, "node_modules/has-symbols": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.1.0.tgz", @@ -6914,19 +4777,6 @@ "url": "https://github.com/sponsors/ljharb" } }, - "node_modules/has-to-string-tag-x": { - "version": "1.4.1", - "resolved": "https://registry.npmjs.org/has-to-string-tag-x/-/has-to-string-tag-x-1.4.1.tgz", - "integrity": "sha512-vdbKfmw+3LoOYVr+mtxHaX5a96+0f3DljYd8JOqvOLsf5mw2Otda2qCDT9qRqLAhrjyQ0h7ual5nOiASpsGNFw==", - "dev": true, - "license": "MIT", - "dependencies": { - "has-symbol-support-x": "^1.4.1" - }, - "engines": { - "node": "*" - } - }, "node_modules/has-tostringtag": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.2.tgz", @@ -6943,17 +4793,6 @@ "url": "https://github.com/sponsors/ljharb" } }, - "node_modules/hash.js": { - "version": "1.1.7", - "resolved": "https://registry.npmjs.org/hash.js/-/hash.js-1.1.7.tgz", - "integrity": "sha512-taOaskGt4z4SOANNseOviYDvjEJinIkRgmp7LbKP2YTTmVxWBl87s/uzK9r+44BclBSp2X7K1hqeNfz9JbBeXA==", - "dev": true, - "license": "MIT", - "dependencies": { - "inherits": "^2.0.3", - "minimalistic-assert": "^1.0.1" - } - }, "node_modules/hasown": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", @@ -6967,31 +4806,6 @@ "node": ">= 0.4" } }, - "node_modules/header-case": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/header-case/-/header-case-2.0.4.tgz", - "integrity": "sha512-H/vuk5TEEVZwrR0lp2zed9OCo1uAILMlx0JEMgC26rzyJJ3N1v6XkwHHXJQdR2doSjcGPM6OKPYoJgf0plJ11Q==", - "dev": true, - "license": "MIT", - "dependencies": { - "capital-case": "^1.0.4", - "tslib": "^2.0.3" - } - }, - "node_modules/home-or-tmp": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/home-or-tmp/-/home-or-tmp-2.0.0.tgz", - "integrity": "sha512-ycURW7oUxE2sNiPVw1HVEFsW+ecOpJ5zaj7eC0RlwhibhRBod20muUN8qu/gzx956YrLolVvs1MTXwKgC2rVEg==", - "dev": true, - "license": "MIT", - "dependencies": { - "os-homedir": "^1.0.0", - "os-tmpdir": "^1.0.1" - }, - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/html-escaper": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", @@ -6999,13 +4813,6 @@ "dev": true, "license": "MIT" }, - "node_modules/http-cache-semantics": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.2.0.tgz", - "integrity": "sha512-dTxcvPXqPvXBQpq5dUr6mEMJX4oIEFv6bwom3FDwKRDsuIjjJGANqhBuoAn9c1RQJIdAKav33ED65E2ys+87QQ==", - "dev": true, - "license": "BSD-2-Clause" - }, "node_modules/http-errors": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", @@ -7048,34 +4855,6 @@ "node": ">=8.0.0" } }, - "node_modules/http2-wrapper": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/http2-wrapper/-/http2-wrapper-1.0.3.tgz", - "integrity": "sha512-V+23sDMr12Wnz7iTcDeJr3O6AIxlnvT/bmaAAAP/Xda35C90p9599p0F1eHR/N1KILWSoWVAiOMFjBBXaXSMxg==", - "dev": true, - "license": "MIT", - "dependencies": { - "quick-lru": "^5.1.1", - "resolve-alpn": "^1.0.0" - }, - "engines": { - "node": ">=10.19.0" - } - }, - "node_modules/https-proxy-agent": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-4.0.0.tgz", - "integrity": "sha512-zoDhWrkR3of1l9QAL8/scJZyLu8j/gBkcwcaQOZh7Gyh/+uJQzGVETdgT30akuwkpL8HTRfssqI3BZuV18teDg==", - "dev": true, - "license": "MIT", - "dependencies": { - "agent-base": "5", - "debug": "4" - }, - "engines": { - "node": ">= 6.0.0" - } - }, "node_modules/husky": { "version": "9.1.7", "resolved": "https://registry.npmjs.org/husky/-/husky-9.1.7.tgz", @@ -7160,17 +4939,7 @@ "dev": true, "license": "MIT", "engines": { - "node": ">=4" - } - }, - "node_modules/import-lazy": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-3.1.0.tgz", - "integrity": "sha512-8/gvXvX2JMn0F+CDlSC4l6kOmVaLOO3XLkksI7CI3Ud95KDYJuYur2b9P/PUt/i/pDAMd/DulQsNbbbmRRsDIQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=6" + "node": ">=4" } }, "node_modules/imurmurhash": { @@ -7202,74 +4971,120 @@ "dev": true, "license": "ISC" }, - "node_modules/ini": { - "version": "1.3.8", - "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz", - "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==", + "node_modules/inquirer": { + "version": "9.3.8", + "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-9.3.8.tgz", + "integrity": "sha512-pFGGdaHrmRKMh4WoDDSowddgjT1Vkl90atobmTeSmcPGdYiwikch/m/Ef5wRaiamHejtw0cUUMMerzDUXCci2w==", "dev": true, - "license": "ISC" + "license": "MIT", + "dependencies": { + "@inquirer/external-editor": "^1.0.2", + "@inquirer/figures": "^1.0.3", + "ansi-escapes": "^4.3.2", + "cli-width": "^4.1.0", + "mute-stream": "1.0.0", + "ora": "^5.4.1", + "run-async": "^3.0.0", + "rxjs": "^7.8.1", + "string-width": "^4.2.3", + "strip-ansi": "^6.0.1", + "wrap-ansi": "^6.2.0", + "yoctocolors-cjs": "^2.1.2" + }, + "engines": { + "node": ">=18" + } }, - "node_modules/inject-loader": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/inject-loader/-/inject-loader-4.0.1.tgz", - "integrity": "sha512-fUFtHkso2AnzQyyJjuGuDYL0mW2EIQUlS4MgXXmCIRjVLyDk3oXGJqNcSTUg6DGs1q4gvqVIWsxfmPKxF44xfw==", + "node_modules/inquirer/node_modules/ansi-escapes": { + "version": "4.3.2", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", + "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", "dev": true, "license": "MIT", "dependencies": { - "babel-core": "~6" + "type-fest": "^0.21.3" }, - "peerDependencies": { - "webpack": "^1 || ^2 || ^3 || ^4" + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/into-stream": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/into-stream/-/into-stream-3.1.0.tgz", - "integrity": "sha512-TcdjPibTksa1NQximqep2r17ISRiNE9fwlfbg3F8ANdvP5/yrFTew86VcO//jk4QTaMlbjypPBq76HN2zaKfZQ==", + "node_modules/inquirer/node_modules/ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/inquirer/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", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/inquirer/node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", "dev": true, "license": "MIT", "dependencies": { - "from2": "^2.1.1", - "p-is-promise": "^1.1.0" + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" }, "engines": { - "node": ">=4" + "node": ">=8" } }, - "node_modules/invariant": { - "version": "2.2.4", - "resolved": "https://registry.npmjs.org/invariant/-/invariant-2.2.4.tgz", - "integrity": "sha512-phJfQVBuaJM5raOpJjSfkiD6BpbCE4Ns//LaXl6wGYtUBY83nWS6Rf9tXm2e8VaK60JEjYldbPif/A2B1C2gNA==", + "node_modules/inquirer/node_modules/strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", "dev": true, "license": "MIT", "dependencies": { - "loose-envify": "^1.0.0" + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" } }, - "node_modules/is-binary-path": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", - "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", + "node_modules/inquirer/node_modules/wrap-ansi": { + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", + "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", "dev": true, "license": "MIT", "dependencies": { - "binary-extensions": "^2.0.0" + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" }, "engines": { "node": ">=8" } }, - "node_modules/is-callable": { - "version": "1.2.7", - "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", - "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==", + "node_modules/is-binary-path": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", + "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", "dev": true, "license": "MIT", - "engines": { - "node": ">= 0.4" + "dependencies": { + "binary-extensions": "^2.0.0" }, - "funding": { - "url": "https://github.com/sponsors/ljharb" + "engines": { + "node": ">=8" } }, "node_modules/is-core-module": { @@ -7314,27 +5129,17 @@ "node": ">=0.10.0" } }, - "node_modules/is-finite": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/is-finite/-/is-finite-1.1.0.tgz", - "integrity": "sha512-cdyMtqX/BOqqNBBiKlIVkytNHm49MtMlYyn1zxzvJKWmFMlGzm+ry5BBfYyeY9YmNKbRSo/o7OX9w9ale0wg3w==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, "node_modules/is-fullwidth-code-point": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-4.0.0.tgz", - "integrity": "sha512-O4L094N2/dZ7xqVdrXhh9r1KODPJpFms8B5sGdJLPy664AgvXsreZUyCQQNItZRDlYug4xStLjNp/sz3HvBowQ==", + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-5.1.0.tgz", + "integrity": "sha512-5XHYaSyiqADb4RnZ1Bdad6cPp8Toise4TzEjcOYDHZkTCbKgiUl7WTUCpNWHuxmDt91wnsZBc9xinNzopv3JMQ==", "dev": true, "license": "MIT", + "dependencies": { + "get-east-asian-width": "^1.3.1" + }, "engines": { - "node": ">=12" + "node": ">=18" }, "funding": { "url": "https://github.com/sponsors/sindresorhus" @@ -7353,6 +5158,16 @@ "node": ">=0.10.0" } }, + "node_modules/is-interactive": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-interactive/-/is-interactive-1.0.0.tgz", + "integrity": "sha512-2HvIEKRoqS62guEC+qBjpvRubdX910WCMuJTZ+I9yvqKU2/12eSL549HMwtabb4oupdj2sMP50k+XJfB/8JE6w==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, "node_modules/is-module": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz", @@ -7360,13 +5175,6 @@ "dev": true, "license": "MIT" }, - "node_modules/is-natural-number": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/is-natural-number/-/is-natural-number-4.0.1.tgz", - "integrity": "sha512-Y4LTamMe0DDQIIAlaer9eKebAlDSV6huy+TWhJVPlzZh2o4tRP5SQWFlLn5N0To4mDD22/qdOq+veo1cSISLgQ==", - "dev": true, - "license": "MIT" - }, "node_modules/is-number": { "version": "7.0.0", "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", @@ -7377,26 +5185,6 @@ "node": ">=0.12.0" } }, - "node_modules/is-object": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/is-object/-/is-object-1.0.2.tgz", - "integrity": "sha512-2rRIahhZr2UWb45fIOuvZGpFtz0TyOZLf32KxBbSoUCeZR495zCKlWUKKUByk3geS2eAs7ZAABt0Y/Rx0GiQGA==", - "dev": true, - "license": "MIT", - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/is-plain-obj": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-1.1.0.tgz", - "integrity": "sha512-yvkRyxmFKEOQ4pNXCmJG5AEQNlXJS5LaONXo5/cLdTZdWvsZ1ioJEonLGAosKlMWE8lwUy/bJzMjcw8az73+Fg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/is-plain-object": { "version": "5.0.0", "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-5.0.0.tgz", @@ -7435,40 +5223,17 @@ "url": "https://github.com/sponsors/ljharb" } }, - "node_modules/is-retry-allowed": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/is-retry-allowed/-/is-retry-allowed-1.2.0.tgz", - "integrity": "sha512-RUbUeKwvm3XG2VYamhJL1xFktgjvPzL0Hq8C+6yrWIswDy3BIXGqCxhxkc30N9jqK311gVU137K8Ei55/zVJRg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/is-stream": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", - "integrity": "sha512-uQPm8kcs47jx38atAcWTVxyltQYoPT68y9aWYdV6yWXSyW8mzSat0TL6CiWdZeCdF3KrAvpVtnHbTv4RN+rqdQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/is-typed-array": { - "version": "1.1.15", - "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.15.tgz", - "integrity": "sha512-p3EcsicXjit7SaskXHs1hA91QxgTw46Fv6EFKKGS5DRFLD8yKnohjF3hxoju94b/OcMZoQukzpPpBE9uLVKzgQ==", + "node_modules/is-unicode-supported": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", + "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", "dev": true, "license": "MIT", - "dependencies": { - "which-typed-array": "^1.1.16" - }, "engines": { - "node": ">= 0.4" + "node": ">=10" }, "funding": { - "url": "https://github.com/sponsors/ljharb" + "url": "https://github.com/sponsors/sindresorhus" } }, "node_modules/is-wsl": { @@ -7484,13 +5249,6 @@ "node": ">=8" } }, - "node_modules/isarray": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", - "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==", - "dev": true, - "license": "MIT" - }, "node_modules/isbinaryfile": { "version": "4.0.10", "resolved": "https://registry.npmjs.org/isbinaryfile/-/isbinaryfile-4.0.10.tgz", @@ -7538,6 +5296,19 @@ "node": ">=10" } }, + "node_modules/istanbul-lib-instrument/node_modules/semver": { + "version": "7.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.2.tgz", + "integrity": "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA==", + "dev": true, + "license": "ISC", + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, "node_modules/istanbul-lib-report": { "version": "3.0.1", "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.1.tgz", @@ -7618,20 +5389,10 @@ "semver": "bin/semver" } }, - "node_modules/istanbul-lib-source-maps/node_modules/source-map": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", - "dev": true, - "license": "BSD-3-Clause", - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/istanbul-reports": { - "version": "3.1.7", - "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.7.tgz", - "integrity": "sha512-BewmUXImeuRk2YY0PVbxgKAysvhRPUQE0h5QRM++nVWyubKGV0l8qQ5op8+B2DOmwSe63Jivj0BjkPQVf8fP5g==", + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.2.0.tgz", + "integrity": "sha512-HGYWWS/ehqTV3xN10i23tkPkpH46MLCIMFNCaaKNavAXTF1RkqxawEPtnjnGZ6XKSInBKkiOA5BKS+aZiY3AvA==", "dev": true, "license": "BSD-3-Clause", "dependencies": { @@ -7642,24 +5403,10 @@ "node": ">=8" } }, - "node_modules/isurl": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/isurl/-/isurl-1.0.0.tgz", - "integrity": "sha512-1P/yWsxPlDtn7QeRD+ULKQPaIaN6yF368GZ2vDfv0AL0NwpStafjWCDDdn0k8wgFMWpVAqG7oJhxHnlud42i9w==", - "dev": true, - "license": "MIT", - "dependencies": { - "has-to-string-tag-x": "^1.2.0", - "is-object": "^1.0.1" - }, - "engines": { - "node": ">= 4" - } - }, "node_modules/jasmine-core": { - "version": "5.8.0", - "resolved": "https://registry.npmjs.org/jasmine-core/-/jasmine-core-5.8.0.tgz", - "integrity": "sha512-Q9dqmpUAfptwyueW3+HqBOkSuYd9I/clZSSfN97wXE/Nr2ROFNCwIBEC1F6kb3QXS9Fcz0LjFYSDQT+BiwjuhA==", + "version": "5.11.0", + "resolved": "https://registry.npmjs.org/jasmine-core/-/jasmine-core-5.11.0.tgz", + "integrity": "sha512-MPJ8L5yyNul0F2SuEsLASwESXQjJvBXnKu31JWFyRZSvuv2B79K4GDWN3pSqvLheUNh7Fyb6dXwd4rsz95O2Kg==", "dev": true, "license": "MIT" }, @@ -7711,9 +5458,9 @@ "license": "MIT" }, "node_modules/js-tokens": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-3.0.2.tgz", - "integrity": "sha512-RjTcuD4xjtthQkaWH7dFlH85L+QaVtSoOyGdZ3g6HFhS9dFNDfLyqgm2NFe2X6cQpeFmt0452FJjFG5UameExg==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", + "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", "dev": true, "license": "MIT" }, @@ -7732,13 +5479,16 @@ } }, "node_modules/jsesc": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-1.3.0.tgz", - "integrity": "sha512-Mke0DA0QjUWuJlhsE0ZPPhYiJkRap642SmI/4ztCFaUs6V2AiH1sfecc+57NgaryfAA2VR3v6O+CSjC1jZJKOA==", + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-3.1.0.tgz", + "integrity": "sha512-/sM3dO2FOzXjKQhJuo0Q173wf2KOo8t4I8vHy6lF9poUp7bKT0/NHE8fPX23PwfhnykfqnC2xRxOnVw5XuGIaA==", "dev": true, "license": "MIT", "bin": { "jsesc": "bin/jsesc" + }, + "engines": { + "node": ">=6" } }, "node_modules/json-buffer": { @@ -7769,21 +5519,17 @@ "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", - "integrity": "sha512-ZClg6AaYvamvYEE82d3Iyd3vSSIjQ+odgjaTzRuO3s7toCdFKczob2i0zCh7JE8kWn17yvAWhUVxvqGwUalsRA==", - "dev": true, - "license": "ISC" - }, "node_modules/json5": { - "version": "0.5.1", - "resolved": "https://registry.npmjs.org/json5/-/json5-0.5.1.tgz", - "integrity": "sha512-4xrs1aW+6N5DalkqSVA8fxh458CXvR99WU8WLKmq4v8eWAL86Xo3BVqyd3SkA9wEVjCMqyvvRRkshAdOnBp5rw==", + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", + "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", "dev": true, "license": "MIT", "bin": { "json5": "lib/cli.js" + }, + "engines": { + "node": ">=6" } }, "node_modules/jsonfile": { @@ -7945,21 +5691,6 @@ "karma": ">=0.9" } }, - "node_modules/karma-sauce-launcher": { - "version": "4.3.6", - "resolved": "https://registry.npmjs.org/karma-sauce-launcher/-/karma-sauce-launcher-4.3.6.tgz", - "integrity": "sha512-Ej62q4mUPFktyAm8g0g8J5qhwEkXwdHrwtiV4pZjKNHNnSs+4qgDyzs3VkpOy3AmNTsTqQXUN/lpiy0tZpDJZQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "global-agent": "^2.1.12", - "saucelabs": "^4.6.3", - "webdriverio": "^6.7.0" - }, - "engines": { - "node": ">= 10.0.0" - } - }, "node_modules/karma-webpack": { "version": "5.0.1", "resolved": "https://registry.npmjs.org/karma-webpack/-/karma-webpack-5.0.1.tgz", @@ -8026,13 +5757,6 @@ "wrap-ansi": "^7.0.0" } }, - "node_modules/karma/node_modules/emoji-regex": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", - "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", - "dev": true, - "license": "MIT" - }, "node_modules/karma/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", @@ -8043,16 +5767,6 @@ "node": ">=8" } }, - "node_modules/karma/node_modules/source-map": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", - "dev": true, - "license": "BSD-3-Clause", - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/karma/node_modules/string-width": { "version": "4.2.3", "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", @@ -8135,101 +5849,44 @@ "dev": true, "license": "MIT" }, - "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/lazystream": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/lazystream/-/lazystream-1.0.1.tgz", - "integrity": "sha512-b94GiNHQNy6JNTrt5w6zNyffMrNkXZb3KTkCZJb2V1xaEGCk093vkZ2jk3tpaeP33/OiXC+WvK9AxUebnf5nbw==", - "dev": true, - "license": "MIT", - "dependencies": { - "readable-stream": "^2.0.5" - }, - "engines": { - "node": ">= 0.6.3" - } - }, - "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/lighthouse-logger": { - "version": "1.4.2", - "resolved": "https://registry.npmjs.org/lighthouse-logger/-/lighthouse-logger-1.4.2.tgz", - "integrity": "sha512-gPWxznF6TKmUHrOQjlVo2UbaL2EJ71mb2CCeRs/2qBpi4L/g4LUVc9+3lKQ6DTUZwJswfM7ainGrLO1+fOqa2g==", - "dev": true, - "license": "Apache-2.0", - "dependencies": { - "debug": "^2.6.9", - "marky": "^1.2.2" - } - }, - "node_modules/lighthouse-logger/node_modules/debug": { - "version": "2.6.9", - "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "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": { - "ms": "2.0.0" + "json-buffer": "3.0.1" } }, - "node_modules/lighthouse-logger/node_modules/ms": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", - "dev": true, - "license": "MIT" - }, - "node_modules/lilconfig": { - "version": "3.1.3", - "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-3.1.3.tgz", - "integrity": "sha512-/vlFKAoH5Cgt3Ie+JLhRbwOsCQePABiU3tJ1egGvyQ+33R/vcwM2Zl2QR/LzjsBeItPt3oSVXapn+m4nQDvpzw==", + "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", - "engines": { - "node": ">=14" + "dependencies": { + "prelude-ls": "^1.2.1", + "type-check": "~0.4.0" }, - "funding": { - "url": "https://github.com/sponsors/antonk52" + "engines": { + "node": ">= 0.8.0" } }, "node_modules/lint-staged": { - "version": "16.1.2", - "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.1.2.tgz", - "integrity": "sha512-sQKw2Si2g9KUZNY3XNvRuDq4UJqpHwF0/FQzZR2M7I5MvtpWvibikCjUVJzZdGE0ByurEl3KQNvsGetd1ty1/Q==", + "version": "16.2.3", + "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-16.2.3.tgz", + "integrity": "sha512-1OnJEESB9zZqsp61XHH2fvpS1es3hRCxMplF/AJUDa8Ho8VrscYDIuxGrj3m8KPXbcWZ8fT9XTMUhEQmOVKpKw==", "dev": true, "license": "MIT", "dependencies": { - "chalk": "^5.4.1", - "commander": "^14.0.0", - "debug": "^4.4.1", - "lilconfig": "^3.1.3", - "listr2": "^8.3.3", + "commander": "^14.0.1", + "listr2": "^9.0.4", "micromatch": "^4.0.8", - "nano-spawn": "^1.0.2", + "nano-spawn": "^1.0.3", "pidtree": "^0.6.0", "string-argv": "^0.3.2", - "yaml": "^2.8.0" + "yaml": "^2.8.1" }, "bin": { "lint-staged": "bin/lint-staged.js" @@ -8241,27 +5898,14 @@ "url": "https://opencollective.com/lint-staged" } }, - "node_modules/lint-staged/node_modules/chalk": { - "version": "5.4.1", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-5.4.1.tgz", - "integrity": "sha512-zgVZuo2WcZgfUEmsn6eO3kINexW8RAE4maiQ8QNs8CtpPCSyMiYsULR3HQYkm3w8FIA3SberyMJMSldGsW+U3w==", - "dev": true, - "license": "MIT", - "engines": { - "node": "^12.17.0 || ^14.13 || >=16.0.0" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, "node_modules/listr2": { - "version": "8.3.3", - "resolved": "https://registry.npmjs.org/listr2/-/listr2-8.3.3.tgz", - "integrity": "sha512-LWzX2KsqcB1wqQ4AHgYb4RsDXauQiqhjLk+6hjbaeHG4zpjjVAB6wC/gz6X0l+Du1cN3pUB5ZlrvTbhGSNnUQQ==", + "version": "9.0.4", + "resolved": "https://registry.npmjs.org/listr2/-/listr2-9.0.4.tgz", + "integrity": "sha512-1wd/kpAdKRLwv7/3OKC8zZ5U8e/fajCfWMxacUvB79S5nLrYGPtUI/8chMQhn3LQjsRVErTb9i1ECAwW0ZIHnQ==", "dev": true, "license": "MIT", "dependencies": { - "cli-truncate": "^4.0.0", + "cli-truncate": "^5.0.0", "colorette": "^2.0.20", "eventemitter3": "^5.0.1", "log-update": "^6.1.0", @@ -8269,7 +5913,7 @@ "wrap-ansi": "^9.0.0" }, "engines": { - "node": ">=18.0.0" + "node": ">=20.0.0" } }, "node_modules/listr2/node_modules/eventemitter3": { @@ -8290,16 +5934,19 @@ } }, "node_modules/locate-path": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", - "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", + "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": "^4.1.0" + "p-locate": "^5.0.0" }, "engines": { - "node": ">=8" + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" } }, "node_modules/lodash": { @@ -8313,7 +5960,6 @@ "version": "4.5.0", "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", "integrity": "sha512-H5ZhCF25riFd9uB5UCkVKo61m3S/xZk1x4wA6yp/L3RFP6Z/eHH1ymQcGLo7J3GMPfm0V/7m1tryHuGVxpqEBQ==", - "dev": true, "license": "MIT" }, "node_modules/lodash.debounce": { @@ -8323,41 +5969,6 @@ "dev": true, "license": "MIT" }, - "node_modules/lodash.defaults": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/lodash.defaults/-/lodash.defaults-4.2.0.tgz", - "integrity": "sha512-qjxPLHd3r5DnsdGacqOMU6pb/avJzdh9tFX2ymgoZE27BmjXrNy/y4LoaiTeAb+O3gL8AfpJGtqfX/ae2leYYQ==", - "dev": true, - "license": "MIT" - }, - "node_modules/lodash.difference": { - "version": "4.5.0", - "resolved": "https://registry.npmjs.org/lodash.difference/-/lodash.difference-4.5.0.tgz", - "integrity": "sha512-dS2j+W26TQ7taQBGN8Lbbq04ssV3emRw4NY58WErlTO29pIqS0HmoT5aJ9+TUQ1N3G+JOZSji4eugsWwGp9yPA==", - "dev": true, - "license": "MIT" - }, - "node_modules/lodash.flatten": { - "version": "4.4.0", - "resolved": "https://registry.npmjs.org/lodash.flatten/-/lodash.flatten-4.4.0.tgz", - "integrity": "sha512-C5N2Z3DgnnKr0LOpv/hKCgKdb7ZZwafIrsesve6lmzvZIRZRGaZ/l6Q8+2W7NaT+ZwO3fFlSCzCzrDCFdJfZ4g==", - "dev": true, - "license": "MIT" - }, - "node_modules/lodash.isobject": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/lodash.isobject/-/lodash.isobject-3.0.2.tgz", - "integrity": "sha512-3/Qptq2vr7WeJbB4KHUSKlq8Pl7ASXi3UG6CMbBm8WRtXi8+GHm7mKaU3urfpSEzWe2wCIChs6/sdocUsTKJiA==", - "dev": true, - "license": "MIT" - }, - "node_modules/lodash.isplainobject": { - "version": "4.0.6", - "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", - "integrity": "sha512-oSXzaWypCMHkPC3NvBEaPHf0KsA5mvPrOPgQWDsbg8n7orZ290M0BmC/jgRZ4vcJ6DTAhjrsSYgdsW/F+MFOBA==", - "dev": true, - "license": "MIT" - }, "node_modules/lodash.merge": { "version": "4.6.2", "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", @@ -8365,19 +5976,22 @@ "dev": true, "license": "MIT" }, - "node_modules/lodash.union": { - "version": "4.6.0", - "resolved": "https://registry.npmjs.org/lodash.union/-/lodash.union-4.6.0.tgz", - "integrity": "sha512-c4pB2CdGrGdjMKYLA+XiRDO7Y0PRQbm/Gzg8qMj+QH+pFVAoTp5sBpO0odL3FjoPCGjK96p6qsP+yQoiLoOBcw==", - "dev": true, - "license": "MIT" - }, - "node_modules/lodash.zip": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/lodash.zip/-/lodash.zip-4.2.0.tgz", - "integrity": "sha512-C7IOaBBK/0gMORRBd8OETNx3kmOkgIWIPvyDpZSCTwUrpYmgZwJkjZeOD8ww4xbOUOs4/attY+pciKvadNfFbg==", + "node_modules/log-symbols": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", + "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", "dev": true, - "license": "MIT" + "license": "MIT", + "dependencies": { + "chalk": "^4.1.0", + "is-unicode-supported": "^0.1.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } }, "node_modules/log-update": { "version": "6.1.0", @@ -8399,52 +6013,6 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/log-update/node_modules/ansi-styles": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", - "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/log-update/node_modules/is-fullwidth-code-point": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-5.0.0.tgz", - "integrity": "sha512-OVa3u9kkBbw7b8Xw5F9P+D/T9X+Z4+JruYVNapTjPYZYUznQ5YfWeFkOj606XYYW8yugTfC8Pj0hYqvi4ryAhA==", - "dev": true, - "license": "MIT", - "dependencies": { - "get-east-asian-width": "^1.0.0" - }, - "engines": { - "node": ">=18" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/log-update/node_modules/slice-ansi": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-7.1.0.tgz", - "integrity": "sha512-bSiSngZ/jWeX93BqeIAbImyTbEihizcwNjFoRUIY/T1wWQsfsm2Vw1agPKylXvQTU7iASGdHhyqRlqQzfz+Htg==", - "dev": true, - "license": "MIT", - "dependencies": { - "ansi-styles": "^6.2.1", - "is-fullwidth-code-point": "^5.0.0" - }, - "engines": { - "node": ">=18" - }, - "funding": { - "url": "https://github.com/chalk/slice-ansi?sponsor=1" - } - }, "node_modules/log4js": { "version": "6.9.1", "resolved": "https://registry.npmjs.org/log4js/-/log4js-6.9.1.tgz", @@ -8462,60 +6030,6 @@ "node": ">=8.0" } }, - "node_modules/loglevel": { - "version": "1.9.2", - "resolved": "https://registry.npmjs.org/loglevel/-/loglevel-1.9.2.tgz", - "integrity": "sha512-HgMmCqIJSAKqo68l0rS2AanEWfkxaZ5wNiEFb5ggm08lDs9Xl2KxBlX3PTcaD2chBM1gXAYf491/M2Rv8Jwayg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">= 0.6.0" - }, - "funding": { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/loglevel" - } - }, - "node_modules/loglevel-plugin-prefix": { - "version": "0.8.4", - "resolved": "https://registry.npmjs.org/loglevel-plugin-prefix/-/loglevel-plugin-prefix-0.8.4.tgz", - "integrity": "sha512-WpG9CcFAOjz/FtNht+QJeGpvVl/cdR6P0z6OcXSkr8wFJOsV2GRj2j10JLfjuA4aYkcKCNIEqRGCyTife9R8/g==", - "dev": true, - "license": "MIT" - }, - "node_modules/loose-envify": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", - "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", - "dev": true, - "license": "MIT", - "dependencies": { - "js-tokens": "^3.0.0 || ^4.0.0" - }, - "bin": { - "loose-envify": "cli.js" - } - }, - "node_modules/lower-case": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/lower-case/-/lower-case-2.0.2.tgz", - "integrity": "sha512-7fm3l3NAF9WfN6W3JOmf5drwpVqX78JtoGJ3A6W0a6ZnldM41w2fV5D490psKFTpMds8TJse/eHLFFsNHHjHgg==", - "dev": true, - "license": "MIT", - "dependencies": { - "tslib": "^2.0.3" - } - }, - "node_modules/lowercase-keys": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-2.0.0.tgz", - "integrity": "sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=8" - } - }, "node_modules/lru-cache": { "version": "5.1.1", "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", @@ -8527,13 +6041,13 @@ } }, "node_modules/magic-string": { - "version": "0.30.17", - "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.30.17.tgz", - "integrity": "sha512-sNPKHvyjVf7gyjwS4xGTaW/mCnF8wnjtifKBEhxfZ7E/S8tQ0rssrwGNn6q8JH/ohItJfSQp9mBtQYuTlH5QnA==", + "version": "0.30.19", + "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.30.19.tgz", + "integrity": "sha512-2N21sPY9Ws53PZvsEpVtNuSW+ScYbQdp4b9qUaL+9QkHUrGFKo56Lg9Emg5s9V/qrtNBmiR01sYhUOwu3H+VOw==", "dev": true, "license": "MIT", "dependencies": { - "@jridgewell/sourcemap-codec": "^1.5.0" + "@jridgewell/sourcemap-codec": "^1.5.5" } }, "node_modules/make-dir": { @@ -8552,21 +6066,14 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/marky": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/marky/-/marky-1.3.0.tgz", - "integrity": "sha512-ocnPZQLNpvbedwTy9kNrQEsknEfgvcLMvOtz3sFeWApDq1MXH1TqkCIx58xlpESsfwQOnuBO9beyQuNGzVvuhQ==", - "dev": true, - "license": "Apache-2.0" - }, - "node_modules/matcher": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/matcher/-/matcher-3.0.0.tgz", - "integrity": "sha512-OkeDaAZ/bQCxeFAozM55PKcKU0yJMPGifLwV4Qgjitu+5MoAfSQN4lsLJeXZ1b8w0x+/Emda6MZgXS1jvsapng==", + "node_modules/make-dir/node_modules/semver": { + "version": "7.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.2.tgz", + "integrity": "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA==", "dev": true, - "license": "MIT", - "dependencies": { - "escape-string-regexp": "^4.0.0" + "license": "ISC", + "bin": { + "semver": "bin/semver.js" }, "engines": { "node": ">=10" @@ -8640,9 +6147,9 @@ } }, "node_modules/mime-db": { - "version": "1.54.0", - "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.54.0.tgz", - "integrity": "sha512-aU5EJuIN2WDemCcAp2vFBfp/m4EAhWJnUNSSw0ixs7/kXbd6Pg64EmwJkNdFhB8aWt1sH2CTXrLxo/iAGV3oPQ==", + "version": "1.52.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", + "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", "dev": true, "license": "MIT", "engines": { @@ -8662,14 +6169,14 @@ "node": ">= 0.6" } }, - "node_modules/mime-types/node_modules/mime-db": { - "version": "1.52.0", - "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", - "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", + "node_modules/mimic-fn": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", + "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", "dev": true, "license": "MIT", "engines": { - "node": ">= 0.6" + "node": ">=6" } }, "node_modules/mimic-function": { @@ -8685,23 +6192,6 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/mimic-response": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-1.0.1.tgz", - "integrity": "sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=4" - } - }, - "node_modules/minimalistic-assert": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz", - "integrity": "sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A==", - "dev": true, - "license": "ISC" - }, "node_modules/minimatch": { "version": "3.1.2", "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", @@ -8738,13 +6228,6 @@ "mkdirp": "bin/cmd.js" } }, - "node_modules/mkdirp-classic": { - "version": "0.5.3", - "resolved": "https://registry.npmjs.org/mkdirp-classic/-/mkdirp-classic-0.5.3.tgz", - "integrity": "sha512-gKLcREMhtuZRwRAfqP3RFW+TK4JqApVBtOIftVgjuABpAtpxhPGaDcfvbhNvD0B8iD1oUr/txX35NjcaY6Ns/A==", - "dev": true, - "license": "MIT" - }, "node_modules/mri": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/mri/-/mri-1.2.0.tgz", @@ -8762,10 +6245,20 @@ "dev": true, "license": "MIT" }, + "node_modules/mute-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-1.0.0.tgz", + "integrity": "sha512-avsJQhyd+680gKXyG/sQc0nXaC6rBkPOfyHYcFb9+hdkqQkR9bdnkJ0AMZhke0oesPqIO+mFFJ+IdBc7mst4IA==", + "dev": true, + "license": "ISC", + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } + }, "node_modules/nano-spawn": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/nano-spawn/-/nano-spawn-1.0.2.tgz", - "integrity": "sha512-21t+ozMQDAL/UGgQVBbZ/xXvNO10++ZPuTmKRO8k9V3AClVRht49ahtDjfY8l1q6nSHOrE5ASfthzH3ol6R/hg==", + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/nano-spawn/-/nano-spawn-1.0.3.tgz", + "integrity": "sha512-jtpsQDetTnvS2Ts1fiRdci5rx0VYws5jGyC+4IYOTnIQ/wwdf6JdomlHBwqC3bJYOvaKu0C2GSZ1A60anrYpaA==", "dev": true, "license": "MIT", "engines": { @@ -8799,120 +6292,63 @@ "dev": true, "license": "MIT" }, - "node_modules/nice-try": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", - "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", - "dev": true, - "license": "MIT" - }, - "node_modules/no-case": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/no-case/-/no-case-3.0.4.tgz", - "integrity": "sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg==", - "dev": true, - "license": "MIT", - "dependencies": { - "lower-case": "^2.0.2", - "tslib": "^2.0.3" - } - }, - "node_modules/node-fetch": { - "version": "2.7.0", - "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.7.0.tgz", - "integrity": "sha512-c4FRfUm/dbcWZ7U+1Wq0AwCyFL+3nt2bEw05wfxSz+DWpWsitgmSgYmy2dQdWyKC1694ELPqMs/YzUSNozLt8A==", - "dev": true, - "license": "MIT", - "dependencies": { - "whatwg-url": "^5.0.0" - }, - "engines": { - "node": "4.x || >=6.0.0" - }, - "peerDependencies": { - "encoding": "^0.1.0" - }, - "peerDependenciesMeta": { - "encoding": { - "optional": true - } - } - }, - "node_modules/node-releases": { - "version": "2.0.19", - "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.19.tgz", - "integrity": "sha512-xxOWJsBKtzAq7DY0J+DTzuz58K8e7sJbdgwkbMWQe8UYB6ekmsQ45q0M/tJDsGaZmbC+l7n57UV8Hl5tHxO9uw==", - "dev": true, - "license": "MIT" - }, - "node_modules/normalize-path": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", - "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/normalize-url": { - "version": "6.1.0", - "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-6.1.0.tgz", - "integrity": "sha512-DlL+XwOy3NxAQ8xuC0okPgK46iuVNAK01YN7RueYBqqFeGsBjV9XmCAzAdgt+667bCl5kPh9EqKKDwnaPG1I7A==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/npm-conf": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/npm-conf/-/npm-conf-1.1.3.tgz", - "integrity": "sha512-Yic4bZHJOt9RCFbRP3GgpqhScOY4HH3V2P8yBj6CeYq118Qr+BLXqT2JvpJ00mryLESpgOxf5XlFv4ZjXxLScw==", - "dev": true, - "license": "MIT", - "dependencies": { - "config-chain": "^1.1.11", - "pify": "^3.0.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/npm-conf/node_modules/pify": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", - "integrity": "sha512-C3FsVNH1udSEX48gGX1xfvwTWfsYWj5U+8/uK15BGzIGrKoUpghX8hWZwa/OFnakBiiVNmBvemTJR5mcy7iPcg==", + "node_modules/node-domexception": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/node-domexception/-/node-domexception-1.0.0.tgz", + "integrity": "sha512-/jKZoMpw0F8GRwl4/eLROPA3cfcXtLApP0QzLmUT/HuPCZWyB7IY9ZrMeKw2O/nFIqPQB3PVM9aYm0F312AXDQ==", + "deprecated": "Use your platform's native DOMException instead", "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/jimmywarting" + }, + { + "type": "github", + "url": "https://paypal.me/jimmywarting" + } + ], "license": "MIT", "engines": { - "node": ">=4" + "node": ">=10.5.0" } }, - "node_modules/npm-run-path": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz", - "integrity": "sha512-lJxZYlT4DW/bRUtFh1MQIWqmLwQfAxnqWG4HhEdjMlkrJYnJn0Jrr2u3mgxqaWsdiBc76TYkTG/mhrnYTuzfHw==", + "node_modules/node-fetch": { + "version": "2.7.0", + "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.7.0.tgz", + "integrity": "sha512-c4FRfUm/dbcWZ7U+1Wq0AwCyFL+3nt2bEw05wfxSz+DWpWsitgmSgYmy2dQdWyKC1694ELPqMs/YzUSNozLt8A==", "dev": true, "license": "MIT", "dependencies": { - "path-key": "^2.0.0" + "whatwg-url": "^5.0.0" }, "engines": { - "node": ">=4" + "node": "4.x || >=6.0.0" + }, + "peerDependencies": { + "encoding": "^0.1.0" + }, + "peerDependenciesMeta": { + "encoding": { + "optional": true + } } }, - "node_modules/npm-run-path/node_modules/path-key": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", - "integrity": "sha512-fEHGKCSmUSDPv4uoj8AlD+joPlq3peND+HRYyxFz4KPw4z926S/b8rIuFs2FYJg3BwsxJf6A9/3eIdLaYC+9Dw==", + "node_modules/node-releases": { + "version": "2.0.23", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.23.tgz", + "integrity": "sha512-cCmFDMSm26S6tQSDpBCg/NR8NENrVPhAJSf+XbxBG4rPFaaonlEoE9wHQmun+cls499TQGSb7ZyPBRlzgKfpeg==", + "dev": true, + "license": "MIT" + }, + "node_modules/normalize-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", + "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", "dev": true, "license": "MIT", "engines": { - "node": ">=4" + "node": ">=0.10.0" } }, "node_modules/object-assign": { @@ -8938,16 +6374,6 @@ "url": "https://github.com/sponsors/ljharb" } }, - "node_modules/object-keys": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", - "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">= 0.4" - } - }, "node_modules/on-finished": { "version": "2.4.1", "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", @@ -9005,122 +6431,133 @@ "node": ">= 0.8.0" } }, - "node_modules/os-filter-obj": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/os-filter-obj/-/os-filter-obj-2.0.0.tgz", - "integrity": "sha512-uksVLsqG3pVdzzPvmAHpBK0wKxYItuzZr7SziusRPoz67tGV8rL1szZ6IdeUrbqLjGDwApBtN29eEE3IqGHOjg==", + "node_modules/ora": { + "version": "5.4.1", + "resolved": "https://registry.npmjs.org/ora/-/ora-5.4.1.tgz", + "integrity": "sha512-5b6Y85tPxZZ7QytO+BQzysW31HJku27cRIlkbAXaNx+BdcVi+LlRFmVXzeF6a7JCwJpyw5c4b+YSVImQIrBpuQ==", "dev": true, "license": "MIT", "dependencies": { - "arch": "^2.1.0" + "bl": "^4.1.0", + "chalk": "^4.1.0", + "cli-cursor": "^3.1.0", + "cli-spinners": "^2.5.0", + "is-interactive": "^1.0.0", + "is-unicode-supported": "^0.1.0", + "log-symbols": "^4.1.0", + "strip-ansi": "^6.0.0", + "wcwidth": "^1.0.1" }, "engines": { - "node": ">=4" - } - }, - "node_modules/os-homedir": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", - "integrity": "sha512-B5JU3cabzk8c67mRRd3ECmROafjYMXbuzlwtqdM8IbS8ktlTix8aFGb2bAGKrSRIlnfKwovGUUr72JUPyOb6kQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/os-tmpdir": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", - "integrity": "sha512-D2FR03Vir7FIu45XBY20mTb+/ZSWB00sjU9jdQXt83gDrI4Ztz5Fs7/yy74g2N5SVQY4xY1qDr4rNddwYRVX0g==", + "node_modules/ora/node_modules/ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", "dev": true, "license": "MIT", "engines": { - "node": ">=0.10.0" + "node": ">=8" } }, - "node_modules/p-cancelable": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/p-cancelable/-/p-cancelable-2.1.1.tgz", - "integrity": "sha512-BZOr3nRQHOntUjTrH8+Lh54smKHoHyur8We1V8DSMVrl5A2malOOwuJRnKRDjSnkoeBh4at6BwEnb5I7Jl31wg==", + "node_modules/ora/node_modules/cli-cursor": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", + "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", "dev": true, "license": "MIT", + "dependencies": { + "restore-cursor": "^3.1.0" + }, "engines": { "node": ">=8" } }, - "node_modules/p-event": { - "version": "2.3.1", - "resolved": "https://registry.npmjs.org/p-event/-/p-event-2.3.1.tgz", - "integrity": "sha512-NQCqOFhbpVTMX4qMe8PF8lbGtzZ+LCiN7pcNrb/413Na7+TRoe1xkKUzuWa/YEJdGQ0FvKtj35EEbDoVPO2kbA==", + "node_modules/ora/node_modules/onetime": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", + "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", "dev": true, "license": "MIT", "dependencies": { - "p-timeout": "^2.0.1" + "mimic-fn": "^2.1.0" }, "engines": { "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/p-finally": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", - "integrity": "sha512-LICb2p9CB7FS+0eR1oqWnHhp0FljGLZCWBE9aix0Uye9W8LTQPwMTYVGWQWIw9RdQiDg4+epXQODwIYJtSJaow==", + "node_modules/ora/node_modules/restore-cursor": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", + "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", "dev": true, "license": "MIT", + "dependencies": { + "onetime": "^5.1.0", + "signal-exit": "^3.0.2" + }, "engines": { - "node": ">=4" + "node": ">=8" } }, - "node_modules/p-is-promise": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/p-is-promise/-/p-is-promise-1.1.0.tgz", - "integrity": "sha512-zL7VE4JVS2IFSkR2GQKDSPEVxkoH43/p7oEnwpdCndKYJO0HVeRB7fA8TJwuLOTBREtK0ea8eHaxdwcpob5dmg==", + "node_modules/ora/node_modules/signal-exit": { + "version": "3.0.7", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", + "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", + "dev": true, + "license": "ISC" + }, + "node_modules/ora/node_modules/strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", "dev": true, "license": "MIT", + "dependencies": { + "ansi-regex": "^5.0.1" + }, "engines": { - "node": ">=4" + "node": ">=8" } }, "node_modules/p-limit": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", - "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", + "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": { - "p-try": "^2.0.0" + "yocto-queue": "^0.1.0" }, "engines": { - "node": ">=6" + "node": ">=10" }, "funding": { "url": "https://github.com/sponsors/sindresorhus" } }, "node_modules/p-locate": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", - "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", + "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": "^2.2.0" + "p-limit": "^3.0.2" }, "engines": { - "node": ">=8" - } - }, - "node_modules/p-timeout": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/p-timeout/-/p-timeout-2.0.1.tgz", - "integrity": "sha512-88em58dDVB/KzPEx1X0N3LwFfYZPyDc4B6eF38M1rk9VTZMbxXXgjugz8mmwpS9Ox4BDZ+t6t3QP5+/gazweIA==", - "dev": true, - "license": "MIT", - "dependencies": { - "p-finally": "^1.0.0" + "node": ">=10" }, - "engines": { - "node": ">=4" + "funding": { + "url": "https://github.com/sponsors/sindresorhus" } }, "node_modules/p-try": { @@ -9133,17 +6570,6 @@ "node": ">=6" } }, - "node_modules/param-case": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/param-case/-/param-case-3.0.4.tgz", - "integrity": "sha512-RXlj7zCYokReqWpOPH9oYivUzLYZ5vAPIfEmCTNViosC78F8F0H9y7T7gG2M39ymgutxF5gcFEsyZQSph9Bp3A==", - "dev": true, - "license": "MIT", - "dependencies": { - "dot-case": "^3.0.4", - "tslib": "^2.0.3" - } - }, "node_modules/parent-module": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", @@ -9167,28 +6593,6 @@ "node": ">= 0.8" } }, - "node_modules/pascal-case": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/pascal-case/-/pascal-case-3.1.2.tgz", - "integrity": "sha512-uWlGT3YSnK9x3BQJaOdcZwrnV6hPpd8jFH1/ucpiLRPh/2zCVJKS19E4GvYHvaCcACn3foXZ0cLB9Wrx1KGe5g==", - "dev": true, - "license": "MIT", - "dependencies": { - "no-case": "^3.0.4", - "tslib": "^2.0.3" - } - }, - "node_modules/path-case": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/path-case/-/path-case-3.0.4.tgz", - "integrity": "sha512-qO4qCFjXqVTrcbPt/hQfhTQ+VhFsqNKOPtytgNKkKxSoEp3XPUQ8ObFuePylOIok5gjn69ry8XiULxCwot3Wfg==", - "dev": true, - "license": "MIT", - "dependencies": { - "dot-case": "^3.0.4", - "tslib": "^2.0.3" - } - }, "node_modules/path-exists": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", @@ -9226,13 +6630,6 @@ "dev": true, "license": "MIT" }, - "node_modules/pend": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/pend/-/pend-1.2.0.tgz", - "integrity": "sha512-F3asv42UuXchdzt+xXqfW1OGlVBe+mxa2mqI0pg5yAHZPvFmY3Y6drSf/GQ1A86WgWEN9Kzh/WrgKa6iGcHXLg==", - "dev": true, - "license": "MIT" - }, "node_modules/picocolors": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.1.tgz", @@ -9241,9 +6638,9 @@ "license": "ISC" }, "node_modules/picomatch": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-4.0.2.tgz", - "integrity": "sha512-M7BAV6Rlcy5u+m6oPhAPFgJTzAioX/6B0DxyvDlo9l8+T3nLKbrczg2WLUyzd45L8RqfUMyGPzekbMvX2Ldkwg==", + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-4.0.3.tgz", + "integrity": "sha512-5gTmgEY/sqK6gFXLIsQNH19lWb4ebPDLA4SdLP7dsWkIXHWlG66oPuVvXSGFPppYZz8ZDZq0dYYrbHfBCVUb1Q==", "dev": true, "license": "MIT", "engines": { @@ -9276,50 +6673,51 @@ "node": ">=6" } }, - "node_modules/pinkie": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", - "integrity": "sha512-MnUuEycAemtSaeFSjXKW/aroV7akBbY+Sv+RkyqFjgAe73F+MR0TBWKBRDkmfWq/HiFmdavfZ1G7h4SPZXaCSg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/pinkie-promise": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", - "integrity": "sha512-0Gni6D4UcLTbv9c57DfxDGdr41XfgUjqWZu492f0cIGr16zDU06BWP/RAEvOuo7CQ0CNjHaLlM59YJJFm3NWlw==", + "node_modules/playwright": { + "version": "1.56.1", + "resolved": "https://registry.npmjs.org/playwright/-/playwright-1.56.1.tgz", + "integrity": "sha512-aFi5B0WovBHTEvpM3DzXTUaeN6eN0qWnTkKx4NQaH4Wvcmc153PdaY2UBdSYKaGYw+UyWXSVyxDUg5DoPEttjw==", "dev": true, - "license": "MIT", + "license": "Apache-2.0", "dependencies": { - "pinkie": "^2.0.0" + "playwright-core": "1.56.1" + }, + "bin": { + "playwright": "cli.js" }, "engines": { - "node": ">=0.10.0" + "node": ">=18" + }, + "optionalDependencies": { + "fsevents": "2.3.2" } }, - "node_modules/pkg-dir": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", - "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", + "node_modules/playwright-core": { + "version": "1.56.1", + "resolved": "https://registry.npmjs.org/playwright-core/-/playwright-core-1.56.1.tgz", + "integrity": "sha512-hutraynyn31F+Bifme+Ps9Vq59hKuUCz7H1kDOcBs+2oGguKkWTU50bBWrtz34OUWmIwpBTWDxaRPXrIXkgvmQ==", "dev": true, - "license": "MIT", - "dependencies": { - "find-up": "^4.0.0" + "license": "Apache-2.0", + "bin": { + "playwright-core": "cli.js" }, "engines": { - "node": ">=8" + "node": ">=18" } }, - "node_modules/possible-typed-array-names": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/possible-typed-array-names/-/possible-typed-array-names-1.1.0.tgz", - "integrity": "sha512-/+5VFTchJDoVj3bhoqi6UeymcD00DAwb1nJwamzPvHEszJ4FpF6SNNbUbOS8yI56qHzdV8eK0qEfOSiodkTdxg==", + "node_modules/playwright/node_modules/fsevents": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", + "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", "dev": true, + "hasInstallScript": true, "license": "MIT", + "optional": true, + "os": [ + "darwin" + ], "engines": { - "node": ">= 0.4" + "node": "^8.16.0 || ^10.6.0 || >=11.0.0" } }, "node_modules/prelude-ls": { @@ -9332,20 +6730,10 @@ "node": ">= 0.8.0" } }, - "node_modules/prepend-http": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-2.0.0.tgz", - "integrity": "sha512-ravE6m9Atw9Z/jjttRUZ+clIXogdghyZAuWJ3qEzjT+jI/dL1ifAqhZeC5VHzQp1MSt1+jxKkFNemj/iO7tVUA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=4" - } - }, "node_modules/prettier": { - "version": "3.6.0", - "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.6.0.tgz", - "integrity": "sha512-ujSB9uXHJKzM/2GBuE0hBOUgC77CN3Bnpqa+g80bkv3T3A93wL/xlzDATHhnhkzifz/UE2SNOvmbTz5hSkDlHw==", + "version": "3.6.2", + "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.6.2.tgz", + "integrity": "sha512-I7AIg5boAr5R0FFtJ6rCfD+LFsWHp81dolrFD8S79U9tb8Az2nGrJncnMSnys+bpQJfRUzqs9hnA81OAA3hCuQ==", "dev": true, "license": "MIT", "bin": { @@ -9409,65 +6797,6 @@ "node": ">= 4" } }, - "node_modules/private": { - "version": "0.1.8", - "resolved": "https://registry.npmjs.org/private/-/private-0.1.8.tgz", - "integrity": "sha512-VvivMrbvd2nKkiG38qjULzlc+4Vx4wm/whI9pQD35YrARNnhxeiRktSOhSukRLFNlzg6Br/cJPet5J/u19r/mg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/process-nextick-args": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", - "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", - "dev": true, - "license": "MIT" - }, - "node_modules/progress": { - "version": "2.0.3", - "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", - "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.4.0" - } - }, - "node_modules/proto-list": { - "version": "1.2.4", - "resolved": "https://registry.npmjs.org/proto-list/-/proto-list-1.2.4.tgz", - "integrity": "sha512-vtK/94akxsTMhe0/cbfpR+syPuszcuwhqVjJq26CuNDgFGj682oRBXOP5MJpv2r7JtE8MsiepGIqvvOTBwn2vA==", - "dev": true, - "license": "ISC" - }, - "node_modules/proxy-from-env": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", - "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==", - "dev": true, - "license": "MIT" - }, - "node_modules/pseudomap": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", - "integrity": "sha512-b/YwNhb8lk1Zz2+bXXpS/LK9OisiZZ1SNsSLxN1x2OXVEhW2Ckr/7mWE5vrC1ZTiJlD9g19jWszTmJsB+oEpFQ==", - "dev": true, - "license": "ISC" - }, - "node_modules/pump": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.3.tgz", - "integrity": "sha512-todwxLMY7/heScKmntwQG8CXVkWUOdYxIvY2s0VWAAMh/nd8SoYiRaKjlr7+iCs984f2P8zvrfWcDDYVb73NfA==", - "dev": true, - "license": "MIT", - "dependencies": { - "end-of-stream": "^1.1.0", - "once": "^1.3.1" - } - }, "node_modules/punycode": { "version": "1.4.1", "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", @@ -9475,52 +6804,6 @@ "dev": true, "license": "MIT" }, - "node_modules/puppeteer-core": { - "version": "5.5.0", - "resolved": "https://registry.npmjs.org/puppeteer-core/-/puppeteer-core-5.5.0.tgz", - "integrity": "sha512-tlA+1n+ziW/Db03hVV+bAecDKse8ihFRXYiEypBe9IlLRvOCzYFG6qrCMBYK34HO/Q/Ecjc+tvkHRAfLVH+NgQ==", - "dev": true, - "license": "Apache-2.0", - "dependencies": { - "debug": "^4.1.0", - "devtools-protocol": "0.0.818844", - "extract-zip": "^2.0.0", - "https-proxy-agent": "^4.0.0", - "node-fetch": "^2.6.1", - "pkg-dir": "^4.2.0", - "progress": "^2.0.1", - "proxy-from-env": "^1.0.0", - "rimraf": "^3.0.2", - "tar-fs": "^2.0.0", - "unbzip2-stream": "^1.3.3", - "ws": "^7.2.3" - }, - "engines": { - "node": ">=10.18.1" - } - }, - "node_modules/puppeteer-core/node_modules/ws": { - "version": "7.5.10", - "resolved": "https://registry.npmjs.org/ws/-/ws-7.5.10.tgz", - "integrity": "sha512-+dbF1tHwZpXcbOJdVOkzLDxZP1ailvSxM6ZweXTegylPny803bFhA+vqBYw4s31NSAk4S2Qz+AKXK9a4wkdjcQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=8.3.0" - }, - "peerDependencies": { - "bufferutil": "^4.0.1", - "utf-8-validate": "^5.0.2" - }, - "peerDependenciesMeta": { - "bufferutil": { - "optional": true - }, - "utf-8-validate": { - "optional": true - } - } - }, "node_modules/qjobs": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/qjobs/-/qjobs-1.2.0.tgz", @@ -9538,41 +6821,13 @@ "dev": true, "license": "BSD-3-Clause", "dependencies": { - "side-channel": "^1.0.6" - }, - "engines": { - "node": ">=0.6" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/query-string": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/query-string/-/query-string-5.1.1.tgz", - "integrity": "sha512-gjWOsm2SoGlgLEdAGt7a6slVOk9mGiXmPFMqrEhLQ68rhQuBnpfs3+EmlvqKyxnCo9/PPlF+9MtY02S1aFg+Jw==", - "dev": true, - "license": "MIT", - "dependencies": { - "decode-uri-component": "^0.2.0", - "object-assign": "^4.1.0", - "strict-uri-encode": "^1.0.0" + "side-channel": "^1.0.6" }, "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/quick-lru": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/quick-lru/-/quick-lru-5.1.1.tgz", - "integrity": "sha512-WuyALRjWPDGtt/wzJiadO5AXY+8hZ80hVpe6MyivgraREW751X3SbhRvG3eLKOYN+8VEvqLcf3wdnt44Z4S4SA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=10" + "node": ">=0.6" }, "funding": { - "url": "https://github.com/sponsors/sindresorhus" + "url": "https://github.com/sponsors/ljharb" } }, "node_modules/randombytes": { @@ -9612,59 +6867,18 @@ } }, "node_modules/readable-stream": { - "version": "2.3.8", - "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz", - "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==", - "dev": true, - "license": "MIT", - "dependencies": { - "core-util-is": "~1.0.0", - "inherits": "~2.0.3", - "isarray": "~1.0.0", - "process-nextick-args": "~2.0.0", - "safe-buffer": "~5.1.1", - "string_decoder": "~1.1.1", - "util-deprecate": "~1.0.1" - } - }, - "node_modules/readable-stream/node_modules/safe-buffer": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", - "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", - "dev": true, - "license": "MIT" - }, - "node_modules/readdir-glob": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/readdir-glob/-/readdir-glob-1.1.3.tgz", - "integrity": "sha512-v05I2k7xN8zXvPD9N+z/uhXPaj0sUFCe2rcWZIpBsqxfP7xXFQ0tipAd/wjj1YxWyWtUS5IDJpOG82JKt2EAVA==", - "dev": true, - "license": "Apache-2.0", - "dependencies": { - "minimatch": "^5.1.0" - } - }, - "node_modules/readdir-glob/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": "3.6.2", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", + "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", "dev": true, "license": "MIT", "dependencies": { - "balanced-match": "^1.0.0" - } - }, - "node_modules/readdir-glob/node_modules/minimatch": { - "version": "5.1.6", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.6.tgz", - "integrity": "sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g==", - "dev": true, - "license": "ISC", - "dependencies": { - "brace-expansion": "^2.0.1" + "inherits": "^2.0.3", + "string_decoder": "^1.1.1", + "util-deprecate": "^1.0.1" }, "engines": { - "node": ">=10" + "node": ">= 6" } }, "node_modules/readdirp": { @@ -9701,9 +6915,9 @@ "license": "MIT" }, "node_modules/regenerate-unicode-properties": { - "version": "10.2.0", - "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-10.2.0.tgz", - "integrity": "sha512-DqHn3DwbmmPVzeKj9woBadqmXxLvQoQIwu7nopMc72ztvxVmVk2SBhSnx67zuye5TP+lJsb/TBQsjLKhnDf3MA==", + "version": "10.2.2", + "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-10.2.2.tgz", + "integrity": "sha512-m03P+zhBeQd1RGnYxrGyDAPpWX/epKirLrp8e3qevZdVkKtnCrjjWczIbYc8+xd6vcTStVlqfycTx1KR4LOr0g==", "dev": true, "license": "MIT", "dependencies": { @@ -9713,26 +6927,19 @@ "node": ">=4" } }, - "node_modules/regenerator-runtime": { - "version": "0.11.1", - "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.11.1.tgz", - "integrity": "sha512-MguG95oij0fC3QV3URf4V2SDYGJhJnJGqvIIgdECeODCT98wSWDAJ94SSuVpYQUoTcGUIL6L4yNB7j1DFFHSBg==", - "dev": true, - "license": "MIT" - }, "node_modules/regexpu-core": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-6.2.0.tgz", - "integrity": "sha512-H66BPQMrv+V16t8xtmq+UC0CBpiTBA60V8ibS1QVReIp8T1z8hwFxqcGzm9K6lgsN7sB5edVH8a+ze6Fqm4weA==", + "version": "6.4.0", + "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-6.4.0.tgz", + "integrity": "sha512-0ghuzq67LI9bLXpOX/ISfve/Mq33a4aFRzoQYhnnok1JOFpmE/A2TBGkNVenOGEeSBCjIiWcc6MVOG5HEQv0sA==", "dev": true, "license": "MIT", "dependencies": { "regenerate": "^1.4.2", - "regenerate-unicode-properties": "^10.2.0", + "regenerate-unicode-properties": "^10.2.2", "regjsgen": "^0.8.0", - "regjsparser": "^0.12.0", + "regjsparser": "^0.13.0", "unicode-match-property-ecmascript": "^2.0.0", - "unicode-match-property-value-ecmascript": "^2.1.0" + "unicode-match-property-value-ecmascript": "^2.2.1" }, "engines": { "node": ">=4" @@ -9746,44 +6953,18 @@ "license": "MIT" }, "node_modules/regjsparser": { - "version": "0.12.0", - "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.12.0.tgz", - "integrity": "sha512-cnE+y8bz4NhMjISKbgeVJtqNbtf5QpjZP+Bslo+UqkIt9QPnX9q095eiRRASJG1/tz6dlNr6Z5NsBiWYokp6EQ==", + "version": "0.13.0", + "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.13.0.tgz", + "integrity": "sha512-NZQZdC5wOE/H3UT28fVGL+ikOZcEzfMGk/c3iN9UGxzWHMa1op7274oyiUVrAG4B2EuFhus8SvkaYnhvW92p9Q==", "dev": true, "license": "BSD-2-Clause", "dependencies": { - "jsesc": "~3.0.2" + "jsesc": "~3.1.0" }, "bin": { "regjsparser": "bin/parser" } }, - "node_modules/regjsparser/node_modules/jsesc": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-3.0.2.tgz", - "integrity": "sha512-xKqzzWXDttJuOcawBt4KnKHHIf5oQ/Cxax+0PWFG+DFDgHNAdi+TXECADI+RYiFUMmx8792xsMbbgXj4CwnP4g==", - "dev": true, - "license": "MIT", - "bin": { - "jsesc": "bin/jsesc" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/repeating": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/repeating/-/repeating-2.0.1.tgz", - "integrity": "sha512-ZqtSMuVybkISo2OWvqvm7iHSWngvdaW3IpsT9/uP8v4gMi591LY6h35wdOfvQdWCKFWZWm2Y1Opp4kV7vQKT6A==", - "dev": true, - "license": "MIT", - "dependencies": { - "is-finite": "^1.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/require-directory": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", @@ -9832,13 +7013,6 @@ "url": "https://github.com/sponsors/ljharb" } }, - "node_modules/resolve-alpn": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/resolve-alpn/-/resolve-alpn-1.2.1.tgz", - "integrity": "sha512-0a1F4l73/ZFZOakJnQ3FvkJ2+gSTQWz/r2KE5OdDY0TxPm5h4GkqkWWfM47T7HsbnOtcJVEF4epCVy6u7Q3K+g==", - "dev": true, - "license": "MIT" - }, "node_modules/resolve-from": { "version": "5.0.0", "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", @@ -9849,36 +7023,6 @@ "node": ">=8" } }, - "node_modules/responselike": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/responselike/-/responselike-2.0.1.tgz", - "integrity": "sha512-4gl03wn3hj1HP3yzgdI7d3lCkF95F21Pz4BPGvKHinyQzALR5CapwC8yIi0Rh58DEMQ/SguC03wFj2k0M/mHhw==", - "dev": true, - "license": "MIT", - "dependencies": { - "lowercase-keys": "^2.0.0" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/resq": { - "version": "1.11.0", - "resolved": "https://registry.npmjs.org/resq/-/resq-1.11.0.tgz", - "integrity": "sha512-G10EBz+zAAy3zUd/CDoBbXRL6ia9kOo3xRHrMDsHljI0GDkhYlyjwoCx5+3eCC4swi1uCoZQhskuJkj7Gp57Bw==", - "dev": true, - "license": "MIT", - "dependencies": { - "fast-deep-equal": "^2.0.1" - } - }, - "node_modules/resq/node_modules/fast-deep-equal": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", - "integrity": "sha512-bCK/2Z4zLidyB4ReuIsvALH6w31YfAQDmXMqMx6FyfHqvBxtjC0eRumeSu4Bs3XtXwpyIywtSTrVT99BxY1f9w==", - "dev": true, - "license": "MIT" - }, "node_modules/restore-cursor": { "version": "5.1.0", "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-5.1.0.tgz", @@ -9903,13 +7047,6 @@ "dev": true, "license": "MIT" }, - "node_modules/rgb2hex": { - "version": "0.2.3", - "resolved": "https://registry.npmjs.org/rgb2hex/-/rgb2hex-0.2.3.tgz", - "integrity": "sha512-clEe0m1xv+Tva1B/TOepuIcvLAxP0U+sCDfgt1SX1HmI2Ahr5/Cd/nzJM1e78NKVtWdoo0s33YehpFA8UfIShQ==", - "dev": true, - "license": "MIT" - }, "node_modules/rimraf": { "version": "3.0.2", "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", @@ -9927,35 +7064,10 @@ "url": "https://github.com/sponsors/isaacs" } }, - "node_modules/roarr": { - "version": "2.15.4", - "resolved": "https://registry.npmjs.org/roarr/-/roarr-2.15.4.tgz", - "integrity": "sha512-CHhPh+UNHD2GTXNYhPWLnU8ONHdI+5DI+4EYIAOaiD63rHeYlZvyh8P+in5999TTSFgUYuKUAjzRI4mdh/p+2A==", - "dev": true, - "license": "BSD-3-Clause", - "dependencies": { - "boolean": "^3.0.1", - "detect-node": "^2.0.4", - "globalthis": "^1.0.1", - "json-stringify-safe": "^5.0.1", - "semver-compare": "^1.0.0", - "sprintf-js": "^1.1.2" - }, - "engines": { - "node": ">=8.0" - } - }, - "node_modules/roarr/node_modules/sprintf-js": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.1.3.tgz", - "integrity": "sha512-Oo+0REFV59/rz3gfJNKQiBlwfHaSESl1pcGyABQsnnIfWOFt6JNj5gCog2U6MLZ//IGYD+nA8nI+mTShREReaA==", - "dev": true, - "license": "BSD-3-Clause" - }, "node_modules/rollup": { - "version": "4.44.0", - "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.44.0.tgz", - "integrity": "sha512-qHcdEzLCiktQIfwBq420pn2dP+30uzqYxv9ETm91wdt2R9AFcWfjNAmje4NWlnCIQ5RMTzVf0ZyisOKqHR6RwA==", + "version": "4.52.4", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.52.4.tgz", + "integrity": "sha512-CLEVl+MnPAiKh5pl4dEWSyMTpuflgNQiLGhMv8ezD5W/qP8AKvmYpCOKRRNOh7oRKnauBZ4SyeYkMS+1VSyKwQ==", "dev": true, "license": "MIT", "dependencies": { @@ -9969,29 +7081,89 @@ "npm": ">=8.0.0" }, "optionalDependencies": { - "@rollup/rollup-android-arm-eabi": "4.44.0", - "@rollup/rollup-android-arm64": "4.44.0", - "@rollup/rollup-darwin-arm64": "4.44.0", - "@rollup/rollup-darwin-x64": "4.44.0", - "@rollup/rollup-freebsd-arm64": "4.44.0", - "@rollup/rollup-freebsd-x64": "4.44.0", - "@rollup/rollup-linux-arm-gnueabihf": "4.44.0", - "@rollup/rollup-linux-arm-musleabihf": "4.44.0", - "@rollup/rollup-linux-arm64-gnu": "4.44.0", - "@rollup/rollup-linux-arm64-musl": "4.44.0", - "@rollup/rollup-linux-loongarch64-gnu": "4.44.0", - "@rollup/rollup-linux-powerpc64le-gnu": "4.44.0", - "@rollup/rollup-linux-riscv64-gnu": "4.44.0", - "@rollup/rollup-linux-riscv64-musl": "4.44.0", - "@rollup/rollup-linux-s390x-gnu": "4.44.0", - "@rollup/rollup-linux-x64-gnu": "4.44.0", - "@rollup/rollup-linux-x64-musl": "4.44.0", - "@rollup/rollup-win32-arm64-msvc": "4.44.0", - "@rollup/rollup-win32-ia32-msvc": "4.44.0", - "@rollup/rollup-win32-x64-msvc": "4.44.0", + "@rollup/rollup-android-arm-eabi": "4.52.4", + "@rollup/rollup-android-arm64": "4.52.4", + "@rollup/rollup-darwin-arm64": "4.52.4", + "@rollup/rollup-darwin-x64": "4.52.4", + "@rollup/rollup-freebsd-arm64": "4.52.4", + "@rollup/rollup-freebsd-x64": "4.52.4", + "@rollup/rollup-linux-arm-gnueabihf": "4.52.4", + "@rollup/rollup-linux-arm-musleabihf": "4.52.4", + "@rollup/rollup-linux-arm64-gnu": "4.52.4", + "@rollup/rollup-linux-arm64-musl": "4.52.4", + "@rollup/rollup-linux-loong64-gnu": "4.52.4", + "@rollup/rollup-linux-ppc64-gnu": "4.52.4", + "@rollup/rollup-linux-riscv64-gnu": "4.52.4", + "@rollup/rollup-linux-riscv64-musl": "4.52.4", + "@rollup/rollup-linux-s390x-gnu": "4.52.4", + "@rollup/rollup-linux-x64-gnu": "4.52.4", + "@rollup/rollup-linux-x64-musl": "4.52.4", + "@rollup/rollup-openharmony-arm64": "4.52.4", + "@rollup/rollup-win32-arm64-msvc": "4.52.4", + "@rollup/rollup-win32-ia32-msvc": "4.52.4", + "@rollup/rollup-win32-x64-gnu": "4.52.4", + "@rollup/rollup-win32-x64-msvc": "4.52.4", "fsevents": "~2.3.2" } }, + "node_modules/rollup-plugin-strip-code": { + "version": "0.2.8", + "resolved": "https://registry.npmjs.org/rollup-plugin-strip-code/-/rollup-plugin-strip-code-0.2.8.tgz", + "integrity": "sha512-QfKPwZjBDi45Hi4tpo0385GQY57KbSoapIo+VSFuAmf3hf3ZM+SWapsehHEhe1lDfZuk1fpQW6v0058QftG+5w==", + "dev": true, + "license": "MIT", + "dependencies": { + "magic-string": "0.25.3", + "rollup-pluginutils": "2.8.1" + } + }, + "node_modules/rollup-plugin-strip-code/node_modules/magic-string": { + "version": "0.25.3", + "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.3.tgz", + "integrity": "sha512-6QK0OpF/phMz0Q2AxILkX2mFhi7m+WMwTRg0LQKq/WBB0cDP4rYH3Wp4/d3OTXlrPLVJT/RFqj8tFeAR4nk8AA==", + "dev": true, + "license": "MIT", + "dependencies": { + "sourcemap-codec": "^1.4.4" + } + }, + "node_modules/rollup-pluginutils": { + "version": "2.8.1", + "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.1.tgz", + "integrity": "sha512-J5oAoysWar6GuZo0s+3bZ6sVZAC0pfqKz68De7ZgDi5z63jOVZn1uJL/+z1jeKHNbGII8kAyHF5q8LnxSX5lQg==", + "dev": true, + "license": "MIT", + "dependencies": { + "estree-walker": "^0.6.1" + } + }, + "node_modules/rollup-pluginutils/node_modules/estree-walker": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz", + "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==", + "dev": true, + "license": "MIT" + }, + "node_modules/run-async": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/run-async/-/run-async-3.0.0.tgz", + "integrity": "sha512-540WwVDOMxA6dN6We19EcT9sc3hkXPw5mzRNGM3FkdN/vtE9NFvj5lFAPNwUDmJjXidm3v7TC1cTE7t17Ulm1Q==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.12.0" + } + }, + "node_modules/rxjs": { + "version": "7.8.2", + "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-7.8.2.tgz", + "integrity": "sha512-dhKf903U/PQZY6boNNtAGdWbG85WAbjT/1xYoZIC7FAY0yWapOBQVsVrDl58W86//e1VpMNBtRV4MaXfdMySFA==", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "tslib": "^2.1.0" + } + }, "node_modules/safe-buffer": { "version": "5.2.1", "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", @@ -10031,150 +7203,17 @@ "url": "https://github.com/sponsors/ljharb" } }, - "node_modules/safer-buffer": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", - "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", - "dev": true, - "license": "MIT" - }, - "node_modules/saucelabs": { - "version": "4.7.8", - "resolved": "https://registry.npmjs.org/saucelabs/-/saucelabs-4.7.8.tgz", - "integrity": "sha512-K2qaRUixc7+8JiAwpTvEsIQVzzUkYwa0mAfs0akGagRlWXUR1JrsmgJRyz28qkwpERW1KDuByn3Ju96BuW1V7Q==", - "dev": true, - "license": "Apache-2.0", - "dependencies": { - "bin-wrapper": "^4.1.0", - "change-case": "^4.1.1", - "form-data": "^3.0.0", - "got": "^11.7.0", - "hash.js": "^1.1.7", - "tunnel": "0.0.6", - "yargs": "^16.0.3" - }, - "bin": { - "sl": "bin/sl" - } - }, - "node_modules/saucelabs/node_modules/ansi-regex": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", - "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=8" - } - }, - "node_modules/saucelabs/node_modules/cliui": { - "version": "7.0.4", - "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", - "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", - "dev": true, - "license": "ISC", - "dependencies": { - "string-width": "^4.2.0", - "strip-ansi": "^6.0.0", - "wrap-ansi": "^7.0.0" - } - }, - "node_modules/saucelabs/node_modules/emoji-regex": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", - "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", - "dev": true, - "license": "MIT" - }, - "node_modules/saucelabs/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", - "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=8" - } - }, - "node_modules/saucelabs/node_modules/string-width": { - "version": "4.2.3", - "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", - "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", - "dev": true, - "license": "MIT", - "dependencies": { - "emoji-regex": "^8.0.0", - "is-fullwidth-code-point": "^3.0.0", - "strip-ansi": "^6.0.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/saucelabs/node_modules/strip-ansi": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", - "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", - "dev": true, - "license": "MIT", - "dependencies": { - "ansi-regex": "^5.0.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/saucelabs/node_modules/wrap-ansi": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", - "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", - "dev": true, - "license": "MIT", - "dependencies": { - "ansi-styles": "^4.0.0", - "string-width": "^4.1.0", - "strip-ansi": "^6.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/wrap-ansi?sponsor=1" - } - }, - "node_modules/saucelabs/node_modules/yargs": { - "version": "16.2.0", - "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", - "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", - "dev": true, - "license": "MIT", - "dependencies": { - "cliui": "^7.0.2", - "escalade": "^3.1.1", - "get-caller-file": "^2.0.5", - "require-directory": "^2.1.1", - "string-width": "^4.2.0", - "y18n": "^5.0.5", - "yargs-parser": "^20.2.2" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/saucelabs/node_modules/yargs-parser": { - "version": "20.2.9", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", - "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", - "dev": true, - "license": "ISC", - "engines": { - "node": ">=10" - } - }, + "node_modules/safer-buffer": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", + "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", + "dev": true, + "license": "MIT" + }, "node_modules/schema-utils": { - "version": "4.3.2", - "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-4.3.2.tgz", - "integrity": "sha512-Gn/JaSk/Mt9gYubxTtSn/QCV4em9mpAPiR1rqy/Ocu19u/G9J5WWdNoUT4SiV6mFC3y6cxyFcFwdzPM3FgxGAQ==", + "version": "4.3.3", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-4.3.3.tgz", + "integrity": "sha512-eflK8wEtyOE6+hsaRVPxvUKYCpRgzLqDTb8krvAsRIwOGlHoSgYLgBXoubGgLd2fT41/OUYdb48v4k4WWHQurA==", "dev": true, "license": "MIT", "dependencies": { @@ -10228,106 +7267,14 @@ "dev": true, "license": "MIT" }, - "node_modules/seek-bzip": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/seek-bzip/-/seek-bzip-1.0.6.tgz", - "integrity": "sha512-e1QtP3YL5tWww8uKaOCQ18UxIT2laNBXHjV/S2WYCiK4udiv8lkG89KRIoCjUagnAmCBurjF4zEVX2ByBbnCjQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "commander": "^2.8.1" - }, - "bin": { - "seek-bunzip": "bin/seek-bunzip", - "seek-table": "bin/seek-bzip-table" - } - }, - "node_modules/seek-bzip/node_modules/commander": { - "version": "2.20.3", - "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", - "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", - "dev": true, - "license": "MIT" - }, "node_modules/semver": { - "version": "7.7.2", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.2.tgz", - "integrity": "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA==", + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", "dev": true, "license": "ISC", "bin": { "semver": "bin/semver.js" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/semver-compare": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/semver-compare/-/semver-compare-1.0.0.tgz", - "integrity": "sha512-YM3/ITh2MJ5MtzaM429anh+x2jiLVjqILF4m4oyQB18W7Ggea7BfqdH/wGMK7dDiMghv/6WG7znWMwUDzJiXow==", - "dev": true, - "license": "MIT" - }, - "node_modules/semver-regex": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/semver-regex/-/semver-regex-2.0.0.tgz", - "integrity": "sha512-mUdIBBvdn0PLOeP3TEkMH7HHeUP3GjsXCwKarjv/kGmUFOYg1VqEemKhoQpWMu6X2I8kHeuVdGibLGkVK+/5Qw==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=6" - } - }, - "node_modules/semver-truncate": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/semver-truncate/-/semver-truncate-1.1.2.tgz", - "integrity": "sha512-V1fGg9i4CL3qesB6U0L6XAm4xOJiHmt4QAacazumuasc03BvtFGIMCduv01JWQ69Nv+JST9TqhSCiJoxoY031w==", - "dev": true, - "license": "MIT", - "dependencies": { - "semver": "^5.3.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/semver-truncate/node_modules/semver": { - "version": "5.7.2", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", - "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", - "dev": true, - "license": "ISC", - "bin": { - "semver": "bin/semver" - } - }, - "node_modules/sentence-case": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/sentence-case/-/sentence-case-3.0.4.tgz", - "integrity": "sha512-8LS0JInaQMCRoQ7YUytAo/xUu5W2XnQxV2HI/6uM6U7CITS1RqPElr30V6uIqyMKM9lJGRVFy5/4CuzcixNYSg==", - "dev": true, - "license": "MIT", - "dependencies": { - "no-case": "^3.0.4", - "tslib": "^2.0.3", - "upper-case-first": "^2.0.2" - } - }, - "node_modules/serialize-error": { - "version": "7.0.1", - "resolved": "https://registry.npmjs.org/serialize-error/-/serialize-error-7.0.1.tgz", - "integrity": "sha512-8I8TjW5KMOKsZQTvoxjuSIa7foAwPWGOts+6o7sgjz41/qMD9VQHEDxi6PBvK2l0MXUmqZyNpUK+T2tQaaElvw==", - "dev": true, - "license": "MIT", - "dependencies": { - "type-fest": "^0.13.1" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" } }, "node_modules/serialize-javascript": { @@ -10340,24 +7287,6 @@ "randombytes": "^2.1.0" } }, - "node_modules/set-function-length": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.2.tgz", - "integrity": "sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==", - "dev": true, - "license": "MIT", - "dependencies": { - "define-data-property": "^1.1.4", - "es-errors": "^1.3.0", - "function-bind": "^1.1.2", - "get-intrinsic": "^1.2.4", - "gopd": "^1.0.1", - "has-property-descriptors": "^1.0.2" - }, - "engines": { - "node": ">= 0.4" - } - }, "node_modules/setprototypeof": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", @@ -10477,37 +7406,27 @@ "url": "https://github.com/sponsors/isaacs" } }, - "node_modules/slash": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/slash/-/slash-1.0.0.tgz", - "integrity": "sha512-3TYDR7xWt4dIqV2JauJr+EJeW356RXijHeUlO+8djJ+uBXPn8/2dpzBc8yQhh583sVvc9CvFAeQVgijsH+PNNg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/slice-ansi": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-5.0.0.tgz", - "integrity": "sha512-FC+lgizVPfie0kkhqUScwRu1O/lF6NOgJmlCgK+/LYxDCTk8sGelYaHDhFcDN+Sn3Cv+3VSa4Byeo+IMCzpMgQ==", + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-7.1.2.tgz", + "integrity": "sha512-iOBWFgUX7caIZiuutICxVgX1SdxwAVFFKwt1EvMYYec/NWO5meOJ6K5uQxhrYBdQJne4KxiqZc+KptFOWFSI9w==", "dev": true, "license": "MIT", "dependencies": { - "ansi-styles": "^6.0.0", - "is-fullwidth-code-point": "^4.0.0" + "ansi-styles": "^6.2.1", + "is-fullwidth-code-point": "^5.0.0" }, "engines": { - "node": ">=12" + "node": ">=18" }, "funding": { "url": "https://github.com/chalk/slice-ansi?sponsor=1" } }, "node_modules/slice-ansi/node_modules/ansi-styles": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", - "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", + "version": "6.2.3", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.3.tgz", + "integrity": "sha512-4Dj6M28JB+oAH8kFkTLUo+a2jwOFkuqb3yucU0CANcRRUbxS0cP0nZYCGjcc3BNXwRIsUVmDGgzawme7zvJHvg==", "dev": true, "license": "MIT", "engines": { @@ -10517,17 +7436,6 @@ "url": "https://github.com/chalk/ansi-styles?sponsor=1" } }, - "node_modules/snake-case": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/snake-case/-/snake-case-3.0.4.tgz", - "integrity": "sha512-LAOh4z89bGQvl9pFfNF8V146i7o7/CqFPbqzYgP+yYzDIDeS9HaNFtXABamRW+AQzEVODcvE79ljJ+8a9YSdMg==", - "dev": true, - "license": "MIT", - "dependencies": { - "dot-case": "^3.0.4", - "tslib": "^2.0.3" - } - }, "node_modules/socket.io": { "version": "4.8.1", "resolved": "https://registry.npmjs.org/socket.io/-/socket.io-4.8.1.tgz", @@ -10626,36 +7534,10 @@ } } }, - "node_modules/sort-keys": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/sort-keys/-/sort-keys-1.1.2.tgz", - "integrity": "sha512-vzn8aSqKgytVik0iwdBEi+zevbTYZogewTUM6dtpmGwEcdzbub/TX4bCzRhebDCRC3QzXgJsLRKB2V/Oof7HXg==", - "dev": true, - "license": "MIT", - "dependencies": { - "is-plain-obj": "^1.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/sort-keys-length": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/sort-keys-length/-/sort-keys-length-1.0.1.tgz", - "integrity": "sha512-GRbEOUqCxemTAk/b32F2xa8wDTs+Z1QHOkbhJDQTvv/6G3ZkbJ+frYWsTcc7cBB3Fu4wy4XlLCuNtJuMn7Gsvw==", - "dev": true, - "license": "MIT", - "dependencies": { - "sort-keys": "^1.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/source-map": { - "version": "0.5.7", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", - "integrity": "sha512-LbrmJOMUSdEVxIKvdcJzQC+nQhe8FUZQTXQy6+I75skNgn3OoQ0DZA8YnFa7gp8tqtL3KPf1kmo0R5DoApeSGQ==", + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", "dev": true, "license": "BSD-3-Clause", "engines": { @@ -10663,15 +7545,24 @@ } }, "node_modules/source-map-support": { - "version": "0.4.18", - "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.4.18.tgz", - "integrity": "sha512-try0/JqxPLF9nOjvSta7tVondkP5dwgyLDjVoyMDlmjugT2lRZ1OfsrYTkCd2hkDnJTKRbO/Rl3orm8vlsUzbA==", + "version": "0.5.21", + "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", + "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", "dev": true, "license": "MIT", "dependencies": { - "source-map": "^0.5.6" + "buffer-from": "^1.0.0", + "source-map": "^0.6.0" } }, + "node_modules/sourcemap-codec": { + "version": "1.4.8", + "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz", + "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==", + "deprecated": "Please use @jridgewell/sourcemap-codec instead", + "dev": true, + "license": "MIT" + }, "node_modules/sprintf-js": { "version": "1.0.3", "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", @@ -10704,33 +7595,16 @@ "node": ">=8.0" } }, - "node_modules/strict-uri-encode": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/strict-uri-encode/-/strict-uri-encode-1.1.0.tgz", - "integrity": "sha512-R3f198pcvnB+5IpnBlRkphuE9n46WyVl8I39W/ZUTZLz4nqSP/oLYUrcnJrw462Ds8he4YKMov2efsTIw1BDGQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/string_decoder": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", - "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", + "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", "dev": true, "license": "MIT", "dependencies": { - "safe-buffer": "~5.1.0" + "safe-buffer": "~5.2.0" } }, - "node_modules/string_decoder/node_modules/safe-buffer": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", - "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", - "dev": true, - "license": "MIT" - }, "node_modules/string-argv": { "version": "0.3.2", "resolved": "https://registry.npmjs.org/string-argv/-/string-argv-0.3.2.tgz", @@ -10742,27 +7616,26 @@ } }, "node_modules/string-width": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/string-width/-/string-width-7.2.0.tgz", - "integrity": "sha512-tsaTIkKW9b4N+AEj+SVA+WhJzV7/zMhcSu78mLKWSk7cXMOSHsBKFWUs0fWwq8QyK3MgJBQRX6Gbi4kYbdvGkQ==", + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-8.1.0.tgz", + "integrity": "sha512-Kxl3KJGb/gxkaUMOjRsQ8IrXiGW75O4E3RPjFIINOVH8AMl2SQ/yWdTzWwF3FevIX9LcMAjJW+GRwAlAbTSXdg==", "dev": true, "license": "MIT", "dependencies": { - "emoji-regex": "^10.3.0", - "get-east-asian-width": "^1.0.0", + "get-east-asian-width": "^1.3.0", "strip-ansi": "^7.1.0" }, "engines": { - "node": ">=18" + "node": ">=20" }, "funding": { "url": "https://github.com/sponsors/sindresorhus" } }, "node_modules/strip-ansi": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", - "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.2.tgz", + "integrity": "sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA==", "dev": true, "license": "MIT", "dependencies": { @@ -10775,26 +7648,6 @@ "url": "https://github.com/chalk/strip-ansi?sponsor=1" } }, - "node_modules/strip-dirs": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/strip-dirs/-/strip-dirs-2.1.0.tgz", - "integrity": "sha512-JOCxOeKLm2CAS73y/U4ZeZPTkE+gNVCzKt7Eox84Iej1LT/2pTWYpZKJuxwQpvX1LiZb1xokNR7RLfuBAa7T3g==", - "dev": true, - "license": "MIT", - "dependencies": { - "is-natural-number": "^4.0.1" - } - }, - "node_modules/strip-eof": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz", - "integrity": "sha512-7FCwGGmx8mD5xQd3RPUvnSpUXHM3BWuzjtpD4TXsfcZ9EL4azvVVUscFYwD9nx8Kh+uCBC00XBtAykoMHwTh8Q==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/strip-json-comments": { "version": "3.1.1", "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", @@ -10808,29 +7661,6 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/strip-outer": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/strip-outer/-/strip-outer-1.0.1.tgz", - "integrity": "sha512-k55yxKHwaXnpYGsOzg4Vl8+tDrWylxDEpknGjhTiZB8dFRU5rTo9CAzeycivxV3s+zlTKwrs6WxMxR95n26kwg==", - "dev": true, - "license": "MIT", - "dependencies": { - "escape-string-regexp": "^1.0.2" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/strip-outer/node_modules/escape-string-regexp": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.8.0" - } - }, "node_modules/supports-color": { "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", @@ -10858,13 +7688,13 @@ } }, "node_modules/synckit": { - "version": "0.11.8", - "resolved": "https://registry.npmjs.org/synckit/-/synckit-0.11.8.tgz", - "integrity": "sha512-+XZ+r1XGIJGeQk3VvXhT6xx/VpbHsRzsTkGgF6E5RX9TTXD0118l87puaEBZ566FhqblC6U0d4XnubznJDm30A==", + "version": "0.11.11", + "resolved": "https://registry.npmjs.org/synckit/-/synckit-0.11.11.tgz", + "integrity": "sha512-MeQTA1r0litLUf0Rp/iisCaL8761lKAZHaimlbGK4j0HysC4PLfqygQj9srcs0m2RdtDYnF8UuYyKpbjHYp7Jw==", "dev": true, "license": "MIT", "dependencies": { - "@pkgr/core": "^0.2.4" + "@pkgr/core": "^0.2.9" }, "engines": { "node": "^14.18.0 || >=16.0.0" @@ -10874,100 +7704,28 @@ } }, "node_modules/tapable": { - "version": "2.2.2", - "resolved": "https://registry.npmjs.org/tapable/-/tapable-2.2.2.tgz", - "integrity": "sha512-Re10+NauLTMCudc7T5WLFLAwDhQ0JWdrMK+9B2M8zR5hRExKmsRDCBA7/aV/pNJFltmBFO5BAMlQFi/vq3nKOg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=6" - } - }, - "node_modules/tar-fs": { - "version": "2.1.3", - "resolved": "https://registry.npmjs.org/tar-fs/-/tar-fs-2.1.3.tgz", - "integrity": "sha512-090nwYJDmlhwFwEW3QQl+vaNnxsO2yVsd45eTKRBzSzu+hlb1w2K9inVq5b0ngXuLVqQ4ApvsUHHnu/zQNkWAg==", - "dev": true, - "license": "MIT", - "dependencies": { - "chownr": "^1.1.1", - "mkdirp-classic": "^0.5.2", - "pump": "^3.0.0", - "tar-stream": "^2.1.4" - } - }, - "node_modules/tar-fs/node_modules/bl": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/bl/-/bl-4.1.0.tgz", - "integrity": "sha512-1W07cM9gS6DcLperZfFSj+bWLtaPGSOHWhPiGzXmvVJbRLdG82sH/Kn8EtW1VqWVA54AKf2h5k5BbnIbwF3h6w==", - "dev": true, - "license": "MIT", - "dependencies": { - "buffer": "^5.5.0", - "inherits": "^2.0.4", - "readable-stream": "^3.4.0" - } - }, - "node_modules/tar-fs/node_modules/readable-stream": { - "version": "3.6.2", - "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", - "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", - "dev": true, - "license": "MIT", - "dependencies": { - "inherits": "^2.0.3", - "string_decoder": "^1.1.1", - "util-deprecate": "^1.0.1" - }, - "engines": { - "node": ">= 6" - } - }, - "node_modules/tar-fs/node_modules/tar-stream": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/tar-stream/-/tar-stream-2.2.0.tgz", - "integrity": "sha512-ujeqbceABgwMZxEJnk2HDY2DlnUZ+9oEcb1KzTVfYHio0UE6dG71n60d8D2I4qNvleWrrXpmjpt7vZeF1LnMZQ==", + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/tapable/-/tapable-2.3.0.tgz", + "integrity": "sha512-g9ljZiwki/LfxmQADO3dEY1CbpmXT5Hm2fJ+QaGKwSXUylMybePR7/67YW7jOrrvjEgL1Fmz5kzyAjWVWLlucg==", "dev": true, "license": "MIT", - "dependencies": { - "bl": "^4.0.3", - "end-of-stream": "^1.4.1", - "fs-constants": "^1.0.0", - "inherits": "^2.0.3", - "readable-stream": "^3.1.1" - }, "engines": { "node": ">=6" - } - }, - "node_modules/tar-stream": { - "version": "1.6.2", - "resolved": "https://registry.npmjs.org/tar-stream/-/tar-stream-1.6.2.tgz", - "integrity": "sha512-rzS0heiNf8Xn7/mpdSVVSMAWAoy9bfb1WOTYC78Z0UQKeKa/CWS8FOq0lKGNa8DWKAn9gxjCvMLYc5PGXYlK2A==", - "dev": true, - "license": "MIT", - "dependencies": { - "bl": "^1.0.0", - "buffer-alloc": "^1.2.0", - "end-of-stream": "^1.0.0", - "fs-constants": "^1.0.0", - "readable-stream": "^2.3.0", - "to-buffer": "^1.1.1", - "xtend": "^4.0.0" }, - "engines": { - "node": ">= 0.8.0" + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" } }, "node_modules/terser": { - "version": "5.43.1", - "resolved": "https://registry.npmjs.org/terser/-/terser-5.43.1.tgz", - "integrity": "sha512-+6erLbBm0+LROX2sPXlUYx/ux5PyE9K/a92Wrt6oA+WDAoFTdpHE5tCYCI5PNzq2y8df4rA+QgHLJuR4jNymsg==", + "version": "5.44.0", + "resolved": "https://registry.npmjs.org/terser/-/terser-5.44.0.tgz", + "integrity": "sha512-nIVck8DK+GM/0Frwd+nIhZ84pR/BX7rmXMfYwyg+Sri5oGVE99/E3KvXqpC2xHFxyqXyGHTKBSioxxplrO4I4w==", "dev": true, "license": "BSD-2-Clause", "dependencies": { "@jridgewell/source-map": "^0.3.3", - "acorn": "^8.14.0", + "acorn": "^8.15.0", "commander": "^2.20.0", "source-map-support": "~0.5.20" }, @@ -11020,27 +7778,6 @@ "dev": true, "license": "MIT" }, - "node_modules/terser/node_modules/source-map": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", - "dev": true, - "license": "BSD-3-Clause", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/terser/node_modules/source-map-support": { - "version": "0.5.21", - "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", - "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", - "dev": true, - "license": "MIT", - "dependencies": { - "buffer-from": "^1.0.0", - "source-map": "^0.6.0" - } - }, "node_modules/test-exclude": { "version": "6.0.0", "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", @@ -11056,23 +7793,6 @@ "node": ">=8" } }, - "node_modules/through": { - "version": "2.3.8", - "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", - "integrity": "sha512-w89qg7PI8wAdvX60bMDP+bFoD5Dvhm9oLheFp5O4a2QF0cSBGsBX4qZmadPMvVqlLJBBci+WqGGOAPvcDeNSVg==", - "dev": true, - "license": "MIT" - }, - "node_modules/timed-out": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/timed-out/-/timed-out-4.0.1.tgz", - "integrity": "sha512-G7r3AhovYtr5YKOWQkta8RKAPb+J9IsO4uVmzjl8AZwfhs8UcUwTiD6gcJYSgOtzyjvQKrKYn41syHbUWMkafA==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/tinyexec": { "version": "0.3.2", "resolved": "https://registry.npmjs.org/tinyexec/-/tinyexec-0.3.2.tgz", @@ -11081,47 +7801,15 @@ "license": "MIT" }, "node_modules/tmp": { - "version": "0.2.3", - "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.2.3.tgz", - "integrity": "sha512-nZD7m9iCPC5g0pYmcaxogYKggSfLsdxl8of3Q/oIbqCqLLIO9IAF0GWjX1z9NZRHPiXv8Wex4yDCaZsgEw0Y8w==", + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.2.5.tgz", + "integrity": "sha512-voyz6MApa1rQGUxT3E+BK7/ROe8itEx7vD8/HEvt4xwXucvQ5G5oeEiHkmHZJuBO21RpOf+YYm9MOivj709jow==", "dev": true, "license": "MIT", "engines": { "node": ">=14.14" } }, - "node_modules/to-buffer": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/to-buffer/-/to-buffer-1.2.1.tgz", - "integrity": "sha512-tB82LpAIWjhLYbqjx3X4zEeHN6M8CiuOEy2JY8SEQVdYRe3CCHOFaqrBW1doLDrfpWhplcW7BL+bO3/6S3pcDQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "isarray": "^2.0.5", - "safe-buffer": "^5.2.1", - "typed-array-buffer": "^1.0.3" - }, - "engines": { - "node": ">= 0.4" - } - }, - "node_modules/to-buffer/node_modules/isarray": { - "version": "2.0.5", - "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz", - "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==", - "dev": true, - "license": "MIT" - }, - "node_modules/to-fast-properties": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-1.0.3.tgz", - "integrity": "sha512-lxrWP8ejsq+7E3nNjwYmUBMAgjMTZoTI+sdBOpvNyijeDLa29LUn9QaoXAHv4+Z578hbmHHJKZknzxVtvo77og==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/to-regex-range": { "version": "5.0.1", "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", @@ -11152,39 +7840,6 @@ "dev": true, "license": "MIT" }, - "node_modules/trim-repeated": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/trim-repeated/-/trim-repeated-1.0.0.tgz", - "integrity": "sha512-pkonvlKk8/ZuR0D5tLW8ljt5I8kmxp2XKymhepUeOdCEfKpZaktSArkLHZt76OB1ZvO9bssUsDty4SWhLvZpLg==", - "dev": true, - "license": "MIT", - "dependencies": { - "escape-string-regexp": "^1.0.2" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/trim-repeated/node_modules/escape-string-regexp": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.8.0" - } - }, - "node_modules/trim-right": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/trim-right/-/trim-right-1.0.1.tgz", - "integrity": "sha512-WZGXGstmCWgeevgTL54hrCuw1dyMQIzWy7ZfqRJfSmJZBwklI15egmQytFP6bPidmw3M8d5yEowl1niq4vmqZw==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.10.0" - } - }, "node_modules/tslib": { "version": "2.8.1", "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.8.1.tgz", @@ -11192,29 +7847,6 @@ "dev": true, "license": "0BSD" }, - "node_modules/tunnel": { - "version": "0.0.6", - "resolved": "https://registry.npmjs.org/tunnel/-/tunnel-0.0.6.tgz", - "integrity": "sha512-1h/Lnq9yajKY2PEbBadPXj3VxsDDu844OnaAo52UVmIzIvwwtBPIuNvkjuzBlTWpfJyUbG3ez0KSBibQkj4ojg==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.6.11 <=0.7.0 || >=0.7.3" - } - }, - "node_modules/tunnel-agent": { - "version": "0.6.0", - "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", - "integrity": "sha512-McnNiV1l8RYeY8tBgEpuodCC1mLUdbSN+CYBL7kJsJNInOP8UjDDEwdk6Mw60vdLLrr5NHKZhMAOSrR2NZuQ+w==", - "dev": true, - "license": "Apache-2.0", - "dependencies": { - "safe-buffer": "^5.0.1" - }, - "engines": { - "node": "*" - } - }, "node_modules/type-check": { "version": "0.4.0", "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", @@ -11229,9 +7861,9 @@ } }, "node_modules/type-fest": { - "version": "0.13.1", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.13.1.tgz", - "integrity": "sha512-34R7HTnG0XIJcBSn5XhDd7nNFPRcXYRZrBB2O2jdKqYODldSzBAqzsWoZYYvduky73toYS/ESqxPvkDf/F0XMg==", + "version": "0.21.3", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", + "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", "dev": true, "license": "(MIT OR CC0-1.0)", "engines": { @@ -11255,25 +7887,10 @@ "node": ">= 0.6" } }, - "node_modules/typed-array-buffer": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.3.tgz", - "integrity": "sha512-nAYYwfY3qnzX30IkA6AQZjVbtK6duGontcQm1WSG1MD94YLqK0515GNApXkoxKOWMusVssAHWLh9SeaoefYFGw==", - "dev": true, - "license": "MIT", - "dependencies": { - "call-bound": "^1.0.3", - "es-errors": "^1.3.0", - "is-typed-array": "^1.1.14" - }, - "engines": { - "node": ">= 0.4" - } - }, "node_modules/ua-parser-js": { - "version": "0.7.40", - "resolved": "https://registry.npmjs.org/ua-parser-js/-/ua-parser-js-0.7.40.tgz", - "integrity": "sha512-us1E3K+3jJppDBa3Tl0L3MOJiGhe1C6P0+nIvQAFYbxlMAx0h81eOwLmU57xgqToduDDPx3y5QsdjPfDu+FgOQ==", + "version": "0.7.41", + "resolved": "https://registry.npmjs.org/ua-parser-js/-/ua-parser-js-0.7.41.tgz", + "integrity": "sha512-O3oYyCMPYgNNHuO7Jjk3uacJWZF8loBgwrfd/5LE/HyZ3lUIOdniQ7DNXJcIgZbwioZxk0fLfI4EVnetdiX5jg==", "dev": true, "funding": [ { @@ -11310,21 +7927,10 @@ "node": ">=0.8.0" } }, - "node_modules/unbzip2-stream": { - "version": "1.4.3", - "resolved": "https://registry.npmjs.org/unbzip2-stream/-/unbzip2-stream-1.4.3.tgz", - "integrity": "sha512-mlExGW4w71ebDJviH16lQLtZS32VKqsSfk80GCfUlwT/4/hNRFsoscrF/c++9xinkMzECL1uL9DDwXqFWkruPg==", - "dev": true, - "license": "MIT", - "dependencies": { - "buffer": "^5.2.1", - "through": "^2.3.8" - } - }, "node_modules/undici-types": { - "version": "7.8.0", - "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-7.8.0.tgz", - "integrity": "sha512-9UJ2xGDvQ43tYyVMpuHlsgApydB8ZKfVYTsLDhXkFL/6gfkp+U8xTGdh8pMJv1SpZna0zxG1DwsKZsreLbXBxw==", + "version": "7.13.0", + "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-7.13.0.tgz", + "integrity": "sha512-Ov2Rr9Sx+fRgagJ5AX0qvItZG/JKKoBRAVITs1zk7IqZGTJUwgUr7qoYBpWwakpWilTZFM98rG/AFRocu10iIQ==", "dev": true, "license": "MIT" }, @@ -11353,9 +7959,9 @@ } }, "node_modules/unicode-match-property-value-ecmascript": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.2.0.tgz", - "integrity": "sha512-4IehN3V/+kkr5YeSSDDQG8QLqO26XpL2XP3GQtqwlT/QYSECAwFztxVHjlbh0+gjJ3XmNLS0zDsbgs9jWKExLg==", + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.2.1.tgz", + "integrity": "sha512-JQ84qTuMg4nVkx8ga4A16a1epI9H6uTXAknqxkGF/aFfRLw1xC/Bp24HNLaZhHSkWd3+84t8iXnp1J0kYcZHhg==", "dev": true, "license": "MIT", "engines": { @@ -11363,9 +7969,9 @@ } }, "node_modules/unicode-property-aliases-ecmascript": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.1.0.tgz", - "integrity": "sha512-6t3foTQI9qne+OZoVQB/8x8rk2k1eVy1gRXhV3oFQ5T6R1dqQ1xtin3XqSlx3+ATBkliTaR/hHyJBm+LVPNM8w==", + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.2.0.tgz", + "integrity": "sha512-hpbDzxUY9BFwX+UeBnxv3Sh1q7HFxj48DTmXchNgRa46lO8uj3/1iEn3MiNUYTg1g9ctIqXCCERn8gYZhHC5lQ==", "dev": true, "license": "MIT", "engines": { @@ -11423,26 +8029,6 @@ "browserslist": ">= 4.21.0" } }, - "node_modules/upper-case": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/upper-case/-/upper-case-2.0.2.tgz", - "integrity": "sha512-KgdgDGJt2TpuwBUIjgG6lzw2GWFRCW9Qkfkiv0DxqHHLYJHmtmdUIKcZd8rHgFSjopVTlw6ggzCm1b8MFQwikg==", - "dev": true, - "license": "MIT", - "dependencies": { - "tslib": "^2.0.3" - } - }, - "node_modules/upper-case-first": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/upper-case-first/-/upper-case-first-2.0.2.tgz", - "integrity": "sha512-514ppYHBaKwfJRK/pNC6c/OxfGa0obSnAl106u97Ed0I625Nin96KAjttZF6ZL3e1XLtphxnqrOi9iWgm+u+bg==", - "dev": true, - "license": "MIT", - "dependencies": { - "tslib": "^2.0.3" - } - }, "node_modules/uri-js": { "version": "4.4.1", "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", @@ -11463,29 +8049,6 @@ "node": ">=6" } }, - "node_modules/url-parse-lax": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-3.0.0.tgz", - "integrity": "sha512-NjFKA0DidqPa5ciFcSrXnAltTtzz84ogy+NebPvfEgAck0+TNg4UJ4IN+fB7zRZfbgUf0syOo9MDxFkDSMuFaQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "prepend-http": "^2.0.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/url-to-options": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/url-to-options/-/url-to-options-1.0.1.tgz", - "integrity": "sha512-0kQLIzG4fdk/G5NONku64rSH/x32NOA39LVQqlK8Le6lvTF6GGRJpqaQFGgU+CLwySIqBSMdwYM0sYcW9f6P4A==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">= 4" - } - }, "node_modules/util-deprecate": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", @@ -11503,16 +8066,6 @@ "node": ">= 0.4.0" } }, - "node_modules/uuid": { - "version": "8.3.2", - "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", - "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", - "dev": true, - "license": "MIT", - "bin": { - "uuid": "dist/bin/uuid" - } - }, "node_modules/vary": { "version": "1.1.2", "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", @@ -11547,125 +8100,24 @@ "node": ">=10.13.0" } }, - "node_modules/webdriver": { - "version": "6.12.1", - "resolved": "https://registry.npmjs.org/webdriver/-/webdriver-6.12.1.tgz", - "integrity": "sha512-3rZgAj9o2XHp16FDTzvUYaHelPMSPbO1TpLIMUT06DfdZjNYIzZiItpIb/NbQDTPmNhzd9cuGmdI56WFBGY2BA==", - "dev": true, - "license": "MIT", - "dependencies": { - "@wdio/config": "6.12.1", - "@wdio/logger": "6.10.10", - "@wdio/protocols": "6.12.0", - "@wdio/utils": "6.11.0", - "got": "^11.0.2", - "lodash.merge": "^4.6.1" - }, - "engines": { - "node": ">=10.0.0" - } - }, - "node_modules/webdriverio": { - "version": "6.12.1", - "resolved": "https://registry.npmjs.org/webdriverio/-/webdriverio-6.12.1.tgz", - "integrity": "sha512-Nx7ge0vTWHVIRUbZCT+IuMwB5Q0Q5nLlYdgnmmJviUKLuc3XtaEBkYPTbhHWHgSBXsPZMIc023vZKNkn+6iyeQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "@types/puppeteer-core": "^5.4.0", - "@wdio/config": "6.12.1", - "@wdio/logger": "6.10.10", - "@wdio/repl": "6.11.0", - "@wdio/utils": "6.11.0", - "archiver": "^5.0.0", - "atob": "^2.1.2", - "css-shorthand-properties": "^1.1.1", - "css-value": "^0.0.1", - "devtools": "6.12.1", - "fs-extra": "^9.0.1", - "get-port": "^5.1.1", - "grapheme-splitter": "^1.0.2", - "lodash.clonedeep": "^4.5.0", - "lodash.isobject": "^3.0.2", - "lodash.isplainobject": "^4.0.6", - "lodash.zip": "^4.2.0", - "minimatch": "^3.0.4", - "puppeteer-core": "^5.1.0", - "resq": "^1.9.1", - "rgb2hex": "0.2.3", - "serialize-error": "^8.0.0", - "webdriver": "6.12.1" - }, - "engines": { - "node": ">=10.0.0" - } - }, - "node_modules/webdriverio/node_modules/fs-extra": { - "version": "9.1.0", - "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-9.1.0.tgz", - "integrity": "sha512-hcg3ZmepS30/7BSFqRvoo3DOMQu7IjqxO5nCDt+zM9XWjb33Wg7ziNT+Qvqbuc3+gWpzO02JubVyk2G4Zvo1OQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "at-least-node": "^1.0.0", - "graceful-fs": "^4.2.0", - "jsonfile": "^6.0.1", - "universalify": "^2.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/webdriverio/node_modules/jsonfile": { - "version": "6.1.0", - "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-6.1.0.tgz", - "integrity": "sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "universalify": "^2.0.0" - }, - "optionalDependencies": { - "graceful-fs": "^4.1.6" - } - }, - "node_modules/webdriverio/node_modules/serialize-error": { - "version": "8.1.0", - "resolved": "https://registry.npmjs.org/serialize-error/-/serialize-error-8.1.0.tgz", - "integrity": "sha512-3NnuWfM6vBYoy5gZFvHiYsVbafvI9vZv/+jlIigFn4oP4zjNPK3LhcY0xSCgeb1a5L8jO71Mit9LlNoi2UfDDQ==", + "node_modules/wcwidth": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/wcwidth/-/wcwidth-1.0.1.tgz", + "integrity": "sha512-XHPEwS0q6TaxcvG85+8EYkbiCux2XtWG2mkc47Ng2A77BQu9+DqIOJldST4HgPkuea7dvKSj5VgX3P1d4rW8Tg==", "dev": true, "license": "MIT", "dependencies": { - "type-fest": "^0.20.2" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" + "defaults": "^1.0.3" } }, - "node_modules/webdriverio/node_modules/type-fest": { - "version": "0.20.2", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", - "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", - "dev": true, - "license": "(MIT OR CC0-1.0)", - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/webdriverio/node_modules/universalify": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.1.tgz", - "integrity": "sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw==", + "node_modules/web-streams-polyfill": { + "version": "3.3.3", + "resolved": "https://registry.npmjs.org/web-streams-polyfill/-/web-streams-polyfill-3.3.3.tgz", + "integrity": "sha512-d2JWLCivmZYTSIoge9MsgFCZrt571BikcWGYkjC1khllbTeDlGqZ2D8vD8E/lJa8WGWbb7Plm8/XJYV7IJHZZw==", "dev": true, "license": "MIT", "engines": { - "node": ">= 10.0.0" + "node": ">= 8" } }, "node_modules/webidl-conversions": { @@ -11676,22 +8128,23 @@ "license": "BSD-2-Clause" }, "node_modules/webpack": { - "version": "5.99.9", - "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.99.9.tgz", - "integrity": "sha512-brOPwM3JnmOa+7kd3NsmOUOwbDAj8FT9xDsG3IW0MgbN9yZV7Oi/s/+MNQ/EcSMqw7qfoRyXPoeEWT8zLVdVGg==", + "version": "5.102.0", + "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.102.0.tgz", + "integrity": "sha512-hUtqAR3ZLVEYDEABdBioQCIqSoguHbFn1K7WlPPWSuXmx0031BD73PSE35jKyftdSh4YLDoQNgK4pqBt5Q82MA==", "dev": true, "license": "MIT", "dependencies": { "@types/eslint-scope": "^3.7.7", - "@types/estree": "^1.0.6", + "@types/estree": "^1.0.8", "@types/json-schema": "^7.0.15", "@webassemblyjs/ast": "^1.14.1", "@webassemblyjs/wasm-edit": "^1.14.1", "@webassemblyjs/wasm-parser": "^1.14.1", - "acorn": "^8.14.0", - "browserslist": "^4.24.0", + "acorn": "^8.15.0", + "acorn-import-phases": "^1.0.3", + "browserslist": "^4.24.5", "chrome-trace-event": "^1.0.2", - "enhanced-resolve": "^5.17.1", + "enhanced-resolve": "^5.17.3", "es-module-lexer": "^1.2.1", "eslint-scope": "5.1.1", "events": "^3.2.0", @@ -11702,10 +8155,10 @@ "mime-types": "^2.1.27", "neo-async": "^2.6.2", "schema-utils": "^4.3.2", - "tapable": "^2.1.1", + "tapable": "^2.2.3", "terser-webpack-plugin": "^5.3.11", - "watchpack": "^2.4.1", - "webpack-sources": "^3.2.3" + "watchpack": "^2.4.4", + "webpack-sources": "^3.3.3" }, "bin": { "webpack": "bin/webpack.js" @@ -11794,28 +8247,6 @@ "node": ">= 8" } }, - "node_modules/which-typed-array": { - "version": "1.1.19", - "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.19.tgz", - "integrity": "sha512-rEvr90Bck4WZt9HHFC4DJMsjvu7x+r6bImz0/BrbWb7A2djJ8hnZMrWnHo9F8ssv0OMErasDhftrfROTyqSDrw==", - "dev": true, - "license": "MIT", - "dependencies": { - "available-typed-arrays": "^1.0.7", - "call-bind": "^1.0.8", - "call-bound": "^1.0.4", - "for-each": "^0.3.5", - "get-proto": "^1.0.1", - "gopd": "^1.2.0", - "has-tostringtag": "^1.0.2" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, "node_modules/word-wrap": { "version": "1.2.5", "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz", @@ -11827,9 +8258,9 @@ } }, "node_modules/wrap-ansi": { - "version": "9.0.0", - "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-9.0.0.tgz", - "integrity": "sha512-G8ura3S+3Z2G+mkgNRq8dqaFZAuxfsxpBB8OCTGRTCtp+l/v9nbFNmCUP1BZMts3G1142MsZfn6eeUKrr4PD1Q==", + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-9.0.2.tgz", + "integrity": "sha512-42AtmgqjV+X1VpdOfyTGOYRi0/zsoLqtXQckTmqTeybT+BDIbM/Guxo7x3pE2vtpr1ok6xRqM9OpBe+Jyoqyww==", "dev": true, "license": "MIT", "dependencies": { @@ -11845,9 +8276,9 @@ } }, "node_modules/wrap-ansi/node_modules/ansi-styles": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", - "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", + "version": "6.2.3", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.3.tgz", + "integrity": "sha512-4Dj6M28JB+oAH8kFkTLUo+a2jwOFkuqb3yucU0CANcRRUbxS0cP0nZYCGjcc3BNXwRIsUVmDGgzawme7zvJHvg==", "dev": true, "license": "MIT", "engines": { @@ -11857,6 +8288,31 @@ "url": "https://github.com/chalk/ansi-styles?sponsor=1" } }, + "node_modules/wrap-ansi/node_modules/emoji-regex": { + "version": "10.5.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.5.0.tgz", + "integrity": "sha512-lb49vf1Xzfx080OKA0o6l8DQQpV+6Vg95zyCJX9VB/BqKYlhG7N4wgROUUHRA+ZPUefLnteQOad7z1kT2bV7bg==", + "dev": true, + "license": "MIT" + }, + "node_modules/wrap-ansi/node_modules/string-width": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-7.2.0.tgz", + "integrity": "sha512-tsaTIkKW9b4N+AEj+SVA+WhJzV7/zMhcSu78mLKWSk7cXMOSHsBKFWUs0fWwq8QyK3MgJBQRX6Gbi4kYbdvGkQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "emoji-regex": "^10.3.0", + "get-east-asian-width": "^1.0.0", + "strip-ansi": "^7.1.0" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, "node_modules/wrappy": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", @@ -11886,16 +8342,6 @@ } } }, - "node_modules/xtend": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", - "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", - "dev": true, - "license": "MIT", - "engines": { - "node": ">=0.4" - } - }, "node_modules/y18n": { "version": "5.0.8", "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", @@ -11914,9 +8360,9 @@ "license": "ISC" }, "node_modules/yaml": { - "version": "2.8.0", - "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.8.0.tgz", - "integrity": "sha512-4lLa/EcQCB0cJkyts+FpIRx5G/llPxfP6VQU5KByHEhLxY3IJCH0f0Hy1MHI8sClTvsIb8qwRJ6R/ZdlDJ/leQ==", + "version": "2.8.1", + "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.8.1.tgz", + "integrity": "sha512-lcYcMxX2PO9XMGvAJkJ3OsNMw+/7FKes7/hgerGUYWIoWu5j/+YQqcZr5JnPZWzOsEBgMbSbiSTn/dv/69Mkpw==", "dev": true, "license": "ISC", "bin": { @@ -11965,13 +8411,6 @@ "node": ">=8" } }, - "node_modules/yargs/node_modules/emoji-regex": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", - "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", - "dev": true, - "license": "MIT" - }, "node_modules/yargs/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", @@ -12010,17 +8449,6 @@ "node": ">=8" } }, - "node_modules/yauzl": { - "version": "2.10.0", - "resolved": "https://registry.npmjs.org/yauzl/-/yauzl-2.10.0.tgz", - "integrity": "sha512-p4a9I6X6nu6IhoGmBqAcbJy1mlC4j27vEPZX9F4L4/vZT3Lyq1VkFHw/V/PUcB9Buo+DG3iHkT0x3Qya58zc3g==", - "dev": true, - "license": "MIT", - "dependencies": { - "buffer-crc32": "~0.2.3", - "fd-slicer": "~1.1.0" - } - }, "node_modules/yocto-queue": { "version": "0.1.0", "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", @@ -12034,56 +8462,17 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/zip-stream": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/zip-stream/-/zip-stream-4.1.1.tgz", - "integrity": "sha512-9qv4rlDiopXg4E69k+vMHjNN63YFMe9sZMrdlvKnCjlCRWeCBswPPMPUfx+ipsAWq1LXHe70RcbaHdJJpS6hyQ==", - "dev": true, - "license": "MIT", - "dependencies": { - "archiver-utils": "^3.0.4", - "compress-commons": "^4.1.2", - "readable-stream": "^3.6.0" - }, - "engines": { - "node": ">= 10" - } - }, - "node_modules/zip-stream/node_modules/archiver-utils": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/archiver-utils/-/archiver-utils-3.0.4.tgz", - "integrity": "sha512-KVgf4XQVrTjhyWmx6cte4RxonPLR9onExufI1jhvw/MQ4BB6IsZD5gT8Lq+u/+pRkWna/6JoHpiQioaqFP5Rzw==", + "node_modules/yoctocolors-cjs": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/yoctocolors-cjs/-/yoctocolors-cjs-2.1.3.tgz", + "integrity": "sha512-U/PBtDf35ff0D8X8D0jfdzHYEPFxAI7jJlxZXwCSez5M3190m+QobIfh+sWDWSHMCWWJN2AWamkegn6vr6YBTw==", "dev": true, "license": "MIT", - "dependencies": { - "glob": "^7.2.3", - "graceful-fs": "^4.2.0", - "lazystream": "^1.0.0", - "lodash.defaults": "^4.2.0", - "lodash.difference": "^4.5.0", - "lodash.flatten": "^4.4.0", - "lodash.isplainobject": "^4.0.6", - "lodash.union": "^4.6.0", - "normalize-path": "^3.0.0", - "readable-stream": "^3.6.0" - }, "engines": { - "node": ">= 10" - } - }, - "node_modules/zip-stream/node_modules/readable-stream": { - "version": "3.6.2", - "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", - "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", - "dev": true, - "license": "MIT", - "dependencies": { - "inherits": "^2.0.3", - "string_decoder": "^1.1.1", - "util-deprecate": "^1.0.1" + "node": ">=18" }, - "engines": { - "node": ">= 6" + "funding": { + "url": "https://github.com/sponsors/sindresorhus" } } } diff --git a/package.json b/package.json index 5cdfab77..b8bdf7e0 100644 --- a/package.json +++ b/package.json @@ -1,20 +1,27 @@ { "name": "@adobe/reactor-turbine", - "version": "28.2.0-beta.1", + "version": "29.0.0-beta.2", "description": "Tags rule engine which processes rules on client websites and delegates logic to extensions.", "license": "Apache-2.0", "scripts": { - "build": "npm run clean && rollup -c && npm run minify", - "build:watch": "npm run clean && rollup --watch -c", + "build": "npm run clean && rollup -c", + "build:production": "NODE_ENV=production npm run build && npm run minify && npm run verify-no-test-code", + "verify-no-test-code": "bash ./verify-no-test-code.sh", "clean": "rm -rf dist", "format": "pretty-quick", - "minify": "uglifyjs dist/engine.js -c -m -o dist/engine.min.js", - "prepublishOnly": "npm run build", - "test": "karma start", - "test:watch": "karma start --no-single-run --no-coverage", "lint": "eslint 'src/**/*.js' 'coreModulePackages/**/*.js'", + "minify": "uglifyjs dist/engine.js -c -m -o dist/engine.min.js", "prepare": "husky install", - "upgrade-repo": "npx npm-check-updates -u" + "postinstall": "npx playwright install", + "test": "npm run test:unit && npm run test:integration", + "test:unit": "karma start karma.unit.conf.js", + "test:unit:ci:pull:request": "npm install karma-sauce-launcher@4.3.6 && karma start karma.unit.conf.js", + "test:unit:ci:npm:publish": "karma start karma.unit.conf.js --browsers=ChromeHeadless --no-coverage", + "generate-access-token": "node ci-scripts/setup/generate-access-token.js", + "ensure-integration-containers": "npm run generate-access-token && node ci-scripts/ensure-library-builds-for-integration.js", + "test:integration": "npm run build && karma start karma.integration.conf.js --no-coverage && npm run test:integration:playwright", + "test:integration:playwright": "npm run ensure-integration-containers && playwright test", + "test:integration:ci:npm:publish": "npm run build && npm run ensure-integration-containers && karma start karma.integration.conf.js --browsers=ChromeHeadless --no-coverage" }, "author": { "name": "Adobe Systems", @@ -33,21 +40,26 @@ "@adobe/reactor-promise": "*", "@adobe/reactor-query-string": "*", "@adobe/reactor-window": "*", - "is-plain-object": "^5.0.0" + "is-plain-object": "^5.0.0", + "lodash.clonedeep": "^4.5.0" }, "devDependencies": { + "@adobe/auth-token": "^1.0.1", + "@adobe/reactor-sdk": "^2.0.0-beta.5", "@babel/core": "^7.27.4", "@babel/preset-env": "^7.27.2", + "@playwright/test": "^1.56.1", "@rollup/plugin-commonjs": "^28.0.6", "@rollup/plugin-node-resolve": "^16.0.1", + "@rollup/plugin-replace": "^6.0.2", "babel-loader": "^10.0.0", "babel-plugin-istanbul": "^7.0.0", "camelize": "1.0.1", - "eslint": "^9.29.0", + "dotenv": "^17.2.3", + "eslint": "^9.37.0", "eslint-config-prettier": "^10.1.5", "eslint-plugin-prettier": "^5.5.0", "husky": "^9.1.7", - "inject-loader": "^4.0.1", "jasmine-core": "^5.8.0", "karma": "^6.4.4", "karma-chrome-launcher": "^3.2.0", @@ -56,13 +68,13 @@ "karma-jasmine": "^5.1.0", "karma-jasmine-matchers": "^5.0.0", "karma-safari-launcher": "^1.0.0", - "karma-sauce-launcher": "^4.3.6", "karma-webpack": "^5.0.1", "kebab-case": "2.0.2", "lint-staged": "^16.1.2", - "prettier": "3.6.0", + "prettier": "^3.6.2", "pretty-quick": "^4.2.2", - "rollup": "^4.44.0", + "rollup": "^4.52.4", + "rollup-plugin-strip-code": "^0.2.8", "uglify-js": "^3.19.3", "webpack": "^5.99.9", "yargs": "^17.7.2" @@ -73,11 +85,6 @@ ] }, "engines": { - "node": ">=v20.17.0" - }, - "overrides": { - "inject-loader": { - "webpack": "^5.99.9" - } + "node": ">=v22.19.0" } } diff --git a/playwright-report/data/184b8da9737b5e64acc80da58cd381685efd27dc.md b/playwright-report/data/184b8da9737b5e64acc80da58cd381685efd27dc.md new file mode 100644 index 00000000..73c24a9c --- /dev/null +++ b/playwright-report/data/184b8da9737b5e64acc80da58cd381685efd27dc.md @@ -0,0 +1,5 @@ +# Page snapshot + +```yaml +- heading "Testing Script Injection" [level=1] [ref=e2] +``` \ No newline at end of file diff --git a/playwright-report/index.html b/playwright-report/index.html new file mode 100644 index 00000000..c21f2ac8 --- /dev/null +++ b/playwright-report/index.html @@ -0,0 +1,85 @@ + + + + + + + + + Playwright Test Report + + + + +
+ + + \ No newline at end of file diff --git a/playwright.config.js b/playwright.config.js new file mode 100644 index 00000000..790a5ee1 --- /dev/null +++ b/playwright.config.js @@ -0,0 +1,26 @@ +/*************************************************************************************** + * (c) 2025 Adobe. All rights reserved. + * This file is licensed to you under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. You may obtain a copy + * of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under + * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS + * OF ANY KIND, either express or implied. See the License for the specific language + * governing permissions and limitations under the License. + ****************************************************************************************/ + +'use strict'; + +const path = require('path'); + +module.exports = { + testDir: path.join(__dirname, 'src', '__integration__', 'real-containers'), + timeout: 30 * 1000, + use: { + headless: true, + viewport: { width: 1280, height: 720 }, + ignoreHTTPSErrors: true + }, + reporter: [['list']] +}; diff --git a/rollup.config.mjs b/rollup.config.mjs index a5d2278e..c9308a67 100644 --- a/rollup.config.mjs +++ b/rollup.config.mjs @@ -1,6 +1,21 @@ +/*************************************************************************************** + * (c) 2025 Adobe. All rights reserved. + * This file is licensed to you under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. You may obtain a copy + * of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under + * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS + * OF ANY KIND, either express or implied. See the License for the specific language + * governing permissions and limitations under the License. + ****************************************************************************************/ + import { nodeResolve } from '@rollup/plugin-node-resolve'; import commonjs from '@rollup/plugin-commonjs'; +import replace from '@rollup/plugin-replace'; +import stripCode from 'rollup-plugin-strip-code'; +/* eslint-disable camelcase */ export default { input: 'src/index.js', output: { @@ -11,6 +26,16 @@ export default { name: '_satellite' }, plugins: [ + replace({ + preventAssignment: true, + REACTOR_KARMA_CI_UNIT_TEST_MODE: JSON.stringify(false) + }), + ...('production' === process.env.NODE_ENV + ? [stripCode({ + start_comment: 'START.TESTS_ONLY', + end_comment: 'END.TESTS_ONLY' + })] + : []), nodeResolve({ preferBuiltins: false }), diff --git a/src/__integration__/faked-containers/createSimpleIntegrationContainers.js b/src/__integration__/faked-containers/createSimpleIntegrationContainers.js new file mode 100644 index 00000000..7783e8d0 --- /dev/null +++ b/src/__integration__/faked-containers/createSimpleIntegrationContainers.js @@ -0,0 +1,185 @@ +/*************************************************************************************** + * (c) 2025 Adobe. All rights reserved. + * This file is licensed to you under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. You may obtain a copy + * of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under + * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS + * OF ANY KIND, either express or implied. See the License for the specific language + * governing permissions and limitations under the License. + ****************************************************************************************/ + +const cloneDeep = require('lodash.clonedeep'); + +/* eslint-disable max-len */ + +module.exports.bareBonesContainer = function () { + return cloneDeep({ + container: { + buildInfo: { + turbineVersion: '1.0.0-testing' + }, + company: { + dynamicCdnEnabled: false, + cdnAllowList: [] + }, + property: { + settings: { + undefinedVarsReturnEmpty: false, + ruleComponentSequencingEnabled: true + } + }, + environment: { + stage: 'development' + } + } + }); +}; + +/* eslint-disable no-unused-vars */ + +// event - on dom click +// condition - always true +// action - sets window[customActionWindowVariable] to the resolved data element value of 'data:element:value' +module.exports.simpleEventConditionActionContainer = function ({ + ruleComponentSequencingEnabled = false, + customActionWindowVariable +}) { + // this is where the action places the output when it runs + if (!customActionWindowVariable) { + throw new Error('actionWindowVariable is required'); + } + + return cloneDeep({ + container: { + buildInfo: { + turbineVersion: '1.0.0-testing' + }, + company: { + dynamicCdnEnabled: false, + cdnAllowList: [] + }, + property: { + settings: { + undefinedVarsReturnEmpty: false, + ruleComponentSequencingEnabled + } + }, + environment: { + stage: 'development' + }, + dataElements: { + 'core data element': { + modulePath: 'core/src/lib/dataElements/constant.js', + settings: { + value: 'data:element:value' + } + } + }, + extensions: { + core: { + displayName: 'Core', + hostedLibFilesBaseUrl: 'http://fakewebsite.localhost', + modules: { + 'core/src/lib/condition/alwaysTrue.js': { + name: 'always-true', + displayName: 'Always True', + script: function (module, exports, require, turbine) { + module.exports = function (settings) { + // who cares? just return true. + return true; + }; + } + }, + 'core/src/lib/dataElements/constant.js': { + name: 'constant', + displayName: 'Constant', + script: function (module, exports, require, turbine) { + module.exports = function (settings) { + return settings.value; + }; + } + } + } + }, + 'integration-test-extension': { + displayName: 'Integration Test Extension', + hostedLibFilesBaseUrl: 'http://fakewebsite.localhost', + modules: { + 'integration-test-module/src/lib/actions/customActionSource.js': { + name: 'custom-action-source', + displayName: 'Custom Action Source', + script: function (module, exports, require, turbine) { + var window = require('@adobe/reactor-window'); + module.exports = function (settings) { + window[customActionWindowVariable] = + `integration-test-module:sequencingEnabled-${ruleComponentSequencingEnabled}:${turbine.getDataElementValue(settings.dataElementNameToGrab)}`; + }; + } + }, + 'integration-test-module/src/lib/events/simpleEventTrigger.js': { + name: 'simple-event-trigger', + displayName: 'Simple Event Trigger', + // integration-test-module/src/lib/events/simpleEventTrigger.js + script: function (module, exports, require, turbine) { + var document = require('@adobe/reactor-document'); + module.exports = function (settings, trigger) { + function addClickListener() { + document.body.addEventListener('click', function () { + trigger(); + }); + } + + if ( + document.readyState === 'complete' || + document.readyState === 'interactive' + ) { + addClickListener(); + } else { + document.addEventListener( + 'DOMContentLoaded', + addClickListener + ); + } + }; + } + } + } + } + }, + rules: [ + { + id: 'RL123456', + name: 'Invoke Custom Action Source', + events: [ + { + modulePath: + 'integration-test-module/src/lib/events/simpleEventTrigger.js', + settings: {}, + ruleOrder: 50 + } + ], + conditions: [ + { + modulePath: 'core/src/lib/condition/alwaysTrue.js', + settings: {}, + timeout: 2000 + } + ], + actions: [ + { + modulePath: + 'integration-test-module/src/lib/actions/customActionSource.js', + settings: { + dataElementNameToGrab: 'core data element' + }, + timeout: 2000, + delayNext: true + } + ] + } + ] + } + }); +}; diff --git a/src/__integration__/faked-containers/faked-containers.test.js b/src/__integration__/faked-containers/faked-containers.test.js new file mode 100644 index 00000000..244e84e5 --- /dev/null +++ b/src/__integration__/faked-containers/faked-containers.test.js @@ -0,0 +1,216 @@ +/*************************************************************************************** + * (c) 2025 Adobe. All rights reserved. + * This file is licensed to you under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. You may obtain a copy + * of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under + * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS + * OF ANY KIND, either express or implied. See the License for the specific language + * governing permissions and limitations under the License. + ****************************************************************************************/ + +const createSimpleIntegrationContainers = require('./createSimpleIntegrationContainers'); +const loadContainer = require('./loadContainerForTest'); + +/* eslint-disable max-len */ + +describe('Integration: dist/engine.js', () => { + beforeEach(() => { + delete window._satellite; + delete window.__satelliteLoaded; + delete window.customActionSourceValueSynchronous; + delete window.customActionSourceValueASynchronous; + }); + + describe('_satellite startup', () => { + let initialSatelliteReference; + beforeEach((done) => { + const container = createSimpleIntegrationContainers.bareBonesContainer(); + initialSatelliteReference = container; + loadContainer({ + container, + resolveDoneLoading: done + }); + }); + + it('window._satellite should be decorated without the reference changing', () => { + // loadContainer places the handed container on window._satellite. so when everything is done, then window._satellite should be strictly equal to the original container. + expect(window._satellite).toBe(initialSatelliteReference); + }); + + it('should have expected _satellite functions', () => { + expect(window._satellite) + .withContext('Expected window._satellite to be defined.') + .toBeDefined(); + expect(window._satellite.property) + .withContext('Expected window._satellite.property to be defined.') + .toBeDefined(); + expect(window._satellite.buildInfo) + .withContext('Expected window._satellite.buildInfo to be defined.') + .toBeDefined(); + expect(window._satellite.environment) + .withContext('Expected window._satellite.environment to be defined.') + .toBeDefined(); + expect(window._satellite.cookie) + .withContext('Expected window._satellite.cookie to be defined.') + .toBeDefined(); + expect(window._satellite.logger) + .withContext('Expected window._satellite.logger to be defined.') + .toBeDefined(); + expect(window._satellite.logger.log) + .withContext('Expected window._satellite.logger.log to be defined.') + .toBeDefined(); + expect(window._satellite.logger.info) + .withContext('Expected window._satellite.logger.info to be defined.') + .toBeDefined(); + expect(window._satellite.logger.debug) + .withContext('Expected window._satellite.logger.debug to be defined.') + .toBeDefined(); + expect(window._satellite.logger.warn) + .withContext('Expected window._satellite.logger.warn to be defined.') + .toBeDefined(); + expect(window._satellite.logger.error) + .withContext('Expected window._satellite.logger.error to be defined.') + .toBeDefined(); + expect(window._satellite.readCookie) + .withContext('Expected window._satellite.readCookie to be defined.') + .toBeDefined(); + expect(window._satellite.removeCookie) + .withContext('Expected window._satellite.removeCookie to be defined.') + .toBeDefined(); + expect(window._satellite.setCookie) + .withContext('Expected window._satellite.setCookie to be defined.') + .toBeDefined(); + expect(window._satellite.pageBottom) + .withContext('Expected window._satellite.pageBottom to be defined.') + .toBeDefined(); + expect(window._satellite.notify) + .withContext('Expected window._satellite.notify to be defined.') + .toBeDefined(); + expect(window._satellite.getVisitorId) + .withContext('Expected window._satellite.getVisitorId to be defined.') + .toBeDefined(); + expect(window._satellite.track) + .withContext('Expected window._satellite.track to be defined.') + .toBeDefined(); + expect(window._satellite.setVar) + .withContext('Expected window._satellite.setVar to be defined.') + .toBeDefined(); + expect(window._satellite.getVar) + .withContext('Expected window._satellite.getVar to be defined.') + .toBeDefined(); + expect(window._satellite.setDebug) + .withContext('Expected window._satellite.setDebug to be defined.') + .toBeDefined(); + }); + + it('Can call setVar and getVar', () => { + expect(window._satellite.setVar('testVar')).toBeFalsy(); + window._satellite.setVar('testVar', 123); + expect(window._satellite.getVar('testVar')).toBe(123); + }); + + it('should have the proper shape for _satellite.environment', () => { + expect(window._satellite.environment).toEqual({ stage: 'development' }); + }); + + it('should have the proper shape for _satellite.buildInfo', () => { + expect(window._satellite.buildInfo).toEqual({ + turbineVersion: '1.0.0-testing' + }); + }); + }); + + describe('tests a basic event/condition/action loop works', () => { + /* + * integration-test-module/src/lib/events/simpleEventTrigger.js adds a click listener to document.body. + * if core/src/lib/condition/alwaysTrue.js fails in some way + * or integration-test-module/src/lib/actions/customActionSource.js doesn't run and set window.customActionSourceValue + * then this test will time out. + */ + + describe('with ruleComponentSequencingEnabled: false', () => { + beforeAll((done) => { + loadContainer({ + container: + createSimpleIntegrationContainers.simpleEventConditionActionContainer( + { + ruleComponentSequencingEnabled: false, + customActionWindowVariable: 'customActionSourceValueSynchronous' + } + ), + resolveDoneLoading: done + }); + }); + + it('can run a simple event/condition/action loop', (done) => { + expect(window.customActionSourceValueSynchronous).toBeFalsy(); + + let internalValue; + + Object.defineProperty(window, 'customActionSourceValueSynchronous', { + configurable: true, + enumerable: true, + get() { + return internalValue; + }, + set(value) { + internalValue = value; + if ( + value === + 'integration-test-module:sequencingEnabled-false:data:element:value' + ) { + done(); + } + } + }); + + const event = new MouseEvent('click', { bubbles: true }); + document.body.dispatchEvent(event); + }); + }); + + describe('with ruleComponentSequencingEnabled: true', () => { + beforeAll((done) => { + loadContainer({ + container: + createSimpleIntegrationContainers.simpleEventConditionActionContainer( + { + ruleComponentSequencingEnabled: true, + customActionWindowVariable: + 'customActionSourceValueASynchronous' + } + ), + resolveDoneLoading: done + }); + }); + + it('can run a simple event/condition/action loop', (done) => { + expect(window.customActionSourceValueASynchronous).toBeFalsy(); + + let internalValue; + + Object.defineProperty(window, 'customActionSourceValueASynchronous', { + configurable: true, + enumerable: true, + get() { + return internalValue; + }, + set(value) { + internalValue = value; + if ( + value === + 'integration-test-module:sequencingEnabled-true:data:element:value' + ) { + done(); + } + } + }); + + const event = new MouseEvent('click', { bubbles: true }); + document.body.dispatchEvent(event); + }); + }); + }); +}); diff --git a/src/__integration__/faked-containers/loadContainerForTest.js b/src/__integration__/faked-containers/loadContainerForTest.js new file mode 100644 index 00000000..a1f13986 --- /dev/null +++ b/src/__integration__/faked-containers/loadContainerForTest.js @@ -0,0 +1,34 @@ +/*************************************************************************************** + * (c) 2025 Adobe. All rights reserved. + * This file is licensed to you under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. You may obtain a copy + * of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under + * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS + * OF ANY KIND, either express or implied. See the License for the specific language + * governing permissions and limitations under the License. + ****************************************************************************************/ + +module.exports = async function loadContainer({ + container, + resolveDoneLoading +}) { + expect(window._satellite).not.toBeDefined(); + expect(Boolean(window.__satelliteLoaded)).toBeFalse(); + + // Simulate a container being present before index.js is imported + window._satellite = container; + + expect(Boolean(window.__satelliteLoaded)).toBeFalse(); + const script = document.createElement('script'); + script.src = '/base/dist/engine.js'; // '/base/' is Karma's base URL prefix + script.onload = () => { + expect(Boolean(window.__satelliteLoaded)).toBeTrue(); + resolveDoneLoading(); + }; + script.onerror = (e) => { + return resolveDoneLoading.fail(`Failed to load engine.js: ${e.message}`); + }; + document.body.appendChild(script); +}; diff --git a/src/__integration__/real-containers/load-page-environment-html.js b/src/__integration__/real-containers/load-page-environment-html.js new file mode 100644 index 00000000..af588203 --- /dev/null +++ b/src/__integration__/real-containers/load-page-environment-html.js @@ -0,0 +1,22 @@ +/*************************************************************************************** + * (c) 2025 Adobe. All rights reserved. + * This file is licensed to you under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. You may obtain a copy + * of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under + * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS + * OF ANY KIND, either express or implied. See the License for the specific language + * governing permissions and limitations under the License. + ****************************************************************************************/ + +const path = require('path'); +const fs = require('fs'); + +module.exports = async function loadHtml(page) { + const htmlContent = fs.readFileSync( + path.resolve(__dirname, 'test-page-environment.html'), + 'utf-8' + ); + await page.setContent(htmlContent); +}; diff --git a/src/__integration__/real-containers/sync-container.test.js b/src/__integration__/real-containers/sync-container.test.js new file mode 100644 index 00000000..de757273 --- /dev/null +++ b/src/__integration__/real-containers/sync-container.test.js @@ -0,0 +1,30 @@ +/*************************************************************************************** + * (c) 2025 Adobe. All rights reserved. + * This file is licensed to you under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. You may obtain a copy + * of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under + * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS + * OF ANY KIND, either express or implied. See the License for the specific language + * governing permissions and limitations under the License. + ****************************************************************************************/ + +const libraryBuildPathsFile = require('../../../ci-scripts/library-build-paths.json'); +const loadHtml = require('./load-page-environment-html'); +const { test, expect } = require('@playwright/test'); + +test('load environment HTML and inject script, then assert', async ({ + page +}) => { + await loadHtml(page); + + // Inject the script dynamically (don't navigate away) + await page.addScriptTag({ url: libraryBuildPathsFile.SYNC_CONTAINER }); + + const headerText = await page.textContent('h1'); + expect(headerText).toBe('Testing Script Injection'); + + // Or click the body etc. + await page.click('body'); +}); diff --git a/src/__integration__/real-containers/test-page-environment.html b/src/__integration__/real-containers/test-page-environment.html new file mode 100644 index 00000000..f5356cc7 --- /dev/null +++ b/src/__integration__/real-containers/test-page-environment.html @@ -0,0 +1,7 @@ + + +Playwright Test Page + +

Testing Script Injection

+ + diff --git a/src/__tests__/createDynamicHostResolver.test.js b/src/__tests__/createDynamicHostResolver.test.js index 2ade2f32..4d2537a4 100644 --- a/src/__tests__/createDynamicHostResolver.test.js +++ b/src/__tests__/createDynamicHostResolver.test.js @@ -10,7 +10,9 @@ * governing permissions and limitations under the License. ****************************************************************************************/ -var injectCreateDynamicHostResolver = require('inject-loader!../createDynamicHostResolver'); +var { + injectCreateDynamicHostResolver +} = require('../createDynamicHostResolver'); var createDebugController = require('../createDebugController'); var loggerSpy = jasmine.createSpy('logger'); @@ -36,7 +38,7 @@ describe('createDynamicHostResolver returns a function that when called', functi delete window.dynamicHostResolver; mockWindow = createMockWindowProtocol('https'); createDynamicHostResolver = injectCreateDynamicHostResolver({ - '@adobe/reactor-window': mockWindow + window: mockWindow }); consoleSpy = spyOn(console, 'warn'); debugController = jasmine.createSpyObj('debugController', [ @@ -173,7 +175,7 @@ describe('createDynamicHostResolver returns a function that when called', functi it('and the window protocol is http', function () { var mockWindow = createMockWindowProtocol('http'); createDynamicHostResolver = injectCreateDynamicHostResolver({ - '@adobe/reactor-window': mockWindow + window: mockWindow }); turbineEmbedCode = '//assets.adobedtm.com/lib/dev.js'; dynamicHostResolver = createDynamicHostResolver( @@ -209,7 +211,7 @@ describe('createDynamicHostResolver returns a function that when called', functi it('and the window protocol is http', function () { var mockWindow = createMockWindowProtocol('http'); createDynamicHostResolver = injectCreateDynamicHostResolver({ - '@adobe/reactor-window': mockWindow + window: mockWindow }); turbineEmbedCode = '//assets.adobedtm.com/lib/dev.js'; diff --git a/src/__tests__/createGetDataElementValue.test.js b/src/__tests__/createGetDataElementValue.test.js index 8d5836e6..a17e5194 100644 --- a/src/__tests__/createGetDataElementValue.test.js +++ b/src/__tests__/createGetDataElementValue.test.js @@ -12,18 +12,18 @@ 'use strict'; -var injectCreateGetDataElementValue = require('inject-loader!../createGetDataElementValue'); +var { + injectCreateGetDataElementValue +} = require('../createGetDataElementValue'); +var cleanText = require('../cleanText'); +var dataElementSafe = require('../dataElementSafe'); var createSettingsFileTransformer = require('../createSettingsFileTransformer'); describe('function returned by createGetDataElementValue', function () { + var createGetDataElementValue; var logger; var replaceTokens; var settingsFileTransformer; - var getInjectedCreateGetDataElementValue = function (mocks) { - mocks = mocks || {}; - mocks['./logger'] = logger; - return injectCreateGetDataElementValue(mocks); - }; beforeEach(function () { logger = jasmine.createSpyObj('logger', ['log', 'error']); @@ -31,10 +31,14 @@ describe('function returned by createGetDataElementValue', function () { return settings; }); settingsFileTransformer = jasmine.createSpy('settingsFileTransformer'); + createGetDataElementValue = injectCreateGetDataElementValue({ + logger, + cleanText, + dataElementSafe + }); }); it('returns a data element value using data from settings', function () { - var createGetDataElementValue = getInjectedCreateGetDataElementValue(); var moduleProvider = { getModuleExports: function () { return function (settings) { @@ -68,7 +72,6 @@ describe('function returned by createGetDataElementValue', function () { // DTM-12602 Allows data elements to reference event // data when retrieved within the context of a rule execution it('returns a data element value using data from event', function () { - var createGetDataElementValue = getInjectedCreateGetDataElementValue(); var moduleProvider = { getModuleExports: function () { return function (settings, event) { @@ -101,11 +104,13 @@ describe('function returned by createGetDataElementValue', function () { }); it('stores the data element value if value exists and storageDuration provided', function () { - var dataElementSafe = { + var dataElementSafeMock = { setValue: jasmine.createSpy() }; - var createGetDataElementValue = getInjectedCreateGetDataElementValue({ - './dataElementSafe': dataElementSafe + createGetDataElementValue = injectCreateGetDataElementValue({ + logger, + cleanText, + dataElementSafe: dataElementSafeMock }); var moduleProvider = { getModuleExports: function () { @@ -135,7 +140,7 @@ describe('function returned by createGetDataElementValue', function () { ); getDataElementValue('testDataElement'); - expect(dataElementSafe.setValue).toHaveBeenCalledWith( + expect(dataElementSafeMock.setValue).toHaveBeenCalledWith( 'testDataElement', 'visitor', 'bar' @@ -143,10 +148,12 @@ describe('function returned by createGetDataElementValue', function () { }); it('cleans the value when cleanText = true', function () { - var createGetDataElementValue = getInjectedCreateGetDataElementValue({ - './cleanText': function (value) { + createGetDataElementValue = injectCreateGetDataElementValue({ + logger, + cleanText: function (value) { return 'cleaned:' + value; - } + }, + dataElementSafe }); var moduleProvider = { getModuleExports: function () { @@ -178,10 +185,12 @@ describe('function returned by createGetDataElementValue', function () { }); it('cleans the default value when cleanText = true', function () { - var createGetDataElementValue = getInjectedCreateGetDataElementValue({ - './cleanText': function (value) { + createGetDataElementValue = injectCreateGetDataElementValue({ + logger, + cleanText: function (value) { return 'cleaned:' + value; - } + }, + dataElementSafe }); var moduleProvider = { getModuleExports: function () { @@ -215,7 +224,6 @@ describe('function returned by createGetDataElementValue', function () { 'returns undefined when undefinedVarsReturnEmpty = false and data element ' + 'does not exist', function () { - var createGetDataElementValue = getInjectedCreateGetDataElementValue(); var moduleProvider = {}; var getDataElementDefinition = function () {}; var undefinedVarsReturnEmpty = false; @@ -233,8 +241,10 @@ describe('function returned by createGetDataElementValue', function () { ); it('does not return default value if cached value is present', function () { - var createGetDataElementValue = getInjectedCreateGetDataElementValue({ - './dataElementSafe': { + createGetDataElementValue = injectCreateGetDataElementValue({ + logger, + cleanText, + dataElementSafe: { getValue: function () { return 'cachedValue'; } @@ -272,8 +282,10 @@ describe('function returned by createGetDataElementValue', function () { it( 'returns a cached value if current value is ' + dataElementValue, function () { - var createGetDataElementValue = getInjectedCreateGetDataElementValue({ - './dataElementSafe': { + createGetDataElementValue = injectCreateGetDataElementValue({ + logger, + cleanText, + dataElementSafe: { getValue: function () { return 'cachedValue'; } @@ -310,7 +322,6 @@ describe('function returned by createGetDataElementValue', function () { ); it('returns a default value if value is ' + dataElementValue, function () { - var createGetDataElementValue = getInjectedCreateGetDataElementValue(); var moduleProvider = { getModuleExports: function () { return function () { @@ -347,10 +358,12 @@ describe('function returned by createGetDataElementValue', function () { 'is ' + dataElementValue, function () { - var createGetDataElementValue = getInjectedCreateGetDataElementValue({ - './cleanText': function (value) { + createGetDataElementValue = injectCreateGetDataElementValue({ + logger, + cleanText: function (value) { return 'cleaned:' + value; - } + }, + dataElementSafe }); var moduleProvider = { getModuleExports: function () { @@ -388,7 +401,6 @@ describe('function returned by createGetDataElementValue', function () { dataElementValue + ' and default is undefined', function () { - var createGetDataElementValue = getInjectedCreateGetDataElementValue(); var moduleProvider = { getModuleExports: function () { return function () { @@ -423,7 +435,6 @@ describe('function returned by createGetDataElementValue', function () { it( 'does not return a default value if value is ' + dataElementValue, function () { - var createGetDataElementValue = getInjectedCreateGetDataElementValue(); var moduleProvider = { getModuleExports: function () { return function () { @@ -456,7 +467,6 @@ describe('function returned by createGetDataElementValue', function () { }); it('lowercases the value if forceLowerCase = true', function () { - var createGetDataElementValue = getInjectedCreateGetDataElementValue(); var moduleProvider = { getModuleExports: function () { return function (settings) { @@ -489,7 +499,6 @@ describe('function returned by createGetDataElementValue', function () { }); it('lowercases the default value if forceLowerCase = true', function () { - var createGetDataElementValue = getInjectedCreateGetDataElementValue(); var moduleProvider = { getModuleExports: function () { return function () {}; @@ -519,7 +528,6 @@ describe('function returned by createGetDataElementValue', function () { }); it('replaces tokens in settings object', function () { - var createGetDataElementValue = getInjectedCreateGetDataElementValue(); var moduleProvider = { getModuleExports: function () { return function (settings) { @@ -571,7 +579,6 @@ describe('function returned by createGetDataElementValue', function () { .createSpy('settingsFileTransform') .and.callFake(settingsFileTransformer); - var createGetDataElementValue = getInjectedCreateGetDataElementValue(); var moduleProvider = { getModuleExports: function () { return function (settings) { @@ -655,7 +662,6 @@ describe('function returned by createGetDataElementValue', function () { .createSpy('settingsFileTransform') .and.callFake(settingsFileTransformer); - var createGetDataElementValue = getInjectedCreateGetDataElementValue(); var moduleProvider = { getModuleExports: function () { return function (settings) { @@ -698,7 +704,6 @@ describe('function returned by createGetDataElementValue', function () { describe('error handling', function () { it('logs an error when retrieving data element module exports fails', function () { - var createGetDataElementValue = getInjectedCreateGetDataElementValue(); var moduleProvider = { getModuleExports: function () { throw new Error('noob tried to divide by zero'); @@ -733,7 +738,6 @@ describe('function returned by createGetDataElementValue', function () { }); it('logs an error when executing data element module exports fails', function () { - var createGetDataElementValue = getInjectedCreateGetDataElementValue(); var moduleProvider = { getModuleExports: function () { return function () { @@ -770,7 +774,6 @@ describe('function returned by createGetDataElementValue', function () { }); it('logs an error when the data element module does not export a function', function () { - var createGetDataElementValue = getInjectedCreateGetDataElementValue(); var moduleProvider = { getModuleExports: function () { return {}; diff --git a/src/__tests__/createModuleProvider.test.js b/src/__tests__/createModuleProvider.test.js index 2f150403..e7a5b0c2 100644 --- a/src/__tests__/createModuleProvider.test.js +++ b/src/__tests__/createModuleProvider.test.js @@ -12,10 +12,10 @@ 'use strict'; -var injectCreateModuleProvider = require('inject-loader!../createModuleProvider'); +var { injectCreateModuleProvider } = require('../createModuleProvider'); describe('function returned by createModuleProvider', function () { - var logger; + var loggerMock; var referencePath = 'hello-world/src/foo.js'; var extensionName = 'test-extension'; var name = 'foo'; @@ -26,14 +26,14 @@ describe('function returned by createModuleProvider', function () { var moduleProvider; beforeEach(function () { - logger = jasmine.createSpyObj('logger', ['log', 'error']); + loggerMock = jasmine.createSpyObj('logger', ['log', 'error']); extractModuleExportsSpy = jasmine .createSpy('extractModuleExports') .and.callFake(extractModuleExports); var createModuleProvider = injectCreateModuleProvider({ - './logger': logger, - './extractModuleExports': extractModuleExportsSpy + extractModuleExports: extractModuleExportsSpy, + logger: loggerMock }); moduleProvider = createModuleProvider(); @@ -79,7 +79,7 @@ describe('function returned by createModuleProvider', function () { moduleProvider.hydrateCache(); - var errorMessage = logger.error.calls.mostRecent().args[0]; + var errorMessage = loggerMock.error.calls.mostRecent().args[0]; expect(errorMessage).toStartWith( 'Error initializing module ' + referencePath + diff --git a/src/__tests__/createNotifyMonitors.test.js b/src/__tests__/createNotifyMonitors.test.js index 03721ae7..15871fb0 100644 --- a/src/__tests__/createNotifyMonitors.test.js +++ b/src/__tests__/createNotifyMonitors.test.js @@ -10,23 +10,26 @@ * governing permissions and limitations under the License. ****************************************************************************************/ -var injectCreateNotifyMonitors = require('inject-loader!../createNotifyMonitors'); +var { injectCreateNotifyMonitors } = require('../createNotifyMonitors'); describe('function returned by createNotifyMonitors', function () { - var logger; + var loggerMock; var createNotifyMonitors; beforeEach(function () { - logger = { + loggerMock = { warn: jasmine.createSpy() }; createNotifyMonitors = injectCreateNotifyMonitors({ - './logger': logger + logger: loggerMock }); }); it("doesn't throw errors if monitors aren't defined", function () { + var createNotifyMonitors = injectCreateNotifyMonitors({ + logger: loggerMock + }); var notifyMonitors = createNotifyMonitors({}); expect(function () { @@ -48,14 +51,14 @@ describe('function returned by createNotifyMonitors', function () { notifyMonitors('ruleTriggered', event); expect(monitor.ruleTriggered).toHaveBeenCalledWith(event); - expect(logger.warn).toHaveBeenCalledWith( + expect(loggerMock.warn).toHaveBeenCalledWith( 'The _satellite._monitors API may change at ' + 'any time and should only be used for debugging.' ); // It shouldn't warn again. notifyMonitors('ruleTriggered', event); - expect(logger.warn.calls.count()).toBe(1); + expect(loggerMock.warn.calls.count()).toBe(1); }); it("doesn't throw an error if method on monitor doesn't exist", function () { diff --git a/src/__tests__/createPublicRequire.test.js b/src/__tests__/createPublicRequire.test.js index f76b08bb..fcafbccc 100644 --- a/src/__tests__/createPublicRequire.test.js +++ b/src/__tests__/createPublicRequire.test.js @@ -12,7 +12,7 @@ 'use strict'; -var injectCreatePublicRequire = require('inject-loader!../createPublicRequire'); +var { injectCreatePublicRequire } = require('../createPublicRequire'); describe('function returned by createPublicRequire', function () { it('should return the static core modules', function () { @@ -25,13 +25,15 @@ describe('function returned by createPublicRequire', function () { var windowMock = {}; var createPublicRequire = injectCreatePublicRequire({ - '@adobe/reactor-cookie': cookieMock, - '@adobe/reactor-document': documentMock, - '@adobe/reactor-load-script': loadScriptMock, - '@adobe/reactor-object-assign': objectAssignMock, - '@adobe/reactor-promise': promiseMock, - '@adobe/reactor-query-string': queryStringMock, - '@adobe/reactor-window': windowMock + moduleMap: { + cookie: cookieMock, + document: documentMock, + 'load-script': loadScriptMock, + 'object-assign': objectAssignMock, + promise: promiseMock, + 'query-string': queryStringMock, + window: windowMock + } }); var publicRequire = createPublicRequire(); @@ -50,7 +52,9 @@ describe('function returned by createPublicRequire', function () { it('should call for relative module when relative path is used', function () { var relativeModuleMock = {}; - var createPublicRequire = injectCreatePublicRequire({}); + var createPublicRequire = injectCreatePublicRequire({ + moduleMap: {} + }); var getModuleExportsByRelativePath = jasmine .createSpy() @@ -70,8 +74,10 @@ describe('function returned by createPublicRequire', function () { }); it('should throw error when a module that is neither core nor relative is required', function () { - var createPublicRequire = injectCreatePublicRequire({}); - var publicRequire = createPublicRequire(); + var createPublicRequire = injectCreatePublicRequire({ + moduleMap: {} + }); + var publicRequire = createPublicRequire({}); expect(function () { publicRequire('@adobe/reactor-invalidmodulename'); }).toThrowError(Error); diff --git a/src/__tests__/createReplaceTokens.test.js b/src/__tests__/createReplaceTokens.test.js index 972c9684..d314c37f 100644 --- a/src/__tests__/createReplaceTokens.test.js +++ b/src/__tests__/createReplaceTokens.test.js @@ -11,7 +11,7 @@ ****************************************************************************************/ 'use strict'; -var injectCreateReplaceTokens = require('inject-loader!../createReplaceTokens'); +var { injectCreateReplaceTokens } = require('../createReplaceTokens'); describe('function returned by replaceTokens', function () { var isVar; @@ -30,7 +30,7 @@ describe('function returned by replaceTokens', function () { }; undefinedVarsReturnEmpty = false; createReplaceTokens = injectCreateReplaceTokens({ - './logger': logger + logger }); }); diff --git a/src/__tests__/getNamespacedStorage.test.js b/src/__tests__/getNamespacedStorage.test.js index 913b5c44..a98f63bf 100644 --- a/src/__tests__/getNamespacedStorage.test.js +++ b/src/__tests__/getNamespacedStorage.test.js @@ -12,7 +12,8 @@ 'use strict'; -var injectGetNamespacedStorage = require('inject-loader!../getNamespacedStorage'); +var window = require('@adobe/reactor-window'); +var { injectGetNamespacedStorage } = require('../getNamespacedStorage'); describe('getNamespacedStorage', function () { var createMockWindowUnavailableStorage = function () { @@ -33,7 +34,7 @@ describe('getNamespacedStorage', function () { ['sessionStorage', 'localStorage'].forEach(function (storageType) { describe('getItem', function () { it('returns item', function () { - var getNamespacedStorage = injectGetNamespacedStorage(); + var getNamespacedStorage = injectGetNamespacedStorage({ window }); var storage = getNamespacedStorage(storageType); window[storageType].setItem('com.adobe.reactor.foo', 'something'); @@ -42,9 +43,8 @@ describe('getNamespacedStorage', function () { it('proper error handling if storage is disabled', function () { var mockWindow = createMockWindowUnavailableStorage(); - var getNamespacedStorage = injectGetNamespacedStorage({ - '@adobe/reactor-window': mockWindow + window: mockWindow }); var storage = getNamespacedStorage(storageType); @@ -55,7 +55,7 @@ describe('getNamespacedStorage', function () { describe('setItem', function () { it('sets item', function () { - var getNamespacedStorage = injectGetNamespacedStorage(); + var getNamespacedStorage = injectGetNamespacedStorage({ window }); var storage = getNamespacedStorage(storageType); storage.setItem('foo', 'something'); @@ -66,9 +66,8 @@ describe('getNamespacedStorage', function () { it('proper error handling if storage is disabled', function () { var mockWindow = createMockWindowUnavailableStorage(); - var getNamespacedStorage = injectGetNamespacedStorage({ - '@adobe/reactor-window': mockWindow + window: mockWindow }); var storage = getNamespacedStorage(storageType); diff --git a/src/__tests__/hydrateModuleProvider.test.js b/src/__tests__/hydrateModuleProvider.test.js index 3211ab94..d537cb16 100644 --- a/src/__tests__/hydrateModuleProvider.test.js +++ b/src/__tests__/hydrateModuleProvider.test.js @@ -12,11 +12,19 @@ 'use strict'; -var injectHydrateModuleProvider = require('inject-loader!../hydrateModuleProvider'); +var { injectHydrateModuleProvider } = require('../hydrateModuleProvider'); +var createGetSharedModuleExports = require('../createGetSharedModuleExports'); +var createGetExtensionSettings = require('../createGetExtensionSettings'); +var createGetHostedLibFileUrl = require('../createGetHostedLibFileUrl'); +var resolveRelativePath = require('../resolveRelativePath'); +var createPublicRequire = require('../createPublicRequire'); var createDynamicHostResolver = require('../createDynamicHostResolver'); var createSettingsFileTransformer = require('../createSettingsFileTransformer'); describe('hydrateModuleProvider', function () { + var loggerMock; + var prefixedLoggerMock; + var hydrateModuleProvider; var container; var moduleProvider; var replaceTokens; @@ -26,6 +34,20 @@ describe('hydrateModuleProvider', function () { var decorateWithDynamicHost; beforeEach(function () { + prefixedLoggerMock = {}; + loggerMock = { + createPrefixedLogger: jasmine.createSpy().and.callFake(function () { + return prefixedLoggerMock; + }) + }; + hydrateModuleProvider = injectHydrateModuleProvider({ + createGetSharedModuleExports, + createGetExtensionSettings, + createGetHostedLibFileUrl, + resolveRelativePath, + createPublicRequire, + logger: loggerMock + }); container = { extensions: { 'ext-a': { @@ -74,7 +96,6 @@ describe('hydrateModuleProvider', function () { }); it('registers all modules', function () { - var hydrateModuleProvider = injectHydrateModuleProvider(); var a1Module = function () {}; var a2Module = function () {}; var b1Module = function () {}; @@ -139,8 +160,6 @@ describe('hydrateModuleProvider', function () { }); it('hydrates module cache', function () { - var hydrateModuleProvider = injectHydrateModuleProvider(); - hydrateModuleProvider( container, moduleProvider, @@ -155,21 +174,26 @@ describe('hydrateModuleProvider', function () { }); describe('public require provided to modules', function () { - var publicRequire; - var createPublicRequire; + var publicRequireMock; + var createPublicRequireMock; var getModuleExportsByRelativePath; beforeEach(function () { - publicRequire = function () {}; - createPublicRequire = jasmine + publicRequireMock = function () {}; + createPublicRequireMock = jasmine .createSpy() .and.callFake(function (_getModuleExportsByRelativePath) { getModuleExportsByRelativePath = _getModuleExportsByRelativePath; - return publicRequire; + return publicRequireMock; }); var hydrateModuleProvider = injectHydrateModuleProvider({ - './createPublicRequire': createPublicRequire + createGetSharedModuleExports, + createGetExtensionSettings, + createGetHostedLibFileUrl, + resolveRelativePath, + createPublicRequire: createPublicRequireMock, + logger: loggerMock }); hydrateModuleProvider( @@ -185,7 +209,7 @@ describe('hydrateModuleProvider', function () { it('is the publicRequire returned from createPublicRequire', function () { expect(moduleProvider.registerModule.calls.mostRecent().args[3]).toEqual( - publicRequire + publicRequireMock ); }); @@ -201,44 +225,40 @@ describe('hydrateModuleProvider', function () { describe('turbine object provided to modules', function () { var turbine; - var createGetExtensionSettings; - var getExtensionSettings; - var createGetHostedLibFileUrl; - var getHostedLibFileUrl; - var getSharedModuleExports; - var createGetSharedModuleExports; - var prefixedLogger; - var logger; + var createGetSharedModuleExportsMock; + var getSharedModuleExportsMock; + var createGetExtensionSettingsMock; + var getExtensionSettingsMock; + var createGetHostedLibFileUrlMock; + var getHostedLibFileUrlMock; beforeEach(function () { - getExtensionSettings = function () {}; - createGetExtensionSettings = jasmine + getExtensionSettingsMock = function () {}; + createGetExtensionSettingsMock = jasmine .createSpy() .and.callFake(function () { - return getExtensionSettings; + return getExtensionSettingsMock; }); - getHostedLibFileUrl = function () {}; - createGetHostedLibFileUrl = jasmine.createSpy().and.callFake(function () { - return getHostedLibFileUrl; - }); - getSharedModuleExports = function () {}; - createGetSharedModuleExports = jasmine + getHostedLibFileUrlMock = function () {}; + createGetHostedLibFileUrlMock = jasmine .createSpy() .and.callFake(function () { - return getSharedModuleExports; + return getHostedLibFileUrlMock; + }); + getSharedModuleExportsMock = function () {}; + createGetSharedModuleExportsMock = jasmine + .createSpy() + .and.callFake(function () { + return getSharedModuleExportsMock; }); - prefixedLogger = {}; - logger = { - createPrefixedLogger: jasmine.createSpy().and.callFake(function () { - return prefixedLogger; - }) - }; - var hydrateModuleProvider = injectHydrateModuleProvider({ - './createGetExtensionSettings': createGetExtensionSettings, - './createGetHostedLibFileUrl': createGetHostedLibFileUrl, - './createGetSharedModuleExports': createGetSharedModuleExports, - './logger': logger + hydrateModuleProvider = injectHydrateModuleProvider({ + createGetSharedModuleExports: createGetSharedModuleExportsMock, + createGetExtensionSettings: createGetExtensionSettingsMock, + createGetHostedLibFileUrl: createGetHostedLibFileUrlMock, + resolveRelativePath, + createPublicRequire, + logger: loggerMock }); hydrateModuleProvider( @@ -262,33 +282,35 @@ describe('hydrateModuleProvider', function () { }); it('contains getExtensionSettings', function () { - expect(createGetExtensionSettings).toHaveBeenCalledWith( + expect(createGetExtensionSettingsMock).toHaveBeenCalledWith( replaceTokens, container.extensions['ext-a'].settings ); - expect(turbine.getExtensionSettings).toEqual(getExtensionSettings); + expect(turbine.getExtensionSettings).toEqual(getExtensionSettingsMock); }); it('contains getHostedLibFileUrl', function () { - expect(createGetHostedLibFileUrl).toHaveBeenCalledWith( + expect(createGetHostedLibFileUrlMock).toHaveBeenCalledWith( decorateWithDynamicHost, 'somebaseurl', true ); - expect(turbine.getHostedLibFileUrl).toEqual(getHostedLibFileUrl); + expect(turbine.getHostedLibFileUrl).toEqual(getHostedLibFileUrlMock); }); it('contains getSharedModule', function () { - expect(createGetSharedModuleExports).toHaveBeenCalledWith( + expect(createGetSharedModuleExportsMock).toHaveBeenCalledWith( container.extensions, moduleProvider ); - expect(turbine.getSharedModule).toBe(getSharedModuleExports); + expect(turbine.getSharedModule).toBe(getSharedModuleExportsMock); }); it('contains logger', function () { - expect(logger.createPrefixedLogger).toHaveBeenCalledWith('Extension A'); - expect(turbine.logger).toBe(prefixedLogger); + expect(loggerMock.createPrefixedLogger).toHaveBeenCalledWith( + 'Extension A' + ); + expect(turbine.logger).toBe(prefixedLoggerMock); }); it('contains property information similar to _satellite.property', function () { @@ -324,7 +346,6 @@ describe('hydrateModuleProvider', function () { }); it('when extension.filePaths is missing', function () { - var hydrateModuleProvider = injectHydrateModuleProvider(); var a1Module = function () {}; var extensionA = { modules: { @@ -353,7 +374,6 @@ describe('hydrateModuleProvider', function () { }); it('when extension.filePaths is not an array', function () { - var hydrateModuleProvider = injectHydrateModuleProvider(); var a1Module = function () {}; var extensionA = { modules: { @@ -383,7 +403,6 @@ describe('hydrateModuleProvider', function () { }); it('transforms file paths when extension.filePaths is present', function () { - var hydrateModuleProvider = injectHydrateModuleProvider(); var a1Module = function () {}; var extensionA = { modules: { diff --git a/src/__tests__/hydrateSatelliteObject.test.js b/src/__tests__/hydrateSatelliteObject.test.js index a1078b89..f77d75f0 100644 --- a/src/__tests__/hydrateSatelliteObject.test.js +++ b/src/__tests__/hydrateSatelliteObject.test.js @@ -12,12 +12,14 @@ 'use strict'; -var injectHydrateSatelliteObject = require('inject-loader!../hydrateSatelliteObject'); +var { injectHydrateSatelliteObject } = require('../hydrateSatelliteObject'); +var cookie = require('@adobe/reactor-cookie'); describe('hydrateSatelliteObject', function () { var _satellite; - var container; + var loggerMock; + var hydrateSatelliteObject; beforeEach(function () { _satellite = {}; @@ -42,34 +44,41 @@ describe('hydrateSatelliteObject', function () { stage: 'development' } }; + loggerMock = jasmine.createSpyObj('logger', [ + 'log', + 'info', + 'warn', + 'error', + 'deprecation' + ]); + loggerMock.createPrefixedLogger = jasmine + .createSpy('createPrefixedLogger') + .and.callFake(function () { + return loggerMock; + }); + hydrateSatelliteObject = injectHydrateSatelliteObject({ + cookie, + logger: loggerMock + }); }); it('should add a track function on _satellite', function () { - var logger = { - log: jasmine.createSpy(), - createPrefixedLogger: function () {} - }; - var hydrateSatelliteObject = injectHydrateSatelliteObject({ - './logger': logger - }); hydrateSatelliteObject(_satellite, container); expect(_satellite.track).toEqual(jasmine.any(Function)); // shouldn't throw an error. _satellite.track('checkout'); - expect(logger.log).toHaveBeenCalledWith( + expect(loggerMock.log).toHaveBeenCalledWith( '"checkout" does not match any direct call identifiers.' ); }); it('should add a getVisitorId function on _satellite', function () { - var hydrateSatelliteObject = injectHydrateSatelliteObject(); hydrateSatelliteObject(_satellite, container); expect(_satellite.getVisitorId).toEqual(jasmine.any(Function)); expect(_satellite.getVisitorId()).toBe(null); }); it('should add a property name on _satellite but not settings', function () { - var hydrateSatelliteObject = injectHydrateSatelliteObject(); hydrateSatelliteObject(_satellite, container); expect(_satellite.property.name).toEqual('Test Property'); expect(_satellite.property.id).toEqual('property-id'); @@ -77,7 +86,6 @@ describe('hydrateSatelliteObject', function () { }); it('should add company info on _satellite', function () { - var hydrateSatelliteObject = injectHydrateSatelliteObject(); hydrateSatelliteObject(_satellite, container); expect(_satellite.company.orgId).toEqual( 'CB20F0CC53FCF3AC0A4C98A1@AdobeOrg' @@ -85,37 +93,28 @@ describe('hydrateSatelliteObject', function () { }); it('should add build info on _satellite', function () { - var logger = { - deprecation: jasmine.createSpy('deprecation'), - createPrefixedLogger: function () {} - }; // make sure this isn't messed with when it gets passed Object.defineProperty(container.buildInfo, 'environment', { get: function () { - logger.deprecation('use container.environment.stage instead.'); + loggerMock.deprecation('use container.environment.stage instead.'); return container.environment.stage; } }); - var hydrateSatelliteObject = injectHydrateSatelliteObject({ - './logger': logger - }); hydrateSatelliteObject(_satellite, container); expect(_satellite.buildInfo).toEqual(container.buildInfo); expect(_satellite.buildInfo.environment).toBe('development'); - expect(logger.deprecation).toHaveBeenCalledWith( + expect(loggerMock.deprecation).toHaveBeenCalledWith( 'use container.environment.stage instead.' ); }); it('should add environment info on _satellite', function () { - var hydrateSatelliteObject = injectHydrateSatelliteObject(); hydrateSatelliteObject(_satellite, container); expect(_satellite.environment).toEqual(container.environment); }); it('should add setDebug function on _satellite', function () { var setDebugEnabledSpy = jasmine.createSpy('setDebugEnabled'); - var hydrateSatelliteObject = injectHydrateSatelliteObject(); hydrateSatelliteObject(_satellite, container, setDebugEnabledSpy); _satellite.setDebug(true); @@ -123,21 +122,13 @@ describe('hydrateSatelliteObject', function () { }); it('successfully allows setting, reading, and removing a cookie', function () { - var logger = { - deprecation: jasmine.createSpy(), - createPrefixedLogger: function () {} - }; - var hydrateSatelliteObject = injectHydrateSatelliteObject({ - './logger': logger - }); hydrateSatelliteObject(_satellite, container); - var cookieName = 'cookiename'; var cookieValue = 'cookievalue'; _satellite.setCookie(cookieName, cookieValue, 91); - expect(logger.deprecation).toHaveBeenCalledWith( + expect(loggerMock.deprecation).toHaveBeenCalledWith( '_satellite.setCookie is deprecated. Please use ' + '_satellite.cookie.set("cookiename", "cookievalue", { expires: 91 }).' ); @@ -148,13 +139,13 @@ describe('hydrateSatelliteObject', function () { expect(_satellite.readCookie(cookieName)).toEqual('cookievalue'); - expect(logger.deprecation).toHaveBeenCalledWith( + expect(loggerMock.deprecation).toHaveBeenCalledWith( '_satellite.readCookie is deprecated. Please use _satellite.cookie.get("cookiename").' ); _satellite.removeCookie(cookieName); - expect(logger.deprecation).toHaveBeenCalledWith( + expect(loggerMock.deprecation).toHaveBeenCalledWith( '_satellite.removeCookie is deprecated. Please use _satellite.cookie.remove("cookiename").' ); @@ -162,7 +153,6 @@ describe('hydrateSatelliteObject', function () { }); it('exposes npm cookie package methods', function () { - var hydrateSatelliteObject = injectHydrateSatelliteObject(); hydrateSatelliteObject(_satellite, container); expect(_satellite.cookie.get).toEqual(jasmine.any(Function)); @@ -171,7 +161,6 @@ describe('hydrateSatelliteObject', function () { }); it('exposes a logger', function () { - var hydrateSatelliteObject = injectHydrateSatelliteObject(); hydrateSatelliteObject(_satellite, container); expect(_satellite.logger.log).toEqual(jasmine.any(Function)); @@ -181,22 +170,6 @@ describe('hydrateSatelliteObject', function () { }); it('exposes a notify method', function () { - var loggerMock = jasmine.createSpyObj('logger', [ - 'log', - 'info', - 'warn', - 'error', - 'deprecation' - ]); - loggerMock.createPrefixedLogger = jasmine - .createSpy('createPrefixedLogger') - .and.callFake(function () { - return loggerMock; - }); - var hydrateSatelliteObject = injectHydrateSatelliteObject({ - './logger': loggerMock - }); - hydrateSatelliteObject(_satellite, container); _satellite.notify('log test'); @@ -223,50 +196,7 @@ describe('hydrateSatelliteObject', function () { }); }); - it( - 'logger.deprecation is called for all deprecated methods on the ' + - '_satellite object', - function () { - var loggerMock = jasmine.createSpyObj('logger', [ - 'log', - 'info', - 'warn', - 'error', - 'deprecation' - ]); - loggerMock.createPrefixedLogger = jasmine - .createSpy('createPrefixedLogger') - .and.callFake(function () { - return loggerMock; - }); - var hydrateSatelliteObject = injectHydrateSatelliteObject({ - './logger': loggerMock - }); - - hydrateSatelliteObject(_satellite, container); - - _satellite.setCookie('cookie name', 'cookie value', 1); - expect(loggerMock.deprecation).toHaveBeenCalledWith( - '_satellite.setCookie is deprecated. Please use _satellite.cookie.set(' + - '"cookie name", "cookie value", { expires: 1 }).' - ); - - _satellite.readCookie('cookie name'); - expect(loggerMock.deprecation).toHaveBeenCalledWith( - '_satellite.readCookie is deprecated. Please use ' + - '_satellite.cookie.get("cookie name").' - ); - - _satellite.removeCookie('cookie name'); - expect(loggerMock.deprecation).toHaveBeenCalledWith( - '_satellite.removeCookie is deprecated. Please use ' + - '_satellite.cookie.remove("cookie name").' - ); - } - ); - it('exposes a pageBottom method', function () { - var hydrateSatelliteObject = injectHydrateSatelliteObject(); hydrateSatelliteObject(_satellite, container); expect(_satellite.pageBottom).toEqual(jasmine.any(Function)); // shouldn't throw an error. @@ -274,24 +204,24 @@ describe('hydrateSatelliteObject', function () { }); it('exposes the container', function () { - var logger = { + var loggerMock = { warn: jasmine.createSpy(), - createPrefixedLogger: function () {} + createPrefixedLogger: jasmine.createSpy('cratePrefixedLogger') }; var hydrateSatelliteObject = injectHydrateSatelliteObject({ - './logger': logger + cookie, + logger: loggerMock }); - hydrateSatelliteObject(_satellite, container); spyOn(console, 'warn'); expect(_satellite._container).toBe(container); - expect(logger.warn).toHaveBeenCalledWith( + expect(loggerMock.warn).toHaveBeenCalledWith( '_satellite._container may change at any time and ' + 'should only be used for debugging.' ); // It shouldn't warn again. expect(_satellite._container).toBe(container); - expect(logger.warn.calls.count()).toBe(1); + expect(loggerMock.warn.calls.count()).toBe(1); }); }); diff --git a/src/__tests__/index.test.js b/src/__tests__/index.test.js index 4a9e3b1a..1f5fd682 100644 --- a/src/__tests__/index.test.js +++ b/src/__tests__/index.test.js @@ -12,9 +12,100 @@ 'use strict'; -var injectIndex = require('inject-loader!../index'); +var index = require('../index'); +var injectIndex = index.injectIndex; +var cloneDeep = require('lodash.clonedeep'); +const logger = require('../logger'); +var document = require('@adobe/reactor-document'); +var objectAssign = require('@adobe/reactor-object-assign'); +var createDynamicHostResolver = require('../createDynamicHostResolver'); +var buildRuleExecutionOrder = require('../buildRuleExecutionOrder'); +var createDebugController = require('../createDebugController'); +var createExecuteDelegateModule = require('../createExecuteDelegateModule'); +var createGetDataElementValue = require('../createGetDataElementValue'); +var createGetVar = require('../createGetVar'); +var createIsVar = require('../createIsVar'); +var createModuleProvider = require('../createModuleProvider'); +var createNotifyMonitors = require('../createNotifyMonitors'); +var createReplaceTokens = require('../createReplaceTokens'); +var createSetCustomVar = require('../createSetCustomVar'); +var createAddActionToQueue = require('../rules/createAddActionToQueue'); +var createAddConditionToQueue = require('../rules/createAddConditionToQueue'); +var createAddRuleToQueue = require('../rules/createAddRuleToQueue'); +var createEvaluateConditions = require('../rules/createEvaluateConditions'); +var createExecuteRule = require('../rules/createExecuteRule'); +var createGetModuleDisplayNameByRuleComponent = require('../rules/createGetModuleDisplayNameByRuleComponent'); +var createGetSyntheticEventMeta = require('../rules/createGetSyntheticEventMeta'); +var createInitEventModule = require('../rules/createInitEventModule'); +var createLogActionError = require('../rules/createLogActionError'); +var createLogConditionError = require('../rules/createLogConditionError'); +var createLogConditionNotMet = require('../rules/createLogConditionNotMet'); +var createLogRuleCompleted = require('../rules/createLogRuleCompleted'); +var createRunActions = require('../rules/createRunActions'); +var createTriggerRule = require('../rules/createTriggerRule'); +var getRuleComponentErrorMessage = require('../rules/getRuleComponentErrorMessage'); +var isConditionMet = require('../rules/isConditionMet'); +var initRules = require('../rules/initRules'); +var normalizeRuleComponentError = require('../rules/normalizeRuleComponentError'); +var normalizeSyntheticEvent = require('../rules/normalizeSyntheticEvent'); +var getNamespacedStorage = require('../getNamespacedStorage'); +var hydrateModuleProvider = require('../hydrateModuleProvider'); +var hydrateSatelliteObject = require('../hydrateSatelliteObject'); +var createSettingsFileTransformer = require('../createSettingsFileTransformer'); +var loggerMock; +var satelliteMock; + +function getRealDeps() { + return { + logger, + document, + objectAssign, + createDynamicHostResolver, + buildRuleExecutionOrder, + createDebugController, + createExecuteDelegateModule, + createGetDataElementValue, + createGetVar, + createIsVar, + createModuleProvider, + createNotifyMonitors, + createReplaceTokens, + createSetCustomVar, + createAddActionToQueue, + createAddConditionToQueue, + createAddRuleToQueue, + createEvaluateConditions, + createExecuteRule, + createGetModuleDisplayNameByRuleComponent, + createGetSyntheticEventMeta, + createInitEventModule, + createLogActionError, + createLogConditionError, + createLogConditionNotMet, + createLogRuleCompleted, + createRunActions, + createTriggerRule, + getRuleComponentErrorMessage, + isConditionMet, + initRules, + normalizeRuleComponentError, + normalizeSyntheticEvent, + getNamespacedStorage, + hydrateModuleProvider, + hydrateSatelliteObject, + createSettingsFileTransformer + }; +} +function injectPartialMocks(mockEntries) { + if (mockEntries && Object.keys(mockEntries).length > 0) { + return { + ...getRealDeps(), + ...mockEntries + }; + } -var logger; + return getRealDeps(); +} describe('index', function () { var turbineScriptId = 'turbine-script-id'; @@ -23,7 +114,7 @@ describe('index', function () { 'https://fake.adobeassets.com:443/launch-ENabc123-development.min.js'; beforeEach(function () { - window._satellite = { + satelliteMock = { container: { property: { settings: { @@ -34,11 +125,19 @@ describe('index', function () { company: { dynamicCdnEnabled: true, cdnAllowList: undefined + }, + buildInfo: { + environment: 'development' + }, + environment: { + id: 'environment-id', + stage: 'test' } } }; + window._satellite = satelliteMock; - logger = jasmine.createSpyObj('logger', [ + loggerMock = jasmine.createSpyObj('logger', [ 'log', 'info', 'debug', @@ -81,34 +180,38 @@ describe('index', function () { it('starts up just fine when container.company.cdnAllowList is undefined', function () { expect(function () { - injectIndex({ - './logger': logger - }); + delete satelliteMock.container.company.cdnAllowList; + var decorateSatellite = injectIndex( + injectPartialMocks({ + logger: loggerMock + }) + ); + decorateSatellite(satelliteMock); }).not.toThrow(); - expect(logger.warn).not.toHaveBeenCalledWith( + expect(loggerMock.warn).not.toHaveBeenCalledWith( 'Please review the following error:' ); }); - it('exports the window._satellite object', function () { - var index = injectIndex(); - expect(index).toBe(window._satellite); - }); - it('prevents turbine from executing multiple times', function () { - var createModuleProvider = jasmine.createSpy(); + var createModuleProviderMock = jasmine.createSpy(); + var decorateSatellite = injectIndex( + injectPartialMocks({ + createModuleProvider: createModuleProviderMock, + logger: loggerMock + }) + ); - injectIndex(); - injectIndex({ - './createModuleProvider': createModuleProvider - }); + decorateSatellite(satelliteMock); + decorateSatellite(satelliteMock); - expect(createModuleProvider).not.toHaveBeenCalled(); + expect(createModuleProviderMock).toHaveBeenCalledTimes(1); }); it('deletes the container', function () { - injectIndex(); + var decorateSatellite = injectIndex(getRealDeps()); + decorateSatellite(satelliteMock); expect(window._satellite.container).toBe(undefined); }); @@ -116,21 +219,24 @@ describe('index', function () { 'redefines container.buildInfo.environment to point to ' + 'container.environment.container.stage ', function () { - var container = window._satellite.container; - container.buildInfo = { + satelliteMock.container.buildInfo = { environment: undefined }; - container.environment = { + satelliteMock.container.environment = { id: 'the-environment-id', stage: 'the-environment-stage-in-environment' }; - injectIndex({ - './logger': logger - }); - expect(container.buildInfo.environment).toBe( + var decorateSatellite = injectIndex( + injectPartialMocks({ + logger: loggerMock + }) + ); + decorateSatellite(satelliteMock); + + expect(window._satellite.buildInfo.environment).toBe( 'the-environment-stage-in-environment' ); - expect(logger.deprecation).toHaveBeenCalledWith( + expect(loggerMock.deprecation).toHaveBeenCalledWith( 'container.buildInfo.environment is deprecated.' + 'Please use `container.environment.stage` instead' ); @@ -138,123 +244,149 @@ describe('index', function () { ); it('creates moduleProvider', function () { - var createModuleProvider = jasmine.createSpy(); - injectIndex({ - './createModuleProvider': createModuleProvider - }); + var createModuleProviderMock = jasmine.createSpy(); + var decorateSatellite = injectIndex( + injectPartialMocks({ + createModuleProvider: createModuleProviderMock + }) + ); + decorateSatellite(satelliteMock); - expect(createModuleProvider).toHaveBeenCalled(); + expect(createModuleProviderMock).toHaveBeenCalled(); }); it('creates getDataElementValue', function () { - var createGetDataElementValue = jasmine.createSpy(); - var settingsFileTransformer = jasmine.createSpy('settingsFileTransformer'); + var createGetDataElementValueMock = jasmine.createSpy(); + var settingsFileTransformerMock = jasmine.createSpy( + 'settingsFileTransformer' + ); var createSettingsFileTransformer = function () { - return settingsFileTransformer; + return settingsFileTransformerMock; }; - var moduleProvider = function () {}; - injectIndex({ - './createGetDataElementValue': createGetDataElementValue, - './createModuleProvider': function () { - return moduleProvider; - }, - './createSettingsFileTransformer': createSettingsFileTransformer - }); + var moduleProviderMock = function () {}; + var decorateSatellite = injectIndex( + injectPartialMocks({ + createGetDataElementValue: createGetDataElementValueMock, + createModuleProvider: function () { + return moduleProviderMock; + }, + createSettingsFileTransformer: createSettingsFileTransformer + }) + ); + decorateSatellite(satelliteMock); - expect(createGetDataElementValue).toHaveBeenCalledWith( - moduleProvider, + expect(createGetDataElementValueMock).toHaveBeenCalledWith( + moduleProviderMock, jasmine.any(Function), jasmine.any(Function), true, - settingsFileTransformer + settingsFileTransformerMock ); }); it('creates setCustomVar', function () { - var createSetCustomVar = jasmine.createSpy(); - injectIndex({ - './createSetCustomVar': createSetCustomVar - }); + var createSetCustomVarMock = jasmine.createSpy(); + var decorateSatellite = injectIndex( + injectPartialMocks({ + createSetCustomVar: createSetCustomVarMock, + logger: loggerMock + }) + ); + decorateSatellite(satelliteMock); - expect(createSetCustomVar).toHaveBeenCalledWith(jasmine.any(Object)); + expect(createSetCustomVarMock).toHaveBeenCalledWith(jasmine.any(Object)); }); it('creates isVar', function () { - var createIsVar = jasmine.createSpy(); - injectIndex({ - './createIsVar': createIsVar - }); + var createIsVarMock = jasmine.createSpy(); - expect(createIsVar).toHaveBeenCalledWith( + var decorateSatellite = injectIndex( + injectPartialMocks({ + createIsVar: createIsVarMock, + logger: loggerMock + }) + ); + decorateSatellite(satelliteMock); + + expect(createIsVarMock).toHaveBeenCalledWith( jasmine.any(Object), jasmine.any(Function) ); }); it('creates getVar', function () { - var createGetVar = jasmine.createSpy(); - var getDataElementValue = function () {}; - injectIndex({ - './createGetVar': createGetVar, - './createGetDataElementValue': function () { - return getDataElementValue; - } - }); + var createGetVarMock = jasmine.createSpy(); + var getDataElementValueMock = function () {}; + var decorateSatellite = injectIndex( + injectPartialMocks({ + createGetVar: createGetVarMock, + createGetDataElementValue: function () { + return getDataElementValueMock; + }, + logger: loggerMock + }) + ); - expect(createGetVar).toHaveBeenCalledWith( + decorateSatellite(satelliteMock); + + expect(createGetVarMock).toHaveBeenCalledWith( jasmine.any(Object), jasmine.any(Function), - getDataElementValue + getDataElementValueMock ); }); it('creates replaceTokens', function () { - var createReplaceTokens = jasmine.createSpy(); - var isVar = function () {}; - var getVar = function () {}; - injectIndex({ - './createReplaceTokens': createReplaceTokens, - './createIsVar': function () { - return isVar; - }, - './createGetVar': function () { - return getVar; - } - }); - - expect(createReplaceTokens).toHaveBeenCalledWith(isVar, getVar, true); - }); - - it('creates namespaced storage', function () { - var getNamespacedStorage = jasmine.createSpy().and.returnValue({ - getItem: function () {} - }); - injectIndex({ - './getNamespacedStorage': getNamespacedStorage - }); + var createReplaceTokensMock = jasmine.createSpy(); + var isVarMock = function () {}; + var getVarMock = function () {}; + var decorateSatellite = injectIndex( + injectPartialMocks({ + createReplaceTokens: createReplaceTokensMock, + createIsVar: function () { + return isVarMock; + }, + createGetVar: function () { + return getVarMock; + }, + logger: loggerMock + }) + ); + decorateSatellite(satelliteMock); - expect(getNamespacedStorage).toHaveBeenCalledWith('localStorage'); + expect(createReplaceTokensMock).toHaveBeenCalledWith( + isVarMock, + getVarMock, + true + ); }); it('creates namespaced storage', function () { - var getNamespacedStorage = jasmine.createSpy().and.returnValue({ + var getNamespacedStorageMock = jasmine.createSpy().and.returnValue({ getItem: function () {} }); - injectIndex({ - './getNamespacedStorage': getNamespacedStorage - }); + var decorateSatellite = injectIndex( + injectPartialMocks({ + getNamespacedStorage: getNamespacedStorageMock, + logger: loggerMock + }) + ); + decorateSatellite(satelliteMock); - expect(getNamespacedStorage).toHaveBeenCalledWith('localStorage'); + expect(getNamespacedStorageMock).toHaveBeenCalledWith('localStorage'); }); it("sets logger output enabled when local storage item is 'true'", function () { window.localStorage.setItem('com.adobe.reactor.debug', true); - injectIndex({ - './logger': logger - }); + var decorateSatellite = injectIndex( + injectPartialMocks({ + logger: loggerMock + }) + ); + decorateSatellite(satelliteMock); - expect(logger.outputEnabled).toBe(true); + expect(loggerMock.outputEnabled).toBe(true); }); it( @@ -263,140 +395,192 @@ describe('index', function () { function () { window.localStorage.setItem('com.adobe.reactor.debug', false); - injectIndex({ - './logger': logger - }); + var decorateSatellite = injectIndex( + injectPartialMocks({ + logger: loggerMock + }) + ); + decorateSatellite(satelliteMock); - expect(logger.outputEnabled).toBe(false); + expect(loggerMock.outputEnabled).toBe(false); } ); it('hydrates satellite object', function () { - var container = window._satellite.container; - var hydrateSatelliteObject = jasmine.createSpy(); - var getVar = function () {}; - var setCustomVar = function () {}; - injectIndex({ - './hydrateSatelliteObject': hydrateSatelliteObject, - './createGetVar': function () { - return getVar; - }, - './createSetCustomVar': function () { - return setCustomVar; - } - }); + var hydrateSatelliteObjectMock = jasmine.createSpy(); + var getVarMock = function () {}; + var setCustomVarMock = function () {}; + var decorateSatellite = injectIndex( + injectPartialMocks({ + hydrateSatelliteObject: hydrateSatelliteObjectMock, + createGetVar: function () { + return getVarMock; + }, + createSetCustomVar: function () { + return setCustomVarMock; + }, + logger: loggerMock + }) + ); - expect(hydrateSatelliteObject).toHaveBeenCalledWith( - window._satellite, - container, + const satelliteWithoutContainerMock = cloneDeep(satelliteMock); + const satelliteContainerMock = cloneDeep(satelliteMock.container); + delete satelliteWithoutContainerMock.container; + decorateSatellite(satelliteMock); + + expect(hydrateSatelliteObjectMock).toHaveBeenCalledWith( + satelliteWithoutContainerMock, + jasmine.objectContaining({ + property: satelliteContainerMock.property, + company: satelliteContainerMock.company, + buildInfo: { + environment: satelliteContainerMock.environment.stage + }, + environment: satelliteContainerMock.environment + }), jasmine.any(Function), - getVar, - setCustomVar + getVarMock, + setCustomVarMock ); }); it('hydrates module provider', function () { - var container = window._satellite.container; - var hydrateModuleProvider = jasmine.createSpy(); + var hydrateModuleProviderMock = jasmine.createSpy(); var moduleProvider = { type: 'moduleProvider' }; var debugController = { type: 'debugController' }; - var replaceTokens = jasmine.createSpy('replaceTokens'); - var getDataElementValue = jasmine.createSpy('getDataElementValue'); - var settingsFileTransformer = jasmine.createSpy('settingsFileTransformer'); - var decorateWithDynamicHost = jasmine.createSpy('decorateWithDynamicHost'); - injectIndex({ - './hydrateModuleProvider': hydrateModuleProvider, - './createModuleProvider': function () { - return moduleProvider; - }, - './createDebugController': function () { - return debugController; - }, - './createReplaceTokens': function () { - return replaceTokens; - }, - './createGetDataElementValue': function () { - return getDataElementValue; - }, - './createDynamicHostResolver': function () { - return { - decorateWithDynamicHost: decorateWithDynamicHost - }; - }, - './createSettingsFileTransformer': function () { - return settingsFileTransformer; - } - }); - - expect(hydrateModuleProvider).toHaveBeenCalledWith( - container, + var replaceTokensMock = jasmine.createSpy('replaceTokens'); + var getDataElementValueMock = jasmine.createSpy('getDataElementValue'); + var settingsFileTransformerMock = jasmine.createSpy( + 'settingsFileTransformer' + ); + var decorateWithDynamicHostMock = jasmine.createSpy( + 'decorateWithDynamicHost' + ); + const satelliteContainerMock = cloneDeep(satelliteMock.container); + var decorateSatellite = injectIndex( + injectPartialMocks({ + hydrateModuleProvider: hydrateModuleProviderMock, + createModuleProvider: function () { + return moduleProvider; + }, + createDebugController: function () { + return debugController; + }, + createReplaceTokens: function () { + return replaceTokensMock; + }, + createGetDataElementValue: function () { + return getDataElementValueMock; + }, + createDynamicHostResolver: function () { + return { + decorateWithDynamicHost: decorateWithDynamicHostMock + }; + }, + createSettingsFileTransformer: function () { + return settingsFileTransformerMock; + }, + logger: loggerMock + }) + ); + decorateSatellite(satelliteMock); + + expect(hydrateModuleProviderMock).toHaveBeenCalledWith( + jasmine.objectContaining({ + property: satelliteContainerMock.property, + company: satelliteContainerMock.company, + buildInfo: { + environment: satelliteContainerMock.environment.stage + }, + environment: satelliteContainerMock.environment + }), moduleProvider, debugController, - replaceTokens, - getDataElementValue, - settingsFileTransformer, - decorateWithDynamicHost + replaceTokensMock, + getDataElementValueMock, + settingsFileTransformerMock, + decorateWithDynamicHostMock ); }); it('initializes rules', function () { var rules = []; - var initRules = jasmine.createSpy(); - var buildRuleExecutionOrder = function () {}; - var initEventModule = function () {}; - injectIndex({ - './rules/initRules': initRules, - './buildRuleExecutionOrder': buildRuleExecutionOrder, - './rules/createInitEventModule': function () { - return initEventModule; - } - }); + var initRulesMock = jasmine.createSpy(); + var buildRuleExecutionOrderMock = function () {}; + var initEventModuleMock = function () {}; + var decorateSatellite = injectIndex( + injectPartialMocks({ + initRules: initRulesMock, + buildRuleExecutionOrder: buildRuleExecutionOrderMock, + createInitEventModule: function () { + return initEventModuleMock; + }, + logger: loggerMock + }) + ); + decorateSatellite(satelliteMock); - expect(initRules).toHaveBeenCalledWith( - buildRuleExecutionOrder, + expect(initRulesMock).toHaveBeenCalledWith( + buildRuleExecutionOrderMock, rules, - initEventModule + initEventModuleMock ); }); it("provides an empty array for rules when container doesn't have rules", function () { - delete window._satellite.container.rules; + delete satelliteMock.container.rules; var rules; - injectIndex({ - './rules/initRules': function (_satellite, _rules) { - rules = _rules; - } - }); + + var decorateSatellite = injectIndex( + injectPartialMocks({ + initRules: function (_satellite, _rules) { + rules = _rules; + }, + logger: loggerMock + }) + ); + decorateSatellite(satelliteMock); expect(rules).toEqual([]); }); describe('getDataElementDefinition', function () { it('returns data elements from container', function () { - var dataElementDefinition = {}; - window._satellite.container.dataElements = { + var dataElementDefinition = { + name: 'foo', + value: 'bar' + }; + satelliteMock.container.dataElements = { foo: dataElementDefinition }; var getDataElementDefinition; - injectIndex({ - './createIsVar': function (customVars, _getDataElementDefinition) { - getDataElementDefinition = _getDataElementDefinition; - return function () {}; - } - }); + var decorateSatellite = injectIndex( + injectPartialMocks({ + createIsVar: function (customVars, _getDataElementDefinition) { + getDataElementDefinition = _getDataElementDefinition; + return function () {}; + }, + logger: loggerMock + }) + ); + decorateSatellite(satelliteMock); - expect(getDataElementDefinition('foo')).toBe(dataElementDefinition); + expect(getDataElementDefinition('foo')).toEqual(dataElementDefinition); }); it("doesn't throw an error when container doesn't have data elements", function () { - delete window._satellite.container.dataElements; + delete satelliteMock.container.dataElements; var getDataElementDefinition; - injectIndex({ - './createIsVar': function (customVars, _getDataElementDefinition) { - getDataElementDefinition = _getDataElementDefinition; - return function () {}; - } - }); + var decorateSatellite = injectIndex( + injectPartialMocks({ + createIsVar: function (customVars, _getDataElementDefinition) { + getDataElementDefinition = _getDataElementDefinition; + return function () {}; + }, + logger: loggerMock + }) + ); + decorateSatellite(satelliteMock); expect(getDataElementDefinition('foo')).toBe(undefined); }); @@ -405,15 +589,23 @@ describe('index', function () { describe('setDebugOutputEnabled', function () { it('sets localStorage item', function () { var setOutputDebugEnabled; - injectIndex({ - './hydrateSatelliteObject': function ( - _satellite, - container, - _setOutputDebugEnabled - ) { - setOutputDebugEnabled = _setOutputDebugEnabled; - } - }); + var decorateSatellite = injectIndex( + injectPartialMocks({ + hydrateSatelliteObject: function ( + _satellite, + container, + _setOutputDebugEnabled + ) { + setOutputDebugEnabled = _setOutputDebugEnabled; + }, + logger: loggerMock + }) + ); + decorateSatellite(satelliteMock); + + expect( + window.localStorage.getItem('com.adobe.reactor.debug') + ).toBeFalsy(); setOutputDebugEnabled(true); @@ -445,21 +637,24 @@ describe('index', function () { describe('isDynamicEnforced=true', function () { beforeEach(function () { - window._satellite.container.company.isDynamicEnforced = true; + satelliteMock.container.company.isDynamicEnforced = true; }); it('and the approved hosts list is empty', function () { - window._satellite.container.company.cdnAllowList = []; + satelliteMock.container.company.cdnAllowList = []; expect(function () { - injectIndex({ - './logger': logger - }); + var decorateSatellite = injectIndex( + injectPartialMocks({ + logger: loggerMock + }) + ); + decorateSatellite(satelliteMock); }).toThrowError( 'Unable to find the Library Embed Code for Dynamic Host Resolution.' ); - expect(logger.warn).toHaveBeenCalledOnceWith( + expect(loggerMock.warn).toHaveBeenCalledOnceWith( 'Please review the following error:' ); }); @@ -469,42 +664,48 @@ describe('index', function () { describe('there is a proper turbineEmbedCode', function () { describe('isDynamicEnforced=true', function () { beforeEach(function () { - window._satellite.container.company.isDynamicEnforced = true; + satelliteMock.container.company.isDynamicEnforced = true; }); it('and the approved hosts list is empty', function () { - window._satellite.container.company.cdnAllowList = []; + satelliteMock.container.company.cdnAllowList = []; expect(function () { - injectIndex({ - './logger': logger - }); + var decorateSatellite = injectIndex( + injectPartialMocks({ + logger: loggerMock + }) + ); + decorateSatellite(satelliteMock); }).toThrowError( 'This library is not authorized for this domain. ' + 'Please contact your CSM for more information.' ); - expect(logger.warn).toHaveBeenCalledOnceWith( + expect(loggerMock.warn).toHaveBeenCalledOnceWith( 'Please review the following error:' ); }); it('and the turbine embed code is not in the list of approved hosts', function () { - window._satellite.container.company.cdnAllowList = [ + satelliteMock.container.company.cdnAllowList = [ 'first.domain.com', 'second.domain.com' ]; expect(function () { - injectIndex({ - './logger': logger - }); + var decorateSatellite = injectIndex( + injectPartialMocks({ + logger: loggerMock + }) + ); + decorateSatellite(satelliteMock); }).toThrowError( 'This library is not authorized for this domain. ' + 'Please contact your CSM for more information.' ); - expect(logger.warn).toHaveBeenCalledOnceWith( + expect(loggerMock.warn).toHaveBeenCalledOnceWith( 'Please review the following error:' ); }); diff --git a/src/__tests__/logger.test.js b/src/__tests__/logger.test.js index 2a68d470..8d934add 100644 --- a/src/__tests__/logger.test.js +++ b/src/__tests__/logger.test.js @@ -104,21 +104,197 @@ describe('logger', function () { expect(logger.outputEnabled).toBe(false); }); - it('logs deprecations to the console when logger.outputEnabled=true', function () { - var message = '_satellite.deprecatedFeature is officially deprecated'; - logger.outputEnabled = true; - logger.deprecation(message); + describe('logger.deprecation', function () { + it('logs deprecations to the console when logger.outputEnabled=true', function () { + var message = '_satellite.deprecatedFeature is officially deprecated'; + logger.outputEnabled = true; + logger.deprecation(message); - expect(window.console.warn).toHaveBeenCalledWith(launchPrefix, message); - expect(logger.outputEnabled).toBeTrue(); - }); + expect(window.console.warn).toHaveBeenCalledWith(launchPrefix, message); + expect(logger.outputEnabled).toBeTrue(); + }); - it('logs deprecations to the console when logger.outputEnabled=false', function () { - var message = '_satellite.deprecatedFeature is officially deprecated'; - logger.outputEnabled = false; - logger.deprecation(message); + it('logs deprecations to the console when logger.outputEnabled=false', function () { + var message = '_satellite.deprecatedFeature is officially deprecated'; + logger.outputEnabled = false; + logger.deprecation(message); + + expect(window.console.warn).toHaveBeenCalledWith(launchPrefix, message); + expect(logger.outputEnabled).toBeFalse(); + }); + + it('always logs deprecations when outputEnabled is true (no deduplication)', function () { + var message = '_satellite.someDeprecatedThing'; + logger.outputEnabled = true; + + logger.deprecation(message); + logger.deprecation(message); + + expect(window.console.warn.calls.count()).toBe(2); + expect(window.console.warn.calls.argsFor(0)).toEqual([ + launchPrefix, + message + ]); + expect(window.console.warn.calls.argsFor(1)).toEqual([ + launchPrefix, + message + ]); + }); + + it('logs deprecation only once when outputEnabled is false, then suppresses', function () { + var message = '_satellite.anotherDeprecatedThing'; + logger.outputEnabled = false; + + logger.deprecation(message); // should log + logger.deprecation(message); // should be suppressed + + expect(window.console.warn.calls.count()).toBe(1); + expect(window.console.warn).toHaveBeenCalledWith(launchPrefix, message); + }); + + it('evicts oldest deprecation messages when deduplication cache is full', function () { + logger.outputEnabled = false; + + var total = 105; // Exceed cache limit (default 100) + var oldMessage = '_satellite.oldDeprecatedThing'; + + // Fill cache with unique messages + for (var i = 0; i < total; i++) { + logger.deprecation('_satellite.deprecated' + i); + } + + // Cache should evict oldest (index 0) + logger.deprecation(oldMessage); // first time -> should log + logger.deprecation(oldMessage); // second time -> should be suppressed + + expect(window.console.warn).toHaveBeenCalledWith( + launchPrefix, + oldMessage + ); + expect(window.console.warn.calls.count()).toBe(total + 1); // 105 unique + 1 old message + }); + + it('evicts the oldest deprecation message when deduplication cache exceeds limit', function () { + logger.outputEnabled = false; + + var max = 100; // Assuming MAX_DEPRECATION_CACHE_SIZE = 100 + var oldestMessage = '_satellite.oldestMessage'; + + // Log the oldest message first + logger.deprecation(oldestMessage); + + // Log (max) other unique messages to fill the cache + for (var i = 0; i < max; i++) { + logger.deprecation('_satellite.newMessage' + i); + } + + // At this point, the oldestMessage should have been evicted (FIFO policy) + // because we logged (max + 1) unique messages and the cache size is capped at 100 + + // Now log oldestMessage again — it should go through again (was evicted) + logger.deprecation(oldestMessage); + + // Total expected: + // 1st call to oldestMessage logs + // 100 new unique messages log + // 2nd call to oldestMessage logs again (after eviction) + expect(window.console.warn.calls.count()).toBe(max + 2); + + // Confirm that oldestMessage was logged *twice* + const callsWithOldest = window.console.warn.calls + .all() + .filter((call) => call.args[1] === oldestMessage); + expect(callsWithOldest.length).toBe(2); + }); + + it('coerces non-string deprecation messages and deduplicates based on string form', function () { + logger.outputEnabled = false; + + var nonStringMessage = { toString: () => 'custom-toString' }; - expect(window.console.warn).toHaveBeenCalledWith(launchPrefix, message); - expect(logger.outputEnabled).toBeFalse(); + logger.deprecation(nonStringMessage); // should log + logger.deprecation(nonStringMessage); // should be suppressed + + expect(window.console.warn.calls.count()).toBe(1); + expect(window.console.warn).toHaveBeenCalledWith( + launchPrefix, + jasmine.stringMatching('custom-toString') + ); + }); + + it('preserves outputEnabled state after logging with it temporarily set to true', function () { + var message = '_satellite.deprecatedPreserve'; + + logger.outputEnabled = false; + logger.deprecation(message); + + expect(logger.outputEnabled).toBeFalse(); // Make sure it didn’t flip to true + }); + + it( + 'flushes the deprecation deduplication buffer when outputEnabled is set ' + + 'to true, allowing repeated messages to log again', + function () { + var msg1 = '_satellite.deprecatedFeature1'; + var msg2 = '_satellite.deprecatedFeature2'; + + // Start with output disabled: deduplication is active. + logger.outputEnabled = false; + + // Log two distinct messages. Both should be logged (first-time). + logger.deprecation(msg1); + logger.deprecation(msg2); + + // Log duplicates of the same messages. These should be suppressed due to deduplication. + logger.deprecation(msg1); + logger.deprecation(msg2); + + // Only the first occurrences should have caused console.warn calls. + expect(window.console.warn.calls.count()).toBe(2); + + // Enable output: this action should flush the deduplication buffer internally. + logger.outputEnabled = true; + + // Disable output again to reactivate deduplication. + logger.outputEnabled = false; + + // Now log the same messages again. + // Since the buffer was cleared on enabling output, + // these should log again (not be suppressed). + logger.deprecation(msg1); + logger.deprecation(msg2); + + // Total console.warn calls should be 4: + // - 2 from first calls (before buffer flush) + // - 2 from calls after buffer flush (duplicates allowed again) + expect(window.console.warn.calls.count()).toBe(4); + } + ); }); + + it( + 'does not suppress duplicate log calls for info, warn, error, log, ' + + 'and debug when outputEnabled is true', + function () { + logger.outputEnabled = true; + + var message = 'Repeated message'; + var methods = ['info', 'warn', 'error', 'log', 'debug']; + + methods.forEach(function (methodName) { + var spy = window.console[methodName]; + spy.calls.reset(); + + logger[methodName](message); + logger[methodName](message); + + expect(spy.calls.count()).toBe( + 2, + methodName + ' should not suppress duplicate calls' + ); + expect(spy.calls.argsFor(0)).toEqual([launchPrefix, message]); + expect(spy.calls.argsFor(1)).toEqual([launchPrefix, message]); + }); + } + ); }); diff --git a/src/__tests__/production-exports.integrity.test.js b/src/__tests__/production-exports.integrity.test.js new file mode 100644 index 00000000..084ab6b5 --- /dev/null +++ b/src/__tests__/production-exports.integrity.test.js @@ -0,0 +1,97 @@ +/*************************************************************************************** + * (c) 2025 Adobe. All rights reserved. + * This file is licensed to you under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. You may obtain a copy + * of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under + * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS + * OF ANY KIND, either express or implied. See the License for the specific language + * governing permissions and limitations under the License. + ****************************************************************************************/ + +describe( + 'production integrity checks verify default exports contain' + + 'the dependencies these injectable modules require', + function () { + describe('createDynamicHostResolver', function () { + it('should load module.exports without throwing', () => { + expect(() => { + require('../../src/createDynamicHostResolver'); + }).not.toThrow(); + }); + }); + + describe('createGetDataElementValue', function () { + it('should load module.exports without throwing', () => { + expect(() => { + require('../../src/createGetDataElementValue'); + }).not.toThrow(); + }); + }); + + describe('createModuleProvider', function () { + it('should load module.exports without throwing', () => { + expect(() => { + require('../../src/createModuleProvider'); + }).not.toThrow(); + }); + }); + + describe('createNotifyMonitors', function () { + it('should load module.exports without throwing', () => { + expect(() => { + require('../../src/createNotifyMonitors'); + }).not.toThrow(); + }); + }); + + describe('createPublicRequire', function () { + it('should load module.exports without throwing', () => { + expect(() => { + require('../../src/createPublicRequire'); + }).not.toThrow(); + }); + }); + + describe('createReplaceTokens', function () { + it('should load module.exports without throwing', () => { + expect(() => { + require('../../src/createReplaceTokens'); + }).not.toThrow(); + }); + }); + + describe('getNamespacedStorage', function () { + it('should load module.exports without throwing', () => { + expect(() => { + require('../../src/getNamespacedStorage'); + }).not.toThrow(); + }); + }); + + describe('hydrateModuleProvider', function () { + it('should load module.exports without throwing', () => { + expect(() => { + require('../../src/hydrateModuleProvider'); + }).not.toThrow(); + }); + }); + + describe('hydrateSatelliteObject', function () { + it('should load module.exports without throwing', () => { + expect(() => { + require('../../src/hydrateSatelliteObject'); + }).not.toThrow(); + }); + }); + + describe('normalizeSyntheticEvent', function () { + it('should load module.exports without throwing', () => { + expect(() => { + require('../../src/rules/normalizeSyntheticEvent'); + }).not.toThrow(); + }); + }); + } +); diff --git a/src/createDynamicHostResolver.js b/src/createDynamicHostResolver.js index 100f47e8..0c0f744a 100644 --- a/src/createDynamicHostResolver.js +++ b/src/createDynamicHostResolver.js @@ -10,129 +10,145 @@ * governing permissions and limitations under the License. ****************************************************************************************/ -var window = require('@adobe/reactor-window'); - -module.exports = function ( - turbineEmbedCode, - dynamicCdnEnabled, - cdnAllowList, - debugController -) { - // A missing list means that we are not trying to dynamic replace (archives, - // sftp, no premium CDN option enabled on the company). - // even an empty list is flagging to us that we're trying to enforce dynamic - var isDynamicEnforced = Boolean( - dynamicCdnEnabled && Array.isArray(cdnAllowList) - ); - var shouldAugment = Boolean(isDynamicEnforced && turbineEmbedCode); - - // using document.createElement('a') because IE10/11 doesn't support new URL() - var turbineUrl = document.createElement('a'); - if (isDynamicEnforced) { - var throwUnavailableEmbedCode = function () { - var missingEmbedCodeError = new Error( - 'Unable to find the Library Embed Code for Dynamic Host Resolution.' - ); - missingEmbedCodeError.code = 'dynamic_host_resolver_constructor_error'; - throw missingEmbedCodeError; - }; - if (turbineEmbedCode) { - if (!/^((https?:)?\/\/).+/.test(turbineEmbedCode)) { +var validateInjectedParams = require('./helpers/validate-injected-params'); + +function injectCreateDynamicHostResolver({ window }) { + return function createDynamicHostResolver( + turbineEmbedCode, + dynamicCdnEnabled, + cdnAllowList, + debugController + ) { + // A missing list means that we are not trying to dynamic replace (archives, + // sftp, no premium CDN option enabled on the company). + // even an empty list is flagging to us that we're trying to enforce dynamic + var isDynamicEnforced = Boolean( + dynamicCdnEnabled && Array.isArray(cdnAllowList) + ); + var shouldAugment = Boolean(isDynamicEnforced && turbineEmbedCode); + + // using document.createElement('a') because IE10/11 doesn't support new URL() + var turbineUrl = document.createElement('a'); + if (isDynamicEnforced) { + var throwUnavailableEmbedCode = function () { + var missingEmbedCodeError = new Error( + 'Unable to find the Library Embed Code for Dynamic Host Resolution.' + ); + missingEmbedCodeError.code = 'dynamic_host_resolver_constructor_error'; + throw missingEmbedCodeError; + }; + if (turbineEmbedCode) { + if (!/^((https?:)?\/\/).+/.test(turbineEmbedCode)) { + throwUnavailableEmbedCode(); + } + if (/^\/\/.+/.test(turbineEmbedCode)) { + // for IE 10, you must throw on the protocol + turbineUrl.href = window.location.protocol + turbineEmbedCode; + } else { + turbineUrl.href = turbineEmbedCode; + } + } + + // check URL construction + if (!turbineUrl.hostname) { throwUnavailableEmbedCode(); } - if (/^\/\/.+/.test(turbineEmbedCode)) { - // for IE 10, you must throw on the protocol - turbineUrl.href = window.location.protocol + turbineEmbedCode; - } else { - turbineUrl.href = turbineEmbedCode; + // is this within the allowed list of hosts? + if (cdnAllowList.indexOf(turbineUrl.hostname) === -1) { + var dynamicDeniedError = new Error( + 'This library is not authorized for this domain. ' + + 'Please contact your CSM for more information.' + ); + dynamicDeniedError.code = 'dynamic_host_not_allowed'; + throw dynamicDeniedError; } } - // check URL construction - if (!turbineUrl.hostname) { - throwUnavailableEmbedCode(); - } - // is this within the allowed list of hosts? - if (cdnAllowList.indexOf(turbineUrl.hostname) === -1) { - var dynamicDeniedError = new Error( - 'This library is not authorized for this domain. ' + - 'Please contact your CSM for more information.' - ); - dynamicDeniedError.code = 'dynamic_host_not_allowed'; - throw dynamicDeniedError; - } - } - - /** - * Returns the host of the Turbine embed code, or an empty string if Dynamic Host - * is not enabled. - * @returns {string} - */ - var memoizedHostResult; - var getTurbineHost = function () { - if (memoizedHostResult != null) { + /** + * Returns the host of the Turbine embed code, or an empty string if Dynamic Host + * is not enabled. + * @returns {string} + */ + var memoizedHostResult; + var getTurbineHost = function () { + if (memoizedHostResult != null) { + return memoizedHostResult; + } + + if (shouldAugment) { + // be sure we always force https to Adobe managed domains. + // IE 10/11 returns the :443 protocol when modern browsers don't, so this replacement + // is bringing every browser in line with the same return value + var sanitizedHost = turbineUrl.host; + if (/:80$/.test(sanitizedHost)) { + sanitizedHost = sanitizedHost.replace(':80', ''); + } else if (/:80\/$/.test(sanitizedHost)) { + sanitizedHost = sanitizedHost.replace(':80/', ''); + } else if (/:443$/.test(sanitizedHost)) { + sanitizedHost = sanitizedHost.replace(':443', ''); + } else if (/:443\/$/.test(sanitizedHost)) { + sanitizedHost = sanitizedHost.replace(':443/', ''); + } + + memoizedHostResult = turbineUrl.protocol + '//' + sanitizedHost; + } else { + memoizedHostResult = ''; + } + return memoizedHostResult; - } + }; + + /** + * Returns a url decorated with the host of the Turbine embed code. If Dynamic host + * is disabled, the original sourceUrl is returned unmodified. + * @param sourceUrl + * @returns {string|*} + */ + var decorateWithDynamicHost = function (sourceUrl) { + if (shouldAugment && typeof sourceUrl === 'string') { + var urlParts = [ + getTurbineHost(), + sourceUrl.charAt(0) === '/' ? sourceUrl.slice(1) : sourceUrl + ]; - if (shouldAugment) { - // be sure we always force https to Adobe managed domains. - // IE 10/11 returns the :443 protocol when modern browsers don't, so this replacement - // is bringing every browser in line with the same return value - var sanitizedHost = turbineUrl.host; - if (/:80$/.test(sanitizedHost)) { - sanitizedHost = sanitizedHost.replace(':80', ''); - } else if (/:80\/$/.test(sanitizedHost)) { - sanitizedHost = sanitizedHost.replace(':80/', ''); - } else if (/:443$/.test(sanitizedHost)) { - sanitizedHost = sanitizedHost.replace(':443', ''); - } else if (/:443\/$/.test(sanitizedHost)) { - sanitizedHost = sanitizedHost.replace(':443/', ''); + return urlParts.join('/'); } - memoizedHostResult = turbineUrl.protocol + '//' + sanitizedHost; - } else { - memoizedHostResult = ''; - } + return sourceUrl; + }; - return memoizedHostResult; - }; + var dynamicHostResolver = { + getTurbineHost: getTurbineHost, + decorateWithDynamicHost: decorateWithDynamicHost, + get isDynamicEnforced() { + return isDynamicEnforced; + } + }; - /** - * Returns a url decorated with the host of the Turbine embed code. If Dynamic host - * is disabled, the original sourceUrl is returned unmodified. - * @param sourceUrl - * @returns {string|*} - */ - var decorateWithDynamicHost = function (sourceUrl) { - if (shouldAugment && typeof sourceUrl === 'string') { - var urlParts = [ - getTurbineHost(), - sourceUrl.charAt(0) === '/' ? sourceUrl.slice(1) : sourceUrl - ]; - - return urlParts.join('/'); + if (window) { + debugController.onDebugChanged(function (isEnabled) { + if (isEnabled) { + window.dynamicHostResolver = dynamicHostResolver; + } else { + delete window.dynamicHostResolver; + } + }); } - return sourceUrl; + return dynamicHostResolver; }; +} - var dynamicHostResolver = { - getTurbineHost: getTurbineHost, - decorateWithDynamicHost: decorateWithDynamicHost, - get isDynamicEnforced() { - return isDynamicEnforced; - } - }; +const validateInjection = validateInjectedParams( + injectCreateDynamicHostResolver +); - if (window) { - debugController.onDebugChanged(function (isEnabled) { - if (isEnabled) { - window.dynamicHostResolver = dynamicHostResolver; - } else { - delete window.dynamicHostResolver; - } - }); - } +module.exports = validateInjection({ + window: require('@adobe/reactor-window') +}); - return dynamicHostResolver; -}; +if (REACTOR_KARMA_CI_UNIT_TEST_MODE) { + /* START.TESTS_ONLY */ + module.exports.injectCreateDynamicHostResolver = validateInjection; + /* END.TESTS_ONLY */ +} diff --git a/src/createGetDataElementValue.js b/src/createGetDataElementValue.js index 694b5c92..4c115165 100644 --- a/src/createGetDataElementValue.js +++ b/src/createGetDataElementValue.js @@ -10,9 +10,7 @@ * governing permissions and limitations under the License. ****************************************************************************************/ -var cleanText = require('./cleanText'); -var logger = require('./logger'); -var dataElementSafe = require('./dataElementSafe'); +var validateInjectedParams = require('./helpers/validate-injected-params'); var getErrorMessage = function ( dataDef, @@ -31,83 +29,107 @@ var getErrorMessage = function ( ); }; -module.exports = function ( - moduleProvider, - getDataElementDefinition, - replaceTokens, - undefinedVarsReturnEmpty, - settingsFileTransformer -) { - return function (name, syntheticEvent) { - var dataDef = getDataElementDefinition(name); - - if (!dataDef) { - return undefinedVarsReturnEmpty ? '' : undefined; - } - - var storageDuration = dataDef.storageDuration; - var moduleExports; - var moduleDefinition; - - try { - moduleExports = moduleProvider.getModuleExports(dataDef.modulePath); - moduleDefinition = moduleProvider.getModuleDefinition(dataDef.modulePath); - } catch (e) { - logger.error(getErrorMessage(dataDef, name, e.message, e.stack)); - return; - } - - if (typeof moduleExports !== 'function') { - logger.error( - getErrorMessage(dataDef, name, 'Module did not export a function.') - ); - return; - } - - var value; - - var dataElementSettings = dataDef.settings || {}; - if (!dataDef.hasTransformedFilePaths && moduleDefinition.filePaths) { - settingsFileTransformer( - dataElementSettings, - moduleDefinition.filePaths, - dataDef.modulePath - ); - dataDef.hasTransformedFilePaths = true; - } - - try { - value = moduleExports( - replaceTokens(dataElementSettings, syntheticEvent), - syntheticEvent - ); - } catch (e) { - logger.error(getErrorMessage(dataDef, name, e.message, e.stack)); - return; - } - - if (storageDuration) { - if (value != null) { - dataElementSafe.setValue(name, storageDuration, value); - } else { - value = dataElementSafe.getValue(name, storageDuration); +function injectCreateGetDataElementValue({ + cleanText, + dataElementSafe, + logger +}) { + return function createGetDataElementValue( + moduleProvider, + getDataElementDefinition, + replaceTokens, + undefinedVarsReturnEmpty, + settingsFileTransformer + ) { + return function (name, syntheticEvent) { + var dataDef = getDataElementDefinition(name); + + if (!dataDef) { + return undefinedVarsReturnEmpty ? '' : undefined; + } + + var storageDuration = dataDef.storageDuration; + var moduleExports; + var moduleDefinition; + + try { + moduleExports = moduleProvider.getModuleExports(dataDef.modulePath); + moduleDefinition = moduleProvider.getModuleDefinition( + dataDef.modulePath + ); + } catch (e) { + logger.error(getErrorMessage(dataDef, name, e.message, e.stack)); + return; + } + + if (typeof moduleExports !== 'function') { + logger.error( + getErrorMessage(dataDef, name, 'Module did not export a function.') + ); + return; + } + + var value; + + var dataElementSettings = dataDef.settings || {}; + if (!dataDef.hasTransformedFilePaths && moduleDefinition.filePaths) { + settingsFileTransformer( + dataElementSettings, + moduleDefinition.filePaths, + dataDef.modulePath + ); + dataDef.hasTransformedFilePaths = true; } - } - if (value == null && dataDef.defaultValue != null) { - value = dataDef.defaultValue; - } + try { + value = moduleExports( + replaceTokens(dataElementSettings, syntheticEvent), + syntheticEvent + ); + } catch (e) { + logger.error(getErrorMessage(dataDef, name, e.message, e.stack)); + return; + } - if (typeof value === 'string') { - if (dataDef.cleanText) { - value = cleanText(value); + if (storageDuration) { + if (value != null) { + dataElementSafe.setValue(name, storageDuration, value); + } else { + value = dataElementSafe.getValue(name, storageDuration); + } } - if (dataDef.forceLowerCase) { - value = value.toLowerCase(); + if (value == null && dataDef.defaultValue != null) { + value = dataDef.defaultValue; + } + + if (typeof value === 'string') { + if (dataDef.cleanText) { + value = cleanText(value); + } + + if (dataDef.forceLowerCase) { + value = value.toLowerCase(); + } } - } - return value; + return value; + }; }; -}; +} + +const validateInjection = validateInjectedParams( + injectCreateGetDataElementValue +); + +module.exports = validateInjection({ + cleanText: require('./cleanText'), + logger: require('./logger'), + dataElementSafe: require('./dataElementSafe') +}); + +if (REACTOR_KARMA_CI_UNIT_TEST_MODE) { + /* START.TESTS_ONLY */ + module.exports.injectCreateGetDataElementValue = validateInjection; + /* END.TESTS_ONLY */ +} diff --git a/src/createModuleProvider.js b/src/createModuleProvider.js index 37143057..9382d77b 100644 --- a/src/createModuleProvider.js +++ b/src/createModuleProvider.js @@ -10,84 +10,98 @@ * governing permissions and limitations under the License. ****************************************************************************************/ -var extractModuleExports = require('./extractModuleExports'); -var logger = require('./logger'); +var validateInjectedParams = require('./helpers/validate-injected-params'); -module.exports = function () { - var moduleByReferencePath = {}; +function injectCreateModuleProvider({ extractModuleExports, logger }) { + return function createModuleProvider() { + var moduleByReferencePath = {}; - var getModule = function (referencePath) { - var module = moduleByReferencePath[referencePath]; + var getModule = function (referencePath) { + var module = moduleByReferencePath[referencePath]; - if (!module) { - throw new Error('Module ' + referencePath + ' not found.'); - } + if (!module) { + throw new Error('Module ' + referencePath + ' not found.'); + } - return module; - }; + return module; + }; - var registerModule = function ( - referencePath, - moduleDefinition, - extensionName, - require, - turbine - ) { - var module = { - definition: moduleDefinition, - extensionName: extensionName, - require: require, - turbine: turbine + var registerModule = function ( + referencePath, + moduleDefinition, + extensionName, + require, + turbine + ) { + var module = { + definition: moduleDefinition, + extensionName: extensionName, + require: require, + turbine: turbine + }; + module.require = require; + moduleByReferencePath[referencePath] = module; }; - module.require = require; - moduleByReferencePath[referencePath] = module; - }; - var hydrateCache = function () { - Object.keys(moduleByReferencePath).forEach(function (referencePath) { - try { - getModuleExports(referencePath); - } catch (e) { - var errorMessage = - 'Error initializing module ' + - referencePath + - '. ' + - e.message + - (e.stack ? '\n' + e.stack : ''); - logger.error(errorMessage); + var hydrateCache = function () { + Object.keys(moduleByReferencePath).forEach(function (referencePath) { + try { + getModuleExports(referencePath); + } catch (e) { + var errorMessage = + 'Error initializing module ' + + referencePath + + '. ' + + e.message + + (e.stack ? '\n' + e.stack : ''); + logger.error(errorMessage); + } + }); + }; + + var getModuleExports = function (referencePath) { + var module = getModule(referencePath); + + // Using hasOwnProperty instead of a falsey check because the module could export undefined + // in which case we don't want to execute the module each time the exports is requested. + if (!module.hasOwnProperty('exports')) { + module.exports = extractModuleExports( + module.definition.script, + module.require, + module.turbine + ); } - }); - }; - var getModuleExports = function (referencePath) { - var module = getModule(referencePath); + return module.exports; + }; - // Using hasOwnProperty instead of a falsey check because the module could export undefined - // in which case we don't want to execute the module each time the exports is requested. - if (!module.hasOwnProperty('exports')) { - module.exports = extractModuleExports( - module.definition.script, - module.require, - module.turbine - ); - } + var getModuleDefinition = function (referencePath) { + return getModule(referencePath).definition; + }; - return module.exports; - }; + var getModuleExtensionName = function (referencePath) { + return getModule(referencePath).extensionName; + }; - var getModuleDefinition = function (referencePath) { - return getModule(referencePath).definition; + return { + registerModule: registerModule, + hydrateCache: hydrateCache, + getModuleExports: getModuleExports, + getModuleDefinition: getModuleDefinition, + getModuleExtensionName: getModuleExtensionName + }; }; +} - var getModuleExtensionName = function (referencePath) { - return getModule(referencePath).extensionName; - }; +const validateInjection = validateInjectedParams(injectCreateModuleProvider); - return { - registerModule: registerModule, - hydrateCache: hydrateCache, - getModuleExports: getModuleExports, - getModuleDefinition: getModuleDefinition, - getModuleExtensionName: getModuleExtensionName - }; -}; +module.exports = validateInjection({ + extractModuleExports: require('./extractModuleExports'), + logger: require('./logger') +}); + +if (REACTOR_KARMA_CI_UNIT_TEST_MODE) { + /* START.TESTS_ONLY */ + module.exports.injectCreateModuleProvider = validateInjection; + /* END.TESTS_ONLY */ +} diff --git a/src/createNotifyMonitors.js b/src/createNotifyMonitors.js index 867310ec..6da0c010 100644 --- a/src/createNotifyMonitors.js +++ b/src/createNotifyMonitors.js @@ -9,28 +9,43 @@ * OF ANY KIND, either express or implied. See the License for the specific language * governing permissions and limitations under the License. ****************************************************************************************/ -var logger = require('./logger'); -var warningLogged = false; +var validateInjectedParams = require('./helpers/validate-injected-params'); -module.exports = function (_satellite) { - return function (type, event) { - var monitors = _satellite._monitors; +function injectCreateNotifyMonitors({ logger }) { + return function createNotifyMonitors(satellite) { + var warningLogged = false; - if (monitors) { - if (!warningLogged) { - logger.warn( - 'The _satellite._monitors API may change at any time and should only ' + - 'be used for debugging.' - ); - warningLogged = true; - } + return function notifyMonitors(type, event) { + var monitors = satellite._monitors; - monitors.forEach(function (monitor) { - if (monitor[type]) { - monitor[type](event); + if (monitors) { + if (!warningLogged) { + logger.warn( + 'The _satellite._monitors API may change at any time and should only ' + + 'be used for debugging.' + ); + warningLogged = true; } - }); - } + + monitors.forEach(function (monitor) { + if (monitor[type]) { + monitor[type](event); + } + }); + } + }; }; -}; +} + +const validateInjection = validateInjectedParams(injectCreateNotifyMonitors); + +module.exports = validateInjection({ + logger: require('./logger') +}); + +if (REACTOR_KARMA_CI_UNIT_TEST_MODE) { + /* START.TESTS_ONLY */ + module.exports.injectCreateNotifyMonitors = validateInjection; + /* END.TESTS_ONLY */ +} diff --git a/src/createPublicRequire.js b/src/createPublicRequire.js index 28142610..11adc2ee 100644 --- a/src/createPublicRequire.js +++ b/src/createPublicRequire.js @@ -10,39 +10,49 @@ * governing permissions and limitations under the License. ****************************************************************************************/ -var CORE_MODULE_PREFIX = '@adobe/reactor-'; +var validateInjectedParams = require('./helpers/validate-injected-params'); -var modules = { - cookie: require('@adobe/reactor-cookie'), - document: require('@adobe/reactor-document'), - 'load-script': require('@adobe/reactor-load-script'), - 'object-assign': require('@adobe/reactor-object-assign'), - promise: require('@adobe/reactor-promise'), - 'query-string': require('@adobe/reactor-query-string'), - window: require('@adobe/reactor-window') -}; - -/** - * Creates a function which can be passed as a "require" function to extension modules. - * - * @param {Function} getModuleExportsByRelativePath - * @returns {Function} - */ -module.exports = function (getModuleExportsByRelativePath) { - return function (key) { - if (key.indexOf(CORE_MODULE_PREFIX) === 0) { - var keyWithoutScope = key.substr(CORE_MODULE_PREFIX.length); - var module = modules[keyWithoutScope]; - - if (module) { - return module; +function injectCreatePublicRequire({ moduleMap }) { + moduleMap = moduleMap || {}; + return function createPublicRequire(getModuleExportsByRelativePath) { + // I thought about allowing this prefix to be overridden for testing but + // I think it's safer if we don't allow it to be tampered with. + var CORE_MODULE_PREFIX = '@adobe/reactor-'; + return function publicRequire(key) { + if (key.indexOf(CORE_MODULE_PREFIX) === 0) { + var keyWithoutScope = key.substr(CORE_MODULE_PREFIX.length); + if (moduleMap.hasOwnProperty(keyWithoutScope)) { + return moduleMap[keyWithoutScope]; + } } - } - if (key.indexOf('./') === 0 || key.indexOf('../') === 0) { - return getModuleExportsByRelativePath(key); - } + if (key.indexOf('./') === 0 || key.indexOf('../') === 0) { + return getModuleExportsByRelativePath(key); + } - throw new Error('Cannot resolve module "' + key + '".'); + throw new Error('Cannot resolve module "' + key + '".'); + }; }; -}; +} + +const validateInjection = validateInjectedParams(injectCreatePublicRequire); + +// 'promise' in this context should be lowercase because imports are of the shape: +// @adobe/reactor-promise, etc. +module.exports = validateInjection({ + moduleMap: { + cookie: require('@adobe/reactor-cookie'), + document: require('@adobe/reactor-document'), + 'load-script': require('@adobe/reactor-load-script'), + 'object-assign': require('@adobe/reactor-object-assign'), + promise: require('@adobe/reactor-promise'), + 'query-string': require('@adobe/reactor-query-string'), + window: require('@adobe/reactor-window') + } +}); + +if (REACTOR_KARMA_CI_UNIT_TEST_MODE) { + /* START.TESTS_ONLY */ + module.exports.injectCreatePublicRequire = validateInjection; + /* END.TESTS_ONLY */ +} diff --git a/src/createReplaceTokens.js b/src/createReplaceTokens.js index 1da90f78..70cc77af 100644 --- a/src/createReplaceTokens.js +++ b/src/createReplaceTokens.js @@ -10,103 +10,117 @@ * governing permissions and limitations under the License. ****************************************************************************************/ -var logger = require('./logger'); - -/** - * Replacing any variable tokens (%myDataElement%, %this.foo%, etc.) with their associated values. - * A new string, object, or array will be created; the thing being processed will never be - * modified. - * @param {*} thing Thing potentially containing variable tokens. Objects and arrays will be - * deeply processed. - * @param {HTMLElement} [element] Associated HTML element. Used for special tokens - * (%this.something%). - * @param {Object} [event] Associated event. Used for special tokens (%event.something%, - * %target.something%) - * @returns {*} A processed value. - */ -module.exports = function (isVar, getVar, undefinedVarsReturnEmpty) { - var replaceTokensInString; - var replaceTokensInObject; - var replaceTokensInArray; - var replaceTokens; - var variablesBeingRetrieved = []; - - var getVarValue = function (token, variableName, syntheticEvent) { - if (!isVar(variableName)) { - return token; - } - - variablesBeingRetrieved.push(variableName); - var val = getVar(variableName, syntheticEvent); - variablesBeingRetrieved.pop(); - return val == null && undefinedVarsReturnEmpty ? '' : val; - }; +var validateInjectedParams = require('./helpers/validate-injected-params'); +function injectCreateReplaceTokens({ logger }) { /** - * Perform variable substitutions to a string where tokens are specified in the form %foo%. - * If the only content of the string is a single data element token, then the raw data element - * value will be returned instead. - * - * @param str {string} The string potentially containing data element tokens. - * @param element {HTMLElement} The element to use for tokens in the form of %this.property%. - * @param event {Object} The event object to use for tokens in the form of %target.property%. - * @returns {*} + * Replacing any variable tokens (%myDataElement%, %this.foo%, etc.) with their associated values. + * A new string, object, or array will be created; the thing being processed will never be + * modified. + * @param {*} thing Thing potentially containing variable tokens. Objects and arrays will be + * deeply processed. + * @param {HTMLElement} [element] Associated HTML element. Used for special tokens + * (%this.something%). + * @param {Object} [event] Associated event. Used for special tokens (%event.something%, + * %target.something%) + * @returns {*} A processed value. */ - replaceTokensInString = function (str, syntheticEvent) { - // Is the string a single data element token and nothing else? - var result = /^%([^%]+)%$/.exec(str); + return function createReplaceTokens(isVar, getVar, undefinedVarsReturnEmpty) { + var replaceTokensInString; + var replaceTokensInObject; + var replaceTokensInArray; + var replaceTokens; + var variablesBeingRetrieved = []; - if (result) { - return getVarValue(str, result[1], syntheticEvent); - } else { - return str.replace(/%(.+?)%/g, function (token, variableName) { - return getVarValue(token, variableName, syntheticEvent); - }); - } - }; + var getVarValue = function (token, variableName, syntheticEvent) { + if (!isVar(variableName)) { + return token; + } - replaceTokensInObject = function (obj, syntheticEvent) { - var ret = {}; - var keys = Object.keys(obj); - for (var i = 0; i < keys.length; i++) { - var key = keys[i]; - var value = obj[key]; - ret[key] = replaceTokens(value, syntheticEvent); - } - return ret; - }; + variablesBeingRetrieved.push(variableName); + var val = getVar(variableName, syntheticEvent); + variablesBeingRetrieved.pop(); + return val == null && undefinedVarsReturnEmpty ? '' : val; + }; - replaceTokensInArray = function (arr, syntheticEvent) { - var ret = []; - for (var i = 0, len = arr.length; i < len; i++) { - ret.push(replaceTokens(arr[i], syntheticEvent)); - } - return ret; - }; + /** + * Perform variable substitutions to a string where tokens are specified in the form %foo%. + * If the only content of the string is a single data element token, then the raw data element + * value will be returned instead. + * + * @param str {string} The string potentially containing data element tokens. + * @param element {HTMLElement} The element to use for tokens in the form of %this.property%. + * @param event {Object} The event object to use for tokens in the form of %target.property%. + * @returns {*} + */ + replaceTokensInString = function (str, syntheticEvent) { + // Is the string a single data element token and nothing else? + var result = /^%([^%]+)%$/.exec(str); - replaceTokens = function (thing, syntheticEvent) { - if (typeof thing === 'string') { - return replaceTokensInString(thing, syntheticEvent); - } else if (Array.isArray(thing)) { - return replaceTokensInArray(thing, syntheticEvent); - } else if (typeof thing === 'object' && thing !== null) { - return replaceTokensInObject(thing, syntheticEvent); - } + if (result) { + return getVarValue(str, result[1], syntheticEvent); + } else { + return str.replace(/%(.+?)%/g, function (token, variableName) { + return getVarValue(token, variableName, syntheticEvent); + }); + } + }; - return thing; - }; + replaceTokensInObject = function (obj, syntheticEvent) { + var ret = {}; + var keys = Object.keys(obj); + for (var i = 0; i < keys.length; i++) { + var key = keys[i]; + var value = obj[key]; + ret[key] = replaceTokens(value, syntheticEvent); + } + return ret; + }; + + replaceTokensInArray = function (arr, syntheticEvent) { + var ret = []; + for (var i = 0, len = arr.length; i < len; i++) { + ret.push(replaceTokens(arr[i], syntheticEvent)); + } + return ret; + }; + + replaceTokens = function (thing, syntheticEvent) { + if (typeof thing === 'string') { + return replaceTokensInString(thing, syntheticEvent); + } else if (Array.isArray(thing)) { + return replaceTokensInArray(thing, syntheticEvent); + } else if (typeof thing === 'object' && thing !== null) { + return replaceTokensInObject(thing, syntheticEvent); + } - return function (thing, syntheticEvent) { - // It's possible for a data element to reference another data element. Because of this, - // we need to prevent circular dependencies from causing an infinite loop. - if (variablesBeingRetrieved.length > 10) { - logger.error( - 'Data element circular reference detected: ' + - variablesBeingRetrieved.join(' -> ') - ); return thing; - } + }; + + return function (thing, syntheticEvent) { + // It's possible for a data element to reference another data element. Because of this, + // we need to prevent circular dependencies from causing an infinite loop. + if (variablesBeingRetrieved.length > 10) { + logger.error( + 'Data element circular reference detected: ' + + variablesBeingRetrieved.join(' -> ') + ); + return thing; + } - return replaceTokens(thing, syntheticEvent); + return replaceTokens(thing, syntheticEvent); + }; }; -}; +} + +const validateInjection = validateInjectedParams(injectCreateReplaceTokens); + +module.exports = validateInjection({ + logger: require('./logger') +}); + +if (REACTOR_KARMA_CI_UNIT_TEST_MODE) { + /* START.TESTS_ONLY */ + module.exports.injectCreateReplaceTokens = validateInjection; + /* END.TESTS_ONLY */ +} diff --git a/src/extractModuleExports.js b/src/extractModuleExports.js index bcae599d..f01a4873 100644 --- a/src/extractModuleExports.js +++ b/src/extractModuleExports.js @@ -15,6 +15,7 @@ module.exports = function (script, require, turbine) { exports: {} }; + // simulate CommonJS environment where a developer can define module.exports script.call(module.exports, module, module.exports, require, turbine); if ( diff --git a/src/getNamespacedStorage.js b/src/getNamespacedStorage.js index 7ffe720a..c198040d 100644 --- a/src/getNamespacedStorage.js +++ b/src/getNamespacedStorage.js @@ -10,42 +10,56 @@ * governing permissions and limitations under the License. ****************************************************************************************/ -var window = require('@adobe/reactor-window'); -var NAMESPACE = 'com.adobe.reactor.'; +var validateInjectedParams = require('./helpers/validate-injected-params'); -module.exports = function (storageType, additionalNamespace) { - var finalNamespace = NAMESPACE + (additionalNamespace || ''); +function injectGetNamespacedStorage({ window }) { + var NAMESPACE = 'com.adobe.reactor.'; // Default namespace. + return function getNamespacedStorage(storageType, additionalNamespace) { + var finalNamespace = NAMESPACE + (additionalNamespace || ''); - // When storage is disabled on Safari, the mere act of referencing window.localStorage - // or window.sessionStorage throws an error. For this reason, we wrap in a try-catch. - return { - /** - * Reads a value from storage. - * @param {string} name The name of the item to be read. - * @returns {string} - */ - getItem: function (name) { - try { - return window[storageType].getItem(finalNamespace + name); - // eslint-disable-next-line no-unused-vars - } catch (e) { - return null; + // When storage is disabled on Safari, the mere act of referencing window.localStorage + // or window.sessionStorage throws an error. For this reason, we wrap in a try-catch. + return { + /** + * Reads a value from storage. + * @param {string} name The name of the item to be read. + * @returns {string} + */ + getItem: function (name) { + try { + return window[storageType].getItem(finalNamespace + name); + // eslint-disable-next-line no-unused-vars + } catch (e) { + return null; + } + }, + /** + * Saves a value to storage. + * @param {string} name The name of the item to be saved. + * @param {string} value The value of the item to be saved. + * @returns {boolean} Whether the item was successfully saved to storage. + */ + setItem: function (name, value) { + try { + window[storageType].setItem(finalNamespace + name, value); + return true; + // eslint-disable-next-line no-unused-vars + } catch (e) { + return false; + } } - }, - /** - * Saves a value to storage. - * @param {string} name The name of the item to be saved. - * @param {string} value The value of the item to be saved. - * @returns {boolean} Whether the item was successfully saved to storage. - */ - setItem: function (name, value) { - try { - window[storageType].setItem(finalNamespace + name, value); - return true; - // eslint-disable-next-line no-unused-vars - } catch (e) { - return false; - } - } + }; }; -}; +} + +const validateInjection = validateInjectedParams(injectGetNamespacedStorage); + +module.exports = validateInjection({ + window: require('@adobe/reactor-window') +}); + +if (REACTOR_KARMA_CI_UNIT_TEST_MODE) { + /* START.TESTS_ONLY */ + module.exports.injectGetNamespacedStorage = validateInjection; + /* END.TESTS_ONLY */ +} diff --git a/src/helpers/validate-injected-params.js b/src/helpers/validate-injected-params.js new file mode 100644 index 00000000..237df881 --- /dev/null +++ b/src/helpers/validate-injected-params.js @@ -0,0 +1,48 @@ +/*************************************************************************************** + * (c) 2025 Adobe. All rights reserved. + * This file is licensed to you under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. You may obtain a copy + * of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under + * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS + * OF ANY KIND, either express or implied. See the License for the specific language + * governing permissions and limitations under the License. + ****************************************************************************************/ + +// reads the function signature and sees if a caller doesn't pass enough parameters +module.exports = function validateInjectedParams(fn) { + if (REACTOR_KARMA_CI_UNIT_TEST_MODE) { + /* START.TESTS_ONLY */ + return function proxyValidateArgs(args = {}) { + const missing = []; + + // Call fn with Proxy to detect what props it tries to access + const proxy = new Proxy(args, { + get(target, prop) { + if (!(prop in target)) { + missing.push(prop); + } + return target[prop]; + } + }); + + fn(proxy); + + if (missing.length > 0) { + throw new Error( + `${fn.name}: Missing required argument(s): ${missing.join(', ')}` + ); + } + + // All required keys accessed successfully — call with original args + return fn(args); + }; + /* END.TESTS_ONLY */ + } else { + // in production builds we have run all our tests and trust that the files + // whose default export functions use an inject pattern contain the appropriate + // production-ready require statements to make the module run. + return fn; + } +}; diff --git a/src/hydrateModuleProvider.js b/src/hydrateModuleProvider.js index 7278db37..2530dc6e 100644 --- a/src/hydrateModuleProvider.js +++ b/src/hydrateModuleProvider.js @@ -10,104 +10,127 @@ * governing permissions and limitations under the License. ****************************************************************************************/ -var createGetSharedModuleExports = require('./createGetSharedModuleExports'); -var createGetExtensionSettings = require('./createGetExtensionSettings'); -var createGetHostedLibFileUrl = require('./createGetHostedLibFileUrl'); -var logger = require('./logger'); -var resolveRelativePath = require('./resolveRelativePath'); -var createPublicRequire = require('./createPublicRequire'); +var validateInjectedParams = require('./helpers/validate-injected-params'); -module.exports = function ( - container, - moduleProvider, - debugController, - replaceTokens, - getDataElementValue, - settingsFileTransformer, - decorateWithDynamicHost -) { - var extensions = container.extensions; - var buildInfo = container.buildInfo; - var environment = container.environment; - var propertySettings = container.property.settings; +function injectHydrateModuleProvider({ + createGetSharedModuleExports, + createGetExtensionSettings, + createGetHostedLibFileUrl, + resolveRelativePath, + createPublicRequire, + logger +}) { + return function hydrateModuleProvider( + container, + moduleProvider, + debugController, + replaceTokens, + getDataElementValue, + settingsFileTransformer, + decorateWithDynamicHost + ) { + var extensions = container.extensions; + var buildInfo = container.buildInfo; + var environment = container.environment; + var propertySettings = container.property.settings; - if (extensions) { - var getSharedModuleExports = createGetSharedModuleExports( - extensions, - moduleProvider - ); - - Object.keys(extensions).forEach(function (extensionName) { - var extension = extensions[extensionName]; - var extensionSettings = extension.settings; - if (Array.isArray(extension.filePaths)) { - extensionSettings = settingsFileTransformer( - extensionSettings, - extension.filePaths - ); - } - var getExtensionSettings = createGetExtensionSettings( - replaceTokens, - extensionSettings + if (extensions) { + var getSharedModuleExports = createGetSharedModuleExports( + extensions, + moduleProvider ); - if (extension.modules) { - var prefixedLogger = logger.createPrefixedLogger(extension.displayName); - var getHostedLibFileUrl = createGetHostedLibFileUrl( - decorateWithDynamicHost, - extension.hostedLibFilesBaseUrl, - buildInfo.minified + Object.keys(extensions).forEach(function (extensionName) { + var extension = extensions[extensionName]; + var extensionSettings = extension.settings; + if (Array.isArray(extension.filePaths)) { + extensionSettings = settingsFileTransformer( + extensionSettings, + extension.filePaths + ); + } + var getExtensionSettings = createGetExtensionSettings( + replaceTokens, + extensionSettings ); - var turbine = { - buildInfo: buildInfo, - environment: environment, - property: { - name: container.property.name, - id: container.property.id - }, - getDataElementValue: getDataElementValue, - getExtensionSettings: getExtensionSettings, - getHostedLibFileUrl: getHostedLibFileUrl, - getSharedModule: getSharedModuleExports, - logger: prefixedLogger, - propertySettings: propertySettings, - replaceTokens: replaceTokens, - onDebugChanged: debugController.onDebugChanged, - get debugEnabled() { - return debugController.getDebugEnabled(); - } - }; - Object.keys(extension.modules).forEach(function (referencePath) { - var module = extension.modules[referencePath]; - var getModuleExportsByRelativePath = function (relativePath) { - var resolvedReferencePath = resolveRelativePath( + if (extension.modules) { + var prefixedLogger = logger.createPrefixedLogger( + extension.displayName + ); + var getHostedLibFileUrl = createGetHostedLibFileUrl( + decorateWithDynamicHost, + extension.hostedLibFilesBaseUrl, + buildInfo.minified + ); + var turbine = { + buildInfo: buildInfo, + environment: environment, + property: { + name: container.property.name, + id: container.property.id + }, + getDataElementValue: getDataElementValue, + getExtensionSettings: getExtensionSettings, + getHostedLibFileUrl: getHostedLibFileUrl, + getSharedModule: getSharedModuleExports, + logger: prefixedLogger, + propertySettings: propertySettings, + replaceTokens: replaceTokens, + onDebugChanged: debugController.onDebugChanged, + get debugEnabled() { + return debugController.getDebugEnabled(); + } + }; + + Object.keys(extension.modules).forEach(function (referencePath) { + var module = extension.modules[referencePath]; + var getModuleExportsByRelativePath = function (relativePath) { + var resolvedReferencePath = resolveRelativePath( + referencePath, + relativePath + ); + return moduleProvider.getModuleExports(resolvedReferencePath); + }; + var publicRequire = createPublicRequire( + getModuleExportsByRelativePath + ); + + moduleProvider.registerModule( referencePath, - relativePath + module, + extensionName, + publicRequire, + turbine ); - return moduleProvider.getModuleExports(resolvedReferencePath); - }; - var publicRequire = createPublicRequire( - getModuleExportsByRelativePath - ); + }); + } + }); - moduleProvider.registerModule( - referencePath, - module, - extensionName, - publicRequire, - turbine - ); - }); - } - }); + // We want to extract the module exports immediately to allow the modules + // to run some logic immediately. + // We need to do the extraction here in order for the moduleProvider to + // have all the modules previously registered. (eg. when moduleA needs moduleB, both modules + // must exist inside moduleProvider). + moduleProvider.hydrateCache(); + } + return moduleProvider; + }; +} + +const validateInjection = validateInjectedParams(injectHydrateModuleProvider); + +module.exports = validateInjection({ + createGetSharedModuleExports: require('./createGetSharedModuleExports'), + createGetExtensionSettings: require('./createGetExtensionSettings'), + createGetHostedLibFileUrl: require('./createGetHostedLibFileUrl'), + resolveRelativePath: require('./resolveRelativePath'), + createPublicRequire: require('./createPublicRequire'), + logger: require('./logger') +}); - // We want to extract the module exports immediately to allow the modules - // to run some logic immediately. - // We need to do the extraction here in order for the moduleProvider to - // have all the modules previously registered. (eg. when moduleA needs moduleB, both modules - // must exist inside moduleProvider). - moduleProvider.hydrateCache(); - } - return moduleProvider; -}; +if (REACTOR_KARMA_CI_UNIT_TEST_MODE) { + /* START.TESTS_ONLY */ + module.exports.injectHydrateModuleProvider = validateInjection; + /* END.TESTS_ONLY */ +} diff --git a/src/hydrateSatelliteObject.js b/src/hydrateSatelliteObject.js index 3db96158..8a2bb36e 100644 --- a/src/hydrateSatelliteObject.js +++ b/src/hydrateSatelliteObject.js @@ -10,161 +10,176 @@ * governing permissions and limitations under the License. ****************************************************************************************/ -var cookie = require('@adobe/reactor-cookie'); -var logger = require('./logger'); - -module.exports = function ( - _satellite, - container, - setDebugEnabled, - getVar, - setCustomVar -) { - var customScriptPrefixedLogger = logger.createPrefixedLogger('Custom Script'); - - // Will get replaced by the directCall event delegate from the Core extension. Exists here in - // case there are no direct call rules (and therefore the directCall event delegate won't get - // included) and our customers are still calling the method. In this case, we don't want an error - // to be thrown. This method existed before Reactor. - _satellite.track = function (identifier) { - logger.log( - '"' + identifier + '" does not match any direct call identifiers.' - ); - }; - - // Will get replaced by the Marketing Cloud ID extension if installed. Exists here in case - // the extension is not installed and our customers are still calling the method. In this case, - // we don't want an error to be thrown. This method existed before Reactor. - _satellite.getVisitorId = function () { - return null; - }; - - // container.property also has property settings, but it shouldn't concern the user. - // By limiting our API exposure to necessities, we provide more flexibility in the future. - _satellite.property = { - name: container.property.name, - id: container.property.id - }; - - _satellite.company = container.company; - - _satellite.buildInfo = container.buildInfo; - - _satellite.environment = container.environment; - - _satellite.logger = customScriptPrefixedLogger; - - /** - * Log a message. We keep this due to legacy baggage. - * @param {string} message The message to log. - * @param {number} [level] A number that represents the level of logging. - * 3=info, 4=warn, 5=error, anything else=log - */ - _satellite.notify = function (message, level) { - logger.deprecation( - '_satellite.notify is deprecated. Please use the `_satellite.logger` API.' - ); - - switch (level) { - case 3: - customScriptPrefixedLogger.info(message); - break; - case 4: - customScriptPrefixedLogger.warn(message); - break; - case 5: - customScriptPrefixedLogger.error(message); - break; - default: - customScriptPrefixedLogger.log(message); - } - }; - - _satellite.getVar = getVar; - _satellite.setVar = setCustomVar; - - /** - * Writes a cookie. - * @param {string} name The name of the cookie to save. - * @param {string} value The value of the cookie to save. - * @param {number} [days] The number of days to store the cookie. If not specified, the cookie - * will be stored for the session only. - */ - _satellite.setCookie = function (name, value, days) { - var optionsStr = ''; - var options = {}; - - if (days) { - optionsStr = ', { expires: ' + days + ' }'; - options.expires = days; - } - - var msg = - '_satellite.setCookie is deprecated. Please use ' + - '_satellite.cookie.set("' + - name + - '", "' + - value + - '"' + - optionsStr + - ').'; - - logger.deprecation(msg); - cookie.set(name, value, options); - }; - - /** - * Reads a cookie value. - * @param {string} name The name of the cookie to read. - * @returns {string} - */ - _satellite.readCookie = function (name) { - logger.deprecation( - '_satellite.readCookie is deprecated. ' + - 'Please use _satellite.cookie.get("' + - name + - '").' - ); - return cookie.get(name); - }; +var validateInjectedParams = require('./helpers/validate-injected-params'); + +function injectHydrateSatelliteObject({ cookie, logger }) { + return function hydrateSatelliteObject( + _satellite, + container, + setDebugEnabled, + getVar, + setCustomVar + ) { + var customScriptPrefixedLogger = + logger.createPrefixedLogger('Custom Script'); + + // Will get replaced by the directCall event delegate from the Core extension. Exists here in + // case there are no direct call rules (and therefore the directCall event delegate won't get + // included) and our customers are still calling the method. In this case, we don't want an error + // to be thrown. This method existed before Reactor. + _satellite.track = function (identifier) { + logger.log( + '"' + identifier + '" does not match any direct call identifiers.' + ); + }; + + // Will get replaced by the Marketing Cloud ID extension if installed. Exists here in case + // the extension is not installed and our customers are still calling the method. In this case, + // we don't want an error to be thrown. This method existed before Reactor. + _satellite.getVisitorId = function () { + return null; + }; + + // container.property also has property settings, but it shouldn't concern the user. + // By limiting our API exposure to necessities, we provide more flexibility in the future. + _satellite.property = { + name: container.property.name, + id: container.property.id + }; + + _satellite.company = container.company; + + _satellite.buildInfo = container.buildInfo; + + _satellite.environment = container.environment; + + _satellite.logger = customScriptPrefixedLogger; + + /** + * Log a message. We keep this due to legacy baggage. + * @param {string} message The message to log. + * @param {number} [level] A number that represents the level of logging. + * 3=info, 4=warn, 5=error, anything else=log + */ + _satellite.notify = function (message, level) { + logger.deprecation( + '_satellite.notify is deprecated. Please use the `_satellite.logger` API.' + ); + + switch (level) { + case 3: + customScriptPrefixedLogger.info(message); + break; + case 4: + customScriptPrefixedLogger.warn(message); + break; + case 5: + customScriptPrefixedLogger.error(message); + break; + default: + customScriptPrefixedLogger.log(message); + } + }; + + _satellite.getVar = getVar; + _satellite.setVar = setCustomVar; + + /** + * Writes a cookie. + * @param {string} name The name of the cookie to save. + * @param {string} value The value of the cookie to save. + * @param {number} [days] The number of days to store the cookie. If not specified, the cookie + * will be stored for the session only. + */ + _satellite.setCookie = function (name, value, days) { + var optionsStr = ''; + var options = {}; + + if (days) { + optionsStr = ', { expires: ' + days + ' }'; + options.expires = days; + } - /** - * Removes a cookie value. - * @param name - */ - _satellite.removeCookie = function (name) { - logger.deprecation( - '_satellite.removeCookie is deprecated. ' + - 'Please use _satellite.cookie.remove("' + + var msg = + '_satellite.setCookie is deprecated. Please use ' + + '_satellite.cookie.set("' + name + - '").' - ); - cookie.remove(name); + '", "' + + value + + '"' + + optionsStr + + ').'; + + logger.deprecation(msg); + cookie.set(name, value, options); + }; + + /** + * Reads a cookie value. + * @param {string} name The name of the cookie to read. + * @returns {string} + */ + _satellite.readCookie = function (name) { + logger.deprecation( + '_satellite.readCookie is deprecated. ' + + 'Please use _satellite.cookie.get("' + + name + + '").' + ); + return cookie.get(name); + }; + + /** + * Removes a cookie value. + * @param name + */ + _satellite.removeCookie = function (name) { + logger.deprecation( + '_satellite.removeCookie is deprecated. ' + + 'Please use _satellite.cookie.remove("' + + name + + '").' + ); + cookie.remove(name); + }; + + _satellite.cookie = cookie; + + // Will get replaced by the pageBottom event delegate from the Core extension. Exists here in + // case the customers are not using core (and therefore the pageBottom event delegate won't get + // included) and they are still calling the method. In this case, we don't want an error + // to be thrown. This method existed before Reactor. + _satellite.pageBottom = function () {}; + + _satellite.setDebug = setDebugEnabled; + + var warningLogged = false; + + Object.defineProperty(_satellite, '_container', { + get: function () { + if (!warningLogged) { + logger.warn( + '_satellite._container may change at any time and should only ' + + 'be used for debugging.' + ); + warningLogged = true; + } + + return container; + } + }); }; +} - _satellite.cookie = cookie; +const validateInjection = validateInjectedParams(injectHydrateSatelliteObject); - // Will get replaced by the pageBottom event delegate from the Core extension. Exists here in - // case the customers are not using core (and therefore the pageBottom event delegate won't get - // included) and they are still calling the method. In this case, we don't want an error - // to be thrown. This method existed before Reactor. - _satellite.pageBottom = function () {}; - - _satellite.setDebug = setDebugEnabled; - - var warningLogged = false; - - Object.defineProperty(_satellite, '_container', { - get: function () { - if (!warningLogged) { - logger.warn( - '_satellite._container may change at any time and should only ' + - 'be used for debugging.' - ); - warningLogged = true; - } +module.exports = validateInjection({ + cookie: require('@adobe/reactor-cookie'), + logger: require('./logger') +}); - return container; - } - }); -}; +if (REACTOR_KARMA_CI_UNIT_TEST_MODE) { + /* START.TESTS_ONLY */ + module.exports.injectHydrateSatelliteObject = validateInjection; + /* END.TESTS_ONLY */ +} diff --git a/src/index.js b/src/index.js index 4ad0f9c9..1d1a18f2 100644 --- a/src/index.js +++ b/src/index.js @@ -1,263 +1,309 @@ -/*************************************************************************************** - * (c) 2017 Adobe. All rights reserved. - * This file is licensed to you under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. You may obtain a copy - * of the License at http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software distributed under - * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS - * OF ANY KIND, either express or implied. See the License for the specific language - * governing permissions and limitations under the License. - ****************************************************************************************/ - -// DYNAMIC URL -var document = require('@adobe/reactor-document'); -var objectAssign = require('@adobe/reactor-object-assign'); -var createDynamicHostResolver = require('./createDynamicHostResolver'); -var buildRuleExecutionOrder = require('./buildRuleExecutionOrder'); - -var createDebugController = require('./createDebugController'); -var createExecuteDelegateModule = require('./createExecuteDelegateModule'); -var createGetDataElementValue = require('./createGetDataElementValue'); -var createGetVar = require('./createGetVar'); -var createIsVar = require('./createIsVar'); -var createModuleProvider = require('./createModuleProvider'); -var createNotifyMonitors = require('./createNotifyMonitors'); -var createReplaceTokens = require('./createReplaceTokens'); -var createSetCustomVar = require('./createSetCustomVar'); - -var createAddActionToQueue = require('./rules/createAddActionToQueue'); -var createAddConditionToQueue = require('./rules/createAddConditionToQueue'); -var createAddRuleToQueue = require('./rules/createAddRuleToQueue'); -var createEvaluateConditions = require('./rules/createEvaluateConditions'); -var createExecuteRule = require('./rules/createExecuteRule'); -var createGetModuleDisplayNameByRuleComponent = require('./rules/createGetModuleDisplayNameByRuleComponent'); -var createGetSyntheticEventMeta = require('./rules/createGetSyntheticEventMeta'); -var createInitEventModule = require('./rules/createInitEventModule'); -var createLogActionError = require('./rules/createLogActionError'); -var createLogConditionError = require('./rules/createLogConditionError'); -var createLogConditionNotMet = require('./rules/createLogConditionNotMet'); -var createLogRuleCompleted = require('./rules/createLogRuleCompleted'); -var createRunActions = require('./rules/createRunActions'); -var createTriggerRule = require('./rules/createTriggerRule'); - -var getRuleComponentErrorMessage = require('./rules/getRuleComponentErrorMessage'); -var isConditionMet = require('./rules/isConditionMet'); -var initRules = require('./rules/initRules'); -var normalizeRuleComponentError = require('./rules/normalizeRuleComponentError'); -var normalizeSyntheticEvent = require('./rules/normalizeSyntheticEvent'); - -var getNamespacedStorage = require('./getNamespacedStorage'); - -var hydrateModuleProvider = require('./hydrateModuleProvider'); -var hydrateSatelliteObject = require('./hydrateSatelliteObject'); - -var createSettingsFileTransformer = require('./createSettingsFileTransformer'); - -var logger = require('./logger'); +var validateInjectedParams = require('./helpers/validate-injected-params'); + +function indexDependencyInjector({ + logger, + document, + objectAssign, + createDynamicHostResolver, + buildRuleExecutionOrder, + createDebugController, + createExecuteDelegateModule, + createGetDataElementValue, + createGetVar, + createIsVar, + createModuleProvider, + createNotifyMonitors, + createReplaceTokens, + createSetCustomVar, + createAddActionToQueue, + createAddConditionToQueue, + createAddRuleToQueue, + createEvaluateConditions, + createExecuteRule, + createGetModuleDisplayNameByRuleComponent, + createGetSyntheticEventMeta, + createInitEventModule, + createLogActionError, + createLogConditionError, + createLogConditionNotMet, + createLogRuleCompleted, + createRunActions, + createTriggerRule, + getRuleComponentErrorMessage, + isConditionMet, + initRules, + normalizeRuleComponentError, + normalizeSyntheticEvent, + getNamespacedStorage, + hydrateModuleProvider, + hydrateSatelliteObject, + createSettingsFileTransformer +}) { + // this satellite variable needs to be a reference to the window._satellite object. + // we will modify it in place. + return function decorateSatellite(satellite) { + if (satellite && !window.__satelliteLoaded) { + // If a consumer loads the library multiple times, make sure only the first time is effective. + window.__satelliteLoaded = true; + + var container = satellite.container; + + // Remove container in public scope ASAP so it can't be manipulated by extension or user code. + delete satellite.container; + + /* + get rid of container.buildInfo decoration once deprecation is finished of + buildInfo.environment string + */ + var buildInfo = objectAssign({}, container.buildInfo); + Object.defineProperty(buildInfo, 'environment', { + get: function () { + logger.deprecation( + 'container.buildInfo.environment is deprecated.' + + 'Please use `container.environment.stage` instead' + ); + return container.environment.stage; + } + }); + container.buildInfo = buildInfo; + + var localStorage = getNamespacedStorage('localStorage'); + var debugController = createDebugController(localStorage, logger); + + var currentScriptSource = ''; + if ( + document.currentScript && + document.currentScript.getAttribute('src') + ) { + currentScriptSource = document.currentScript.getAttribute('src'); + } + var dynamicHostResolver; + try { + dynamicHostResolver = createDynamicHostResolver( + currentScriptSource, + Boolean(container.company.dynamicCdnEnabled), + container.company.cdnAllowList, + debugController + ); + } catch (e) { + logger.warn('Please review the following error:'); + throw e; // We don't want to continue allowing Turbine to start up if we detect an error in here + } + + var settingsFileTransformer = createSettingsFileTransformer( + dynamicHostResolver.isDynamicEnforced, + dynamicHostResolver.decorateWithDynamicHost + ); -var _satellite = window._satellite; + var moduleProvider = createModuleProvider(); + + var replaceTokens; + + var undefinedVarsReturnEmpty = + container.property.settings.undefinedVarsReturnEmpty; + var ruleComponentSequencingEnabled = + container.property.settings.ruleComponentSequencingEnabled; + + var dataElements = container.dataElements || {}; + + var getDataElementDefinition = function (name) { + return dataElements[name]; + }; + + // We support data elements referencing other data elements. In order to be able to retrieve a + // data element value, we need to be able to replace data element tokens inside its settings + // object (which is what replaceTokens is for). In order to be able to replace data element + // tokens inside a settings object, we need to be able to retrieve data element + // values (which is what getDataElementValue is for). This proxy replaceTokens function solves the + // chicken-or-the-egg problem by allowing us to provide a replaceTokens function to + // getDataElementValue that will stand in place of the real replaceTokens function until it + // can be created. This also means that createDataElementValue should not call the proxy + // replaceTokens function until after the real replaceTokens has been created. + var proxyReplaceTokens = function () { + return replaceTokens.apply(null, arguments); + }; + + var getDataElementValue = createGetDataElementValue( + moduleProvider, + getDataElementDefinition, + proxyReplaceTokens, + undefinedVarsReturnEmpty, + settingsFileTransformer + ); -if (_satellite && !window.__satelliteLoaded) { - // If a consumer loads the library multiple times, make sure only the first time is effective. - window.__satelliteLoaded = true; + var customVars = {}; + var setCustomVar = createSetCustomVar(customVars); - var container = _satellite.container; + var isVar = createIsVar(customVars, getDataElementDefinition); - // Remove container in public scope ASAP so it can't be manipulated by extension or user code. - delete _satellite.container; + var getVar = createGetVar( + customVars, + getDataElementDefinition, + getDataElementValue + ); - /* - get rid of container.buildInfo decoration once deprecation is finished of - buildInfo.environment string - */ - var buildInfo = objectAssign({}, container.buildInfo); - Object.defineProperty(buildInfo, 'environment', { - get: function () { - logger.deprecation( - 'container.buildInfo.environment is deprecated.' + - 'Please use `container.environment.stage` instead' + replaceTokens = createReplaceTokens( + isVar, + getVar, + undefinedVarsReturnEmpty ); - return container.environment.stage; - } - }); - container.buildInfo = buildInfo; - var localStorage = getNamespacedStorage('localStorage'); - var debugController = createDebugController(localStorage, logger); + // Important to hydrate satellite object before we hydrate the module provider or init rules. + // When we hydrate module provider, we also execute extension code which may be + // accessing _satellite. + hydrateSatelliteObject( + satellite, + container, + debugController.setDebugEnabled, + getVar, + setCustomVar + ); - var currentScriptSource = ''; - if (document.currentScript && document.currentScript.getAttribute('src')) { - currentScriptSource = document.currentScript.getAttribute('src'); - } - var dynamicHostResolver; - try { - dynamicHostResolver = createDynamicHostResolver( - currentScriptSource, - Boolean(container.company.dynamicCdnEnabled), - container.company.cdnAllowList, - debugController - ); - } catch (e) { - logger.warn('Please review the following error:'); - throw e; // We don't want to continue allowing Turbine to start up if we detect an error in here - } + hydrateModuleProvider( + container, + moduleProvider, + debugController, + replaceTokens, + getDataElementValue, + settingsFileTransformer, + dynamicHostResolver.decorateWithDynamicHost + ); - var settingsFileTransformer = createSettingsFileTransformer( - dynamicHostResolver.isDynamicEnforced, - dynamicHostResolver.decorateWithDynamicHost - ); + var notifyMonitors = createNotifyMonitors(satellite); + var executeDelegateModule = createExecuteDelegateModule( + moduleProvider, + replaceTokens, + settingsFileTransformer + ); - var moduleProvider = createModuleProvider(); + var getModuleDisplayNameByRuleComponent = + createGetModuleDisplayNameByRuleComponent(moduleProvider); + var logConditionNotMet = createLogConditionNotMet( + getModuleDisplayNameByRuleComponent, + logger, + notifyMonitors + ); + var logConditionError = createLogConditionError( + getRuleComponentErrorMessage, + getModuleDisplayNameByRuleComponent, + logger, + notifyMonitors + ); + var logActionError = createLogActionError( + getRuleComponentErrorMessage, + getModuleDisplayNameByRuleComponent, + logger, + notifyMonitors + ); + var logRuleCompleted = createLogRuleCompleted(logger, notifyMonitors); - var replaceTokens; + var evaluateConditions = createEvaluateConditions( + executeDelegateModule, + isConditionMet, + logConditionNotMet, + logConditionError + ); + var runActions = createRunActions( + executeDelegateModule, + logActionError, + logRuleCompleted + ); + var executeRule = createExecuteRule(evaluateConditions, runActions); + + var addConditionToQueue = createAddConditionToQueue( + executeDelegateModule, + normalizeRuleComponentError, + isConditionMet, + logConditionError, + logConditionNotMet + ); + var addActionToQueue = createAddActionToQueue( + executeDelegateModule, + normalizeRuleComponentError, + logActionError + ); + var addRuleToQueue = createAddRuleToQueue( + addConditionToQueue, + addActionToQueue, + logRuleCompleted + ); - var undefinedVarsReturnEmpty = - container.property.settings.undefinedVarsReturnEmpty; - var ruleComponentSequencingEnabled = - container.property.settings.ruleComponentSequencingEnabled; + var triggerRule = createTriggerRule( + ruleComponentSequencingEnabled, + executeRule, + addRuleToQueue, + notifyMonitors + ); - var dataElements = container.dataElements || {}; + var getSyntheticEventMeta = createGetSyntheticEventMeta(moduleProvider); - var getDataElementDefinition = function (name) { - return dataElements[name]; - }; + var initEventModule = createInitEventModule( + triggerRule, + executeDelegateModule, + normalizeSyntheticEvent, + getRuleComponentErrorMessage, + getSyntheticEventMeta, + logger + ); - // We support data elements referencing other data elements. In order to be able to retrieve a - // data element value, we need to be able to replace data element tokens inside its settings - // object (which is what replaceTokens is for). In order to be able to replace data element - // tokens inside a settings object, we need to be able to retrieve data element - // values (which is what getDataElementValue is for). This proxy replaceTokens function solves the - // chicken-or-the-egg problem by allowing us to provide a replaceTokens function to - // getDataElementValue that will stand in place of the real replaceTokens function until it - // can be created. This also means that createDataElementValue should not call the proxy - // replaceTokens function until after the real replaceTokens has been created. - var proxyReplaceTokens = function () { - return replaceTokens.apply(null, arguments); + initRules( + buildRuleExecutionOrder, + container.rules || [], + initEventModule + ); + } }; - - var getDataElementValue = createGetDataElementValue( - moduleProvider, - getDataElementDefinition, - proxyReplaceTokens, - undefinedVarsReturnEmpty, - settingsFileTransformer - ); - - var customVars = {}; - var setCustomVar = createSetCustomVar(customVars); - - var isVar = createIsVar(customVars, getDataElementDefinition); - - var getVar = createGetVar( - customVars, - getDataElementDefinition, - getDataElementValue - ); - - replaceTokens = createReplaceTokens(isVar, getVar, undefinedVarsReturnEmpty); - - // Important to hydrate satellite object before we hydrate the module provider or init rules. - // When we hydrate module provider, we also execute extension code which may be - // accessing _satellite. - hydrateSatelliteObject( - _satellite, - container, - debugController.setDebugEnabled, - getVar, - setCustomVar - ); - - hydrateModuleProvider( - container, - moduleProvider, - debugController, - replaceTokens, - getDataElementValue, - settingsFileTransformer, - dynamicHostResolver.decorateWithDynamicHost - ); - - var notifyMonitors = createNotifyMonitors(_satellite); - var executeDelegateModule = createExecuteDelegateModule( - moduleProvider, - replaceTokens, - settingsFileTransformer - ); - - var getModuleDisplayNameByRuleComponent = - createGetModuleDisplayNameByRuleComponent(moduleProvider); - var logConditionNotMet = createLogConditionNotMet( - getModuleDisplayNameByRuleComponent, - logger, - notifyMonitors - ); - var logConditionError = createLogConditionError( - getRuleComponentErrorMessage, - getModuleDisplayNameByRuleComponent, - logger, - notifyMonitors - ); - var logActionError = createLogActionError( - getRuleComponentErrorMessage, - getModuleDisplayNameByRuleComponent, - logger, - notifyMonitors - ); - var logRuleCompleted = createLogRuleCompleted(logger, notifyMonitors); - - var evaluateConditions = createEvaluateConditions( - executeDelegateModule, - isConditionMet, - logConditionNotMet, - logConditionError - ); - var runActions = createRunActions( - executeDelegateModule, - logActionError, - logRuleCompleted - ); - var executeRule = createExecuteRule(evaluateConditions, runActions); - - var addConditionToQueue = createAddConditionToQueue( - executeDelegateModule, - normalizeRuleComponentError, - isConditionMet, - logConditionError, - logConditionNotMet - ); - var addActionToQueue = createAddActionToQueue( - executeDelegateModule, - normalizeRuleComponentError, - logActionError - ); - var addRuleToQueue = createAddRuleToQueue( - addConditionToQueue, - addActionToQueue, - logRuleCompleted - ); - - var triggerRule = createTriggerRule( - ruleComponentSequencingEnabled, - executeRule, - addRuleToQueue, - notifyMonitors - ); - - var getSyntheticEventMeta = createGetSyntheticEventMeta(moduleProvider); - - var initEventModule = createInitEventModule( - triggerRule, - executeDelegateModule, - normalizeSyntheticEvent, - getRuleComponentErrorMessage, - getSyntheticEventMeta, - logger - ); - - initRules(buildRuleExecutionOrder, container.rules || [], initEventModule); } -// Rollup's iife option always sets a global with whatever is exported, so we'll set the -// _satellite global with the same object it already is (we've only modified it). -module.exports = _satellite; +var decorateSatellite = validateInjectedParams( + indexDependencyInjector({ + logger: require('./logger'), + document: require('@adobe/reactor-document'), + objectAssign: require('@adobe/reactor-object-assign'), + createDynamicHostResolver: require('./createDynamicHostResolver'), + buildRuleExecutionOrder: require('./buildRuleExecutionOrder'), + createDebugController: require('./createDebugController'), + createExecuteDelegateModule: require('./createExecuteDelegateModule'), + createGetDataElementValue: require('./createGetDataElementValue'), + createGetVar: require('./createGetVar'), + createIsVar: require('./createIsVar'), + createModuleProvider: require('./createModuleProvider'), + createNotifyMonitors: require('./createNotifyMonitors'), + createReplaceTokens: require('./createReplaceTokens'), + createSetCustomVar: require('./createSetCustomVar'), + createAddActionToQueue: require('./rules/createAddActionToQueue'), + createAddConditionToQueue: require('./rules/createAddConditionToQueue'), + createAddRuleToQueue: require('./rules/createAddRuleToQueue'), + createEvaluateConditions: require('./rules/createEvaluateConditions'), + createExecuteRule: require('./rules/createExecuteRule'), + createGetModuleDisplayNameByRuleComponent: require('./rules/createGetModuleDisplayNameByRuleComponent'), + createGetSyntheticEventMeta: require('./rules/createGetSyntheticEventMeta'), + createInitEventModule: require('./rules/createInitEventModule'), + createLogActionError: require('./rules/createLogActionError'), + createLogConditionError: require('./rules/createLogConditionError'), + createLogConditionNotMet: require('./rules/createLogConditionNotMet'), + createLogRuleCompleted: require('./rules/createLogRuleCompleted'), + createRunActions: require('./rules/createRunActions'), + createTriggerRule: require('./rules/createTriggerRule'), + getRuleComponentErrorMessage: require('./rules/getRuleComponentErrorMessage'), + isConditionMet: require('./rules/isConditionMet'), + initRules: require('./rules/initRules'), + normalizeRuleComponentError: require('./rules/normalizeRuleComponentError'), + normalizeSyntheticEvent: require('./rules/normalizeSyntheticEvent'), + getNamespacedStorage: require('./getNamespacedStorage'), + hydrateModuleProvider: require('./hydrateModuleProvider'), + hydrateSatelliteObject: require('./hydrateSatelliteObject'), + createSettingsFileTransformer: require('./createSettingsFileTransformer') + }) +); + +if (REACTOR_KARMA_CI_UNIT_TEST_MODE) { + /* START.TESTS_ONLY */ + module.exports.injectIndex = validateInjectedParams(indexDependencyInjector); + /* END.TESTS_ONLY */ +} else { + // Forge is outputting an IIFE that defines window._satellite + var _satellite = window._satellite; + decorateSatellite(_satellite); + module.exports = _satellite; +} diff --git a/src/logger.js b/src/logger.js index 46656a05..632266cf 100644 --- a/src/logger.js +++ b/src/logger.js @@ -51,6 +51,19 @@ var launchPrefix = ieVersion === 10 ? '[Launch]' : ROCKET; */ var outputEnabled = false; +/** + * Maximum number of deduplicated deprecation messages to hold when outputEnabled is false. + * This bounds memory usage. + * @type {number} + */ +var MAX_DEPRECATION_CACHE_SIZE = 100; + +/** + * Set to track deduplicated deprecation messages when outputEnabled is false. + * @type {Set} + */ +var dedupDeprecationMessages = new Set(); + /** * Processes a log message. * @param {string} level The level of message to log. @@ -76,15 +89,14 @@ var process = function (level) { var log = process.bind(null, levels.LOG); /** - * Outputs informational message to the web console. In some browsers a small "i" icon is - * displayed next to these items in the web console's log. + * Outputs informational message to the web console. * @param {...*} arg Any argument to be logged. */ var info = process.bind(null, levels.INFO); /** - * Outputs debug message to the web console. In browsers that do not support - * console.debug, console.info is used instead. + * Outputs debug message to the web console. + * In browsers that do not support console.debug, console.info is used instead. * @param {...*} arg Any argument to be logged. */ var debug = process.bind(null, levels.DEBUG); @@ -102,40 +114,60 @@ var warn = process.bind(null, levels.WARN); var error = process.bind(null, levels.ERROR); /** - * Outputs a warning message to the web console. - * @param {...*} arg Any argument to be logged. + * Outputs a deprecation warning to the web console. + * Deduplicates messages when output is disabled. + * Passes all through when output is enabled. + * @param {string} message The deprecation message. + * @param {...*} additionalArgs Additional optional args. */ var logDeprecation = function () { - var wasEnabled = outputEnabled; - outputEnabled = true; + var message = arguments[0]; - process.apply( - null, - Array.prototype.concat(levels.WARN, Array.prototype.slice.call(arguments)) - ); + if (typeof message !== 'string') { + message = String(message); + } - if (!wasEnabled) { - outputEnabled = false; + // Always log when output is enabled + if (outputEnabled) { + process.apply( + null, + [levels.WARN].concat(Array.prototype.slice.call(arguments)) + ); + return; } + + // When output is disabled: only log first time per unique message + if (!dedupDeprecationMessages.has(message)) { + dedupDeprecationMessages.add(message); + + // Maintain bounded size + if (dedupDeprecationMessages.size > MAX_DEPRECATION_CACHE_SIZE) { + var first = dedupDeprecationMessages.values().next().value; + dedupDeprecationMessages.delete(first); + } + + // Log even though outputEnabled is false (just once per unique message) + var wasEnabled = outputEnabled; + outputEnabled = true; + process.apply( + null, + [levels.WARN].concat(Array.prototype.slice.call(arguments)) + ); + outputEnabled = wasEnabled; + } + + // Already logged → suppress }; -module.exports = { +// Build the module exports object +var loggerExports = { log: log, info: info, debug: debug, warn: warn, error: error, deprecation: logDeprecation, - /** - * Whether logged messages should be output to the console. - * @type {boolean} - */ - get outputEnabled() { - return outputEnabled; - }, - set outputEnabled(value) { - outputEnabled = value; - }, + /** * Creates a logging utility that only exposes logging functionality and prefixes all messages * with an identifier. @@ -152,3 +184,21 @@ module.exports = { }; } }; + +// Define outputEnabled getter/setter with deduplication flush behavior +Object.defineProperty(loggerExports, 'outputEnabled', { + get: function () { + return outputEnabled; + }, + set: function (value) { + if (outputEnabled === false && value === true) { + // Flush deduplication set on enable + dedupDeprecationMessages.clear(); + } + outputEnabled = value; + }, + enumerable: true, + configurable: true +}); + +module.exports = loggerExports; diff --git a/src/rules/__tests__/normalizeSyntheticEvent.test.js b/src/rules/__tests__/normalizeSyntheticEvent.test.js index 2995ac6b..9c0b46ab 100644 --- a/src/rules/__tests__/normalizeSyntheticEvent.test.js +++ b/src/rules/__tests__/normalizeSyntheticEvent.test.js @@ -12,8 +12,10 @@ 'use strict'; -var injectNormalizeSyntheticEvent = require('inject-loader!../normalizeSyntheticEvent'); +var { injectNormalizeSyntheticEvent } = require('../normalizeSyntheticEvent'); var CustomEventShim = require('./helpers/CustomEventShim'); +var objectAssign = require('@adobe/reactor-object-assign'); +var { isPlainObject } = require('is-plain-object'); var mockMeta = { $type: 'extension-name.event-name', @@ -23,16 +25,18 @@ var mockMeta = { }; describe('normalizeSyntheticEvent', function () { - var logger; + var loggerMock; var normalizeSyntheticEvent; beforeEach(function () { - logger = { + loggerMock = { deprecation: jasmine.createSpy() }; normalizeSyntheticEvent = injectNormalizeSyntheticEvent({ - '../logger': logger + objectAssign, + isPlainObject, + logger: loggerMock }); }); @@ -93,7 +97,7 @@ describe('normalizeSyntheticEvent', function () { // Note that the type property is non-enumerable, which is why the other tests pass without // accounting for the type property. expect(syntheticEvent.type).toBe('extension-name.event-name'); - expect(logger.deprecation).toHaveBeenCalledWith( + expect(loggerMock.deprecation).toHaveBeenCalledWith( 'Accessing event.type in Adobe Launch has been ' + 'deprecated and will be removed soon. Please use event.$type instead.' ); diff --git a/src/rules/normalizeSyntheticEvent.js b/src/rules/normalizeSyntheticEvent.js index c73f298c..ab27900c 100644 --- a/src/rules/normalizeSyntheticEvent.js +++ b/src/rules/normalizeSyntheticEvent.js @@ -10,42 +10,45 @@ * governing permissions and limitations under the License. ****************************************************************************************/ -var logger = require('../logger'); -var objectAssign = require('@adobe/reactor-object-assign'); -var { isPlainObject } = require('is-plain-object'); +var validateInjectedParams = require('../helpers/validate-injected-params'); -/** - * Normalizes a synthetic event so that it exists and has at least meta. - * @param {Object} syntheticEventMeta - * @param {Object} [syntheticEvent] - * @returns {Object} - */ -module.exports = function (syntheticEventMeta, syntheticEvent) { - syntheticEvent = syntheticEvent || {}; +function injectNormalizeSyntheticEvent({ + objectAssign, + isPlainObject, + logger +}) { + return function normalizeSyntheticEvent(syntheticEventMeta, syntheticEvent) { + syntheticEvent = syntheticEvent || {}; + if (isPlainObject(syntheticEvent)) { + syntheticEvent = objectAssign({}, syntheticEvent, syntheticEventMeta); + } else { + objectAssign(syntheticEvent, syntheticEventMeta); + } + if (!syntheticEvent.hasOwnProperty('type')) { + Object.defineProperty(syntheticEvent, 'type', { + get: function () { + logger.deprecation( + 'Accessing event.type in Adobe Launch has been deprecated and will be ' + + 'removed soon. Please use event.$type instead.' + ); + return syntheticEvent.$type; + } + }); + } + return syntheticEvent; + }; +} - // This ensures that as the user hands us a synthetic event for multiple rules, - // we aren't overwriting a new meta into the same object reference. - if (isPlainObject(syntheticEvent)) { - syntheticEvent = objectAssign({}, syntheticEvent, syntheticEventMeta); - } else { - // When syntheticEvent is not an object, there's nothing we can guarantee - // about the ability to "copy". Leave it alone. - objectAssign(syntheticEvent, syntheticEventMeta); - } +const validateInjection = validateInjectedParams(injectNormalizeSyntheticEvent); - // Remove after some arbitrary time period when we think users have had sufficient chance - // to move away from event.type - if (!syntheticEvent.hasOwnProperty('type')) { - Object.defineProperty(syntheticEvent, 'type', { - get: function () { - logger.deprecation( - 'Accessing event.type in Adobe Launch has been deprecated and will be ' + - 'removed soon. Please use event.$type instead.' - ); - return syntheticEvent.$type; - } - }); - } +module.exports = validateInjection({ + objectAssign: require('@adobe/reactor-object-assign'), + isPlainObject: require('is-plain-object').isPlainObject, + logger: require('../logger') +}); - return syntheticEvent; -}; +if (REACTOR_KARMA_CI_UNIT_TEST_MODE) { + /* START.TESTS_ONLY */ + module.exports.injectNormalizeSyntheticEvent = validateInjection; + /* END.TESTS_ONLY */ +} diff --git a/test-results/.last-run.json b/test-results/.last-run.json new file mode 100644 index 00000000..cbcc1fba --- /dev/null +++ b/test-results/.last-run.json @@ -0,0 +1,4 @@ +{ + "status": "passed", + "failedTests": [] +} \ No newline at end of file diff --git a/test.integrationIndex.js b/test.integrationIndex.js new file mode 100644 index 00000000..f2ab02d8 --- /dev/null +++ b/test.integrationIndex.js @@ -0,0 +1,21 @@ +/*************************************************************************************** + * (c) 2025 Adobe. All rights reserved. + * This file is licensed to you under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. You may obtain a copy + * of the License at http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under + * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS + * OF ANY KIND, either express or implied. See the License for the specific language + * governing permissions and limitations under the License. + ****************************************************************************************/ + +'use strict'; + +// Only run integration tests +var testsContext = require.context( + './src/__integration__/faked-containers', + true, + /\.test\.jsx?$/ +); +testsContext.keys().forEach(testsContext); diff --git a/testIndex.js b/test.unitIndex.js similarity index 53% rename from testIndex.js rename to test.unitIndex.js index dc3518b9..c2df9757 100644 --- a/testIndex.js +++ b/test.unitIndex.js @@ -1,5 +1,5 @@ /*************************************************************************************** - * (c) 2019 Adobe. All rights reserved. + * (c) 2025 Adobe. All rights reserved. * This file is licensed to you under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. You may obtain a copy * of the License at http://www.apache.org/licenses/LICENSE-2.0 @@ -12,20 +12,38 @@ 'use strict'; -// Engine tests -var testsContext = require.context('./src', true, /__tests__\/.*\.test\.jsx?$/); +// First, run integrity / sanity tests for production files that export an "injected" function +require('./src/__tests__/production-exports.integrity.test.js'); + +// Load unit tests from __tests__ directories, excluding integrity tests +var testsContext = require.context( + './src', + true, + /__tests__\/(?!.*integrity\.test\.).*\.test\.jsx?$/ +); + testsContext.keys().forEach(testsContext); -// This is necessary for the coverage report to show all source files even when they're not -// included by tests. https://github.com/webpack-contrib/istanbul-instrumenter-loader/issues/15 -var srcContext = require.context('./src', true, /^((?!__tests__).)*\.jsx?$/); +// Coverage for all non-test code in src (exclude __tests__ and __integration__) +var srcContext = require.context( + './src', + true, + /^((?!(__tests__|__integration__)).)*\.jsx?$/ +); srcContext.keys().forEach(srcContext); -// Core module package tests -testsContext = require.context('./coreModulePackages', true, /^.\/[^\/]*\/test\.js/); +// Core module tests +testsContext = require.context( + './coreModulePackages', + true, + /^.\/[^\/]*\/test\.js/ +); testsContext.keys().forEach(testsContext); -// This is necessary for the coverage report to show all source files even when they're not -// included by tests. https://github.com/webpack-contrib/istanbul-instrumenter-loader/issues/15 -srcContext = require.context('./coreModulePackages', true, /^.\/[^\/]*\/index\.js/); +// Coverage for core module source +srcContext = require.context( + './coreModulePackages', + true, + /^.\/[^\/]*\/index\.js/ +); srcContext.keys().forEach(srcContext); diff --git a/verify-no-test-code.sh b/verify-no-test-code.sh new file mode 100755 index 00000000..01e6245b --- /dev/null +++ b/verify-no-test-code.sh @@ -0,0 +1,32 @@ +#!/bin/bash +# ========================================= +# (c) 2025 Adobe. All rights reserved. +# This file is licensed to you under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. You may obtain a copy +# of the License at http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software distributed under +# the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS +# OF ANY KIND, either express or implied. See the License for the specific language +# governing permissions and limitations under the License. +# ========================================= + +set -e + +PATTERNS=("injectIndex" "REACTOR_KARMA_CI_UNIT_TEST_MODE") +FILES=("dist/engine.js" "dist/engine.min.js") + +for FILE in "${FILES[@]}"; do + if [ ! -f "$FILE" ]; then + echo "❌ $FILE is missing!" + exit 1 + fi + for PATTERN in "${PATTERNS[@]}"; do + if grep -q "$PATTERN" "$FILE"; then + echo "❌ Found '$PATTERN' in $FILE!" + exit 1 + fi + done +done + +echo "✅ No test-only code found. dist/engine.js and dist/engine.min.js are ready for production."