diff --git a/.github/workflows/deploy-mcp-runtime.yml b/.github/workflows/deploy-mcp-runtime.yml new file mode 100644 index 000000000..fcf9a1b87 --- /dev/null +++ b/.github/workflows/deploy-mcp-runtime.yml @@ -0,0 +1,64 @@ +name: Deploy MCP Runtime Actions + +on: + push: + branches: + - main + paths: + - 'io/mcp-server/**' + - '.github/workflows/deploy-mcp-runtime.yml' + workflow_dispatch: + +jobs: + deploy: + runs-on: ubuntu-latest + + steps: + - name: Checkout code + uses: actions/checkout@v4 + + - name: Setup Node.js + uses: actions/setup-node@v4 + with: + node-version: '22' + cache: 'npm' + cache-dependency-path: io/mcp-server/package-lock.json + + - name: Install Adobe I/O CLI + run: npm install -g @adobe/aio-cli + + - name: Configure Adobe I/O CLI + env: + AIO_RUNTIME_NAMESPACE: ${{ secrets.AIO_RUNTIME_NAMESPACE }} + AIO_RUNTIME_AUTH: ${{ secrets.AIO_RUNTIME_AUTH }} + run: | + aio config:set runtime.namespace $AIO_RUNTIME_NAMESPACE + aio config:set runtime.auth $AIO_RUNTIME_AUTH + + - name: Install dependencies + working-directory: io/mcp-server + run: npm ci + + - name: Deploy to Adobe I/O Runtime + working-directory: io/mcp-server + env: + AEM_BASE_URL: ${{ secrets.AEM_BASE_URL }} + STUDIO_BASE_URL: ${{ secrets.STUDIO_BASE_URL }} + run: aio app deploy --all + + - name: Verify deployment + working-directory: io/mcp-server + run: aio runtime action list + + - name: Deployment summary + run: | + echo "✅ MCP Runtime actions deployed successfully" + echo "" + echo "Deployed actions:" + echo " - publish-card" + echo " - unpublish-card" + echo " - get-card" + echo " - search-cards" + echo " - delete-card" + echo " - copy-card" + echo " - update-card" diff --git a/.gitignore b/.gitignore index 28e0bfffa..2bbb9083f 100644 --- a/.gitignore +++ b/.gitignore @@ -30,6 +30,7 @@ nala/.auth/ .claude/ .logs/ .specify/ +.superpowers/ .worktrees/ .pids /specs/ @@ -56,3 +57,7 @@ web-components/commerce.json web-components/mas.json web-components/stats.json *.jsonl + +# MWPW-183572 workspace-local (not shipped with PR) +io/knowledge/ +.claude diff --git a/io/mcp-server/DEPLOYMENT.md b/io/mcp-server/DEPLOYMENT.md new file mode 100644 index 000000000..c59273e6a --- /dev/null +++ b/io/mcp-server/DEPLOYMENT.md @@ -0,0 +1,141 @@ +# MCP Runtime Deployment Guide + +> **Note (MWPW-183572):** the Studio frontend has already been migrated +> to call Runtime actions directly — see `studio/src/constants.js` +> `MCP_SERVER_URL` and `getMCPServerURL()`. The post-deployment steps +> below describe that historical migration; treat them as reference +> material, not a current checklist. The retired Express bridge on +> port 3001 has been removed. + +## Post-Deployment: Update Studio Frontend (historical) + +After deploying the Runtime actions, update the Studio frontend to use the Runtime URLs. + +### 1. Get Runtime Action URLs + +After deployment, get your action URLs: + +```bash +aio runtime action get publish-card --url +``` + +The URL will look like: +``` +https://adobeioruntime.net/api/v1/web//MerchAtScaleMCP/publish-card +``` + +### 2. Update Studio Constants + +Edit [`studio/src/constants.js`](../../studio/src/constants.js) line 150: + +**Before:** +```javascript +export const MCP_SERVER_URL = window.location.hostname === 'localhost' ? 'http://localhost:3001' : 'https://mas-mcp.adobe.com'; +``` + +**After:** +```javascript +export const MCP_SERVER_URL = window.location.hostname === 'localhost' + ? 'http://localhost:3001' + : 'https://adobeioruntime.net/api/v1/web//MerchAtScaleMCP'; +``` + +### 3. Update MCP Client + +The Studio MCP client ([`studio/src/services/mcp-client.js`](../../studio/src/services/mcp-client.js)) will need to use the Runtime action names instead of the `/tools/:toolName` pattern: + +**Current:** +```javascript +const response = await fetch(`${MCP_SERVER_URL}/tools/${toolName}`, { + method: 'POST', + headers, + body: JSON.stringify(requestBody), +}); +``` + +**Update to:** +```javascript +const response = await fetch(`${MCP_SERVER_URL}/${toolName.replace('studio_', '')}`, { + method: 'POST', + headers, + body: JSON.stringify(requestBody), +}); +``` + +This maps: +- `studio_publish_card` → `publish-card` +- `studio_search_cards` → `search-cards` +- etc. + +### 4. Test the Integration + +1. Deploy the Runtime actions +2. Update Studio constants with the Runtime URL +3. Test each operation in Studio AI chat: + - "publish this card" + - "search for fries cards" + - "copy this card" + - etc. + +### 5. Environment-Specific URLs + +For different environments: + +**Development (localhost):** +```javascript +MCP_SERVER_URL = 'http://localhost:3001' +``` + +**Staging:** +```javascript +MCP_SERVER_URL = 'https://adobeioruntime.net/api/v1/web/stage-namespace/MerchAtScaleMCP' +``` + +**Production:** +```javascript +MCP_SERVER_URL = 'https://adobeioruntime.net/api/v1/web/prod-namespace/MerchAtScaleMCP' +``` + +## Rollback Plan + +If Runtime actions have issues, rollback to the Express server: + +1. Start the Express MCP server: + ```bash + cd mas-mcp-server + npm run http + ``` + +2. Revert Studio constants to point to `https://mas-mcp.adobe.com` + +3. Investigate Runtime issues using action logs: + ```bash + aio runtime activation list + aio runtime activation logs + ``` + +## Monitoring + +### Check Action Status +```bash +aio runtime action list +``` + +### View Recent Activations +```bash +aio runtime activation list --limit 10 +``` + +### Get Action Logs +```bash +aio runtime activation logs +``` + +### Action Metrics +View in Adobe I/O Console → Runtime → Actions → Select action → Metrics + +## Security + +Runtime actions use Adobe IMS authentication via the `require-adobe-auth: true` annotation. Users must be authenticated with Adobe IMS to call these actions. + +The Studio frontend passes the IMS access token in the `Authorization` header, which the Runtime action extracts from `__ow_headers.authorization`. diff --git a/io/mcp-server/README.md b/io/mcp-server/README.md new file mode 100644 index 000000000..8237ec378 --- /dev/null +++ b/io/mcp-server/README.md @@ -0,0 +1,131 @@ +# MAS MCP Server - Adobe I/O Runtime Actions + +Adobe I/O Runtime actions for MAS Studio MCP operations. These serverless functions provide AEM Content Fragment operations for Studio's AI chat. + +## Architecture + +This is the production deployment of the MAS MCP Server using Adobe I/O Runtime. It replaces the local Express HTTP server with serverless functions that auto-deploy on git push. + +### Actions + +- **publish-card**: Publish a card to production +- **unpublish-card**: Unpublish a card from production +- **get-card**: Get card details by ID +- **search-cards**: Search for cards with filters +- **delete-card**: Delete a card +- **copy-card**: Copy/duplicate a card +- **update-card**: Update card fields + +## Local Development + +### Prerequisites + +- Node.js 22+ +- Adobe I/O CLI: `npm install -g @adobe/aio-cli` +- Adobe I/O Runtime credentials + +### Setup + +1. Install dependencies: + ```bash + cd io/mcp-server + npm install + ``` + +2. Configure Adobe I/O CLI: + ```bash + aio config:set runtime.namespace + aio config:set runtime.auth + ``` + +3. Shared libraries (auth-manager, aem-client, studio-url-builder, + studio-operations) now live directly in `src/lib/`. The previous + copy-from-`mas-mcp-server` step is no longer required. + +### Deploy + +Deploy all actions: +```bash +aio app deploy --all +``` + +Deploy specific action: +```bash +aio app deploy -a publish-card +``` + +### Test + +List deployed actions: +```bash +aio runtime action list +``` + +Invoke action directly: +```bash +aio runtime action invoke publish-card --param id --result +``` + +## Auto-Deployment + +The GitHub Actions workflow [`.github/workflows/deploy-mcp-runtime.yml`](../../.github/workflows/deploy-mcp-runtime.yml) automatically deploys actions when changes are pushed to `main` branch. + +### Required Secrets + +Configure these in GitHub repository settings: + +- `AIO_RUNTIME_NAMESPACE`: Adobe I/O Runtime namespace +- `AIO_RUNTIME_AUTH`: Adobe I/O Runtime auth token +- `AEM_BASE_URL`: AEM author URL (e.g., `https://author-p133911-e1313554.adobeaemcloud.com`) +- `STUDIO_BASE_URL`: Studio base URL (e.g., `https://mas.adobe.com/studio.html`) + +## Runtime URLs + +After deployment, actions are available at: +``` +https://adobeioruntime.net/api/v1/web//MerchAtScaleMCP/ +``` + +Example: +``` +https://adobeioruntime.net/api/v1/web/prod-namespace/MerchAtScaleMCP/publish-card +``` + +## Local development + +Run `aio app dev` from this directory to start the Runtime actions +locally. Studio's MCP client (`studio/src/services/mcp-client.js`) +routes to your local dev server when the Studio URL includes +`?mcp.server=`. + +The former local Express bridge (`mas-mcp-server/src/http-server.js`) +has been retired — it duplicated the Runtime actions over a separate +port (3001) without giving anything the Runtime dev server doesn't +already give. The stdio MCP entry in `mas-mcp-server/src/index.js` +stays for Claude Code / Cursor clients. +| **Scaling** | Single instance | Auto-scales | + +## Troubleshooting + +### View action logs +```bash +aio runtime activation list +aio runtime activation logs +``` + +### Test authentication +```bash +curl -H "Authorization: Bearer " \ + https://adobeioruntime.net/api/v1/web//MerchAtScaleMCP/get-card?id= +``` + +### Undeploy actions +```bash +aio app undeploy +``` + +## Related Documentation + +- [MAS MCP Server (Express)](../../mas-mcp-server/README.md) +- [Adobe I/O Runtime Documentation](https://developer.adobe.com/runtime/docs/) +- [Studio MCP Integration](../../MCP_INTEGRATION.md) diff --git a/io/mcp-server/app.config.yaml b/io/mcp-server/app.config.yaml new file mode 100644 index 000000000..5242e63d4 --- /dev/null +++ b/io/mcp-server/app.config.yaml @@ -0,0 +1,334 @@ +application: + actions: actions + hooks: + test: npm run test + runtimeManifest: + packages: + MerchAtScaleMCP: + license: Apache-2.0 + actions: + publish-card: + function: src/actions/publish-card.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + unpublish-card: + function: src/actions/unpublish-card.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + get-card: + function: src/actions/get-card.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + search-cards: + function: src/actions/search-cards.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + delete-card: + function: src/actions/delete-card.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + copy-card: + function: src/actions/copy-card.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + update-card: + function: src/actions/update-card.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + bulk-update-cards: + function: src/actions/bulk-update-cards.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + STUDIO_BASE_URL: $STUDIO_BASE_URL + limits: + timeout: 300000 + annotations: + require-adobe-auth: false + final: true + bulk-publish-cards: + function: src/actions/bulk-publish-cards.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + STUDIO_BASE_URL: $STUDIO_BASE_URL + limits: + timeout: 300000 + annotations: + require-adobe-auth: false + final: true + bulk-delete-cards: + function: src/actions/bulk-delete-cards.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + STUDIO_BASE_URL: $STUDIO_BASE_URL + limits: + timeout: 300000 + annotations: + require-adobe-auth: false + final: true + get-job-status: + function: src/actions/get-job-status.js + web: 'yes' + runtime: nodejs:22 + annotations: + require-adobe-auth: false + final: true + preview-bulk-update: + function: src/actions/preview-bulk-update.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + preview-bulk-publish: + function: src/actions/preview-bulk-publish.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + preview-bulk-delete: + function: src/actions/preview-bulk-delete.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + get-fragment-variations: + function: src/actions/get-fragment-variations.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + create-card: + function: src/actions/create-card.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + create-collection: + function: src/actions/create-collection.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + get-collection: + function: src/actions/get-collection.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + add-cards-to-collection: + function: src/actions/add-cards-to-collection.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + search-collections: + function: src/actions/search-collections.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + search-offers: + function: src/actions/search-offers.js + web: 'yes' + runtime: nodejs:22 + inputs: + AOS_URL: $AOS_URL + AOS_API_KEY: $AOS_API_KEY + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + get-offer-by-id: + function: src/actions/get-offer-by-id.js + web: 'yes' + runtime: nodejs:22 + inputs: + AOS_URL: $AOS_URL + AOS_API_KEY: $AOS_API_KEY + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + list-products: + function: src/actions/list-products.js + web: 'yes' + runtime: nodejs:22 + inputs: + PRODUCTS_ENDPOINT: $PRODUCTS_ENDPOINT + annotations: + require-adobe-auth: false + final: true + get-product-detail: + function: src/actions/get-product-detail.js + web: 'yes' + runtime: nodejs:22 + inputs: + AOS_URL: $AOS_URL + AOS_API_KEY: $AOS_API_KEY + annotations: + require-adobe-auth: false + final: true + compare-offers: + function: src/actions/compare-offers.js + web: 'yes' + runtime: nodejs:22 + inputs: + AOS_URL: $AOS_URL + AOS_API_KEY: $AOS_API_KEY + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + create-offer-selector: + function: src/actions/create-offer-selector.js + web: 'yes' + runtime: nodejs:22 + inputs: + AOS_URL: $AOS_URL + AOS_API_KEY: $AOS_API_KEY + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + resolve-offer-selector: + function: src/actions/resolve-offer-selector.js + web: 'yes' + runtime: nodejs:22 + inputs: + AOS_URL: $AOS_URL + AOS_API_KEY: $AOS_API_KEY + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + link-card-to-offer: + function: src/actions/link-card-to-offer.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + AOS_URL: $AOS_URL + AOS_API_KEY: $AOS_API_KEY + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + validate-card-offer: + function: src/actions/validate-card-offer.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + AOS_URL: $AOS_URL + AOS_API_KEY: $AOS_API_KEY + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true + create-release-cards: + function: src/actions/create-release-cards.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + STUDIO_BASE_URL: $STUDIO_BASE_URL + AOS_URL: $AOS_URL + AOS_API_KEY: $AOS_API_KEY + limits: + timeout: 300000 + annotations: + require-adobe-auth: false + final: true + list-context-cards: + function: src/actions/list-context-cards.js + web: 'yes' + runtime: nodejs:22 + inputs: + AEM_BASE_URL: $AEM_BASE_URL + STUDIO_BASE_URL: $STUDIO_BASE_URL + annotations: + require-adobe-auth: false + final: true diff --git a/io/mcp-server/package-lock.json b/io/mcp-server/package-lock.json new file mode 100644 index 000000000..892b27bf1 --- /dev/null +++ b/io/mcp-server/package-lock.json @@ -0,0 +1,5423 @@ +{ + "name": "MerchAtScaleMCP", + "version": "1.0.0", + "lockfileVersion": 3, + "requires": true, + "packages": { + "": { + "name": "MerchAtScaleMCP", + "version": "1.0.0", + "dependencies": { + "@adobe/aio-lib-ims": "^7.0.2", + "@adobe/aio-lib-state": "^5.1.0", + "@adobe/aio-sdk": "^6", + "node-fetch": "^2.6.0" + }, + "devDependencies": { + "chai": "^4.3.6", + "eslint": "^8", + "mocha": "^10.2.0" + }, + "engines": { + "node": ">=22" + } + }, + "node_modules/@adobe/aio-lib-analytics": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/@adobe/aio-lib-analytics/-/aio-lib-analytics-4.0.2.tgz", + "integrity": "sha512-/arNqy84uKTTgd99sf2ANejiIuka31T2x8eH8hkdnozGl4nuuhnRqYKI+BnrEet017aha7s/FbNe3rUdNs4a2Q==", + "dependencies": { + "@adobe/aio-lib-core-errors": "^4", + "@adobe/aio-lib-core-logging": "^3", + "swagger-client": "^3.35.6" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/@adobe/aio-lib-campaign-standard/-/aio-lib-campaign-standard-4.0.2.tgz", + "integrity": "sha512-SdmNhRh+boPeNT5gwuMc5DNsfW7SGQ6/KUOc7FLvLpr8qUBrOtjEbdtHiq36TVlBwxXpSa/TK3xt6nd9Hyfzvw==", + "license": "Apache-2.0", + "dependencies": { + "@adobe/aio-lib-core-errors": "^4", + "@adobe/aio-lib-core-logging": "^3", + "@adobe/aio-lib-core-networking": "^5", + "swagger-client": "3.34.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-core": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-core/-/apidom-core-1.0.0-beta.51.tgz", + "integrity": "sha512-vDtp1bUWm91S3Pn2Ry2ksZOfZPDiOQIhdkpB/Q0Jy6cRJCIz/IPiLWTfUaypmPCRcxcnyOXEUCSPWd+jKHKRMw==", + "license": "Apache-2.0", + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-ast": "^1.0.0-beta.51", + "@swagger-api/apidom-error": "^1.0.0-beta.51", + "@types/ramda": "~0.30.0", + "minim": "~0.23.8", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "short-unique-id": "^5.3.2", + "ts-mixer": "^6.0.3" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-error": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-error/-/apidom-error-1.0.0-beta.51.tgz", + "integrity": "sha512-8Q1ghVuN83si6v6y/hiUYAXCDsSQEiWYHyyD1IzlDBb/f+lGu78nqaBC3cduvv/rMS1nLv8gvhMd2Gs//eDAhg==", + "license": "Apache-2.0", + "dependencies": { + "@babel/runtime-corejs3": "^7.20.7" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-json-pointer": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-json-pointer/-/apidom-json-pointer-1.0.0-beta.51.tgz", + "integrity": "sha512-GiVTAFr5GwmJY+80w2E9cMuQikPm3bvrlab/6m01N1mR9m/w/kmVD+3CQKAvPN5mIzapLgHZxOLiz2upf0cemw==", + "license": "Apache-2.0", + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-beta.51", + "@swagger-api/apidom-error": "^1.0.0-beta.51", + "@swaggerexpert/json-pointer": "^2.10.1" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-ns-arazzo-1": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-ns-arazzo-1/-/apidom-ns-arazzo-1-1.0.0-beta.51.tgz", + "integrity": "sha512-AM80F1f6ii/is6GOCd7RGpeTPoxA1dwy8YCLzAUJqCeEJqtCo3cjuoBqkxNRhipt/0+euauxdHyItiGGlybiBw==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-beta.51", + "@swagger-api/apidom-ns-json-schema-2020-12": "^1.0.0-beta.51", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "ts-mixer": "^6.0.3" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-ns-asyncapi-2": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-ns-asyncapi-2/-/apidom-ns-asyncapi-2-1.0.0-beta.51.tgz", + "integrity": "sha512-iSkd1NaTG3Dd5cmFpZPirjc3xev66Rx30/G3ETyb2k/kuJQqpYpVv8ctCAZmRsaaY175jqk6OwQd06EyAvPgMg==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-beta.51", + "@swagger-api/apidom-ns-json-schema-draft-7": "^1.0.0-beta.51", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "ts-mixer": "^6.0.3" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-ns-openapi-2": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-ns-openapi-2/-/apidom-ns-openapi-2-1.0.0-beta.51.tgz", + "integrity": "sha512-Pv2rPjywIhs0kl8nkWhy5UXbqthHihcXVdNdVJF1aHDBt5VVh49VIWvM+8ngDeCad/xTPQYjeyiURX986kv/ww==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-beta.51", + "@swagger-api/apidom-error": "^1.0.0-beta.51", + "@swagger-api/apidom-ns-json-schema-draft-4": "^1.0.0-beta.51", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "ts-mixer": "^6.0.3" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-ns-openapi-3-0": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-ns-openapi-3-0/-/apidom-ns-openapi-3-0-1.0.0-beta.51.tgz", + "integrity": "sha512-noFmJAQEdrS+Dm662PiJ0fzxzylz/2WzY3ZHdhbs+pVk6RY8pQsfZMIaWSzs6OTZ7BTKzxW1DvTauFRbtPxIeA==", + "license": "Apache-2.0", + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-beta.51", + "@swagger-api/apidom-error": "^1.0.0-beta.51", + "@swagger-api/apidom-ns-json-schema-draft-4": "^1.0.0-beta.51", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "ts-mixer": "^6.0.3" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-ns-openapi-3-1": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-ns-openapi-3-1/-/apidom-ns-openapi-3-1-1.0.0-beta.51.tgz", + "integrity": "sha512-CKFZxo8sNd4SPwEmn5z+WzUBPENPMznQ64PDws/CAdJo++YwXuzeI+A6Ut1WPtB3A6n30cmYBBcasZQyuHFe8Q==", + "license": "Apache-2.0", + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-ast": "^1.0.0-beta.51", + "@swagger-api/apidom-core": "^1.0.0-beta.51", + "@swagger-api/apidom-json-pointer": "^1.0.0-beta.51", + "@swagger-api/apidom-ns-json-schema-2020-12": "^1.0.0-beta.51", + "@swagger-api/apidom-ns-openapi-3-0": "^1.0.0-beta.51", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "ts-mixer": "^6.0.3" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-parser-adapter-api-design-systems-json": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-api-design-systems-json/-/apidom-parser-adapter-api-design-systems-json-1.0.0-beta.51.tgz", + "integrity": "sha512-5MkROexCuCNGUc1ymznFIIO0F54HAx7mkoJs/0fpYaQWVyjgQT6OKI9ft76Vl8cmGOKA6D7Jp0j8aoVdrjayIw==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-beta.51", + "@swagger-api/apidom-ns-api-design-systems": "^1.0.0-beta.51", + "@swagger-api/apidom-parser-adapter-json": "^1.0.0-beta.51", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-parser-adapter-api-design-systems-yaml": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-api-design-systems-yaml/-/apidom-parser-adapter-api-design-systems-yaml-1.0.0-beta.51.tgz", + "integrity": "sha512-9drxT6AZzO2HQcGu97x1xAN8VdS6YPZL9K9Hr5fz8RkAR8SBUNblfUm796YNjJESN+Jk4DAiVoGdeI0cf6dsUA==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-beta.51", + "@swagger-api/apidom-ns-api-design-systems": "^1.0.0-beta.51", + "@swagger-api/apidom-parser-adapter-yaml-1-2": "^1.0.0-beta.51", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-parser-adapter-arazzo-json-1": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-arazzo-json-1/-/apidom-parser-adapter-arazzo-json-1-1.0.0-beta.51.tgz", + "integrity": "sha512-EEDBI3Z4xWzhsIpFUW94n9H0cuF4lKFczhauKe5ORG2MFwaJ16MNtpnoYvpY5Ad5YZmEEn8QqaBCAgQIi8qsGA==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-beta.51", + "@swagger-api/apidom-ns-arazzo-1": "^1.0.0-beta.51", + "@swagger-api/apidom-parser-adapter-json": "^1.0.0-beta.51", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-parser-adapter-arazzo-yaml-1": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-arazzo-yaml-1/-/apidom-parser-adapter-arazzo-yaml-1-1.0.0-beta.51.tgz", + "integrity": "sha512-kUMyMf6KjDIvcfw1ukekVBf/21NA6b1ZmVEtqZK5Kmr8bnUTzrxXdXAksBGuIVhWXduuQsE8kvWigUOoMiFD3A==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-beta.51", + "@swagger-api/apidom-ns-arazzo-1": "^1.0.0-beta.51", + "@swagger-api/apidom-parser-adapter-yaml-1-2": "^1.0.0-beta.51", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-parser-adapter-asyncapi-json-2": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-asyncapi-json-2/-/apidom-parser-adapter-asyncapi-json-2-1.0.0-beta.51.tgz", + "integrity": "sha512-bDRE4a67V/GyuKov/ox9nEEhZxKd6kwf+VQxatzm75b+U9PPb2l+105r5mJbi7nGHETt46GCT/ahZcs737wgEw==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-beta.51", + "@swagger-api/apidom-ns-asyncapi-2": "^1.0.0-beta.51", + "@swagger-api/apidom-parser-adapter-json": "^1.0.0-beta.51", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-parser-adapter-asyncapi-yaml-2": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-asyncapi-yaml-2/-/apidom-parser-adapter-asyncapi-yaml-2-1.0.0-beta.51.tgz", + "integrity": "sha512-eDZfzv+1lPWZWAk6zaDk8u8FmbvHD4i3WL3AVm5tNG8MkWAEcVzdaXiVb/GMsdmyeZ3qSIG9MPgKCdCUFkjfNw==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-beta.51", + "@swagger-api/apidom-ns-asyncapi-2": "^1.0.0-beta.51", + "@swagger-api/apidom-parser-adapter-yaml-1-2": "^1.0.0-beta.51", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-parser-adapter-json": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-json/-/apidom-parser-adapter-json-1.0.0-beta.51.tgz", + "integrity": "sha512-dkVx3YBoGdbTXtMEdu3i7eQ7R3yYCf9uEGsF2iDQgx7lq5HBmr+JAbWgKbf4hYQRGtSHvm+tpGgkzBPSZAqoRg==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-ast": "^1.0.0-beta.51", + "@swagger-api/apidom-core": "^1.0.0-beta.51", + "@swagger-api/apidom-error": "^1.0.0-beta.51", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "tree-sitter": "=0.21.1", + "tree-sitter-json": "=0.24.8", + "web-tree-sitter": "=0.24.5" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-parser-adapter-openapi-json-2": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-openapi-json-2/-/apidom-parser-adapter-openapi-json-2-1.0.0-beta.51.tgz", + "integrity": "sha512-SuNoICSgmP2ZcwRgxJNez2c+iVN59OCuPlYlej4WqJP6EjXJgOwSwpNVKPc7U3XrJX1jRcSWYbI6vKRDFo6dZQ==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-beta.51", + "@swagger-api/apidom-ns-openapi-2": "^1.0.0-beta.51", + "@swagger-api/apidom-parser-adapter-json": "^1.0.0-beta.51", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-parser-adapter-openapi-json-3-0": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-openapi-json-3-0/-/apidom-parser-adapter-openapi-json-3-0-1.0.0-beta.51.tgz", + "integrity": "sha512-VnG+7Yi/c4jOaXU0KHyKDzTpiW4fDTvWDq09i3EuEbrWIjDwFBp8RbvVL0zQu3rwiPH0rja+fZscINmHdL+eNA==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-beta.51", + "@swagger-api/apidom-ns-openapi-3-0": "^1.0.0-beta.51", + "@swagger-api/apidom-parser-adapter-json": "^1.0.0-beta.51", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-parser-adapter-openapi-json-3-1": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-openapi-json-3-1/-/apidom-parser-adapter-openapi-json-3-1-1.0.0-beta.51.tgz", + "integrity": "sha512-UXgdwLENW3dclCy5JJjiEznmQhtoN2kQV0YfeAYMgVvb/7flR9neq4zKWfmUjjyjsUre2WXowr52qMgQ1LDnCw==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-beta.51", + "@swagger-api/apidom-ns-openapi-3-1": "^1.0.0-beta.51", + "@swagger-api/apidom-parser-adapter-json": "^1.0.0-beta.51", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-parser-adapter-openapi-yaml-2": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-openapi-yaml-2/-/apidom-parser-adapter-openapi-yaml-2-1.0.0-beta.51.tgz", + "integrity": "sha512-tbY48w31+X6qvEVadKIKFOGqpw+y2S7VTb5xPWBn8yQGt+KjaDj2ni+9KiAen8Ulnzuhk3f9KkIV2NJziig8Mw==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-beta.51", + "@swagger-api/apidom-ns-openapi-2": "^1.0.0-beta.51", + "@swagger-api/apidom-parser-adapter-yaml-1-2": "^1.0.0-beta.51", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-parser-adapter-openapi-yaml-3-0": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-openapi-yaml-3-0/-/apidom-parser-adapter-openapi-yaml-3-0-1.0.0-beta.51.tgz", + "integrity": "sha512-TEk1d4XsZokhY1k8O1ueZpKo78++o9IIzmM7oI/d5tU9wQ4dxOr2n47zZx5xFWRjjz5g6q3QBzDhTe5COdSRSw==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-beta.51", + "@swagger-api/apidom-ns-openapi-3-0": "^1.0.0-beta.51", + "@swagger-api/apidom-parser-adapter-yaml-1-2": "^1.0.0-beta.51", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-parser-adapter-openapi-yaml-3-1": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-openapi-yaml-3-1/-/apidom-parser-adapter-openapi-yaml-3-1-1.0.0-beta.51.tgz", + "integrity": "sha512-rg5QMNHwdXSJWRQl6Xk61YWu7Echt50zRkvARvEwBE7h0EdDpjdjBMs3ZQwTPjMgtrEuUyNwOKFrAhdpAGvQEA==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-beta.51", + "@swagger-api/apidom-ns-openapi-3-1": "^1.0.0-beta.51", + "@swagger-api/apidom-parser-adapter-yaml-1-2": "^1.0.0-beta.51", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-parser-adapter-yaml-1-2": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-yaml-1-2/-/apidom-parser-adapter-yaml-1-2-1.0.0-beta.51.tgz", + "integrity": "sha512-mURkw1jK7rVjfyjmcT3nMjl6tZlI2rdIabX4h7PpytM95Rhl885Djy1ee+p1GExVnHNo3G8RtVZLYqHC2AXZNQ==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-ast": "^1.0.0-beta.51", + "@swagger-api/apidom-core": "^1.0.0-beta.51", + "@swagger-api/apidom-error": "^1.0.0-beta.51", + "@tree-sitter-grammars/tree-sitter-yaml": "=0.7.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "tree-sitter": "=0.22.4", + "web-tree-sitter": "=0.24.5" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-parser-adapter-yaml-1-2/node_modules/@tree-sitter-grammars/tree-sitter-yaml": { + "version": "0.7.1", + "resolved": "https://registry.npmjs.org/@tree-sitter-grammars/tree-sitter-yaml/-/tree-sitter-yaml-0.7.1.tgz", + "integrity": "sha512-AynBwkIoQCTgjDR33bDUp9Mqq+YTco0is3n5hRApMqG9of/6A4eQsfC1/uSEeHSUyMQSYawcAWamsexnVpIP4Q==", + "hasInstallScript": true, + "license": "MIT", + "optional": true, + "dependencies": { + "node-addon-api": "^8.3.1", + "node-gyp-build": "^4.8.4" + }, + "peerDependencies": { + "tree-sitter": "^0.22.4" + }, + "peerDependenciesMeta": { + "tree-sitter": { + "optional": true + } + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-parser-adapter-yaml-1-2/node_modules/tree-sitter": { + "version": "0.22.4", + "resolved": "https://registry.npmjs.org/tree-sitter/-/tree-sitter-0.22.4.tgz", + "integrity": "sha512-usbHZP9/oxNsUY65MQUsduGRqDHQOou1cagUSwjhoSYAmSahjQDAVsh9s+SlZkn8X8+O1FULRGwHu7AFP3kjzg==", + "hasInstallScript": true, + "license": "MIT", + "optional": true, + "dependencies": { + "node-addon-api": "^8.3.0", + "node-gyp-build": "^4.8.4" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swagger-api/apidom-reference": { + "version": "1.0.0-beta.51", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-reference/-/apidom-reference-1.0.0-beta.51.tgz", + "integrity": "sha512-JjK5VXyIZtp4teIDIFcwIOmuBOQNc7CpD0wjIruMkNkOEzAWL4Mt+OZ9F2tZaOsNUQjWERM1NDCmb3PfuznVew==", + "license": "Apache-2.0", + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-beta.51", + "@swagger-api/apidom-error": "^1.0.0-beta.51", + "@types/ramda": "~0.30.0", + "axios": "^1.12.2", + "minimatch": "^7.4.3", + "process": "^0.11.10", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + }, + "optionalDependencies": { + "@swagger-api/apidom-json-pointer": "^1.0.0-beta.40 <1.0.0-rc.0", + "@swagger-api/apidom-ns-arazzo-1": "^1.0.0-beta.40 <1.0.0-rc.0", + "@swagger-api/apidom-ns-asyncapi-2": "^1.0.0-beta.40 <1.0.0-rc.0", + "@swagger-api/apidom-ns-openapi-2": "^1.0.0-beta.40 <1.0.0-rc.0", + "@swagger-api/apidom-ns-openapi-3-0": "^1.0.0-beta.40 <1.0.0-rc.0", + "@swagger-api/apidom-ns-openapi-3-1": "^1.0.0-beta.40 <1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-api-design-systems-json": "^1.0.0-beta.40 <1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-api-design-systems-yaml": "^1.0.0-beta.40 <1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-arazzo-json-1": "^1.0.0-beta.40 <1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-arazzo-yaml-1": "^1.0.0-beta.40 <1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-asyncapi-json-2": "^1.0.0-beta.40 <1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-asyncapi-yaml-2": "^1.0.0-beta.40 <1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-json": "^1.0.0-beta.40 <1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-openapi-json-2": "^1.0.0-beta.40 <1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-openapi-json-3-0": "^1.0.0-beta.40 <1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-openapi-json-3-1": "^1.0.0-beta.40 <1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-openapi-yaml-2": "^1.0.0-beta.40 <1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-openapi-yaml-3-0": "^1.0.0-beta.40 <1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-openapi-yaml-3-1": "^1.0.0-beta.40 <1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-yaml-1-2": "^1.0.0-beta.40 <1.0.0-rc.0" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/@swaggerexpert/cookie": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/@swaggerexpert/cookie/-/cookie-1.4.1.tgz", + "integrity": "sha512-ZRbRC2017wMs+uZeIOC55ghwgbTxeolo+s6I0njzqina7MTrOhz8WMfTj0KGk3hfBUO/yhTQD/aQZ0lQHEIKxQ==", + "license": "Apache-2.0", + "dependencies": { + "apg-lite": "^1.0.3" + }, + "engines": { + "node": ">=12.20.0" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/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==", + "license": "MIT", + "dependencies": { + "balanced-match": "^1.0.0" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/minimatch": { + "version": "7.4.6", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-7.4.6.tgz", + "integrity": "sha512-sBz8G/YjVniEz6lKPNpKxXwazJe4c19fEfV2GDMX6AjFz+MX9uDWIZW8XreVhkFW3fkIdTv/gxWr/Kks5FFAVw==", + "license": "ISC", + "dependencies": { + "brace-expansion": "^2.0.1" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/@adobe/aio-lib-campaign-standard/node_modules/swagger-client": { + "version": "3.34.0", + "resolved": "https://registry.npmjs.org/swagger-client/-/swagger-client-3.34.0.tgz", + "integrity": "sha512-DQyg74J1XjpzmoOrSX0/x8OP7feeEzLTQ4ILe15TJ7oTXeC6XKQvnc5z59H5rW7vFxe+rkMlbzLCg/ri0w7Rag==", + "license": "Apache-2.0", + "dependencies": { + "@babel/runtime-corejs3": "^7.22.15", + "@scarf/scarf": "=1.4.0", + "@swagger-api/apidom-core": ">=1.0.0-beta.11 <1.0.0-rc.0", + "@swagger-api/apidom-error": ">=1.0.0-beta.11 <1.0.0-rc.0", + "@swagger-api/apidom-json-pointer": ">=1.0.0-beta.11 <1.0.0-rc.0", + "@swagger-api/apidom-ns-openapi-3-1": ">=1.0.0-beta.11 <1.0.0-rc.0", + "@swagger-api/apidom-reference": ">=1.0.0-beta.11 <1.0.0-rc.0", + "@swaggerexpert/cookie": "^1.4.1", + "deepmerge": "~4.3.0", + "fast-json-patch": "^3.0.0-1", + "js-yaml": "^4.1.0", + "neotraverse": "=0.6.18", + "node-abort-controller": "^3.1.1", + "node-fetch-commonjs": "^3.3.2", + "openapi-path-templating": "^2.0.1", + "openapi-server-url-templating": "^1.2.0", + "ramda": "^0.30.1", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@adobe/aio-lib-core-config": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/@adobe/aio-lib-core-config/-/aio-lib-core-config-5.0.1.tgz", + "integrity": "sha512-OQmQublmy/uXM1HC6qXfxSAXEl85nExh/yiajlEfJheKuJ9iPWwVWXR5vBHVVDlOXgWEVMWRUQPMIUu1lmR5lA==", + "license": "Apache-2.0", + "dependencies": { + "debug": "^4.1.1", + "deepmerge": "^4.0.0", + "dotenv": "16.3.1", + "hjson": "^3.1.2", + "js-yaml": "^4.1.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@adobe/aio-lib-core-errors": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/@adobe/aio-lib-core-errors/-/aio-lib-core-errors-4.0.1.tgz", + "integrity": "sha512-zrQm9TJh13wEHH5O2TQAUQvYGGe01R9DHzKy+b6B0URbl2lcuqXyNiUx896lpcgXD2bzUoH7ARRH97aCW2tlfw==", + "license": "Apache-2.0" + }, + "node_modules/@adobe/aio-lib-core-logging": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/@adobe/aio-lib-core-logging/-/aio-lib-core-logging-3.0.2.tgz", + "integrity": "sha512-f6f9IspB7FjpyGiL7eqUKgBkhZukwDnkPXDhGhYLCjrP3dr+jQnK3uQh9VXZoH4SIWcnpayMUTKZsbDs3WXC+g==", + "license": "Apache-2.0", + "dependencies": { + "debug": "^4.1.1", + "winston": "^3.2.1" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@adobe/aio-lib-core-networking": { + "version": "5.0.4", + "resolved": "https://registry.npmjs.org/@adobe/aio-lib-core-networking/-/aio-lib-core-networking-5.0.4.tgz", + "integrity": "sha512-LsFPKIXqfWiMwSjD9NJbb6uUSlZ+DZiV8p9NhpqPyzqAAl9NNONAH0jcIKtsKWSULcHc20INaRAw8dqKzQBTbw==", + "license": "Apache-2.0", + "dependencies": { + "@adobe/aio-lib-core-config": "^5.0.0", + "@adobe/aio-lib-core-errors": "^4.0.0", + "@adobe/aio-lib-core-logging": "^3.0.0", + "fetch-retry": "^6.0.0", + "http-proxy-agent": "^7", + "https-proxy-agent": "^7", + "node-fetch": "^2.6.4", + "proxy-from-env": "^1.1.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@adobe/aio-lib-core-tvm": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/@adobe/aio-lib-core-tvm/-/aio-lib-core-tvm-4.0.3.tgz", + "integrity": "sha512-zwl4GeU5CryZBozpub4jI9tnGW2ewD6mMLaXX8HhO8DqKzcjnjYr+MbUS0c/QzGd8gTzZWbikm4J7tfpCn3cAA==", + "license": "Apache-2.0", + "dependencies": { + "@adobe/aio-lib-core-errors": "^4", + "@adobe/aio-lib-core-logging": "^3", + "@adobe/aio-lib-core-networking": "^5", + "@adobe/aio-lib-env": "^3", + "fs-extra": "^11.1.1", + "joi": "^17.4.2", + "lodash.clonedeep": "^4.5.0", + "upath": "^2.0.1" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@adobe/aio-lib-customer-profile": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/@adobe/aio-lib-customer-profile/-/aio-lib-customer-profile-3.0.2.tgz", + "integrity": "sha512-me1VM2RJzT2TwW6U74dDKqjAvh/IudZEHUcECwYN/WtcN8kbn2cuW5QB5e8SY7b6yVV52hovzpaJirW2MnKfhA==", + "license": "Apache-2.0", + "dependencies": { + "@adobe/aio-lib-core-errors": "^4", + "@adobe/aio-lib-core-logging": "^3", + "change-case": "^4.1.1", + "swagger-client": "^3.35.6", + "uuid": "^9.0.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@adobe/aio-lib-env": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/@adobe/aio-lib-env/-/aio-lib-env-3.0.1.tgz", + "integrity": "sha512-UaLosV8jBowEA2ho4BNmWuHhrNCFbx26kJAr2SAIdEm4lZ/D8av8FUSMOEyAKJ/dfO2HCnLKMy77ie2AU7HI3g==", + "license": "Apache-2.0", + "dependencies": { + "@adobe/aio-lib-core-config": "^5.0.0", + "@adobe/aio-lib-core-logging": "^3.0.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@adobe/aio-lib-events": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/@adobe/aio-lib-events/-/aio-lib-events-4.0.1.tgz", + "integrity": "sha512-n6y7daoHoz79o06+kIJzHcOTbD7j9jt2YCT7njtms6Aoj8fbkiBuGBIjCx+XxXy1TJJxfwUrL5TZjbzeroHiXw==", + "license": "Apache-2.0", + "dependencies": { + "@adobe/aio-lib-core-errors": "^4", + "@adobe/aio-lib-core-logging": "^3", + "@adobe/aio-lib-core-networking": "^5", + "@adobe/aio-lib-env": "^3", + "@adobe/aio-lib-state": "^3", + "crypto-js": "^4.0.0", + "http-link-header": "^1.0.2", + "node-fetch": "^2.6.0", + "rxjs": "^7.8.1", + "valid-url": "^1.0.9" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@adobe/aio-lib-events/node_modules/@adobe/aio-lib-state": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/@adobe/aio-lib-state/-/aio-lib-state-3.0.2.tgz", + "integrity": "sha512-ZwZUM5jVUmI0+8GmSwQ99pZVAa9Hii9afwje8X+4+D+SVmifi8K7hndP5LXR0W/NR67oC3ceEY6Uh+KNcgJdGQ==", + "license": "Apache-2.0", + "dependencies": { + "@adobe/aio-lib-core-errors": "^4", + "@adobe/aio-lib-core-logging": "^3", + "@adobe/aio-lib-core-tvm": "^4", + "@azure/cosmos": "^3.17.1", + "joi": "^17.4.2", + "lodash.clonedeep": "^4.5.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@adobe/aio-lib-files": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/@adobe/aio-lib-files/-/aio-lib-files-4.1.2.tgz", + "integrity": "sha512-4Ll776OGB34R7nPgMF+UQpIYm33yjtH5yLUuvtvKNHZtRF/wODG1Q8Oqcy9pOFutRIacg/xM0AMB6OKrQTP+Xw==", + "license": "Apache-2.0", + "dependencies": { + "@adobe/aio-lib-core-errors": "^4", + "@adobe/aio-lib-core-logging": "^3", + "@adobe/aio-lib-core-tvm": "^4", + "@adobe/aio-lib-env": "^3.0.0", + "@azure/storage-blob": "^12.3.0", + "@types/hapi__joi": "^17.1.13", + "fs-extra": "^11.1.1", + "joi": "^17.4.2", + "lodash.clonedeep": "^4.5.0", + "mime-types": "^2.1.24", + "node-fetch": "^2.6.0", + "upath": "^2.0.1", + "uuid": "^9.0.0", + "xml-js": "^1.6.11" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@adobe/aio-lib-ims": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/@adobe/aio-lib-ims/-/aio-lib-ims-7.0.2.tgz", + "integrity": "sha512-H4LK6fVcADPpnD6lZIzfosBAkHyOW1Yluk7MnNGs5TKM41i3NGGl/GaI/oQjDQGH4pIISK7HPU6FO0M+0+w04g==", + "license": "Apache-2.0", + "dependencies": { + "@adobe/aio-lib-core-config": "^5", + "@adobe/aio-lib-core-errors": "^4", + "@adobe/aio-lib-core-logging": "^3", + "@adobe/aio-lib-core-networking": "^5", + "@adobe/aio-lib-env": "^3", + "@adobe/aio-lib-ims-jwt": "^5", + "@adobe/aio-lib-ims-oauth": "^6", + "@adobe/aio-lib-state": "^3", + "form-data": "^4.0.0", + "lodash.clonedeep": "^4.5.0", + "lru-cache": "^5.1.1" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@adobe/aio-lib-ims-jwt": { + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/@adobe/aio-lib-ims-jwt/-/aio-lib-ims-jwt-5.0.2.tgz", + "integrity": "sha512-KaK+RB4FbfF5llYJueoOd9r6NeJp+d8pUE2QxqP6tpfr8NGt40Fw68XduQSTnPoOxKLn2piTD+IfaQ9a5teKHg==", + "license": "Apache-2.0", + "dependencies": { + "@adobe/aio-lib-core-errors": "^4", + "@adobe/aio-lib-core-logging": "^3", + "jsonwebtoken": "^9.0.0" + }, + "engines": { + "node": ">=18" + }, + "peerDependencies": { + "@adobe/aio-lib-ims": "^7" + } + }, + "node_modules/@adobe/aio-lib-ims-oauth": { + "version": "6.0.4", + "resolved": "https://registry.npmjs.org/@adobe/aio-lib-ims-oauth/-/aio-lib-ims-oauth-6.0.4.tgz", + "integrity": "sha512-YS5sediBHllDBtDk6iyFplnb5zgTF/ZXmp2W/ocBlLXqgy1dor/IZYZu06XgkaaWLHDqqXlfgRJlx/K5YKijOw==", + "license": "Apache-2.0", + "dependencies": { + "@adobe/aio-lib-core-errors": "^4", + "@adobe/aio-lib-core-logging": "^3", + "@adobe/aio-lib-env": "^3", + "ci-info": "^4.2.0", + "open": "^8.4.2", + "ora": "^5.4.1" + }, + "engines": { + "node": ">=18" + }, + "peerDependencies": { + "@adobe/aio-lib-ims": "^7" + } + }, + "node_modules/@adobe/aio-lib-ims/node_modules/@adobe/aio-lib-state": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/@adobe/aio-lib-state/-/aio-lib-state-3.0.2.tgz", + "integrity": "sha512-ZwZUM5jVUmI0+8GmSwQ99pZVAa9Hii9afwje8X+4+D+SVmifi8K7hndP5LXR0W/NR67oC3ceEY6Uh+KNcgJdGQ==", + "license": "Apache-2.0", + "dependencies": { + "@adobe/aio-lib-core-errors": "^4", + "@adobe/aio-lib-core-logging": "^3", + "@adobe/aio-lib-core-tvm": "^4", + "@azure/cosmos": "^3.17.1", + "joi": "^17.4.2", + "lodash.clonedeep": "^4.5.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@adobe/aio-lib-state": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/@adobe/aio-lib-state/-/aio-lib-state-5.1.0.tgz", + "integrity": "sha512-RC0r4ZH7V7oIr3xEAgspHhD3bg3passfkzQVtb6KApj+QpkOQdqiIKc/MBeyiyWP9U7YGsQhAYtnrMKMBYxTAw==", + "license": "Apache-2.0", + "dependencies": { + "@adobe/aio-lib-core-errors": "^4", + "@adobe/aio-lib-core-logging": "^3", + "@adobe/aio-lib-core-networking": "^5", + "@adobe/aio-lib-env": "^3", + "ajv": "^8.12.0", + "lodash.clonedeep": "^4.5.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@adobe/aio-lib-target": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/@adobe/aio-lib-target/-/aio-lib-target-4.0.2.tgz", + "integrity": "sha512-uMIUg+pwclxUAJfJx/Wdlkmkb4oHLIGjFgIUkjGI7f/el8qswpZGgSPub4Q1igRboRriQHNcmtytJGDnwMifHg==", + "dependencies": { + "@adobe/aio-lib-core-errors": "^4", + "@adobe/aio-lib-core-logging": "^3", + "swagger-client": "^3.35.6" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@adobe/aio-sdk": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/@adobe/aio-sdk/-/aio-sdk-6.0.0.tgz", + "integrity": "sha512-PR9it0eHqI9BsNjG0tmkjt27JZ7qGj7JiIDsUbIdmc7fqvu+4uXnC+XjK558h5+Ll7QQN9ETKr56YS/V546Wkw==", + "license": "Apache-2.0", + "dependencies": { + "@adobe/aio-lib-analytics": "^4", + "@adobe/aio-lib-campaign-standard": "^4", + "@adobe/aio-lib-customer-profile": "^3", + "@adobe/aio-lib-events": "^4", + "@adobe/aio-lib-files": "^4", + "@adobe/aio-lib-state": "^5", + "@adobe/aio-lib-target": "^4", + "@adobe/aio-sdk-core": "^3" + } + }, + "node_modules/@adobe/aio-sdk-core": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/@adobe/aio-sdk-core/-/aio-sdk-core-3.0.0.tgz", + "integrity": "sha512-M1or6szOAtuNN7owyTeojQ+yyaIBKa9u0hRkl0mFmv5WnO7Edfk5uP8ZBGYhfJ9XkEZz6c2NKNvR36dqrrmDnA==", + "license": "Apache-2.0", + "dependencies": { + "@adobe/aio-lib-core-config": "^5", + "@adobe/aio-lib-core-errors": "^4", + "@adobe/aio-lib-core-logging": "^3", + "@adobe/aio-lib-core-networking": "^5", + "@adobe/aio-lib-core-tvm": "^4" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@azure/abort-controller": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/@azure/abort-controller/-/abort-controller-2.1.2.tgz", + "integrity": "sha512-nBrLsEWm4J2u5LpAPjxADTlq3trDgVZZXHNKabeXZtpq3d3AbN/KGO82R87rdDz5/lYB024rtEf10/q0urNgsA==", + "license": "MIT", + "dependencies": { + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@azure/core-auth": { + "version": "1.10.1", + "resolved": "https://registry.npmjs.org/@azure/core-auth/-/core-auth-1.10.1.tgz", + "integrity": "sha512-ykRMW8PjVAn+RS6ww5cmK9U2CyH9p4Q88YJwvUslfuMmN98w/2rdGRLPqJYObapBCdzBVeDgYWdJnFPFb7qzpg==", + "license": "MIT", + "dependencies": { + "@azure/abort-controller": "^2.1.2", + "@azure/core-util": "^1.13.0", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@azure/core-client": { + "version": "1.10.1", + "resolved": "https://registry.npmjs.org/@azure/core-client/-/core-client-1.10.1.tgz", + "integrity": "sha512-Nh5PhEOeY6PrnxNPsEHRr9eimxLwgLlpmguQaHKBinFYA/RU9+kOYVOQqOrTsCL+KSxrLLl1gD8Dk5BFW/7l/w==", + "license": "MIT", + "dependencies": { + "@azure/abort-controller": "^2.1.2", + "@azure/core-auth": "^1.10.0", + "@azure/core-rest-pipeline": "^1.22.0", + "@azure/core-tracing": "^1.3.0", + "@azure/core-util": "^1.13.0", + "@azure/logger": "^1.3.0", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@azure/core-http-compat": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/@azure/core-http-compat/-/core-http-compat-2.3.1.tgz", + "integrity": "sha512-az9BkXND3/d5VgdRRQVkiJb2gOmDU8Qcq4GvjtBmDICNiQ9udFmDk4ZpSB5Qq1OmtDJGlQAfBaS4palFsazQ5g==", + "license": "MIT", + "dependencies": { + "@azure/abort-controller": "^2.1.2", + "@azure/core-client": "^1.10.0", + "@azure/core-rest-pipeline": "^1.22.0" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@azure/core-lro": { + "version": "2.7.2", + "resolved": "https://registry.npmjs.org/@azure/core-lro/-/core-lro-2.7.2.tgz", + "integrity": "sha512-0YIpccoX8m/k00O7mDDMdJpbr6mf1yWo2dfmxt5A8XVZVVMz2SSKaEbMCeJRvgQ0IaSlqhjT47p4hVIRRy90xw==", + "license": "MIT", + "dependencies": { + "@azure/abort-controller": "^2.0.0", + "@azure/core-util": "^1.2.0", + "@azure/logger": "^1.0.0", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@azure/core-paging": { + "version": "1.6.2", + "resolved": "https://registry.npmjs.org/@azure/core-paging/-/core-paging-1.6.2.tgz", + "integrity": "sha512-YKWi9YuCU04B55h25cnOYZHxXYtEvQEbKST5vqRga7hWY9ydd3FZHdeQF8pyh+acWZvppw13M/LMGx0LABUVMA==", + "license": "MIT", + "dependencies": { + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@azure/core-rest-pipeline": { + "version": "1.22.1", + "resolved": "https://registry.npmjs.org/@azure/core-rest-pipeline/-/core-rest-pipeline-1.22.1.tgz", + "integrity": "sha512-UVZlVLfLyz6g3Hy7GNDpooMQonUygH7ghdiSASOOHy97fKj/mPLqgDX7aidOijn+sCMU+WU8NjlPlNTgnvbcGA==", + "license": "MIT", + "dependencies": { + "@azure/abort-controller": "^2.1.2", + "@azure/core-auth": "^1.10.0", + "@azure/core-tracing": "^1.3.0", + "@azure/core-util": "^1.13.0", + "@azure/logger": "^1.3.0", + "@typespec/ts-http-runtime": "^0.3.0", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@azure/core-tracing": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/@azure/core-tracing/-/core-tracing-1.3.1.tgz", + "integrity": "sha512-9MWKevR7Hz8kNzzPLfX4EAtGM2b8mr50HPDBvio96bURP/9C+HjdH3sBlLSNNrvRAr5/k/svoH457gB5IKpmwQ==", + "license": "MIT", + "dependencies": { + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@azure/core-util": { + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/@azure/core-util/-/core-util-1.13.1.tgz", + "integrity": "sha512-XPArKLzsvl0Hf0CaGyKHUyVgF7oDnhKoP85Xv6M4StF/1AhfORhZudHtOyf2s+FcbuQ9dPRAjB8J2KvRRMUK2A==", + "license": "MIT", + "dependencies": { + "@azure/abort-controller": "^2.1.2", + "@typespec/ts-http-runtime": "^0.3.0", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@azure/core-xml": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/@azure/core-xml/-/core-xml-1.5.0.tgz", + "integrity": "sha512-D/sdlJBMJfx7gqoj66PKVmhDDaU6TKA49ptcolxdas29X7AfvLTmfAGLjAcIMBK7UZ2o4lygHIqVckOlQU3xWw==", + "license": "MIT", + "dependencies": { + "fast-xml-parser": "^5.0.7", + "tslib": "^2.8.1" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@azure/cosmos": { + "version": "3.17.3", + "resolved": "https://registry.npmjs.org/@azure/cosmos/-/cosmos-3.17.3.tgz", + "integrity": "sha512-wBglkQ6Irjv5Vo2iw8fd6eYj60WYRSSg4/0DBkeOP6BwQ4RA91znsOHd6s3qG6UAbNgYuzC9Nnq07vlFFZkHEw==", + "license": "MIT", + "dependencies": { + "@azure/abort-controller": "^1.0.0", + "@azure/core-auth": "^1.3.0", + "@azure/core-rest-pipeline": "^1.2.0", + "@azure/core-tracing": "^1.0.0", + "debug": "^4.1.1", + "fast-json-stable-stringify": "^2.1.0", + "jsbi": "^3.1.3", + "node-abort-controller": "^3.0.0", + "priorityqueuejs": "^1.0.0", + "semaphore": "^1.0.5", + "tslib": "^2.2.0", + "universal-user-agent": "^6.0.0", + "uuid": "^8.3.0" + }, + "engines": { + "node": ">=14.0.0" + } + }, + "node_modules/@azure/cosmos/node_modules/@azure/abort-controller": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@azure/abort-controller/-/abort-controller-1.1.0.tgz", + "integrity": "sha512-TrRLIoSQVzfAJX9H1JeFjzAoDGcoK1IYX1UImfceTZpsyYfWr09Ss1aHW1y5TrrR3iq6RZLBwJ3E24uwPhwahw==", + "license": "MIT", + "dependencies": { + "tslib": "^2.2.0" + }, + "engines": { + "node": ">=12.0.0" + } + }, + "node_modules/@azure/cosmos/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==", + "license": "MIT", + "bin": { + "uuid": "dist/bin/uuid" + } + }, + "node_modules/@azure/logger": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/@azure/logger/-/logger-1.3.0.tgz", + "integrity": "sha512-fCqPIfOcLE+CGqGPd66c8bZpwAji98tZ4JI9i/mlTNTlsIWslCfpg48s/ypyLxZTump5sypjrKn2/kY7q8oAbA==", + "license": "MIT", + "dependencies": { + "@typespec/ts-http-runtime": "^0.3.0", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@azure/storage-blob": { + "version": "12.29.1", + "resolved": "https://registry.npmjs.org/@azure/storage-blob/-/storage-blob-12.29.1.tgz", + "integrity": "sha512-7ktyY0rfTM0vo7HvtK6E3UvYnI9qfd6Oz6z/+92VhGRveWng3kJwMKeUpqmW/NmwcDNbxHpSlldG+vsUnRFnBg==", + "license": "MIT", + "dependencies": { + "@azure/abort-controller": "^2.1.2", + "@azure/core-auth": "^1.9.0", + "@azure/core-client": "^1.9.3", + "@azure/core-http-compat": "^2.2.0", + "@azure/core-lro": "^2.2.0", + "@azure/core-paging": "^1.6.2", + "@azure/core-rest-pipeline": "^1.19.1", + "@azure/core-tracing": "^1.2.0", + "@azure/core-util": "^1.11.0", + "@azure/core-xml": "^1.4.5", + "@azure/logger": "^1.1.4", + "@azure/storage-common": "^12.1.1", + "events": "^3.0.0", + "tslib": "^2.8.1" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@azure/storage-common": { + "version": "12.1.1", + "resolved": "https://registry.npmjs.org/@azure/storage-common/-/storage-common-12.1.1.tgz", + "integrity": "sha512-eIOH1pqFwI6UmVNnDQvmFeSg0XppuzDLFeUNO/Xht7ODAzRLgGDh7h550pSxoA+lPDxBl1+D2m/KG3jWzCUjTg==", + "license": "MIT", + "dependencies": { + "@azure/abort-controller": "^2.1.2", + "@azure/core-auth": "^1.9.0", + "@azure/core-http-compat": "^2.2.0", + "@azure/core-rest-pipeline": "^1.19.1", + "@azure/core-tracing": "^1.2.0", + "@azure/core-util": "^1.11.0", + "@azure/logger": "^1.1.4", + "events": "^3.3.0", + "tslib": "^2.8.1" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@babel/runtime-corejs3": { + "version": "7.28.4", + "resolved": "https://registry.npmjs.org/@babel/runtime-corejs3/-/runtime-corejs3-7.28.4.tgz", + "integrity": "sha512-h7iEYiW4HebClDEhtvFObtPmIvrd1SSfpI9EhOeKk4CtIK/ngBWFpuhCzhdmRKtg71ylcue+9I6dv54XYO1epQ==", + "license": "MIT", + "dependencies": { + "core-js-pure": "^3.43.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@colors/colors": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/@colors/colors/-/colors-1.6.0.tgz", + "integrity": "sha512-Ir+AOibqzrIsL6ajt3Rz3LskB7OiMVHqltZmspbW/TJuTVuyOMirVqAkjfY6JISiLHgyNqicAC8AyHHGzNd/dA==", + "license": "MIT", + "engines": { + "node": ">=0.1.90" + } + }, + "node_modules/@dabh/diagnostics": { + "version": "2.0.8", + "resolved": "https://registry.npmjs.org/@dabh/diagnostics/-/diagnostics-2.0.8.tgz", + "integrity": "sha512-R4MSXTVnuMzGD7bzHdW2ZhhdPC/igELENcq5IjEverBvq5hn1SXCWcsi6eSsdWP0/Ur+SItRRjAktmdoX/8R/Q==", + "license": "MIT", + "dependencies": { + "@so-ric/colorspace": "^1.1.6", + "enabled": "2.0.x", + "kuler": "^2.0.0" + } + }, + "node_modules/@eslint-community/eslint-utils": { + "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": { + "eslint-visitor-keys": "^3.4.3" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + }, + "peerDependencies": { + "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" + } + }, + "node_modules/@eslint-community/regexpp": { + "version": "4.12.2", + "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.12.2.tgz", + "integrity": "sha512-EriSTlt5OC9/7SXkRSCAhfSxxoSUgBm33OH+IkwbdpgoqsSsUg7y3uh+IICI/Qg4BBWr3U2i39RpmycbxMq4ew==", + "dev": true, + "license": "MIT", + "engines": { + "node": "^12.0.0 || ^14.0.0 || >=16.0.0" + } + }, + "node_modules/@eslint/eslintrc": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz", + "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "ajv": "^6.12.4", + "debug": "^4.3.2", + "espree": "^9.6.0", + "globals": "^13.19.0", + "ignore": "^5.2.0", + "import-fresh": "^3.2.1", + "js-yaml": "^4.1.0", + "minimatch": "^3.1.2", + "strip-json-comments": "^3.1.1" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/@eslint/eslintrc/node_modules/ajv": { + "version": "6.12.6", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", + "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", + "dev": true, + "license": "MIT", + "dependencies": { + "fast-deep-equal": "^3.1.1", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/epoberezkin" + } + }, + "node_modules/@eslint/eslintrc/node_modules/json-schema-traverse": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", + "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", + "dev": true, + "license": "MIT" + }, + "node_modules/@eslint/js": { + "version": "8.57.1", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.57.1.tgz", + "integrity": "sha512-d9zaMRSTIKDLhctzH12MtXvJKSSUhaHcjV+2Z+GK+EEY7XKpP5yR4x+N3TAcHTcu963nIr+TMcCb4DBCYX1z6Q==", + "dev": true, + "license": "MIT", + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + } + }, + "node_modules/@hapi/hoek": { + "version": "9.3.0", + "resolved": "https://registry.npmjs.org/@hapi/hoek/-/hoek-9.3.0.tgz", + "integrity": "sha512-/c6rf4UJlmHlC9b5BaNvzAcFv7HZ2QHaV0D4/HNlBdvFnvQq8RI4kYdhyPCl7Xj+oWvTWQ8ujhqS53LIgAe6KQ==", + "license": "BSD-3-Clause" + }, + "node_modules/@hapi/topo": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/@hapi/topo/-/topo-5.1.0.tgz", + "integrity": "sha512-foQZKJig7Ob0BMAYBfcJk8d77QtOe7Wo4ox7ff1lQYoNNAb6jwcY1ncdoy2e9wQZzvNy7ODZCYJkK8kzmcAnAg==", + "license": "BSD-3-Clause", + "dependencies": { + "@hapi/hoek": "^9.0.0" + } + }, + "node_modules/@humanwhocodes/config-array": { + "version": "0.13.0", + "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.13.0.tgz", + "integrity": "sha512-DZLEEqFWQFiyK6h5YIeynKx7JlvCYWL0cImfSRXZ9l4Sg2efkFGTuFf6vzXjK1cq6IYkU+Eg/JizXw+TD2vRNw==", + "deprecated": "Use @eslint/config-array instead", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "@humanwhocodes/object-schema": "^2.0.3", + "debug": "^4.3.1", + "minimatch": "^3.0.5" + }, + "engines": { + "node": ">=10.10.0" + } + }, + "node_modules/@humanwhocodes/module-importer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", + "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", + "dev": true, + "license": "Apache-2.0", + "engines": { + "node": ">=12.22" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/nzakas" + } + }, + "node_modules/@humanwhocodes/object-schema": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.3.tgz", + "integrity": "sha512-93zYdMES/c1D69yZiKDBj0V24vqNzB/koF26KPaagAfd3P/4gUlh3Dys5ogAK+Exi9QyzlD8x/08Zt7wIKcDcA==", + "deprecated": "Use @eslint/object-schema instead", + "dev": true, + "license": "BSD-3-Clause" + }, + "node_modules/@nodelib/fs.scandir": { + "version": "2.1.5", + "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", + "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", + "dev": true, + "license": "MIT", + "dependencies": { + "@nodelib/fs.stat": "2.0.5", + "run-parallel": "^1.1.9" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/@nodelib/fs.stat": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", + "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 8" + } + }, + "node_modules/@nodelib/fs.walk": { + "version": "1.2.8", + "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", + "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@nodelib/fs.scandir": "2.1.5", + "fastq": "^1.6.0" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/@scarf/scarf": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/@scarf/scarf/-/scarf-1.4.0.tgz", + "integrity": "sha512-xxeapPiUXdZAE3che6f3xogoJPeZgig6omHEy1rIY5WVsB3H2BHNnZH+gHG6x91SCWyQCzWGsuL2Hh3ClO5/qQ==", + "hasInstallScript": true, + "license": "Apache-2.0" + }, + "node_modules/@sideway/address": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/@sideway/address/-/address-4.1.5.tgz", + "integrity": "sha512-IqO/DUQHUkPeixNQ8n0JA6102hT9CmaljNTPmQ1u8MEhBo/R4Q8eKLN/vGZxuebwOroDB4cbpjheD4+/sKFK4Q==", + "license": "BSD-3-Clause", + "dependencies": { + "@hapi/hoek": "^9.0.0" + } + }, + "node_modules/@sideway/formula": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/@sideway/formula/-/formula-3.0.1.tgz", + "integrity": "sha512-/poHZJJVjx3L+zVD6g9KgHfYnb443oi7wLu/XKojDviHy6HOEOA6z1Trk5aR1dGcmPenJEgb2sK2I80LeS3MIg==", + "license": "BSD-3-Clause" + }, + "node_modules/@sideway/pinpoint": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/@sideway/pinpoint/-/pinpoint-2.0.0.tgz", + "integrity": "sha512-RNiOoTPkptFtSVzQevY/yWtZwf/RxyVnPy/OcA9HBM3MlGDnBEYL5B41H0MTn0Uec8Hi+2qUtTfG2WWZBmMejQ==", + "license": "BSD-3-Clause" + }, + "node_modules/@so-ric/colorspace": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/@so-ric/colorspace/-/colorspace-1.1.6.tgz", + "integrity": "sha512-/KiKkpHNOBgkFJwu9sh48LkHSMYGyuTcSFK/qMBdnOAlrRJzRSXAOFB5qwzaVQuDl8wAvHVMkaASQDReTahxuw==", + "license": "MIT", + "dependencies": { + "color": "^5.0.2", + "text-hex": "1.0.x" + } + }, + "node_modules/@swagger-api/apidom-ast": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-ast/-/apidom-ast-1.0.0-rc.1.tgz", + "integrity": "sha512-hsAySkWlIjgkQEDu1YEbvnxdEC3rD9bjQf7UYm0vzkvL5PNDd6lHLhxb825bQAfXQjw7WOxtV7eNrgqRQohMDg==", + "license": "Apache-2.0", + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-error": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "unraw": "^3.0.0" + } + }, + "node_modules/@swagger-api/apidom-core": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-core/-/apidom-core-1.0.0-rc.1.tgz", + "integrity": "sha512-vlguVts28oYBjCU5ZYfnX6yAFys/dZ1PUZqpYevMIGi8lEvxEfoxKEaUQa1Lr974cfKaVGBs8gNNhvDKXbH/jA==", + "license": "Apache-2.0", + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-ast": "^1.0.0-rc.1", + "@swagger-api/apidom-error": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "minim": "~0.23.8", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "short-unique-id": "^5.3.2", + "ts-mixer": "^6.0.3" + } + }, + "node_modules/@swagger-api/apidom-error": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-error/-/apidom-error-1.0.0-rc.1.tgz", + "integrity": "sha512-74tTb6QX8VeAvu/9XipXd4Ly3N3q+yJez+lGZD7Qa11E00AhNpzqH7swgZKutLEfq1tHxyGWE1A6xF8IiU4CJg==", + "license": "Apache-2.0", + "dependencies": { + "@babel/runtime-corejs3": "^7.20.7" + } + }, + "node_modules/@swagger-api/apidom-json-pointer": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-json-pointer/-/apidom-json-pointer-1.0.0-rc.1.tgz", + "integrity": "sha512-fNDQozPRuD9ReYcCnIqr5jU0faFDUl3VrUtfeLl3YevxNB+onZkUidUvzUJgDjZK9Se567BgL0rK9hnEO/Q8qw==", + "license": "Apache-2.0", + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-error": "^1.0.0-rc.1", + "@swaggerexpert/json-pointer": "^2.10.1" + } + }, + "node_modules/@swagger-api/apidom-ns-api-design-systems": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-ns-api-design-systems/-/apidom-ns-api-design-systems-1.0.0-rc.1.tgz", + "integrity": "sha512-gV6vQHpdtVKtrV+uUCPwsSL5nX5zD/3vR7dSYE0Lii7f7RkpIXAgQViZSbv7+h8TB20DNobGt+JZH/gGaY+Oxg==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-error": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-openapi-3-1": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "ts-mixer": "^6.0.3" + } + }, + "node_modules/@swagger-api/apidom-ns-arazzo-1": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-ns-arazzo-1/-/apidom-ns-arazzo-1-1.0.0-rc.1.tgz", + "integrity": "sha512-Bx3PMLp+613EgSsLLg6Ucg3FtbO2i1bVcFZXgImun5pYNfmtQu21ELfWKj8ty/Ts2zR1VKOn5+i9DyMOH/zpsA==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-json-schema-2020-12": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "ts-mixer": "^6.0.3" + } + }, + "node_modules/@swagger-api/apidom-ns-asyncapi-2": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-ns-asyncapi-2/-/apidom-ns-asyncapi-2-1.0.0-rc.1.tgz", + "integrity": "sha512-Vvo1f/H3mUuTny1d+XPudSattDWdHP1VhowxAOAFrnLVM4qvFbeBdzWjmTPEaeRsOz+Vq6rJOC4DPmHmtkR+oQ==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-json-schema-draft-7": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "ts-mixer": "^6.0.3" + } + }, + "node_modules/@swagger-api/apidom-ns-json-schema-2019-09": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-ns-json-schema-2019-09/-/apidom-ns-json-schema-2019-09-1.0.0-rc.1.tgz", + "integrity": "sha512-1va09+kSTpNKc9oKs0rk2FWP2wk9AAdOcdmLpPEbzMnThQD1DHeBCk5OMStGZlaROxKWMPVZ5EmKy6rTRXvEIQ==", + "license": "Apache-2.0", + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-error": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-json-schema-draft-7": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "ts-mixer": "^6.0.4" + } + }, + "node_modules/@swagger-api/apidom-ns-json-schema-2020-12": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-ns-json-schema-2020-12/-/apidom-ns-json-schema-2020-12-1.0.0-rc.1.tgz", + "integrity": "sha512-ixNci2lwVD0yC4lUrmOOhgE/denI8keGVnHXYokbq0QxlQWuwuVzjVEtVMdmEaX3JaYVmEI5tr8K9MPW1zso1A==", + "license": "Apache-2.0", + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-error": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-json-schema-2019-09": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "ts-mixer": "^6.0.4" + } + }, + "node_modules/@swagger-api/apidom-ns-json-schema-draft-4": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-ns-json-schema-draft-4/-/apidom-ns-json-schema-draft-4-1.0.0-rc.1.tgz", + "integrity": "sha512-kLGANNv8oAWWvnVqWat/AqOEo6XBfdMF3I7BLL2eZFBE8bhTbFMvmAvUfnwcehYo3K4vT+J60DWrwqYBoGSSUQ==", + "license": "Apache-2.0", + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-ast": "^1.0.0-rc.1", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "ts-mixer": "^6.0.4" + } + }, + "node_modules/@swagger-api/apidom-ns-json-schema-draft-6": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-ns-json-schema-draft-6/-/apidom-ns-json-schema-draft-6-1.0.0-rc.1.tgz", + "integrity": "sha512-UzoTSrPOh+dwzSKZmawBwhWg4xGgpdNBmtV7jDJGEyFGsEkPvDBvViq+4sfMxO/BGoqPCD/jdt4yF16AKRxLiw==", + "license": "Apache-2.0", + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-error": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-json-schema-draft-4": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "ts-mixer": "^6.0.4" + } + }, + "node_modules/@swagger-api/apidom-ns-json-schema-draft-7": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-ns-json-schema-draft-7/-/apidom-ns-json-schema-draft-7-1.0.0-rc.1.tgz", + "integrity": "sha512-3alW6gJKeb+DzTu+LYpYyEc5swo3oP8aoatOcVceWo/A/568zfIW0wWssf9WoasI42jEktV17z4A6ZwT6PzYbA==", + "license": "Apache-2.0", + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-error": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-json-schema-draft-6": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "ts-mixer": "^6.0.4" + } + }, + "node_modules/@swagger-api/apidom-ns-openapi-2": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-ns-openapi-2/-/apidom-ns-openapi-2-1.0.0-rc.1.tgz", + "integrity": "sha512-SJ79fGH+WA7IYEXOJFPjXCB5bg6uoJDmkEYxMtZpN0Q+juFSkMcquh3jVf0j0y+6gFe/MZjIFDHxiBdeJarOig==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-error": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-json-schema-draft-4": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "ts-mixer": "^6.0.3" + } + }, + "node_modules/@swagger-api/apidom-ns-openapi-3-0": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-ns-openapi-3-0/-/apidom-ns-openapi-3-0-1.0.0-rc.1.tgz", + "integrity": "sha512-TC2EBxBFJWD5pbZKUcbySqCt2nQmeP60ooS4f4Nl5r6vB/BeNbuO4FmO7CDI8OXD7b4J2+ro5KrXMs1EOQ3kVA==", + "license": "Apache-2.0", + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-error": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-json-schema-draft-4": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "ts-mixer": "^6.0.3" + } + }, + "node_modules/@swagger-api/apidom-ns-openapi-3-1": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-ns-openapi-3-1/-/apidom-ns-openapi-3-1-1.0.0-rc.1.tgz", + "integrity": "sha512-IY87MhqFBJnzhPWlr/OEVUa3iDjZuiwlyoWX4lw2jbKX+mLDrceGG5nqZawDACAjTjvtsjJcFP81D2VmjHVT5Q==", + "license": "Apache-2.0", + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-ast": "^1.0.0-rc.1", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-json-pointer": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-json-schema-2020-12": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-openapi-3-0": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "ts-mixer": "^6.0.3" + } + }, + "node_modules/@swagger-api/apidom-parser-adapter-api-design-systems-json": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-api-design-systems-json/-/apidom-parser-adapter-api-design-systems-json-1.0.0-rc.1.tgz", + "integrity": "sha512-1/koF8VwJHzFwk6FMWen39vpMUNcoCMXVY6MjMGag0h37LY5YAByl0LcYzLa33cvm5KCa23Aa75cu7Ns0SR1HQ==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-api-design-systems": "^1.0.0-rc.1", + "@swagger-api/apidom-parser-adapter-json": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@swagger-api/apidom-parser-adapter-api-design-systems-yaml": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-api-design-systems-yaml/-/apidom-parser-adapter-api-design-systems-yaml-1.0.0-rc.1.tgz", + "integrity": "sha512-Gjx1gojtYvGFqKnGttv84ba0RCkY7Xa+12kj9HVik8G+YVzUN78Qt8yu96ak0oXFlY1Ai8MQb5siC8YH4pC8Dg==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-api-design-systems": "^1.0.0-rc.1", + "@swagger-api/apidom-parser-adapter-yaml-1-2": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@swagger-api/apidom-parser-adapter-arazzo-json-1": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-arazzo-json-1/-/apidom-parser-adapter-arazzo-json-1-1.0.0-rc.1.tgz", + "integrity": "sha512-RHIly3bprJELMlt91UFqmMbAtIxDyHi8DM27YVXRjrX7zncP6QKyevcg2ajEe8UaNtkCFvPZW9h0gDh/ZW6ZYQ==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-arazzo-1": "^1.0.0-rc.1", + "@swagger-api/apidom-parser-adapter-json": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@swagger-api/apidom-parser-adapter-arazzo-yaml-1": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-arazzo-yaml-1/-/apidom-parser-adapter-arazzo-yaml-1-1.0.0-rc.1.tgz", + "integrity": "sha512-a+FweCIFAAnjvEWpMAd93xczbYX7AU4prwAMJ3QpFszltq2K7HKWUN1mMRplYPg5SSRLZojymdyMlu1evuP2Sg==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-arazzo-1": "^1.0.0-rc.1", + "@swagger-api/apidom-parser-adapter-yaml-1-2": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@swagger-api/apidom-parser-adapter-asyncapi-json-2": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-asyncapi-json-2/-/apidom-parser-adapter-asyncapi-json-2-1.0.0-rc.1.tgz", + "integrity": "sha512-IKJ95OH35dW1+yGYDoE8uE3movG9z8Nht2QW8Ja75/H/jAFYGCxj56ZborEIiZxp83ItFqxQFn+ZUvwD7bDZew==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-asyncapi-2": "^1.0.0-rc.1", + "@swagger-api/apidom-parser-adapter-json": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@swagger-api/apidom-parser-adapter-asyncapi-yaml-2": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-asyncapi-yaml-2/-/apidom-parser-adapter-asyncapi-yaml-2-1.0.0-rc.1.tgz", + "integrity": "sha512-cVu2Ue1U809HiGeAR/54yF42y4UKiWh45sEKzkXPYJUqRUd2Ewyo5KHtlckjNnCDRILZEhaPaZFpxURSbyUeSg==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-asyncapi-2": "^1.0.0-rc.1", + "@swagger-api/apidom-parser-adapter-yaml-1-2": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@swagger-api/apidom-parser-adapter-json": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-json/-/apidom-parser-adapter-json-1.0.0-rc.1.tgz", + "integrity": "sha512-pmWOuZFxSNdbV1xNV0IoIrRiweaVl9yGAiEtiYH0BzbD+yGQSxi1ltMkZDVoyBPbe2NtygFDRaINSDLwuYpUYA==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-ast": "^1.0.0-rc.1", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-error": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "tree-sitter": "=0.21.1", + "tree-sitter-json": "=0.24.8", + "web-tree-sitter": "=0.24.5" + } + }, + "node_modules/@swagger-api/apidom-parser-adapter-openapi-json-2": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-openapi-json-2/-/apidom-parser-adapter-openapi-json-2-1.0.0-rc.1.tgz", + "integrity": "sha512-+OsFBsD9PPqtcgETXU7l00/TMOfbtM+gvafJIdS/a+O1NQ2upAujQB3ArIB3sry3vloorjKmPyY6ZK/8rEKhNA==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-openapi-2": "^1.0.0-rc.1", + "@swagger-api/apidom-parser-adapter-json": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@swagger-api/apidom-parser-adapter-openapi-json-3-0": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-openapi-json-3-0/-/apidom-parser-adapter-openapi-json-3-0-1.0.0-rc.1.tgz", + "integrity": "sha512-FEUJ+RaXKMP6LHMVeVyUPKdqjEqMSEZVhpvZt3Kh5fvnZvdgWngqs4gUjxO+dQCDVWkBxH/29uXm2eghdaM2Lw==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-openapi-3-0": "^1.0.0-rc.1", + "@swagger-api/apidom-parser-adapter-json": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@swagger-api/apidom-parser-adapter-openapi-json-3-1": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-openapi-json-3-1/-/apidom-parser-adapter-openapi-json-3-1-1.0.0-rc.1.tgz", + "integrity": "sha512-pcfPj3FW2IWPYmU5kE0YB7npqV2vN+DvqUsw1GcDzsb8y2IdkzagHtMPZkM/KrfHFmhsoHm5YNpYC+Vvd2g61Q==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-openapi-3-1": "^1.0.0-rc.1", + "@swagger-api/apidom-parser-adapter-json": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@swagger-api/apidom-parser-adapter-openapi-yaml-2": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-openapi-yaml-2/-/apidom-parser-adapter-openapi-yaml-2-1.0.0-rc.1.tgz", + "integrity": "sha512-ckt6b1P+iwYkTMibixpo0oKWFm0wOGf88gslMMCo1xNaLVJnjxiadTQ/lNJd58CBJiQeN/dziTkRqGcFDqV9JQ==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-openapi-2": "^1.0.0-rc.1", + "@swagger-api/apidom-parser-adapter-yaml-1-2": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@swagger-api/apidom-parser-adapter-openapi-yaml-3-0": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-openapi-yaml-3-0/-/apidom-parser-adapter-openapi-yaml-3-0-1.0.0-rc.1.tgz", + "integrity": "sha512-JFyNwcj43cmps18Y+iqyna3uufyib8eLku+z4EhKFRPCuGFQ2bjsfVCFSP+Sv6sJATlagRRcfont+Q0BgNjwvw==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-openapi-3-0": "^1.0.0-rc.1", + "@swagger-api/apidom-parser-adapter-yaml-1-2": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@swagger-api/apidom-parser-adapter-openapi-yaml-3-1": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-openapi-yaml-3-1/-/apidom-parser-adapter-openapi-yaml-3-1-1.0.0-rc.1.tgz", + "integrity": "sha512-kLRZYxJdix+irs0HTXJ223rj4Ou8AXo9IHiSf44KTuAZ/bsuakb0P8xROHg5MWTTEHYMfDrdLX+LaUo3b2GFyA==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-openapi-3-1": "^1.0.0-rc.1", + "@swagger-api/apidom-parser-adapter-yaml-1-2": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + } + }, + "node_modules/@swagger-api/apidom-parser-adapter-yaml-1-2": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-parser-adapter-yaml-1-2/-/apidom-parser-adapter-yaml-1-2-1.0.0-rc.1.tgz", + "integrity": "sha512-XmRG/5lmoRusCupHEf10OeK1SQnSym4N1OrK+c3OTfN1GGX60Gxu2XCZ70pafJDuu+cvo/F8Db8UX3UOHapjwA==", + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-ast": "^1.0.0-rc.1", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-error": "^1.0.0-rc.1", + "@tree-sitter-grammars/tree-sitter-yaml": "=0.7.1", + "@types/ramda": "~0.30.0", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0", + "tree-sitter": "=0.22.4", + "web-tree-sitter": "=0.24.5" + } + }, + "node_modules/@swagger-api/apidom-parser-adapter-yaml-1-2/node_modules/@tree-sitter-grammars/tree-sitter-yaml": { + "version": "0.7.1", + "resolved": "https://registry.npmjs.org/@tree-sitter-grammars/tree-sitter-yaml/-/tree-sitter-yaml-0.7.1.tgz", + "integrity": "sha512-AynBwkIoQCTgjDR33bDUp9Mqq+YTco0is3n5hRApMqG9of/6A4eQsfC1/uSEeHSUyMQSYawcAWamsexnVpIP4Q==", + "hasInstallScript": true, + "license": "MIT", + "optional": true, + "dependencies": { + "node-addon-api": "^8.3.1", + "node-gyp-build": "^4.8.4" + }, + "peerDependencies": { + "tree-sitter": "^0.22.4" + }, + "peerDependenciesMeta": { + "tree-sitter": { + "optional": true + } + } + }, + "node_modules/@swagger-api/apidom-parser-adapter-yaml-1-2/node_modules/tree-sitter": { + "version": "0.22.4", + "resolved": "https://registry.npmjs.org/tree-sitter/-/tree-sitter-0.22.4.tgz", + "integrity": "sha512-usbHZP9/oxNsUY65MQUsduGRqDHQOou1cagUSwjhoSYAmSahjQDAVsh9s+SlZkn8X8+O1FULRGwHu7AFP3kjzg==", + "hasInstallScript": true, + "license": "MIT", + "optional": true, + "dependencies": { + "node-addon-api": "^8.3.0", + "node-gyp-build": "^4.8.4" + } + }, + "node_modules/@swagger-api/apidom-reference": { + "version": "1.0.0-rc.1", + "resolved": "https://registry.npmjs.org/@swagger-api/apidom-reference/-/apidom-reference-1.0.0-rc.1.tgz", + "integrity": "sha512-Xj4aYrawCseCf6N6UuGSIaboN60ERmQVcKqXs/rybQz1gnD2AVqb8gklC2sUdOIUyN+ehDy+HDSM8I+yP32J0w==", + "license": "Apache-2.0", + "dependencies": { + "@babel/runtime-corejs3": "^7.26.10", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-error": "^1.0.0-rc.1", + "@types/ramda": "~0.30.0", + "axios": "^1.12.2", + "minimatch": "^7.4.3", + "process": "^0.11.10", + "ramda": "~0.30.0", + "ramda-adjunct": "^5.0.0" + }, + "optionalDependencies": { + "@swagger-api/apidom-json-pointer": "^1.0.0-rc.0", + "@swagger-api/apidom-ns-arazzo-1": "^1.0.0-rc.0", + "@swagger-api/apidom-ns-asyncapi-2": "^1.0.0-rc.0", + "@swagger-api/apidom-ns-openapi-2": "^1.0.0-rc.0", + "@swagger-api/apidom-ns-openapi-3-0": "^1.0.0-rc.0", + "@swagger-api/apidom-ns-openapi-3-1": "^1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-api-design-systems-json": "^1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-api-design-systems-yaml": "^1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-arazzo-json-1": "^1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-arazzo-yaml-1": "^1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-asyncapi-json-2": "^1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-asyncapi-yaml-2": "^1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-json": "^1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-openapi-json-2": "^1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-openapi-json-3-0": "^1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-openapi-json-3-1": "^1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-openapi-yaml-2": "^1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-openapi-yaml-3-0": "^1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-openapi-yaml-3-1": "^1.0.0-rc.0", + "@swagger-api/apidom-parser-adapter-yaml-1-2": "^1.0.0-rc.0" + } + }, + "node_modules/@swagger-api/apidom-reference/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==", + "license": "MIT", + "dependencies": { + "balanced-match": "^1.0.0" + } + }, + "node_modules/@swagger-api/apidom-reference/node_modules/minimatch": { + "version": "7.4.6", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-7.4.6.tgz", + "integrity": "sha512-sBz8G/YjVniEz6lKPNpKxXwazJe4c19fEfV2GDMX6AjFz+MX9uDWIZW8XreVhkFW3fkIdTv/gxWr/Kks5FFAVw==", + "license": "ISC", + "dependencies": { + "brace-expansion": "^2.0.1" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/@swaggerexpert/cookie": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/@swaggerexpert/cookie/-/cookie-2.0.2.tgz", + "integrity": "sha512-DPI8YJ0Vznk4CT+ekn3rcFNq1uQwvUHZhH6WvTSPD0YKBIlMS9ur2RYKghXuxxOiqOam/i4lHJH4xTIiTgs3Mg==", + "license": "Apache-2.0", + "dependencies": { + "apg-lite": "^1.0.3" + }, + "engines": { + "node": ">=12.20.0" + } + }, + "node_modules/@swaggerexpert/json-pointer": { + "version": "2.10.2", + "resolved": "https://registry.npmjs.org/@swaggerexpert/json-pointer/-/json-pointer-2.10.2.tgz", + "integrity": "sha512-qMx1nOrzoB+PF+pzb26Q4Tc2sOlrx9Ba2UBNX9hB31Omrq+QoZ2Gly0KLrQWw4Of1AQ4J9lnD+XOdwOdcdXqqw==", + "license": "Apache-2.0", + "dependencies": { + "apg-lite": "^1.0.4" + }, + "engines": { + "node": ">=12.20.0" + } + }, + "node_modules/@types/hapi__joi": { + "version": "17.1.15", + "resolved": "https://registry.npmjs.org/@types/hapi__joi/-/hapi__joi-17.1.15.tgz", + "integrity": "sha512-Ehq/YQB0ZqZGObrGngztxtThTiShrG0jlqyUSsNK3cebJSoyYgE/hdZvYt6lH4Wimi28RowDwnr87XseiemqAg==", + "license": "MIT" + }, + "node_modules/@types/ramda": { + "version": "0.30.2", + "resolved": "https://registry.npmjs.org/@types/ramda/-/ramda-0.30.2.tgz", + "integrity": "sha512-PyzHvjCalm2BRYjAU6nIB3TprYwMNOUY/7P/N8bSzp9W/yM2YrtGtAnnVtaCNSeOZ8DzKyFDvaqQs7LnWwwmBA==", + "license": "MIT", + "dependencies": { + "types-ramda": "^0.30.1" + } + }, + "node_modules/@types/triple-beam": { + "version": "1.3.5", + "resolved": "https://registry.npmjs.org/@types/triple-beam/-/triple-beam-1.3.5.tgz", + "integrity": "sha512-6WaYesThRMCl19iryMYP7/x2OVgCtbIVflDGFpWnb9irXI3UjYE4AzmYuiUKY1AJstGijoY+MgUszMgRxIYTYw==", + "license": "MIT" + }, + "node_modules/@typespec/ts-http-runtime": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/@typespec/ts-http-runtime/-/ts-http-runtime-0.3.1.tgz", + "integrity": "sha512-SnbaqayTVFEA6/tYumdF0UmybY0KHyKwGPBXnyckFlrrKdhWFrL3a2HIPXHjht5ZOElKGcXfD2D63P36btb+ww==", + "license": "MIT", + "dependencies": { + "http-proxy-agent": "^7.0.0", + "https-proxy-agent": "^7.0.0", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@ungap/structured-clone": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.3.0.tgz", + "integrity": "sha512-WmoN8qaIAo7WTYWbAZuG8PYEhn5fkz7dZrqTBZ7dtt//lL2Gwms1IcnQ5yHqjDfX8Ft5j4YzDM23f87zBfDe9g==", + "dev": true, + "license": "ISC" + }, + "node_modules/acorn": { + "version": "8.15.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.15.0.tgz", + "integrity": "sha512-NZyJarBfL7nWwIq+FDL6Zp/yHEhePMNnnJ0y3qfieCrmNvYct8uvtiV41UvlSe6apAfk0fY1FbWx+NwfmpvtTg==", + "dev": true, + "license": "MIT", + "bin": { + "acorn": "bin/acorn" + }, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/acorn-jsx": { + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", + "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", + "dev": true, + "license": "MIT", + "peerDependencies": { + "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" + } + }, + "node_modules/agent-base": { + "version": "7.1.4", + "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-7.1.4.tgz", + "integrity": "sha512-MnA+YT8fwfJPgBx3m60MNqakm30XOkyIoH1y6huTQvC0PwZG7ki8NacLBcrPbNoo8vEZy7Jpuk7+jMO+CUovTQ==", + "license": "MIT", + "engines": { + "node": ">= 14" + } + }, + "node_modules/ajv": { + "version": "8.17.1", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.17.1.tgz", + "integrity": "sha512-B/gBuNg5SiMTrPkC+A2+cW0RszwxYmn6VYxB/inlBStS5nx6xHIt/ehKRhIMhqusl7a8LjQoZnjCs5vhwxOQ1g==", + "license": "MIT", + "dependencies": { + "fast-deep-equal": "^3.1.3", + "fast-uri": "^3.0.1", + "json-schema-traverse": "^1.0.0", + "require-from-string": "^2.0.2" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/epoberezkin" + } + }, + "node_modules/ansi-colors": { + "version": "4.1.3", + "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.3.tgz", + "integrity": "sha512-/6w/C21Pm1A7aZitlI5Ni/2J6FFQN8i1Cvz3kHABAAbw93v/NlvKdVOqz7CCWz/3iv/JplRSEEZ83XION15ovw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "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==", + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "license": "MIT", + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/anymatch": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", + "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", + "dev": true, + "license": "ISC", + "dependencies": { + "normalize-path": "^3.0.0", + "picomatch": "^2.0.4" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/apg-lite": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/apg-lite/-/apg-lite-1.0.5.tgz", + "integrity": "sha512-SlI+nLMQDzCZfS39ihzjGp3JNBQfJXyMi6cg9tkLOCPVErgFsUIAEdO9IezR7kbP5Xd0ozcPNQBkf9TO5cHgWw==", + "license": "BSD-2-Clause" + }, + "node_modules/argparse": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", + "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", + "license": "Python-2.0" + }, + "node_modules/assertion-error": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", + "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", + "dev": true, + "license": "MIT", + "engines": { + "node": "*" + } + }, + "node_modules/async": { + "version": "3.2.6", + "resolved": "https://registry.npmjs.org/async/-/async-3.2.6.tgz", + "integrity": "sha512-htCUDlxyyCLMgaM3xXg0C0LW2xqfuQ6p05pCEIsXuyQ+a1koYKTuBMzRNwmybfLgvJDMd0r1LTn4+E0Ti6C2AA==", + "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==", + "license": "MIT" + }, + "node_modules/axios": { + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/axios/-/axios-1.13.1.tgz", + "integrity": "sha512-hU4EGxxt+j7TQijx1oYdAjw4xuIp1wRQSsbMFwSthCWeBQur1eF+qJ5iQ5sN3Tw8YRzQNKb8jszgBdMDVqwJcw==", + "license": "MIT", + "dependencies": { + "follow-redirects": "^1.15.6", + "form-data": "^4.0.4", + "proxy-from-env": "^1.1.0" + } + }, + "node_modules/balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", + "license": "MIT" + }, + "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==", + "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/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": "4.1.0", + "resolved": "https://registry.npmjs.org/bl/-/bl-4.1.0.tgz", + "integrity": "sha512-1W07cM9gS6DcLperZfFSj+bWLtaPGSOHWhPiGzXmvVJbRLdG82sH/Kn8EtW1VqWVA54AKf2h5k5BbnIbwF3h6w==", + "license": "MIT", + "dependencies": { + "buffer": "^5.5.0", + "inherits": "^2.0.4", + "readable-stream": "^3.4.0" + } + }, + "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/browser-stdout": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", + "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", + "dev": true, + "license": "ISC" + }, + "node_modules/buffer": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz", + "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==", + "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-equal-constant-time": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", + "integrity": "sha512-zRpUiDwd/xk6ADqPMATG8vc9VPrkck7T07OIx0gnjmJAnHnTVXNQG3vfvWNuiZIkwu9KrKdA1iJKfsfTVxE6NA==", + "license": "BSD-3-Clause" + }, + "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==", + "license": "MIT", + "dependencies": { + "es-errors": "^1.3.0", + "function-bind": "^1.1.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "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==", + "license": "MIT", + "dependencies": { + "pascal-case": "^3.1.2", + "tslib": "^2.0.3" + } + }, + "node_modules/camelcase": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", + "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/capital-case": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/capital-case/-/capital-case-1.0.4.tgz", + "integrity": "sha512-ds37W8CytHgwnhGGTi88pcPyR15qoNkOpYwmMMfnWqqWgESapLqvDx6huFjQ5vqWSn2Z06173XNA7LtMOeUh1A==", + "license": "MIT", + "dependencies": { + "no-case": "^3.0.4", + "tslib": "^2.0.3", + "upper-case-first": "^2.0.2" + } + }, + "node_modules/chai": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/chai/-/chai-4.5.0.tgz", + "integrity": "sha512-RITGBfijLkBddZvnn8jdqoTypxvqbOLYQkGGxXzeFjVHvudaPw0HNFD9x928/eUwYWd2dPCugVqspGALTZZQKw==", + "dev": true, + "license": "MIT", + "dependencies": { + "assertion-error": "^1.1.0", + "check-error": "^1.0.3", + "deep-eql": "^4.1.3", + "get-func-name": "^2.0.2", + "loupe": "^2.3.6", + "pathval": "^1.1.1", + "type-detect": "^4.1.0" + }, + "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==", + "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==", + "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/check-error": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.3.tgz", + "integrity": "sha512-iKEoDYaRmd1mxM90a2OEfWhjsjPpYPuQ+lMYsoxB126+t8fw7ySEO48nmDg5COTjxDI65/Y2OWpeEHk3ZOe8zg==", + "dev": true, + "license": "MIT", + "dependencies": { + "get-func-name": "^2.0.2" + }, + "engines": { + "node": "*" + } + }, + "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/ci-info": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-4.3.1.tgz", + "integrity": "sha512-Wdy2Igu8OcBpI2pZePZ5oWjPC38tmDVx5WKUXKwlLYkA0ozo85sLsLvkBbBn/sZaSCMFOGZJ14fvW9t5/d7kdA==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/sibiraj-s" + } + ], + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "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==", + "license": "MIT", + "dependencies": { + "restore-cursor": "^3.1.0" + }, + "engines": { + "node": ">=8" + } + }, + "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==", + "license": "MIT", + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "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/clone": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz", + "integrity": "sha512-JQHZ2QMW6l3aH/j6xCqQThY/9OH4D/9ls34cgkUBiEeocRTU04tHfKPBsUK1PqZCUQM7GiA0IIXJSuXHI64Kbg==", + "license": "MIT", + "engines": { + "node": ">=0.8" + } + }, + "node_modules/color": { + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/color/-/color-5.0.2.tgz", + "integrity": "sha512-e2hz5BzbUPcYlIRHo8ieAhYgoajrJr+hWoceg6E345TPsATMUKqDgzt8fSXZJJbxfpiPzkWyphz8yn8At7q3fA==", + "license": "MIT", + "dependencies": { + "color-convert": "^3.0.1", + "color-string": "^2.0.0" + }, + "engines": { + "node": ">=18" + } + }, + "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==", + "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==", + "license": "MIT" + }, + "node_modules/color-string": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/color-string/-/color-string-2.1.2.tgz", + "integrity": "sha512-RxmjYxbWemV9gKu4zPgiZagUxbH3RQpEIO77XoSSX0ivgABDZ+h8Zuash/EMFLTI4N9QgFPOJ6JQpPZKFxa+dA==", + "license": "MIT", + "dependencies": { + "color-name": "^2.0.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/color-string/node_modules/color-name": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-2.0.2.tgz", + "integrity": "sha512-9vEt7gE16EW7Eu7pvZnR0abW9z6ufzhXxGXZEVU9IqPdlsUiMwJeJfRtq0zePUmnbHGT9zajca7mX8zgoayo4A==", + "license": "MIT", + "engines": { + "node": ">=12.20" + } + }, + "node_modules/color/node_modules/color-convert": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-3.1.2.tgz", + "integrity": "sha512-UNqkvCDXstVck3kdowtOTWROIJQwafjOfXSmddoDrXo4cewMKmusCeF22Q24zvjR8nwWib/3S/dfyzPItPEiJg==", + "license": "MIT", + "dependencies": { + "color-name": "^2.0.0" + }, + "engines": { + "node": ">=14.6" + } + }, + "node_modules/color/node_modules/color-name": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-2.0.2.tgz", + "integrity": "sha512-9vEt7gE16EW7Eu7pvZnR0abW9z6ufzhXxGXZEVU9IqPdlsUiMwJeJfRtq0zePUmnbHGT9zajca7mX8zgoayo4A==", + "license": "MIT", + "engines": { + "node": ">=12.20" + } + }, + "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==", + "license": "MIT", + "dependencies": { + "delayed-stream": "~1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "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/constant-case": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/constant-case/-/constant-case-3.0.4.tgz", + "integrity": "sha512-I2hSBi7Vvs7BEuJDr5dDHfzb/Ruj3FyvFyh7KLilAjNQw3Be+xgqUBA2W6scVEcL0hL1dwPRtIqEPVUCKkSsyQ==", + "license": "MIT", + "dependencies": { + "no-case": "^3.0.4", + "tslib": "^2.0.3", + "upper-case": "^2.0.2" + } + }, + "node_modules/core-js-pure": { + "version": "3.46.0", + "resolved": "https://registry.npmjs.org/core-js-pure/-/core-js-pure-3.46.0.tgz", + "integrity": "sha512-NMCW30bHNofuhwLhYPt66OLOKTMbOhgTTatKVbaQC3KRHpTCiRIBYvtshr+NBYSnBxwAFhjW/RfJ0XbIjS16rw==", + "hasInstallScript": true, + "license": "MIT", + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/core-js" + } + }, + "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": { + "path-key": "^3.1.0", + "shebang-command": "^2.0.0", + "which": "^2.0.1" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/crypto-js": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/crypto-js/-/crypto-js-4.2.0.tgz", + "integrity": "sha512-KALDyEYgpY+Rlob/iriUtjV6d5Eq+Y191A5g4UqLAi8CyGP9N1+FdVbkc1SxKc2r4YAYqG8JzO2KGL+AizD70Q==", + "license": "MIT" + }, + "node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/decamelize": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", + "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/deep-eql": { + "version": "4.1.4", + "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-4.1.4.tgz", + "integrity": "sha512-SUwdGfqdKOwxCPeVYjwSyRpJ7Z+fhpwIAtmCUdZIWZ/YP5R9WAsyuSgpLVDi9bjWoN2LXHNss/dk3urXtdQxGg==", + "dev": true, + "license": "MIT", + "dependencies": { + "type-detect": "^4.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "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==", + "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==", + "license": "MIT", + "dependencies": { + "clone": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/define-lazy-prop": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/define-lazy-prop/-/define-lazy-prop-2.0.0.tgz", + "integrity": "sha512-Ds09qNh8yw3khSjiJjiUInaGX9xlqZDY7JVryGxdxV7NPeuqQfplOpQ66yJFZut3jLa5zOwkXw1g9EI2uKh4Og==", + "license": "MIT", + "engines": { + "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==", + "license": "MIT", + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/diff": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/diff/-/diff-5.2.0.tgz", + "integrity": "sha512-uIFDxqpRZGZ6ThOk84hEfqWoHx2devRFvpTZcTHur85vImfaxUbTW9Ryh4CpCuDnToOP1CEtXKIgytHBPVff5A==", + "dev": true, + "license": "BSD-3-Clause", + "engines": { + "node": ">=0.3.1" + } + }, + "node_modules/doctrine": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", + "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "esutils": "^2.0.2" + }, + "engines": { + "node": ">=6.0.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==", + "license": "MIT", + "dependencies": { + "no-case": "^3.0.4", + "tslib": "^2.0.3" + } + }, + "node_modules/dotenv": { + "version": "16.3.1", + "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.3.1.tgz", + "integrity": "sha512-IPzF4w4/Rd94bA9imS68tZBaYyBWSCE47V1RGuMrB94iyTOIEwRmVL2x/4An+6mETpLrKJ5hQkB8W4kFAadeIQ==", + "license": "BSD-2-Clause", + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/motdotla/dotenv?sponsor=1" + } + }, + "node_modules/dunder-proto": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/dunder-proto/-/dunder-proto-1.0.1.tgz", + "integrity": "sha512-KIN/nDJBQRcXw0MLVhZE9iQHmG68qAVIBg9CqmUYjmQIhgij9U5MFvrqkUL5FbtyyzZuOeOt0zdeRe4UY7ct+A==", + "license": "MIT", + "dependencies": { + "call-bind-apply-helpers": "^1.0.1", + "es-errors": "^1.3.0", + "gopd": "^1.2.0" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/ecdsa-sig-formatter": { + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", + "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", + "license": "Apache-2.0", + "dependencies": { + "safe-buffer": "^5.0.1" + } + }, + "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/enabled": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/enabled/-/enabled-2.0.0.tgz", + "integrity": "sha512-AKrN98kuwOzMIdAizXGI86UFBoo26CL21UM763y1h/GMSJ4/OHU9k2YlsmBpyScFo/wbLzWQJBMCW4+IO3/+OQ==", + "license": "MIT" + }, + "node_modules/es-define-property": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.1.tgz", + "integrity": "sha512-e3nRfgfUZ4rNGL232gUgX06QNyyez04KdjFrF+LTRoOXmrOgFKDg4BCdsjW8EnT69eqdYGmRpJwiPVYNrCaW3g==", + "license": "MIT", + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-errors": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz", + "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", + "license": "MIT", + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-object-atoms": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/es-object-atoms/-/es-object-atoms-1.1.1.tgz", + "integrity": "sha512-FGgH2h8zKNim9ljj7dankFPcICIK9Cp5bm+c2gQSYePhpaG5+esrLODihIorn+Pe6FGJzWhXQotPv73jTaldXA==", + "license": "MIT", + "dependencies": { + "es-errors": "^1.3.0" + }, + "engines": { + "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==", + "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/escalade": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.2.0.tgz", + "integrity": "sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/escape-string-regexp": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", + "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/eslint": { + "version": "8.57.1", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.57.1.tgz", + "integrity": "sha512-ypowyDxpVSYpkXr9WPv2PAZCtNip1Mv5KTW0SCurXv/9iOpcrH9PaqUElksqEB6pChqHGDRCFTyrZlGhnLNGiA==", + "deprecated": "This version is no longer supported. Please see https://eslint.org/version-support for other options.", + "dev": true, + "license": "MIT", + "dependencies": { + "@eslint-community/eslint-utils": "^4.2.0", + "@eslint-community/regexpp": "^4.6.1", + "@eslint/eslintrc": "^2.1.4", + "@eslint/js": "8.57.1", + "@humanwhocodes/config-array": "^0.13.0", + "@humanwhocodes/module-importer": "^1.0.1", + "@nodelib/fs.walk": "^1.2.8", + "@ungap/structured-clone": "^1.2.0", + "ajv": "^6.12.4", + "chalk": "^4.0.0", + "cross-spawn": "^7.0.2", + "debug": "^4.3.2", + "doctrine": "^3.0.0", + "escape-string-regexp": "^4.0.0", + "eslint-scope": "^7.2.2", + "eslint-visitor-keys": "^3.4.3", + "espree": "^9.6.1", + "esquery": "^1.4.2", + "esutils": "^2.0.2", + "fast-deep-equal": "^3.1.3", + "file-entry-cache": "^6.0.1", + "find-up": "^5.0.0", + "glob-parent": "^6.0.2", + "globals": "^13.19.0", + "graphemer": "^1.4.0", + "ignore": "^5.2.0", + "imurmurhash": "^0.1.4", + "is-glob": "^4.0.0", + "is-path-inside": "^3.0.3", + "js-yaml": "^4.1.0", + "json-stable-stringify-without-jsonify": "^1.0.1", + "levn": "^0.4.1", + "lodash.merge": "^4.6.2", + "minimatch": "^3.1.2", + "natural-compare": "^1.4.0", + "optionator": "^0.9.3", + "strip-ansi": "^6.0.1", + "text-table": "^0.2.0" + }, + "bin": { + "eslint": "bin/eslint.js" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/eslint-scope": { + "version": "7.2.2", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", + "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", + "dev": true, + "license": "BSD-2-Clause", + "dependencies": { + "esrecurse": "^4.3.0", + "estraverse": "^5.2.0" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/eslint-visitor-keys": { + "version": "3.4.3", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", + "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", + "dev": true, + "license": "Apache-2.0", + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/eslint/node_modules/ajv": { + "version": "6.12.6", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", + "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", + "dev": true, + "license": "MIT", + "dependencies": { + "fast-deep-equal": "^3.1.1", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/epoberezkin" + } + }, + "node_modules/eslint/node_modules/json-schema-traverse": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", + "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", + "dev": true, + "license": "MIT" + }, + "node_modules/espree": { + "version": "9.6.1", + "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", + "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", + "dev": true, + "license": "BSD-2-Clause", + "dependencies": { + "acorn": "^8.9.0", + "acorn-jsx": "^5.3.2", + "eslint-visitor-keys": "^3.4.1" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/esquery": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.6.0.tgz", + "integrity": "sha512-ca9pw9fomFcKPvFLXhBKUK90ZvGibiGOvRJNbjljY7s7uq/5YO4BOzcYtJqExdx99rF6aAcnRxHmcUHcz6sQsg==", + "dev": true, + "license": "BSD-3-Clause", + "dependencies": { + "estraverse": "^5.1.0" + }, + "engines": { + "node": ">=0.10" + } + }, + "node_modules/esrecurse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", + "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", + "dev": true, + "license": "BSD-2-Clause", + "dependencies": { + "estraverse": "^5.2.0" + }, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", + "dev": true, + "license": "BSD-2-Clause", + "engines": { + "node": ">=4.0" + } + }, + "node_modules/esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", + "dev": true, + "license": "BSD-2-Clause", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/events": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/events/-/events-3.3.0.tgz", + "integrity": "sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==", + "license": "MIT", + "engines": { + "node": ">=0.8.x" + } + }, + "node_modules/fast-deep-equal": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", + "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", + "license": "MIT" + }, + "node_modules/fast-json-patch": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/fast-json-patch/-/fast-json-patch-3.1.1.tgz", + "integrity": "sha512-vf6IHUX2SBcA+5/+4883dsIjpBTqmfBjmYiWK1savxQmFk4JfBMLa7ynTYOs1Rolp/T1betJxHiGD3g1Mn8lUQ==", + "license": "MIT" + }, + "node_modules/fast-json-stable-stringify": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", + "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", + "license": "MIT" + }, + "node_modules/fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", + "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", + "dev": true, + "license": "MIT" + }, + "node_modules/fast-uri": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/fast-uri/-/fast-uri-3.1.0.tgz", + "integrity": "sha512-iPeeDKJSWf4IEOasVVrknXpaBV0IApz/gp7S2bb7Z4Lljbl2MGJRqInZiUrQwV16cpzw/D3S5j5Julj/gT52AA==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/fastify" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/fastify" + } + ], + "license": "BSD-3-Clause" + }, + "node_modules/fast-xml-parser": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/fast-xml-parser/-/fast-xml-parser-5.3.0.tgz", + "integrity": "sha512-gkWGshjYcQCF+6qtlrqBqELqNqnt4CxruY6UVAWWnqb3DQ6qaNFEIKqzYep1XzHLM/QtrHVCxyPOtTk4LTQ7Aw==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/NaturalIntelligence" + } + ], + "license": "MIT", + "dependencies": { + "strnum": "^2.1.0" + }, + "bin": { + "fxparser": "src/cli/cli.js" + } + }, + "node_modules/fastq": { + "version": "1.19.1", + "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.19.1.tgz", + "integrity": "sha512-GwLTyxkCXjXbxqIhTsMI2Nui8huMPtnxg7krajPJAjnEG/iiOS7i+zCtWGZR9G0NBKbXKh6X9m9UIsYX/N6vvQ==", + "dev": true, + "license": "ISC", + "dependencies": { + "reusify": "^1.0.4" + } + }, + "node_modules/fecha": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/fecha/-/fecha-4.2.3.tgz", + "integrity": "sha512-OP2IUU6HeYKJi3i0z4A19kHMQoLVs4Hc+DPqqxI2h/DPZHTm/vjsfC6P0b4jCMy14XizLBqvndQ+UilD7707Jw==", + "license": "MIT" + }, + "node_modules/fetch-retry": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/fetch-retry/-/fetch-retry-6.0.0.tgz", + "integrity": "sha512-BUFj1aMubgib37I3v4q78fYo63Po7t4HUPTpQ6/QE6yK6cIQrP+W43FYToeTEyg5m2Y7eFUtijUuAv/PDlWuag==", + "license": "MIT" + }, + "node_modules/file-entry-cache": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", + "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", + "dev": true, + "license": "MIT", + "dependencies": { + "flat-cache": "^3.0.4" + }, + "engines": { + "node": "^10.12.0 || >=12.0.0" + } + }, + "node_modules/fill-range": { + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", + "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", + "dev": true, + "license": "MIT", + "dependencies": { + "to-regex-range": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "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/flat": { + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", + "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", + "dev": true, + "license": "BSD-3-Clause", + "bin": { + "flat": "cli.js" + } + }, + "node_modules/flat-cache": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", + "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", + "dev": true, + "license": "MIT", + "dependencies": { + "flatted": "^3.2.9", + "keyv": "^4.5.3", + "rimraf": "^3.0.2" + }, + "engines": { + "node": "^10.12.0 || >=12.0.0" + } + }, + "node_modules/flatted": { + "version": "3.3.3", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.3.tgz", + "integrity": "sha512-GX+ysw4PBCz0PzosHDepZGANEuFCMLrnRTiEy9McGjmkCQYwRq4A/X786G/fjM/+OjsWSU1ZrY5qyARZmO/uwg==", + "dev": true, + "license": "ISC" + }, + "node_modules/fn.name": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/fn.name/-/fn.name-1.1.0.tgz", + "integrity": "sha512-GRnmB5gPyJpAhTQdSZTSp9uaPSvl09KoYcMQtsB9rQoOmzs9dH6ffeccH+Z+cv6P68Hu5bC6JjRh4Ah/mHSNRw==", + "license": "MIT" + }, + "node_modules/follow-redirects": { + "version": "1.15.11", + "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.11.tgz", + "integrity": "sha512-deG2P0JfjrTxl50XGCDyfI97ZGVCxIpfKYmfyrQ54n5FO/0gfIES8C/Psl6kWVDolizcaaxZJnTS0QSMxvnsBQ==", + "funding": [ + { + "type": "individual", + "url": "https://github.com/sponsors/RubenVerborgh" + } + ], + "license": "MIT", + "engines": { + "node": ">=4.0" + }, + "peerDependenciesMeta": { + "debug": { + "optional": true + } + } + }, + "node_modules/form-data": { + "version": "4.0.4", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.4.tgz", + "integrity": "sha512-KrGhL9Q4zjj0kiUt5OO4Mr/A/jlI2jDYs5eHBpYHPcBEVSiipAvn2Ko2HnPe20rmcuuvMHNdZFp+4IlGTMF0Ow==", + "license": "MIT", + "dependencies": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.8", + "es-set-tostringtag": "^2.1.0", + "hasown": "^2.0.2", + "mime-types": "^2.1.12" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/fs-extra": { + "version": "11.3.2", + "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-11.3.2.tgz", + "integrity": "sha512-Xr9F6z6up6Ws+NjzMCZc6WXg2YFRlrLP9NQDO3VQrWrfiojdhS56TzueT88ze0uBdCTwEIhQ3ptnmKeWGFAe0A==", + "license": "MIT", + "dependencies": { + "graceful-fs": "^4.2.0", + "jsonfile": "^6.0.1", + "universalify": "^2.0.0" + }, + "engines": { + "node": ">=14.14" + } + }, + "node_modules/fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", + "dev": true, + "license": "ISC" + }, + "node_modules/fsevents": { + "version": "2.3.3", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", + "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", + "dev": true, + "hasInstallScript": true, + "license": "MIT", + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": "^8.16.0 || ^10.6.0 || >=11.0.0" + } + }, + "node_modules/function-bind": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", + "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", + "license": "MIT", + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/get-caller-file": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", + "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", + "dev": true, + "license": "ISC", + "engines": { + "node": "6.* || 8.* || >= 10.*" + } + }, + "node_modules/get-func-name": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.2.tgz", + "integrity": "sha512-8vXOvuE167CtIc3OyItco7N/dpRtBbYOsPsXCz7X/PMnlGjYjSGuZJgM1Y7mmew7BKf9BqvLX2tnOVy1BBUsxQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": "*" + } + }, + "node_modules/get-intrinsic": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.3.0.tgz", + "integrity": "sha512-9fSjSaos/fRIVIp+xSJlE6lfwhES7LNtKaCBIamHsjr2na1BiABJPo0mOjjz8GJDURarmCPGqaiVg5mfjb98CQ==", + "license": "MIT", + "dependencies": { + "call-bind-apply-helpers": "^1.0.2", + "es-define-property": "^1.0.1", + "es-errors": "^1.3.0", + "es-object-atoms": "^1.1.1", + "function-bind": "^1.1.2", + "get-proto": "^1.0.1", + "gopd": "^1.2.0", + "has-symbols": "^1.1.0", + "hasown": "^2.0.2", + "math-intrinsics": "^1.1.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/get-proto": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/get-proto/-/get-proto-1.0.1.tgz", + "integrity": "sha512-sTSfBjoXBp89JvIKIefqw7U2CCebsc74kiY6awiGogKtoSGbgjYE/G/+l9sF3MWFPNc9IcoOC4ODfKHfxFmp0g==", + "license": "MIT", + "dependencies": { + "dunder-proto": "^1.0.1", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/glob": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/glob/-/glob-8.1.0.tgz", + "integrity": "sha512-r8hpEjiQEYlF2QU0df3dS+nxxSIreXQS1qRhMJM0Q5NDdR386C7jb7Hwwod8Fgiuex+k0GFjgft18yvxm5XoCQ==", + "deprecated": "Glob versions prior to v9 are no longer supported", + "dev": true, + "license": "ISC", + "dependencies": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^5.0.1", + "once": "^1.3.0" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/glob-parent": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", + "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", + "dev": true, + "license": "ISC", + "dependencies": { + "is-glob": "^4.0.3" + }, + "engines": { + "node": ">=10.13.0" + } + }, + "node_modules/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==", + "dev": true, + "license": "MIT", + "dependencies": { + "balanced-match": "^1.0.0" + } + }, + "node_modules/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" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/globals": { + "version": "13.24.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", + "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "type-fest": "^0.20.2" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/gopd": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.2.0.tgz", + "integrity": "sha512-ZUKRh6/kUFoAiTAtTYPZJ3hw9wNxx+BIBOijnlG9PnrJsCcSjs1wyyD6vJpaYtgnzDrKYRSqf3OO6Rfa93xsRg==", + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/graceful-fs": { + "version": "4.2.11", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", + "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", + "license": "ISC" + }, + "node_modules/graphemer": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", + "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", + "dev": true, + "license": "MIT" + }, + "node_modules/has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/has-symbols": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.1.0.tgz", + "integrity": "sha512-1cDNdwJ2Jaohmb3sg4OmKaMBwuC48sYni5HUw2DvsC8LjGTLK9h+eb1X6RyuOHe4hT0ULCW68iomhjUoKUqlPQ==", + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-tostringtag": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.2.tgz", + "integrity": "sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==", + "license": "MIT", + "dependencies": { + "has-symbols": "^1.0.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/hasown": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", + "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", + "license": "MIT", + "dependencies": { + "function-bind": "^1.1.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/he": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", + "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", + "dev": true, + "license": "MIT", + "bin": { + "he": "bin/he" + } + }, + "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==", + "license": "MIT", + "dependencies": { + "capital-case": "^1.0.4", + "tslib": "^2.0.3" + } + }, + "node_modules/hjson": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/hjson/-/hjson-3.2.2.tgz", + "integrity": "sha512-MkUeB0cTIlppeSsndgESkfFD21T2nXPRaBStLtf3cAYA2bVEFdXlodZB0TukwZiobPD1Ksax5DK4RTZeaXCI3Q==", + "license": "MIT", + "bin": { + "hjson": "bin/hjson" + } + }, + "node_modules/http-link-header": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/http-link-header/-/http-link-header-1.1.3.tgz", + "integrity": "sha512-3cZ0SRL8fb9MUlU3mKM61FcQvPfXx2dBrZW3Vbg5CXa8jFlK8OaEpePenLe1oEXQduhz8b0QjsqfS59QP4AJDQ==", + "license": "MIT", + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/http-proxy-agent": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-7.0.2.tgz", + "integrity": "sha512-T1gkAiYYDWYx3V5Bmyu7HcfcvL7mUrTWiM6yOfa3PIphViJ/gFPbvidQ+veqSOHci/PxBcDabeUNCzpOODJZig==", + "license": "MIT", + "dependencies": { + "agent-base": "^7.1.0", + "debug": "^4.3.4" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/https-proxy-agent": { + "version": "7.0.6", + "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-7.0.6.tgz", + "integrity": "sha512-vK9P5/iUfdl95AI+JVyUuIcVtd4ofvtrOr3HNtM2yxC9bnMbEdp3x01OhQNnjb8IJYi38VlTE3mBXwcfvywuSw==", + "license": "MIT", + "dependencies": { + "agent-base": "^7.1.2", + "debug": "4" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/ieee754": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", + "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==", + "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": "BSD-3-Clause" + }, + "node_modules/ignore": { + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.2.tgz", + "integrity": "sha512-hsBTNUqQTDwkWtcdYI2i06Y/nUBEsNEDJKjWdigLvegy8kDuJAS8uRlpkkcQpyEXL0Z/pjDy5HBmMjRCJ2gq+g==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 4" + } + }, + "node_modules/import-fresh": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.1.tgz", + "integrity": "sha512-TR3KfrTZTYLPB6jUjfx6MF9WcWrHL9su5TObK4ZkYgBdWKPOFoSoQIdEuTuR82pmtxH2spWG9h6etwfr1pLBqQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "parent-module": "^1.0.0", + "resolve-from": "^4.0.0" + }, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/imurmurhash": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", + "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.8.19" + } + }, + "node_modules/inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", + "deprecated": "This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful.", + "dev": true, + "license": "ISC", + "dependencies": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "node_modules/inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", + "license": "ISC" + }, + "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", + "dependencies": { + "binary-extensions": "^2.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/is-docker": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/is-docker/-/is-docker-2.2.1.tgz", + "integrity": "sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ==", + "license": "MIT", + "bin": { + "is-docker": "cli.js" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/is-glob": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", + "dev": true, + "license": "MIT", + "dependencies": { + "is-extglob": "^2.1.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/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==", + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/is-number": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", + "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.12.0" + } + }, + "node_modules/is-path-inside": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", + "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/is-plain-obj": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", + "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/is-stream": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", + "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", + "license": "MIT", + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "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==", + "license": "MIT", + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/is-wsl": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/is-wsl/-/is-wsl-2.2.0.tgz", + "integrity": "sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww==", + "license": "MIT", + "dependencies": { + "is-docker": "^2.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", + "dev": true, + "license": "ISC" + }, + "node_modules/joi": { + "version": "17.13.3", + "resolved": "https://registry.npmjs.org/joi/-/joi-17.13.3.tgz", + "integrity": "sha512-otDA4ldcIx+ZXsKHWmp0YizCweVRZG96J10b0FevjfuncLO1oX59THoAmHkNubYJ+9gWsYsp5k8v4ib6oDv1fA==", + "license": "BSD-3-Clause", + "dependencies": { + "@hapi/hoek": "^9.3.0", + "@hapi/topo": "^5.1.0", + "@sideway/address": "^4.1.5", + "@sideway/formula": "^3.0.1", + "@sideway/pinpoint": "^2.0.0" + } + }, + "node_modules/js-yaml": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", + "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", + "license": "MIT", + "dependencies": { + "argparse": "^2.0.1" + }, + "bin": { + "js-yaml": "bin/js-yaml.js" + } + }, + "node_modules/jsbi": { + "version": "3.2.5", + "resolved": "https://registry.npmjs.org/jsbi/-/jsbi-3.2.5.tgz", + "integrity": "sha512-aBE4n43IPvjaddScbvWRA2YlTzKEynHzu7MqOyTipdHucf/VxS63ViCjxYRg86M8Rxwbt/GfzHl1kKERkt45fQ==", + "license": "Apache-2.0" + }, + "node_modules/json-buffer": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", + "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", + "dev": true, + "license": "MIT" + }, + "node_modules/json-schema-traverse": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", + "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", + "license": "MIT" + }, + "node_modules/json-stable-stringify-without-jsonify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", + "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", + "dev": true, + "license": "MIT" + }, + "node_modules/jsonfile": { + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-6.2.0.tgz", + "integrity": "sha512-FGuPw30AdOIUTRMC2OMRtQV+jkVj2cfPqSeWXv1NEAJ1qZ5zb1X6z1mFhbfOB/iy3ssJCD+3KuZ8r8C3uVFlAg==", + "license": "MIT", + "dependencies": { + "universalify": "^2.0.0" + }, + "optionalDependencies": { + "graceful-fs": "^4.1.6" + } + }, + "node_modules/jsonwebtoken": { + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-9.0.2.tgz", + "integrity": "sha512-PRp66vJ865SSqOlgqS8hujT5U4AOgMfhrwYIuIhfKaoSCZcirrmASQr8CX7cUg+RMih+hgznrjp99o+W4pJLHQ==", + "license": "MIT", + "dependencies": { + "jws": "^3.2.2", + "lodash.includes": "^4.3.0", + "lodash.isboolean": "^3.0.3", + "lodash.isinteger": "^4.0.4", + "lodash.isnumber": "^3.0.3", + "lodash.isplainobject": "^4.0.6", + "lodash.isstring": "^4.0.1", + "lodash.once": "^4.0.0", + "ms": "^2.1.1", + "semver": "^7.5.4" + }, + "engines": { + "node": ">=12", + "npm": ">=6" + } + }, + "node_modules/jwa": { + "version": "1.4.2", + "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.2.tgz", + "integrity": "sha512-eeH5JO+21J78qMvTIDdBXidBd6nG2kZjg5Ohz/1fpa28Z4CcsWUzJ1ZZyFq/3z3N17aZy+ZuBoHljASbL1WfOw==", + "license": "MIT", + "dependencies": { + "buffer-equal-constant-time": "^1.0.1", + "ecdsa-sig-formatter": "1.0.11", + "safe-buffer": "^5.0.1" + } + }, + "node_modules/jws": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", + "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", + "license": "MIT", + "dependencies": { + "jwa": "^1.4.1", + "safe-buffer": "^5.0.1" + } + }, + "node_modules/keyv": { + "version": "4.5.4", + "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", + "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", + "dev": true, + "license": "MIT", + "dependencies": { + "json-buffer": "3.0.1" + } + }, + "node_modules/kuler": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/kuler/-/kuler-2.0.0.tgz", + "integrity": "sha512-Xq9nH7KlWZmXAtodXDDRE7vs6DU1gTU8zYDHDiWLSip45Egwq3plLHzPn27NgvzL2r1LMPC1vdqh98sQxtqj4A==", + "license": "MIT" + }, + "node_modules/levn": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", + "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "prelude-ls": "^1.2.1", + "type-check": "~0.4.0" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/locate-path": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", + "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", + "dev": true, + "license": "MIT", + "dependencies": { + "p-locate": "^5.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/lodash": { + "version": "4.17.21", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", + "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", + "license": "MIT" + }, + "node_modules/lodash.clonedeep": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", + "integrity": "sha512-H5ZhCF25riFd9uB5UCkVKo61m3S/xZk1x4wA6yp/L3RFP6Z/eHH1ymQcGLo7J3GMPfm0V/7m1tryHuGVxpqEBQ==", + "license": "MIT" + }, + "node_modules/lodash.includes": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", + "integrity": "sha512-W3Bx6mdkRTGtlJISOvVD/lbqjTlPPUDTMnlXZFnVwi9NKJ6tiAk6LVdlhZMm17VZisqhKcgzpO5Wz91PCt5b0w==", + "license": "MIT" + }, + "node_modules/lodash.isboolean": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", + "integrity": "sha512-Bz5mupy2SVbPHURB98VAcw+aHh4vRV5IPNhILUCsOzRmsTmSQ17jIuqopAentWoehktxGd9e/hbIXq980/1QJg==", + "license": "MIT" + }, + "node_modules/lodash.isinteger": { + "version": "4.0.4", + "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", + "integrity": "sha512-DBwtEWN2caHQ9/imiNeEA5ys1JoRtRfY3d7V9wkqtbycnAmTvRRmbHKDV4a0EYc678/dia0jrte4tjYwVBaZUA==", + "license": "MIT" + }, + "node_modules/lodash.isnumber": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", + "integrity": "sha512-QYqzpfwO3/CWf3XP+Z+tkQsfaLL/EnUlXWVkIk5FUPc4sBdTehEqZONuyRt2P67PXAk+NXmTBcc97zw9t1FQrw==", + "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==", + "license": "MIT" + }, + "node_modules/lodash.isstring": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", + "integrity": "sha512-0wJxfxH1wgO3GrbuP+dTTk7op+6L41QCXbGINEmD+ny/G/eCqGzxyCsh7159S+mgDDcoarnBw6PC1PS5+wUGgw==", + "license": "MIT" + }, + "node_modules/lodash.merge": { + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", + "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", + "dev": true, + "license": "MIT" + }, + "node_modules/lodash.once": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", + "integrity": "sha512-Sb487aTOCr9drQVL8pIxOzVhafOjZN9UU54hiN8PU3uAiSV7lx1yYNpbNmex2PK6dSJoNTSJUUswT651yww3Mg==", + "license": "MIT" + }, + "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==", + "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/logform": { + "version": "2.7.0", + "resolved": "https://registry.npmjs.org/logform/-/logform-2.7.0.tgz", + "integrity": "sha512-TFYA4jnP7PVbmlBIfhlSe+WKxs9dklXMTEGcBCIvLhE/Tn3H6Gk1norupVW7m5Cnd4bLcr08AytbyV/xj7f/kQ==", + "license": "MIT", + "dependencies": { + "@colors/colors": "1.6.0", + "@types/triple-beam": "^1.3.2", + "fecha": "^4.2.0", + "ms": "^2.1.1", + "safe-stable-stringify": "^2.3.1", + "triple-beam": "^1.3.0" + }, + "engines": { + "node": ">= 12.0.0" + } + }, + "node_modules/loupe": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/loupe/-/loupe-2.3.7.tgz", + "integrity": "sha512-zSMINGVYkdpYSOBmLi0D1Uo7JU9nVdQKrHxC8eYlV+9YKK9WePqAlL7lSlorG/U2Fw1w0hTBmaa/jrQ3UbPHtA==", + "dev": true, + "license": "MIT", + "dependencies": { + "get-func-name": "^2.0.1" + } + }, + "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==", + "license": "MIT", + "dependencies": { + "tslib": "^2.0.3" + } + }, + "node_modules/lru-cache": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", + "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", + "license": "ISC", + "dependencies": { + "yallist": "^3.0.2" + } + }, + "node_modules/math-intrinsics": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/math-intrinsics/-/math-intrinsics-1.1.0.tgz", + "integrity": "sha512-/IXtbwEk5HTPyEwyKX6hGkYXxM9nbj64B+ilVJnC/R6B0pH5G4V3b0pVbL7DBj4tkhBAppbQUlf6F6Xl9LHu1g==", + "license": "MIT", + "engines": { + "node": ">= 0.4" + } + }, + "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==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mime-types": { + "version": "2.1.35", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", + "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", + "license": "MIT", + "dependencies": { + "mime-db": "1.52.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "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==", + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/minim": { + "version": "0.23.8", + "resolved": "https://registry.npmjs.org/minim/-/minim-0.23.8.tgz", + "integrity": "sha512-bjdr2xW1dBCMsMGGsUeqM4eFI60m94+szhxWys+B1ztIt6gWSfeGBdSVCIawezeHYLYn0j6zrsXdQS/JllBzww==", + "license": "MIT", + "dependencies": { + "lodash": "^4.15.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "license": "ISC", + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, + "node_modules/mocha": { + "version": "10.8.2", + "resolved": "https://registry.npmjs.org/mocha/-/mocha-10.8.2.tgz", + "integrity": "sha512-VZlYo/WE8t1tstuRmqgeyBgCbJc/lEdopaa+axcKzTBJ+UIdlAB9XnmvTCAH4pwR4ElNInaedhEBmZD8iCSVEg==", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-colors": "^4.1.3", + "browser-stdout": "^1.3.1", + "chokidar": "^3.5.3", + "debug": "^4.3.5", + "diff": "^5.2.0", + "escape-string-regexp": "^4.0.0", + "find-up": "^5.0.0", + "glob": "^8.1.0", + "he": "^1.2.0", + "js-yaml": "^4.1.0", + "log-symbols": "^4.1.0", + "minimatch": "^5.1.6", + "ms": "^2.1.3", + "serialize-javascript": "^6.0.2", + "strip-json-comments": "^3.1.1", + "supports-color": "^8.1.1", + "workerpool": "^6.5.1", + "yargs": "^16.2.0", + "yargs-parser": "^20.2.9", + "yargs-unparser": "^2.0.0" + }, + "bin": { + "_mocha": "bin/_mocha", + "mocha": "bin/mocha.js" + }, + "engines": { + "node": ">= 14.0.0" + } + }, + "node_modules/mocha/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==", + "dev": true, + "license": "MIT", + "dependencies": { + "balanced-match": "^1.0.0" + } + }, + "node_modules/mocha/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" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/mocha/node_modules/supports-color": { + "version": "8.1.1", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", + "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", + "dev": true, + "license": "MIT", + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/supports-color?sponsor=1" + } + }, + "node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "license": "MIT" + }, + "node_modules/natural-compare": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", + "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", + "dev": true, + "license": "MIT" + }, + "node_modules/neotraverse": { + "version": "0.6.18", + "resolved": "https://registry.npmjs.org/neotraverse/-/neotraverse-0.6.18.tgz", + "integrity": "sha512-Z4SmBUweYa09+o6pG+eASabEpP6QkQ70yHj351pQoEXIs8uHbaU2DWVmzBANKgflPa47A50PtB2+NgRpQvr7vA==", + "license": "MIT", + "engines": { + "node": ">= 10" + } + }, + "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==", + "license": "MIT", + "dependencies": { + "lower-case": "^2.0.2", + "tslib": "^2.0.3" + } + }, + "node_modules/node-abort-controller": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/node-abort-controller/-/node-abort-controller-3.1.1.tgz", + "integrity": "sha512-AGK2yQKIjRuqnc6VkX2Xj5d+QW8xZ87pa1UK6yA6ouUyuxfHuMP6umE5QK7UmTeOAymo+Zx1Fxiuw9rVx8taHQ==", + "license": "MIT" + }, + "node_modules/node-addon-api": { + "version": "8.5.0", + "resolved": "https://registry.npmjs.org/node-addon-api/-/node-addon-api-8.5.0.tgz", + "integrity": "sha512-/bRZty2mXUIFY/xU5HLvveNHlswNJej+RnxBjOMkidWfwZzgTbPG1E3K5TOxRLOR+5hX7bSofy8yf1hZevMS8A==", + "license": "MIT", + "optional": true, + "engines": { + "node": "^18 || ^20 || >= 21" + } + }, + "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", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/jimmywarting" + }, + { + "type": "github", + "url": "https://paypal.me/jimmywarting" + } + ], + "license": "MIT", + "engines": { + "node": ">=10.5.0" + } + }, + "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==", + "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-fetch-commonjs": { + "version": "3.3.2", + "resolved": "https://registry.npmjs.org/node-fetch-commonjs/-/node-fetch-commonjs-3.3.2.tgz", + "integrity": "sha512-VBlAiynj3VMLrotgwOS3OyECFxas5y7ltLcK4t41lMUZeaK15Ym4QRkqN0EQKAFL42q9i21EPKjzLUPfltR72A==", + "license": "MIT", + "dependencies": { + "node-domexception": "^1.0.0", + "web-streams-polyfill": "^3.0.3" + }, + "engines": { + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/node-fetch" + } + }, + "node_modules/node-gyp-build": { + "version": "4.8.4", + "resolved": "https://registry.npmjs.org/node-gyp-build/-/node-gyp-build-4.8.4.tgz", + "integrity": "sha512-LA4ZjwlnUblHVgq0oBF3Jl/6h/Nvs5fzBLwdEF4nuxnFdsfajde4WfxtJr3CaiH+F6ewcIB/q4jQ4UzPyid+CQ==", + "license": "MIT", + "optional": true, + "bin": { + "node-gyp-build": "bin.js", + "node-gyp-build-optional": "optional.js", + "node-gyp-build-test": "build-test.js" + } + }, + "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/once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", + "dev": true, + "license": "ISC", + "dependencies": { + "wrappy": "1" + } + }, + "node_modules/one-time": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/one-time/-/one-time-1.0.0.tgz", + "integrity": "sha512-5DXOiRKwuSEcQ/l0kGCF6Q3jcADFv5tSmRaJck/OqkVFcOzutB134KRSfF0xDrL39MNnqxbHBbUUcjZIhTgb2g==", + "license": "MIT", + "dependencies": { + "fn.name": "1.x.x" + } + }, + "node_modules/onetime": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", + "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", + "license": "MIT", + "dependencies": { + "mimic-fn": "^2.1.0" + }, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/open": { + "version": "8.4.2", + "resolved": "https://registry.npmjs.org/open/-/open-8.4.2.tgz", + "integrity": "sha512-7x81NCL719oNbsq/3mh+hVrAWmFuEYUqrq/Iw3kUzH8ReypT9QQ0BLoJS7/G9k6N81XjW4qHWtjWwe/9eLy1EQ==", + "license": "MIT", + "dependencies": { + "define-lazy-prop": "^2.0.0", + "is-docker": "^2.1.1", + "is-wsl": "^2.2.0" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/openapi-path-templating": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/openapi-path-templating/-/openapi-path-templating-2.2.1.tgz", + "integrity": "sha512-eN14VrDvl/YyGxxrkGOHkVkWEoPyhyeydOUrbvjoz8K5eIGgELASwN1eqFOJ2CTQMGCy2EntOK1KdtJ8ZMekcg==", + "license": "Apache-2.0", + "dependencies": { + "apg-lite": "^1.0.4" + }, + "engines": { + "node": ">=12.20.0" + } + }, + "node_modules/openapi-server-url-templating": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/openapi-server-url-templating/-/openapi-server-url-templating-1.3.0.tgz", + "integrity": "sha512-DPlCms3KKEbjVQb0spV6Awfn6UWNheuG/+folQPzh/wUaKwuqvj8zt5gagD7qoyxtE03cIiKPgLFS3Q8Bz00uQ==", + "license": "Apache-2.0", + "dependencies": { + "apg-lite": "^1.0.4" + }, + "engines": { + "node": ">=12.20.0" + } + }, + "node_modules/optionator": { + "version": "0.9.4", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.4.tgz", + "integrity": "sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g==", + "dev": true, + "license": "MIT", + "dependencies": { + "deep-is": "^0.1.3", + "fast-levenshtein": "^2.0.6", + "levn": "^0.4.1", + "prelude-ls": "^1.2.1", + "type-check": "^0.4.0", + "word-wrap": "^1.2.5" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/ora": { + "version": "5.4.1", + "resolved": "https://registry.npmjs.org/ora/-/ora-5.4.1.tgz", + "integrity": "sha512-5b6Y85tPxZZ7QytO+BQzysW31HJku27cRIlkbAXaNx+BdcVi+LlRFmVXzeF6a7JCwJpyw5c4b+YSVImQIrBpuQ==", + "license": "MIT", + "dependencies": { + "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": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/p-limit": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", + "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "yocto-queue": "^0.1.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/p-locate": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", + "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", + "dev": true, + "license": "MIT", + "dependencies": { + "p-limit": "^3.0.2" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/param-case": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/param-case/-/param-case-3.0.4.tgz", + "integrity": "sha512-RXlj7zCYokReqWpOPH9oYivUzLYZ5vAPIfEmCTNViosC78F8F0H9y7T7gG2M39ymgutxF5gcFEsyZQSph9Bp3A==", + "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", + "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", + "dev": true, + "license": "MIT", + "dependencies": { + "callsites": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "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==", + "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==", + "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", + "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/path-key": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", + "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/pathval": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.1.tgz", + "integrity": "sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": "*" + } + }, + "node_modules/picomatch": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", + "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8.6" + }, + "funding": { + "url": "https://github.com/sponsors/jonschlinkert" + } + }, + "node_modules/prelude-ls": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", + "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/priorityqueuejs": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/priorityqueuejs/-/priorityqueuejs-1.0.0.tgz", + "integrity": "sha512-lg++21mreCEOuGWTbO5DnJKAdxfjrdN0S9ysoW9SzdSJvbkWpkaDdpG/cdsPCsEnoLUwmd9m3WcZhngW7yKA2g==", + "license": "MIT" + }, + "node_modules/process": { + "version": "0.11.10", + "resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz", + "integrity": "sha512-cdGef/drWFoydD1JsMzuFf8100nZl+GT+yacc2bEced5f9Rjk4z+WtFUTBu9PhOi9j/jfmBPu0mMEY4wIdAF8A==", + "license": "MIT", + "engines": { + "node": ">= 0.6.0" + } + }, + "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==", + "license": "MIT" + }, + "node_modules/punycode": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", + "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/queue-microtask": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", + "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", + "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/ramda": { + "version": "0.30.1", + "resolved": "https://registry.npmjs.org/ramda/-/ramda-0.30.1.tgz", + "integrity": "sha512-tEF5I22zJnuclswcZMc8bDIrwRHRzf+NqVEmqg50ShAZMP7MWeR/RGDthfM/p+BlqvF2fXAzpn8i+SJcYD3alw==", + "license": "MIT", + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/ramda" + } + }, + "node_modules/ramda-adjunct": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/ramda-adjunct/-/ramda-adjunct-5.1.0.tgz", + "integrity": "sha512-8qCpl2vZBXEJyNbi4zqcgdfHtcdsWjOGbiNSEnEBrM6Y0OKOT8UxJbIVGm1TIcjaSu2MxaWcgtsNlKlCk7o7qg==", + "license": "BSD-3-Clause", + "engines": { + "node": ">=0.10.3" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/ramda-adjunct" + }, + "peerDependencies": { + "ramda": ">= 0.30.0" + } + }, + "node_modules/randombytes": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", + "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "safe-buffer": "^5.1.0" + } + }, + "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==", + "license": "MIT", + "dependencies": { + "inherits": "^2.0.3", + "string_decoder": "^1.1.1", + "util-deprecate": "^1.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/readdirp": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", + "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", + "dev": true, + "license": "MIT", + "dependencies": { + "picomatch": "^2.2.1" + }, + "engines": { + "node": ">=8.10.0" + } + }, + "node_modules/require-directory": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", + "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/require-from-string": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", + "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "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==", + "license": "MIT", + "dependencies": { + "onetime": "^5.1.0", + "signal-exit": "^3.0.2" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/reusify": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.1.0.tgz", + "integrity": "sha512-g6QUff04oZpHs0eG5p83rFLhHeV00ug/Yf9nZM6fLeUrPguBTkTQOdpAWWspMh55TZfVQDPaN3NQJfbVRAxdIw==", + "dev": true, + "license": "MIT", + "engines": { + "iojs": ">=1.0.0", + "node": ">=0.10.0" + } + }, + "node_modules/rimraf": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", + "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", + "deprecated": "Rimraf versions prior to v4 are no longer supported", + "dev": true, + "license": "ISC", + "dependencies": { + "glob": "^7.1.3" + }, + "bin": { + "rimraf": "bin.js" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/rimraf/node_modules/glob": { + "version": "7.2.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", + "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", + "deprecated": "Glob versions prior to v9 are no longer supported", + "dev": true, + "license": "ISC", + "dependencies": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.1.1", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + }, + "engines": { + "node": "*" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/run-parallel": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", + "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", + "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": { + "queue-microtask": "^1.2.2" + } + }, + "node_modules/rxjs": { + "version": "7.8.2", + "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-7.8.2.tgz", + "integrity": "sha512-dhKf903U/PQZY6boNNtAGdWbG85WAbjT/1xYoZIC7FAY0yWapOBQVsVrDl58W86//e1VpMNBtRV4MaXfdMySFA==", + "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", + "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", + "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/safe-stable-stringify": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/safe-stable-stringify/-/safe-stable-stringify-2.5.0.tgz", + "integrity": "sha512-b3rppTKm9T+PsVCBEOUR46GWI7fdOs00VKZ1+9c1EWDaDMvjQc6tUwuFyIprgGgTcWoVHSKrU8H31ZHA2e0RHA==", + "license": "MIT", + "engines": { + "node": ">=10" + } + }, + "node_modules/sax": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/sax/-/sax-1.4.1.tgz", + "integrity": "sha512-+aWOz7yVScEGoKNd4PA10LZ8sk0A/z5+nXQG5giUO5rprX9jgYsTdov9qCchZiPIZezbZH+jRut8nPodFAX4Jg==", + "license": "ISC" + }, + "node_modules/semaphore": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/semaphore/-/semaphore-1.1.0.tgz", + "integrity": "sha512-O4OZEaNtkMd/K0i6js9SL+gqy0ZCBMgUvlSqHKi4IBdjhe7wB8pwztUk1BbZ1fmrvpwFrPbHzqd2w5pTcJH6LA==", + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/semver": { + "version": "7.7.3", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.3.tgz", + "integrity": "sha512-SdsKMrI9TdgjdweUSR9MweHA4EJ8YxHn8DFaDisvhVlUOe4BF1tLD7GAj0lIqWVl+dPb/rExr0Btby5loQm20Q==", + "license": "ISC", + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, + "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==", + "license": "MIT", + "dependencies": { + "no-case": "^3.0.4", + "tslib": "^2.0.3", + "upper-case-first": "^2.0.2" + } + }, + "node_modules/serialize-javascript": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.2.tgz", + "integrity": "sha512-Saa1xPByTTq2gdeFZYLLo+RFE35NHZkAbqZeWNd3BpzppeVisAqpDjcp8dyf6uIvEqJRd46jemmyA4iFIeVk8g==", + "dev": true, + "license": "BSD-3-Clause", + "dependencies": { + "randombytes": "^2.1.0" + } + }, + "node_modules/shebang-command": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", + "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", + "dev": true, + "license": "MIT", + "dependencies": { + "shebang-regex": "^3.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/shebang-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", + "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/short-unique-id": { + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/short-unique-id/-/short-unique-id-5.3.2.tgz", + "integrity": "sha512-KRT/hufMSxXKEDSQujfVE0Faa/kZ51ihUcZQAcmP04t00DvPj7Ox5anHke1sJYUtzSuiT/Y5uyzg/W7bBEGhCg==", + "license": "Apache-2.0", + "bin": { + "short-unique-id": "bin/short-unique-id", + "suid": "bin/short-unique-id" + } + }, + "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==", + "license": "ISC" + }, + "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==", + "license": "MIT", + "dependencies": { + "dot-case": "^3.0.4", + "tslib": "^2.0.3" + } + }, + "node_modules/stack-trace": { + "version": "0.0.10", + "resolved": "https://registry.npmjs.org/stack-trace/-/stack-trace-0.0.10.tgz", + "integrity": "sha512-KGzahc7puUKkzyMt+IqAep+TVNbKP+k2Lmwhub39m1AsTSkaDutx56aDCo+HLDzf/D26BIHTJWNiTG1KAJiQCg==", + "license": "MIT", + "engines": { + "node": "*" + } + }, + "node_modules/string_decoder": { + "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==", + "license": "MIT", + "dependencies": { + "safe-buffer": "~5.2.0" + } + }, + "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/strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "license": "MIT", + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/strip-json-comments": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", + "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/strnum": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/strnum/-/strnum-2.1.1.tgz", + "integrity": "sha512-7ZvoFTiCnGxBtDqJ//Cu6fWtZtc7Y3x+QOirG15wztbdngGSkht27o2pyGWrVy0b4WAy3jbKmnoK6g5VlVNUUw==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/NaturalIntelligence" + } + ], + "license": "MIT" + }, + "node_modules/supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "license": "MIT", + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/swagger-client": { + "version": "3.36.0", + "resolved": "https://registry.npmjs.org/swagger-client/-/swagger-client-3.36.0.tgz", + "integrity": "sha512-9fkjxGHXuKy20jj8zwE6RwgFSOGKAyOD5U7aKgW/+/futtHZHOdZeqiEkb97sptk2rdBv7FEiUQDNlWZR186RA==", + "license": "Apache-2.0", + "dependencies": { + "@babel/runtime-corejs3": "^7.22.15", + "@scarf/scarf": "=1.4.0", + "@swagger-api/apidom-core": "^1.0.0-rc.1", + "@swagger-api/apidom-error": "^1.0.0-rc.1", + "@swagger-api/apidom-json-pointer": "^1.0.0-rc.1", + "@swagger-api/apidom-ns-openapi-3-1": "^1.0.0-rc.1", + "@swagger-api/apidom-reference": "^1.0.0-rc.1", + "@swaggerexpert/cookie": "^2.0.2", + "deepmerge": "~4.3.0", + "fast-json-patch": "^3.0.0-1", + "js-yaml": "^4.1.0", + "neotraverse": "=0.6.18", + "node-abort-controller": "^3.1.1", + "node-fetch-commonjs": "^3.3.2", + "openapi-path-templating": "^2.2.1", + "openapi-server-url-templating": "^1.3.0", + "ramda": "^0.30.1", + "ramda-adjunct": "^5.1.0" + } + }, + "node_modules/text-hex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/text-hex/-/text-hex-1.0.0.tgz", + "integrity": "sha512-uuVGNWzgJ4yhRaNSiubPY7OjISw4sw4E5Uv0wbjp+OzcbmVU/rsT8ujgcXJhn9ypzsgr5vlzpPqP+MBBKcGvbg==", + "license": "MIT" + }, + "node_modules/text-table": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", + "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", + "dev": true, + "license": "MIT" + }, + "node_modules/to-regex-range": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", + "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "is-number": "^7.0.0" + }, + "engines": { + "node": ">=8.0" + } + }, + "node_modules/tr46": { + "version": "0.0.3", + "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", + "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==", + "license": "MIT" + }, + "node_modules/tree-sitter": { + "version": "0.21.1", + "resolved": "https://registry.npmjs.org/tree-sitter/-/tree-sitter-0.21.1.tgz", + "integrity": "sha512-7dxoA6kYvtgWw80265MyqJlkRl4yawIjO7S5MigytjELkX43fV2WsAXzsNfO7sBpPPCF5Gp0+XzHk0DwLCq3xQ==", + "hasInstallScript": true, + "license": "MIT", + "optional": true, + "dependencies": { + "node-addon-api": "^8.0.0", + "node-gyp-build": "^4.8.0" + } + }, + "node_modules/tree-sitter-json": { + "version": "0.24.8", + "resolved": "https://registry.npmjs.org/tree-sitter-json/-/tree-sitter-json-0.24.8.tgz", + "integrity": "sha512-Tc9ZZYwHyWZ3Tt1VEw7Pa2scu1YO7/d2BCBbKTx5hXwig3UfdQjsOPkPyLpDJOn/m1UBEWYAtSdGAwCSyagBqQ==", + "hasInstallScript": true, + "license": "MIT", + "optional": true, + "dependencies": { + "node-addon-api": "^8.2.2", + "node-gyp-build": "^4.8.2" + }, + "peerDependencies": { + "tree-sitter": "^0.21.1" + }, + "peerDependenciesMeta": { + "tree-sitter": { + "optional": true + } + } + }, + "node_modules/triple-beam": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/triple-beam/-/triple-beam-1.4.1.tgz", + "integrity": "sha512-aZbgViZrg1QNcG+LULa7nhZpJTZSLm/mXnHXnbAbjmN5aSa0y7V+wvv6+4WaBtpISJzThKy+PIPxc1Nq1EJ9mg==", + "license": "MIT", + "engines": { + "node": ">= 14.0.0" + } + }, + "node_modules/ts-mixer": { + "version": "6.0.4", + "resolved": "https://registry.npmjs.org/ts-mixer/-/ts-mixer-6.0.4.tgz", + "integrity": "sha512-ufKpbmrugz5Aou4wcr5Wc1UUFWOLhq+Fm6qa6P0w0K5Qw2yhaUoiWszhCVuNQyNwrlGiscHOmqYoAox1PtvgjA==", + "license": "MIT" + }, + "node_modules/ts-toolbelt": { + "version": "9.6.0", + "resolved": "https://registry.npmjs.org/ts-toolbelt/-/ts-toolbelt-9.6.0.tgz", + "integrity": "sha512-nsZd8ZeNUzukXPlJmTBwUAuABDe/9qtVDelJeT/qW0ow3ZS3BsQJtNkan1802aM9Uf68/Y8ljw86Hu0h5IUW3w==", + "license": "Apache-2.0" + }, + "node_modules/tslib": { + "version": "2.8.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.8.1.tgz", + "integrity": "sha512-oJFu94HQb+KVduSUQL7wnpmqnfmLsOA/nAh6b6EH0wCEoK0/mPeXU6c3wKDV83MkOuHPRHtSXKKU99IBazS/2w==", + "license": "0BSD" + }, + "node_modules/type-check": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", + "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", + "dev": true, + "license": "MIT", + "dependencies": { + "prelude-ls": "^1.2.1" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/type-detect": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.1.0.tgz", + "integrity": "sha512-Acylog8/luQ8L7il+geoSxhEkazvkslg7PSNKOX59mbB9cOveP5aq9h74Y7YU8yDpJwetzQQrfIwtf4Wp4LKcw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "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/types-ramda": { + "version": "0.30.1", + "resolved": "https://registry.npmjs.org/types-ramda/-/types-ramda-0.30.1.tgz", + "integrity": "sha512-1HTsf5/QVRmLzcGfldPFvkVsAdi1db1BBKzi7iW3KBUlOICg/nKnFS+jGqDJS3YD8VsWbAh7JiHeBvbsw8RPxA==", + "license": "MIT", + "dependencies": { + "ts-toolbelt": "^9.6.0" + } + }, + "node_modules/universal-user-agent": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/universal-user-agent/-/universal-user-agent-6.0.1.tgz", + "integrity": "sha512-yCzhz6FN2wU1NiiQRogkTQszlQSlpWaw8SvVegAc+bDxbzHgh1vX8uIe8OYyMH6DwH+sdTJsgMl36+mSMdRJIQ==", + "license": "ISC" + }, + "node_modules/universalify": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.1.tgz", + "integrity": "sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw==", + "license": "MIT", + "engines": { + "node": ">= 10.0.0" + } + }, + "node_modules/unraw": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/unraw/-/unraw-3.0.0.tgz", + "integrity": "sha512-08/DA66UF65OlpUDIQtbJyrqTR0jTAlJ+jsnkQ4jxR7+K5g5YG1APZKQSMCE1vqqmD+2pv6+IdEjmopFatacvg==", + "license": "MIT" + }, + "node_modules/upath": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/upath/-/upath-2.0.1.tgz", + "integrity": "sha512-1uEe95xksV1O0CYKXo8vQvN1JEbtJp7lb7C5U9HMsIp6IVwntkH/oNUzyVNQSd4S1sYk2FpSSW44FqMc8qee5w==", + "license": "MIT", + "engines": { + "node": ">=4", + "yarn": "*" + } + }, + "node_modules/upper-case": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/upper-case/-/upper-case-2.0.2.tgz", + "integrity": "sha512-KgdgDGJt2TpuwBUIjgG6lzw2GWFRCW9Qkfkiv0DxqHHLYJHmtmdUIKcZd8rHgFSjopVTlw6ggzCm1b8MFQwikg==", + "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==", + "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", + "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", + "dev": true, + "license": "BSD-2-Clause", + "dependencies": { + "punycode": "^2.1.0" + } + }, + "node_modules/util-deprecate": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", + "license": "MIT" + }, + "node_modules/uuid": { + "version": "9.0.1", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-9.0.1.tgz", + "integrity": "sha512-b+1eJOlsR9K8HJpow9Ok3fiWOWSIcIzXodvv0rQjVoOVNpWMpxf1wZNpt4y9h10odCNrqnYp1OBzRktckBe3sA==", + "funding": [ + "https://github.com/sponsors/broofa", + "https://github.com/sponsors/ctavan" + ], + "license": "MIT", + "bin": { + "uuid": "dist/bin/uuid" + } + }, + "node_modules/valid-url": { + "version": "1.0.9", + "resolved": "https://registry.npmjs.org/valid-url/-/valid-url-1.0.9.tgz", + "integrity": "sha512-QQDsV8OnSf5Uc30CKSwG9lnhMPe6exHtTXLRYX8uMwKENy640pU+2BgBL0LRbDh/eYRahNCS7aewCx0wf3NYVA==" + }, + "node_modules/wcwidth": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/wcwidth/-/wcwidth-1.0.1.tgz", + "integrity": "sha512-XHPEwS0q6TaxcvG85+8EYkbiCux2XtWG2mkc47Ng2A77BQu9+DqIOJldST4HgPkuea7dvKSj5VgX3P1d4rW8Tg==", + "license": "MIT", + "dependencies": { + "defaults": "^1.0.3" + } + }, + "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==", + "license": "MIT", + "engines": { + "node": ">= 8" + } + }, + "node_modules/web-tree-sitter": { + "version": "0.24.5", + "resolved": "https://registry.npmjs.org/web-tree-sitter/-/web-tree-sitter-0.24.5.tgz", + "integrity": "sha512-+J/2VSHN8J47gQUAvF8KDadrfz6uFYVjxoxbKWDoXVsH2u7yLdarCnIURnrMA6uSRkgX3SdmqM5BOoQjPdSh5w==", + "license": "MIT", + "optional": true + }, + "node_modules/webidl-conversions": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", + "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==", + "license": "BSD-2-Clause" + }, + "node_modules/whatwg-url": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", + "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", + "license": "MIT", + "dependencies": { + "tr46": "~0.0.3", + "webidl-conversions": "^3.0.0" + } + }, + "node_modules/which": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "dev": true, + "license": "ISC", + "dependencies": { + "isexe": "^2.0.0" + }, + "bin": { + "node-which": "bin/node-which" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/winston": { + "version": "3.18.3", + "resolved": "https://registry.npmjs.org/winston/-/winston-3.18.3.tgz", + "integrity": "sha512-NoBZauFNNWENgsnC9YpgyYwOVrl2m58PpQ8lNHjV3kosGs7KJ7Npk9pCUE+WJlawVSe8mykWDKWFSVfs3QO9ww==", + "license": "MIT", + "dependencies": { + "@colors/colors": "^1.6.0", + "@dabh/diagnostics": "^2.0.8", + "async": "^3.2.3", + "is-stream": "^2.0.0", + "logform": "^2.7.0", + "one-time": "^1.0.0", + "readable-stream": "^3.4.0", + "safe-stable-stringify": "^2.3.1", + "stack-trace": "0.0.x", + "triple-beam": "^1.3.0", + "winston-transport": "^4.9.0" + }, + "engines": { + "node": ">= 12.0.0" + } + }, + "node_modules/winston-transport": { + "version": "4.9.0", + "resolved": "https://registry.npmjs.org/winston-transport/-/winston-transport-4.9.0.tgz", + "integrity": "sha512-8drMJ4rkgaPo1Me4zD/3WLfI/zPdA9o2IipKODunnGDcuqbHwjsbB79ylv04LCGGzU0xQ6vTznOMpQGaLhhm6A==", + "license": "MIT", + "dependencies": { + "logform": "^2.7.0", + "readable-stream": "^3.6.2", + "triple-beam": "^1.3.0" + }, + "engines": { + "node": ">= 12.0.0" + } + }, + "node_modules/word-wrap": { + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz", + "integrity": "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/workerpool": { + "version": "6.5.1", + "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.5.1.tgz", + "integrity": "sha512-Fs4dNYcsdpYSAfVxhnl1L5zTksjvOJxtC5hzMNl+1t9B8hTJTdKDyZ5ju7ztgPy+ft9tBFXoOlDNiOT9WUXZlA==", + "dev": true, + "license": "Apache-2.0" + }, + "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/wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", + "dev": true, + "license": "ISC" + }, + "node_modules/xml-js": { + "version": "1.6.11", + "resolved": "https://registry.npmjs.org/xml-js/-/xml-js-1.6.11.tgz", + "integrity": "sha512-7rVi2KMfwfWFl+GpPg6m80IVMWXLRjO+PxTq7V2CDhoGak0wzYzFgUY2m4XJ47OGdXd8eLE8EmwfAmdjw7lC1g==", + "license": "MIT", + "dependencies": { + "sax": "^1.2.4" + }, + "bin": { + "xml-js": "bin/cli.js" + } + }, + "node_modules/y18n": { + "version": "5.0.8", + "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", + "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", + "dev": true, + "license": "ISC", + "engines": { + "node": ">=10" + } + }, + "node_modules/yallist": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", + "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", + "license": "ISC" + }, + "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/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/yargs-unparser": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", + "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", + "dev": true, + "license": "MIT", + "dependencies": { + "camelcase": "^6.0.0", + "decamelize": "^4.0.0", + "flat": "^5.0.2", + "is-plain-obj": "^2.1.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/yocto-queue": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", + "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + } + } +} diff --git a/io/mcp-server/package.json b/io/mcp-server/package.json new file mode 100644 index 000000000..cf38d1927 --- /dev/null +++ b/io/mcp-server/package.json @@ -0,0 +1,29 @@ +{ + "name": "MerchAtScaleMCP", + "version": "1.0.0", + "private": true, + "description": "Adobe I/O Runtime actions for MAS Studio MCP operations", + "type": "module", + "dependencies": { + "@adobe/aio-lib-ims": "^7.0.2", + "@adobe/aio-lib-state": "^5.1.0", + "@adobe/aio-sdk": "^6", + "node-fetch": "^2.6.0" + }, + "devDependencies": { + "chai": "^4.3.6", + "eslint": "^8", + "mocha": "^10.2.0" + }, + "scripts": { + "test": "mocha --recursive ./test", + "lint": "eslint src", + "lint:fix": "eslint src --fix", + "deploy": "aio app deploy", + "deploy:all": "aio app deploy --all", + "undeploy": "aio app undeploy" + }, + "engines": { + "node": ">=22" + } +} diff --git a/io/mcp-server/src/actions/add-cards-to-collection.js b/io/mcp-server/src/actions/add-cards-to-collection.js new file mode 100644 index 000000000..28c34ee36 --- /dev/null +++ b/io/mcp-server/src/actions/add-cards-to-collection.js @@ -0,0 +1,89 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { requireIMSAuth, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +async function main(params) { + const { id, cardPaths, etag, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + if (!id) { + return { + statusCode: 400, + body: { error: 'Collection ID is required' }, + }; + } + + if (!cardPaths || cardPaths.length === 0) { + return { + statusCode: 400, + body: { error: 'At least one card path is required' }, + }; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + + const fragment = await aemClient.getFragment(id); + const cardPathsField = fragment.fields?.find?.((f) => f.name === 'cardPaths'); + const existingPaths = cardPathsField?.values || []; + + const newPaths = [...new Set([...existingPaths, ...cardPaths])]; + + const updateFields = { + cardPaths: newPaths, + }; + + const updatedFragment = await aemClient.updateFragment(id, updateFields, etag || fragment.etag); + + const updatedCardPathsField = updatedFragment.fields?.find?.((f) => f.name === 'cardPaths'); + const collection = { + id: updatedFragment.id, + path: updatedFragment.path, + title: updatedFragment.title, + cardPaths: updatedCardPathsField?.values || [], + fields: updatedFragment.fields, + tags: updatedFragment.tags || [], + modified: updatedFragment.modified, + published: updatedFragment.published, + }; + + const studioLinks = urlBuilder.createCollectionLinks(collection); + + return { + statusCode: 200, + body: { + success: true, + operation: 'add_cards_to_collection', + collection, + addedCount: cardPaths.length, + message: `Added ${cardPaths.length} card(s) to collection "${updatedFragment.title}"`, + studioLinks: { + viewInStudio: studioLinks.view, + }, + }, + }; + } catch (error) { + console.error('Add cards to collection error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/bulk-delete-cards.js b/io/mcp-server/src/actions/bulk-delete-cards.js new file mode 100644 index 000000000..0d0eb0f7a --- /dev/null +++ b/io/mcp-server/src/actions/bulk-delete-cards.js @@ -0,0 +1,48 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { StudioOperations } from '../lib/studio-operations.js'; +import { requireIMSAuth, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +/** + * Bulk delete multiple cards + * Adobe I/O Runtime action for studio_bulk_delete_cards operation + */ +async function main(params) { + const { fragmentIds, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + const studioOps = new StudioOperations(aemClient, urlBuilder); + + const result = await studioOps.bulkDeleteCards({ fragmentIds }); + + return { + statusCode: 200, + body: result, + }; + } catch (error) { + console.error('Bulk delete cards error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/bulk-publish-cards.js b/io/mcp-server/src/actions/bulk-publish-cards.js new file mode 100644 index 000000000..dfb3ec0c1 --- /dev/null +++ b/io/mcp-server/src/actions/bulk-publish-cards.js @@ -0,0 +1,48 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { StudioOperations } from '../lib/studio-operations.js'; +import { requireIMSAuth, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +/** + * Bulk publish/unpublish multiple cards + * Adobe I/O Runtime action for studio_bulk_publish_cards operation + */ +async function main(params) { + const { fragmentIds, action, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + const studioOps = new StudioOperations(aemClient, urlBuilder); + + const result = await studioOps.bulkPublishCards({ fragmentIds, action }); + + return { + statusCode: 200, + body: result, + }; + } catch (error) { + console.error('Bulk publish cards error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/bulk-update-cards.js b/io/mcp-server/src/actions/bulk-update-cards.js new file mode 100644 index 000000000..5ec34b840 --- /dev/null +++ b/io/mcp-server/src/actions/bulk-update-cards.js @@ -0,0 +1,48 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { StudioOperations } from '../lib/studio-operations.js'; +import { requireIMSAuth, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +/** + * Bulk update multiple cards + * Adobe I/O Runtime action for studio_bulk_update_cards operation + */ +async function main(params) { + const { fragmentIds, updates, textReplacements, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + const studioOps = new StudioOperations(aemClient, urlBuilder); + + const result = await studioOps.bulkUpdateCards({ fragmentIds, updates, textReplacements }); + + return { + statusCode: 200, + body: result, + }; + } catch (error) { + console.error('Bulk update cards error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/compare-offers.js b/io/mcp-server/src/actions/compare-offers.js new file mode 100644 index 000000000..8ca0755d3 --- /dev/null +++ b/io/mcp-server/src/actions/compare-offers.js @@ -0,0 +1,99 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { AOSClient } from '../services/aos-client.js'; +import { requireIMSAuth } from '../lib/ims-validator.js'; + +async function main(params) { + const { arrangementCode, customerSegment, marketSegment, country = 'US', __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + if (!arrangementCode) { + return { + statusCode: 400, + body: { error: 'Arrangement code is required' }, + }; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const aosBaseUrl = params.AOS_URL || 'https://aos.adobe.io'; + const aosApiKey = params.AOS_API_KEY || ''; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aosClient = new AOSClient(authManager, { + baseUrl: aosBaseUrl, + apiKey: aosApiKey, + }); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + + const offers = await aosClient.searchOffers({ + arrangementCode, + customerSegment, + marketSegment, + country, + }); + + const byPlanType = {}; + const byOfferType = {}; + const byPricePoint = {}; + + offers.forEach((offer) => { + if (offer.planType) { + if (!byPlanType[offer.planType]) { + byPlanType[offer.planType] = []; + } + byPlanType[offer.planType].push(offer); + } + + if (offer.offer_type) { + if (!byOfferType[offer.offer_type]) { + byOfferType[offer.offer_type] = []; + } + byOfferType[offer.offer_type].push(offer); + } + + if (offer.price_point) { + if (!byPricePoint[offer.price_point]) { + byPricePoint[offer.price_point] = []; + } + byPricePoint[offer.price_point].push(offer); + } + }); + + const studioLinks = urlBuilder.createOfferLinks({ + product_arrangement_code: arrangementCode, + customer_segment: customerSegment, + }); + + return { + statusCode: 200, + body: { + success: true, + operation: 'compare_offers', + offers, + comparison: { + byPlanType, + byOfferType, + byPricePoint, + }, + studioLinks, + }, + }; + } catch (error) { + console.error('Compare offers error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/copy-card.js b/io/mcp-server/src/actions/copy-card.js new file mode 100644 index 000000000..017a732bd --- /dev/null +++ b/io/mcp-server/src/actions/copy-card.js @@ -0,0 +1,48 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { StudioOperations } from '../lib/studio-operations.js'; +import { requireSurfaceAccess, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +/** + * Copy/duplicate a card + * Adobe I/O Runtime action for studio_copy_card operation + */ +async function main(params) { + const { id, parentPath, newTitle, __ow_headers } = params; + + try { + const authError = await requireSurfaceAccess(__ow_headers, params); + if (authError) { + return authError; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + const studioOps = new StudioOperations(aemClient, urlBuilder); + + const result = await studioOps.copyCard({ id, parentPath, newTitle }); + + return { + statusCode: 200, + body: result, + }; + } catch (error) { + console.error('Copy card error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/create-card.js b/io/mcp-server/src/actions/create-card.js new file mode 100644 index 000000000..67a577193 --- /dev/null +++ b/io/mcp-server/src/actions/create-card.js @@ -0,0 +1,44 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { StudioOperations } from '../lib/studio-operations.js'; +import { requireSurfaceAccess, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +async function main(params) { + const { title, parentPath, variant, size, fields, tags, __ow_headers } = params; + + try { + const authError = await requireSurfaceAccess(__ow_headers, params); + if (authError) { + return authError; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + const studioOps = new StudioOperations(aemClient, urlBuilder); + + const result = await studioOps.createCard({ title, parentPath, variant, size, fields, tags }); + + return { + statusCode: 200, + body: result, + }; + } catch (error) { + console.error('Create card error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/create-collection.js b/io/mcp-server/src/actions/create-collection.js new file mode 100644 index 000000000..add9fd71b --- /dev/null +++ b/io/mcp-server/src/actions/create-collection.js @@ -0,0 +1,80 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { requireSurfaceAccess, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +const COLLECTION_MODEL_ID = 'L2NvbmYvbWFzL3NldHRpbmdzL2RhbS9jZm0vbW9kZWxzL2NvbGxlY3Rpb24'; + +async function main(params) { + const { title, parentPath, cardPaths = [], fields = {}, tags = [], __ow_headers } = params; + + try { + const authError = await requireSurfaceAccess(__ow_headers, params); + if (authError) { + return authError; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + + const fragmentData = { + title, + description: `Merch card collection: ${title}`, + modelId: COLLECTION_MODEL_ID, + parentPath, + fields: [ + { name: 'cardPaths', values: cardPaths }, + ...Object.entries(fields).map(([name, value]) => ({ + name, + values: Array.isArray(value) ? value : [value], + })), + ], + tags: [...tags, 'mas:studio/content-type/merch-card-collection'], + }; + + const fragment = await aemClient.createFragment(fragmentData); + + const collection = { + id: fragment.id, + path: fragment.path, + title: fragment.title, + cardPaths: cardPaths, + fields: fragment.fields, + tags: fragment.tags || [], + modified: fragment.modified, + published: fragment.published, + }; + + const studioLinks = urlBuilder.createCollectionLinks(collection); + + return { + statusCode: 200, + body: { + success: true, + operation: 'create_collection', + collection, + message: `Created collection: "${fragment.title}"`, + studioLinks: { + viewInStudio: studioLinks.view, + }, + }, + }; + } catch (error) { + console.error('Create collection error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/create-offer-selector.js b/io/mcp-server/src/actions/create-offer-selector.js new file mode 100644 index 000000000..92933d5da --- /dev/null +++ b/io/mcp-server/src/actions/create-offer-selector.js @@ -0,0 +1,110 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { AOSClient } from '../services/aos-client.js'; +import { requireIMSAuth } from '../lib/ims-validator.js'; + +async function main(params) { + const { + productArrangementCode, + commitment, + term, + customerSegment, + marketSegment, + offerType, + pricePoint, + buyingProgram, + merchant, + salesChannel, + __ow_headers, + } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + if (!productArrangementCode) { + return { + statusCode: 400, + body: { error: 'Product arrangement code is required' }, + }; + } + + if (!customerSegment) { + return { + statusCode: 400, + body: { error: 'Customer segment is required' }, + }; + } + + if (!marketSegment) { + return { + statusCode: 400, + body: { error: 'Market segment is required' }, + }; + } + + if (!offerType) { + return { + statusCode: 400, + body: { error: 'Offer type is required' }, + }; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const aosBaseUrl = params.AOS_URL || 'https://aos.adobe.io'; + const aosApiKey = params.AOS_API_KEY || ''; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aosClient = new AOSClient(authManager, { + baseUrl: aosBaseUrl, + apiKey: aosApiKey, + }); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + + const result = await aosClient.createOfferSelector({ + product_arrangement_code: productArrangementCode, + commitment, + term, + customer_segment: customerSegment, + market_segment: marketSegment, + offer_type: offerType, + price_point: pricePoint, + buying_program: buyingProgram, + merchant, + sales_channel: salesChannel, + }); + + const checkoutUrl = aosClient.getCheckoutUrl(result.id); + + const studioLinks = urlBuilder.createOfferLinks({ + product_arrangement_code: productArrangementCode, + customer_segment: customerSegment, + offer_type: offerType, + }); + + return { + statusCode: 200, + body: { + success: true, + operation: 'create_offer_selector', + offerSelectorId: result.id, + checkoutUrl, + studioLinks, + }, + }; + } catch (error) { + console.error('Create offer selector error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/create-release-cards.js b/io/mcp-server/src/actions/create-release-cards.js new file mode 100644 index 000000000..89138db6a --- /dev/null +++ b/io/mcp-server/src/actions/create-release-cards.js @@ -0,0 +1,198 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { StudioOperations } from '../lib/studio-operations.js'; +import { requireSurfaceAccess, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +/** + * Fetch full MCS merchandising data directly from AOS API for a given arrangement code. + * Same pattern as ost-products-write.js line 38, but filtered by arrangement_code. + */ +async function fetchMCSProduct(arrangementCode, aosUrl, aosApiKey, locale = 'en_US') { + const [, country] = locale.split('_'); + const baseUrl = aosUrl.endsWith('/offers') ? aosUrl : `${aosUrl}/offers`; + const endpoint = `${baseUrl}?country=${encodeURIComponent(country)}&merchant=ADOBE&service_providers=MERCHANDISING,PRODUCT_ARRANGEMENT_V2&locale=${encodeURIComponent(locale)}&landscape=PUBLISHED&arrangement_code=${encodeURIComponent(arrangementCode)}&page_size=200`; + + const response = await fetch(endpoint, { + headers: { 'x-api-key': aosApiKey }, + }); + if (!response.ok) { + throw new Error(`AOS API error: ${response.status} ${response.statusText}`); + } + + const offers = await response.json(); + if (!offers || offers.length === 0) { + return null; + } + + // Take the first offer that has merchandising data + const offer = offers.find((o) => o.merchandising) || offers[0]; + const merch = offer.merchandising || {}; + + // Detect offer types across ALL offers for CTA generation + const hasTrial = offers.some((o) => o.offer_type === 'TRIAL'); + const hasBuy = offers.some((o) => o.offer_type === 'BASE' || o.offer_type === 'PROMOTION'); + + return { + arrangement_code: offer.product_arrangement_code || arrangementCode, + product_code: offer.product_code, + product_family: offer.product_arrangement_v2?.family, + customer_segment: offer.customer_segment, + market_segments: offer.market_segments || [], + commitment: offer.commitment, + term: offer.term, + // Full merchandising payload + copy: merch.copy || {}, + assets: merch.assets || {}, + links: merch.links || {}, + misc: merch.misc || {}, + fulfillable_items: merch.fulfillable_items || [], + metadata: merch.metadata || {}, + // Convenience aliases + name: merch.copy?.name, + icon: merch.assets?.icons?.svg, + // Offer type flags for CTA generation + hasTrial, + hasBuy, + }; +} + +function generateCtaHtml(product, osi, variant) { + const checkoutAttrs = `is="checkout-link" data-wcs-osi="${osi}" data-checkout-workflow="UCv2" data-checkout-workflow-step="email"`; + const isPlans = variant === 'plans' || variant === 'plans-students' || variant === 'plans-education'; + const ctaStyle = variant === 'catalog' ? 'accent' : 'primary'; + const buyLabel = isPlans ? 'Select' : 'Buy now'; + if (!isPlans && product.hasTrial && product.hasBuy) { + return `Free trial ${buyLabel}`; + } + if (!isPlans && product.hasTrial) { + return `Start free trial`; + } + return `${buyLabel}`; +} + +async function main(params) { + const { arrangement_code, variants, parentPath, locale, osi, __ow_headers } = params; + + try { + if (!arrangement_code) { + return { statusCode: 400, body: { error: 'arrangement_code is required' } }; + } + if (!Array.isArray(variants) || variants.length === 0) { + return { statusCode: 400, body: { error: 'variants array is required' } }; + } + if (!parentPath) { + return { statusCode: 400, body: { error: 'parentPath is required' } }; + } + + const authError = await requireSurfaceAccess(__ow_headers, params); + if (authError) return authError; + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + const aosUrl = params.AOS_URL; + const aosApiKey = params.AOS_API_KEY; + + if (!aosUrl || !aosApiKey) { + return { statusCode: 500, body: { error: 'AOS_URL and AOS_API_KEY must be configured' } }; + } + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + const studioOps = new StudioOperations(aemClient, urlBuilder); + + // Fetch full MCS data directly from AOS + const product = await fetchMCSProduct(arrangement_code, aosUrl, aosApiKey, 'en_US'); + + if (!product) { + return { statusCode: 404, body: { error: `Product not found in AOS for arrangement code: ${arrangement_code}` } }; + } + + // Deterministic field mapping from MCS merchandising + const productName = product.copy.name || product.name; + const iconUrl = product.assets.icons?.svg || product.icon; + const descriptionCandidates = [ + product.copy.description, + product.copy.short_description, + product.copy.shortDescription, + ].filter(Boolean); + const description = descriptionCandidates.sort((a, b) => b.length - a.length)[0]; + + const baseFields = { cardTitle: productName }; + if (description) baseFields.description = description; + if (iconUrl) { + baseFields.mnemonics = [{ icon: iconUrl, alt: productName }]; + } + + if (osi) { + baseFields.osi = osi; + } + + // Deterministic tag mapping from AOS offer data + const tags = []; + if (product.product_code) tags.push(`mas:product_code/${product.product_code}`); + if (product.arrangement_code) tags.push(`mas:pa/${product.arrangement_code}`); + if (product.product_family) tags.push(`mas:product_family/${product.product_family}`); + if (product.customer_segment) tags.push(`mas:customer_segment/${product.customer_segment}`); + if (product.market_segments) { + product.market_segments.forEach((s) => tags.push(`mas:market_segments/${s}`)); + } + + // Create cards + const results = []; + for (const variant of variants) { + const fields = { ...baseFields }; + const isCatalog = variant === 'catalog'; + const perUnit = product.customer_segment === 'TEAM' ? 'true' : 'false'; + if (osi && !isCatalog) { + fields.prices = ``; + } + if (osi) { + fields.ctas = generateCtaHtml(product, osi, variant); + } + const card = { + title: `${productName} - ${variant.charAt(0).toUpperCase() + variant.slice(1)}`, + variant, + parentPath, + fields, + tags, + }; + try { + const result = await studioOps.createCard(card); + results.push(result); + } catch (e) { + results.push({ success: false, error: e.message, card }); + } + } + + const successCount = results.filter((r) => r.success).length; + return { + statusCode: 200, + body: { + success: successCount === results.length, + cards: results, + count: results.length, + successCount, + product: { + name: productName, + product_code: product.product_code, + arrangement_code: product.arrangement_code, + copy: product.copy, + assets: product.assets, + links: product.links, + misc: product.misc, + }, + }, + }; + } catch (error) { + console.error('Create release cards error:', error); + return { statusCode: 500, body: { error: error.message } }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/delete-card.js b/io/mcp-server/src/actions/delete-card.js new file mode 100644 index 000000000..ae94faad6 --- /dev/null +++ b/io/mcp-server/src/actions/delete-card.js @@ -0,0 +1,48 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { StudioOperations } from '../lib/studio-operations.js'; +import { requireIMSAuth, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +/** + * Delete a card + * Adobe I/O Runtime action for studio_delete_card operation + */ +async function main(params) { + const { id, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + const studioOps = new StudioOperations(aemClient, urlBuilder); + + const result = await studioOps.deleteCard({ id }); + + return { + statusCode: 200, + body: result, + }; + } catch (error) { + console.error('Delete card error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/get-card.js b/io/mcp-server/src/actions/get-card.js new file mode 100644 index 000000000..c2d173697 --- /dev/null +++ b/io/mcp-server/src/actions/get-card.js @@ -0,0 +1,48 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { StudioOperations } from '../lib/studio-operations.js'; +import { requireIMSAuth, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +/** + * Get card details by ID + * Adobe I/O Runtime action for studio_get_card operation + */ +async function main(params) { + const { id, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + const studioOps = new StudioOperations(aemClient, urlBuilder); + + const result = await studioOps.getCard({ id }); + + return { + statusCode: 200, + body: result, + }; + } catch (error) { + console.error('Get card error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/get-collection.js b/io/mcp-server/src/actions/get-collection.js new file mode 100644 index 000000000..a319eaa2e --- /dev/null +++ b/io/mcp-server/src/actions/get-collection.js @@ -0,0 +1,79 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { requireIMSAuth, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +async function main(params) { + const { id, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + if (!id) { + return { + statusCode: 400, + body: { error: 'Collection ID is required' }, + }; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + + const fragment = await aemClient.getFragment(id); + + if (!fragment) { + return { + statusCode: 404, + body: { error: `Collection not found: ${id}` }, + }; + } + + const cardPathsField = fragment.fields?.find?.((f) => f.name === 'cardPaths'); + const cardPaths = cardPathsField?.values || []; + + const collection = { + id: fragment.id, + path: fragment.path, + title: fragment.title, + cardPaths, + fields: fragment.fields, + tags: fragment.tags || [], + modified: fragment.modified, + published: fragment.published, + }; + + const studioLinks = urlBuilder.createCollectionLinks(collection); + + return { + statusCode: 200, + body: { + success: true, + operation: 'get_collection', + collection, + studioLinks: { + viewInStudio: studioLinks.view, + }, + }, + }; + } catch (error) { + console.error('Get collection error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/get-fragment-variations.js b/io/mcp-server/src/actions/get-fragment-variations.js new file mode 100644 index 000000000..fe0d3b5c9 --- /dev/null +++ b/io/mcp-server/src/actions/get-fragment-variations.js @@ -0,0 +1,48 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { StudioOperations } from '../lib/studio-operations.js'; +import { requireIMSAuth, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +/** + * Get all regional locale variations of a fragment + * Adobe I/O Runtime action for studio_get_variations operation + */ +async function main(params) { + const { id, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + const studioOps = new StudioOperations(aemClient, urlBuilder); + + const result = await studioOps.getFragmentVariations({ id }); + + return { + statusCode: 200, + body: result, + }; + } catch (error) { + console.error('Get fragment variations error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/get-job-status.js b/io/mcp-server/src/actions/get-job-status.js new file mode 100644 index 000000000..f37ec8376 --- /dev/null +++ b/io/mcp-server/src/actions/get-job-status.js @@ -0,0 +1,62 @@ +import { sharedJobManager } from '../lib/shared-job-manager.js'; +import { requireIMSAuth } from '../lib/ims-validator.js'; + +/** + * Get job status for bulk operations + * Adobe I/O Runtime action for checking progress of background jobs + */ +async function main(params) { + const { jobId, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + if (!jobId) { + return { + statusCode: 400, + body: { error: 'jobId parameter is required' }, + }; + } + + const job = await sharedJobManager.getJob(jobId); + + if (!job) { + return { + statusCode: 404, + body: { error: `Job ${jobId} not found` }, + }; + } + + return { + statusCode: 200, + body: { + jobId: job.jobId, + type: job.type, + status: job.status, + total: job.total, + completed: job.completed, + successful: job.successful, + failed: job.failed, + skipped: job.skipped, + successCount: job.successful.length, + failureCount: job.failed.length, + skippedCount: job.skipped.length, + startedAt: job.startedAt, + updatedAt: job.updatedAt, + completedAt: job.completedAt, + percentage: job.total > 0 ? Math.round((job.completed / job.total) * 100) : 0, + }, + }; + } catch (error) { + console.error('Get job status error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/get-offer-by-id.js b/io/mcp-server/src/actions/get-offer-by-id.js new file mode 100644 index 000000000..e9fa77479 --- /dev/null +++ b/io/mcp-server/src/actions/get-offer-by-id.js @@ -0,0 +1,63 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { AOSClient } from '../services/aos-client.js'; +import { requireIMSAuth } from '../lib/ims-validator.js'; + +async function main(params) { + const { offerId, country = 'US', __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + if (!offerId) { + return { + statusCode: 400, + body: { error: 'Offer ID is required' }, + }; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const aosBaseUrl = params.AOS_URL || 'https://aos.adobe.io'; + const aosApiKey = params.AOS_API_KEY || ''; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aosClient = new AOSClient(authManager, { + baseUrl: aosBaseUrl, + apiKey: aosApiKey, + }); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + + const offer = await aosClient.getOffer(offerId, country); + + const studioLinks = urlBuilder.createOfferLinks({ + product_arrangement_code: offer.product_arrangement_code, + customer_segment: offer.customer_segment, + offer_type: offer.offer_type, + }); + + return { + statusCode: 200, + body: { + success: true, + operation: 'get_offer_by_id', + offer, + studioLinks, + }, + }; + } catch (error) { + console.error('Get offer by ID error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/get-product-detail.js b/io/mcp-server/src/actions/get-product-detail.js new file mode 100644 index 000000000..ea29a9e9f --- /dev/null +++ b/io/mcp-server/src/actions/get-product-detail.js @@ -0,0 +1,85 @@ +import { requireIMSAuth } from '../lib/ims-validator.js'; + +async function main(params) { + const { arrangementCode, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + if (!arrangementCode) { + return { + statusCode: 400, + body: { error: 'arrangementCode is required' }, + }; + } + + const aosUrl = params.AOS_URL; + const aosApiKey = params.AOS_API_KEY; + if (!aosUrl || !aosApiKey) { + return { + statusCode: 500, + body: { error: 'AOS_URL and AOS_API_KEY must be configured' }, + }; + } + + const baseUrl = aosUrl.endsWith('/offers') ? aosUrl : `${aosUrl}/offers`; + const endpoint = `${baseUrl}?country=US&merchant=ADOBE&service_providers=MERCHANDISING,PRODUCT_ARRANGEMENT_V2&locale=en_US&landscape=PUBLISHED&arrangement_code=${encodeURIComponent(arrangementCode)}&page_size=200`; + + const response = await fetch(endpoint, { + headers: { 'x-api-key': aosApiKey }, + }); + if (!response.ok) { + return { + statusCode: response.status, + body: { error: `AOS API error: ${response.status} ${response.statusText}` }, + }; + } + + const offers = await response.json(); + if (!offers || offers.length === 0) { + return { + statusCode: 404, + body: { error: `No product found for arrangement code: ${arrangementCode}` }, + }; + } + + const offer = offers.find((o) => o.merchandising) || offers[0]; + const merch = offer.merchandising || {}; + + const product = { + arrangement_code: offer.product_arrangement_code || arrangementCode, + product_code: offer.product_code, + product_family: offer.product_arrangement_v2?.family, + customer_segment: offer.customer_segment, + market_segments: offer.market_segments || [], + copy: merch.copy || {}, + assets: merch.assets || {}, + links: merch.links || {}, + misc: merch.misc || {}, + fulfillable_items: merch.fulfillable_items || [], + metadata: merch.metadata || {}, + name: merch.copy?.name, + icon: merch.assets?.icons?.svg, + }; + + return { + statusCode: 200, + body: { + success: true, + operation: 'get_product_detail', + product, + }, + }; + } catch (error) { + console.error('Get product detail error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/link-card-to-offer.js b/io/mcp-server/src/actions/link-card-to-offer.js new file mode 100644 index 000000000..da54589e4 --- /dev/null +++ b/io/mcp-server/src/actions/link-card-to-offer.js @@ -0,0 +1,98 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { AOSClient } from '../services/aos-client.js'; +import { requireIMSAuth, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +async function main(params) { + const { cardId, offerSelectorId, etag, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + if (!cardId) { + return { + statusCode: 400, + body: { error: 'Card ID is required' }, + }; + } + + if (!offerSelectorId) { + return { + statusCode: 400, + body: { error: 'Offer selector ID is required' }, + }; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const aosBaseUrl = params.AOS_URL || 'https://aos.adobe.io'; + const aosApiKey = params.AOS_API_KEY || ''; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const aosClient = new AOSClient(authManager, { + baseUrl: aosBaseUrl, + apiKey: aosApiKey, + }); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + + const updateFields = { + mnemonicIcon: [offerSelectorId], + }; + + const fragment = await aemClient.getFragment(cardId); + const updatedFragment = await aemClient.updateFragment(cardId, updateFields, etag || fragment.etag); + + const variantField = updatedFragment.fields?.find?.((f) => f.name === 'variant'); + const sizeField = updatedFragment.fields?.find?.((f) => f.name === 'size'); + + const card = { + id: updatedFragment.id, + path: updatedFragment.path, + title: updatedFragment.title, + variant: variantField?.values?.[0] || 'plans', + size: sizeField?.values?.[0] || 'wide', + fields: updatedFragment.fields, + tags: updatedFragment.tags || [], + modified: updatedFragment.modified, + published: updatedFragment.published, + }; + + const offers = await aosClient.resolveOfferSelector(offerSelectorId); + const offer = offers[0]; + + const studioLinks = urlBuilder.createCardLinks(card); + + return { + statusCode: 200, + body: { + success: true, + operation: 'link_card_to_offer', + card, + offer, + message: `Linked card "${card.title}" to offer selector ${offerSelectorId}`, + studioLinks: { + viewInStudio: studioLinks.view, + viewFolder: studioLinks.folder, + }, + }, + }; + } catch (error) { + console.error('Link card to offer error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/list-context-cards.js b/io/mcp-server/src/actions/list-context-cards.js new file mode 100644 index 000000000..48c7fb75a --- /dev/null +++ b/io/mcp-server/src/actions/list-context-cards.js @@ -0,0 +1,48 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { StudioOperations } from '../lib/studio-operations.js'; +import { requireIMSAuth, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +/** + * List cards from context (previous operation) + * Adobe I/O Runtime action for list_context_cards operation + */ +async function main(params) { + const { fragmentIds, operationType, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + const studioOps = new StudioOperations(aemClient, urlBuilder); + + const result = await studioOps.listContextCards({ fragmentIds, operationType }); + + return { + statusCode: 200, + body: result, + }; + } catch (error) { + console.error('List context cards error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/list-products.js b/io/mcp-server/src/actions/list-products.js new file mode 100644 index 000000000..90e04c5d3 --- /dev/null +++ b/io/mcp-server/src/actions/list-products.js @@ -0,0 +1,47 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { ProductCatalog } from '../services/product-catalog.js'; +import { requireIMSAuth } from '../lib/ims-validator.js'; + +async function main(params) { + const { searchText, customerSegment, marketSegment, limit, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const productsEndpoint = params.PRODUCTS_ENDPOINT; + const productCatalog = new ProductCatalog(authManager, productsEndpoint); + + const products = await productCatalog.searchProducts({ + searchText, + customerSegment, + marketSegment, + limit, + }); + + return { + statusCode: 200, + body: { + success: true, + operation: 'list_products', + products, + count: products.length, + }, + }; + } catch (error) { + console.error('List products error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/preview-bulk-delete.js b/io/mcp-server/src/actions/preview-bulk-delete.js new file mode 100644 index 000000000..f7a6e3cf5 --- /dev/null +++ b/io/mcp-server/src/actions/preview-bulk-delete.js @@ -0,0 +1,49 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { StudioOperations } from '../lib/studio-operations.js'; +import { requireIMSAuth, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +/** + * Preview bulk delete for multiple cards + * Adobe I/O Runtime action for studio_preview_bulk_delete operation + * Returns preview of what would be deleted without executing the deletion + */ +async function main(params) { + const { fragmentIds, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + const studioOps = new StudioOperations(aemClient, urlBuilder); + + const result = await studioOps.previewBulkDelete({ fragmentIds }); + + return { + statusCode: 200, + body: result, + }; + } catch (error) { + console.error('Preview bulk delete error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/preview-bulk-publish.js b/io/mcp-server/src/actions/preview-bulk-publish.js new file mode 100644 index 000000000..df64a2d39 --- /dev/null +++ b/io/mcp-server/src/actions/preview-bulk-publish.js @@ -0,0 +1,49 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { StudioOperations } from '../lib/studio-operations.js'; +import { requireIMSAuth, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +/** + * Preview bulk publish/unpublish for multiple cards + * Adobe I/O Runtime action for studio_preview_bulk_publish operation + * Returns preview of what would change without executing the publish/unpublish + */ +async function main(params) { + const { fragmentIds, action, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + const studioOps = new StudioOperations(aemClient, urlBuilder); + + const result = await studioOps.previewBulkPublish({ fragmentIds, action }); + + return { + statusCode: 200, + body: result, + }; + } catch (error) { + console.error('Preview bulk publish error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/preview-bulk-update.js b/io/mcp-server/src/actions/preview-bulk-update.js new file mode 100644 index 000000000..9f2324117 --- /dev/null +++ b/io/mcp-server/src/actions/preview-bulk-update.js @@ -0,0 +1,49 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { StudioOperations } from '../lib/studio-operations.js'; +import { requireIMSAuth, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +/** + * Preview bulk update for multiple cards + * Adobe I/O Runtime action for studio_preview_bulk_update operation + * Returns preview of what would change without executing the updates + */ +async function main(params) { + const { fragmentIds, updates, textReplacements, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + const studioOps = new StudioOperations(aemClient, urlBuilder); + + const result = await studioOps.previewBulkUpdate({ fragmentIds, updates, textReplacements }); + + return { + statusCode: 200, + body: result, + }; + } catch (error) { + console.error('Preview bulk update error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/publish-card.js b/io/mcp-server/src/actions/publish-card.js new file mode 100644 index 000000000..7a0b534e0 --- /dev/null +++ b/io/mcp-server/src/actions/publish-card.js @@ -0,0 +1,48 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { StudioOperations } from '../lib/studio-operations.js'; +import { requireIMSAuth, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +/** + * Publish a card to production + * Adobe I/O Runtime action for studio_publish_card operation + */ +async function main(params) { + const { id, publishReferences = true, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + const studioOps = new StudioOperations(aemClient, urlBuilder); + + const result = await studioOps.publishCard({ id, publishReferences }); + + return { + statusCode: 200, + body: result, + }; + } catch (error) { + console.error('Publish card error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/resolve-offer-selector.js b/io/mcp-server/src/actions/resolve-offer-selector.js new file mode 100644 index 000000000..182e61101 --- /dev/null +++ b/io/mcp-server/src/actions/resolve-offer-selector.js @@ -0,0 +1,68 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { AOSClient } from '../services/aos-client.js'; +import { requireIMSAuth } from '../lib/ims-validator.js'; + +async function main(params) { + const { offerSelectorId, country = 'US', __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + if (!offerSelectorId) { + return { + statusCode: 400, + body: { error: 'Offer selector ID is required' }, + }; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const aosBaseUrl = params.AOS_URL || 'https://aos.adobe.io'; + const aosApiKey = params.AOS_API_KEY || ''; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aosClient = new AOSClient(authManager, { + baseUrl: aosBaseUrl, + apiKey: aosApiKey, + }); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + + const selector = await aosClient.getOfferSelector(offerSelectorId, country); + const offers = await aosClient.resolveOfferSelector(offerSelectorId, country); + + const checkoutUrl = aosClient.getCheckoutUrl(offerSelectorId); + + const studioLinks = urlBuilder.createOfferLinks({ + product_arrangement_code: selector.product_arrangement_code, + customer_segment: selector.customer_segment, + offer_type: selector.offer_type, + }); + + return { + statusCode: 200, + body: { + success: true, + operation: 'resolve_offer_selector', + offers, + selector, + checkoutUrl, + studioLinks, + }, + }; + } catch (error) { + console.error('Resolve offer selector error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/search-cards.js b/io/mcp-server/src/actions/search-cards.js new file mode 100644 index 000000000..1fafc0120 --- /dev/null +++ b/io/mcp-server/src/actions/search-cards.js @@ -0,0 +1,48 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { StudioOperations } from '../lib/studio-operations.js'; +import { requireIMSAuth, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +/** + * Search for cards with filters + * Adobe I/O Runtime action for studio_search_cards operation + */ +async function main(params) { + const { surface, query, tags, limit, locale, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + const studioOps = new StudioOperations(aemClient, urlBuilder); + + const result = await studioOps.searchCards({ surface, query, tags, limit, locale }); + + return { + statusCode: 200, + body: result, + }; + } catch (error) { + console.error('Search cards error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/search-collections.js b/io/mcp-server/src/actions/search-collections.js new file mode 100644 index 000000000..ef7f92a43 --- /dev/null +++ b/io/mcp-server/src/actions/search-collections.js @@ -0,0 +1,104 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { requireIMSAuth, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +const COLLECTION_MODEL_ID = 'L2NvbmYvbWFzL3NldHRpbmdzL2RhbS9jZm0vbW9kZWxzL2NvbGxlY3Rpb24'; + +const SURFACE_PATHS = { + acom: '/content/dam/mas/acom', + ccd: '/content/dam/mas/ccd', + 'adobe-home': '/content/dam/mas/adobe-home', + commerce: '/content/dam/mas/commerce', + sandbox: '/content/dam/mas/sandbox', + nala: '/content/dam/mas/nala', +}; + +async function main(params) { + const { surface, query, limit = 50, offset = 0, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + if (!surface) { + return { + statusCode: 400, + body: { error: 'Surface is required' }, + }; + } + + if (!SURFACE_PATHS[surface]) { + return { + statusCode: 400, + body: { error: `Invalid surface: ${surface}. Must be one of: ${Object.keys(SURFACE_PATHS).join(', ')}` }, + }; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + + const path = SURFACE_PATHS[surface]; + + const fragments = await aemClient.searchFragments({ + path, + query, + modelIds: [COLLECTION_MODEL_ID], + tags: ['mas:studio/content-type/merch-card-collection'], + limit, + offset, + }); + + const collections = fragments.map((fragment) => { + const cardPathsField = fragment.fields?.find?.((f) => f.name === 'cardPaths'); + return { + id: fragment.id, + path: fragment.path, + title: fragment.title, + cardPaths: cardPathsField?.values || [], + fields: fragment.fields, + tags: fragment.tags || [], + modified: fragment.modified, + published: fragment.published, + }; + }); + + const studioLinks = { + viewInStudio: urlBuilder.buildContentLink({ + path, + query, + tags: { contentType: ['merch-card-collection'] }, + }), + }; + + return { + statusCode: 200, + body: { + success: true, + operation: 'search_collections', + collections, + count: collections.length, + studioLinks, + }, + }; + } catch (error) { + console.error('Search collections error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/search-offers.js b/io/mcp-server/src/actions/search-offers.js new file mode 100644 index 000000000..2fb0037c7 --- /dev/null +++ b/io/mcp-server/src/actions/search-offers.js @@ -0,0 +1,83 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { AOSClient } from '../services/aos-client.js'; +import { requireIMSAuth } from '../lib/ims-validator.js'; + +async function main(params) { + const { + arrangementCode, + commitment, + term, + customerSegment, + marketSegment, + offerType, + country, + language, + pricePoint, + __ow_headers, + } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const aosBaseUrl = params.AOS_URL || 'https://aos.adobe.io'; + const aosApiKey = params.AOS_API_KEY || ''; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aosClient = new AOSClient(authManager, { + baseUrl: aosBaseUrl, + apiKey: aosApiKey, + }); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + + const offers = await aosClient.searchOffers({ + arrangementCode, + commitment, + term, + customerSegment, + marketSegment, + offerType, + country, + language, + pricePoint, + }); + + const studioLinks = { + viewCardsInStudio: urlBuilder.buildContentLink({ + tags: { + offerType: offerType ? [offerType] : undefined, + customerSegment: customerSegment ? [customerSegment] : undefined, + marketSegments: marketSegment ? [marketSegment] : undefined, + }, + }), + createWithAI: urlBuilder.buildChatLink(), + }; + + return { + statusCode: 200, + body: { + success: true, + operation: 'search_offers', + offers, + count: offers.length, + studioLinks, + }, + }; + } catch (error) { + console.error('Search offers error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/unpublish-card.js b/io/mcp-server/src/actions/unpublish-card.js new file mode 100644 index 000000000..199ce44e1 --- /dev/null +++ b/io/mcp-server/src/actions/unpublish-card.js @@ -0,0 +1,48 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { StudioOperations } from '../lib/studio-operations.js'; +import { requireIMSAuth, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +/** + * Unpublish a card from production + * Adobe I/O Runtime action for studio_unpublish_card operation + */ +async function main(params) { + const { id, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + const studioOps = new StudioOperations(aemClient, urlBuilder); + + const result = await studioOps.unpublishCard({ id }); + + return { + statusCode: 200, + body: result, + }; + } catch (error) { + console.error('Unpublish card error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/update-card.js b/io/mcp-server/src/actions/update-card.js new file mode 100644 index 000000000..059329b38 --- /dev/null +++ b/io/mcp-server/src/actions/update-card.js @@ -0,0 +1,48 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { StudioOperations } from '../lib/studio-operations.js'; +import { requireIMSAuth, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +/** + * Update card fields + * Adobe I/O Runtime action for studio_update_card operation + */ +async function main(params) { + const { id, fields, title, tags, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + const studioOps = new StudioOperations(aemClient, urlBuilder); + + const result = await studioOps.updateCard({ id, fields, title, tags }); + + return { + statusCode: 200, + body: result, + }; + } catch (error) { + console.error('Update card error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/actions/validate-card-offer.js b/io/mcp-server/src/actions/validate-card-offer.js new file mode 100644 index 000000000..e9583fd8b --- /dev/null +++ b/io/mcp-server/src/actions/validate-card-offer.js @@ -0,0 +1,121 @@ +import { AuthManager } from '../lib/auth-manager.js'; +import { AEMClient } from '../lib/aem-client.js'; +import { StudioURLBuilder } from '../lib/studio-url-builder.js'; +import { AOSClient } from '../services/aos-client.js'; +import { requireIMSAuth, resolveAemBaseUrl } from '../lib/ims-validator.js'; + +async function main(params) { + const { cardId, __ow_headers } = params; + + try { + const authError = await requireIMSAuth(__ow_headers); + if (authError) { + return authError; + } + + if (!cardId) { + return { + statusCode: 400, + body: { error: 'Card ID is required' }, + }; + } + + const accessToken = __ow_headers.authorization.replace('Bearer ', ''); + + const authManager = new AuthManager(); + authManager.setAccessToken(accessToken); + + const { url: aemBaseUrl, error: aemError } = resolveAemBaseUrl(params); + if (aemError) return aemError; + const aosBaseUrl = params.AOS_URL || 'https://aos.adobe.io'; + const aosApiKey = params.AOS_API_KEY || ''; + const studioBaseUrl = params.STUDIO_BASE_URL || 'https://mas.adobe.com/studio.html'; + + const aemClient = new AEMClient(aemBaseUrl, authManager); + const aosClient = new AOSClient(authManager, { + baseUrl: aosBaseUrl, + apiKey: aosApiKey, + }); + const urlBuilder = new StudioURLBuilder(studioBaseUrl); + + const fragment = await aemClient.getFragment(cardId); + + const variantField = fragment.fields?.find?.((f) => f.name === 'variant'); + const sizeField = fragment.fields?.find?.((f) => f.name === 'size'); + const osiField = fragment.fields?.find?.((f) => f.name === 'osi'); + + const card = { + id: fragment.id, + path: fragment.path, + title: fragment.title, + variant: variantField?.values?.[0] || 'plans', + size: sizeField?.values?.[0] || 'wide', + fields: fragment.fields, + tags: fragment.tags || [], + modified: fragment.modified, + published: fragment.published, + }; + + const issues = []; + let offer = null; + + const offerSelectorId = osiField?.values?.[0]; + + if (!offerSelectorId) { + issues.push('No offer selector linked to card'); + } else { + try { + const offers = await aosClient.resolveOfferSelector(offerSelectorId); + offer = offers[0]; + + const cardTags = card.tags || []; + const offerPlanType = offer.planType; + const offerType = offer.offer_type; + const customerSegment = offer.customer_segment; + + if (offerPlanType && !cardTags.some((tag) => tag === `mas:plan_type/${offerPlanType.toLowerCase()}`)) { + issues.push(`Card missing plan_type tag: mas:plan_type/${offerPlanType.toLowerCase()}`); + } + + if (offerType && !cardTags.some((tag) => tag === `mas:offer_type/${offerType.toLowerCase()}`)) { + issues.push(`Card missing offer_type tag: mas:offer_type/${offerType.toLowerCase()}`); + } + + if ( + customerSegment && + !cardTags.some((tag) => tag === `mas:customer_segment/${customerSegment.toLowerCase()}`) + ) { + issues.push(`Card missing customer_segment tag: mas:customer_segment/${customerSegment.toLowerCase()}`); + } + } catch (error) { + issues.push(`Failed to resolve offer selector: ${error.message}`); + } + } + + const studioLinks = urlBuilder.createCardLinks(card); + + return { + statusCode: 200, + body: { + success: true, + operation: 'validate_card_offer', + card, + offer, + isConsistent: issues.length === 0, + issues, + studioLinks: { + viewInStudio: studioLinks.view, + viewFolder: studioLinks.folder, + }, + }, + }; + } catch (error) { + console.error('Validate card offer error:', error); + return { + statusCode: 500, + body: { error: error.message }, + }; + } +} + +export { main }; diff --git a/io/mcp-server/src/lib/aem-client.js b/io/mcp-server/src/lib/aem-client.js new file mode 100644 index 000000000..6e57c5cc8 --- /dev/null +++ b/io/mcp-server/src/lib/aem-client.js @@ -0,0 +1,726 @@ +import { AuthManager } from './auth-manager.js'; + +/** + * AEM Client + * Wrapper for AEM Sites Content Fragment APIs + */ +export class AEMClient { + constructor(baseUrl, authManager) { + this.baseUrl = baseUrl.replace(/\/$/, ''); + this.authManager = authManager; + } + + /** + * Search for fragments with filters + */ + async searchFragments(params) { + const { path = '/content/dam/mas', query, tags, modelIds, limit = 50, offset = 0, searchMode = 'EDGES' } = params; + + const authHeader = await this.authManager.getAuthHeader(); + console.log('[AEMClient] Auth header:', authHeader ? 'present' : 'MISSING'); + + const filter = { path }; + + if (query && query.trim()) { + const trimmedQuery = query.trim(); + + // Auto-detect if we should use EXACT_PHRASE mode for special characters + let resolvedMode = searchMode; + const hasSpecialChars = /[+\-()]/.test(trimmedQuery); + const isQuoted = trimmedQuery.startsWith('"') && trimmedQuery.endsWith('"'); + + if ((hasSpecialChars || isQuoted) && searchMode === 'EDGES') { + resolvedMode = 'EXACT_PHRASE'; + console.log(`[AEMClient] Auto-detected special characters/quoted phrase, switching to EXACT_PHRASE mode`); + } + + // Strip quotes for EXACT_PHRASE mode (the mode itself indicates phrase matching) + let queryText = trimmedQuery; + if (resolvedMode === 'EXACT_PHRASE' && isQuoted) { + queryText = trimmedQuery.slice(1, -1); + console.log(`[AEMClient] Stripped quotes for EXACT_PHRASE: "${trimmedQuery}" → "${queryText}"`); + } + + filter.fullText = { + text: queryText, + queryMode: resolvedMode, + }; + + console.log(`[AEMClient] Full text search: query="${queryText}" mode="${resolvedMode}"`); + } + + if (tags && tags.length > 0) { + filter.tags = tags; + } + + if (modelIds && modelIds.length > 0) { + filter.modelIds = modelIds; + } + + const searchQuery = { + filter, + }; + + console.log('[AEMClient] Search query structure:', JSON.stringify(searchQuery, null, 2)); + + const searchParams = new URLSearchParams({ + query: JSON.stringify(searchQuery), + }); + + if (limit) { + searchParams.set('limit', String(limit)); + } + + if (offset) { + searchParams.set('offset', String(offset)); + } + + const url = `${this.baseUrl}/adobe/sites/cf/fragments/search?${searchParams}`; + + console.log('[AEMClient] Request URL:', url); + + const response = await fetch(url, { + method: 'GET', + headers: { + Authorization: authHeader, + 'Content-Type': 'application/json', + pragma: 'no-cache', + 'cache-control': 'no-cache', + 'x-aem-affinity-type': 'api', + }, + }); + + if (!response.ok) { + const errorText = await response.text().catch(() => ''); + console.error('[AEMClient] Search failed!'); + console.error('[AEMClient] Response status:', response.status, response.statusText); + console.error('[AEMClient] Response headers:', Object.fromEntries(response.headers.entries())); + console.error('[AEMClient] Response body:', errorText); + console.error('[AEMClient] Search params:', { path, query, tags, limit, offset }); + throw new Error(`AEM search failed: ${response.statusText}${errorText ? ` - ${errorText}` : ''}`); + } + + const data = await response.json(); + return data.items || []; + } + + /** + * Get fragment by ID + */ + async getFragment(id) { + const authHeader = await this.authManager.getAuthHeader(); + + const url = `${this.baseUrl}/adobe/sites/cf/fragments/${encodeURIComponent(id)}`; + + const response = await fetch(url, { + method: 'GET', + headers: { + Authorization: authHeader, + Accept: 'application/json', + 'Content-Type': 'application/json', + pragma: 'no-cache', + 'cache-control': 'no-cache', + 'x-aem-affinity-type': 'api', + }, + }); + + if (!response.ok) { + throw new Error(`Failed to get fragment: ${response.statusText}`); + } + + // Extract ETag from response headers (required for updates) + const etag = response.headers.get('Etag'); + const fragment = await response.json(); + fragment.etag = etag; + + return fragment; + } + + /** + * Get fragment by path + */ + async getFragmentByPath(path) { + const authHeader = await this.authManager.getAuthHeader(); + + const url = `${this.baseUrl}/adobe/sites/cf/fragments?path=${encodeURIComponent(path)}`; + + const response = await fetch(url, { + method: 'GET', + headers: { + Authorization: authHeader, + 'Content-Type': 'application/json', + pragma: 'no-cache', + 'cache-control': 'no-cache', + 'x-aem-affinity-type': 'api', + }, + }); + + if (!response.ok) { + throw new Error(`Failed to get fragment by path: ${response.statusText}`); + } + + return await response.json(); + } + + /** + * Create a tag in AEM's taxonomy if it doesn't exist. + * Tag ID format: "mas:category/value" → path: /content/cq:tags/mas/category/value + */ + async createTag(tagId, title) { + const authHeader = await this.authManager.getAuthHeader(); + const csrfToken = await this.getCsrfToken(); + + const tagPath = `/content/cq:tags/${tagId.replace(':', '/')}`; + const url = `${this.baseUrl}${tagPath}`; + + const body = new URLSearchParams(); + body.append('jcr:primaryType', 'cq:Tag'); + body.append('jcr:title', title || tagId.split('/').pop()); + + const response = await fetch(url, { + method: 'POST', + headers: { + Authorization: authHeader, + 'CSRF-Token': csrfToken, + 'Content-Type': 'application/x-www-form-urlencoded', + }, + body: body.toString(), + }); + + if (response.status === 201 || response.status === 200 || response.status === 409) { + return true; + } + console.error(`[AEMClient] createTag failed for ${tagId}: ${response.status}`); + return false; + } + + /** + * Ensure all tags exist in AEM taxonomy, creating missing ones. + */ + async ensureTags(tagIds) { + const results = []; + for (const tagId of tagIds) { + const created = await this.createTag(tagId); + results.push({ tagId, created }); + } + return results; + } + + /** + * Create a new fragment + */ + async createFragment(data) { + const authHeader = await this.authManager.getAuthHeader(); + const csrfToken = await this.getCsrfToken(); + + const url = `${this.baseUrl}/adobe/sites/cf/fragments`; + + const response = await fetch(url, { + method: 'POST', + headers: { + Authorization: authHeader, + 'Content-Type': 'application/json', + 'CSRF-Token': csrfToken, + pragma: 'no-cache', + 'cache-control': 'no-cache', + 'x-aem-affinity-type': 'api', + }, + body: JSON.stringify(data), + }); + + if (!response.ok) { + const errorBody = await response.json().catch(() => null); + const detail = errorBody?.detail || errorBody?.message || errorBody?.['o:errorCode'] || JSON.stringify(errorBody); + throw new Error(`Failed to create fragment: ${response.status} ${detail || response.statusText}`); + } + + const fragment = await response.json(); + + await this.waitForFragment(fragment.id); + + return fragment; + } + + /** + * Save a fragment with complete fields array (PUT method) + * Mirrors frontend approach for consistency + */ + async saveFragment(id, title, description, fields, etag) { + const authHeader = await this.authManager.getAuthHeader(); + const csrfToken = await this.getCsrfToken(); + + const url = `${this.baseUrl}/adobe/sites/cf/fragments/${encodeURIComponent(id)}`; + + const headers = { + Authorization: authHeader, + 'Content-Type': 'application/json', + 'CSRF-Token': csrfToken, + pragma: 'no-cache', + 'cache-control': 'no-cache', + 'x-aem-affinity-type': 'api', + }; + + if (etag) { + headers['If-Match'] = etag; + } + + const body = { + title, + description, + fields, + }; + + console.log('[AEMClient] saveFragment called with:', { + id, + title, + description, + fieldsCount: Array.isArray(fields) ? fields.length : 0, + etag: etag ? 'present' : 'missing', + }); + + console.log('[AEMClient] PUT request body to be sent:', JSON.stringify(body, null, 2)); + + const response = await fetch(url, { + method: 'PUT', + headers, + body: JSON.stringify(body), + }); + + if (!response.ok) { + const responseText = await response.text(); + let error; + try { + error = JSON.parse(responseText); + } catch { + error = { message: response.statusText, body: responseText }; + } + + console.error('[AEMClient] Save failed:', { + status: response.status, + statusText: response.statusText, + errorMessage: error.message, + responseBody: responseText.substring(0, 500), + requestBody: JSON.stringify(body, null, 2), + requestHeaders: headers, + }); + throw new Error(`Failed to save fragment (${response.status}): ${error.message || response.statusText}`); + } + + return await response.json(); + } + + /** + * Update a fragment + */ + async updateFragment(id, fields, etag, title, tags) { + const authHeader = await this.authManager.getAuthHeader(); + const csrfToken = await this.getCsrfToken(); + + const url = `${this.baseUrl}/adobe/sites/cf/fragments/${encodeURIComponent(id)}`; + + const currentFragment = await this.getFragment(id); + if (!currentFragment) throw new Error(`Fragment not found: ${id}`); + + const currentEtag = etag || currentFragment.etag; + + const currentFields = Array.isArray(currentFragment.fields) ? currentFragment.fields : []; + + const mergedFields = currentFields.map((field) => { + if (fields && field.name in fields) { + const newValue = fields[field.name]; + return { + ...field, + values: Array.isArray(newValue) ? newValue : [newValue], + }; + } + return field; + }); + + if (fields) { + const existingNames = new Set(currentFields.map((f) => f.name)); + for (const [key, value] of Object.entries(fields)) { + if (!existingNames.has(key)) { + mergedFields.push({ + name: key, + values: Array.isArray(value) ? value : [value], + }); + } + } + } + + const body = { + title: title !== undefined ? title : currentFragment.title, + fields: mergedFields, + }; + + const headers = { + Authorization: authHeader, + 'Content-Type': 'application/json', + 'CSRF-Token': csrfToken, + pragma: 'no-cache', + 'cache-control': 'no-cache', + 'x-aem-affinity-type': 'api', + }; + + if (currentEtag) { + headers['If-Match'] = currentEtag; + } + + const response = await fetch(url, { + method: 'PUT', + headers, + body: JSON.stringify(body), + }); + + if (!response.ok) { + const responseText = await response.text(); + let error; + try { + error = JSON.parse(responseText); + } catch { + error = { message: response.statusText, body: responseText }; + } + + console.error('[AEMClient] Update failed:', { + status: response.status, + statusText: response.statusText, + errorMessage: error.message, + responseBody: responseText.substring(0, 500), + }); + throw new Error(`Failed to update fragment (${response.status}): ${error.message || response.statusText}`); + } + + const result = await response.json(); + + if (tags !== undefined) { + await this.applyValidTags(id, tags); + } + + return result; + } + + /** + * Apply tags to a fragment, skipping any that don't exist in AEM taxonomy. + */ + async applyValidTags(id, tags) { + try { + await this.updateFragmentTags(id, tags); + } catch (error) { + const match = error.message?.match(/Tag id\(s\) not valid: \[([^\]]+)\]/); + if (match) { + const invalidTags = match[1].split(',').map((t) => t.trim()); + const validTags = tags.filter((t) => !invalidTags.includes(t)); + if (validTags.length > 0) { + console.log( + `[AEMClient] Retrying with ${validTags.length} valid tags (skipped ${invalidTags.length} invalid)`, + ); + await this.updateFragmentTags(id, validTags); + } else { + console.log('[AEMClient] No valid tags to apply'); + } + } else { + throw error; + } + } + } + + /** + * Update fragment tags via dedicated tags endpoint + */ + async updateFragmentTags(id, tags) { + const authHeader = await this.authManager.getAuthHeader(); + + const tagsUrl = `${this.baseUrl}/adobe/sites/cf/fragments/${encodeURIComponent(id)}/tags`; + + let getResp = await fetch(tagsUrl, { method: 'GET', headers: { Authorization: authHeader } }); + if (getResp.status === 404) { + await new Promise((r) => setTimeout(r, 3000)); + getResp = await fetch(tagsUrl, { method: 'GET', headers: { Authorization: authHeader } }); + } + if (!getResp.ok) { + throw new Error(`Failed to get tags for fragment (${getResp.status})`); + } + const etag = getResp.headers.get('Etag'); + + let response = await fetch(tagsUrl, { + method: 'PUT', + headers: { + Authorization: authHeader, + 'Content-Type': 'application/json', + 'If-Match': etag, + }, + body: JSON.stringify({ tags }), + }); + + if (response.status === 404) { + await new Promise((r) => setTimeout(r, 3000)); + getResp = await fetch(tagsUrl, { method: 'GET', headers: { Authorization: authHeader } }); + if (!getResp.ok) throw new Error(`Failed to get tags for fragment (${getResp.status})`); + const freshEtag = getResp.headers.get('Etag'); + response = await fetch(tagsUrl, { + method: 'PUT', + headers: { + Authorization: authHeader, + 'Content-Type': 'application/json', + 'If-Match': freshEtag, + }, + body: JSON.stringify({ tags }), + }); + } + + if (!response.ok) { + const responseText = await response.text(); + console.error('[AEMClient] updateFragmentTags failed:', { status: response.status, responseText }); + throw new Error(`Failed to update tags (${response.status}): ${responseText}`); + } + } + + /** + * Delete a fragment + */ + async deleteFragment(id) { + const authHeader = await this.authManager.getAuthHeader(); + const csrfToken = await this.getCsrfToken(); + + const url = `${this.baseUrl}/adobe/sites/cf/fragments/${encodeURIComponent(id)}`; + + const response = await fetch(url, { + method: 'DELETE', + headers: { + Authorization: authHeader, + 'CSRF-Token': csrfToken, + pragma: 'no-cache', + 'cache-control': 'no-cache', + 'x-aem-affinity-type': 'api', + }, + }); + + if (!response.ok) { + throw new Error(`Failed to delete fragment: ${response.statusText}`); + } + } + + /** + * Publish a fragment + */ + async publishFragment(id) { + const authHeader = await this.authManager.getAuthHeader(); + const csrfToken = await this.getCsrfToken(); + + const fragment = await this.getFragment(id); + if (!fragment) throw new Error(`Fragment not found: ${id}`); + + const url = `${this.baseUrl}/adobe/sites/cf/fragments/publish`; + + const response = await fetch(url, { + method: 'POST', + headers: { + Authorization: authHeader, + 'Content-Type': 'application/json', + 'CSRF-Token': csrfToken, + 'If-Match': fragment.etag, + pragma: 'no-cache', + 'cache-control': 'no-cache', + 'x-aem-affinity-type': 'api', + }, + body: JSON.stringify({ + paths: [fragment.path], + filterReferencesByStatus: ['DRAFT', 'UNPUBLISHED'], + workflowModelId: '/var/workflow/models/scheduled_activation_with_references', + }), + }); + + if (!response.ok) { + const text = await response.text(); + throw new Error( + `Failed to publish fragment (${response.status}): ${text.substring(0, 200) || response.statusText}`, + ); + } + + if (response.status === 204) return { success: true }; + return await response.json(); + } + + /** + * Unpublish a fragment + */ + async unpublishFragment(id) { + const authHeader = await this.authManager.getAuthHeader(); + const csrfToken = await this.getCsrfToken(); + + const fragment = await this.getFragment(id); + if (!fragment) throw new Error(`Fragment not found: ${id}`); + + const url = `${this.baseUrl}/adobe/sites/cf/fragments/publish`; + + const response = await fetch(url, { + method: 'POST', + headers: { + Authorization: authHeader, + 'Content-Type': 'application/json', + 'CSRF-Token': csrfToken, + 'If-Match': fragment.etag, + pragma: 'no-cache', + 'cache-control': 'no-cache', + 'x-aem-affinity-type': 'api', + }, + body: JSON.stringify({ + paths: [fragment.path], + workflowModelId: '/var/workflow/models/scheduled_deactivation', + }), + }); + + if (!response.ok) { + const text = await response.text(); + throw new Error( + `Failed to unpublish fragment (${response.status}): ${text.substring(0, 200) || response.statusText}`, + ); + } + + if (response.status === 204) return { success: true }; + return await response.json(); + } + + /** + * Copy/duplicate a fragment + */ + async copyFragment(params) { + const { id, parentPath, newTitle } = params; + + const fragment = await this.getFragment(id); + + if (!fragment) { + throw new Error(`Fragment ${id} not found`); + } + + const copyData = { + title: newTitle || `${fragment.title} (Copy)`, + description: fragment.description, + model: fragment.model?.id || fragment.model, + parentPath: parentPath || fragment.parentPath, + fields: fragment.fields, + tags: fragment.tags || [], + }; + + return await this.createFragment(copyData); + } + + /** + * Get CSRF token for write operations + */ + async getCsrfToken() { + const authHeader = await this.authManager.getAuthHeader(); + + const url = `${this.baseUrl}/libs/granite/csrf/token.json`; + + const response = await fetch(url, { + method: 'GET', + headers: { + Authorization: authHeader, + pragma: 'no-cache', + 'cache-control': 'no-cache', + 'x-aem-affinity-type': 'api', + }, + }); + + if (!response.ok) { + throw new Error('Failed to get CSRF token'); + } + + const data = await response.json(); + return data.token; + } + + /** + * Wait for fragment to be fully created/updated (polling) + */ + async waitForFragment(id, maxAttempts = 10) { + for (let i = 0; i < maxAttempts; i++) { + try { + const fragment = await this.getFragment(id); + if (fragment && fragment.id) { + return fragment; + } + } catch { + // Fragment not ready yet + } + + await new Promise((resolve) => setTimeout(resolve, 250)); + } + + throw new Error(`Fragment ${id} not available after ${maxAttempts} attempts`); + } + + async createFolder(path) { + const authHeader = await this.authManager.getAuthHeader(); + const csrfToken = await this.getCsrfToken(); + const url = `${this.baseUrl}${path}`; + const response = await fetch(url, { + method: 'POST', + headers: { + Authorization: authHeader, + 'CSRF-Token': csrfToken, + 'Content-Type': 'application/json', + pragma: 'no-cache', + 'cache-control': 'no-cache', + }, + body: JSON.stringify({ 'jcr:primaryType': 'sling:OrderedFolder' }), + }); + return response.status === 201 || response.ok || response.status === 409; + } + + async getFragmentTranslations(id) { + const authHeader = await this.authManager.getAuthHeader(); + + const url = `${this.baseUrl}/adobe/sites/cf/fragments/${encodeURIComponent(id)}/translations`; + + const response = await fetch(url, { + method: 'GET', + headers: { + Authorization: authHeader, + Accept: 'application/json', + 'Content-Type': 'application/json', + pragma: 'no-cache', + 'cache-control': 'no-cache', + 'x-aem-affinity-type': 'api', + }, + }); + + if (!response.ok) { + throw new Error(`Failed to get fragment translations: ${response.statusText}`); + } + + return await response.json(); + } + + /** + * List folders in a path + */ + async listFolders(path) { + const authHeader = await this.authManager.getAuthHeader(); + + const url = `${this.baseUrl}/api/assets${path}.json`; + + const response = await fetch(url, { + method: 'GET', + headers: { + Authorization: authHeader, + pragma: 'no-cache', + 'cache-control': 'no-cache', + 'x-aem-affinity-type': 'api', + }, + }); + + if (!response.ok) { + throw new Error(`Failed to list folders: ${response.statusText}`); + } + + const data = await response.json(); + const folders = data.entities?.filter((e) => e.class?.includes('folder')) || []; + + return folders.map((f) => ({ + path: f.properties?.path || '', + name: f.properties?.name || f.properties?.['jcr:title'] || '', + })); + } +} diff --git a/io/mcp-server/src/lib/auth-manager.js b/io/mcp-server/src/lib/auth-manager.js new file mode 100644 index 000000000..056903fcd --- /dev/null +++ b/io/mcp-server/src/lib/auth-manager.js @@ -0,0 +1,93 @@ +/** + * Authentication Manager + * Handles Adobe IMS authentication and token management + */ +export class AuthManager { + constructor(clientId, clientSecret) { + this.accessToken = null; + this.refreshToken = null; + this.expiresAt = null; + this.clientId = clientId; + this.clientSecret = clientSecret; + + this.loadFromEnvironment(); + } + + /** + * Load access token from environment variables + */ + loadFromEnvironment() { + if (process.env.MAS_ACCESS_TOKEN) { + this.accessToken = process.env.MAS_ACCESS_TOKEN; + } + + if (process.env.IMS_ACCESS_TOKEN) { + this.accessToken = process.env.IMS_ACCESS_TOKEN; + } + } + + /** + * Set access token manually + */ + setAccessToken(token, expiresIn) { + this.accessToken = token; + if (expiresIn) { + this.expiresAt = Date.now() + expiresIn * 1000; + } + } + + /** + * Set tokens from OAuth response + */ + setTokens(tokens) { + this.accessToken = tokens.accessToken; + this.refreshToken = tokens.refreshToken || null; + this.expiresAt = tokens.expiresAt || null; + } + + /** + * Get current access token + */ + async getAccessToken() { + if (!this.accessToken) { + throw new Error('No access token available. Please set MAS_ACCESS_TOKEN or IMS_ACCESS_TOKEN environment variable.'); + } + + if (this.expiresAt && Date.now() >= this.expiresAt) { + if (this.refreshToken) { + await this.refreshAccessToken(); + } else { + throw new Error('Access token expired and no refresh token available'); + } + } + + return this.accessToken; + } + + /** + * Refresh the access token using refresh token + */ + async refreshAccessToken() { + throw new Error('Token refresh not implemented. Please provide a valid access token.'); + } + + /** + * Validate that authentication is configured + */ + async validateAuth() { + try { + await this.getAccessToken(); + return true; + } catch { + return false; + } + } + + /** + * Get authorization header value + */ + async getAuthHeader() { + const token = await this.getAccessToken(); + return `Bearer ${token}`; + } +} diff --git a/io/mcp-server/src/lib/ims-validator.js b/io/mcp-server/src/lib/ims-validator.js new file mode 100644 index 000000000..31a62a29d --- /dev/null +++ b/io/mcp-server/src/lib/ims-validator.js @@ -0,0 +1,181 @@ +import { Ims } from '@adobe/aio-lib-ims'; + +/** + * MAS admin group — bypasses surface-scoped checks. + */ +const MAS_ADMIN_GROUP = 'GRP-ODIN-MAS-ADMINS'; + +/** + * Surface path segment → LDAP group required to mutate fragments in that surface. + * Mirrors studio/src/groups.js::SETTINGS_ACCESS_GROUP_BY_SURFACE but for editor + * permission on fragment content (not just settings). + */ +const EDITOR_ACCESS_GROUP_BY_SURFACE = new Map([ + ['acom', 'GRP-ODIN-MAS-ACOM-EDITORS'], + ['acom-cc', 'GRP-ODIN-MAS-ACOM-CC-EDITORS'], + ['acom-dc', 'GRP-ODIN-MAS-ACOM-DC-EDITORS'], + ['adobe-home', 'GRP-ODIN-MAS-AH-EDITORS'], + ['ccd', 'GRP-ODIN-MAS-CCD-EDITORS'], + ['express', 'GRP-ODIN-MAS-EXPRESS-EDITORS'], +]); + +/** + * Validates IMS token for the mas-studio client + * @param {string} token - Bearer token from Authorization header + * @returns {Promise<{valid: boolean, error?: string}>} + */ +export async function validateIMSToken(token) { + try { + const ims = new Ims('prod'); + const validation = await ims.validateToken(token, 'mas-studio'); + + if (!validation || !validation.valid) { + return { + valid: false, + error: 'Invalid IMS token', + }; + } + + return { valid: true }; + } catch (error) { + console.error('IMS token validation error:', error); + return { + valid: false, + error: error.message || 'Token validation failed', + }; + } +} + +/** + * Extract the MAS surface segment from a fragment or parent path. + * Accepts '/content/dam/mas/{surface}/...' and returns the surface, or null. + * + * @param {string} path + * @returns {string|null} + */ +export function deriveSurfaceFromPath(path) { + if (typeof path !== 'string' || !path) return null; + const match = path.match(/^\/content\/dam\/mas\/([^/]+)/); + if (!match) return null; + return match[1].toLowerCase(); +} + +/** + * Fetch the LDAP groups of the caller from Adobe's profile endpoint. + * Groups come back uppercase-normalized for case-insensitive comparisons. + * + * @param {string} token - Bearer token (no 'Bearer ' prefix) + * @returns {Promise} - uppercase LDAP group names, or [] on failure + */ +export async function fetchUserGroups(token) { + try { + const response = await fetch('https://ims-na1.adobelogin.com/ims/profile/v1', { + headers: { Authorization: `Bearer ${token}` }, + }); + if (!response.ok) return []; + const profile = await response.json(); + const groups = Array.isArray(profile?.groups) ? profile.groups : []; + return groups.map((g) => String(g).toUpperCase()); + } catch (error) { + console.error('Failed to fetch user groups from IMS profile:', error.message); + return []; + } +} + +/** + * Returns true if the caller is allowed to mutate fragments in the given surface. + * Admin group bypasses the check. Otherwise the caller must be in the per-surface + * EDITORS group. + * + * @param {string[]} groups - uppercase LDAP group names + * @param {string|null} surface - surface segment (lowercase), e.g. 'acom' + * @returns {boolean} + */ +export function canEditSurface(groups, surface) { + if (!Array.isArray(groups) || groups.length === 0) return false; + if (groups.includes(MAS_ADMIN_GROUP.toUpperCase())) return true; + if (!surface) return false; + const required = EDITOR_ACCESS_GROUP_BY_SURFACE.get(surface); + return !!required && groups.includes(required.toUpperCase()); +} + +/** + * Middleware-style gate for mutating Runtime actions. Validates IMS token, + * derives the surface from params, fetches user groups, and returns a 403 if + * the caller lacks editor access for that surface. + * + * @param {Object} headers - __ow_headers + * @param {Object} params - Runtime params (must contain parentPath or path) + * @returns {Promise} - error response or null if authorized + */ +export async function requireSurfaceAccess(headers, params) { + const authError = await requireIMSAuth(headers); + if (authError) return authError; + + const pathForSurface = params?.parentPath || params?.path; + const surface = deriveSurfaceFromPath(pathForSurface); + if (!surface) { + return { + statusCode: 400, + body: { + error: 'parentPath or path (under /content/dam/mas/{surface}/...) is required to authorize this operation', + }, + }; + } + + const token = headers.authorization.replace('Bearer ', ''); + const groups = await fetchUserGroups(token); + if (!canEditSurface(groups, surface)) { + return { + statusCode: 403, + body: { + error: `Forbidden: caller does not have editor access to surface "${surface}"`, + }, + }; + } + + return null; +} + +/** + * Middleware-style function to validate auth in Runtime actions + * Returns error response if invalid, null if valid + * @param {Object} headers - Runtime __ow_headers object + * @returns {Promise} Error response or null if valid + */ +/** + * Resolves AEM base URL from action params + * Returns error response if not configured, null if valid + * @param {Object} params - Runtime action params + * @returns {{url: string, error?: Object}} + */ +export function resolveAemBaseUrl(params) { + const url = params._aemBaseUrl || params.AEM_BASE_URL; + if (!url) { + return { url: null, error: { statusCode: 500, body: { error: 'AEM_BASE_URL is not configured' } } }; + } + return { url, error: null }; +} + +export async function requireIMSAuth(headers) { + const authHeader = headers?.authorization; + + if (!authHeader?.startsWith('Bearer ')) { + return { + statusCode: 401, + body: { error: 'Authorization required: Bearer token missing' }, + }; + } + + const token = authHeader.slice(7); + const validation = await validateIMSToken(token); + + if (!validation.valid) { + return { + statusCode: 401, + body: { error: `Unauthorized: ${validation.error}` }, + }; + } + + return null; // No error, auth is valid +} diff --git a/io/mcp-server/src/lib/job-manager.js b/io/mcp-server/src/lib/job-manager.js new file mode 100644 index 000000000..f696f6a23 --- /dev/null +++ b/io/mcp-server/src/lib/job-manager.js @@ -0,0 +1,192 @@ +/** + * Job Manager for tracking bulk operation progress + * Uses Adobe I/O Runtime State API when available, falls back to in-memory storage + */ +export class JobManager { + constructor(useInMemory = false) { + this.useInMemory = useInMemory; + this.memoryStore = new Map(); + } + + generateJobId(type) { + const timestamp = Date.now(); + const random = Math.random().toString(36).substring(2, 9); + return `${type}-${timestamp}-${random}`; + } + + async createJob(type, total, metadata = {}) { + const jobId = this.generateJobId(type); + const job = { + jobId, + type, + status: 'processing', + total, + completed: 0, + successful: [], + failed: [], + skipped: [], + startedAt: new Date().toISOString(), + ...metadata, + }; + + await this.saveJob(jobId, job); + console.log('[JobManager] Created job:', { jobId, type, total }); + return jobId; + } + + async updateJobProgress(jobId, update) { + const job = await this.getJob(jobId); + if (!job) { + throw new Error(`Job ${jobId} not found`); + } + + const updatedJob = { + ...job, + ...update, + updatedAt: new Date().toISOString(), + }; + + await this.saveJob(jobId, updatedJob); + return updatedJob; + } + + async addSuccessfulItem(jobId, item) { + const job = await this.getJob(jobId); + if (!job) { + throw new Error(`Job ${jobId} not found`); + } + + const updatedJob = { + ...job, + completed: job.completed + 1, + successful: [...job.successful, item], + updatedAt: new Date().toISOString(), + }; + + await this.saveJob(jobId, updatedJob); + return updatedJob; + } + + async addFailedItem(jobId, item) { + const job = await this.getJob(jobId); + if (!job) { + throw new Error(`Job ${jobId} not found`); + } + + const updatedJob = { + ...job, + completed: job.completed + 1, + failed: [...job.failed, item], + updatedAt: new Date().toISOString(), + }; + + await this.saveJob(jobId, updatedJob); + return updatedJob; + } + + async addSkippedItem(jobId, item) { + const job = await this.getJob(jobId); + if (!job) { + throw new Error(`Job ${jobId} not found`); + } + + const updatedJob = { + ...job, + completed: job.completed + 1, + skipped: [...job.skipped, item], + updatedAt: new Date().toISOString(), + }; + + await this.saveJob(jobId, updatedJob); + return updatedJob; + } + + async completeJob(jobId, finalData = {}) { + const job = await this.getJob(jobId); + if (!job) { + throw new Error(`Job ${jobId} not found`); + } + + const completedJob = { + ...job, + ...finalData, + status: 'completed', + completedAt: new Date().toISOString(), + }; + + await this.saveJob(jobId, completedJob); + console.log('[JobManager] Completed job:', { + jobId, + total: job.total, + successful: job.successful.length, + skipped: job.skipped.length, + failed: job.failed.length, + }); + return completedJob; + } + + async failJob(jobId, error) { + const job = await this.getJob(jobId); + if (!job) { + throw new Error(`Job ${jobId} not found`); + } + + const failedJob = { + ...job, + status: 'failed', + error: error.message || error, + failedAt: new Date().toISOString(), + }; + + await this.saveJob(jobId, failedJob); + console.error('[JobManager] Job failed:', { jobId, error: failedJob.error }); + return failedJob; + } + + async getJob(jobId) { + if (this.useInMemory) { + return this.memoryStore.get(jobId); + } + + if (typeof process !== 'undefined' && process.env.__OW_ACTION_NAME) { + const stateLib = await import('@adobe/aio-lib-state'); + const state = await stateLib.init(); + const result = await state.get(`job-${jobId}`); + return result?.value ? JSON.parse(result.value) : null; + } + + return this.memoryStore.get(jobId); + } + + async saveJob(jobId, job) { + if (this.useInMemory) { + this.memoryStore.set(jobId, job); + return; + } + + if (typeof process !== 'undefined' && process.env.__OW_ACTION_NAME) { + const stateLib = await import('@adobe/aio-lib-state'); + const state = await stateLib.init(); + await state.put(`job-${jobId}`, JSON.stringify(job), { ttl: 3600 }); + return; + } + + this.memoryStore.set(jobId, job); + } + + async deleteJob(jobId) { + if (this.useInMemory) { + this.memoryStore.delete(jobId); + return; + } + + if (typeof process !== 'undefined' && process.env.__OW_ACTION_NAME) { + const stateLib = await import('@adobe/aio-lib-state'); + const state = await stateLib.init(); + await state.delete(`job-${jobId}`); + return; + } + + this.memoryStore.delete(jobId); + } +} diff --git a/io/mcp-server/src/lib/shared-job-manager.js b/io/mcp-server/src/lib/shared-job-manager.js new file mode 100644 index 000000000..8cea8d492 --- /dev/null +++ b/io/mcp-server/src/lib/shared-job-manager.js @@ -0,0 +1,8 @@ +/** + * Singleton JobManager instance for shared access across all I/O Runtime actions + * This ensures that jobs created by bulk operation actions can be retrieved by status actions + * (Important for consistent job state across serverless function invocations) + */ +import { JobManager } from './job-manager.js'; + +export const sharedJobManager = new JobManager(); diff --git a/io/mcp-server/src/lib/studio-operations.js b/io/mcp-server/src/lib/studio-operations.js new file mode 100644 index 000000000..6541c69f6 --- /dev/null +++ b/io/mcp-server/src/lib/studio-operations.js @@ -0,0 +1,1928 @@ +import { AEMClient } from './aem-client.js'; +import { StudioURLBuilder } from './studio-url-builder.js'; +import { sharedJobManager } from './shared-job-manager.js'; + +const PATH_TOKENS = /\/content\/dam\/mas\/(?[\w-]+)\/(?[a-z]{2}_[A-Z]{2,4})\/(?.+)/; + +const LOCALE_DEFAULTS = [ + 'ar_MENA', + 'bg_BG', + 'cs_CZ', + 'da_DK', + 'de_DE', + 'en_US', + 'es_ES', + 'fi_FI', + 'fr_FR', + 'he_IL', + 'hu_HU', + 'id_ID', + 'it_IT', + 'ja_JP', + 'ko_KR', + 'nb_NO', + 'nl_NL', + 'pl_PL', + 'pt_BR', + 'ro_RO', + 'ru_RU', + 'sk_SK', + 'sl_SI', + 'sv_SE', + 'th_TH', + 'tr_TR', + 'uk_UA', + 'vi_VN', + 'zh_CN', + 'zh_TW', +]; + +const TAG_MODEL_ID_MAPPING = { + 'mas:studio/content-type/merch-card-collection': 'L2NvbmYvbWFzL3NldHRpbmdzL2RhbS9jZm0vbW9kZWxzL2NvbGxlY3Rpb24', + 'mas:studio/content-type/merch-card': 'L2NvbmYvbWFzL3NldHRpbmdzL2RhbS9jZm0vbW9kZWxzL2NhcmQ', +}; + +const CARD_MODEL_ID = TAG_MODEL_ID_MAPPING['mas:studio/content-type/merch-card']; +const COLLECTION_MODEL_ID = TAG_MODEL_ID_MAPPING['mas:studio/content-type/merch-card-collection']; +const EDITABLE_FRAGMENT_MODEL_IDS = Object.values(TAG_MODEL_ID_MAPPING); + +/** + * Strip HTML tags from text while preserving the content + * Used for searching text in HTML-formatted fields + * @param {string} html - HTML text to strip + * @returns {string} - Plain text without HTML tags + */ +function stripHtml(html) { + if (typeof html !== 'string') { + return ''; + } + return html.replace(/<[^>]*>/g, ''); +} + +/** + * Check if text exists in either raw HTML or stripped plain text + * Handles both HTML-formatted fields and plain text fields + * @param {string} value - The field value to search in + * @param {string} find - The text to find + * @returns {boolean} - True if found in either raw or stripped version + */ +function textExistsInField(value, find) { + if (typeof value !== 'string' || typeof find !== 'string') { + return false; + } + return value.includes(find) || stripHtml(value).includes(find); +} + +/** + * Studio Operations Tools + * MCP tools for Studio AI Chat operations (NO AI CALLS - pure execution only) + * + * These tools handle AEM operations requested through Studio's AI chat. + * AI intent detection happens in Adobe I/O Runtime, these tools only execute. + * Auto-synced to io/mcp-server via Claude Code hook (verified working) + */ +export class StudioOperations { + constructor(aemClient, urlBuilder) { + this.aemClient = aemClient; + this.urlBuilder = urlBuilder; + } + + /** + * Publish a card to production + * @param {Object} params - { id: string, publishReferences?: boolean } + */ + async publishCard(params) { + const { id, publishReferences = true } = params; + + if (!id) { + throw new Error('Card ID is required for publish operation'); + } + + const fragment = await this.aemClient.getFragment(id); + + if (!fragment) { + throw new Error(`Card not found: ${id}`); + } + + await this.aemClient.publishFragment(fragment.id, publishReferences); + + const card = this.formatCard(fragment); + const studioLinks = this.urlBuilder.createCardLinks(card); + + return { + success: true, + operation: 'publish', + card, + message: `✓ "${fragment.title}" has been published to production.`, + studioLinks: { + viewInStudio: studioLinks.view, + viewFolder: studioLinks.folder, + }, + }; + } + + /** + * Unpublish a card from production + * @param {Object} params - { id: string } + */ + async unpublishCard(params) { + const { id } = params; + + if (!id) { + throw new Error('Card ID is required for unpublish operation'); + } + + const fragment = await this.aemClient.getFragment(id); + + if (!fragment) { + throw new Error(`Card not found: ${id}`); + } + + await this.aemClient.unpublishFragment(fragment.id); + + const card = this.formatCard(fragment); + const studioLinks = this.urlBuilder.createCardLinks(card); + + return { + success: true, + operation: 'unpublish', + card, + message: `✓ "${fragment.title}" has been unpublished from production.`, + studioLinks: { + viewInStudio: studioLinks.view, + viewFolder: studioLinks.folder, + }, + }; + } + + /** + * Get a card by ID + * @param {Object} params - { id: string } + */ + async getCard(params) { + const { id } = params; + + if (!id) { + throw new Error('Card ID is required for get operation'); + } + + const fragment = await this.aemClient.getFragment(id); + + if (!fragment) { + throw new Error(`Card not found: ${id}`); + } + + const card = this.formatCard(fragment); + const studioLinks = this.urlBuilder.createCardLinks(card); + + return { + success: true, + operation: 'get', + card, + message: `Found "${fragment.title}"`, + studioLinks: { + viewInStudio: studioLinks.view, + viewFolder: studioLinks.folder, + }, + }; + } + + /** + * Check if a search query is CTA-related + * @param {string} query - Search query string + * @returns {boolean} True if query is searching for CTAs + */ + static isCTASearch(query) { + if (!query || typeof query !== 'string') { + return false; + } + + const ctaKeywords = [ + 'cta', + 'button', + 'link', + 'trial', + 'buy', + 'purchase', + 'checkout', + 'select', + 'start', + 'get started', + 'learn more', + 'free trial', + 'buy now', + 'shop now', + 'subscribe', + ]; + + const lowerQuery = query.toLowerCase(); + return ctaKeywords.some((keyword) => lowerQuery.includes(keyword)); + } + + /** + * Extract content from slot="footer" attribute + * @private + * @param {string} htmlContent - HTML string to parse + * @returns {Array} Array of footer slot content strings + */ + static extractFooterSlotContent(htmlContent) { + const footerSlots = []; + + // Match div or other elements with slot="footer" + const slotRegex = /<(div|[a-z]+)\s[^>]*slot="footer"[^>]*>(.*?)<\/\1>/gis; + let match; + + while ((match = slotRegex.exec(htmlContent)) !== null) { + footerSlots.push(match[2]); + } + + // Also match slot element itself + const namedSlotRegex = /]*><\/slot>/gis; + if (namedSlotRegex.test(htmlContent)) { + // For named slots, we need to extract content from corresponding slot="footer" + footerSlots.push(htmlContent); + } + + return footerSlots; + } + + /** + * Check if content is inside a merch-addon element + * @private + * @param {string} htmlContent - Full HTML content + * @param {number} matchIndex - Index position to check + * @returns {boolean} True if position is inside merch-addon + */ + static isInsideMerchAddon(htmlContent, matchIndex) { + // Find all merch-addon boundaries + const addonRegex = /]*>(.*?)<\/merch-addon>/gis; + let addonMatch; + + while ((addonMatch = addonRegex.exec(htmlContent)) !== null) { + const addonStart = addonMatch.index; + const addonEnd = addonMatch.index + addonMatch[0].length; + + if (matchIndex >= addonStart && matchIndex < addonEnd) { + return true; + } + } + + return false; + } + + /** + * Extract CTA elements from HTML content + * Extracts ALL and