varlock 0.0.12 → 0.0.13

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 (47) hide show
  1. package/dist/{chunk-52FLZJCQ.js → chunk-5EBVEGDW.js} +5 -24
  2. package/dist/chunk-5EBVEGDW.js.map +1 -0
  3. package/dist/{chunk-IBMSAOL6.js → chunk-AS4LIW7A.js} +21 -15
  4. package/dist/chunk-AS4LIW7A.js.map +1 -0
  5. package/dist/{chunk-2GR4YQFJ.js → chunk-IML4QZHB.js} +4 -5
  6. package/dist/chunk-IML4QZHB.js.map +1 -0
  7. package/dist/{chunk-MHDV65DI.js → chunk-LXJMZMID.js} +98 -66
  8. package/dist/chunk-LXJMZMID.js.map +1 -0
  9. package/dist/{chunk-NXAXPMO5.js → chunk-MV5ZAKN7.js} +483 -243
  10. package/dist/chunk-MV5ZAKN7.js.map +1 -0
  11. package/dist/{chunk-AMAUWR7O.js → chunk-MVYXWTAV.js} +4 -4
  12. package/dist/{chunk-AMAUWR7O.js.map → chunk-MVYXWTAV.js.map} +1 -1
  13. package/dist/{chunk-23GW4X5J.js → chunk-T3I4UFB2.js} +16 -5
  14. package/dist/chunk-T3I4UFB2.js.map +1 -0
  15. package/dist/{chunk-LBVGWRPL.js → chunk-UA3DMAAQ.js} +4 -4
  16. package/dist/{chunk-LBVGWRPL.js.map → chunk-UA3DMAAQ.js.map} +1 -1
  17. package/dist/cli/cli-executable.js +14 -15
  18. package/dist/cli/cli-executable.js.map +1 -1
  19. package/dist/{env-DxiD5Ylz.d.ts → env-B_LAqK4w.d.ts} +94 -63
  20. package/dist/index.d.ts +2 -3
  21. package/dist/index.js +2 -4
  22. package/dist/index.js.map +1 -1
  23. package/dist/init.command-CTO64XBL.js +8 -0
  24. package/dist/{init.command-ZSH7NCV7.js.map → init.command-CTO64XBL.js.map} +1 -1
  25. package/dist/load.command-EWIJDF55.js +8 -0
  26. package/dist/{load.command-U2GASZRB.js.map → load.command-EWIJDF55.js.map} +1 -1
  27. package/dist/login.command-UZJJ4XTV.js +8 -0
  28. package/dist/{login.command-2WG4GZV4.js.map → login.command-UZJJ4XTV.js.map} +1 -1
  29. package/dist/run.command-T44BAZ7X.js +8 -0
  30. package/dist/{run.command-IETNJ6UU.js.map → run.command-T44BAZ7X.js.map} +1 -1
  31. package/dist/runtime/env.d.ts +1 -1
  32. package/dist/telemetry.command-2C3MQA4K.js +8 -0
  33. package/dist/{telemetry.command-US72HXMS.js.map → telemetry.command-2C3MQA4K.js.map} +1 -1
  34. package/package.json +2 -2
  35. package/dist/chunk-23GW4X5J.js.map +0 -1
  36. package/dist/chunk-2GR4YQFJ.js.map +0 -1
  37. package/dist/chunk-52FLZJCQ.js.map +0 -1
  38. package/dist/chunk-IBMSAOL6.js.map +0 -1
  39. package/dist/chunk-MHDV65DI.js.map +0 -1
  40. package/dist/chunk-NXAXPMO5.js.map +0 -1
  41. package/dist/chunk-Y2EGAWAH.js +0 -17
  42. package/dist/chunk-Y2EGAWAH.js.map +0 -1
  43. package/dist/init.command-ZSH7NCV7.js +0 -9
  44. package/dist/load.command-U2GASZRB.js +0 -9
  45. package/dist/login.command-2WG4GZV4.js +0 -8
  46. package/dist/run.command-IETNJ6UU.js +0 -9
  47. package/dist/telemetry.command-US72HXMS.js +0 -8
@@ -1,6 +1,6 @@
1
- import { CliExitError, fmt } from './chunk-52FLZJCQ.js';
1
+ import { CliExitError, fmt } from './chunk-5EBVEGDW.js';
2
2
  import { define } from './chunk-33ROL4J5.js';
3
- import { gracefulExit } from './chunk-NXAXPMO5.js';
3
+ import { gracefulExit } from './chunk-MV5ZAKN7.js';
4
4
  import { __name } from './chunk-XN24GZXQ.js';
5
5
  import { homedir } from 'os';
6
6
  import { join } from 'path';
@@ -50,5 +50,5 @@ var commandFn = /* @__PURE__ */ __name(async (ctx) => {
50
50
  }, "commandFn");
51
51
 
52
52
  export { commandFn, commandSpec };
53
- //# sourceMappingURL=chunk-AMAUWR7O.js.map
54
- //# sourceMappingURL=chunk-AMAUWR7O.js.map
53
+ //# sourceMappingURL=chunk-MVYXWTAV.js.map
54
+ //# sourceMappingURL=chunk-MVYXWTAV.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/cli/commands/telemetry.command.ts"],"names":[],"mappings":";;;;;;;;;AAWO,IAAM,cAAc,MAAA,CAAO;AAAA,EAChC,IAAA,EAAM,WAAA;AAAA,EACN,WAAA,EAAa,0CAAA;AAAA,EACb,IAAA,EAAM;AAAA,IACJ,IAAA,EAAM;AAAA,MACJ,IAAA,EAAM,YAAA;AAAA,MACN,WAAA,EAAa;AAAA;AACf;AAEJ,CAAC;AAEM,IAAM,SAAA,iCAA6D,GAAA,KAAQ;AAEhF,EAAA,IAAI,CAAC,CAAC,QAAA,EAAU,SAAS,EAAE,QAAA,CAAS,GAAA,CAAI,MAAA,CAAO,IAAI,CAAA,EAAG;AACpD,IAAA,MAAM,IAAI,aAAa,8CAAA,EAAgD;AAAA,MACrE,SAAA,EAAW;AAAA,KACZ,CAAA;AAAA,EACH;AAEA,EAAA,MAAM,SAAA,GAAY,IAAA,CAAK,OAAA,EAAQ,EAAG,UAAU,CAAA;AAC5C,EAAA,MAAM,UAAA,GAAa,IAAA,CAAK,SAAA,EAAW,aAAa,CAAA;AAEhD,EAAA,IAAI;AAEF,IAAA,IAAI,CAAC,UAAA,CAAW,SAAS,CAAA,EAAG;AAC1B,MAAA,MAAM,KAAA,CAAM,SAAA,EAAW,EAAE,SAAA,EAAW,MAAM,CAAA;AAAA,IAC5C;AAGA,IAAA,IAAI,SAA8B,EAAC;AACnC,IAAA,IAAI,UAAA,CAAW,UAAU,CAAA,EAAG;AAC1B,MAAA,MAAM,aAAA,GAAgB,MAAM,QAAA,CAAS,UAAA,EAAY,OAAO,CAAA;AACxD,MAAA,MAAA,GAAS,IAAA,CAAK,MAAM,aAAa,CAAA;AAAA,IACnC;AAGA,IAAA,IAAI,GAAA,CAAI,MAAA,CAAO,IAAA,KAAS,SAAA,SAAkB,iBAAA,GAAoB,IAAA;AAAA,gBAClD,MAAA,CAAO,iBAAA;AACnB,IAAA,MAAM,UAAU,UAAA,EAAY,IAAA,CAAK,UAAU,MAAA,EAAQ,IAAA,EAAM,CAAC,CAAC,CAAA;AAE3D,IAAA,IAAI,GAAA,CAAI,OAAO,IAAA,EAAM;AACnB,MAAA,OAAA,CAAQ,IAAI,uDAAkD,CAAA;AAAA,IAChE,CAAA,MAAO;AACL,MAAA,OAAA,CAAQ,IAAI,wDAAmD,CAAA;AAAA,IACjE;AACA,IAAA,OAAA,CAAQ,GAAA,CAAI,aAAA,EAAe,GAAA,CAAI,QAAA,CAAS,UAAU,CAAC,CAAA;AAAA,EACrD,SAAS,KAAA,EAAO;AACd,IAAA,OAAA,CAAQ,KAAA,CAAM,mCAAmC,KAAK,CAAA;AACtD,IAAA,OAAO,aAAa,CAAC,CAAA;AAAA,EACvB;AACF,CAAA,EAvCmE,WAAA","file":"chunk-AMAUWR7O.js","sourcesContent":["import { homedir } from 'node:os';\nimport { join } from 'node:path';\nimport { mkdir, writeFile, readFile } from 'node:fs/promises';\nimport { existsSync } from 'node:fs';\nimport { define } from 'gunshi';\nimport { type TypedGunshiCommandFn } from '../helpers/gunshi-type-utils';\nimport { gracefulExit } from 'exit-hook';\nimport { fmt } from '../helpers/pretty-format';\nimport { CliExitError } from '../helpers/exit-error';\n\n\nexport const commandSpec = define({\n name: 'telemetry',\n description: 'Enable/disable anonymous usage analytics',\n args: {\n mode: {\n type: 'positional',\n description: '\"enable\" or \"disable\"',\n },\n },\n});\n\nexport const commandFn: TypedGunshiCommandFn<typeof commandSpec> = async (ctx) => {\n // TODO: remove this when gunshi supports types/validation for positional args\n if (!['enable', 'disable'].includes(ctx.values.mode)) {\n throw new CliExitError('additional arg must be \"enable\" or \"disable\"', {\n forceExit: true,\n });\n }\n\n const configDir = join(homedir(), '.varlock');\n const configPath = join(configDir, 'config.json');\n\n try {\n // Create .varlock directory if it doesn't exist\n if (!existsSync(configDir)) {\n await mkdir(configDir, { recursive: true });\n }\n\n // Read existing config if it exists\n let config: Record<string, any> = {};\n if (existsSync(configPath)) {\n const configContent = await readFile(configPath, 'utf-8');\n config = JSON.parse(configContent);\n }\n\n // update config `telemetryDisabled` setting\n if (ctx.values.mode === 'disable') config.telemetryDisabled = true;\n else delete config.telemetryDisabled;\n await writeFile(configPath, JSON.stringify(config, null, 2));\n\n if (ctx.values.mode) {\n console.log('✅ Successfully enabled anonymous usage analytics');\n } else {\n console.log('✅ Successfully disabled anonymous usage analytics');\n }\n console.log('> saved in:', fmt.filePath(configPath));\n } catch (error) {\n console.error('Failed to opt out of analytics:', error);\n return gracefulExit(1);\n }\n};\n"]}
1
+ {"version":3,"sources":["../src/cli/commands/telemetry.command.ts"],"names":[],"mappings":";;;;;;;;;AAWO,IAAM,cAAc,MAAA,CAAO;AAAA,EAChC,IAAA,EAAM,WAAA;AAAA,EACN,WAAA,EAAa,0CAAA;AAAA,EACb,IAAA,EAAM;AAAA,IACJ,IAAA,EAAM;AAAA,MACJ,IAAA,EAAM,YAAA;AAAA,MACN,WAAA,EAAa;AAAA;AACf;AAEJ,CAAC;AAEM,IAAM,SAAA,iCAA6D,GAAA,KAAQ;AAEhF,EAAA,IAAI,CAAC,CAAC,QAAA,EAAU,SAAS,EAAE,QAAA,CAAS,GAAA,CAAI,MAAA,CAAO,IAAI,CAAA,EAAG;AACpD,IAAA,MAAM,IAAI,aAAa,8CAAA,EAAgD;AAAA,MACrE,SAAA,EAAW;AAAA,KACZ,CAAA;AAAA,EACH;AAEA,EAAA,MAAM,SAAA,GAAY,IAAA,CAAK,OAAA,EAAQ,EAAG,UAAU,CAAA;AAC5C,EAAA,MAAM,UAAA,GAAa,IAAA,CAAK,SAAA,EAAW,aAAa,CAAA;AAEhD,EAAA,IAAI;AAEF,IAAA,IAAI,CAAC,UAAA,CAAW,SAAS,CAAA,EAAG;AAC1B,MAAA,MAAM,KAAA,CAAM,SAAA,EAAW,EAAE,SAAA,EAAW,MAAM,CAAA;AAAA,IAC5C;AAGA,IAAA,IAAI,SAA8B,EAAC;AACnC,IAAA,IAAI,UAAA,CAAW,UAAU,CAAA,EAAG;AAC1B,MAAA,MAAM,aAAA,GAAgB,MAAM,QAAA,CAAS,UAAA,EAAY,OAAO,CAAA;AACxD,MAAA,MAAA,GAAS,IAAA,CAAK,MAAM,aAAa,CAAA;AAAA,IACnC;AAGA,IAAA,IAAI,GAAA,CAAI,MAAA,CAAO,IAAA,KAAS,SAAA,SAAkB,iBAAA,GAAoB,IAAA;AAAA,gBAClD,MAAA,CAAO,iBAAA;AACnB,IAAA,MAAM,UAAU,UAAA,EAAY,IAAA,CAAK,UAAU,MAAA,EAAQ,IAAA,EAAM,CAAC,CAAC,CAAA;AAE3D,IAAA,IAAI,GAAA,CAAI,OAAO,IAAA,EAAM;AACnB,MAAA,OAAA,CAAQ,IAAI,uDAAkD,CAAA;AAAA,IAChE,CAAA,MAAO;AACL,MAAA,OAAA,CAAQ,IAAI,wDAAmD,CAAA;AAAA,IACjE;AACA,IAAA,OAAA,CAAQ,GAAA,CAAI,aAAA,EAAe,GAAA,CAAI,QAAA,CAAS,UAAU,CAAC,CAAA;AAAA,EACrD,SAAS,KAAA,EAAO;AACd,IAAA,OAAA,CAAQ,KAAA,CAAM,mCAAmC,KAAK,CAAA;AACtD,IAAA,OAAO,aAAa,CAAC,CAAA;AAAA,EACvB;AACF,CAAA,EAvCmE,WAAA","file":"chunk-MVYXWTAV.js","sourcesContent":["import { homedir } from 'node:os';\nimport { join } from 'node:path';\nimport { mkdir, writeFile, readFile } from 'node:fs/promises';\nimport { existsSync } from 'node:fs';\nimport { define } from 'gunshi';\nimport { type TypedGunshiCommandFn } from '../helpers/gunshi-type-utils';\nimport { gracefulExit } from 'exit-hook';\nimport { fmt } from '../helpers/pretty-format';\nimport { CliExitError } from '../helpers/exit-error';\n\n\nexport const commandSpec = define({\n name: 'telemetry',\n description: 'Enable/disable anonymous usage analytics',\n args: {\n mode: {\n type: 'positional',\n description: '\"enable\" or \"disable\"',\n },\n },\n});\n\nexport const commandFn: TypedGunshiCommandFn<typeof commandSpec> = async (ctx) => {\n // TODO: remove this when gunshi supports types/validation for positional args\n if (!['enable', 'disable'].includes(ctx.values.mode)) {\n throw new CliExitError('additional arg must be \"enable\" or \"disable\"', {\n forceExit: true,\n });\n }\n\n const configDir = join(homedir(), '.varlock');\n const configPath = join(configDir, 'config.json');\n\n try {\n // Create .varlock directory if it doesn't exist\n if (!existsSync(configDir)) {\n await mkdir(configDir, { recursive: true });\n }\n\n // Read existing config if it exists\n let config: Record<string, any> = {};\n if (existsSync(configPath)) {\n const configContent = await readFile(configPath, 'utf-8');\n config = JSON.parse(configContent);\n }\n\n // update config `telemetryDisabled` setting\n if (ctx.values.mode === 'disable') config.telemetryDisabled = true;\n else delete config.telemetryDisabled;\n await writeFile(configPath, JSON.stringify(config, null, 2));\n\n if (ctx.values.mode) {\n console.log('✅ Successfully enabled anonymous usage analytics');\n } else {\n console.log('✅ Successfully disabled anonymous usage analytics');\n }\n console.log('> saved in:', fmt.filePath(configPath));\n } catch (error) {\n console.error('Failed to opt out of analytics:', error);\n return gracefulExit(1);\n }\n};\n"]}
@@ -1,9 +1,9 @@
1
- import { ansis_default, gracefulExit, my_dash_default, getItemSummary, joinAndCompact } from './chunk-NXAXPMO5.js';
1
+ import { ansis_default, gracefulExit, my_dash_default, getItemSummary, joinAndCompact, loadEnvGraph } from './chunk-MV5ZAKN7.js';
2
2
  import { __name } from './chunk-XN24GZXQ.js';
