@layerzerolabs/vm-tooling 0.0.42 → 0.0.44

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.
Files changed (62) hide show
  1. package/dist/{YTUEW27V.js → 5KA4B3WL.js} +10 -3
  2. package/dist/5KA4B3WL.js.map +1 -0
  3. package/dist/{7ILXMMXL.cjs → 67EGQ6NV.cjs} +14 -14
  4. package/dist/{7ILXMMXL.cjs.map → 67EGQ6NV.cjs.map} +1 -1
  5. package/dist/{QSKQ7BQT.cjs → 7S3N6ZPY.cjs} +10 -3
  6. package/dist/7S3N6ZPY.cjs.map +1 -0
  7. package/dist/{LWFEVAEC.js → BQE33FG7.js} +7 -4
  8. package/dist/BQE33FG7.js.map +1 -0
  9. package/dist/{AQLGVUST.js → CFMPNPDE.js} +4 -4
  10. package/dist/{AQLGVUST.js.map → CFMPNPDE.js.map} +1 -1
  11. package/dist/{SW6HQVVH.js → CRLXMIJF.js} +13 -16
  12. package/dist/CRLXMIJF.js.map +1 -0
  13. package/dist/{MLFIQN3U.cjs → FTNN2BYM.cjs} +13 -13
  14. package/dist/{MLFIQN3U.cjs.map → FTNN2BYM.cjs.map} +1 -1
  15. package/dist/{XKCPVHEI.cjs → JSQ7H2ZH.cjs} +15 -12
  16. package/dist/JSQ7H2ZH.cjs.map +1 -0
  17. package/dist/{LUOR2YGF.js → N7J75JOO.js} +4 -4
  18. package/dist/{LUOR2YGF.js.map → N7J75JOO.js.map} +1 -1
  19. package/dist/{NVWCOJWR.cjs → RYB7HXPO.cjs} +14 -17
  20. package/dist/RYB7HXPO.cjs.map +1 -0
  21. package/dist/config/index.cjs +6 -6
  22. package/dist/config/index.js +2 -2
  23. package/dist/config/tools.cjs +3 -3
  24. package/dist/config/tools.d.ts.map +1 -1
  25. package/dist/config/tools.js +2 -2
  26. package/dist/config/version-matrices.cjs +2 -2
  27. package/dist/config/version-matrices.d.ts.map +1 -1
  28. package/dist/config/version-matrices.js +1 -1
  29. package/dist/core/index.cjs +9 -9
  30. package/dist/core/index.js +5 -5
  31. package/dist/core/tool-executor.cjs +6 -6
  32. package/dist/core/tool-executor.js +5 -5
  33. package/dist/core/version-resolver.cjs +7 -7
  34. package/dist/core/version-resolver.d.ts +1 -1
  35. package/dist/core/version-resolver.d.ts.map +1 -1
  36. package/dist/core/version-resolver.js +4 -4
  37. package/dist/display/index.cjs +6 -6
  38. package/dist/display/index.js +4 -4
  39. package/dist/display/version-display.cjs +6 -6
  40. package/dist/display/version-display.js +4 -4
  41. package/dist/index.cjs +16 -16
  42. package/dist/index.js +8 -8
  43. package/dist/scripts/generate-github-matrix.cjs +3 -2
  44. package/dist/scripts/generate-github-matrix.cjs.map +1 -1
  45. package/dist/scripts/generate-github-matrix.js +2 -1
  46. package/dist/scripts/generate-github-matrix.js.map +1 -1
  47. package/dist/types/tool.d.ts.map +1 -1
  48. package/dist/utils/finder-utils.cjs +9 -9
  49. package/dist/utils/finder-utils.d.ts +1 -1
  50. package/dist/utils/finder-utils.d.ts.map +1 -1
  51. package/dist/utils/finder-utils.js +2 -2
  52. package/dist/utils/index.cjs +13 -13
  53. package/dist/utils/index.js +2 -2
  54. package/dist/utils/version-utils.cjs +6 -6
  55. package/dist/utils/version-utils.js +2 -2
  56. package/package.json +5 -5
  57. package/dist/LWFEVAEC.js.map +0 -1
  58. package/dist/NVWCOJWR.cjs.map +0 -1
  59. package/dist/QSKQ7BQT.cjs.map +0 -1
  60. package/dist/SW6HQVVH.js.map +0 -1
  61. package/dist/XKCPVHEI.cjs.map +0 -1
  62. package/dist/YTUEW27V.js.map +0 -1
@@ -4,9 +4,16 @@ var versionMatrices = [
4
4
  toolType: "evm",
5
5
  combinations: [
6
6
  {
7
- id: "evm_hardhat_2.19.3",
7
+ id: "hardhat_2.19.3",
8
8
  versions: {
9
9
  hardhat: "2.19.3"
10
+ }
11
+ },
12
+ {
13
+ id: "forge_1.3.6_hardhat_2.26.3",
14
+ versions: {
15
+ forge: "1.3.6",
16
+ hardhat: "2.26.3"
10
17
  },
11
18
  isRecommended: true
12
19
  }
@@ -105,5 +112,5 @@ var versionMatrices = [
105
112
  ];
106
113
 
107
114
  export { versionMatrices };
108
- //# sourceMappingURL=YTUEW27V.js.map
109
- //# sourceMappingURL=YTUEW27V.js.map
115
+ //# sourceMappingURL=5KA4B3WL.js.map
116
+ //# sourceMappingURL=5KA4B3WL.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/config/version-matrices.ts"],"names":["versionMatrices","toolType","combinations","id","versions","hardhat","forge","isRecommended","solana","anchor","description","aptos","initiad","blueprint","scarb","patch","sui"],"mappings":";AAMO,IAAMA,eAAAA,GAAuC;AAChD,EAAA;IACIC,QAAAA,EAAU,KAAA;IACVC,YAAAA,EAAc;AACV,MAAA;QACIC,EAAAA,EAAI,gBAAA;QACJC,QAAAA,EAAU;UAAEC,OAAAA,EAAS;AAAS;AAClC,OAAA;AACA,MAAA;QACIF,EAAAA,EAAI,4BAAA;QACJC,QAAAA,EAAU;UAAEE,KAAAA,EAAO,OAAA;UAASD,OAAAA,EAAS;AAAS,SAAA;QAC9CE,aAAAA,EAAe;AACnB;;AAER,GAAA;AACA,EAAA;IACIN,QAAAA,EAAU,QAAA;IACVC,YAAAA,EAAc;AACV,MAAA;QACIC,EAAAA,EAAI,8BAAA;QACJC,QAAAA,EAAU;UAAEI,MAAAA,EAAQ,SAAA;UAAWC,MAAAA,EAAQ;AAAS,SAAA;QAChDF,aAAAA,EAAe,IAAA;QACfG,WAAAA,EAAa;AACjB,OAAA;AACA,MAAA;QACIP,EAAAA,EAAI,8BAAA;QACJC,QAAAA,EAAU;UAAEI,MAAAA,EAAQ,SAAA;UAAWC,MAAAA,EAAQ;AAAS;AACpD,OAAA;AACA,MAAA;QACIN,EAAAA,EAAI,8BAAA;QACJC,QAAAA,EAAU;UAAEI,MAAAA,EAAQ,SAAA;UAAWC,MAAAA,EAAQ;AAAS,SAAA;QAChDC,WAAAA,EAAa;AACjB;;AAER,GAAA;AACA,EAAA;IACIT,QAAAA,EAAU,OAAA;IACVC,YAAAA,EAAc;AACV,MAAA;QACIC,EAAAA,EAAI,aAAA;QACJC,QAAAA,EAAU;UAAEO,KAAAA,EAAO;AAAQ,SAAA;QAC3BJ,aAAAA,EAAe;AACnB;;AAOR,GAAA;AACA,EAAA;IACIN,QAAAA,EAAU,QAAA;IACVC,YAAAA,EAAc;AACV,MAAA;QACIC,EAAAA,EAAI,cAAA;QACJC,QAAAA,EAAU;UAAEQ,OAAAA,EAAS;AAAQ,SAAA;QAC7BL,aAAAA,EAAe;AACnB;;AAER,GAAA;AACA,EAAA;IACIN,QAAAA,EAAU,KAAA;IACVC,YAAAA,EAAc;AACV,MAAA;QACIC,EAAAA,EAAI,mBAAA;QACJC,QAAAA,EAAU;UAAES,SAAAA,EAAW;AAAgB,SAAA;QACvCN,aAAAA,EAAe;AACnB;;AAER,GAAA;AACA,EAAA;IACIN,QAAAA,EAAU,UAAA;IACVC,YAAAA,EAAc;AACV,MAAA;QACIC,EAAAA,EAAI,cAAA;QACJC,QAAAA,EAAU;UAAEU,KAAAA,EAAO,QAAA;UAAUC,KAAAA,EAAO;AAAI,SAAA;QACxCR,aAAAA,EAAe;AACnB;;AAER,GAAA;AACA,EAAA;IACIN,QAAAA,EAAU,KAAA;IACVC,YAAAA,EAAc;AACV,MAAA;QACIC,EAAAA,EAAI,YAAA;QACJC,QAAAA,EAAU;UAAEY,GAAAA,EAAK;AAAgB,SAAA;QACjCT,aAAAA,EAAe;AACnB;;AAER","file":"5KA4B3WL.js","sourcesContent":["import type { ToolVersionMatrix } from '../types';\n\n/**\n * Version compatibility matrices for each tool type\n * Default combination is the first one marked as isRecommended=true\n */\nexport const versionMatrices: ToolVersionMatrix[] = [\n {\n toolType: 'evm',\n combinations: [\n {\n id: 'hardhat_2.19.3',\n versions: { hardhat: '2.19.3' },\n },\n {\n id: 'forge_1.3.6_hardhat_2.26.3',\n versions: { forge: '1.3.6', hardhat: '2.26.3' },\n isRecommended: true,\n },\n ],\n },\n {\n toolType: 'solana',\n combinations: [\n {\n id: 'solana_1.17.31_anchor_0.29.0',\n versions: { solana: '1.17.31', anchor: '0.29.0' },\n isRecommended: true,\n description: 'Stable and well-tested',\n },\n {\n id: 'solana_1.18.16_anchor_0.30.0',\n versions: { solana: '1.18.16', anchor: '0.30.0' },\n },\n {\n id: 'solana_1.18.16_anchor_0.31.0',\n versions: { solana: '1.18.16', anchor: '0.31.0' },\n description: 'Latest stable release',\n },\n ],\n },\n {\n toolType: 'aptos',\n combinations: [\n {\n id: 'aptos_4.6.0',\n versions: { aptos: '4.6.0' },\n isRecommended: true,\n },\n // TODO Enable Aptos v6.\n // {\n // id: 'aptos_6.0.1',\n // versions: { aptos: '6.0.1' },\n // },\n ],\n },\n {\n toolType: 'initia',\n combinations: [\n {\n id: 'initia_0.6.3',\n versions: { initiad: '0.6.3' },\n isRecommended: true,\n },\n ],\n },\n {\n toolType: 'ton',\n combinations: [\n {\n id: 'ton_0.25.0-beta.1',\n versions: { blueprint: '0.25.0-beta.1' },\n isRecommended: true,\n },\n ],\n },\n {\n toolType: 'starknet',\n combinations: [\n {\n id: 'scarb_2.12.0',\n versions: { scarb: '2.12.0', patch: '1' },\n isRecommended: true,\n },\n ],\n },\n {\n toolType: 'sui',\n combinations: [\n {\n id: 'sui_1.54.1',\n versions: { sui: '1.54.1-beta.0' },\n isRecommended: true,\n },\n ],\n },\n];\n"]}
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
- var XKCPVHEI_cjs = require('./XKCPVHEI.cjs');
4
- var NVWCOJWR_cjs = require('./NVWCOJWR.cjs');
3
+ var JSQ7H2ZH_cjs = require('./JSQ7H2ZH.cjs');
4
+ var RYB7HXPO_cjs = require('./RYB7HXPO.cjs');
5
5
  var NX4KBEWA_cjs = require('./NX4KBEWA.cjs');
6
6
  var fs = require('fs');
7
7
  var path = require('path');
@@ -34,13 +34,13 @@ function mergeVolumes(defaultVolumes, userVolumes) {
34
34
  }
35
35
  NX4KBEWA_cjs.__name(mergeVolumes, "mergeVolumes");
36
36
  function getImageName(target, vmToolingName, version) {
37
- const repository = `${NVWCOJWR_cjs.AWS_ACCOUNT_ID}.dkr.ecr.${NVWCOJWR_cjs.AWS_REGION}.amazonaws.com/layerzerolabs`;
37
+ const repository = `${RYB7HXPO_cjs.AWS_ACCOUNT_ID}.dkr.ecr.${RYB7HXPO_cjs.AWS_REGION}.amazonaws.com/layerzerolabs`;
38
38
  const imageName = `${target}-tooling`;
39
- const tool = NVWCOJWR_cjs.findToolByName(vmToolingName);
39
+ const tool = RYB7HXPO_cjs.findToolByName(vmToolingName);
40
40
  if (!tool) {
41
41
  throw new Error(`Tool '${vmToolingName}' not found`);
42
42
  }
43
- const matrix = NVWCOJWR_cjs.findMatrixByType(tool.toolType);
43
+ const matrix = RYB7HXPO_cjs.findMatrixByType(tool.toolType);
44
44
  if (!matrix) {
45
45
  throw new Error(`No version matrix found for tool type ${tool.toolType}`);
46
46
  }
@@ -101,7 +101,7 @@ async function ensureDockerImage(imageURI, imageTag) {
101
101
  - Local fallback: ${localFallbackURI} (not found)
102
102
 
103
103
  \u{1F4A1} Solutions:
104
- 1. Authenticate with ECR: aws ecr get-login-password --region ${NVWCOJWR_cjs.AWS_REGION} | docker login --username AWS --password-stdin ${NVWCOJWR_cjs.AWS_ACCOUNT_ID}.dkr.ecr.${NVWCOJWR_cjs.AWS_REGION}.amazonaws.com
104
+ 1. Authenticate with ECR: aws ecr get-login-password --region ${RYB7HXPO_cjs.AWS_REGION} | docker login --username AWS --password-stdin ${RYB7HXPO_cjs.AWS_ACCOUNT_ID}.dkr.ecr.${RYB7HXPO_cjs.AWS_REGION}.amazonaws.com
105
105
  2. Build local image: docker build -t ${localFallbackURI} <dockerfile-path>
106
106
  3. Check if the image tag exists in ECR`);
107
107
  } catch (error) {
@@ -114,8 +114,8 @@ async function ensureDockerImage(imageURI, imageTag) {
114
114
  NX4KBEWA_cjs.__name(ensureDockerImage, "ensureDockerImage");
115
115
  async function executeToolCommand(command, args, options) {
116
116
  const { cwd, forceDocker, volumes: userVolumes, customEntrypoint, env: customEnvVars, script } = options;
117
- const tool = NVWCOJWR_cjs.findToolByName(command);
118
- const type = NVWCOJWR_cjs.getToolType(command);
117
+ const tool = RYB7HXPO_cjs.findToolByName(command);
118
+ const type = RYB7HXPO_cjs.getToolType(command);
119
119
  if (!tool || type === void 0) {
120
120
  const { tools } = await import('./config/index.cjs');
121
121
  const availableTools = tools.map((t) => t.name).join(", ");
@@ -134,8 +134,8 @@ Try: lz-tool --list-versions to see all available tools`);
134
134
  }
135
135
  }
136
136
  }
