@dragonmastery/tamer 0.42.1 → 0.43.0

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 (104) hide show
  1. package/dist/SecretsVault-D_JTJm5s.mjs +3 -0
  2. package/dist/{apply-Mk9usR-U.mjs → apply-J081Hfqc.mjs} +15 -15
  3. package/dist/{apply-Mk9usR-U.mjs.map → apply-J081Hfqc.mjs.map} +1 -1
  4. package/dist/{applyTarget-CJSn9DeJ.mjs → applyTarget-CTsOrwco.mjs} +3 -3
  5. package/dist/{applyTarget-CJSn9DeJ.mjs.map → applyTarget-CTsOrwco.mjs.map} +1 -1
  6. package/dist/{bootstrap-BCy6B-B6.mjs → bootstrap-D663FPHF.mjs} +4 -4
  7. package/dist/{bootstrap-BCy6B-B6.mjs.map → bootstrap-D663FPHF.mjs.map} +1 -1
  8. package/dist/{cloudflareSnapshot-DqP8v_xG.mjs → cloudflareSnapshot-dKYupX1L.mjs} +5 -5
  9. package/dist/{cloudflareSnapshot-DqP8v_xG.mjs.map → cloudflareSnapshot-dKYupX1L.mjs.map} +1 -1
  10. package/dist/crypto-5HwDmS4B.mjs +3 -0
  11. package/dist/{deploy-DbXBHpCG.mjs → deploy-N8cVT5M9.mjs} +10 -10
  12. package/dist/{deploy-DbXBHpCG.mjs.map → deploy-N8cVT5M9.mjs.map} +1 -1
  13. package/dist/{destroy-CesVkyxf.mjs → destroy-kkOR_ZBj.mjs} +11 -11
  14. package/dist/{destroy-CesVkyxf.mjs.map → destroy-kkOR_ZBj.mjs.map} +1 -1
  15. package/dist/{destroy-tenant-DMynv_u-.mjs → destroy-tenant-DdObj9pd.mjs} +2 -2
  16. package/dist/{destroy-tenant-DMynv_u-.mjs.map → destroy-tenant-DdObj9pd.mjs.map} +1 -1
  17. package/dist/{dev-sk6JGKe4.mjs → dev-zQRvUhdd.mjs} +8 -8
  18. package/dist/{dev-sk6JGKe4.mjs.map → dev-zQRvUhdd.mjs.map} +1 -1
  19. package/dist/{dns-records.resolve-SPYGYNHa.mjs → dns-records.resolve-CUQz6Ivz.mjs} +1 -1
  20. package/dist/{dns-records.resolve-SPYGYNHa.mjs.map → dns-records.resolve-CUQz6Ivz.mjs.map} +1 -1
  21. package/dist/{dns-records.resolve-jECsH6N-.mjs → dns-records.resolve-Dge2kukJ.mjs} +1 -1
  22. package/dist/{dns-records.sync-BORRvLky.mjs → dns-records.sync-BnOga2LS.mjs} +3 -3
  23. package/dist/{dns-records.sync-BORRvLky.mjs.map → dns-records.sync-BnOga2LS.mjs.map} +1 -1
  24. package/dist/{doctor-BgqnscIE.mjs → doctor-yTe9cUO5.mjs} +2 -2
  25. package/dist/{doctor-BgqnscIE.mjs.map → doctor-yTe9cUO5.mjs.map} +1 -1
  26. package/dist/{drift-C5r1cKxV.mjs → drift-B-oPsgPW.mjs} +7 -7
  27. package/dist/{drift-C5r1cKxV.mjs.map → drift-B-oPsgPW.mjs.map} +1 -1
  28. package/dist/drift-RsT8UGQw.mjs +8 -0
  29. package/dist/{emit-C7KXAVP0.mjs → emit-DDH99lzS.mjs} +3 -3
  30. package/dist/{emit-C7KXAVP0.mjs.map → emit-DDH99lzS.mjs.map} +1 -1
  31. package/dist/{env-gc-DE4EV7j7.mjs → env-gc-DrXu7DlG.mjs} +11 -11
  32. package/dist/{env-gc-DE4EV7j7.mjs.map → env-gc-DrXu7DlG.mjs.map} +1 -1
  33. package/dist/{env-list-DKseThiA.mjs → env-list-D-wnLl8W.mjs} +2 -2
  34. package/dist/{env-list-DKseThiA.mjs.map → env-list-D-wnLl8W.mjs.map} +1 -1
  35. package/dist/{events-CqbN9sbT.mjs → events-C86vo1gV.mjs} +2 -2
  36. package/dist/{events-CqbN9sbT.mjs.map → events-C86vo1gV.mjs.map} +1 -1
  37. package/dist/fingerprint-D6E5FTkq.mjs +3 -0
  38. package/dist/{generator-CbH3UZ3K.mjs → generator-Cu5XUkjr.mjs} +2 -2
  39. package/dist/{generator-CbH3UZ3K.mjs.map → generator-Cu5XUkjr.mjs.map} +1 -1
  40. package/dist/{import-leVD9Ryg.mjs → import-QJc0fI1h.mjs} +6 -6
  41. package/dist/{import-leVD9Ryg.mjs.map → import-QJc0fI1h.mjs.map} +1 -1
  42. package/dist/index.d.mts +9 -0
  43. package/dist/index.d.mts.map +1 -1
  44. package/dist/loader-DY6STQU3.mjs +3 -0
  45. package/dist/{logpush-job-Dqlt-wEw.mjs → logpush-job-DZG-3nkJ.mjs} +2 -2
  46. package/dist/{logpush-job-Dqlt-wEw.mjs.map → logpush-job-DZG-3nkJ.mjs.map} +1 -1
  47. package/dist/masterKey-D9gq3eNP.mjs +3 -0
  48. package/dist/{migrate-DyrTw9ep.mjs → migrate-v1UQCzNi.mjs} +6 -6
  49. package/dist/{migrate-DyrTw9ep.mjs.map → migrate-v1UQCzNi.mjs.map} +1 -1
  50. package/dist/normalize-DVSTRZhO.mjs.map +1 -1
  51. package/dist/{plan-D7UyLznb.mjs → plan-Dp2aTzEU.mjs} +12 -12
  52. package/dist/{plan-D7UyLznb.mjs.map → plan-Dp2aTzEU.mjs.map} +1 -1
  53. package/dist/{planFormat-CJw8Kq2s.mjs → planFormat-C8mq3sbD.mjs} +1 -1
  54. package/dist/{planFormat-CJw8Kq2s.mjs.map → planFormat-C8mq3sbD.mjs.map} +1 -1
  55. package/dist/{provision-tenant-DoGlAu6H.mjs → provision-tenant-DEscl-jo.mjs} +38 -34
  56. package/dist/provision-tenant-DEscl-jo.mjs.map +1 -0
  57. package/dist/{r2S3EmptyBucket-DD81ZWQ7.mjs → r2S3EmptyBucket-CDE2lTM8.mjs} +1 -1
  58. package/dist/{r2S3EmptyBucket-DD81ZWQ7.mjs.map → r2S3EmptyBucket-CDE2lTM8.mjs.map} +1 -1
  59. package/dist/{registry-CTerXUza.mjs → registry-CRgobiU4.mjs} +4 -4
  60. package/dist/{registry-CTerXUza.mjs.map → registry-CRgobiU4.mjs.map} +1 -1
  61. package/dist/{resolveTenantBindings-86AmRQcW.mjs → resolveTenantBindings-CXLwAG0F.mjs} +2 -2
  62. package/dist/{resolveTenantBindings-86AmRQcW.mjs.map → resolveTenantBindings-CXLwAG0F.mjs.map} +1 -1
  63. package/dist/secretsDb-CMEcKvSi.mjs +3 -0
  64. package/dist/{stackOutputs-BLp-dyzl.mjs → stackOutputs-BMPahRAl.mjs} +2 -2
  65. package/dist/{stackOutputs-BLp-dyzl.mjs.map → stackOutputs-BMPahRAl.mjs.map} +1 -1
  66. package/dist/{status-CL4MEGbn.mjs → status-CQpgTTeG.mjs} +7 -7
  67. package/dist/{status-CL4MEGbn.mjs.map → status-CQpgTTeG.mjs.map} +1 -1
  68. package/dist/sync-Blz5emYO.mjs +7 -0
  69. package/dist/{sync-Dii9n2nJ.mjs → sync-DqMMQ7mQ.mjs} +6 -6
  70. package/dist/{sync-Dii9n2nJ.mjs.map → sync-DqMMQ7mQ.mjs.map} +1 -1
  71. package/dist/tamer.mjs +52 -27
  72. package/dist/tamer.mjs.map +1 -1
  73. package/dist/{tamerArtifactsR2-B3X21TGV.mjs → tamerArtifactsR2-BePICoT8.mjs} +2 -2
  74. package/dist/{tamerArtifactsR2-B3X21TGV.mjs.map → tamerArtifactsR2-BePICoT8.mjs.map} +1 -1
  75. package/dist/{tenant-MWIs0esz.mjs → tenant-2XTWe9j0.mjs} +2 -2
  76. package/dist/{tenant-MWIs0esz.mjs.map → tenant-2XTWe9j0.mjs.map} +1 -1
  77. package/dist/{tenant-migrate-CM6cb1zo.mjs → tenant-migrate-B-n4ppSk.mjs} +5 -5
  78. package/dist/{tenant-migrate-CM6cb1zo.mjs.map → tenant-migrate-B-n4ppSk.mjs.map} +1 -1
  79. package/dist/{types-DCL0mEjS.mjs → types-BCTgIotG.mjs} +6 -6
  80. package/dist/{types-DCL0mEjS.mjs.map → types-BCTgIotG.mjs.map} +1 -1
  81. package/dist/{verifyPlanFile-B9VCcFIJ.mjs → verifyPlanFile-DrFZjkVY.mjs} +2 -2
  82. package/dist/{verifyPlanFile-B9VCcFIJ.mjs.map → verifyPlanFile-DrFZjkVY.mjs.map} +1 -1
  83. package/dist/{wfp-delete-CwWQFxxj.mjs → wfp-delete-BblKos51.mjs} +2 -2
  84. package/dist/{wfp-delete-CwWQFxxj.mjs.map → wfp-delete-BblKos51.mjs.map} +1 -1
  85. package/dist/{wfp-put-Bl5K3snx.mjs → wfp-put-oYvLiM_c.mjs} +2 -2
  86. package/dist/{wfp-put-Bl5K3snx.mjs.map → wfp-put-oYvLiM_c.mjs.map} +1 -1
  87. package/dist/{worker-route-BapxsQyX.mjs → worker-route-BPDAwUL0.mjs} +3 -3
  88. package/dist/{worker-route-BapxsQyX.mjs.map → worker-route-BPDAwUL0.mjs.map} +1 -1
  89. package/dist/{workers-D7ow_joN.mjs → workers-D08-ri2Q.mjs} +2 -2
  90. package/dist/{workers-D7ow_joN.mjs.map → workers-D08-ri2Q.mjs.map} +1 -1
  91. package/dist/wranglerOutFile-eViugwTw.mjs +3 -0
  92. package/dist/wranglerSpawn-BUOsdo5R.mjs +3 -0
  93. package/dist/{wranglerSpawn-VkSL0gZd.mjs → wranglerSpawn-Dg-lr-rf.mjs} +1 -1
  94. package/dist/{wranglerSpawn-VkSL0gZd.mjs.map → wranglerSpawn-Dg-lr-rf.mjs.map} +1 -1
  95. package/dist/{zoneResolver-CamXJpSB.mjs → zoneResolver-Dfp2glm8.mjs} +1 -1
  96. package/dist/{zoneResolver-CamXJpSB.mjs.map → zoneResolver-Dfp2glm8.mjs.map} +1 -1
  97. package/package.json +1 -1
  98. package/dist/drift-oOUlh0u8.mjs +0 -8
  99. package/dist/loader-B5iVsP6t.mjs +0 -3
  100. package/dist/provision-tenant-DoGlAu6H.mjs.map +0 -1
  101. package/dist/sync-DSgJGQh1.mjs +0 -7
  102. package/dist/wranglerOutFile-DDFKeKwO.mjs +0 -3
  103. package/dist/wranglerSpawn-CfPkFLP3.mjs +0 -3
  104. /package/dist/{secrets-DJ1yUy01.mjs → secrets-DVNZwGUS.mjs} +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"emit-C7KXAVP0.mjs","names":["row: ShardRegistryEntryV1","shards: ShardRegistryEntryV1[]"],"sources":["../src/core/codegen/shardRegistry/build.ts","../src/core/codegen/shardRegistry/emit.ts"],"sourcesContent":["import type { WranglerD1Database } from \"../../../generated/wrangler-types.js\";\nimport type { NamingEngine } from \"../../naming/NamingEngine.js\";\nimport type { StateManager } from \"../../state/StateManager.js\";\nimport type {\n D1ResourceConfig,\n D1StateEntry,\n ShardRegistryEntryV1,\n ShardRegistryV1,\n} from \"../../../types.js\";\nimport {\n d1CloudflareDatabaseName,\n d1SkipsProvisionAndMigrate,\n} from \"../../../features/d1/d1.ownership.js\";\n\nfunction registryRoleFor(config: D1ResourceConfig): string {\n return config.registryRole?.trim() || config.logicalName;\n}\n\nfunction optionalAliases(values: string[] | undefined): string[] | undefined {\n if (!values?.length) return undefined;\n const trimmed = values.map((v) => v.trim()).filter(Boolean);\n return trimmed.length > 0 ? trimmed : undefined;\n}\n\nfunction entryFromState(\n config: D1ResourceConfig,\n databaseName: string,\n binding: string,\n shardDate?: string,\n): ShardRegistryEntryV1 {\n const row: ShardRegistryEntryV1 = {\n id: databaseName,\n role: registryRoleFor(config),\n binding,\n databaseName,\n };\n if (shardDate) row.shardDate = shardDate;\n if (config.current === false) row.current = false;\n const legacyIds = optionalAliases(config.legacyIds);\n const legacyBindings = optionalAliases(config.legacyBindings);\n if (legacyIds) row.legacyIds = legacyIds;\n if (legacyBindings) row.legacyBindings = legacyBindings;\n return row;\n}\n\n/**\n * Build {@link ShardRegistryV1} for env `E` from merged worker D1 config +\n * hydrated state. Uses the same binding/name resolution path as wrangler\n * generation (`d1DeriveBindingKey`, state `bindingKey`, ownership helpers).\n */\nexport function buildShardRegistryV1(\n resources: D1ResourceConfig[],\n env: string,\n state: StateManager,\n naming: NamingEngine,\n): ShardRegistryV1 {\n const shards: ShardRegistryEntryV1[] = [];\n\n for (const config of resources) {\n if (config.type === \"single\") {\n const derivedName = d1CloudflareDatabaseName(config, env, naming);\n const entry = state.get(derivedName);\n if (!entry || entry.type !== \"d1_database\") {\n if (d1SkipsProvisionAndMigrate(config)) {\n throw new Error(\n `shard registry: cross-stack D1 \"${config.logicalName}\" (${derivedName}) not in state — ` +\n `deploy the owning stack first, then re-run apply for env \"${env}\".`,\n );\n }\n throw new Error(\n `shard registry: D1 \"${config.logicalName}\" not in state — run \\`tamer apply --env ${env}\\` first.`,\n );\n }\n shards.push(\n entryFromState(\n config,\n derivedName,\n entry.bindingKey,\n ),\n );\n continue;\n }\n\n const allResources = state.getAll();\n const stateShards = Object.values(allResources).filter(\n (e): e is D1StateEntry =>\n e.type === \"d1_database\" && e.logicalName === config.logicalName,\n );\n if (stateShards.length === 0) {\n throw new Error(\n `shard registry: no shards in state for \"${config.logicalName}\" — run \\`tamer apply --env ${env}\\` first.`,\n );\n }\n\n for (const shard of stateShards) {\n shards.push(\n entryFromState(\n config,\n shard.derivedName,\n shard.bindingKey,\n shard.shardDate,\n ),\n );\n }\n }\n\n shards.sort((a, b) => a.binding.localeCompare(b.binding));\n\n return { version: 1, shards };\n}\n\nexport class ShardRegistryDriftError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"ShardRegistryDriftError\";\n }\n}\n\n/**\n * Assert generated wrangler D1 bindings match the registry for apply env `E`.\n */\nexport function assertShardRegistryWranglerDrift(\n registry: ShardRegistryV1,\n wranglerD1: WranglerD1Database[] | undefined,\n env: string,\n): void {\n const d1List = wranglerD1 ?? [];\n const byBinding = new Map(registry.shards.map((s) => [s.binding, s]));\n\n for (const d1 of d1List) {\n const row = byBinding.get(d1.binding);\n if (!row) {\n throw new ShardRegistryDriftError(\n `shard registry drift (${env}): wrangler binding \"${d1.binding}\" has no registry row — ` +\n `re-run \\`tamer apply --env ${env}\\` or fix resources.d1 / state.`,\n );\n }\n if (d1.database_name !== row.databaseName) {\n throw new ShardRegistryDriftError(\n `shard registry drift (${env}): binding \"${d1.binding}\" wrangler database_name ` +\n `\"${d1.database_name}\" !== registry databaseName \"${row.databaseName}\".`,\n );\n }\n if (d1.database_name !== row.id) {\n throw new ShardRegistryDriftError(\n `shard registry drift (${env}): binding \"${d1.binding}\" wrangler database_name ` +\n `\"${d1.database_name}\" !== registry id \"${row.id}\".`,\n );\n }\n byBinding.delete(d1.binding);\n }\n\n for (const [binding, row] of byBinding) {\n throw new ShardRegistryDriftError(\n `shard registry drift (${env}): registry binding \"${binding}\" (${row.role}) ` +\n `missing from generated wrangler d1_databases — re-run \\`tamer apply --env ${env}\\`.`,\n );\n }\n}\n","import { existsSync, mkdirSync, writeFileSync } from \"fs\";\nimport { dirname, join } from \"path\";\nimport type { WranglerConfig } from \"../../../generated/wrangler-types.js\";\nimport type { NamingEngine } from \"../../naming/NamingEngine.js\";\nimport type { StateManager } from \"../../state/StateManager.js\";\nimport { resolveWorkerConfig } from \"../../config/resolver.js\";\nimport type {\n CfiConfig,\n ShardRegistryCodegenConfig,\n WorkerConfig,\n} from \"../../../types.js\";\nimport {\n assertShardRegistryWranglerDrift,\n buildShardRegistryV1,\n} from \"./build.js\";\n\nconst DEFAULT_OUT_FILE = \"src/db/shard-registry.ts\";\nconst DEFAULT_EXPORT_NAME = \"shardRegistry\";\n\nexport function resolveShardRegistryWorkerKey(\n workers: Array<[string, WorkerConfig]>,\n spec?: ShardRegistryCodegenConfig,\n): string {\n if (spec?.worker) {\n const hit = workers.find(([key]) => key === spec.worker);\n if (!hit) {\n throw new Error(\n `codegen.shardRegistry.worker \"${spec.worker}\" not found in stack workers`,\n );\n }\n return spec.worker;\n }\n if (workers.length === 1) {\n return workers[0]![0];\n }\n throw new Error(\n \"codegen.shardRegistry.worker is required when the stack declares multiple workers\",\n );\n}\n\nexport function shardRegistryOutPath(\n workerDir: string,\n spec?: ShardRegistryCodegenConfig,\n): string {\n return join(workerDir, spec?.outFile?.trim() || DEFAULT_OUT_FILE);\n}\n\nexport function renderShardRegistryModule(\n registry: ReturnType<typeof buildShardRegistryV1>,\n env: string,\n exportName: string = DEFAULT_EXPORT_NAME,\n): string {\n const body = JSON.stringify(registry, null, 2);\n return `/** Generated by @dragonmastery/tamer — do not edit. Re-run \\`tamer apply --env ${env}\\`. */\nimport type { ShardRegistryV1 } from \"@dragonmastery/tamer\";\n\nexport const ${exportName}: ShardRegistryV1 = ${body};\n`;\n}\n\nexport function writeShardRegistryModule(\n workerDir: string,\n content: string,\n spec?: ShardRegistryCodegenConfig,\n): string {\n const path = shardRegistryOutPath(workerDir, spec);\n mkdirSync(dirname(path), { recursive: true });\n writeFileSync(path, content, \"utf-8\");\n return path;\n}\n\nexport async function emitShardRegistryOnApply(args: {\n config: CfiConfig;\n env: string;\n baseDir: string;\n accountId: string;\n naming: NamingEngine;\n state: StateManager;\n imports: Awaited<\n ReturnType<\n typeof import(\"../../imports/fetchStackImports.js\").fetchStackImports\n >\n >;\n workers: Array<[string, WorkerConfig]>;\n wranglerByWorker: Map<string, WranglerConfig>;\n}): Promise<string | undefined> {\n const spec = args.config.codegen?.shardRegistry;\n if (!spec) return undefined;\n\n const workerKey = resolveShardRegistryWorkerKey(args.workers, spec);\n const workerEntry = args.workers.find(([key]) => key === workerKey);\n if (!workerEntry) {\n throw new Error(`codegen.shardRegistry: worker \"${workerKey}\" not found`);\n }\n const [, workerConfig] = workerEntry;\n\n const resolved = await resolveWorkerConfig(\n args.config,\n workerKey,\n workerConfig,\n args.env,\n args.baseDir,\n args.accountId,\n args.naming,\n args.state,\n { imports: args.imports },\n );\n const d1Resources = resolved.resources?.d1 ?? [];\n if (d1Resources.length === 0) {\n throw new Error(\n `codegen.shardRegistry: worker \"${workerKey}\" has no resources.d1 entries`,\n );\n }\n\n const registry = buildShardRegistryV1(\n d1Resources,\n args.env,\n args.state,\n args.naming,\n );\n\n const wrangler = args.wranglerByWorker.get(workerKey);\n if (!wrangler) {\n throw new Error(\n `codegen.shardRegistry: missing generated wrangler config for worker \"${workerKey}\"`,\n );\n }\n assertShardRegistryWranglerDrift(registry, wrangler.d1_databases, args.env);\n\n const exportName = spec.exportName?.trim() || DEFAULT_EXPORT_NAME;\n const content = renderShardRegistryModule(registry, args.env, exportName);\n const written = writeShardRegistryModule(resolved.workerDir, content, spec);\n console.log(\n `Generated shard registry for ${workerKey}: ${spec.outFile ?? DEFAULT_OUT_FILE}`,\n );\n return written;\n}\n\nexport async function assertShardRegistryPresentForDeploy(args: {\n config: CfiConfig;\n env: string;\n baseDir: string;\n accountId: string;\n naming: NamingEngine;\n state: StateManager;\n imports: Awaited<\n ReturnType<\n typeof import(\"../../imports/fetchStackImports.js\").fetchStackImports\n >\n >;\n workers: Array<[string, WorkerConfig]>;\n}): Promise<void> {\n const spec = args.config.codegen?.shardRegistry;\n if (!spec) return;\n\n const workerKey = resolveShardRegistryWorkerKey(args.workers, spec);\n const workerEntry = args.workers.find(([key]) => key === workerKey);\n if (!workerEntry) {\n throw new Error(`codegen.shardRegistry: worker \"${workerKey}\" not found`);\n }\n const [, workerConfig] = workerEntry;\n\n const resolved = await resolveWorkerConfig(\n args.config,\n workerKey,\n workerConfig,\n args.env,\n args.baseDir,\n args.accountId,\n args.naming,\n args.state,\n { imports: args.imports },\n );\n const path = shardRegistryOutPath(resolved.workerDir, spec);\n if (!existsSync(path)) {\n throw new Error(\n `Missing shard registry at ${spec.outFile ?? DEFAULT_OUT_FILE} for worker \"${workerKey}\". ` +\n `Run \\`tamer apply --env ${args.env}\\` before deploy.`,\n );\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"emit-DDH99lzS.mjs","names":["row: ShardRegistryEntryV1","shards: ShardRegistryEntryV1[]"],"sources":["../src/core/codegen/shardRegistry/build.ts","../src/core/codegen/shardRegistry/emit.ts"],"sourcesContent":["import type { WranglerD1Database } from \"../../../generated/wrangler-types.js\";\nimport type { NamingEngine } from \"../../naming/NamingEngine.js\";\nimport type { StateManager } from \"../../state/StateManager.js\";\nimport type {\n D1ResourceConfig,\n D1StateEntry,\n ShardRegistryEntryV1,\n ShardRegistryV1,\n} from \"../../../types.js\";\nimport {\n d1CloudflareDatabaseName,\n d1SkipsProvisionAndMigrate,\n} from \"../../../features/d1/d1.ownership.js\";\n\nfunction registryRoleFor(config: D1ResourceConfig): string {\n return config.registryRole?.trim() || config.logicalName;\n}\n\nfunction optionalAliases(values: string[] | undefined): string[] | undefined {\n if (!values?.length) return undefined;\n const trimmed = values.map((v) => v.trim()).filter(Boolean);\n return trimmed.length > 0 ? trimmed : undefined;\n}\n\nfunction entryFromState(\n config: D1ResourceConfig,\n databaseName: string,\n binding: string,\n shardDate?: string,\n): ShardRegistryEntryV1 {\n const row: ShardRegistryEntryV1 = {\n id: databaseName,\n role: registryRoleFor(config),\n binding,\n databaseName,\n };\n if (shardDate) row.shardDate = shardDate;\n if (config.current === false) row.current = false;\n const legacyIds = optionalAliases(config.legacyIds);\n const legacyBindings = optionalAliases(config.legacyBindings);\n if (legacyIds) row.legacyIds = legacyIds;\n if (legacyBindings) row.legacyBindings = legacyBindings;\n return row;\n}\n\n/**\n * Build {@link ShardRegistryV1} for env `E` from merged worker D1 config +\n * hydrated state. Uses the same binding/name resolution path as wrangler\n * generation (`d1DeriveBindingKey`, state `bindingKey`, ownership helpers).\n */\nexport function buildShardRegistryV1(\n resources: D1ResourceConfig[],\n env: string,\n state: StateManager,\n naming: NamingEngine,\n): ShardRegistryV1 {\n const shards: ShardRegistryEntryV1[] = [];\n\n for (const config of resources) {\n if (config.type === \"single\") {\n const derivedName = d1CloudflareDatabaseName(config, env, naming);\n const entry = state.get(derivedName);\n if (!entry || entry.type !== \"d1_database\") {\n if (d1SkipsProvisionAndMigrate(config)) {\n throw new Error(\n `shard registry: cross-stack D1 \"${config.logicalName}\" (${derivedName}) not in state — ` +\n `deploy the owning stack first, then re-run apply for env \"${env}\".`,\n );\n }\n throw new Error(\n `shard registry: D1 \"${config.logicalName}\" not in state — run \\`tamer apply --env ${env}\\` first.`,\n );\n }\n shards.push(\n entryFromState(\n config,\n derivedName,\n entry.bindingKey,\n ),\n );\n continue;\n }\n\n const allResources = state.getAll();\n const stateShards = Object.values(allResources).filter(\n (e): e is D1StateEntry =>\n e.type === \"d1_database\" && e.logicalName === config.logicalName,\n );\n if (stateShards.length === 0) {\n throw new Error(\n `shard registry: no shards in state for \"${config.logicalName}\" — run \\`tamer apply --env ${env}\\` first.`,\n );\n }\n\n for (const shard of stateShards) {\n shards.push(\n entryFromState(\n config,\n shard.derivedName,\n shard.bindingKey,\n shard.shardDate,\n ),\n );\n }\n }\n\n shards.sort((a, b) => a.binding.localeCompare(b.binding));\n\n return { version: 1, shards };\n}\n\nexport class ShardRegistryDriftError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"ShardRegistryDriftError\";\n }\n}\n\n/**\n * Assert generated wrangler D1 bindings match the registry for apply env `E`.\n */\nexport function assertShardRegistryWranglerDrift(\n registry: ShardRegistryV1,\n wranglerD1: WranglerD1Database[] | undefined,\n env: string,\n): void {\n const d1List = wranglerD1 ?? [];\n const byBinding = new Map(registry.shards.map((s) => [s.binding, s]));\n\n for (const d1 of d1List) {\n const row = byBinding.get(d1.binding);\n if (!row) {\n throw new ShardRegistryDriftError(\n `shard registry drift (${env}): wrangler binding \"${d1.binding}\" has no registry row — ` +\n `re-run \\`tamer apply --env ${env}\\` or fix resources.d1 / state.`,\n );\n }\n if (d1.database_name !== row.databaseName) {\n throw new ShardRegistryDriftError(\n `shard registry drift (${env}): binding \"${d1.binding}\" wrangler database_name ` +\n `\"${d1.database_name}\" !== registry databaseName \"${row.databaseName}\".`,\n );\n }\n if (d1.database_name !== row.id) {\n throw new ShardRegistryDriftError(\n `shard registry drift (${env}): binding \"${d1.binding}\" wrangler database_name ` +\n `\"${d1.database_name}\" !== registry id \"${row.id}\".`,\n );\n }\n byBinding.delete(d1.binding);\n }\n\n for (const [binding, row] of byBinding) {\n throw new ShardRegistryDriftError(\n `shard registry drift (${env}): registry binding \"${binding}\" (${row.role}) ` +\n `missing from generated wrangler d1_databases — re-run \\`tamer apply --env ${env}\\`.`,\n );\n }\n}\n","import { existsSync, mkdirSync, writeFileSync } from \"fs\";\nimport { dirname, join } from \"path\";\nimport type { WranglerConfig } from \"../../../generated/wrangler-types.js\";\nimport type { NamingEngine } from \"../../naming/NamingEngine.js\";\nimport type { StateManager } from \"../../state/StateManager.js\";\nimport { resolveWorkerConfig } from \"../../config/resolver.js\";\nimport type {\n CfiConfig,\n ShardRegistryCodegenConfig,\n WorkerConfig,\n} from \"../../../types.js\";\nimport {\n assertShardRegistryWranglerDrift,\n buildShardRegistryV1,\n} from \"./build.js\";\n\nconst DEFAULT_OUT_FILE = \"src/db/shard-registry.ts\";\nconst DEFAULT_EXPORT_NAME = \"shardRegistry\";\n\nexport function resolveShardRegistryWorkerKey(\n workers: Array<[string, WorkerConfig]>,\n spec?: ShardRegistryCodegenConfig,\n): string {\n if (spec?.worker) {\n const hit = workers.find(([key]) => key === spec.worker);\n if (!hit) {\n throw new Error(\n `codegen.shardRegistry.worker \"${spec.worker}\" not found in stack workers`,\n );\n }\n return spec.worker;\n }\n if (workers.length === 1) {\n return workers[0]![0];\n }\n throw new Error(\n \"codegen.shardRegistry.worker is required when the stack declares multiple workers\",\n );\n}\n\nexport function shardRegistryOutPath(\n workerDir: string,\n spec?: ShardRegistryCodegenConfig,\n): string {\n return join(workerDir, spec?.outFile?.trim() || DEFAULT_OUT_FILE);\n}\n\nexport function renderShardRegistryModule(\n registry: ReturnType<typeof buildShardRegistryV1>,\n env: string,\n exportName: string = DEFAULT_EXPORT_NAME,\n): string {\n const body = JSON.stringify(registry, null, 2);\n return `/** Generated by @dragonmastery/tamer — do not edit. Re-run \\`tamer apply --env ${env}\\`. */\nimport type { ShardRegistryV1 } from \"@dragonmastery/tamer\";\n\nexport const ${exportName}: ShardRegistryV1 = ${body};\n`;\n}\n\nexport function writeShardRegistryModule(\n workerDir: string,\n content: string,\n spec?: ShardRegistryCodegenConfig,\n): string {\n const path = shardRegistryOutPath(workerDir, spec);\n mkdirSync(dirname(path), { recursive: true });\n writeFileSync(path, content, \"utf-8\");\n return path;\n}\n\nexport async function emitShardRegistryOnApply(args: {\n config: CfiConfig;\n env: string;\n baseDir: string;\n accountId: string;\n naming: NamingEngine;\n state: StateManager;\n imports: Awaited<\n ReturnType<\n typeof import(\"../../imports/fetchStackImports.js\").fetchStackImports\n >\n >;\n workers: Array<[string, WorkerConfig]>;\n wranglerByWorker: Map<string, WranglerConfig>;\n}): Promise<string | undefined> {\n const spec = args.config.codegen?.shardRegistry;\n if (!spec) return undefined;\n\n const workerKey = resolveShardRegistryWorkerKey(args.workers, spec);\n const workerEntry = args.workers.find(([key]) => key === workerKey);\n if (!workerEntry) {\n throw new Error(`codegen.shardRegistry: worker \"${workerKey}\" not found`);\n }\n const [, workerConfig] = workerEntry;\n\n const resolved = await resolveWorkerConfig(\n args.config,\n workerKey,\n workerConfig,\n args.env,\n args.baseDir,\n args.accountId,\n args.naming,\n args.state,\n { imports: args.imports },\n );\n const d1Resources = resolved.resources?.d1 ?? [];\n if (d1Resources.length === 0) {\n throw new Error(\n `codegen.shardRegistry: worker \"${workerKey}\" has no resources.d1 entries`,\n );\n }\n\n const registry = buildShardRegistryV1(\n d1Resources,\n args.env,\n args.state,\n args.naming,\n );\n\n const wrangler = args.wranglerByWorker.get(workerKey);\n if (!wrangler) {\n throw new Error(\n `codegen.shardRegistry: missing generated wrangler config for worker \"${workerKey}\"`,\n );\n }\n assertShardRegistryWranglerDrift(registry, wrangler.d1_databases, args.env);\n\n const exportName = spec.exportName?.trim() || DEFAULT_EXPORT_NAME;\n const content = renderShardRegistryModule(registry, args.env, exportName);\n const written = writeShardRegistryModule(resolved.workerDir, content, spec);\n console.log(\n `Generated shard registry for ${workerKey}: ${spec.outFile ?? DEFAULT_OUT_FILE}`,\n );\n return written;\n}\n\nexport async function assertShardRegistryPresentForDeploy(args: {\n config: CfiConfig;\n env: string;\n baseDir: string;\n accountId: string;\n naming: NamingEngine;\n state: StateManager;\n imports: Awaited<\n ReturnType<\n typeof import(\"../../imports/fetchStackImports.js\").fetchStackImports\n >\n >;\n workers: Array<[string, WorkerConfig]>;\n}): Promise<void> {\n const spec = args.config.codegen?.shardRegistry;\n if (!spec) return;\n\n const workerKey = resolveShardRegistryWorkerKey(args.workers, spec);\n const workerEntry = args.workers.find(([key]) => key === workerKey);\n if (!workerEntry) {\n throw new Error(`codegen.shardRegistry: worker \"${workerKey}\" not found`);\n }\n const [, workerConfig] = workerEntry;\n\n const resolved = await resolveWorkerConfig(\n args.config,\n workerKey,\n workerConfig,\n args.env,\n args.baseDir,\n args.accountId,\n args.naming,\n args.state,\n { imports: args.imports },\n );\n const path = shardRegistryOutPath(resolved.workerDir, spec);\n if (!existsSync(path)) {\n throw new Error(\n `Missing shard registry at ${spec.outFile ?? DEFAULT_OUT_FILE} for worker \"${workerKey}\". ` +\n `Run \\`tamer apply --env ${args.env}\\` before deploy.`,\n );\n }\n}\n"],"mappings":"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"}
