@lumenflow/cli 3.1.2 → 3.1.3

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 (389) hide show
  1. package/README.md +36 -35
  2. package/dist/agent-issues-query.js +13 -8
  3. package/dist/agent-log-issue.js +15 -4
  4. package/dist/agent-session-end.js +15 -4
  5. package/dist/agent-session.js +18 -6
  6. package/dist/backlog-prune.js +1 -1
  7. package/dist/commands/integrate.js +32 -18
  8. package/dist/config-get.js +27 -15
  9. package/dist/config-set.js +104 -37
  10. package/dist/delegation-list.js +1 -1
  11. package/dist/doctor.js +19 -13
  12. package/dist/file-delete.js +1 -1
  13. package/dist/file-edit.js +1 -1
  14. package/dist/file-read.js +1 -1
  15. package/dist/file-write.js +1 -1
  16. package/dist/flow-bottlenecks.js +1 -1
  17. package/dist/flow-report.js +10 -9
  18. package/dist/gates.js +3 -2
  19. package/dist/git-branch.js +1 -1
  20. package/dist/git-diff.js +1 -1
  21. package/dist/git-log.js +1 -1
  22. package/dist/init.js +238 -42
  23. package/dist/initiative-add-wu.js +1 -1
  24. package/dist/initiative-bulk-assign-wus.js +1 -1
  25. package/dist/initiative-create.js +2 -2
  26. package/dist/initiative-edit.js +1 -1
  27. package/dist/initiative-list.js +1 -1
  28. package/dist/initiative-plan.js +1 -3
  29. package/dist/initiative-status.js +47 -6
  30. package/dist/lane-edit.js +19 -10
  31. package/dist/lane-health.js +13 -24
  32. package/dist/lane-lock.js +4 -5
  33. package/dist/lane-setup.js +5 -5
  34. package/dist/lane-status.js +4 -5
  35. package/dist/lane-suggest.js +9 -7
  36. package/dist/lane-validate.js +4 -5
  37. package/dist/lumenflow-upgrade.js +17 -11
  38. package/dist/mem-checkpoint.js +1 -1
  39. package/dist/mem-cleanup.js +6 -23
  40. package/dist/mem-context.js +1 -1
  41. package/dist/mem-create.js +1 -1
  42. package/dist/mem-delete.js +1 -1
  43. package/dist/mem-export.js +1 -1
  44. package/dist/mem-inbox.js +1 -1
  45. package/dist/mem-init.js +1 -1
  46. package/dist/mem-ready.js +1 -1
  47. package/dist/mem-recover.js +1 -1
  48. package/dist/mem-signal.js +1 -1
  49. package/dist/mem-start.js +1 -1
  50. package/dist/mem-summarize.js +8 -7
  51. package/dist/mem-triage.js +7 -5
  52. package/dist/metrics-cli.js +1 -1
  53. package/dist/metrics-snapshot.js +1 -1
  54. package/dist/onboard.js +295 -120
  55. package/dist/orchestrate-init-status.js +12 -7
  56. package/dist/orchestrate-initiative.js +23 -12
  57. package/dist/orchestrate-monitor.js +20 -8
  58. package/dist/pack-scaffold.js +1 -1
  59. package/dist/plan-create.js +1 -3
  60. package/dist/plan-edit.js +1 -3
  61. package/dist/plan-link.js +1 -3
  62. package/dist/plan-promote.js +1 -3
  63. package/dist/release.js +1 -3
  64. package/dist/signal-cleanup.js +4 -18
  65. package/dist/state-bootstrap.js +11 -8
  66. package/dist/state-cleanup.js +5 -19
  67. package/dist/state-doctor.js +213 -9
  68. package/dist/task-claim.js +1 -1
  69. package/dist/validate.js +1 -1
  70. package/dist/workspace-init.js +61 -61
  71. package/dist/wu-block.js +1 -1
  72. package/dist/wu-brief.js +1 -1
  73. package/dist/wu-claim.js +1 -1
  74. package/dist/wu-cleanup.js +1 -1
  75. package/dist/wu-create.js +3 -3
  76. package/dist/wu-delegate.js +1 -1
  77. package/dist/wu-deps.js +1 -1
  78. package/dist/wu-done.js +66 -34
  79. package/dist/wu-edit.js +1 -1
  80. package/dist/wu-infer-lane.js +1 -1
  81. package/dist/wu-preflight.js +1 -1
  82. package/dist/wu-prep.js +1 -1
  83. package/dist/wu-proto.js +1 -1
  84. package/dist/wu-prune.js +1 -1
  85. package/dist/wu-recover.js +1 -1
  86. package/dist/wu-release.js +1 -1
  87. package/dist/wu-repair.js +1 -1
  88. package/dist/wu-sandbox.js +40 -27
  89. package/dist/wu-status.js +1 -1
  90. package/dist/wu-unblock.js +1 -1
  91. package/dist/wu-unlock-lane.js +1 -1
  92. package/dist/wu-validate.js +1 -1
  93. package/package.json +12 -8
  94. package/packs/software-delivery/constants.ts +10 -0
  95. package/packs/software-delivery/extensions.ts +140 -0
  96. package/packs/software-delivery/gate-policies.ts +134 -0
  97. package/packs/software-delivery/index.ts +8 -0
  98. package/packs/software-delivery/manifest-schema.ts +236 -0
  99. package/packs/software-delivery/manifest.ts +417 -0
  100. package/packs/software-delivery/manifest.yaml +711 -0
  101. package/packs/software-delivery/pack-registration.ts +113 -0
  102. package/packs/software-delivery/tool-impl/agent-tools.ts +263 -0
  103. package/packs/software-delivery/tool-impl/delegation-tools.ts +66 -0
  104. package/packs/software-delivery/tool-impl/flow-metrics-tools.ts +219 -0
  105. package/packs/software-delivery/tool-impl/git-runner.ts +113 -0
  106. package/packs/software-delivery/tool-impl/git-tools.ts +316 -0
  107. package/packs/software-delivery/tool-impl/index.ts +15 -0
  108. package/packs/software-delivery/tool-impl/initiative-orchestration-tools.ts +720 -0
  109. package/packs/software-delivery/tool-impl/lane-lock.ts +246 -0
  110. package/packs/software-delivery/tool-impl/memory-tools.ts +415 -0
  111. package/packs/software-delivery/tool-impl/pending-runtime-tools.ts +21 -0
  112. package/packs/software-delivery/tool-impl/runtime-cli-adapter.ts +328 -0
  113. package/packs/software-delivery/tool-impl/runtime-native-tools.ts +687 -0
  114. package/packs/software-delivery/tool-impl/worker-loader.ts +52 -0
  115. package/packs/software-delivery/tool-impl/worktree-tools.ts +46 -0
  116. package/packs/software-delivery/tool-impl/wu-lifecycle-tools.ts +759 -0
  117. package/packs/software-delivery/tools/delegation-tools.ts +23 -0
  118. package/packs/software-delivery/tools/git-tools.ts +55 -0
  119. package/packs/software-delivery/tools/index.ts +8 -0
  120. package/packs/software-delivery/tools/lane-lock-tool.ts +37 -0
  121. package/packs/software-delivery/tools/types.ts +71 -0
  122. package/packs/software-delivery/tools/worktree-tools.ts +49 -0
  123. package/templates/core/LUMENFLOW.md.template +3 -3
  124. package/templates/core/ai/onboarding/agent-invocation-guide.md.template +1 -1
  125. package/templates/core/ai/onboarding/lumenflow-force-usage.md.template +1 -1
  126. package/templates/core/ai/onboarding/quick-ref-commands.md.template +5 -5
  127. package/templates/core/ai/onboarding/starting-prompt.md.template +3 -3
  128. package/templates/core/ai/onboarding/vendor-support.md.template +1 -1
  129. package/templates/core/ai/onboarding/wu-create-checklist.md.template +1 -1
  130. package/dist/agent-issues-query.js.map +0 -1
  131. package/dist/agent-log-issue.js.map +0 -1
  132. package/dist/agent-session-end.js.map +0 -1
  133. package/dist/agent-session.js.map +0 -1
  134. package/dist/backlog-prune.js.map +0 -1
  135. package/dist/cli-entry-point.js +0 -149
  136. package/dist/cli-entry-point.js.map +0 -1
  137. package/dist/commands/integrate.js.map +0 -1
  138. package/dist/commands.js.map +0 -1
  139. package/dist/config-get.js.map +0 -1
  140. package/dist/config-set.js.map +0 -1
  141. package/dist/delegation-list.js.map +0 -1
  142. package/dist/deps-add.js +0 -259
  143. package/dist/deps-add.js.map +0 -1
  144. package/dist/deps-remove.js +0 -105
  145. package/dist/deps-remove.js.map +0 -1
  146. package/dist/docs-sync.js.map +0 -1
  147. package/dist/doctor.js.map +0 -1
  148. package/dist/file-delete.js.map +0 -1
  149. package/dist/file-edit.js.map +0 -1
  150. package/dist/file-read.js.map +0 -1
  151. package/dist/file-write.js.map +0 -1
  152. package/dist/flow-bottlenecks.js.map +0 -1
  153. package/dist/flow-report.js.map +0 -1
  154. package/dist/formatters.js +0 -151
  155. package/dist/formatters.js.map +0 -1
  156. package/dist/gate-defaults.js +0 -131
  157. package/dist/gate-defaults.js.map +0 -1
  158. package/dist/gate-registry.js +0 -73
  159. package/dist/gate-registry.js.map +0 -1
  160. package/dist/gates-graceful-degradation.js +0 -153
  161. package/dist/gates-graceful-degradation.js.map +0 -1
  162. package/dist/gates-plan-resolvers.js +0 -152
  163. package/dist/gates-plan-resolvers.js.map +0 -1
  164. package/dist/gates-runners.js +0 -509
  165. package/dist/gates-runners.js.map +0 -1
  166. package/dist/gates-types.js +0 -4
  167. package/dist/gates-types.js.map +0 -1
  168. package/dist/gates-utils.js +0 -323
  169. package/dist/gates-utils.js.map +0 -1
  170. package/dist/gates.js.map +0 -1
  171. package/dist/git-branch.js.map +0 -1
  172. package/dist/git-diff.js.map +0 -1
  173. package/dist/git-log.js.map +0 -1
  174. package/dist/git-status.js.map +0 -1
  175. package/dist/guard-locked.js +0 -172
  176. package/dist/guard-locked.js.map +0 -1
  177. package/dist/guard-main-branch.js +0 -217
  178. package/dist/guard-main-branch.js.map +0 -1
  179. package/dist/guard-worktree-commit.js +0 -163
  180. package/dist/guard-worktree-commit.js.map +0 -1
  181. package/dist/hooks/auto-checkpoint-utils.js +0 -54
  182. package/dist/hooks/auto-checkpoint-utils.js.map +0 -1
  183. package/dist/hooks/enforcement-checks.js +0 -399
  184. package/dist/hooks/enforcement-checks.js.map +0 -1
  185. package/dist/hooks/enforcement-generator.js +0 -139
  186. package/dist/hooks/enforcement-generator.js.map +0 -1
  187. package/dist/hooks/enforcement-sync.js +0 -385
  188. package/dist/hooks/enforcement-sync.js.map +0 -1
  189. package/dist/hooks/generators/auto-checkpoint.js +0 -125
  190. package/dist/hooks/generators/auto-checkpoint.js.map +0 -1
  191. package/dist/hooks/generators/enforce-worktree.js +0 -190
  192. package/dist/hooks/generators/enforce-worktree.js.map +0 -1
  193. package/dist/hooks/generators/index.js +0 -18
  194. package/dist/hooks/generators/index.js.map +0 -1
  195. package/dist/hooks/generators/pre-compact-checkpoint.js +0 -136
  196. package/dist/hooks/generators/pre-compact-checkpoint.js.map +0 -1
  197. package/dist/hooks/generators/require-wu.js +0 -117
  198. package/dist/hooks/generators/require-wu.js.map +0 -1
  199. package/dist/hooks/generators/session-start-recovery.js +0 -103
  200. package/dist/hooks/generators/session-start-recovery.js.map +0 -1
  201. package/dist/hooks/generators/signal-utils.js +0 -54
  202. package/dist/hooks/generators/signal-utils.js.map +0 -1
  203. package/dist/hooks/generators/warn-incomplete.js +0 -67
  204. package/dist/hooks/generators/warn-incomplete.js.map +0 -1
  205. package/dist/hooks/index.js +0 -10
  206. package/dist/hooks/index.js.map +0 -1
  207. package/dist/index.js.map +0 -1
  208. package/dist/init-detection.js +0 -232
  209. package/dist/init-detection.js.map +0 -1
  210. package/dist/init-lane-validation.js +0 -143
  211. package/dist/init-lane-validation.js.map +0 -1
  212. package/dist/init-scaffolding.js +0 -158
  213. package/dist/init-scaffolding.js.map +0 -1
  214. package/dist/init-templates.js +0 -1982
  215. package/dist/init-templates.js.map +0 -1
  216. package/dist/init.js.map +0 -1
  217. package/dist/initiative-add-wu.js.map +0 -1
  218. package/dist/initiative-bulk-assign-wus.js.map +0 -1
  219. package/dist/initiative-create.js.map +0 -1
  220. package/dist/initiative-edit.js.map +0 -1
  221. package/dist/initiative-list.js.map +0 -1
  222. package/dist/initiative-plan.js.map +0 -1
  223. package/dist/initiative-remove-wu.js.map +0 -1
  224. package/dist/initiative-status.js.map +0 -1
  225. package/dist/lane-edit.js.map +0 -1
  226. package/dist/lane-health.js.map +0 -1
  227. package/dist/lane-lifecycle-process.js +0 -366
  228. package/dist/lane-lifecycle-process.js.map +0 -1
  229. package/dist/lane-lock.js.map +0 -1
  230. package/dist/lane-setup.js.map +0 -1
  231. package/dist/lane-status.js.map +0 -1
  232. package/dist/lane-suggest.js.map +0 -1
  233. package/dist/lane-validate.js.map +0 -1
  234. package/dist/lifecycle-regression-harness.js +0 -181
  235. package/dist/lifecycle-regression-harness.js.map +0 -1
  236. package/dist/lumenflow-upgrade.js.map +0 -1
  237. package/dist/mem-checkpoint.js.map +0 -1
  238. package/dist/mem-cleanup.js.map +0 -1
  239. package/dist/mem-context.js.map +0 -1
  240. package/dist/mem-create.js.map +0 -1
  241. package/dist/mem-delete.js.map +0 -1
  242. package/dist/mem-export.js.map +0 -1
  243. package/dist/mem-inbox.js.map +0 -1
  244. package/dist/mem-index.js +0 -214
  245. package/dist/mem-index.js.map +0 -1
  246. package/dist/mem-init.js.map +0 -1
  247. package/dist/mem-profile.js +0 -210
  248. package/dist/mem-profile.js.map +0 -1
  249. package/dist/mem-promote.js +0 -257
  250. package/dist/mem-promote.js.map +0 -1
  251. package/dist/mem-ready.js.map +0 -1
  252. package/dist/mem-recover.js.map +0 -1
  253. package/dist/mem-signal.js.map +0 -1
  254. package/dist/mem-start.js.map +0 -1
  255. package/dist/mem-summarize.js.map +0 -1
  256. package/dist/mem-triage.js.map +0 -1
  257. package/dist/merge-block.js +0 -225
  258. package/dist/merge-block.js.map +0 -1
  259. package/dist/metrics-cli.js.map +0 -1
  260. package/dist/metrics-snapshot.js.map +0 -1
  261. package/dist/onboard.js.map +0 -1
  262. package/dist/onboarding-smoke-test.js +0 -418
  263. package/dist/onboarding-smoke-test.js.map +0 -1
  264. package/dist/orchestrate-init-status.js.map +0 -1
  265. package/dist/orchestrate-initiative.js.map +0 -1
  266. package/dist/orchestrate-monitor.js.map +0 -1
  267. package/dist/pack-author.js.map +0 -1
  268. package/dist/pack-hash.js.map +0 -1
  269. package/dist/pack-install.js.map +0 -1
  270. package/dist/pack-publish.js.map +0 -1
  271. package/dist/pack-scaffold.js.map +0 -1
  272. package/dist/pack-search.js.map +0 -1
  273. package/dist/pack-validate.js.map +0 -1
  274. package/dist/plan-create.js.map +0 -1
  275. package/dist/plan-edit.js.map +0 -1
  276. package/dist/plan-link.js.map +0 -1
  277. package/dist/plan-promote.js.map +0 -1
  278. package/dist/public-manifest.js +0 -920
  279. package/dist/public-manifest.js.map +0 -1
  280. package/dist/release.js.map +0 -1
  281. package/dist/rotate-progress.js +0 -253
  282. package/dist/rotate-progress.js.map +0 -1
  283. package/dist/session-coordinator.js +0 -303
  284. package/dist/session-coordinator.js.map +0 -1
  285. package/dist/shared-validators.js +0 -81
  286. package/dist/shared-validators.js.map +0 -1
  287. package/dist/signal-cleanup.js.map +0 -1
  288. package/dist/state-bootstrap.js.map +0 -1
  289. package/dist/state-cleanup.js.map +0 -1
  290. package/dist/state-doctor-fix.js +0 -226
  291. package/dist/state-doctor-fix.js.map +0 -1
  292. package/dist/state-doctor-stamps.js +0 -23
  293. package/dist/state-doctor-stamps.js.map +0 -1
  294. package/dist/state-doctor.js.map +0 -1
  295. package/dist/strict-progress.js +0 -255
  296. package/dist/strict-progress.js.map +0 -1
  297. package/dist/sync-templates.js.map +0 -1
  298. package/dist/task-claim.js.map +0 -1
  299. package/dist/trace-gen.js +0 -401
  300. package/dist/trace-gen.js.map +0 -1
  301. package/dist/validate-agent-skills.js +0 -223
  302. package/dist/validate-agent-skills.js.map +0 -1
  303. package/dist/validate-agent-sync.js +0 -151
  304. package/dist/validate-agent-sync.js.map +0 -1
  305. package/dist/validate-backlog-sync.js +0 -77
  306. package/dist/validate-backlog-sync.js.map +0 -1
  307. package/dist/validate-skills-spec.js +0 -211
  308. package/dist/validate-skills-spec.js.map +0 -1
  309. package/dist/validate.js.map +0 -1
  310. package/dist/validator-defaults.js +0 -107
  311. package/dist/validator-defaults.js.map +0 -1
  312. package/dist/validator-registry.js +0 -71
  313. package/dist/validator-registry.js.map +0 -1
  314. package/dist/workspace-init.js.map +0 -1
  315. package/dist/wu-block.js.map +0 -1
  316. package/dist/wu-brief.js.map +0 -1
  317. package/dist/wu-claim-branch.js +0 -123
  318. package/dist/wu-claim-branch.js.map +0 -1
  319. package/dist/wu-claim-cloud.js +0 -79
  320. package/dist/wu-claim-cloud.js.map +0 -1
  321. package/dist/wu-claim-mode.js +0 -82
  322. package/dist/wu-claim-mode.js.map +0 -1
  323. package/dist/wu-claim-output.js +0 -85
  324. package/dist/wu-claim-output.js.map +0 -1
  325. package/dist/wu-claim-repair-guidance.js +0 -12
  326. package/dist/wu-claim-repair-guidance.js.map +0 -1
  327. package/dist/wu-claim-resume-handler.js +0 -87
  328. package/dist/wu-claim-resume-handler.js.map +0 -1
  329. package/dist/wu-claim-state.js +0 -581
  330. package/dist/wu-claim-state.js.map +0 -1
  331. package/dist/wu-claim-validation.js +0 -457
  332. package/dist/wu-claim-validation.js.map +0 -1
  333. package/dist/wu-claim-worktree.js +0 -223
  334. package/dist/wu-claim-worktree.js.map +0 -1
  335. package/dist/wu-claim.js.map +0 -1
  336. package/dist/wu-cleanup-cloud.js +0 -78
  337. package/dist/wu-cleanup-cloud.js.map +0 -1
  338. package/dist/wu-cleanup.js.map +0 -1
  339. package/dist/wu-code-path-coverage.js +0 -83
  340. package/dist/wu-code-path-coverage.js.map +0 -1
  341. package/dist/wu-create-cloud.js +0 -30
  342. package/dist/wu-create-cloud.js.map +0 -1
  343. package/dist/wu-create-content.js +0 -264
  344. package/dist/wu-create-content.js.map +0 -1
  345. package/dist/wu-create-readiness.js +0 -59
  346. package/dist/wu-create-readiness.js.map +0 -1
  347. package/dist/wu-create-validation.js +0 -128
  348. package/dist/wu-create-validation.js.map +0 -1
  349. package/dist/wu-create.js.map +0 -1
  350. package/dist/wu-delegate.js.map +0 -1
  351. package/dist/wu-delete.js.map +0 -1
  352. package/dist/wu-deps.js.map +0 -1
  353. package/dist/wu-done-auto-cleanup.js +0 -203
  354. package/dist/wu-done-auto-cleanup.js.map +0 -1
  355. package/dist/wu-done-check.js +0 -38
  356. package/dist/wu-done-check.js.map +0 -1
  357. package/dist/wu-done-cloud.js +0 -48
  358. package/dist/wu-done-cloud.js.map +0 -1
  359. package/dist/wu-done-decay.js +0 -86
  360. package/dist/wu-done-decay.js.map +0 -1
  361. package/dist/wu-done.js.map +0 -1
  362. package/dist/wu-edit-operations.js +0 -399
  363. package/dist/wu-edit-operations.js.map +0 -1
  364. package/dist/wu-edit-validators.js +0 -282
  365. package/dist/wu-edit-validators.js.map +0 -1
  366. package/dist/wu-edit.js.map +0 -1
  367. package/dist/wu-infer-lane.js.map +0 -1
  368. package/dist/wu-preflight.js.map +0 -1
  369. package/dist/wu-prep.js.map +0 -1
  370. package/dist/wu-proto.js.map +0 -1
  371. package/dist/wu-prune.js.map +0 -1
  372. package/dist/wu-recover.js.map +0 -1
  373. package/dist/wu-release.js.map +0 -1
  374. package/dist/wu-repair.js.map +0 -1
  375. package/dist/wu-sandbox.js.map +0 -1
  376. package/dist/wu-spawn-completion.js +0 -33
  377. package/dist/wu-spawn-completion.js.map +0 -1
  378. package/dist/wu-spawn-prompt-builders.js +0 -1197
  379. package/dist/wu-spawn-prompt-builders.js.map +0 -1
  380. package/dist/wu-spawn-strategy-resolver.js +0 -322
  381. package/dist/wu-spawn-strategy-resolver.js.map +0 -1
  382. package/dist/wu-spawn.js +0 -59
  383. package/dist/wu-spawn.js.map +0 -1
  384. package/dist/wu-state-cloud.js +0 -41
  385. package/dist/wu-state-cloud.js.map +0 -1
  386. package/dist/wu-status.js.map +0 -1
  387. package/dist/wu-unblock.js.map +0 -1
  388. package/dist/wu-unlock-lane.js.map +0 -1
  389. package/dist/wu-validate.js.map +0 -1
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@lumenflow/cli",
3
- "version": "3.1.2",
3
+ "version": "3.1.3",
4
4
  "description": "Command-line interface for LumenFlow workflow framework",
