@layerzerolabs/vm-tooling 0.2.88 → 0.2.90
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{56KN6KX2.cjs → 7E7TMR5F.cjs} +2 -2
- package/dist/{56KN6KX2.cjs.map → 7E7TMR5F.cjs.map} +1 -1
- package/dist/{KHVBCTKK.js → JYJBE36S.js} +2 -2
- package/dist/{KHVBCTKK.js.map → JYJBE36S.js.map} +1 -1
- package/dist/{2JEGETUJ.cjs → MH3SPPX5.cjs} +4 -4
- package/dist/{2JEGETUJ.cjs.map → MH3SPPX5.cjs.map} +1 -1
- package/dist/{3I5XNU26.js → UQGPF6NC.js} +3 -3
- package/dist/{3I5XNU26.js.map → UQGPF6NC.js.map} +1 -1
- package/dist/cli.cjs +3 -3
- package/dist/cli.js +2 -2
- package/dist/core/index.cjs +2 -2
- package/dist/core/index.js +1 -1
- package/dist/core/tool-executor.cjs +2 -2
- package/dist/core/tool-executor.js +1 -1
- package/dist/index.cjs +4 -4
- package/dist/index.js +2 -2
- package/package.json +4 -4
|
@@ -233,5 +233,5 @@ ${stdout}` : ""}`);
|
|
|
233
233
|
KHVGLVR5_cjs.__name(executeToolCommand, "executeToolCommand");
|
|
234
234
|
|
|
235
235
|
exports.executeToolCommand = executeToolCommand;
|
|
236
|
-
//# sourceMappingURL=
|
|
237
|
-
//# sourceMappingURL=
|
|
236
|
+
//# sourceMappingURL=7E7TMR5F.cjs.map
|
|
237
|
+
//# sourceMappingURL=7E7TMR5F.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/core/tool-executor.ts"],"names":["init_cjs_shims","getHostUserIds","__name","userInfo","os","uid","gid","undefined","$","verbose","stdio","process","stderr","mergeVolumes","defaultVolumes","userVolumes","uniqBy","volume","containerPath","resolveVolumePath","workspaceRoot","type","hostPath","path","resolve","replace","homedir","ensureDockerImage","imageUri","output","nothrow","quiet","exitCode","console","info","error","Error","stringifyError","isAuthError","includes","join","executeToolCommand","context","toolName","args","cwd","volumes","customEntrypoint","entrypoint","env","customEnvVars","script","publish","versions","defaultVolumesEnabled","tool","findToolByName","preExecute","findWorkspaceRoot","map","qualifyVolumeName","length","name","overrides","filter","uv","some","dv","resolvedVersion","resolveTypeVersions","getSecondaryVersion","secondaryVersion","satisfies","warn","getImageUriForTool","relativePath","relative","trim","defaultEnv","hasDockerSocketMount","dockerSocketEnv","value","envArgs","flatMap","hostUserIds","userIdEnvArgs","finalArgs","dockerArgs","privileged","p","lockMany","locked","label","time","result","timeEnd","stdout"],"mappings":"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","file":"56KN6KX2.cjs","sourcesContent":["import { uniqBy } from 'es-toolkit';\nimport os from 'node:os';\nimport path from 'node:path';\nimport process from 'node:process';\nimport * as semver from 'semver';\nimport { $, type ProcessOutput } from 'zx';\n\nimport type { EnvironmentVariable, VolumeMapping } from '../config';\nimport type { ChainContext } from '../context';\nimport { findWorkspaceRoot } from '../utils';\nimport { getImageUriForTool, qualifyVolumeName } from '../utils/docker';\nimport { stringifyError } from '../utils/error';\nimport { findToolByName } from '../utils/finder';\nimport { lockMany } from './lock';\nimport { resolveTypeVersions } from './version-resolver';\n\n/**\n * Get the current user's UID and GID for Docker container user matching.\n * This prevents permission issues when containers write to bind-mounted directories.\n * On Windows or when running as root, returns undefined as UID/GID matching is not needed.\n */\nconst getHostUserIds = (): { uid: number; gid: number } | undefined => {\n // os.userInfo() returns uid/gid on POSIX systems, -1 on Windows\n const userInfo = os.userInfo();\n if (userInfo.uid === -1 || userInfo.gid === -1) {\n return undefined;\n }\n\n return { uid: userInfo.uid, gid: userInfo.gid };\n};\n\n// Configure zx to inherit stdio by default (moved from original setup)\n$.verbose = true;\n$.stdio = ['inherit', 'pipe', process.stderr];\n\n/**\n * Merge default volumes with user-specified volumes\n * User volumes take precedence when containerPath conflicts\n */\nconst mergeVolumes = (\n defaultVolumes: readonly VolumeMapping[],\n userVolumes: readonly VolumeMapping[],\n): VolumeMapping[] => uniqBy([...userVolumes, ...defaultVolumes], (volume) => volume.containerPath);\n\n/**\n * Resolve a host path in a volume to an absolute path.\n * - Paths starting with ~ are resolved to home directory\n * - Relative paths (starting with . or no prefix) are resolved to workspace root\n * - Absolute paths are left unchanged\n */\nconst resolveVolumePath = (volume: VolumeMapping, workspaceRoot: string): VolumeMapping =>\n volume.type === 'host'\n ? {\n ...volume,\n hostPath: path.resolve(workspaceRoot, volume.hostPath.replace(/^~/, os.homedir())),\n }\n : volume;\n\nconst ensureDockerImage = async (imageUri: string): Promise<void> => {\n let output: ProcessOutput;\n\n try {\n // Check local images first.\n //\n // NOTE: `docker image ls <ref>` prints repository/tag in separate columns, so\n // `stdout.includes(<full-ref>)` is not reliable. Use `inspect` instead: exitCode=0\n // means the image exists locally.\n // Keep output minimal to avoid dumping full inspect JSON into CI logs.\n //\n // NOTE: Using `.quiet()` to avoid stderr being captured in the CI logs. If the image\n // is not in the cache, the process prints \"Error response from daemon: No such image: ...\"\n // which can confuse the uninitiated. It's just a cache miss, not an error.\n output = await $`docker image inspect --format {{.Id}} ${imageUri}`.nothrow().quiet();\n if (!output.exitCode) {\n console.info(`✅ Using cached Docker image: ${imageUri}`);\n return;\n }\n\n console.info('📥 Pulling Docker image from:', imageUri);\n output = await $`docker pull ${imageUri}`.nothrow();\n } catch (error: unknown) {\n throw new Error(`Failed to pull Docker image ${imageUri}: ${stringifyError(error)}`);\n }\n\n if (output.exitCode) {\n const stderr = output.stderr ?? '';\n const isAuthError =\n stderr.includes('authorization token has expired') ||\n stderr.includes('denied') ||\n stderr.includes('pull access denied');\n\n throw new Error(\n [\n 'Docker image not available:',\n ` - Image: ${imageUri} (pull failed)`,\n isAuthError\n ? ' - ECR auth expired. Run: pnpm localnet login'\n : ' - Check if the image tag exists in image registry.',\n ].join('\\n'),\n );\n }\n\n console.info(`✅ Successfully pulled: ${imageUri}`);\n};\n\nexport interface ToolCommandExecutionOptions {\n cwd: string;\n volumes: readonly VolumeMapping[];\n customEntrypoint?: string;\n env: EnvironmentVariable[];\n args?: string[];\n script?: string;\n publish?: string[];\n versions?: Record<string, string>;\n defaultVolumesEnabled?: boolean;\n}\n\n/**\n * Enhanced tool command execution using the new version compatibility matrix system\n */\nexport async function executeToolCommand<TImageId extends string>(\n context: ChainContext<TImageId>,\n toolName: string,\n args: string[],\n {\n cwd,\n volumes: userVolumes,\n customEntrypoint: entrypoint,\n env: customEnvVars,\n script,\n publish,\n versions = {},\n defaultVolumesEnabled = true,\n }: ToolCommandExecutionOptions,\n): Promise<ProcessOutput> {\n const tool = findToolByName(context, toolName);\n\n // Run pre-execution hook if defined (e.g., toolchain sync)\n if (tool.preExecute) {\n await tool.preExecute(context, {\n cwd,\n args,\n volumes: userVolumes,\n env: customEnvVars,\n script,\n publish,\n versions,\n defaultVolumesEnabled,\n });\n }\n\n const workspaceRoot = await findWorkspaceRoot(cwd);\n\n const defaultVolumes = defaultVolumesEnabled ? (tool.defaultVolumes ?? []) : [];\n const volumes = mergeVolumes(defaultVolumes, userVolumes)\n .map((volume) => resolveVolumePath(volume, workspaceRoot))\n .map(qualifyVolumeName);\n\n if (defaultVolumes.length > 0) {\n console.info(`📦 Using ${defaultVolumes.length} default volume(s) for ${tool.name}`);\n if (userVolumes.length > 0) {\n const overrides = userVolumes.filter((uv) =>\n defaultVolumes.some((dv) => dv.containerPath === uv.containerPath),\n );\n if (overrides.length > 0) {\n console.info(`🔧 User volumes override ${overrides.length} default volume(s)`);\n }\n }\n }\n\n // Get the resolved version for the current tool.\n const resolvedVersion = resolveTypeVersions(context, versions)[tool.name];\n\n if (!resolvedVersion) {\n throw new Error(`No version resolved for tool ${tool.name}`);\n }\n\n console.info(`🔧 ${tool.name} version: ${resolvedVersion}`);\n\n // Check secondary version validation if available\n if (tool.getSecondaryVersion) {\n try {\n const secondaryVersion = await tool.getSecondaryVersion({ cwd });\n\n if (!semver.satisfies(secondaryVersion, resolvedVersion)) {\n console.warn(\n `Warning: Local configuration version (${secondaryVersion}) differs from resolved version (${resolvedVersion})`,\n );\n }\n } catch (error) {\n // Secondary version check failed, but continue with resolved version\n console.warn('Could not validate secondary version:', stringifyError(error));\n }\n }\n\n // Use Docker image with merged volumes\n const imageUri = await getImageUriForTool(context, tool.name, resolvedVersion);\n const relativePath = path.relative(workspaceRoot, cwd);\n\n await ensureDockerImage(imageUri);\n\n if (entrypoint?.trim()) {\n console.info(`🔧 Using custom entrypoint: ${entrypoint}`);\n }\n\n // Merge default env vars with custom env vars (custom takes precedence)\n const defaultEnv = tool.defaultEnv ?? [];\n\n // Check if Docker socket is mounted (for tools that spawn Docker containers like anchor --verifiable)\n // If so, inject HOST_CWD and HOST_WORKSPACE_ROOT so the inner container knows the host paths\n const hasDockerSocketMount = volumes.some(\n (volume) => volume.type === 'host' && volume.containerPath === '/var/run/docker.sock',\n );\n const dockerSocketEnv: EnvironmentVariable[] = hasDockerSocketMount\n ? [\n { name: 'HOST_CWD', value: cwd },\n { name: 'HOST_WORKSPACE_ROOT', value: workspaceRoot },\n ]\n : [];\n\n const envArgs = uniqBy(\n [...customEnvVars, ...dockerSocketEnv, ...defaultEnv],\n ({ name }) => name,\n ).flatMap(({ name, value }) => ['-e', `${name}=${value}`]);\n\n // Add host user UID/GID for permission matching on Linux/macOS\n // This prevents artifacts created in containers from having root ownership\n // Currently only used for stellar which has an entrypoint that handles UID/GID\n const hostUserIds = getHostUserIds();\n const userIdEnvArgs = hostUserIds\n ? ['-e', `LOCAL_UID=${hostUserIds.uid}`, '-e', `LOCAL_GID=${hostUserIds.gid}`]\n : [];\n\n console.info(`👤 Running container as UID:GID ${hostUserIds?.uid}:${hostUserIds?.gid}`);\n\n if (defaultEnv.length > 0) {\n console.info(\n `🌍 Using ${defaultEnv.length} default environment variable(s) for ${tool.name}`,\n );\n }\n if (customEnvVars.length > 0) {\n console.info(`🌍 Using ${customEnvVars.length} custom environment variable(s)`);\n }\n\n // Handle custom script execution\n let finalArgs: string[];\n if (script && script.trim() !== '') {\n console.info(`📜 Executing custom script: ${script}`);\n finalArgs = ['bash', '-c', script];\n } else {\n finalArgs = entrypoint === undefined ? [tool.name, ...args] : args;\n }\n\n // Build the Docker command with proper argument separation\n const dockerArgs = [\n 'run',\n ...(tool.privileged ? ['--privileged'] : []),\n '--rm',\n '--add-host=host.docker.internal:host-gateway',\n ...envArgs,\n ...userIdEnvArgs,\n '-v',\n `${workspaceRoot}:/workspace`,\n '-w',\n `/workspace/${relativePath}`,\n ...(publish ?? []).flatMap((p) => ['-p', p.trim()]),\n ...volumes.flatMap((volume) => [\n '-v',\n `${volume.type === 'host' ? volume.hostPath : volume.name}:${volume.containerPath}`,\n ]),\n ...(entrypoint ? ['--entrypoint', entrypoint] : []),\n imageUri,\n ...finalArgs,\n ];\n\n const output = await lockMany(\n volumes.flatMap((volume) =>\n volume.type === 'isolate' && volume.locked ? [volume.name] : [],\n ),\n async () => {\n const label = `⏳ ${finalArgs.join(' ')}`;\n console.time(label);\n const result = await $`docker ${dockerArgs}`.nothrow();\n console.timeEnd(label);\n\n return result;\n },\n );\n\n if (output.exitCode) {\n const stdout = output.stdout.trim();\n throw new Error(\n `Failed to run Docker container (exit code: ${output.exitCode})${stdout ? `\\n${stdout}` : ''}`,\n );\n }\n\n return output;\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/core/tool-executor.ts"],"names":["init_cjs_shims","getHostUserIds","__name","userInfo","os","uid","gid","undefined","$","verbose","stdio","process","stderr","mergeVolumes","defaultVolumes","userVolumes","uniqBy","volume","containerPath","resolveVolumePath","workspaceRoot","type","hostPath","path","resolve","replace","homedir","ensureDockerImage","imageUri","output","nothrow","quiet","exitCode","console","info","error","Error","stringifyError","isAuthError","includes","join","executeToolCommand","context","toolName","args","cwd","volumes","customEntrypoint","entrypoint","env","customEnvVars","script","publish","versions","defaultVolumesEnabled","tool","findToolByName","preExecute","findWorkspaceRoot","map","qualifyVolumeName","length","name","overrides","filter","uv","some","dv","resolvedVersion","resolveTypeVersions","getSecondaryVersion","secondaryVersion","satisfies","warn","getImageUriForTool","relativePath","relative","trim","defaultEnv","hasDockerSocketMount","dockerSocketEnv","value","envArgs","flatMap","hostUserIds","userIdEnvArgs","finalArgs","dockerArgs","privileged","p","lockMany","locked","label","time","result","timeEnd","stdout"],"mappings":"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","file":"7E7TMR5F.cjs","sourcesContent":["import { uniqBy } from 'es-toolkit';\nimport os from 'node:os';\nimport path from 'node:path';\nimport process from 'node:process';\nimport * as semver from 'semver';\nimport { $, type ProcessOutput } from 'zx';\n\nimport type { EnvironmentVariable, VolumeMapping } from '../config';\nimport type { ChainContext } from '../context';\nimport { findWorkspaceRoot } from '../utils';\nimport { getImageUriForTool, qualifyVolumeName } from '../utils/docker';\nimport { stringifyError } from '../utils/error';\nimport { findToolByName } from '../utils/finder';\nimport { lockMany } from './lock';\nimport { resolveTypeVersions } from './version-resolver';\n\n/**\n * Get the current user's UID and GID for Docker container user matching.\n * This prevents permission issues when containers write to bind-mounted directories.\n * On Windows or when running as root, returns undefined as UID/GID matching is not needed.\n */\nconst getHostUserIds = (): { uid: number; gid: number } | undefined => {\n // os.userInfo() returns uid/gid on POSIX systems, -1 on Windows\n const userInfo = os.userInfo();\n if (userInfo.uid === -1 || userInfo.gid === -1) {\n return undefined;\n }\n\n return { uid: userInfo.uid, gid: userInfo.gid };\n};\n\n// Configure zx to inherit stdio by default (moved from original setup)\n$.verbose = true;\n$.stdio = ['inherit', 'pipe', process.stderr];\n\n/**\n * Merge default volumes with user-specified volumes\n * User volumes take precedence when containerPath conflicts\n */\nconst mergeVolumes = (\n defaultVolumes: readonly VolumeMapping[],\n userVolumes: readonly VolumeMapping[],\n): VolumeMapping[] => uniqBy([...userVolumes, ...defaultVolumes], (volume) => volume.containerPath);\n\n/**\n * Resolve a host path in a volume to an absolute path.\n * - Paths starting with ~ are resolved to home directory\n * - Relative paths (starting with . or no prefix) are resolved to workspace root\n * - Absolute paths are left unchanged\n */\nconst resolveVolumePath = (volume: VolumeMapping, workspaceRoot: string): VolumeMapping =>\n volume.type === 'host'\n ? {\n ...volume,\n hostPath: path.resolve(workspaceRoot, volume.hostPath.replace(/^~/, os.homedir())),\n }\n : volume;\n\nconst ensureDockerImage = async (imageUri: string): Promise<void> => {\n let output: ProcessOutput;\n\n try {\n // Check local images first.\n //\n // NOTE: `docker image ls <ref>` prints repository/tag in separate columns, so\n // `stdout.includes(<full-ref>)` is not reliable. Use `inspect` instead: exitCode=0\n // means the image exists locally.\n // Keep output minimal to avoid dumping full inspect JSON into CI logs.\n //\n // NOTE: Using `.quiet()` to avoid stderr being captured in the CI logs. If the image\n // is not in the cache, the process prints \"Error response from daemon: No such image: ...\"\n // which can confuse the uninitiated. It's just a cache miss, not an error.\n output = await $`docker image inspect --format {{.Id}} ${imageUri}`.nothrow().quiet();\n if (!output.exitCode) {\n console.info(`✅ Using cached Docker image: ${imageUri}`);\n return;\n }\n\n console.info('📥 Pulling Docker image from:', imageUri);\n output = await $`docker pull ${imageUri}`.nothrow();\n } catch (error: unknown) {\n throw new Error(`Failed to pull Docker image ${imageUri}: ${stringifyError(error)}`);\n }\n\n if (output.exitCode) {\n const stderr = output.stderr ?? '';\n const isAuthError =\n stderr.includes('authorization token has expired') ||\n stderr.includes('denied') ||\n stderr.includes('pull access denied');\n\n throw new Error(\n [\n 'Docker image not available:',\n ` - Image: ${imageUri} (pull failed)`,\n isAuthError\n ? ' - ECR auth expired. Run: pnpm localnet login'\n : ' - Check if the image tag exists in image registry.',\n ].join('\\n'),\n );\n }\n\n console.info(`✅ Successfully pulled: ${imageUri}`);\n};\n\nexport interface ToolCommandExecutionOptions {\n cwd: string;\n volumes: readonly VolumeMapping[];\n customEntrypoint?: string;\n env: EnvironmentVariable[];\n args?: string[];\n script?: string;\n publish?: string[];\n versions?: Record<string, string>;\n defaultVolumesEnabled?: boolean;\n}\n\n/**\n * Enhanced tool command execution using the new version compatibility matrix system\n */\nexport async function executeToolCommand<TImageId extends string>(\n context: ChainContext<TImageId>,\n toolName: string,\n args: string[],\n {\n cwd,\n volumes: userVolumes,\n customEntrypoint: entrypoint,\n env: customEnvVars,\n script,\n publish,\n versions = {},\n defaultVolumesEnabled = true,\n }: ToolCommandExecutionOptions,\n): Promise<ProcessOutput> {\n const tool = findToolByName(context, toolName);\n\n // Run pre-execution hook if defined (e.g., toolchain sync)\n if (tool.preExecute) {\n await tool.preExecute(context, {\n cwd,\n args,\n volumes: userVolumes,\n env: customEnvVars,\n script,\n publish,\n versions,\n defaultVolumesEnabled,\n });\n }\n\n const workspaceRoot = await findWorkspaceRoot(cwd);\n\n const defaultVolumes = defaultVolumesEnabled ? (tool.defaultVolumes ?? []) : [];\n const volumes = mergeVolumes(defaultVolumes, userVolumes)\n .map((volume) => resolveVolumePath(volume, workspaceRoot))\n .map(qualifyVolumeName);\n\n if (defaultVolumes.length > 0) {\n console.info(`📦 Using ${defaultVolumes.length} default volume(s) for ${tool.name}`);\n if (userVolumes.length > 0) {\n const overrides = userVolumes.filter((uv) =>\n defaultVolumes.some((dv) => dv.containerPath === uv.containerPath),\n );\n if (overrides.length > 0) {\n console.info(`🔧 User volumes override ${overrides.length} default volume(s)`);\n }\n }\n }\n\n // Get the resolved version for the current tool.\n const resolvedVersion = resolveTypeVersions(context, versions)[tool.name];\n\n if (!resolvedVersion) {\n throw new Error(`No version resolved for tool ${tool.name}`);\n }\n\n console.info(`🔧 ${tool.name} version: ${resolvedVersion}`);\n\n // Check secondary version validation if available\n if (tool.getSecondaryVersion) {\n try {\n const secondaryVersion = await tool.getSecondaryVersion({ cwd });\n\n if (!semver.satisfies(secondaryVersion, resolvedVersion)) {\n console.warn(\n `Warning: Local configuration version (${secondaryVersion}) differs from resolved version (${resolvedVersion})`,\n );\n }\n } catch (error) {\n // Secondary version check failed, but continue with resolved version\n console.warn('Could not validate secondary version:', stringifyError(error));\n }\n }\n\n // Use Docker image with merged volumes\n const imageUri = await getImageUriForTool(context, tool.name, resolvedVersion);\n const relativePath = path.relative(workspaceRoot, cwd);\n\n await ensureDockerImage(imageUri);\n\n if (entrypoint?.trim()) {\n console.info(`🔧 Using custom entrypoint: ${entrypoint}`);\n }\n\n // Merge default env vars with custom env vars (custom takes precedence)\n const defaultEnv = tool.defaultEnv ?? [];\n\n // Check if Docker socket is mounted (for tools that spawn Docker containers like anchor --verifiable)\n // If so, inject HOST_CWD and HOST_WORKSPACE_ROOT so the inner container knows the host paths\n const hasDockerSocketMount = volumes.some(\n (volume) => volume.type === 'host' && volume.containerPath === '/var/run/docker.sock',\n );\n const dockerSocketEnv: EnvironmentVariable[] = hasDockerSocketMount\n ? [\n { name: 'HOST_CWD', value: cwd },\n { name: 'HOST_WORKSPACE_ROOT', value: workspaceRoot },\n ]\n : [];\n\n const envArgs = uniqBy(\n [...customEnvVars, ...dockerSocketEnv, ...defaultEnv],\n ({ name }) => name,\n ).flatMap(({ name, value }) => ['-e', `${name}=${value}`]);\n\n // Add host user UID/GID for permission matching on Linux/macOS\n // This prevents artifacts created in containers from having root ownership\n // Used by stellar, sui, and iota images which have an entrypoint that handles UID/GID\n const hostUserIds = getHostUserIds();\n const userIdEnvArgs = hostUserIds\n ? ['-e', `LOCAL_UID=${hostUserIds.uid}`, '-e', `LOCAL_GID=${hostUserIds.gid}`]\n : [];\n\n console.info(`👤 Running container as UID:GID ${hostUserIds?.uid}:${hostUserIds?.gid}`);\n\n if (defaultEnv.length > 0) {\n console.info(\n `🌍 Using ${defaultEnv.length} default environment variable(s) for ${tool.name}`,\n );\n }\n if (customEnvVars.length > 0) {\n console.info(`🌍 Using ${customEnvVars.length} custom environment variable(s)`);\n }\n\n // Handle custom script execution\n let finalArgs: string[];\n if (script && script.trim() !== '') {\n console.info(`📜 Executing custom script: ${script}`);\n finalArgs = ['bash', '-c', script];\n } else {\n finalArgs = entrypoint === undefined ? [tool.name, ...args] : args;\n }\n\n // Build the Docker command with proper argument separation\n const dockerArgs = [\n 'run',\n ...(tool.privileged ? ['--privileged'] : []),\n '--rm',\n '--add-host=host.docker.internal:host-gateway',\n ...envArgs,\n ...userIdEnvArgs,\n '-v',\n `${workspaceRoot}:/workspace`,\n '-w',\n `/workspace/${relativePath}`,\n ...(publish ?? []).flatMap((p) => ['-p', p.trim()]),\n ...volumes.flatMap((volume) => [\n '-v',\n `${volume.type === 'host' ? volume.hostPath : volume.name}:${volume.containerPath}`,\n ]),\n ...(entrypoint ? ['--entrypoint', entrypoint] : []),\n imageUri,\n ...finalArgs,\n ];\n\n const output = await lockMany(\n volumes.flatMap((volume) =>\n volume.type === 'isolate' && volume.locked ? [volume.name] : [],\n ),\n async () => {\n const label = `⏳ ${finalArgs.join(' ')}`;\n console.time(label);\n const result = await $`docker ${dockerArgs}`.nothrow();\n console.timeEnd(label);\n\n return result;\n },\n );\n\n if (output.exitCode) {\n const stdout = output.stdout.trim();\n throw new Error(\n `Failed to run Docker container (exit code: ${output.exitCode})${stdout ? `\\n${stdout}` : ''}`,\n );\n }\n\n return output;\n}\n"]}
|
|
@@ -206,5 +206,5 @@ ${stdout}` : ""}`);
|
|
|
206
206
|
__name(executeToolCommand, "executeToolCommand");
|
|
207
207
|
|
|
208
208
|
export { executeToolCommand };
|
|
209
|
-
//# sourceMappingURL=
|
|
210
|
-
//# sourceMappingURL=
|
|
209
|
+
//# sourceMappingURL=JYJBE36S.js.map
|
|
210
|
+
//# sourceMappingURL=JYJBE36S.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/core/tool-executor.ts"],"names":["getHostUserIds","userInfo","os","uid","gid","undefined","$","verbose","stdio","process","stderr","mergeVolumes","defaultVolumes","userVolumes","uniqBy","volume","containerPath","resolveVolumePath","workspaceRoot","type","hostPath","path","resolve","replace","homedir","ensureDockerImage","imageUri","output","nothrow","quiet","exitCode","console","info","error","Error","stringifyError","isAuthError","includes","join","executeToolCommand","context","toolName","args","cwd","volumes","customEntrypoint","entrypoint","env","customEnvVars","script","publish","versions","defaultVolumesEnabled","tool","findToolByName","preExecute","findWorkspaceRoot","map","qualifyVolumeName","length","name","overrides","filter","uv","some","dv","resolvedVersion","resolveTypeVersions","getSecondaryVersion","secondaryVersion","satisfies","warn","getImageUriForTool","relativePath","relative","trim","defaultEnv","hasDockerSocketMount","dockerSocketEnv","value","envArgs","flatMap","hostUserIds","userIdEnvArgs","finalArgs","dockerArgs","privileged","p","lockMany","locked","label","time","result","timeEnd","stdout"],"mappings":"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","file":"KHVBCTKK.js","sourcesContent":["import { uniqBy } from 'es-toolkit';\nimport os from 'node:os';\nimport path from 'node:path';\nimport process from 'node:process';\nimport * as semver from 'semver';\nimport { $, type ProcessOutput } from 'zx';\n\nimport type { EnvironmentVariable, VolumeMapping } from '../config';\nimport type { ChainContext } from '../context';\nimport { findWorkspaceRoot } from '../utils';\nimport { getImageUriForTool, qualifyVolumeName } from '../utils/docker';\nimport { stringifyError } from '../utils/error';\nimport { findToolByName } from '../utils/finder';\nimport { lockMany } from './lock';\nimport { resolveTypeVersions } from './version-resolver';\n\n/**\n * Get the current user's UID and GID for Docker container user matching.\n * This prevents permission issues when containers write to bind-mounted directories.\n * On Windows or when running as root, returns undefined as UID/GID matching is not needed.\n */\nconst getHostUserIds = (): { uid: number; gid: number } | undefined => {\n // os.userInfo() returns uid/gid on POSIX systems, -1 on Windows\n const userInfo = os.userInfo();\n if (userInfo.uid === -1 || userInfo.gid === -1) {\n return undefined;\n }\n\n return { uid: userInfo.uid, gid: userInfo.gid };\n};\n\n// Configure zx to inherit stdio by default (moved from original setup)\n$.verbose = true;\n$.stdio = ['inherit', 'pipe', process.stderr];\n\n/**\n * Merge default volumes with user-specified volumes\n * User volumes take precedence when containerPath conflicts\n */\nconst mergeVolumes = (\n defaultVolumes: readonly VolumeMapping[],\n userVolumes: readonly VolumeMapping[],\n): VolumeMapping[] => uniqBy([...userVolumes, ...defaultVolumes], (volume) => volume.containerPath);\n\n/**\n * Resolve a host path in a volume to an absolute path.\n * - Paths starting with ~ are resolved to home directory\n * - Relative paths (starting with . or no prefix) are resolved to workspace root\n * - Absolute paths are left unchanged\n */\nconst resolveVolumePath = (volume: VolumeMapping, workspaceRoot: string): VolumeMapping =>\n volume.type === 'host'\n ? {\n ...volume,\n hostPath: path.resolve(workspaceRoot, volume.hostPath.replace(/^~/, os.homedir())),\n }\n : volume;\n\nconst ensureDockerImage = async (imageUri: string): Promise<void> => {\n let output: ProcessOutput;\n\n try {\n // Check local images first.\n //\n // NOTE: `docker image ls <ref>` prints repository/tag in separate columns, so\n // `stdout.includes(<full-ref>)` is not reliable. Use `inspect` instead: exitCode=0\n // means the image exists locally.\n // Keep output minimal to avoid dumping full inspect JSON into CI logs.\n //\n // NOTE: Using `.quiet()` to avoid stderr being captured in the CI logs. If the image\n // is not in the cache, the process prints \"Error response from daemon: No such image: ...\"\n // which can confuse the uninitiated. It's just a cache miss, not an error.\n output = await $`docker image inspect --format {{.Id}} ${imageUri}`.nothrow().quiet();\n if (!output.exitCode) {\n console.info(`✅ Using cached Docker image: ${imageUri}`);\n return;\n }\n\n console.info('📥 Pulling Docker image from:', imageUri);\n output = await $`docker pull ${imageUri}`.nothrow();\n } catch (error: unknown) {\n throw new Error(`Failed to pull Docker image ${imageUri}: ${stringifyError(error)}`);\n }\n\n if (output.exitCode) {\n const stderr = output.stderr ?? '';\n const isAuthError =\n stderr.includes('authorization token has expired') ||\n stderr.includes('denied') ||\n stderr.includes('pull access denied');\n\n throw new Error(\n [\n 'Docker image not available:',\n ` - Image: ${imageUri} (pull failed)`,\n isAuthError\n ? ' - ECR auth expired. Run: pnpm localnet login'\n : ' - Check if the image tag exists in image registry.',\n ].join('\\n'),\n );\n }\n\n console.info(`✅ Successfully pulled: ${imageUri}`);\n};\n\nexport interface ToolCommandExecutionOptions {\n cwd: string;\n volumes: readonly VolumeMapping[];\n customEntrypoint?: string;\n env: EnvironmentVariable[];\n args?: string[];\n script?: string;\n publish?: string[];\n versions?: Record<string, string>;\n defaultVolumesEnabled?: boolean;\n}\n\n/**\n * Enhanced tool command execution using the new version compatibility matrix system\n */\nexport async function executeToolCommand<TImageId extends string>(\n context: ChainContext<TImageId>,\n toolName: string,\n args: string[],\n {\n cwd,\n volumes: userVolumes,\n customEntrypoint: entrypoint,\n env: customEnvVars,\n script,\n publish,\n versions = {},\n defaultVolumesEnabled = true,\n }: ToolCommandExecutionOptions,\n): Promise<ProcessOutput> {\n const tool = findToolByName(context, toolName);\n\n // Run pre-execution hook if defined (e.g., toolchain sync)\n if (tool.preExecute) {\n await tool.preExecute(context, {\n cwd,\n args,\n volumes: userVolumes,\n env: customEnvVars,\n script,\n publish,\n versions,\n defaultVolumesEnabled,\n });\n }\n\n const workspaceRoot = await findWorkspaceRoot(cwd);\n\n const defaultVolumes = defaultVolumesEnabled ? (tool.defaultVolumes ?? []) : [];\n const volumes = mergeVolumes(defaultVolumes, userVolumes)\n .map((volume) => resolveVolumePath(volume, workspaceRoot))\n .map(qualifyVolumeName);\n\n if (defaultVolumes.length > 0) {\n console.info(`📦 Using ${defaultVolumes.length} default volume(s) for ${tool.name}`);\n if (userVolumes.length > 0) {\n const overrides = userVolumes.filter((uv) =>\n defaultVolumes.some((dv) => dv.containerPath === uv.containerPath),\n );\n if (overrides.length > 0) {\n console.info(`🔧 User volumes override ${overrides.length} default volume(s)`);\n }\n }\n }\n\n // Get the resolved version for the current tool.\n const resolvedVersion = resolveTypeVersions(context, versions)[tool.name];\n\n if (!resolvedVersion) {\n throw new Error(`No version resolved for tool ${tool.name}`);\n }\n\n console.info(`🔧 ${tool.name} version: ${resolvedVersion}`);\n\n // Check secondary version validation if available\n if (tool.getSecondaryVersion) {\n try {\n const secondaryVersion = await tool.getSecondaryVersion({ cwd });\n\n if (!semver.satisfies(secondaryVersion, resolvedVersion)) {\n console.warn(\n `Warning: Local configuration version (${secondaryVersion}) differs from resolved version (${resolvedVersion})`,\n );\n }\n } catch (error) {\n // Secondary version check failed, but continue with resolved version\n console.warn('Could not validate secondary version:', stringifyError(error));\n }\n }\n\n // Use Docker image with merged volumes\n const imageUri = await getImageUriForTool(context, tool.name, resolvedVersion);\n const relativePath = path.relative(workspaceRoot, cwd);\n\n await ensureDockerImage(imageUri);\n\n if (entrypoint?.trim()) {\n console.info(`🔧 Using custom entrypoint: ${entrypoint}`);\n }\n\n // Merge default env vars with custom env vars (custom takes precedence)\n const defaultEnv = tool.defaultEnv ?? [];\n\n // Check if Docker socket is mounted (for tools that spawn Docker containers like anchor --verifiable)\n // If so, inject HOST_CWD and HOST_WORKSPACE_ROOT so the inner container knows the host paths\n const hasDockerSocketMount = volumes.some(\n (volume) => volume.type === 'host' && volume.containerPath === '/var/run/docker.sock',\n );\n const dockerSocketEnv: EnvironmentVariable[] = hasDockerSocketMount\n ? [\n { name: 'HOST_CWD', value: cwd },\n { name: 'HOST_WORKSPACE_ROOT', value: workspaceRoot },\n ]\n : [];\n\n const envArgs = uniqBy(\n [...customEnvVars, ...dockerSocketEnv, ...defaultEnv],\n ({ name }) => name,\n ).flatMap(({ name, value }) => ['-e', `${name}=${value}`]);\n\n // Add host user UID/GID for permission matching on Linux/macOS\n // This prevents artifacts created in containers from having root ownership\n // Currently only used for stellar which has an entrypoint that handles UID/GID\n const hostUserIds = getHostUserIds();\n const userIdEnvArgs = hostUserIds\n ? ['-e', `LOCAL_UID=${hostUserIds.uid}`, '-e', `LOCAL_GID=${hostUserIds.gid}`]\n : [];\n\n console.info(`👤 Running container as UID:GID ${hostUserIds?.uid}:${hostUserIds?.gid}`);\n\n if (defaultEnv.length > 0) {\n console.info(\n `🌍 Using ${defaultEnv.length} default environment variable(s) for ${tool.name}`,\n );\n }\n if (customEnvVars.length > 0) {\n console.info(`🌍 Using ${customEnvVars.length} custom environment variable(s)`);\n }\n\n // Handle custom script execution\n let finalArgs: string[];\n if (script && script.trim() !== '') {\n console.info(`📜 Executing custom script: ${script}`);\n finalArgs = ['bash', '-c', script];\n } else {\n finalArgs = entrypoint === undefined ? [tool.name, ...args] : args;\n }\n\n // Build the Docker command with proper argument separation\n const dockerArgs = [\n 'run',\n ...(tool.privileged ? ['--privileged'] : []),\n '--rm',\n '--add-host=host.docker.internal:host-gateway',\n ...envArgs,\n ...userIdEnvArgs,\n '-v',\n `${workspaceRoot}:/workspace`,\n '-w',\n `/workspace/${relativePath}`,\n ...(publish ?? []).flatMap((p) => ['-p', p.trim()]),\n ...volumes.flatMap((volume) => [\n '-v',\n `${volume.type === 'host' ? volume.hostPath : volume.name}:${volume.containerPath}`,\n ]),\n ...(entrypoint ? ['--entrypoint', entrypoint] : []),\n imageUri,\n ...finalArgs,\n ];\n\n const output = await lockMany(\n volumes.flatMap((volume) =>\n volume.type === 'isolate' && volume.locked ? [volume.name] : [],\n ),\n async () => {\n const label = `⏳ ${finalArgs.join(' ')}`;\n console.time(label);\n const result = await $`docker ${dockerArgs}`.nothrow();\n console.timeEnd(label);\n\n return result;\n },\n );\n\n if (output.exitCode) {\n const stdout = output.stdout.trim();\n throw new Error(\n `Failed to run Docker container (exit code: ${output.exitCode})${stdout ? `\\n${stdout}` : ''}`,\n );\n }\n\n return output;\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/core/tool-executor.ts"],"names":["getHostUserIds","userInfo","os","uid","gid","undefined","$","verbose","stdio","process","stderr","mergeVolumes","defaultVolumes","userVolumes","uniqBy","volume","containerPath","resolveVolumePath","workspaceRoot","type","hostPath","path","resolve","replace","homedir","ensureDockerImage","imageUri","output","nothrow","quiet","exitCode","console","info","error","Error","stringifyError","isAuthError","includes","join","executeToolCommand","context","toolName","args","cwd","volumes","customEntrypoint","entrypoint","env","customEnvVars","script","publish","versions","defaultVolumesEnabled","tool","findToolByName","preExecute","findWorkspaceRoot","map","qualifyVolumeName","length","name","overrides","filter","uv","some","dv","resolvedVersion","resolveTypeVersions","getSecondaryVersion","secondaryVersion","satisfies","warn","getImageUriForTool","relativePath","relative","trim","defaultEnv","hasDockerSocketMount","dockerSocketEnv","value","envArgs","flatMap","hostUserIds","userIdEnvArgs","finalArgs","dockerArgs","privileged","p","lockMany","locked","label","time","result","timeEnd","stdout"],"mappings":"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","file":"JYJBE36S.js","sourcesContent":["import { uniqBy } from 'es-toolkit';\nimport os from 'node:os';\nimport path from 'node:path';\nimport process from 'node:process';\nimport * as semver from 'semver';\nimport { $, type ProcessOutput } from 'zx';\n\nimport type { EnvironmentVariable, VolumeMapping } from '../config';\nimport type { ChainContext } from '../context';\nimport { findWorkspaceRoot } from '../utils';\nimport { getImageUriForTool, qualifyVolumeName } from '../utils/docker';\nimport { stringifyError } from '../utils/error';\nimport { findToolByName } from '../utils/finder';\nimport { lockMany } from './lock';\nimport { resolveTypeVersions } from './version-resolver';\n\n/**\n * Get the current user's UID and GID for Docker container user matching.\n * This prevents permission issues when containers write to bind-mounted directories.\n * On Windows or when running as root, returns undefined as UID/GID matching is not needed.\n */\nconst getHostUserIds = (): { uid: number; gid: number } | undefined => {\n // os.userInfo() returns uid/gid on POSIX systems, -1 on Windows\n const userInfo = os.userInfo();\n if (userInfo.uid === -1 || userInfo.gid === -1) {\n return undefined;\n }\n\n return { uid: userInfo.uid, gid: userInfo.gid };\n};\n\n// Configure zx to inherit stdio by default (moved from original setup)\n$.verbose = true;\n$.stdio = ['inherit', 'pipe', process.stderr];\n\n/**\n * Merge default volumes with user-specified volumes\n * User volumes take precedence when containerPath conflicts\n */\nconst mergeVolumes = (\n defaultVolumes: readonly VolumeMapping[],\n userVolumes: readonly VolumeMapping[],\n): VolumeMapping[] => uniqBy([...userVolumes, ...defaultVolumes], (volume) => volume.containerPath);\n\n/**\n * Resolve a host path in a volume to an absolute path.\n * - Paths starting with ~ are resolved to home directory\n * - Relative paths (starting with . or no prefix) are resolved to workspace root\n * - Absolute paths are left unchanged\n */\nconst resolveVolumePath = (volume: VolumeMapping, workspaceRoot: string): VolumeMapping =>\n volume.type === 'host'\n ? {\n ...volume,\n hostPath: path.resolve(workspaceRoot, volume.hostPath.replace(/^~/, os.homedir())),\n }\n : volume;\n\nconst ensureDockerImage = async (imageUri: string): Promise<void> => {\n let output: ProcessOutput;\n\n try {\n // Check local images first.\n //\n // NOTE: `docker image ls <ref>` prints repository/tag in separate columns, so\n // `stdout.includes(<full-ref>)` is not reliable. Use `inspect` instead: exitCode=0\n // means the image exists locally.\n // Keep output minimal to avoid dumping full inspect JSON into CI logs.\n //\n // NOTE: Using `.quiet()` to avoid stderr being captured in the CI logs. If the image\n // is not in the cache, the process prints \"Error response from daemon: No such image: ...\"\n // which can confuse the uninitiated. It's just a cache miss, not an error.\n output = await $`docker image inspect --format {{.Id}} ${imageUri}`.nothrow().quiet();\n if (!output.exitCode) {\n console.info(`✅ Using cached Docker image: ${imageUri}`);\n return;\n }\n\n console.info('📥 Pulling Docker image from:', imageUri);\n output = await $`docker pull ${imageUri}`.nothrow();\n } catch (error: unknown) {\n throw new Error(`Failed to pull Docker image ${imageUri}: ${stringifyError(error)}`);\n }\n\n if (output.exitCode) {\n const stderr = output.stderr ?? '';\n const isAuthError =\n stderr.includes('authorization token has expired') ||\n stderr.includes('denied') ||\n stderr.includes('pull access denied');\n\n throw new Error(\n [\n 'Docker image not available:',\n ` - Image: ${imageUri} (pull failed)`,\n isAuthError\n ? ' - ECR auth expired. Run: pnpm localnet login'\n : ' - Check if the image tag exists in image registry.',\n ].join('\\n'),\n );\n }\n\n console.info(`✅ Successfully pulled: ${imageUri}`);\n};\n\nexport interface ToolCommandExecutionOptions {\n cwd: string;\n volumes: readonly VolumeMapping[];\n customEntrypoint?: string;\n env: EnvironmentVariable[];\n args?: string[];\n script?: string;\n publish?: string[];\n versions?: Record<string, string>;\n defaultVolumesEnabled?: boolean;\n}\n\n/**\n * Enhanced tool command execution using the new version compatibility matrix system\n */\nexport async function executeToolCommand<TImageId extends string>(\n context: ChainContext<TImageId>,\n toolName: string,\n args: string[],\n {\n cwd,\n volumes: userVolumes,\n customEntrypoint: entrypoint,\n env: customEnvVars,\n script,\n publish,\n versions = {},\n defaultVolumesEnabled = true,\n }: ToolCommandExecutionOptions,\n): Promise<ProcessOutput> {\n const tool = findToolByName(context, toolName);\n\n // Run pre-execution hook if defined (e.g., toolchain sync)\n if (tool.preExecute) {\n await tool.preExecute(context, {\n cwd,\n args,\n volumes: userVolumes,\n env: customEnvVars,\n script,\n publish,\n versions,\n defaultVolumesEnabled,\n });\n }\n\n const workspaceRoot = await findWorkspaceRoot(cwd);\n\n const defaultVolumes = defaultVolumesEnabled ? (tool.defaultVolumes ?? []) : [];\n const volumes = mergeVolumes(defaultVolumes, userVolumes)\n .map((volume) => resolveVolumePath(volume, workspaceRoot))\n .map(qualifyVolumeName);\n\n if (defaultVolumes.length > 0) {\n console.info(`📦 Using ${defaultVolumes.length} default volume(s) for ${tool.name}`);\n if (userVolumes.length > 0) {\n const overrides = userVolumes.filter((uv) =>\n defaultVolumes.some((dv) => dv.containerPath === uv.containerPath),\n );\n if (overrides.length > 0) {\n console.info(`🔧 User volumes override ${overrides.length} default volume(s)`);\n }\n }\n }\n\n // Get the resolved version for the current tool.\n const resolvedVersion = resolveTypeVersions(context, versions)[tool.name];\n\n if (!resolvedVersion) {\n throw new Error(`No version resolved for tool ${tool.name}`);\n }\n\n console.info(`🔧 ${tool.name} version: ${resolvedVersion}`);\n\n // Check secondary version validation if available\n if (tool.getSecondaryVersion) {\n try {\n const secondaryVersion = await tool.getSecondaryVersion({ cwd });\n\n if (!semver.satisfies(secondaryVersion, resolvedVersion)) {\n console.warn(\n `Warning: Local configuration version (${secondaryVersion}) differs from resolved version (${resolvedVersion})`,\n );\n }\n } catch (error) {\n // Secondary version check failed, but continue with resolved version\n console.warn('Could not validate secondary version:', stringifyError(error));\n }\n }\n\n // Use Docker image with merged volumes\n const imageUri = await getImageUriForTool(context, tool.name, resolvedVersion);\n const relativePath = path.relative(workspaceRoot, cwd);\n\n await ensureDockerImage(imageUri);\n\n if (entrypoint?.trim()) {\n console.info(`🔧 Using custom entrypoint: ${entrypoint}`);\n }\n\n // Merge default env vars with custom env vars (custom takes precedence)\n const defaultEnv = tool.defaultEnv ?? [];\n\n // Check if Docker socket is mounted (for tools that spawn Docker containers like anchor --verifiable)\n // If so, inject HOST_CWD and HOST_WORKSPACE_ROOT so the inner container knows the host paths\n const hasDockerSocketMount = volumes.some(\n (volume) => volume.type === 'host' && volume.containerPath === '/var/run/docker.sock',\n );\n const dockerSocketEnv: EnvironmentVariable[] = hasDockerSocketMount\n ? [\n { name: 'HOST_CWD', value: cwd },\n { name: 'HOST_WORKSPACE_ROOT', value: workspaceRoot },\n ]\n : [];\n\n const envArgs = uniqBy(\n [...customEnvVars, ...dockerSocketEnv, ...defaultEnv],\n ({ name }) => name,\n ).flatMap(({ name, value }) => ['-e', `${name}=${value}`]);\n\n // Add host user UID/GID for permission matching on Linux/macOS\n // This prevents artifacts created in containers from having root ownership\n // Used by stellar, sui, and iota images which have an entrypoint that handles UID/GID\n const hostUserIds = getHostUserIds();\n const userIdEnvArgs = hostUserIds\n ? ['-e', `LOCAL_UID=${hostUserIds.uid}`, '-e', `LOCAL_GID=${hostUserIds.gid}`]\n : [];\n\n console.info(`👤 Running container as UID:GID ${hostUserIds?.uid}:${hostUserIds?.gid}`);\n\n if (defaultEnv.length > 0) {\n console.info(\n `🌍 Using ${defaultEnv.length} default environment variable(s) for ${tool.name}`,\n );\n }\n if (customEnvVars.length > 0) {\n console.info(`🌍 Using ${customEnvVars.length} custom environment variable(s)`);\n }\n\n // Handle custom script execution\n let finalArgs: string[];\n if (script && script.trim() !== '') {\n console.info(`📜 Executing custom script: ${script}`);\n finalArgs = ['bash', '-c', script];\n } else {\n finalArgs = entrypoint === undefined ? [tool.name, ...args] : args;\n }\n\n // Build the Docker command with proper argument separation\n const dockerArgs = [\n 'run',\n ...(tool.privileged ? ['--privileged'] : []),\n '--rm',\n '--add-host=host.docker.internal:host-gateway',\n ...envArgs,\n ...userIdEnvArgs,\n '-v',\n `${workspaceRoot}:/workspace`,\n '-w',\n `/workspace/${relativePath}`,\n ...(publish ?? []).flatMap((p) => ['-p', p.trim()]),\n ...volumes.flatMap((volume) => [\n '-v',\n `${volume.type === 'host' ? volume.hostPath : volume.name}:${volume.containerPath}`,\n ]),\n ...(entrypoint ? ['--entrypoint', entrypoint] : []),\n imageUri,\n ...finalArgs,\n ];\n\n const output = await lockMany(\n volumes.flatMap((volume) =>\n volume.type === 'isolate' && volume.locked ? [volume.name] : [],\n ),\n async () => {\n const label = `⏳ ${finalArgs.join(' ')}`;\n console.time(label);\n const result = await $`docker ${dockerArgs}`.nothrow();\n console.timeEnd(label);\n\n return result;\n },\n );\n\n if (output.exitCode) {\n const stdout = output.stdout.trim();\n throw new Error(\n `Failed to run Docker container (exit code: ${output.exitCode})${stdout ? `\\n${stdout}` : ''}`,\n );\n }\n\n return output;\n}\n"]}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
var HOQEVWFL_cjs = require('./HOQEVWFL.cjs');
|
|
4
|
-
var
|
|
4
|
+
var _7E7TMR5F_cjs = require('./7E7TMR5F.cjs');
|
|
5
5
|
var RVRC4KBY_cjs = require('./RVRC4KBY.cjs');
|
|
6
6
|
var _4BP4CCPZ_cjs = require('./4BP4CCPZ.cjs');
|
|
7
7
|
var KHVGLVR5_cjs = require('./KHVGLVR5.cjs');
|
|
@@ -120,7 +120,7 @@ var createCli = /* @__PURE__ */ KHVGLVR5_cjs.__name((context, registerExtraComma
|
|
|
120
120
|
program.command(tool.name, {
|
|
121
121
|
isDefault: false
|
|
122
122
|
}).description(`Run ${tool.name} with version checking`).passThroughOptions(true).allowUnknownOption().helpOption(false).argument("[args...]", "Arguments to pass to the tool").action(async (args) => {
|
|
123
|
-
await
|
|
123
|
+
await _7E7TMR5F_cjs.executeToolCommand(context, tool.name, args, await parseGlobalOptions(program));
|
|
124
124
|
});
|
|
125
125
|
}
|
|
126
126
|
registerExtraCommands?.(program, parseGlobalOptions);
|
|
@@ -136,5 +136,5 @@ var runCli = /* @__PURE__ */ KHVGLVR5_cjs.__name(async (config, registerExtraCom
|
|
|
136
136
|
}, "runCli");
|
|
137
137
|
|
|
138
138
|
exports.runCli = runCli;
|
|
139
|
-
//# sourceMappingURL=
|
|
140
|
-
//# sourceMappingURL=
|
|
139
|
+
//# sourceMappingURL=MH3SPPX5.cjs.map
|
|
140
|
+
//# sourceMappingURL=MH3SPPX5.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/cli.ts"],"names":["init_cjs_shims","createCli","__name","context","registerExtraCommands","tools","toolVersionOptions","Object","fromEntries","map","name","camelCase","parseGlobalOptions","command","cwd","volume","defaultVolumes","options","opts","resolvedCwd","process","cliVersions","entries","version","filter","tool","configVersions","getDefaultVersions","versions","volumes","defaultVolumesEnabled","program","Command","description","enablePositionalOptions","argv","includes","displayVersionCombinations","exit","option","input","Error","path","isAbsolute","fs","existsSync","statSync","isDirectory","variables","valueParts","split","length","value","join","type","hostPath","containerPath","volumeMappingSchema","parse","previous","defaultVersion","getToolDefaultVersion","supportedVersions","getToolSupportedVersions","action","toolName","displayToolVersionInfo","isDefault","passThroughOptions","allowUnknownOption","helpOption","argument","args","executeToolCommand","runCli","config","parseAsync","error","console"],"mappings":"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","file":"2JEGETUJ.cjs","sourcesContent":["import { Command } from 'commander';\nimport { camelCase } from 'es-toolkit';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport process from 'node:process';\n\nimport type { EnvironmentVariable, VolumeMapping } from './config';\nimport { volumeMappingSchema } from './config';\nimport type { ChainContext } from './context';\nimport type { ToolCommandExecutionOptions } from './core';\nimport { executeToolCommand } from './core';\nimport { displayToolVersionInfo, displayVersionCombinations } from './display';\nimport { getToolDefaultVersion, getToolSupportedVersions } from './utils/finder';\n\ninterface GlobalOptions {\n cwd?: string;\n volume: VolumeMapping[];\n env: EnvironmentVariable[];\n publish?: string[];\n script?: string;\n customEntrypoint?: string;\n defaultVolumes: boolean;\n}\n\ntype RegisterExtraCommands = (\n program: Command,\n parseGlobalOptions: (command: Command) => Promise<ToolCommandExecutionOptions>,\n) => void;\n\nconst createCli = <TImageId extends string>(\n context: ChainContext<TImageId>,\n registerExtraCommands?: RegisterExtraCommands,\n): Command => {\n const { tools } = context;\n const toolVersionOptions = Object.fromEntries(\n tools.map(({ name }) => [`${camelCase(name)}Version`, name]),\n );\n\n const parseGlobalOptions = async (command: Command): Promise<ToolCommandExecutionOptions> => {\n const { cwd, volume, defaultVolumes, ...options } = command.opts<GlobalOptions>();\n const resolvedCwd = cwd ?? process.cwd();\n\n // CLI flags take precedence over project config versions\n const cliVersions = Object.fromEntries(\n Object.entries(options)\n .map(([name, version]) => [toolVersionOptions[name], version])\n .filter(([tool]) => tool),\n );\n\n // Read defaults from project config (e.g., Anchor.toml) if the chain provides a hook\n const configVersions = (await context.getDefaultVersions?.(resolvedCwd)) ?? {};\n const versions = { ...configVersions, ...cliVersions };\n\n return {\n ...options,\n cwd: resolvedCwd,\n volumes: volume,\n versions,\n defaultVolumesEnabled: defaultVolumes,\n };\n };\n\n const program = new Command();\n\n program\n .name('lz-tool')\n .description(\n '🚀 LayerZero VM tooling with intelligent version management\\n' +\n '\\n' +\n 'Usage pattern:\\n' +\n ' lz-tool [global-options] <tool> [tool-args...]\\n' +\n '\\n' +\n 'Examples:\\n' +\n ' lz-tool -e bash sui --help\\n' +\n ' lz-tool --sui-version 1.38.0 sui client\\n' +\n '\\n' +\n 'Note: All lz-tool options must appear BEFORE the tool name.',\n )\n .version('1.0.0')\n .enablePositionalOptions(); // Required for passThroughOptions to work\n\n // Check for --list-versions before parsing to avoid help display\n if (process.argv.includes('--list-versions')) {\n displayVersionCombinations(context);\n process.exit(0);\n }\n\n // Add global options.\n program\n .option('-c, --cwd <path>', 'Current working directory', (input: string) => {\n if (typeof input !== 'string') {\n throw new Error('cwd flag must be a string');\n }\n\n if (!path.isAbsolute(input)) {\n throw new Error('cwd must be an absolute path if provided');\n }\n\n if (!fs.existsSync(input)) {\n throw new Error('cwd does not exist');\n }\n\n if (!fs.statSync(input).isDirectory()) {\n throw new Error('cwd must be a directory');\n }\n\n return input;\n })\n .option(\n '-e, --custom-entrypoint <entrypoint>',\n 'Override the default Docker entrypoint for the tool',\n )\n .option(\n '--script <script>',\n 'Execute a custom script using bash -c in the Docker container (e.g., --script \"npm install && npm test\")',\n )\n .option(\n '--env <name=value>',\n 'Set environment variables for Docker container (e.g., --env NODE_ENV=production)',\n (input: string, variables: EnvironmentVariable[]) => {\n const [name, ...valueParts] = input.split('=');\n\n if (!name || !valueParts.length) {\n throw new Error(\n `Invalid environment variable format: ${input}. Use --env NAME=VALUE`,\n );\n }\n\n return [...variables, { name, value: valueParts.join('=') }];\n },\n [],\n )\n .option(\n '-v, --volume <type:hostPath:containerPath[:name]>',\n 'Volume mappings in the format type:hostPath:containerPath[:name] (e.g., host:/host/path:/container/path or isolate::/container/path:volumeName)',\n (input: string, volumes: VolumeMapping[]) => {\n const [type, hostPath, containerPath, name] = input.split(':');\n\n switch (type) {\n case 'host':\n if (!hostPath) {\n throw new Error(`Host path is required for volume type 'host'`);\n }\n break;\n case 'isolate':\n if (!name) {\n throw new Error(`Name is required for volume type 'isolate'`);\n }\n break;\n default:\n throw new Error(`Invalid volume type: ${type}`);\n }\n\n if (!containerPath) {\n throw new Error(`Container path is required`);\n }\n\n return [\n ...volumes,\n volumeMappingSchema.parse({ type, hostPath, containerPath, name }),\n ];\n },\n [],\n )\n .option(\n '-p, --publish <host_port:container_port>',\n \"Publish a container's port(s) to the host (repeatable)\",\n (value: string, previous: string[]) => [...previous, value],\n [],\n )\n .option('--no-default-volumes', 'Disable default volumes for the tool');\n\n // Add version options for each tool dynamically\n for (const tool of tools) {\n const defaultVersion = getToolDefaultVersion(context, tool.name);\n const supportedVersions = getToolSupportedVersions(context, tool.name);\n\n program.option(\n `--${tool.name}-version <version>`,\n `Specify ${tool.name} version (default: ${defaultVersion}, supported: ${supportedVersions.join(', ')})`,\n );\n }\n\n // Add utility options\n program.option('--list-versions', 'Display all supported version combinations and exit');\n\n // Add version info command\n program\n .command('version-info <tool>')\n .description('Display detailed version information for a specific tool')\n .action((toolName: string) => displayToolVersionInfo(context, toolName));\n\n for (const tool of tools) {\n // Don't add any options to the subcommand level.\n // All lz-tool options must be specified before the subcommand.\n program\n .command(tool.name, { isDefault: false })\n .description(`Run ${tool.name} with version checking`)\n .passThroughOptions(true) // Pass through all options after the subcommand\n .allowUnknownOption()\n .helpOption(false) // Disable automatic help option to pass --help to the tool\n .argument('[args...]', 'Arguments to pass to the tool')\n .action(async (args: string[]) => {\n await executeToolCommand(\n context,\n tool.name,\n args,\n await parseGlobalOptions(program),\n );\n });\n }\n\n // Allow external registration of extra commands\n registerExtraCommands?.(program, parseGlobalOptions);\n\n return program;\n};\n\nexport const runCli = async <TImageId extends string>(\n config: ChainContext<TImageId>,\n registerExtraCommands?: RegisterExtraCommands,\n): Promise<void> => {\n try {\n await createCli<TImageId>(config, registerExtraCommands).parseAsync();\n } catch (error) {\n console.error('❌ VM tool execution failed', error);\n process.exit(1);\n }\n};\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/cli.ts"],"names":["init_cjs_shims","createCli","__name","context","registerExtraCommands","tools","toolVersionOptions","Object","fromEntries","map","name","camelCase","parseGlobalOptions","command","cwd","volume","defaultVolumes","options","opts","resolvedCwd","process","cliVersions","entries","version","filter","tool","configVersions","getDefaultVersions","versions","volumes","defaultVolumesEnabled","program","Command","description","enablePositionalOptions","argv","includes","displayVersionCombinations","exit","option","input","Error","path","isAbsolute","fs","existsSync","statSync","isDirectory","variables","valueParts","split","length","value","join","type","hostPath","containerPath","volumeMappingSchema","parse","previous","defaultVersion","getToolDefaultVersion","supportedVersions","getToolSupportedVersions","action","toolName","displayToolVersionInfo","isDefault","passThroughOptions","allowUnknownOption","helpOption","argument","args","executeToolCommand","runCli","config","parseAsync","error","console"],"mappings":"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","file":"MH3SPPX5.cjs","sourcesContent":["import { Command } from 'commander';\nimport { camelCase } from 'es-toolkit';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport process from 'node:process';\n\nimport type { EnvironmentVariable, VolumeMapping } from './config';\nimport { volumeMappingSchema } from './config';\nimport type { ChainContext } from './context';\nimport type { ToolCommandExecutionOptions } from './core';\nimport { executeToolCommand } from './core';\nimport { displayToolVersionInfo, displayVersionCombinations } from './display';\nimport { getToolDefaultVersion, getToolSupportedVersions } from './utils/finder';\n\ninterface GlobalOptions {\n cwd?: string;\n volume: VolumeMapping[];\n env: EnvironmentVariable[];\n publish?: string[];\n script?: string;\n customEntrypoint?: string;\n defaultVolumes: boolean;\n}\n\ntype RegisterExtraCommands = (\n program: Command,\n parseGlobalOptions: (command: Command) => Promise<ToolCommandExecutionOptions>,\n) => void;\n\nconst createCli = <TImageId extends string>(\n context: ChainContext<TImageId>,\n registerExtraCommands?: RegisterExtraCommands,\n): Command => {\n const { tools } = context;\n const toolVersionOptions = Object.fromEntries(\n tools.map(({ name }) => [`${camelCase(name)}Version`, name]),\n );\n\n const parseGlobalOptions = async (command: Command): Promise<ToolCommandExecutionOptions> => {\n const { cwd, volume, defaultVolumes, ...options } = command.opts<GlobalOptions>();\n const resolvedCwd = cwd ?? process.cwd();\n\n // CLI flags take precedence over project config versions\n const cliVersions = Object.fromEntries(\n Object.entries(options)\n .map(([name, version]) => [toolVersionOptions[name], version])\n .filter(([tool]) => tool),\n );\n\n // Read defaults from project config (e.g., Anchor.toml) if the chain provides a hook\n const configVersions = (await context.getDefaultVersions?.(resolvedCwd)) ?? {};\n const versions = { ...configVersions, ...cliVersions };\n\n return {\n ...options,\n cwd: resolvedCwd,\n volumes: volume,\n versions,\n defaultVolumesEnabled: defaultVolumes,\n };\n };\n\n const program = new Command();\n\n program\n .name('lz-tool')\n .description(\n '🚀 LayerZero VM tooling with intelligent version management\\n' +\n '\\n' +\n 'Usage pattern:\\n' +\n ' lz-tool [global-options] <tool> [tool-args...]\\n' +\n '\\n' +\n 'Examples:\\n' +\n ' lz-tool -e bash sui --help\\n' +\n ' lz-tool --sui-version 1.38.0 sui client\\n' +\n '\\n' +\n 'Note: All lz-tool options must appear BEFORE the tool name.',\n )\n .version('1.0.0')\n .enablePositionalOptions(); // Required for passThroughOptions to work\n\n // Check for --list-versions before parsing to avoid help display\n if (process.argv.includes('--list-versions')) {\n displayVersionCombinations(context);\n process.exit(0);\n }\n\n // Add global options.\n program\n .option('-c, --cwd <path>', 'Current working directory', (input: string) => {\n if (typeof input !== 'string') {\n throw new Error('cwd flag must be a string');\n }\n\n if (!path.isAbsolute(input)) {\n throw new Error('cwd must be an absolute path if provided');\n }\n\n if (!fs.existsSync(input)) {\n throw new Error('cwd does not exist');\n }\n\n if (!fs.statSync(input).isDirectory()) {\n throw new Error('cwd must be a directory');\n }\n\n return input;\n })\n .option(\n '-e, --custom-entrypoint <entrypoint>',\n 'Override the default Docker entrypoint for the tool',\n )\n .option(\n '--script <script>',\n 'Execute a custom script using bash -c in the Docker container (e.g., --script \"npm install && npm test\")',\n )\n .option(\n '--env <name=value>',\n 'Set environment variables for Docker container (e.g., --env NODE_ENV=production)',\n (input: string, variables: EnvironmentVariable[]) => {\n const [name, ...valueParts] = input.split('=');\n\n if (!name || !valueParts.length) {\n throw new Error(\n `Invalid environment variable format: ${input}. Use --env NAME=VALUE`,\n );\n }\n\n return [...variables, { name, value: valueParts.join('=') }];\n },\n [],\n )\n .option(\n '-v, --volume <type:hostPath:containerPath[:name]>',\n 'Volume mappings in the format type:hostPath:containerPath[:name] (e.g., host:/host/path:/container/path or isolate::/container/path:volumeName)',\n (input: string, volumes: VolumeMapping[]) => {\n const [type, hostPath, containerPath, name] = input.split(':');\n\n switch (type) {\n case 'host':\n if (!hostPath) {\n throw new Error(`Host path is required for volume type 'host'`);\n }\n break;\n case 'isolate':\n if (!name) {\n throw new Error(`Name is required for volume type 'isolate'`);\n }\n break;\n default:\n throw new Error(`Invalid volume type: ${type}`);\n }\n\n if (!containerPath) {\n throw new Error(`Container path is required`);\n }\n\n return [\n ...volumes,\n volumeMappingSchema.parse({ type, hostPath, containerPath, name }),\n ];\n },\n [],\n )\n .option(\n '-p, --publish <host_port:container_port>',\n \"Publish a container's port(s) to the host (repeatable)\",\n (value: string, previous: string[]) => [...previous, value],\n [],\n )\n .option('--no-default-volumes', 'Disable default volumes for the tool');\n\n // Add version options for each tool dynamically\n for (const tool of tools) {\n const defaultVersion = getToolDefaultVersion(context, tool.name);\n const supportedVersions = getToolSupportedVersions(context, tool.name);\n\n program.option(\n `--${tool.name}-version <version>`,\n `Specify ${tool.name} version (default: ${defaultVersion}, supported: ${supportedVersions.join(', ')})`,\n );\n }\n\n // Add utility options\n program.option('--list-versions', 'Display all supported version combinations and exit');\n\n // Add version info command\n program\n .command('version-info <tool>')\n .description('Display detailed version information for a specific tool')\n .action((toolName: string) => displayToolVersionInfo(context, toolName));\n\n for (const tool of tools) {\n // Don't add any options to the subcommand level.\n // All lz-tool options must be specified before the subcommand.\n program\n .command(tool.name, { isDefault: false })\n .description(`Run ${tool.name} with version checking`)\n .passThroughOptions(true) // Pass through all options after the subcommand\n .allowUnknownOption()\n .helpOption(false) // Disable automatic help option to pass --help to the tool\n .argument('[args...]', 'Arguments to pass to the tool')\n .action(async (args: string[]) => {\n await executeToolCommand(\n context,\n tool.name,\n args,\n await parseGlobalOptions(program),\n );\n });\n }\n\n // Allow external registration of extra commands\n registerExtraCommands?.(program, parseGlobalOptions);\n\n return program;\n};\n\nexport const runCli = async <TImageId extends string>(\n config: ChainContext<TImageId>,\n registerExtraCommands?: RegisterExtraCommands,\n): Promise<void> => {\n try {\n await createCli<TImageId>(config, registerExtraCommands).parseAsync();\n } catch (error) {\n console.error('❌ VM tool execution failed', error);\n process.exit(1);\n }\n};\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { displayVersionCombinations, displayToolVersionInfo } from './QH3FM6DD.js';
|
|
2
|
-
import { executeToolCommand } from './
|
|
2
|
+
import { executeToolCommand } from './JYJBE36S.js';
|
|
3
3
|
import { volumeMappingSchema } from './BJUOU4DR.js';
|
|
4
4
|
import { getToolDefaultVersion, getToolSupportedVersions } from './3XEUJAQB.js';
|
|
5
5
|
import { init_esm_shims, __name } from './CWKWODSW.js';
|
|
@@ -128,5 +128,5 @@ var runCli = /* @__PURE__ */ __name(async (config, registerExtraCommands) => {
|
|
|
128
128
|
}, "runCli");
|
|
129
129
|
|
|
130
130
|
export { runCli };
|
|
131
|
-
//# sourceMappingURL=
|
|
132
|
-
//# sourceMappingURL=
|
|
131
|
+
//# sourceMappingURL=UQGPF6NC.js.map
|
|
132
|
+
//# sourceMappingURL=UQGPF6NC.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/cli.ts"],"names":["createCli","context","registerExtraCommands","tools","toolVersionOptions","Object","fromEntries","map","name","camelCase","parseGlobalOptions","command","cwd","volume","defaultVolumes","options","opts","resolvedCwd","process","cliVersions","entries","version","filter","tool","configVersions","getDefaultVersions","versions","volumes","defaultVolumesEnabled","program","Command","description","enablePositionalOptions","argv","includes","displayVersionCombinations","exit","option","input","Error","path","isAbsolute","fs","existsSync","statSync","isDirectory","variables","valueParts","split","length","value","join","type","hostPath","containerPath","volumeMappingSchema","parse","previous","defaultVersion","getToolDefaultVersion","supportedVersions","getToolSupportedVersions","action","toolName","displayToolVersionInfo","isDefault","passThroughOptions","allowUnknownOption","helpOption","argument","args","executeToolCommand","runCli","config","parseAsync","error","console"],"mappings":"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","file":"3I5XNU26.js","sourcesContent":["import { Command } from 'commander';\nimport { camelCase } from 'es-toolkit';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport process from 'node:process';\n\nimport type { EnvironmentVariable, VolumeMapping } from './config';\nimport { volumeMappingSchema } from './config';\nimport type { ChainContext } from './context';\nimport type { ToolCommandExecutionOptions } from './core';\nimport { executeToolCommand } from './core';\nimport { displayToolVersionInfo, displayVersionCombinations } from './display';\nimport { getToolDefaultVersion, getToolSupportedVersions } from './utils/finder';\n\ninterface GlobalOptions {\n cwd?: string;\n volume: VolumeMapping[];\n env: EnvironmentVariable[];\n publish?: string[];\n script?: string;\n customEntrypoint?: string;\n defaultVolumes: boolean;\n}\n\ntype RegisterExtraCommands = (\n program: Command,\n parseGlobalOptions: (command: Command) => Promise<ToolCommandExecutionOptions>,\n) => void;\n\nconst createCli = <TImageId extends string>(\n context: ChainContext<TImageId>,\n registerExtraCommands?: RegisterExtraCommands,\n): Command => {\n const { tools } = context;\n const toolVersionOptions = Object.fromEntries(\n tools.map(({ name }) => [`${camelCase(name)}Version`, name]),\n );\n\n const parseGlobalOptions = async (command: Command): Promise<ToolCommandExecutionOptions> => {\n const { cwd, volume, defaultVolumes, ...options } = command.opts<GlobalOptions>();\n const resolvedCwd = cwd ?? process.cwd();\n\n // CLI flags take precedence over project config versions\n const cliVersions = Object.fromEntries(\n Object.entries(options)\n .map(([name, version]) => [toolVersionOptions[name], version])\n .filter(([tool]) => tool),\n );\n\n // Read defaults from project config (e.g., Anchor.toml) if the chain provides a hook\n const configVersions = (await context.getDefaultVersions?.(resolvedCwd)) ?? {};\n const versions = { ...configVersions, ...cliVersions };\n\n return {\n ...options,\n cwd: resolvedCwd,\n volumes: volume,\n versions,\n defaultVolumesEnabled: defaultVolumes,\n };\n };\n\n const program = new Command();\n\n program\n .name('lz-tool')\n .description(\n '🚀 LayerZero VM tooling with intelligent version management\\n' +\n '\\n' +\n 'Usage pattern:\\n' +\n ' lz-tool [global-options] <tool> [tool-args...]\\n' +\n '\\n' +\n 'Examples:\\n' +\n ' lz-tool -e bash sui --help\\n' +\n ' lz-tool --sui-version 1.38.0 sui client\\n' +\n '\\n' +\n 'Note: All lz-tool options must appear BEFORE the tool name.',\n )\n .version('1.0.0')\n .enablePositionalOptions(); // Required for passThroughOptions to work\n\n // Check for --list-versions before parsing to avoid help display\n if (process.argv.includes('--list-versions')) {\n displayVersionCombinations(context);\n process.exit(0);\n }\n\n // Add global options.\n program\n .option('-c, --cwd <path>', 'Current working directory', (input: string) => {\n if (typeof input !== 'string') {\n throw new Error('cwd flag must be a string');\n }\n\n if (!path.isAbsolute(input)) {\n throw new Error('cwd must be an absolute path if provided');\n }\n\n if (!fs.existsSync(input)) {\n throw new Error('cwd does not exist');\n }\n\n if (!fs.statSync(input).isDirectory()) {\n throw new Error('cwd must be a directory');\n }\n\n return input;\n })\n .option(\n '-e, --custom-entrypoint <entrypoint>',\n 'Override the default Docker entrypoint for the tool',\n )\n .option(\n '--script <script>',\n 'Execute a custom script using bash -c in the Docker container (e.g., --script \"npm install && npm test\")',\n )\n .option(\n '--env <name=value>',\n 'Set environment variables for Docker container (e.g., --env NODE_ENV=production)',\n (input: string, variables: EnvironmentVariable[]) => {\n const [name, ...valueParts] = input.split('=');\n\n if (!name || !valueParts.length) {\n throw new Error(\n `Invalid environment variable format: ${input}. Use --env NAME=VALUE`,\n );\n }\n\n return [...variables, { name, value: valueParts.join('=') }];\n },\n [],\n )\n .option(\n '-v, --volume <type:hostPath:containerPath[:name]>',\n 'Volume mappings in the format type:hostPath:containerPath[:name] (e.g., host:/host/path:/container/path or isolate::/container/path:volumeName)',\n (input: string, volumes: VolumeMapping[]) => {\n const [type, hostPath, containerPath, name] = input.split(':');\n\n switch (type) {\n case 'host':\n if (!hostPath) {\n throw new Error(`Host path is required for volume type 'host'`);\n }\n break;\n case 'isolate':\n if (!name) {\n throw new Error(`Name is required for volume type 'isolate'`);\n }\n break;\n default:\n throw new Error(`Invalid volume type: ${type}`);\n }\n\n if (!containerPath) {\n throw new Error(`Container path is required`);\n }\n\n return [\n ...volumes,\n volumeMappingSchema.parse({ type, hostPath, containerPath, name }),\n ];\n },\n [],\n )\n .option(\n '-p, --publish <host_port:container_port>',\n \"Publish a container's port(s) to the host (repeatable)\",\n (value: string, previous: string[]) => [...previous, value],\n [],\n )\n .option('--no-default-volumes', 'Disable default volumes for the tool');\n\n // Add version options for each tool dynamically\n for (const tool of tools) {\n const defaultVersion = getToolDefaultVersion(context, tool.name);\n const supportedVersions = getToolSupportedVersions(context, tool.name);\n\n program.option(\n `--${tool.name}-version <version>`,\n `Specify ${tool.name} version (default: ${defaultVersion}, supported: ${supportedVersions.join(', ')})`,\n );\n }\n\n // Add utility options\n program.option('--list-versions', 'Display all supported version combinations and exit');\n\n // Add version info command\n program\n .command('version-info <tool>')\n .description('Display detailed version information for a specific tool')\n .action((toolName: string) => displayToolVersionInfo(context, toolName));\n\n for (const tool of tools) {\n // Don't add any options to the subcommand level.\n // All lz-tool options must be specified before the subcommand.\n program\n .command(tool.name, { isDefault: false })\n .description(`Run ${tool.name} with version checking`)\n .passThroughOptions(true) // Pass through all options after the subcommand\n .allowUnknownOption()\n .helpOption(false) // Disable automatic help option to pass --help to the tool\n .argument('[args...]', 'Arguments to pass to the tool')\n .action(async (args: string[]) => {\n await executeToolCommand(\n context,\n tool.name,\n args,\n await parseGlobalOptions(program),\n );\n });\n }\n\n // Allow external registration of extra commands\n registerExtraCommands?.(program, parseGlobalOptions);\n\n return program;\n};\n\nexport const runCli = async <TImageId extends string>(\n config: ChainContext<TImageId>,\n registerExtraCommands?: RegisterExtraCommands,\n): Promise<void> => {\n try {\n await createCli<TImageId>(config, registerExtraCommands).parseAsync();\n } catch (error) {\n console.error('❌ VM tool execution failed', error);\n process.exit(1);\n }\n};\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/cli.ts"],"names":["createCli","context","registerExtraCommands","tools","toolVersionOptions","Object","fromEntries","map","name","camelCase","parseGlobalOptions","command","cwd","volume","defaultVolumes","options","opts","resolvedCwd","process","cliVersions","entries","version","filter","tool","configVersions","getDefaultVersions","versions","volumes","defaultVolumesEnabled","program","Command","description","enablePositionalOptions","argv","includes","displayVersionCombinations","exit","option","input","Error","path","isAbsolute","fs","existsSync","statSync","isDirectory","variables","valueParts","split","length","value","join","type","hostPath","containerPath","volumeMappingSchema","parse","previous","defaultVersion","getToolDefaultVersion","supportedVersions","getToolSupportedVersions","action","toolName","displayToolVersionInfo","isDefault","passThroughOptions","allowUnknownOption","helpOption","argument","args","executeToolCommand","runCli","config","parseAsync","error","console"],"mappings":"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","file":"UQGPF6NC.js","sourcesContent":["import { Command } from 'commander';\nimport { camelCase } from 'es-toolkit';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport process from 'node:process';\n\nimport type { EnvironmentVariable, VolumeMapping } from './config';\nimport { volumeMappingSchema } from './config';\nimport type { ChainContext } from './context';\nimport type { ToolCommandExecutionOptions } from './core';\nimport { executeToolCommand } from './core';\nimport { displayToolVersionInfo, displayVersionCombinations } from './display';\nimport { getToolDefaultVersion, getToolSupportedVersions } from './utils/finder';\n\ninterface GlobalOptions {\n cwd?: string;\n volume: VolumeMapping[];\n env: EnvironmentVariable[];\n publish?: string[];\n script?: string;\n customEntrypoint?: string;\n defaultVolumes: boolean;\n}\n\ntype RegisterExtraCommands = (\n program: Command,\n parseGlobalOptions: (command: Command) => Promise<ToolCommandExecutionOptions>,\n) => void;\n\nconst createCli = <TImageId extends string>(\n context: ChainContext<TImageId>,\n registerExtraCommands?: RegisterExtraCommands,\n): Command => {\n const { tools } = context;\n const toolVersionOptions = Object.fromEntries(\n tools.map(({ name }) => [`${camelCase(name)}Version`, name]),\n );\n\n const parseGlobalOptions = async (command: Command): Promise<ToolCommandExecutionOptions> => {\n const { cwd, volume, defaultVolumes, ...options } = command.opts<GlobalOptions>();\n const resolvedCwd = cwd ?? process.cwd();\n\n // CLI flags take precedence over project config versions\n const cliVersions = Object.fromEntries(\n Object.entries(options)\n .map(([name, version]) => [toolVersionOptions[name], version])\n .filter(([tool]) => tool),\n );\n\n // Read defaults from project config (e.g., Anchor.toml) if the chain provides a hook\n const configVersions = (await context.getDefaultVersions?.(resolvedCwd)) ?? {};\n const versions = { ...configVersions, ...cliVersions };\n\n return {\n ...options,\n cwd: resolvedCwd,\n volumes: volume,\n versions,\n defaultVolumesEnabled: defaultVolumes,\n };\n };\n\n const program = new Command();\n\n program\n .name('lz-tool')\n .description(\n '🚀 LayerZero VM tooling with intelligent version management\\n' +\n '\\n' +\n 'Usage pattern:\\n' +\n ' lz-tool [global-options] <tool> [tool-args...]\\n' +\n '\\n' +\n 'Examples:\\n' +\n ' lz-tool -e bash sui --help\\n' +\n ' lz-tool --sui-version 1.38.0 sui client\\n' +\n '\\n' +\n 'Note: All lz-tool options must appear BEFORE the tool name.',\n )\n .version('1.0.0')\n .enablePositionalOptions(); // Required for passThroughOptions to work\n\n // Check for --list-versions before parsing to avoid help display\n if (process.argv.includes('--list-versions')) {\n displayVersionCombinations(context);\n process.exit(0);\n }\n\n // Add global options.\n program\n .option('-c, --cwd <path>', 'Current working directory', (input: string) => {\n if (typeof input !== 'string') {\n throw new Error('cwd flag must be a string');\n }\n\n if (!path.isAbsolute(input)) {\n throw new Error('cwd must be an absolute path if provided');\n }\n\n if (!fs.existsSync(input)) {\n throw new Error('cwd does not exist');\n }\n\n if (!fs.statSync(input).isDirectory()) {\n throw new Error('cwd must be a directory');\n }\n\n return input;\n })\n .option(\n '-e, --custom-entrypoint <entrypoint>',\n 'Override the default Docker entrypoint for the tool',\n )\n .option(\n '--script <script>',\n 'Execute a custom script using bash -c in the Docker container (e.g., --script \"npm install && npm test\")',\n )\n .option(\n '--env <name=value>',\n 'Set environment variables for Docker container (e.g., --env NODE_ENV=production)',\n (input: string, variables: EnvironmentVariable[]) => {\n const [name, ...valueParts] = input.split('=');\n\n if (!name || !valueParts.length) {\n throw new Error(\n `Invalid environment variable format: ${input}. Use --env NAME=VALUE`,\n );\n }\n\n return [...variables, { name, value: valueParts.join('=') }];\n },\n [],\n )\n .option(\n '-v, --volume <type:hostPath:containerPath[:name]>',\n 'Volume mappings in the format type:hostPath:containerPath[:name] (e.g., host:/host/path:/container/path or isolate::/container/path:volumeName)',\n (input: string, volumes: VolumeMapping[]) => {\n const [type, hostPath, containerPath, name] = input.split(':');\n\n switch (type) {\n case 'host':\n if (!hostPath) {\n throw new Error(`Host path is required for volume type 'host'`);\n }\n break;\n case 'isolate':\n if (!name) {\n throw new Error(`Name is required for volume type 'isolate'`);\n }\n break;\n default:\n throw new Error(`Invalid volume type: ${type}`);\n }\n\n if (!containerPath) {\n throw new Error(`Container path is required`);\n }\n\n return [\n ...volumes,\n volumeMappingSchema.parse({ type, hostPath, containerPath, name }),\n ];\n },\n [],\n )\n .option(\n '-p, --publish <host_port:container_port>',\n \"Publish a container's port(s) to the host (repeatable)\",\n (value: string, previous: string[]) => [...previous, value],\n [],\n )\n .option('--no-default-volumes', 'Disable default volumes for the tool');\n\n // Add version options for each tool dynamically\n for (const tool of tools) {\n const defaultVersion = getToolDefaultVersion(context, tool.name);\n const supportedVersions = getToolSupportedVersions(context, tool.name);\n\n program.option(\n `--${tool.name}-version <version>`,\n `Specify ${tool.name} version (default: ${defaultVersion}, supported: ${supportedVersions.join(', ')})`,\n );\n }\n\n // Add utility options\n program.option('--list-versions', 'Display all supported version combinations and exit');\n\n // Add version info command\n program\n .command('version-info <tool>')\n .description('Display detailed version information for a specific tool')\n .action((toolName: string) => displayToolVersionInfo(context, toolName));\n\n for (const tool of tools) {\n // Don't add any options to the subcommand level.\n // All lz-tool options must be specified before the subcommand.\n program\n .command(tool.name, { isDefault: false })\n .description(`Run ${tool.name} with version checking`)\n .passThroughOptions(true) // Pass through all options after the subcommand\n .allowUnknownOption()\n .helpOption(false) // Disable automatic help option to pass --help to the tool\n .argument('[args...]', 'Arguments to pass to the tool')\n .action(async (args: string[]) => {\n await executeToolCommand(\n context,\n tool.name,\n args,\n await parseGlobalOptions(program),\n );\n });\n }\n\n // Allow external registration of extra commands\n registerExtraCommands?.(program, parseGlobalOptions);\n\n return program;\n};\n\nexport const runCli = async <TImageId extends string>(\n config: ChainContext<TImageId>,\n registerExtraCommands?: RegisterExtraCommands,\n): Promise<void> => {\n try {\n await createCli<TImageId>(config, registerExtraCommands).parseAsync();\n } catch (error) {\n console.error('❌ VM tool execution failed', error);\n process.exit(1);\n }\n};\n"]}
|
package/dist/cli.cjs
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var MH3SPPX5_cjs = require('./MH3SPPX5.cjs');
|
|
4
4
|
require('./M6CETDAD.cjs');
|
|
5
5
|
require('./HOQEVWFL.cjs');
|
|
6
6
|
require('./UOFUYV3K.cjs');
|
|
7
7
|
require('./XSZ224E6.cjs');
|
|
8
|
-
require('./
|
|
8
|
+
require('./7E7TMR5F.cjs');
|
|
9
9
|
require('./X64VX57C.cjs');
|
|
10
10
|
require('./WFBRUQAF.cjs');
|
|
11
11
|
require('./S6PEV2YJ.cjs');
|
|
@@ -19,7 +19,7 @@ require('./KHVGLVR5.cjs');
|
|
|
19
19
|
|
|
20
20
|
Object.defineProperty(exports, "runCli", {
|
|
21
21
|
enumerable: true,
|
|
22
|
-
get: function () { return
|
|
22
|
+
get: function () { return MH3SPPX5_cjs.runCli; }
|
|
23
23
|
});
|
|
24
24
|
//# sourceMappingURL=cli.cjs.map
|
|
25
25
|
//# sourceMappingURL=cli.cjs.map
|
package/dist/cli.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
export { runCli } from './
|
|
1
|
+
export { runCli } from './UQGPF6NC.js';
|
|
2
2
|
import './CAPBDIIE.js';
|
|
3
3
|
import './QH3FM6DD.js';
|
|
4
4
|
import './S7YAUZ26.js';
|
|
5
5
|
import './P4BHRQMD.js';
|
|
6
|
-
import './
|
|
6
|
+
import './JYJBE36S.js';
|
|
7
7
|
import './2XGBQPKA.js';
|
|
8
8
|
import './6L6NUQMM.js';
|
|
9
9
|
import './AXL4SBDJ.js';
|
package/dist/core/index.cjs
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
require('../XSZ224E6.cjs');
|
|
4
|
-
var
|
|
4
|
+
var _7E7TMR5F_cjs = require('../7E7TMR5F.cjs');
|
|
5
5
|
require('../X64VX57C.cjs');
|
|
6
6
|
var WFBRUQAF_cjs = require('../WFBRUQAF.cjs');
|
|
7
7
|
require('../S6PEV2YJ.cjs');
|
|
@@ -15,7 +15,7 @@ require('../KHVGLVR5.cjs');
|
|
|
15
15
|
|
|
16
16
|
Object.defineProperty(exports, "executeToolCommand", {
|
|
17
17
|
enumerable: true,
|
|
18
|
-
get: function () { return
|
|
18
|
+
get: function () { return _7E7TMR5F_cjs.executeToolCommand; }
|
|
19
19
|
});
|
|
20
20
|
Object.defineProperty(exports, "resolveTypeVersions", {
|
|
21
21
|
enumerable: true,
|
package/dist/core/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var _7E7TMR5F_cjs = require('../7E7TMR5F.cjs');
|
|
4
4
|
require('../X64VX57C.cjs');
|
|
5
5
|
require('../WFBRUQAF.cjs');
|
|
6
6
|
require('../S6PEV2YJ.cjs');
|
|
@@ -14,7 +14,7 @@ require('../KHVGLVR5.cjs');
|
|
|
14
14
|
|
|
15
15
|
Object.defineProperty(exports, "executeToolCommand", {
|
|
16
16
|
enumerable: true,
|
|
17
|
-
get: function () { return
|
|
17
|
+
get: function () { return _7E7TMR5F_cjs.executeToolCommand; }
|
|
18
18
|
});
|
|
19
19
|
//# sourceMappingURL=tool-executor.cjs.map
|
|
20
20
|
//# sourceMappingURL=tool-executor.cjs.map
|
package/dist/index.cjs
CHANGED
|
@@ -2,13 +2,13 @@
|
|
|
2
2
|
|
|
3
3
|
var _25W5MXEX_cjs = require('./25W5MXEX.cjs');
|
|
4
4
|
require('./XKJWJQ2X.cjs');
|
|
5
|
-
var
|
|
5
|
+
var MH3SPPX5_cjs = require('./MH3SPPX5.cjs');
|
|
6
6
|
require('./M6CETDAD.cjs');
|
|
7
7
|
require('./HOQEVWFL.cjs');
|
|
8
8
|
require('./UOFUYV3K.cjs');
|
|
9
9
|
var QLR2UW44_cjs = require('./QLR2UW44.cjs');
|
|
10
10
|
require('./XSZ224E6.cjs');
|
|
11
|
-
var
|
|
11
|
+
var _7E7TMR5F_cjs = require('./7E7TMR5F.cjs');
|
|
12
12
|
require('./X64VX57C.cjs');
|
|
13
13
|
var WFBRUQAF_cjs = require('./WFBRUQAF.cjs');
|
|
14
14
|
require('./S6PEV2YJ.cjs');
|
|
@@ -27,7 +27,7 @@ Object.defineProperty(exports, "runGithubMatrixGenerator", {
|
|
|
27
27
|
});
|
|
28
28
|
Object.defineProperty(exports, "runCli", {
|
|
29
29
|
enumerable: true,
|
|
30
|
-
get: function () { return
|
|
30
|
+
get: function () { return MH3SPPX5_cjs.runCli; }
|
|
31
31
|
});
|
|
32
32
|
Object.defineProperty(exports, "testTools", {
|
|
33
33
|
enumerable: true,
|
|
@@ -35,7 +35,7 @@ Object.defineProperty(exports, "testTools", {
|
|
|
35
35
|
});
|
|
36
36
|
Object.defineProperty(exports, "executeToolCommand", {
|
|
37
37
|
enumerable: true,
|
|
38
|
-
get: function () { return
|
|
38
|
+
get: function () { return _7E7TMR5F_cjs.executeToolCommand; }
|
|
39
39
|
});
|
|
40
40
|
Object.defineProperty(exports, "resolveTypeVersions", {
|
|
41
41
|
enumerable: true,
|
package/dist/index.js
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
export { runGithubMatrixGenerator } from './6V27P6AU.js';
|
|
2
2
|
import './ZSOVVFOM.js';
|
|
3
|
-
export { runCli } from './
|
|
3
|
+
export { runCli } from './UQGPF6NC.js';
|
|
4
4
|
import './CAPBDIIE.js';
|
|
5
5
|
import './QH3FM6DD.js';
|
|
6
6
|
import './S7YAUZ26.js';
|
|
7
7
|
export { testTools } from './BTPRTHPR.js';
|
|
8
8
|
import './P4BHRQMD.js';
|
|
9
|
-
export { executeToolCommand } from './
|
|
9
|
+
export { executeToolCommand } from './JYJBE36S.js';
|
|
10
10
|
import './2XGBQPKA.js';
|
|
11
11
|
export { resolveTypeVersions } from './6L6NUQMM.js';
|
|
12
12
|
import './AXL4SBDJ.js';
|
package/package.json
CHANGED
|
@@ -22,7 +22,7 @@
|
|
|
22
22
|
"semver": "^7.5.4",
|
|
23
23
|
"zod": "4.3.5",
|
|
24
24
|
"zx": "^8.8.5",
|
|
25
|
-
"@layerzerolabs/common-node-utils": "0.2.
|
|
25
|
+
"@layerzerolabs/common-node-utils": "0.2.90"
|
|
26
26
|
},
|
|
27
27
|
"devDependencies": {
|
|
28
28
|
"@jest/globals": "^29.7.0",
|
|
@@ -34,8 +34,8 @@
|
|
|
34
34
|
"tsx": "^4.19.3",
|
|
35
35
|
"typescript": "^5.8.2",
|
|
36
36
|
"vitest": "^3.2.3",
|
|
37
|
-
"@layerzerolabs/
|
|
38
|
-
"@layerzerolabs/
|
|
37
|
+
"@layerzerolabs/typescript-configuration": "0.2.90",
|
|
38
|
+
"@layerzerolabs/tsup-configuration": "0.2.90"
|
|
39
39
|
},
|
|
40
40
|
"publishConfig": {
|
|
41
41
|
"access": "public",
|
|
@@ -49,7 +49,7 @@
|
|
|
49
49
|
"layerzero-ver"
|
|
50
50
|
]
|
|
51
51
|
},
|
|
52
|
-
"version": "0.2.
|
|
52
|
+
"version": "0.2.90",
|
|
53
53
|
"scripts": {
|
|
54
54
|
"build": "tsup",
|
|
55
55
|
"lint": "eslint . --max-warnings 0 || (eslint . --fix --max-warnings 0 && false)",
|