@stdiobus/workers-registry 1.3.11 → 1.3.12
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/launcher/index.js +6 -0
- package/launcher/index.js.map +1 -1
- package/out/dist/workers/acp-registry/registry-launcher-client.js +6 -0
- package/out/dist/workers/acp-registry/registry-launcher-client.js.map +1 -1
- package/out/dist/workers/acp-worker/index.js +6 -0
- package/out/dist/workers/acp-worker/index.js.map +1 -1
- package/out/dist/workers/echo-worker/echo-worker.js +6 -0
- package/out/dist/workers/echo-worker/echo-worker.js.map +1 -1
- package/out/dist/workers/mcp-echo-server/index.js +6 -0
- package/out/dist/workers/mcp-echo-server/index.js.map +1 -1
- package/out/dist/workers/mcp-to-acp-proxy/proxy.js +6 -0
- package/out/dist/workers/mcp-to-acp-proxy/proxy.js.map +1 -1
- package/package.json +1 -1
package/launcher/index.js
CHANGED
|
@@ -1,4 +1,10 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
+
import { createRequire } from 'module';
|
|
3
|
+
import { fileURLToPath } from 'url';
|
|
4
|
+
import { dirname } from 'path';
|
|
5
|
+
const require = createRequire(import.meta.url);
|
|
6
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
7
|
+
const __dirname = dirname(__filename);
|
|
2
8
|
import{fileURLToPath}from"url";import{dirname,join}from"path";import{readFile}from"fs/promises";var __filename=fileURLToPath(import.meta.url);var __dirname=dirname(__filename);var WORKERS={"acp-worker":{path:"../out/dist/workers/acp-worker/index.js",description:"Full ACP protocol implementation with MCP integration"},"acp-registry":{path:"../out/dist/workers/acp-registry/registry-launcher-client.js",description:"Registry Launcher for ACP Registry agents"},"echo-worker":{path:"../out/dist/workers/echo-worker/echo-worker.js",description:"Simple echo worker for testing NDJSON protocol"},"mcp-echo-server":{path:"../out/dist/workers/mcp-echo-server/index.js",description:"MCP server example for testing"},"mcp-to-acp-proxy":{path:"../out/dist/workers/mcp-to-acp-proxy/proxy.js",description:"MCP-to-ACP protocol bridge"}};function showUsage(){console.error("Usage: node index.js <worker-name>");console.error("");console.error("Available workers:");for(const[name,config]of Object.entries(WORKERS)){console.error(` - ${name.padEnd(20)} ${config.description}`)}console.error("");console.error("Examples:");console.error(" node index.js acp-worker");console.error(" node index.js echo-worker");console.error(" node index.js mcp-echo-server")}function isValidWorkerName(name){return name in WORKERS}async function main(){const workerName=process.argv[2];if(!workerName){console.error("Error: Worker name is required\n");showUsage();process.exit(1)}if(!isValidWorkerName(workerName)){console.error(`Error: Unknown worker "${workerName}"
|
|
3
9
|
`);showUsage();process.exit(1)}const workerConfig=WORKERS[workerName];const workerPath=workerConfig.path;const absolutePath=join(__dirname,workerPath);try{await readFile(absolutePath);console.error(`[launcher] Starting worker: ${workerName}`);console.error(`[launcher] Description: ${workerConfig.description}`);console.error(`[launcher] Path: ${absolutePath}`);await import(absolutePath)}catch(error){if(error&&typeof error==="object"&&"code"in error&&error.code==="ENOENT"){console.error(`Error: Worker file not found: ${absolutePath}`);console.error("");console.error('Please run "npm run build" first to compile the workers.');process.exit(1)}const errorMessage=error instanceof Error?error.message:String(error);const errorStack=error instanceof Error?error.stack:void 0;console.error(`Error loading worker "${workerName}":`,errorMessage);if(errorStack){console.error(errorStack)}process.exit(1)}}main().catch(error=>{console.error("Fatal error:",error);process.exit(1)});
|
|
4
10
|
//# sourceMappingURL=index.js.map
|
package/launcher/index.js.map
CHANGED
|
@@ -2,6 +2,6 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../workers-registry/launcher/index.ts"],
|
|
4
4
|
"sourcesContent": ["#!/usr/bin/env node\n\n/*\n * Apache License 2.0\n * Copyright (c) 2025\u2013present Raman Marozau, Target Insight Function.\n * Contact: raman@worktif.com\n *\n * This file is part of the stdio bus protocol reference implementation:\n * stdio_bus_kernel_workers (target: <target_stdio_bus_kernel_workers>).\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n *\n * SPDX-License-Identifier: Apache-2.0\n */\n\n/**\n * Universal worker launcher for stdio Bus Workers Registry\n * \n * Usage:\n * node index.js <worker-name>\n * node index.js acp-worker\n * node index.js echo-worker\n * node index.js mcp-echo-server\n * \n * This script dynamically imports and runs the specified worker from the compiled output.\n */\n\nimport { fileURLToPath } from 'url';\nimport { dirname, join } from 'path';\nimport { readFile } from 'fs/promises';\n\nconst __filename = fileURLToPath(import.meta.url);\nconst __dirname = dirname(__filename);\n\n/**\n * Worker configuration mapping worker names to their entry points\n */\ninterface WorkerConfig {\n readonly path: string;\n readonly description: string;\n}\n\n/**\n * Available workers mapping\n */\nconst WORKERS: Readonly<Record<string, WorkerConfig>> = {\n 'acp-worker': {\n path: '../out/dist/workers/acp-worker/index.js',\n description: 'Full ACP protocol implementation with MCP integration'\n },\n 'acp-registry': {\n path: '../out/dist/workers/acp-registry/registry-launcher-client.js',\n description: 'Registry Launcher for ACP Registry agents'\n },\n 'echo-worker': {\n path: '../out/dist/workers/echo-worker/echo-worker.js',\n description: 'Simple echo worker for testing NDJSON protocol'\n },\n 'mcp-echo-server': {\n path: '../out/dist/workers/mcp-echo-server/index.js',\n description: 'MCP server example for testing'\n },\n 'mcp-to-acp-proxy': {\n path: '../out/dist/workers/mcp-to-acp-proxy/proxy.js',\n description: 'MCP-to-ACP protocol bridge'\n }\n} as const;\n\n/**\n * Worker name type\n */\ntype WorkerName = keyof typeof WORKERS;\n\n/**\n * Display usage information\n */\nfunction showUsage(): void {\n console.error('Usage: node index.js <worker-name>');\n console.error('');\n console.error('Available workers:');\n\n for (const [name, config] of Object.entries(WORKERS)) {\n console.error(` - ${name.padEnd(20)} ${config.description}`);\n }\n\n console.error('');\n console.error('Examples:');\n console.error(' node index.js acp-worker');\n console.error(' node index.js echo-worker');\n console.error(' node index.js mcp-echo-server');\n}\n\n/**\n * Validate worker name\n */\nfunction isValidWorkerName(name: string): name is WorkerName {\n return name in WORKERS;\n}\n\n/**\n * Main entry point\n */\nasync function main(): Promise<void> {\n const workerName = process.argv[2];\n\n // Check if worker name is provided\n if (!workerName) {\n console.error('Error: Worker name is required\\n');\n showUsage();\n process.exit(1);\n }\n\n // Check if worker exists\n if (!isValidWorkerName(workerName)) {\n console.error(`Error: Unknown worker \"${workerName}\"\\n`);\n showUsage();\n process.exit(1);\n }\n\n const workerConfig = WORKERS[workerName];\n const workerPath = workerConfig.path;\n\n // Resolve absolute path\n const absolutePath = join(__dirname, workerPath);\n\n try {\n // Verify the worker file exists\n await readFile(absolutePath);\n\n // Import and run the worker\n console.error(`[launcher] Starting worker: ${workerName}`);\n console.error(`[launcher] Description: ${workerConfig.description}`);\n console.error(`[launcher] Path: ${absolutePath}`);\n\n await import(absolutePath);\n } catch (error) {\n if (error && typeof error === 'object' && 'code' in error && error.code === 'ENOENT') {\n console.error(`Error: Worker file not found: ${absolutePath}`);\n console.error('');\n console.error('Please run \"npm run build\" first to compile the workers.');\n process.exit(1);\n }\n\n const errorMessage = error instanceof Error ? error.message : String(error);\n const errorStack = error instanceof Error ? error.stack : undefined;\n\n console.error(`Error loading worker \"${workerName}\":`, errorMessage);\n if (errorStack) {\n console.error(errorStack);\n }\n process.exit(1);\n }\n}\n\n// Run main function\nmain().catch((error) => {\n console.error('Fatal error:', error);\n process.exit(1);\n});\n"],
|
|
5
|
-
"mappings": "
|
|
5
|
+
"mappings": ";;;;;;;AAqCA,OAAS,kBAAqB,MAC9B,OAAS,QAAS,SAAY,OAC9B,OAAS,aAAgB,cAEzB,IAAM,WAAa,cAAc,YAAY,GAAG,EAChD,IAAM,UAAY,QAAQ,UAAU,EAapC,IAAM,QAAkD,CACtD,aAAc,CACZ,KAAM,0CACN,YAAa,uDACf,EACA,eAAgB,CACd,KAAM,+DACN,YAAa,2CACf,EACA,cAAe,CACb,KAAM,iDACN,YAAa,gDACf,EACA,kBAAmB,CACjB,KAAM,+CACN,YAAa,gCACf,EACA,mBAAoB,CAClB,KAAM,gDACN,YAAa,4BACf,CACF,EAUA,SAAS,WAAkB,CACzB,QAAQ,MAAM,oCAAoC,EAClD,QAAQ,MAAM,EAAE,EAChB,QAAQ,MAAM,oBAAoB,EAElC,SAAW,CAAC,KAAM,MAAM,IAAK,OAAO,QAAQ,OAAO,EAAG,CACpD,QAAQ,MAAM,OAAO,KAAK,OAAO,EAAE,CAAC,IAAI,OAAO,WAAW,EAAE,CAC9D,CAEA,QAAQ,MAAM,EAAE,EAChB,QAAQ,MAAM,WAAW,EACzB,QAAQ,MAAM,4BAA4B,EAC1C,QAAQ,MAAM,6BAA6B,EAC3C,QAAQ,MAAM,iCAAiC,CACjD,CAKA,SAAS,kBAAkB,KAAkC,CAC3D,OAAO,QAAQ,OACjB,CAKA,eAAe,MAAsB,CACnC,MAAM,WAAa,QAAQ,KAAK,CAAC,EAGjC,GAAI,CAAC,WAAY,CACf,QAAQ,MAAM,kCAAkC,EAChD,UAAU,EACV,QAAQ,KAAK,CAAC,CAChB,CAGA,GAAI,CAAC,kBAAkB,UAAU,EAAG,CAClC,QAAQ,MAAM,0BAA0B,UAAU;AAAA,CAAK,EACvD,UAAU,EACV,QAAQ,KAAK,CAAC,CAChB,CAEA,MAAM,aAAe,QAAQ,UAAU,EACvC,MAAM,WAAa,aAAa,KAGhC,MAAM,aAAe,KAAK,UAAW,UAAU,EAE/C,GAAI,CAEF,MAAM,SAAS,YAAY,EAG3B,QAAQ,MAAM,+BAA+B,UAAU,EAAE,EACzD,QAAQ,MAAM,2BAA2B,aAAa,WAAW,EAAE,EACnE,QAAQ,MAAM,oBAAoB,YAAY,EAAE,EAEhD,MAAM,OAAO,aACf,OAAS,MAAO,CACd,GAAI,OAAS,OAAO,QAAU,UAAY,SAAU,OAAS,MAAM,OAAS,SAAU,CACpF,QAAQ,MAAM,iCAAiC,YAAY,EAAE,EAC7D,QAAQ,MAAM,EAAE,EAChB,QAAQ,MAAM,0DAA0D,EACxE,QAAQ,KAAK,CAAC,CAChB,CAEA,MAAM,aAAe,iBAAiB,MAAQ,MAAM,QAAU,OAAO,KAAK,EAC1E,MAAM,WAAa,iBAAiB,MAAQ,MAAM,MAAQ,OAE1D,QAAQ,MAAM,yBAAyB,UAAU,KAAM,YAAY,EACnE,GAAI,WAAY,CACd,QAAQ,MAAM,UAAU,CAC1B,CACA,QAAQ,KAAK,CAAC,CAChB,CACF,CAGA,KAAK,EAAE,MAAO,OAAU,CACtB,QAAQ,MAAM,eAAgB,KAAK,EACnC,QAAQ,KAAK,CAAC,CAChB,CAAC",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -1,4 +1,10 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
+
import { createRequire } from 'module';
|
|
3
|
+
import { fileURLToPath } from 'url';
|
|
4
|
+
import { dirname } from 'path';
|
|
5
|
+
const require = createRequire(import.meta.url);
|
|
6
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
7
|
+
const __dirname = dirname(__filename);
|
|
2
8
|
import net from"net";import readline from"readline";import crypto from"crypto";function parseArgs(){const args=process.argv.slice(2);const options={tcp:null,unix:null,agentId:null,flow:null,sessionId:null,prompt:"Hello, agent!",interactive:false,timeout:3e4,help:false};for(let i=0;i<args.length;i++){const arg=args[i];switch(arg){case"--tcp":options.tcp=args[++i];break;case"--unix":options.unix=args[++i];break;case"--agent":options.agentId=args[++i];break;case"--flow":options.flow=args[++i];break;case"--session":options.sessionId=args[++i];break;case"--prompt":options.prompt=args[++i];break;case"--interactive":options.interactive=true;break;case"--timeout":options.timeout=parseInt(args[++i],10);break;case"--help":case"-h":options.help=true;break;default:console.error(`Unknown option: ${arg}`);process.exit(1)}}return options}function showHelp(){console.log(`
|
|
3
9
|
ACP Registry Transit Test Client
|
|
4
10
|
|
|
@@ -2,6 +2,6 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../workers-registry/acp-registry/registry-launcher-client.js"],
|
|
4
4
|
"sourcesContent": ["#!/usr/bin/env node\n\n/*\n * Apache License 2.0\n * Copyright (c) 2025\u2013present Raman Marozau, Target Insight Function.\n * Contact: raman@worktif.com\n *\n * This file is part of the stdio bus protocol reference implementation:\n * stdio_bus_kernel_workers (target: <target_stdio_bus_kernel_workers>).\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n *\n * SPDX-License-Identifier: Apache-2.0\n */\n\n/**\n * @file registry-launcher-client.js\n * @brief Test client for ACP Registry Transit via stdio Bus\n *\n * This test client demonstrates sending ACP messages through the Registry Launcher\n * transit chain. It shows how to use the agentId field for routing messages to\n * specific agents registered in the ACP Registry.\n *\n * ## Transit Chain\n *\n * ```\n * This Client \u2192 stdio Bus \u2192 Registry Launcher \u2192 ACP Agent \u2192 back\n * ```\n *\n * ## Connection Modes\n *\n * The client supports TCP and Unix socket connections to stdio Bus:\n *\n * - **TCP**: Connect to `--tcp <host:port>` mode\n * ```bash\n * node workers-registry/acp-registry/registry-launcher-client.js --tcp localhost:9000 --agent my-agent\n * ```\n *\n * - **Unix Socket**: Connect to `--unix <path>` mode\n * ```bash\n * node workers-registry/acp-registry/registry-launcher-client.js --unix /tmp/stdio_bus.sock --agent my-agent\n * ```\n *\n * ## Usage\n *\n * ```bash\n * # Start stdio Bus with Registry Launcher configuration. stdio Bus kernel repo: https://github.com/stdiobus/stdiobus\n * ./stdio_bus --config workers-registry/acp-registry/registry-launcher-config.json --tcp localhost:9000\n *\n * # In another terminal, run the test client\n * node workers-registry/acp-registry/registry-launcher-client.js --tcp localhost:9000 --agent my-agent\n *\n * # Run specific ACP flow\n * node workers-registry/acp-registry/registry-launcher-client.js --tcp localhost:9000 --agent my-agent --flow initialize\n * node workers-registry/acp-registry/registry-launcher-client.js --tcp localhost:9000 --agent my-agent --flow session-new\n * node workers-registry/acp-registry/registry-launcher-client.js --tcp localhost:9000 --agent my-agent --flow session-prompt\n *\n * # Run full ACP flow (initialize \u2192 session/new \u2192 session/prompt)\n * node workers-registry/acp-registry/registry-launcher-client.js --tcp localhost:9000 --agent my-agent --flow full\n *\n * # Interactive mode - send custom messages with agentId\n * node workers-registry/acp-registry/registry-launcher-client.js --tcp localhost:9000 --agent my-agent --interactive\n * ```\n *\n * ## Command Line Options\n *\n * | Option | Description |\n * |--------|-------------|\n * | `--tcp <host:port>` | Connect via TCP to specified host and port |\n * | `--unix <path>` | Connect via Unix domain socket |\n * | `--agent <id>` | Agent ID from ACP Registry (required) |\n * | `--flow <type>` | ACP flow to execute: initialize, session-new, session-prompt, full |\n * | `--session <id>` | Session ID for session-based requests (auto-generated if not provided) |\n * | `--prompt <text>` | Prompt text for session/prompt request (default: \"Hello, agent!\") |\n * | `--interactive` | Interactive mode: read JSON from stdin, auto-add agentId |\n * | `--timeout <ms>` | Response timeout in milliseconds (default: 30000) |\n * | `--help` | Show usage information |\n *\n * ## ACP Message Flows\n *\n * ### Initialize Flow\n *\n * Sends an `initialize` request to establish protocol version and capabilities:\n *\n * ```json\n * {\n * \"jsonrpc\": \"2.0\",\n * \"id\": \"init-1\",\n * \"method\": \"initialize\",\n * \"agentId\": \"my-agent\",\n * \"params\": {\n * \"protocolVersion\": 1,\n * \"capabilities\": {},\n * \"clientInfo\": {\n * \"name\": \"registry-launcher-test-client\",\n * \"version\": \"1.0.0\"\n * }\n * }\n * }\n * ```\n *\n * ### Session/New Flow\n *\n * Creates a new session with the agent:\n *\n * ```json\n * {\n * \"jsonrpc\": \"2.0\",\n * \"id\": \"session-new-1\",\n * \"method\": \"session/new\",\n * \"agentId\": \"my-agent\",\n * \"params\": {}\n * }\n * ```\n *\n * ### Session/Prompt Flow\n *\n * Sends a prompt to an existing session:\n *\n * ```json\n * {\n * \"jsonrpc\": \"2.0\",\n * \"id\": \"prompt-1\",\n * \"method\": \"session/prompt\",\n * \"agentId\": \"my-agent\",\n * \"params\": {\n * \"sessionId\": \"sess-123\",\n * \"prompt\": {\n * \"messages\": [\n * {\n * \"role\": \"user\",\n * \"content\": { \"type\": \"text\", \"text\": \"Hello, agent!\" }\n * }\n * ]\n * }\n * }\n * }\n * ```\n *\n * ## Important Notes\n *\n * - The `agentId` field is required for all messages and is used by the Registry\n * Launcher to route messages to the correct agent process\n * - The Registry Launcher removes the `agentId` field before forwarding to the agent\n * - Responses from agents are forwarded unchanged (no agentId added)\n * - Session IDs returned by session/new should be used in subsequent session/prompt calls\n */\n\nimport net from 'net';\nimport readline from 'readline';\nimport crypto from 'crypto';\n\n/**\n * Parse command line arguments.\n * @returns {Object} Parsed options\n */\nfunction parseArgs() {\n const args = process.argv.slice(2);\n const options = {\n tcp: null,\n unix: null,\n agentId: null,\n flow: null,\n sessionId: null,\n prompt: 'Hello, agent!',\n interactive: false,\n timeout: 30000,\n help: false\n };\n\n for (let i = 0; i < args.length; i++) {\n const arg = args[i];\n switch (arg) {\n case '--tcp':\n options.tcp = args[++i];\n break;\n case '--unix':\n options.unix = args[++i];\n break;\n case '--agent':\n options.agentId = args[++i];\n break;\n case '--flow':\n options.flow = args[++i];\n break;\n case '--session':\n options.sessionId = args[++i];\n break;\n case '--prompt':\n options.prompt = args[++i];\n break;\n case '--interactive':\n options.interactive = true;\n break;\n case '--timeout':\n options.timeout = parseInt(args[++i], 10);\n break;\n case '--help':\n case '-h':\n options.help = true;\n break;\n default:\n console.error(`Unknown option: ${arg}`);\n process.exit(1);\n }\n }\n\n return options;\n}\n\n/**\n * Display usage information.\n */\nfunction showHelp() {\n console.log(`\nACP Registry Transit Test Client\n\nThis client demonstrates sending ACP messages through the Registry Launcher\ntransit chain: Client \u2192 stdio Bus \u2192 Registry Launcher \u2192 ACP Agent \u2192 back\n\nUsage:\n node registry-launcher-client.js --tcp <host:port> --agent <id> [options]\n node registry-launcher-client.js --unix <path> --agent <id> [options]\n\nConnection (one required):\n --tcp <host:port> Connect via TCP (e.g., localhost:9000)\n --unix <path> Connect via Unix socket (e.g., /tmp/stdio_bus.sock)\n\nRequired:\n --agent <id> Agent ID from ACP Registry to route messages to\n\nACP Flow Options:\n --flow <type> ACP flow to execute:\n initialize - Send initialize request\n session-new - Create new session\n session-prompt - Send prompt to session\n full - Run full flow (init \u2192 new \u2192 prompt)\n --session <id> Session ID for session/prompt (auto-generated if not set)\n --prompt <text> Prompt text for session/prompt (default: \"Hello, agent!\")\n\nModes:\n --interactive Read JSON from stdin, auto-add agentId to messages\n --timeout <ms> Response timeout in ms (default: 30000)\n\nOther:\n --help, -h Show this help message\n\nExamples:\n # Run full ACP flow with an agent\n node registry-launcher-client.js --tcp localhost:9000 --agent my-agent --flow full\n\n # Send just an initialize request\n node registry-launcher-client.js --tcp localhost:9000 --agent my-agent --flow initialize\n\n # Create a new session\n node registry-launcher-client.js --tcp localhost:9000 --agent my-agent --flow session-new\n\n # Send a prompt to an existing session\n node registry-launcher-client.js --tcp localhost:9000 --agent my-agent --flow session-prompt --session sess-123\n\n # Interactive mode - type JSON messages, agentId added automatically\n node registry-launcher-client.js --tcp localhost:9000 --agent my-agent --interactive\n`);\n}\n\n/**\n * Generate a unique request ID.\n * @param {string} prefix - Prefix for the ID\n * @returns {string} Unique ID\n */\nfunction generateId(prefix = 'req') {\n return `${prefix}-${crypto.randomUUID().slice(0, 8)}`;\n}\n\n/**\n * Generate a unique session ID.\n * @returns {string} Session ID\n */\nfunction generateSessionId() {\n return `sess-${crypto.randomUUID().slice(0, 8)}`;\n}\n\n/**\n * Build an ACP initialize request.\n * @param {string} agentId - Agent ID for routing\n * @returns {Object} JSON-RPC initialize request\n */\nfunction buildInitializeRequest(agentId) {\n return {\n jsonrpc: '2.0',\n id: generateId('init'),\n method: 'initialize',\n agentId,\n params: {\n protocolVersion: 1,\n clientCapabilities: {},\n clientInfo: {\n name: 'registry-launcher-test-client',\n version: '1.0.0'\n }\n }\n };\n}\n\n/**\n * Build an ACP authenticate request.\n * @param {string} agentId - Agent ID for routing\n * @param {string} methodId - Authentication method ID\n * @returns {Object} JSON-RPC authenticate request\n */\nfunction buildAuthenticateRequest(agentId, methodId) {\n return {\n jsonrpc: '2.0',\n id: generateId('auth'),\n method: 'authenticate',\n agentId,\n params: {\n methodId\n }\n };\n}\n\n/**\n * Build an ACP session/new request.\n * @param {string} agentId - Agent ID for routing\n * @returns {Object} JSON-RPC session/new request\n */\nfunction buildSessionNewRequest(agentId) {\n return {\n jsonrpc: '2.0',\n id: generateId('session-new'),\n method: 'session/new',\n agentId,\n params: {\n cwd: process.cwd(),\n mcpServers: []\n }\n };\n}\n\n/**\n * Build an ACP session/prompt request.\n * @param {string} agentId - Agent ID for routing\n * @param {string} sessionId - Session ID\n * @param {string} promptText - Prompt text\n * @returns {Object} JSON-RPC session/prompt request\n */\nfunction buildSessionPromptRequest(agentId, sessionId, promptText) {\n return {\n jsonrpc: '2.0',\n id: generateId('prompt'),\n method: 'session/prompt',\n agentId,\n params: {\n sessionId,\n prompt: [\n {\n type: 'text',\n text: promptText\n }\n ]\n }\n };\n}\n\n/**\n * Create a socket connection to stdio Bus.\n * @param {Object} options - Connection options\n * @returns {net.Socket} Connected socket\n */\nfunction createConnection(options) {\n if (options.tcp) {\n const [host, portStr] = options.tcp.split(':');\n const port = parseInt(portStr, 10);\n if (!host || isNaN(port)) {\n console.error('Invalid TCP address. Use format: host:port');\n process.exit(1);\n }\n console.error(`Connecting to TCP ${host}:${port}...`);\n return net.createConnection({ host, port });\n } else if (options.unix) {\n console.error(`Connecting to Unix socket ${options.unix}...`);\n return net.createConnection({ path: options.unix });\n } else {\n console.error('Error: Must specify --tcp or --unix');\n process.exit(1);\n }\n}\n\n/**\n * Send a request and wait for response.\n * @param {net.Socket} socket - Connected socket\n * @param {Object} request - Request to send\n * @param {number} timeout - Timeout in ms\n * @returns {Promise<Object>} Response object\n */\nfunction sendRequest(socket, request, timeout) {\n return new Promise((resolve, reject) => {\n let buffer = '';\n let timeoutId;\n\n const cleanup = () => {\n clearTimeout(timeoutId);\n socket.removeListener('data', onData);\n socket.removeListener('error', onError);\n socket.removeListener('close', onClose);\n };\n\n const onData = (data) => {\n buffer += data.toString();\n\n let newlineIndex;\n while ((newlineIndex = buffer.indexOf('\\n')) !== -1) {\n const line = buffer.slice(0, newlineIndex);\n buffer = buffer.slice(newlineIndex + 1);\n\n if (line.trim()) {\n try {\n const response = JSON.parse(line);\n // Check if this response matches our request ID\n if (response.id === request.id) {\n cleanup();\n resolve(response);\n return;\n } else {\n // Log other responses (notifications, etc.)\n console.error(`\u2190 Received (other): ${JSON.stringify(response)}`);\n }\n } catch (err) {\n console.error(`Error parsing response: ${err.message}`);\n }\n }\n }\n };\n\n const onError = (err) => {\n cleanup();\n reject(new Error(`Connection error: ${err.message}`));\n };\n\n const onClose = () => {\n cleanup();\n reject(new Error('Connection closed before response received'));\n };\n\n timeoutId = setTimeout(() => {\n cleanup();\n reject(new Error(`Timeout: No response within ${timeout}ms`));\n }, timeout);\n\n socket.on('data', onData);\n socket.on('error', onError);\n socket.on('close', onClose);\n\n // Send the request\n console.error(`\u2192 Sending: ${JSON.stringify(request)}`);\n socket.write(JSON.stringify(request) + '\\n');\n });\n}\n\n/**\n * Run the initialize flow.\n * @param {net.Socket} socket - Connected socket\n * @param {Object} options - Options\n * @returns {Promise<Object>} Initialize response\n */\nasync function runInitializeFlow(socket, options) {\n console.error('\\n=== Initialize Flow ===');\n const request = buildInitializeRequest(options.agentId);\n const response = await sendRequest(socket, request, options.timeout);\n\n console.log('\\nInitialize Response:');\n console.log(JSON.stringify(response, null, 2));\n\n if (response.error) {\n console.error(`\u2717 Initialize failed: ${response.error.message}`);\n } else {\n console.error('\u2713 Initialize successful');\n if (response.result?.protocolVersion) {\n console.error(` Protocol version: ${response.result.protocolVersion}`);\n }\n if (response.result?.serverInfo) {\n console.error(` Server: ${response.result.serverInfo.name} v${response.result.serverInfo.version}`);\n }\n }\n\n return response;\n}\n\n/**\n * Run the authenticate flow.\n * @param {net.Socket} socket - Connected socket\n * @param {Object} options - Options\n * @param {string} methodId - Authentication method ID\n * @returns {Promise<Object>} Authenticate response\n */\nasync function runAuthenticateFlow(socket, options, methodId) {\n console.error('\\n=== Authenticate Flow ===');\n console.error(` Method: ${methodId}`);\n const request = buildAuthenticateRequest(options.agentId, methodId);\n const response = await sendRequest(socket, request, options.timeout);\n\n console.log('\\nAuthenticate Response:');\n console.log(JSON.stringify(response, null, 2));\n\n if (response.error) {\n console.error(`\u2717 Authentication failed: ${response.error.message}`);\n } else {\n console.error('\u2713 Authentication successful');\n }\n\n return response;\n}\n\n/**\n * Run the session/new flow.\n * @param {net.Socket} socket - Connected socket\n * @param {Object} options - Options\n * @returns {Promise<Object>} Session/new response\n */\nasync function runSessionNewFlow(socket, options) {\n console.error('\\n=== Session/New Flow ===');\n const request = buildSessionNewRequest(options.agentId);\n const response = await sendRequest(socket, request, options.timeout);\n\n console.log('\\nSession/New Response:');\n console.log(JSON.stringify(response, null, 2));\n\n if (response.error) {\n console.error(`\u2717 Session creation failed: ${response.error.message}`);\n } else {\n console.error('\u2713 Session created successfully');\n if (response.result?.sessionId) {\n console.error(` Session ID: ${response.result.sessionId}`);\n }\n }\n\n return response;\n}\n\n/**\n * Run the session/prompt flow.\n * @param {net.Socket} socket - Connected socket\n * @param {Object} options - Options\n * @param {string} sessionId - Session ID to use\n * @returns {Promise<Object>} Session/prompt response\n */\nasync function runSessionPromptFlow(socket, options, sessionId) {\n console.error('\\n=== Session/Prompt Flow ===');\n const request = buildSessionPromptRequest(options.agentId, sessionId, options.prompt);\n const response = await sendRequest(socket, request, options.timeout);\n\n console.log('\\nSession/Prompt Response:');\n console.log(JSON.stringify(response, null, 2));\n\n if (response.error) {\n console.error(`\u2717 Prompt failed: ${response.error.message}`);\n } else {\n console.error('\u2713 Prompt successful');\n if (response.result?.messages) {\n console.error(` Response messages: ${response.result.messages.length}`);\n }\n }\n\n return response;\n}\n\n/**\n * Run the full ACP flow (initialize \u2192 session/new \u2192 session/prompt).\n * @param {net.Socket} socket - Connected socket\n * @param {Object} options - Options\n */\nasync function runFullFlow(socket, options) {\n console.error('\\n========================================');\n console.error('Running Full ACP Flow');\n console.error(`Agent: ${options.agentId}`);\n console.error('========================================');\n\n // Step 1: Initialize\n const initResponse = await runInitializeFlow(socket, options);\n if (initResponse.error) {\n console.error('\\nFull flow aborted due to initialize failure.');\n return;\n }\n\n // Step 2: Authenticate if required\n const authMethods = initResponse.result?.authMethods || [];\n if (authMethods.length > 0) {\n // Prefer openai-api-key, then any api-key method, then first available\n const openaiMethod = authMethods.find(m => m.id === 'openai-api-key');\n const apiKeyMethod = authMethods.find(m =>\n m.id.includes('api-key') || m.id.includes('apikey')\n );\n const methodId = openaiMethod?.id || apiKeyMethod?.id || authMethods[0].id;\n\n const authResponse = await runAuthenticateFlow(socket, options, methodId);\n if (authResponse.error) {\n console.error('\\nFull flow aborted due to authentication failure.');\n return;\n }\n }\n\n // Step 3: Create session\n const sessionResponse = await runSessionNewFlow(socket, options);\n if (sessionResponse.error) {\n console.error('\\nFull flow aborted due to session creation failure.');\n return;\n }\n\n // Extract session ID from response\n const sessionId = sessionResponse.result?.sessionId || options.sessionId || generateSessionId();\n\n // Step 4: Send prompt\n await runSessionPromptFlow(socket, options, sessionId);\n\n console.error('\\n========================================');\n console.error('Full ACP Flow Complete');\n console.error('========================================');\n}\n\n/**\n * Run a single flow based on options.\n * @param {Object} options - Parsed options\n */\nasync function runSingleFlow(options) {\n const socket = createConnection(options);\n\n socket.on('connect', async () => {\n console.error('Connected.');\n\n try {\n switch (options.flow) {\n case 'initialize':\n await runInitializeFlow(socket, options);\n break;\n case 'session-new':\n await runSessionNewFlow(socket, options);\n break;\n case 'session-prompt':\n const sessionId = options.sessionId || generateSessionId();\n if (!options.sessionId) {\n console.error(`Note: Using generated session ID: ${sessionId}`);\n }\n await runSessionPromptFlow(socket, options, sessionId);\n break;\n case 'full':\n await runFullFlow(socket, options);\n break;\n default:\n console.error(`Unknown flow: ${options.flow}`);\n console.error('Valid flows: initialize, session-new, session-prompt, full');\n }\n } catch (err) {\n console.error(`\\nError: ${err.message}`);\n } finally {\n socket.end();\n }\n });\n\n socket.on('error', (err) => {\n console.error(`Connection error: ${err.message}`);\n process.exit(1);\n });\n\n socket.on('close', () => {\n console.error('\\nConnection closed.');\n process.exit(0);\n });\n}\n\n/**\n * Run in interactive mode.\n * Reads JSON messages from stdin and adds agentId before sending.\n * @param {Object} options - Parsed options\n */\nfunction runInteractive(options) {\n const socket = createConnection(options);\n let buffer = '';\n\n const rl = readline.createInterface({\n input: process.stdin,\n output: process.stderr,\n terminal: false\n });\n\n socket.on('connect', () => {\n console.error('Connected in interactive mode.');\n console.error(`Agent ID: ${options.agentId} (will be added to all messages)`);\n console.error('\\nEnter JSON-RPC messages (one per line). agentId will be added automatically.');\n console.error('Example: {\"jsonrpc\":\"2.0\",\"id\":\"1\",\"method\":\"initialize\",\"params\":{}}');\n console.error('Press Ctrl+D to exit.\\n');\n });\n\n // Handle incoming responses\n socket.on('data', (data) => {\n buffer += data.toString();\n\n let newlineIndex;\n while ((newlineIndex = buffer.indexOf('\\n')) !== -1) {\n const line = buffer.slice(0, newlineIndex);\n buffer = buffer.slice(newlineIndex + 1);\n\n if (line.trim()) {\n try {\n const response = JSON.parse(line);\n console.log('\\n\u2190 Response:');\n console.log(JSON.stringify(response, null, 2));\n console.error('');\n } catch (err) {\n console.error(`Error parsing response: ${err.message}`);\n }\n }\n }\n });\n\n // Handle user input\n rl.on('line', (line) => {\n if (!line.trim()) return;\n\n try {\n // Parse the user's JSON\n const msg = JSON.parse(line);\n\n // Add agentId for routing\n msg.agentId = options.agentId;\n\n console.error(`\u2192 Sending (with agentId=${options.agentId}): ${JSON.stringify(msg)}`);\n socket.write(JSON.stringify(msg) + '\\n');\n } catch (err) {\n console.error(`Invalid JSON: ${err.message}`);\n console.error('Please enter a valid JSON object.');\n }\n });\n\n rl.on('close', () => {\n console.error('\\nClosing connection...');\n socket.end();\n });\n\n socket.on('error', (err) => {\n console.error(`Connection error: ${err.message}`);\n rl.close();\n process.exit(1);\n });\n\n socket.on('close', () => {\n console.error('Connection closed.');\n process.exit(0);\n });\n}\n\n/**\n * Main entry point.\n */\nfunction main() {\n const options = parseArgs();\n\n if (options.help) {\n showHelp();\n process.exit(0);\n }\n\n // Validate required options\n if (!options.tcp && !options.unix) {\n console.error('Error: Must specify --tcp or --unix connection');\n console.error('Use --help for usage information.');\n process.exit(1);\n }\n\n if (!options.agentId) {\n console.error('Error: Must specify --agent <id> for routing');\n console.error('Use --help for usage information.');\n process.exit(1);\n }\n\n // Determine mode\n if (options.interactive) {\n runInteractive(options);\n } else if (options.flow) {\n runSingleFlow(options);\n } else {\n // Default to full flow if no specific flow or interactive mode\n options.flow = 'full';\n runSingleFlow(options);\n }\n}\n\n// Handle uncaught exceptions\nprocess.on('uncaughtException', (err) => {\n console.error(`Uncaught exception: ${err.message}`);\n process.exit(1);\n});\n\n// Handle unhandled promise rejections\nprocess.on('unhandledRejection', (reason) => {\n console.error(`Unhandled rejection: ${reason}`);\n process.exit(1);\n});\n\nmain();\n"],
|
|
5
|
-
"mappings": "
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -1,4 +1,10 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
+
import { createRequire } from 'module';
|
|
3
|
+
import { fileURLToPath } from 'url';
|
|
4
|
+
import { dirname } from 'path';
|
|
5
|
+
const require = createRequire(import.meta.url);
|
|
6
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
7
|
+
const __dirname = dirname(__filename);
|
|
2
8
|
var __create=Object.create;var __defProp=Object.defineProperty;var __getOwnPropDesc=Object.getOwnPropertyDescriptor;var __getOwnPropNames=Object.getOwnPropertyNames;var __getProtoOf=Object.getPrototypeOf;var __hasOwnProp=Object.prototype.hasOwnProperty;var __require=(x=>typeof require!=="undefined"?require:typeof Proxy!=="undefined"?new Proxy(x,{get:(a,b)=>(typeof require!=="undefined"?require:a)[b]}):x)(function(x){if(typeof require!=="undefined")return require.apply(this,arguments);throw Error('Dynamic require of "'+x+'" is not supported')});var __commonJS=(cb,mod)=>function __require2(){return mod||(0,cb[__getOwnPropNames(cb)[0]])((mod={exports:{}}).exports,mod),mod.exports};var __export=(target,all)=>{for(var name in all)__defProp(target,name,{get:all[name],enumerable:true})};var __copyProps=(to,from,except,desc)=>{if(from&&typeof from==="object"||typeof from==="function"){for(let key of __getOwnPropNames(from))if(!__hasOwnProp.call(to,key)&&key!==except)__defProp(to,key,{get:()=>from[key],enumerable:!(desc=__getOwnPropDesc(from,key))||desc.enumerable})}return to};var __toESM=(mod,isNodeMode,target)=>(target=mod!=null?__create(__getProtoOf(mod)):{},__copyProps(isNodeMode||!mod||!mod.__esModule?__defProp(target,"default",{value:mod,enumerable:true}):target,mod));var require_code=__commonJS({"node_modules/ajv/dist/compile/codegen/code.js"(exports){"use strict";Object.defineProperty(exports,"__esModule",{value:true});exports.regexpCode=exports.getEsmExportName=exports.getProperty=exports.safeStringify=exports.stringify=exports.strConcat=exports.addCodeArg=exports.str=exports._=exports.nil=exports._Code=exports.Name=exports.IDENTIFIER=exports._CodeOrName=void 0;var _CodeOrName=class{};exports._CodeOrName=_CodeOrName;exports.IDENTIFIER=/^[a-z$_][a-z$_0-9]*$/i;var Name=class extends _CodeOrName{constructor(s){super();if(!exports.IDENTIFIER.test(s))throw new Error("CodeGen: name must be a valid identifier");this.str=s}toString(){return this.str}emptyStr(){return false}get names(){return{[this.str]:1}}};exports.Name=Name;var _Code=class extends _CodeOrName{constructor(code){super();this._items=typeof code==="string"?[code]:code}toString(){return this.str}emptyStr(){if(this._items.length>1)return false;const item=this._items[0];return item===""||item==='""'}get str(){var _a2;return(_a2=this._str)!==null&&_a2!==void 0?_a2:this._str=this._items.reduce((s,c)=>`${s}${c}`,"")}get names(){var _a2;return(_a2=this._names)!==null&&_a2!==void 0?_a2:this._names=this._items.reduce((names,c)=>{if(c instanceof Name)names[c.str]=(names[c.str]||0)+1;return names},{})}};exports._Code=_Code;exports.nil=new _Code("");function _(strs,...args){const code=[strs[0]];let i=0;while(i<args.length){addCodeArg(code,args[i]);code.push(strs[++i])}return new _Code(code)}exports._=_;var plus=new _Code("+");function str(strs,...args){const expr=[safeStringify(strs[0])];let i=0;while(i<args.length){expr.push(plus);addCodeArg(expr,args[i]);expr.push(plus,safeStringify(strs[++i]))}optimize(expr);return new _Code(expr)}exports.str=str;function addCodeArg(code,arg){if(arg instanceof _Code)code.push(...arg._items);else if(arg instanceof Name)code.push(arg);else code.push(interpolate(arg))}exports.addCodeArg=addCodeArg;function optimize(expr){let i=1;while(i<expr.length-1){if(expr[i]===plus){const res=mergeExprItems(expr[i-1],expr[i+1]);if(res!==void 0){expr.splice(i-1,3,res);continue}expr[i++]="+"}i++}}function mergeExprItems(a,b){if(b==='""')return a;if(a==='""')return b;if(typeof a=="string"){if(b instanceof Name||a[a.length-1]!=='"')return;if(typeof b!="string")return`${a.slice(0,-1)}${b}"`;if(b[0]==='"')return a.slice(0,-1)+b.slice(1);return}if(typeof b=="string"&&b[0]==='"'&&!(a instanceof Name))return`"${a}${b.slice(1)}`;return}function strConcat(c1,c2){return c2.emptyStr()?c1:c1.emptyStr()?c2:str`${c1}${c2}`}exports.strConcat=strConcat;function interpolate(x){return typeof x=="number"||typeof x=="boolean"||x===null?x:safeStringify(Array.isArray(x)?x.join(","):x)}function stringify(x){return new _Code(safeStringify(x))}exports.stringify=stringify;function safeStringify(x){return JSON.stringify(x).replace(/\u2028/g,"\\u2028").replace(/\u2029/g,"\\u2029")}exports.safeStringify=safeStringify;function getProperty(key){return typeof key=="string"&&exports.IDENTIFIER.test(key)?new _Code(`.${key}`):_`[${key}]`}exports.getProperty=getProperty;function getEsmExportName(key){if(typeof key=="string"&&exports.IDENTIFIER.test(key)){return new _Code(`${key}`)}throw new Error(`CodeGen: invalid export name: ${key}, use explicit $id name mapping`)}exports.getEsmExportName=getEsmExportName;function regexpCode(rx){return new _Code(rx.toString())}exports.regexpCode=regexpCode}});var require_scope=__commonJS({"node_modules/ajv/dist/compile/codegen/scope.js"(exports){"use strict";Object.defineProperty(exports,"__esModule",{value:true});exports.ValueScope=exports.ValueScopeName=exports.Scope=exports.varKinds=exports.UsedValueState=void 0;var code_1=require_code();var ValueError=class extends Error{constructor(name){super(`CodeGen: "code" for ${name} not defined`);this.value=name.value}};var UsedValueState;(function(UsedValueState2){UsedValueState2[UsedValueState2["Started"]=0]="Started";UsedValueState2[UsedValueState2["Completed"]=1]="Completed"})(UsedValueState||(exports.UsedValueState=UsedValueState={}));exports.varKinds={const:new code_1.Name("const"),let:new code_1.Name("let"),var:new code_1.Name("var")};var Scope=class{constructor({prefixes,parent}={}){this._names={};this._prefixes=prefixes;this._parent=parent}toName(nameOrPrefix){return nameOrPrefix instanceof code_1.Name?nameOrPrefix:this.name(nameOrPrefix)}name(prefix){return new code_1.Name(this._newName(prefix))}_newName(prefix){const ng=this._names[prefix]||this._nameGroup(prefix);return`${prefix}${ng.index++}`}_nameGroup(prefix){var _a2,_b;if(((_b=(_a2=this._parent)===null||_a2===void 0?void 0:_a2._prefixes)===null||_b===void 0?void 0:_b.has(prefix))||this._prefixes&&!this._prefixes.has(prefix)){throw new Error(`CodeGen: prefix "${prefix}" is not allowed in this scope`)}return this._names[prefix]={prefix,index:0}}};exports.Scope=Scope;var ValueScopeName=class extends code_1.Name{constructor(prefix,nameStr){super(nameStr);this.prefix=prefix}setValue(value,{property,itemIndex}){this.value=value;this.scopePath=(0,code_1._)`.${new code_1.Name(property)}[${itemIndex}]`}};exports.ValueScopeName=ValueScopeName;var line=(0,code_1._)`\n`;var ValueScope=class extends Scope{constructor(opts){super(opts);this._values={};this._scope=opts.scope;this.opts={...opts,_n:opts.lines?line:code_1.nil}}get(){return this._scope}name(prefix){return new ValueScopeName(prefix,this._newName(prefix))}value(nameOrPrefix,value){var _a2;if(value.ref===void 0)throw new Error("CodeGen: ref must be passed in value");const name=this.toName(nameOrPrefix);const{prefix}=name;const valueKey=(_a2=value.key)!==null&&_a2!==void 0?_a2:value.ref;let vs=this._values[prefix];if(vs){const _name=vs.get(valueKey);if(_name)return _name}else{vs=this._values[prefix]=new Map}vs.set(valueKey,name);const s=this._scope[prefix]||(this._scope[prefix]=[]);const itemIndex=s.length;s[itemIndex]=value.ref;name.setValue(value,{property:prefix,itemIndex});return name}getValue(prefix,keyOrRef){const vs=this._values[prefix];if(!vs)return;return vs.get(keyOrRef)}scopeRefs(scopeName,values=this._values){return this._reduceValues(values,name=>{if(name.scopePath===void 0)throw new Error(`CodeGen: name "${name}" has no value`);return(0,code_1._)`${scopeName}${name.scopePath}`})}scopeCode(values=this._values,usedValues,getCode){return this._reduceValues(values,name=>{if(name.value===void 0)throw new Error(`CodeGen: name "${name}" has no value`);return name.value.code},usedValues,getCode)}_reduceValues(values,valueCode,usedValues={},getCode){let code=code_1.nil;for(const prefix in values){const vs=values[prefix];if(!vs)continue;const nameSet=usedValues[prefix]=usedValues[prefix]||new Map;vs.forEach(name=>{if(nameSet.has(name))return;nameSet.set(name,UsedValueState.Started);let c=valueCode(name);if(c){const def=this.opts.es5?exports.varKinds.var:exports.varKinds.const;code=(0,code_1._)`${code}${def} ${name} = ${c};${this.opts._n}`}else if(c=getCode===null||getCode===void 0?void 0:getCode(name)){code=(0,code_1._)`${code}${c}${this.opts._n}`}else{throw new ValueError(name)}nameSet.set(name,UsedValueState.Completed)})}return code}};exports.ValueScope=ValueScope}});var require_codegen=__commonJS({"node_modules/ajv/dist/compile/codegen/index.js"(exports){"use strict";Object.defineProperty(exports,"__esModule",{value:true});exports.or=exports.and=exports.not=exports.CodeGen=exports.operators=exports.varKinds=exports.ValueScopeName=exports.ValueScope=exports.Scope=exports.Name=exports.regexpCode=exports.stringify=exports.getProperty=exports.nil=exports.strConcat=exports.str=exports._=void 0;var code_1=require_code();var scope_1=require_scope();var code_2=require_code();Object.defineProperty(exports,"_",{enumerable:true,get:function(){return code_2._}});Object.defineProperty(exports,"str",{enumerable:true,get:function(){return code_2.str}});Object.defineProperty(exports,"strConcat",{enumerable:true,get:function(){return code_2.strConcat}});Object.defineProperty(exports,"nil",{enumerable:true,get:function(){return code_2.nil}});Object.defineProperty(exports,"getProperty",{enumerable:true,get:function(){return code_2.getProperty}});Object.defineProperty(exports,"stringify",{enumerable:true,get:function(){return code_2.stringify}});Object.defineProperty(exports,"regexpCode",{enumerable:true,get:function(){return code_2.regexpCode}});Object.defineProperty(exports,"Name",{enumerable:true,get:function(){return code_2.Name}});var scope_2=require_scope();Object.defineProperty(exports,"Scope",{enumerable:true,get:function(){return scope_2.Scope}});Object.defineProperty(exports,"ValueScope",{enumerable:true,get:function(){return scope_2.ValueScope}});Object.defineProperty(exports,"ValueScopeName",{enumerable:true,get:function(){return scope_2.ValueScopeName}});Object.defineProperty(exports,"varKinds",{enumerable:true,get:function(){return scope_2.varKinds}});exports.operators={GT:new code_1._Code(">"),GTE:new code_1._Code(">="),LT:new code_1._Code("<"),LTE:new code_1._Code("<="),EQ:new code_1._Code("==="),NEQ:new code_1._Code("!=="),NOT:new code_1._Code("!"),OR:new code_1._Code("||"),AND:new code_1._Code("&&"),ADD:new code_1._Code("+")};var Node=class{optimizeNodes(){return this}optimizeNames(_names,_constants){return this}};var Def=class extends Node{constructor(varKind,name,rhs){super();this.varKind=varKind;this.name=name;this.rhs=rhs}render({es5,_n}){const varKind=es5?scope_1.varKinds.var:this.varKind;const rhs=this.rhs===void 0?"":` = ${this.rhs}`;return`${varKind} ${this.name}${rhs};`+_n}optimizeNames(names,constants){if(!names[this.name.str])return;if(this.rhs)this.rhs=optimizeExpr(this.rhs,names,constants);return this}get names(){return this.rhs instanceof code_1._CodeOrName?this.rhs.names:{}}};var Assign=class extends Node{constructor(lhs,rhs,sideEffects){super();this.lhs=lhs;this.rhs=rhs;this.sideEffects=sideEffects}render({_n}){return`${this.lhs} = ${this.rhs};`+_n}optimizeNames(names,constants){if(this.lhs instanceof code_1.Name&&!names[this.lhs.str]&&!this.sideEffects)return;this.rhs=optimizeExpr(this.rhs,names,constants);return this}get names(){const names=this.lhs instanceof code_1.Name?{}:{...this.lhs.names};return addExprNames(names,this.rhs)}};var AssignOp=class extends Assign{constructor(lhs,op,rhs,sideEffects){super(lhs,rhs,sideEffects);this.op=op}render({_n}){return`${this.lhs} ${this.op}= ${this.rhs};`+_n}};var Label=class extends Node{constructor(label){super();this.label=label;this.names={}}render({_n}){return`${this.label}:`+_n}};var Break=class extends Node{constructor(label){super();this.label=label;this.names={}}render({_n}){const label=this.label?` ${this.label}`:"";return`break${label};`+_n}};var Throw=class extends Node{constructor(error48){super();this.error=error48}render({_n}){return`throw ${this.error};`+_n}get names(){return this.error.names}};var AnyCode=class extends Node{constructor(code){super();this.code=code}render({_n}){return`${this.code};`+_n}optimizeNodes(){return`${this.code}`?this:void 0}optimizeNames(names,constants){this.code=optimizeExpr(this.code,names,constants);return this}get names(){return this.code instanceof code_1._CodeOrName?this.code.names:{}}};var ParentNode=class extends Node{constructor(nodes=[]){super();this.nodes=nodes}render(opts){return this.nodes.reduce((code,n)=>code+n.render(opts),"")}optimizeNodes(){const{nodes}=this;let i=nodes.length;while(i--){const n=nodes[i].optimizeNodes();if(Array.isArray(n))nodes.splice(i,1,...n);else if(n)nodes[i]=n;else nodes.splice(i,1)}return nodes.length>0?this:void 0}optimizeNames(names,constants){const{nodes}=this;let i=nodes.length;while(i--){const n=nodes[i];if(n.optimizeNames(names,constants))continue;subtractNames(names,n.names);nodes.splice(i,1)}return nodes.length>0?this:void 0}get names(){return this.nodes.reduce((names,n)=>addNames(names,n.names),{})}};var BlockNode=class extends ParentNode{render(opts){return"{"+opts._n+super.render(opts)+"}"+opts._n}};var Root=class extends ParentNode{};var Else=class extends BlockNode{};Else.kind="else";var If=class _If extends BlockNode{constructor(condition,nodes){super(nodes);this.condition=condition}render(opts){let code=`if(${this.condition})`+super.render(opts);if(this.else)code+="else "+this.else.render(opts);return code}optimizeNodes(){super.optimizeNodes();const cond=this.condition;if(cond===true)return this.nodes;let e=this.else;if(e){const ns=e.optimizeNodes();e=this.else=Array.isArray(ns)?new Else(ns):ns}if(e){if(cond===false)return e instanceof _If?e:e.nodes;if(this.nodes.length)return this;return new _If(not(cond),e instanceof _If?[e]:e.nodes)}if(cond===false||!this.nodes.length)return void 0;return this}optimizeNames(names,constants){var _a2;this.else=(_a2=this.else)===null||_a2===void 0?void 0:_a2.optimizeNames(names,constants);if(!(super.optimizeNames(names,constants)||this.else))return;this.condition=optimizeExpr(this.condition,names,constants);return this}get names(){const names=super.names;addExprNames(names,this.condition);if(this.else)addNames(names,this.else.names);return names}};If.kind="if";var For=class extends BlockNode{};For.kind="for";var ForLoop=class extends For{constructor(iteration){super();this.iteration=iteration}render(opts){return`for(${this.iteration})`+super.render(opts)}optimizeNames(names,constants){if(!super.optimizeNames(names,constants))return;this.iteration=optimizeExpr(this.iteration,names,constants);return this}get names(){return addNames(super.names,this.iteration.names)}};var ForRange=class extends For{constructor(varKind,name,from,to){super();this.varKind=varKind;this.name=name;this.from=from;this.to=to}render(opts){const varKind=opts.es5?scope_1.varKinds.var:this.varKind;const{name,from,to}=this;return`for(${varKind} ${name}=${from}; ${name}<${to}; ${name}++)`+super.render(opts)}get names(){const names=addExprNames(super.names,this.from);return addExprNames(names,this.to)}};var ForIter=class extends For{constructor(loop,varKind,name,iterable){super();this.loop=loop;this.varKind=varKind;this.name=name;this.iterable=iterable}render(opts){return`for(${this.varKind} ${this.name} ${this.loop} ${this.iterable})`+super.render(opts)}optimizeNames(names,constants){if(!super.optimizeNames(names,constants))return;this.iterable=optimizeExpr(this.iterable,names,constants);return this}get names(){return addNames(super.names,this.iterable.names)}};var Func=class extends BlockNode{constructor(name,args,async){super();this.name=name;this.args=args;this.async=async}render(opts){const _async=this.async?"async ":"";return`${_async}function ${this.name}(${this.args})`+super.render(opts)}};Func.kind="func";var Return=class extends ParentNode{render(opts){return"return "+super.render(opts)}};Return.kind="return";var Try=class extends BlockNode{render(opts){let code="try"+super.render(opts);if(this.catch)code+=this.catch.render(opts);if(this.finally)code+=this.finally.render(opts);return code}optimizeNodes(){var _a2,_b;super.optimizeNodes();(_a2=this.catch)===null||_a2===void 0?void 0:_a2.optimizeNodes();(_b=this.finally)===null||_b===void 0?void 0:_b.optimizeNodes();return this}optimizeNames(names,constants){var _a2,_b;super.optimizeNames(names,constants);(_a2=this.catch)===null||_a2===void 0?void 0:_a2.optimizeNames(names,constants);(_b=this.finally)===null||_b===void 0?void 0:_b.optimizeNames(names,constants);return this}get names(){const names=super.names;if(this.catch)addNames(names,this.catch.names);if(this.finally)addNames(names,this.finally.names);return names}};var Catch=class extends BlockNode{constructor(error48){super();this.error=error48}render(opts){return`catch(${this.error})`+super.render(opts)}};Catch.kind="catch";var Finally=class extends BlockNode{render(opts){return"finally"+super.render(opts)}};Finally.kind="finally";var CodeGen=class{constructor(extScope,opts={}){this._values={};this._blockStarts=[];this._constants={};this.opts={...opts,_n:opts.lines?"\n":""};this._extScope=extScope;this._scope=new scope_1.Scope({parent:extScope});this._nodes=[new Root]}toString(){return this._root.render(this.opts)}name(prefix){return this._scope.name(prefix)}scopeName(prefix){return this._extScope.name(prefix)}scopeValue(prefixOrName,value){const name=this._extScope.value(prefixOrName,value);const vs=this._values[name.prefix]||(this._values[name.prefix]=new Set);vs.add(name);return name}getScopeValue(prefix,keyOrRef){return this._extScope.getValue(prefix,keyOrRef)}scopeRefs(scopeName){return this._extScope.scopeRefs(scopeName,this._values)}scopeCode(){return this._extScope.scopeCode(this._values)}_def(varKind,nameOrPrefix,rhs,constant){const name=this._scope.toName(nameOrPrefix);if(rhs!==void 0&&constant)this._constants[name.str]=rhs;this._leafNode(new Def(varKind,name,rhs));return name}const(nameOrPrefix,rhs,_constant){return this._def(scope_1.varKinds.const,nameOrPrefix,rhs,_constant)}let(nameOrPrefix,rhs,_constant){return this._def(scope_1.varKinds.let,nameOrPrefix,rhs,_constant)}var(nameOrPrefix,rhs,_constant){return this._def(scope_1.varKinds.var,nameOrPrefix,rhs,_constant)}assign(lhs,rhs,sideEffects){return this._leafNode(new Assign(lhs,rhs,sideEffects))}add(lhs,rhs){return this._leafNode(new AssignOp(lhs,exports.operators.ADD,rhs))}code(c){if(typeof c=="function")c();else if(c!==code_1.nil)this._leafNode(new AnyCode(c));return this}object(...keyValues){const code=["{"];for(const[key,value]of keyValues){if(code.length>1)code.push(",");code.push(key);if(key!==value||this.opts.es5){code.push(":");(0,code_1.addCodeArg)(code,value)}}code.push("}");return new code_1._Code(code)}if(condition,thenBody,elseBody){this._blockNode(new If(condition));if(thenBody&&elseBody){this.code(thenBody).else().code(elseBody).endIf()}else if(thenBody){this.code(thenBody).endIf()}else if(elseBody){throw new Error('CodeGen: "else" body without "then" body')}return this}elseIf(condition){return this._elseNode(new If(condition))}else(){return this._elseNode(new Else)}endIf(){return this._endBlockNode(If,Else)}_for(node,forBody){this._blockNode(node);if(forBody)this.code(forBody).endFor();return this}for(iteration,forBody){return this._for(new ForLoop(iteration),forBody)}forRange(nameOrPrefix,from,to,forBody,varKind=this.opts.es5?scope_1.varKinds.var:scope_1.varKinds.let){const name=this._scope.toName(nameOrPrefix);return this._for(new ForRange(varKind,name,from,to),()=>forBody(name))}forOf(nameOrPrefix,iterable,forBody,varKind=scope_1.varKinds.const){const name=this._scope.toName(nameOrPrefix);if(this.opts.es5){const arr=iterable instanceof code_1.Name?iterable:this.var("_arr",iterable);return this.forRange("_i",0,(0,code_1._)`${arr}.length`,i=>{this.var(name,(0,code_1._)`${arr}[${i}]`);forBody(name)})}return this._for(new ForIter("of",varKind,name,iterable),()=>forBody(name))}forIn(nameOrPrefix,obj,forBody,varKind=this.opts.es5?scope_1.varKinds.var:scope_1.varKinds.const){if(this.opts.ownProperties){return this.forOf(nameOrPrefix,(0,code_1._)`Object.keys(${obj})`,forBody)}const name=this._scope.toName(nameOrPrefix);return this._for(new ForIter("in",varKind,name,obj),()=>forBody(name))}endFor(){return this._endBlockNode(For)}label(label){return this._leafNode(new Label(label))}break(label){return this._leafNode(new Break(label))}return(value){const node=new Return;this._blockNode(node);this.code(value);if(node.nodes.length!==1)throw new Error('CodeGen: "return" should have one node');return this._endBlockNode(Return)}try(tryBody,catchCode,finallyCode){if(!catchCode&&!finallyCode)throw new Error('CodeGen: "try" without "catch" and "finally"');const node=new Try;this._blockNode(node);this.code(tryBody);if(catchCode){const error48=this.name("e");this._currNode=node.catch=new Catch(error48);catchCode(error48)}if(finallyCode){this._currNode=node.finally=new Finally;this.code(finallyCode)}return this._endBlockNode(Catch,Finally)}throw(error48){return this._leafNode(new Throw(error48))}block(body,nodeCount){this._blockStarts.push(this._nodes.length);if(body)this.code(body).endBlock(nodeCount);return this}endBlock(nodeCount){const len=this._blockStarts.pop();if(len===void 0)throw new Error("CodeGen: not in self-balancing block");const toClose=this._nodes.length-len;if(toClose<0||nodeCount!==void 0&&toClose!==nodeCount){throw new Error(`CodeGen: wrong number of nodes: ${toClose} vs ${nodeCount} expected`)}this._nodes.length=len;return this}func(name,args=code_1.nil,async,funcBody){this._blockNode(new Func(name,args,async));if(funcBody)this.code(funcBody).endFunc();return this}endFunc(){return this._endBlockNode(Func)}optimize(n=1){while(n-- >0){this._root.optimizeNodes();this._root.optimizeNames(this._root.names,this._constants)}}_leafNode(node){this._currNode.nodes.push(node);return this}_blockNode(node){this._currNode.nodes.push(node);this._nodes.push(node)}_endBlockNode(N1,N2){const n=this._currNode;if(n instanceof N1||N2&&n instanceof N2){this._nodes.pop();return this}throw new Error(`CodeGen: not in block "${N2?`${N1.kind}/${N2.kind}`:N1.kind}"`)}_elseNode(node){const n=this._currNode;if(!(n instanceof If)){throw new Error('CodeGen: "else" without "if"')}this._currNode=n.else=node;return this}get _root(){return this._nodes[0]}get _currNode(){const ns=this._nodes;return ns[ns.length-1]}set _currNode(node){const ns=this._nodes;ns[ns.length-1]=node}};exports.CodeGen=CodeGen;function addNames(names,from){for(const n in from)names[n]=(names[n]||0)+(from[n]||0);return names}function addExprNames(names,from){return from instanceof code_1._CodeOrName?addNames(names,from.names):names}function optimizeExpr(expr,names,constants){if(expr instanceof code_1.Name)return replaceName(expr);if(!canOptimize(expr))return expr;return new code_1._Code(expr._items.reduce((items,c)=>{if(c instanceof code_1.Name)c=replaceName(c);if(c instanceof code_1._Code)items.push(...c._items);else items.push(c);return items},[]));function replaceName(n){const c=constants[n.str];if(c===void 0||names[n.str]!==1)return n;delete names[n.str];return c}function canOptimize(e){return e instanceof code_1._Code&&e._items.some(c=>c instanceof code_1.Name&&names[c.str]===1&&constants[c.str]!==void 0)}}function subtractNames(names,from){for(const n in from)names[n]=(names[n]||0)-(from[n]||0)}function not(x){return typeof x=="boolean"||typeof x=="number"||x===null?!x:(0,code_1._)`!${par(x)}`}exports.not=not;var andCode=mappend(exports.operators.AND);function and(...args){return args.reduce(andCode)}exports.and=and;var orCode=mappend(exports.operators.OR);function or(...args){return args.reduce(orCode)}exports.or=or;function mappend(op){return(x,y)=>x===code_1.nil?y:y===code_1.nil?x:(0,code_1._)`${par(x)} ${op} ${par(y)}`}function par(x){return x instanceof code_1.Name?x:(0,code_1._)`(${x})`}}});var require_util=__commonJS({"node_modules/ajv/dist/compile/util.js"(exports){"use strict";Object.defineProperty(exports,"__esModule",{value:true});exports.checkStrictMode=exports.getErrorPath=exports.Type=exports.useFunc=exports.setEvaluated=exports.evaluatedPropsToName=exports.mergeEvaluated=exports.eachItem=exports.unescapeJsonPointer=exports.escapeJsonPointer=exports.escapeFragment=exports.unescapeFragment=exports.schemaRefOrVal=exports.schemaHasRulesButRef=exports.schemaHasRules=exports.checkUnknownRules=exports.alwaysValidSchema=exports.toHash=void 0;var codegen_1=require_codegen();var code_1=require_code();function toHash(arr){const hash2={};for(const item of arr)hash2[item]=true;return hash2}exports.toHash=toHash;function alwaysValidSchema(it,schema){if(typeof schema=="boolean")return schema;if(Object.keys(schema).length===0)return true;checkUnknownRules(it,schema);return!schemaHasRules(schema,it.self.RULES.all)}exports.alwaysValidSchema=alwaysValidSchema;function checkUnknownRules(it,schema=it.schema){const{opts,self}=it;if(!opts.strictSchema)return;if(typeof schema==="boolean")return;const rules=self.RULES.keywords;for(const key in schema){if(!rules[key])checkStrictMode(it,`unknown keyword: "${key}"`)}}exports.checkUnknownRules=checkUnknownRules;function schemaHasRules(schema,rules){if(typeof schema=="boolean")return!schema;for(const key in schema)if(rules[key])return true;return false}exports.schemaHasRules=schemaHasRules;function schemaHasRulesButRef(schema,RULES){if(typeof schema=="boolean")return!schema;for(const key in schema)if(key!=="$ref"&&RULES.all[key])return true;return false}exports.schemaHasRulesButRef=schemaHasRulesButRef;function schemaRefOrVal({topSchemaRef,schemaPath},schema,keyword,$data){if(!$data){if(typeof schema=="number"||typeof schema=="boolean")return schema;if(typeof schema=="string")return(0,codegen_1._)`${schema}`}return(0,codegen_1._)`${topSchemaRef}${schemaPath}${(0,codegen_1.getProperty)(keyword)}`}exports.schemaRefOrVal=schemaRefOrVal;function unescapeFragment(str){return unescapeJsonPointer(decodeURIComponent(str))}exports.unescapeFragment=unescapeFragment;function escapeFragment(str){return encodeURIComponent(escapeJsonPointer(str))}exports.escapeFragment=escapeFragment;function escapeJsonPointer(str){if(typeof str=="number")return`${str}`;return str.replace(/~/g,"~0").replace(/\//g,"~1")}exports.escapeJsonPointer=escapeJsonPointer;function unescapeJsonPointer(str){return str.replace(/~1/g,"/").replace(/~0/g,"~")}exports.unescapeJsonPointer=unescapeJsonPointer;function eachItem(xs,f){if(Array.isArray(xs)){for(const x of xs)f(x)}else{f(xs)}}exports.eachItem=eachItem;function makeMergeEvaluated({mergeNames,mergeToName,mergeValues:mergeValues3,resultToName}){return(gen,from,to,toName)=>{const res=to===void 0?from:to instanceof codegen_1.Name?(from instanceof codegen_1.Name?mergeNames(gen,from,to):mergeToName(gen,from,to),to):from instanceof codegen_1.Name?(mergeToName(gen,to,from),from):mergeValues3(from,to);return toName===codegen_1.Name&&!(res instanceof codegen_1.Name)?resultToName(gen,res):res}}exports.mergeEvaluated={props:makeMergeEvaluated({mergeNames:(gen,from,to)=>gen.if((0,codegen_1._)`${to} !== true && ${from} !== undefined`,()=>{gen.if((0,codegen_1._)`${from} === true`,()=>gen.assign(to,true),()=>gen.assign(to,(0,codegen_1._)`${to} || {}`).code((0,codegen_1._)`Object.assign(${to}, ${from})`))}),mergeToName:(gen,from,to)=>gen.if((0,codegen_1._)`${to} !== true`,()=>{if(from===true){gen.assign(to,true)}else{gen.assign(to,(0,codegen_1._)`${to} || {}`);setEvaluated(gen,to,from)}}),mergeValues:(from,to)=>from===true?true:{...from,...to},resultToName:evaluatedPropsToName}),items:makeMergeEvaluated({mergeNames:(gen,from,to)=>gen.if((0,codegen_1._)`${to} !== true && ${from} !== undefined`,()=>gen.assign(to,(0,codegen_1._)`${from} === true ? true : ${to} > ${from} ? ${to} : ${from}`)),mergeToName:(gen,from,to)=>gen.if((0,codegen_1._)`${to} !== true`,()=>gen.assign(to,from===true?true:(0,codegen_1._)`${to} > ${from} ? ${to} : ${from}`)),mergeValues:(from,to)=>from===true?true:Math.max(from,to),resultToName:(gen,items)=>gen.var("items",items)})};function evaluatedPropsToName(gen,ps){if(ps===true)return gen.var("props",true);const props=gen.var("props",(0,codegen_1._)`{}`);if(ps!==void 0)setEvaluated(gen,props,ps);return props}exports.evaluatedPropsToName=evaluatedPropsToName;function setEvaluated(gen,props,ps){Object.keys(ps).forEach(p=>gen.assign((0,codegen_1._)`${props}${(0,codegen_1.getProperty)(p)}`,true))}exports.setEvaluated=setEvaluated;var snippets={};function useFunc(gen,f){return gen.scopeValue("func",{ref:f,code:snippets[f.code]||(snippets[f.code]=new code_1._Code(f.code))})}exports.useFunc=useFunc;var Type;(function(Type2){Type2[Type2["Num"]=0]="Num";Type2[Type2["Str"]=1]="Str"})(Type||(exports.Type=Type={}));function getErrorPath(dataProp,dataPropType,jsPropertySyntax){if(dataProp instanceof codegen_1.Name){const isNumber=dataPropType===Type.Num;return jsPropertySyntax?isNumber?(0,codegen_1._)`"[" + ${dataProp} + "]"`:(0,codegen_1._)`"['" + ${dataProp} + "']"`:isNumber?(0,codegen_1._)`"/" + ${dataProp}`:(0,codegen_1._)`"/" + ${dataProp}.replace(/~/g, "~0").replace(/\\//g, "~1")`}return jsPropertySyntax?(0,codegen_1.getProperty)(dataProp).toString():"/"+escapeJsonPointer(dataProp)}exports.getErrorPath=getErrorPath;function checkStrictMode(it,msg,mode=it.opts.strictSchema){if(!mode)return;msg=`strict mode: ${msg}`;if(mode===true)throw new Error(msg);it.self.logger.warn(msg)}exports.checkStrictMode=checkStrictMode}});var require_names=__commonJS({"node_modules/ajv/dist/compile/names.js"(exports){"use strict";Object.defineProperty(exports,"__esModule",{value:true});var codegen_1=require_codegen();var names={data:new codegen_1.Name("data"),valCxt:new codegen_1.Name("valCxt"),instancePath:new codegen_1.Name("instancePath"),parentData:new codegen_1.Name("parentData"),parentDataProperty:new codegen_1.Name("parentDataProperty"),rootData:new codegen_1.Name("rootData"),dynamicAnchors:new codegen_1.Name("dynamicAnchors"),vErrors:new codegen_1.Name("vErrors"),errors:new codegen_1.Name("errors"),this:new codegen_1.Name("this"),self:new codegen_1.Name("self"),scope:new codegen_1.Name("scope"),json:new codegen_1.Name("json"),jsonPos:new codegen_1.Name("jsonPos"),jsonLen:new codegen_1.Name("jsonLen"),jsonPart:new codegen_1.Name("jsonPart")};exports.default=names}});var require_errors=__commonJS({"node_modules/ajv/dist/compile/errors.js"(exports){"use strict";Object.defineProperty(exports,"__esModule",{value:true});exports.extendErrors=exports.resetErrorsCount=exports.reportExtraError=exports.reportError=exports.keyword$DataError=exports.keywordError=void 0;var codegen_1=require_codegen();var util_1=require_util();var names_1=require_names();exports.keywordError={message:({keyword})=>(0,codegen_1.str)`must pass "${keyword}" keyword validation`};exports.keyword$DataError={message:({keyword,schemaType})=>schemaType?(0,codegen_1.str)`"${keyword}" keyword must be ${schemaType} ($data)`:(0,codegen_1.str)`"${keyword}" keyword is invalid ($data)`};function reportError(cxt,error48=exports.keywordError,errorPaths,overrideAllErrors){const{it}=cxt;const{gen,compositeRule,allErrors}=it;const errObj=errorObjectCode(cxt,error48,errorPaths);if(overrideAllErrors!==null&&overrideAllErrors!==void 0?overrideAllErrors:compositeRule||allErrors){addError(gen,errObj)}else{returnErrors(it,(0,codegen_1._)`[${errObj}]`)}}exports.reportError=reportError;function reportExtraError(cxt,error48=exports.keywordError,errorPaths){const{it}=cxt;const{gen,compositeRule,allErrors}=it;const errObj=errorObjectCode(cxt,error48,errorPaths);addError(gen,errObj);if(!(compositeRule||allErrors)){returnErrors(it,names_1.default.vErrors)}}exports.reportExtraError=reportExtraError;function resetErrorsCount(gen,errsCount){gen.assign(names_1.default.errors,errsCount);gen.if((0,codegen_1._)`${names_1.default.vErrors} !== null`,()=>gen.if(errsCount,()=>gen.assign((0,codegen_1._)`${names_1.default.vErrors}.length`,errsCount),()=>gen.assign(names_1.default.vErrors,null)))}exports.resetErrorsCount=resetErrorsCount;function extendErrors({gen,keyword,schemaValue,data,errsCount,it}){if(errsCount===void 0)throw new Error("ajv implementation error");const err=gen.name("err");gen.forRange("i",errsCount,names_1.default.errors,i=>{gen.const(err,(0,codegen_1._)`${names_1.default.vErrors}[${i}]`);gen.if((0,codegen_1._)`${err}.instancePath === undefined`,()=>gen.assign((0,codegen_1._)`${err}.instancePath`,(0,codegen_1.strConcat)(names_1.default.instancePath,it.errorPath)));gen.assign((0,codegen_1._)`${err}.schemaPath`,(0,codegen_1.str)`${it.errSchemaPath}/${keyword}`);if(it.opts.verbose){gen.assign((0,codegen_1._)`${err}.schema`,schemaValue);gen.assign((0,codegen_1._)`${err}.data`,data)}})}exports.extendErrors=extendErrors;function addError(gen,errObj){const err=gen.const("err",errObj);gen.if((0,codegen_1._)`${names_1.default.vErrors} === null`,()=>gen.assign(names_1.default.vErrors,(0,codegen_1._)`[${err}]`),(0,codegen_1._)`${names_1.default.vErrors}.push(${err})`);gen.code((0,codegen_1._)`${names_1.default.errors}++`)}function returnErrors(it,errs){const{gen,validateName,schemaEnv}=it;if(schemaEnv.$async){gen.throw((0,codegen_1._)`new ${it.ValidationError}(${errs})`)}else{gen.assign((0,codegen_1._)`${validateName}.errors`,errs);gen.return(false)}}var E={keyword:new codegen_1.Name("keyword"),schemaPath:new codegen_1.Name("schemaPath"),params:new codegen_1.Name("params"),propertyName:new codegen_1.Name("propertyName"),message:new codegen_1.Name("message"),schema:new codegen_1.Name("schema"),parentSchema:new codegen_1.Name("parentSchema")};function errorObjectCode(cxt,error48,errorPaths){const{createErrors}=cxt.it;if(createErrors===false)return(0,codegen_1._)`{}`;return errorObject(cxt,error48,errorPaths)}function errorObject(cxt,error48,errorPaths={}){const{gen,it}=cxt;const keyValues=[errorInstancePath(it,errorPaths),errorSchemaPath(cxt,errorPaths)];extraErrorProps(cxt,error48,keyValues);return gen.object(...keyValues)}function errorInstancePath({errorPath},{instancePath}){const instPath=instancePath?(0,codegen_1.str)`${errorPath}${(0,util_1.getErrorPath)(instancePath,util_1.Type.Str)}`:errorPath;return[names_1.default.instancePath,(0,codegen_1.strConcat)(names_1.default.instancePath,instPath)]}function errorSchemaPath({keyword,it:{errSchemaPath}},{schemaPath,parentSchema}){let schPath=parentSchema?errSchemaPath:(0,codegen_1.str)`${errSchemaPath}/${keyword}`;if(schemaPath){schPath=(0,codegen_1.str)`${schPath}${(0,util_1.getErrorPath)(schemaPath,util_1.Type.Str)}`}return[E.schemaPath,schPath]}function extraErrorProps(cxt,{params,message},keyValues){const{keyword,data,schemaValue,it}=cxt;const{opts,propertyName,topSchemaRef,schemaPath}=it;keyValues.push([E.keyword,keyword],[E.params,typeof params=="function"?params(cxt):params||(0,codegen_1._)`{}`]);if(opts.messages){keyValues.push([E.message,typeof message=="function"?message(cxt):message])}if(opts.verbose){keyValues.push([E.schema,schemaValue],[E.parentSchema,(0,codegen_1._)`${topSchemaRef}${schemaPath}`],[names_1.default.data,data])}if(propertyName)keyValues.push([E.propertyName,propertyName])}}});var require_boolSchema=__commonJS({"node_modules/ajv/dist/compile/validate/boolSchema.js"(exports){"use strict";Object.defineProperty(exports,"__esModule",{value:true});exports.boolOrEmptySchema=exports.topBoolOrEmptySchema=void 0;var errors_1=require_errors();var codegen_1=require_codegen();var names_1=require_names();var boolError={message:"boolean schema is false"};function topBoolOrEmptySchema(it){const{gen,schema,validateName}=it;if(schema===false){falseSchemaError(it,false)}else if(typeof schema=="object"&&schema.$async===true){gen.return(names_1.default.data)}else{gen.assign((0,codegen_1._)`${validateName}.errors`,null);gen.return(true)}}exports.topBoolOrEmptySchema=topBoolOrEmptySchema;function boolOrEmptySchema(it,valid){const{gen,schema}=it;if(schema===false){gen.var(valid,false);falseSchemaError(it)}else{gen.var(valid,true)}}exports.boolOrEmptySchema=boolOrEmptySchema;function falseSchemaError(it,overrideAllErrors){const{gen,data}=it;const cxt={gen,keyword:"false schema",data,schema:false,schemaCode:false,schemaValue:false,params:{},it};(0,errors_1.reportError)(cxt,boolError,void 0,overrideAllErrors)}}});var require_rules=__commonJS({"node_modules/ajv/dist/compile/rules.js"(exports){"use strict";Object.defineProperty(exports,"__esModule",{value:true});exports.getRules=exports.isJSONType=void 0;var _jsonTypes=["string","number","integer","boolean","null","object","array"];var jsonTypes=new Set(_jsonTypes);function isJSONType(x){return typeof x=="string"&&jsonTypes.has(x)}exports.isJSONType=isJSONType;function getRules(){const groups={number:{type:"number",rules:[]},string:{type:"string",rules:[]},array:{type:"array",rules:[]},object:{type:"object",rules:[]}};return{types:{...groups,integer:true,boolean:true,null:true},rules:[{rules:[]},groups.number,groups.string,groups.array,groups.object],post:{rules:[]},all:{},keywords:{}}}exports.getRules=getRules}});var require_applicability=__commonJS({"node_modules/ajv/dist/compile/validate/applicability.js"(exports){"use strict";Object.defineProperty(exports,"__esModule",{value:true});exports.shouldUseRule=exports.shouldUseGroup=exports.schemaHasRulesForType=void 0;function schemaHasRulesForType({schema,self},type){const group=self.RULES.types[type];return group&&group!==true&&shouldUseGroup(schema,group)}exports.schemaHasRulesForType=schemaHasRulesForType;function shouldUseGroup(schema,group){return group.rules.some(rule=>shouldUseRule(schema,rule))}exports.shouldUseGroup=shouldUseGroup;function shouldUseRule(schema,rule){var _a2;return schema[rule.keyword]!==void 0||((_a2=rule.definition.implements)===null||_a2===void 0?void 0:_a2.some(kwd=>schema[kwd]!==void 0))}exports.shouldUseRule=shouldUseRule}});var require_dataType=__commonJS({"node_modules/ajv/dist/compile/validate/dataType.js"(exports){"use strict";Object.defineProperty(exports,"__esModule",{value:true});exports.reportTypeError=exports.checkDataTypes=exports.checkDataType=exports.coerceAndCheckDataType=exports.getJSONTypes=exports.getSchemaTypes=exports.DataType=void 0;var rules_1=require_rules();var applicability_1=require_applicability();var errors_1=require_errors();var codegen_1=require_codegen();var util_1=require_util();var DataType;(function(DataType2){DataType2[DataType2["Correct"]=0]="Correct";DataType2[DataType2["Wrong"]=1]="Wrong"})(DataType||(exports.DataType=DataType={}));function getSchemaTypes(schema){const types=getJSONTypes(schema.type);const hasNull=types.includes("null");if(hasNull){if(schema.nullable===false)throw new Error("type: null contradicts nullable: false")}else{if(!types.length&&schema.nullable!==void 0){throw new Error('"nullable" cannot be used without "type"')}if(schema.nullable===true)types.push("null")}return types}exports.getSchemaTypes=getSchemaTypes;function getJSONTypes(ts){const types=Array.isArray(ts)?ts:ts?[ts]:[];if(types.every(rules_1.isJSONType))return types;throw new Error("type must be JSONType or JSONType[]: "+types.join(","))}exports.getJSONTypes=getJSONTypes;function coerceAndCheckDataType(it,types){const{gen,data,opts}=it;const coerceTo=coerceToTypes(types,opts.coerceTypes);const checkTypes=types.length>0&&!(coerceTo.length===0&&types.length===1&&(0,applicability_1.schemaHasRulesForType)(it,types[0]));if(checkTypes){const wrongType=checkDataTypes(types,data,opts.strictNumbers,DataType.Wrong);gen.if(wrongType,()=>{if(coerceTo.length)coerceData(it,types,coerceTo);else reportTypeError(it)})}return checkTypes}exports.coerceAndCheckDataType=coerceAndCheckDataType;var COERCIBLE=new Set(["string","number","integer","boolean","null"]);function coerceToTypes(types,coerceTypes){return coerceTypes?types.filter(t=>COERCIBLE.has(t)||coerceTypes==="array"&&t==="array"):[]}function coerceData(it,types,coerceTo){const{gen,data,opts}=it;const dataType=gen.let("dataType",(0,codegen_1._)`typeof ${data}`);const coerced=gen.let("coerced",(0,codegen_1._)`undefined`);if(opts.coerceTypes==="array"){gen.if((0,codegen_1._)`${dataType} == 'object' && Array.isArray(${data}) && ${data}.length == 1`,()=>gen.assign(data,(0,codegen_1._)`${data}[0]`).assign(dataType,(0,codegen_1._)`typeof ${data}`).if(checkDataTypes(types,data,opts.strictNumbers),()=>gen.assign(coerced,data)))}gen.if((0,codegen_1._)`${coerced} !== undefined`);for(const t of coerceTo){if(COERCIBLE.has(t)||t==="array"&&opts.coerceTypes==="array"){coerceSpecificType(t)}}gen.else();reportTypeError(it);gen.endIf();gen.if((0,codegen_1._)`${coerced} !== undefined`,()=>{gen.assign(data,coerced);assignParentData(it,coerced)});function coerceSpecificType(t){switch(t){case"string":gen.elseIf((0,codegen_1._)`${dataType} == "number" || ${dataType} == "boolean"`).assign(coerced,(0,codegen_1._)`"" + ${data}`).elseIf((0,codegen_1._)`${data} === null`).assign(coerced,(0,codegen_1._)`""`);return;case"number":gen.elseIf((0,codegen_1._)`${dataType} == "boolean" || ${data} === null
|
|
3
9
|
|| (${dataType} == "string" && ${data} && ${data} == +${data})`).assign(coerced,(0,codegen_1._)`+${data}`);return;case"integer":gen.elseIf((0,codegen_1._)`${dataType} === "boolean" || ${data} === null
|
|
4
10
|
|| (${dataType} === "string" && ${data} && ${data} == +${data} && !(${data} % 1))`).assign(coerced,(0,codegen_1._)`+${data}`);return;case"boolean":gen.elseIf((0,codegen_1._)`${data} === "false" || ${data} === 0 || ${data} === null`).assign(coerced,false).elseIf((0,codegen_1._)`${data} === "true" || ${data} === 1`).assign(coerced,true);return;case"null":gen.elseIf((0,codegen_1._)`${data} === "" || ${data} === 0 || ${data} === false`);gen.assign(coerced,null);return;case"array":gen.elseIf((0,codegen_1._)`${dataType} === "string" || ${dataType} === "number"
|