5
5
  "keywords": [
6
6
  "lumenflow",
@@ -142,11 +142,13 @@
142
142
  "workspace-init": "./dist/workspace-init.js",
143
143
  "config-set": "./dist/config-set.js",
144
144
  "config-get": "./dist/config-get.js",
145
+ "cloud-connect": "./dist/init.js",
145
146
  "lumenflow-onboard": "./dist/onboard.js",
146
147
  "onboard": "./dist/onboard.js"
147
148
  },
148
149
  "files": [
149
150
  "dist",
151
+ "packs",
150
152
  "templates",
151
153
  "LICENSE",
152
154
  "README.md"
@@ -176,12 +178,12 @@
176
178
  "xstate": "^5.28.0",
177
179
  "yaml": "^2.8.2",
178
180
  "zod": "^4.3.6",
179
- "@lumenflow/agent": "3.1.2",
180
- "@lumenflow/kernel": "3.1.2",
181
- "@lumenflow/memory": "3.1.2",
182
- "@lumenflow/initiatives": "3.1.2",
183
- "@lumenflow/core": "3.1.2",
184
- "@lumenflow/metrics": "3.1.2"
181
+ "@lumenflow/agent": "3.1.3",
182
+ "@lumenflow/core": "3.1.3",
183
+ "@lumenflow/initiatives": "3.1.3",
184
+ "@lumenflow/metrics": "3.1.3",
185
+ "@lumenflow/memory": "3.1.3",
186
+ "@lumenflow/kernel": "3.1.3"
185
187
  },