137
- const userSpecifiedVersions = XKCPVHEI_cjs.extractUserVersions(options);
138
- const versionResult = XKCPVHEI_cjs.resolveTypeVersions(type, userSpecifiedVersions, options, cwd);
137
+ const userSpecifiedVersions = JSQ7H2ZH_cjs.extractUserVersions(options);
138
+ const versionResult = JSQ7H2ZH_cjs.resolveTypeVersions(type, userSpecifiedVersions, options, cwd);
139
139
  versionResult.warnings.forEach((warning) => {
140
140
  console.warn(warning);
141
141
  });
@@ -152,7 +152,7 @@ Try: lz-tool --list-versions to see all available tools`);
152
152
  const resolvedVersionObj = {
153
153
  version: resolvedVersion
154
154
  };
155
- if (!NVWCOJWR_cjs.versionsSatisfied(secondaryVersion, resolvedVersionObj)) {
155
+ if (!RYB7HXPO_cjs.versionsSatisfied(secondaryVersion, resolvedVersionObj)) {
156
156
  console.warn(`Warning: Local configuration version (${secondaryVersion.version}) differs from resolved version (${resolvedVersion})`);
157
157
  }
158
158
  } catch (error) {
@@ -171,7 +171,7 @@ Try: lz-tool --list-versions to see all available tools`);
171
171
  const resolvedVersionObj = {
172
172
  version: resolvedVersion
173
173
  };
