@pugi/cli 0.1.0-beta.99 → 1.0.0-alpha.1

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 (448) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +11 -191
  3. package/bin/pugi +8 -0
  4. package/package.json +15 -71
  5. package/postinstall.mjs +31 -0
  6. package/CHANGELOG.md +0 -132
  7. package/THIRD_PARTY_NOTICES.md +0 -40
  8. package/assets/pugi-mascot.ansi +0 -16
  9. package/assets/pugi-prozr2-mascot.ansi +0 -9
  10. package/bin/run.js +0 -34
  11. package/dist/commands/deploy.js +0 -439
  12. package/dist/commands/flatten.js +0 -191
  13. package/dist/commands/jobs-watch.js +0 -201
  14. package/dist/commands/jobs.js +0 -260
  15. package/dist/commands/retro.js +0 -210
  16. package/dist/commands/smoke.js +0 -133
  17. package/dist/core/agent-progress/cleanup.js +0 -134
  18. package/dist/core/agent-progress/schema.js +0 -144
  19. package/dist/core/agent-progress/writer.js +0 -101
  20. package/dist/core/agents/adaptive-router.js +0 -330
  21. package/dist/core/agents/loader.js +0 -104
  22. package/dist/core/agents/query-decomposer.js +0 -297
  23. package/dist/core/agents/registry.js +0 -69
  24. package/dist/core/approvals/shortcut-resolver.js +0 -98
  25. package/dist/core/artifact-chain/dispatcher.js +0 -148
  26. package/dist/core/artifact-chain/exporter.js +0 -164
  27. package/dist/core/artifact-chain/state.js +0 -243
  28. package/dist/core/artifact-chain/steps.js +0 -169
  29. package/dist/core/ask-user/question.js +0 -92
  30. package/dist/core/audit/audit-trail.js +0 -275
  31. package/dist/core/auth/ensure-authenticated.js +0 -129
  32. package/dist/core/auth/env-provider.js +0 -238
  33. package/dist/core/auto-open-browser.js +0 -128
  34. package/dist/core/auto-update/channels.js +0 -122
  35. package/dist/core/auto-update/checker.js +0 -241
  36. package/dist/core/auto-update/state.js +0 -235
  37. package/dist/core/bare-mode/index.js +0 -107
  38. package/dist/core/bash/redirect.js +0 -281
  39. package/dist/core/bash-classifier.js +0 -1397
  40. package/dist/core/checkpoint/resumer.js +0 -149
  41. package/dist/core/checkpoint/rewinder.js +0 -291
  42. package/dist/core/checkpoints/shadow-git.js +0 -670
  43. package/dist/core/citations/parser.js +0 -109
  44. package/dist/core/classifier/yolo-classifier.js +0 -88
  45. package/dist/core/clipboard.js +0 -70
  46. package/dist/core/codegraph/decision-store.js +0 -248
  47. package/dist/core/codegraph/detect-repo.js +0 -459
  48. package/dist/core/codegraph/install.js +0 -134
  49. package/dist/core/codegraph/offer-hook.js +0 -220
  50. package/dist/core/compact/auto-trigger.js +0 -96
  51. package/dist/core/compact/buffer-rewriter.js +0 -115
  52. package/dist/core/compact/summarizer.js +0 -208
  53. package/dist/core/compact/token-counter.js +0 -108
  54. package/dist/core/consensus/anvil-fanout.js +0 -276
  55. package/dist/core/consensus/diff-capture.js +0 -491
  56. package/dist/core/consensus/rubric.js +0 -233
  57. package/dist/core/context/builder.js +0 -114
  58. package/dist/core/context/compaction-events.js +0 -99
  59. package/dist/core/context/compaction.js +0 -602
  60. package/dist/core/context/index.js +0 -28
  61. package/dist/core/context/invariants.js +0 -250
  62. package/dist/core/context/markdown-loader.js +0 -288
  63. package/dist/core/context/markdown-traverse.js +0 -255
  64. package/dist/core/context/pugiignore.js +0 -316
  65. package/dist/core/context/repo-skeleton.js +0 -533
  66. package/dist/core/context/tool-eviction.js +0 -55
  67. package/dist/core/context/watcher.js +0 -342
  68. package/dist/core/context/working-set.js +0 -165
  69. package/dist/core/coordinator/agent-tools.js +0 -77
  70. package/dist/core/coordinator/agent-toolset.js +0 -65
  71. package/dist/core/coordinator/fsm.js +0 -73
  72. package/dist/core/coordinator/mode-fsm.js +0 -70
  73. package/dist/core/cost/rate-card.js +0 -129
  74. package/dist/core/cost/tracker.js +0 -221
  75. package/dist/core/credentials.js +0 -355
  76. package/dist/core/cron/scheduler.js +0 -138
  77. package/dist/core/denial-tracking/index.js +0 -8
  78. package/dist/core/denial-tracking/state.js +0 -264
  79. package/dist/core/diagnostics/probe-runner.js +0 -93
  80. package/dist/core/diagnostics/probes/api.js +0 -46
  81. package/dist/core/diagnostics/probes/auth.js +0 -93
  82. package/dist/core/diagnostics/probes/bare-mode.js +0 -42
  83. package/dist/core/diagnostics/probes/cli-version.js +0 -127
  84. package/dist/core/diagnostics/probes/config.js +0 -72
  85. package/dist/core/diagnostics/probes/denial-tracking.js +0 -57
  86. package/dist/core/diagnostics/probes/disk.js +0 -81
  87. package/dist/core/diagnostics/probes/engine-live.js +0 -46
  88. package/dist/core/diagnostics/probes/git.js +0 -65
  89. package/dist/core/diagnostics/probes/hooks.js +0 -118
  90. package/dist/core/diagnostics/probes/mcp.js +0 -75
  91. package/dist/core/diagnostics/probes/node.js +0 -59
  92. package/dist/core/diagnostics/probes/pnpm.js +0 -36
  93. package/dist/core/diagnostics/probes/pugi-md.js +0 -89
  94. package/dist/core/diagnostics/probes/sandbox.js +0 -72
  95. package/dist/core/diagnostics/probes/session.js +0 -74
  96. package/dist/core/diagnostics/probes/status-snapshot.js +0 -488
  97. package/dist/core/diagnostics/probes/workspace.js +0 -63
  98. package/dist/core/diagnostics/types.js +0 -70
  99. package/dist/core/dispatch/cache-cleanup.js +0 -197
  100. package/dist/core/dispatch/cache-handoff.js +0 -295
  101. package/dist/core/edits/apply-patch-layer-e.js +0 -189
  102. package/dist/core/edits/dispatch.js +0 -511
  103. package/dist/core/edits/format-detector.js +0 -260
  104. package/dist/core/edits/format-matrix.js +0 -26
  105. package/dist/core/edits/fuzzy-ladder.js +0 -650
  106. package/dist/core/edits/index.js +0 -19
  107. package/dist/core/edits/journal.js +0 -199
  108. package/dist/core/edits/layer-a-apply.js +0 -217
  109. package/dist/core/edits/layer-a-fuzzy-apply.js +0 -198
  110. package/dist/core/edits/layer-b-apply.js +0 -211
  111. package/dist/core/edits/layer-c-apply.js +0 -160
  112. package/dist/core/edits/layer-d-ast.js +0 -572
  113. package/dist/core/edits/marker-parser.js +0 -401
  114. package/dist/core/edits/security-gate.js +0 -223
  115. package/dist/core/edits/verify-hook.js +0 -273
  116. package/dist/core/edits/worktree.js +0 -322
  117. package/dist/core/engine/adapter-runner.js +0 -8
  118. package/dist/core/engine/anvil-client.js +0 -344
  119. package/dist/core/engine/auto-compact.js +0 -179
  120. package/dist/core/engine/budgets.js +0 -195
  121. package/dist/core/engine/context-prefix.js +0 -155
  122. package/dist/core/engine/index.js +0 -12
  123. package/dist/core/engine/intensity.js +0 -163
  124. package/dist/core/engine/intent.js +0 -260
  125. package/dist/core/engine/native-pugi.js +0 -1616
  126. package/dist/core/engine/noop.js +0 -27
  127. package/dist/core/engine/prompts.js +0 -236
  128. package/dist/core/engine/strip-internal-fields.js +0 -124
  129. package/dist/core/engine/tool-bridge.js +0 -2173
  130. package/dist/core/engine/verification-patterns.js +0 -195
  131. package/dist/core/evaluation/golden-dataset.js +0 -293
  132. package/dist/core/feedback/queue.js +0 -177
  133. package/dist/core/feedback/submitter.js +0 -145
  134. package/dist/core/file-cache.js +0 -141
  135. package/dist/core/flatten/flatten-repo.js +0 -439
  136. package/dist/core/format/osc8-link.js +0 -28
  137. package/dist/core/hook-chains.js +0 -392
  138. package/dist/core/hooks/citation-verify-hook.js +0 -138
  139. package/dist/core/hooks/citation-verify.js +0 -112
  140. package/dist/core/hooks/events.js +0 -46
  141. package/dist/core/hooks/index.js +0 -15
  142. package/dist/core/hooks/registry.js +0 -216
  143. package/dist/core/hooks/runner.js +0 -236
  144. package/dist/core/hooks/v2/event-emitter.js +0 -115
  145. package/dist/core/hooks/v2/executor.js +0 -282
  146. package/dist/core/hooks/v2/index.js +0 -25
  147. package/dist/core/hooks/v2/lifecycle.js +0 -104
  148. package/dist/core/hooks/v2/loader.js +0 -216
  149. package/dist/core/hooks/v2/matcher.js +0 -125
  150. package/dist/core/hooks/v2/trust.js +0 -143
  151. package/dist/core/hooks/v2/types.js +0 -86
  152. package/dist/core/hooks/worktree-events.js +0 -158
  153. package/dist/core/hooks.js +0 -415
  154. package/dist/core/image/renderer.js +0 -71
  155. package/dist/core/index-store.js +0 -260
  156. package/dist/core/init/detector.js +0 -582
  157. package/dist/core/init/template-renderer.js +0 -242
  158. package/dist/core/jobs/registry.js +0 -462
  159. package/dist/core/ledger/results-tsv.js +0 -142
  160. package/dist/core/log-discipline/stdout-redirect.js +0 -51
  161. package/dist/core/lsp/cache.js +0 -105
  162. package/dist/core/lsp/client.js +0 -1229
  163. package/dist/core/lsp/language-detect.js +0 -66
  164. package/dist/core/lsp/post-edit-diagnostics.js +0 -171
  165. package/dist/core/lsp/server-detect.js +0 -173
  166. package/dist/core/lsp/symbol-cache.js +0 -162
  167. package/dist/core/lsp/symbol-tools.js +0 -664
  168. package/dist/core/mcp/client.js +0 -385
  169. package/dist/core/mcp/http-server.js +0 -553
  170. package/dist/core/mcp/orchestrator-config.js +0 -192
  171. package/dist/core/mcp/orchestrator-tools.js +0 -806
  172. package/dist/core/mcp/permission.js +0 -190
  173. package/dist/core/mcp/registry.js +0 -193
  174. package/dist/core/mcp/server-tools.js +0 -219
  175. package/dist/core/mcp/server.js +0 -397
  176. package/dist/core/mcp/trust.js +0 -91
  177. package/dist/core/memory/dual-write.js +0 -416
  178. package/dist/core/memory/passive-extract.js +0 -130
  179. package/dist/core/memory/phase1-kinds.js +0 -20
  180. package/dist/core/memory/secret-scanner.js +0 -304
  181. package/dist/core/memory-sync/queue.js +0 -170
  182. package/dist/core/metrics/extract.js +0 -113
  183. package/dist/core/modes/roo-modes.js +0 -68
  184. package/dist/core/onboarding/ensure-initialized.js +0 -133
  185. package/dist/core/onboarding/marker.js +0 -111
  186. package/dist/core/onboarding/telemetry-state.js +0 -108
  187. package/dist/core/output-style/presets.js +0 -176
  188. package/dist/core/output-style/state.js +0 -185
  189. package/dist/core/path-security.js +0 -345
  190. package/dist/core/permission.js +0 -369
  191. package/dist/core/permissions/auto-classifier.js +0 -124
  192. package/dist/core/permissions/bash-parser.js +0 -371
  193. package/dist/core/permissions/circuit-breaker.js +0 -83
  194. package/dist/core/permissions/constrained-edit.js +0 -91
  195. package/dist/core/permissions/gate.js +0 -278
  196. package/dist/core/permissions/index.js +0 -20
  197. package/dist/core/permissions/mode.js +0 -174
  198. package/dist/core/permissions/network-egress.js +0 -137
  199. package/dist/core/permissions/state.js +0 -241
  200. package/dist/core/permissions/tool-class.js +0 -107
  201. package/dist/core/plan-mode/ui-state.js +0 -51
  202. package/dist/core/plans/plan-artifact.js +0 -721
  203. package/dist/core/policy-limits/etag-store.js +0 -122
  204. package/dist/core/prd-check/parser.js +0 -215
  205. package/dist/core/prd-check/reporter.js +0 -127
  206. package/dist/core/prd-check/session-review.js +0 -557
  207. package/dist/core/prd-check/verifiers.js +0 -223
  208. package/dist/core/prompt-cache/client-cache.js +0 -99
  209. package/dist/core/prompts/assembly.js +0 -29
  210. package/dist/core/prompts/registry.js +0 -364
  211. package/dist/core/pugi-gitignore.js +0 -52
  212. package/dist/core/pugi-md/cc-compat-rules.js +0 -735
  213. package/dist/core/pugi-md/context-injector.js +0 -76
  214. package/dist/core/pugi-md/walk-up.js +0 -207
  215. package/dist/core/python/uv-installer.js +0 -270
  216. package/dist/core/python/uv-resolver.js +0 -83
  217. package/dist/core/rate-limit/narrator.js +0 -146
  218. package/dist/core/recipes/cli-types.js +0 -20
  219. package/dist/core/recipes/loader.js +0 -103
  220. package/dist/core/recipes/runner.js +0 -345
  221. package/dist/core/recipes/schema.js +0 -587
  222. package/dist/core/release-notes/parser.js +0 -241
  223. package/dist/core/release-notes/state.js +0 -116
  224. package/dist/core/repl/ask.js +0 -512
  225. package/dist/core/repl/cancellation.js +0 -98
  226. package/dist/core/repl/cap-warning.js +0 -91
  227. package/dist/core/repl/clipboard-read.js +0 -174
  228. package/dist/core/repl/dispatch-fsm.js +0 -220
  229. package/dist/core/repl/engine-bridge.js +0 -303
  230. package/dist/core/repl/history-search.js +0 -175
  231. package/dist/core/repl/history.js +0 -182
  232. package/dist/core/repl/kill-ring.js +0 -138
  233. package/dist/core/repl/model-pricing.js +0 -135
  234. package/dist/core/repl/privacy-banner.js +0 -71
  235. package/dist/core/repl/session.js +0 -4962
  236. package/dist/core/repl/slash-commands.js +0 -747
  237. package/dist/core/repl/store/index.js +0 -12
  238. package/dist/core/repl/store/jsonl-log.js +0 -321
  239. package/dist/core/repl/store/lockfile.js +0 -155
  240. package/dist/core/repl/store/session-store.js +0 -821
  241. package/dist/core/repl/store/types.js +0 -44
  242. package/dist/core/repl/store/uuid-v7.js +0 -68
  243. package/dist/core/repl/tool-route.js +0 -382
  244. package/dist/core/repl/workspace-context.js +0 -206
  245. package/dist/core/repo-map/build.js +0 -125
  246. package/dist/core/repo-map/cache.js +0 -185
  247. package/dist/core/repo-map/extractor.js +0 -254
  248. package/dist/core/repo-map/formatter.js +0 -145
  249. package/dist/core/repo-map/page-rank.js +0 -105
  250. package/dist/core/repo-map/scanner.js +0 -211
  251. package/dist/core/retro/git-collector.js +0 -251
  252. package/dist/core/retro/health-card.js +0 -25
  253. package/dist/core/retro/metrics.js +0 -342
  254. package/dist/core/retro/narrative.js +0 -249
  255. package/dist/core/retro/plane-collector.js +0 -274
  256. package/dist/core/retro/pr-issue-link.js +0 -65
  257. package/dist/core/retro/types.js +0 -16
  258. package/dist/core/retry-budget/budget.js +0 -284
  259. package/dist/core/retry-budget/index.js +0 -5
  260. package/dist/core/retry-budget/retry-cap.js +0 -74
  261. package/dist/core/routing/lead-worker.js +0 -43
  262. package/dist/core/routing/pre-flight-estimator.js +0 -108
  263. package/dist/core/runs/run-tree.js +0 -103
  264. package/dist/core/sandboxing/adapter.js +0 -29
  265. package/dist/core/sandboxing/index.js +0 -49
  266. package/dist/core/sandboxing/none.js +0 -19
  267. package/dist/core/sandboxing/seatbelt.js +0 -183
  268. package/dist/core/security/injection-scanner.js +0 -367
  269. package/dist/core/security/output-filter.js +0 -418
  270. package/dist/core/session/env-file.js +0 -105
  271. package/dist/core/session/section-budgets.js +0 -140
  272. package/dist/core/session.js +0 -377
  273. package/dist/core/settings.js +0 -400
  274. package/dist/core/share/formatter.js +0 -271
  275. package/dist/core/share/redactor.js +0 -221
  276. package/dist/core/share/uploader.js +0 -267
  277. package/dist/core/skills/defaults.js +0 -457
  278. package/dist/core/skills/loader.js +0 -454
  279. package/dist/core/skills/sources.js +0 -480
  280. package/dist/core/skills/trust.js +0 -172
  281. package/dist/core/smoke/headless-driver.js +0 -174
  282. package/dist/core/smoke/orchestrator.js +0 -194
  283. package/dist/core/smoke/runner.js +0 -238
  284. package/dist/core/smoke/scenario-parser.js +0 -316
  285. package/dist/core/statusline.js +0 -99
  286. package/dist/core/subagents/dispatcher-real.js +0 -600
  287. package/dist/core/subagents/dispatcher.js +0 -352
  288. package/dist/core/subagents/index.js +0 -39
  289. package/dist/core/subagents/isolation-matrix.js +0 -213
  290. package/dist/core/subagents/spawn.js +0 -101
  291. package/dist/core/telemetry/emitter.js +0 -229
  292. package/dist/core/telemetry/queue.js +0 -251
  293. package/dist/core/theme/context.js +0 -91
  294. package/dist/core/theme/presets.js +0 -228
  295. package/dist/core/theme/state.js +0 -181
  296. package/dist/core/todos/invariant.js +0 -10
  297. package/dist/core/todos/state.js +0 -177
  298. package/dist/core/tool-schema/compressor.js +0 -89
  299. package/dist/core/transport/version-interceptor.js +0 -166
  300. package/dist/core/trust.js +0 -109
  301. package/dist/core/tui/thinking-block.js +0 -64
  302. package/dist/core/vim/keymap.js +0 -288
  303. package/dist/core/vim/state.js +0 -92
  304. package/dist/core/watch-markers/marker-watcher.js +0 -133
  305. package/dist/core/worktree/include-parser.js +0 -249
  306. package/dist/core/worktree-manager/cleanup.js +0 -123
  307. package/dist/core/worktree-manager/manager.js +0 -303
  308. package/dist/index.js +0 -44
  309. package/dist/runtime/bootstrap.js +0 -190
  310. package/dist/runtime/cli.js +0 -8121
  311. package/dist/runtime/commands/agents.js +0 -385
  312. package/dist/runtime/commands/budget.js +0 -192
  313. package/dist/runtime/commands/cancel.js +0 -231
  314. package/dist/runtime/commands/chain.js +0 -489
  315. package/dist/runtime/commands/codegraph-status.js +0 -227
  316. package/dist/runtime/commands/compact.js +0 -297
  317. package/dist/runtime/commands/config.js +0 -595
  318. package/dist/runtime/commands/cost.js +0 -199
  319. package/dist/runtime/commands/delegate.js +0 -312
  320. package/dist/runtime/commands/dispatch.js +0 -126
  321. package/dist/runtime/commands/doctor.js +0 -579
  322. package/dist/runtime/commands/feedback.js +0 -184
  323. package/dist/runtime/commands/hooks.js +0 -187
  324. package/dist/runtime/commands/init.js +0 -254
  325. package/dist/runtime/commands/lsp.js +0 -368
  326. package/dist/runtime/commands/mcp.js +0 -935
  327. package/dist/runtime/commands/memory.js +0 -582
  328. package/dist/runtime/commands/model.js +0 -237
  329. package/dist/runtime/commands/onboarding.js +0 -275
  330. package/dist/runtime/commands/patch.js +0 -128
  331. package/dist/runtime/commands/permissions.js +0 -112
  332. package/dist/runtime/commands/plan.js +0 -143
  333. package/dist/runtime/commands/prd-check.js +0 -285
  334. package/dist/runtime/commands/privacy.js +0 -107
  335. package/dist/runtime/commands/recipe.js +0 -325
  336. package/dist/runtime/commands/redo-blob-store.js +0 -92
  337. package/dist/runtime/commands/redo.js +0 -361
  338. package/dist/runtime/commands/release-notes.js +0 -229
  339. package/dist/runtime/commands/repo-map.js +0 -95
  340. package/dist/runtime/commands/report.js +0 -299
  341. package/dist/runtime/commands/resume.js +0 -118
  342. package/dist/runtime/commands/review-consensus.js +0 -414
  343. package/dist/runtime/commands/rewind.js +0 -333
  344. package/dist/runtime/commands/roster.js +0 -117
  345. package/dist/runtime/commands/sessions.js +0 -163
  346. package/dist/runtime/commands/share.js +0 -316
  347. package/dist/runtime/commands/skills.js +0 -401
  348. package/dist/runtime/commands/status.js +0 -186
  349. package/dist/runtime/commands/stickers.js +0 -82
  350. package/dist/runtime/commands/style.js +0 -194
  351. package/dist/runtime/commands/theme.js +0 -196
  352. package/dist/runtime/commands/undo.js +0 -361
  353. package/dist/runtime/commands/update.js +0 -289
  354. package/dist/runtime/commands/vim.js +0 -140
  355. package/dist/runtime/commands/worktree.js +0 -177
  356. package/dist/runtime/commands/worktrees.js +0 -155
  357. package/dist/runtime/deprecation-warning.js +0 -69
  358. package/dist/runtime/engine-exit-code.js +0 -50
  359. package/dist/runtime/headless-repl.js +0 -195
  360. package/dist/runtime/headless.js +0 -548
  361. package/dist/runtime/load-hooks-or-exit.js +0 -71
  362. package/dist/runtime/plan-decompose.js +0 -531
  363. package/dist/runtime/sigint-guard.js +0 -272
  364. package/dist/runtime/stream-renderer.js +0 -195
  365. package/dist/runtime/update-check.js +0 -294
  366. package/dist/runtime/version.js +0 -65
  367. package/dist/runtime/worktree-bootstrap.js +0 -579
  368. package/dist/skills/bundled/batch.js +0 -617
  369. package/dist/skills/bundled/index.js +0 -45
  370. package/dist/skills/bundled/loop.js +0 -358
  371. package/dist/skills/bundled/remember.js +0 -383
  372. package/dist/skills/bundled/simplify.js +0 -289
  373. package/dist/skills/bundled/skillify.js +0 -373
  374. package/dist/skills/bundled/stuck.js +0 -558
  375. package/dist/skills/bundled/verify.js +0 -439
  376. package/dist/testing/vcr.js +0 -486
  377. package/dist/tools/agent-tool.js +0 -229
  378. package/dist/tools/apply-patch.js +0 -556
  379. package/dist/tools/ask-user-question.js +0 -337
  380. package/dist/tools/ask-user.js +0 -115
  381. package/dist/tools/bash.js +0 -1238
  382. package/dist/tools/brief.js +0 -224
  383. package/dist/tools/cron.js +0 -433
  384. package/dist/tools/enter-worktree.js +0 -250
  385. package/dist/tools/exit-worktree.js +0 -147
  386. package/dist/tools/file-tools.js +0 -553
  387. package/dist/tools/http-request.js +0 -336
  388. package/dist/tools/lsp-tools.js +0 -565
  389. package/dist/tools/mcp-tool.js +0 -260
  390. package/dist/tools/multi-edit.js +0 -361
  391. package/dist/tools/powershell.js +0 -268
  392. package/dist/tools/registry.js +0 -166
  393. package/dist/tools/server-tools.js +0 -892
  394. package/dist/tools/skill-tool.js +0 -96
  395. package/dist/tools/sleep.js +0 -99
  396. package/dist/tools/synthetic-output.js +0 -133
  397. package/dist/tools/tasks.js +0 -208
  398. package/dist/tools/todo-write.js +0 -184
  399. package/dist/tools/verify-plan-execution.js +0 -295
  400. package/dist/tools/web-fetch-injection-scanner.js +0 -207
  401. package/dist/tools/web-fetch.js +0 -720
  402. package/dist/tools/web-search.js +0 -458
  403. package/dist/tui/agent-progress-card.js +0 -111
  404. package/dist/tui/agent-tree-pane.js +0 -9
  405. package/dist/tui/agent-tree.js +0 -87
  406. package/dist/tui/ask-cli.js +0 -52
  407. package/dist/tui/ask-modal.js +0 -211
  408. package/dist/tui/ask-user-question-chips.js +0 -315
  409. package/dist/tui/ask-user-question-prompt.js +0 -203
  410. package/dist/tui/compact-banner.js +0 -81
  411. package/dist/tui/conversation-pane.js +0 -164
  412. package/dist/tui/cost-table.js +0 -111
  413. package/dist/tui/device-flow.js +0 -142
  414. package/dist/tui/doctor-table.js +0 -46
  415. package/dist/tui/feedback-prompt.js +0 -156
  416. package/dist/tui/input-box.js +0 -732
  417. package/dist/tui/login-picker.js +0 -69
  418. package/dist/tui/markdown-render.js +0 -266
  419. package/dist/tui/multi-file-diff-approval.js +0 -375
  420. package/dist/tui/onboarding-wizard.js +0 -240
  421. package/dist/tui/permissions-picker.js +0 -86
  422. package/dist/tui/render.js +0 -160
  423. package/dist/tui/repl-render.js +0 -770
  424. package/dist/tui/repl-splash-art.js +0 -64
  425. package/dist/tui/repl-splash-mascot.js +0 -154
  426. package/dist/tui/repl-splash.js +0 -117
  427. package/dist/tui/repl.js +0 -378
  428. package/dist/tui/slash-palette.js +0 -106
  429. package/dist/tui/splash-data.js +0 -61
  430. package/dist/tui/splash.js +0 -31
  431. package/dist/tui/status-bar.js +0 -209
  432. package/dist/tui/status-table.js +0 -7
  433. package/dist/tui/stickers-art.js +0 -136
  434. package/dist/tui/style-table.js +0 -28
  435. package/dist/tui/theme-table.js +0 -29
  436. package/dist/tui/thinking-spinner.js +0 -123
  437. package/dist/tui/tool-stream-pane.js +0 -140
  438. package/dist/tui/update-banner.js +0 -33
  439. package/dist/tui/vim-input.js +0 -267
  440. package/dist/tui/welcome-banner.js +0 -107
  441. package/dist/tui/welcome-data.js +0 -293
  442. package/dist/tui/workspace-context.js +0 -105
  443. package/docs/examples/codegraph.mcp.json +0 -10
  444. package/test/scenarios/codegen-create-file.scenario.txt +0 -13
  445. package/test/scenarios/compact-force.scenario.txt +0 -12
  446. package/test/scenarios/identity.scenario.txt +0 -11
  447. package/test/scenarios/persona-handoff.scenario.txt +0 -12
  448. package/test/scenarios/walkback.scenario.txt +0 -12