186
188
  "devDependencies": {
187
189
  "@vitest/coverage-v8": "^4.0.18",
@@ -197,8 +199,10 @@
197
199
  "access": "public"
198
200
  },
199
201
  "scripts": {
202
+ "sync:bundled-packs": "node scripts/sync-bundled-packs.mjs",
200
203
  "build": "tsc && node scripts/check-shebangs.mjs",
201
- "build:dist": "tsup && node scripts/fix-entry-points.mjs && node scripts/check-shebangs.mjs",
204
+ "build:dist:deps": "pnpm --filter @lumenflow/metrics build && pnpm --filter @lumenflow/kernel build && pnpm --filter @lumenflow/core build && pnpm --filter @lumenflow/memory build && pnpm --filter @lumenflow/agent build && pnpm --filter @lumenflow/initiatives build",
205
+ "build:dist": "pnpm run clean && pnpm run build:dist:deps && tsup && node scripts/fix-entry-points.mjs && node scripts/check-shebangs.mjs",
202
206
  "pack:dist": "pnpm pack",
203
207
  "clean": "rm -rf dist *.tgz",
204
208
  "test": "vitest run",
@@ -0,0 +1,10 @@
1
+ // Copyright (c) 2026 Hellmai Ltd
2
+ // SPDX-License-Identifier: AGPL-3.0-only
3
+
4
+ export const SOFTWARE_DELIVERY_PACK_ID = 'software-delivery' as const;
5
+ export const SOFTWARE_DELIVERY_PACK_VERSION = '0.1.0' as const;
6
+ export const SOFTWARE_DELIVERY_DOMAIN = SOFTWARE_DELIVERY_PACK_ID;
7
+ export const SOFTWARE_DELIVERY_POLICY_ID_PREFIX = `${SOFTWARE_DELIVERY_PACK_ID}.gate` as const;
8
+ export const SOFTWARE_DELIVERY_MANIFEST_FILE_NAME = 'manifest.yaml' as const;
9
+ export const SHA256_ALGORITHM = 'sha256' as const;
10
+ export const UTF8_ENCODING = 'utf8' as const;
@@ -0,0 +1,140 @@
1
+ // Copyright (c) 2026 Hellmai Ltd
2
+ // SPDX-License-Identifier: AGPL-3.0-only
3
+
4
+ import { SOFTWARE_DELIVERY_DOMAIN } from './constants.js';
5
+
6
+ export const SOFTWARE_DELIVERY_EXTENSION_KEY = 'software_delivery';
7
+ export const SOFTWARE_DELIVERY_EXPOSURES = ['ui', 'api', 'backend-only', 'documentation'] as const;
8
+
9
+ interface Parser<T> {
10
+ parse(input: unknown): T;
11
+ }
12
+
13
+ export interface SoftwareDeliveryTests {
14
+ unit: string[];
15
+ e2e: string[];
16
+ manual: string[];
17
+ }
18
+
19
+ export interface SoftwareDeliveryTaskExtensions {
20
+ code_paths: string[];
21
+ tests: SoftwareDeliveryTests;
22
+ exposure: (typeof SOFTWARE_DELIVERY_EXPOSURES)[number];
23
+ worktree: string;
24
+ branch: string;
25
+ }
26
+
27
+ export interface SoftwareDeliveryTask {
28
+ domain: typeof SOFTWARE_DELIVERY_DOMAIN;
29
+ extensions: Record<string, unknown> & {
30
+ [SOFTWARE_DELIVERY_EXTENSION_KEY]: SoftwareDeliveryTaskExtensions;
31
+ };
32
+ }
33
+
34
+ function asRecord(input: unknown, label: string): Record<string, unknown> {
35
+ if (!input || typeof input !== 'object' || Array.isArray(input)) {
36
+ throw new Error(`${label} must be an object.`);
37
+ }
38
+ return input as Record<string, unknown>;
39
+ }
40
+
41
+ function assertOnlyKeys(
42
+ record: Record<string, unknown>,
43
+ allowedKeys: readonly string[],
44
+ label: string,
45
+ ): void {
46
+ const allowed = new Set(allowedKeys);
47
+ for (const key of Object.keys(record)) {
48
+ if (!allowed.has(key)) {
49
+ throw new Error(`${label} has unrecognized key "${key}".`);
50
+ }
51
+ }
52
+ }
53
+
54
+ function parseNonEmptyString(value: unknown, label: string): string {
55
+ if (typeof value !== 'string' || value.trim().length === 0) {
56
+ throw new Error(`${label} must be a non-empty string.`);
57
+ }
58
+ return value;
59
+ }
60
+
61
+ function parseStringArray(value: unknown, label: string): string[] {
62
+ if (!Array.isArray(value)) {
63
+ throw new Error(`${label} must be an array.`);
64
+ }
65
+ return value.map((entry, index) => parseNonEmptyString(entry, `${label}[${index}]`));
66
+ }
67
+
68
+ function parseTests(input: unknown): SoftwareDeliveryTests {
69
+ const tests = asRecord(input, 'tests');
70
+ assertOnlyKeys(tests, ['unit', 'e2e', 'manual'], 'tests');
71
+ return {
72
+ unit: parseStringArray(tests.unit ?? [], 'tests.unit'),
73
+ e2e: parseStringArray(tests.e2e ?? [], 'tests.e2e'),
74
+ manual: parseStringArray(tests.manual ?? [], 'tests.manual'),
75
+ };
76
+ }
77
+
78
+ const ExposureSet = new Set<string>(SOFTWARE_DELIVERY_EXPOSURES);
79
+
80
+ export const SoftwareDeliveryTaskExtensionsSchema: Parser<SoftwareDeliveryTaskExtensions> = {
81
+ parse(input: unknown): SoftwareDeliveryTaskExtensions {
82
+ const extension = asRecord(input, 'software delivery extension');
83
+ assertOnlyKeys(
84
+ extension,
85
+ ['code_paths', 'tests', 'exposure', 'worktree', 'branch'],
86
+ 'software delivery extension',
87
+ );
88
+
89
+ const exposure = parseNonEmptyString(extension.exposure, 'exposure');
90
+ if (!ExposureSet.has(exposure)) {
91
+ throw new Error(`exposure must be one of: ${SOFTWARE_DELIVERY_EXPOSURES.join(', ')}`);
92
+ }
93
+
94
+ return {
95
+ code_paths: parseStringArray(extension.code_paths, 'code_paths'),
96
+ tests: parseTests(extension.tests),
97
+ exposure: exposure as (typeof SOFTWARE_DELIVERY_EXPOSURES)[number],
98
+ worktree: parseNonEmptyString(extension.worktree, 'worktree'),
99
+ branch: parseNonEmptyString(extension.branch, 'branch'),
100
+ };
101
+ },
102
+ };
103
+
104
+ export const TaskExtensionsOpaqueRecordSchema: Parser<Record<string, unknown>> = {
105
+ parse(input: unknown): Record<string, unknown> {
106
+ return asRecord(input, 'extensions');
107
+ },
108
+ };
109
+
110
+ export function extractSoftwareDeliveryExtensions(
111
+ extensions: Record<string, unknown> | undefined,
112
+ ): SoftwareDeliveryTaskExtensions {
113
+ const parsedExtensions = TaskExtensionsOpaqueRecordSchema.parse(extensions ?? {});
114
+ return SoftwareDeliveryTaskExtensionsSchema.parse(
115
+ parsedExtensions[SOFTWARE_DELIVERY_EXTENSION_KEY],
116
+ );
117
+ }
118
+
119
+ export const SoftwareDeliveryTaskSchema: Parser<SoftwareDeliveryTask> = {
120
+ parse(input: unknown): SoftwareDeliveryTask {
121
+ const task = asRecord(input, 'task');
122
+
123
+ if (task.domain !== SOFTWARE_DELIVERY_DOMAIN) {
124
+ throw new Error(`task.domain must be "${SOFTWARE_DELIVERY_DOMAIN}".`);
125
+ }
126
+
127
+ const parsedExtensions = TaskExtensionsOpaqueRecordSchema.parse(task.extensions);
128
+ const parsedSoftwareDeliveryExtensions = SoftwareDeliveryTaskExtensionsSchema.parse(
129
+ parsedExtensions[SOFTWARE_DELIVERY_EXTENSION_KEY],
130
+ );
131
+
132
+ return {
133
+ domain: SOFTWARE_DELIVERY_DOMAIN,
134
+ extensions: {
135
+ ...parsedExtensions,
136
+ [SOFTWARE_DELIVERY_EXTENSION_KEY]: parsedSoftwareDeliveryExtensions,
137
+ },
138
+ };
139
+ },
140
+ };
@@ -0,0 +1,134 @@
1
+ // Copyright (c) 2026 Hellmai Ltd
2
+ // SPDX-License-Identifier: AGPL-3.0-only
3
+
4
+ import { SOFTWARE_DELIVERY_PACK_ID, SOFTWARE_DELIVERY_POLICY_ID_PREFIX } from './constants.js';
5
+
6
+ export const SOFTWARE_DELIVERY_GATE_NAMES = [
7
+ 'format',
8
+ 'lint',
9
+ 'typecheck',
10
+ 'test',
11
+ 'coverage',
12
+ ] as const;
13
+
14
+ export type SoftwareDeliveryGateName = (typeof SOFTWARE_DELIVERY_GATE_NAMES)[number];
15
+
16
+ export interface PolicyProvider {
17
+ id: string;
18
+ gate: SoftwareDeliveryGateName;
19
+ trigger: 'on_completion';
20
+ command: string;
21
+ }
22
+
23
+ export interface CompletionPolicyContext {
24
+ trigger: 'on_completion';
25
+ run_id: string;
26
+ task_id: string;
27
+ gate: SoftwareDeliveryGateName;
28
+ pack_id: typeof SOFTWARE_DELIVERY_PACK_ID;
29
+ }
30
+
31
+ export interface CompletionPolicyEvaluation {
32
+ decision: 'allow' | 'deny';
33
+ decisions: Array<{
34
+ policy_id: string;
35
+ decision: 'allow' | 'deny';
36
+ reason?: string;
37
+ }>;
38
+ warnings: string[];
39
+ }
40
+
41
+ export interface CompletionPolicyEngine {
42
+ evaluate(context: CompletionPolicyContext): Promise<CompletionPolicyEvaluation>;
43
+ }
44
+
45
+ export interface CompletionPolicyExecution {
46
+ ok: boolean;
47
+ }
48
+
49
+ export interface CompletionPolicyRunResult {
50
+ gate: SoftwareDeliveryGateName;
51
+ policy_id: string;
52
+ decision: 'allow' | 'deny';
53
+ command: string;
54
+ executed: boolean;
55
+ ok: boolean;
56
+ }
57
+
58
+ const SOFTWARE_DELIVERY_GATE_COMMANDS: Record<SoftwareDeliveryGateName, string> = {
59
+ format: 'pnpm format:check',
60
+ lint: 'pnpm lint',
61
+ typecheck: 'pnpm typecheck',
62
+ test: 'pnpm turbo run test',
63
+ coverage: 'pnpm vitest run --coverage',
64
+ };
65
+
66
+ export const SOFTWARE_DELIVERY_GATE_POLICIES: readonly PolicyProvider[] =
67
+ SOFTWARE_DELIVERY_GATE_NAMES.map((gate) => ({
68
+ id: `${SOFTWARE_DELIVERY_POLICY_ID_PREFIX}.${gate}`,
69
+ gate,
70
+ trigger: 'on_completion',
71
+ command: SOFTWARE_DELIVERY_GATE_COMMANDS[gate],
72
+ }));
73
+
74
+ export const SOFTWARE_DELIVERY_STATE_ALIASES = {
75
+ active: 'in_progress',
76
+ } as const;
77
+
78
+ export function resolveSoftwareDeliveryStateAlias(
79
+ state: string,
80
+ aliases: Record<string, string> = SOFTWARE_DELIVERY_STATE_ALIASES,
81
+ ): string {
82
+ return aliases[state] ?? state;
83
+ }
84
+
85
+ export async function runCompletionGatePolicies(options: {
86
+ engine: CompletionPolicyEngine;
87
+ runId: string;
88
+ taskId: string;
89
+ providers?: readonly PolicyProvider[];
90
+ executePolicy?: (provider: PolicyProvider) => Promise<CompletionPolicyExecution>;
91
+ }): Promise<CompletionPolicyRunResult[]> {
92
+ const providers = options.providers ?? SOFTWARE_DELIVERY_GATE_POLICIES;
93
+ const executePolicy =
94
+ options.executePolicy ??
95
+ (async () => ({
96
+ ok: true,
97
+ }));
98
+
99
+ const results: CompletionPolicyRunResult[] = [];
100
+
101
+ for (const provider of providers) {
102
+ const evaluation = await options.engine.evaluate({
103
+ trigger: provider.trigger,
104
+ run_id: options.runId,
105
+ task_id: options.taskId,
106
+ gate: provider.gate,
107
+ pack_id: SOFTWARE_DELIVERY_PACK_ID,
108
+ });
109
+
110
+ if (evaluation.decision === 'deny') {
111
+ results.push({
112
+ gate: provider.gate,
113
+ policy_id: provider.id,
114
+ decision: 'deny',
115
+ command: provider.command,
116
+ executed: false,
117
+ ok: false,
118
+ });
119
+ continue;
120
+ }
121
+
122
+ const execution = await executePolicy(provider);
123
+ results.push({
124
+ gate: provider.gate,
125
+ policy_id: provider.id,
126
+ decision: 'allow',
127
+ command: provider.command,
128
+ executed: true,
129
+ ok: execution.ok,
130
+ });
131
+ }
132
+
133
+ return results;
134
+ }
@@ -0,0 +1,8 @@
1
+ // Copyright (c) 2026 Hellmai Ltd
2
+ // SPDX-License-Identifier: AGPL-3.0-only
3
+
4
+ export * from './constants.js';
5
+ export * from './extensions.js';
6
+ export * from './gate-policies.js';
7
+ export * from './manifest.js';
8
+ export * from './pack-registration.js';
@@ -0,0 +1,236 @@
1
+ // Copyright (c) 2026 Hellmai Ltd
2
+ // SPDX-License-Identifier: AGPL-3.0-only
3
+
4
+ import {
5
+ TOOL_PERMISSIONS,
6
+ TOOL_SCOPE_ACCESS,
7
+ TOOL_SCOPE_TYPES,
8
+ type PathScope,
9
+ type ToolPermission,
10
+ } from './tools/types.js';
11
+
12
+ interface Parser<T> {
13
+ parse(input: unknown): T;
14
+ }
15
+
16
+ export const MANIFEST_POLICY_TRIGGERS = {
17
+ ON_TOOL_REQUEST: 'on_tool_request',
18
+ ON_CLAIM: 'on_claim',
19
+ ON_COMPLETION: 'on_completion',
20
+ ON_EVIDENCE_ADDED: 'on_evidence_added',
21
+ } as const;
22
+
23
+ export type ManifestPolicyTrigger =
24
+ (typeof MANIFEST_POLICY_TRIGGERS)[keyof typeof MANIFEST_POLICY_TRIGGERS];
25
+
26
+ export const MANIFEST_POLICY_DECISIONS = {
27
+ ALLOW: 'allow',
28
+ DENY: 'deny',
29
+ } as const;
30
+
31
+ export type ManifestPolicyDecision =
32
+ (typeof MANIFEST_POLICY_DECISIONS)[keyof typeof MANIFEST_POLICY_DECISIONS];
33
+
34
+ export interface SoftwareDeliveryManifestTool {
35
+ name: string;
36
+ entry: string;
37
+ permission: ToolPermission;
38
+ required_scopes: PathScope[];
39
+ internal_only?: boolean;
40
+ }
41
+
42
+ export interface SoftwareDeliveryManifestPolicy {
43
+ id: string;
44
+ trigger: ManifestPolicyTrigger;
45
+ decision: ManifestPolicyDecision;
46
+ reason?: string;
47
+ }
48
+
49
+ export interface SoftwareDeliveryPackManifest {
50
+ id: string;
51
+ version: string;
52
+ task_types: string[];
53
+ tools: SoftwareDeliveryManifestTool[];
54
+ policies: SoftwareDeliveryManifestPolicy[];
55
+ evidence_types: string[];
56
+ state_aliases: Record<string, string>;
57
+ lane_templates: Array<{ id: string }>;
58
+ }
59
+
60
+ function asRecord(input: unknown, label: string): Record<string, unknown> {
61
+ if (!input || typeof input !== 'object' || Array.isArray(input)) {
62
+ throw new Error(`${label} must be an object.`);
63
+ }
64
+ return input as Record<string, unknown>;
65
+ }
66
+
67
+ function parseNonEmptyString(value: unknown, label: string): string {
68
+ if (typeof value !== 'string' || value.trim().length === 0) {
69
+ throw new Error(`${label} must be a non-empty string.`);
70
+ }
71
+ return value;
72
+ }
73
+
74
+ function parseStringArray(value: unknown, label: string): string[] {
75
+ if (!Array.isArray(value)) {
76
+ throw new Error(`${label} must be an array.`);
77
+ }
78
+ return value.map((entry, index) => parseNonEmptyString(entry, `${label}[${index}]`));
79
+ }
80
+
81
+ function isSemver(value: string): boolean {
82
+ let core = value;
83
+ const prereleaseIndex = core.indexOf('-');
84
+ if (prereleaseIndex >= 0) {
85
+ core = core.slice(0, prereleaseIndex);
86
+ }
87
+ const metadataIndex = core.indexOf('+');
88
+ if (metadataIndex >= 0) {
89
+ core = core.slice(0, metadataIndex);
90
+ }
91
+ const parts = core.split('.');
92
+ if (parts.length !== 3) {
93
+ return false;
94
+ }
95
+ return parts.every(
96
+ (part) => part.length > 0 && [...part].every((char) => char >= '0' && char <= '9'),
97
+ );
98
+ }
99
+
100
+ const ALLOWED_POLICY_TRIGGERS = new Set<string>(Object.values(MANIFEST_POLICY_TRIGGERS));
101
+ const ALLOWED_POLICY_DECISIONS = new Set<string>(Object.values(MANIFEST_POLICY_DECISIONS));
102
+ const ALLOWED_TOOL_PERMISSIONS = new Set<string>(Object.values(TOOL_PERMISSIONS));
103
+
104
+ function parsePathScope(input: unknown, label: string): PathScope {
105
+ const scope = asRecord(input, label);
106
+ const type = parseNonEmptyString(scope.type, `${label}.type`);
107
+ const pattern = parseNonEmptyString(scope.pattern, `${label}.pattern`);
108
+ const access = parseNonEmptyString(scope.access, `${label}.access`);
109
+
110
+ if (type !== TOOL_SCOPE_TYPES.PATH) {
111
+ throw new Error(`${label}.type must be "${TOOL_SCOPE_TYPES.PATH}".`);
112
+ }
113
+ if (access !== TOOL_SCOPE_ACCESS.READ && access !== TOOL_SCOPE_ACCESS.WRITE) {
114
+ throw new Error(
115
+ `${label}.access must be "${TOOL_SCOPE_ACCESS.READ}" or "${TOOL_SCOPE_ACCESS.WRITE}".`,
116
+ );
117
+ }
118
+
119
+ return {
120
+ type: TOOL_SCOPE_TYPES.PATH,
121
+ pattern,
122
+ access,
123
+ };
124
+ }
125
+
126
+ function parseRequiredScopes(value: unknown, label: string): PathScope[] {
127
+ if (!Array.isArray(value) || value.length === 0) {
128
+ throw new Error(`${label} must be a non-empty array.`);
129
+ }
130
+ return value.map((entry, index) => parsePathScope(entry, `${label}[${index}]`));
131
+ }
132
+
133
+ function parsePolicy(input: unknown, index: number): SoftwareDeliveryManifestPolicy {
134
+ const policy = asRecord(input, `policies[${index}]`);
135
+ const trigger = parseNonEmptyString(policy.trigger, `policies[${index}].trigger`);
136
+ const decision = parseNonEmptyString(policy.decision, `policies[${index}].decision`);
137
+
138
+ if (!ALLOWED_POLICY_TRIGGERS.has(trigger)) {
139
+ throw new Error(`policies[${index}].trigger is invalid.`);
140
+ }
141
+ if (!ALLOWED_POLICY_DECISIONS.has(decision)) {
142
+ throw new Error(`policies[${index}].decision is invalid.`);
143
+ }
144
+
145
+ return {
146
+ id: parseNonEmptyString(policy.id, `policies[${index}].id`),
147
+ trigger: trigger as ManifestPolicyTrigger,
148
+ decision: decision as ManifestPolicyDecision,
149
+ reason:
150
+ policy.reason === undefined
151
+ ? undefined
152
+ : parseNonEmptyString(policy.reason, `policies[${index}].reason`),
153
+ };
154
+ }
155
+
156
+ function parseTool(input: unknown, index: number): SoftwareDeliveryManifestTool {
157
+ const tool = asRecord(input, `tools[${index}]`);
158
+ const permission =
159
+ tool.permission === undefined
160
+ ? TOOL_PERMISSIONS.READ
161
+ : parseNonEmptyString(tool.permission, `tools[${index}].permission`);
162
+
163
+ if (!ALLOWED_TOOL_PERMISSIONS.has(permission)) {
164
+ throw new Error(`tools[${index}].permission is invalid.`);
165
+ }
166
+
167
+ return {
168
+ name: parseNonEmptyString(tool.name, `tools[${index}].name`),
169
+ entry: parseNonEmptyString(tool.entry, `tools[${index}].entry`),
170
+ permission: permission as ToolPermission,
171
+ required_scopes: parseRequiredScopes(tool.required_scopes, `tools[${index}].required_scopes`),
172
+ internal_only:
173
+ tool.internal_only === undefined
174
+ ? undefined
175
+ : (() => {
176
+ if (typeof tool.internal_only !== 'boolean') {
177
+ throw new Error(`tools[${index}].internal_only must be boolean.`);
178
+ }
179
+ return tool.internal_only;
180
+ })(),
181
+ };
182
+ }
183
+
184
+ function parseStateAliases(input: unknown): Record<string, string> {
185
+ const aliases = asRecord(input ?? {}, 'state_aliases');
186
+ const parsed: Record<string, string> = {};
187
+ for (const [key, value] of Object.entries(aliases)) {
188
+ parsed[parseNonEmptyString(key, 'state_aliases key')] = parseNonEmptyString(
189
+ value,
190
+ `state_aliases.${key}`,
191
+ );
192
+ }
193
+ return parsed;
194
+ }
195
+
196
+ export const SoftwareDeliveryManifestSchema: Parser<SoftwareDeliveryPackManifest> = {
197
+ parse(input: unknown): SoftwareDeliveryPackManifest {
198
+ const manifest = asRecord(input, 'manifest');
199
+ const version = parseNonEmptyString(manifest.version, 'version');
200
+ if (!isSemver(version)) {
201
+ throw new Error('version must be semver.');
202
+ }
203
+
204
+ const taskTypes = parseStringArray(manifest.task_types, 'task_types');
205
+ if (taskTypes.length === 0) {
206
+ throw new Error('task_types must include at least one item.');
207
+ }
208
+
209
+ const toolsValue = manifest.tools ?? [];
210
+ if (!Array.isArray(toolsValue)) {
211
+ throw new Error('tools must be an array.');
212
+ }
213
+ const policiesValue = manifest.policies ?? [];
214
+ if (!Array.isArray(policiesValue)) {
215
+ throw new Error('policies must be an array.');
216
+ }
217
+ const laneTemplatesValue = manifest.lane_templates ?? [];
218
+ if (!Array.isArray(laneTemplatesValue)) {
219
+ throw new Error('lane_templates must be an array.');
220
+ }
221
+
222
+ return {
223
+ id: parseNonEmptyString(manifest.id, 'id'),
224
+ version,
225
+ task_types: taskTypes,
226
+ tools: toolsValue.map((tool, index) => parseTool(tool, index)),
227
+ policies: policiesValue.map((policy, index) => parsePolicy(policy, index)),
228
+ evidence_types: parseStringArray(manifest.evidence_types ?? [], 'evidence_types'),
229
+ state_aliases: parseStateAliases(manifest.state_aliases),
230
+ lane_templates: laneTemplatesValue.map((laneTemplate, index) => {
231
+ const entry = asRecord(laneTemplate, `lane_templates[${index}]`);
232
+ return { id: parseNonEmptyString(entry.id, `lane_templates[${index}].id`) };
233
+ }),
234
+ };
235
+ },
236
+ };