3
3
 
4
4
  // src/cli/helpers/error-checks.ts
5
5
  function checkForSchemaErrors(envGraph) {
6
- for (const source of envGraph.dataSources) {
6
+ for (const source of envGraph.sortedDataSources) {
7
7
  if (source.loadingError) {
8
8
  console.log(`\u{1F6A8} Error encountered while loading ${source.label}`);
9
9
  console.log(source.loadingError.message);
@@ -64,6 +64,17 @@ function checkForConfigErrors(envGraph, opts) {
64
64
  }
65
65
  __name(checkForConfigErrors, "checkForConfigErrors");
66
66
 
67
- export { InvalidEnvError, checkForConfigErrors, checkForSchemaErrors };
68
- //# sourceMappingURL=chunk-23GW4X5J.js.map
69
- //# sourceMappingURL=chunk-23GW4X5J.js.map
67
+ // src/lib/load-graph.ts
68
+ async function loadVarlockEnvGraph(opts) {
69
+ const envGraph = await loadEnvGraph({
70
+ ...opts,
71
+ afterInit: /* @__PURE__ */ __name(async (_g) => {
72
+ }, "afterInit")
73
+ });
74
+ return envGraph;
75
+ }
76
+ __name(loadVarlockEnvGraph, "loadVarlockEnvGraph");
77
+
78
+ export { InvalidEnvError, checkForConfigErrors, checkForSchemaErrors, loadVarlockEnvGraph };
79
+ //# sourceMappingURL=chunk-T3I4UFB2.js.map
80
+ //# sourceMappingURL=chunk-T3I4UFB2.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/cli/helpers/error-checks.ts","../src/lib/load-graph.ts"],"names":[],"mappings":"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","file":"chunk-T3I4UFB2.js","sourcesContent":["import ansis from 'ansis';\nimport { EnvGraph, ConfigItem, EnvSourceParseError } from '../../../env-graph';\nimport _ from '@env-spec/utils/my-dash';\nimport { getItemSummary, joinAndCompact } from '../../lib/formatting';\nimport { gracefulExit } from 'exit-hook';\n\nexport function checkForSchemaErrors(envGraph: EnvGraph) {\n // first we check for loading/parse errors - some cases we may want to let it fail silently?\n for (const source of envGraph.sortedDataSources) {\n // do we care about loading errors from disabled sources?\n // if (source.disabled) continue;\n\n // console.log(source);\n\n // TODO: use a formatting helper to show the error - which will include location/stack/etc appropriately\n if (source.loadingError) {\n console.log(`🚨 Error encountered while loading ${source.label}`);\n console.log(source.loadingError.message);\n\n // Check if the error has a location property (like EnvSourceParseError)\n if ('location' in source.loadingError) {\n console.log((source.loadingError as EnvSourceParseError).location);\n\n const errLoc = (source.loadingError as EnvSourceParseError).location;\n\n const errPreview = [\n errLoc.lineStr,\n `${ansis.gray('-'.repeat(errLoc.colNumber - 1))}${ansis.red('^')}`,\n ].join('\\n');\n\n console.log('Error parsing .env file');\n console.log(` ${errLoc.path}:${errLoc.lineNumber}:${errLoc.colNumber}`);\n console.log(errPreview);\n }\n\n return gracefulExit(1);\n }\n }\n\n // now we check for any schema errors - where something about how things are wired up is invalid\n // NOTE - we should not have run any resolution yet\n // TODO: make sure we are calling this before attempting to resolve values\n // const failingItems = _.filter(_.values(envGraph.configSchema), (item) => item.validationState === 'error');\n // if (failingItems.length > 0) {\n // throw new CliExitError('Schema is currently invalid');\n // }\n}\n\nexport class InvalidEnvError extends Error {\n constructor() {\n super('Resolved config/env did not pass validation');\n }\n getFormattedOutput() {\n return `\\n💥 ${ansis.red(this.message)} 💥\\n`;\n }\n}\n\nexport function checkForConfigErrors(envGraph: EnvGraph, opts?: {\n showAll?: boolean\n}) {\n const failingItems = _.filter(_.values(envGraph.configSchema), (item: ConfigItem) => item.validationState === 'error');\n\n // TODO: use service.isValid?\n if (failingItems.length > 0) {\n console.log(`\\n🚨 🚨 🚨 ${ansis.bold.underline('Configuration is currently invalid ')} 🚨 🚨 🚨\\n`);\n console.log('Invalid items:\\n');\n\n _.each(failingItems, (item: ConfigItem) => {\n console.log(getItemSummary(item));\n console.log();\n });\n if (opts?.showAll) {\n console.log();\n console.log(joinAndCompact([\n 'Valid items:',\n ansis.italic.gray('(remove `--show-all` flag to hide)'),\n ]));\n console.log();\n const validItems = _.filter(_.values(envGraph.configSchema), (i: ConfigItem) => !!i.isValid);\n _.each(validItems, (item: ConfigItem) => {\n console.log(getItemSummary(item));\n });\n }\n\n throw new InvalidEnvError();\n }\n}\n","import { loadEnvGraph } from '../../env-graph';\n\nexport async function loadVarlockEnvGraph(opts?: {\n currentEnvFallback?: string,\n}) {\n const envGraph = await loadEnvGraph({\n ...opts,\n afterInit: async (_g) => {\n // TODO: register varlock resolver\n },\n });\n\n return envGraph;\n}\n"]}
@@ -1,6 +1,6 @@
1
- import { logLines } from './chunk-52FLZJCQ.js';
1
+ import { logLines } from './chunk-5EBVEGDW.js';
2
2
  import { define } from './chunk-33ROL4J5.js';
3
- import { gracefulExit, ansis_default } from './chunk-NXAXPMO5.js';
3
+ import { gracefulExit, ansis_default } from './chunk-MV5ZAKN7.js';
4
4
  import { __name } from './chunk-XN24GZXQ.js';
5
5
  import { setTimeout } from 'timers/promises';
6
6
  import os from 'os';
@@ -142,5 +142,5 @@ var commandFn = /* @__PURE__ */ __name(async (ctx) => {
142
142
  }, "commandFn");
143
143
 
144
144
  export { CONFIG, commandFn, commandSpec };
145
- //# sourceMappingURL=chunk-LBVGWRPL.js.map
146
- //# sourceMappingURL=chunk-LBVGWRPL.js.map
145
+ //# sourceMappingURL=chunk-UA3DMAAQ.js.map
146
+ //# sourceMappingURL=chunk-UA3DMAAQ.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/config.ts","../src/cli/helpers/open-url.ts","../src/cli/helpers/key-press.ts","../src/cli/commands/login.command.ts"],"names":["delay"],"mappings":"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","file":"chunk-LBVGWRPL.js","sourcesContent":["// TODO: figure out dev vs prod env vars... would be great to use varlock here!\n\n// NOTE - these keys are safe to publish\n\nexport const CONFIG = {\n // VARLOCK_API_URL: 'http://localhost:8888',\n VARLOCK_API_URL: 'https://api.varlock.dev',\n GITHUB_APP_CLIENT_ID: 'Iv23li50gB8bMxLauiJQ', // varlock.dev app\n POSTHOG_API_KEY: 'phc_bfzH97VIta8yQa8HrsgmitqS6rTydjMISs0m8aqJTnq',\n POSTHOG_HOST: 'https://ph.varlock.dev',\n};\n","import os from 'node:os';\nimport { spawn } from 'node:child_process';\n\nconst platform = os.platform();\n\nconst isWindows = platform.match(/^win/i);\nconst isMac = platform.match(/^darwin/i);\nconst isLinux = (!isWindows && !isMac);\n\n/** opens a url using the default browser */\nexport function openUrl(url: string) {\n if (isWindows) {\n spawn('cmd', ['/c', 'start', ' ', url], { detached: true });\n } else if (isMac) {\n spawn('open', [url], { detached: true });\n } else if (isLinux) {\n // TODO: maybe check for x-www-browser instead?\n spawn('xdg-open', [url], { detached: true });\n }\n}\n","import { gracefulExit } from 'exit-hook';\n\nexport async function keyPressed(keys: Array<string> | true = true) {\n process.stdin.setRawMode(true);\n return new Promise<void>((resolve) => {\n function keyPressHandler(d: Buffer) {\n const keyStr = d.toString();\n // exit on ctrl+c or ctrl+d\n if (['\\u0003', '\\u0004'].includes(keyStr)) {\n return gracefulExit(1);\n }\n if (keys === true || keys.includes(keyStr)) {\n process.stdin.setRawMode(false);\n process.stdin.off('data', keyPressHandler);\n resolve();\n }\n }\n process.stdin.on('data', keyPressHandler);\n });\n}\n","\nimport { setTimeout as delay } from 'node:timers/promises';\nimport ansis from 'ansis';\nimport { define } from 'gunshi';\nimport { logLines } from '../helpers/pretty-format';\nimport { CONFIG } from '../../config';\nimport { openUrl } from '../helpers/open-url';\nimport { keyPressed } from '../helpers/key-press';\nimport { type TypedGunshiCommandFn } from '../helpers/gunshi-type-utils';\nimport { gracefulExit } from 'exit-hook';\n\n\nexport const commandSpec = define({\n name: 'login',\n description: 'Authenticate (using GitHub)',\n args: {},\n});\n\n\nexport const commandFn: TypedGunshiCommandFn<typeof commandSpec> = async (ctx) => {\n const codeReq = await fetch('https://github.com/login/device/code', {\n method: 'POST',\n body: JSON.stringify({\n client_id: CONFIG.GITHUB_APP_CLIENT_ID,\n }),\n headers: {\n 'Content-Type': 'application/json',\n Accept: 'application/json',\n },\n });\n if (codeReq.status !== 200) {\n console.log('Failed to initiate GitHub device flow login!');\n return gracefulExit(1);\n }\n\n const ghCodeInfo = await codeReq.json() as {\n device_code: string;\n user_code: string;\n verification_uri: string;\n expires_in: number;\n interval: number;\n };\n\n logLines([\n '🔑 Authenticating using GitHub:',\n '',\n `First please copy this code: ${ansis.bold.magenta(ghCodeInfo.user_code)}`,\n '',\n `Log in @ ${ghCodeInfo.verification_uri}`,\n '',\n 'Press ENTER to open in your default browser...',\n ]);\n await keyPressed(['\\r']);\n console.log(ansis.italic.gray('... please complete login on github.com ...'));\n openUrl(ghCodeInfo.verification_uri);\n\n const pollMs = ghCodeInfo.interval * 1000;\n const expiresMs = ghCodeInfo.expires_in * 1000;\n const startAt = new Date();\n\n let oauthStatus: any;\n while (true) {\n await delay(pollMs);\n try {\n const oauthStatusReq = await fetch('https://github.com/login/oauth/access_token', {\n method: 'POST',\n body: JSON.stringify({\n client_id: CONFIG.GITHUB_APP_CLIENT_ID,\n device_code: ghCodeInfo.device_code,\n grant_type: 'urn:ietf:params:oauth:grant-type:device_code',\n }),\n headers: {\n 'Content-Type': 'application/json',\n Accept: 'application/json',\n },\n });\n oauthStatus = await oauthStatusReq.json();\n } catch (err) {\n console.log(err);\n }\n\n // we are expecting to see { error: 'authorization_pending' }\n // probably a few more error types we could bail early on\n if (oauthStatus.error === 'access_denied') {\n console.log('❌ Login attempt was cancelled! Please try again.');\n return gracefulExit(1);\n }\n\n // if we got the token, we break and continue\n if (oauthStatus.access_token) break;\n\n // if we've been polling for too long, give up\n if (new Date().getTime() - startAt.getTime() > expiresMs) {\n console.log('❌ Login timed out! Please try again.');\n return gracefulExit(1);\n }\n }\n\n // oauthStatus when completed looks like:\n // {\n // access_token: 'ghu_abcxyz',\n // expires_in: 28800,\n // refresh_token: 'ghr_abcxyz',\n // refresh_token_expires_in: 15897600,\n // token_type: 'bearer',\n // scope: ''\n // }\n\n // pass along github auth info to API, which will fetch info from HG, handle login/signup, return JWT\n const authReq = await fetch(`${CONFIG.VARLOCK_API_URL}/github/auth-from-device-flow`, {\n method: 'POST',\n body: JSON.stringify({\n accessToken: oauthStatus.access_token,\n refreshToken: oauthStatus.refresh_token,\n accessTokenExpiresAt: new Date(Date.now() + oauthStatus.expires_in * 1000).toISOString(),\n refreshTokenExpiresAt: new Date(Date.now() + oauthStatus.refresh_token_expires_in * 1000).toISOString(),\n tokenType: oauthStatus.token_type,\n scope: oauthStatus.scope,\n }),\n headers: {\n 'Content-Type': 'application/json',\n Accept: 'application/json',\n },\n });\n if (authReq.status !== 200) {\n console.log(await authReq.json());\n return gracefulExit(1);\n }\n\n const authRes = await authReq.json() as {\n user: {\n githubUserId: string;\n githubUsername: string;\n name: string;\n },\n token: string;\n isNewUser: boolean;\n publicKey?: string;\n };\n\n // TODO: if app exists, pass off login info to it instead of storing in home folder\n // otherwise save login info in ~/.varlock/identity.json\n // also save it along with a new keypair if necessary, and send the public key to the api\n\n console.log(`✅ Logged in as ${authRes.user.githubUsername} (${authRes.user.name})!`);\n};\n"]}
1
+ {"version":3,"sources":["../src/config.ts","../src/cli/helpers/open-url.ts","../src/cli/helpers/key-press.ts","../src/cli/commands/login.command.ts"],"names":["delay"],"mappings":";;;;;;;;;AAIO,IAAM,MAAA,GAAS;AAAA;AAAA,EAEpB,eAAA,EAAiB,yBAAA;AAAA,EACjB,oBAAA,EAAsB,sBAAA;AAAA;AAAA,EACtB,eAAA,EAAiB,iDAAA;AAAA,EACjB,YAAA,EAAc;AAChB;ACPA,IAAM,QAAA,GAAW,GAAG,QAAA,EAAS;AAE7B,IAAM,SAAA,GAAY,QAAA,CAAS,KAAA,CAAM,OAAO,CAAA;AACxC,IAAM,KAAA,GAAQ,QAAA,CAAS,KAAA,CAAM,UAAU,CAAA;AACvC,IAAM,OAAA,GAAW,CAAC,SAAA,IAAa,CAAC,KAAA;AAGzB,SAAS,QAAQ,GAAA,EAAa;AACnC,EAAA,IAAI,SAAA,EAAW;AACb,IAAA,KAAA,CAAM,KAAA,EAAO,CAAC,IAAA,EAAM,OAAA,EAAS,GAAA,EAAK,GAAG,CAAA,EAAG,EAAE,QAAA,EAAU,IAAA,EAAM,CAAA;AAAA,EAC5D,WAAW,KAAA,EAAO;AAChB,IAAA,KAAA,CAAM,QAAQ,CAAC,GAAG,GAAG,EAAE,QAAA,EAAU,MAAM,CAAA;AAAA,EACzC,WAAW,OAAA,EAAS;AAElB,IAAA,KAAA,CAAM,YAAY,CAAC,GAAG,GAAG,EAAE,QAAA,EAAU,MAAM,CAAA;AAAA,EAC7C;AACF;AATgB,MAAA,CAAA,OAAA,EAAA,SAAA,CAAA;;;ACRhB,eAAsB,UAAA,CAAW,OAA6B,IAAA,EAAM;AAClE,EAAA,OAAA,CAAQ,KAAA,CAAM,WAAW,IAAI,CAAA;AAC7B,EAAA,OAAO,IAAI,OAAA,CAAc,CAAC,OAAA,KAAY;AACpC,IAAA,SAAS,gBAAgB,CAAA,EAAW;AAClC,MAAA,MAAM,MAAA,GAAS,EAAE,QAAA,EAAS;AAE1B,MAAA,IAAI,CAAC,GAAA,EAAU,GAAQ,CAAA,CAAE,QAAA,CAAS,MAAM,CAAA,EAAG;AACzC,QAAA,OAAO,aAAa,CAAC,CAAA;AAAA,MACvB;AACA,MAAA,IAAI,IAAA,KAAS,IAAA,IAAQ,IAAA,CAAK,QAAA,CAAS,MAAM,CAAA,EAAG;AAC1C,QAAA,OAAA,CAAQ,KAAA,CAAM,WAAW,KAAK,CAAA;AAC9B,QAAA,OAAA,CAAQ,KAAA,CAAM,GAAA,CAAI,MAAA,EAAQ,eAAe,CAAA;AACzC,QAAA,OAAA,EAAQ;AAAA,MACV;AAAA,IACF;AAXS,IAAA,MAAA,CAAA,eAAA,EAAA,iBAAA,CAAA;AAYT,IAAA,OAAA,CAAQ,KAAA,CAAM,EAAA,CAAG,MAAA,EAAQ,eAAe,CAAA;AAAA,EAC1C,CAAC,CAAA;AACH;AAjBsB,MAAA,CAAA,UAAA,EAAA,YAAA,CAAA;;;ACUf,IAAM,cAAc,MAAA,CAAO;AAAA,EAChC,IAAA,EAAM,OAAA;AAAA,EACN,WAAA,EAAa,6BAAA;AAAA,EACb,MAAM;AACR,CAAC;AAGM,IAAM,SAAA,iCAA6D,GAAA,KAAQ;AAChF,EAAA,MAAM,OAAA,GAAU,MAAM,KAAA,CAAM,sCAAA,EAAwC;AAAA,IAClE,MAAA,EAAQ,MAAA;AAAA,IACR,IAAA,EAAM,KAAK,SAAA,CAAU;AAAA,MACnB,WAAW,MAAA,CAAO;AAAA,KACnB,CAAA;AAAA,IACD,OAAA,EAAS;AAAA,MACP,cAAA,EAAgB,kBAAA;AAAA,MAChB,MAAA,EAAQ;AAAA;AACV,GACD,CAAA;AACD,EAAA,IAAI,OAAA,CAAQ,WAAW,GAAA,EAAK;AAC1B,IAAA,OAAA,CAAQ,IAAI,8CAA8C,CAAA;AAC1D,IAAA,OAAO,aAAa,CAAC,CAAA;AAAA,EACvB;AAEA,EAAA,MAAM,UAAA,GAAa,MAAM,OAAA,CAAQ,IAAA,EAAK;AAQtC,EAAA,QAAA,CAAS;AAAA,IACP,wCAAA;AAAA,IACA,EAAA;AAAA,IACA,gCAAgC,aAAA,CAAM,IAAA,CAAK,OAAA,CAAQ,UAAA,CAAW,SAAS,CAAC,CAAA,CAAA;AAAA,IACxE,EAAA;AAAA,IACA,CAAA,SAAA,EAAY,WAAW,gBAAgB,CAAA,CAAA;AAAA,IACvC,EAAA;AAAA,IACA;AAAA,GACD,CAAA;AACD,EAAA,MAAM,UAAA,CAAW,CAAC,IAAI,CAAC,CAAA;AACvB,EAAA,OAAA,CAAQ,GAAA,CAAI,aAAA,CAAM,MAAA,CAAO,IAAA,CAAK,6CAA6C,CAAC,CAAA;AAC5E,EAAA,OAAA,CAAQ,WAAW,gBAAgB,CAAA;AAEnC,EAAA,MAAM,MAAA,GAAS,WAAW,QAAA,GAAW,GAAA;AACrC,EAAA,MAAM,SAAA,GAAY,WAAW,UAAA,GAAa,GAAA;AAC1C,EAAA,MAAM,OAAA,uBAAc,IAAA,EAAK;AAEzB,EAAA,IAAI,WAAA;AACJ,EAAA,OAAO,IAAA,EAAM;AACX,IAAA,MAAMA,WAAM,MAAM,CAAA;AAClB,IAAA,IAAI;AACF,MAAA,MAAM,cAAA,GAAiB,MAAM,KAAA,CAAM,6CAAA,EAA+C;AAAA,QAChF,MAAA,EAAQ,MAAA;AAAA,QACR,IAAA,EAAM,KAAK,SAAA,CAAU;AAAA,UACnB,WAAW,MAAA,CAAO,oBAAA;AAAA,UAClB,aAAa,UAAA,CAAW,WAAA;AAAA,UACxB,UAAA,EAAY;AAAA,SACb,CAAA;AAAA,QACD,OAAA,EAAS;AAAA,UACP,cAAA,EAAgB,kBAAA;AAAA,UAChB,MAAA,EAAQ;AAAA;AACV,OACD,CAAA;AACD,MAAA,WAAA,GAAc,MAAM,eAAe,IAAA,EAAK;AAAA,IAC1C,SAAS,GAAA,EAAK;AACZ,MAAA,OAAA,CAAQ,IAAI,GAAG,CAAA;AAAA,IACjB;AAIA,IAAA,IAAI,WAAA,CAAY,UAAU,eAAA,EAAiB;AACzC,MAAA,OAAA,CAAQ,IAAI,uDAAkD,CAAA;AAC9D,MAAA,OAAO,aAAa,CAAC,CAAA;AAAA,IACvB;AAGA,IAAA,IAAI,YAAY,YAAA,EAAc;AAG9B,IAAA,IAAA,iBAAI,IAAI,MAAK,EAAE,OAAA,KAAY,OAAA,CAAQ,OAAA,KAAY,SAAA,EAAW;AACxD,MAAA,OAAA,CAAQ,IAAI,2CAAsC,CAAA;AAClD,MAAA,OAAO,aAAa,CAAC,CAAA;AAAA,IACvB;AAAA,EACF;AAaA,EAAA,MAAM,UAAU,MAAM,KAAA,CAAM,CAAA,EAAG,MAAA,CAAO,eAAe,CAAA,6BAAA,CAAA,EAAiC;AAAA,IACpF,MAAA,EAAQ,MAAA;AAAA,IACR,IAAA,EAAM,KAAK,SAAA,CAAU;AAAA,MACnB,aAAa,WAAA,CAAY,YAAA;AAAA,MACzB,cAAc,WAAA,CAAY,aAAA;AAAA,MAC1B,oBAAA,EAAsB,IAAI,IAAA,CAAK,IAAA,CAAK,GAAA,KAAQ,WAAA,CAAY,UAAA,GAAa,GAAI,CAAA,CAAE,WAAA,EAAY;AAAA,MACvF,qBAAA,EAAuB,IAAI,IAAA,CAAK,IAAA,CAAK,GAAA,KAAQ,WAAA,CAAY,wBAAA,GAA2B,GAAI,CAAA,CAAE,WAAA,EAAY;AAAA,MACtG,WAAW,WAAA,CAAY,UAAA;AAAA,MACvB,OAAO,WAAA,CAAY;AAAA,KACpB,CAAA;AAAA,IACD,OAAA,EAAS;AAAA,MACP,cAAA,EAAgB,kBAAA;AAAA,MAChB,MAAA,EAAQ;AAAA;AACV,GACD,CAAA;AACD,EAAA,IAAI,OAAA,CAAQ,WAAW,GAAA,EAAK;AAC1B,IAAA,OAAA,CAAQ,GAAA,CAAI,MAAM,OAAA,CAAQ,IAAA,EAAM,CAAA;AAChC,IAAA,OAAO,aAAa,CAAC,CAAA;AAAA,EACvB;AAEA,EAAA,MAAM,OAAA,GAAU,MAAM,OAAA,CAAQ,IAAA,EAAK;AAenC,EAAA,OAAA,CAAQ,GAAA,CAAI,uBAAkB,OAAA,CAAQ,IAAA,CAAK,cAAc,CAAA,EAAA,EAAK,OAAA,CAAQ,IAAA,CAAK,IAAI,CAAA,EAAA,CAAI,CAAA;AACrF,CAAA,EA9HmE,WAAA","file":"chunk-UA3DMAAQ.js","sourcesContent":["// TODO: figure out dev vs prod env vars... would be great to use varlock here!\n\n// NOTE - these keys are safe to publish\n\nexport const CONFIG = {\n // VARLOCK_API_URL: 'http://localhost:8888',\n VARLOCK_API_URL: 'https://api.varlock.dev',\n GITHUB_APP_CLIENT_ID: 'Iv23li50gB8bMxLauiJQ', // varlock.dev app\n POSTHOG_API_KEY: 'phc_bfzH97VIta8yQa8HrsgmitqS6rTydjMISs0m8aqJTnq',\n POSTHOG_HOST: 'https://ph.varlock.dev',\n};\n","import os from 'node:os';\nimport { spawn } from 'node:child_process';\n\nconst platform = os.platform();\n\nconst isWindows = platform.match(/^win/i);\nconst isMac = platform.match(/^darwin/i);\nconst isLinux = (!isWindows && !isMac);\n\n/** opens a url using the default browser */\nexport function openUrl(url: string) {\n if (isWindows) {\n spawn('cmd', ['/c', 'start', ' ', url], { detached: true });\n } else if (isMac) {\n spawn('open', [url], { detached: true });\n } else if (isLinux) {\n // TODO: maybe check for x-www-browser instead?\n spawn('xdg-open', [url], { detached: true });\n }\n}\n","import { gracefulExit } from 'exit-hook';\n\nexport async function keyPressed(keys: Array<string> | true = true) {\n process.stdin.setRawMode(true);\n return new Promise<void>((resolve) => {\n function keyPressHandler(d: Buffer) {\n const keyStr = d.toString();\n // exit on ctrl+c or ctrl+d\n if (['\\u0003', '\\u0004'].includes(keyStr)) {\n return gracefulExit(1);\n }\n if (keys === true || keys.includes(keyStr)) {\n process.stdin.setRawMode(false);\n process.stdin.off('data', keyPressHandler);\n resolve();\n }\n }\n process.stdin.on('data', keyPressHandler);\n });\n}\n","\nimport { setTimeout as delay } from 'node:timers/promises';\nimport ansis from 'ansis';\nimport { define } from 'gunshi';\nimport { logLines } from '../helpers/pretty-format';\nimport { CONFIG } from '../../config';\nimport { openUrl } from '../helpers/open-url';\nimport { keyPressed } from '../helpers/key-press';\nimport { type TypedGunshiCommandFn } from '../helpers/gunshi-type-utils';\nimport { gracefulExit } from 'exit-hook';\n\n\nexport const commandSpec = define({\n name: 'login',\n description: 'Authenticate (using GitHub)',\n args: {},\n});\n\n\nexport const commandFn: TypedGunshiCommandFn<typeof commandSpec> = async (ctx) => {\n const codeReq = await fetch('https://github.com/login/device/code', {\n method: 'POST',\n body: JSON.stringify({\n client_id: CONFIG.GITHUB_APP_CLIENT_ID,\n }),\n headers: {\n 'Content-Type': 'application/json',\n Accept: 'application/json',\n },\n });\n if (codeReq.status !== 200) {\n console.log('Failed to initiate GitHub device flow login!');\n return gracefulExit(1);\n }\n\n const ghCodeInfo = await codeReq.json() as {\n device_code: string;\n user_code: string;\n verification_uri: string;\n expires_in: number;\n interval: number;\n };\n\n logLines([\n '🔑 Authenticating using GitHub:',\n '',\n `First please copy this code: ${ansis.bold.magenta(ghCodeInfo.user_code)}`,\n '',\n `Log in @ ${ghCodeInfo.verification_uri}`,\n '',\n 'Press ENTER to open in your default browser...',\n ]);\n await keyPressed(['\\r']);\n console.log(ansis.italic.gray('... please complete login on github.com ...'));\n openUrl(ghCodeInfo.verification_uri);\n\n const pollMs = ghCodeInfo.interval * 1000;\n const expiresMs = ghCodeInfo.expires_in * 1000;\n const startAt = new Date();\n\n let oauthStatus: any;\n while (true) {\n await delay(pollMs);\n try {\n const oauthStatusReq = await fetch('https://github.com/login/oauth/access_token', {\n method: 'POST',\n body: JSON.stringify({\n client_id: CONFIG.GITHUB_APP_CLIENT_ID,\n device_code: ghCodeInfo.device_code,\n grant_type: 'urn:ietf:params:oauth:grant-type:device_code',\n }),\n headers: {\n 'Content-Type': 'application/json',\n Accept: 'application/json',\n },\n });\n oauthStatus = await oauthStatusReq.json();\n } catch (err) {\n console.log(err);\n }\n\n // we are expecting to see { error: 'authorization_pending' }\n // probably a few more error types we could bail early on\n if (oauthStatus.error === 'access_denied') {\n console.log('❌ Login attempt was cancelled! Please try again.');\n return gracefulExit(1);\n }\n\n // if we got the token, we break and continue\n if (oauthStatus.access_token) break;\n\n // if we've been polling for too long, give up\n if (new Date().getTime() - startAt.getTime() > expiresMs) {\n console.log('❌ Login timed out! Please try again.');\n return gracefulExit(1);\n }\n }\n\n // oauthStatus when completed looks like:\n // {\n // access_token: 'ghu_abcxyz',\n // expires_in: 28800,\n // refresh_token: 'ghr_abcxyz',\n // refresh_token_expires_in: 15897600,\n // token_type: 'bearer',\n // scope: ''\n // }\n\n // pass along github auth info to API, which will fetch info from HG, handle login/signup, return JWT\n const authReq = await fetch(`${CONFIG.VARLOCK_API_URL}/github/auth-from-device-flow`, {\n method: 'POST',\n body: JSON.stringify({\n accessToken: oauthStatus.access_token,\n refreshToken: oauthStatus.refresh_token,\n accessTokenExpiresAt: new Date(Date.now() + oauthStatus.expires_in * 1000).toISOString(),\n refreshTokenExpiresAt: new Date(Date.now() + oauthStatus.refresh_token_expires_in * 1000).toISOString(),\n tokenType: oauthStatus.token_type,\n scope: oauthStatus.scope,\n }),\n headers: {\n 'Content-Type': 'application/json',\n Accept: 'application/json',\n },\n });\n if (authReq.status !== 200) {\n console.log(await authReq.json());\n return gracefulExit(1);\n }\n\n const authRes = await authReq.json() as {\n user: {\n githubUserId: string;\n githubUsername: string;\n name: string;\n },\n token: string;\n isNewUser: boolean;\n publicKey?: string;\n };\n\n // TODO: if app exists, pass off login info to it instead of storing in home folder\n // otherwise save login info in ~/.varlock/identity.json\n // also save it along with a new keypair if necessary, and send the public key to the api\n\n console.log(`✅ Logged in as ${authRes.user.githubUsername} (${authRes.user.name})!`);\n};\n"]}
@@ -1,14 +1,13 @@
1
- import { commandSpec } from '../chunk-MHDV65DI.js';
2
- import { commandSpec as commandSpec$1 } from '../chunk-IBMSAOL6.js';
3
- import { commandSpec as commandSpec$2 } from '../chunk-2GR4YQFJ.js';
1
+ import { commandSpec } from '../chunk-LXJMZMID.js';
2
+ import { commandSpec as commandSpec$1 } from '../chunk-AS4LIW7A.js';
3
+ import { commandSpec as commandSpec$2 } from '../chunk-IML4QZHB.js';
4
4
  import { commandSpec as commandSpec$3 } from '../chunk-RZT65DRA.js';
5
- import { commandSpec as commandSpec$4 } from '../chunk-AMAUWR7O.js';
6
- import { CONFIG, commandSpec as commandSpec$5 } from '../chunk-LBVGWRPL.js';
7
- import { CliExitError, fmt } from '../chunk-52FLZJCQ.js';
5
+ import { commandSpec as commandSpec$4 } from '../chunk-MVYXWTAV.js';
6
+ import { CONFIG, commandSpec as commandSpec$5 } from '../chunk-UA3DMAAQ.js';
7
+ import { CliExitError, fmt } from '../chunk-5EBVEGDW.js';
8
8
  import { cli } from '../chunk-33ROL4J5.js';
9
- import { InvalidEnvError } from '../chunk-23GW4X5J.js';
10
- import '../chunk-Y2EGAWAH.js';
11
- import { ansis_default, gracefulExit, EnvSourceParseError, asyncExitHook } from '../chunk-NXAXPMO5.js';
9
+ import { InvalidEnvError } from '../chunk-T3I4UFB2.js';
10
+ import { ansis_default, gracefulExit, EnvSourceParseError, asyncExitHook } from '../chunk-MV5ZAKN7.js';
12
11
  import '../chunk-FGMXIEFA.js';
13
12
  import { __commonJS, __name, __toESM } from '../chunk-XN24GZXQ.js';
14
13
  import os2 from 'os';
@@ -539,7 +538,7 @@ var is_wsl_default = process2.env.__IS_WSL_TEST__ ? isWsl : isWsl();
539
538
 
540
539
  // package.json
541
540
  var package_default = {
542
- version: "0.0.12"};
541
+ version: "0.0.13"};
543
542
 
544
543
  // src/cli/helpers/telemetry.ts
545
544
  var debug = Debug("varlock:telemetry");
@@ -724,12 +723,12 @@ function buildLazyCommand(commandSpec7, loadCommandFn) {
724
723
  }
725
724
  __name(buildLazyCommand, "buildLazyCommand");
726
725
  var subCommands = /* @__PURE__ */ new Map();
727
- subCommands.set("init", buildLazyCommand(commandSpec, async () => await import('../init.command-ZSH7NCV7.js')));
728
- subCommands.set("load", buildLazyCommand(commandSpec$1, async () => await import('../load.command-U2GASZRB.js')));
729
- subCommands.set("run", buildLazyCommand(commandSpec$2, async () => await import('../run.command-IETNJ6UU.js')));
726
+ subCommands.set("init", buildLazyCommand(commandSpec, async () => await import('../init.command-CTO64XBL.js')));
727
+ subCommands.set("load", buildLazyCommand(commandSpec$1, async () => await import('../load.command-EWIJDF55.js')));
728
+ subCommands.set("run", buildLazyCommand(commandSpec$2, async () => await import('../run.command-T44BAZ7X.js')));
730
729
  subCommands.set("help", buildLazyCommand(commandSpec$3, async () => await import('../help.command-B7VWA53B.js')));
731
- subCommands.set("telemetry", buildLazyCommand(commandSpec$4, async () => await import('../telemetry.command-US72HXMS.js')));
732
- subCommands.set("login", buildLazyCommand(commandSpec$5, async () => await import('../login.command-2WG4GZV4.js')));
730
+ subCommands.set("telemetry", buildLazyCommand(commandSpec$4, async () => await import('../telemetry.command-2C3MQA4K.js')));
731
+ subCommands.set("login", buildLazyCommand(commandSpec$5, async () => await import('../login.command-UZJJ4XTV.js')));
733
732
  (/* @__PURE__ */ __name(async function go() {
734
733
  try {
735
734
  let args = process.argv.slice(2);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../node_modules/.pnpm/ci-info@4.3.0/node_modules/ci-info/vendors.json","../../../../node_modules/.pnpm/ci-info@4.3.0/node_modules/ci-info/index.js","../../src/lib/ascii-art.ts","../../src/cli/helpers/telemetry.ts","../../../../node_modules/.pnpm/is-docker@3.0.0/node_modules/is-docker/index.js","../../../../node_modules/.pnpm/is-inside-container@1.0.0/node_modules/is-inside-container/index.js","../../../../node_modules/.pnpm/is-wsl@3.1.0/node_modules/is-wsl/index.js","../../package.json","../../src/cli/cli-executable.ts"],"names":["isCI","fs","process","os","ciName","commandSpec"],"mappings":"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","file":"cli-executable.js","sourcesContent":["[\n {\n \"name\": \"Agola CI\",\n \"constant\": \"AGOLA\",\n \"env\": \"AGOLA_GIT_REF\",\n \"pr\": \"AGOLA_PULL_REQUEST_ID\"\n },\n {\n \"name\": \"Appcircle\",\n \"constant\": \"APPCIRCLE\",\n \"env\": \"AC_APPCIRCLE\",\n \"pr\": {\n \"env\": \"AC_GIT_PR\",\n \"ne\": \"false\"\n }\n },\n {\n \"name\": \"AppVeyor\",\n \"constant\": \"APPVEYOR\",\n \"env\": \"APPVEYOR\",\n \"pr\": \"APPVEYOR_PULL_REQUEST_NUMBER\"\n },\n {\n \"name\": \"AWS CodeBuild\",\n \"constant\": \"CODEBUILD\",\n \"env\": \"CODEBUILD_BUILD_ARN\",\n \"pr\": {\n \"env\": \"CODEBUILD_WEBHOOK_EVENT\",\n \"any\": [\n \"PULL_REQUEST_CREATED\",\n \"PULL_REQUEST_UPDATED\",\n \"PULL_REQUEST_REOPENED\"\n ]\n }\n },\n {\n \"name\": \"Azure Pipelines\",\n \"constant\": \"AZURE_PIPELINES\",\n \"env\": \"TF_BUILD\",\n \"pr\": {\n \"BUILD_REASON\": \"PullRequest\"\n }\n },\n {\n \"name\": \"Bamboo\",\n \"constant\": \"BAMBOO\",\n \"env\": \"bamboo_planKey\"\n },\n {\n \"name\": \"Bitbucket Pipelines\",\n \"constant\": \"BITBUCKET\",\n \"env\": \"BITBUCKET_COMMIT\",\n \"pr\": \"BITBUCKET_PR_ID\"\n },\n {\n \"name\": \"Bitrise\",\n \"constant\": \"BITRISE\",\n \"env\": \"BITRISE_IO\",\n \"pr\": \"BITRISE_PULL_REQUEST\"\n },\n {\n \"name\": \"Buddy\",\n \"constant\": \"BUDDY\",\n \"env\": \"BUDDY_WORKSPACE_ID\",\n \"pr\": \"BUDDY_EXECUTION_PULL_REQUEST_ID\"\n },\n {\n \"name\": \"Buildkite\",\n \"constant\": \"BUILDKITE\",\n \"env\": \"BUILDKITE\",\n \"pr\": {\n \"env\": \"BUILDKITE_PULL_REQUEST\",\n \"ne\": \"false\"\n }\n },\n {\n \"name\": \"CircleCI\",\n \"constant\": \"CIRCLE\",\n \"env\": \"CIRCLECI\",\n \"pr\": \"CIRCLE_PULL_REQUEST\"\n },\n {\n \"name\": \"Cirrus CI\",\n \"constant\": \"CIRRUS\",\n \"env\": \"CIRRUS_CI\",\n \"pr\": \"CIRRUS_PR\"\n },\n {\n \"name\": \"Cloudflare Pages\",\n \"constant\": \"CLOUDFLARE_PAGES\",\n \"env\": \"CF_PAGES\"\n },\n {\n \"name\": \"Cloudflare Workers\",\n \"constant\": \"CLOUDFLARE_WORKERS\",\n \"env\": \"WORKERS_CI\"\n },\n {\n \"name\": \"Codefresh\",\n \"constant\": \"CODEFRESH\",\n \"env\": \"CF_BUILD_ID\",\n \"pr\": {\n \"any\": [\n \"CF_PULL_REQUEST_NUMBER\",\n \"CF_PULL_REQUEST_ID\"\n ]\n }\n },\n {\n \"name\": \"Codemagic\",\n \"constant\": \"CODEMAGIC\",\n \"env\": \"CM_BUILD_ID\",\n \"pr\": \"CM_PULL_REQUEST\"\n },\n {\n \"name\": \"Codeship\",\n \"constant\": \"CODESHIP\",\n \"env\": {\n \"CI_NAME\": \"codeship\"\n }\n },\n {\n \"name\": \"Drone\",\n \"constant\": \"DRONE\",\n \"env\": \"DRONE\",\n \"pr\": {\n \"DRONE_BUILD_EVENT\": \"pull_request\"\n }\n },\n {\n \"name\": \"dsari\",\n \"constant\": \"DSARI\",\n \"env\": \"DSARI\"\n },\n {\n \"name\": \"Earthly\",\n \"constant\": \"EARTHLY\",\n \"env\": \"EARTHLY_CI\"\n },\n {\n \"name\": \"Expo Application Services\",\n \"constant\": \"EAS\",\n \"env\": \"EAS_BUILD\"\n },\n {\n \"name\": \"Gerrit\",\n \"constant\": \"GERRIT\",\n \"env\": \"GERRIT_PROJECT\"\n },\n {\n \"name\": \"Gitea Actions\",\n \"constant\": \"GITEA_ACTIONS\",\n \"env\": \"GITEA_ACTIONS\"\n },\n {\n \"name\": \"GitHub Actions\",\n \"constant\": \"GITHUB_ACTIONS\",\n \"env\": \"GITHUB_ACTIONS\",\n \"pr\": {\n \"GITHUB_EVENT_NAME\": \"pull_request\"\n }\n },\n {\n \"name\": \"GitLab CI\",\n \"constant\": \"GITLAB\",\n \"env\": \"GITLAB_CI\",\n \"pr\": \"CI_MERGE_REQUEST_ID\"\n },\n {\n \"name\": \"GoCD\",\n \"constant\": \"GOCD\",\n \"env\": \"GO_PIPELINE_LABEL\"\n },\n {\n \"name\": \"Google Cloud Build\",\n \"constant\": \"GOOGLE_CLOUD_BUILD\",\n \"env\": \"BUILDER_OUTPUT\"\n },\n {\n \"name\": \"Harness CI\",\n \"constant\": \"HARNESS\",\n \"env\": \"HARNESS_BUILD_ID\"\n },\n {\n \"name\": \"Heroku\",\n \"constant\": \"HEROKU\",\n \"env\": {\n \"env\": \"NODE\",\n \"includes\": \"/app/.heroku/node/bin/node\"\n }\n },\n {\n \"name\": \"Hudson\",\n \"constant\": \"HUDSON\",\n \"env\": \"HUDSON_URL\"\n },\n {\n \"name\": \"Jenkins\",\n \"constant\": \"JENKINS\",\n \"env\": [\n \"JENKINS_URL\",\n \"BUILD_ID\"\n ],\n \"pr\": {\n \"any\": [\n \"ghprbPullId\",\n \"CHANGE_ID\"\n ]\n }\n },\n {\n \"name\": \"LayerCI\",\n \"constant\": \"LAYERCI\",\n \"env\": \"LAYERCI\",\n \"pr\": \"LAYERCI_PULL_REQUEST\"\n },\n {\n \"name\": \"Magnum CI\",\n \"constant\": \"MAGNUM\",\n \"env\": \"MAGNUM\"\n },\n {\n \"name\": \"Netlify CI\",\n \"constant\": \"NETLIFY\",\n \"env\": \"NETLIFY\",\n \"pr\": {\n \"env\": \"PULL_REQUEST\",\n \"ne\": \"false\"\n }\n },\n {\n \"name\": \"Nevercode\",\n \"constant\": \"NEVERCODE\",\n \"env\": \"NEVERCODE\",\n \"pr\": {\n \"env\": \"NEVERCODE_PULL_REQUEST\",\n \"ne\": \"false\"\n }\n },\n {\n \"name\": \"Prow\",\n \"constant\": \"PROW\",\n \"env\": \"PROW_JOB_ID\"\n },\n {\n \"name\": \"ReleaseHub\",\n \"constant\": \"RELEASEHUB\",\n \"env\": \"RELEASE_BUILD_ID\"\n },\n {\n \"name\": \"Render\",\n \"constant\": \"RENDER\",\n \"env\": \"RENDER\",\n \"pr\": {\n \"IS_PULL_REQUEST\": \"true\"\n }\n },\n {\n \"name\": \"Sail CI\",\n \"constant\": \"SAIL\",\n \"env\": \"SAILCI\",\n \"pr\": \"SAIL_PULL_REQUEST_NUMBER\"\n },\n {\n \"name\": \"Screwdriver\",\n \"constant\": \"SCREWDRIVER\",\n \"env\": \"SCREWDRIVER\",\n \"pr\": {\n \"env\": \"SD_PULL_REQUEST\",\n \"ne\": \"false\"\n }\n },\n {\n \"name\": \"Semaphore\",\n \"constant\": \"SEMAPHORE\",\n \"env\": \"SEMAPHORE\",\n \"pr\": \"PULL_REQUEST_NUMBER\"\n },\n {\n \"name\": \"Sourcehut\",\n \"constant\": \"SOURCEHUT\",\n \"env\": {\n \"CI_NAME\": \"sourcehut\"\n }\n },\n {\n \"name\": \"Strider CD\",\n \"constant\": \"STRIDER\",\n \"env\": \"STRIDER\"\n },\n {\n \"name\": \"TaskCluster\",\n \"constant\": \"TASKCLUSTER\",\n \"env\": [\n \"TASK_ID\",\n \"RUN_ID\"\n ]\n },\n {\n \"name\": \"TeamCity\",\n \"constant\": \"TEAMCITY\",\n \"env\": \"TEAMCITY_VERSION\"\n },\n {\n \"name\": \"Travis CI\",\n \"constant\": \"TRAVIS\",\n \"env\": \"TRAVIS\",\n \"pr\": {\n \"env\": \"TRAVIS_PULL_REQUEST\",\n \"ne\": \"false\"\n }\n },\n {\n \"name\": \"Vela\",\n \"constant\": \"VELA\",\n \"env\": \"VELA\",\n \"pr\": {\n \"VELA_PULL_REQUEST\": \"1\"\n }\n },\n {\n \"name\": \"Vercel\",\n \"constant\": \"VERCEL\",\n \"env\": {\n \"any\": [\n \"NOW_BUILDER\",\n \"VERCEL\"\n ]\n },\n \"pr\": \"VERCEL_GIT_PULL_REQUEST_ID\"\n },\n {\n \"name\": \"Visual Studio App Center\",\n \"constant\": \"APPCENTER\",\n \"env\": \"APPCENTER_BUILD_ID\"\n },\n {\n \"name\": \"Woodpecker\",\n \"constant\": \"WOODPECKER\",\n \"env\": {\n \"CI\": \"woodpecker\"\n },\n \"pr\": {\n \"CI_BUILD_EVENT\": \"pull_request\"\n }\n },\n {\n \"name\": \"Xcode Cloud\",\n \"constant\": \"XCODE_CLOUD\",\n \"env\": \"CI_XCODE_PROJECT\",\n \"pr\": \"CI_PULL_REQUEST_NUMBER\"\n },\n {\n \"name\": \"Xcode Server\",\n \"constant\": \"XCODE_SERVER\",\n \"env\": \"XCS\"\n }\n]\n","'use strict'\n\nconst vendors = require('./vendors.json')\n\nconst env = process.env\n\n// Used for testing only\nObject.defineProperty(exports, '_vendors', {\n value: vendors.map(function (v) {\n return v.constant\n })\n})\n\nexports.name = null\nexports.isPR = null\nexports.id = null\n\nvendors.forEach(function (vendor) {\n const envs = Array.isArray(vendor.env) ? vendor.env : [vendor.env]\n const isCI = envs.every(function (obj) {\n return checkEnv(obj)\n })\n\n exports[vendor.constant] = isCI\n\n if (!isCI) {\n return\n }\n\n exports.name = vendor.name\n exports.isPR = checkPR(vendor)\n exports.id = vendor.constant\n})\n\nexports.isCI = !!(\n env.CI !== 'false' && // Bypass all checks if CI env is explicitly set to 'false'\n (env.BUILD_ID || // Jenkins, Cloudbees\n env.BUILD_NUMBER || // Jenkins, TeamCity\n env.CI || // Travis CI, CircleCI, Cirrus CI, Gitlab CI, Appveyor, CodeShip, dsari, Cloudflare Pages/Workers\n env.CI_APP_ID || // Appflow\n env.CI_BUILD_ID || // Appflow\n env.CI_BUILD_NUMBER || // Appflow\n env.CI_NAME || // Codeship and others\n env.CONTINUOUS_INTEGRATION || // Travis CI, Cirrus CI\n env.RUN_ID || // TaskCluster, dsari\n exports.name ||\n false)\n)\n\nfunction checkEnv (obj) {\n // \"env\": \"CIRRUS\"\n if (typeof obj === 'string') return !!env[obj]\n\n // \"env\": { \"env\": \"NODE\", \"includes\": \"/app/.heroku/node/bin/node\" }\n if ('env' in obj) {\n // Currently there are no other types, uncomment when there are\n // if ('includes' in obj) {\n return env[obj.env] && env[obj.env].includes(obj.includes)\n // }\n }\n\n if ('any' in obj) {\n return obj.any.some(function (k) {\n return !!env[k]\n })\n }\n\n return Object.keys(obj).every(function (k) {\n return env[k] === obj[k]\n })\n}\n\nfunction checkPR (vendor) {\n switch (typeof vendor.pr) {\n case 'string':\n // \"pr\": \"CIRRUS_PR\"\n return !!env[vendor.pr]\n case 'object':\n if ('env' in vendor.pr) {\n if ('any' in vendor.pr) {\n // \"pr\": { \"env\": \"CODEBUILD_WEBHOOK_EVENT\", \"any\": [\"PULL_REQUEST_CREATED\", \"PULL_REQUEST_UPDATED\"] }\n return vendor.pr.any.some(function (key) {\n return env[vendor.pr.env] === key\n })\n } else {\n // \"pr\": { \"env\": \"BUILDKITE_PULL_REQUEST\", \"ne\": \"false\" }\n return vendor.pr.env in env && env[vendor.pr.env] !== vendor.pr.ne\n }\n } else if ('any' in vendor.pr) {\n // \"pr\": { \"any\": [\"ghprbPullId\", \"CHANGE_ID\"] }\n return vendor.pr.any.some(function (key) {\n return !!env[key]\n })\n } else {\n // \"pr\": { \"DRONE_BUILD_EVENT\": \"pull_request\" }\n return checkEnv(vendor.pr)\n }\n default:\n // PR detection not supported for this vendor\n return null\n }\n}\n","import ansis from 'ansis';\n\nexport const VARLOCK_BANNER2 = [\n ' ▄ ██ █▄▄▄▄ █ ████▄ ▄█▄ █ █▀ ',\n ' █ █ █ █ ▄▀ █ █ █ █▀ ▀▄ █▄█ ',\n '█ █ █▄▄█ █▀▀▌ █ █ █ █ ▀ █▀▄ ',\n ' █ █ █ █ █ █ ███▄ ▀████ █▄ ▄▀ █ █ ',\n ' █ █ █ █ ▀ ▀███▀ █ ',\n ' █▐ █ ▀ ▀ ',\n ' ▐ ▀ ',\n].join('\\n');\n\nexport const VARLOCK_BANNER = [\n '',\n ' ██▒ █▓ ▄▄▄ ██▀███ ██▓ ▒█████ ▄████▄ ██ ▄█▀',\n ' ▓██░ █▒▒████▄ ▓██ ▒ ██▒▓██▒ ▒██▒ ██▒▒██▀ ▀█ ██▄█▒ ',\n ' ▓██ █▒░▒██ ▀█▄ ▓██ ░▄█ ▒▒██░ ▒██░ ██▒▒██ ▄ ▓███▄░ ',\n ' ▒██ █░░░██▄▄▄▄██ ▒██▀▀█▄ ▒██░ ▒██ ██░▒██▄ ▄██▒▓██ █▄ ',\n ' ▒▀█░ ▓█ ▓██▒░██▓ ▒██▒░██████▒░ █████▒░▒ ████▀ ░▒██▒ █▄',\n ' ░ ▐░ ▒▒ ▓▒█░░ ▒▓ ░▒▓░░ ▒░▓ ░░ ▒░▒░▒░ ░ ░▒ ▒ ░▒ ▒▒ ▓▒',\n ' ░ ░░ ▒ ▒▒ ░ ░▒ ░ ▒░░ ░ ▒ ░ ░ ▒ ▒░ ░ ▒ ░ ░▒ ▒░',\n ' ░░ ░ ▒ ░░ ░ ░ ░ ░ ░ ░ ▒ ░ ░ ░░ ░ ',\n ' ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ',\n // ' ░ ░ ',\n].join('\\n');\n\n\nexport const FIRE = [\n ' ▚▐▟ ',\n '▗▗█▓▓█ ',\n '▟█▓░▓█▙',\n '▜█░▒░█▛',\n ' ▜▓░▓▛ ',\n ' ▀▀▀ ',\n].join('\\n');\n\n// const SOLID_BLOCK_CHARS = '▀▁▂▃▄▅▆▇█▉▊▋▌▍▎▏▐▔▕▖▗▘▙▚▛▜▝▞▟';\n// const LIGHT_BLOCK_CHARS = '░▒▓';\n\nexport const VARLOCK_BANNER_COLOR = VARLOCK_BANNER\n .replaceAll(/([▀▁▂▃▄▅▆▇█▉▊▋▌▍▎▏▐▔▕▖▗▘▙▚▛▜▝▞▟]+)/g, (m) => ansis.hex('#DD0000')(m))\n .replaceAll(/([▓░▒]+)/g, (m) => ansis.blue(m));\n\n\n","import os from 'node:os';\nimport crypto, { type BinaryLike, createHash } from 'node:crypto';\nimport { join } from 'node:path';\nimport {\n existsSync, readFileSync, writeFileSync,\n mkdirSync,\n} from 'node:fs';\nimport { asyncExitHook } from 'exit-hook';\nimport Debug from 'debug';\nimport { name as ciName, isCI } from 'ci-info';\nimport isDocker from 'is-docker';\nimport isWSL from 'is-wsl';\n\n\nimport packageJson from '../../../package.json';\n\nimport { CONFIG } from '../../config';\n\n\nconst debug = Debug('varlock:telemetry');\n\nconst TRUE_ENV_VAR_VALUES = ['true', '1', 't'];\n\nconst varlockConfigDirPath = join(os.homedir(), '.varlock');\nconst varlockConfigFilePath = join(varlockConfigDirPath, 'config.json');\nlet varlockConfigFileContents: Record<string, any> | undefined;\nfunction getConfigFileContents() {\n if (varlockConfigFileContents) return varlockConfigFileContents;\n try {\n const configContent = readFileSync(varlockConfigFilePath, 'utf-8');\n varlockConfigFileContents = JSON.parse(configContent);\n return varlockConfigFileContents;\n } catch (error) {\n debug('Failed to read varlock config:', error);\n return {};\n }\n}\n\n// we will identify users using a random UUID stored in the `~/.varlock/config.json` file\nlet cachedAnonymousId: string | undefined;\nfunction getAnonymousId() {\n if (cachedAnonymousId) return cachedAnonymousId;\n\n const configFileContents = getConfigFileContents();\n if (configFileContents?.anonymousId) {\n cachedAnonymousId = configFileContents.anonymousId;\n return configFileContents.anonymousId;\n }\n\n const newAnonymousId = `${isCI ? 'ci-' : ''}${crypto.randomUUID()}`;\n\n if (!existsSync(varlockConfigDirPath)) {\n mkdirSync(varlockConfigDirPath, { recursive: true });\n }\n\n writeFileSync(\n varlockConfigFilePath,\n JSON.stringify({\n ...configFileContents,\n anonymousId: newAnonymousId,\n }, null, 2),\n { flag: 'w' },\n );\n cachedAnonymousId = newAnonymousId;\n return newAnonymousId;\n}\n\n\nfunction checkIsOptedOut() {\n // Check if this is a dev build, rather than a published npm package or standalone binary\n if (__VARLOCK_BUILD_TYPE__ === 'dev') {\n debug('telemetry opted out - dev build');\n return true;\n }\n\n // Check environment variable\n if (\n process.env.PH_OPT_OUT === 'true' // legacy\n || TRUE_ENV_VAR_VALUES.includes((process.env.VARLOCK_TELEMETRY_DISABLED || '').toLowerCase())\n ) {\n debug('telemetry opted out - env var');\n return true;\n }\n\n // Check config file\n const varlockConfigFile = getConfigFileContents();\n if (varlockConfigFile?.analytics_opt_out || varlockConfigFile?.telemetryDisabled) {\n debug('telemetry opted out - config file');\n return true;\n }\n return false;\n}\n\n\n\nfunction anonymizeValue(payload: BinaryLike): string {\n // We use empty string to represent an empty value. Avoid hashing this\n // since that would create a real hash and remove its \"empty\" meaning.\n if (payload === '') {\n return payload;\n }\n // Otherwise, create a new hash from the payload and return it.\n const hash = createHash('sha256');\n hash.update(payload);\n return hash.digest('hex');\n}\n\nfunction getProjectGitRemoteUrl(): string | undefined {\n try {\n // Find the git directory by scanning upwards\n let gitDirPath: string | undefined;\n let currentDir = process.cwd();\n while (currentDir && currentDir !== '/') {\n const possibleGitDirPath = join(currentDir, '.git');\n if (existsSync(possibleGitDirPath)) {\n gitDirPath = possibleGitDirPath;\n break;\n }\n currentDir = join(currentDir, '..');\n }\n if (!gitDirPath) return undefined;\n const gitConfigContents = readFileSync(join(gitDirPath, 'config'), 'utf-8');\n // first look for upstream\n const remoteUpstreamPos = gitConfigContents.indexOf('[remote \"upstream\"]');\n if (remoteUpstreamPos !== -1) {\n const remoteUpstreamUrl = gitConfigContents.slice(remoteUpstreamPos).match(/url = (.+)/)?.[1];\n return remoteUpstreamUrl;\n }\n // otherwise fallback to origin\n const remoteOriginPos = gitConfigContents.indexOf('[remote \"origin\"]');\n if (remoteOriginPos === -1) return undefined;\n const remoteOriginUrl = gitConfigContents.slice(remoteOriginPos).match(/url = (.+)/)?.[1];\n return remoteOriginUrl;\n } catch (err) {\n return undefined;\n }\n}\nfunction getAnonymousProjectId() {\n // we want a project ID tied to the git repo, so we can group telemetry data by project\n // we could use the first commit hash, but this is more costly to compute, as we either need to rely\n // on the git cli and execSync, or we need to parse the git objects directly\n // so for now, we'll use the git remote URL (upstream if it exists, or origin)\n const gitRemoteUrl = getProjectGitRemoteUrl();\n if (!gitRemoteUrl) return null;\n return anonymizeValue(gitRemoteUrl);\n}\n\n\ntype TelemetryMeta = {\n // project info\n anonymous_project_id: string | null;\n // version information\n node_version: string;\n varlock_version: string;\n // OS information\n system_platform: string;\n system_release: string;\n system_architecture: string;\n // Machine information\n cpu_count: number,\n cpu_model: string | null,\n cpu_speed: number | null,\n memory_mb: number,\n // Environment information\n is_docker: boolean,\n is_tty: boolean,\n is_wsl: boolean,\n is_ci: boolean,\n ci_name: string | null,\n is_sea: boolean,\n};\n\nlet cachedTelemetryMetadata: TelemetryMeta | undefined;\nfunction getTelemetryMeta() {\n if (cachedTelemetryMetadata) return cachedTelemetryMetadata;\n\n const cpus = os.cpus() || [];\n\n let versionIdentifier = packageJson.version;\n // TODO: for preview builds, it would be nice to track which preview it is (PR number or commit hash)\n if (__VARLOCK_BUILD_TYPE__ !== 'release') versionIdentifier += `-${__VARLOCK_BUILD_TYPE__}`;\n\n cachedTelemetryMetadata = {\n anonymous_project_id: getAnonymousProjectId(),\n node_version: process.version.replace(/^v?/, ''),\n varlock_version: versionIdentifier,\n // TODO: pass through version info for specific integrations/plugins?\n system_platform: os.platform(),\n system_release: os.release(),\n system_architecture: os.arch(),\n cpu_count: cpus.length,\n cpu_model: cpus.length ? cpus[0].model : null,\n cpu_speed: cpus.length ? cpus[0].speed : null,\n memory_mb: Math.trunc(os.totalmem() / 1024 ** 2),\n is_docker: isDocker(),\n is_tty: process.stdout.isTTY,\n is_wsl: isWSL,\n is_ci: isCI,\n ci_name: ciName,\n is_sea: __VARLOCK_SEA_BUILD__,\n };\n return cachedTelemetryMetadata;\n}\n\n\nconst isOptedOut = checkIsOptedOut();\n\nlet lastTelemetryReq: Promise<any> | undefined;\n\nasync function posthogCapture(event: string, properties?: Record<string, any>) {\n const telemetryMeta = getTelemetryMeta();\n const payload = {\n api_key: CONFIG.POSTHOG_API_KEY,\n event,\n properties: {\n $process_person_profile: false,\n ...telemetryMeta,\n ...properties,\n },\n distinct_id: getAnonymousId(),\n };\n\n debug(`track${isOptedOut ? ' (disabled)' : ''}`, payload);\n\n if (isOptedOut) return;\n\n // add exit hook, so we can give the request a little time to finish\n const removeExitHook = asyncExitHook(async () => {\n // will still exit if the timeout is met, but will finish early if the request completes\n await lastTelemetryReq;\n }, { wait: 500 });\n\n // Make the fetch call\n lastTelemetryReq = fetch(`${CONFIG.POSTHOG_HOST}/i/v0/e/`, {\n method: 'POST',\n body: JSON.stringify(payload),\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n .then((res) => {\n if (!res.ok) throw new Error(`HTTP error! status: ${res.status}`);\n return res.text();\n })\n .then((text) => debug('telemetry response:', text))\n .catch((error) => {\n debug('telemetry error:', error);\n })\n .finally(() => {\n removeExitHook();\n });\n}\n\n\n\nexport async function trackCommand(command: string, properties?: Record<string, any>) {\n await posthogCapture('cli_command_executed', {\n command,\n ...properties,\n });\n}\n\nexport async function trackInstall(source: 'brew' | 'curl') {\n await posthogCapture('cli_install', {\n source,\n });\n}\n\n","import fs from 'node:fs';\n\nlet isDockerCached;\n\nfunction hasDockerEnv() {\n\ttry {\n\t\tfs.statSync('/.dockerenv');\n\t\treturn true;\n\t} catch {\n\t\treturn false;\n\t}\n}\n\nfunction hasDockerCGroup() {\n\ttry {\n\t\treturn fs.readFileSync('/proc/self/cgroup', 'utf8').includes('docker');\n\t} catch {\n\t\treturn false;\n\t}\n}\n\nexport default function isDocker() {\n\t// TODO: Use `??=` when targeting Node.js 16.\n\tif (isDockerCached === undefined) {\n\t\tisDockerCached = hasDockerEnv() || hasDockerCGroup();\n\t}\n\n\treturn isDockerCached;\n}\n","import fs from 'node:fs';\nimport isDocker from 'is-docker';\n\nlet cachedResult;\n\n// Podman detection\nconst hasContainerEnv = () => {\n\ttry {\n\t\tfs.statSync('/run/.containerenv');\n\t\treturn true;\n\t} catch {\n\t\treturn false;\n\t}\n};\n\nexport default function isInsideContainer() {\n\t// TODO: Use `??=` when targeting Node.js 16.\n\tif (cachedResult === undefined) {\n\t\tcachedResult = hasContainerEnv() || isDocker();\n\t}\n\n\treturn cachedResult;\n}\n","import process from 'node:process';\nimport os from 'node:os';\nimport fs from 'node:fs';\nimport isInsideContainer from 'is-inside-container';\n\nconst isWsl = () => {\n\tif (process.platform !== 'linux') {\n\t\treturn false;\n\t}\n\n\tif (os.release().toLowerCase().includes('microsoft')) {\n\t\tif (isInsideContainer()) {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t}\n\n\ttry {\n\t\treturn fs.readFileSync('/proc/version', 'utf8').toLowerCase().includes('microsoft')\n\t\t\t? !isInsideContainer() : false;\n\t} catch {\n\t\treturn false;\n\t}\n};\n\nexport default process.env.__IS_WSL_TEST__ ? isWsl : isWsl();\n","{\n \"name\": \"varlock\",\n \"version\": \"0.0.12\",\n \"description\": \"\",\n \"main\": \"index.js\",\n \"type\": \"module\",\n \"author\": \"dmno-dev\",\n \"license\": \"MIT\",\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/dmno-dev/varlock.git\",\n \"directory\": \"packages/varlock\"\n },\n \"scripts\": {\n \"build\": \"tsup\",\n \"build:sea\": \"tsup --config tsup-sea.config.ts\",\n \"dev\": \"tsup\",\n \"test\": \"vitest\",\n \"lint\": \"eslint .\",\n \"lint:fix\": \"pnpm run lint --fix\"\n },\n \"keywords\": [],\n \"files\": [\n \"/bin\",\n \"/dist\"\n ],\n \"bin\": {\n \"varlock\": \"./bin/cli.js\"\n },\n \"engines\": {\n \"node\": \">=22\"\n },\n \"exports\": {\n \".\": {\n \"ts-src\": \"./src/index.ts\",\n \"types\": \"./dist/index.d.ts\",\n \"default\": \"./dist/index.js\"\n },\n \"./env\": {\n \"ts-src\": \"./src/runtime/env.ts\",\n \"types\": \"./dist/runtime/env.d.ts\",\n \"default\": \"./dist/runtime/env.js\"\n },\n \"./auto-load\": {\n \"ts-src\": \"./src/auto-load.ts\",\n \"types\": \"./dist/auto-load.d.ts\",\n \"default\": \"./dist/auto-load.js\"\n },\n \"./patch-console\": {\n \"ts-src\": \"./src/runtime/patch-console.ts\",\n \"types\": \"./dist/runtime/patch-console.d.ts\",\n \"default\": \"./dist/runtime/patch-console.js\"\n },\n \"./patch-response\": {\n \"ts-src\": \"./src/runtime/patch-response.ts\",\n \"types\": \"./dist/runtime/patch-response.d.ts\",\n \"default\": \"./dist/runtime/patch-response.js\"\n },\n \"./patch-server-response\": {\n \"ts-src\": \"./src/runtime/patch-server-response.ts\",\n \"types\": \"./dist/runtime/patch-server-response.d.ts\",\n \"default\": \"./dist/runtime/patch-server-response.js\"\n },\n \"./config\": {\n \"ts-src\": \"./src/config.ts\",\n \"types\": \"./dist/dotenv-compat.d.ts\",\n \"default\": \"./dist/dotenv-compat.js\"\n },\n \"./config.js\": {\n \"ts-src\": \"./src/config.ts\",\n \"types\": \"./dist/dotenv-compat.d.ts\",\n \"default\": \"./dist/dotenv-compat.js\"\n }\n },\n \"dependencies\": {\n \"@env-spec/parser\": \"workspace:^\",\n \"debug\": \"catalog:\",\n \"execa\": \"^9.6.0\",\n \"which\": \"^5.0.0\"\n },\n \"devDependencies\": {\n \"@clack/core\": \"^0.5.0\",\n \"@clack/prompts\": \"^0.11.0\",\n \"@env-spec/utils\": \"workspace:*\",\n \"@sindresorhus/is\": \"catalog:\",\n \"@types/debug\": \"catalog:\",\n \"@types/node\": \"catalog:\",\n \"@types/which\": \"^3.0.4\",\n \"@yao-pkg/pkg\": \"^6.6.0\",\n \"ansis\": \"catalog:\",\n \"browser-or-node\": \"^3.0.0\",\n \"ci-info\": \"^4.3.0\",\n \"exit-hook\": \"^4.0.0\",\n \"gunshi\": \"^0.26.3\",\n \"is-docker\": \"^3.0.0\",\n \"is-unicode-supported\": \"^2.1.0\",\n \"is-wsl\": \"^3.1.0\",\n \"outdent\": \"catalog:\",\n \"tsup\": \"catalog:\",\n \"vitest\": \"catalog:\"\n }\n}\n","import { cli, type Command } from 'gunshi';\nimport { gracefulExit } from 'exit-hook';\n\nimport { VARLOCK_BANNER_COLOR } from '../lib/ascii-art';\nimport { CliExitError } from './helpers/exit-error';\nimport { EnvSourceParseError } from '../../env-graph';\nimport ansis from 'ansis';\nimport { fmt } from './helpers/pretty-format';\nimport { trackCommand, trackInstall } from './helpers/telemetry';\nimport { InvalidEnvError } from './helpers/error-checks';\nimport packageJson from '../../package.json';\n\n// we'll import just the spec from each, so the implementations can be lazy loaded\nimport { commandSpec as initCommandSpec } from './commands/init.command';\nimport { commandSpec as loadCommandSpec } from './commands/load.command';\nimport { commandSpec as runCommandSpec } from './commands/run.command';\n// import { commandSpec as encryptCommandSpec } from './commands/encrypt.command';\n// import { commandSpec as doctorCommandSpec } from './commands/doctor.command';\nimport { commandSpec as helpCommandSpec } from './commands/help.command';\nimport { commandSpec as telemetryCommandSpec } from './commands/telemetry.command';\nimport { commandSpec as loginCommandSpec } from './commands/login.command';\n\nlet versionId = packageJson.version;\nif (__VARLOCK_BUILD_TYPE__ !== 'release') versionId += `-${__VARLOCK_BUILD_TYPE__}`;\n\n// TODO: this is not splitting the bundle correctly to actually lazy load the command fns\nfunction buildLazyCommand(\n commandSpec: Command<any>,\n loadCommandFn: () => Promise<{ commandSpec: Command<any>, commandFn: any }>,\n) {\n const commandName = commandSpec.name!;\n return {\n ...commandSpec,\n run: async (...args: Array<any>) => {\n // Track command execution\n await trackCommand(commandName, { command: commandName });\n // load the command fn and run it\n const commandSpecAndFn = await loadCommandFn();\n return commandSpecAndFn.commandFn(...args);\n },\n };\n}\n\nconst subCommands = new Map();\nsubCommands.set('init', buildLazyCommand(initCommandSpec, async () => await import('./commands/init.command')));\nsubCommands.set('load', buildLazyCommand(loadCommandSpec, async () => await import('./commands/load.command')));\nsubCommands.set('run', buildLazyCommand(runCommandSpec, async () => await import('./commands/run.command')));\n// subCommands.set('encrypt', buildLazyCommand(encryptCommandSpec, async () => await import('./commands/encrypt.command')));\n// subCommands.set('doctor', buildLazyCommand(doctorCommandSpec, async () => await import('./commands/doctor.command')));\nsubCommands.set('help', buildLazyCommand(helpCommandSpec, async () => await import('./commands/help.command')));\nsubCommands.set('telemetry', buildLazyCommand(telemetryCommandSpec, async () => await import('./commands/telemetry.command')));\nsubCommands.set('login', buildLazyCommand(loginCommandSpec, async () => await import('./commands/login.command')));\n\n(async function go() {\n try {\n let args = process.argv.slice(2);\n\n // TODO: remove this once we have a better way to re-trigger help\n if (args[0] === 'help') args = ['--help'];\n\n // track standalone installs via homebrew/curl\n if (__VARLOCK_SEA_BUILD__) {\n if (args[0] === '--post-install') {\n await trackInstall(args[1] as 'brew' | 'curl');\n //! this ouput is used by homebrew formula to check installed version is correct\n console.log(versionId);\n gracefulExit();\n }\n }\n\n if (args[0] === '--version') {\n await trackCommand('version');\n }\n\n await cli(args, {\n // main command - triggered if you just run `varlock` with no args\n run: () => {\n console.log('Please run one of the sub-commands. Run `varlock --help` for more info.');\n },\n }, {\n name: 'varlock',\n description: 'Encrypt and protect your env vars',\n version: versionId,\n subCommands,\n renderHeader: async (ctx) => {\n // do not show header if we are running a sub-command\n if (ctx.name) return '';\n return VARLOCK_BANNER_COLOR;\n },\n });\n gracefulExit();\n } catch (error) {\n if (error instanceof Error && error.message.startsWith('Command not found: ')) {\n const badCommandName = error.message.split(': ')[1];\n const badCommandErr = new CliExitError(`Invalid subcommand: ${badCommandName}`, {\n suggestion: `Run \\`${fmt.command('varlock --help', { jsPackageManager: true })}\\` for more info.`,\n });\n console.error(badCommandErr.getFormattedOutput());\n gracefulExit(1);\n } else if (error instanceof CliExitError || error instanceof InvalidEnvError) {\n // in watch mode, we just log but do not actually exit\n console.error(error.getFormattedOutput());\n // TODO: we'll probably want to implement watch mode, so it wont actually exit\n } else if (error instanceof EnvSourceParseError) {\n console.error(`🚨 Error encountered while loading ${error.location.path}`);\n console.error(error.message);\n\n const errLoc = error.location as any;\n\n const errPreview = [\n errLoc.lineStr,\n `${ansis.gray('-'.repeat(errLoc.colNumber - 1))}${ansis.red('^')}`,\n ].join('\\n');\n\n console.error('Error parsing .env file');\n console.error(fmt.filePath(`${errLoc.path}:${errLoc.lineNumber}:${errLoc.colNumber}`));\n console.error(errPreview);\n\n gracefulExit(1);\n } else {\n throw error;\n }\n\n gracefulExit(1);\n }\n}());\n"]}
1
+ {"version":3,"sources":["../../../../node_modules/.pnpm/ci-info@4.3.0/node_modules/ci-info/vendors.json","../../../../node_modules/.pnpm/ci-info@4.3.0/node_modules/ci-info/index.js","../../src/lib/ascii-art.ts","../../src/cli/helpers/telemetry.ts","../../../../node_modules/.pnpm/is-docker@3.0.0/node_modules/is-docker/index.js","../../../../node_modules/.pnpm/is-inside-container@1.0.0/node_modules/is-inside-container/index.js","../../../../node_modules/.pnpm/is-wsl@3.1.0/node_modules/is-wsl/index.js","../../package.json","../../src/cli/cli-executable.ts"],"names":["isCI","fs","process","os","ciName","commandSpec"],"mappings":"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","file":"cli-executable.js","sourcesContent":["[\n {\n \"name\": \"Agola CI\",\n \"constant\": \"AGOLA\",\n \"env\": \"AGOLA_GIT_REF\",\n \"pr\": \"AGOLA_PULL_REQUEST_ID\"\n },\n {\n \"name\": \"Appcircle\",\n \"constant\": \"APPCIRCLE\",\n \"env\": \"AC_APPCIRCLE\",\n \"pr\": {\n \"env\": \"AC_GIT_PR\",\n \"ne\": \"false\"\n }\n },\n {\n \"name\": \"AppVeyor\",\n \"constant\": \"APPVEYOR\",\n \"env\": \"APPVEYOR\",\n \"pr\": \"APPVEYOR_PULL_REQUEST_NUMBER\"\n },\n {\n \"name\": \"AWS CodeBuild\",\n \"constant\": \"CODEBUILD\",\n \"env\": \"CODEBUILD_BUILD_ARN\",\n \"pr\": {\n \"env\": \"CODEBUILD_WEBHOOK_EVENT\",\n \"any\": [\n \"PULL_REQUEST_CREATED\",\n \"PULL_REQUEST_UPDATED\",\n \"PULL_REQUEST_REOPENED\"\n ]\n }\n },\n {\n \"name\": \"Azure Pipelines\",\n \"constant\": \"AZURE_PIPELINES\",\n \"env\": \"TF_BUILD\",\n \"pr\": {\n \"BUILD_REASON\": \"PullRequest\"\n }\n },\n {\n \"name\": \"Bamboo\",\n \"constant\": \"BAMBOO\",\n \"env\": \"bamboo_planKey\"\n },\n {\n \"name\": \"Bitbucket Pipelines\",\n \"constant\": \"BITBUCKET\",\n \"env\": \"BITBUCKET_COMMIT\",\n \"pr\": \"BITBUCKET_PR_ID\"\n },\n {\n \"name\": \"Bitrise\",\n \"constant\": \"BITRISE\",\n \"env\": \"BITRISE_IO\",\n \"pr\": \"BITRISE_PULL_REQUEST\"\n },\n {\n \"name\": \"Buddy\",\n \"constant\": \"BUDDY\",\n \"env\": \"BUDDY_WORKSPACE_ID\",\n \"pr\": \"BUDDY_EXECUTION_PULL_REQUEST_ID\"\n },\n {\n \"name\": \"Buildkite\",\n \"constant\": \"BUILDKITE\",\n \"env\": \"BUILDKITE\",\n \"pr\": {\n \"env\": \"BUILDKITE_PULL_REQUEST\",\n \"ne\": \"false\"\n }\n },\n {\n \"name\": \"CircleCI\",\n \"constant\": \"CIRCLE\",\n \"env\": \"CIRCLECI\",\n \"pr\": \"CIRCLE_PULL_REQUEST\"\n },\n {\n \"name\": \"Cirrus CI\",\n \"constant\": \"CIRRUS\",\n \"env\": \"CIRRUS_CI\",\n \"pr\": \"CIRRUS_PR\"\n },\n {\n \"name\": \"Cloudflare Pages\",\n \"constant\": \"CLOUDFLARE_PAGES\",\n \"env\": \"CF_PAGES\"\n },\n {\n \"name\": \"Cloudflare Workers\",\n \"constant\": \"CLOUDFLARE_WORKERS\",\n \"env\": \"WORKERS_CI\"\n },\n {\n \"name\": \"Codefresh\",\n \"constant\": \"CODEFRESH\",\n \"env\": \"CF_BUILD_ID\",\n \"pr\": {\n \"any\": [\n \"CF_PULL_REQUEST_NUMBER\",\n \"CF_PULL_REQUEST_ID\"\n ]\n }\n },\n {\n \"name\": \"Codemagic\",\n \"constant\": \"CODEMAGIC\",\n \"env\": \"CM_BUILD_ID\",\n \"pr\": \"CM_PULL_REQUEST\"\n },\n {\n \"name\": \"Codeship\",\n \"constant\": \"CODESHIP\",\n \"env\": {\n \"CI_NAME\": \"codeship\"\n }\n },\n {\n \"name\": \"Drone\",\n \"constant\": \"DRONE\",\n \"env\": \"DRONE\",\n \"pr\": {\n \"DRONE_BUILD_EVENT\": \"pull_request\"\n }\n },\n {\n \"name\": \"dsari\",\n \"constant\": \"DSARI\",\n \"env\": \"DSARI\"\n },\n {\n \"name\": \"Earthly\",\n \"constant\": \"EARTHLY\",\n \"env\": \"EARTHLY_CI\"\n },\n {\n \"name\": \"Expo Application Services\",\n \"constant\": \"EAS\",\n \"env\": \"EAS_BUILD\"\n },\n {\n \"name\": \"Gerrit\",\n \"constant\": \"GERRIT\",\n \"env\": \"GERRIT_PROJECT\"\n },\n {\n \"name\": \"Gitea Actions\",\n \"constant\": \"GITEA_ACTIONS\",\n \"env\": \"GITEA_ACTIONS\"\n },\n {\n \"name\": \"GitHub Actions\",\n \"constant\": \"GITHUB_ACTIONS\",\n \"env\": \"GITHUB_ACTIONS\",\n \"pr\": {\n \"GITHUB_EVENT_NAME\": \"pull_request\"\n }\n },\n {\n \"name\": \"GitLab CI\",\n \"constant\": \"GITLAB\",\n \"env\": \"GITLAB_CI\",\n \"pr\": \"CI_MERGE_REQUEST_ID\"\n },\n {\n \"name\": \"GoCD\",\n \"constant\": \"GOCD\",\n \"env\": \"GO_PIPELINE_LABEL\"\n },\n {\n \"name\": \"Google Cloud Build\",\n \"constant\": \"GOOGLE_CLOUD_BUILD\",\n \"env\": \"BUILDER_OUTPUT\"\n },\n {\n \"name\": \"Harness CI\",\n \"constant\": \"HARNESS\",\n \"env\": \"HARNESS_BUILD_ID\"\n },\n {\n \"name\": \"Heroku\",\n \"constant\": \"HEROKU\",\n \"env\": {\n \"env\": \"NODE\",\n \"includes\": \"/app/.heroku/node/bin/node\"\n }\n },\n {\n \"name\": \"Hudson\",\n \"constant\": \"HUDSON\",\n \"env\": \"HUDSON_URL\"\n },\n {\n \"name\": \"Jenkins\",\n \"constant\": \"JENKINS\",\n \"env\": [\n \"JENKINS_URL\",\n \"BUILD_ID\"\n ],\n \"pr\": {\n \"any\": [\n \"ghprbPullId\",\n \"CHANGE_ID\"\n ]\n }\n },\n {\n \"name\": \"LayerCI\",\n \"constant\": \"LAYERCI\",\n \"env\": \"LAYERCI\",\n \"pr\": \"LAYERCI_PULL_REQUEST\"\n },\n {\n \"name\": \"Magnum CI\",\n \"constant\": \"MAGNUM\",\n \"env\": \"MAGNUM\"\n },\n {\n \"name\": \"Netlify CI\",\n \"constant\": \"NETLIFY\",\n \"env\": \"NETLIFY\",\n \"pr\": {\n \"env\": \"PULL_REQUEST\",\n \"ne\": \"false\"\n }\n },\n {\n \"name\": \"Nevercode\",\n \"constant\": \"NEVERCODE\",\n \"env\": \"NEVERCODE\",\n \"pr\": {\n \"env\": \"NEVERCODE_PULL_REQUEST\",\n \"ne\": \"false\"\n }\n },\n {\n \"name\": \"Prow\",\n \"constant\": \"PROW\",\n \"env\": \"PROW_JOB_ID\"\n },\n {\n \"name\": \"ReleaseHub\",\n \"constant\": \"RELEASEHUB\",\n \"env\": \"RELEASE_BUILD_ID\"\n },\n {\n \"name\": \"Render\",\n \"constant\": \"RENDER\",\n \"env\": \"RENDER\",\n \"pr\": {\n \"IS_PULL_REQUEST\": \"true\"\n }\n },\n {\n \"name\": \"Sail CI\",\n \"constant\": \"SAIL\",\n \"env\": \"SAILCI\",\n \"pr\": \"SAIL_PULL_REQUEST_NUMBER\"\n },\n {\n \"name\": \"Screwdriver\",\n \"constant\": \"SCREWDRIVER\",\n \"env\": \"SCREWDRIVER\",\n \"pr\": {\n \"env\": \"SD_PULL_REQUEST\",\n \"ne\": \"false\"\n }\n },\n {\n \"name\": \"Semaphore\",\n \"constant\": \"SEMAPHORE\",\n \"env\": \"SEMAPHORE\",\n \"pr\": \"PULL_REQUEST_NUMBER\"\n },\n {\n \"name\": \"Sourcehut\",\n \"constant\": \"SOURCEHUT\",\n \"env\": {\n \"CI_NAME\": \"sourcehut\"\n }\n },\n {\n \"name\": \"Strider CD\",\n \"constant\": \"STRIDER\",\n \"env\": \"STRIDER\"\n },\n {\n \"name\": \"TaskCluster\",\n \"constant\": \"TASKCLUSTER\",\n \"env\": [\n \"TASK_ID\",\n \"RUN_ID\"\n ]\n },\n {\n \"name\": \"TeamCity\",\n \"constant\": \"TEAMCITY\",\n \"env\": \"TEAMCITY_VERSION\"\n },\n {\n \"name\": \"Travis CI\",\n \"constant\": \"TRAVIS\",\n \"env\": \"TRAVIS\",\n \"pr\": {\n \"env\": \"TRAVIS_PULL_REQUEST\",\n \"ne\": \"false\"\n }\n },\n {\n \"name\": \"Vela\",\n \"constant\": \"VELA\",\n \"env\": \"VELA\",\n \"pr\": {\n \"VELA_PULL_REQUEST\": \"1\"\n }\n },\n {\n \"name\": \"Vercel\",\n \"constant\": \"VERCEL\",\n \"env\": {\n \"any\": [\n \"NOW_BUILDER\",\n \"VERCEL\"\n ]\n },\n \"pr\": \"VERCEL_GIT_PULL_REQUEST_ID\"\n },\n {\n \"name\": \"Visual Studio App Center\",\n \"constant\": \"APPCENTER\",\n \"env\": \"APPCENTER_BUILD_ID\"\n },\n {\n \"name\": \"Woodpecker\",\n \"constant\": \"WOODPECKER\",\n \"env\": {\n \"CI\": \"woodpecker\"\n },\n \"pr\": {\n \"CI_BUILD_EVENT\": \"pull_request\"\n }\n },\n {\n \"name\": \"Xcode Cloud\",\n \"constant\": \"XCODE_CLOUD\",\n \"env\": \"CI_XCODE_PROJECT\",\n \"pr\": \"CI_PULL_REQUEST_NUMBER\"\n },\n {\n \"name\": \"Xcode Server\",\n \"constant\": \"XCODE_SERVER\",\n \"env\": \"XCS\"\n }\n]\n","'use strict'\n\nconst vendors = require('./vendors.json')\n\nconst env = process.env\n\n// Used for testing only\nObject.defineProperty(exports, '_vendors', {\n value: vendors.map(function (v) {\n return v.constant\n })\n})\n\nexports.name = null\nexports.isPR = null\nexports.id = null\n\nvendors.forEach(function (vendor) {\n const envs = Array.isArray(vendor.env) ? vendor.env : [vendor.env]\n const isCI = envs.every(function (obj) {\n return checkEnv(obj)\n })\n\n exports[vendor.constant] = isCI\n\n if (!isCI) {\n return\n }\n\n exports.name = vendor.name\n exports.isPR = checkPR(vendor)\n exports.id = vendor.constant\n})\n\nexports.isCI = !!(\n env.CI !== 'false' && // Bypass all checks if CI env is explicitly set to 'false'\n (env.BUILD_ID || // Jenkins, Cloudbees\n env.BUILD_NUMBER || // Jenkins, TeamCity\n env.CI || // Travis CI, CircleCI, Cirrus CI, Gitlab CI, Appveyor, CodeShip, dsari, Cloudflare Pages/Workers\n env.CI_APP_ID || // Appflow\n env.CI_BUILD_ID || // Appflow\n env.CI_BUILD_NUMBER || // Appflow\n env.CI_NAME || // Codeship and others\n env.CONTINUOUS_INTEGRATION || // Travis CI, Cirrus CI\n env.RUN_ID || // TaskCluster, dsari\n exports.name ||\n false)\n)\n\nfunction checkEnv (obj) {\n // \"env\": \"CIRRUS\"\n if (typeof obj === 'string') return !!env[obj]\n\n // \"env\": { \"env\": \"NODE\", \"includes\": \"/app/.heroku/node/bin/node\" }\n if ('env' in obj) {\n // Currently there are no other types, uncomment when there are\n // if ('includes' in obj) {\n return env[obj.env] && env[obj.env].includes(obj.includes)\n // }\n }\n\n if ('any' in obj) {\n return obj.any.some(function (k) {\n return !!env[k]\n })\n }\n\n return Object.keys(obj).every(function (k) {\n return env[k] === obj[k]\n })\n}\n\nfunction checkPR (vendor) {\n switch (typeof vendor.pr) {\n case 'string':\n // \"pr\": \"CIRRUS_PR\"\n return !!env[vendor.pr]\n case 'object':\n if ('env' in vendor.pr) {\n if ('any' in vendor.pr) {\n // \"pr\": { \"env\": \"CODEBUILD_WEBHOOK_EVENT\", \"any\": [\"PULL_REQUEST_CREATED\", \"PULL_REQUEST_UPDATED\"] }\n return vendor.pr.any.some(function (key) {\n return env[vendor.pr.env] === key\n })\n } else {\n // \"pr\": { \"env\": \"BUILDKITE_PULL_REQUEST\", \"ne\": \"false\" }\n return vendor.pr.env in env && env[vendor.pr.env] !== vendor.pr.ne\n }\n } else if ('any' in vendor.pr) {\n // \"pr\": { \"any\": [\"ghprbPullId\", \"CHANGE_ID\"] }\n return vendor.pr.any.some(function (key) {\n return !!env[key]\n })\n } else {\n // \"pr\": { \"DRONE_BUILD_EVENT\": \"pull_request\" }\n return checkEnv(vendor.pr)\n }\n default:\n // PR detection not supported for this vendor\n return null\n }\n}\n","import ansis from 'ansis';\n\nexport const VARLOCK_BANNER2 = [\n ' ▄ ██ █▄▄▄▄ █ ████▄ ▄█▄ █ █▀ ',\n ' █ █ █ █ ▄▀ █ █ █ █▀ ▀▄ █▄█ ',\n '█ █ █▄▄█ █▀▀▌ █ █ █ █ ▀ █▀▄ ',\n ' █ █ █ █ █ █ ███▄ ▀████ █▄ ▄▀ █ █ ',\n ' █ █ █ █ ▀ ▀███▀ █ ',\n ' █▐ █ ▀ ▀ ',\n ' ▐ ▀ ',\n].join('\\n');\n\nexport const VARLOCK_BANNER = [\n '',\n ' ██▒ █▓ ▄▄▄ ██▀███ ██▓ ▒█████ ▄████▄ ██ ▄█▀',\n ' ▓██░ █▒▒████▄ ▓██ ▒ ██▒▓██▒ ▒██▒ ██▒▒██▀ ▀█ ██▄█▒ ',\n ' ▓██ █▒░▒██ ▀█▄ ▓██ ░▄█ ▒▒██░ ▒██░ ██▒▒██ ▄ ▓███▄░ ',\n ' ▒██ █░░░██▄▄▄▄██ ▒██▀▀█▄ ▒██░ ▒██ ██░▒██▄ ▄██▒▓██ █▄ ',\n ' ▒▀█░ ▓█ ▓██▒░██▓ ▒██▒░██████▒░ █████▒░▒ ████▀ ░▒██▒ █▄',\n ' ░ ▐░ ▒▒ ▓▒█░░ ▒▓ ░▒▓░░ ▒░▓ ░░ ▒░▒░▒░ ░ ░▒ ▒ ░▒ ▒▒ ▓▒',\n ' ░ ░░ ▒ ▒▒ ░ ░▒ ░ ▒░░ ░ ▒ ░ ░ ▒ ▒░ ░ ▒ ░ ░▒ ▒░',\n ' ░░ ░ ▒ ░░ ░ ░ ░ ░ ░ ░ ▒ ░ ░ ░░ ░ ',\n ' ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ',\n // ' ░ ░ ',\n].join('\\n');\n\n\nexport const FIRE = [\n ' ▚▐▟ ',\n '▗▗█▓▓█ ',\n '▟█▓░▓█▙',\n '▜█░▒░█▛',\n ' ▜▓░▓▛ ',\n ' ▀▀▀ ',\n].join('\\n');\n\n// const SOLID_BLOCK_CHARS = '▀▁▂▃▄▅▆▇█▉▊▋▌▍▎▏▐▔▕▖▗▘▙▚▛▜▝▞▟';\n// const LIGHT_BLOCK_CHARS = '░▒▓';\n\nexport const VARLOCK_BANNER_COLOR = VARLOCK_BANNER\n .replaceAll(/([▀▁▂▃▄▅▆▇█▉▊▋▌▍▎▏▐▔▕▖▗▘▙▚▛▜▝▞▟]+)/g, (m) => ansis.hex('#DD0000')(m))\n .replaceAll(/([▓░▒]+)/g, (m) => ansis.blue(m));\n\n\n","import os from 'node:os';\nimport crypto, { type BinaryLike, createHash } from 'node:crypto';\nimport { join } from 'node:path';\nimport {\n existsSync, readFileSync, writeFileSync,\n mkdirSync,\n} from 'node:fs';\nimport { asyncExitHook } from 'exit-hook';\nimport Debug from 'debug';\nimport { name as ciName, isCI } from 'ci-info';\nimport isDocker from 'is-docker';\nimport isWSL from 'is-wsl';\n\n\nimport packageJson from '../../../package.json';\n\nimport { CONFIG } from '../../config';\n\n\nconst debug = Debug('varlock:telemetry');\n\nconst TRUE_ENV_VAR_VALUES = ['true', '1', 't'];\n\nconst varlockConfigDirPath = join(os.homedir(), '.varlock');\nconst varlockConfigFilePath = join(varlockConfigDirPath, 'config.json');\nlet varlockConfigFileContents: Record<string, any> | undefined;\nfunction getConfigFileContents() {\n if (varlockConfigFileContents) return varlockConfigFileContents;\n try {\n const configContent = readFileSync(varlockConfigFilePath, 'utf-8');\n varlockConfigFileContents = JSON.parse(configContent);\n return varlockConfigFileContents;\n } catch (error) {\n debug('Failed to read varlock config:', error);\n return {};\n }\n}\n\n// we will identify users using a random UUID stored in the `~/.varlock/config.json` file\nlet cachedAnonymousId: string | undefined;\nfunction getAnonymousId() {\n if (cachedAnonymousId) return cachedAnonymousId;\n\n const configFileContents = getConfigFileContents();\n if (configFileContents?.anonymousId) {\n cachedAnonymousId = configFileContents.anonymousId;\n return configFileContents.anonymousId;\n }\n\n const newAnonymousId = `${isCI ? 'ci-' : ''}${crypto.randomUUID()}`;\n\n if (!existsSync(varlockConfigDirPath)) {\n mkdirSync(varlockConfigDirPath, { recursive: true });\n }\n\n writeFileSync(\n varlockConfigFilePath,\n JSON.stringify({\n ...configFileContents,\n anonymousId: newAnonymousId,\n }, null, 2),\n { flag: 'w' },\n );\n cachedAnonymousId = newAnonymousId;\n return newAnonymousId;\n}\n\n\nfunction checkIsOptedOut() {\n // Check if this is a dev build, rather than a published npm package or standalone binary\n if (__VARLOCK_BUILD_TYPE__ === 'dev') {\n debug('telemetry opted out - dev build');\n return true;\n }\n\n // Check environment variable\n if (\n process.env.PH_OPT_OUT === 'true' // legacy\n || TRUE_ENV_VAR_VALUES.includes((process.env.VARLOCK_TELEMETRY_DISABLED || '').toLowerCase())\n ) {\n debug('telemetry opted out - env var');\n return true;\n }\n\n // Check config file\n const varlockConfigFile = getConfigFileContents();\n if (varlockConfigFile?.analytics_opt_out || varlockConfigFile?.telemetryDisabled) {\n debug('telemetry opted out - config file');\n return true;\n }\n return false;\n}\n\n\n\nfunction anonymizeValue(payload: BinaryLike): string {\n // We use empty string to represent an empty value. Avoid hashing this\n // since that would create a real hash and remove its \"empty\" meaning.\n if (payload === '') {\n return payload;\n }\n // Otherwise, create a new hash from the payload and return it.\n const hash = createHash('sha256');\n hash.update(payload);\n return hash.digest('hex');\n}\n\nfunction getProjectGitRemoteUrl(): string | undefined {\n try {\n // Find the git directory by scanning upwards\n let gitDirPath: string | undefined;\n let currentDir = process.cwd();\n while (currentDir && currentDir !== '/') {\n const possibleGitDirPath = join(currentDir, '.git');\n if (existsSync(possibleGitDirPath)) {\n gitDirPath = possibleGitDirPath;\n break;\n }\n currentDir = join(currentDir, '..');\n }\n if (!gitDirPath) return undefined;\n const gitConfigContents = readFileSync(join(gitDirPath, 'config'), 'utf-8');\n // first look for upstream\n const remoteUpstreamPos = gitConfigContents.indexOf('[remote \"upstream\"]');\n if (remoteUpstreamPos !== -1) {\n const remoteUpstreamUrl = gitConfigContents.slice(remoteUpstreamPos).match(/url = (.+)/)?.[1];\n return remoteUpstreamUrl;\n }\n // otherwise fallback to origin\n const remoteOriginPos = gitConfigContents.indexOf('[remote \"origin\"]');\n if (remoteOriginPos === -1) return undefined;\n const remoteOriginUrl = gitConfigContents.slice(remoteOriginPos).match(/url = (.+)/)?.[1];\n return remoteOriginUrl;\n } catch (err) {\n return undefined;\n }\n}\nfunction getAnonymousProjectId() {\n // we want a project ID tied to the git repo, so we can group telemetry data by project\n // we could use the first commit hash, but this is more costly to compute, as we either need to rely\n // on the git cli and execSync, or we need to parse the git objects directly\n // so for now, we'll use the git remote URL (upstream if it exists, or origin)\n const gitRemoteUrl = getProjectGitRemoteUrl();\n if (!gitRemoteUrl) return null;\n return anonymizeValue(gitRemoteUrl);\n}\n\n\ntype TelemetryMeta = {\n // project info\n anonymous_project_id: string | null;\n // version information\n node_version: string;\n varlock_version: string;\n // OS information\n system_platform: string;\n system_release: string;\n system_architecture: string;\n // Machine information\n cpu_count: number,\n cpu_model: string | null,\n cpu_speed: number | null,\n memory_mb: number,\n // Environment information\n is_docker: boolean,\n is_tty: boolean,\n is_wsl: boolean,\n is_ci: boolean,\n ci_name: string | null,\n is_sea: boolean,\n};\n\nlet cachedTelemetryMetadata: TelemetryMeta | undefined;\nfunction getTelemetryMeta() {\n if (cachedTelemetryMetadata) return cachedTelemetryMetadata;\n\n const cpus = os.cpus() || [];\n\n let versionIdentifier = packageJson.version;\n // TODO: for preview builds, it would be nice to track which preview it is (PR number or commit hash)\n if (__VARLOCK_BUILD_TYPE__ !== 'release') versionIdentifier += `-${__VARLOCK_BUILD_TYPE__}`;\n\n cachedTelemetryMetadata = {\n anonymous_project_id: getAnonymousProjectId(),\n node_version: process.version.replace(/^v?/, ''),\n varlock_version: versionIdentifier,\n // TODO: pass through version info for specific integrations/plugins?\n system_platform: os.platform(),\n system_release: os.release(),\n system_architecture: os.arch(),\n cpu_count: cpus.length,\n cpu_model: cpus.length ? cpus[0].model : null,\n cpu_speed: cpus.length ? cpus[0].speed : null,\n memory_mb: Math.trunc(os.totalmem() / 1024 ** 2),\n is_docker: isDocker(),\n is_tty: process.stdout.isTTY,\n is_wsl: isWSL,\n is_ci: isCI,\n ci_name: ciName,\n is_sea: __VARLOCK_SEA_BUILD__,\n };\n return cachedTelemetryMetadata;\n}\n\n\nconst isOptedOut = checkIsOptedOut();\n\nlet lastTelemetryReq: Promise<any> | undefined;\n\nasync function posthogCapture(event: string, properties?: Record<string, any>) {\n const telemetryMeta = getTelemetryMeta();\n const payload = {\n api_key: CONFIG.POSTHOG_API_KEY,\n event,\n properties: {\n $process_person_profile: false,\n ...telemetryMeta,\n ...properties,\n },\n distinct_id: getAnonymousId(),\n };\n\n debug(`track${isOptedOut ? ' (disabled)' : ''}`, payload);\n\n if (isOptedOut) return;\n\n // add exit hook, so we can give the request a little time to finish\n const removeExitHook = asyncExitHook(async () => {\n // will still exit if the timeout is met, but will finish early if the request completes\n await lastTelemetryReq;\n }, { wait: 500 });\n\n // Make the fetch call\n lastTelemetryReq = fetch(`${CONFIG.POSTHOG_HOST}/i/v0/e/`, {\n method: 'POST',\n body: JSON.stringify(payload),\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n .then((res) => {\n if (!res.ok) throw new Error(`HTTP error! status: ${res.status}`);\n return res.text();\n })\n .then((text) => debug('telemetry response:', text))\n .catch((error) => {\n debug('telemetry error:', error);\n })\n .finally(() => {\n removeExitHook();\n });\n}\n\n\n\nexport async function trackCommand(command: string, properties?: Record<string, any>) {\n await posthogCapture('cli_command_executed', {\n command,\n ...properties,\n });\n}\n\nexport async function trackInstall(source: 'brew' | 'curl') {\n await posthogCapture('cli_install', {\n source,\n });\n}\n\n","import fs from 'node:fs';\n\nlet isDockerCached;\n\nfunction hasDockerEnv() {\n\ttry {\n\t\tfs.statSync('/.dockerenv');\n\t\treturn true;\n\t} catch {\n\t\treturn false;\n\t}\n}\n\nfunction hasDockerCGroup() {\n\ttry {\n\t\treturn fs.readFileSync('/proc/self/cgroup', 'utf8').includes('docker');\n\t} catch {\n\t\treturn false;\n\t}\n}\n\nexport default function isDocker() {\n\t// TODO: Use `??=` when targeting Node.js 16.\n\tif (isDockerCached === undefined) {\n\t\tisDockerCached = hasDockerEnv() || hasDockerCGroup();\n\t}\n\n\treturn isDockerCached;\n}\n","import fs from 'node:fs';\nimport isDocker from 'is-docker';\n\nlet cachedResult;\n\n// Podman detection\nconst hasContainerEnv = () => {\n\ttry {\n\t\tfs.statSync('/run/.containerenv');\n\t\treturn true;\n\t} catch {\n\t\treturn false;\n\t}\n};\n\nexport default function isInsideContainer() {\n\t// TODO: Use `??=` when targeting Node.js 16.\n\tif (cachedResult === undefined) {\n\t\tcachedResult = hasContainerEnv() || isDocker();\n\t}\n\n\treturn cachedResult;\n}\n","import process from 'node:process';\nimport os from 'node:os';\nimport fs from 'node:fs';\nimport isInsideContainer from 'is-inside-container';\n\nconst isWsl = () => {\n\tif (process.platform !== 'linux') {\n\t\treturn false;\n\t}\n\n\tif (os.release().toLowerCase().includes('microsoft')) {\n\t\tif (isInsideContainer()) {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t}\n\n\ttry {\n\t\treturn fs.readFileSync('/proc/version', 'utf8').toLowerCase().includes('microsoft')\n\t\t\t? !isInsideContainer() : false;\n\t} catch {\n\t\treturn false;\n\t}\n};\n\nexport default process.env.__IS_WSL_TEST__ ? isWsl : isWsl();\n","{\n \"name\": \"varlock\",\n \"version\": \"0.0.13\",\n \"description\": \"\",\n \"main\": \"index.js\",\n \"type\": \"module\",\n \"author\": \"dmno-dev\",\n \"license\": \"MIT\",\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/dmno-dev/varlock.git\",\n \"directory\": \"packages/varlock\"\n },\n \"scripts\": {\n \"build\": \"tsup\",\n \"build:sea\": \"tsup --config tsup-sea.config.ts\",\n \"dev\": \"tsup\",\n \"test\": \"vitest\",\n \"lint\": \"eslint .\",\n \"lint:fix\": \"pnpm run lint --fix\"\n },\n \"keywords\": [],\n \"files\": [\n \"/bin\",\n \"/dist\"\n ],\n \"bin\": {\n \"varlock\": \"./bin/cli.js\"\n },\n \"engines\": {\n \"node\": \">=22\"\n },\n \"exports\": {\n \".\": {\n \"ts-src\": \"./src/index.ts\",\n \"types\": \"./dist/index.d.ts\",\n \"default\": \"./dist/index.js\"\n },\n \"./env\": {\n \"ts-src\": \"./src/runtime/env.ts\",\n \"types\": \"./dist/runtime/env.d.ts\",\n \"default\": \"./dist/runtime/env.js\"\n },\n \"./auto-load\": {\n \"ts-src\": \"./src/auto-load.ts\",\n \"types\": \"./dist/auto-load.d.ts\",\n \"default\": \"./dist/auto-load.js\"\n },\n \"./patch-console\": {\n \"ts-src\": \"./src/runtime/patch-console.ts\",\n \"types\": \"./dist/runtime/patch-console.d.ts\",\n \"default\": \"./dist/runtime/patch-console.js\"\n },\n \"./patch-response\": {\n \"ts-src\": \"./src/runtime/patch-response.ts\",\n \"types\": \"./dist/runtime/patch-response.d.ts\",\n \"default\": \"./dist/runtime/patch-response.js\"\n },\n \"./patch-server-response\": {\n \"ts-src\": \"./src/runtime/patch-server-response.ts\",\n \"types\": \"./dist/runtime/patch-server-response.d.ts\",\n \"default\": \"./dist/runtime/patch-server-response.js\"\n },\n \"./config\": {\n \"ts-src\": \"./src/config.ts\",\n \"types\": \"./dist/dotenv-compat.d.ts\",\n \"default\": \"./dist/dotenv-compat.js\"\n },\n \"./config.js\": {\n \"ts-src\": \"./src/config.ts\",\n \"types\": \"./dist/dotenv-compat.d.ts\",\n \"default\": \"./dist/dotenv-compat.js\"\n }\n },\n \"dependencies\": {\n \"@env-spec/parser\": \"workspace:^\",\n \"debug\": \"catalog:\",\n \"execa\": \"^9.6.0\",\n \"which\": \"^5.0.0\"\n },\n \"devDependencies\": {\n \"@clack/core\": \"^0.5.0\",\n \"@clack/prompts\": \"^0.11.0\",\n \"@env-spec/utils\": \"workspace:*\",\n \"@sindresorhus/is\": \"catalog:\",\n \"@types/debug\": \"catalog:\",\n \"@types/node\": \"catalog:\",\n \"@types/which\": \"^3.0.4\",\n \"@yao-pkg/pkg\": \"^6.6.0\",\n \"ansis\": \"catalog:\",\n \"browser-or-node\": \"^3.0.0\",\n \"ci-info\": \"^4.3.0\",\n \"exit-hook\": \"^4.0.0\",\n \"gunshi\": \"^0.26.3\",\n \"is-docker\": \"^3.0.0\",\n \"is-unicode-supported\": \"^2.1.0\",\n \"is-wsl\": \"^3.1.0\",\n \"outdent\": \"catalog:\",\n \"tsup\": \"catalog:\",\n \"vitest\": \"catalog:\"\n }\n}\n","import { cli, type Command } from 'gunshi';\nimport { gracefulExit } from 'exit-hook';\n\nimport { VARLOCK_BANNER_COLOR } from '../lib/ascii-art';\nimport { CliExitError } from './helpers/exit-error';\nimport { EnvSourceParseError } from '../../env-graph';\nimport ansis from 'ansis';\nimport { fmt } from './helpers/pretty-format';\nimport { trackCommand, trackInstall } from './helpers/telemetry';\nimport { InvalidEnvError } from './helpers/error-checks';\nimport packageJson from '../../package.json';\n\n// we'll import just the spec from each, so the implementations can be lazy loaded\nimport { commandSpec as initCommandSpec } from './commands/init.command';\nimport { commandSpec as loadCommandSpec } from './commands/load.command';\nimport { commandSpec as runCommandSpec } from './commands/run.command';\n// import { commandSpec as encryptCommandSpec } from './commands/encrypt.command';\n// import { commandSpec as doctorCommandSpec } from './commands/doctor.command';\nimport { commandSpec as helpCommandSpec } from './commands/help.command';\nimport { commandSpec as telemetryCommandSpec } from './commands/telemetry.command';\nimport { commandSpec as loginCommandSpec } from './commands/login.command';\n\nlet versionId = packageJson.version;\nif (__VARLOCK_BUILD_TYPE__ !== 'release') versionId += `-${__VARLOCK_BUILD_TYPE__}`;\n\n// TODO: this is not splitting the bundle correctly to actually lazy load the command fns\nfunction buildLazyCommand(\n commandSpec: Command<any>,\n loadCommandFn: () => Promise<{ commandSpec: Command<any>, commandFn: any }>,\n) {\n const commandName = commandSpec.name!;\n return {\n ...commandSpec,\n run: async (...args: Array<any>) => {\n // Track command execution\n await trackCommand(commandName, { command: commandName });\n // load the command fn and run it\n const commandSpecAndFn = await loadCommandFn();\n return commandSpecAndFn.commandFn(...args);\n },\n };\n}\n\nconst subCommands = new Map();\nsubCommands.set('init', buildLazyCommand(initCommandSpec, async () => await import('./commands/init.command')));\nsubCommands.set('load', buildLazyCommand(loadCommandSpec, async () => await import('./commands/load.command')));\nsubCommands.set('run', buildLazyCommand(runCommandSpec, async () => await import('./commands/run.command')));\n// subCommands.set('encrypt', buildLazyCommand(encryptCommandSpec, async () => await import('./commands/encrypt.command')));\n// subCommands.set('doctor', buildLazyCommand(doctorCommandSpec, async () => await import('./commands/doctor.command')));\nsubCommands.set('help', buildLazyCommand(helpCommandSpec, async () => await import('./commands/help.command')));\nsubCommands.set('telemetry', buildLazyCommand(telemetryCommandSpec, async () => await import('./commands/telemetry.command')));\nsubCommands.set('login', buildLazyCommand(loginCommandSpec, async () => await import('./commands/login.command')));\n\n(async function go() {\n try {\n let args = process.argv.slice(2);\n\n // TODO: remove this once we have a better way to re-trigger help\n if (args[0] === 'help') args = ['--help'];\n\n // track standalone installs via homebrew/curl\n if (__VARLOCK_SEA_BUILD__) {\n if (args[0] === '--post-install') {\n await trackInstall(args[1] as 'brew' | 'curl');\n //! this ouput is used by homebrew formula to check installed version is correct\n console.log(versionId);\n gracefulExit();\n }\n }\n\n if (args[0] === '--version') {\n await trackCommand('version');\n }\n\n await cli(args, {\n // main command - triggered if you just run `varlock` with no args\n run: () => {\n console.log('Please run one of the sub-commands. Run `varlock --help` for more info.');\n },\n }, {\n name: 'varlock',\n description: 'Encrypt and protect your env vars',\n version: versionId,\n subCommands,\n renderHeader: async (ctx) => {\n // do not show header if we are running a sub-command\n if (ctx.name) return '';\n return VARLOCK_BANNER_COLOR;\n },\n });\n gracefulExit();\n } catch (error) {\n if (error instanceof Error && error.message.startsWith('Command not found: ')) {\n const badCommandName = error.message.split(': ')[1];\n const badCommandErr = new CliExitError(`Invalid subcommand: ${badCommandName}`, {\n suggestion: `Run \\`${fmt.command('varlock --help', { jsPackageManager: true })}\\` for more info.`,\n });\n console.error(badCommandErr.getFormattedOutput());\n gracefulExit(1);\n } else if (error instanceof CliExitError || error instanceof InvalidEnvError) {\n // in watch mode, we just log but do not actually exit\n console.error(error.getFormattedOutput());\n // TODO: we'll probably want to implement watch mode, so it wont actually exit\n } else if (error instanceof EnvSourceParseError) {\n console.error(`🚨 Error encountered while loading ${error.location.path}`);\n console.error(error.message);\n\n const errLoc = error.location as any;\n\n const errPreview = [\n errLoc.lineStr,\n `${ansis.gray('-'.repeat(errLoc.colNumber - 1))}${ansis.red('^')}`,\n ].join('\\n');\n\n console.error('Error parsing .env file');\n console.error(fmt.filePath(`${errLoc.path}:${errLoc.lineNumber}:${errLoc.colNumber}`));\n console.error(errPreview);\n\n gracefulExit(1);\n } else {\n throw error;\n }\n\n gracefulExit(1);\n }\n}());\n"]}