@@ -1,112 +0,0 @@
1
- /**
2
- * `pugi permissions` / `/permissions` — 4-mode gate control.
3
- *
4
- * Two entry points share one runtime helper:
5
- * 1. `/permissions` in the REPL — forwarded by `core/repl/session.ts`.
6
- * 2. `pugi permissions ...` top-level CLI command (handler in
7
- * `runtime/cli.ts`).
8
- *
9
- * Both pass a `PermissionsCommand` payload describing the operator
10
- * intent (show / flip / persist) and a `writeOutput` callback that
11
- * lets the caller route the rendered lines into the right surface
12
- * (REPL transcript vs. stdout). The helper is intentionally I/O-free
13
- * itself — it produces lines and lets the caller stream them.
14
- */
15
- import { DEFAULT_PERMISSION_MODE, PERMISSION_MODES, PERMISSION_MODE_GLOSS, getCurrentMode, getGlobalDefaultMode, setCurrentMode, setGlobalDefaultMode, } from '../../core/permissions/index.js';
16
- /**
17
- * Run the `/permissions` or `pugi permissions` flow. Side effects:
18
- * - When `command.mode` is undefined: prints the current mode + the
19
- * 4-mode table (no writes).
20
- * - When `command.mode === 'bypass'` without `confirmBypass`: prints
21
- * a refusal + the safety copy, no writes.
22
- * - When `command.mode` is set + valid: writes workspace session
23
- * state; optionally writes global default when `persist` is true.
24
- * - Always prints the new effective mode + a one-line confirmation.
25
- */
26
- export async function runPermissionsCommand(command, ctx) {
27
- if (!command.mode) {
28
- renderCurrentMode(ctx);
29
- renderModeTable(ctx);
30
- return;
31
- }
32
- if (command.mode === 'bypassPermissions' && !command.confirmBypass) {
33
- ctx.writeOutput('bypassPermissions disables policy hooks (skill steering, denial tracking) AND skips the deny-list.');
34
- ctx.writeOutput('Catastrophic patterns (rm -rf /, fork bomb, dd if=/) still trip the circuit-breaker, но that is the only guardrail left.');
35
- ctx.writeOutput('Run `/permissions bypassPermissions --confirm` to acknowledge before flipping.');
36
- return;
37
- }
38
- setCurrentMode(ctx.workspaceRoot, command.mode);
39
- if (command.persist) {
40
- setGlobalDefaultMode(command.mode, ctx.homeDir);
41
- }
42
- const persistedHint = command.persist
43
- ? ' Persisted to ~/.pugi/config.json for future sessions.'
44
- : '';
45
- ctx.writeOutput(`Permission mode set to '${command.mode}'.${persistedHint} ${PERMISSION_MODE_GLOSS[command.mode]}`);
46
- if (command.mode === 'bypassPermissions') {
47
- ctx.writeOutput('bypassPermissions — all tools execute without prompts AND policy hooks disabled (circuit-breaker still trips on rm -rf /). Switch back with /permissions dontAsk.');
48
- }
49
- }
50
- /**
51
- * Print the resolved current mode + the layered source. The merge
52
- * order mirrors `resolveMode()`: workspace > global > default.
53
- */
54
- function renderCurrentMode(ctx) {
55
- const workspace = getCurrentMode(ctx.workspaceRoot);
56
- const global = getGlobalDefaultMode(ctx.homeDir);
57
- const effective = workspace ?? global ?? DEFAULT_PERMISSION_MODE;
58
- const source = workspace
59
- ? 'workspace session.json'
60
- : global
61
- ? 'global ~/.pugi/config.json'
62
- : 'default (no override)';
63
- ctx.writeOutput(`Current permission mode: ${effective} (source: ${source})`);
64
- }
65
- /**
66
- * Print the 4-mode reference table. Keeps the gloss + the side-effect
67
- * matrix in one place so the operator can see the contract while they
68
- * decide which mode to switch to.
69
- */
70
- function renderModeTable(ctx) {
71
- ctx.writeOutput('');
72
- ctx.writeOutput('Permission modes (Shift+Tab cycles in REPL):');
73
- for (const mode of PERMISSION_MODES) {
74
- // : longest canonical name is `bypassPermissions` (17 chars).
75
- ctx.writeOutput(` ${mode.padEnd(18)} ${PERMISSION_MODE_GLOSS[mode]}`);
76
- }
77
- ctx.writeOutput('');
78
- ctx.writeOutput('Switch with `/permissions <mode> [--persist]`. bypassPermissions requires `--confirm`.');
79
- }
80
- /**
81
- * Render the one-shot banner shown on session boot when the effective
82
- * mode is `bypass`. The caller (engine adapter / REPL bootstrap) calls
83
- * this once per session — repeated invocations are idempotent in copy
84
- * but the caller is responsible for the once-only semantics.
85
- */
86
- export function renderBypassBanner(writeOutput) {
87
- writeOutput('bypassPermissions — all tools execute without prompts AND policy hooks disabled (circuit-breaker still trips on rm -rf /). Switch back with /permissions dontAsk.');
88
- }
89
- /**
90
- * Resolve the effective mode + the layered source label used by the
91
- * Ink picker. Shares the merge order with `renderCurrentMode` above so
92
- * the picker title and the bare `/permissions` print stay in lock-step.
93
- *
94
- * Exposed publicly because the host (session.ts) needs the same merge
95
- * shape to seed the Ink picker BEFORE it mounts.
96
- */
97
- export function resolveLayeredMode(workspaceRoot, homeDir) {
98
- const workspace = getCurrentMode(workspaceRoot);
99
- const global = getGlobalDefaultMode(homeDir);
100
- const effective = workspace ?? global ?? DEFAULT_PERMISSION_MODE;
101
- const source = workspace
102
- ? 'workspace session.json'
103
- : global
104
- ? 'global ~/.pugi/config.json'
105
- : 'default (no override)';
106
- return {
107
- effective,
108
- source,
109
- firstRun: !workspace && !global,
110
- };
111
- }
112
- //# sourceMappingURL=permissions.js.map
@@ -1,143 +0,0 @@
1
- /**
2
- * `pugi plan` / `/plan` — quick mode-switch shortcut.
3
- *
4
- * `/plan` is the slick UX shortcut for `/permissions plan`: one keystroke
5
- * (well, five) puts the gate into plan mode + surfaces a banner so the
6
- * operator knows write/dispatch tools are refused. The model goes off and
7
- * thinks / researches without side effects until the operator types
8
- * `/plan --back` (restore previous mode) or explicitly flips with
9
- * `/permissions <mode>`.
10
- *
11
- * The slash and CLI surfaces both go through `runPlanCommand` — same
12
- * separation as `runPermissionsCommand`. The runtime is I/O free w.r.t.
13
- * the engine; the optional one-shot dispatch (`/plan <prompt>`) is
14
- * handled by the CLI dispatcher AFTER this helper sets the workspace
15
- * mode so the existing `runEngineTask('plan')` path sees plan mode as
16
- * the workspace state without needing a parallel code path.
17
- *
18
- * Verdicts (the helper returns one so the caller can decide what to do
19
- * after the mode write — print the banner, dispatch the engine, no-op):
20
- * - `entered` — first `/plan` from a non-plan mode. Print the
21
- * banner. Caller may then run a one-shot prompt.
22
- * - `already-in-plan` — `/plan` while already in plan. No-op + show
23
- * current. No banner reprint.
24
- * - `reverted` — `/plan --back` popped the snapshot. Print a
25
- * one-line confirmation; no banner.
26
- * - `no-previous` — `/plan --back` without a snapshot. Print a
27
- * clear "nothing to revert" line.
28
- * - `persisted` — `/plan --persist` wrote the global default
29
- * AND set workspace state to plan. Banner +
30
- * persistence-confirmation line.
31
- *
32
- * `previousMode` semantics: stashed BEFORE the workspace write on
33
- * `entered` / `persisted`. Cleared after a successful `reverted` so a
34
- * second `--back` reports `no-previous` instead of looping back to plan.
35
- */
36
- import { PERMISSION_MODES, PERMISSION_MODE_GLOSS, getCurrentMode, getGlobalDefaultMode, getPreviousMode, setCurrentMode, setGlobalDefaultMode, setPreviousMode, } from '../../core/permissions/index.js';
37
- /**
38
- * Run the `/plan` flow. Side effects:
39
- *
40
- * command.back = true:
41
- * - If a previousMode snapshot exists → restore it, clear snapshot,
42
- * return `reverted`.
43
- * - Otherwise → no writes, return `no-previous`.
44
- *
45
- * command.back = false, current mode is plan:
46
- * - If `--persist`, write global config (no workspace re-write — it
47
- * is already plan).
48
- * - Print "already in plan" + the banner-summary line. Return
49
- * `already-in-plan`.
50
- *
51
- * command.back = false, current mode is NOT plan:
52
- * - Snapshot current mode → previousPermissionMode.
53
- * - Write workspace mode = plan.
54
- * - If `--persist`, also write global config.
55
- * - Print the banner + (if persisted) the persistence line.
56
- * - Return `entered` or `persisted`.
57
- *
58
- * --back + --persist is a no-op for persistence (revert never writes
59
- * global config) but the revert itself fires.
60
- */
61
- export async function runPlanCommand(command, ctx) {
62
- const current = effectiveMode(ctx);
63
- if (command.back) {
64
- const prev = getPreviousMode(ctx.workspaceRoot);
65
- if (!prev) {
66
- ctx.writeOutput(`No previous mode to restore. Current: ${current}. Use \`/permissions <mode>\` to switch explicitly.`);
67
- return { verdict: 'no-previous', mode: current };
68
- }
69
- setCurrentMode(ctx.workspaceRoot, prev);
70
- setPreviousMode(ctx.workspaceRoot, null);
71
- ctx.writeOutput(`Switched back to '${prev}' mode. ${PERMISSION_MODE_GLOSS[prev]}`);
72
- return { verdict: 'reverted', mode: prev };
73
- }
74
- if (current === 'plan') {
75
- // Repeat /plan in plan mode is a no-op for the mode write, but
76
- // --persist still honours the operator's intent to lock plan as
77
- // the global default for future sessions.
78
- if (command.persist) {
79
- setGlobalDefaultMode('plan', ctx.homeDir);
80
- ctx.writeOutput('Already in plan mode. Persisted plan as the default for future sessions (~/.pugi/config.json).');
81
- return { verdict: 'persisted', mode: 'plan' };
82
- }
83
- ctx.writeOutput(`Already in plan mode. ${PERMISSION_MODE_GLOSS.plan} Switch back with \`/plan --back\` or \`/permissions <mode>\`.`);
84
- return { verdict: 'already-in-plan', mode: 'plan' };
85
- }
86
- // Entering plan mode from a non-plan baseline. Stash the current mode
87
- // BEFORE the write so /plan --back can pop it. We intentionally use the
88
- // observed effective mode (workspace || global || default) rather than
89
- // strictly the workspace value — if the operator's previous mode was
90
- // sourced from the global config, `--back` should restore that observed
91
- // state, not silently degrade to default.
92
- setPreviousMode(ctx.workspaceRoot, current);
93
- setCurrentMode(ctx.workspaceRoot, 'plan');
94
- if (command.persist) {
95
- setGlobalDefaultMode('plan', ctx.homeDir);
96
- }
97
- for (const line of renderPlanBanner()) {
98
- ctx.writeOutput(line);
99
- }
100
- if (command.persist) {
101
- ctx.writeOutput('Persisted plan as the default for future sessions (~/.pugi/config.json).');
102
- return { verdict: 'persisted', mode: 'plan' };
103
- }
104
- return { verdict: 'entered', mode: 'plan' };
105
- }
106
- /**
107
- * Render the plan-mode banner as a sequence of lines. The slash + CLI
108
- * surfaces both print these line-by-line through their respective
109
- * `writeOutput` sinks so the Ink REPL conversation pane and the plain
110
- * stdout pipeline render identically.
111
- *
112
- * The box-drawing uses light-line glyphs (U+2500 family) which render in
113
- * every modern terminal we target (Linux/macOS/Windows Terminal/iTerm/
114
- * Ghostty/Alacritty). No emoji per brand-voice gate.
115
- */
116
- export function renderPlanBanner() {
117
- return [
118
- '┌─ Plan mode active ────────────────────────────────────────┐',
119
- '│ Read-only tools allowed. Write/dispatch tools blocked. │',
120
- '│ Pugi will think + research without making changes. │',
121
- '│ Switch back: /plan --back or /permissions <mode> │',
122
- '└───────────────────────────────────────────────────────────┘',
123
- ];
124
- }
125
- /**
126
- * Resolve the effective mode at the moment the helper was invoked,
127
- * mirroring `resolveMode` but without taking a CLI flag (the `/plan`
128
- * helper is called AFTER the top-level `--mode` flag has been applied
129
- * to the workspace, so the file state is the source of truth here).
130
- */
131
- function effectiveMode(ctx) {
132
- const workspace = getCurrentMode(ctx.workspaceRoot);
133
- if (workspace)
134
- return workspace;
135
- const global = getGlobalDefaultMode(ctx.homeDir);
136
- if (global)
137
- return global;
138
- // canonical default — `PERMISSION_MODES[0]` is `default` (the
139
- // CC-parity ask-every-call ground state). Fall back literally if the
140
- // array is empty (defensive — should never happen).
141
- return PERMISSION_MODES[0] ?? 'default';
142
- }
143
- //# sourceMappingURL=plan.js.map
@@ -1,285 +0,0 @@
1
- /**
2
- * `pugi prd-check` — Pugi verified-deliverable gate .
3
- *
4
- * Runs a PRD ↔ delivered-artifact verification sweep BEFORE the
5
- * operator (or an autonomous agent) claims a feature is done.
6
- * Reads `docs/prd/<feature>.md` (or any explicit path), parses the
7
- * acceptance-criteria section, and runs file / test / doc / command
8
- * / route verifiers per criterion. Output mirrors `pugi doctor`:
9
- * either a plain-text table or a JSON envelope (`--json`).
10
- *
11
- * Module contract (mirrors L17 doctor split):
12
- *
13
- * - parser + verifiers + reporter are pure with respect to deps;
14
- * this file is the THIN wiring that resolves cwd, glob-expands
15
- * `--all`, loads each PRD, and forwards the structured result
16
- * к the supplied writeOutput sink.
17
- *
18
- * - `runPrdCheckCommand` is the single entry point. Both the
19
- * top-level `pugi prd-check` shell command AND the in-REPL
20
- * `/prd-check` slash command call it. The function returns the
21
- * `PrdCheckEnvelope[]` so the REPL can render via Ink without
22
- * re-running the verification.
23
- *
24
- * - Exit codes follow `exitCodeFor` from the reporter:
25
- * 0 — healthy (every criterion PASS or SKIPPED)
26
- * 1 — failing (≥1 FAIL across the scanned PRDs)
27
- * 2 — unparsed (≥1 PRD missing the acceptance section)
28
- * When `--all` scans multiple PRDs the worst verdict wins (1 > 2 > 0).
29
- *
30
- * - The `knownCommands` set is sourced from the CLI registry — we
31
- * accept it as an injected parameter so the spec can drive
32
- * command-verification without importing the entire cli.ts
33
- * module (which would pull the engine graph into the test).
34
- */
35
- import { readdirSync, readFileSync, statSync } from 'node:fs';
36
- import { isAbsolute, join, relative, resolve } from 'node:path';
37
- import { parsePrd } from '../../core/prd-check/parser.js';
38
- import { buildEnvelope, exitCodeFor, renderTable, } from '../../core/prd-check/reporter.js';
39
- import { defaultSessionReviewDeps, renderSessionReview, runSessionReview, } from '../../core/prd-check/session-review.js';
40
- import { createDefaultDeps, verifyAll, } from '../../core/prd-check/verifiers.js';
41
- const DEFAULT_PRD_DIR = 'docs/prd';
42
- /**
43
- * Run the gate. Resolves which PRDs to inspect, runs the parser +
44
- * verifiers + reporter chain per PRD, emits the combined output,
45
- * and sets `process.exitCode` to the worst verdict across the set.
46
- */
47
- export async function runPrdCheckCommand(ctx) {
48
- // final : session-review mode. Orthogonal to
49
- // the verifier-graph mode — no PRD path resolution, no command
50
- // registry. The runner walks up for PRD.md, reads the NDJSON
51
- // events log, and dispatches a cross-review subagent.
52
- if (ctx.flags.session) {
53
- const status = (line) => {
54
- // Emit status lines through the output sink so the slash
55
- // surface can render them inline. The status payload is
56
- // intentionally lightweight — only the human-facing text.
57
- ctx.writeOutput({
58
- command: 'prd-check',
59
- overall: 'healthy',
60
- envelopes: [],
61
- }, line);
62
- };
63
- const sessionDeps = ctx.sessionDeps ??
64
- defaultSessionReviewDeps({ onStatus: status });
65
- const review = await runSessionReview(ctx.cwd, sessionDeps);
66
- const overall = review.status === 'ok'
67
- ? review.outstanding.length === 0
68
- ? 'healthy'
69
- : 'failing'
70
- : 'unparsed';
71
- const result = {
72
- command: 'prd-check',
73
- overall,
74
- envelopes: [],
75
- sessionReview: review,
76
- };
77
- ctx.writeOutput(result, renderSessionReview(review));
78
- process.exitCode = exitCodeFor(overall);
79
- return result;
80
- }
81
- const paths = resolveTargets(ctx);
82
- if (paths.length === 0) {
83
- const result = {
84
- command: 'prd-check',
85
- overall: 'unparsed',
86
- envelopes: [],
87
- };
88
- ctx.writeOutput(result, 'No PRD files found.');
89
- process.exitCode = exitCodeFor('unparsed');
90
- return result;
91
- }
92
- const deps = ctx.deps ??
93
- createDefaultDeps({
94
- workspaceRoot: ctx.cwd,
95
- knownCommands: ctx.knownCommands,
96
- });
97
- const envelopes = [];
98
- for (const path of paths) {
99
- envelopes.push(checkSinglePrd(path, ctx.cwd, deps));
100
- }
101
- const overall = combineOverall(envelopes.map((e) => e.overall));
102
- const result = {
103
- command: 'prd-check',
104
- overall,
105
- envelopes,
106
- };
107
- const text = renderRun(result, ctx.cwd);
108
- ctx.writeOutput(result, text);
109
- process.exitCode = exitCodeFor(overall);
110
- return result;
111
- }
112
- /**
113
- * Render the combined plain-text view. Multi-PRD runs print one
114
- * table per envelope separated by a divider; single-PRD runs print
115
- * just the table to keep the output narrow.
116
- */
117
- function renderRun(result, cwd) {
118
- if (result.envelopes.length === 0) {
119
- return 'No PRD files found.';
120
- }
121
- if (result.envelopes.length === 1) {
122
- return renderTable(result.envelopes[0]);
123
- }
124
- const parts = [];
125
- for (const envelope of result.envelopes) {
126
- const relPath = relative(cwd, envelope.prdPath) || envelope.prdPath;
127
- parts.push(renderTable({ ...envelope, prdPath: relPath }));
128
- parts.push('');
129
- }
130
- parts.push('-'.repeat(50));
131
- const summary = `${result.envelopes.length} PRD(s) scanned. Overall: ${result.overall.toUpperCase()}`;
132
- parts.push(summary);
133
- return parts.join('\n');
134
- }
135
- function checkSinglePrd(prdPath, workspaceRoot, deps) {
136
- let source;
137
- try {
138
- source = readFileSync(prdPath, 'utf8');
139
- }
140
- catch (error) {
141
- const message = error instanceof Error ? error.message : String(error);
142
- return {
143
- command: 'prd-check',
144
- prdPath: relative(workspaceRoot, prdPath) || prdPath,
145
- title: null,
146
- overall: 'unparsed',
147
- counts: { pass: 0, fail: 0, skipped: 0 },
148
- criteria: [
149
- {
150
- index: 0,
151
- text: `PRD file unreadable: ${message}`,
152
- status: 'fail',
153
- results: [],
154
- },
155
- ],
156
- };
157
- }
158
- const parsed = parsePrd(source);
159
- const verified = verifyAll(parsed.criteria, deps);
160
- return buildEnvelope({
161
- prdPath: relative(workspaceRoot, prdPath) || prdPath,
162
- title: parsed.title,
163
- hasAcceptanceSection: parsed.hasAcceptanceSection,
164
- verified,
165
- });
166
- }
167
- function resolveTargets(ctx) {
168
- if (ctx.flags.all) {
169
- const prdDir = resolve(ctx.cwd, DEFAULT_PRD_DIR);
170
- return listMarkdownFiles(prdDir);
171
- }
172
- if (ctx.prdPath) {
173
- const absolute = isAbsolute(ctx.prdPath)
174
- ? ctx.prdPath
175
- : resolve(ctx.cwd, ctx.prdPath);
176
- return [absolute];
177
- }
178
- return [];
179
- }
180
- function listMarkdownFiles(dir) {
181
- let entries;
182
- try {
183
- entries = readdirSync(dir);
184
- }
185
- catch {
186
- return [];
187
- }
188
- const out = [];
189
- for (const entry of entries) {
190
- const full = join(dir, entry);
191
- let isDirectory = false;
192
- try {
193
- isDirectory = statSync(full).isDirectory();
194
- }
195
- catch {
196
- continue;
197
- }
198
- if (isDirectory) {
199
- out.push(...listMarkdownFiles(full));
200
- continue;
201
- }
202
- if (entry.endsWith('.md')) {
203
- out.push(full);
204
- }
205
- }
206
- return out.sort();
207
- }
208
- /**
209
- * Combine per-PRD verdicts into the run-wide one. failing > unparsed > healthy.
210
- * Exported for the spec.
211
- */
212
- export function combineOverall(verdicts) {
213
- if (verdicts.length === 0)
214
- return 'unparsed';
215
- if (verdicts.some((v) => v === 'failing'))
216
- return 'failing';
217
- if (verdicts.some((v) => v === 'unparsed'))
218
- return 'unparsed';
219
- return 'healthy';
220
- }
221
- /**
222
- * Parse the CLI argv tail. Accepts:
223
- *
224
- * pugi prd-check -> error (no target)
225
- * pugi prd-check <path> -> single PRD
226
- * pugi prd-check --all -> scan docs/prd/**.md
227
- * pugi prd-check <path> --json -> single PRD, JSON envelope
228
- *
229
- * `--json` is also forwarded from the global flag set in cli.ts;
230
- * the local parse re-honours it so the slash command can use the
231
- * same parser without the global flag plumbing.
232
- */
233
- export function parsePrdCheckArgs(args, options) {
234
- let json = options.jsonDefault;
235
- let all = false;
236
- let session = false;
237
- let prdPath;
238
- for (const arg of args) {
239
- if (arg === '--json') {
240
- json = true;
241
- continue;
242
- }
243
- if (arg === '--all') {
244
- all = true;
245
- continue;
246
- }
247
- if (arg === '--session') {
248
- session = true;
249
- continue;
250
- }
251
- if (arg.startsWith('--')) {
252
- return { ok: false, error: `unknown flag: ${arg}` };
253
- }
254
- if (prdPath !== undefined) {
255
- return { ok: false, error: `unexpected extra argument: ${arg}` };
256
- }
257
- prdPath = arg;
258
- }
259
- // final : `--session` is mutually exclusive with
260
- // the verifier modes — it walks up for a PRD, reads NDJSON turns,
261
- // and dispatches a subagent. No <path>, no --all, no command-
262
- // registry inputs. Validating up-front gives operators a clear
263
- // error instead of a silent fall-through.
264
- if (session && (all || prdPath !== undefined)) {
265
- return {
266
- ok: false,
267
- error: 'cannot combine --session with --all or <path>',
268
- };
269
- }
270
- if (!session && !all && prdPath === undefined) {
271
- return {
272
- ok: false,
273
- error: 'pugi prd-check <prd-path> | --all | --session (pass a PRD path, --all to scan docs/prd/**.md, or --session to review the live session against PRD.md)',
274
- };
275
- }
276
- if (all && prdPath !== undefined) {
277
- return { ok: false, error: 'cannot combine <path> with --all' };
278
- }
279
- return {
280
- ok: true,
281
- flags: { json, all, session },
282
- ...(prdPath !== undefined ? { prdPath } : {}),
283
- };
284
- }
285
- //# sourceMappingURL=prd-check.js.map
@@ -1,107 +0,0 @@
1
- import { z } from 'zod';
2
- import { readConfig } from './config.js';
3
- import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'node:fs';
4
- import { homedir } from 'node:os';
5
- import { dirname, resolve } from 'node:path';
6
- /**
7
- * `pugi privacy` — read or update the operator's privacy mode.
8
- *
9
- * Subcommands:
10
- * - `pugi privacy show` — print current mode + source
11
- * - `pugi privacy set <mode>` — write `local-only | metadata | full`
12
- *
13
- * Persistence:
14
- * - Stored in `~/.pugi/privacy.json` (PUGI_HOME-aware).
15
- * - The `privacy` key in `~/.pugi/config.json` is also consulted at
16
- * read time (config takes precedence when both exist) so a user who
17
- * already set `pugi config set privacy ...` sees the same value
18
- * here.
19
- *
20
- * Modes:
21
- * - `local-only` — nothing leaves the workstation. Engine commands
22
- * refuse to ship transcripts; sync is a no-op.
23
- * - `metadata` — only artifact metadata + session timeline ships
24
- * (no raw file contents).
25
- * - `full` — full sync allowed (operator-acknowledged).
26
- */
27
- export const privacyModeSchema = z.enum(['local-only', 'metadata', 'full']);
28
- const privacyFileSchema = z.object({
29
- schema: z.number().int().positive().default(1),
30
- mode: privacyModeSchema,
31
- });
32
- function privacyPath() {
33
- const home = process.env.PUGI_HOME ?? resolve(homedir(), '.pugi');
34
- return resolve(home, 'privacy.json');
35
- }
36
- export function readPrivacyFile() {
37
- const path = privacyPath();
38
- if (!existsSync(path))
39
- return null;
40
- const raw = readFileSync(path, 'utf8');
41
- if (raw.trim() === '')
42
- return null;
43
- const parsed = JSON.parse(raw);
44
- const result = privacyFileSchema.safeParse(parsed);
45
- if (!result.success)
46
- return null;
47
- return result.data.mode;
48
- }
49
- function writePrivacyFile(mode) {
50
- const path = privacyPath();
51
- mkdirSync(dirname(path), { recursive: true });
52
- writeFileSync(path, `${JSON.stringify({ schema: 1, mode }, null, 2)}\n`, { encoding: 'utf8', mode: 0o600 });
53
- }
54
- /**
55
- * Effective privacy mode resolution order:
56
- * 1. `~/.pugi/config.json` privacy key (when set via `pugi config set`)
57
- * 2. `~/.pugi/privacy.json` (when set via `pugi privacy set`)
58
- * 3. `metadata` (default — matches the M1 default-ship posture)
59
- */
60
- export function resolvePrivacyMode() {
61
- const config = readConfig();
62
- if (config.privacy)
63
- return { mode: config.privacy, source: 'config' };
64
- const fromFile = readPrivacyFile();
65
- if (fromFile)
66
- return { mode: fromFile, source: 'privacy' };
67
- return { mode: 'metadata', source: 'default' };
68
- }
69
- export async function runPrivacyCommand(args, ctx) {
70
- const sub = args[0];
71
- if (!sub || sub === '--help' || sub === '-h') {
72
- ctx.writeOutput({
73
- command: 'privacy',
74
- usage: ['pugi privacy show', 'pugi privacy set <mode>'],
75
- modes: ['local-only', 'metadata', 'full'],
76
- }, [
77
- 'Usage:',
78
- ' pugi privacy show Show current privacy mode.',
79
- ' pugi privacy set <mode> Set mode to local-only, metadata, or full.',
80
- ].join('\n'));
81
- return;
82
- }
83
- switch (sub) {
84
- case 'show':
85
- return runPrivacyShow(ctx);
86
- case 'set':
87
- return runPrivacySet(args.slice(1), ctx);
88
- default:
89
- throw new Error(`Unknown sub-command "pugi privacy ${sub}". Expected show or set.`);
90
- }
91
- }
92
- function runPrivacyShow(ctx) {
93
- const resolved = resolvePrivacyMode();
94
- ctx.writeOutput({ command: 'privacy.show', ...resolved }, `Privacy mode: ${resolved.mode} (source: ${resolved.source})`);
95
- }
96
- function runPrivacySet(args, ctx) {
97
- const raw = args[0];
98
- if (!raw)
99
- throw new Error('pugi privacy set requires a mode: local-only, metadata, or full.');
100
- const result = privacyModeSchema.safeParse(raw);
101
- if (!result.success) {
102
- throw new Error(`Invalid privacy mode "${raw}". Allowed: local-only, metadata, full.`);
103
- }
104
- writePrivacyFile(result.data);
105
- ctx.writeOutput({ command: 'privacy.set', mode: result.data }, `Privacy mode set to ${result.data}.`);
106
- }
107
- //# sourceMappingURL=privacy.js.map