174
- if (NVWCOJWR_cjs.versionsSatisfied(installedVersion, resolvedVersionObj)) {
174
+ if (RYB7HXPO_cjs.versionsSatisfied(installedVersion, resolvedVersionObj)) {
175
175
  hasLocalExecutable = true;
176
176
  console.info(`\u2705 Using local ${command} v${installedVersion.version}`);
177
177
  } else {
@@ -276,5 +276,5 @@ function saveAptosModulesOrder(command, processOutput, workspaceRoot, relPath) {
276
276
  NX4KBEWA_cjs.__name(saveAptosModulesOrder, "saveAptosModulesOrder");
277
277
 
278
278
  exports.executeToolCommand = executeToolCommand;
279
- //# sourceMappingURL=7ILXMMXL.cjs.map
280
- //# sourceMappingURL=7ILXMMXL.cjs.map
279
+ //# sourceMappingURL=67EGQ6NV.cjs.map
280
+ //# sourceMappingURL=67EGQ6NV.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/core/tool-executor.ts"],"names":["$","verbose","stdio","process","stderr","mergeVolumes","defaultVolumes","userVolumes","merged","userPaths","Set","map","v","containerPath","push","defaultVolume","has","getImageName","target","vmToolingName","version","repository","AWS_ACCOUNT_ID","AWS_REGION","imageName","tool","findToolByName","Error","matrix","findMatrixByType","toolType","foundCombination","combination","combinations","toolVersion","versions","validVersions","toolName","Object","entries","length","imageTag","getCombinationTag","imageURI","input","tags","key","value","sort","a","b","localeCompare","join","ensureDockerImage","checkResult","nothrow","stdout","includes","console","info","pullResult","exitCode","localImageName","split","pop","replace","localFallbackURI","localCheckResult","error","message","String","executeToolCommand","command","args","options","cwd","forceDocker","volumes","customEntrypoint","env","customEnvVars","script","type","getToolType","undefined","tools","availableTools","t","name","overrides","filter","uv","some","dv","userSpecifiedVersions","extractUserVersions","versionResult","resolveTypeVersions","warnings","forEach","warning","warn","resolvedVersion","resolvedVersions","getSecondaryVersionCheckValue","secondaryVersion","resolvedVersionObj","versionsSatisfied","hasLocalExecutable","versionFlags","versionCliArguments","result","parseVersionCliVersionOutput","installedVersion","processOutput","fromImage","workspaceRoot","getFullyQualifiedRepoRootPath","relPath","path","relative","privileged","volumeArgs","volume","hostPath","flat","entryPoint","trim","envArgs","envVar","finalArgs","dockerArgs","saveAptosModulesOrder","exit","outputJson","json","modules","Result","item","fs","writeFileSync","JSON","stringify"],"mappings":"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","file":"7ILXMMXL.cjs","sourcesContent":["import fs from 'fs';\nimport path from 'path';\nimport process from 'process';\nimport type { ProcessOutput } from 'zx';\nimport { $ } from 'zx';\n\nimport { getFullyQualifiedRepoRootPath } from '@layerzerolabs/common-node-utils';\n\nimport { AWS_ACCOUNT_ID, AWS_REGION } from '../config';\nimport type { EnvironmentVariable, ToolingImageTargetName, Version, VolumeMapping } from '../types';\nimport { findMatrixByType, findToolByName, getToolType } from '../utils/finder-utils';\nimport { versionsSatisfied } from '../utils/version-utils';\nimport { extractUserVersions, resolveTypeVersions } from './version-resolver';\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 */\nfunction mergeVolumes(\n defaultVolumes: VolumeMapping[],\n userVolumes: VolumeMapping[],\n): VolumeMapping[] {\n const merged: VolumeMapping[] = [];\n const userPaths = new Set(userVolumes.map((v) => v.containerPath));\n\n // Add user volumes first (highest priority)\n merged.push(...userVolumes);\n\n // Add default volumes that don't conflict with user volumes\n for (const defaultVolume of defaultVolumes) {\n if (!userPaths.has(defaultVolume.containerPath)) {\n merged.push(defaultVolume);\n }\n }\n\n return merged;\n}\n\n/**\n * Get Docker image name and tag for a specific tool and version\n */\nfunction getImageName(\n target: ToolingImageTargetName,\n vmToolingName: string,\n version: string,\n): { imageURI: string; imageTag: string } {\n // const repository = 'ghcr.io/layerzero-labs';\n const repository = `${AWS_ACCOUNT_ID}.dkr.ecr.${AWS_REGION}.amazonaws.com/layerzerolabs`;\n const imageName = `${target}-tooling`;\n\n // Find the tool and its type\n const tool = findToolByName(vmToolingName);\n if (!tool) {\n throw new Error(`Tool '${vmToolingName}' not found`);\n }\n\n // Find the version matrix for this tool type\n const matrix = findMatrixByType(tool.toolType);\n if (!matrix) {\n throw new Error(`No version matrix found for tool type ${tool.toolType}`);\n }\n\n // Find a combination that includes this tool with the specified version\n let foundCombination = null;\n for (const combination of matrix.combinations) {\n const toolVersion = combination.versions[vmToolingName];\n if (toolVersion === version) {\n foundCombination = combination.versions;\n break;\n }\n }\n\n if (!foundCombination) {\n throw new Error(\n `No version combination found for tool ${vmToolingName} with version ${version}`,\n );\n }\n\n // Filter out undefined/empty values for tag generation\n const validVersions: { [key: string]: string } = {};\n for (const [toolName, toolVersion] of Object.entries(foundCombination)) {\n if (typeof toolVersion === 'string' && toolVersion.length > 0) {\n validVersions[toolName] = toolVersion;\n }\n }\n\n const imageTag = getCombinationTag(validVersions);\n const imageURI = `${repository}/${imageName}:${imageTag}`;\n\n return { imageURI, imageTag };\n}\n\n/**\n * Generate Docker image tag from version combination\n */\nfunction getCombinationTag(input: { [key: string]: string }): string {\n const tags = Object.entries(input)\n .map(([key, value]) => `${key}_${value}`)\n .sort((a, b) => a.localeCompare(b));\n\n return tags.join('_');\n}\n\n/**\n * Enhanced Docker image management with intelligent caching\n * Tries ECR first, falls back to local build if available, and caches locally\n */\nasync function ensureDockerImage(imageURI: string, imageTag: string): Promise<void> {\n try {\n // Check if image exists locally first\n const checkResult = await $`docker image ls ${imageURI}`.nothrow();\n\n if (checkResult.stdout.includes(imageTag)) {\n console.info(`✅ Using cached Docker image: ${imageURI}`);\n return;\n }\n\n // Try to pull from ECR\n console.info(`📥 Pulling Docker image from ECR: ${imageURI}`);\n const pullResult = await $`docker pull ${imageURI}`.nothrow();\n\n if (pullResult.exitCode === 0) {\n console.info(`✅ Successfully pulled: ${imageURI}`);\n return;\n }\n\n // If ECR pull fails, check for local fallback image\n const localImageName = imageURI.split('/').pop()?.replace(/:.*$/, '') || '';\n const localFallbackURI = `local-${localImageName}:latest`;\n\n const localCheckResult = await $`docker image ls ${localFallbackURI}`.nothrow();\n\n if (localCheckResult.stdout.includes('local-')) {\n console.info(`🏠 ECR image not available, using local fallback: ${localFallbackURI}`);\n\n // Tag the local image with the ECR URI for consistency\n await $`docker tag ${localFallbackURI} ${imageURI}`;\n console.info(`🏷️ Tagged local image as: ${imageURI}`);\n return;\n }\n\n // If all else fails, provide helpful error message\n throw new Error(\n `❌ Docker image not available:\\n` +\n ` - ECR image: ${imageURI} (pull failed)\\n` +\n ` - Local fallback: ${localFallbackURI} (not found)\\n` +\n `\\n💡 Solutions:\\n` +\n ` 1. Authenticate with ECR: aws ecr get-login-password --region ${AWS_REGION} | docker login --username AWS --password-stdin ${AWS_ACCOUNT_ID}.dkr.ecr.${AWS_REGION}.amazonaws.com\\n` +\n ` 2. Build local image: docker build -t ${localFallbackURI} <dockerfile-path>\\n` +\n ` 3. Check if the image tag exists in ECR`,\n );\n } catch (error) {\n if (error instanceof Error && error.message.includes('❌ Docker image not available')) {\n throw error;\n }\n throw new Error(\n `Failed to ensure Docker image ${imageURI}: ${error instanceof Error ? error.message : String(error)}`,\n );\n }\n}\n\n/**\n * Enhanced tool command execution using the new version compatibility matrix system\n */\nexport async function executeToolCommand(\n command: string,\n args: string[],\n options: {\n cwd: string;\n forceDocker: boolean;\n volumes: VolumeMapping[];\n customEntrypoint?: string;\n env: EnvironmentVariable[];\n script?: string;\n [key: string]: any;\n },\n): Promise<void> {\n const {\n cwd,\n forceDocker,\n volumes: userVolumes,\n customEntrypoint,\n env: customEnvVars,\n script,\n } = options;\n\n const tool = findToolByName(command);\n const type = getToolType(command);\n\n if (!tool || type === undefined) {\n const { tools } = await import('../config');\n const availableTools = tools.map((t) => t.name).join(', ');\n throw new Error(\n `❌ Tool '${command}' not found or no type configuration available.\\n` +\n `Available tools: ${availableTools}\\n` +\n `Try: lz-tool --list-versions to see all available tools`,\n );\n }\n\n // Merge default volumes with user-specified volumes\n const defaultVolumes = tool.defaultVolumes ?? [];\n const volumes = mergeVolumes(defaultVolumes, userVolumes);\n\n if (defaultVolumes.length > 0) {\n console.info(`📦 Using ${defaultVolumes.length} default cache volume(s) for ${command}`);\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 // Extract user-specified versions from command line options\n const userSpecifiedVersions = extractUserVersions(options);\n\n // Resolve versions for all tools in the type using compatibility matrix\n const versionResult = resolveTypeVersions(type, userSpecifiedVersions, options, cwd);\n\n // Display any warnings\n versionResult.warnings.forEach((warning) => {\n console.warn(warning);\n });\n\n // Get the resolved version for the current tool\n const resolvedVersion = versionResult.resolvedVersions[command];\n if (typeof resolvedVersion !== 'string' || resolvedVersion === '') {\n throw new Error(`No version resolved for tool ${command}`);\n }\n\n console.info(`🔧 ${command} version: ${resolvedVersion}`);\n\n // Check secondary version validation if available\n if (tool.getSecondaryVersionCheckValue) {\n try {\n const secondaryVersion = tool.getSecondaryVersionCheckValue({ cwd });\n const resolvedVersionObj: Version = { version: resolvedVersion };\n\n if (!versionsSatisfied(secondaryVersion, resolvedVersionObj)) {\n console.warn(\n `Warning: Local configuration version (${secondaryVersion.version}) differs from resolved version (${resolvedVersion})`,\n );\n }\n } catch (error) {\n // Secondary version check failed, but continue with resolved version\n console.warn(\n `Could not validate secondary version: ${error instanceof Error ? error.message : String(error)}`,\n );\n }\n }\n\n // Check if we should try to use local executable first\n let hasLocalExecutable = false;\n\n if (!forceDocker) {\n const versionFlags = tool.versionCliArguments ?? ['--version'];\n\n try {\n const result = await $`${command} ${versionFlags}`;\n\n // Use tool for parsing output\n if (tool.parseVersionCliVersionOutput) {\n const installedVersion = tool.parseVersionCliVersionOutput(result.stdout);\n const resolvedVersionObj: Version = { version: resolvedVersion };\n\n if (versionsSatisfied(installedVersion, resolvedVersionObj)) {\n hasLocalExecutable = true;\n console.info(`✅ Using local ${command} v${installedVersion.version}`);\n } else {\n console.info(\n `🐳 Local ${command} v${installedVersion.version} ≠ required v${resolvedVersion}, using Docker`,\n );\n }\n }\n } catch (error) {\n // Check if the command is not found (127 exit code)\n if (!(error instanceof Error) || !('exitCode' in error) || error.exitCode !== 127) {\n throw error;\n }\n console.info(`🐳 ${command} not found locally, using Docker`);\n }\n }\n\n let processOutput: ProcessOutput;\n\n if (hasLocalExecutable) {\n // Execute command directly\n processOutput = await $`${command} ${args}`.nothrow();\n } else {\n // Use Docker image with merged volumes\n const { imageTag, imageURI } = getImageName(tool.fromImage, tool.name, resolvedVersion);\n const workspaceRoot = await getFullyQualifiedRepoRootPath();\n const relPath = path.relative(workspaceRoot, cwd);\n const privileged = tool.privileged ?? false;\n\n // Enhanced Docker image caching logic\n await ensureDockerImage(imageURI, imageTag);\n\n const volumeArgs = volumes\n .map((volume) => {\n if (volume.type === 'host') {\n if (volume.hostPath === undefined) {\n throw new Error(`Host path is required for volume mapping of type 'host'`);\n }\n return ['-v', `${volume.hostPath}:${volume.containerPath}`];\n } else {\n if (volume.name === undefined) {\n throw new Error(`Name is required for volume mapping of type 'isolate'`);\n }\n return ['-v', `${volume.name}:${volume.containerPath}`];\n }\n })\n .flat(); // Flatten the array to get ['-v', 'vol1', '-v', 'vol2', ...]\n\n // Use custom entrypoint if provided, otherwise fall back to tool config or tool name\n const entryPoint = customEntrypoint ?? tool.entryPoint;\n\n if (customEntrypoint !== undefined && customEntrypoint.trim() !== '') {\n console.info(`🔧 Using custom entrypoint: ${customEntrypoint}`);\n }\n\n // Build the Docker command with proper argument separation\n const envArgs = customEnvVars\n .map((envVar) => ['-e', `${envVar.name}=${envVar.value}`])\n .flat();\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 !== undefined && 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 ...(privileged ? ['--privileged'] : []),\n '--rm',\n ...envArgs,\n '-v',\n `${workspaceRoot}:/workspace`,\n '-w',\n `/workspace/${relPath}`,\n ...volumeArgs,\n ...(entryPoint === undefined ? [] : ['--entrypoint', entryPoint]),\n imageURI,\n ...finalArgs,\n ];\n\n processOutput = await $`docker ${dockerArgs}`.nothrow();\n saveAptosModulesOrder(command, processOutput, workspaceRoot, relPath);\n }\n\n // Handle the process completion\n const { exitCode } = processOutput;\n if (exitCode !== 0) {\n process.exit(exitCode ?? 1);\n }\n}\n\nfunction saveAptosModulesOrder(\n command: string,\n processOutput: ProcessOutput,\n workspaceRoot: string,\n relPath: string,\n): void {\n if ('aptos' === command) {\n const outputJson: { Result: string[] } = processOutput.json();\n const modules = outputJson.Result.map((item: string) => `${item.split('::')[1]}.mv`);\n fs.writeFileSync(\n path.join(workspaceRoot, relPath, 'modules.json'),\n JSON.stringify(modules, null, 2),\n );\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/core/tool-executor.ts"],"names":["$","verbose","stdio","process","stderr","mergeVolumes","defaultVolumes","userVolumes","merged","userPaths","Set","map","v","containerPath","push","defaultVolume","has","getImageName","target","vmToolingName","version","repository","AWS_ACCOUNT_ID","AWS_REGION","imageName","tool","findToolByName","Error","matrix","findMatrixByType","toolType","foundCombination","combination","combinations","toolVersion","versions","validVersions","toolName","Object","entries","length","imageTag","getCombinationTag","imageURI","input","tags","key","value","sort","a","b","localeCompare","join","ensureDockerImage","checkResult","nothrow","stdout","includes","console","info","pullResult","exitCode","localImageName","split","pop","replace","localFallbackURI","localCheckResult","error","message","String","executeToolCommand","command","args","options","cwd","forceDocker","volumes","customEntrypoint","env","customEnvVars","script","type","getToolType","undefined","tools","availableTools","t","name","overrides","filter","uv","some","dv","userSpecifiedVersions","extractUserVersions","versionResult","resolveTypeVersions","warnings","forEach","warning","warn","resolvedVersion","resolvedVersions","getSecondaryVersionCheckValue","secondaryVersion","resolvedVersionObj","versionsSatisfied","hasLocalExecutable","versionFlags","versionCliArguments","result","parseVersionCliVersionOutput","installedVersion","processOutput","fromImage","workspaceRoot","getFullyQualifiedRepoRootPath","relPath","path","relative","privileged","volumeArgs","volume","hostPath","flat","entryPoint","trim","envArgs","envVar","finalArgs","dockerArgs","saveAptosModulesOrder","exit","outputJson","json","modules","Result","item","fs","writeFileSync","JSON","stringify"],"mappings":"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","file":"67EGQ6NV.cjs","sourcesContent":["import fs from 'fs';\nimport path from 'path';\nimport process from 'process';\nimport type { ProcessOutput } from 'zx';\nimport { $ } from 'zx';\n\nimport { getFullyQualifiedRepoRootPath } from '@layerzerolabs/common-node-utils';\n\nimport { AWS_ACCOUNT_ID, AWS_REGION } from '../config';\nimport type { EnvironmentVariable, ToolingImageTargetName, Version, VolumeMapping } from '../types';\nimport { findMatrixByType, findToolByName, getToolType } from '../utils/finder-utils';\nimport { versionsSatisfied } from '../utils/version-utils';\nimport { extractUserVersions, resolveTypeVersions } from './version-resolver';\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 */\nfunction mergeVolumes(\n defaultVolumes: VolumeMapping[],\n userVolumes: VolumeMapping[],\n): VolumeMapping[] {\n const merged: VolumeMapping[] = [];\n const userPaths = new Set(userVolumes.map((v) => v.containerPath));\n\n // Add user volumes first (highest priority)\n merged.push(...userVolumes);\n\n // Add default volumes that don't conflict with user volumes\n for (const defaultVolume of defaultVolumes) {\n if (!userPaths.has(defaultVolume.containerPath)) {\n merged.push(defaultVolume);\n }\n }\n\n return merged;\n}\n\n/**\n * Get Docker image name and tag for a specific tool and version\n */\nfunction getImageName(\n target: ToolingImageTargetName,\n vmToolingName: string,\n version: string,\n): { imageURI: string; imageTag: string } {\n // const repository = 'ghcr.io/layerzero-labs';\n const repository = `${AWS_ACCOUNT_ID}.dkr.ecr.${AWS_REGION}.amazonaws.com/layerzerolabs`;\n const imageName = `${target}-tooling`;\n\n // Find the tool and its type\n const tool = findToolByName(vmToolingName);\n if (!tool) {\n throw new Error(`Tool '${vmToolingName}' not found`);\n }\n\n // Find the version matrix for this tool type\n const matrix = findMatrixByType(tool.toolType);\n if (!matrix) {\n throw new Error(`No version matrix found for tool type ${tool.toolType}`);\n }\n\n // Find a combination that includes this tool with the specified version\n let foundCombination = null;\n for (const combination of matrix.combinations) {\n const toolVersion = combination.versions[vmToolingName];\n if (toolVersion === version) {\n foundCombination = combination.versions;\n break;\n }\n }\n\n if (!foundCombination) {\n throw new Error(\n `No version combination found for tool ${vmToolingName} with version ${version}`,\n );\n }\n\n // Filter out undefined/empty values for tag generation\n const validVersions: { [key: string]: string } = {};\n for (const [toolName, toolVersion] of Object.entries(foundCombination)) {\n if (typeof toolVersion === 'string' && toolVersion.length > 0) {\n validVersions[toolName] = toolVersion;\n }\n }\n\n const imageTag = getCombinationTag(validVersions);\n const imageURI = `${repository}/${imageName}:${imageTag}`;\n\n return { imageURI, imageTag };\n}\n\n/**\n * Generate Docker image tag from version combination\n */\nfunction getCombinationTag(input: { [key: string]: string }): string {\n const tags = Object.entries(input)\n .map(([key, value]) => `${key}_${value}`)\n .sort((a, b) => a.localeCompare(b));\n\n return tags.join('_');\n}\n\n/**\n * Enhanced Docker image management with intelligent caching\n * Tries ECR first, falls back to local build if available, and caches locally\n */\nasync function ensureDockerImage(imageURI: string, imageTag: string): Promise<void> {\n try {\n // Check if image exists locally first\n const checkResult = await $`docker image ls ${imageURI}`.nothrow();\n\n if (checkResult.stdout.includes(imageTag)) {\n console.info(`✅ Using cached Docker image: ${imageURI}`);\n return;\n }\n\n // Try to pull from ECR\n console.info(`📥 Pulling Docker image from ECR: ${imageURI}`);\n const pullResult = await $`docker pull ${imageURI}`.nothrow();\n\n if (pullResult.exitCode === 0) {\n console.info(`✅ Successfully pulled: ${imageURI}`);\n return;\n }\n\n // If ECR pull fails, check for local fallback image\n const localImageName = imageURI.split('/').pop()?.replace(/:.*$/, '') || '';\n const localFallbackURI = `local-${localImageName}:latest`;\n\n const localCheckResult = await $`docker image ls ${localFallbackURI}`.nothrow();\n\n if (localCheckResult.stdout.includes('local-')) {\n console.info(`🏠 ECR image not available, using local fallback: ${localFallbackURI}`);\n\n // Tag the local image with the ECR URI for consistency\n await $`docker tag ${localFallbackURI} ${imageURI}`;\n console.info(`🏷️ Tagged local image as: ${imageURI}`);\n return;\n }\n\n // If all else fails, provide helpful error message\n throw new Error(\n `❌ Docker image not available:\\n` +\n ` - ECR image: ${imageURI} (pull failed)\\n` +\n ` - Local fallback: ${localFallbackURI} (not found)\\n` +\n `\\n💡 Solutions:\\n` +\n ` 1. Authenticate with ECR: aws ecr get-login-password --region ${AWS_REGION} | docker login --username AWS --password-stdin ${AWS_ACCOUNT_ID}.dkr.ecr.${AWS_REGION}.amazonaws.com\\n` +\n ` 2. Build local image: docker build -t ${localFallbackURI} <dockerfile-path>\\n` +\n ` 3. Check if the image tag exists in ECR`,\n );\n } catch (error) {\n if (error instanceof Error && error.message.includes('❌ Docker image not available')) {\n throw error;\n }\n throw new Error(\n `Failed to ensure Docker image ${imageURI}: ${error instanceof Error ? error.message : String(error)}`,\n );\n }\n}\n\n/**\n * Enhanced tool command execution using the new version compatibility matrix system\n */\nexport async function executeToolCommand(\n command: string,\n args: string[],\n options: {\n cwd: string;\n forceDocker: boolean;\n volumes: VolumeMapping[];\n customEntrypoint?: string;\n env: EnvironmentVariable[];\n script?: string;\n [key: string]: any;\n },\n): Promise<void> {\n const {\n cwd,\n forceDocker,\n volumes: userVolumes,\n customEntrypoint,\n env: customEnvVars,\n script,\n } = options;\n\n const tool = findToolByName(command);\n const type = getToolType(command);\n\n if (!tool || type === undefined) {\n const { tools } = await import('../config');\n const availableTools = tools.map((t) => t.name).join(', ');\n throw new Error(\n `❌ Tool '${command}' not found or no type configuration available.\\n` +\n `Available tools: ${availableTools}\\n` +\n `Try: lz-tool --list-versions to see all available tools`,\n );\n }\n\n // Merge default volumes with user-specified volumes\n const defaultVolumes = tool.defaultVolumes ?? [];\n const volumes = mergeVolumes(defaultVolumes, userVolumes);\n\n if (defaultVolumes.length > 0) {\n console.info(`📦 Using ${defaultVolumes.length} default cache volume(s) for ${command}`);\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 // Extract user-specified versions from command line options\n const userSpecifiedVersions = extractUserVersions(options);\n\n // Resolve versions for all tools in the type using compatibility matrix\n const versionResult = resolveTypeVersions(type, userSpecifiedVersions, options, cwd);\n\n // Display any warnings\n versionResult.warnings.forEach((warning) => {\n console.warn(warning);\n });\n\n // Get the resolved version for the current tool\n const resolvedVersion = versionResult.resolvedVersions[command];\n if (typeof resolvedVersion !== 'string' || resolvedVersion === '') {\n throw new Error(`No version resolved for tool ${command}`);\n }\n\n console.info(`🔧 ${command} version: ${resolvedVersion}`);\n\n // Check secondary version validation if available\n if (tool.getSecondaryVersionCheckValue) {\n try {\n const secondaryVersion = tool.getSecondaryVersionCheckValue({ cwd });\n const resolvedVersionObj: Version = { version: resolvedVersion };\n\n if (!versionsSatisfied(secondaryVersion, resolvedVersionObj)) {\n console.warn(\n `Warning: Local configuration version (${secondaryVersion.version}) differs from resolved version (${resolvedVersion})`,\n );\n }\n } catch (error) {\n // Secondary version check failed, but continue with resolved version\n console.warn(\n `Could not validate secondary version: ${error instanceof Error ? error.message : String(error)}`,\n );\n }\n }\n\n // Check if we should try to use local executable first\n let hasLocalExecutable = false;\n\n if (!forceDocker) {\n const versionFlags = tool.versionCliArguments ?? ['--version'];\n\n try {\n const result = await $`${command} ${versionFlags}`;\n\n // Use tool for parsing output\n if (tool.parseVersionCliVersionOutput) {\n const installedVersion = tool.parseVersionCliVersionOutput(result.stdout);\n const resolvedVersionObj: Version = { version: resolvedVersion };\n\n if (versionsSatisfied(installedVersion, resolvedVersionObj)) {\n hasLocalExecutable = true;\n console.info(`✅ Using local ${command} v${installedVersion.version}`);\n } else {\n console.info(\n `🐳 Local ${command} v${installedVersion.version} ≠ required v${resolvedVersion}, using Docker`,\n );\n }\n }\n } catch (error) {\n // Check if the command is not found (127 exit code)\n if (!(error instanceof Error) || !('exitCode' in error) || error.exitCode !== 127) {\n throw error;\n }\n console.info(`🐳 ${command} not found locally, using Docker`);\n }\n }\n\n let processOutput: ProcessOutput;\n\n if (hasLocalExecutable) {\n // Execute command directly\n processOutput = await $`${command} ${args}`.nothrow();\n } else {\n // Use Docker image with merged volumes\n const { imageTag, imageURI } = getImageName(tool.fromImage, tool.name, resolvedVersion);\n const workspaceRoot = await getFullyQualifiedRepoRootPath();\n const relPath = path.relative(workspaceRoot, cwd);\n const privileged = tool.privileged ?? false;\n\n // Enhanced Docker image caching logic\n await ensureDockerImage(imageURI, imageTag);\n\n const volumeArgs = volumes\n .map((volume) => {\n if (volume.type === 'host') {\n if (volume.hostPath === undefined) {\n throw new Error(`Host path is required for volume mapping of type 'host'`);\n }\n return ['-v', `${volume.hostPath}:${volume.containerPath}`];\n } else {\n if (volume.name === undefined) {\n throw new Error(`Name is required for volume mapping of type 'isolate'`);\n }\n return ['-v', `${volume.name}:${volume.containerPath}`];\n }\n })\n .flat(); // Flatten the array to get ['-v', 'vol1', '-v', 'vol2', ...]\n\n // Use custom entrypoint if provided, otherwise fall back to tool config or tool name\n const entryPoint = customEntrypoint ?? tool.entryPoint;\n\n if (customEntrypoint !== undefined && customEntrypoint.trim() !== '') {\n console.info(`🔧 Using custom entrypoint: ${customEntrypoint}`);\n }\n\n // Build the Docker command with proper argument separation\n const envArgs = customEnvVars\n .map((envVar) => ['-e', `${envVar.name}=${envVar.value}`])\n .flat();\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 !== undefined && 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 ...(privileged ? ['--privileged'] : []),\n '--rm',\n ...envArgs,\n '-v',\n `${workspaceRoot}:/workspace`,\n '-w',\n `/workspace/${relPath}`,\n ...volumeArgs,\n ...(entryPoint === undefined ? [] : ['--entrypoint', entryPoint]),\n imageURI,\n ...finalArgs,\n ];\n\n processOutput = await $`docker ${dockerArgs}`.nothrow();\n saveAptosModulesOrder(command, processOutput, workspaceRoot, relPath);\n }\n\n // Handle the process completion\n const { exitCode } = processOutput;\n if (exitCode !== 0) {\n process.exit(exitCode ?? 1);\n }\n}\n\nfunction saveAptosModulesOrder(\n command: string,\n processOutput: ProcessOutput,\n workspaceRoot: string,\n relPath: string,\n): void {\n if ('aptos' === command) {\n const outputJson: { Result: string[] } = processOutput.json();\n const modules = outputJson.Result.map((item: string) => `${item.split('::')[1]}.mv`);\n fs.writeFileSync(\n path.join(workspaceRoot, relPath, 'modules.json'),\n JSON.stringify(modules, null, 2),\n );\n }\n}\n"]}
@@ -6,9 +6,16 @@ var versionMatrices = [
6
6
  toolType: "evm",
7
7
  combinations: [
8
8
  {
9
- id: "evm_hardhat_2.19.3",
9
+ id: "hardhat_2.19.3",
10
10
  versions: {
11
11
  hardhat: "2.19.3"
12
+ }
13
+ },
14
+ {
15
+ id: "forge_1.3.6_hardhat_2.26.3",
16
+ versions: {
17
+ forge: "1.3.6",
18
+ hardhat: "2.26.3"
12
19
  },
13
20
  isRecommended: true
14
21
  }
@@ -107,5 +114,5 @@ var versionMatrices = [
107
114
  ];
108
115
 
109
116
  exports.versionMatrices = versionMatrices;
110
- //# sourceMappingURL=QSKQ7BQT.cjs.map
111
- //# sourceMappingURL=QSKQ7BQT.cjs.map
117
+ //# sourceMappingURL=7S3N6ZPY.cjs.map
118
+ //# sourceMappingURL=7S3N6ZPY.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/config/version-matrices.ts"],"names":["versionMatrices","toolType","combinations","id","versions","hardhat","forge","isRecommended","solana","anchor","description","aptos","initiad","blueprint","scarb","patch","sui"],"mappings":";;;AAMO,IAAMA,eAAAA,GAAuC;AAChD,EAAA;IACIC,QAAAA,EAAU,KAAA;IACVC,YAAAA,EAAc;AACV,MAAA;QACIC,EAAAA,EAAI,gBAAA;QACJC,QAAAA,EAAU;UAAEC,OAAAA,EAAS;AAAS;AAClC,OAAA;AACA,MAAA;QACIF,EAAAA,EAAI,4BAAA;QACJC,QAAAA,EAAU;UAAEE,KAAAA,EAAO,OAAA;UAASD,OAAAA,EAAS;AAAS,SAAA;QAC9CE,aAAAA,EAAe;AACnB;;AAER,GAAA;AACA,EAAA;IACIN,QAAAA,EAAU,QAAA;IACVC,YAAAA,EAAc;AACV,MAAA;QACIC,EAAAA,EAAI,8BAAA;QACJC,QAAAA,EAAU;UAAEI,MAAAA,EAAQ,SAAA;UAAWC,MAAAA,EAAQ;AAAS,SAAA;QAChDF,aAAAA,EAAe,IAAA;QACfG,WAAAA,EAAa;AACjB,OAAA;AACA,MAAA;QACIP,EAAAA,EAAI,8BAAA;QACJC,QAAAA,EAAU;UAAEI,MAAAA,EAAQ,SAAA;UAAWC,MAAAA,EAAQ;AAAS;AACpD,OAAA;AACA,MAAA;QACIN,EAAAA,EAAI,8BAAA;QACJC,QAAAA,EAAU;UAAEI,MAAAA,EAAQ,SAAA;UAAWC,MAAAA,EAAQ;AAAS,SAAA;QAChDC,WAAAA,EAAa;AACjB;;AAER,GAAA;AACA,EAAA;IACIT,QAAAA,EAAU,OAAA;IACVC,YAAAA,EAAc;AACV,MAAA;QACIC,EAAAA,EAAI,aAAA;QACJC,QAAAA,EAAU;UAAEO,KAAAA,EAAO;AAAQ,SAAA;QAC3BJ,aAAAA,EAAe;AACnB;;AAOR,GAAA;AACA,EAAA;IACIN,QAAAA,EAAU,QAAA;IACVC,YAAAA,EAAc;AACV,MAAA;QACIC,EAAAA,EAAI,cAAA;QACJC,QAAAA,EAAU;UAAEQ,OAAAA,EAAS;AAAQ,SAAA;QAC7BL,aAAAA,EAAe;AACnB;;AAER,GAAA;AACA,EAAA;IACIN,QAAAA,EAAU,KAAA;IACVC,YAAAA,EAAc;AACV,MAAA;QACIC,EAAAA,EAAI,mBAAA;QACJC,QAAAA,EAAU;UAAES,SAAAA,EAAW;AAAgB,SAAA;QACvCN,aAAAA,EAAe;AACnB;;AAER,GAAA;AACA,EAAA;IACIN,QAAAA,EAAU,UAAA;IACVC,YAAAA,EAAc;AACV,MAAA;QACIC,EAAAA,EAAI,cAAA;QACJC,QAAAA,EAAU;UAAEU,KAAAA,EAAO,QAAA;UAAUC,KAAAA,EAAO;AAAI,SAAA;QACxCR,aAAAA,EAAe;AACnB;;AAER,GAAA;AACA,EAAA;IACIN,QAAAA,EAAU,KAAA;IACVC,YAAAA,EAAc;AACV,MAAA;QACIC,EAAAA,EAAI,YAAA;QACJC,QAAAA,EAAU;UAAEY,GAAAA,EAAK;AAAgB,SAAA;QACjCT,aAAAA,EAAe;AACnB;;AAER","file":"7S3N6ZPY.cjs","sourcesContent":["import type { ToolVersionMatrix } from '../types';\n\n/**\n * Version compatibility matrices for each tool type\n * Default combination is the first one marked as isRecommended=true\n */\nexport const versionMatrices: ToolVersionMatrix[] = [\n {\n toolType: 'evm',\n combinations: [\n {\n id: 'hardhat_2.19.3',\n versions: { hardhat: '2.19.3' },\n },\n {\n id: 'forge_1.3.6_hardhat_2.26.3',\n versions: { forge: '1.3.6', hardhat: '2.26.3' },\n isRecommended: true,\n },\n ],\n },\n {\n toolType: 'solana',\n combinations: [\n {\n id: 'solana_1.17.31_anchor_0.29.0',\n versions: { solana: '1.17.31', anchor: '0.29.0' },\n isRecommended: true,\n description: 'Stable and well-tested',\n },\n {\n id: 'solana_1.18.16_anchor_0.30.0',\n versions: { solana: '1.18.16', anchor: '0.30.0' },\n },\n {\n id: 'solana_1.18.16_anchor_0.31.0',\n versions: { solana: '1.18.16', anchor: '0.31.0' },\n description: 'Latest stable release',\n },\n ],\n },\n {\n toolType: 'aptos',\n combinations: [\n {\n id: 'aptos_4.6.0',\n versions: { aptos: '4.6.0' },\n isRecommended: true,\n },\n // TODO Enable Aptos v6.\n // {\n // id: 'aptos_6.0.1',\n // versions: { aptos: '6.0.1' },\n // },\n ],\n },\n {\n toolType: 'initia',\n combinations: [\n {\n id: 'initia_0.6.3',\n versions: { initiad: '0.6.3' },\n isRecommended: true,\n },\n ],\n },\n {\n toolType: 'ton',\n combinations: [\n {\n id: 'ton_0.25.0-beta.1',\n versions: { blueprint: '0.25.0-beta.1' },\n isRecommended: true,\n },\n ],\n },\n {\n toolType: 'starknet',\n combinations: [\n {\n id: 'scarb_2.12.0',\n versions: { scarb: '2.12.0', patch: '1' },\n isRecommended: true,\n },\n ],\n },\n {\n toolType: 'sui',\n combinations: [\n {\n id: 'sui_1.54.1',\n versions: { sui: '1.54.1-beta.0' },\n isRecommended: true,\n },\n ],\n },\n];\n"]}
@@ -1,6 +1,6 @@
1
- import { findBestCompatibleCombination } from './GAZMRBLT.js';
2
- import { tools, findToolByName, getToolDefaultVersion, findMatrixByType, findToolsByType, getToolSupportedVersions } from './SW6HQVVH.js';
1
+ import { tools, findToolByName, getToolDefaultVersion, findMatrixByType, findToolsByType, getToolSupportedVersions } from './CRLXMIJF.js';
3
2
  import { parseVersionFileContents } from './BA2LAHMY.js';
3
+ import { findBestCompatibleCombination } from './GAZMRBLT.js';
4
4
  import { __name } from './VUOMXK5T.js';
5
5
  import process from 'process';
6
6
 
@@ -53,6 +53,9 @@ function resolveTypeVersions(type, userSpecifiedVersions, options, cwd) {
53
53
  const warnings = [];
54
54
  for (const tool of typeTools) {
55
55
  const version = resolveToolVersion(tool.name, userSpecifiedVersions, options, cwd);
56
+ if (!version) {
57
+ continue;
58
+ }
56
59
  resolvedVersions[tool.name] = version;
57
60
  if (version === getToolDefaultVersion(tool.name)) {
58
61
  usedDefaultFor.push(tool.name);
@@ -114,5 +117,5 @@ function resolveTypeVersions(type, userSpecifiedVersions, options, cwd) {
114
117
  __name(resolveTypeVersions, "resolveTypeVersions");
115
118
 
116
119
  export { extractUserVersions, resolveToolVersion, resolveTypeVersions };
117
- //# sourceMappingURL=LWFEVAEC.js.map
118
- //# sourceMappingURL=LWFEVAEC.js.map
120
+ //# sourceMappingURL=BQE33FG7.js.map
121
+ //# sourceMappingURL=BQE33FG7.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/core/version-resolver.ts"],"names":["extractUserVersions","options","userVersions","tool","tools","versionKey","name","versionValue","resolveToolVersion","toolName","userSpecifiedVersions","cwd","findToolByName","Error","userVersion","envKey","toUpperCase","envVersion","process","env","parsedVersions","parseVersionFileContents","foundVersion","error","getToolDefaultVersion","resolveTypeVersions","type","matrix","findMatrixByType","typeTools","findToolsByType","length","resolvedVersions","usedDefaultFor","warnings","version","push","supportedVersions","getToolSupportedVersions","includes","join","matchedCombination","isCompatibleCombination","combo","combinations","matches","Object","entries","versions","every","compatibleCombo","findBestCompatibleCombination","adjusted","comboVersion","undefined","oldVersion","recommendedCombos","filter","c","isRecommended","map","id","description","console","info","combinationId"],"mappings":"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","file":"BQE33FG7.js","sourcesContent":["import process from 'process';\n\nimport { tools } from '../config';\nimport type { ToolType, VersionCombination, VersionResolutionResult } from '../types';\nimport { parseVersionFileContents } from '../utils';\nimport {\n findMatrixByType,\n findToolByName,\n findToolsByType,\n getToolDefaultVersion,\n getToolSupportedVersions,\n} from '../utils/finder-utils';\nimport { findBestCompatibleCombination } from './compatibility';\n\n/**\n * Extract user-specified versions from command line options\n */\nexport function extractUserVersions(options: { [key: string]: any }): { [key: string]: string } {\n const userVersions: { [key: string]: string } = {};\n\n // Extract versions from command line options\n for (const tool of tools) {\n const versionKey = `${tool.name}Version`;\n const versionValue = options[versionKey] as unknown;\n if (typeof versionValue === 'string' && versionValue !== '') {\n userVersions[tool.name] = versionValue;\n }\n }\n\n return userVersions;\n}\n\n/**\n * Resolve version for a single tool following priority order:\n * 1. Command line options\n * 2. Environment variables\n * 3. .versions file\n * 4. Default version\n */\nexport function resolveToolVersion(\n toolName: string,\n userSpecifiedVersions: { [key: string]: string },\n options: { [key: string]: any },\n cwd: string,\n): string | null {\n const tool = findToolByName(toolName);\n if (!tool) {\n throw new Error(`Tool ${toolName} not found`);\n }\n\n // 1. Check command line options (highest priority)\n const userVersion = userSpecifiedVersions[toolName];\n if (typeof userVersion === 'string' && userVersion !== '') {\n return userVersion;\n }\n\n // 2. Check environment variables\n const envKey = `${tool.name.toUpperCase()}_VERSION`;\n const envVersion = process.env[envKey];\n if (typeof envVersion === 'string' && envVersion !== '') {\n return envVersion;\n }\n\n // 3. Check .versions file\n try {\n const parsedVersions = parseVersionFileContents(cwd);\n const versionKey = `${tool.name}_version`.toUpperCase();\n const foundVersion = parsedVersions[versionKey];\n\n if (typeof foundVersion === 'string' && foundVersion !== '') {\n return foundVersion;\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n } catch (error) {\n // If .versions file doesn't exist or can't be parsed, continue to default\n }\n\n // 4. Use default version\n return getToolDefaultVersion(tool.name);\n}\n\n/**\n * Resolve versions for all tools in a type with compatibility checking\n */\nexport function resolveTypeVersions(\n type: ToolType,\n userSpecifiedVersions: { [key: string]: string },\n options: { [key: string]: any },\n cwd: string,\n): VersionResolutionResult {\n const matrix = findMatrixByType(type);\n const typeTools = findToolsByType(type);\n\n if (!matrix || typeTools.length === 0) {\n throw new Error(`Type ${type} not found or no version matrix available`);\n }\n\n // 1. Collect versions from all sources for each tool\n const resolvedVersions: { [key: string]: string } = {};\n const usedDefaultFor: string[] = [];\n const warnings: string[] = [];\n\n for (const tool of typeTools) {\n const version = resolveToolVersion(tool.name, userSpecifiedVersions, options, cwd);\n\n if (!version) {\n continue;\n }\n\n resolvedVersions[tool.name] = version;\n\n if (version === getToolDefaultVersion(tool.name)) {\n usedDefaultFor.push(tool.name);\n }\n\n // Validate user-specified version if not default\n if (version !== getToolDefaultVersion(tool.name)) {\n const supportedVersions = getToolSupportedVersions(tool.name);\n if (!supportedVersions.includes(version)) {\n warnings.push(\n `⚠️ Version ${version} for ${tool.name} is not in the supported list.\\n` +\n ` Supported versions: ${supportedVersions.join(', ')}\\n` +\n ` Continuing with Docker availability as final validation...`,\n );\n }\n }\n }\n\n // 2. Check if current combination matches any compatible combination\n let matchedCombination: VersionCombination | undefined;\n let isCompatibleCombination = false;\n\n for (const combo of matrix.combinations) {\n const matches = Object.entries(combo.versions).every(\n ([tool, version]) => resolvedVersions[tool] === version,\n );\n\n if (matches) {\n matchedCombination = combo;\n isCompatibleCombination = true;\n break;\n }\n }\n\n // 3. If not compatible and some tools used defaults, try to auto-adjust\n if (!isCompatibleCombination && usedDefaultFor.length > 0) {\n const compatibleCombo = findBestCompatibleCombination(resolvedVersions, matrix);\n\n if (compatibleCombo) {\n let adjusted = false;\n\n for (const toolName of usedDefaultFor) {\n const comboVersion = compatibleCombo.versions[toolName];\n if (comboVersion !== undefined && comboVersion !== resolvedVersions[toolName]) {\n const oldVersion = resolvedVersions[toolName];\n resolvedVersions[toolName] = comboVersion;\n warnings.push(\n `🔄 Auto-adjusted ${toolName}: ${oldVersion} → ${comboVersion} (for compatibility)`,\n );\n adjusted = true;\n }\n }\n\n if (adjusted) {\n matchedCombination = compatibleCombo;\n isCompatibleCombination = true;\n }\n }\n }\n\n // 4. Add compatibility warnings\n if (!isCompatibleCombination) {\n const recommendedCombos = matrix.combinations\n .filter((c) => c.isRecommended)\n .map((c) => c.id)\n .join(', ');\n\n warnings.push(\n `⚠️ Custom version combination detected - not officially tested.\\n` +\n ` 💡 Stable combinations: ${recommendedCombos}\\n` +\n ` 🔍 Use 'lz-tool --list-versions' to see all tested combinations.`,\n );\n } else if (matchedCombination?.description !== undefined) {\n console.info(`✅ ${matchedCombination.description} (${matchedCombination.id})`);\n }\n\n return {\n resolvedVersions,\n isCompatibleCombination,\n usedDefaultFor,\n warnings,\n combinationId: matchedCombination?.id,\n };\n}\n"]}
@@ -1,5 +1,5 @@
1
- import { extractUserVersions, resolveTypeVersions } from './LWFEVAEC.js';
2
- import { findToolByName, findMatrixByType, AWS_ACCOUNT_ID, AWS_REGION, getToolType, versionsSatisfied } from './SW6HQVVH.js';
1
+ import { extractUserVersions, resolveTypeVersions } from './BQE33FG7.js';
2
+ import { findToolByName, findMatrixByType, AWS_ACCOUNT_ID, AWS_REGION, getToolType, versionsSatisfied } from './CRLXMIJF.js';
3
3
  import { __name } from './VUOMXK5T.js';
4
4
  import fs from 'fs';
5
5
  import path from 'path';
@@ -268,5 +268,5 @@ function saveAptosModulesOrder(command, processOutput, workspaceRoot, relPath) {
268
268
  __name(saveAptosModulesOrder, "saveAptosModulesOrder");
269
269
 
270
270
  export { executeToolCommand };
271
- //# sourceMappingURL=AQLGVUST.js.map
272
- //# sourceMappingURL=AQLGVUST.js.map
271
+ //# sourceMappingURL=CFMPNPDE.js.map
272
+ //# sourceMappingURL=CFMPNPDE.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/core/tool-executor.ts"],"names":["$","verbose","stdio","process","stderr","mergeVolumes","defaultVolumes","userVolumes","merged","userPaths","Set","map","v","containerPath","push","defaultVolume","has","getImageName","target","vmToolingName","version","repository","AWS_ACCOUNT_ID","AWS_REGION","imageName","tool","findToolByName","Error","matrix","findMatrixByType","toolType","foundCombination","combination","combinations","toolVersion","versions","validVersions","toolName","Object","entries","length","imageTag","getCombinationTag","imageURI","input","tags","key","value","sort","a","b","localeCompare","join","ensureDockerImage","checkResult","nothrow","stdout","includes","console","info","pullResult","exitCode","localImageName","split","pop","replace","localFallbackURI","localCheckResult","error","message","String","executeToolCommand","command","args","options","cwd","forceDocker","volumes","customEntrypoint","env","customEnvVars","script","type","getToolType","undefined","tools","availableTools","t","name","overrides","filter","uv","some","dv","userSpecifiedVersions","extractUserVersions","versionResult","resolveTypeVersions","warnings","forEach","warning","warn","resolvedVersion","resolvedVersions","getSecondaryVersionCheckValue","secondaryVersion","resolvedVersionObj","versionsSatisfied","hasLocalExecutable","versionFlags","versionCliArguments","result","parseVersionCliVersionOutput","installedVersion","processOutput","fromImage","workspaceRoot","getFullyQualifiedRepoRootPath","relPath","path","relative","privileged","volumeArgs","volume","hostPath","flat","entryPoint","trim","envArgs","envVar","finalArgs","dockerArgs","saveAptosModulesOrder","exit","outputJson","json","modules","Result","item","fs","writeFileSync","JSON","stringify"],"mappings":";;;;;;;;;AAeAA,CAAAA,CAAEC,OAAAA,GAAU,IAAA;AACZD,CAAAA,CAAEE,KAAAA,GAAQ;AAAC,EAAA,SAAA;AAAW,EAAA,MAAA;EAAQC,OAAAA,CAAQC;;AAMtC,SAASC,YAAAA,CACLC,gBACAC,WAAAA,EAA4B;AAE5B,EAAA,MAAMC,SAA0B,EAAA;AAChC,EAAA,MAAMC,SAAAA,GAAY,IAAIC,GAAAA,CAAIH,WAAAA,CAAYI,IAAI,CAACC,CAAAA,KAAMA,CAAAA,CAAEC,aAAa,CAAA,CAAA;AAGhEL,EAAAA,MAAAA,CAAOM,IAAAA,CAAI,GAAIP,WAAAA,CAAAA;AAGf,EAAA,KAAA,MAAWQ,iBAAiBT,cAAAA,EAAgB;AACxC,IAAA,IAAI,CAACG,SAAAA,CAAUO,GAAAA,CAAID,aAAAA,CAAcF,aAAa,CAAA,EAAG;AAC7CL,MAAAA,MAAAA,CAAOM,KAAKC,aAAAA,CAAAA;AAChB,IAAA;AACJ,EAAA;AAEA,EAAA,OAAOP,MAAAA;AACX;AAlBSH,MAAAA,CAAAA,YAAAA,EAAAA,cAAAA,CAAAA;AAuBT,SAASY,YAAAA,CACLC,MAAAA,EACAC,aAAAA,EACAC,OAAAA,EAAe;AAGf,EAAA,MAAMC,UAAAA,GAAa,CAAA,EAAGC,cAAAA,CAAAA,SAAAA,EAA0BC,UAAAA,CAAAA,4BAAAA,CAAAA;AAChD,EAAA,MAAMC,SAAAA,GAAY,GAAGN,MAAAA,CAAAA,QAAAA,CAAAA;AAGrB,EAAA,MAAMO,IAAAA,GAAOC,eAAeP,aAAAA,CAAAA;AAC5B,EAAA,IAAI,CAACM,IAAAA,EAAM;AACP,IAAA,MAAM,IAAIE,KAAAA,CAAM,CAAA,MAAA,EAASR,aAAAA,CAAAA,WAAAA,CAA0B,CAAA;AACvD,EAAA;AAGA,EAAA,MAAMS,MAAAA,GAASC,gBAAAA,CAAiBJ,IAAAA,CAAKK,QAAQ,CAAA;AAC7C,EAAA,IAAI,CAACF,MAAAA,EAAQ;AACT,IAAA,MAAM,IAAID,KAAAA,CAAM,CAAA,sCAAA,EAAyCF,IAAAA,CAAKK,QAAQ,CAAA,CAAE,CAAA;AAC5E,EAAA;AAGA,EAAA,IAAIC,gBAAAA,GAAmB,IAAA;AACvB,EAAA,KAAA,MAAWC,WAAAA,IAAeJ,OAAOK,YAAAA,EAAc;AAC3C,IAAA,MAAMC,WAAAA,GAAcF,WAAAA,CAAYG,QAAAA,CAAShB,aAAAA,CAAAA;AACzC,IAAA,IAAIe,gBAAgBd,OAAAA,EAAS;AACzBW,MAAAA,gBAAAA,GAAmBC,WAAAA,CAAYG,QAAAA;AAC/B,MAAA;AACJ,IAAA;AACJ,EAAA;AAEA,EAAA,IAAI,CAACJ,gBAAAA,EAAkB;AACnB,IAAA,MAAM,IAAIJ,KAAAA,CACN,CAAA,sCAAA,EAAyCR,aAAAA,CAAAA,cAAAA,EAA8BC,OAAAA,CAAAA,CAAS,CAAA;AAExF,EAAA;AAGA,EAAA,MAAMgB,gBAA2C,EAAC;AAClD,EAAA,KAAA,MAAW,CAACC,QAAAA,EAAUH,WAAAA,KAAgBI,MAAAA,CAAOC,OAAAA,CAAQR,gBAAAA,CAAAA,EAAmB;AACpE,IAAA,IAAI,OAAOG,WAAAA,KAAgB,QAAA,IAAYA,WAAAA,CAAYM,SAAS,CAAA,EAAG;AAC3DJ,MAAAA,aAAAA,CAAcC,QAAAA,CAAAA,GAAYH,WAAAA;AAC9B,IAAA;AACJ,EAAA;AAEA,EAAA,MAAMO,QAAAA,GAAWC,kBAAkBN,aAAAA,CAAAA;AACnC,EAAA,MAAMO,WAAW,CAAA,EAAGtB,UAAAA,CAAAA,CAAAA,EAAcG,SAAAA,IAAaiB,QAAAA,CAAAA,CAAAA;AAE/C,EAAA,OAAO;AAAEE,IAAAA,QAAAA;AAAUF,IAAAA;AAAS,GAAA;AAChC;AAjDSxB,MAAAA,CAAAA,YAAAA,EAAAA,cAAAA,CAAAA;AAsDT,SAASyB,kBAAkBE,KAAAA,EAAgC;AACvD,EAAA,MAAMC,IAAAA,GAAOP,MAAAA,CAAOC,OAAAA,CAAQK,KAAAA,CAAAA,CACvBjC,IAAI,CAAC,CAACmC,GAAAA,EAAKC,KAAAA,CAAAA,KAAW,CAAA,EAAGD,GAAAA,CAAAA,CAAAA,EAAOC,KAAAA,CAAAA,CAAO,CAAA,CACvCC,IAAAA,CAAK,CAACC,GAAGC,CAAAA,KAAMD,CAAAA,CAAEE,aAAAA,CAAcD,CAAAA,CAAAA,CAAAA;AAEpC,EAAA,OAAOL,IAAAA,CAAKO,KAAK,GAAA,CAAA;AACrB;AANSV,MAAAA,CAAAA,iBAAAA,EAAAA,mBAAAA,CAAAA;AAYT,eAAeW,iBAAAA,CAAkBV,UAAkBF,QAAAA,EAAgB;AAC/D,EAAA,IAAI;AAEA,IAAA,MAAMa,WAAAA,GAAc,MAAMtD,CAAAA,CAAAA,gBAAAA,EAAoB2C,QAAAA,GAAWY,OAAAA,EAAO;AAEhE,IAAA,IAAID,WAAAA,CAAYE,MAAAA,CAAOC,QAAAA,CAAShB,QAAAA,CAAAA,EAAW;AACvCiB,MAAAA,OAAAA,CAAQC,IAAAA,CAAK,CAAA,kCAAA,EAAgChB,QAAAA,CAAAA,CAAU,CAAA;AACvD,MAAA;AACJ,IAAA;AAGAe,IAAAA,OAAAA,CAAQC,IAAAA,CAAK,CAAA,yCAAA,EAAqChB,QAAAA,CAAAA,CAAU,CAAA;AAC5D,IAAA,MAAMiB,UAAAA,GAAa,MAAM5D,CAAAA,CAAAA,YAAAA,EAAgB2C,QAAAA,GAAWY,OAAAA,EAAO;AAE3D,IAAA,IAAIK,UAAAA,CAAWC,aAAa,CAAA,EAAG;AAC3BH,MAAAA,OAAAA,CAAQC,IAAAA,CAAK,CAAA,4BAAA,EAA0BhB,QAAAA,CAAAA,CAAU,CAAA;AACjD,MAAA;AACJ,IAAA;AAGA,IAAA,MAAMmB,cAAAA,GAAiBnB,QAAAA,CAASoB,KAAAA,CAAM,GAAA,CAAA,CAAKC,KAAG,EAAIC,OAAAA,CAAQ,MAAA,EAAQ,EAAA,CAAA,IAAO,EAAA;AACzE,IAAA,MAAMC,gBAAAA,GAAmB,SAASJ,cAAAA,CAAAA,OAAAA,CAAAA;AAElC,IAAA,MAAMK,gBAAAA,GAAmB,MAAMnE,CAAAA,CAAAA,gBAAAA,EAAoBkE,gBAAAA,GAAmBX,OAAAA,EAAO;AAE7E,IAAA,IAAIY,gBAAAA,CAAiBX,MAAAA,CAAOC,QAAAA,CAAS,QAAA,CAAA,EAAW;AAC5CC,MAAAA,OAAAA,CAAQC,IAAAA,CAAK,CAAA,yDAAA,EAAqDO,gBAAAA,CAAAA,CAAkB,CAAA;AAGpF,MAAA,MAAMlE,CAAAA,CAAAA,WAAAA,EAAekE,gBAAAA,CAAAA,CAAAA,EAAoBvB,QAAAA,CAAAA,CAAAA;AACzCe,MAAAA,OAAAA,CAAQC,IAAAA,CAAK,CAAA,wCAAA,EAA+BhB,QAAAA,CAAAA,CAAU,CAAA;AACtD,MAAA;AACJ,IAAA;AAGA,IAAA,MAAM,IAAIhB,KAAAA,CACN,CAAA;iBACsBgB,QAAAA,CAAAA;sBACKuB,gBAAAA,CAAAA;;;kEAE4C3C,UAAAA,CAAAA,gDAAAA,EAA6DD,cAAAA,CAAAA,SAAAA,EAA0BC,UAAAA,CAAAA;0CAC/G2C,gBAAAA,CAAAA;AACA,yCAAA,CAAA,CAAA;AAEvD,EAAA,CAAA,CAAA,OAASE,KAAAA,EAAO;AACZ,IAAA,IAAIA,iBAAiBzC,KAAAA,IAASyC,KAAAA,CAAMC,OAAAA,CAAQZ,QAAAA,CAAS,mCAAA,CAAA,EAAiC;AAClF,MAAA,MAAMW,KAAAA;AACV,IAAA;AACA,IAAA,MAAM,IAAIzC,KAAAA,CACN,CAAA,8BAAA,EAAiCgB,QAAAA,CAAAA,EAAAA,EAAayB,KAAAA,YAAiBzC,KAAAA,GAAQyC,KAAAA,CAAMC,OAAAA,GAAUC,MAAAA,CAAOF,KAAAA,CAAAA,CAAAA,CAAQ,CAAA;AAE9G,EAAA;AACJ;AApDef,MAAAA,CAAAA,iBAAAA,EAAAA,mBAAAA,CAAAA;AAyDf,eAAsBkB,kBAAAA,CAClBC,OAAAA,EACAC,IAAAA,EACAC,OAAAA,EAQC;AAED,EAAA,MAAM,EACFC,KACAC,WAAAA,EACAC,OAAAA,EAAStE,aACTuE,gBAAAA,EACAC,GAAAA,EAAKC,aAAAA,EACLC,MAAAA,EAAM,GACNP,OAAAA;AAEJ,EAAA,MAAMjD,IAAAA,GAAOC,eAAe8C,OAAAA,CAAAA;AAC5B,EAAA,MAAMU,IAAAA,GAAOC,YAAYX,OAAAA,CAAAA;AAEzB,EAAA,IAAI,CAAC/C,IAAAA,IAAQyD,IAAAA,KAASE,MAAAA,EAAW;AAC7B,IAAA,MAAM,EAAEC,KAAAA,EAAK,GAAK,MAAM,OAAO,mBAAA,CAAA;AAC/B,IAAA,MAAMC,cAAAA,GAAiBD,MAAM1E,GAAAA,CAAI,CAAC4E,MAAMA,CAAAA,CAAEC,IAAI,CAAA,CAAEpC,IAAAA,CAAK,IAAA,CAAA;AACrD,IAAA,MAAM,IAAIzB,KAAAA,CACN,CAAA,aAAA,EAAW6C,OAAAA,CAAAA;mBACac,cAAAA;AACqC,uDAAA,CAAA,CAAA;AAErE,EAAA;AAGA,EAAA,MAAMhF,cAAAA,GAAiBmB,IAAAA,CAAKnB,cAAAA,IAAkB,EAAA;AAC9C,EAAA,MAAMuE,OAAAA,GAAUxE,YAAAA,CAAaC,cAAAA,EAAgBC,WAAAA,CAAAA;AAE7C,EAAA,IAAID,cAAAA,CAAekC,SAAS,CAAA,EAAG;AAC3BkB,IAAAA,OAAAA,CAAQC,KAAK,CAAA,gBAAA,EAAYrD,cAAAA,CAAekC,MAAM,CAAA,6BAAA,EAAgCgC,OAAAA,CAAAA,CAAS,CAAA;AACvF,IAAA,IAAIjE,WAAAA,CAAYiC,SAAS,CAAA,EAAG;AACxB,MAAA,MAAMiD,SAAAA,GAAYlF,WAAAA,CAAYmF,MAAAA,CAAO,CAACC,EAAAA,KAClCrF,cAAAA,CAAesF,IAAAA,CAAK,CAACC,EAAAA,KAAOA,EAAAA,CAAGhF,aAAAA,KAAkB8E,EAAAA,CAAG9E,aAAa,CAAA,CAAA;AAErE,MAAA,IAAI4E,SAAAA,CAAUjD,SAAS,CAAA,EAAG;AACtBkB,QAAAA,OAAAA,CAAQC,IAAAA,CAAK,CAAA,gCAAA,EAA4B8B,SAAAA,CAAUjD,MAAM,CAAA,kBAAA,CAAoB,CAAA;AACjF,MAAA;AACJ,IAAA;AACJ,EAAA;AAGA,EAAA,MAAMsD,qBAAAA,GAAwBC,oBAAoBrB,OAAAA,CAAAA;AAGlD,EAAA,MAAMsB,aAAAA,GAAgBC,mBAAAA,CAAoBf,IAAAA,EAAMY,qBAAAA,EAAuBpB,SAASC,GAAAA,CAAAA;AAGhFqB,EAAAA,aAAAA,CAAcE,QAAAA,CAASC,OAAAA,CAAQ,CAACC,OAAAA,KAAAA;AAC5B1C,IAAAA,OAAAA,CAAQ2C,KAAKD,OAAAA,CAAAA;EACjB,CAAA,CAAA;AAGA,EAAA,MAAME,eAAAA,GAAkBN,aAAAA,CAAcO,gBAAAA,CAAiB/B,OAAAA,CAAAA;AACvD,EAAA,IAAI,OAAO8B,eAAAA,KAAoB,QAAA,IAAYA,eAAAA,KAAoB,EAAA,EAAI;AAC/D,IAAA,MAAM,IAAI3E,KAAAA,CAAM,CAAA,6BAAA,EAAgC6C,OAAAA,CAAAA,CAAS,CAAA;AAC7D,EAAA;AAEAd,EAAAA,OAAAA,CAAQC,IAAAA,CAAK,CAAA,UAAA,EAAMa,OAAAA,CAAAA,UAAAA,EAAoB8B,eAAAA,CAAAA,CAAiB,CAAA;AAGxD,EAAA,IAAI7E,KAAK+E,6BAAAA,EAA+B;AACpC,IAAA,IAAI;AACA,MAAA,MAAMC,gBAAAA,GAAmBhF,KAAK+E,6BAAAA,CAA8B;AAAE7B,QAAAA;OAAI,CAAA;AAClE,MAAA,MAAM+B,kBAAAA,GAA8B;QAAEtF,OAAAA,EAASkF;AAAgB,OAAA;AAE/D,MAAA,IAAI,CAACK,iBAAAA,CAAkBF,gBAAAA,EAAkBC,kBAAAA,CAAAA,EAAqB;AAC1DhD,QAAAA,OAAAA,CAAQ2C,KACJ,CAAA,sCAAA,EAAyCI,gBAAAA,CAAiBrF,OAAO,CAAA,iCAAA,EAAoCkF,eAAAA,CAAAA,CAAAA,CAAkB,CAAA;AAE/H,MAAA;AACJ,IAAA,CAAA,CAAA,OAASlC,KAAAA,EAAO;AAEZV,MAAAA,OAAAA,CAAQ2C,IAAAA,CACJ,yCAAyCjC,KAAAA,YAAiBzC,KAAAA,GAAQyC,MAAMC,OAAAA,GAAUC,MAAAA,CAAOF,KAAAA,CAAAA,CAAAA,CAAQ,CAAA;AAEzG,IAAA;AACJ,EAAA;AAGA,EAAA,IAAIwC,kBAAAA,GAAqB,KAAA;AAEzB,EAAA,IAAI,CAAChC,WAAAA,EAAa;AACd,IAAA,MAAMiC,YAAAA,GAAepF,KAAKqF,mBAAAA,IAAuB;AAAC,MAAA;;AAElD,IAAA,IAAI;AACA,MAAA,MAAMC,MAAAA,GAAS,MAAM/G,CAAAA,CAAAA,EAAIwE,OAAAA,IAAWqC,YAAAA,CAAAA,CAAAA;AAGpC,MAAA,IAAIpF,KAAKuF,4BAAAA,EAA8B;AACnC,QAAA,MAAMC,gBAAAA,GAAmBxF,IAAAA,CAAKuF,4BAAAA,CAA6BD,MAAAA,CAAOvD,MAAM,CAAA;AACxE,QAAA,MAAMkD,kBAAAA,GAA8B;UAAEtF,OAAAA,EAASkF;AAAgB,SAAA;AAE/D,QAAA,IAAIK,iBAAAA,CAAkBM,gBAAAA,EAAkBP,kBAAAA,CAAAA,EAAqB;AACzDE,UAAAA,kBAAAA,GAAqB,IAAA;AACrBlD,UAAAA,OAAAA,CAAQC,KAAK,CAAA,mBAAA,EAAiBa,OAAAA,CAAAA,EAAAA,EAAYyC,gBAAAA,CAAiB7F,OAAO,CAAA,CAAE,CAAA;QACxE,CAAA,MAAO;AACHsC,UAAAA,OAAAA,CAAQC,IAAAA,CACJ,mBAAYa,OAAAA,CAAAA,EAAAA,EAAYyC,iBAAiB7F,OAAO,CAAA,kBAAA,EAAgBkF,eAAAA,CAAAA,cAAAA,CAA+B,CAAA;AAEvG,QAAA;AACJ,MAAA;AACJ,IAAA,CAAA,CAAA,OAASlC,KAAAA,EAAO;AAEZ,MAAA,IAAI,EAAEA,iBAAiBzC,KAAAA,CAAAA,IAAU,EAAE,cAAcyC,KAAAA,CAAAA,IAAUA,KAAAA,CAAMP,aAAa,GAAA,EAAK;AAC/E,QAAA,MAAMO,KAAAA;AACV,MAAA;AACAV,MAAAA,OAAAA,CAAQC,IAAAA,CAAK,CAAA,UAAA,EAAMa,OAAAA,CAAAA,gCAAAA,CAAyC,CAAA;AAChE,IAAA;AACJ,EAAA;AAEA,EAAA,IAAI0C,aAAAA;AAEJ,EAAA,IAAIN,kBAAAA,EAAoB;AAEpBM,IAAAA,aAAAA,GAAgB,MAAMlH,CAAAA,CAAAA,EAAIwE,OAAAA,CAAAA,CAAAA,EAAWC,IAAAA,GAAOlB,OAAAA,EAAO;EACvD,CAAA,MAAO;AAEH,IAAA,MAAM,EAAEd,UAAUE,QAAAA,EAAQ,GAAK1B,aAAaQ,IAAAA,CAAK0F,SAAAA,EAAW1F,IAAAA,CAAK+D,IAAAA,EAAMc,eAAAA,CAAAA;AACvE,IAAA,MAAMc,aAAAA,GAAgB,MAAMC,6BAAAA,EAAAA;AAC5B,IAAA,MAAMC,OAAAA,GAAUC,IAAAA,CAAKC,QAAAA,CAASJ,aAAAA,EAAezC,GAAAA,CAAAA;AAC7C,IAAA,MAAM8C,UAAAA,GAAahG,KAAKgG,UAAAA,IAAc,KAAA;AAGtC,IAAA,MAAMpE,iBAAAA,CAAkBV,UAAUF,QAAAA,CAAAA;AAElC,IAAA,MAAMiF,UAAAA,GAAa7C,OAAAA,CACdlE,GAAAA,CAAI,CAACgH,MAAAA,KAAAA;AACF,MAAA,IAAIA,MAAAA,CAAOzC,SAAS,MAAA,EAAQ;AACxB,QAAA,IAAIyC,MAAAA,CAAOC,aAAaxC,MAAAA,EAAW;AAC/B,UAAA,MAAM,IAAIzD,MAAM,CAAA,uDAAA,CAAyD,CAAA;AAC7E,QAAA;AACA,QAAA,OAAO;AAAC,UAAA,IAAA;AAAM,UAAA,CAAA,EAAGgG,MAAAA,CAAOC,QAAQ,CAAA,CAAA,EAAID,MAAAA,CAAO9G,aAAa,CAAA;;MAC5D,CAAA,MAAO;AACH,QAAA,IAAI8G,MAAAA,CAAOnC,SAASJ,MAAAA,EAAW;AAC3B,UAAA,MAAM,IAAIzD,MAAM,CAAA,qDAAA,CAAuD,CAAA;AAC3E,QAAA;AACA,QAAA,OAAO;AAAC,UAAA,IAAA;AAAM,UAAA,CAAA,EAAGgG,MAAAA,CAAOnC,IAAI,CAAA,CAAA,EAAImC,MAAAA,CAAO9G,aAAa,CAAA;;AACxD,MAAA;AACJ,IAAA,CAAA,EACCgH,IAAAA,EAAI;AAGT,IAAA,MAAMC,UAAAA,GAAahD,oBAAoBrD,IAAAA,CAAKqG,UAAAA;AAE5C,IAAA,IAAIhD,gBAAAA,KAAqBM,MAAAA,IAAaN,gBAAAA,CAAiBiD,IAAAA,OAAW,EAAA,EAAI;AAClErE,MAAAA,OAAAA,CAAQC,IAAAA,CAAK,CAAA,mCAAA,EAA+BmB,gBAAAA,CAAAA,CAAkB,CAAA;AAClE,IAAA;AAGA,IAAA,MAAMkD,OAAAA,GAAUhD,aAAAA,CACXrE,GAAAA,CAAI,CAACsH,MAAAA,KAAW;AAAC,MAAA,IAAA;AAAM,MAAA,CAAA,EAAGA,MAAAA,CAAOzC,IAAI,CAAA,CAAA,EAAIyC,MAAAA,CAAOlF,KAAK,CAAA;AAAG,KAAA,CAAA,CACxD8E,IAAAA,EAAI;AAET,IAAA,IAAI7C,aAAAA,CAAcxC,SAAS,CAAA,EAAG;AAC1BkB,MAAAA,OAAAA,CAAQC,IAAAA,CAAK,CAAA,gBAAA,EAAYqB,aAAAA,CAAcxC,MAAM,CAAA,+BAAA,CAAiC,CAAA;AAClF,IAAA;AAGA,IAAA,IAAI0F,SAAAA;AACJ,IAAA,IAAIjD,MAAAA,KAAWG,MAAAA,IAAaH,MAAAA,CAAO8C,IAAAA,OAAW,EAAA,EAAI;AAC9CrE,MAAAA,OAAAA,CAAQC,IAAAA,CAAK,CAAA,mCAAA,EAA+BsB,MAAAA,CAAAA,CAAQ,CAAA;AACpDiD,MAAAA,SAAAA,GAAY;AAAC,QAAA,MAAA;AAAQ,QAAA,IAAA;AAAMjD,QAAAA;;IAC/B,CAAA,MAAO;AACHiD,MAAAA,SAAAA,GAAYJ,eAAe1C,MAAAA,GAAY;QAAC3D,IAAAA,CAAK+D,IAAAA;AAASf,QAAAA,GAAAA;AAAQA,OAAAA,GAAAA,IAAAA;AAClE,IAAA;AAGA,IAAA,MAAM0D,UAAAA,GAAa;AACf,MAAA,KAAA;SACIV,UAAAA,GAAa;AAAC,QAAA;UAAkB,EAAA;AACpC,MAAA,MAAA;AACGO,MAAAA,GAAAA,OAAAA;AACH,MAAA,IAAA;AACA,MAAA,CAAA,EAAGZ,aAAAA,CAAAA,WAAAA,CAAAA;AACH,MAAA,IAAA;AACA,MAAA,CAAA,WAAA,EAAcE,OAAAA,CAAAA,CAAAA;AACXI,MAAAA,GAAAA,UAAAA;SACCI,UAAAA,KAAe1C,MAAAA,GAAY,EAAA,GAAK;AAAC,QAAA,cAAA;AAAgB0C,QAAAA;;AACrDnF,MAAAA,QAAAA;AACGuF,MAAAA,GAAAA;;AAGPhB,IAAAA,aAAAA,GAAgB,MAAMlH,CAAAA,CAAAA,OAAAA,EAAWmI,UAAAA,CAAAA,CAAAA,CAAa5E,OAAAA,EAAO;AACrD6E,IAAAA,qBAAAA,CAAsB5D,OAAAA,EAAS0C,aAAAA,EAAeE,aAAAA,EAAeE,OAAAA,CAAAA;AACjE,EAAA;AAGA,EAAA,MAAM,EAAEzD,UAAQ,GAAKqD,aAAAA;AACrB,EAAA,IAAIrD,aAAa,CAAA,EAAG;AAChB1D,IAAAA,OAAAA,CAAQkI,IAAAA,CAAKxE,YAAY,CAAA,CAAA;AAC7B,EAAA;AACJ;AA1MsBU,MAAAA,CAAAA,kBAAAA,EAAAA,oBAAAA,CAAAA;AA4MtB,SAAS6D,qBAAAA,CACL5D,OAAAA,EACA0C,aAAAA,EACAE,aAAAA,EACAE,OAAAA,EAAe;AAEf,EAAA,IAAI,YAAY9C,OAAAA,EAAS;AACrB,IAAA,MAAM8D,UAAAA,GAAmCpB,cAAcqB,IAAAA,EAAI;AAC3D,IAAA,MAAMC,OAAAA,GAAUF,UAAAA,CAAWG,MAAAA,CAAO9H,GAAAA,CAAI,CAAC+H,IAAAA,KAAiB,CAAA,EAAGA,IAAAA,CAAK3E,KAAAA,CAAM,IAAA,CAAA,CAAM,CAAA,CAAE,CAAA,GAAA,CAAK,CAAA;AACnF4E,IAAAA,EAAAA,CAAGC,aAAAA,CACCrB,IAAAA,CAAKnE,IAAAA,CAAKgE,aAAAA,EAAeE,OAAAA,EAAS,cAAA,CAAA,EAClCuB,IAAAA,CAAKC,SAAAA,CAAUN,OAAAA,EAAS,IAAA,EAAM,CAAA,CAAA,CAAA;AAEtC,EAAA;AACJ;AAdSJ,MAAAA,CAAAA,qBAAAA,EAAAA,uBAAAA,CAAAA","file":"AQLGVUST.js","sourcesContent":["import fs from 'fs';\nimport path from 'path';\nimport process from 'process';\nimport type { ProcessOutput } from 'zx';\nimport { $ } from 'zx';\n\nimport { getFullyQualifiedRepoRootPath } from '@layerzerolabs/common-node-utils';\n\nimport { AWS_ACCOUNT_ID, AWS_REGION } from '../config';\nimport type { EnvironmentVariable, ToolingImageTargetName, Version, VolumeMapping } from '../types';\nimport { findMatrixByType, findToolByName, getToolType } from '../utils/finder-utils';\nimport { versionsSatisfied } from '../utils/version-utils';\nimport { extractUserVersions, resolveTypeVersions } from './version-resolver';\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 */\nfunction mergeVolumes(\n defaultVolumes: VolumeMapping[],\n userVolumes: VolumeMapping[],\n): VolumeMapping[] {\n const merged: VolumeMapping[] = [];\n const userPaths = new Set(userVolumes.map((v) => v.containerPath));\n\n // Add user volumes first (highest priority)\n merged.push(...userVolumes);\n\n // Add default volumes that don't conflict with user volumes\n for (const defaultVolume of defaultVolumes) {\n if (!userPaths.has(defaultVolume.containerPath)) {\n merged.push(defaultVolume);\n }\n }\n\n return merged;\n}\n\n/**\n * Get Docker image name and tag for a specific tool and version\n */\nfunction getImageName(\n target: ToolingImageTargetName,\n vmToolingName: string,\n version: string,\n): { imageURI: string; imageTag: string } {\n // const repository = 'ghcr.io/layerzero-labs';\n const repository = `${AWS_ACCOUNT_ID}.dkr.ecr.${AWS_REGION}.amazonaws.com/layerzerolabs`;\n const imageName = `${target}-tooling`;\n\n // Find the tool and its type\n const tool = findToolByName(vmToolingName);\n if (!tool) {\n throw new Error(`Tool '${vmToolingName}' not found`);\n }\n\n // Find the version matrix for this tool type\n const matrix = findMatrixByType(tool.toolType);\n if (!matrix) {\n throw new Error(`No version matrix found for tool type ${tool.toolType}`);\n }\n\n // Find a combination that includes this tool with the specified version\n let foundCombination = null;\n for (const combination of matrix.combinations) {\n const toolVersion = combination.versions[vmToolingName];\n if (toolVersion === version) {\n foundCombination = combination.versions;\n break;\n }\n }\n\n if (!foundCombination) {\n throw new Error(\n `No version combination found for tool ${vmToolingName} with version ${version}`,\n );\n }\n\n // Filter out undefined/empty values for tag generation\n const validVersions: { [key: string]: string } = {};\n for (const [toolName, toolVersion] of Object.entries(foundCombination)) {\n if (typeof toolVersion === 'string' && toolVersion.length > 0) {\n validVersions[toolName] = toolVersion;\n }\n }\n\n const imageTag = getCombinationTag(validVersions);\n const imageURI = `${repository}/${imageName}:${imageTag}`;\n\n return { imageURI, imageTag };\n}\n\n/**\n * Generate Docker image tag from version combination\n */\nfunction getCombinationTag(input: { [key: string]: string }): string {\n const tags = Object.entries(input)\n .map(([key, value]) => `${key}_${value}`)\n .sort((a, b) => a.localeCompare(b));\n\n return tags.join('_');\n}\n\n/**\n * Enhanced Docker image management with intelligent caching\n * Tries ECR first, falls back to local build if available, and caches locally\n */\nasync function ensureDockerImage(imageURI: string, imageTag: string): Promise<void> {\n try {\n // Check if image exists locally first\n const checkResult = await $`docker image ls ${imageURI}`.nothrow();\n\n if (checkResult.stdout.includes(imageTag)) {\n console.info(`✅ Using cached Docker image: ${imageURI}`);\n return;\n }\n\n // Try to pull from ECR\n console.info(`📥 Pulling Docker image from ECR: ${imageURI}`);\n const pullResult = await $`docker pull ${imageURI}`.nothrow();\n\n if (pullResult.exitCode === 0) {\n console.info(`✅ Successfully pulled: ${imageURI}`);\n return;\n }\n\n // If ECR pull fails, check for local fallback image\n const localImageName = imageURI.split('/').pop()?.replace(/:.*$/, '') || '';\n const localFallbackURI = `local-${localImageName}:latest`;\n\n const localCheckResult = await $`docker image ls ${localFallbackURI}`.nothrow();\n\n if (localCheckResult.stdout.includes('local-')) {\n console.info(`🏠 ECR image not available, using local fallback: ${localFallbackURI}`);\n\n // Tag the local image with the ECR URI for consistency\n await $`docker tag ${localFallbackURI} ${imageURI}`;\n console.info(`🏷️ Tagged local image as: ${imageURI}`);\n return;\n }\n\n // If all else fails, provide helpful error message\n throw new Error(\n `❌ Docker image not available:\\n` +\n ` - ECR image: ${imageURI} (pull failed)\\n` +\n ` - Local fallback: ${localFallbackURI} (not found)\\n` +\n `\\n💡 Solutions:\\n` +\n ` 1. Authenticate with ECR: aws ecr get-login-password --region ${AWS_REGION} | docker login --username AWS --password-stdin ${AWS_ACCOUNT_ID}.dkr.ecr.${AWS_REGION}.amazonaws.com\\n` +\n ` 2. Build local image: docker build -t ${localFallbackURI} <dockerfile-path>\\n` +\n ` 3. Check if the image tag exists in ECR`,\n );\n } catch (error) {\n if (error instanceof Error && error.message.includes('❌ Docker image not available')) {\n throw error;\n }\n throw new Error(\n `Failed to ensure Docker image ${imageURI}: ${error instanceof Error ? error.message : String(error)}`,\n );\n }\n}\n\n/**\n * Enhanced tool command execution using the new version compatibility matrix system\n */\nexport async function executeToolCommand(\n command: string,\n args: string[],\n options: {\n cwd: string;\n forceDocker: boolean;\n volumes: VolumeMapping[];\n customEntrypoint?: string;\n env: EnvironmentVariable[];\n script?: string;\n [key: string]: any;\n },\n): Promise<void> {\n const {\n cwd,\n forceDocker,\n volumes: userVolumes,\n customEntrypoint,\n env: customEnvVars,\n script,\n } = options;\n\n const tool = findToolByName(command);\n const type = getToolType(command);\n\n if (!tool || type === undefined) {\n const { tools } = await import('../config');\n const availableTools = tools.map((t) => t.name).join(', ');\n throw new Error(\n `❌ Tool '${command}' not found or no type configuration available.\\n` +\n `Available tools: ${availableTools}\\n` +\n `Try: lz-tool --list-versions to see all available tools`,\n );\n }\n\n // Merge default volumes with user-specified volumes\n const defaultVolumes = tool.defaultVolumes ?? [];\n const volumes = mergeVolumes(defaultVolumes, userVolumes);\n\n if (defaultVolumes.length > 0) {\n console.info(`📦 Using ${defaultVolumes.length} default cache volume(s) for ${command}`);\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 // Extract user-specified versions from command line options\n const userSpecifiedVersions = extractUserVersions(options);\n\n // Resolve versions for all tools in the type using compatibility matrix\n const versionResult = resolveTypeVersions(type, userSpecifiedVersions, options, cwd);\n\n // Display any warnings\n versionResult.warnings.forEach((warning) => {\n console.warn(warning);\n });\n\n // Get the resolved version for the current tool\n const resolvedVersion = versionResult.resolvedVersions[command];\n if (typeof resolvedVersion !== 'string' || resolvedVersion === '') {\n throw new Error(`No version resolved for tool ${command}`);\n }\n\n console.info(`🔧 ${command} version: ${resolvedVersion}`);\n\n // Check secondary version validation if available\n if (tool.getSecondaryVersionCheckValue) {\n try {\n const secondaryVersion = tool.getSecondaryVersionCheckValue({ cwd });\n const resolvedVersionObj: Version = { version: resolvedVersion };\n\n if (!versionsSatisfied(secondaryVersion, resolvedVersionObj)) {\n console.warn(\n `Warning: Local configuration version (${secondaryVersion.version}) differs from resolved version (${resolvedVersion})`,\n );\n }\n } catch (error) {\n // Secondary version check failed, but continue with resolved version\n console.warn(\n `Could not validate secondary version: ${error instanceof Error ? error.message : String(error)}`,\n );\n }\n }\n\n // Check if we should try to use local executable first\n let hasLocalExecutable = false;\n\n if (!forceDocker) {\n const versionFlags = tool.versionCliArguments ?? ['--version'];\n\n try {\n const result = await $`${command} ${versionFlags}`;\n\n // Use tool for parsing output\n if (tool.parseVersionCliVersionOutput) {\n const installedVersion = tool.parseVersionCliVersionOutput(result.stdout);\n const resolvedVersionObj: Version = { version: resolvedVersion };\n\n if (versionsSatisfied(installedVersion, resolvedVersionObj)) {\n hasLocalExecutable = true;\n console.info(`✅ Using local ${command} v${installedVersion.version}`);\n } else {\n console.info(\n `🐳 Local ${command} v${installedVersion.version} ≠ required v${resolvedVersion}, using Docker`,\n );\n }\n }\n } catch (error) {\n // Check if the command is not found (127 exit code)\n if (!(error instanceof Error) || !('exitCode' in error) || error.exitCode !== 127) {\n throw error;\n }\n console.info(`🐳 ${command} not found locally, using Docker`);\n }\n }\n\n let processOutput: ProcessOutput;\n\n if (hasLocalExecutable) {\n // Execute command directly\n processOutput = await $`${command} ${args}`.nothrow();\n } else {\n // Use Docker image with merged volumes\n const { imageTag, imageURI } = getImageName(tool.fromImage, tool.name, resolvedVersion);\n const workspaceRoot = await getFullyQualifiedRepoRootPath();\n const relPath = path.relative(workspaceRoot, cwd);\n const privileged = tool.privileged ?? false;\n\n // Enhanced Docker image caching logic\n await ensureDockerImage(imageURI, imageTag);\n\n const volumeArgs = volumes\n .map((volume) => {\n if (volume.type === 'host') {\n if (volume.hostPath === undefined) {\n throw new Error(`Host path is required for volume mapping of type 'host'`);\n }\n return ['-v', `${volume.hostPath}:${volume.containerPath}`];\n } else {\n if (volume.name === undefined) {\n throw new Error(`Name is required for volume mapping of type 'isolate'`);\n }\n return ['-v', `${volume.name}:${volume.containerPath}`];\n }\n })\n .flat(); // Flatten the array to get ['-v', 'vol1', '-v', 'vol2', ...]\n\n // Use custom entrypoint if provided, otherwise fall back to tool config or tool name\n const entryPoint = customEntrypoint ?? tool.entryPoint;\n\n if (customEntrypoint !== undefined && customEntrypoint.trim() !== '') {\n console.info(`🔧 Using custom entrypoint: ${customEntrypoint}`);\n }\n\n // Build the Docker command with proper argument separation\n const envArgs = customEnvVars\n .map((envVar) => ['-e', `${envVar.name}=${envVar.value}`])\n .flat();\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 !== undefined && 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 ...(privileged ? ['--privileged'] : []),\n '--rm',\n ...envArgs,\n '-v',\n `${workspaceRoot}:/workspace`,\n '-w',\n `/workspace/${relPath}`,\n ...volumeArgs,\n ...(entryPoint === undefined ? [] : ['--entrypoint', entryPoint]),\n imageURI,\n ...finalArgs,\n ];\n\n processOutput = await $`docker ${dockerArgs}`.nothrow();\n saveAptosModulesOrder(command, processOutput, workspaceRoot, relPath);\n }\n\n // Handle the process completion\n const { exitCode } = processOutput;\n if (exitCode !== 0) {\n process.exit(exitCode ?? 1);\n }\n}\n\nfunction saveAptosModulesOrder(\n command: string,\n processOutput: ProcessOutput,\n workspaceRoot: string,\n relPath: string,\n): void {\n if ('aptos' === command) {\n const outputJson: { Result: string[] } = processOutput.json();\n const modules = outputJson.Result.map((item: string) => `${item.split('::')[1]}.mv`);\n fs.writeFileSync(\n path.join(workspaceRoot, relPath, 'modules.json'),\n JSON.stringify(modules, null, 2),\n );\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/core/tool-executor.ts"],"names":["$","verbose","stdio","process","stderr","mergeVolumes","defaultVolumes","userVolumes","merged","userPaths","Set","map","v","containerPath","push","defaultVolume","has","getImageName","target","vmToolingName","version","repository","AWS_ACCOUNT_ID","AWS_REGION","imageName","tool","findToolByName","Error","matrix","findMatrixByType","toolType","foundCombination","combination","combinations","toolVersion","versions","validVersions","toolName","Object","entries","length","imageTag","getCombinationTag","imageURI","input","tags","key","value","sort","a","b","localeCompare","join","ensureDockerImage","checkResult","nothrow","stdout","includes","console","info","pullResult","exitCode","localImageName","split","pop","replace","localFallbackURI","localCheckResult","error","message","String","executeToolCommand","command","args","options","cwd","forceDocker","volumes","customEntrypoint","env","customEnvVars","script","type","getToolType","undefined","tools","availableTools","t","name","overrides","filter","uv","some","dv","userSpecifiedVersions","extractUserVersions","versionResult","resolveTypeVersions","warnings","forEach","warning","warn","resolvedVersion","resolvedVersions","getSecondaryVersionCheckValue","secondaryVersion","resolvedVersionObj","versionsSatisfied","hasLocalExecutable","versionFlags","versionCliArguments","result","parseVersionCliVersionOutput","installedVersion","processOutput","fromImage","workspaceRoot","getFullyQualifiedRepoRootPath","relPath","path","relative","privileged","volumeArgs","volume","hostPath","flat","entryPoint","trim","envArgs","envVar","finalArgs","dockerArgs","saveAptosModulesOrder","exit","outputJson","json","modules","Result","item","fs","writeFileSync","JSON","stringify"],"mappings":"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","file":"CFMPNPDE.js","sourcesContent":["import fs from 'fs';\nimport path from 'path';\nimport process from 'process';\nimport type { ProcessOutput } from 'zx';\nimport { $ } from 'zx';\n\nimport { getFullyQualifiedRepoRootPath } from '@layerzerolabs/common-node-utils';\n\nimport { AWS_ACCOUNT_ID, AWS_REGION } from '../config';\nimport type { EnvironmentVariable, ToolingImageTargetName, Version, VolumeMapping } from '../types';\nimport { findMatrixByType, findToolByName, getToolType } from '../utils/finder-utils';\nimport { versionsSatisfied } from '../utils/version-utils';\nimport { extractUserVersions, resolveTypeVersions } from './version-resolver';\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 */\nfunction mergeVolumes(\n defaultVolumes: VolumeMapping[],\n userVolumes: VolumeMapping[],\n): VolumeMapping[] {\n const merged: VolumeMapping[] = [];\n const userPaths = new Set(userVolumes.map((v) => v.containerPath));\n\n // Add user volumes first (highest priority)\n merged.push(...userVolumes);\n\n // Add default volumes that don't conflict with user volumes\n for (const defaultVolume of defaultVolumes) {\n if (!userPaths.has(defaultVolume.containerPath)) {\n merged.push(defaultVolume);\n }\n }\n\n return merged;\n}\n\n/**\n * Get Docker image name and tag for a specific tool and version\n */\nfunction getImageName(\n target: ToolingImageTargetName,\n vmToolingName: string,\n version: string,\n): { imageURI: string; imageTag: string } {\n // const repository = 'ghcr.io/layerzero-labs';\n const repository = `${AWS_ACCOUNT_ID}.dkr.ecr.${AWS_REGION}.amazonaws.com/layerzerolabs`;\n const imageName = `${target}-tooling`;\n\n // Find the tool and its type\n const tool = findToolByName(vmToolingName);\n if (!tool) {\n throw new Error(`Tool '${vmToolingName}' not found`);\n }\n\n // Find the version matrix for this tool type\n const matrix = findMatrixByType(tool.toolType);\n if (!matrix) {\n throw new Error(`No version matrix found for tool type ${tool.toolType}`);\n }\n\n // Find a combination that includes this tool with the specified version\n let foundCombination = null;\n for (const combination of matrix.combinations) {\n const toolVersion = combination.versions[vmToolingName];\n if (toolVersion === version) {\n foundCombination = combination.versions;\n break;\n }\n }\n\n if (!foundCombination) {\n throw new Error(\n `No version combination found for tool ${vmToolingName} with version ${version}`,\n );\n }\n\n // Filter out undefined/empty values for tag generation\n const validVersions: { [key: string]: string } = {};\n for (const [toolName, toolVersion] of Object.entries(foundCombination)) {\n if (typeof toolVersion === 'string' && toolVersion.length > 0) {\n validVersions[toolName] = toolVersion;\n }\n }\n\n const imageTag = getCombinationTag(validVersions);\n const imageURI = `${repository}/${imageName}:${imageTag}`;\n\n return { imageURI, imageTag };\n}\n\n/**\n * Generate Docker image tag from version combination\n */\nfunction getCombinationTag(input: { [key: string]: string }): string {\n const tags = Object.entries(input)\n .map(([key, value]) => `${key}_${value}`)\n .sort((a, b) => a.localeCompare(b));\n\n return tags.join('_');\n}\n\n/**\n * Enhanced Docker image management with intelligent caching\n * Tries ECR first, falls back to local build if available, and caches locally\n */\nasync function ensureDockerImage(imageURI: string, imageTag: string): Promise<void> {\n try {\n // Check if image exists locally first\n const checkResult = await $`docker image ls ${imageURI}`.nothrow();\n\n if (checkResult.stdout.includes(imageTag)) {\n console.info(`✅ Using cached Docker image: ${imageURI}`);\n return;\n }\n\n // Try to pull from ECR\n console.info(`📥 Pulling Docker image from ECR: ${imageURI}`);\n const pullResult = await $`docker pull ${imageURI}`.nothrow();\n\n if (pullResult.exitCode === 0) {\n console.info(`✅ Successfully pulled: ${imageURI}`);\n return;\n }\n\n // If ECR pull fails, check for local fallback image\n const localImageName = imageURI.split('/').pop()?.replace(/:.*$/, '') || '';\n const localFallbackURI = `local-${localImageName}:latest`;\n\n const localCheckResult = await $`docker image ls ${localFallbackURI}`.nothrow();\n\n if (localCheckResult.stdout.includes('local-')) {\n console.info(`🏠 ECR image not available, using local fallback: ${localFallbackURI}`);\n\n // Tag the local image with the ECR URI for consistency\n await $`docker tag ${localFallbackURI} ${imageURI}`;\n console.info(`🏷️ Tagged local image as: ${imageURI}`);\n return;\n }\n\n // If all else fails, provide helpful error message\n throw new Error(\n `❌ Docker image not available:\\n` +\n ` - ECR image: ${imageURI} (pull failed)\\n` +\n ` - Local fallback: ${localFallbackURI} (not found)\\n` +\n `\\n💡 Solutions:\\n` +\n ` 1. Authenticate with ECR: aws ecr get-login-password --region ${AWS_REGION} | docker login --username AWS --password-stdin ${AWS_ACCOUNT_ID}.dkr.ecr.${AWS_REGION}.amazonaws.com\\n` +\n ` 2. Build local image: docker build -t ${localFallbackURI} <dockerfile-path>\\n` +\n ` 3. Check if the image tag exists in ECR`,\n );\n } catch (error) {\n if (error instanceof Error && error.message.includes('❌ Docker image not available')) {\n throw error;\n }\n throw new Error(\n `Failed to ensure Docker image ${imageURI}: ${error instanceof Error ? error.message : String(error)}`,\n );\n }\n}\n\n/**\n * Enhanced tool command execution using the new version compatibility matrix system\n */\nexport async function executeToolCommand(\n command: string,\n args: string[],\n options: {\n cwd: string;\n forceDocker: boolean;\n volumes: VolumeMapping[];\n customEntrypoint?: string;\n env: EnvironmentVariable[];\n script?: string;\n [key: string]: any;\n },\n): Promise<void> {\n const {\n cwd,\n forceDocker,\n volumes: userVolumes,\n customEntrypoint,\n env: customEnvVars,\n script,\n } = options;\n\n const tool = findToolByName(command);\n const type = getToolType(command);\n\n if (!tool || type === undefined) {\n const { tools } = await import('../config');\n const availableTools = tools.map((t) => t.name).join(', ');\n throw new Error(\n `❌ Tool '${command}' not found or no type configuration available.\\n` +\n `Available tools: ${availableTools}\\n` +\n `Try: lz-tool --list-versions to see all available tools`,\n );\n }\n\n // Merge default volumes with user-specified volumes\n const defaultVolumes = tool.defaultVolumes ?? [];\n const volumes = mergeVolumes(defaultVolumes, userVolumes);\n\n if (defaultVolumes.length > 0) {\n console.info(`📦 Using ${defaultVolumes.length} default cache volume(s) for ${command}`);\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 // Extract user-specified versions from command line options\n const userSpecifiedVersions = extractUserVersions(options);\n\n // Resolve versions for all tools in the type using compatibility matrix\n const versionResult = resolveTypeVersions(type, userSpecifiedVersions, options, cwd);\n\n // Display any warnings\n versionResult.warnings.forEach((warning) => {\n console.warn(warning);\n });\n\n // Get the resolved version for the current tool\n const resolvedVersion = versionResult.resolvedVersions[command];\n if (typeof resolvedVersion !== 'string' || resolvedVersion === '') {\n throw new Error(`No version resolved for tool ${command}`);\n }\n\n console.info(`🔧 ${command} version: ${resolvedVersion}`);\n\n // Check secondary version validation if available\n if (tool.getSecondaryVersionCheckValue) {\n try {\n const secondaryVersion = tool.getSecondaryVersionCheckValue({ cwd });\n const resolvedVersionObj: Version = { version: resolvedVersion };\n\n if (!versionsSatisfied(secondaryVersion, resolvedVersionObj)) {\n console.warn(\n `Warning: Local configuration version (${secondaryVersion.version}) differs from resolved version (${resolvedVersion})`,\n );\n }\n } catch (error) {\n // Secondary version check failed, but continue with resolved version\n console.warn(\n `Could not validate secondary version: ${error instanceof Error ? error.message : String(error)}`,\n );\n }\n }\n\n // Check if we should try to use local executable first\n let hasLocalExecutable = false;\n\n if (!forceDocker) {\n const versionFlags = tool.versionCliArguments ?? ['--version'];\n\n try {\n const result = await $`${command} ${versionFlags}`;\n\n // Use tool for parsing output\n if (tool.parseVersionCliVersionOutput) {\n const installedVersion = tool.parseVersionCliVersionOutput(result.stdout);\n const resolvedVersionObj: Version = { version: resolvedVersion };\n\n if (versionsSatisfied(installedVersion, resolvedVersionObj)) {\n hasLocalExecutable = true;\n console.info(`✅ Using local ${command} v${installedVersion.version}`);\n } else {\n console.info(\n `🐳 Local ${command} v${installedVersion.version} ≠ required v${resolvedVersion}, using Docker`,\n );\n }\n }\n } catch (error) {\n // Check if the command is not found (127 exit code)\n if (!(error instanceof Error) || !('exitCode' in error) || error.exitCode !== 127) {\n throw error;\n }\n console.info(`🐳 ${command} not found locally, using Docker`);\n }\n }\n\n let processOutput: ProcessOutput;\n\n if (hasLocalExecutable) {\n // Execute command directly\n processOutput = await $`${command} ${args}`.nothrow();\n } else {\n // Use Docker image with merged volumes\n const { imageTag, imageURI } = getImageName(tool.fromImage, tool.name, resolvedVersion);\n const workspaceRoot = await getFullyQualifiedRepoRootPath();\n const relPath = path.relative(workspaceRoot, cwd);\n const privileged = tool.privileged ?? false;\n\n // Enhanced Docker image caching logic\n await ensureDockerImage(imageURI, imageTag);\n\n const volumeArgs = volumes\n .map((volume) => {\n if (volume.type === 'host') {\n if (volume.hostPath === undefined) {\n throw new Error(`Host path is required for volume mapping of type 'host'`);\n }\n return ['-v', `${volume.hostPath}:${volume.containerPath}`];\n } else {\n if (volume.name === undefined) {\n throw new Error(`Name is required for volume mapping of type 'isolate'`);\n }\n return ['-v', `${volume.name}:${volume.containerPath}`];\n }\n })\n .flat(); // Flatten the array to get ['-v', 'vol1', '-v', 'vol2', ...]\n\n // Use custom entrypoint if provided, otherwise fall back to tool config or tool name\n const entryPoint = customEntrypoint ?? tool.entryPoint;\n\n if (customEntrypoint !== undefined && customEntrypoint.trim() !== '') {\n console.info(`🔧 Using custom entrypoint: ${customEntrypoint}`);\n }\n\n // Build the Docker command with proper argument separation\n const envArgs = customEnvVars\n .map((envVar) => ['-e', `${envVar.name}=${envVar.value}`])\n .flat();\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 !== undefined && 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 ...(privileged ? ['--privileged'] : []),\n '--rm',\n ...envArgs,\n '-v',\n `${workspaceRoot}:/workspace`,\n '-w',\n `/workspace/${relPath}`,\n ...volumeArgs,\n ...(entryPoint === undefined ? [] : ['--entrypoint', entryPoint]),\n imageURI,\n ...finalArgs,\n ];\n\n processOutput = await $`docker ${dockerArgs}`.nothrow();\n saveAptosModulesOrder(command, processOutput, workspaceRoot, relPath);\n }\n\n // Handle the process completion\n const { exitCode } = processOutput;\n if (exitCode !== 0) {\n process.exit(exitCode ?? 1);\n }\n}\n\nfunction saveAptosModulesOrder(\n command: string,\n processOutput: ProcessOutput,\n workspaceRoot: string,\n relPath: string,\n): void {\n if ('aptos' === command) {\n const outputJson: { Result: string[] } = processOutput.json();\n const modules = outputJson.Result.map((item: string) => `${item.split('::')[1]}.mv`);\n fs.writeFileSync(\n path.join(workspaceRoot, relPath, 'modules.json'),\n JSON.stringify(modules, null, 2),\n );\n }\n}\n"]}
@@ -1,5 +1,5 @@
1
- import { versionMatrices } from './YTUEW27V.js';
2
1
  import { findParentDirectoryWithFile } from './BA2LAHMY.js';
2
+ import { versionMatrices } from './5KA4B3WL.js';
3
3
  import { __name } from './VUOMXK5T.js';
4
4
  import fs from 'fs';
5
5
  import * as semver from 'semver';
@@ -66,18 +66,16 @@ var tools = [
66
66
  name: "hardhat",
67
67
  toolType: "evm",
68
68
  fromImage: "evm",
69
- entryPoint: "/usr/local/lib/node_modules/hardhat/internal/cli/bootstrap.js",
70
69
  defaultVolumes: [],
71
- parseVersionCliVersionOutput: /* @__PURE__ */ __name((output) => {
72
- console.log("output", output);
73
- return {
74
- version: "2.19.3"
75
- };
76
- }, "parseVersionCliVersionOutput"),
77
70
  versionCliArguments: [
78
71
  "--version"
79
72
  ]
80
73
  },
74
+ {
75
+ name: "forge",
76
+ toolType: "evm",
77
+ fromImage: "evm"
78
+ },
81
79
  {
82
80
  name: "anchor",
83
81
  toolType: "solana",
@@ -132,14 +130,12 @@ var tools = [
132
130
  {
133
131
  name: "blueprint",
134
132
  toolType: "ton",
135
- fromImage: "ton",
136
- defaultVolumes: []
133
+ fromImage: "ton"
137
134
  },
138
135
  {
139
136
  name: "scarb",
140
137
  toolType: "starknet",
141
- fromImage: "starknet",
142
- defaultVolumes: []
138
+ fromImage: "starknet"
143
139
  },
144
140
  {
145
141
  name: "sui",
@@ -202,8 +198,9 @@ function getToolDefaultVersion(toolName) {
202
198
  }
203
199
  const defaultCombination = findDefaultCombination(matrix);
204
200
  const defaultVersion = defaultCombination.versions[toolName];
205
- if (defaultVersion == null || defaultVersion.length === 0) {
206
- throw new Error(`No default version found for tool '${toolName}' in matrix`);
201
+ if (!defaultVersion?.length) {
202
+ console.warn(`No default version found for tool '${toolName}' in matrix`);
203
+ return null;
207
204
  }
208
205
  return defaultVersion;
209
206
  }
@@ -229,5 +226,5 @@ function getToolSupportedVersions(toolName) {
229
226
  __name(getToolSupportedVersions, "getToolSupportedVersions");
230
227
 
231
228
  export { AWS_ACCOUNT_ID, AWS_REGION, findDefaultCombination, findMatrixByType, findSemVersionFromString, findToolByName, findToolsByType, getToolDefaultVersion, getToolSupportedVersions, getToolType, parseAnchorTomlVersion, tools, validateToolVersion, versionsSatisfied };
232
- //# sourceMappingURL=SW6HQVVH.js.map
233
- //# sourceMappingURL=SW6HQVVH.js.map
229
+ //# sourceMappingURL=CRLXMIJF.js.map
230
+ //# sourceMappingURL=CRLXMIJF.js.map