@@ -1,13 +1,13 @@
1
- import { C as listEnvRows, F as isEphemeralEnv, R as CFApiClient, U as loadConfig, z as cloudflareAccountIdFromEnv } from "./tamer.mjs";
2
- import "./registry-CTerXUza.mjs";
3
- import "./r2S3EmptyBucket-DD81ZWQ7.mjs";
4
- import "./logpush-job-Dqlt-wEw.mjs";
5
- import "./worker-route-BapxsQyX.mjs";
6
- import "./sync-Dii9n2nJ.mjs";
7
- import "./cloudflareSnapshot-DqP8v_xG.mjs";
8
- import "./tamerArtifactsR2-B3X21TGV.mjs";
9
- import "./workers-D7ow_joN.mjs";
10
- import { runDestroy } from "./destroy-CesVkyxf.mjs";
1
+ import { $ as CFApiClient, B as isEphemeralEnv, O as listEnvRows, et as cloudflareAccountIdFromEnv, it as loadConfig } from "./tamer.mjs";
2
+ import "./registry-CRgobiU4.mjs";
3
+ import "./r2S3EmptyBucket-CDE2lTM8.mjs";
4
+ import "./logpush-job-DZG-3nkJ.mjs";
5
+ import "./worker-route-BPDAwUL0.mjs";
6
+ import "./sync-DqMMQ7mQ.mjs";
7
+ import "./cloudflareSnapshot-dKYupX1L.mjs";
8
+ import "./tamerArtifactsR2-BePICoT8.mjs";
9
+ import "./workers-D08-ri2Q.mjs";
10
+ import { runDestroy } from "./destroy-kkOR_ZBj.mjs";
11
11
 
