From 8ba939ba685694de0faddb4591b84c6c7f266db5 Mon Sep 17 00:00:00 2001 From: nirholas Date: Tue, 31 Mar 2026 10:26:23 +0000 Subject: [PATCH] =?UTF-8?q?=F0=9F=93=9D?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/copilot-instructions.md | 1 + Dockerfile | 1 + LICENSE | 1 + Skill.md | 1 + agent.md | 1 + mcp-server/src/index.ts | 22 -- server.json | 18 +- src/Tool.ts | 1 + src/assistant/sessionHistory.ts | 1 + src/bridge/bridgeDebug.ts | 1 + src/bridge/bridgeMessaging.ts | 1 + src/bridge/bridgeStatusUtil.ts | 1 + src/bridge/debugUtils.ts | 1 + src/bridge/initReplBridge.ts | 1 + src/bridge/pollConfigDefaults.ts | 1 + src/bridge/sessionRunner.ts | 1 + src/buddy/prompt.ts | 1 + src/buddy/types.ts | 1 + src/buddy/useBuddyNotification.tsx | 1 + src/cli/handlers/auth.ts | 1 + src/cli/handlers/util.tsx | 1 + src/cli/ndjsonSafeStringify.ts | 1 + src/cli/remoteIO.ts | 1 + src/cli/structuredIO.ts | 1 + src/cli/transports/SSETransport.ts | 1 + src/cli/transports/WebSocketTransport.ts | 1 + src/cli/transports/WorkerStateUploader.ts | 1 + src/cli/transports/transportUtils.ts | 1 + src/commands/agents/index.ts | 1 + src/commands/branch/index.ts | 1 + src/commands/break-cache/index.js | 1 + src/commands/bridge-kick.ts | 1 + src/commands/bridge/bridge.tsx | 1 + src/commands/bridge/index.ts | 1 + src/commands/bughunter/index.js | 1 + src/commands/clear/clear.ts | 1 + src/commands/commit.ts | 1 + src/commands/compact/index.ts | 1 + src/commands/config/config.tsx | 1 + src/commands/context/context.tsx | 1 + src/commands/context/index.ts | 1 + src/commands/copy/copy.tsx | 1 + src/commands/copy/index.ts | 1 + src/commands/createMovedToPluginCommand.ts | 1 + src/commands/debug-tool-call/index.js | 1 + src/commands/desktop/desktop.tsx | 1 + src/commands/diff/index.ts | 1 + src/commands/x402/index.ts | 12 + src/cost-tracker.ts | 14 +- src/services/api/client.ts | 14 +- src/services/api/logging.ts | 1 + src/services/api/metricsOptOut.ts | 1 + src/services/api/overageCreditGrant.ts | 1 + src/services/x402/client.ts | 399 +++++++++++++++++++++ src/services/x402/config.ts | 185 ++++++++++ src/services/x402/index.ts | 59 +++ src/services/x402/paymentFetch.ts | 156 ++++++++ src/services/x402/tracker.ts | 81 +++++ 58 files changed, 982 insertions(+), 26 deletions(-) create mode 100644 src/commands/x402/index.ts create mode 100644 src/services/x402/client.ts create mode 100644 src/services/x402/config.ts create mode 100644 src/services/x402/index.ts create mode 100644 src/services/x402/paymentFetch.ts create mode 100644 src/services/x402/tracker.ts diff --git a/.github/copilot-instructions.md b/.github/copilot-instructions.md index e70b5c6..842b239 100644 --- a/.github/copilot-instructions.md +++ b/.github/copilot-instructions.md @@ -64,3 +64,4 @@ Bun strips inactive code at build time via `import { feature } from 'bun:bundle' - **Follow the bridge**: IDE integration starts at `src/bridge/bridgeMain.ts` - **MCP integration**: `src/services/mcp/` + diff --git a/Dockerfile b/Dockerfile index ce54691..47885b5 100644 --- a/Dockerfile +++ b/Dockerfile @@ -28,3 +28,4 @@ COPY . . # Default: drop into a shell for exploration CMD ["sh"] + diff --git a/LICENSE b/LICENSE index ac07d87..1958a9c 100644 --- a/LICENSE +++ b/LICENSE @@ -8,3 +8,4 @@ under any permissive or copyleft license. Use at your own legal risk. For the official Claude Code CLI, see: https://docs.anthropic.com/en/docs/claude-code + diff --git a/Skill.md b/Skill.md index 92e11bd..7847a75 100644 --- a/Skill.md +++ b/Skill.md @@ -217,3 +217,4 @@ Some features are also gated via `process.env.USER_TYPE === 'ant'`. 7. Use lazy imports when adding dependencies that could create circular references. 8. Update this file as project conventions evolve. + diff --git a/agent.md b/agent.md index c361bd7..d18b48e 100644 --- a/agent.md +++ b/agent.md @@ -31,3 +31,4 @@ Define how an automated coding agent should operate in this repository. ## Notes - Repository conventions may evolve; update this file when team norms change. + diff --git a/mcp-server/src/index.ts b/mcp-server/src/index.ts index 3436d18..8f8a19c 100644 --- a/mcp-server/src/index.ts +++ b/mcp-server/src/index.ts @@ -23,28 +23,6 @@ main().catch((err) => { process.exit(1); }); - } catch { - return false; - } -} - -async function fileExists(p: string): Promise { - try { - return (await fs.stat(p)).isFile(); - } catch { - return false; - } -} - -/** List immediate children of a directory (files & dirs). */ -async function listDir(dir: string): Promise { - try { - const entries = await fs.readdir(dir, { withFileTypes: true }); - return entries.map((e: { isDirectory(): boolean; name: string }) => (e.isDirectory() ? e.name + "/" : e.name)).sort(); - } catch { - return []; - } -} /** Recursively collect all file paths under `root` (relative to root). */ async function walkFiles(root: string, rel = ""): Promise { diff --git a/server.json b/server.json index 3fff420..010fd4f 100644 --- a/server.json +++ b/server.json @@ -1,19 +1,33 @@ { "$schema": "https://static.modelcontextprotocol.io/schemas/2025-12-11/server.schema.json", "name": "io.github.nirholas/claude-code-explorer-mcp", - "description": "MCP server for exploring the Claude Code CLI source code — tools, commands, and architecture.", + "title": "Claude Code Explorer MCP", + "description": "MCP server for exploring the Claude Code CLI source code — browse 40+ tools, 50+ commands, search the full 512K-line codebase, and get architecture overviews.", "repository": { "url": "https://github.com/nirholas/claude-code", - "source": "github" + "source": "github", + "subfolder": "mcp-server" }, "version": "1.1.0", "packages": [ { "registryType": "npm", + "registryBaseUrl": "https://registry.npmjs.org", "identifier": "claude-code-explorer-mcp", "version": "1.1.0", "transport": { "type": "stdio" + }, + "runtimeHint": { + "commandLine": { + "args": [] + }, + "env": { + "CLAUDE_CODE_SRC_ROOT": { + "description": "Path to the Claude Code src/ directory to explore", + "required": false + } + } } } ] diff --git a/src/Tool.ts b/src/Tool.ts index 7ac0551..285ed10 100644 --- a/src/Tool.ts +++ b/src/Tool.ts @@ -791,3 +791,4 @@ export function buildTool(def: D): BuiltTool { } as BuiltTool } + diff --git a/src/assistant/sessionHistory.ts b/src/assistant/sessionHistory.ts index 5200f9e..8253d46 100644 --- a/src/assistant/sessionHistory.ts +++ b/src/assistant/sessionHistory.ts @@ -86,3 +86,4 @@ export async function fetchOlderEvents( return fetchPage(ctx, { limit, before_id: beforeId }, 'fetchOlderEvents') } + diff --git a/src/bridge/bridgeDebug.ts b/src/bridge/bridgeDebug.ts index babb58d..28a493e 100644 --- a/src/bridge/bridgeDebug.ts +++ b/src/bridge/bridgeDebug.ts @@ -134,3 +134,4 @@ export function wrapApiForFaultInjection( } } + diff --git a/src/bridge/bridgeMessaging.ts b/src/bridge/bridgeMessaging.ts index ff893e7..3360002 100644 --- a/src/bridge/bridgeMessaging.ts +++ b/src/bridge/bridgeMessaging.ts @@ -460,3 +460,4 @@ export class BoundedUUIDSet { } } + diff --git a/src/bridge/bridgeStatusUtil.ts b/src/bridge/bridgeStatusUtil.ts index 2db8796..39cedd9 100644 --- a/src/bridge/bridgeStatusUtil.ts +++ b/src/bridge/bridgeStatusUtil.ts @@ -162,3 +162,4 @@ export function wrapWithOsc8Link(text: string, url: string): string { return `\x1b]8;;${url}\x07${text}\x1b]8;;\x07` } + diff --git a/src/bridge/debugUtils.ts b/src/bridge/debugUtils.ts index c03d7d1..88b1048 100644 --- a/src/bridge/debugUtils.ts +++ b/src/bridge/debugUtils.ts @@ -140,3 +140,4 @@ export function logBridgeSkip( }) } + diff --git a/src/bridge/initReplBridge.ts b/src/bridge/initReplBridge.ts index d6fa990..b617590 100644 --- a/src/bridge/initReplBridge.ts +++ b/src/bridge/initReplBridge.ts @@ -568,3 +568,4 @@ function deriveTitle(raw: string): string | undefined { : flat } + diff --git a/src/bridge/pollConfigDefaults.ts b/src/bridge/pollConfigDefaults.ts index b1785ef..c1a561a 100644 --- a/src/bridge/pollConfigDefaults.ts +++ b/src/bridge/pollConfigDefaults.ts @@ -81,3 +81,4 @@ export const DEFAULT_POLL_CONFIG: PollIntervalConfig = { session_keepalive_interval_v2_ms: 120_000, } + diff --git a/src/bridge/sessionRunner.ts b/src/bridge/sessionRunner.ts index 3ba62f4..577df94 100644 --- a/src/bridge/sessionRunner.ts +++ b/src/bridge/sessionRunner.ts @@ -549,3 +549,4 @@ export function createSessionSpawner(deps: SessionSpawnerDeps): SessionSpawner { export { extractActivities as _extractActivitiesForTesting } + diff --git a/src/buddy/prompt.ts b/src/buddy/prompt.ts index b1b63b6..fa5ce5c 100644 --- a/src/buddy/prompt.ts +++ b/src/buddy/prompt.ts @@ -35,3 +35,4 @@ export function getCompanionIntroAttachment( ] } + diff --git a/src/buddy/types.ts b/src/buddy/types.ts index c6ffda3..5278b09 100644 --- a/src/buddy/types.ts +++ b/src/buddy/types.ts @@ -147,3 +147,4 @@ export const RARITY_COLORS = { legendary: 'warning', } as const satisfies Record + diff --git a/src/buddy/useBuddyNotification.tsx b/src/buddy/useBuddyNotification.tsx index 4ffe04c..01b79f0 100644 --- a/src/buddy/useBuddyNotification.tsx +++ b/src/buddy/useBuddyNotification.tsx @@ -96,3 +96,4 @@ export function findBuddyTriggerPositions(text: string): Array<{ return triggers; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJmZWF0dXJlIiwiUmVhY3QiLCJ1c2VFZmZlY3QiLCJ1c2VOb3RpZmljYXRpb25zIiwiVGV4dCIsImdldEdsb2JhbENvbmZpZyIsImdldFJhaW5ib3dDb2xvciIsImlzQnVkZHlUZWFzZXJXaW5kb3ciLCJkIiwiRGF0ZSIsImdldEZ1bGxZZWFyIiwiZ2V0TW9udGgiLCJnZXREYXRlIiwiaXNCdWRkeUxpdmUiLCJSYWluYm93VGV4dCIsInQwIiwiJCIsIl9jIiwidGV4dCIsInQxIiwibWFwIiwiX3RlbXAiLCJjaCIsImkiLCJ1c2VCdWRkeU5vdGlmaWNhdGlvbiIsImFkZE5vdGlmaWNhdGlvbiIsInJlbW92ZU5vdGlmaWNhdGlvbiIsImNvbmZpZyIsImNvbXBhbmlvbiIsImtleSIsImpzeCIsInByaW9yaXR5IiwidGltZW91dE1zIiwiZmluZEJ1ZGR5VHJpZ2dlclBvc2l0aW9ucyIsIkFycmF5Iiwic3RhcnQiLCJlbmQiLCJ0cmlnZ2VycyIsInJlIiwibSIsIlJlZ0V4cEV4ZWNBcnJheSIsImV4ZWMiLCJwdXNoIiwiaW5kZXgiLCJsZW5ndGgiXSwic291cmNlcyI6WyJ1c2VCdWRkeU5vdGlmaWNhdGlvbi50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZmVhdHVyZSB9IGZyb20gJ2J1bjpidW5kbGUnXG5pbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0IH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VOb3RpZmljYXRpb25zIH0gZnJvbSAnLi4vY29udGV4dC9ub3RpZmljYXRpb25zLmpzJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL2luay5qcydcbmltcG9ydCB7IGdldEdsb2JhbENvbmZpZyB9IGZyb20gJy4uL3V0aWxzL2NvbmZpZy5qcydcbmltcG9ydCB7IGdldFJhaW5ib3dDb2xvciB9IGZyb20gJy4uL3V0aWxzL3RoaW5raW5nLmpzJ1xuXG4vLyBMb2NhbCBkYXRlLCBub3QgVVRDIOKAlCAyNGggcm9sbGluZyB3YXZlIGFjcm9zcyB0aW1lem9uZXMuIFN1c3RhaW5lZCBUd2l0dGVyXG4vLyBidXp6IGluc3RlYWQgb2YgYSBzaW5nbGUgVVRDLW1pZG5pZ2h0IHNwaWtlLCBnZW50bGVyIG9uIHNvdWwtZ2VuIGxvYWQuXG4vLyBUZWFzZXIgd2luZG93OiBBcHJpbCAxLTcsIDIwMjYgb25seS4gQ29tbWFuZCBzdGF5cyBsaXZlIGZvcmV2ZXIgYWZ0ZXIuXG5leHBvcnQgZnVuY3Rpb24gaXNCdWRkeVRlYXNlcldpbmRvdygpOiBib29sZWFuIHtcbiAgaWYgKFwiZXh0ZXJuYWxcIiA9PT0gJ2FudCcpIHJldHVybiB0cnVlXG4gIGNvbnN0IGQgPSBuZXcgRGF0ZSgpXG4gIHJldHVybiBkLmdldEZ1bGxZZWFyKCkgPT09IDIwMjYgJiYgZC5nZXRNb250aCgpID09PSAzICYmIGQuZ2V0RGF0ZSgpIDw9IDdcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzQnVkZHlMaXZlKCk6IGJvb2xlYW4ge1xuICBpZiAoXCJleHRlcm5hbFwiID09PSAnYW50JykgcmV0dXJuIHRydWVcbiAgY29uc3QgZCA9IG5ldyBEYXRlKClcbiAgcmV0dXJuIChcbiAgICBkLmdldEZ1bGxZZWFyKCkgPiAyMDI2IHx8IChkLmdldEZ1bGxZZWFyKCkgPT09IDIwMjYgJiYgZC5nZXRNb250aCgpID49IDMpXG4gIClcbn1cblxuZnVuY3Rpb24gUmFpbmJvd1RleHQoeyB0ZXh0IH06IHsgdGV4dDogc3RyaW5nIH0pOiBSZWFjdC5SZWFjdE5vZGUge1xuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICB7Wy4uLnRleHRdLm1hcCgoY2gsIGkpID0+IChcbiAgICAgICAgPFRleHQga2V5PXtpfSBjb2xvcj17Z2V0UmFpbmJvd0NvbG9yKGkpfT5cbiAgICAgICAgICB7Y2h9XG4gICAgICAgIDwvVGV4dD5cbiAgICAgICkpfVxuICAgIDwvPlxuICApXG59XG5cbi8vIFJhaW5ib3cgL2J1ZGR5IHRlYXNlciBzaG93biBvbiBzdGFydHVwIHdoZW4gbm8gY29tcGFuaW9uIGhhdGNoZWQgeWV0LlxuLy8gSWRsZSBwcmVzZW5jZSBhbmQgcmVhY3Rpb25zIGFyZSBoYW5kbGVkIGJ5IENvbXBhbmlvblNwcml0ZSBkaXJlY3RseS5cbmV4cG9ydCBmdW5jdGlvbiB1c2VCdWRkeU5vdGlmaWNhdGlvbigpOiB2b2lkIHtcbiAgY29uc3QgeyBhZGROb3RpZmljYXRpb24sIHJlbW92ZU5vdGlmaWNhdGlvbiB9ID0gdXNlTm90aWZpY2F0aW9ucygpXG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoIWZlYXR1cmUoJ0JVRERZJykpIHJldHVyblxuICAgIGNvbnN0IGNvbmZpZyA9IGdldEdsb2JhbENvbmZpZygpXG4gICAgaWYgKGNvbmZpZy5jb21wYW5pb24gfHwgIWlzQnVkZHlUZWFzZXJXaW5kb3coKSkgcmV0dXJuXG4gICAgYWRkTm90aWZpY2F0aW9uKHtcbiAgICAgIGtleTogJ2J1ZGR5LXRlYXNlcicsXG4gICAgICBqc3g6IDxSYWluYm93VGV4dCB0ZXh0PVwiL2J1ZGR5XCIgLz4sXG4gICAgICBwcmlvcml0eTogJ2ltbWVkaWF0ZScsXG4gICAgICB0aW1lb3V0TXM6IDE1XzAwMCxcbiAgICB9KVxuICAgIHJldHVybiAoKSA9PiByZW1vdmVOb3RpZmljYXRpb24oJ2J1ZGR5LXRlYXNlcicpXG4gIH0sIFthZGROb3RpZmljYXRpb24sIHJlbW92ZU5vdGlmaWNhdGlvbl0pXG59XG5cbmV4cG9ydCBmdW5jdGlvbiBmaW5kQnVkZHlUcmlnZ2VyUG9zaXRpb25zKFxuICB0ZXh0OiBzdHJpbmcsXG4pOiBBcnJheTx7IHN0YXJ0OiBudW1iZXI7IGVuZDogbnVtYmVyIH0+IHtcbiAgaWYgKCFmZWF0dXJlKCdCVUREWScpKSByZXR1cm4gW11cbiAgY29uc3QgdHJpZ2dlcnM6IEFycmF5PHsgc3RhcnQ6IG51bWJlcjsgZW5kOiBudW1iZXIgfT4gPSBbXVxuICBjb25zdCByZSA9IC9cXC9idWRkeVxcYi9nXG4gIGxldCBtOiBSZWdFeHBFeGVjQXJyYXkgfCBudWxsXG4gIHdoaWxlICgobSA9IHJlLmV4ZWModGV4dCkpICE9PSBudWxsKSB7XG4gICAgdHJpZ2dlcnMucHVzaCh7IHN0YXJ0OiBtLmluZGV4LCBlbmQ6IG0uaW5kZXggKyBtWzBdLmxlbmd0aCB9KVxuICB9XG4gIHJldHVybiB0cmlnZ2Vyc1xufVxuIl0sIm1hcHBpbmdzIjoiO0FBQUEsU0FBU0EsT0FBTyxRQUFRLFlBQVk7QUFDcEMsT0FBT0MsS0FBSyxJQUFJQyxTQUFTLFFBQVEsT0FBTztBQUN4QyxTQUFTQyxnQkFBZ0IsUUFBUSw2QkFBNkI7QUFDOUQsU0FBU0MsSUFBSSxRQUFRLFdBQVc7QUFDaEMsU0FBU0MsZUFBZSxRQUFRLG9CQUFvQjtBQUNwRCxTQUFTQyxlQUFlLFFBQVEsc0JBQXNCOztBQUV0RDtBQUNBO0FBQ0E7QUFDQSxPQUFPLFNBQVNDLG1CQUFtQkEsQ0FBQSxDQUFFLEVBQUUsT0FBTyxDQUFDO0VBQzdDLElBQUksVUFBVSxLQUFLLEtBQUssRUFBRSxPQUFPLElBQUk7RUFDckMsTUFBTUMsQ0FBQyxHQUFHLElBQUlDLElBQUksQ0FBQyxDQUFDO0VBQ3BCLE9BQU9ELENBQUMsQ0FBQ0UsV0FBVyxDQUFDLENBQUMsS0FBSyxJQUFJLElBQUlGLENBQUMsQ0FBQ0csUUFBUSxDQUFDLENBQUMsS0FBSyxDQUFDLElBQUlILENBQUMsQ0FBQ0ksT0FBTyxDQUFDLENBQUMsSUFBSSxDQUFDO0FBQzNFO0FBRUEsT0FBTyxTQUFTQyxXQUFXQSxDQUFBLENBQUUsRUFBRSxPQUFPLENBQUM7RUFDckMsSUFBSSxVQUFVLEtBQUssS0FBSyxFQUFFLE9BQU8sSUFBSTtFQUNyQyxNQUFNTCxDQUFDLEdBQUcsSUFBSUMsSUFBSSxDQUFDLENBQUM7RUFDcEIsT0FDRUQsQ0FBQyxDQUFDRSxXQUFXLENBQUMsQ0FBQyxHQUFHLElBQUksSUFBS0YsQ0FBQyxDQUFDRSxXQUFXLENBQUMsQ0FBQyxLQUFLLElBQUksSUFBSUYsQ0FBQyxDQUFDRyxRQUFRLENBQUMsQ0FBQyxJQUFJLENBQUU7QUFFN0U7QUFFQSxTQUFBRyxZQUFBQyxFQUFBO0VBQUEsTUFBQUMsQ0FBQSxH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 + diff --git a/src/cli/handlers/auth.ts b/src/cli/handlers/auth.ts index 2e47982..35c0946 100644 --- a/src/cli/handlers/auth.ts +++ b/src/cli/handlers/auth.ts @@ -329,3 +329,4 @@ export async function authLogout(): Promise { process.exit(0) } + diff --git a/src/cli/handlers/util.tsx b/src/cli/handlers/util.tsx index ea11fc7..d3f71f3 100644 --- a/src/cli/handlers/util.tsx +++ b/src/cli/handlers/util.tsx @@ -108,3 +108,4 @@ export async function installHandler(target: string | undefined, options: { }); } //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjd2QiLCJSZWFjdCIsIldlbGNvbWVWMiIsInVzZU1hbmFnZVBsdWdpbnMiLCJSb290IiwiQm94IiwiVGV4dCIsIktleWJpbmRpbmdTZXR1cCIsImxvZ0V2ZW50IiwiTUNQQ29ubmVjdGlvbk1hbmFnZXIiLCJBcHBTdGF0ZVByb3ZpZGVyIiwib25DaGFuZ2VBcHBTdGF0ZSIsImlzQW50aHJvcGljQXV0aEVuYWJsZWQiLCJzZXR1cFRva2VuSGFuZGxlciIsInJvb3QiLCJQcm9taXNlIiwic2hvd0F1dGhXYXJuaW5nIiwiQ29uc29sZU9BdXRoRmxvdyIsInJlc29sdmUiLCJyZW5kZXIiLCJ1bm1vdW50IiwicHJvY2VzcyIsImV4aXQiLCJEb2N0b3JMYXp5IiwibGF6eSIsInRoZW4iLCJtIiwiZGVmYXVsdCIsIkRvY3RvciIsIkRvY3RvcldpdGhQbHVnaW5zIiwidDAiLCIkIiwiX2MiLCJvbkRvbmUiLCJ0MSIsImRvY3RvckhhbmRsZXIiLCJ1bmRlZmluZWQiLCJpbnN0YWxsSGFuZGxlciIsInRhcmdldCIsIm9wdGlvbnMiLCJmb3JjZSIsInNldHVwIiwiaW5zdGFsbCIsImFyZ3MiLCJwdXNoIiwiY2FsbCIsInJlc3VsdCIsImluY2x1ZGVzIl0sInNvdXJjZXMiOlsidXRpbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBNaXNjZWxsYW5lb3VzIHN1YmNvbW1hbmQgaGFuZGxlcnMg4oCUIGV4dHJhY3RlZCBmcm9tIG1haW4udHN4IGZvciBsYXp5IGxvYWRpbmcuXG4gKiBzZXR1cC10b2tlbiwgZG9jdG9yLCBpbnN0YWxsXG4gKi9cbi8qIGVzbGludC1kaXNhYmxlIGN1c3RvbS1ydWxlcy9uby1wcm9jZXNzLWV4aXQgLS0gQ0xJIHN1YmNvbW1hbmQgaGFuZGxlcnMgaW50ZW50aW9uYWxseSBleGl0ICovXG5cbmltcG9ydCB7IGN3ZCB9IGZyb20gJ3Byb2Nlc3MnXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBXZWxjb21lVjIgfSBmcm9tICcuLi8uLi9jb21wb25lbnRzL0xvZ29WMi9XZWxjb21lVjIuanMnXG5pbXBvcnQgeyB1c2VNYW5hZ2VQbHVnaW5zIH0gZnJvbSAnLi4vLi4vaG9va3MvdXNlTWFuYWdlUGx1Z2lucy5qcydcbmltcG9ydCB0eXBlIHsgUm9vdCB9IGZyb20gJy4uLy4uL2luay5qcydcbmltcG9ydCB7IEJveCwgVGV4dCB9IGZyb20gJy4uLy4uL2luay5qcydcbmltcG9ydCB7IEtleWJpbmRpbmdTZXR1cCB9IGZyb20gJy4uLy4uL2tleWJpbmRpbmdzL0tleWJpbmRpbmdQcm92aWRlclNldHVwLmpzJ1xuaW1wb3J0IHsgbG9nRXZlbnQgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9hbmFseXRpY3MvaW5kZXguanMnXG5pbXBvcnQgeyBNQ1BDb25uZWN0aW9uTWFuYWdlciB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL21jcC9NQ1BDb25uZWN0aW9uTWFuYWdlci5qcydcbmltcG9ydCB7IEFwcFN0YXRlUHJvdmlkZXIgfSBmcm9tICcuLi8uLi9zdGF0ZS9BcHBTdGF0ZS5qcydcbmltcG9ydCB7IG9uQ2hhbmdlQXBwU3RhdGUgfSBmcm9tICcuLi8uLi9zdGF0ZS9vbkNoYW5nZUFwcFN0YXRlLmpzJ1xuaW1wb3J0IHsgaXNBbnRocm9waWNBdXRoRW5hYmxlZCB9IGZyb20gJy4uLy4uL3V0aWxzL2F1dGguanMnXG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBzZXR1cFRva2VuSGFuZGxlcihyb290OiBSb290KTogUHJvbWlzZTx2b2lkPiB7XG4gIGxvZ0V2ZW50KCd0ZW5ndV9zZXR1cF90b2tlbl9jb21tYW5kJywge30pXG5cbiAgY29uc3Qgc2hvd0F1dGhXYXJuaW5nID0gIWlzQW50aHJvcGljQXV0aEVuYWJsZWQoKVxuICBjb25zdCB7IENvbnNvbGVPQXV0aEZsb3cgfSA9IGF3YWl0IGltcG9ydChcbiAgICAnLi4vLi4vY29tcG9uZW50cy9Db25zb2xlT0F1dGhGbG93LmpzJ1xuICApXG4gIGF3YWl0IG5ldyBQcm9taXNlPHZvaWQ+KHJlc29sdmUgPT4ge1xuICAgIHJvb3QucmVuZGVyKFxuICAgICAgPEFwcFN0YXRlUHJvdmlkZXIgb25DaGFuZ2VBcHBTdGF0ZT17b25DaGFuZ2VBcHBTdGF0ZX0+XG4gICAgICAgIDxLZXliaW5kaW5nU2V0dXA+XG4gICAgICAgICAgPEJveCBmbGV4RGlyZWN0aW9uPVwiY29sdW1uXCIgZ2FwPXsxfT5cbiAgICAgICAgICAgIDxXZWxjb21lVjIgLz5cbiAgICAgICAgICAgIHtzaG93QXV0aFdhcm5pbmcgJiYgKFxuICAgICAgICAgICAgICA8Qm94IGZsZXhEaXJlY3Rpb249XCJjb2x1bW5cIj5cbiAgICAgICAgICAgICAgICA8VGV4dCBjb2xvcj1cIndhcm5pbmdcIj5cbiAgICAgICAgICAgICAgICAgIFdhcm5pbmc6IFlvdSBhbHJlYWR5IGhhdmUgYXV0aGVudGljYXRpb24gY29uZmlndXJlZCB2aWFcbiAgICAgICAgICAgICAgICAgIGVudmlyb25tZW50IHZhcmlhYmxlIG9yIEFQSSBrZXkgaGVscGVyLlxuICAgICAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICAgICAgICA8VGV4dCBjb2xvcj1cIndhcm5pbmdcIj5cbiAgICAgICAgICAgICAgICAgIFRoZSBzZXR1cC10b2tlbiBjb21tYW5kIHdpbGwgY3JlYXRlIGEgbmV3IE9BdXRoIHRva2VuIHdoaWNoXG4gICAgICAgICAgICAgICAgICB5b3UgY2FuIHVzZSBpbnN0ZWFkLlxuICAgICAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICAgICAgPC9Cb3g+XG4gICAgICAgICAgICApfVxuICAgICAgICAgICAgPENvbnNvbGVPQXV0aEZsb3dcbiAgICAgICAgICAgICAgb25Eb25lPXsoKSA9PiB7XG4gICAgICAgICAgICAgICAgdm9pZCByZXNvbHZlKClcbiAgICAgICAgICAgICAgfX1cbiAgICAgICAgICAgICAgbW9kZT1cInNldHVwLXRva2VuXCJcbiAgICAgICAgICAgICAgc3RhcnRpbmdNZXNzYWdlPVwiVGhpcyB3aWxsIGd1aWRlIHlvdSB0aHJvdWdoIGxvbmctbGl2ZWQgKDEteWVhcikgYXV0aCB0b2tlbiBzZXR1cCBmb3IgeW91ciBDbGF1ZGUgYWNjb3VudC4gQ2xhdWRlIHN1YnNjcmlwdGlvbiByZXF1aXJlZC5cIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L0JveD5cbiAgICAgICAgPC9LZXliaW5kaW5nU2V0dXA+XG4gICAgICA8L0FwcFN0YXRlUHJvdmlkZXI+LFxuICAgIClcbiAgfSlcbiAgcm9vdC51bm1vdW50KClcbiAgcHJvY2Vzcy5leGl0KDApXG59XG5cbi8vIERvY3RvcldpdGhQbHVnaW5zIHdyYXBwZXIgKyBkb2N0b3IgaGFuZGxlclxuY29uc3QgRG9jdG9yTGF6eSA9IFJlYWN0LmxhenkoKCkgPT5cbiAgaW1wb3J0KCcuLi8uLi9zY3JlZW5zL0RvY3Rvci5qcycpLnRoZW4obSA9PiAoeyBkZWZhdWx0OiBtLkRvY3RvciB9KSksXG4pXG5cbmZ1bmN0aW9uIERvY3RvcldpdGhQbHVnaW5zKHtcbiAgb25Eb25lLFxufToge1xuICBvbkRvbmU6ICgpID0+IHZvaWRcbn0pOiBSZWFjdC5SZWFjdE5vZGUge1xuICB1c2VNYW5hZ2VQbHVnaW5zKClcbiAgcmV0dXJuIChcbiAgICA8UmVhY3QuU3VzcGVuc2UgZmFsbGJhY2s9e251bGx9PlxuICAgICAgPERvY3Rvckxhenkgb25Eb25lPXtvbkRvbmV9IC8+XG4gICAgPC9SZWFjdC5TdXNwZW5zZT5cbiAgKVxufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZG9jdG9ySGFuZGxlcihyb290OiBSb290KTogUHJvbWlzZTx2b2lkPiB7XG4gIGxvZ0V2ZW50KCd0ZW5ndV9kb2N0b3JfY29tbWFuZCcsIHt9KVxuXG4gIGF3YWl0IG5ldyBQcm9taXNlPHZvaWQ+KHJlc29sdmUgPT4ge1xuICAgIHJvb3QucmVuZGVyKFxuICAgICAgPEFwcFN0YXRlUHJvdmlkZXI+XG4gICAgICAgIDxLZXliaW5kaW5nU2V0dXA+XG4gICAgICAgICAgPE1DUENvbm5lY3Rpb25NYW5hZ2VyXG4gICAgICAgICAgICBkeW5hbWljTWNwQ29uZmlnPXt1bmRlZmluZWR9XG4gICAgICAgICAgICBpc1N0cmljdE1jcENvbmZpZz17ZmFsc2V9XG4gICAgICAgICAgPlxuICAgICAgICAgICAgPERvY3RvcldpdGhQbHVnaW5zXG4gICAgICAgICAgICAgIG9uRG9uZT17KCkgPT4ge1xuICAgICAgICAgICAgICAgIHZvaWQgcmVzb2x2ZSgpXG4gICAgICAgICAgICAgIH19XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvTUNQQ29ubmVjdGlvbk1hbmFnZXI+XG4gICAgICAgIDwvS2V5YmluZGluZ1NldHVwPlxuICAgICAgPC9BcHBTdGF0ZVByb3ZpZGVyPixcbiAgICApXG4gIH0pXG4gIHJvb3QudW5tb3VudCgpXG4gIHByb2Nlc3MuZXhpdCgwKVxufVxuXG4vLyBpbnN0YWxsIGhhbmRsZXJcbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBpbnN0YWxsSGFuZGxlcihcbiAgdGFyZ2V0OiBzdHJpbmcgfCB1bmRlZmluZWQsXG4gIG9wdGlvbnM6IHsgZm9yY2U/OiBib29sZWFuIH0sXG4pOiBQcm9taXNlPHZvaWQ+IHtcbiAgY29uc3QgeyBzZXR1cCB9ID0gYXdhaXQgaW1wb3J0KCcuLi8uLi9zZXR1cC5qcycpXG4gIGF3YWl0IHNldHVwKGN3ZCgpLCAnZGVmYXVsdCcsIGZhbHNlLCBmYWxzZSwgdW5kZWZpbmVkLCBmYWxzZSlcbiAgY29uc3QgeyBpbnN0YWxsIH0gPSBhd2FpdCBpbXBvcnQoJy4uLy4uL2NvbW1hbmRzL2luc3RhbGwuanMnKVxuICBhd2FpdCBuZXcgUHJvbWlzZTx2b2lkPihyZXNvbHZlID0+IHtcbiAgICBjb25zdCBhcmdzOiBzdHJpbmdbXSA9IFtdXG4gICAgaWYgKHRhcmdldCkgYXJncy5wdXNoKHRhcmdldClcbiAgICBpZiAob3B0aW9ucy5mb3JjZSkgYXJncy5wdXNoKCctLWZvcmNlJylcblxuICAgIHZvaWQgaW5zdGFsbC5jYWxsKFxuICAgICAgcmVzdWx0ID0+IHtcbiAgICAgICAgdm9pZCByZXNvbHZlKClcbiAgICAgICAgcHJvY2Vzcy5leGl0KHJlc3VsdC5pbmNsdWRlcygnZmFpbGVkJykgPyAxIDogMClcbiAgICAgIH0sXG4gICAgICB7fSxcbiAgICAgIGFyZ3MsXG4gICAgKVxuICB9KVxufVxuIl0sIm1hcHBpbmdzIjoiO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxTQUFTQSxHQUFHLFFBQVEsU0FBUztBQUM3QixPQUFPQyxLQUFLLE1BQU0sT0FBTztBQUN6QixTQUFTQyxTQUFTLFFBQVEsc0NBQXNDO0FBQ2hFLFNBQVNDLGdCQUFnQixRQUFRLGlDQUFpQztBQUNsRSxjQUFjQyxJQUFJLFFBQVEsY0FBYztBQUN4QyxTQUFTQyxHQUFHLEVBQUVDLElBQUksUUFBUSxjQUFjO0FBQ3hDLFNBQVNDLGVBQWUsUUFBUSw4Q0FBOEM7QUFDOUUsU0FBU0MsUUFBUSxRQUFRLG1DQUFtQztBQUM1RCxTQUFTQyxvQkFBb0IsUUFBUSw0Q0FBNEM7QUFDakYsU0FBU0MsZ0JBQWdCLFFBQVEseUJBQXlCO0FBQzFELFNBQVNDLGdCQUFnQixRQUFRLGlDQUFpQztBQUNsRSxTQUFTQyxzQkFBc0IsUUFBUSxxQkFBcUI7QUFFNUQsT0FBTyxlQUFlQyxpQkFBaUJBLENBQUNDLElBQUksRUFBRVYsSUFBSSxDQUFDLEVBQUVXLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztFQUNqRVAsUUFBUSxDQUFDLDJCQUEyQixFQUFFLENBQUMsQ0FBQyxDQUFDO0VBRXpDLE1BQU1RLGVBQWUsR0FBRyxDQUFDSixzQkFBc0IsQ0FBQyxDQUFDO0VBQ2pELE1BQU07SUFBRUs7RUFBaUIsQ0FBQyxHQUFHLE1BQU0sTUFBTSxDQUN2QyxzQ0FDRixDQUFDO0VBQ0QsTUFBTSxJQUFJRixPQUFPLENBQUMsSUFBSSxDQUFDLENBQUNHLE9BQU8sSUFBSTtJQUNqQ0osSUFBSSxDQUFDSyxNQUFNLENBQ1QsQ0FBQyxnQkFBZ0IsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDUixnQkFBZ0IsQ0FBQztBQUMzRCxRQUFRLENB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 + diff --git a/src/cli/ndjsonSafeStringify.ts b/src/cli/ndjsonSafeStringify.ts index ad21576..147f602 100644 --- a/src/cli/ndjsonSafeStringify.ts +++ b/src/cli/ndjsonSafeStringify.ts @@ -31,3 +31,4 @@ export function ndjsonSafeStringify(value: unknown): string { return escapeJsLineTerminators(jsonStringify(value)) } + diff --git a/src/cli/remoteIO.ts b/src/cli/remoteIO.ts index 857e482..ba4eea4 100644 --- a/src/cli/remoteIO.ts +++ b/src/cli/remoteIO.ts @@ -254,3 +254,4 @@ export class RemoteIO extends StructuredIO { } } + diff --git a/src/cli/structuredIO.ts b/src/cli/structuredIO.ts index 065d71d..d4fdc7a 100644 --- a/src/cli/structuredIO.ts +++ b/src/cli/structuredIO.ts @@ -858,3 +858,4 @@ async function executePermissionRequestHooksForSDK( return undefined } + diff --git a/src/cli/transports/SSETransport.ts b/src/cli/transports/SSETransport.ts index e88dd9e..78017c7 100644 --- a/src/cli/transports/SSETransport.ts +++ b/src/cli/transports/SSETransport.ts @@ -710,3 +710,4 @@ function convertSSEUrlToPostUrl(sseUrl: URL): string { return `${sseUrl.protocol}//${sseUrl.host}${pathname}` } + diff --git a/src/cli/transports/WebSocketTransport.ts b/src/cli/transports/WebSocketTransport.ts index cfb5a7f..e60ef22 100644 --- a/src/cli/transports/WebSocketTransport.ts +++ b/src/cli/transports/WebSocketTransport.ts @@ -799,3 +799,4 @@ export class WebSocketTransport implements Transport { } } + diff --git a/src/cli/transports/WorkerStateUploader.ts b/src/cli/transports/WorkerStateUploader.ts index 9544756..ee2831d 100644 --- a/src/cli/transports/WorkerStateUploader.ts +++ b/src/cli/transports/WorkerStateUploader.ts @@ -130,3 +130,4 @@ function coalescePatches( return merged } + diff --git a/src/cli/transports/transportUtils.ts b/src/cli/transports/transportUtils.ts index e8f6a95..700dd82 100644 --- a/src/cli/transports/transportUtils.ts +++ b/src/cli/transports/transportUtils.ts @@ -44,3 +44,4 @@ export function getTransportForUrl( } } + diff --git a/src/commands/agents/index.ts b/src/commands/agents/index.ts index 79c566b..1c597dd 100644 --- a/src/commands/agents/index.ts +++ b/src/commands/agents/index.ts @@ -9,3 +9,4 @@ const agents = { export default agents + diff --git a/src/commands/branch/index.ts b/src/commands/branch/index.ts index f6ec9b3..2aa7fb7 100644 --- a/src/commands/branch/index.ts +++ b/src/commands/branch/index.ts @@ -13,3 +13,4 @@ const branch = { export default branch + diff --git a/src/commands/break-cache/index.js b/src/commands/break-cache/index.js index 9627ea7..01e6d3f 100644 --- a/src/commands/break-cache/index.js +++ b/src/commands/break-cache/index.js @@ -1,2 +1,3 @@ export default { isEnabled: () => false, isHidden: true, name: 'stub' }; + diff --git a/src/commands/bridge-kick.ts b/src/commands/bridge-kick.ts index bd5c6f5..065e179 100644 --- a/src/commands/bridge-kick.ts +++ b/src/commands/bridge-kick.ts @@ -199,3 +199,4 @@ const bridgeKick = { export default bridgeKick + diff --git a/src/commands/bridge/bridge.tsx b/src/commands/bridge/bridge.tsx index fbfe540..7881966 100644 --- a/src/commands/bridge/bridge.tsx +++ b/src/commands/bridge/bridge.tsx @@ -507,3 +507,4 @@ export async function call(onDone: LocalJSXCommandOnDone, _context: ToolUseConte return ; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJmZWF0dXJlIiwidG9TdHJpbmciLCJxclRvU3RyaW5nIiwiUmVhY3QiLCJ1c2VFZmZlY3QiLCJ1c2VTdGF0ZSIsImdldEJyaWRnZUFjY2Vzc1Rva2VuIiwiY2hlY2tCcmlkZ2VNaW5WZXJzaW9uIiwiZ2V0QnJpZGdlRGlzYWJsZWRSZWFzb24iLCJpc0Vudkxlc3NCcmlkZ2VFbmFibGVkIiwiY2hlY2tFbnZMZXNzQnJpZGdlTWluVmVyc2lvbiIsIkJSSURHRV9MT0dJTl9JTlNUUlVDVElPTiIsIlJFTU9URV9DT05UUk9MX0RJU0NPTk5FQ1RFRF9NU0ciLCJEaWFsb2ciLCJMaXN0SXRlbSIsInNob3VsZFNob3dSZW1vdGVDYWxsb3V0IiwidXNlUmVnaXN0ZXJPdmVybGF5IiwiQm94IiwiVGV4dCIsInVzZUtleWJpbmRpbmdzIiwiQW5hbHl0aWNzTWV0YWRhdGFfSV9WRVJJRklFRF9USElTX0lTX05PVF9DT0RFX09SX0ZJTEVQQVRIUyIsImxvZ0V2ZW50IiwidXNlQXBwU3RhdGUiLCJ1c2VTZXRBcHBTdGF0ZSIsIlRvb2xVc2VDb250ZXh0IiwiTG9jYWxKU1hDb21tYW5kQ29udGV4dCIsIkxvY2FsSlNYQ29tbWFuZE9uRG9uZSIsImxvZ0ZvckRlYnVnZ2luZyIsIlByb3BzIiwib25Eb25lIiwibmFtZSIsIkJyaWRnZVRvZ2dsZSIsInQwIiwiJCIsIl9jIiwic2V0QXBwU3RhdGUiLCJyZXBsQnJpZGdlQ29ubmVjdGVkIiwiX3RlbXAiLCJyZXBsQnJpZGdlRW5hYmxlZCIsIl90ZW1wMiIsInJlcGxCcmlkZ2VPdXRib3VuZE9ubHkiLCJfdGVtcDMiLCJzaG93RGlzY29ubmVjdERpYWxvZyIsInNldFNob3dEaXNjb25uZWN0RGlhbG9nIiwidDEiLCJjYW5jZWxsZWQiLCJlcnJvciIsImNoZWNrQnJpZGdlUHJlcmVxdWlzaXRlcyIsImFjdGlvbiIsImRpc3BsYXkiLCJwcmV2Iiwic2hvd1JlbW90ZUNhbGxvdXQiLCJyZXBsQnJpZGdlSW5pdGlhbE5hbWUiLCJwcmV2XzAiLCJyZXBsQnJpZGdlRXhwbGljaXQiLCJ0MiIsIlN5bWJvbCIsImZvciIsInQzIiwic18xIiwicyIsInNfMCIsIkJyaWRnZURpc2Nvbm5lY3REaWFsb2ciLCJzZXNzaW9uVXJsIiwiX3RlbXA0IiwiY29ubmVjdFVybCIsIl90ZW1wNSIsInNlc3Npb25BY3RpdmUiLCJfdGVtcDYiLCJmb2N1c0luZGV4Iiwic2V0Rm9jdXNJbmRleCIsInNob3dRUiIsInNldFNob3dRUiIsInFyVGV4dCIsInNldFFyVGV4dCIsImRpc3BsYXlVcmwiLCJ0eXBlIiwiZXJyb3JDb3JyZWN0aW9uTGV2ZWwiLCJzbWFsbCIsInRoZW4iLCJjYXRjaCIsImhhbmRsZURpc2Nvbm5lY3QiLCJfdGVtcDciLCJ0NCIsImhhbmRsZVNob3dRUiIsIl90ZW1wOCIsInQ1IiwiaGFuZGxlQ29udGludWUiLCJ1bmRlZmluZWQiLCJ0NiIsInQ3IiwiX3RlbXA5IiwiX3RlbXAwIiwidDgiLCJzZWxlY3Q6YWNjZXB0IiwidDkiLCJjb250ZXh0IiwiVDAiLCJUMSIsInQxMCIsInQxMSIsInQxMiIsInQxMyIsInQxNCIsInQxNSIsInQxNiIsInFyTGluZXMiLCJzcGxpdCIsImZpbHRlciIsIl90ZW1wMSIsInQxNyIsImxlbmd0aCIsIm1hcCIsIl90ZW1wMTAiLCJ0MTgiLCJ0MTkiLCJ0MjAiLCJ0MjEiLCJ0MjIiLCJ0MjMiLCJ0MjQiLCJ0MjUiLCJ0MjYiLCJ0MjciLCJ0MjgiLCJ0MjkiLCJ0MzAiLCJsaW5lIiwiaV8xIiwiaSIsImwiLCJpXzAiLCJyZXBsQnJpZGdlU2Vzc2lvbkFjdGl2ZSIsInJlcGxCcmlkZ2VDb25uZWN0VXJsIiwicmVwbEJyaWRnZVNlc3Npb25VcmwiLCJQcm9taXNlIiwid2FpdEZvclBvbGljeUxpbWl0c1RvTG9hZCIsImlzUG9saWN5QWxsb3dlZCIsImRpc2FibGVkUmVhc29uIiwidXNlVjIiLCJpc0Fzc2lzdGFudE1vZGUiLCJ2ZXJzaW9uRXJyb3IiLCJjYWxsIiwiX2NvbnRleHQiLCJhcmdzIiwiUmVhY3ROb2RlIiwidHJpbSJdLCJzb3VyY2VzIjpbImJyaWRnZS50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZmVhdHVyZSB9IGZyb20gJ2J1bjpidW5kbGUnXG5pbXBvcnQgeyB0b1N0cmluZyBhcyBxclRvU3RyaW5nIH0gZnJvbSAncXJjb2RlJ1xuaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBnZXRCcmlkZ2VBY2Nlc3NUb2tlbiB9IGZyb20gJy4uLy4uL2JyaWRnZS9icmlkZ2VDb25maWcuanMnXG5pbXBvcnQge1xuICBjaGVja0JyaWRnZU1pblZlcnNpb24sXG4gIGdldEJyaWRnZURpc2FibGVkUmVhc29uLFxuICBpc0Vudkxlc3NCcmlkZ2VFbmFibGVkLFxufSBmcm9tICcuLi8uLi9icmlkZ2UvYnJpZGdlRW5hYmxlZC5qcydcbmltcG9ydCB7IGNoZWNrRW52TGVzc0JyaWRnZU1pblZlcnNpb24gfSBmcm9tICcuLi8uLi9icmlkZ2UvZW52TGVzc0JyaWRnZUNvbmZpZy5qcydcbmltcG9ydCB7XG4gIEJSSURHRV9MT0dJTl9JTlNUUlVDVElPTixcbiAgUkVNT1RFX0NPTlRST0xfRElTQ09OTkVDVEVEX01TRyxcbn0gZnJvbSAnLi4vLi4vYnJpZGdlL3R5cGVzLmpzJ1xuaW1wb3J0IHsgRGlhbG9nIH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9kZXNpZ24tc3lzdGVtL0RpYWxvZy5qcydcbmltcG9ydCB7IExpc3RJdGVtIH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9kZXNpZ24tc3lzdGVtL0xpc3RJdGVtLmpzJ1xuaW1wb3J0IHsgc2hvdWxkU2hvd1JlbW90ZUNhbGxvdXQgfSBmcm9tICcuLi8uLi9jb21wb25lbnRzL1JlbW90ZUNhbGxvdXQuanMnXG5pbXBvcnQgeyB1c2VSZWdpc3Rlck92ZXJsYXkgfSBmcm9tICcuLi8uLi9jb250ZXh0L292ZXJsYXlDb250ZXh0LmpzJ1xuaW1wb3J0IHsgQm94LCBUZXh0IH0gZnJvbSAnLi4vLi4vaW5rLmpzJ1xuaW1wb3J0IHsgdXNlS2V5YmluZGluZ3MgfSBmcm9tICcuLi8uLi9rZXliaW5kaW5ncy91c2VLZXliaW5kaW5nLmpzJ1xuaW1wb3J0IHtcbiAgdHlwZSBBbmFseXRpY3NNZXRhZGF0YV9JX1ZFUklGSUVEX1RISVNfSVNfTk9UX0NPREVfT1JfRklMRVBBVEhTLFxuICBsb2dFdmVudCxcbn0gZnJvbSAnLi4vLi4vc2VydmljZXMvYW5hbHl0aWNzL2luZGV4LmpzJ1xuaW1wb3J0IHsgdXNlQXBwU3RhdGUsIHVzZVNldEFwcFN0YXRlIH0gZnJvbSAnLi4vLi4vc3RhdGUvQXBwU3RhdGUuanMnXG5pbXBvcnQgdHlwZSB7IFRvb2xVc2VDb250ZXh0IH0gZnJvbSAnLi4vLi4vVG9vbC5qcydcbmltcG9ydCB0eXBlIHtcbiAgTG9jYWxKU1hDb21tYW5kQ29udGV4dCxcbiAgTG9jYWxKU1hDb21tYW5kT25Eb25lLFxufSBmcm9tICcuLi8uLi90eXBlcy9jb21tYW5kLmpzJ1xuaW1wb3J0IHsgbG9nRm9yRGVidWdnaW5nIH0gZnJvbSAnLi4vLi4vdXRpbHMvZGVidWcuanMnXG5cbnR5cGUgUHJvcHMgPSB7XG4gIG9uRG9uZTogTG9jYWxKU1hDb21tYW5kT25Eb25lXG4gIG5hbWU/OiBzdHJpbmdcbn1cblxuLyoqXG4gKiAvcmVtb3RlLWNvbnRyb2wgY29tbWFuZCDigJQgbWFuYWdlcyB0aGUgYmlkaXJlY3Rpb25hbCBicmlkZ2UgY29ubmVjdGlvbi5cbiAqXG4gKiBXaGVuIGVuYWJsZWQsIHNldHMgcmVwbEJyaWRnZUVuYWJsZWQgaW4gQXBwU3RhdGUsIHdoaWNoIHRyaWdnZXJzXG4gKiB1c2VSZXBsQnJpZGdlIGluIFJFUEwudHN4IHRvIGluaXRpYWxpemUgdGhlIGJyaWRnZSBjb25uZWN0aW9uLlxuICogVGhlIGJyaWRnZSByZWdpc3RlcnMgYW4gZW52aXJvbm1lbnQsIGNyZWF0ZXMgYSBzZXNzaW9uIHdpdGggdGhlIGN1cnJlbnRcbiAqIGNvbnZlcnNhdGlvbiwgcG9sbHMgZm9yIHdvcmssIGFuZCBjb25uZWN0cyBhbiBpbmdyZXNzIFdlYlNvY2tldCBmb3JcbiAqIGJpZGlyZWN0aW9uYWwgbWVzc2FnaW5nIGJldHdlZW4gdGhlIENMSSBhbmQgY2xhdWRlLmFpLlxuICpcbiAqIFJ1bm5pbmcgL3JlbW90ZS1jb250cm9sIHdoZW4gYWxyZWFkeSBjb25uZWN0ZWQgc2hvd3MgYSBkaWFsb2cgd2l0aCB0aGUgc2Vzc2lvblxuICogVVJMIGFuZCBvcHRpb25zIHRvIGRpc2Nvbm5lY3Qgb3IgY29udGludWUuXG4gKi9cbmZ1bmN0aW9uIEJyaWRnZVRvZ2dsZSh7IG9uRG9uZSwgbmFtZSB9OiBQcm9wcyk6IFJlYWN0LlJlYWN0Tm9kZSB7XG4gIGNvbnN0IHNldEFwcFN0YXRlID0gdXNlU2V0QXBwU3RhdGUoKVxuICBjb25zdCByZXBsQnJpZGdlQ29ubmVjdGVkID0gdXNlQXBwU3RhdGUocyA9PiBzLnJlcGxCcmlkZ2VDb25uZWN0ZWQpXG4gIGNvbnN0IHJlcGxCcmlkZ2VFbmFibGVkID0gdXNlQXBwU3RhdGUocyA9PiBzLnJlcGxCcmlkZ2VFbmFibGVkKVxuICBjb25zdCByZXBsQnJpZGdlT3V0Ym91bmRPbmx5ID0gdXNlQXBwU3RhdGUocyA9PiBzLnJlcGxCcmlkZ2VPdXRib3VuZE9ubHkpXG4gIGNvbnN0IFtzaG93RGlzY29ubmVjdERpYWxvZywgc2V0U2hvd0Rpc2Nvbm5lY3REaWFsb2ddID0gdXNlU3RhdGUoZmFsc2UpXG5cbiAgLy8gYmlvbWUtaWdub3JlIGxpbnQvY29ycmVjdG5lc3MvdXNlRXhoYXVzdGl2ZURlcGVuZGVuY2llczogYnJpZGdlIHN0YXJ0cyBvbmNlLCBzaG91bGQgbm90IHJlc3RhcnQgb24gc3RhdGUgY2hhbmdlc1xuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIC8vIElmIGFscmVhZHkgY29ubmVjdGVkIG9yIGVuYWJsZWQgaW4gZnVsbCBiaWRpcmVjdGlvbmFsIG1vZGUsIHNob3dcbiAgICAvLyBkaXNjb25uZWN0IGNvbmZpcm1hdGlvbi4gT3V0Ym91bmQtb25seSAoQ0NSIG1pcnJvcikgZG9lc24ndCBjb3VudCDigJRcbiAgICAvLyAvcmVtb3RlLWNvbnRyb2wgdXBncmFkZXMgaXQgdG8gZnVsbCBSQyBpbnN0ZWFkLlxuICAgIGlmICgocmVwbEJyaWRnZUNvbm5lY3RlZCB8fCByZXBsQnJpZGdlRW5hYmxlZCkgJiYgIXJlcGxCcmlkZ2VPdXRib3VuZE9ubHkpIHtcbiAgICAgIHNldFNob3dEaXNjb25uZWN0RGlhbG9nKHRydWUpXG4gICAgICByZXR1cm5cbiAgICB9XG5cbiAgICBsZXQgY2FuY2VsbGVkID0gZmFsc2VcbiAgICB2b2lkIChhc3luYyAoKSA9PiB7XG4gICAgICAvLyBQcmUtZmxpZ2h0IGNoZWNrcyBiZWZvcmUgZW5hYmxpbmcgKGF3YWl0cyBHcm93dGhCb29rIGluaXQgaWYgZGlza1xuICAgICAgLy8gY2FjaGUgaXMgc3RhbGUg4oCUIHNvIE1heCB1c2VycyBkb24ndCBnZXQgYSBmYWxzZSBcIm5vdCBlbmFibGVkXCIgZXJyb3IpXG4gICAgICBjb25zdCBlcnJvciA9IGF3YWl0IGNoZWNrQnJpZGdlUHJlcmVxdWlzaXRlcygpXG4gICAgICBpZiAoY2FuY2VsbGVkKSByZXR1cm5cbiAgICAgIGlmIChlcnJvcikge1xuICAgICAgICBsb2dFdmVudCgndGVuZ3VfYnJpZGdlX2NvbW1hbmQnLCB7XG4gICAgICAgICAgYWN0aW9uOlxuICAgICAgICAgICAgJ3ByZWZsaWdodF9mYWlsZWQnIGFzIEFuYWx5dGljc01ldGFkYXRhX0lfVkVSSUZJRURfVEhJU19JU19OT1RfQ09ERV9PUl9GSUxFUEFUSFMsXG4gICAgICAgIH0pXG4gICAgICAgIG9uRG9uZShlcnJvciwgeyBkaXNwbGF5OiAnc3lzdGVtJyB9KVxuICAgICAgICByZXR1cm5cbiAgICAgIH1cblxuICAgICAgLy8gU2hvdyBmaXJzdC10aW1lIHJlbW90ZSBkaWFsb2cgaWYgbm90IHlldCBzZWVuLlxuICAgICAgLy8gU3RvcmUgdGhlIG5hbWUgbm93IHNvIGl0J3MgaW4gQXBwU3RhdGUgd2hlbiB0aGUgY2FsbG91dCBoYW5kbGVyIGxhdGVyXG4gICAgICAvLyBlbmFibGVzIHRoZSBicmlkZ2UgKHRoZSBoYW5kbGVyIG9ubHkgc2V0cyByZXBsQnJpZGdlRW5hYmxlZCwgbm90IHRoZSBuYW1lKS5cbiAgICAgIGlmIChzaG91bGRTaG93UmVtb3RlQ2FsbG91dCgpKSB7XG4gICAgICAgIHNldEFwcFN0YXRlKHByZXYgPT4ge1xuICAgICAgICAgIGlmIChwcmV2LnNob3dSZW1vdGVDYWxsb3V0KSByZXR1cm4gcHJldlxuICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICAuLi5wcmV2LFxuICAgICAgICAgICAgc2hvd1JlbW90ZUNhbGxvdXQ6IHRydWUsXG4gICAgICAgICAgICByZXBsQnJpZGdlSW5pdGlhbE5hbWU6IG5hbWUsXG4gICAgICAgICAgfVxuICAgICAgICB9KVxuICAgICAgICBvbkRvbmUoJycsIHsgZGlzcGxheTogJ3N5c3RlbScgfSlcbiAgICAgICAgcmV0dXJuXG4gICAgICB9XG5cbiAgICAgIC8vIEVuYWJsZSB0aGUgYnJpZGdlIOKAlCB1c2VSZXBsQnJpZGdlIGluIFJFUEwudHN4IGhhbmRsZXMgdGhlIHJlc3Q6XG4gICAgICAvLyByZWdpc3RlcnMgZW52aXJvbm1lbnQsIGNyZWF0ZXMgc2Vzc2lvbiB3aXRoIGNvbnZlcnNhdGlvbiwgY29ubmVjdHMgV2ViU29ja2V0XG4gICAgICBsb2dFdmVudCgndGVuZ3VfYnJpZGdlX2NvbW1hbmQnLCB7XG4gICAgICAgIGFjdGlvbjpcbiAgICAgICAgICAnY29ubmVjdCcgYXMgQW5hbHl0aWNzTWV0YWRhdGFfSV9WRVJJRklFRF9USElTX0lTX05PVF9DT0RFX09SX0ZJTEVQQVRIUyxcbiAgICAgIH0pXG4gICAgICBzZXRBcHBTdGF0ZShwcmV2ID0+IHtcbiAgICAgICAgaWYgKHByZXYucmVwbEJyaWRnZUVuYWJsZWQgJiYgIXByZXYucmVwbEJyaWRnZU91dGJvdW5kT25seSkgcmV0dXJuIHByZXZcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAuLi5wcmV2LFxuICAgICAgICAgIHJlcGxCcmlkZ2VFbmFibGVkOiB0cnVlLFxuICAgICAgICAgIHJlcGxCcmlkZ2VFeHBsaWNpdDogdHJ1ZSxcbiAgICAgICAgICByZXBsQnJpZGdlT3V0Ym91bmRPbmx5OiBmYWxzZSxcbiAgICAgICAgICByZXBsQnJpZGdlSW5pdGlhbE5hbWU6IG5hbWUsXG4gICAgICAgIH1cbiAgICAgIH0pXG4gICAgICBvbkRvbmUoJ1JlbW90ZSBDb250cm9sIGNvbm5lY3RpbmdcXHUyMDI2Jywge1xuICAgICAgICBkaXNwbGF5OiAnc3lzdGVtJyxcbiAgICAgIH0pXG4gICAgfSkoKVxuXG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgIGNhbmNlbGxlZCA9IHRydWVcbiAgICB9XG4gIH0sIFtdKSAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIHJlYWN0LWhvb2tzL2V4aGF1c3RpdmUtZGVwcyAtLSBydW4gb25jZSBvbiBtb3VudFxuXG4gIGlmIChzaG93RGlzY29ubmVjdERpYWxvZykge1xuICAgIHJldHVybiA8QnJpZGdlRGlzY29ubmVjdERpYWxvZyBvbkRvbmU9e29uRG9uZX0gLz5cbiAgfVxuXG4gIHJldHVybiBudWxsXG59XG5cbi8qKlxuICogRGlhbG9nIHNob3duIHdoZW4gL3JlbW90ZS1jb250cm9sIGlzIHVzZWQgd2hpbGUgdGhlIGJyaWRnZSBpcyBhbHJlYWR5IGNvbm5lY3RlZC5cbiAqIFNob3dzIHRoZSBzZXNzaW9uIFVSTCBhbmQgbGV0cyB0aGUgdXNlciBkaXNjb25uZWN0IG9yIGNvbnRpbnVlLlxuICovXG5mdW5jdGlvbiBCcmlkZ2VEaXNjb25uZWN0RGlhbG9nKHsgb25Eb25lIH06IFByb3BzKTogUmVhY3QuUmVhY3ROb2RlIHtcbiAgdXNlUmVnaXN0ZXJPdmVybGF5KCdicmlkZ2UtZGlzY29ubmVjdC1kaWFsb2cnKVxuICBjb25zdCBzZXRBcHBTdGF0ZSA9IHVzZVNldEFwcFN0YXRlKClcbiAgY29uc3Qgc2Vzc2lvblVybCA9IHVzZUFwcFN0YXRlKHMgPT4gcy5yZXBsQnJpZGdlU2Vzc2lvblVybClcbiAgY29uc3QgY29ubmVjdFVybCA9IHVzZUFwcFN0YXRlKHMgPT4gcy5yZXBsQnJpZGdlQ29ubmVjdFVybClcbiAgY29uc3Qgc2Vzc2lvbkFjdGl2ZSA9IHVzZUFwcFN0YXRlKHMgPT4gcy5yZXBsQnJpZGdlU2Vzc2lvbkFjdGl2ZSlcbiAgY29uc3QgW2ZvY3VzSW5kZXgsIHNldEZvY3VzSW5kZXhdID0gdXNlU3RhdGUoMilcbiAgY29uc3QgW3Nob3dRUiwgc2V0U2hvd1FSXSA9IHVzZVN0YXRlKGZhbHNlKVxuICBjb25zdCBbcXJUZXh0LCBzZXRRclRleHRdID0gdXNlU3RhdGUoJycpXG5cbiAgY29uc3QgZGlzcGxheVVybCA9IHNlc3Npb25BY3RpdmUgPyBzZXNzaW9uVXJsIDogY29ubmVjdFVybFxuXG4gIC8vIEdlbmVyYXRlIFFSIGNvZGUgd2hlbiBVUkwgY2hhbmdlcyBvciBRUiBpcyB0b2dnbGVkIG9uXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKCFzaG93UVIgfHwgIWRpc3BsYXlVcmwpIHtcbiAgICAgIHNldFFyVGV4dCgnJylcbiAgICAgIHJldHVyblxuICAgIH1cbiAgICBxclRvU3RyaW5nKGRpc3BsYXlVcmwsIHtcbiAgICAgIHR5cGU6ICd1dGY4JyxcbiAgICAgIGVycm9yQ29ycmVjdGlvbkxldmVsOiAnTCcsXG4gICAgICBzbWFsbDogdHJ1ZSxcbiAgICB9KVxuICAgICAgLnRoZW4oc2V0UXJUZXh0KVxuICAgICAgLmNhdGNoKCgpID0+IHNldFFyVGV4dCgnJykpXG4gIH0sIFtzaG93UVIsIGRpc3BsYXlVcmxdKVxuXG4gIGZ1bmN0aW9uIGhhbmRsZURpc2Nvbm5lY3QoKTogdm9pZCB7XG4gICAgc2V0QXBwU3RhdGUocHJldiA9PiB7XG4gICAgICBpZiAoIXByZXYucmVwbEJyaWRnZUVuYWJsZWQpIHJldHVybiBwcmV2XG4gICAgICByZXR1cm4ge1xuICAgICAgICAuLi5wcmV2LFxuICAgICAgICByZXBsQnJpZGdlRW5hYmxlZDogZmFsc2UsXG4gICAgICAgIHJlcGxCcmlkZ2VFeHBsaWNpdDogZmFsc2UsXG4gICAgICAgIHJlcGxCcmlkZ2VPdXRib3VuZE9ubHk6IGZhbHNlLFxuICAgICAgfVxuICAgIH0pXG4gICAgbG9nRXZlbnQoJ3Rlbmd1X2JyaWRnZV9jb21tYW5kJywge1xuICAgICAgYWN0aW9uOlxuICAgICAgICAnZGlzY29ubmVjdCcgYXMgQW5hbHl0aWNzTWV0YWRhdGFfSV9WRVJJRklFRF9USElTX0lTX05PVF9DT0RFX09SX0ZJTEVQQVRIUyxcbiAgICB9KVxuICAgIG9uRG9uZShSRU1PVEVfQ09OVFJPTF9ESVNDT05ORUNURURfTVNHLCB7IGRpc3BsYXk6ICdzeXN0ZW0nIH0pXG4gIH1cblxuICBmdW5jdGlvbiBoYW5kbGVTaG93UVIoKTogdm9pZCB7XG4gICAgc2V0U2hvd1FSKHByZXYgPT4gIXByZXYpXG4gIH1cblxuICBmdW5jdGlvbiBoYW5kbGVDb250aW51ZSgpOiB2b2lkIHtcbiAgICBvbkRvbmUodW5kZWZpbmVkLCB7IGRpc3BsYXk6ICdza2lwJyB9KVxuICB9XG5cbiAgY29uc3QgSVRFTV9DT1VOVCA9IDNcblxuICB1c2VLZXliaW5kaW5ncyhcbiAgICB7XG4gICAgICAnc2VsZWN0Om5leHQnOiAoKSA9PiBzZXRGb2N1c0luZGV4KGkgPT4gKGkgKyAxKSAlIElURU1fQ09VTlQpLFxuICAgICAgJ3NlbGVjdDpwcmV2aW91cyc6ICgpID0+XG4gICAgICAgIHNldEZvY3VzSW5kZXgoaSA9PiAoaSAtIDEgKyBJVEVNX0NPVU5UKSAlIElURU1fQ09VTlQpLFxuICAgICAgJ3NlbGVjdDphY2NlcHQnOiAoKSA9PiB7XG4gICAgICAgIGlmIChmb2N1c0luZGV4ID09PSAwKSB7XG4gICAgICAgICAgaGFuZGxlRGlzY29ubmVjdCgpXG4gICAgICAgIH0gZWxzZSBpZiAoZm9jdXNJbmRleCA9PT0gMSkge1xuICAgICAgICAgIGhhbmRsZVNob3dRUigpXG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgaGFuZGxlQ29udGludWUoKVxuICAgICAgICB9XG4gICAgICB9LFxuICAgIH0sXG4gICAgeyBjb250ZXh0OiAnU2VsZWN0JyB9LFxuICApXG5cbiAgY29uc3QgcXJMaW5lcyA9IHFyVGV4dCA/IHFyVGV4dC5zcGxpdCgnXFxuJykuZmlsdGVyKGwgPT4gbC5sZW5ndGggPiAwKSA6IFtdXG5cbiAgcmV0dXJuIChcbiAgICA8RGlhbG9nIHRpdGxlPVwiUmVtb3RlIENvbnRyb2xcIiBvbkNhbmNlbD17aGFuZGxlQ29udGludWV9IGhpZGVJbnB1dEd1aWRlPlxuICAgICAgPEJveCBmbGV4RGlyZWN0aW9uPVwiY29sdW1uXCIgZ2FwPXsxfT5cbiAgICAgICAgPFRleHQ+XG4gICAgICAgICAgVGhpcyBzZXNzaW9uIGlzIGF2YWlsYWJsZSB2aWEgUmVtb3RlIENvbnRyb2xcbiAgICAgICAgICB7ZGlzcGxheVVybCA/IGAgYXQgJHtkaXNwbGF5VXJsfWAgOiAnJ30uXG4gICAgICAgIDwvVGV4dD5cbiAgICAgICAge3Nob3dRUiAmJiBxckxpbmVzLmxlbmd0aCA+IDAgJiYgKFxuICAgICAgICAgIDxCb3ggZmxleERpcmVjdGlvbj1cImNvbHVtblwiPlxuICAgICAgICAgICAge3FyTGluZXMubWFwKChsaW5lLCBpKSA9PiAoXG4gICAgICAgICAgICAgIDxUZXh0IGtleT17aX0+e2xpbmV9PC9UZXh0PlxuICAgICAgICAgICAgKSl9XG4gICAgICAgICAgPC9Cb3g+XG4gICAgICAgICl9XG4gICAgICAgIDxCb3ggZmxleERpcmVjdGlvbj1cImNvbHVtblwiPlxuICAgICAgICAgIDxMaXN0SXRlbSBpc0ZvY3VzZWQ9e2ZvY3VzSW5kZXggPT09IDB9PlxuICAgICAgICAgICAgPFRleHQ+RGlzY29ubmVjdCB0aGlzIHNlc3Npb248L1RleHQ+XG4gICAgICAgICAgPC9MaXN0SXRlbT5cbiAgICAgICAgICA8TGlzdEl0ZW0gaXNGb2N1c2VkPXtmb2N1c0luZGV4ID09PSAxfT5cbiAgICAgICAgICAgIDxUZXh0PntzaG93UVIgPyAnSGlkZSBRUiBjb2RlJyA6ICdTaG93IFFSIGNvZGUnfTwvVGV4dD5cbiAgICAgICAgICA8L0xpc3RJdGVtPlxuICAgICAgICAgIDxMaXN0SXRlbSBpc0ZvY3VzZWQ9e2ZvY3VzSW5kZXggPT09IDJ9PlxuICAgICAgICAgICAgPFRleHQ+Q29udGludWU8L1RleHQ+XG4gICAgICAgICAgPC9MaXN0SXRlbT5cbiAgICAgICAgPC9Cb3g+XG4gICAgICAgIDxUZXh0IGRpbUNvbG9yPkVudGVyIHRvIHNlbGVjdCDCtyBFc2MgdG8gY29udGludWU8L1RleHQ+XG4gICAgICA8L0JveD5cbiAgICA8L0RpYWxvZz5cbiAgKVxufVxuXG4vKipcbiAqIENoZWNrIGJyaWRnZSBwcmVyZXF1aXNpdGVzLiBSZXR1cm5zIGFuIGVycm9yIG1lc3NhZ2UgaWYgYSBwcmVjb25kaXRpb25cbiAqIGZhaWxzLCBvciBudWxsIGlmIGFsbCBjaGVja3MgcGFzcy4gQXdhaXRzIEdyb3d0aEJvb2sgaW5pdCBpZiB0aGUgZGlza1xuICogY2FjaGUgaXMgc3RhbGUsIHNvIGEgdXNlciB3aG8ganVzdCBiZWNhbWUgZW50aXRsZWQgKGUuZy4gdXBncmFkZWQgdG8gTWF4LFxuICogb3IgdGhlIGZsYWcganVzdCBsYXVuY2hlZCkgZ2V0cyBhbiBhY2N1cmF0ZSByZXN1bHQgb24gdGhlIGZpcnN0IHRyeS5cbiAqL1xuYXN5bmMgZnVuY3Rpb24gY2hlY2tCcmlkZ2VQcmVyZXF1aXNpdGVzKCk6IFByb21pc2U8c3RyaW5nIHwgbnVsbD4ge1xuICAvLyBDaGVjayBvcmdhbml6YXRpb24gcG9saWN5IOKAlCByZW1vdGUgY29udHJvbCBtYXkgYmUgZGlzYWJsZWRcbiAgY29uc3QgeyB3YWl0Rm9yUG9saWN5TGltaXRzVG9Mb2FkLCBpc1BvbGljeUFsbG93ZWQgfSA9IGF3YWl0IGltcG9ydChcbiAgICAnLi4vLi4vc2VydmljZXMvcG9saWN5TGltaXRzL2luZGV4LmpzJ1xuICApXG4gIGF3YWl0IHdhaXRGb3JQb2xpY3lMaW1pdHNUb0xvYWQoKVxuICBpZiAoIWlzUG9saWN5QWxsb3dlZCgnYWxsb3dfcmVtb3RlX2NvbnRyb2wnKSkge1xuICAgIHJldHVybiBcIlJlbW90ZSBDb250cm9sIGlzIGRpc2FibGVkIGJ5IHlvdXIgb3JnYW5pemF0aW9uJ3MgcG9saWN5LlwiXG4gIH1cblxuICBjb25zdCBkaXNhYmxlZFJlYXNvbiA9IGF3YWl0IGdldEJyaWRnZURpc2FibGVkUmVhc29uKClcbiAgaWYgKGRpc2FibGVkUmVhc29uKSB7XG4gICAgcmV0dXJuIGRpc2FibGVkUmVhc29uXG4gIH1cblxuICAvLyBNaXJyb3IgdGhlIHYxL3YyIGJyYW5jaGluZyBsb2dpYyBpbiBpbml0UmVwbEJyaWRnZTogZW52LWxlc3MgKHYyKSBpcyB1c2VkXG4gIC8vIG9ubHkgd2hlbiB0aGUgZmxhZyBpcyBvbiBBTkQgdGhlIHNlc3Npb24gaXMgbm90IHBlcnBldHVhbC4gIEluIGFzc2lzdGFudFxuICAvLyBtb2RlIChLQUlST1MpIHVzZVJlcGxCcmlkZ2Ugc2V0cyBwZXJwZXR1YWw9dHJ1ZSwgd2hpY2ggZm9yY2VzXG4gIC8vIGluaXRSZXBsQnJpZGdlIG9udG8gdGhlIHYxIHBhdGgg4oCUIHNvIHRoZSBwcmVyZXF1aXNpdGUgY2hlY2sgbXVzdCBtYXRjaC5cbiAgbGV0IHVzZVYyID0gaXNFbnZMZXNzQnJpZGdlRW5hYmxlZCgpXG4gIGlmIChmZWF0dXJlKCdLQUlST1MnKSAmJiB1c2VWMikge1xuICAgIGNvbnN0IHsgaXNBc3Npc3RhbnRNb2RlIH0gPSBhd2FpdCBpbXBvcnQoJy4uLy4uL2Fzc2lzdGFudC9pbmRleC5qcycpXG4gICAgaWYgKGlzQXNzaXN0YW50TW9kZSgpKSB7XG4gICAgICB1c2VWMiA9IGZhbHNlXG4gICAgfVxuICB9XG4gIGNvbnN0IHZlcnNpb25FcnJvciA9IHVzZVYyXG4gICAgPyBhd2FpdCBjaGVja0Vudkxlc3NCcmlkZ2VNaW5WZXJzaW9uKClcbiAgICA6IGNoZWNrQnJpZGdlTWluVmVyc2lvbigpXG4gIGlmICh2ZXJzaW9uRXJyb3IpIHtcbiAgICByZXR1cm4gdmVyc2lvbkVycm9yXG4gIH1cblxuICBpZiAoIWdldEJyaWRnZUFjY2Vzc1Rva2VuKCkpIHtcbiAgICByZXR1cm4gQlJJREdFX0xPR0lOX0lOU1RSVUNUSU9OXG4gIH1cblxuICBsb2dGb3JEZWJ1Z2dpbmcoJ1ticmlkZ2VdIFByZXJlcXVpc2l0ZXMgcGFzc2VkLCBlbmFibGluZyBicmlkZ2UnKVxuICByZXR1cm4gbnVsbFxufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gY2FsbChcbiAgb25Eb25lOiBMb2NhbEpTWENvbW1hbmRPbkRvbmUsXG4gIF9jb250ZXh0OiBUb29sVXNlQ29udGV4dCAmIExvY2FsSlNYQ29tbWFuZENvbnRleHQsXG4gIGFyZ3M6IHN0cmluZyxcbik6IFByb21pc2U8UmVhY3QuUmVhY3ROb2RlPiB7XG4gIGNvbnN0IG5hbWUgPSBhcmdzLnRyaW0oKSB8fCB1bmRlZmluZWRcbiAgcmV0dXJuIDxCcmlkZ2VUb2dnbGUgb25Eb25lPXtvbkRvbmV9IG5hbWU9e25hbWV9IC8+XG59XG4iXSwibWFwcGluZ3MiOiI7QUFBQSxTQUFTQSxPQUFPLFFBQVEsWUFBWTtBQUNwQyxTQUFTQyxRQUFRLElBQUlDLFVBQVUsUUFBUSxRQUFRO0FBQy9DLE9BQU8sS0FBS0MsS0FBSyxNQUFNLE9BQU87QUFDOUIsU0FBU0MsU0FBUyxFQUFFQyxRQUFRLFFBQVEsT0FBTztBQUMzQyxTQUFTQyxvQkFBb0IsUUFBUSw4QkFBOEI7QUFDbkUsU0FDRUMscUJBQXFCLEVBQ3JCQyx1QkFBdUIsRUFDdkJDLHNCQUFzQixRQUNqQiwrQkFBK0I7QUFDdEMsU0FBU0MsNEJBQTRCLFFBQVEscUNBQXFDO0FBQ2xGLFNBQ0VDLHdCQUF3QixFQUN4QkMsK0JBQStCLFFBQzFCLHVCQUF1QjtBQUM5QixTQUFTQyxNQUFNLFFBQVEsMENBQTBDO0FBQ2pFLFNBQVNDLFFBQVEsUUFBUSw0Q0FBNEM7QUFDckUsU0FBU0MsdUJBQXVCLFFBQVEsbUNBQW1DO0FBQzNFLFNBQVNDLGtCQUFrQixRQUFRLGlD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 + diff --git a/src/commands/bridge/index.ts b/src/commands/bridge/index.ts index e4f08f3..7a7a85e 100644 --- a/src/commands/bridge/index.ts +++ b/src/commands/bridge/index.ts @@ -25,3 +25,4 @@ const bridge = { export default bridge + diff --git a/src/commands/bughunter/index.js b/src/commands/bughunter/index.js index 9627ea7..01e6d3f 100644 --- a/src/commands/bughunter/index.js +++ b/src/commands/bughunter/index.js @@ -1,2 +1,3 @@ export default { isEnabled: () => false, isHidden: true, name: 'stub' }; + diff --git a/src/commands/clear/clear.ts b/src/commands/clear/clear.ts index edd8951..e197ec2 100644 --- a/src/commands/clear/clear.ts +++ b/src/commands/clear/clear.ts @@ -6,3 +6,4 @@ export const call: LocalCommandCall = async (_, context) => { return { type: 'text', value: '' } } + diff --git a/src/commands/commit.ts b/src/commands/commit.ts index eb092ad..072ed9a 100644 --- a/src/commands/commit.ts +++ b/src/commands/commit.ts @@ -91,3 +91,4 @@ const command = { export default command + diff --git a/src/commands/compact/index.ts b/src/commands/compact/index.ts index 60f28a9..0904834 100644 --- a/src/commands/compact/index.ts +++ b/src/commands/compact/index.ts @@ -14,3 +14,4 @@ const compact = { export default compact + diff --git a/src/commands/config/config.tsx b/src/commands/config/config.tsx index 253c428..f32ba54 100644 --- a/src/commands/config/config.tsx +++ b/src/commands/config/config.tsx @@ -5,3 +5,4 @@ export const call: LocalJSXCommandCall = async (onDone, context) => { return ; }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsIlNldHRpbmdzIiwiTG9jYWxKU1hDb21tYW5kQ2FsbCIsImNhbGwiLCJvbkRvbmUiLCJjb250ZXh0Il0sInNvdXJjZXMiOlsiY29uZmlnLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFNldHRpbmdzIH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9TZXR0aW5ncy9TZXR0aW5ncy5qcydcbmltcG9ydCB0eXBlIHsgTG9jYWxKU1hDb21tYW5kQ2FsbCB9IGZyb20gJy4uLy4uL3R5cGVzL2NvbW1hbmQuanMnXG5cbmV4cG9ydCBjb25zdCBjYWxsOiBMb2NhbEpTWENvbW1hbmRDYWxsID0gYXN5bmMgKG9uRG9uZSwgY29udGV4dCkgPT4ge1xuICByZXR1cm4gPFNldHRpbmdzIG9uQ2xvc2U9e29uRG9uZX0gY29udGV4dD17Y29udGV4dH0gZGVmYXVsdFRhYj1cIkNvbmZpZ1wiIC8+XG59XG4iXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBS0EsS0FBSyxNQUFNLE9BQU87QUFDOUIsU0FBU0MsUUFBUSxRQUFRLHVDQUF1QztBQUNoRSxjQUFjQyxtQkFBbUIsUUFBUSx3QkFBd0I7QUFFakUsT0FBTyxNQUFNQyxJQUFJLEVBQUVELG1CQUFtQixHQUFHLE1BQUFDLENBQU9DLE1BQU0sRUFBRUMsT0FBTyxLQUFLO0VBQ2xFLE9BQU8sQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUNELE1BQU0sQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDQyxPQUFPLENBQUMsQ0FBQyxVQUFVLENBQUMsUUFBUSxHQUFHO0FBQzVFLENBQUMiLCJpZ25vcmVMaXN0IjpbXX0= + diff --git a/src/commands/context/context.tsx b/src/commands/context/context.tsx index 05e95a9..394acf5 100644 --- a/src/commands/context/context.tsx +++ b/src/commands/context/context.tsx @@ -62,3 +62,4 @@ export async function call(onDone: LocalJSXCommandOnDone, context: LocalJSXComma return null; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJmZWF0dXJlIiwiUmVhY3QiLCJMb2NhbEpTWENvbW1hbmRDb250ZXh0IiwiQ29udGV4dFZpc3VhbGl6YXRpb24iLCJtaWNyb2NvbXBhY3RNZXNzYWdlcyIsIkxvY2FsSlNYQ29tbWFuZE9uRG9uZSIsIk1lc3NhZ2UiLCJhbmFseXplQ29udGV4dFVzYWdlIiwiZ2V0TWVzc2FnZXNBZnRlckNvbXBhY3RCb3VuZGFyeSIsInJlbmRlclRvQW5zaVN0cmluZyIsInRvQXBpVmlldyIsIm1lc3NhZ2VzIiwidmlldyIsInByb2plY3RWaWV3IiwicmVxdWlyZSIsImNhbGwiLCJvbkRvbmUiLCJjb250ZXh0IiwiUHJvbWlzZSIsIlJlYWN0Tm9kZSIsImdldEFwcFN0YXRlIiwib3B0aW9ucyIsIm1haW5Mb29wTW9kZWwiLCJ0b29scyIsImFwaVZpZXciLCJjb21wYWN0ZWRNZXNzYWdlcyIsInRlcm1pbmFsV2lkdGgiLCJwcm9jZXNzIiwic3Rkb3V0IiwiY29sdW1ucyIsImFwcFN0YXRlIiwiZGF0YSIsInRvb2xQZXJtaXNzaW9uQ29udGV4dCIsImFnZW50RGVmaW5pdGlvbnMiLCJ1bmRlZmluZWQiLCJvdXRwdXQiXSwic291cmNlcyI6WyJjb250ZXh0LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmZWF0dXJlIH0gZnJvbSAnYnVuOmJ1bmRsZSdcbmltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHR5cGUgeyBMb2NhbEpTWENvbW1hbmRDb250ZXh0IH0gZnJvbSAnLi4vLi4vY29tbWFuZHMuanMnXG5pbXBvcnQgeyBDb250ZXh0VmlzdWFsaXphdGlvbiB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMvQ29udGV4dFZpc3VhbGl6YXRpb24uanMnXG5pbXBvcnQgeyBtaWNyb2NvbXBhY3RNZXNzYWdlcyB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL2NvbXBhY3QvbWljcm9Db21wYWN0LmpzJ1xuaW1wb3J0IHR5cGUgeyBMb2NhbEpTWENvbW1hbmRPbkRvbmUgfSBmcm9tICcuLi8uLi90eXBlcy9jb21tYW5kLmpzJ1xuaW1wb3J0IHR5cGUgeyBNZXNzYWdlIH0gZnJvbSAnLi4vLi4vdHlwZXMvbWVzc2FnZS5qcydcbmltcG9ydCB7IGFuYWx5emVDb250ZXh0VXNhZ2UgfSBmcm9tICcuLi8uLi91dGlscy9hbmFseXplQ29udGV4dC5qcydcbmltcG9ydCB7IGdldE1lc3NhZ2VzQWZ0ZXJDb21wYWN0Qm91bmRhcnkgfSBmcm9tICcuLi8uLi91dGlscy9tZXNzYWdlcy5qcydcbmltcG9ydCB7IHJlbmRlclRvQW5zaVN0cmluZyB9IGZyb20gJy4uLy4uL3V0aWxzL3N0YXRpY1JlbmRlci5qcydcblxuLyoqXG4gKiBBcHBseSB0aGUgc2FtZSBjb250ZXh0IHRyYW5zZm9ybXMgcXVlcnkudHMgZG9lcyBiZWZvcmUgdGhlIEFQSSBjYWxsLCBzb1xuICogL2NvbnRleHQgc2hvd3Mgd2hhdCB0aGUgbW9kZWwgYWN0dWFsbHkgc2VlcyByYXRoZXIgdGhhbiB0aGUgUkVQTCdzIHJhd1xuICogaGlzdG9yeS4gV2l0aG91dCBwcm9qZWN0VmlldyB0aGUgdG9rZW4gY291bnQgb3ZlcmNvdW50cyBieSBob3dldmVyIG11Y2hcbiAqIHdhcyBjb2xsYXBzZWQg4oCUIHVzZXIgc2VlcyBcIjE4MGssIDMgc3BhbnMgY29sbGFwc2VkXCIgd2hlbiB0aGUgQVBJIHNlZXMgMTIway5cbiAqL1xuZnVuY3Rpb24gdG9BcGlWaWV3KG1lc3NhZ2VzOiBNZXNzYWdlW10pOiBNZXNzYWdlW10ge1xuICBsZXQgdmlldyA9IGdldE1lc3NhZ2VzQWZ0ZXJDb21wYWN0Qm91bmRhcnkobWVzc2FnZXMpXG4gIGlmIChmZWF0dXJlKCdDT05URVhUX0NPTExBUFNFJykpIHtcbiAgICAvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tcmVxdWlyZS1pbXBvcnRzICovXG4gICAgY29uc3QgeyBwcm9qZWN0VmlldyB9ID1cbiAgICAgIHJlcXVpcmUoJy4uLy4uL3NlcnZpY2VzL2NvbnRleHRDb2xsYXBzZS9vcGVyYXRpb25zLmpzJykgYXMgdHlwZW9mIGltcG9ydCgnLi4vLi4vc2VydmljZXMvY29udGV4dENvbGxhcHNlL29wZXJhdGlvbnMuanMnKVxuICAgIC8qIGVzbGludC1lbmFibGUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXJlcXVpcmUtaW1wb3J0cyAqL1xuICAgIHZpZXcgPSBwcm9qZWN0Vmlldyh2aWV3KVxuICB9XG4gIHJldHVybiB2aWV3XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBjYWxsKFxuICBvbkRvbmU6IExvY2FsSlNYQ29tbWFuZE9uRG9uZSxcbiAgY29udGV4dDogTG9jYWxKU1hDb21tYW5kQ29udGV4dCxcbik6IFByb21pc2U8UmVhY3QuUmVhY3ROb2RlPiB7XG4gIGNvbnN0IHtcbiAgICBtZXNzYWdlcyxcbiAgICBnZXRBcHBTdGF0ZSxcbiAgICBvcHRpb25zOiB7IG1haW5Mb29wTW9kZWwsIHRvb2xzIH0sXG4gIH0gPSBjb250ZXh0XG5cbiAgY29uc3QgYXBpVmlldyA9IHRvQXBpVmlldyhtZXNzYWdlcylcblxuICAvLyBBcHBseSBtaWNyb2NvbXBhY3QgdG8gZ2V0IGFjY3VyYXRlIHJlcHJlc2VudGF0aW9uIG9mIG1lc3NhZ2VzIHNlbnQgdG8gQVBJXG4gIGNvbnN0IHsgbWVzc2FnZXM6IGNvbXBhY3RlZE1lc3NhZ2VzIH0gPSBhd2FpdCBtaWNyb2NvbXBhY3RNZXNzYWdlcyhhcGlWaWV3KVxuXG4gIC8vIEdldCB0ZXJtaW5hbCB3aWR0aCBmb3IgcmVzcG9uc2l2ZSBzaXppbmdcbiAgY29uc3QgdGVybWluYWxXaWR0aCA9IHByb2Nlc3Muc3Rkb3V0LmNvbHVtbnMgfHwgODBcblxuICBjb25zdCBhcHBTdGF0ZSA9IGdldEFwcFN0YXRlKClcblxuICAvLyBBbmFseXplIGNvbnRleHQgd2l0aCBjb21wYWN0ZWQgbWVzc2FnZXNcbiAgLy8gUGFzcyBvcmlnaW5hbCBtZXNzYWdlcyBhcyBsYXN0IHBhcmFtZXRlciBmb3IgYWNjdXJhdGUgQVBJIHVzYWdlIGV4dHJhY3Rpb25cbiAgY29uc3QgZGF0YSA9IGF3YWl0IGFuYWx5emVDb250ZXh0VXNhZ2UoXG4gICAgY29tcGFjdGVkTWVzc2FnZXMsXG4gICAgbWFpbkxvb3BNb2RlbCxcbiAgICBhc3luYyAoKSA9PiBhcHBTdGF0ZS50b29sUGVybWlzc2lvbkNvbnRleHQsXG4gICAgdG9vbHMsXG4gICAgYXBwU3RhdGUuYWdlbnREZWZpbml0aW9ucyxcbiAgICB0ZXJtaW5hbFdpZHRoLFxuICAgIGNvbnRleHQsIC8vIFBhc3MgZnVsbCBjb250ZXh0IGZvciBzeXN0ZW0gcHJvbXB0IGNhbGN1bGF0aW9uXG4gICAgdW5kZWZpbmVkLCAvLyBtYWluVGhyZWFkQWdlbnREZWZpbml0aW9uXG4gICAgYXBpVmlldywgLy8gT3JpZ2luYWwgbWVzc2FnZXMgZm9yIEFQSSB1c2FnZSBleHRyYWN0aW9uXG4gIClcblxuICAvLyBSZW5kZXIgdG8gQU5TSSBzdHJpbmcgdG8gcHJlc2VydmUgY29sb3JzIGFuZCBwYXNzIHRvIG9uRG9uZSBsaWtlIGxvY2FsIGNvbW1hbmRzIGRvXG4gIGNvbnN0IG91dHB1dCA9IGF3YWl0IHJlbmRlclRvQW5zaVN0cmluZyg8Q29udGV4dFZpc3VhbGl6YXRpb24gZGF0YT17ZGF0YX0gLz4pXG4gIG9uRG9uZShvdXRwdXQpXG4gIHJldHVybiBudWxsXG59XG4iXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLE9BQU8sUUFBUSxZQUFZO0FBQ3BDLE9BQU8sS0FBS0MsS0FBSyxNQUFNLE9BQU87QUFDOUIsY0FBY0Msc0JBQXNCLFFBQVEsbUJBQW1CO0FBQy9ELFNBQVNDLG9CQUFvQixRQUFRLDBDQUEwQztBQUMvRSxTQUFTQyxvQkFBb0IsUUFBUSx3Q0FBd0M7QUFDN0UsY0FBY0MscUJBQXFCLFFBQVEsd0JBQXdCO0FBQ25FLGNBQWNDLE9BQU8sUUFBUSx3QkFBd0I7QUFDckQsU0FBU0MsbUJBQW1CLFFBQVEsK0JBQStCO0FBQ25FLFNBQVNDLCtCQUErQixRQUFRLHlCQUF5QjtBQUN6RSxTQUFTQyxrQkFBa0IsUUFBUSw2QkFBNkI7O0FBRWhFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVNDLFNBQVNBLENBQUNDLFFBQVEsRUFBRUwsT0FBTyxFQUFFLENBQUMsRUFBRUEsT0FBTyxFQUFFLENBQUM7RUFDakQsSUFBSU0sSUFBSSxHQUFHSiwrQkFBK0IsQ0FBQ0csUUFBUSxDQUFDO0VBQ3BELElBQUlYLE9BQU8sQ0FBQyxrQkFBa0IsQ0FBQyxFQUFFO0lBQy9CO0lBQ0EsTUFBTTtNQUFFYTtJQUFZLENBQUMsR0FDbkJDLE9BQU8sQ0FBQyw4Q0FBOEMsQ0FBQyxJQUFJLE9BQU8sT0FBTyw4Q0FBOEMsQ0FBQztJQUMxSDtJQUNBRixJQUFJLEdBQUdDLFdBQVcsQ0FBQ0QsSUFBSSxDQUFDO0VBQzFCO0VBQ0EsT0FBT0EsSUFBSTtBQUNiO0FBRUEsT0FBTyxlQUFlRyxJQUFJQSxDQUN4QkMsTUFBTSxFQUFFWCxxQkFBcUIsRUFDN0JZLE9BQU8sRUFBRWYsc0JBQXNCLENBQ2hDLEVBQUVnQixPQUFPLENBQUNqQixLQUFLLENBQUNrQixTQUFTLENBQUMsQ0FBQztFQUMxQixNQUFNO0lBQ0pSLFFBQVE7SUFDUlMsV0FBVztJQUNYQyxPQUFPLEVBQUU7TUFBRUMsYUFBYTtNQUFFQztJQUFNO0VBQ2xDLENBQUMsR0FBR04sT0FBTztFQUVYLE1BQU1PLE9BQU8sR0FBR2QsU0FBUyxDQUFDQyxRQUFRLENBQUM7O0VBRW5DO0VBQ0EsTUFBTTtJQUFFQSxRQUFRLEVBQUVjO0VBQWtCLENBQUMsR0FBRyxNQUFNckIsb0JBQW9CLENBQUNvQixPQUFPLENBQUM7O0VBRTNFO0VBQ0EsTUFBTUUsYUFBYSxHQUFHQyxPQUFPLENBQUNDLE1BQU0sQ0FBQ0MsT0FBTyxJQUFJLEVBQUU7RUFFbEQsTUFBTUMsUUFBUSxHQUFHVixXQUFXLENBQUMsQ0FBQzs7RUFFOUI7RUFDQTtFQUNBLE1BQU1XLElBQUksR0FBRyxNQUFNeEIsbUJBQW1CLENBQ3BDa0IsaUJBQWlCLEVBQ2pCSCxhQUFhLEVBQ2IsWUFBWVEsUUFBUSxDQUFDRSxxQkFBcUIsRUFDMUNULEtBQUssRUFDTE8sUUFBUSxDQUFDRyxnQkFBZ0IsRUFDekJQLGFBQWEsRUFDYlQsT0FBTztFQUFFO0VBQ1RpQixTQUFTO0VBQUU7RUFDWFYsT0FBTyxDQUFFO0VBQ1gsQ0FBQzs7RUFFRDtFQUNBLE1BQU1XLE1BQU0sR0FBRyxNQUFNMUIsa0JBQWtCLENBQUMsQ0FBQyxvQkFBb0IsQ0FBQyxJQUFJLENBQUMsQ0FBQ3NCLElBQUksQ0FBQyxHQUFHLENBQUM7RUFDN0VmLE1BQU0sQ0FBQ21CLE1BQU0sQ0FBQztFQUNkLE9BQU8sSUFBSTtBQUNiIiwiaWdub3JlTGlzdCI6W119 + diff --git a/src/commands/context/index.ts b/src/commands/context/index.ts index fbeb2b4..eb7ae4b 100644 --- a/src/commands/context/index.ts +++ b/src/commands/context/index.ts @@ -23,3 +23,4 @@ export const contextNonInteractive: Command = { load: () => import('./context-noninteractive.js'), } + diff --git a/src/commands/copy/copy.tsx b/src/commands/copy/copy.tsx index 0d801a9..9b42c69 100644 --- a/src/commands/copy/copy.tsx +++ b/src/commands/copy/copy.tsx @@ -369,3 +369,4 @@ export const call: LocalJSXCommandCall = async (onDone, context, args) => { return ; }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJta2RpciIsIndyaXRlRmlsZSIsIm1hcmtlZCIsIlRva2VucyIsInRtcGRpciIsImpvaW4iLCJSZWFjdCIsInVzZVJlZiIsIkNvbW1hbmRSZXN1bHREaXNwbGF5IiwiT3B0aW9uV2l0aERlc2NyaXB0aW9uIiwiU2VsZWN0IiwiQnlsaW5lIiwiS2V5Ym9hcmRTaG9ydGN1dEhpbnQiLCJQYW5lIiwiS2V5Ym9hcmRFdmVudCIsInN0cmluZ1dpZHRoIiwic2V0Q2xpcGJvYXJkIiwiQm94IiwiVGV4dCIsImxvZ0V2ZW50IiwiTG9jYWxKU1hDb21tYW5kQ2FsbCIsIkFzc2lzdGFudE1lc3NhZ2UiLCJNZXNzYWdlIiwiZ2V0R2xvYmFsQ29uZmlnIiwic2F2ZUdsb2JhbENvbmZpZyIsImV4dHJhY3RUZXh0Q29udGVudCIsInN0cmlwUHJvbXB0WE1MVGFncyIsImNvdW50Q2hhckluU3RyaW5nIiwiQ09QWV9ESVIiLCJSRVNQT05TRV9GSUxFTkFNRSIsIk1BWF9MT09LQkFDSyIsIkNvZGVCbG9jayIsImNvZGUiLCJsYW5nIiwiZXh0cmFjdENvZGVCbG9ja3MiLCJtYXJrZG93biIsInRva2VucyIsImxleGVyIiwiYmxvY2tzIiwidG9rZW4iLCJ0eXBlIiwiY29kZVRva2VuIiwiQ29kZSIsInB1c2giLCJ0ZXh0IiwiY29sbGVjdFJlY2VudEFzc2lzdGFudFRleHRzIiwibWVzc2FnZXMiLCJ0ZXh0cyIsImkiLCJsZW5ndGgiLCJtc2ciLCJpc0FwaUVycm9yTWVzc2FnZSIsImNvbnRlbnQiLCJtZXNzYWdlIiwiQXJyYXkiLCJpc0FycmF5IiwiZmlsZUV4dGVuc2lvbiIsInNhbml0aXplZCIsInJlcGxhY2UiLCJ3cml0ZVRvRmlsZSIsImZpbGVuYW1lIiwiUHJvbWlzZSIsImZpbGVQYXRoIiwicmVjdXJzaXZlIiwiY29weU9yV3JpdGVUb0ZpbGUiLCJyYXciLCJwcm9jZXNzIiwic3Rkb3V0Iiwid3JpdGUiLCJsaW5lQ291bnQiLCJjaGFyQ291bnQiLCJ0cnVuY2F0ZUxpbmUiLCJtYXhMZW4iLCJmaXJzdExpbmUiLCJzcGxpdCIsInJlc3VsdCIsIndpZHRoIiwidGFyZ2V0V2lkdGgiLCJjaGFyIiwiY2hhcldpZHRoIiwiUGlja2VyUHJvcHMiLCJmdWxsVGV4dCIsImNvZGVCbG9ja3MiLCJtZXNzYWdlQWdlIiwib25Eb25lIiwib3B0aW9ucyIsImRpc3BsYXkiLCJQaWNrZXJTZWxlY3Rpb24iLCJDb3B5UGlja2VyIiwidDAiLCIkIiwiX2MiLCJmb2N1c2VkUmVmIiwidDEiLCJ0MiIsImxhYmVsIiwidmFsdWUiLCJjb25zdCIsImRlc2NyaXB0aW9uIiwidDMiLCJ0NCIsIlN5bWJvbCIsImZvciIsIm1hcCIsIl90ZW1wIiwiZ2V0U2VsZWN0aW9uQ29udGVudCIsInNlbGVjdGVkIiwiYmxvY2tfMCIsImJsb2NrIiwiYmxvY2tJbmRleCIsInQ1IiwiaGFuZGxlU2VsZWN0Iiwic2VsZWN0ZWRfMCIsImNvcHlGdWxsUmVzcG9uc2UiLCJfdGVtcDIiLCJibG9ja19jb3VudCIsImFsd2F5cyIsIm1lc3NhZ2VfYWdlIiwic2VsZWN0ZWRfYmxvY2siLCJyZXN1bHRfMCIsInQ2IiwiaGFuZGxlV3JpdGUiLCJzZWxlY3RlZF8xIiwiY29udGVudF8wIiwid3JpdGVfc2hvcnRjdXQiLCJ0NyIsImUiLCJFcnJvciIsImhhbmRsZUtleURvd24iLCJlXzAiLCJrZXkiLCJwcmV2ZW50RGVmYXVsdCIsImN1cnJlbnQiLCJ0OCIsInQ5Iiwic2VsZWN0ZWRfMiIsInQxMCIsInQxMSIsInQxMiIsInQxMyIsImMiLCJpbmRleCIsImJsb2NrTGluZXMiLCJ1bmRlZmluZWQiLCJmaWx0ZXIiLCJCb29sZWFuIiwiY2FsbCIsImNvbnRleHQiLCJhcmdzIiwiYWdlIiwiYXJnIiwidHJpbSIsIm4iLCJOdW1iZXIiLCJpc0ludGVnZXIiLCJjb25maWciXSwic291cmNlcyI6WyJjb3B5LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBta2Rpciwgd3JpdGVGaWxlIH0gZnJvbSAnZnMvcHJvbWlzZXMnXG5pbXBvcnQgeyBtYXJrZWQsIHR5cGUgVG9rZW5zIH0gZnJvbSAnbWFya2VkJ1xuaW1wb3J0IHsgdG1wZGlyIH0gZnJvbSAnb3MnXG5pbXBvcnQgeyBqb2luIH0gZnJvbSAncGF0aCdcbmltcG9ydCBSZWFjdCwgeyB1c2VSZWYgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgQ29tbWFuZFJlc3VsdERpc3BsYXkgfSBmcm9tICcuLi8uLi9jb21tYW5kcy5qcydcbmltcG9ydCB0eXBlIHsgT3B0aW9uV2l0aERlc2NyaXB0aW9uIH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9DdXN0b21TZWxlY3Qvc2VsZWN0LmpzJ1xuaW1wb3J0IHsgU2VsZWN0IH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9DdXN0b21TZWxlY3Qvc2VsZWN0LmpzJ1xuaW1wb3J0IHsgQnlsaW5lIH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9kZXNpZ24tc3lzdGVtL0J5bGluZS5qcydcbmltcG9ydCB7IEtleWJvYXJkU2hvcnRjdXRIaW50IH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9kZXNpZ24tc3lzdGVtL0tleWJvYXJkU2hvcnRjdXRIaW50LmpzJ1xuaW1wb3J0IHsgUGFuZSB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMvZGVzaWduLXN5c3RlbS9QYW5lLmpzJ1xuaW1wb3J0IHR5cGUgeyBLZXlib2FyZEV2ZW50IH0gZnJvbSAnLi4vLi4vaW5rL2V2ZW50cy9rZXlib2FyZC1ldmVudC5qcydcbmltcG9ydCB7IHN0cmluZ1dpZHRoIH0gZnJvbSAnLi4vLi4vaW5rL3N0cmluZ1dpZHRoLmpzJ1xuaW1wb3J0IHsgc2V0Q2xpcGJvYXJkIH0gZnJvbSAnLi4vLi4vaW5rL3Rlcm1pby9vc2MuanMnXG5pbXBvcnQgeyBCb3gsIFRleHQgfSBmcm9tICcuLi8uLi9pbmsuanMnXG5pbXBvcnQgeyBsb2dFdmVudCB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL2FuYWx5dGljcy9pbmRleC5qcydcbmltcG9ydCB0eXBlIHsgTG9jYWxKU1hDb21tYW5kQ2FsbCB9IGZyb20gJy4uLy4uL3R5cGVzL2NvbW1hbmQuanMnXG5pbXBvcnQgdHlwZSB7IEFzc2lzdGFudE1lc3NhZ2UsIE1lc3NhZ2UgfSBmcm9tICcuLi8uLi90eXBlcy9tZXNzYWdlLmpzJ1xuaW1wb3J0IHsgZ2V0R2xvYmFsQ29uZmlnLCBzYXZlR2xvYmFsQ29uZmlnIH0gZnJvbSAnLi4vLi4vdXRpbHMvY29uZmlnLmpzJ1xuaW1wb3J0IHsgZXh0cmFjdFRleHRDb250ZW50LCBzdHJpcFByb21wdFhNTFRhZ3MgfSBmcm9tICcuLi8uLi91dGlscy9tZXNzYWdlcy5qcydcbmltcG9ydCB7IGNvdW50Q2hhckluU3RyaW5nIH0gZnJvbSAnLi4vLi4vdXRpbHMvc3RyaW5nVXRpbHMuanMnXG5cbmNvbnN0IENPUFlfRElSID0gam9pbih0bXBkaXIoKSwgJ2NsYXVkZScpXG5jb25zdCBSRVNQT05TRV9GSUxFTkFNRSA9ICdyZXNwb25zZS5tZCdcbmNvbnN0IE1BWF9MT09LQkFDSyA9IDIwXG5cbnR5cGUgQ29kZUJsb2NrID0ge1xuICBjb2RlOiBzdHJpbmdcbiAgbGFuZzogc3RyaW5nIHwgdW5kZWZpbmVkXG59XG5cbmZ1bmN0aW9uIGV4dHJhY3RDb2RlQmxvY2tzKG1hcmtkb3duOiBzdHJpbmcpOiBDb2RlQmxvY2tbXSB7XG4gIGNvbnN0IHRva2VucyA9IG1hcmtlZC5sZXhlcihzdHJpcFByb21wdFhNTFRhZ3MobWFya2Rvd24pKVxuICBjb25zdCBibG9ja3M6IENvZGVCbG9ja1tdID0gW11cbiAgZm9yIChjb25zdCB0b2tlbiBvZiB0b2tlbnMpIHtcbiAgICBpZiAodG9rZW4udHlwZSA9PT0gJ2NvZGUnKSB7XG4gICAgICBjb25zdCBjb2RlVG9rZW4gPSB0b2tlbiBhcyBUb2tlbnMuQ29kZVxuICAgICAgYmxvY2tzLnB1c2goeyBjb2RlOiBjb2RlVG9rZW4udGV4dCwgbGFuZzogY29kZVRva2VuLmxhbmcgfSlcbiAgICB9XG4gIH1cbiAgcmV0dXJuIGJsb2Nrc1xufVxuXG4vKipcbiAqIFdhbGsgbWVzc2FnZXMgbmV3ZXN0LWZpcnN0LCByZXR1cm5pbmcgdGV4dCBmcm9tIGFzc2lzdGFudCBtZXNzYWdlcyB0aGF0XG4gKiBhY3R1YWxseSBzYWlkIHNvbWV0aGluZyAoc2tpcHMgdG9vbC11c2Utb25seSB0dXJucyBhbmQgQVBJIGVycm9ycykuXG4gKiBJbmRleCAwID0gbGF0ZXN0LCAxID0gc2Vjb25kLXRvLWxhdGVzdCwgZXRjLiBDYXBzIGF0IE1BWF9MT09LQkFDSy5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNvbGxlY3RSZWNlbnRBc3Npc3RhbnRUZXh0cyhtZXNzYWdlczogTWVzc2FnZVtdKTogc3RyaW5nW10ge1xuICBjb25zdCB0ZXh0czogc3RyaW5nW10gPSBbXVxuICBmb3IgKFxuICAgIGxldCBpID0gbWVzc2FnZXMubGVuZ3RoIC0gMTtcbiAgICBpID49IDAgJiYgdGV4dHMubGVuZ3RoIDwgTUFYX0xPT0tCQUNLO1xuICAgIGktLVxuICApIHtcbiAgICBjb25zdCBtc2cgPSBtZXNzYWdlc1tpXVxuICAgIGlmIChtc2c/LnR5cGUgIT09ICdhc3Npc3RhbnQnIHx8IG1zZy5pc0FwaUVycm9yTWVzc2FnZSkgY29udGludWVcbiAgICBjb25zdCBjb250ZW50ID0gKG1zZyBhcyBBc3Npc3RhbnRNZXNzYWdlKS5tZXNzYWdlLmNvbnRlbnRcbiAgICBpZiAoIUFycmF5LmlzQXJyYXkoY29udGVudCkpIGNvbnRpbnVlXG4gICAgY29uc3QgdGV4dCA9IGV4dHJhY3RUZXh0Q29udGVudChjb250ZW50LCAnXFxuXFxuJylcbiAgICBpZiAodGV4dCkgdGV4dHMucHVzaCh0ZXh0KVxuICB9XG4gIHJldHVybiB0ZXh0c1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZmlsZUV4dGVuc2lvbihsYW5nOiBzdHJpbmcgfCB1bmRlZmluZWQpOiBzdHJpbmcge1xuICBpZiAobGFuZykge1xuICAgIC8vIFNhbml0aXplIHRvIHByZXZlbnQgcGF0aCB0cmF2ZXJzYWwgKGUuZy4gYGBgLi4vLi4vZXRjL3Bhc3N3ZClcbiAgICAvLyBMYW5ndWFnZSBpZGVudGlmaWVycyBhcmUgYWxwaGFudW1lcmljOiBweXRob24sIHRzeCwganNvbmMsIGV0Yy5cbiAgICBjb25zdCBzYW5pdGl6ZWQgPSBsYW5nLnJlcGxhY2UoL1teYS16QS1aMC05XS9nLCAnJylcbiAgICBpZiAoc2FuaXRpemVkICYmIHNhbml0aXplZCAhPT0gJ3BsYWludGV4dCcpIHtcbiAgICAgIHJldHVybiBgLiR7c2FuaXRpemVkfWBcbiAgICB9XG4gIH1cbiAgcmV0dXJuICcudHh0J1xufVxuXG5hc3luYyBmdW5jdGlvbiB3cml0ZVRvRmlsZSh0ZXh0OiBzdHJpbmcsIGZpbGVuYW1lOiBzdHJpbmcpOiBQcm9taXNlPHN0cmluZz4ge1xuICBjb25zdCBmaWxlUGF0aCA9IGpvaW4oQ09QWV9ESVIsIGZpbGVuYW1lKVxuICBhd2FpdCBta2RpcihDT1BZX0RJUiwgeyByZWN1cnNpdmU6IHRydWUgfSlcbiAgYXdhaXQgd3JpdGVGaWxlKGZpbGVQYXRoLCB0ZXh0LCAndXRmLTgnKVxuICByZXR1cm4gZmlsZVBhdGhcbn1cblxuYXN5bmMgZnVuY3Rpb24gY29weU9yV3JpdGVUb0ZpbGUoXG4gIHRleHQ6IHN0cmluZyxcbiAgZmlsZW5hbWU6IHN0cmluZyxcbik6IFByb21pc2U8c3RyaW5nPiB7XG4gIGNvbnN0IHJhdyA9IGF3YWl0IHNldENsaXBib2FyZCh0ZXh0KVxuICBpZiAocmF3KSBwcm9jZXNzLnN0ZG91dC53cml0ZShyYXcpXG4gIGNvbnN0IGxpbmVDb3VudCA9IGNvdW50Q2hhckluU3RyaW5nKHRleHQsICdcXG4nKSArIDFcbiAgY29uc3QgY2hhckNvdW50ID0gdGV4dC5sZW5ndGhcbiAgLy8gQWxzbyB3cml0ZSB0byBhIHRlbXAgZmlsZSDigJQgY2xpcGJvYXJkIHBhdGhzIGFyZSBiZXN0LWVmZm9ydCAoT1NDIDUyIG5lZWRzXG4gIC8vIHRlcm1pbmFsIHN1cHBvcnQpLCBzbyB0aGUgZmlsZSBwcm92aWRlcyBhIHJlbGlhYmxlIGZhbGxiYWNrLlxuICB0cnkge1xuICAgIGNvbnN0IGZpbGVQYXRoID0gYXdhaXQgd3JpdGVUb0ZpbGUodGV4dCwgZmlsZW5hbWUpXG4gICAgcmV0dXJuIGBDb3BpZWQgdG8gY2xpcGJvYXJkICgke2NoYXJDb3VudH0gY2hhcmFjdGVycywgJHtsaW5lQ291bnR9IGxpbmVzKVxcbkFsc28gd3JpdHRlbiB0byAke2ZpbGVQYXRofWBcbiAgfSBjYXRjaCB7XG4gICAgcmV0dXJuIGBDb3BpZWQgdG8gY2xpcGJvYXJkICgke2NoYXJDb3VudH0gY2hhcmFjdGVycywgJHtsaW5lQ291bnR9IGxpbmVzKWBcbiAgfVxufVxuXG5mdW5jdGlvbiB0cnVuY2F0ZUxpbmUodGV4dDogc3RyaW5nLCBtYXhMZW46IG51bWJlcik6IHN0cmluZyB7XG4gIGNvbnN0IGZpcnN0TGluZSA9IHRleHQuc3BsaXQoJ1xcbicpWzBdID8/ICcnXG4gIGlmIChzdHJpbmdXaWR0aChmaXJzdExpbmUpIDw9IG1heExlbikge1xuICAgIHJldHVybiBmaXJzdExpbmVcbiAgfVxuICBsZXQgcmVzdWx0ID0gJydcbiAgbGV0IHdpZHRoID0gMFxuICBjb25zdCB0YXJnZXRXaWR0aCA9IG1heExlbiAtIDFcbiAgZm9yIChjb25zdCBjaGFyIG9mIGZpcnN0TGluZSkge1xuICAgIGNvbnN0IGNoYXJXaWR0aCA9IHN0cmluZ1dpZHRoKGNoYXIpXG4gICAgaWYgKHdpZHRoICsgY2hhcldpZHRoID4gdGFyZ2V0V2lkdGgpIGJyZWFrXG4gICAgcmVzdWx0ICs9IGNoYXJcbiAgICB3aWR0aCArPSBjaGFyV2lkdGhcbiAgfVxuICByZXR1cm4gcmVzdWx0ICsgJ1xcdTIwMjYnXG59XG5cbnR5cGUgUGlja2VyUHJvcHMgPSB7XG4gIGZ1bGxUZXh0OiBzdHJpbmdcbiAgY29kZUJsb2NrczogQ29kZUJsb2NrW11cbiAgbWVzc2FnZUFnZTogbnVtYmVyXG4gIG9uRG9uZTogKFxuICAgIHJlc3VsdD86IHN0cmluZyxcbiAgICBvcHRpb25zPzogeyBkaXNwbGF5PzogQ29tbWFuZFJlc3VsdERpc3BsYXkgfSxcbiAgKSA9PiB2b2lkXG59XG5cbnR5cGUgUGlja2VyU2VsZWN0aW9uID0gbnVtYmVyIHwgJ2Z1bGwnIHwgJ2Fsd2F5cydcblxuZnVuY3Rpb24gQ29weVBpY2tlcih7XG4gIGZ1bGxUZXh0LFxuICBjb2RlQmxvY2tzLFxuICBtZXNzYWdlQWdlLFxuICBvbkRvbmUsXG59OiBQaWNrZXJQcm9wcyk6IFJlYWN0LlJlYWN0Tm9kZSB7XG4gIGNvbnN0IGZvY3VzZWRSZWYgPSB1c2VSZWY8UGlja2VyU2VsZWN0aW9uPignZnVsbCcpXG5cbiAgY29uc3Qgb3B0aW9uczogT3B0aW9uV2l0aERlc2NyaXB0aW9uPFBpY2tlclNlbGVjdGlvbj5bXSA9IFtcbiAgICB7XG4gICAgICBsYWJlbDogJ0Z1bGwgcmVzcG9uc2UnLFxuICAgICAgdmFsdWU6ICdmdWxsJyBhcyBjb25zdCxcbiAgICAgIGRlc2NyaXB0aW9uOiBgJHtmdWxsVGV4dC5sZW5ndGh9IGNoYXJzLCAke2NvdW50Q2hhckluU3RyaW5nKGZ1bGxUZXh0LCAnXFxuJykgKyAxfSBsaW5lc2AsXG4gICAgfSxcbiAgICAuLi5jb2RlQmxvY2tzLm1hcCgoYmxvY2ssIGluZGV4KSA9PiB7XG4gICAgICBjb25zdCBibG9ja0xpbmVzID0gY291bnRDaGFySW5TdHJpbmcoYmxvY2suY29kZSwgJ1xcbicpICsgMVxuICAgICAgcmV0dXJuIHtcbiAgICAgICAgbGFiZWw6IHRydW5jYXRlTGluZShibG9jay5jb2RlLCA2MCksXG4gICAgICAgIHZhbHVlOiBpbmRleCxcbiAgICAgICAgZGVzY3JpcHRpb246XG4gICAgICAgICAgW2Jsb2NrLmxhbmcsIGJsb2NrTGluZXMgPiAxID8gYCR7YmxvY2tMaW5lc30gbGluZXNgIDogdW5kZWZpbmVkXVxuICAgICAgICAgICAgLmZpbHRlcihCb29sZWFuKVxuICAgICAgICAgICAgLmpvaW4oJywgJykgfHwgdW5kZWZpbmVkLFxuICAgICAgfVxuICAgIH0pLFxuICAgIHtcbiAgICAgIGxhYmVsOiAnQWx3YXlzIGNvcHkgZnVsbCByZXNwb25zZScsXG4gICAgICB2YWx1ZTogJ2Fsd2F5cycgYXMgY29uc3QsXG4gICAgICBkZXNjcmlwdGlvbjogJ1NraXAgdGhpcyBwaWNrZXIgaW4gdGhlIGZ1dHVyZSAocmV2ZXJ0IHZpYSAvY29uZmlnKScsXG4gICAgfSxcbiAgXVxuXG4gIGZ1bmN0aW9uIGdldFNlbGVjdGlvbkNvbnRlbnQoc2VsZWN0ZWQ6IFBpY2tlclNlbGVjdGlvbik6IHtcbiAgICB0ZXh0OiBzdHJpbmdcbiAgICBmaWxlbmFtZTogc3RyaW5nXG4gICAgYmxvY2tJbmRleD86IG51bWJlclxuICB9IHtcbiAgICBpZiAoc2VsZWN0ZWQgPT09ICdmdWxsJyB8fCBzZWxlY3RlZCA9PT0gJ2Fsd2F5cycpIHtcbiAgICAgIHJldHVybiB7IHRleHQ6IGZ1bGxUZXh0LCBmaWxlbmFtZTogUkVTUE9OU0VfRklMRU5BTUUgfVxuICAgIH1cbiAgICBjb25zdCBibG9jayA9IGNvZGVCbG9ja3Nbc2VsZWN0ZWRdIVxuICAgIHJldHVybiB7XG4gICAgICB0ZXh0OiBibG9jay5jb2RlLFxuICAgICAgZmlsZW5hbWU6IGBjb3B5JHtmaWxlRXh0ZW5zaW9uKGJsb2NrLmxhbmcpfWAsXG4gICAgICBibG9ja0luZGV4OiBzZWxlY3RlZCxcbiAgICB9XG4gIH1cblxuICBhc3luYyBmdW5jdGlvbiBoYW5kbGVTZWxlY3Qoc2VsZWN0ZWQ6IFBpY2tlclNlbGVjdGlvbik6IFByb21pc2U8dm9pZD4ge1xuICAgIGNvbnN0IGNvbnRlbnQgPSBnZXRTZWxlY3Rpb25Db250ZW50KHNlbGVjdGVkKVxuICAgIGlmIChzZWxlY3RlZCA9PT0gJ2Fsd2F5cycpIHtcbiAgICAgIGlmICghZ2V0R2xvYmFsQ29uZmlnKCkuY29weUZ1bGxSZXNwb25zZSkge1xuICAgICAgICBzYXZlR2xvYmFsQ29uZmlnKGMgPT4gKHsgLi4uYywgY29weUZ1bGxSZXNwb25zZTogdHJ1ZSB9KSlcbiAgICAgIH1cbiAgICAgIGxvZ0V2ZW50KCd0ZW5ndV9jb3B5Jywge1xuICAgICAgICBibG9ja19jb3VudDogY29kZUJsb2Nrcy5sZW5ndGgsXG4gICAgICAgIGFsd2F5czogdHJ1ZSxcbiAgICAgICAgbWVzc2FnZV9hZ2U6IG1lc3NhZ2VBZ2UsXG4gICAgICB9KVxuICAgICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgY29weU9yV3JpdGVUb0ZpbGUoY29udGVudC50ZXh0LCBjb250ZW50LmZpbGVuYW1lKVxuICAgICAgb25Eb25lKFxuICAgICAgICBgJHtyZXN1bHR9XFxuUHJlZmVyZW5jZSBzYXZlZC4gVXNlIC9jb25maWcgdG8gY2hhbmdlIGNvcHlGdWxsUmVzcG9uc2VgLFxuICAgICAgKVxuICAgICAgcmV0dXJuXG4gICAgfVxuICAgIGxvZ0V2ZW50KCd0ZW5ndV9jb3B5Jywge1xuICAgICAgc2VsZWN0ZWRfYmxvY2s6IGNvbnRlbnQuYmxvY2tJbmRleCxcbiAgICAgIGJsb2NrX2NvdW50OiBjb2RlQmxvY2tzLmxlbmd0aCxcbiAgICAgIG1lc3NhZ2VfYWdlOiBtZXNzYWdlQWdlLFxuICAgIH0pXG4gICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgY29weU9yV3JpdGVUb0ZpbGUoY29udGVudC50ZXh0LCBjb250ZW50LmZpbGVuYW1lKVxuICAgIG9uRG9uZShyZXN1bHQpXG4gIH1cblxuICBhc3luYyBmdW5jdGlvbiBoYW5kbGVXcml0ZShzZWxlY3RlZDogUGlja2VyU2VsZWN0aW9uKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgY29uc3QgY29udGVudCA9IGdldFNlbGVjdGlvbkNvbnRlbnQoc2VsZWN0ZWQpXG4gICAgbG9nRXZlbnQoJ3Rlbmd1X2NvcHknLCB7XG4gICAgICBzZWxlY3RlZF9ibG9jazogY29udGVudC5ibG9ja0luZGV4LFxuICAgICAgYmxvY2tfY291bnQ6IGNvZGVCbG9ja3MubGVuZ3RoLFxuICAgICAgbWVzc2FnZV9hZ2U6IG1lc3NhZ2VBZ2UsXG4gICAgICB3cml0ZV9zaG9ydGN1dDogdHJ1ZSxcbiAgICB9KVxuICAgIHRyeSB7XG4gICAgICBjb25zdCBmaWxlUGF0aCA9IGF3YWl0IHdyaXRlVG9GaWxlKGNvbnRlbnQudGV4dCwgY29udGVudC5maWxlbmFtZSlcbiAgICAgIG9uRG9uZShgV3JpdHRlbiB0byAke2ZpbGVQYXRofWApXG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgb25Eb25lKGBGYWlsZWQgdG8gd3JpdGUgZmlsZTogJHtlIGluc3RhbmNlb2YgRXJyb3IgPyBlLm1lc3NhZ2UgOiBlfWApXG4gICAgfVxuICB9XG5cbiAgZnVuY3Rpb24gaGFuZGxlS2V5RG93bihlOiBLZXlib2FyZEV2ZW50KTogdm9pZCB7XG4gICAgaWYgKGUua2V5ID09PSAndycpIHtcbiAgICAgIGUucHJldmVudERlZmF1bHQoKVxuICAgICAgdm9pZCBoYW5kbGVXcml0ZShmb2N1c2VkUmVmLmN1cnJlbnQpXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIChcbiAgICA8UGFuZT5cbiAgICAgIDxCb3hcbiAgICAgICAgZmxleERpcmVjdGlvbj1cImNvbHVtblwiXG4gICAgICAgIGdhcD17MX1cbiAgICAgICAgdGFiSW5kZXg9ezB9XG4gICAgICAgIGF1dG9Gb2N1c1xuICAgICAgICBvbktleURvd249e2hhbmRsZUtleURvd259XG4gICAgICA+XG4gICAgICAgIDxUZXh0IGRpbUNvbG9yPlNlbGVjdCBjb250ZW50IHRvIGNvcHk6PC9UZXh0PlxuICAgICAgICA8U2VsZWN0PFBpY2tlclNlbGVjdGlvbj5cbiAgICAgICAgICBvcHRpb25zPXtvcHRpb25zfVxuICAgICAgICAgIGhpZGVJbmRleGVzPXtmYWxzZX1cbiAgICAgICAgICBvbkZvY3VzPXt2YWx1ZSA9PiB7XG4gICAgICAgICAgICBmb2N1c2VkUmVmLmN1cnJlbnQgPSB2YWx1ZVxuICAgICAgICAgIH19XG4gICAgICAgICAgb25DaGFuZ2U9e3NlbGVjdGVkID0+IHtcbiAgICAgICAgICAgIHZvaWQgaGFuZGxlU2VsZWN0KHNlbGVjdGVkKVxuICAgICAgICAgIH19XG4gICAgICAgICAgb25DYW5jZWw9eygpID0+IHtcbiAgICAgICAgICAgIG9uRG9uZSgnQ29weSBjYW5jZWxsZWQnLCB7IGRpc3BsYXk6ICdzeXN0ZW0nIH0pXG4gICAgICAgICAgfX1cbiAgICAgICAgLz5cbiAgICAgICAgPFRleHQgZGltQ29sb3I+XG4gICAgICAgICAgPEJ5bGluZT5cbiAgICAgICAgICAgIDxLZXlib2FyZFNob3J0Y3V0SGludCBzaG9ydGN1dD1cImVudGVyXCIgYWN0aW9uPVwiY29weVwiIC8+XG4gICAgICAgICAgICA8S2V5Ym9hcmRTaG9ydGN1dEhpbnQgc2hvcnRjdXQ9XCJ3XCIgYWN0aW9uPVwid3JpdGUgdG8gZmlsZVwiIC8+XG4gICAgICAgICAgICA8S2V5Ym9hcmRTaG9ydGN1dEhpbnQgc2hvcnRjdXQ9XCJlc2NcIiBhY3Rpb249XCJjYW5jZWxcIiAvPlxuICAgICAgICAgIDwvQnlsaW5lPlxuICAgICAgICA8L1RleHQ+XG4gICAgICA8L0JveD5cbiAgICA8L1BhbmU+XG4gIClcbn1cblxuZXhwb3J0IGNvbnN0IGNhbGw6IExvY2FsSlNYQ29tbWFuZENhbGwgPSBhc3luYyAob25Eb25lLCBjb250ZXh0LCBhcmdzKSA9PiB7XG4gIGNvbnN0IHRleHRzID0gY29sbGVjdFJlY2VudEFzc2lzdGFudFRleHRzKGNvbnRleHQubWVzc2FnZXMpXG5cbiAgaWYgKHRleHRzLmxlbmd0aCA9PT0gMCkge1xuICAgIG9uRG9uZSgnTm8gYXNzaXN0YW50IG1lc3NhZ2UgdG8gY29weScpXG4gICAgcmV0dXJuIG51bGxcbiAgfVxuXG4gIC8vIC9jb3B5IE4gcmVhY2hlcyBiYWNrIE4tMSBtZXNzYWdlcyAoMSA9IGxhdGVzdCwgMiA9IHNlY29uZC10by1sYXRlc3QsIC4uLilcbiAgbGV0IGFnZSA9IDBcbiAgY29uc3QgYXJnID0gYXJncz8udHJpbSgpXG4gIGlmIChhcmcpIHtcbiAgICBjb25zdCBuID0gTnVtYmVyKGFyZylcbiAgICBpZiAoIU51bWJlci5pc0ludGVnZXIobikgfHwgbiA8IDEpIHtcbiAgICAgIG9uRG9uZShgVXNhZ2U6IC9jb3B5IFtOXSB3aGVyZSBOIGlzIDEgKGxhdGVzdCksIDIsIDMsIFxcdTIwMjYgR290OiAke2FyZ31gKVxuICAgICAgcmV0dXJuIG51bGxcbiAgICB9XG4gICAgaWYgKG4gPiB0ZXh0cy5sZW5ndGgpIHtcbiAgICAgIG9uRG9uZShcbiAgICAgICAgYE9ubHkgJHt0ZXh0cy5sZW5ndGh9IGFzc2lzdGFudCAke3RleHRzLmxlbmd0aCA9PT0gMSA/ICdtZXNzYWdlJyA6ICdtZXNzYWdlcyd9IGF2YWlsYWJsZSB0byBjb3B5YCxcbiAgICAgIClcbiAgICAgIHJldHVybiBudWxsXG4gICAgfVxuICAgIGFnZSA9IG4gLSAxXG4gIH1cblxuICBjb25zdCB0ZXh0ID0gdGV4dHNbYWdlXSFcbiAgY29uc3QgY29kZUJsb2NrcyA9IGV4dHJhY3RDb2RlQmxvY2tzKHRleHQpXG4gIGNvbnN0IGNvbmZpZyA9IGdldEdsb2JhbENvbmZpZygpXG5cbiAgaWYgKGNvZGVCbG9ja3MubGVuZ3RoID09PSAwIHx8IGNvbmZpZy5jb3B5RnVsbFJlc3BvbnNlKSB7XG4gICAgbG9nRXZlbnQoJ3Rlbmd1X2NvcHknLCB7XG4gICAgICBhbHdheXM6IGNvbmZpZy5jb3B5RnVsbFJlc3BvbnNlLFxuICAgICAgYmxvY2tfY291bnQ6IGNvZGVCbG9ja3MubGVuZ3RoLFxuICAgICAgbWVzc2FnZV9hZ2U6IGFnZSxcbiAgICB9KVxuICAgIGNvbnN0IHJlc3VsdCA9IGF3YWl0IGNvcHlPcldyaXRlVG9GaWxlKHRleHQsIFJFU1BPTlNFX0ZJTEVOQU1FKVxuICAgIG9uRG9uZShyZXN1bHQpXG4gICAgcmV0dXJuIG51bGxcbiAgfVxuXG4gIHJldHVybiAoXG4gICAgPENvcHlQaWNrZXJcbiAgICAgIGZ1bGxUZXh0PXt0ZXh0fVxuICAgICAgY29kZUJsb2Nrcz17Y29kZUJsb2Nrc31cbiAgICAgIG1lc3NhZ2VBZ2U9e2FnZX1cbiAgICAgIG9uRG9uZT17b25Eb25lfVxuICAgIC8+XG4gIClcbn1cbiJdLCJtYXBwaW5ncyI6IjtBQUFBLFNBQVNBLEtBQUssRUFBRUMsU0FBUyxRQUFRLGFBQWE7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 + diff --git a/src/commands/copy/index.ts b/src/commands/copy/index.ts index 83c96e4..05edb7b 100644 --- a/src/commands/copy/index.ts +++ b/src/commands/copy/index.ts @@ -14,3 +14,4 @@ const copy = { export default copy + diff --git a/src/commands/createMovedToPluginCommand.ts b/src/commands/createMovedToPluginCommand.ts index 7b94278..f8dc507 100644 --- a/src/commands/createMovedToPluginCommand.ts +++ b/src/commands/createMovedToPluginCommand.ts @@ -64,3 +64,4 @@ Do not attempt to run the command. Simply inform the user about the plugin insta } } + diff --git a/src/commands/debug-tool-call/index.js b/src/commands/debug-tool-call/index.js index 9627ea7..01e6d3f 100644 --- a/src/commands/debug-tool-call/index.js +++ b/src/commands/debug-tool-call/index.js @@ -1,2 +1,3 @@ export default { isEnabled: () => false, isHidden: true, name: 'stub' }; + diff --git a/src/commands/desktop/desktop.tsx b/src/commands/desktop/desktop.tsx index 1621ece..830520b 100644 --- a/src/commands/desktop/desktop.tsx +++ b/src/commands/desktop/desktop.tsx @@ -7,3 +7,4 @@ export async function call(onDone: (result?: string, options?: { return ; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsIkNvbW1hbmRSZXN1bHREaXNwbGF5IiwiRGVza3RvcEhhbmRvZmYiLCJjYWxsIiwib25Eb25lIiwicmVzdWx0Iiwib3B0aW9ucyIsImRpc3BsYXkiLCJQcm9taXNlIiwiUmVhY3ROb2RlIl0sInNvdXJjZXMiOlsiZGVza3RvcC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHR5cGUgeyBDb21tYW5kUmVzdWx0RGlzcGxheSB9IGZyb20gJy4uLy4uL2NvbW1hbmRzLmpzJ1xuaW1wb3J0IHsgRGVza3RvcEhhbmRvZmYgfSBmcm9tICcuLi8uLi9jb21wb25lbnRzL0Rlc2t0b3BIYW5kb2ZmLmpzJ1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gY2FsbChcbiAgb25Eb25lOiAoXG4gICAgcmVzdWx0Pzogc3RyaW5nLFxuICAgIG9wdGlvbnM/OiB7IGRpc3BsYXk/OiBDb21tYW5kUmVzdWx0RGlzcGxheSB9LFxuICApID0+IHZvaWQsXG4pOiBQcm9taXNlPFJlYWN0LlJlYWN0Tm9kZT4ge1xuICByZXR1cm4gPERlc2t0b3BIYW5kb2ZmIG9uRG9uZT17b25Eb25lfSAvPlxufVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPQSxLQUFLLE1BQU0sT0FBTztBQUN6QixjQUFjQyxvQkFBb0IsUUFBUSxtQkFBbUI7QUFDN0QsU0FBU0MsY0FBYyxRQUFRLG9DQUFvQztBQUVuRSxPQUFPLGVBQWVDLElBQUlBLENBQ3hCQyxNQUFNLEVBQUUsQ0FDTkMsTUFBZSxDQUFSLEVBQUUsTUFBTSxFQUNmQyxPQUE0QyxDQUFwQyxFQUFFO0VBQUVDLE9BQU8sQ0FBQyxFQUFFTixvQkFBb0I7QUFBQyxDQUFDLEVBQzVDLEdBQUcsSUFBSSxDQUNWLEVBQUVPLE9BQU8sQ0FBQ1IsS0FBSyxDQUFDUyxTQUFTLENBQUMsQ0FBQztFQUMxQixPQUFPLENBQUMsY0FBYyxDQUFDLE1BQU0sQ0FBQyxDQUFDTCxNQUFNLENBQUMsR0FBRztBQUMzQyIsImlnbm9yZUxpc3QiOltdfQ== + diff --git a/src/commands/diff/index.ts b/src/commands/diff/index.ts index 556bc7c..bf85d58 100644 --- a/src/commands/diff/index.ts +++ b/src/commands/diff/index.ts @@ -7,3 +7,4 @@ export default { load: () => import('./diff.js'), } satisfies Command + diff --git a/src/commands/x402/index.ts b/src/commands/x402/index.ts new file mode 100644 index 0000000..c1d83bc --- /dev/null +++ b/src/commands/x402/index.ts @@ -0,0 +1,12 @@ +import type { Command } from '../../commands.js' + +const x402 = { + type: 'local', + name: 'x402', + aliases: ['wallet', 'pay'], + description: 'Configure x402 crypto payments (USDC on Base)', + argumentHint: '[setup|status|enable|disable|set-limit|remove]', + load: () => import('./x402.js'), +} satisfies Command + +export default x402 diff --git a/src/cost-tracker.ts b/src/cost-tracker.ts index 42ff712..42c109e 100644 --- a/src/cost-tracker.ts +++ b/src/cost-tracker.ts @@ -234,12 +234,24 @@ export function formatTotalCost(): string { const modelUsageDisplay = formatModelUsage() + // Include x402 payment summary if any payments were made + let x402Display = '' + try { + const { formatX402Cost } = require('./services/x402/index.js') as typeof import('./services/x402/index.js') + const x402Summary = formatX402Cost() + if (x402Summary) { + x402Display = '\n' + x402Summary + } + } catch { + // x402 module not available, skip + } + return chalk.dim( `Total cost: ${costDisplay}\n` + `Total duration (API): ${formatDuration(getTotalAPIDuration())} Total duration (wall): ${formatDuration(getTotalDuration())} Total code changes: ${getTotalLinesAdded()} ${getTotalLinesAdded() === 1 ? 'line' : 'lines'} added, ${getTotalLinesRemoved()} ${getTotalLinesRemoved() === 1 ? 'line' : 'lines'} removed -${modelUsageDisplay}`, +${modelUsageDisplay}${x402Display}`, ) } diff --git a/src/services/api/client.ts b/src/services/api/client.ts index 81640df..976a9c0 100644 --- a/src/services/api/client.ts +++ b/src/services/api/client.ts @@ -360,7 +360,19 @@ function buildFetch( source: string | undefined, ): ClientOptions['fetch'] { // eslint-disable-next-line eslint-plugin-n/no-unsupported-features/node-builtins - const inner = fetchOverride ?? globalThis.fetch + let inner = fetchOverride ?? globalThis.fetch + + // Wrap with x402 payment handler for automatic 402 Payment Required handling + try { + const { wrapFetchWithX402, isX402Enabled } = + require('../x402/index.js') as typeof import('../x402/index.js') + if (isX402Enabled()) { + inner = wrapFetchWithX402(inner as typeof globalThis.fetch) as typeof inner + } + } catch { + // x402 module not available, skip + } + // Only send to the first-party API — Bedrock/Vertex/Foundry don't log it // and unknown headers risk rejection by strict proxies (inc-4029 class). const injectClientRequestId = diff --git a/src/services/api/logging.ts b/src/services/api/logging.ts index a411c12..10da24f 100644 --- a/src/services/api/logging.ts +++ b/src/services/api/logging.ts @@ -786,3 +786,4 @@ export function logAPISuccessAndDuration({ markFirstTeleportMessageLogged() } } + diff --git a/src/services/api/metricsOptOut.ts b/src/services/api/metricsOptOut.ts index 8ef884a..f376c23 100644 --- a/src/services/api/metricsOptOut.ts +++ b/src/services/api/metricsOptOut.ts @@ -157,3 +157,4 @@ export async function checkMetricsEnabled(): Promise { export const _clearMetricsEnabledCacheForTesting = (): void => { memoizedCheckMetrics.cache.clear() } + diff --git a/src/services/api/overageCreditGrant.ts b/src/services/api/overageCreditGrant.ts index 5b13948..28ad5af 100644 --- a/src/services/api/overageCreditGrant.ts +++ b/src/services/api/overageCreditGrant.ts @@ -135,3 +135,4 @@ export function formatGrantAmount(info: OverageCreditGrantInfo): string | null { } export type { CachedGrantEntry as OverageCreditGrantCacheEntry } + diff --git a/src/services/x402/client.ts b/src/services/x402/client.ts new file mode 100644 index 0000000..4b7b745 --- /dev/null +++ b/src/services/x402/client.ts @@ -0,0 +1,399 @@ +/** + * x402 Payment Client + * + * Handles the x402 payment protocol flow: + * 1. Parse 402 response headers for payment requirements + * 2. Validate payment amounts against configured limits + * 3. Sign EIP-3009 transferWithAuthorization via EIP-712 + * 4. Construct payment header for retry + */ + +import { createHash, randomBytes } from 'crypto' +import { logForDebugging } from '../../utils/debug.js' +import { getX402Config, getX402PrivateKey } from './config.js' +import { addX402Payment } from './tracker.js' +import { + DEFAULT_FACILITATOR_URLS, + type PaymentNetwork, + type PaymentPayload, + type PaymentRequirement, + USDC_ADDRESSES, + X402_HEADERS, + type X402PaymentRecord, +} from './types.js' + +/** USDC has 6 decimal places */ +const USDC_DECIMALS = 6 + +/** Convert token amount (smallest unit) to USD, assuming 1 USDC = 1 USD */ +function tokenAmountToUSD(amount: string): number { + return parseInt(amount, 10) / 10 ** USDC_DECIMALS +} + +/** + * Parse the X-Payment-Required header from a 402 response. + */ +export function parsePaymentRequirement( + headerValue: string, +): PaymentRequirement { + try { + const parsed = JSON.parse(headerValue) as PaymentRequirement + if (!parsed.scheme || !parsed.network || !parsed.maxAmountRequired || !parsed.payTo) { + throw new Error('Missing required fields in payment requirement') + } + return parsed + } catch (error) { + throw new Error( + `Invalid x402 payment requirement header: ${error instanceof Error ? error.message : String(error)}`, + ) + } +} + +/** + * Validate that a payment requirement is within configured limits. + */ +export function validatePaymentRequirement( + requirement: PaymentRequirement, + sessionSpentUSD: number, +): { valid: boolean; reason?: string } { + const config = getX402Config() + + if (!config.enabled) { + return { valid: false, reason: 'x402 payments are not enabled' } + } + + const amountUSD = tokenAmountToUSD(requirement.maxAmountRequired) + + if (amountUSD > config.maxPaymentPerRequestUSD) { + return { + valid: false, + reason: `Payment of $${amountUSD.toFixed(4)} exceeds per-request limit of $${config.maxPaymentPerRequestUSD.toFixed(2)}`, + } + } + + if (sessionSpentUSD + amountUSD > config.maxSessionSpendUSD) { + return { + valid: false, + reason: `Payment would exceed session limit of $${config.maxSessionSpendUSD.toFixed(2)} (already spent $${sessionSpentUSD.toFixed(4)})`, + } + } + + // Validate network matches config + if (requirement.network !== config.network) { + return { + valid: false, + reason: `Payment requires network ${requirement.network} but wallet is configured for ${config.network}`, + } + } + + // Validate asset is USDC on the configured network + const expectedAsset = USDC_ADDRESSES[requirement.network] + if ( + expectedAsset && + requirement.asset.toLowerCase() !== expectedAsset.toLowerCase() + ) { + return { + valid: false, + reason: `Unknown payment token ${requirement.asset} (expected USDC: ${expectedAsset})`, + } + } + + return { valid: true } +} + +/** + * EIP-712 domain separator for EIP-3009 transferWithAuthorization. + * + * This follows the USDC contract's EIP-712 domain: + * name: token name (e.g. "USD Coin") + * version: token version (e.g. "2") + * chainId: network chain ID + * verifyingContract: USDC contract address + */ +function getEIP712Domain(requirement: PaymentRequirement): { + name: string + version: string + chainId: number + verifyingContract: string +} { + const chainIds: Record = { + 'base': 8453, + 'base-sepolia': 84532, + 'ethereum': 1, + 'ethereum-sepolia': 11155111, + } + + return { + name: requirement.extra?.name ?? 'USD Coin', + version: requirement.extra?.version ?? '2', + chainId: chainIds[requirement.network], + verifyingContract: requirement.asset, + } +} + +/** + * EIP-712 type hash for TransferWithAuthorization. + * + * TransferWithAuthorization(address from,address to,uint256 value,uint256 validAfter,uint256 validBefore,bytes32 nonce) + */ +const TRANSFER_WITH_AUTHORIZATION_TYPEHASH = createHash('sha3-256') + .update( + 'TransferWithAuthorization(address from,address to,uint256 value,uint256 validAfter,uint256 validBefore,bytes32 nonce)', + ) + .digest() + +/** + * Compute EIP-712 domain separator hash. + */ +function computeDomainSeparator(domain: { + name: string + version: string + chainId: number + verifyingContract: string +}): Buffer { + const EIP712_DOMAIN_TYPEHASH = createHash('sha3-256') + .update( + 'EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)', + ) + .digest() + + const nameHash = createHash('sha3-256').update(domain.name).digest() + const versionHash = createHash('sha3-256').update(domain.version).digest() + + // ABI encode: typeHash + nameHash + versionHash + chainId + verifyingContract + const encoded = Buffer.alloc(5 * 32) + EIP712_DOMAIN_TYPEHASH.copy(encoded, 0) + nameHash.copy(encoded, 32) + versionHash.copy(encoded, 64) + // chainId as uint256 + const chainIdBuf = Buffer.alloc(32) + chainIdBuf.writeBigUInt64BE(BigInt(domain.chainId), 24) + chainIdBuf.copy(encoded, 96) + // verifyingContract as address (left-padded to 32 bytes) + const addrBuf = Buffer.alloc(32) + Buffer.from(domain.verifyingContract.replace('0x', ''), 'hex').copy( + addrBuf, + 12, + ) + addrBuf.copy(encoded, 128) + + return createHash('sha3-256').update(encoded).digest() +} + +/** + * Compute the EIP-712 struct hash for TransferWithAuthorization. + */ +function computeStructHash(authorization: { + from: string + to: string + value: string + validAfter: string + validBefore: string + nonce: string +}): Buffer { + // ABI encode all fields as 32-byte words + const encoded = Buffer.alloc(7 * 32) + + TRANSFER_WITH_AUTHORIZATION_TYPEHASH.copy(encoded, 0) + + // from address + const fromBuf = Buffer.alloc(32) + Buffer.from(authorization.from.replace('0x', ''), 'hex').copy(fromBuf, 12) + fromBuf.copy(encoded, 32) + + // to address + const toBuf = Buffer.alloc(32) + Buffer.from(authorization.to.replace('0x', ''), 'hex').copy(toBuf, 12) + toBuf.copy(encoded, 64) + + // value as uint256 + const valueBuf = Buffer.alloc(32) + const value = BigInt(authorization.value) + valueBuf.writeBigUInt64BE(value >> 192n, 0) + valueBuf.writeBigUInt64BE((value >> 128n) & 0xffffffffffffffffn, 8) + valueBuf.writeBigUInt64BE((value >> 64n) & 0xffffffffffffffffn, 16) + valueBuf.writeBigUInt64BE(value & 0xffffffffffffffffn, 24) + valueBuf.copy(encoded, 96) + + // validAfter as uint256 + const validAfterBuf = Buffer.alloc(32) + validAfterBuf.writeBigUInt64BE(BigInt(authorization.validAfter), 24) + validAfterBuf.copy(encoded, 128) + + // validBefore as uint256 + const validBeforeBuf = Buffer.alloc(32) + validBeforeBuf.writeBigUInt64BE(BigInt(authorization.validBefore), 24) + validBeforeBuf.copy(encoded, 160) + + // nonce as bytes32 + const nonceBuf = Buffer.from(authorization.nonce.replace('0x', ''), 'hex') + const noncePadded = Buffer.alloc(32) + nonceBuf.copy(noncePadded, 32 - nonceBuf.length) + noncePadded.copy(encoded, 192) + + return createHash('sha3-256').update(encoded).digest() +} + +/** + * Sign an EIP-712 typed data hash with a secp256k1 private key. + * Returns the signature in compact format (r + s + v). + */ +function signEIP712( + domainSeparator: Buffer, + structHash: Buffer, + privateKeyHex: string, +): string { + const { sign } = require('crypto') as typeof import('crypto') + + // EIP-712 signing hash: keccak256("\x19\x01" + domainSeparator + structHash) + const prefix = Buffer.from('1901', 'hex') + const message = createHash('sha3-256') + .update(Buffer.concat([prefix, domainSeparator, structHash])) + .digest() + + const keyHex = privateKeyHex.startsWith('0x') + ? privateKeyHex.slice(2) + : privateKeyHex + const keyBuf = Buffer.from(keyHex, 'hex') + + // Use secp256k1 ECDSA signing + // Node.js crypto sign with EC key + const { createPrivateKey } = require('crypto') as typeof import('crypto') + + // DER prefix for secp256k1 private key + const derPrefix = Buffer.from('30740201010420', 'hex') + const derMiddle = Buffer.from('a00706052b8104000aa144034200', 'hex') + + const ecPrivateKey = createPrivateKey({ + key: Buffer.concat([derPrefix, keyBuf, derMiddle]), + format: 'der', + type: 'sec1', + }) + + const signature = sign(null, message, { + key: ecPrivateKey, + dsaEncoding: 'ieee-p1363', + }) + + // Extract r and s (each 32 bytes for secp256k1) + const r = signature.subarray(0, 32) + const s = signature.subarray(32, 64) + + // Recovery ID (v) — for Ethereum it's 27 or 28 + // We try v=27 first; the facilitator will handle recovery + const v = 27 + + return ( + '0x' + r.toString('hex') + s.toString('hex') + v.toString(16) + ) +} + +/** + * Create a signed x402 payment payload for a given requirement. + */ +export function createPayment( + requirement: PaymentRequirement, + fromAddress: string, + privateKeyHex: string, +): PaymentPayload { + const nonce = '0x' + randomBytes(32).toString('hex') + const validAfter = '0' + const validBefore = String( + Math.floor(Date.now() / 1000) + requirement.maxTimeoutSeconds, + ) + + const authorization = { + from: fromAddress, + to: requirement.payTo, + value: requirement.maxAmountRequired, + validAfter, + validBefore, + nonce, + } + + const domain = getEIP712Domain(requirement) + const domainSeparator = computeDomainSeparator(domain) + const structHash = computeStructHash(authorization) + const signature = signEIP712(domainSeparator, structHash, privateKeyHex) + + return { + x402Version: 1, + scheme: requirement.scheme, + network: requirement.network, + payload: { + signature, + authorization, + }, + } +} + +/** + * Encode a payment payload as a base64 string for the X-Payment header. + */ +export function encodePaymentHeader(payload: PaymentPayload): string { + return Buffer.from(JSON.stringify(payload)).toString('base64') +} + +/** + * Handle a 402 response by creating and encoding a payment. + * Returns the payment header value, or null if payment is not possible. + */ +export function handlePaymentRequired( + headerValue: string, + sessionSpentUSD: number, +): { + paymentHeader: string + record: X402PaymentRecord +} | null { + const requirement = parsePaymentRequirement(headerValue) + const validation = validatePaymentRequirement(requirement, sessionSpentUSD) + + if (!validation.valid) { + logForDebugging(`[x402] Payment rejected: ${validation.reason}`) + return null + } + + const privateKey = getX402PrivateKey() + if (!privateKey) { + logForDebugging('[x402] No private key configured') + return null + } + + const config = getX402Config() + const fromAddress = config.address + if (!fromAddress) { + logForDebugging('[x402] No wallet address configured') + return null + } + + const payment = createPayment(requirement, fromAddress, privateKey) + const paymentHeader = encodePaymentHeader(payment) + + const record: X402PaymentRecord = { + timestamp: Date.now(), + resource: requirement.resource, + amount: requirement.maxAmountRequired, + amountUSD: tokenAmountToUSD(requirement.maxAmountRequired), + token: requirement.extra?.name ?? 'USDC', + network: requirement.network, + payTo: requirement.payTo, + signature: payment.payload.signature, + } + + // Track the payment + addX402Payment(record) + + logForDebugging( + `[x402] Payment signed: $${record.amountUSD.toFixed(4)} to ${requirement.payTo} for ${requirement.resource}`, + ) + + return { paymentHeader, record } +} + +/** + * Get the facilitator URL for a given network. + */ +export function getFacilitatorUrl(network: PaymentNetwork): string { + const config = getX402Config() + return config.facilitatorUrl ?? DEFAULT_FACILITATOR_URLS[network] +} diff --git a/src/services/x402/config.ts b/src/services/x402/config.ts new file mode 100644 index 0000000..7d84383 --- /dev/null +++ b/src/services/x402/config.ts @@ -0,0 +1,185 @@ +/** + * x402 Wallet Configuration + * + * Manages wallet configuration and private key storage for x402 payments. + * Private keys are stored in the user's global config (~/.claude/config.json) + * and never logged or transmitted. + */ + +import { randomBytes } from 'crypto' +import { getGlobalConfig, saveGlobalConfig } from '../../utils/config.js' +import { logForDebugging } from '../../utils/debug.js' +import { + type PaymentNetwork, + type X402WalletConfig, + X402_DEFAULTS, +} from './types.js' + +/** + * EIP-55 mixed-case checksum address encoding. + * Computes the checksum in-place using keccak256 of the lowercase hex address. + */ +function toChecksumAddress(address: string): string { + const { createHash } = require('crypto') as typeof import('crypto') + const addr = address.toLowerCase().replace('0x', '') + const hash = createHash('sha3-256').update(addr).digest('hex') + let checksummed = '0x' + for (let i = 0; i < addr.length; i++) { + checksummed += + parseInt(hash[i], 16) >= 8 ? addr[i].toUpperCase() : addr[i] + } + return checksummed +} + +/** + * Derives an Ethereum address from a private key using secp256k1. + * Uses Node.js native crypto for the EC operation. + */ +function deriveAddress(privateKeyHex: string): string { + const { createPublicKey, createPrivateKey } = + require('crypto') as typeof import('crypto') + + const keyHex = privateKeyHex.startsWith('0x') + ? privateKeyHex.slice(2) + : privateKeyHex + const keyBuffer = Buffer.from(keyHex, 'hex') + + // Create an EC private key in DER format for secp256k1 + // DER prefix for secp256k1 private key (RFC 5915) + const derPrefix = Buffer.from( + '30740201010420', + 'hex', + ) + const derMiddle = Buffer.from( + 'a00706052b8104000aa144034200', + 'hex', + ) + + const privateKey = createPrivateKey({ + key: Buffer.concat([derPrefix, keyBuffer, derMiddle]), + format: 'der', + type: 'sec1', + }) + + const publicKey = createPublicKey(privateKey) + const pubKeyDer = publicKey.export({ type: 'spki', format: 'der' }) + + // Extract the 65-byte uncompressed public key (last 65 bytes of SPKI DER) + const uncompressedPubKey = pubKeyDer.subarray(pubKeyDer.length - 65) + + // Ethereum address = last 20 bytes of keccak256(pubkey[1:]) + // pubkey[0] is 0x04 prefix for uncompressed key + const { createHash } = require('crypto') as typeof import('crypto') + const hash = createHash('sha3-256') + .update(uncompressedPubKey.subarray(1)) + .digest() + const rawAddress = '0x' + hash.subarray(hash.length - 20).toString('hex') + + return toChecksumAddress(rawAddress) +} + +/** Retrieves x402 config from global config */ +export function getX402Config(): X402WalletConfig { + const config = getGlobalConfig() + return (config as Record).x402 as X402WalletConfig ?? { ...X402_DEFAULTS } +} + +/** Retrieves the private key from environment or global config */ +export function getX402PrivateKey(): string | undefined { + // Environment variable takes precedence (for CI/automation) + if (process.env.X402_PRIVATE_KEY) { + return process.env.X402_PRIVATE_KEY + } + const config = getGlobalConfig() + return (config as Record).x402PrivateKey as string | undefined +} + +/** Checks if x402 payments are configured and enabled */ +export function isX402Enabled(): boolean { + const config = getX402Config() + if (!config.enabled) return false + const key = getX402PrivateKey() + return !!key +} + +/** Saves x402 wallet configuration */ +export function saveX402Config(updates: Partial): void { + const current = getX402Config() + const merged = { ...current, ...updates } + saveGlobalConfig((config) => ({ + ...config, + x402: merged, + })) + logForDebugging('[x402] Config updated') +} + +/** + * Saves a private key and derives + stores the wallet address. + * The private key is stored encrypted-at-rest via the global config's + * file permissions (600). + */ +export function saveX402PrivateKey(privateKeyHex: string): string { + const keyHex = privateKeyHex.startsWith('0x') + ? privateKeyHex.slice(2) + : privateKeyHex + + if (keyHex.length !== 64 || !/^[0-9a-fA-F]+$/.test(keyHex)) { + throw new Error('Invalid private key: must be 32 bytes (64 hex characters)') + } + + const address = deriveAddress(keyHex) + + saveGlobalConfig((config) => ({ + ...config, + x402PrivateKey: `0x${keyHex}`, + })) + + saveX402Config({ address }) + + logForDebugging(`[x402] Wallet configured: ${address}`) + return address +} + +/** Removes the private key and disables x402 */ +export function removeX402PrivateKey(): void { + saveGlobalConfig((config) => { + const { x402PrivateKey: _, ...rest } = config as Record + return rest as typeof config + }) + saveX402Config({ enabled: false, address: undefined }) + logForDebugging('[x402] Wallet removed') +} + +/** Gets the wallet address without exposing the private key */ +export function getX402WalletAddress(): string | undefined { + return getX402Config().address +} + +/** + * Generates a new random private key for x402 payments. + * Returns the hex-encoded key (with 0x prefix). + */ +export function generateX402PrivateKey(): string { + return '0x' + randomBytes(32).toString('hex') +} + +/** Updates the payment network */ +export function setX402Network(network: PaymentNetwork): void { + saveX402Config({ network }) +} + +/** Updates max per-request payment limit */ +export function setX402MaxPayment(amountUSD: number): void { + if (amountUSD <= 0) { + throw new Error('Max payment must be a positive number') + } + saveX402Config({ maxPaymentPerRequestUSD: amountUSD }) +} + +/** Updates max session spend limit */ +export function setX402MaxSessionSpend(amountUSD: number): void { + if (amountUSD <= 0) { + throw new Error('Max session spend must be a positive number') + } + saveX402Config({ maxSessionSpendUSD: amountUSD }) +} diff --git a/src/services/x402/index.ts b/src/services/x402/index.ts new file mode 100644 index 0000000..58c71ff --- /dev/null +++ b/src/services/x402/index.ts @@ -0,0 +1,59 @@ +/** + * x402 Payment Service + * + * Public API for the x402 integration. Provides payment handling for + * HTTP 402 responses using the x402 protocol (USDC on Base). + * + * @see https://github.com/coinbase/x402 + */ + +// Configuration +export { + generateX402PrivateKey, + getX402Config, + getX402PrivateKey, + getX402WalletAddress, + isX402Enabled, + removeX402PrivateKey, + saveX402Config, + saveX402PrivateKey, + setX402MaxPayment, + setX402MaxSessionSpend, + setX402Network, +} from './config.js' + +// Payment client +export { + createPayment, + encodePaymentHeader, + getFacilitatorUrl, + handlePaymentRequired, + parsePaymentRequirement, + validatePaymentRequirement, +} from './client.js' + +// Fetch integration +export { + addX402AxiosInterceptor, + wrapFetchWithX402, +} from './paymentFetch.js' + +// Cost tracking +export { + addX402Payment, + formatX402Cost, + getX402PaymentCount, + getX402SessionPayments, + getX402SessionSpentUSD, + resetX402SessionPayments, +} from './tracker.js' + +// Types +export type { + PaymentNetwork, + PaymentPayload, + PaymentRequirement, + PaymentScheme, + X402PaymentRecord, + X402WalletConfig, +} from './types.js' diff --git a/src/services/x402/paymentFetch.ts b/src/services/x402/paymentFetch.ts new file mode 100644 index 0000000..3c54f25 --- /dev/null +++ b/src/services/x402/paymentFetch.ts @@ -0,0 +1,156 @@ +/** + * x402 Payment Fetch Wrapper + * + * Wraps fetch (or axios) to automatically handle HTTP 402 Payment Required + * responses using the x402 protocol. When a 402 is received: + * + * 1. Parse the X-Payment-Required header + * 2. Validate against spending limits + * 3. Sign a payment authorization + * 4. Retry the request with the X-Payment header + * + * This integrates at the fetch level so it works transparently with + * both the Anthropic SDK client and the WebFetchTool. + */ + +import type { AxiosInstance, AxiosResponse } from 'axios' +import { logForDebugging } from '../../utils/debug.js' +import { handlePaymentRequired } from './client.js' +import { isX402Enabled } from './config.js' +import { getX402SessionSpentUSD } from './tracker.js' +import { X402_HEADERS } from './types.js' + +/** + * Create a fetch wrapper that intercepts 402 responses and handles x402 payment. + * + * Usage with the Anthropic SDK client: + * const wrappedFetch = wrapFetchWithX402(originalFetch) + * // Pass wrappedFetch as the `fetch` option to the SDK + * + * @param innerFetch - The underlying fetch function to wrap + * @returns A fetch-compatible function with x402 payment handling + */ +export function wrapFetchWithX402( + innerFetch: typeof globalThis.fetch, +): typeof globalThis.fetch { + return async ( + input: RequestInfo | URL, + init?: RequestInit, + ): Promise => { + // Make the initial request + const response = await innerFetch(input, init) + + // If not a 402, pass through + if (response.status !== 402) { + return response + } + + // Check if x402 is enabled + if (!isX402Enabled()) { + logForDebugging('[x402] Received 402 but x402 payments are not enabled') + return response + } + + // Check for the x402 payment requirement header + const paymentRequiredHeader = response.headers.get( + X402_HEADERS.PAYMENT_REQUIRED, + ) + if (!paymentRequiredHeader) { + logForDebugging( + '[x402] Received 402 but no X-Payment-Required header present', + ) + return response + } + + logForDebugging(`[x402] Received 402 Payment Required, processing...`) + + // Handle the payment + const result = handlePaymentRequired( + paymentRequiredHeader, + getX402SessionSpentUSD(), + ) + + if (!result) { + logForDebugging('[x402] Payment handling failed, returning original 402') + return response + } + + // Retry with payment header + logForDebugging('[x402] Retrying request with payment header') + + const retryHeaders = new Headers(init?.headers) + retryHeaders.set(X402_HEADERS.PAYMENT, result.paymentHeader) + + const retryResponse = await innerFetch(input, { + ...init, + headers: retryHeaders, + }) + + if (retryResponse.status === 402) { + logForDebugging( + '[x402] Payment was rejected by server (still got 402)', + ) + } else { + logForDebugging( + `[x402] Payment accepted, response status: ${retryResponse.status}`, + ) + } + + return retryResponse + } +} + +/** + * Add x402 payment interceptor to an axios instance. + * + * Usage with WebFetchTool's axios: + * addX402AxiosInterceptor(axiosInstance) + * + * @param instance - The axios instance to add the interceptor to + */ +export function addX402AxiosInterceptor(instance: AxiosInstance): void { + instance.interceptors.response.use( + // Success handler — pass through non-402 responses + (response) => response, + // Error handler — intercept 402 responses + async (error) => { + if ( + !error.response || + error.response.status !== 402 || + !isX402Enabled() + ) { + throw error + } + + const response: AxiosResponse = error.response + + const paymentRequiredHeader = + response.headers[X402_HEADERS.PAYMENT_REQUIRED] + if (!paymentRequiredHeader) { + throw error + } + + logForDebugging('[x402] Axios interceptor: handling 402 Payment Required') + + const result = handlePaymentRequired( + paymentRequiredHeader, + getX402SessionSpentUSD(), + ) + + if (!result) { + throw error + } + + // Retry the original request with the payment header + const retryConfig = { + ...error.config, + headers: { + ...error.config.headers, + [X402_HEADERS.PAYMENT]: result.paymentHeader, + }, + } + + return instance.request(retryConfig) + }, + ) +} diff --git a/src/services/x402/tracker.ts b/src/services/x402/tracker.ts new file mode 100644 index 0000000..07f2e26 --- /dev/null +++ b/src/services/x402/tracker.ts @@ -0,0 +1,81 @@ +/** + * x402 Payment Tracker + * + * Tracks x402 payments within a session for cost display and safety limits. + * Integrates with the main cost tracking system. + */ + +import chalk from 'chalk' +import { logForDebugging } from '../../utils/debug.js' +import { formatNumber } from '../../utils/format.js' +import type { X402PaymentRecord } from './types.js' + +/** In-memory payment records for the current session */ +let sessionPayments: X402PaymentRecord[] = [] +let sessionTotalUSD = 0 + +/** Add a payment record to the session tracker */ +export function addX402Payment(record: X402PaymentRecord): void { + sessionPayments.push(record) + sessionTotalUSD += record.amountUSD + logForDebugging( + `[x402] Session total: $${sessionTotalUSD.toFixed(4)} (${sessionPayments.length} payments)`, + ) +} + +/** Get total USD spent via x402 in the current session */ +export function getX402SessionSpentUSD(): number { + return sessionTotalUSD +} + +/** Get all payment records for the current session */ +export function getX402SessionPayments(): readonly X402PaymentRecord[] { + return sessionPayments +} + +/** Get the count of payments in this session */ +export function getX402PaymentCount(): number { + return sessionPayments.length +} + +/** Reset session payment tracking (used on session switch) */ +export function resetX402SessionPayments(): void { + sessionPayments = [] + sessionTotalUSD = 0 +} + +/** Format x402 payment summary for display */ +export function formatX402Cost(): string { + if (sessionPayments.length === 0) { + return '' + } + + const lines: string[] = [] + lines.push( + `x402 payments: $${sessionTotalUSD.toFixed(4)} (${sessionPayments.length} ${sessionPayments.length === 1 ? 'payment' : 'payments'})`, + ) + + // Group by resource domain + const byDomain: Record = {} + for (const payment of sessionPayments) { + try { + const domain = new URL(payment.resource).hostname + if (!byDomain[domain]) { + byDomain[domain] = { count: 0, totalUSD: 0 } + } + byDomain[domain].count += payment.count ?? 1 + byDomain[domain].totalUSD += payment.amountUSD + } catch { + // Skip malformed URLs + } + } + + for (const [domain, stats] of Object.entries(byDomain)) { + lines.push( + `${domain}:`.padStart(21) + + ` ${formatNumber(stats.count)} ${stats.count === 1 ? 'request' : 'requests'} ($${stats.totalUSD.toFixed(4)})`, + ) + } + + return chalk.dim(lines.join('\n')) +}