12
12
  //#region src/cli/commands/env-gc.ts
13
13
  async function runEnvGc(options) {
@@ -119,4 +119,4 @@ function formatDuration(ms) {
119
119
 
120
120
  //#endregion
121
121
  export { runEnvGc };
122
- //# sourceMappingURL=env-gc-DE4EV7j7.mjs.map
122
+ //# sourceMappingURL=env-gc-DrXu7DlG.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"env-gc-DE4EV7j7.mjs","names":["result: GcResult"],"sources":["../src/cli/commands/env-gc.ts"],"sourcesContent":["import { loadConfig } from \"../../core/config/loader.js\";\nimport { cloudflareAccountIdFromEnv } from \"../../core/cloudflareEnv.js\";\nimport { CFApiClient } from \"../../core/api/CFApiClient.js\";\nimport { listEnvRows } from \"../../core/state/tamerStateDb.js\";\nimport { isEphemeralEnv } from \"../../features/dispatch-namespace/dispatch-namespace.resolve.js\";\nimport { runDestroy } from \"./destroy.js\";\n\ninterface GcResult {\n scanned: number;\n destroyed: Array<{ env: string; success: boolean; error?: string }>;\n}\n\nexport async function runEnvGc(options: {\n maxAge: string;\n force?: boolean;\n dryRun?: boolean;\n configPath?: string;\n json?: boolean;\n}): Promise<void> {\n const { maxAge, force, dryRun, configPath } = options;\n\n const maxAgeMs = parseDuration(maxAge);\n if (maxAgeMs === null) {\n throw new Error(\n `Invalid --max-age \"${maxAge}\". Use formats like \"72h\", \"3d\", \"30m\".`,\n );\n }\n\n const config = await loadConfig(configPath);\n const accountId =\n config.account_id ?? cloudflareAccountIdFromEnv();\n if (!accountId) {\n throw new Error(\n \"account_id required in config or CLOUDFLARE_ACCOUNT_ID env var\",\n );\n }\n\n const api = new CFApiClient(accountId);\n const allEnvs = await listEnvRows(api);\n\n const ephemeralEnvs = allEnvs.filter((e) =>\n isEphemeralEnv(e.env, config.tenant),\n );\n\n const now = Date.now();\n const stale = ephemeralEnvs.filter((e) => {\n if (!e.syncedAt) return true;\n const age = now - new Date(e.syncedAt).getTime();\n return age > maxAgeMs;\n });\n\n const result: GcResult = {\n scanned: ephemeralEnvs.length,\n destroyed: [],\n };\n\n if (options.json) {\n // For JSON output, collect results silently\n for (const env of stale) {\n if (dryRun) {\n result.destroyed.push({ env: env.env, success: true });\n continue;\n }\n try {\n await runDestroy({\n env: env.env,\n force: true,\n confirmEnv: env.env,\n wipeMetadata: true,\n configPath,\n });\n result.destroyed.push({ env: env.env, success: true });\n } catch (err) {\n result.destroyed.push({\n env: env.env,\n success: false,\n error: err instanceof Error ? err.message : String(err),\n });\n }\n }\n console.log(JSON.stringify(result, null, 2));\n return;\n }\n\n const maxAgeLabel = formatDuration(maxAgeMs);\n console.log(\n `\\nScanning for ephemeral envs older than ${maxAgeLabel}...`,\n );\n console.log(`Found ${ephemeralEnvs.length} ephemeral env(s), ${stale.length} stale.`);\n\n if (stale.length === 0) {\n console.log(\"Nothing to clean up.\\n\");\n return;\n }\n\n const envList = stale.map((e) => e.env).join(\", \");\n if (dryRun) {\n console.log(`\\nDry run — would destroy: ${envList}\\n`);\n return;\n }\n\n for (const env of stale) {\n console.log(`\\nDestroying ${env.env}...`);\n try {\n await runDestroy({\n env: env.env,\n force: true,\n confirmEnv: env.env,\n wipeMetadata: true,\n configPath,\n });\n result.destroyed.push({ env: env.env, success: true });\n console.log(`✓ Destroyed ${env.env}`);\n } catch (err) {\n const msg = err instanceof Error ? err.message : String(err);\n result.destroyed.push({ env: env.env, success: false, error: msg });\n console.warn(`✗ Failed to destroy ${env.env}: ${msg}`);\n }\n }\n\n const succeeded = result.destroyed.filter((d) => d.success).length;\n const failed = result.destroyed.filter((d) => !d.success).length;\n console.log(\n `\\nGC complete: ${succeeded} env(s) destroyed, ${failed} failed.\\n`,\n );\n}\n\nfunction parseDuration(s: string): number | null {\n const m = s.match(/^(\\d+)([hmd])$/);\n if (!m) return null;\n const n = parseInt(m[1]!, 10);\n const unit = m[2];\n switch (unit) {\n case \"m\": return n * 60 * 1000;\n case \"h\": return n * 3600 * 1000;\n case \"d\": return n * 86400 * 1000;\n default: return null;\n }\n}\n\nfunction formatDuration(ms: number): string {\n const hours = Math.round(ms / 3600000);\n if (hours >= 24) return `${Math.round(hours / 24)}d`;\n return `${hours}h`;\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"env-gc-DrXu7DlG.mjs","names":["result: GcResult"],"sources":["../src/cli/commands/env-gc.ts"],"sourcesContent":["import { loadConfig } from \"../../core/config/loader.js\";\nimport { cloudflareAccountIdFromEnv } from \"../../core/cloudflareEnv.js\";\nimport { CFApiClient } from \"../../core/api/CFApiClient.js\";\nimport { listEnvRows } from \"../../core/state/tamerStateDb.js\";\nimport { isEphemeralEnv } from \"../../features/dispatch-namespace/dispatch-namespace.resolve.js\";\nimport { runDestroy } from \"./destroy.js\";\n\ninterface GcResult {\n scanned: number;\n destroyed: Array<{ env: string; success: boolean; error?: string }>;\n}\n\nexport async function runEnvGc(options: {\n maxAge: string;\n force?: boolean;\n dryRun?: boolean;\n configPath?: string;\n json?: boolean;\n}): Promise<void> {\n const { maxAge, force, dryRun, configPath } = options;\n\n const maxAgeMs = parseDuration(maxAge);\n if (maxAgeMs === null) {\n throw new Error(\n `Invalid --max-age \"${maxAge}\". Use formats like \"72h\", \"3d\", \"30m\".`,\n );\n }\n\n const config = await loadConfig(configPath);\n const accountId =\n config.account_id ?? cloudflareAccountIdFromEnv();\n if (!accountId) {\n throw new Error(\n \"account_id required in config or CLOUDFLARE_ACCOUNT_ID env var\",\n );\n }\n\n const api = new CFApiClient(accountId);\n const allEnvs = await listEnvRows(api);\n\n const ephemeralEnvs = allEnvs.filter((e) =>\n isEphemeralEnv(e.env, config.tenant),\n );\n\n const now = Date.now();\n const stale = ephemeralEnvs.filter((e) => {\n if (!e.syncedAt) return true;\n const age = now - new Date(e.syncedAt).getTime();\n return age > maxAgeMs;\n });\n\n const result: GcResult = {\n scanned: ephemeralEnvs.length,\n destroyed: [],\n };\n\n if (options.json) {\n // For JSON output, collect results silently\n for (const env of stale) {\n if (dryRun) {\n result.destroyed.push({ env: env.env, success: true });\n continue;\n }\n try {\n await runDestroy({\n env: env.env,\n force: true,\n confirmEnv: env.env,\n wipeMetadata: true,\n configPath,\n });\n result.destroyed.push({ env: env.env, success: true });\n } catch (err) {\n result.destroyed.push({\n env: env.env,\n success: false,\n error: err instanceof Error ? err.message : String(err),\n });\n }\n }\n console.log(JSON.stringify(result, null, 2));\n return;\n }\n\n const maxAgeLabel = formatDuration(maxAgeMs);\n console.log(\n `\\nScanning for ephemeral envs older than ${maxAgeLabel}...`,\n );\n console.log(`Found ${ephemeralEnvs.length} ephemeral env(s), ${stale.length} stale.`);\n\n if (stale.length === 0) {\n console.log(\"Nothing to clean up.\\n\");\n return;\n }\n\n const envList = stale.map((e) => e.env).join(\", \");\n if (dryRun) {\n console.log(`\\nDry run — would destroy: ${envList}\\n`);\n return;\n }\n\n for (const env of stale) {\n console.log(`\\nDestroying ${env.env}...`);\n try {\n await runDestroy({\n env: env.env,\n force: true,\n confirmEnv: env.env,\n wipeMetadata: true,\n configPath,\n });\n result.destroyed.push({ env: env.env, success: true });\n console.log(`✓ Destroyed ${env.env}`);\n } catch (err) {\n const msg = err instanceof Error ? err.message : String(err);\n result.destroyed.push({ env: env.env, success: false, error: msg });\n console.warn(`✗ Failed to destroy ${env.env}: ${msg}`);\n }\n }\n\n const succeeded = result.destroyed.filter((d) => d.success).length;\n const failed = result.destroyed.filter((d) => !d.success).length;\n console.log(\n `\\nGC complete: ${succeeded} env(s) destroyed, ${failed} failed.\\n`,\n );\n}\n\nfunction parseDuration(s: string): number | null {\n const m = s.match(/^(\\d+)([hmd])$/);\n if (!m) return null;\n const n = parseInt(m[1]!, 10);\n const unit = m[2];\n switch (unit) {\n case \"m\": return n * 60 * 1000;\n case \"h\": return n * 3600 * 1000;\n case \"d\": return n * 86400 * 1000;\n default: return null;\n }\n}\n\nfunction formatDuration(ms: number): string {\n const hours = Math.round(ms / 3600000);\n if (hours >= 24) return `${Math.round(hours / 24)}d`;\n return `${hours}h`;\n}\n"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- import { C as listEnvRows, R as CFApiClient, U as loadConfig, z as cloudflareAccountIdFromEnv } from "./tamer.mjs";
1
+ import { $ as CFApiClient, O as listEnvRows, et as cloudflareAccountIdFromEnv, it as loadConfig } from "./tamer.mjs";
2
2
 
3
3
  //#region src/cli/commands/env-list.ts
4
4
  async function runEnvList(options) {
@@ -29,4 +29,4 @@ async function runEnvList(options) {
29
29
 
30
30
  //#endregion
31
31
  export { runEnvList };
32
- //# sourceMappingURL=env-list-DKseThiA.mjs.map
32
+ //# sourceMappingURL=env-list-D-wnLl8W.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"env-list-DKseThiA.mjs","names":[],"sources":["../src/cli/commands/env-list.ts"],"sourcesContent":["import { loadConfig } from \"../../core/config/loader.js\";\nimport { cloudflareAccountIdFromEnv } from \"../../core/cloudflareEnv.js\";\nimport { CFApiClient } from \"../../core/api/CFApiClient.js\";\nimport { listEnvRows, type EnvRowInfo } from \"../../core/state/tamerStateDb.js\";\n\nexport async function runEnvList(options: {\n configPath?: string;\n json?: boolean;\n}): Promise<void> {\n const config = await loadConfig(options.configPath);\n const accountId =\n config.account_id ?? cloudflareAccountIdFromEnv();\n if (!accountId) {\n throw new Error(\n \"account_id required in config or CLOUDFLARE_ACCOUNT_ID env var\",\n );\n }\n\n const api = new CFApiClient(accountId);\n const envs = await listEnvRows(api);\n\n if (options.json) {\n console.log(JSON.stringify(envs, null, 2));\n return;\n }\n\n if (envs.length === 0) {\n console.log(\"No environments found in state.\");\n return;\n }\n\n const ephemeralPattern = config.tenant.ephemeralEnvPattern;\n const now = Date.now();\n\n console.log(\n `\\n${\"Env\".padEnd(20)} ${\"Stack\".padEnd(12)} ${\"Resources\".padEnd(10)} ${\"Last Activity\".padEnd(26)} Status`,\n );\n console.log(`${\"─\".repeat(20)} ${\"─\".repeat(12)} ${\"─\".repeat(10)} ${\"─\".repeat(26)} ${\"─\".repeat(10)}`);\n\n for (const env of envs.sort((a, b) => a.env.localeCompare(b.env))) {\n const isEphemeral = ephemeralPattern\n ? new RegExp(ephemeralPattern).test(env.env)\n : false;\n const tag = isEphemeral ? \" (ephemeral)\" : \"\";\n const age = env.syncedAt\n ? `${Math.round((now - new Date(env.syncedAt).getTime()) / 3600000)}h ago`\n : \"unknown\";\n const status = env.lastOperationStatus ?? \"\";\n console.log(\n `${(env.env + tag).padEnd(20)} ${env.stackName.padEnd(12)} ${String(env.resourceCount).padEnd(10)} ${age.padEnd(26)} ${status}`,\n );\n }\n console.log(\"\");\n}\n"],"mappings":";;;AAKA,eAAsB,WAAW,SAGf;CAChB,MAAM,SAAS,MAAM,WAAW,QAAQ,WAAW;CACnD,MAAM,YACJ,OAAO,cAAc,4BAA4B;AACnD,KAAI,CAAC,UACH,OAAM,IAAI,MACR,iEACD;CAIH,MAAM,OAAO,MAAM,YADP,IAAI,YAAY,UAAU,CACH;AAEnC,KAAI,QAAQ,MAAM;AAChB,UAAQ,IAAI,KAAK,UAAU,MAAM,MAAM,EAAE,CAAC;AAC1C;;AAGF,KAAI,KAAK,WAAW,GAAG;AACrB,UAAQ,IAAI,kCAAkC;AAC9C;;CAGF,MAAM,mBAAmB,OAAO,OAAO;CACvC,MAAM,MAAM,KAAK,KAAK;AAEtB,SAAQ,IACN,KAAK,MAAM,OAAO,GAAG,CAAC,GAAG,QAAQ,OAAO,GAAG,CAAC,GAAG,YAAY,OAAO,GAAG,CAAC,GAAG,gBAAgB,OAAO,GAAG,CAAC,SACrG;AACD,SAAQ,IAAI,GAAG,IAAI,OAAO,GAAG,CAAC,GAAG,IAAI,OAAO,GAAG,CAAC,GAAG,IAAI,OAAO,GAAG,CAAC,GAAG,IAAI,OAAO,GAAG,CAAC,GAAG,IAAI,OAAO,GAAG,GAAG;AAExG,MAAK,MAAM,OAAO,KAAK,MAAM,GAAG,MAAM,EAAE,IAAI,cAAc,EAAE,IAAI,CAAC,EAAE;EAIjE,MAAM,OAHc,mBAChB,IAAI,OAAO,iBAAiB,CAAC,KAAK,IAAI,IAAI,GAC1C,SACsB,iBAAiB;EAC3C,MAAM,MAAM,IAAI,WACZ,GAAG,KAAK,OAAO,MAAM,IAAI,KAAK,IAAI,SAAS,CAAC,SAAS,IAAI,KAAQ,CAAC,SAClE;EACJ,MAAM,SAAS,IAAI,uBAAuB;AAC1C,UAAQ,IACN,IAAI,IAAI,MAAM,KAAK,OAAO,GAAG,CAAC,GAAG,IAAI,UAAU,OAAO,GAAG,CAAC,GAAG,OAAO,IAAI,cAAc,CAAC,OAAO,GAAG,CAAC,GAAG,IAAI,OAAO,GAAG,CAAC,GAAG,SACxH;;AAEH,SAAQ,IAAI,GAAG"}
1
+ {"version":3,"file":"env-list-D-wnLl8W.mjs","names":[],"sources":["../src/cli/commands/env-list.ts"],"sourcesContent":["import { loadConfig } from \"../../core/config/loader.js\";\nimport { cloudflareAccountIdFromEnv } from \"../../core/cloudflareEnv.js\";\nimport { CFApiClient } from \"../../core/api/CFApiClient.js\";\nimport { listEnvRows, type EnvRowInfo } from \"../../core/state/tamerStateDb.js\";\n\nexport async function runEnvList(options: {\n configPath?: string;\n json?: boolean;\n}): Promise<void> {\n const config = await loadConfig(options.configPath);\n const accountId =\n config.account_id ?? cloudflareAccountIdFromEnv();\n if (!accountId) {\n throw new Error(\n \"account_id required in config or CLOUDFLARE_ACCOUNT_ID env var\",\n );\n }\n\n const api = new CFApiClient(accountId);\n const envs = await listEnvRows(api);\n\n if (options.json) {\n console.log(JSON.stringify(envs, null, 2));\n return;\n }\n\n if (envs.length === 0) {\n console.log(\"No environments found in state.\");\n return;\n }\n\n const ephemeralPattern = config.tenant.ephemeralEnvPattern;\n const now = Date.now();\n\n console.log(\n `\\n${\"Env\".padEnd(20)} ${\"Stack\".padEnd(12)} ${\"Resources\".padEnd(10)} ${\"Last Activity\".padEnd(26)} Status`,\n );\n console.log(`${\"─\".repeat(20)} ${\"─\".repeat(12)} ${\"─\".repeat(10)} ${\"─\".repeat(26)} ${\"─\".repeat(10)}`);\n\n for (const env of envs.sort((a, b) => a.env.localeCompare(b.env))) {\n const isEphemeral = ephemeralPattern\n ? new RegExp(ephemeralPattern).test(env.env)\n : false;\n const tag = isEphemeral ? \" (ephemeral)\" : \"\";\n const age = env.syncedAt\n ? `${Math.round((now - new Date(env.syncedAt).getTime()) / 3600000)}h ago`\n : \"unknown\";\n const status = env.lastOperationStatus ?? \"\";\n console.log(\n `${(env.env + tag).padEnd(20)} ${env.stackName.padEnd(12)} ${String(env.resourceCount).padEnd(10)} ${age.padEnd(26)} ${status}`,\n );\n }\n console.log(\"\");\n}\n"],"mappings":";;;AAKA,eAAsB,WAAW,SAGf;CAChB,MAAM,SAAS,MAAM,WAAW,QAAQ,WAAW;CACnD,MAAM,YACJ,OAAO,cAAc,4BAA4B;AACnD,KAAI,CAAC,UACH,OAAM,IAAI,MACR,iEACD;CAIH,MAAM,OAAO,MAAM,YADP,IAAI,YAAY,UAAU,CACH;AAEnC,KAAI,QAAQ,MAAM;AAChB,UAAQ,IAAI,KAAK,UAAU,MAAM,MAAM,EAAE,CAAC;AAC1C;;AAGF,KAAI,KAAK,WAAW,GAAG;AACrB,UAAQ,IAAI,kCAAkC;AAC9C;;CAGF,MAAM,mBAAmB,OAAO,OAAO;CACvC,MAAM,MAAM,KAAK,KAAK;AAEtB,SAAQ,IACN,KAAK,MAAM,OAAO,GAAG,CAAC,GAAG,QAAQ,OAAO,GAAG,CAAC,GAAG,YAAY,OAAO,GAAG,CAAC,GAAG,gBAAgB,OAAO,GAAG,CAAC,SACrG;AACD,SAAQ,IAAI,GAAG,IAAI,OAAO,GAAG,CAAC,GAAG,IAAI,OAAO,GAAG,CAAC,GAAG,IAAI,OAAO,GAAG,CAAC,GAAG,IAAI,OAAO,GAAG,CAAC,GAAG,IAAI,OAAO,GAAG,GAAG;AAExG,MAAK,MAAM,OAAO,KAAK,MAAM,GAAG,MAAM,EAAE,IAAI,cAAc,EAAE,IAAI,CAAC,EAAE;EAIjE,MAAM,OAHc,mBAChB,IAAI,OAAO,iBAAiB,CAAC,KAAK,IAAI,IAAI,GAC1C,SACsB,iBAAiB;EAC3C,MAAM,MAAM,IAAI,WACZ,GAAG,KAAK,OAAO,MAAM,IAAI,KAAK,IAAI,SAAS,CAAC,SAAS,IAAI,KAAQ,CAAC,SAClE;EACJ,MAAM,SAAS,IAAI,uBAAuB;AAC1C,UAAQ,IACN,IAAI,IAAI,MAAM,KAAK,OAAO,GAAG,CAAC,GAAG,IAAI,UAAU,OAAO,GAAG,CAAC,GAAG,OAAO,IAAI,cAAc,CAAC,OAAO,GAAG,CAAC,GAAG,IAAI,OAAO,GAAG,CAAC,GAAG,SACxH;;AAEH,SAAQ,IAAI,GAAG"}
@@ -1,4 +1,4 @@
1
- import { R as CFApiClient, U as loadConfig, h as StateManager, w as stackNameForConfig, z as cloudflareAccountIdFromEnv } from "./tamer.mjs";
1
+ import { $ as CFApiClient, b as StateManager, et as cloudflareAccountIdFromEnv, it as loadConfig, k as stackNameForConfig } from "./tamer.mjs";
2
2
 
3
3
  //#region src/cli/commands/events.ts
4
4
  function formatDuration(startedAt, completedAt) {
@@ -63,4 +63,4 @@ async function runEvents(options) {
63
63
 
64
64
  //#endregion
65
65
  export { runEvents };
66
- //# sourceMappingURL=events-CqbN9sbT.mjs.map
66
+ //# sourceMappingURL=events-C86vo1gV.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"events-CqbN9sbT.mjs","names":[],"sources":["../src/cli/commands/events.ts"],"sourcesContent":["import { loadConfig } from \"../../core/config/loader.js\";\nimport { cloudflareAccountIdFromEnv } from \"../../core/cloudflareEnv.js\";\nimport { StateManager } from \"../../core/state/StateManager.js\";\nimport { stackNameForConfig } from \"../../core/state/stackName.js\";\nimport { CFApiClient } from \"../../core/api/CFApiClient.js\";\nimport type { CfiOperationRecord } from \"../../types.js\";\n\nfunction formatDuration(\n startedAt: string,\n completedAt: string | undefined,\n): string | undefined {\n if (!completedAt) return undefined;\n const a = Date.parse(startedAt);\n const b = Date.parse(completedAt);\n if (!Number.isFinite(a) || !Number.isFinite(b) || b < a) return undefined;\n const ms = b - a;\n if (ms < 1000) return `${ms}ms`;\n return `${(ms / 1000).toFixed(1)}s`;\n}\n\nfunction printOp(label: string, op: CfiOperationRecord): void {\n const dur = formatDuration(op.startedAt, op.completedAt);\n console.log(` [${label}] ${op.command}`);\n console.log(` started: ${op.startedAt}`);\n if (op.completedAt) {\n console.log(` completed: ${op.completedAt}`);\n }\n if (dur) console.log(` duration: ${dur}`);\n if (op.detail) console.log(` detail: ${op.detail}`);\n if (op.errorMessage) console.log(` error: ${op.errorMessage}`);\n console.log();\n}\n\n/**\n * Read-only: print recent completed stack operations from D1 state\n * (`operationHistory`) plus any in-progress marker (`lastOperation`).\n */\nexport async function runEvents(options: {\n env?: string;\n configPath?: string;\n limit?: number;\n json?: boolean;\n}): Promise<void> {\n const env = options.env ?? \"local\";\n const config = await loadConfig(options.configPath, { env });\n const accountId =\n config.account_id ?? cloudflareAccountIdFromEnv();\n if (!accountId) {\n throw new Error(\n \"account_id required in config or CLOUDFLARE_ACCOUNT_ID env var\",\n );\n }\n const stackName = stackNameForConfig(config);\n const api = new CFApiClient(accountId);\n const state = new StateManager(config.tenant.id, env, stackName);\n await state.hydrate(api);\n\n const last = state.getLastOperation();\n const inProgress =\n last?.status === \"in_progress\" ? last : undefined;\n let history = state.getOperationHistory();\n if (options.limit !== undefined) {\n history = history.slice(0, options.limit);\n }\n\n if (options.json) {\n const out = {\n stackName,\n env,\n tenantId: config.tenant.id,\n inProgress: inProgress ?? null,\n history,\n };\n console.log(JSON.stringify(out, null, 2));\n return;\n }\n\n console.log(\n `\\nStack events — ${config.tenant.name} (${config.tenant.slug}) — stack \"${stackName}\" env ${env}\\n`,\n );\n\n if (inProgress) {\n console.log(\"In progress:\\n\");\n printOp(\"in_progress\", inProgress);\n }\n\n if (history.length === 0) {\n console.log(\n inProgress\n ? \"(no completed operations in history yet)\\n\"\n : \"No completed operations recorded in state yet.\\n\",\n );\n return;\n }\n\n console.log(\"Recent completed operations (newest first):\\n\");\n for (const op of history) {\n printOp(op.status, op);\n }\n}\n"],"mappings":";;;AAOA,SAAS,eACP,WACA,aACoB;AACpB,KAAI,CAAC,YAAa,QAAO;CACzB,MAAM,IAAI,KAAK,MAAM,UAAU;CAC/B,MAAM,IAAI,KAAK,MAAM,YAAY;AACjC,KAAI,CAAC,OAAO,SAAS,EAAE,IAAI,CAAC,OAAO,SAAS,EAAE,IAAI,IAAI,EAAG,QAAO;CAChE,MAAM,KAAK,IAAI;AACf,KAAI,KAAK,IAAM,QAAO,GAAG,GAAG;AAC5B,QAAO,IAAI,KAAK,KAAM,QAAQ,EAAE,CAAC;;AAGnC,SAAS,QAAQ,OAAe,IAA8B;CAC5D,MAAM,MAAM,eAAe,GAAG,WAAW,GAAG,YAAY;AACxD,SAAQ,IAAI,MAAM,MAAM,IAAI,GAAG,UAAU;AACzC,SAAQ,IAAI,kBAAkB,GAAG,YAAY;AAC7C,KAAI,GAAG,YACL,SAAQ,IAAI,kBAAkB,GAAG,cAAc;AAEjD,KAAI,IAAK,SAAQ,IAAI,kBAAkB,MAAM;AAC7C,KAAI,GAAG,OAAQ,SAAQ,IAAI,kBAAkB,GAAG,SAAS;AACzD,KAAI,GAAG,aAAc,SAAQ,IAAI,kBAAkB,GAAG,eAAe;AACrE,SAAQ,KAAK;;;;;;AAOf,eAAsB,UAAU,SAKd;CAChB,MAAM,MAAM,QAAQ,OAAO;CAC3B,MAAM,SAAS,MAAM,WAAW,QAAQ,YAAY,EAAE,KAAK,CAAC;CAC5D,MAAM,YACJ,OAAO,cAAc,4BAA4B;AACnD,KAAI,CAAC,UACH,OAAM,IAAI,MACR,iEACD;CAEH,MAAM,YAAY,mBAAmB,OAAO;CAC5C,MAAM,MAAM,IAAI,YAAY,UAAU;CACtC,MAAM,QAAQ,IAAI,aAAa,OAAO,OAAO,IAAI,KAAK,UAAU;AAChE,OAAM,MAAM,QAAQ,IAAI;CAExB,MAAM,OAAO,MAAM,kBAAkB;CACrC,MAAM,aACJ,MAAM,WAAW,gBAAgB,OAAO;CAC1C,IAAI,UAAU,MAAM,qBAAqB;AACzC,KAAI,QAAQ,UAAU,OACpB,WAAU,QAAQ,MAAM,GAAG,QAAQ,MAAM;AAG3C,KAAI,QAAQ,MAAM;EAChB,MAAM,MAAM;GACV;GACA;GACA,UAAU,OAAO,OAAO;GACxB,YAAY,cAAc;GAC1B;GACD;AACD,UAAQ,IAAI,KAAK,UAAU,KAAK,MAAM,EAAE,CAAC;AACzC;;AAGF,SAAQ,IACN,oBAAoB,OAAO,OAAO,KAAK,IAAI,OAAO,OAAO,KAAK,aAAa,UAAU,QAAQ,IAAI,IAClG;AAED,KAAI,YAAY;AACd,UAAQ,IAAI,iBAAiB;AAC7B,UAAQ,eAAe,WAAW;;AAGpC,KAAI,QAAQ,WAAW,GAAG;AACxB,UAAQ,IACN,aACI,+CACA,mDACL;AACD;;AAGF,SAAQ,IAAI,gDAAgD;AAC5D,MAAK,MAAM,MAAM,QACf,SAAQ,GAAG,QAAQ,GAAG"}
1
+ {"version":3,"file":"events-C86vo1gV.mjs","names":[],"sources":["../src/cli/commands/events.ts"],"sourcesContent":["import { loadConfig } from \"../../core/config/loader.js\";\nimport { cloudflareAccountIdFromEnv } from \"../../core/cloudflareEnv.js\";\nimport { StateManager } from \"../../core/state/StateManager.js\";\nimport { stackNameForConfig } from \"../../core/state/stackName.js\";\nimport { CFApiClient } from \"../../core/api/CFApiClient.js\";\nimport type { CfiOperationRecord } from \"../../types.js\";\n\nfunction formatDuration(\n startedAt: string,\n completedAt: string | undefined,\n): string | undefined {\n if (!completedAt) return undefined;\n const a = Date.parse(startedAt);\n const b = Date.parse(completedAt);\n if (!Number.isFinite(a) || !Number.isFinite(b) || b < a) return undefined;\n const ms = b - a;\n if (ms < 1000) return `${ms}ms`;\n return `${(ms / 1000).toFixed(1)}s`;\n}\n\nfunction printOp(label: string, op: CfiOperationRecord): void {\n const dur = formatDuration(op.startedAt, op.completedAt);\n console.log(` [${label}] ${op.command}`);\n console.log(` started: ${op.startedAt}`);\n if (op.completedAt) {\n console.log(` completed: ${op.completedAt}`);\n }\n if (dur) console.log(` duration: ${dur}`);\n if (op.detail) console.log(` detail: ${op.detail}`);\n if (op.errorMessage) console.log(` error: ${op.errorMessage}`);\n console.log();\n}\n\n/**\n * Read-only: print recent completed stack operations from D1 state\n * (`operationHistory`) plus any in-progress marker (`lastOperation`).\n */\nexport async function runEvents(options: {\n env?: string;\n configPath?: string;\n limit?: number;\n json?: boolean;\n}): Promise<void> {\n const env = options.env ?? \"local\";\n const config = await loadConfig(options.configPath, { env });\n const accountId =\n config.account_id ?? cloudflareAccountIdFromEnv();\n if (!accountId) {\n throw new Error(\n \"account_id required in config or CLOUDFLARE_ACCOUNT_ID env var\",\n );\n }\n const stackName = stackNameForConfig(config);\n const api = new CFApiClient(accountId);\n const state = new StateManager(config.tenant.id, env, stackName);\n await state.hydrate(api);\n\n const last = state.getLastOperation();\n const inProgress =\n last?.status === \"in_progress\" ? last : undefined;\n let history = state.getOperationHistory();\n if (options.limit !== undefined) {\n history = history.slice(0, options.limit);\n }\n\n if (options.json) {\n const out = {\n stackName,\n env,\n tenantId: config.tenant.id,\n inProgress: inProgress ?? null,\n history,\n };\n console.log(JSON.stringify(out, null, 2));\n return;\n }\n\n console.log(\n `\\nStack events — ${config.tenant.name} (${config.tenant.slug}) — stack \"${stackName}\" env ${env}\\n`,\n );\n\n if (inProgress) {\n console.log(\"In progress:\\n\");\n printOp(\"in_progress\", inProgress);\n }\n\n if (history.length === 0) {\n console.log(\n inProgress\n ? \"(no completed operations in history yet)\\n\"\n : \"No completed operations recorded in state yet.\\n\",\n );\n return;\n }\n\n console.log(\"Recent completed operations (newest first):\\n\");\n for (const op of history) {\n printOp(op.status, op);\n }\n}\n"],"mappings":";;;AAOA,SAAS,eACP,WACA,aACoB;AACpB,KAAI,CAAC,YAAa,QAAO;CACzB,MAAM,IAAI,KAAK,MAAM,UAAU;CAC/B,MAAM,IAAI,KAAK,MAAM,YAAY;AACjC,KAAI,CAAC,OAAO,SAAS,EAAE,IAAI,CAAC,OAAO,SAAS,EAAE,IAAI,IAAI,EAAG,QAAO;CAChE,MAAM,KAAK,IAAI;AACf,KAAI,KAAK,IAAM,QAAO,GAAG,GAAG;AAC5B,QAAO,IAAI,KAAK,KAAM,QAAQ,EAAE,CAAC;;AAGnC,SAAS,QAAQ,OAAe,IAA8B;CAC5D,MAAM,MAAM,eAAe,GAAG,WAAW,GAAG,YAAY;AACxD,SAAQ,IAAI,MAAM,MAAM,IAAI,GAAG,UAAU;AACzC,SAAQ,IAAI,kBAAkB,GAAG,YAAY;AAC7C,KAAI,GAAG,YACL,SAAQ,IAAI,kBAAkB,GAAG,cAAc;AAEjD,KAAI,IAAK,SAAQ,IAAI,kBAAkB,MAAM;AAC7C,KAAI,GAAG,OAAQ,SAAQ,IAAI,kBAAkB,GAAG,SAAS;AACzD,KAAI,GAAG,aAAc,SAAQ,IAAI,kBAAkB,GAAG,eAAe;AACrE,SAAQ,KAAK;;;;;;AAOf,eAAsB,UAAU,SAKd;CAChB,MAAM,MAAM,QAAQ,OAAO;CAC3B,MAAM,SAAS,MAAM,WAAW,QAAQ,YAAY,EAAE,KAAK,CAAC;CAC5D,MAAM,YACJ,OAAO,cAAc,4BAA4B;AACnD,KAAI,CAAC,UACH,OAAM,IAAI,MACR,iEACD;CAEH,MAAM,YAAY,mBAAmB,OAAO;CAC5C,MAAM,MAAM,IAAI,YAAY,UAAU;CACtC,MAAM,QAAQ,IAAI,aAAa,OAAO,OAAO,IAAI,KAAK,UAAU;AAChE,OAAM,MAAM,QAAQ,IAAI;CAExB,MAAM,OAAO,MAAM,kBAAkB;CACrC,MAAM,aACJ,MAAM,WAAW,gBAAgB,OAAO;CAC1C,IAAI,UAAU,MAAM,qBAAqB;AACzC,KAAI,QAAQ,UAAU,OACpB,WAAU,QAAQ,MAAM,GAAG,QAAQ,MAAM;AAG3C,KAAI,QAAQ,MAAM;EAChB,MAAM,MAAM;GACV;GACA;GACA,UAAU,OAAO,OAAO;GACxB,YAAY,cAAc;GAC1B;GACD;AACD,UAAQ,IAAI,KAAK,UAAU,KAAK,MAAM,EAAE,CAAC;AACzC;;AAGF,SAAQ,IACN,oBAAoB,OAAO,OAAO,KAAK,IAAI,OAAO,OAAO,KAAK,aAAa,UAAU,QAAQ,IAAI,IAClG;AAED,KAAI,YAAY;AACd,UAAQ,IAAI,iBAAiB;AAC7B,UAAQ,eAAe,WAAW;;AAGpC,KAAI,QAAQ,WAAW,GAAG;AACxB,UAAQ,IACN,aACI,+CACA,mDACL;AACD;;AAGF,SAAQ,IAAI,gDAAgD;AAC5D,MAAK,MAAM,MAAM,QACf,SAAQ,GAAG,QAAQ,GAAG"}
@@ -0,0 +1,3 @@
1
+ import { l as secretValueFingerprint } from "./tamer.mjs";
2
+
3
+ export { };
@@ -1,4 +1,4 @@
1
- import { n as resourceModules, r as secretsStoreDeriveName } from "./registry-CTerXUza.mjs";
1
+ import { n as resourceModules, r as secretsStoreDeriveName } from "./registry-CRgobiU4.mjs";
2
2
  import { join } from "path";
3
3
  import { writeFileSync } from "fs";
4
4
 
@@ -75,4 +75,4 @@ function writeWranglerJson(workerDir, config, outFile = "wrangler.json") {
75
75
 
76
76
  //#endregion
77
77
  export { writeWranglerJson as n, generateWranglerConfig as t };
78
- //# sourceMappingURL=generator-CbH3UZ3K.mjs.map
78
+ //# sourceMappingURL=generator-Cu5XUkjr.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"generator-CbH3UZ3K.mjs","names":["out: GeneratedSecretsStoreSecretBinding[]","config: WranglerConfig"],"sources":["../src/features/secrets-store/secrets-store.generate.ts","../src/core/wrangler/generator.ts"],"sourcesContent":["import type { NamingEngine } from \"../../core/naming/NamingEngine.js\";\nimport type {\n StateEntry,\n SecretsStoreResourceConfig,\n SecretsStoreSecretBinding,\n SecretsStoreStateEntry,\n} from \"../../types.js\";\nimport { secretsStoreDeriveName } from \"./secrets-store.naming.js\";\n\nexport interface SecretsStoreStateLike {\n get(key: string): StateEntry | undefined;\n getAll(): Record<string, StateEntry>;\n}\n\n/**\n * One row of wrangler's `secrets_store_secrets[]` array. Resolved from a\n * worker's declared `secretsStoreSecrets[]` by looking up the\n * Tamer-managed store's `store_id` in state. The named secret itself must\n * already exist inside the store (created out-of-band via wrangler\n * `secrets-store secret create`); Tamer never reads or writes secret\n * values.\n */\nexport interface GeneratedSecretsStoreSecretBinding {\n binding: string;\n store_id: string;\n secret_name: string;\n}\n\n/**\n * Resolve `secretsStoreSecrets[]` worker bindings into wrangler-shape\n * `secrets_store_secrets[]` entries by looking up the referenced\n * Tamer-managed store's `store_id` in state. Throws with an actionable\n * message if a referenced store has never been applied — the binding\n * would otherwise be deployed against a non-existent store.\n */\nexport function secretsStoreSecretsGenerate(\n bindings: SecretsStoreSecretBinding[],\n env: string,\n state: SecretsStoreStateLike,\n naming: NamingEngine,\n secretsStores?: SecretsStoreResourceConfig[],\n): GeneratedSecretsStoreSecretBinding[] {\n const out: GeneratedSecretsStoreSecretBinding[] = [];\n for (const b of bindings) {\n const storeConfig = secretsStores?.find((s) => s.logicalName === b.store);\n const derivedName = storeConfig\n ? secretsStoreDeriveName(storeConfig, env, naming)\n : naming.secretsStoreName(b.store, env);\n const entry = state.get(`secrets_store:${derivedName}`) as\n | SecretsStoreStateEntry\n | undefined;\n if (!entry || entry.type !== \"secrets_store\") {\n throw new Error(\n `Secrets Store binding \"${b.binding}\" references store \"${b.store}\" — ` +\n `not in state. Declare it under \\`resources.secretsStores\\` and run ` +\n `'tamer apply --env ${env}' first.`,\n );\n }\n out.push({\n binding: b.binding,\n store_id: entry.cfId,\n secret_name: b.secretName,\n });\n }\n return out;\n}\n","import { writeFileSync } from \"fs\";\nimport { join } from \"path\";\nimport type { WranglerConfig } from \"../../generated/wrangler-types.js\";\nimport type { ResolvedWorkerConfig } from \"../config/resolver.js\";\nimport type { StateManager } from \"../state/StateManager.js\";\nimport type { NamingEngine } from \"../naming/NamingEngine.js\";\nimport { resourceModules } from \"../registry/registry.js\";\nimport { secretsStoreSecretsGenerate } from \"../../features/secrets-store/secrets-store.generate.js\";\n\nexport class CfiError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"CfiError\";\n }\n}\n\n/**\n * Build the worker's `wrangler.json` by asking every registered resource\n * module for its bindings fragment, then merging on top of the\n * passthrough config (`resolved.wranglerConfig`). Adding a new resource\n * kind requires zero edits here — register the module, done.\n */\nexport function generateWranglerConfig(\n resolved: ResolvedWorkerConfig,\n state: StateManager,\n naming: NamingEngine,\n): WranglerConfig {\n let config: WranglerConfig = {\n ...resolved.wranglerConfig,\n $schema: \"node_modules/wrangler/config-schema.json\",\n };\n\n const worker = {\n workerKey: resolved.workerKey,\n deployedName: resolved.workerName,\n };\n for (const mod of resourceModules) {\n const resources = mod.pickResources(resolved.resources);\n const fragment = mod.generate({\n resources,\n env: resolved.env,\n state,\n naming,\n passthrough: resolved.wranglerConfig,\n worker,\n });\n config = { ...config, ...fragment };\n }\n\n const secretBindings = resolved.resources?.secretsStoreSecrets ?? [];\n if (secretBindings.length > 0) {\n const passthroughSecrets =\n resolved.wranglerConfig.secrets_store_secrets ?? [];\n const generated = secretsStoreSecretsGenerate(\n secretBindings,\n resolved.env,\n state,\n naming,\n resolved.resources?.secretsStores,\n );\n config = {\n ...config,\n secrets_store_secrets: [...passthroughSecrets, ...generated],\n };\n }\n\n return config;\n}\n\nexport function writeWranglerJson(\n workerDir: string,\n config: WranglerConfig,\n outFile: string = \"wrangler.json\",\n): void {\n const path = join(workerDir, outFile);\n writeFileSync(path, JSON.stringify(config, null, 2), \"utf-8\");\n}\n"],"mappings":";;;;;;;;;;;;AAmCA,SAAgB,4BACd,UACA,KACA,OACA,QACA,eACsC;CACtC,MAAMA,MAA4C,EAAE;AACpD,MAAK,MAAM,KAAK,UAAU;EACxB,MAAM,cAAc,eAAe,MAAM,MAAM,EAAE,gBAAgB,EAAE,MAAM;EACzE,MAAM,cAAc,cAChB,uBAAuB,aAAa,KAAK,OAAO,GAChD,OAAO,iBAAiB,EAAE,OAAO,IAAI;EACzC,MAAM,QAAQ,MAAM,IAAI,iBAAiB,cAAc;AAGvD,MAAI,CAAC,SAAS,MAAM,SAAS,gBAC3B,OAAM,IAAI,MACR,0BAA0B,EAAE,QAAQ,sBAAsB,EAAE,MAAM,4FAE1C,IAAI,UAC7B;AAEH,MAAI,KAAK;GACP,SAAS,EAAE;GACX,UAAU,MAAM;GAChB,aAAa,EAAE;GAChB,CAAC;;AAEJ,QAAO;;;;;;;;;;;AC1CT,SAAgB,uBACd,UACA,OACA,QACgB;CAChB,IAAIC,SAAyB;EAC3B,GAAG,SAAS;EACZ,SAAS;EACV;CAED,MAAM,SAAS;EACb,WAAW,SAAS;EACpB,cAAc,SAAS;EACxB;AACD,MAAK,MAAM,OAAO,iBAAiB;EACjC,MAAM,YAAY,IAAI,cAAc,SAAS,UAAU;EACvD,MAAM,WAAW,IAAI,SAAS;GAC5B;GACA,KAAK,SAAS;GACd;GACA;GACA,aAAa,SAAS;GACtB;GACD,CAAC;AACF,WAAS;GAAE,GAAG;GAAQ,GAAG;GAAU;;CAGrC,MAAM,iBAAiB,SAAS,WAAW,uBAAuB,EAAE;AACpE,KAAI,eAAe,SAAS,GAAG;EAC7B,MAAM,qBACJ,SAAS,eAAe,yBAAyB,EAAE;EACrD,MAAM,YAAY,4BAChB,gBACA,SAAS,KACT,OACA,QACA,SAAS,WAAW,cACrB;AACD,WAAS;GACP,GAAG;GACH,uBAAuB,CAAC,GAAG,oBAAoB,GAAG,UAAU;GAC7D;;AAGH,QAAO;;AAGT,SAAgB,kBACd,WACA,QACA,UAAkB,iBACZ;AAEN,eADa,KAAK,WAAW,QAAQ,EACjB,KAAK,UAAU,QAAQ,MAAM,EAAE,EAAE,QAAQ"}
1
+ {"version":3,"file":"generator-Cu5XUkjr.mjs","names":["out: GeneratedSecretsStoreSecretBinding[]","config: WranglerConfig"],"sources":["../src/features/secrets-store/secrets-store.generate.ts","../src/core/wrangler/generator.ts"],"sourcesContent":["import type { NamingEngine } from \"../../core/naming/NamingEngine.js\";\nimport type {\n StateEntry,\n SecretsStoreResourceConfig,\n SecretsStoreSecretBinding,\n SecretsStoreStateEntry,\n} from \"../../types.js\";\nimport { secretsStoreDeriveName } from \"./secrets-store.naming.js\";\n\nexport interface SecretsStoreStateLike {\n get(key: string): StateEntry | undefined;\n getAll(): Record<string, StateEntry>;\n}\n\n/**\n * One row of wrangler's `secrets_store_secrets[]` array. Resolved from a\n * worker's declared `secretsStoreSecrets[]` by looking up the\n * Tamer-managed store's `store_id` in state. The named secret itself must\n * already exist inside the store (created out-of-band via wrangler\n * `secrets-store secret create`); Tamer never reads or writes secret\n * values.\n */\nexport interface GeneratedSecretsStoreSecretBinding {\n binding: string;\n store_id: string;\n secret_name: string;\n}\n\n/**\n * Resolve `secretsStoreSecrets[]` worker bindings into wrangler-shape\n * `secrets_store_secrets[]` entries by looking up the referenced\n * Tamer-managed store's `store_id` in state. Throws with an actionable\n * message if a referenced store has never been applied — the binding\n * would otherwise be deployed against a non-existent store.\n */\nexport function secretsStoreSecretsGenerate(\n bindings: SecretsStoreSecretBinding[],\n env: string,\n state: SecretsStoreStateLike,\n naming: NamingEngine,\n secretsStores?: SecretsStoreResourceConfig[],\n): GeneratedSecretsStoreSecretBinding[] {\n const out: GeneratedSecretsStoreSecretBinding[] = [];\n for (const b of bindings) {\n const storeConfig = secretsStores?.find((s) => s.logicalName === b.store);\n const derivedName = storeConfig\n ? secretsStoreDeriveName(storeConfig, env, naming)\n : naming.secretsStoreName(b.store, env);\n const entry = state.get(`secrets_store:${derivedName}`) as\n | SecretsStoreStateEntry\n | undefined;\n if (!entry || entry.type !== \"secrets_store\") {\n throw new Error(\n `Secrets Store binding \"${b.binding}\" references store \"${b.store}\" — ` +\n `not in state. Declare it under \\`resources.secretsStores\\` and run ` +\n `'tamer apply --env ${env}' first.`,\n );\n }\n out.push({\n binding: b.binding,\n store_id: entry.cfId,\n secret_name: b.secretName,\n });\n }\n return out;\n}\n","import { writeFileSync } from \"fs\";\nimport { join } from \"path\";\nimport type { WranglerConfig } from \"../../generated/wrangler-types.js\";\nimport type { ResolvedWorkerConfig } from \"../config/resolver.js\";\nimport type { StateManager } from \"../state/StateManager.js\";\nimport type { NamingEngine } from \"../naming/NamingEngine.js\";\nimport { resourceModules } from \"../registry/registry.js\";\nimport { secretsStoreSecretsGenerate } from \"../../features/secrets-store/secrets-store.generate.js\";\n\nexport class CfiError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"CfiError\";\n }\n}\n\n/**\n * Build the worker's `wrangler.json` by asking every registered resource\n * module for its bindings fragment, then merging on top of the\n * passthrough config (`resolved.wranglerConfig`). Adding a new resource\n * kind requires zero edits here — register the module, done.\n */\nexport function generateWranglerConfig(\n resolved: ResolvedWorkerConfig,\n state: StateManager,\n naming: NamingEngine,\n): WranglerConfig {\n let config: WranglerConfig = {\n ...resolved.wranglerConfig,\n $schema: \"node_modules/wrangler/config-schema.json\",\n };\n\n const worker = {\n workerKey: resolved.workerKey,\n deployedName: resolved.workerName,\n };\n for (const mod of resourceModules) {\n const resources = mod.pickResources(resolved.resources);\n const fragment = mod.generate({\n resources,\n env: resolved.env,\n state,\n naming,\n passthrough: resolved.wranglerConfig,\n worker,\n });\n config = { ...config, ...fragment };\n }\n\n const secretBindings = resolved.resources?.secretsStoreSecrets ?? [];\n if (secretBindings.length > 0) {\n const passthroughSecrets =\n resolved.wranglerConfig.secrets_store_secrets ?? [];\n const generated = secretsStoreSecretsGenerate(\n secretBindings,\n resolved.env,\n state,\n naming,\n resolved.resources?.secretsStores,\n );\n config = {\n ...config,\n secrets_store_secrets: [...passthroughSecrets, ...generated],\n };\n }\n\n return config;\n}\n\nexport function writeWranglerJson(\n workerDir: string,\n config: WranglerConfig,\n outFile: string = \"wrangler.json\",\n): void {\n const path = join(workerDir, outFile);\n writeFileSync(path, JSON.stringify(config, null, 2), \"utf-8\");\n}\n"],"mappings":";;;;;;;;;;;;AAmCA,SAAgB,4BACd,UACA,KACA,OACA,QACA,eACsC;CACtC,MAAMA,MAA4C,EAAE;AACpD,MAAK,MAAM,KAAK,UAAU;EACxB,MAAM,cAAc,eAAe,MAAM,MAAM,EAAE,gBAAgB,EAAE,MAAM;EACzE,MAAM,cAAc,cAChB,uBAAuB,aAAa,KAAK,OAAO,GAChD,OAAO,iBAAiB,EAAE,OAAO,IAAI;EACzC,MAAM,QAAQ,MAAM,IAAI,iBAAiB,cAAc;AAGvD,MAAI,CAAC,SAAS,MAAM,SAAS,gBAC3B,OAAM,IAAI,MACR,0BAA0B,EAAE,QAAQ,sBAAsB,EAAE,MAAM,4FAE1C,IAAI,UAC7B;AAEH,MAAI,KAAK;GACP,SAAS,EAAE;GACX,UAAU,MAAM;GAChB,aAAa,EAAE;GAChB,CAAC;;AAEJ,QAAO;;;;;;;;;;;AC1CT,SAAgB,uBACd,UACA,OACA,QACgB;CAChB,IAAIC,SAAyB;EAC3B,GAAG,SAAS;EACZ,SAAS;EACV;CAED,MAAM,SAAS;EACb,WAAW,SAAS;EACpB,cAAc,SAAS;EACxB;AACD,MAAK,MAAM,OAAO,iBAAiB;EACjC,MAAM,YAAY,IAAI,cAAc,SAAS,UAAU;EACvD,MAAM,WAAW,IAAI,SAAS;GAC5B;GACA,KAAK,SAAS;GACd;GACA;GACA,aAAa,SAAS;GACtB;GACD,CAAC;AACF,WAAS;GAAE,GAAG;GAAQ,GAAG;GAAU;;CAGrC,MAAM,iBAAiB,SAAS,WAAW,uBAAuB,EAAE;AACpE,KAAI,eAAe,SAAS,GAAG;EAC7B,MAAM,qBACJ,SAAS,eAAe,yBAAyB,EAAE;EACrD,MAAM,YAAY,4BAChB,gBACA,SAAS,KACT,OACA,QACA,SAAS,WAAW,cACrB;AACD,WAAS;GACP,GAAG;GACH,uBAAuB,CAAC,GAAG,oBAAoB,GAAG,UAAU;GAC7D;;AAGH,QAAO;;AAGT,SAAgB,kBACd,WACA,QACA,UAAkB,iBACZ;AAEN,eADa,KAAK,WAAW,QAAQ,EACjB,KAAK,UAAU,QAAQ,MAAM,EAAE,EAAE,QAAQ"}
@@ -1,7 +1,7 @@
1
- import { H as getWorkers, R as CFApiClient, U as loadConfig, V as getConfigBaseDir, f as fetchStackImports, h as StateManager, k as resolveWorkerConfig, u as namingFromConfig, w as stackNameForConfig, z as cloudflareAccountIdFromEnv } from "./tamer.mjs";
2
- import { n as resourceModules, t as getResourceModule } from "./registry-CTerXUza.mjs";
3
- import "./r2S3EmptyBucket-DD81ZWQ7.mjs";
4
- import { n as workerRouteStateKey, t as findZoneIdByName } from "./zoneResolver-CamXJpSB.mjs";
1
+ import { $ as CFApiClient, P as resolveWorkerConfig, _ as fetchStackImports, b as StateManager, et as cloudflareAccountIdFromEnv, h as namingFromConfig, it as loadConfig, k as stackNameForConfig, nt as getConfigBaseDir, rt as getWorkers } from "./tamer.mjs";
2
+ import { n as resourceModules, t as getResourceModule } from "./registry-CRgobiU4.mjs";
3
+ import "./r2S3EmptyBucket-CDE2lTM8.mjs";
4
+ import { n as workerRouteStateKey, t as findZoneIdByName } from "./zoneResolver-Dfp2glm8.mjs";
5
5
 
6
6
  //#region src/cli/commands/import.ts
7
7
  const REGISTRY_KINDS = new Set(resourceModules.map((m) => m.kind));
@@ -110,7 +110,7 @@ async function importDnsRecord(ctx) {
110
110
  const hit = (await api.zoneDnsRecordListAll(declared.zoneId)).find((r) => r.id === options.cfId);
111
111
  if (!hit) throw new Error(`import dns_record: record id "${options.cfId}" not found in zone "${declared.zoneId}"`);
112
112
  if (hit.type !== declared.type) throw new Error(`import dns_record: cf record type "${hit.type}" does not match declared type "${declared.type}"`);
113
- const { dnsRecordStateKey } = await import("./dns-records.resolve-jECsH6N-.mjs");
113
+ const { dnsRecordStateKey } = await import("./dns-records.resolve-Dge2kukJ.mjs");
114
114
  const key = dnsRecordStateKey(declared.zoneId, declared.type, declared.name);
115
115
  const existing = state.get(key);
116
116
  state.set(key, {
@@ -161,4 +161,4 @@ async function importWorkerRoute(ctx) {
161
161
 
162
162
  //#endregion
163
163
  export { runImport };
164
- //# sourceMappingURL=import-leVD9Ryg.mjs.map
164
+ //# sourceMappingURL=import-QJc0fI1h.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"import-leVD9Ryg.mjs","names":[],"sources":["../src/cli/commands/import.ts"],"sourcesContent":["import { loadConfig, getWorkers, getConfigBaseDir } from \"../../core/config/loader.js\";\nimport { cloudflareAccountIdFromEnv } from \"../../core/cloudflareEnv.js\";\nimport { namingFromConfig } from \"../../core/config/namingFromConfig.js\";\nimport { CFApiClient } from \"../../core/api/CFApiClient.js\";\nimport { StateManager } from \"../../core/state/StateManager.js\";\nimport { stackNameForConfig } from \"../../core/state/stackName.js\";\nimport { resolveWorkerConfig } from \"../../core/config/resolver.js\";\nimport { fetchStackImports } from \"../../core/imports/fetchStackImports.js\";\nimport { workerRouteStateKey } from \"../../features/worker-route/worker-route.stateKey.js\";\nimport { findZoneIdByName } from \"../../core/routes/zoneResolver.js\";\nimport {\n getResourceModule,\n resourceModules,\n type ResourceKind,\n} from \"../../core/registry/registry.js\";\n\n/** All registered resource kinds plus the non-registry imports. */\nexport type ImportKind =\n | ResourceKind\n | \"dispatch_namespace\"\n | \"dns_record\"\n | \"worker_route\";\n\nexport interface ImportOptions {\n env: string;\n kind: ImportKind;\n /** Logical name from `tamer.config.ts` (or worker key, for `worker_route`). */\n logical: string;\n /** Cloudflare resource id (D1 uuid, KV id, R2 bucket name, or namespace name). */\n cfId?: string;\n /** Required for sharded D1 imports (YYYY-MM-DD). */\n shardDate?: string;\n /** R2 buckets only: creation date (YYYY-MM-DD) used in the binding key. */\n createdDate?: string;\n /** worker_route only: the route id from `/zones/{id}/workers/routes`. */\n routeId?: string;\n /** worker_route only: zone name from `tamerRoutes`. */\n zoneName?: string;\n configPath?: string;\n}\n\nconst REGISTRY_KINDS = new Set<string>(resourceModules.map((m) => m.kind));\n\n/**\n * `tamer import` — register an existing Cloudflare resource into Tamer state\n * by logical name (CloudFormation `import_resources` analogue). For all\n * resource-registry kinds the work is delegated to the module's\n * `importOne` hook; `dispatch_namespace` and `worker_route` remain inline\n * because they aren't registry resources today.\n */\nexport async function runImport(options: ImportOptions): Promise<void> {\n const env = options.env;\n if (env === \"local\") {\n throw new Error(\"import: --env local is not supported (no persisted state)\");\n }\n const config = await loadConfig(options.configPath, { env });\n const baseDir = getConfigBaseDir();\n const accountId = config.account_id ?? cloudflareAccountIdFromEnv();\n if (!accountId) {\n throw new Error(\n \"account_id required in config or CLOUDFLARE_ACCOUNT_ID env var\",\n );\n }\n const api = new CFApiClient(accountId);\n const naming = namingFromConfig(config);\n const state = new StateManager(\n config.tenant.id,\n env,\n stackNameForConfig(config),\n );\n await state.hydrate(api);\n state.beginOperation(\"import\", `${options.kind}:${options.logical}`);\n\n const ts = new Date().toISOString();\n\n try {\n if (REGISTRY_KINDS.has(options.kind)) {\n const mod = getResourceModule(options.kind as ResourceKind);\n if (!mod) throw new Error(`unknown import kind \"${options.kind}\"`);\n await mod.importOne({\n options: {\n env,\n kind: options.kind,\n logical: options.logical,\n cfId: options.cfId,\n shardDate: options.shardDate,\n createdDate: options.createdDate,\n routeId: options.routeId,\n zoneName: options.zoneName,\n },\n env,\n api,\n state,\n naming,\n config,\n baseDir,\n ts,\n });\n } else if (options.kind === \"dispatch_namespace\") {\n await importDispatchNamespace({ options, env, api, state, ts });\n } else if (options.kind === \"dns_record\") {\n await importDnsRecord({ options, env, api, state, config, ts });\n } else if (options.kind === \"worker_route\") {\n await importWorkerRoute({\n options,\n env,\n baseDir,\n accountId,\n api,\n naming,\n state,\n config,\n ts,\n });\n } else {\n throw new Error(`unknown import kind \"${options.kind}\"`);\n }\n\n state.finishOperation(\"imported\");\n await state.persist(api);\n console.log(`Imported ${options.kind} \"${options.logical}\" into ${env} state.`);\n } catch (err) {\n const msg = err instanceof Error ? err.message : String(err);\n state.failOperation(msg);\n try {\n await state.persist(api);\n } catch {\n /* swallow secondary persist failure */\n }\n throw err;\n }\n}\n\nasync function importDispatchNamespace(ctx: {\n options: ImportOptions;\n env: string;\n api: CFApiClient;\n state: StateManager;\n ts: string;\n}): Promise<void> {\n const { options, api, state, ts } = ctx;\n const namespaces = await api.dispatchNamespaceListAll();\n const hit = namespaces.find((n) => n.namespace_name === options.cfId);\n if (!hit) {\n throw new Error(\n `import dispatch_namespace: namespace \"${options.cfId}\" not found`,\n );\n }\n const derivedName = hit.namespace_name;\n const key = `dispatch_ns:${derivedName}`;\n const existing = state.get(key);\n state.set(key, {\n type: \"dispatch_namespace\",\n logicalName: options.logical,\n derivedName,\n createdAt:\n existing?.type === \"dispatch_namespace\" ? existing.createdAt : ts,\n updatedAt: ts,\n });\n}\n\nasync function importDnsRecord(ctx: {\n options: ImportOptions;\n env: string;\n api: CFApiClient;\n state: StateManager;\n config: Awaited<ReturnType<typeof loadConfig>>;\n ts: string;\n}): Promise<void> {\n const { options, api, state, config, ts } = ctx;\n if (!options.cfId) {\n throw new Error(\n \"import dns_record: --cf-id <recordId> is required (the record id from `tamer drift` or the Cloudflare dashboard URL)\",\n );\n }\n const declared = (config.dnsRecords ?? []).find(\n (r) => r.logicalName === options.logical,\n );\n if (!declared) {\n throw new Error(\n `import dns_record: no dnsRecords entry with logicalName \"${options.logical}\" in the Tamer project config`,\n );\n }\n const list = await api.zoneDnsRecordListAll(declared.zoneId);\n const hit = list.find((r) => r.id === options.cfId);\n if (!hit) {\n throw new Error(\n `import dns_record: record id \"${options.cfId}\" not found in zone \"${declared.zoneId}\"`,\n );\n }\n if (hit.type !== declared.type) {\n throw new Error(\n `import dns_record: cf record type \"${hit.type}\" does not match declared type \"${declared.type}\"`,\n );\n }\n const { dnsRecordStateKey } = await import(\n \"../../features/dns-records/dns-records.resolve.js\"\n );\n const key = dnsRecordStateKey(declared.zoneId, declared.type, declared.name);\n const existing = state.get(key);\n state.set(key, {\n type: \"dns_record\",\n logicalName: options.logical,\n zoneId: declared.zoneId,\n recordType: declared.type,\n name: hit.name,\n content: hit.content,\n ttl: hit.ttl ?? 1,\n proxied: hit.proxied ?? false,\n priority: hit.priority,\n comment: hit.comment ?? \"\",\n recordId: hit.id,\n createdAt: existing?.type === \"dns_record\" ? existing.createdAt : ts,\n updatedAt: ts,\n });\n}\n\nasync function importWorkerRoute(ctx: {\n options: ImportOptions;\n env: string;\n baseDir: string;\n accountId: string;\n api: CFApiClient;\n naming: ReturnType<typeof namingFromConfig>;\n state: StateManager;\n config: Awaited<ReturnType<typeof loadConfig>>;\n ts: string;\n}): Promise<void> {\n const { options, env, baseDir, accountId, api, naming, state, config, ts } =\n ctx;\n if (!options.routeId) {\n throw new Error(\"import worker_route: --route-id <id> is required\");\n }\n const workers = await getWorkers(config, baseDir);\n const wc = workers.find(([k]) => k === options.logical)?.[1];\n if (!wc) {\n throw new Error(\n `import worker_route: no worker key \"${options.logical}\" in the Tamer project config`,\n );\n }\n const imports = await fetchStackImports(api, config, env);\n const resolved = await resolveWorkerConfig(\n config,\n options.logical,\n wc,\n env,\n baseDir,\n accountId,\n naming,\n state,\n { imports },\n );\n if (resolved.apiManagedRoutes.length === 0) {\n throw new Error(\n `import worker_route: worker \"${options.logical}\" declares no api-managed tamerRoutes for env ${env}`,\n );\n }\n\n const route = options.zoneName\n ? resolved.apiManagedRoutes.find((r) => r.zone_name === options.zoneName)\n : resolved.apiManagedRoutes[0];\n if (!route) {\n throw new Error(\n `import worker_route: no route for zone \"${options.zoneName}\" in resolved config`,\n );\n }\n const zoneId = await findZoneIdByName(api, route.zone_name);\n if (!zoneId) {\n throw new Error(`import worker_route: zone \"${route.zone_name}\" not found`);\n }\n const list = await api.zoneWorkerRoutesList(zoneId);\n const hit = list.find((r) => r.id === options.routeId);\n if (!hit) {\n throw new Error(\n `import worker_route: route id \"${options.routeId}\" not found in zone \"${route.zone_name}\"`,\n );\n }\n if (hit.pattern !== route.pattern) {\n throw new Error(\n `import worker_route: cf pattern \"${hit.pattern}\" does not match resolved \"${route.pattern}\"`,\n );\n }\n const key = workerRouteStateKey(zoneId, options.routeId);\n const existing = state.get(key);\n state.set(key, {\n type: \"worker_route\",\n workerKey: options.logical,\n workerName: resolved.workerName,\n zoneId,\n zoneName: route.zone_name,\n routeId: options.routeId,\n pattern: route.pattern,\n createdAt: existing?.type === \"worker_route\" ? existing.createdAt : ts,\n updatedAt: ts,\n });\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"import-QJc0fI1h.mjs","names":[],"sources":["../src/cli/commands/import.ts"],"sourcesContent":["import { loadConfig, getWorkers, getConfigBaseDir } from \"../../core/config/loader.js\";\nimport { cloudflareAccountIdFromEnv } from \"../../core/cloudflareEnv.js\";\nimport { namingFromConfig } from \"../../core/config/namingFromConfig.js\";\nimport { CFApiClient } from \"../../core/api/CFApiClient.js\";\nimport { StateManager } from \"../../core/state/StateManager.js\";\nimport { stackNameForConfig } from \"../../core/state/stackName.js\";\nimport { resolveWorkerConfig } from \"../../core/config/resolver.js\";\nimport { fetchStackImports } from \"../../core/imports/fetchStackImports.js\";\nimport { workerRouteStateKey } from \"../../features/worker-route/worker-route.stateKey.js\";\nimport { findZoneIdByName } from \"../../core/routes/zoneResolver.js\";\nimport {\n getResourceModule,\n resourceModules,\n type ResourceKind,\n} from \"../../core/registry/registry.js\";\n\n/** All registered resource kinds plus the non-registry imports. */\nexport type ImportKind =\n | ResourceKind\n | \"dispatch_namespace\"\n | \"dns_record\"\n | \"worker_route\";\n\nexport interface ImportOptions {\n env: string;\n kind: ImportKind;\n /** Logical name from `tamer.config.ts` (or worker key, for `worker_route`). */\n logical: string;\n /** Cloudflare resource id (D1 uuid, KV id, R2 bucket name, or namespace name). */\n cfId?: string;\n /** Required for sharded D1 imports (YYYY-MM-DD). */\n shardDate?: string;\n /** R2 buckets only: creation date (YYYY-MM-DD) used in the binding key. */\n createdDate?: string;\n /** worker_route only: the route id from `/zones/{id}/workers/routes`. */\n routeId?: string;\n /** worker_route only: zone name from `tamerRoutes`. */\n zoneName?: string;\n configPath?: string;\n}\n\nconst REGISTRY_KINDS = new Set<string>(resourceModules.map((m) => m.kind));\n\n/**\n * `tamer import` — register an existing Cloudflare resource into Tamer state\n * by logical name (CloudFormation `import_resources` analogue). For all\n * resource-registry kinds the work is delegated to the module's\n * `importOne` hook; `dispatch_namespace` and `worker_route` remain inline\n * because they aren't registry resources today.\n */\nexport async function runImport(options: ImportOptions): Promise<void> {\n const env = options.env;\n if (env === \"local\") {\n throw new Error(\"import: --env local is not supported (no persisted state)\");\n }\n const config = await loadConfig(options.configPath, { env });\n const baseDir = getConfigBaseDir();\n const accountId = config.account_id ?? cloudflareAccountIdFromEnv();\n if (!accountId) {\n throw new Error(\n \"account_id required in config or CLOUDFLARE_ACCOUNT_ID env var\",\n );\n }\n const api = new CFApiClient(accountId);\n const naming = namingFromConfig(config);\n const state = new StateManager(\n config.tenant.id,\n env,\n stackNameForConfig(config),\n );\n await state.hydrate(api);\n state.beginOperation(\"import\", `${options.kind}:${options.logical}`);\n\n const ts = new Date().toISOString();\n\n try {\n if (REGISTRY_KINDS.has(options.kind)) {\n const mod = getResourceModule(options.kind as ResourceKind);\n if (!mod) throw new Error(`unknown import kind \"${options.kind}\"`);\n await mod.importOne({\n options: {\n env,\n kind: options.kind,\n logical: options.logical,\n cfId: options.cfId,\n shardDate: options.shardDate,\n createdDate: options.createdDate,\n routeId: options.routeId,\n zoneName: options.zoneName,\n },\n env,\n api,\n state,\n naming,\n config,\n baseDir,\n ts,\n });\n } else if (options.kind === \"dispatch_namespace\") {\n await importDispatchNamespace({ options, env, api, state, ts });\n } else if (options.kind === \"dns_record\") {\n await importDnsRecord({ options, env, api, state, config, ts });\n } else if (options.kind === \"worker_route\") {\n await importWorkerRoute({\n options,\n env,\n baseDir,\n accountId,\n api,\n naming,\n state,\n config,\n ts,\n });\n } else {\n throw new Error(`unknown import kind \"${options.kind}\"`);\n }\n\n state.finishOperation(\"imported\");\n await state.persist(api);\n console.log(`Imported ${options.kind} \"${options.logical}\" into ${env} state.`);\n } catch (err) {\n const msg = err instanceof Error ? err.message : String(err);\n state.failOperation(msg);\n try {\n await state.persist(api);\n } catch {\n /* swallow secondary persist failure */\n }\n throw err;\n }\n}\n\nasync function importDispatchNamespace(ctx: {\n options: ImportOptions;\n env: string;\n api: CFApiClient;\n state: StateManager;\n ts: string;\n}): Promise<void> {\n const { options, api, state, ts } = ctx;\n const namespaces = await api.dispatchNamespaceListAll();\n const hit = namespaces.find((n) => n.namespace_name === options.cfId);\n if (!hit) {\n throw new Error(\n `import dispatch_namespace: namespace \"${options.cfId}\" not found`,\n );\n }\n const derivedName = hit.namespace_name;\n const key = `dispatch_ns:${derivedName}`;\n const existing = state.get(key);\n state.set(key, {\n type: \"dispatch_namespace\",\n logicalName: options.logical,\n derivedName,\n createdAt:\n existing?.type === \"dispatch_namespace\" ? existing.createdAt : ts,\n updatedAt: ts,\n });\n}\n\nasync function importDnsRecord(ctx: {\n options: ImportOptions;\n env: string;\n api: CFApiClient;\n state: StateManager;\n config: Awaited<ReturnType<typeof loadConfig>>;\n ts: string;\n}): Promise<void> {\n const { options, api, state, config, ts } = ctx;\n if (!options.cfId) {\n throw new Error(\n \"import dns_record: --cf-id <recordId> is required (the record id from `tamer drift` or the Cloudflare dashboard URL)\",\n );\n }\n const declared = (config.dnsRecords ?? []).find(\n (r) => r.logicalName === options.logical,\n );\n if (!declared) {\n throw new Error(\n `import dns_record: no dnsRecords entry with logicalName \"${options.logical}\" in the Tamer project config`,\n );\n }\n const list = await api.zoneDnsRecordListAll(declared.zoneId);\n const hit = list.find((r) => r.id === options.cfId);\n if (!hit) {\n throw new Error(\n `import dns_record: record id \"${options.cfId}\" not found in zone \"${declared.zoneId}\"`,\n );\n }\n if (hit.type !== declared.type) {\n throw new Error(\n `import dns_record: cf record type \"${hit.type}\" does not match declared type \"${declared.type}\"`,\n );\n }\n const { dnsRecordStateKey } = await import(\n \"../../features/dns-records/dns-records.resolve.js\"\n );\n const key = dnsRecordStateKey(declared.zoneId, declared.type, declared.name);\n const existing = state.get(key);\n state.set(key, {\n type: \"dns_record\",\n logicalName: options.logical,\n zoneId: declared.zoneId,\n recordType: declared.type,\n name: hit.name,\n content: hit.content,\n ttl: hit.ttl ?? 1,\n proxied: hit.proxied ?? false,\n priority: hit.priority,\n comment: hit.comment ?? \"\",\n recordId: hit.id,\n createdAt: existing?.type === \"dns_record\" ? existing.createdAt : ts,\n updatedAt: ts,\n });\n}\n\nasync function importWorkerRoute(ctx: {\n options: ImportOptions;\n env: string;\n baseDir: string;\n accountId: string;\n api: CFApiClient;\n naming: ReturnType<typeof namingFromConfig>;\n state: StateManager;\n config: Awaited<ReturnType<typeof loadConfig>>;\n ts: string;\n}): Promise<void> {\n const { options, env, baseDir, accountId, api, naming, state, config, ts } =\n ctx;\n if (!options.routeId) {\n throw new Error(\"import worker_route: --route-id <id> is required\");\n }\n const workers = await getWorkers(config, baseDir);\n const wc = workers.find(([k]) => k === options.logical)?.[1];\n if (!wc) {\n throw new Error(\n `import worker_route: no worker key \"${options.logical}\" in the Tamer project config`,\n );\n }\n const imports = await fetchStackImports(api, config, env);\n const resolved = await resolveWorkerConfig(\n config,\n options.logical,\n wc,\n env,\n baseDir,\n accountId,\n naming,\n state,\n { imports },\n );\n if (resolved.apiManagedRoutes.length === 0) {\n throw new Error(\n `import worker_route: worker \"${options.logical}\" declares no api-managed tamerRoutes for env ${env}`,\n );\n }\n\n const route = options.zoneName\n ? resolved.apiManagedRoutes.find((r) => r.zone_name === options.zoneName)\n : resolved.apiManagedRoutes[0];\n if (!route) {\n throw new Error(\n `import worker_route: no route for zone \"${options.zoneName}\" in resolved config`,\n );\n }\n const zoneId = await findZoneIdByName(api, route.zone_name);\n if (!zoneId) {\n throw new Error(`import worker_route: zone \"${route.zone_name}\" not found`);\n }\n const list = await api.zoneWorkerRoutesList(zoneId);\n const hit = list.find((r) => r.id === options.routeId);\n if (!hit) {\n throw new Error(\n `import worker_route: route id \"${options.routeId}\" not found in zone \"${route.zone_name}\"`,\n );\n }\n if (hit.pattern !== route.pattern) {\n throw new Error(\n `import worker_route: cf pattern \"${hit.pattern}\" does not match resolved \"${route.pattern}\"`,\n );\n }\n const key = workerRouteStateKey(zoneId, options.routeId);\n const existing = state.get(key);\n state.set(key, {\n type: \"worker_route\",\n workerKey: options.logical,\n workerName: resolved.workerName,\n zoneId,\n zoneName: route.zone_name,\n routeId: options.routeId,\n pattern: route.pattern,\n createdAt: existing?.type === \"worker_route\" ? existing.createdAt : ts,\n updatedAt: ts,\n });\n}\n"],"mappings":"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"}
package/dist/index.d.mts CHANGED
@@ -5785,6 +5785,15 @@ interface TenantMeta {
5785
5785
  service: TamerResolvableString;
5786
5786
  environment?: string;
5787
5787
  }>;
5788
+ /**
5789
+ * Secret names to inject into the tenant dispatch script on
5790
+ * `wfp tenant provision`. Values are read from the Tamer vault
5791
+ * (set via `tamer secrets set <NAME> --env <env>`), decrypted with
5792
+ * the env master key, and pushed to the dispatch namespace script
5793
+ * via the CF API after `wrangler deploy`. Same vault as regular
5794
+ * worker secrets — just a different delivery target.
5795
+ */
5796
+ dispatchSecrets?: string[];
5788
5797
  }
5789
5798
  /**
5790
5799
  * D1 database declared on a worker's `resources.d1[]`.
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.mts","names":[],"sources":["../src/generated/wrangler-types.generated.ts","../src/generated/wrangler-types.ts","../src/dx/cloudflare-bindings.ts","../src/types.ts","../src/dx/normalize.ts","../src/dx/index.ts"],"sourcesContent":[],"mappings":";;AASA;;;;;AAOA;AAYA;AAaY,KAhCA,KAAA,GAgCA,MAAA,GAhCiB,WAgCI,GAhCU,aAgCV,GAhC0B,iBAgC1B;AA+mEjC;;;;;;AAiHU,KAzvEE,oBAAA,GAyvEF,UAAA,GAAA,UAAA,GAAA,cAAA,GAAA,MAAA,GAAA,MAAA,GAAA,cAAA,GAAA,mBAAA;;;;;AAiOkB,KA98EhB,IAAA,GA88EgB,MAAA,GAAA,MAAA,GAAA,OAAA,GAAA,IAAA,GAz8ExB,IAy8EwB,EAAA,GAAA;EA2BZ,CAAA,CAAA,EAAA,MAAA,CAAA,EAl+EG,IAk+EH;CAOA;;;;;AAozBF,KAvxGF,qBAAA,GAuxGE;EAOA;;;EAoiBe,IAAA,EAAA,MAAA;EAAqB;AAyOlD;AASA;EASiB,UAAA,EAAA,MAAA;EAYA;AA+BjB;AAWA;EAsDW,WAAA,CAAA,EAAA,MAAA;EAMQ;;;EAoBL,WAAA,CAAA,EAAA,MAAA;CAiCL,EAAA;;;;;;;;;UArnEQ,cAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;WAsDN;;;;;;mBAMQ,cAAc,gBAAgB;;;;;;;;;;;;;;;;;;;;eAoBlC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UAiCL;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;cA6MI;oBACM;aACP;YACD;;;;;;;;;;;;;;;;;4BAiBgB;;;;;;;;;;;;;;;;;;;;;;;;;;;gBA2BZ;;;;;;;gBAOA;;;;;;;;;;;;;;;;;;;iBAmBC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBA2gBI;;;;;;+BAMU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAqPL;;;;;;;;;;;;;;;;;;;;;;;;;;;cA2BZ;;;;;;;cAOA;;;;;;;;;;;;;;;;;;;eAmBC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mBA2gBI;;;;;;6BAMU;;;;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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBA2gBI;;;;;;+BAMU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAqPL;;;;;;;;;;;;;;;;;;;;;;;;;;;cA2BZ;;;;;;;cAOA;;;;;;;;;;;;;;;;;;;eAmBC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;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"}
1
+ {"version":3,"file":"index.d.mts","names":[],"sources":["../src/generated/wrangler-types.generated.ts","../src/generated/wrangler-types.ts","../src/dx/cloudflare-bindings.ts","../src/types.ts","../src/dx/normalize.ts","../src/dx/index.ts"],"sourcesContent":[],"mappings":";;AASA;;;;;AAOA;AAYA;AAaY,KAhCA,KAAA,GAgCA,MAAA,GAhCiB,WAgCI,GAhCU,aAgCV,GAhC0B,iBAgC1B;AA+mEjC;;;;;;AAiHU,KAzvEE,oBAAA,GAyvEF,UAAA,GAAA,UAAA,GAAA,cAAA,GAAA,MAAA,GAAA,MAAA,GAAA,cAAA,GAAA,mBAAA;;;;;AAiOkB,KA98EhB,IAAA,GA88EgB,MAAA,GAAA,MAAA,GAAA,OAAA,GAAA,IAAA,GAz8ExB,IAy8EwB,EAAA,GAAA;EA2BZ,CAAA,CAAA,EAAA,MAAA,CAAA,EAl+EG,IAk+EH;CAOA;;;;;AAozBF,KAvxGF,qBAAA,GAuxGE;EAOA;;;EAoiBe,IAAA,EAAA,MAAA;EAAqB;AAyOlD;AASA;EASiB,UAAA,EAAA,MAAA;EAYA;AA+BjB;AAWA;EAsDW,WAAA,CAAA,EAAA,MAAA;EAMQ;;;EAoBL,WAAA,CAAA,EAAA,MAAA;CAiCL,EAAA;;;;;;;;;UArnEQ,cAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;WAsDN;;;;;;mBAMQ,cAAc,gBAAgB;;;;;;;;;;;;;;;;;;;;eAoBlC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UAiCL;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;cA6MI;oBACM;aACP;YACD;;;;;;;;;;;;;;;;;4BAiBgB;;;;;;;;;;;;;;;;;;;;;;;;;;;gBA2BZ;;;;;;;gBAOA;;;;;;;;;;;;;;;;;;;iBAmBC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBA2gBI;;;;;;+BAMU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAqPL;;;;;;;;;;;;;;;;;;;;;;;;;;;cA2BZ;;;;;;;cAOA;;;;;;;;;;;;;;;;;;;eAmBC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mBA2gBI;;;;;;6BAMU;;;;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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBA2gBI;;;;;;+BAMU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAqPL;;;;;;;;;;;;;;;;;;;;;;;;;;;cA2BZ;;;;;;;cAOA;;;;;;;;;;;;;;;;;;;eAmBC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;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"}
@@ -0,0 +1,3 @@
1
+ import { it as loadConfig, nt as getConfigBaseDir, rt as getWorkers } from "./tamer.mjs";
2
+
3
+ export { getConfigBaseDir };
@@ -1,5 +1,5 @@
1
1
  import { m as getLogpushJobs } from "./normalize-DVSTRZhO.mjs";
2
- import { n as r2S3CredentialsFromEnv, t as emptyR2BucketViaS3 } from "./r2S3EmptyBucket-DD81ZWQ7.mjs";
2
+ import { n as r2S3CredentialsFromEnv, t as emptyR2BucketViaS3 } from "./r2S3EmptyBucket-CDE2lTM8.mjs";
3
3
 
4
4
  //#region src/features/logpush-job/logpush-job.resolve.ts
5
5
  const DEFAULT_WORKERS_TRACE_LOG_FIELD_NAMES = [
@@ -1103,4 +1103,4 @@ function logpushJobStatus(resources, tenant, env, state, liveJobs) {
1103
1103
 
1104
1104
  //#endregion
1105
1105
  export { logpushJobApply as a, logpushJobSync as i, logpushJobDestroy as n, logpushJobDiffPlanItems as o, logpushJobDrift as r, logpushJobStateKey as s, logpushJobStatus as t };
1106
- //# sourceMappingURL=logpush-job-Dqlt-wEw.mjs.map
1106
+ //# sourceMappingURL=logpush-job-DZG-3nkJ.mjs.map