@productbrain/cli 0.1.0-beta.15 → 0.1.0-beta.1502

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 (948) hide show
  1. package/README.md +76 -115
  2. package/dist/__tests__/adapters.test.d.ts +2 -0
  3. package/dist/__tests__/adapters.test.d.ts.map +1 -0
  4. package/dist/__tests__/adapters.test.js +417 -0
  5. package/dist/__tests__/adapters.test.js.map +1 -0
  6. package/dist/__tests__/audit.test.js +65 -44
  7. package/dist/__tests__/audit.test.js.map +1 -1
  8. package/dist/__tests__/authority-domains-queue.test.d.ts +2 -0
  9. package/dist/__tests__/authority-domains-queue.test.d.ts.map +1 -0
  10. package/dist/__tests__/authority-domains-queue.test.js +169 -0
  11. package/dist/__tests__/authority-domains-queue.test.js.map +1 -0
  12. package/dist/__tests__/authority-domains.test.d.ts +2 -0
  13. package/dist/__tests__/authority-domains.test.d.ts.map +1 -0
  14. package/dist/__tests__/authority-domains.test.js +48 -0
  15. package/dist/__tests__/authority-domains.test.js.map +1 -0
  16. package/dist/__tests__/batch-transformations.test.d.ts +2 -0
  17. package/dist/__tests__/batch-transformations.test.d.ts.map +1 -0
  18. package/dist/__tests__/batch-transformations.test.js +263 -0
  19. package/dist/__tests__/batch-transformations.test.js.map +1 -0
  20. package/dist/__tests__/canonicalRefs.vocab.test.d.ts +2 -0
  21. package/dist/__tests__/canonicalRefs.vocab.test.d.ts.map +1 -0
  22. package/dist/__tests__/canonicalRefs.vocab.test.js +251 -0
  23. package/dist/__tests__/canonicalRefs.vocab.test.js.map +1 -0
  24. package/dist/__tests__/capture-receipt-domain.test.d.ts +2 -0
  25. package/dist/__tests__/capture-receipt-domain.test.d.ts.map +1 -0
  26. package/dist/__tests__/capture-receipt-domain.test.js +29 -0
  27. package/dist/__tests__/capture-receipt-domain.test.js.map +1 -0
  28. package/dist/__tests__/capture.test.js +309 -18
  29. package/dist/__tests__/capture.test.js.map +1 -1
  30. package/dist/__tests__/codex-prep-parity.test.d.ts +2 -0
  31. package/dist/__tests__/codex-prep-parity.test.d.ts.map +1 -0
  32. package/dist/__tests__/codex-prep-parity.test.js +107 -0
  33. package/dist/__tests__/codex-prep-parity.test.js.map +1 -0
  34. package/dist/__tests__/config-prod-fallthrough.test.d.ts +2 -0
  35. package/dist/__tests__/config-prod-fallthrough.test.d.ts.map +1 -0
  36. package/dist/__tests__/config-prod-fallthrough.test.js +82 -0
  37. package/dist/__tests__/config-prod-fallthrough.test.js.map +1 -0
  38. package/dist/__tests__/config.test.d.ts +8 -0
  39. package/dist/__tests__/config.test.d.ts.map +1 -0
  40. package/dist/__tests__/config.test.js +566 -0
  41. package/dist/__tests__/config.test.js.map +1 -0
  42. package/dist/__tests__/constants.test.d.ts +2 -0
  43. package/dist/__tests__/constants.test.d.ts.map +1 -0
  44. package/dist/__tests__/constants.test.js +146 -0
  45. package/dist/__tests__/constants.test.js.map +1 -0
  46. package/dist/__tests__/constellation.test.js +16 -22
  47. package/dist/__tests__/constellation.test.js.map +1 -1
  48. package/dist/__tests__/context-strategy.test.js +8 -8
  49. package/dist/__tests__/context-strategy.test.js.map +1 -1
  50. package/dist/__tests__/envelope-contract.test.d.ts +15 -0
  51. package/dist/__tests__/envelope-contract.test.d.ts.map +1 -0
  52. package/dist/__tests__/envelope-contract.test.js +152 -0
  53. package/dist/__tests__/envelope-contract.test.js.map +1 -0
  54. package/dist/__tests__/errors.test.d.ts +2 -0
  55. package/dist/__tests__/errors.test.d.ts.map +1 -0
  56. package/dist/__tests__/errors.test.js +118 -0
  57. package/dist/__tests__/errors.test.js.map +1 -0
  58. package/dist/__tests__/experiment.test.d.ts +6 -0
  59. package/dist/__tests__/experiment.test.d.ts.map +1 -0
  60. package/dist/__tests__/experiment.test.js +69 -0
  61. package/dist/__tests__/experiment.test.js.map +1 -0
  62. package/dist/__tests__/fields.test.js +36 -36
  63. package/dist/__tests__/fields.test.js.map +1 -1
  64. package/dist/__tests__/glossary.test.d.ts +2 -0
  65. package/dist/__tests__/glossary.test.d.ts.map +1 -0
  66. package/dist/__tests__/glossary.test.js +32 -0
  67. package/dist/__tests__/glossary.test.js.map +1 -0
  68. package/dist/__tests__/handshake-augment.test.d.ts +2 -0
  69. package/dist/__tests__/handshake-augment.test.d.ts.map +1 -0
  70. package/dist/__tests__/handshake-augment.test.js +423 -0
  71. package/dist/__tests__/handshake-augment.test.js.map +1 -0
  72. package/dist/__tests__/handshake-dormancy.test.d.ts +2 -0
  73. package/dist/__tests__/handshake-dormancy.test.d.ts.map +1 -0
  74. package/dist/__tests__/handshake-dormancy.test.js +207 -0
  75. package/dist/__tests__/handshake-dormancy.test.js.map +1 -0
  76. package/dist/__tests__/handshake-formatter.test.d.ts +2 -0
  77. package/dist/__tests__/handshake-formatter.test.d.ts.map +1 -0
  78. package/dist/__tests__/handshake-formatter.test.js +67 -0
  79. package/dist/__tests__/handshake-formatter.test.js.map +1 -0
  80. package/dist/__tests__/handshake-preview.test.d.ts +2 -0
  81. package/dist/__tests__/handshake-preview.test.d.ts.map +1 -0
  82. package/dist/__tests__/handshake-preview.test.js +949 -0
  83. package/dist/__tests__/handshake-preview.test.js.map +1 -0
  84. package/dist/__tests__/handshake.e2e.test.d.ts +2 -0
  85. package/dist/__tests__/handshake.e2e.test.d.ts.map +1 -0
  86. package/dist/__tests__/handshake.e2e.test.js +1252 -0
  87. package/dist/__tests__/handshake.e2e.test.js.map +1 -0
  88. package/dist/__tests__/handshake.test.js +813 -19
  89. package/dist/__tests__/handshake.test.js.map +1 -1
  90. package/dist/__tests__/hook-intents.test.d.ts +2 -0
  91. package/dist/__tests__/hook-intents.test.d.ts.map +1 -0
  92. package/dist/__tests__/hook-intents.test.js +184 -0
  93. package/dist/__tests__/hook-intents.test.js.map +1 -0
  94. package/dist/__tests__/ingest.test.js +28 -28
  95. package/dist/__tests__/ingest.test.js.map +1 -1
  96. package/dist/__tests__/init.test.d.ts +7 -0
  97. package/dist/__tests__/init.test.d.ts.map +1 -0
  98. package/dist/__tests__/init.test.js +146 -0
  99. package/dist/__tests__/init.test.js.map +1 -0
  100. package/dist/__tests__/login.test.d.ts +2 -0
  101. package/dist/__tests__/login.test.d.ts.map +1 -0
  102. package/dist/__tests__/login.test.js +167 -0
  103. package/dist/__tests__/login.test.js.map +1 -0
  104. package/dist/__tests__/manifest.test.d.ts +6 -0
  105. package/dist/__tests__/manifest.test.d.ts.map +1 -0
  106. package/dist/__tests__/manifest.test.js +255 -0
  107. package/dist/__tests__/manifest.test.js.map +1 -0
  108. package/dist/__tests__/method-publish-coherency.test.d.ts +9 -0
  109. package/dist/__tests__/method-publish-coherency.test.d.ts.map +1 -0
  110. package/dist/__tests__/method-publish-coherency.test.js +71 -0
  111. package/dist/__tests__/method-publish-coherency.test.js.map +1 -0
  112. package/dist/__tests__/method-registry.integration.test.d.ts +6 -0
  113. package/dist/__tests__/method-registry.integration.test.d.ts.map +1 -0
  114. package/dist/__tests__/method-registry.integration.test.js +18 -0
  115. package/dist/__tests__/method-registry.integration.test.js.map +1 -0
  116. package/dist/__tests__/method-registry.test.d.ts +14 -0
  117. package/dist/__tests__/method-registry.test.d.ts.map +1 -0
  118. package/dist/__tests__/method-registry.test.js +134 -0
  119. package/dist/__tests__/method-registry.test.js.map +1 -0
  120. package/dist/__tests__/notice-marker.test.d.ts +2 -0
  121. package/dist/__tests__/notice-marker.test.d.ts.map +1 -0
  122. package/dist/__tests__/notice-marker.test.js +41 -0
  123. package/dist/__tests__/notice-marker.test.js.map +1 -0
  124. package/dist/__tests__/onboarding-path-b.test.d.ts +2 -0
  125. package/dist/__tests__/onboarding-path-b.test.d.ts.map +1 -0
  126. package/dist/__tests__/onboarding-path-b.test.js +46 -0
  127. package/dist/__tests__/onboarding-path-b.test.js.map +1 -0
  128. package/dist/__tests__/onboarding.test.d.ts +6 -0
  129. package/dist/__tests__/onboarding.test.d.ts.map +1 -0
  130. package/dist/__tests__/onboarding.test.js +347 -0
  131. package/dist/__tests__/onboarding.test.js.map +1 -0
  132. package/dist/__tests__/orient.test.d.ts +2 -0
  133. package/dist/__tests__/orient.test.d.ts.map +1 -0
  134. package/dist/__tests__/orient.test.js +424 -0
  135. package/dist/__tests__/orient.test.js.map +1 -0
  136. package/dist/__tests__/perimeter.test.d.ts +2 -0
  137. package/dist/__tests__/perimeter.test.d.ts.map +1 -0
  138. package/dist/__tests__/perimeter.test.js +165 -0
  139. package/dist/__tests__/perimeter.test.js.map +1 -0
  140. package/dist/__tests__/personal-layer.test.d.ts +11 -0
  141. package/dist/__tests__/personal-layer.test.d.ts.map +1 -0
  142. package/dist/__tests__/personal-layer.test.js +268 -0
  143. package/dist/__tests__/personal-layer.test.js.map +1 -0
  144. package/dist/__tests__/preview-key-refresh.test.d.ts +2 -0
  145. package/dist/__tests__/preview-key-refresh.test.d.ts.map +1 -0
  146. package/dist/__tests__/preview-key-refresh.test.js +126 -0
  147. package/dist/__tests__/preview-key-refresh.test.js.map +1 -0
  148. package/dist/__tests__/profiles.test.d.ts +2 -0
  149. package/dist/__tests__/profiles.test.d.ts.map +1 -0
  150. package/dist/__tests__/profiles.test.js +316 -0
  151. package/dist/__tests__/profiles.test.js.map +1 -0
  152. package/dist/__tests__/promote-batch.test.d.ts +2 -0
  153. package/dist/__tests__/promote-batch.test.d.ts.map +1 -0
  154. package/dist/__tests__/promote-batch.test.js +185 -0
  155. package/dist/__tests__/promote-batch.test.js.map +1 -0
  156. package/dist/__tests__/promote.test.js +213 -34
  157. package/dist/__tests__/promote.test.js.map +1 -1
  158. package/dist/__tests__/prompts.test.d.ts +6 -0
  159. package/dist/__tests__/prompts.test.d.ts.map +1 -0
  160. package/dist/__tests__/prompts.test.js +146 -0
  161. package/dist/__tests__/prompts.test.js.map +1 -0
  162. package/dist/__tests__/proof-run.test.d.ts +2 -0
  163. package/dist/__tests__/proof-run.test.d.ts.map +1 -0
  164. package/dist/__tests__/proof-run.test.js +255 -0
  165. package/dist/__tests__/proof-run.test.js.map +1 -0
  166. package/dist/__tests__/proposals.test.js +24 -47
  167. package/dist/__tests__/proposals.test.js.map +1 -1
  168. package/dist/__tests__/relate.test.js +34 -36
  169. package/dist/__tests__/relate.test.js.map +1 -1
  170. package/dist/__tests__/repo-detect.test.js +97 -1
  171. package/dist/__tests__/repo-detect.test.js.map +1 -1
  172. package/dist/__tests__/runner.test.js +19 -15
  173. package/dist/__tests__/runner.test.js.map +1 -1
  174. package/dist/__tests__/session-close-loop.test.d.ts +2 -0
  175. package/dist/__tests__/session-close-loop.test.d.ts.map +1 -0
  176. package/dist/__tests__/session-close-loop.test.js +231 -0
  177. package/dist/__tests__/session-close-loop.test.js.map +1 -0
  178. package/dist/__tests__/session-reset.test.d.ts +2 -0
  179. package/dist/__tests__/session-reset.test.d.ts.map +1 -0
  180. package/dist/__tests__/session-reset.test.js +122 -0
  181. package/dist/__tests__/session-reset.test.js.map +1 -0
  182. package/dist/__tests__/session-resume-backstop.test.d.ts +2 -0
  183. package/dist/__tests__/session-resume-backstop.test.d.ts.map +1 -0
  184. package/dist/__tests__/session-resume-backstop.test.js +97 -0
  185. package/dist/__tests__/session-resume-backstop.test.js.map +1 -0
  186. package/dist/__tests__/session-start-key-refresh.test.d.ts +2 -0
  187. package/dist/__tests__/session-start-key-refresh.test.d.ts.map +1 -0
  188. package/dist/__tests__/session-start-key-refresh.test.js +179 -0
  189. package/dist/__tests__/session-start-key-refresh.test.js.map +1 -0
  190. package/dist/__tests__/session-state-machine.test.d.ts +2 -0
  191. package/dist/__tests__/session-state-machine.test.d.ts.map +1 -0
  192. package/dist/__tests__/session-state-machine.test.js +198 -0
  193. package/dist/__tests__/session-state-machine.test.js.map +1 -0
  194. package/dist/__tests__/session-switch.test.d.ts +2 -0
  195. package/dist/__tests__/session-switch.test.d.ts.map +1 -0
  196. package/dist/__tests__/session-switch.test.js +130 -0
  197. package/dist/__tests__/session-switch.test.js.map +1 -0
  198. package/dist/__tests__/session-touch.test.js +11 -11
  199. package/dist/__tests__/session-touch.test.js.map +1 -1
  200. package/dist/__tests__/session.test.js +4 -10
  201. package/dist/__tests__/session.test.js.map +1 -1
  202. package/dist/__tests__/setup-ingest.test.d.ts +2 -0
  203. package/dist/__tests__/setup-ingest.test.d.ts.map +1 -0
  204. package/dist/__tests__/setup-ingest.test.js +71 -0
  205. package/dist/__tests__/setup-ingest.test.js.map +1 -0
  206. package/dist/__tests__/setup-resolver.test.d.ts +14 -0
  207. package/dist/__tests__/setup-resolver.test.d.ts.map +1 -0
  208. package/dist/__tests__/setup-resolver.test.js +228 -0
  209. package/dist/__tests__/setup-resolver.test.js.map +1 -0
  210. package/dist/__tests__/skill-vocabulary.test.d.ts +21 -0
  211. package/dist/__tests__/skill-vocabulary.test.d.ts.map +1 -0
  212. package/dist/__tests__/skill-vocabulary.test.js +192 -0
  213. package/dist/__tests__/skill-vocabulary.test.js.map +1 -0
  214. package/dist/__tests__/spinner-labels.test.d.ts +2 -0
  215. package/dist/__tests__/spinner-labels.test.d.ts.map +1 -0
  216. package/dist/__tests__/spinner-labels.test.js +23 -0
  217. package/dist/__tests__/spinner-labels.test.js.map +1 -0
  218. package/dist/__tests__/state.test.d.ts +6 -0
  219. package/dist/__tests__/state.test.d.ts.map +1 -0
  220. package/dist/__tests__/state.test.js +97 -0
  221. package/dist/__tests__/state.test.js.map +1 -0
  222. package/dist/__tests__/surface-profiles.test.d.ts +2 -0
  223. package/dist/__tests__/surface-profiles.test.d.ts.map +1 -0
  224. package/dist/__tests__/surface-profiles.test.js +233 -0
  225. package/dist/__tests__/surface-profiles.test.js.map +1 -0
  226. package/dist/__tests__/surfaces.test.d.ts +2 -0
  227. package/dist/__tests__/surfaces.test.d.ts.map +1 -0
  228. package/dist/__tests__/surfaces.test.js +46 -0
  229. package/dist/__tests__/surfaces.test.js.map +1 -0
  230. package/dist/__tests__/update-check.test.d.ts +2 -0
  231. package/dist/__tests__/update-check.test.d.ts.map +1 -0
  232. package/dist/__tests__/update-check.test.js +215 -0
  233. package/dist/__tests__/update-check.test.js.map +1 -0
  234. package/dist/__tests__/update.test.js +63 -72
  235. package/dist/__tests__/update.test.js.map +1 -1
  236. package/dist/__tests__/upgrade-runner.test.d.ts +2 -0
  237. package/dist/__tests__/upgrade-runner.test.d.ts.map +1 -0
  238. package/dist/__tests__/upgrade-runner.test.js +54 -0
  239. package/dist/__tests__/upgrade-runner.test.js.map +1 -0
  240. package/dist/__tests__/upgrade.test.d.ts +2 -0
  241. package/dist/__tests__/upgrade.test.d.ts.map +1 -0
  242. package/dist/__tests__/upgrade.test.js +56 -0
  243. package/dist/__tests__/upgrade.test.js.map +1 -0
  244. package/dist/__tests__/vocabulary-leak.test.d.ts +39 -0
  245. package/dist/__tests__/vocabulary-leak.test.d.ts.map +1 -0
  246. package/dist/__tests__/vocabulary-leak.test.js +534 -0
  247. package/dist/__tests__/vocabulary-leak.test.js.map +1 -0
  248. package/dist/__tests__/workspace.test.d.ts +2 -0
  249. package/dist/__tests__/workspace.test.d.ts.map +1 -0
  250. package/dist/__tests__/workspace.test.js +328 -0
  251. package/dist/__tests__/workspace.test.js.map +1 -0
  252. package/dist/commands/__tests__/connect-handoff.test.d.ts +11 -0
  253. package/dist/commands/__tests__/connect-handoff.test.d.ts.map +1 -0
  254. package/dist/commands/__tests__/connect-handoff.test.js +111 -0
  255. package/dist/commands/__tests__/connect-handoff.test.js.map +1 -0
  256. package/dist/commands/__tests__/setup-detect-surfaces.test.d.ts +15 -0
  257. package/dist/commands/__tests__/setup-detect-surfaces.test.d.ts.map +1 -0
  258. package/dist/commands/__tests__/setup-detect-surfaces.test.js +149 -0
  259. package/dist/commands/__tests__/setup-detect-surfaces.test.js.map +1 -0
  260. package/dist/commands/__tests__/setup-state.test.d.ts +2 -0
  261. package/dist/commands/__tests__/setup-state.test.d.ts.map +1 -0
  262. package/dist/commands/__tests__/setup-state.test.js +194 -0
  263. package/dist/commands/__tests__/setup-state.test.js.map +1 -0
  264. package/dist/commands/accept.d.ts.map +1 -1
  265. package/dist/commands/accept.js +10 -6
  266. package/dist/commands/accept.js.map +1 -1
  267. package/dist/commands/admin/cockpit.d.ts +90 -0
  268. package/dist/commands/admin/cockpit.d.ts.map +1 -0
  269. package/dist/commands/admin/cockpit.js +618 -0
  270. package/dist/commands/admin/cockpit.js.map +1 -0
  271. package/dist/commands/admin/index.d.ts +21 -0
  272. package/dist/commands/admin/index.d.ts.map +1 -0
  273. package/dist/commands/admin/index.js +256 -0
  274. package/dist/commands/admin/index.js.map +1 -0
  275. package/dist/commands/admin/inspect.d.ts +30 -0
  276. package/dist/commands/admin/inspect.d.ts.map +1 -0
  277. package/dist/commands/admin/inspect.js +555 -0
  278. package/dist/commands/admin/inspect.js.map +1 -0
  279. package/dist/commands/admin/inspect.test.d.ts +7 -0
  280. package/dist/commands/admin/inspect.test.d.ts.map +1 -0
  281. package/dist/commands/admin/inspect.test.js +90 -0
  282. package/dist/commands/admin/inspect.test.js.map +1 -0
  283. package/dist/commands/admin/manage.d.ts +8 -0
  284. package/dist/commands/admin/manage.d.ts.map +1 -0
  285. package/dist/commands/admin/manage.js +260 -0
  286. package/dist/commands/admin/manage.js.map +1 -0
  287. package/dist/commands/admin/manage.test.d.ts +16 -0
  288. package/dist/commands/admin/manage.test.d.ts.map +1 -0
  289. package/dist/commands/admin/manage.test.js +159 -0
  290. package/dist/commands/admin/manage.test.js.map +1 -0
  291. package/dist/commands/admin/seed.d.ts +75 -0
  292. package/dist/commands/admin/seed.d.ts.map +1 -0
  293. package/dist/commands/admin/seed.js +944 -0
  294. package/dist/commands/admin/seed.js.map +1 -0
  295. package/dist/commands/admin/seed.test.d.ts +11 -0
  296. package/dist/commands/admin/seed.test.d.ts.map +1 -0
  297. package/dist/commands/admin/seed.test.js +127 -0
  298. package/dist/commands/admin/seed.test.js.map +1 -0
  299. package/dist/commands/admin/seedRegistryEntries.generated.d.ts +14 -0
  300. package/dist/commands/admin/seedRegistryEntries.generated.d.ts.map +1 -0
  301. package/dist/commands/admin/seedRegistryEntries.generated.js +144 -0
  302. package/dist/commands/admin/seedRegistryEntries.generated.js.map +1 -0
  303. package/dist/commands/admin/seedRegistryEntries.test.d.ts +11 -0
  304. package/dist/commands/admin/seedRegistryEntries.test.d.ts.map +1 -0
  305. package/dist/commands/admin/seedRegistryEntries.test.js +70 -0
  306. package/dist/commands/admin/seedRegistryEntries.test.js.map +1 -0
  307. package/dist/commands/audit.d.ts.map +1 -1
  308. package/dist/commands/audit.js +42 -7
  309. package/dist/commands/audit.js.map +1 -1
  310. package/dist/commands/authority-domains.d.ts +157 -0
  311. package/dist/commands/authority-domains.d.ts.map +1 -0
  312. package/dist/commands/authority-domains.js +356 -0
  313. package/dist/commands/authority-domains.js.map +1 -0
  314. package/dist/commands/brief.d.ts.map +1 -1
  315. package/dist/commands/brief.js +10 -5
  316. package/dist/commands/brief.js.map +1 -1
  317. package/dist/commands/capture.d.ts +7 -0
  318. package/dist/commands/capture.d.ts.map +1 -1
  319. package/dist/commands/capture.js +266 -19
  320. package/dist/commands/capture.js.map +1 -1
  321. package/dist/commands/chain-walk.d.ts.map +1 -1
  322. package/dist/commands/chain-walk.js +8 -3
  323. package/dist/commands/chain-walk.js.map +1 -1
  324. package/dist/commands/changes.d.ts.map +1 -1
  325. package/dist/commands/changes.js +8 -3
  326. package/dist/commands/changes.js.map +1 -1
  327. package/dist/commands/codex-prep.d.ts +23 -0
  328. package/dist/commands/codex-prep.d.ts.map +1 -0
  329. package/dist/commands/codex-prep.js +56 -0
  330. package/dist/commands/codex-prep.js.map +1 -0
  331. package/dist/commands/collections.d.ts +22 -0
  332. package/dist/commands/collections.d.ts.map +1 -0
  333. package/dist/commands/collections.js +77 -0
  334. package/dist/commands/collections.js.map +1 -0
  335. package/dist/commands/connect-config.test.d.ts +2 -0
  336. package/dist/commands/connect-config.test.d.ts.map +1 -0
  337. package/dist/commands/connect-config.test.js +44 -0
  338. package/dist/commands/connect-config.test.js.map +1 -0
  339. package/dist/commands/connect-context.d.ts +45 -0
  340. package/dist/commands/connect-context.d.ts.map +1 -0
  341. package/dist/commands/connect-context.js +64 -0
  342. package/dist/commands/connect-context.js.map +1 -0
  343. package/dist/commands/connect-context.test.d.ts +2 -0
  344. package/dist/commands/connect-context.test.d.ts.map +1 -0
  345. package/dist/commands/connect-context.test.js +110 -0
  346. package/dist/commands/connect-context.test.js.map +1 -0
  347. package/dist/commands/connect-handoff.d.ts +51 -0
  348. package/dist/commands/connect-handoff.d.ts.map +1 -0
  349. package/dist/commands/connect-handoff.js +70 -0
  350. package/dist/commands/connect-handoff.js.map +1 -0
  351. package/dist/commands/connect-integration.test.d.ts +7 -0
  352. package/dist/commands/connect-integration.test.d.ts.map +1 -0
  353. package/dist/commands/connect-integration.test.js +212 -0
  354. package/dist/commands/connect-integration.test.js.map +1 -0
  355. package/dist/commands/connect-screens.d.ts +23 -0
  356. package/dist/commands/connect-screens.d.ts.map +1 -0
  357. package/dist/commands/connect-screens.js +90 -0
  358. package/dist/commands/connect-screens.js.map +1 -0
  359. package/dist/commands/connect.d.ts +36 -0
  360. package/dist/commands/connect.d.ts.map +1 -0
  361. package/dist/commands/connect.js +264 -0
  362. package/dist/commands/connect.js.map +1 -0
  363. package/dist/commands/connect.test.d.ts +6 -0
  364. package/dist/commands/connect.test.d.ts.map +1 -0
  365. package/dist/commands/connect.test.js +297 -0
  366. package/dist/commands/connect.test.js.map +1 -0
  367. package/dist/commands/constellation.d.ts.map +1 -1
  368. package/dist/commands/constellation.js +8 -3
  369. package/dist/commands/constellation.js.map +1 -1
  370. package/dist/commands/context.d.ts.map +1 -1
  371. package/dist/commands/context.js +8 -3
  372. package/dist/commands/context.js.map +1 -1
  373. package/dist/commands/cross-cut.js +2 -2
  374. package/dist/commands/cross-cut.js.map +1 -1
  375. package/dist/commands/doctor.d.ts +18 -0
  376. package/dist/commands/doctor.d.ts.map +1 -0
  377. package/dist/commands/doctor.js +297 -0
  378. package/dist/commands/doctor.js.map +1 -0
  379. package/dist/commands/doctor.test.d.ts +8 -0
  380. package/dist/commands/doctor.test.d.ts.map +1 -0
  381. package/dist/commands/doctor.test.js +461 -0
  382. package/dist/commands/doctor.test.js.map +1 -0
  383. package/dist/commands/fields.d.ts.map +1 -1
  384. package/dist/commands/fields.js +8 -4
  385. package/dist/commands/fields.js.map +1 -1
  386. package/dist/commands/get.d.ts.map +1 -1
  387. package/dist/commands/get.js +14 -6
  388. package/dist/commands/get.js.map +1 -1
  389. package/dist/commands/handshake.d.ts +233 -2
  390. package/dist/commands/handshake.d.ts.map +1 -1
  391. package/dist/commands/handshake.js +2338 -81
  392. package/dist/commands/handshake.js.map +1 -1
  393. package/dist/commands/ingest.d.ts.map +1 -1
  394. package/dist/commands/ingest.js +17 -9
  395. package/dist/commands/ingest.js.map +1 -1
  396. package/dist/commands/init.d.ts +14 -0
  397. package/dist/commands/init.d.ts.map +1 -0
  398. package/dist/commands/init.js +109 -0
  399. package/dist/commands/init.js.map +1 -0
  400. package/dist/commands/login.d.ts +4 -0
  401. package/dist/commands/login.d.ts.map +1 -1
  402. package/dist/commands/login.js +101 -38
  403. package/dist/commands/login.js.map +1 -1
  404. package/dist/commands/method.d.ts +99 -0
  405. package/dist/commands/method.d.ts.map +1 -0
  406. package/dist/commands/method.js +796 -0
  407. package/dist/commands/method.js.map +1 -0
  408. package/dist/commands/migrate-setup.d.ts +18 -0
  409. package/dist/commands/migrate-setup.d.ts.map +1 -0
  410. package/dist/commands/migrate-setup.js +148 -0
  411. package/dist/commands/migrate-setup.js.map +1 -0
  412. package/dist/commands/orient.d.ts +197 -3
  413. package/dist/commands/orient.d.ts.map +1 -1
  414. package/dist/commands/orient.js +129 -7
  415. package/dist/commands/orient.js.map +1 -1
  416. package/dist/commands/profile.d.ts +34 -0
  417. package/dist/commands/profile.d.ts.map +1 -0
  418. package/dist/commands/profile.js +165 -0
  419. package/dist/commands/profile.js.map +1 -0
  420. package/dist/commands/promote.d.ts +12 -1
  421. package/dist/commands/promote.d.ts.map +1 -1
  422. package/dist/commands/promote.js +197 -30
  423. package/dist/commands/promote.js.map +1 -1
  424. package/dist/commands/proof-run.d.ts +51 -0
  425. package/dist/commands/proof-run.d.ts.map +1 -0
  426. package/dist/commands/proof-run.js +209 -0
  427. package/dist/commands/proof-run.js.map +1 -0
  428. package/dist/commands/proposals.js +2 -2
  429. package/dist/commands/proposals.js.map +1 -1
  430. package/dist/commands/reject.d.ts.map +1 -1
  431. package/dist/commands/reject.js +14 -7
  432. package/dist/commands/reject.js.map +1 -1
  433. package/dist/commands/relate.d.ts.map +1 -1
  434. package/dist/commands/relate.js +49 -16
  435. package/dist/commands/relate.js.map +1 -1
  436. package/dist/commands/scoreboard.d.ts +28 -0
  437. package/dist/commands/scoreboard.d.ts.map +1 -0
  438. package/dist/commands/scoreboard.js +40 -0
  439. package/dist/commands/scoreboard.js.map +1 -0
  440. package/dist/commands/search.js +2 -2
  441. package/dist/commands/search.js.map +1 -1
  442. package/dist/commands/session.d.ts +26 -2
  443. package/dist/commands/session.d.ts.map +1 -1
  444. package/dist/commands/session.js +355 -41
  445. package/dist/commands/session.js.map +1 -1
  446. package/dist/commands/setup-audit.d.ts +59 -0
  447. package/dist/commands/setup-audit.d.ts.map +1 -0
  448. package/dist/commands/setup-audit.js +250 -0
  449. package/dist/commands/setup-audit.js.map +1 -0
  450. package/dist/commands/setup-detect-surfaces.d.ts +38 -0
  451. package/dist/commands/setup-detect-surfaces.d.ts.map +1 -0
  452. package/dist/commands/setup-detect-surfaces.js +76 -0
  453. package/dist/commands/setup-detect-surfaces.js.map +1 -0
  454. package/dist/commands/setup-ingest.d.ts +17 -0
  455. package/dist/commands/setup-ingest.d.ts.map +1 -0
  456. package/dist/commands/setup-ingest.js +174 -0
  457. package/dist/commands/setup-ingest.js.map +1 -0
  458. package/dist/commands/setup-resolver.d.ts +58 -0
  459. package/dist/commands/setup-resolver.d.ts.map +1 -0
  460. package/dist/commands/setup-resolver.js +150 -0
  461. package/dist/commands/setup-resolver.js.map +1 -0
  462. package/dist/commands/setup-state.d.ts +42 -0
  463. package/dist/commands/setup-state.d.ts.map +1 -0
  464. package/dist/commands/setup-state.js +93 -0
  465. package/dist/commands/setup-state.js.map +1 -0
  466. package/dist/commands/setup.d.ts +23 -0
  467. package/dist/commands/setup.d.ts.map +1 -0
  468. package/dist/commands/setup.js +69 -0
  469. package/dist/commands/setup.js.map +1 -0
  470. package/dist/commands/update.d.ts +9 -0
  471. package/dist/commands/update.d.ts.map +1 -1
  472. package/dist/commands/update.js +92 -26
  473. package/dist/commands/update.js.map +1 -1
  474. package/dist/commands/upgrade.d.ts +5 -0
  475. package/dist/commands/upgrade.d.ts.map +1 -0
  476. package/dist/commands/upgrade.js +110 -0
  477. package/dist/commands/upgrade.js.map +1 -0
  478. package/dist/commands/usage.d.ts +40 -0
  479. package/dist/commands/usage.d.ts.map +1 -0
  480. package/dist/commands/usage.js +232 -0
  481. package/dist/commands/usage.js.map +1 -0
  482. package/dist/commands/verify.d.ts.map +1 -1
  483. package/dist/commands/verify.js +14 -7
  484. package/dist/commands/verify.js.map +1 -1
  485. package/dist/commands/welcome.d.ts +21 -0
  486. package/dist/commands/welcome.d.ts.map +1 -0
  487. package/dist/commands/welcome.js +50 -0
  488. package/dist/commands/welcome.js.map +1 -0
  489. package/dist/commands/whoami.d.ts +12 -0
  490. package/dist/commands/whoami.d.ts.map +1 -0
  491. package/dist/commands/whoami.js +70 -0
  492. package/dist/commands/whoami.js.map +1 -0
  493. package/dist/commands/whoami.test.d.ts +2 -0
  494. package/dist/commands/whoami.test.d.ts.map +1 -0
  495. package/dist/commands/whoami.test.js +50 -0
  496. package/dist/commands/whoami.test.js.map +1 -0
  497. package/dist/commands/workspace.d.ts +113 -0
  498. package/dist/commands/workspace.d.ts.map +1 -0
  499. package/dist/commands/workspace.js +263 -0
  500. package/dist/commands/workspace.js.map +1 -0
  501. package/dist/formatters/__tests__/orient-provenance.test.d.ts +7 -0
  502. package/dist/formatters/__tests__/orient-provenance.test.d.ts.map +1 -0
  503. package/dist/formatters/__tests__/orient-provenance.test.js +454 -0
  504. package/dist/formatters/__tests__/orient-provenance.test.js.map +1 -0
  505. package/dist/formatters/__tests__/session.test.d.ts +2 -0
  506. package/dist/formatters/__tests__/session.test.d.ts.map +1 -0
  507. package/dist/formatters/__tests__/session.test.js +113 -0
  508. package/dist/formatters/__tests__/session.test.js.map +1 -0
  509. package/dist/formatters/audit.d.ts +6 -0
  510. package/dist/formatters/audit.d.ts.map +1 -1
  511. package/dist/formatters/audit.js.map +1 -1
  512. package/dist/formatters/capture.d.ts +26 -3
  513. package/dist/formatters/capture.d.ts.map +1 -1
  514. package/dist/formatters/capture.js +25 -1
  515. package/dist/formatters/capture.js.map +1 -1
  516. package/dist/formatters/collections.d.ts +40 -0
  517. package/dist/formatters/collections.d.ts.map +1 -0
  518. package/dist/formatters/collections.js +93 -0
  519. package/dist/formatters/collections.js.map +1 -0
  520. package/dist/formatters/entry.d.ts +30 -4
  521. package/dist/formatters/entry.d.ts.map +1 -1
  522. package/dist/formatters/entry.js +66 -17
  523. package/dist/formatters/entry.js.map +1 -1
  524. package/dist/formatters/handshake.d.ts +45 -0
  525. package/dist/formatters/handshake.d.ts.map +1 -1
  526. package/dist/formatters/handshake.js +150 -3
  527. package/dist/formatters/handshake.js.map +1 -1
  528. package/dist/formatters/orient.d.ts +268 -5
  529. package/dist/formatters/orient.d.ts.map +1 -1
  530. package/dist/formatters/orient.js +381 -34
  531. package/dist/formatters/orient.js.map +1 -1
  532. package/dist/formatters/promote.d.ts +6 -0
  533. package/dist/formatters/promote.d.ts.map +1 -1
  534. package/dist/formatters/promote.js +8 -0
  535. package/dist/formatters/promote.js.map +1 -1
  536. package/dist/formatters/relate.d.ts +2 -0
  537. package/dist/formatters/relate.d.ts.map +1 -1
  538. package/dist/formatters/relate.js +3 -0
  539. package/dist/formatters/relate.js.map +1 -1
  540. package/dist/formatters/scoreboard.d.ts +11 -0
  541. package/dist/formatters/scoreboard.d.ts.map +1 -0
  542. package/dist/formatters/scoreboard.js +48 -0
  543. package/dist/formatters/scoreboard.js.map +1 -0
  544. package/dist/formatters/search.d.ts +0 -4
  545. package/dist/formatters/search.d.ts.map +1 -1
  546. package/dist/formatters/search.js +4 -1
  547. package/dist/formatters/search.js.map +1 -1
  548. package/dist/formatters/session.d.ts +39 -2
  549. package/dist/formatters/session.d.ts.map +1 -1
  550. package/dist/formatters/session.js +130 -9
  551. package/dist/formatters/session.js.map +1 -1
  552. package/dist/formatters/update.d.ts.map +1 -1
  553. package/dist/formatters/update.js +2 -0
  554. package/dist/formatters/update.js.map +1 -1
  555. package/dist/generators/adapters.d.ts +37 -3
  556. package/dist/generators/adapters.d.ts.map +1 -1
  557. package/dist/generators/adapters.js +196 -8
  558. package/dist/generators/adapters.js.map +1 -1
  559. package/dist/generators/adapters.test.d.ts +2 -0
  560. package/dist/generators/adapters.test.d.ts.map +1 -0
  561. package/dist/generators/adapters.test.js +27 -0
  562. package/dist/generators/adapters.test.js.map +1 -0
  563. package/dist/generators/archetypes.d.ts +52 -0
  564. package/dist/generators/archetypes.d.ts.map +1 -0
  565. package/dist/generators/archetypes.js +190 -0
  566. package/dist/generators/archetypes.js.map +1 -0
  567. package/dist/generators/archetypes.test.d.ts +2 -0
  568. package/dist/generators/archetypes.test.d.ts.map +1 -0
  569. package/dist/generators/archetypes.test.js +272 -0
  570. package/dist/generators/archetypes.test.js.map +1 -0
  571. package/dist/generators/boundary-manifest.d.ts +29 -0
  572. package/dist/generators/boundary-manifest.d.ts.map +1 -0
  573. package/dist/generators/boundary-manifest.js +183 -0
  574. package/dist/generators/boundary-manifest.js.map +1 -0
  575. package/dist/generators/boundary-manifest.test.d.ts +2 -0
  576. package/dist/generators/boundary-manifest.test.d.ts.map +1 -0
  577. package/dist/generators/boundary-manifest.test.js +91 -0
  578. package/dist/generators/boundary-manifest.test.js.map +1 -0
  579. package/dist/generators/chain-classifier.d.ts +63 -0
  580. package/dist/generators/chain-classifier.d.ts.map +1 -0
  581. package/dist/generators/chain-classifier.js +131 -0
  582. package/dist/generators/chain-classifier.js.map +1 -0
  583. package/dist/generators/chain-classifier.test.d.ts +2 -0
  584. package/dist/generators/chain-classifier.test.d.ts.map +1 -0
  585. package/dist/generators/chain-classifier.test.js +371 -0
  586. package/dist/generators/chain-classifier.test.js.map +1 -0
  587. package/dist/generators/chain-rules.d.ts +42 -0
  588. package/dist/generators/chain-rules.d.ts.map +1 -0
  589. package/dist/generators/chain-rules.js +152 -0
  590. package/dist/generators/chain-rules.js.map +1 -0
  591. package/dist/generators/chain-rules.test.d.ts +2 -0
  592. package/dist/generators/chain-rules.test.d.ts.map +1 -0
  593. package/dist/generators/chain-rules.test.js +211 -0
  594. package/dist/generators/chain-rules.test.js.map +1 -0
  595. package/dist/generators/context-md.d.ts +1 -1
  596. package/dist/generators/context-md.d.ts.map +1 -1
  597. package/dist/generators/context-md.js +18 -7
  598. package/dist/generators/context-md.js.map +1 -1
  599. package/dist/generators/handshake-diff.d.ts +67 -0
  600. package/dist/generators/handshake-diff.d.ts.map +1 -0
  601. package/dist/generators/handshake-diff.js +183 -0
  602. package/dist/generators/handshake-diff.js.map +1 -0
  603. package/dist/generators/handshake-diff.test.d.ts +2 -0
  604. package/dist/generators/handshake-diff.test.d.ts.map +1 -0
  605. package/dist/generators/handshake-diff.test.js +264 -0
  606. package/dist/generators/handshake-diff.test.js.map +1 -0
  607. package/dist/generators/manifest.d.ts +115 -0
  608. package/dist/generators/manifest.d.ts.map +1 -0
  609. package/dist/generators/manifest.js +277 -0
  610. package/dist/generators/manifest.js.map +1 -0
  611. package/dist/generators/portable-knowledge.d.ts +96 -9
  612. package/dist/generators/portable-knowledge.d.ts.map +1 -1
  613. package/dist/generators/portable-knowledge.js +367 -17
  614. package/dist/generators/portable-knowledge.js.map +1 -1
  615. package/dist/generators/portable-knowledge.test.js +529 -1
  616. package/dist/generators/portable-knowledge.test.js.map +1 -1
  617. package/dist/generators/region-projections.d.ts +18 -0
  618. package/dist/generators/region-projections.d.ts.map +1 -0
  619. package/dist/generators/region-projections.js +49 -0
  620. package/dist/generators/region-projections.js.map +1 -0
  621. package/dist/generators/region-projections.test.d.ts +2 -0
  622. package/dist/generators/region-projections.test.d.ts.map +1 -0
  623. package/dist/generators/region-projections.test.js +63 -0
  624. package/dist/generators/region-projections.test.js.map +1 -0
  625. package/dist/generators/region.d.ts +24 -0
  626. package/dist/generators/region.d.ts.map +1 -0
  627. package/dist/generators/region.js +87 -0
  628. package/dist/generators/region.js.map +1 -0
  629. package/dist/generators/region.test.d.ts +2 -0
  630. package/dist/generators/region.test.d.ts.map +1 -0
  631. package/dist/generators/region.test.js +126 -0
  632. package/dist/generators/region.test.js.map +1 -0
  633. package/dist/generators/surface-profiles.d.ts +48 -0
  634. package/dist/generators/surface-profiles.d.ts.map +1 -0
  635. package/dist/generators/surface-profiles.js +98 -0
  636. package/dist/generators/surface-profiles.js.map +1 -0
  637. package/dist/index.js +800 -252
  638. package/dist/index.js.map +1 -1
  639. package/dist/lib/activation.d.ts +28 -0
  640. package/dist/lib/activation.d.ts.map +1 -0
  641. package/dist/lib/activation.js +57 -0
  642. package/dist/lib/activation.js.map +1 -0
  643. package/dist/lib/activation.test.d.ts +6 -0
  644. package/dist/lib/activation.test.d.ts.map +1 -0
  645. package/dist/lib/activation.test.js +121 -0
  646. package/dist/lib/activation.test.js.map +1 -0
  647. package/dist/lib/canonicalRefs.d.ts +141 -0
  648. package/dist/lib/canonicalRefs.d.ts.map +1 -0
  649. package/dist/lib/canonicalRefs.js +150 -0
  650. package/dist/lib/canonicalRefs.js.map +1 -0
  651. package/dist/lib/client.d.ts +33 -6
  652. package/dist/lib/client.d.ts.map +1 -1
  653. package/dist/lib/client.js +203 -42
  654. package/dist/lib/client.js.map +1 -1
  655. package/dist/lib/collectionRegistry.d.ts +40 -0
  656. package/dist/lib/collectionRegistry.d.ts.map +1 -0
  657. package/dist/lib/collectionRegistry.js +112 -0
  658. package/dist/lib/collectionRegistry.js.map +1 -0
  659. package/dist/lib/compose-wrapup-view.d.ts +48 -0
  660. package/dist/lib/compose-wrapup-view.d.ts.map +1 -0
  661. package/dist/lib/compose-wrapup-view.js +37 -0
  662. package/dist/lib/compose-wrapup-view.js.map +1 -0
  663. package/dist/lib/config.d.ts +204 -4
  664. package/dist/lib/config.d.ts.map +1 -1
  665. package/dist/lib/config.js +594 -42
  666. package/dist/lib/config.js.map +1 -1
  667. package/dist/lib/connectKeyLabel.d.ts +9 -0
  668. package/dist/lib/connectKeyLabel.d.ts.map +1 -0
  669. package/dist/lib/connectKeyLabel.js +12 -0
  670. package/dist/lib/connectKeyLabel.js.map +1 -0
  671. package/dist/lib/constants.d.ts +46 -0
  672. package/dist/lib/constants.d.ts.map +1 -0
  673. package/dist/lib/constants.js +83 -0
  674. package/dist/lib/constants.js.map +1 -0
  675. package/dist/lib/conversation-engine.d.ts +45 -0
  676. package/dist/lib/conversation-engine.d.ts.map +1 -0
  677. package/dist/lib/conversation-engine.js +112 -0
  678. package/dist/lib/conversation-engine.js.map +1 -0
  679. package/dist/lib/conversation-phases.d.ts +59 -0
  680. package/dist/lib/conversation-phases.d.ts.map +1 -0
  681. package/dist/lib/conversation-phases.js +11 -0
  682. package/dist/lib/conversation-phases.js.map +1 -0
  683. package/dist/lib/conversation-signals.d.ts +30 -0
  684. package/dist/lib/conversation-signals.d.ts.map +1 -0
  685. package/dist/lib/conversation-signals.js +64 -0
  686. package/dist/lib/conversation-signals.js.map +1 -0
  687. package/dist/lib/deployment.d.ts +23 -0
  688. package/dist/lib/deployment.d.ts.map +1 -0
  689. package/dist/lib/deployment.js +78 -0
  690. package/dist/lib/deployment.js.map +1 -0
  691. package/dist/lib/deployment.test.d.ts +5 -0
  692. package/dist/lib/deployment.test.d.ts.map +1 -0
  693. package/dist/lib/deployment.test.js +54 -0
  694. package/dist/lib/deployment.test.js.map +1 -0
  695. package/dist/lib/errors.d.ts +63 -0
  696. package/dist/lib/errors.d.ts.map +1 -0
  697. package/dist/lib/errors.js +72 -0
  698. package/dist/lib/errors.js.map +1 -0
  699. package/dist/lib/experiment.d.ts +18 -0
  700. package/dist/lib/experiment.d.ts.map +1 -0
  701. package/dist/lib/experiment.js +28 -0
  702. package/dist/lib/experiment.js.map +1 -0
  703. package/dist/lib/format.d.ts +10 -0
  704. package/dist/lib/format.d.ts.map +1 -0
  705. package/dist/lib/format.js +27 -0
  706. package/dist/lib/format.js.map +1 -0
  707. package/dist/lib/frontmatter.d.ts +55 -0
  708. package/dist/lib/frontmatter.d.ts.map +1 -0
  709. package/dist/lib/frontmatter.js +92 -0
  710. package/dist/lib/frontmatter.js.map +1 -0
  711. package/dist/lib/frontmatter.test.d.ts +15 -0
  712. package/dist/lib/frontmatter.test.d.ts.map +1 -0
  713. package/dist/lib/frontmatter.test.js +98 -0
  714. package/dist/lib/frontmatter.test.js.map +1 -0
  715. package/dist/lib/glossary.d.ts +19 -0
  716. package/dist/lib/glossary.d.ts.map +1 -0
  717. package/dist/lib/glossary.js +53 -0
  718. package/dist/lib/glossary.js.map +1 -0
  719. package/dist/lib/hook-intents.d.ts +51 -0
  720. package/dist/lib/hook-intents.d.ts.map +1 -0
  721. package/dist/lib/hook-intents.js +85 -0
  722. package/dist/lib/hook-intents.js.map +1 -0
  723. package/dist/lib/inferSourceDate.d.ts +12 -0
  724. package/dist/lib/inferSourceDate.d.ts.map +1 -0
  725. package/dist/lib/inferSourceDate.js +44 -0
  726. package/dist/lib/inferSourceDate.js.map +1 -0
  727. package/dist/lib/method-registry.d.ts +32 -0
  728. package/dist/lib/method-registry.d.ts.map +1 -0
  729. package/dist/lib/method-registry.js +53 -0
  730. package/dist/lib/method-registry.js.map +1 -0
  731. package/dist/lib/normalizeMaterializedFilename.d.ts +28 -0
  732. package/dist/lib/normalizeMaterializedFilename.d.ts.map +1 -0
  733. package/dist/lib/normalizeMaterializedFilename.js +56 -0
  734. package/dist/lib/normalizeMaterializedFilename.js.map +1 -0
  735. package/dist/lib/normalizeMaterializedFilename.test.d.ts +16 -0
  736. package/dist/lib/normalizeMaterializedFilename.test.d.ts.map +1 -0
  737. package/dist/lib/normalizeMaterializedFilename.test.js +90 -0
  738. package/dist/lib/normalizeMaterializedFilename.test.js.map +1 -0
  739. package/dist/lib/notice-marker.d.ts +3 -0
  740. package/dist/lib/notice-marker.d.ts.map +1 -0
  741. package/dist/lib/notice-marker.js +53 -0
  742. package/dist/lib/notice-marker.js.map +1 -0
  743. package/dist/lib/onboarding-path-b.d.ts +10 -0
  744. package/dist/lib/onboarding-path-b.d.ts.map +1 -0
  745. package/dist/lib/onboarding-path-b.js +213 -0
  746. package/dist/lib/onboarding-path-b.js.map +1 -0
  747. package/dist/lib/onboarding-shared.d.ts +80 -0
  748. package/dist/lib/onboarding-shared.d.ts.map +1 -0
  749. package/dist/lib/onboarding-shared.js +174 -0
  750. package/dist/lib/onboarding-shared.js.map +1 -0
  751. package/dist/lib/onboarding-topics.d.ts +27 -0
  752. package/dist/lib/onboarding-topics.d.ts.map +1 -0
  753. package/dist/lib/onboarding-topics.js +57 -0
  754. package/dist/lib/onboarding-topics.js.map +1 -0
  755. package/dist/lib/onboarding.d.ts +17 -0
  756. package/dist/lib/onboarding.d.ts.map +1 -0
  757. package/dist/lib/onboarding.js +350 -0
  758. package/dist/lib/onboarding.js.map +1 -0
  759. package/dist/lib/profiles.d.ts +41 -0
  760. package/dist/lib/profiles.d.ts.map +1 -0
  761. package/dist/lib/profiles.js +188 -0
  762. package/dist/lib/profiles.js.map +1 -0
  763. package/dist/lib/prompts.d.ts +65 -0
  764. package/dist/lib/prompts.d.ts.map +1 -0
  765. package/dist/lib/prompts.js +132 -0
  766. package/dist/lib/prompts.js.map +1 -0
  767. package/dist/lib/repo-detect.d.ts +19 -0
  768. package/dist/lib/repo-detect.d.ts.map +1 -1
  769. package/dist/lib/repo-detect.js +25 -0
  770. package/dist/lib/repo-detect.js.map +1 -1
  771. package/dist/lib/runner.d.ts +2 -0
  772. package/dist/lib/runner.d.ts.map +1 -1
  773. package/dist/lib/runner.js +21 -7
  774. package/dist/lib/runner.js.map +1 -1
  775. package/dist/lib/session.d.ts +35 -0
  776. package/dist/lib/session.d.ts.map +1 -1
  777. package/dist/lib/session.js +94 -3
  778. package/dist/lib/session.js.map +1 -1
  779. package/dist/lib/spinner.d.ts +27 -0
  780. package/dist/lib/spinner.d.ts.map +1 -0
  781. package/dist/lib/spinner.js +76 -0
  782. package/dist/lib/spinner.js.map +1 -0
  783. package/dist/lib/spinner.test.d.ts +2 -0
  784. package/dist/lib/spinner.test.d.ts.map +1 -0
  785. package/dist/lib/spinner.test.js +39 -0
  786. package/dist/lib/spinner.test.js.map +1 -0
  787. package/dist/lib/startup-resolution-signals.d.ts +34 -0
  788. package/dist/lib/startup-resolution-signals.d.ts.map +1 -0
  789. package/dist/lib/startup-resolution-signals.js +118 -0
  790. package/dist/lib/startup-resolution-signals.js.map +1 -0
  791. package/dist/lib/startup-resolution-signals.test.d.ts +2 -0
  792. package/dist/lib/startup-resolution-signals.test.d.ts.map +1 -0
  793. package/dist/lib/startup-resolution-signals.test.js +113 -0
  794. package/dist/lib/startup-resolution-signals.test.js.map +1 -0
  795. package/dist/lib/state.d.ts +51 -0
  796. package/dist/lib/state.d.ts.map +1 -0
  797. package/dist/lib/state.js +90 -0
  798. package/dist/lib/state.js.map +1 -0
  799. package/dist/lib/strip.d.ts +1 -0
  800. package/dist/lib/strip.d.ts.map +1 -1
  801. package/dist/lib/strip.js +15 -0
  802. package/dist/lib/strip.js.map +1 -1
  803. package/dist/lib/style.d.ts +96 -0
  804. package/dist/lib/style.d.ts.map +1 -0
  805. package/dist/lib/style.js +169 -0
  806. package/dist/lib/style.js.map +1 -0
  807. package/dist/lib/style.test.d.ts +7 -0
  808. package/dist/lib/style.test.d.ts.map +1 -0
  809. package/dist/lib/style.test.js +263 -0
  810. package/dist/lib/style.test.js.map +1 -0
  811. package/dist/lib/telemetry.d.ts +15 -0
  812. package/dist/lib/telemetry.d.ts.map +1 -0
  813. package/dist/lib/telemetry.js +47 -0
  814. package/dist/lib/telemetry.js.map +1 -0
  815. package/dist/lib/tokenConstants.d.ts +19 -0
  816. package/dist/lib/tokenConstants.d.ts.map +1 -0
  817. package/dist/lib/tokenConstants.js +19 -0
  818. package/dist/lib/tokenConstants.js.map +1 -0
  819. package/dist/lib/update-check.d.ts +56 -0
  820. package/dist/lib/update-check.d.ts.map +1 -0
  821. package/dist/lib/update-check.js +296 -0
  822. package/dist/lib/update-check.js.map +1 -0
  823. package/dist/lib/upgrade-runner.d.ts +22 -0
  824. package/dist/lib/upgrade-runner.d.ts.map +1 -0
  825. package/dist/lib/upgrade-runner.js +110 -0
  826. package/dist/lib/upgrade-runner.js.map +1 -0
  827. package/dist/lib/wizard-surfaces.d.ts +47 -0
  828. package/dist/lib/wizard-surfaces.d.ts.map +1 -0
  829. package/dist/lib/wizard-surfaces.js +176 -0
  830. package/dist/lib/wizard-surfaces.js.map +1 -0
  831. package/dist/lib/wizard-surfaces.test.d.ts +2 -0
  832. package/dist/lib/wizard-surfaces.test.d.ts.map +1 -0
  833. package/dist/lib/wizard-surfaces.test.js +127 -0
  834. package/dist/lib/wizard-surfaces.test.js.map +1 -0
  835. package/dist/lib/wizard-trust.d.ts +31 -0
  836. package/dist/lib/wizard-trust.d.ts.map +1 -0
  837. package/dist/lib/wizard-trust.js +66 -0
  838. package/dist/lib/wizard-trust.js.map +1 -0
  839. package/dist/lib/wizard-trust.test.d.ts +2 -0
  840. package/dist/lib/wizard-trust.test.d.ts.map +1 -0
  841. package/dist/lib/wizard-trust.test.js +32 -0
  842. package/dist/lib/wizard-trust.test.js.map +1 -0
  843. package/dist/lib/workspace-probe.d.ts +19 -0
  844. package/dist/lib/workspace-probe.d.ts.map +1 -0
  845. package/dist/lib/workspace-probe.js +27 -0
  846. package/dist/lib/workspace-probe.js.map +1 -0
  847. package/dist/lib/workspaceVocabCache.d.ts +60 -0
  848. package/dist/lib/workspaceVocabCache.d.ts.map +1 -0
  849. package/dist/lib/workspaceVocabCache.js +98 -0
  850. package/dist/lib/workspaceVocabCache.js.map +1 -0
  851. package/dist/scoreboard/diagnose.d.ts +182 -0
  852. package/dist/scoreboard/diagnose.d.ts.map +1 -0
  853. package/dist/scoreboard/diagnose.js +250 -0
  854. package/dist/scoreboard/diagnose.js.map +1 -0
  855. package/dist/scoreboard/diagnose.test.d.ts +12 -0
  856. package/dist/scoreboard/diagnose.test.d.ts.map +1 -0
  857. package/dist/scoreboard/diagnose.test.js +192 -0
  858. package/dist/scoreboard/diagnose.test.js.map +1 -0
  859. package/dist/scoreboard/localDrift.d.ts +23 -0
  860. package/dist/scoreboard/localDrift.d.ts.map +1 -0
  861. package/dist/scoreboard/localDrift.js +111 -0
  862. package/dist/scoreboard/localDrift.js.map +1 -0
  863. package/dist/scoreboard/localDrift.test.d.ts +9 -0
  864. package/dist/scoreboard/localDrift.test.d.ts.map +1 -0
  865. package/dist/scoreboard/localDrift.test.js +82 -0
  866. package/dist/scoreboard/localDrift.test.js.map +1 -0
  867. package/dist/setup/__tests__/coach-traces.test.d.ts +2 -0
  868. package/dist/setup/__tests__/coach-traces.test.d.ts.map +1 -0
  869. package/dist/setup/__tests__/coach-traces.test.js +189 -0
  870. package/dist/setup/__tests__/coach-traces.test.js.map +1 -0
  871. package/dist/setup/__tests__/setup-commands.test.d.ts +2 -0
  872. package/dist/setup/__tests__/setup-commands.test.d.ts.map +1 -0
  873. package/dist/setup/__tests__/setup-commands.test.js +177 -0
  874. package/dist/setup/__tests__/setup-commands.test.js.map +1 -0
  875. package/dist/setup/__tests__/state-machine.test.d.ts +2 -0
  876. package/dist/setup/__tests__/state-machine.test.d.ts.map +1 -0
  877. package/dist/setup/__tests__/state-machine.test.js +341 -0
  878. package/dist/setup/__tests__/state-machine.test.js.map +1 -0
  879. package/dist/setup/detect-surfaces.d.ts +21 -0
  880. package/dist/setup/detect-surfaces.d.ts.map +1 -0
  881. package/dist/setup/detect-surfaces.js +39 -0
  882. package/dist/setup/detect-surfaces.js.map +1 -0
  883. package/dist/setup/manifest-writer.d.ts +17 -0
  884. package/dist/setup/manifest-writer.d.ts.map +1 -0
  885. package/dist/setup/manifest-writer.js +153 -0
  886. package/dist/setup/manifest-writer.js.map +1 -0
  887. package/dist/setup/perimeter.d.ts +72 -0
  888. package/dist/setup/perimeter.d.ts.map +1 -0
  889. package/dist/setup/perimeter.js +128 -0
  890. package/dist/setup/perimeter.js.map +1 -0
  891. package/dist/setup/state-machine.d.ts +67 -0
  892. package/dist/setup/state-machine.d.ts.map +1 -0
  893. package/dist/setup/state-machine.js +124 -0
  894. package/dist/setup/state-machine.js.map +1 -0
  895. package/dist/surfaces/__tests__/adapter.test.d.ts +2 -0
  896. package/dist/surfaces/__tests__/adapter.test.d.ts.map +1 -0
  897. package/dist/surfaces/__tests__/adapter.test.js +90 -0
  898. package/dist/surfaces/__tests__/adapter.test.js.map +1 -0
  899. package/dist/surfaces/__tests__/pb-setup-passthrough.test.d.ts +2 -0
  900. package/dist/surfaces/__tests__/pb-setup-passthrough.test.d.ts.map +1 -0
  901. package/dist/surfaces/__tests__/pb-setup-passthrough.test.js +132 -0
  902. package/dist/surfaces/__tests__/pb-setup-passthrough.test.js.map +1 -0
  903. package/dist/surfaces/__tests__/telemetry.test.d.ts +2 -0
  904. package/dist/surfaces/__tests__/telemetry.test.d.ts.map +1 -0
  905. package/dist/surfaces/__tests__/telemetry.test.js +55 -0
  906. package/dist/surfaces/__tests__/telemetry.test.js.map +1 -0
  907. package/dist/surfaces/adapter.d.ts +70 -0
  908. package/dist/surfaces/adapter.d.ts.map +1 -0
  909. package/dist/surfaces/adapter.js +2 -0
  910. package/dist/surfaces/adapter.js.map +1 -0
  911. package/dist/surfaces/adapters/claude.d.ts +3 -0
  912. package/dist/surfaces/adapters/claude.d.ts.map +1 -0
  913. package/dist/surfaces/adapters/claude.js +67 -0
  914. package/dist/surfaces/adapters/claude.js.map +1 -0
  915. package/dist/surfaces/adapters/codex.d.ts +3 -0
  916. package/dist/surfaces/adapters/codex.d.ts.map +1 -0
  917. package/dist/surfaces/adapters/codex.js +61 -0
  918. package/dist/surfaces/adapters/codex.js.map +1 -0
  919. package/dist/surfaces/adapters/copilot.d.ts +3 -0
  920. package/dist/surfaces/adapters/copilot.d.ts.map +1 -0
  921. package/dist/surfaces/adapters/copilot.js +59 -0
  922. package/dist/surfaces/adapters/copilot.js.map +1 -0
  923. package/dist/surfaces/adapters/cursor.d.ts +3 -0
  924. package/dist/surfaces/adapters/cursor.d.ts.map +1 -0
  925. package/dist/surfaces/adapters/cursor.js +78 -0
  926. package/dist/surfaces/adapters/cursor.js.map +1 -0
  927. package/dist/surfaces/registry.d.ts +76 -0
  928. package/dist/surfaces/registry.d.ts.map +1 -0
  929. package/dist/surfaces/registry.js +117 -0
  930. package/dist/surfaces/registry.js.map +1 -0
  931. package/dist/surfaces/telemetry.d.ts +17 -0
  932. package/dist/surfaces/telemetry.d.ts.map +1 -0
  933. package/dist/surfaces/telemetry.js +31 -0
  934. package/dist/surfaces/telemetry.js.map +1 -0
  935. package/package.json +12 -4
  936. package/templates/archetypes/boundary.md +23 -0
  937. package/templates/archetypes/constraint.md +23 -0
  938. package/templates/archetypes/convention.md +23 -0
  939. package/templates/archetypes/policy.md +23 -0
  940. package/templates/archetypes/quality-gate.md +23 -0
  941. package/templates/archetypes/workflow.md +23 -0
  942. package/templates/general/code-integrity.md +11 -0
  943. package/templates/general/getting-started.md +12 -0
  944. package/templates/method-registry.json +16 -0
  945. package/templates/node-ts/code-integrity.md +13 -0
  946. package/templates/node-ts/testing.md +12 -0
  947. package/templates/python/code-integrity.md +13 -0
  948. package/templates/python/testing.md +12 -0
@@ -0,0 +1,944 @@
1
+ /**
2
+ * pb admin seed — workspace and platform seed operations (WP-312 S3, FEAT-970).
3
+ *
4
+ * Seed metadata is duplicated from `convex/admin/commandManifest.ts` for CLI help
5
+ * and ordering only — behavior is enforced server-side (STD-101).
6
+ *
7
+ * WP-433 S1b D13: the 4 substrate-repair migrations + backfill-default-team are
8
+ * generated from `convex/admin/seed/registry.ts` (single SSOT) into
9
+ * `seedRegistryEntries.generated.ts`. Run `npm run codegen` to refresh after registry edits.
10
+ */
11
+ import * as clack from '@clack/prompts';
12
+ import { adminCall } from '../../lib/client.js';
13
+ import { resolveAdminConfig } from '../../lib/config.js';
14
+ import { CLIError, ErrorCode } from '../../lib/errors.js';
15
+ import { ask, confirm, intro, isInteractive, log, multiselect, note, outro } from '../../lib/prompts.js';
16
+ import { readSession } from '../../lib/session.js';
17
+ import { isJsonMode } from '../../lib/runner.js';
18
+ import { REGISTRY_SEED_COMMAND_ENTRIES } from './seedRegistryEntries.generated.js';
19
+ import { confirmRiskNoteTitle, requiresAdminDestructiveConfirmation, seedAllConfirmMessage, seedMultiselectConfirmMessage, seedRunConfirmMessage, } from '../../lib/deployment.js';
20
+ import { withSpinner } from '../../lib/spinner.js';
21
+ import { adminBanner, bold, confirmProdAction, cyan, dim, green, heading, hint, icons, red, yellow, } from '../../lib/style.js';
22
+ /**
23
+ * Order matches `ADMIN_COMMANDS` seed block in commandManifest.ts — dependency order for `seed all`.
24
+ */
25
+ export const SEED_COMMAND_ENTRIES = [
26
+ {
27
+ name: 'seed:artifacts',
28
+ description: 'Seed Artifacts collection and related glossary entries (chainId, format, audience)',
29
+ requiresWorkspaceId: true,
30
+ dryRunSupported: false,
31
+ },
32
+ {
33
+ name: 'seed:chain-native-bet-constellation',
34
+ description: 'Seed the chain-native bet constellation for a workspace',
35
+ requiresWorkspaceId: false,
36
+ dryRunSupported: false,
37
+ },
38
+ {
39
+ name: 'seed:definitions-chain',
40
+ description: 'Seed the definitions chain collection',
41
+ requiresWorkspaceId: true,
42
+ dryRunSupported: false,
43
+ },
44
+ {
45
+ name: 'seed:domain-teams',
46
+ description: 'Seed domain teams collection entries',
47
+ requiresWorkspaceId: true,
48
+ dryRunSupported: true,
49
+ },
50
+ {
51
+ name: 'seed:features',
52
+ description: 'Seed Features collection and initial trust-audit entries',
53
+ requiresWorkspaceId: true,
54
+ dryRunSupported: false,
55
+ },
56
+ {
57
+ name: 'seed:hierarchy-tier1',
58
+ description: 'Apply Tier 1 hierarchy migrations (landscape thinkingLayer, key-results fields)',
59
+ requiresWorkspaceId: false,
60
+ dryRunSupported: true,
61
+ },
62
+ {
63
+ name: 'seed:id-prefixes',
64
+ description: 'Seed collection ID prefixes for a workspace',
65
+ requiresWorkspaceId: true,
66
+ dryRunSupported: false,
67
+ },
68
+ {
69
+ name: 'seed:knowledge',
70
+ description: 'Seed initial knowledge base (Standards, Features collections + labels)',
71
+ requiresWorkspaceId: true,
72
+ dryRunSupported: false,
73
+ },
74
+ {
75
+ name: 'seed:process-templates',
76
+ description: 'Seed process templates collection for a workspace',
77
+ requiresWorkspaceId: true,
78
+ dryRunSupported: false,
79
+ },
80
+ {
81
+ name: 'seed:proposals',
82
+ description: 'Seed governance proposals collection',
83
+ requiresWorkspaceId: true,
84
+ dryRunSupported: false,
85
+ },
86
+ {
87
+ name: 'seed:readiness-config',
88
+ description: 'Migrate readiness config (readinessFloor, readinessWeight, readinessLayer) on all collections',
89
+ requiresWorkspaceId: false,
90
+ dryRunSupported: true,
91
+ },
92
+ {
93
+ name: 'seed:semantic-types-all',
94
+ description: 'Seed semantic types into all workspaces (cross-workspace action)',
95
+ requiresWorkspaceId: false,
96
+ dryRunSupported: false,
97
+ },
98
+ {
99
+ name: 'seed:migrate-scope-required-fields',
100
+ description: 'Fix scope semantic type: update requiredFields from description to purpose across all workspaces (TEN-346)',
101
+ requiresWorkspaceId: false,
102
+ dryRunSupported: true,
103
+ },
104
+ {
105
+ name: 'seed:writing-guidance',
106
+ description: 'Seed writing guidance entries for a workspace',
107
+ requiresWorkspaceId: true,
108
+ dryRunSupported: true,
109
+ },
110
+ // ─── WP-379 S5a: Starter Setup seed operations ─────────────────────────────
111
+ {
112
+ name: 'seed:show-starter',
113
+ description: 'List 18 Starter Setup assets for a workspace with body previews, lockLevel, and gate summary',
114
+ requiresWorkspaceId: true,
115
+ dryRunSupported: false,
116
+ },
117
+ {
118
+ name: 'seed:backfill-starter',
119
+ description: 'Idempotent bulk seed of Starter Setup bundle across workspaces. Defaults to dry-run.',
120
+ requiresWorkspaceId: false,
121
+ dryRunSupported: true,
122
+ dangerous: true,
123
+ },
124
+ {
125
+ name: 'seed:migrate-starter-fields',
126
+ description: 'STUB (WP-379 S5b): backfill explicit lockLevel + gate columns on existing setup-assets entries.',
127
+ requiresWorkspaceId: true,
128
+ dryRunSupported: true,
129
+ },
130
+ // WP-433 S1b D13: `seed:migrate-setup-skill-entryid` migrated to the SSOT registry.
131
+ // It now appears via REGISTRY_SEED_COMMAND_ENTRIES below (alongside the 3 new repair ops
132
+ // and `backfill-default-team`).
133
+ ];
134
+ // WP-433 S1b D13: registry-generated entries appended to the static list. These are the
135
+ // 11 ops registered in `convex/admin/seed/registry.ts`. Filter out the prestep
136
+ // (`align-workspace-collections`) — it cannot be invoked via `pb admin seed run`.
137
+ const REGISTRY_RUNNABLE_ENTRIES = REGISTRY_SEED_COMMAND_ENTRIES
138
+ .filter((e) => e.runnable)
139
+ .map((e) => ({
140
+ name: e.name,
141
+ description: e.description,
142
+ requiresWorkspaceId: e.requiresWorkspaceId,
143
+ dryRunSupported: e.dryRunSupported,
144
+ }));
145
+ /** Combined list: static manifest entries (legacy seeds) + registry-generated entries. */
146
+ const ALL_SEED_COMMAND_ENTRIES = [
147
+ ...SEED_COMMAND_ENTRIES,
148
+ ...REGISTRY_RUNNABLE_ENTRIES,
149
+ ];
150
+ const SEED_BY_NAME = new Map(ALL_SEED_COMMAND_ENTRIES.map((e) => [e.name, e]));
151
+ /**
152
+ * Manifest order for `pb admin seed all`.
153
+ *
154
+ * Includes the static legacy seeds plus the registry-generated runnable entries so
155
+ * `seed all` exercises the full surface (D13 SSOT).
156
+ */
157
+ export const SEED_MANIFEST_ORDER = ALL_SEED_COMMAND_ENTRIES.map((e) => e.name);
158
+ function shortLabel(manifestName) {
159
+ return manifestName.startsWith('seed:') ? manifestName.slice('seed:'.length) : manifestName;
160
+ }
161
+ /**
162
+ * Convert a manifest name (which may be a bare slug for registry-generated entries)
163
+ * to the backend command name expected by the admin dispatch layer.
164
+ *
165
+ * Legacy static entries are already stored as `seed:<slug>` — returned as-is.
166
+ * Registry-generated entries are stored as bare slugs (e.g. `seed-system-glossary`);
167
+ * the backend COMMAND_MAP expects `seed:<slug>`, so we add the prefix here.
168
+ */
169
+ function toBackendCommand(manifestName) {
170
+ return manifestName.startsWith('seed:') ? manifestName : `seed:${manifestName}`;
171
+ }
172
+ /**
173
+ * Accept short-form or long-form seed op names; return the canonical backend command name.
174
+ *
175
+ * Static entries (legacy) are stored as `seed:<slug>` (e.g. `seed:knowledge`).
176
+ * Registry-generated entries (WP-433 S1b) are stored as bare slugs (e.g.
177
+ * `seed-system-glossary`) to avoid the double-prefix `seed:seed-*` trap that
178
+ * arose when slugs like `seed-system-glossary` were naively stored as
179
+ * `seed:seed-system-glossary`.
180
+ *
181
+ * Both forms always return the backend command name (`seed:<bare-slug>`):
182
+ * - `'system-glossary'` or `'seed-system-glossary'` → `'seed:seed-system-glossary'`
183
+ * would be wrong; instead the bare slug stored in the map IS `seed-system-glossary`
184
+ * and the backend command is `seed:seed-system-glossary`.
185
+ *
186
+ * Resolution order:
187
+ * 1. Try `seed:<t>` — covers legacy static entries (`seed:knowledge`) and any input
188
+ * that normalises to a key already stored with the `seed:` prefix.
189
+ * 2. Try bare `<t>` (stripping a leading `seed:` from the input if present) —
190
+ * covers registry entries stored without the prefix.
191
+ * When found via bare slug, return `seed:<bare>` so the caller always gets a
192
+ * backend-compatible command name.
193
+ */
194
+ export function normalizeSeedCommandName(input) {
195
+ const t = input.trim();
196
+ if (!t) {
197
+ throw new CLIError('Seed operation name is required.', {
198
+ code: ErrorCode.VALIDATION_FAILED,
199
+ category: 'validation',
200
+ });
201
+ }
202
+ // 1. Try the `seed:`-prefixed form (covers all legacy static entries).
203
+ const withPrefix = t.startsWith('seed:') ? t : `seed:${t}`;
204
+ if (SEED_BY_NAME.has(withPrefix))
205
+ return withPrefix;
206
+ // 2. Try the bare-slug form (covers registry-generated entries stored without `seed:`).
207
+ // Strip one leading `seed:` if the input has it, so both
208
+ // `seed-system-glossary` and `seed:seed-system-glossary` resolve to `seed-system-glossary`.
209
+ const bare = t.startsWith('seed:') ? t.slice('seed:'.length) : t;
210
+ if (SEED_BY_NAME.has(bare)) {
211
+ // Return the backend-compatible `seed:` form so callers can pass this directly
212
+ // to adminCall and the backend COMMAND_MAP will find it.
213
+ return `seed:${bare}`;
214
+ }
215
+ const known = SEED_MANIFEST_ORDER.map((n) => shortLabel(n)).join(', ');
216
+ throw new CLIError(`Unknown seed operation "${input}". Known short names: ${known}`, {
217
+ code: ErrorCode.VALIDATION_FAILED,
218
+ category: 'validation',
219
+ });
220
+ }
221
+ // ─── WP-379 S5a: Starter-specific arg builders ───────────────────────────────
222
+ /**
223
+ * Build args for seed:backfill-starter with CLI-side validation.
224
+ *
225
+ * Rules:
226
+ * - confirm:true requires workspaceScope to be explicitly provided
227
+ * - dryRun defaults to true when confirm is false
228
+ *
229
+ * Exported for testing.
230
+ */
231
+ export function buildBackfillStarterArgs(opts) {
232
+ const confirm = opts.confirm ?? false;
233
+ const dryRun = opts.dryRun ?? !confirm;
234
+ if (confirm && !opts.workspaceScope) {
235
+ throw new CLIError('backfill-starter: --workspace-scope (dev|prod|all) is required when --confirm is passed. ' +
236
+ 'Specify which deployment scope to seed to prevent accidental cross-scope writes.', { code: ErrorCode.VALIDATION_FAILED, category: 'validation' });
237
+ }
238
+ const validScopes = ['dev', 'prod', 'all'];
239
+ if (opts.workspaceScope && !validScopes.includes(opts.workspaceScope)) {
240
+ throw new CLIError(`backfill-starter: --workspace-scope must be one of: ${validScopes.join(', ')}. Got: "${opts.workspaceScope}"`, { code: ErrorCode.VALIDATION_FAILED, category: 'validation' });
241
+ }
242
+ const args = { dryRun, confirm };
243
+ if (opts.workspaceScope)
244
+ args.workspaceScope = opts.workspaceScope;
245
+ return args;
246
+ }
247
+ function resolveWorkspaceId(explicit) {
248
+ if (explicit)
249
+ return explicit;
250
+ return readSession()?.workspaceId;
251
+ }
252
+ function requireWorkspaceId(explicit) {
253
+ const id = resolveWorkspaceId(explicit);
254
+ if (!id) {
255
+ throw new CLIError('Workspace id required — pass --workspace-id or run `pb session start` in this project.', { code: ErrorCode.VALIDATION_FAILED, category: 'validation' });
256
+ }
257
+ return id;
258
+ }
259
+ export function buildSeedArgs(manifestName, opts) {
260
+ // Try exact match first (legacy static entries stored as `seed:<slug>`).
261
+ // Fall back to bare-slug lookup (registry-generated entries stored without `seed:` prefix).
262
+ const bare = manifestName.startsWith('seed:') ? manifestName.slice('seed:'.length) : manifestName;
263
+ const def = SEED_BY_NAME.get(manifestName) ?? SEED_BY_NAME.get(bare);
264
+ if (!def) {
265
+ throw new CLIError(`Unknown seed command: ${manifestName}`, {
266
+ code: ErrorCode.VALIDATION_FAILED,
267
+ category: 'validation',
268
+ });
269
+ }
270
+ const args = {};
271
+ if (def.requiresWorkspaceId) {
272
+ args.workspaceId = requireWorkspaceId(opts.workspaceId);
273
+ }
274
+ else if (opts.workspaceId && manifestName === 'seed:chain-native-bet-constellation') {
275
+ args.workspaceId = opts.workspaceId;
276
+ }
277
+ if (def.dryRunSupported && opts.dryRun) {
278
+ args.dryRun = true;
279
+ }
280
+ return args;
281
+ }
282
+ function printSeedList() {
283
+ const rows = ALL_SEED_COMMAND_ENTRIES.map((e) => ({
284
+ name: shortLabel(e.name),
285
+ description: e.description,
286
+ workspace: e.requiresWorkspaceId ? 'yes' : 'no',
287
+ dryRun: e.dryRunSupported ? 'yes' : '—',
288
+ }));
289
+ if (isJsonMode()) {
290
+ process.stdout.write(JSON.stringify({ commands: rows }, null, 2) + '\n');
291
+ return;
292
+ }
293
+ try {
294
+ adminBanner(resolveAdminConfig().siteUrl);
295
+ }
296
+ catch { /* not configured */ }
297
+ const wName = Math.max(8, ...rows.map((r) => r.name.length));
298
+ const wWs = 9;
299
+ const wDr = 7;
300
+ process.stdout.write(`${bold('Name'.padEnd(wName))} ${bold('Workspace'.padEnd(wWs))} ${bold('Dry-run'.padEnd(wDr))} ${bold('Description')}\n`);
301
+ process.stdout.write(dim('─'.repeat(wName + wWs + wDr + 40)) + '\n');
302
+ for (const r of rows) {
303
+ const dryRunStr = r.dryRun === 'yes' ? green(r.dryRun.padEnd(wDr)) : dim(r.dryRun.padEnd(wDr));
304
+ process.stdout.write(`${cyan(r.name.padEnd(wName))} ${r.workspace.padEnd(wWs)} ${dryRunStr} ${dim(r.description)}\n`);
305
+ }
306
+ process.stdout.write('\n');
307
+ hint(`${ALL_SEED_COMMAND_ENTRIES.length} operations — behavior enforced server-side (commandManifest.ts + WP-433 S1b registry)`);
308
+ hint('pb admin seed run <name> Run one operation');
309
+ hint('pb admin seed all Run all in manifest order');
310
+ }
311
+ async function printSeedStatus(workspaceIdOpt) {
312
+ const readiness = await adminCall('inspect:readiness-config', {});
313
+ let collection = null;
314
+ const wsId = resolveWorkspaceId(workspaceIdOpt);
315
+ if (wsId) {
316
+ collection = await adminCall('inspect:collection', { workspaceId: wsId });
317
+ }
318
+ const statusNote = 'Per-seed run history is not tracked server-side yet — use workspace totals and readiness diagnose as signals.';
319
+ if (isJsonMode()) {
320
+ process.stdout.write(JSON.stringify({
321
+ note: statusNote,
322
+ readinessConfig: readiness,
323
+ workspaceCollections: collection,
324
+ workspaceId: wsId ?? null,
325
+ }, null, 2) + '\n');
326
+ return;
327
+ }
328
+ process.stdout.write(`${bold('Seed status')}\n\n`);
329
+ process.stdout.write(` ${dim(statusNote)}\n\n`);
330
+ process.stdout.write(`${bold('Readiness config migration (inspect:readiness-config)')}\n`);
331
+ process.stdout.write(` ${dim(JSON.stringify(readiness, null, 2).split('\n').join('\n '))}\n\n`);
332
+ if (collection && typeof collection === 'object' && collection !== null && 'workspace' in collection) {
333
+ const c = collection;
334
+ process.stdout.write(`${bold('Workspace')}\n`);
335
+ process.stdout.write(` ${c.workspace.name} (${c.workspace.slug})\n`);
336
+ process.stdout.write(` Collections: ${c.totalCollections} — Entries: ${c.totalEntries}\n\n`);
337
+ }
338
+ else if (!wsId) {
339
+ process.stdout.write(`${dim('No workspace id — pass --workspace-id or use an active session for collection breakdown.')}\n\n`);
340
+ }
341
+ }
342
+ async function runSeedOperation(manifestName, opts) {
343
+ const args = buildSeedArgs(manifestName, opts);
344
+ return adminCall(manifestName, args);
345
+ }
346
+ /**
347
+ * WP-433 S1b D16 — render the system/fleet seed status report.
348
+ *
349
+ * Frame: this is a system-admin (operator) command. Output never says "your workspace" —
350
+ * always "the system" / "X workspaces" / a specific named workspace.
351
+ */
352
+ function renderSeedStatusReport(data) {
353
+ if (!data || typeof data !== 'object') {
354
+ process.stdout.write(`${dim('No data returned.')}\n`);
355
+ return;
356
+ }
357
+ const report = data;
358
+ const mode = report.mode;
359
+ if (mode === 'fleet') {
360
+ const summary = report.summary;
361
+ const failures = report.failures ?? [];
362
+ process.stdout.write(`${bold(`System: ${summary.total} workspace${summary.total === 1 ? '' : 's'} total`)}\n\n`);
363
+ process.stdout.write(` ${green(icons.pass)} ${summary.healthy} healthy (all assertions passed)\n`);
364
+ if (summary.failed > 0) {
365
+ process.stdout.write(` ${red(icons.fail)} ${summary.failed} with failed assertions\n`);
366
+ }
367
+ if (summary.neverRun > 0) {
368
+ process.stdout.write(` ${dim('!')} ${summary.neverRun} with never-run ops (likely created pre-registry)\n`);
369
+ }
370
+ if (failures.length === 0) {
371
+ process.stdout.write(`\n${dim('No failures or never-run ops to report.')}\n`);
372
+ return;
373
+ }
374
+ // Group failures by status for readable output.
375
+ const failedRows = failures.filter((f) => f.status === 'failed');
376
+ const neverRunRows = failures.filter((f) => f.status === 'never-run');
377
+ if (failedRows.length > 0) {
378
+ process.stdout.write(`\n${red('Failures:')}\n`);
379
+ for (const f of failedRows) {
380
+ process.stdout.write(` - ${cyan(`workspace-${f.workspaceId}`)} (${bold(f.workspaceName)}) — ${f.slug}: ${f.detail}\n`);
381
+ if (f.recommendedRepairOp) {
382
+ process.stdout.write(` repair: ${dim(`pb admin seed run ${f.recommendedRepairOp} --workspace-id ${f.workspaceId}`)}\n`);
383
+ }
384
+ }
385
+ }
386
+ if (neverRunRows.length > 0) {
387
+ process.stdout.write(`\n${dim('Never-run ops:')}\n`);
388
+ for (const f of neverRunRows) {
389
+ process.stdout.write(` - ${cyan(`workspace-${f.workspaceId}`)} (${bold(f.workspaceName)}) — ${f.slug} never invoked\n`);
390
+ if (f.recommendedRepairOp) {
391
+ process.stdout.write(` repair: ${dim(`pb admin seed run ${f.recommendedRepairOp} --workspace-id ${f.workspaceId}`)}\n`);
392
+ }
393
+ }
394
+ }
395
+ return;
396
+ }
397
+ if (mode === 'drilldown') {
398
+ const workspaceName = report.workspaceName;
399
+ const workspaceId = report.workspaceId;
400
+ const rows = report.rows ?? [];
401
+ if (rows.length === 0) {
402
+ process.stdout.write(`${bold(`Workspace: ${workspaceName}`)} ${dim(`(${workspaceId})`)}\n\n`);
403
+ process.stdout.write(`${dim('No registered ops.')}\n`);
404
+ return;
405
+ }
406
+ // TEN-2021: group by level so non-tech operators don't conflate
407
+ // platform-substrate ops with on-demand repair tools.
408
+ const levelBySlug = new Map(REGISTRY_SEED_COMMAND_ENTRIES.map((e) => [e.name, e.level]));
409
+ const platformRows = rows.filter((r) => levelBySlug.get(r.slug) === 'platform');
410
+ const workspaceRows = rows.filter((r) => levelBySlug.get(r.slug) === 'workspace');
411
+ const repairRows = rows.filter((r) => levelBySlug.get(r.slug) === 'repair');
412
+ // TEN-2019 known soft-failure: platform-source workspace has no curated
413
+ // methods/skills entries to project. Not a workspace bug — render as ⚠.
414
+ const PLATFORM_SOURCE_EMPTY_MARKER = 'neither methods nor skills collection found';
415
+ const isPlatformSourceEmptyRow = (r) => r.status === 'failed' && r.detail.includes(PLATFORM_SOURCE_EMPTY_MARKER);
416
+ // ── Header: workspace identity + at-a-glance health summary ────────────────
417
+ const isSeedRow = (r) => {
418
+ const lvl = levelBySlug.get(r.slug);
419
+ return lvl === 'platform' || lvl === 'workspace';
420
+ };
421
+ const seedRows = rows.filter(isSeedRow);
422
+ const passCount = seedRows.filter((r) => r.status === 'passed').length;
423
+ const warnCount = seedRows.filter(isPlatformSourceEmptyRow).length;
424
+ const failCount = seedRows.filter((r) => r.status === 'failed' && !isPlatformSourceEmptyRow(r)).length;
425
+ process.stdout.write(`${bold('Workspace:')} ${workspaceName}\n`);
426
+ process.stdout.write(`${bold('ID:')} ${dim(workspaceId)}\n`);
427
+ process.stdout.write(`${bold('Health:')} ${green(`${passCount} ${icons.pass}`)} ${yellow(`${warnCount} ⚠`)} ${red(`${failCount} ${icons.fail}`)}\n\n`);
428
+ // ── Row renderer: only show detail on ⚠ / ✗ via indented sub-line ──────────
429
+ const renderRow = (r) => {
430
+ const isWarn = isPlatformSourceEmptyRow(r);
431
+ const icon = isWarn ? yellow('⚠')
432
+ : r.status === 'passed' ? green(icons.pass)
433
+ : r.status === 'failed' ? red(icons.fail)
434
+ : dim('-');
435
+ process.stdout.write(` ${icon} ${cyan(r.slug)}\n`);
436
+ // Detail sub-line only for genuine signals (⚠ or ✗). ✓ and "-" are noise.
437
+ if (isWarn) {
438
+ process.stdout.write(` ${dim('└─ Platform-curated content not yet published (TEN-2019).')}\n`);
439
+ }
440
+ else if (r.status === 'failed') {
441
+ const cleaned = r.detail.replace(new RegExp(`^${r.slug} assertion failed:\\s*`), '');
442
+ process.stdout.write(` ${dim(`└─ ${cleaned}`)}\n`);
443
+ }
444
+ };
445
+ if (platformRows.length > 0) {
446
+ process.stdout.write(`${bold('Seeded on workspace creation')}\n`);
447
+ process.stdout.write(`${dim('Runs automatically when a new workspace is created.')}\n\n`);
448
+ for (const r of platformRows)
449
+ renderRow(r);
450
+ process.stdout.write('\n');
451
+ }
452
+ if (workspaceRows.length > 0) {
453
+ process.stdout.write(`${bold('Owner-level defaults')}\n`);
454
+ process.stdout.write(`${dim('Per-workspace state seeded for the owner.')}\n\n`);
455
+ for (const r of workspaceRows)
456
+ renderRow(r);
457
+ process.stdout.write('\n');
458
+ }
459
+ if (repairRows.length > 0) {
460
+ process.stdout.write(`${bold('Repair commands (manual)')}\n`);
461
+ process.stdout.write(`${dim('Used to fix older or drifted workspaces. Usually nothing to do.')}\n\n`);
462
+ for (const r of repairRows)
463
+ renderRow(r);
464
+ }
465
+ return;
466
+ }
467
+ if (mode === 'op-filter') {
468
+ const slug = report.slug;
469
+ const rows = report.rows ?? [];
470
+ process.stdout.write(`${bold(`Op: ${slug}`)} ${dim(`(${rows.length} workspace${rows.length === 1 ? '' : 's'})`)}\n\n`);
471
+ if (rows.length === 0) {
472
+ process.stdout.write(`${dim('Op not found in registry, or no workspaces exist.')}\n`);
473
+ return;
474
+ }
475
+ for (const r of rows) {
476
+ const icon = r.status === 'passed' ? green(icons.pass)
477
+ : r.status === 'failed' ? red(icons.fail)
478
+ : dim('-');
479
+ const detail = r.detail ? ` ${dim(r.detail)}` : '';
480
+ process.stdout.write(` ${icon} ${cyan(`workspace-${r.workspaceId}`)} (${bold(r.workspaceName)})${detail}\n`);
481
+ }
482
+ return;
483
+ }
484
+ process.stdout.write(`${dim('Unknown report mode.')}\n`);
485
+ }
486
+ /** Attach seed subcommands to the `seed` Commander node. */
487
+ export function attachSeedCommands(seed) {
488
+ // Default action when `pb admin seed` is invoked with no subcommand.
489
+ seed.action(async () => {
490
+ if (isJsonMode()) {
491
+ process.stdout.write(JSON.stringify({
492
+ operations: ALL_SEED_COMMAND_ENTRIES.map((e) => ({
493
+ name: shortLabel(e.name),
494
+ requiresWorkspaceId: e.requiresWorkspaceId,
495
+ dryRunSupported: e.dryRunSupported,
496
+ description: e.description,
497
+ })),
498
+ }, null, 2) + '\n');
499
+ return;
500
+ }
501
+ let siteUrl = '';
502
+ try {
503
+ siteUrl = resolveAdminConfig().siteUrl;
504
+ }
505
+ catch { /* not configured */ }
506
+ if (siteUrl)
507
+ adminBanner(siteUrl);
508
+ if (isInteractive()) {
509
+ intro('Seed Operations');
510
+ const menuEntries = ALL_SEED_COMMAND_ENTRIES;
511
+ const selected = await multiselect({
512
+ message: 'Select operations to run (space to toggle, enter to confirm):',
513
+ options: menuEntries.map((e) => ({
514
+ value: e.name,
515
+ label: shortLabel(e.name),
516
+ hint: [
517
+ e.requiresWorkspaceId ? 'needs workspace' : 'platform-wide',
518
+ e.dryRunSupported ? 'dry-run ✓' : '',
519
+ ].filter(Boolean).join(' · '),
520
+ })),
521
+ required: false,
522
+ });
523
+ if (!Array.isArray(selected) || selected.length === 0) {
524
+ outro('Nothing selected — use pb admin seed run <name> for individual operations');
525
+ return;
526
+ }
527
+ // Resolve workspace-id upfront for any selected ops that need it
528
+ const needsWs = selected.some((name) => SEED_BY_NAME.get(name)?.requiresWorkspaceId);
529
+ let workspaceId;
530
+ if (needsWs) {
531
+ const sessionWsId = readSession()?.workspaceId;
532
+ if (sessionWsId) {
533
+ workspaceId = sessionWsId;
534
+ log.info(`Using session workspace: ${dim(sessionWsId)}`);
535
+ }
536
+ else {
537
+ workspaceId = await ask({
538
+ message: 'Workspace ID (required for selected operations):',
539
+ validate: (v) => v.trim() ? undefined : 'Workspace ID is required',
540
+ });
541
+ }
542
+ }
543
+ const needsConfirm = requiresAdminDestructiveConfirmation(siteUrl);
544
+ if (needsConfirm) {
545
+ const ok = await confirm({
546
+ message: seedMultiselectConfirmMessage(siteUrl, selected.length),
547
+ initialValue: false,
548
+ });
549
+ if (!ok) {
550
+ outro('Cancelled');
551
+ return;
552
+ }
553
+ }
554
+ // Run selected operations in order, stop on first failure (same policy as seed all)
555
+ const results = [];
556
+ for (const name of selected) {
557
+ try {
558
+ await withSpinner(`Running ${shortLabel(name)}`, async () => {
559
+ const args = buildSeedArgs(name, { workspaceId });
560
+ await adminCall(toBackendCommand(name), args);
561
+ });
562
+ results.push({ name, ok: true });
563
+ }
564
+ catch (e) {
565
+ const msg = e instanceof Error ? e.message : String(e);
566
+ results.push({ name, ok: false, error: msg });
567
+ break;
568
+ }
569
+ }
570
+ const passed = results.filter((r) => r.ok).length;
571
+ const failed = results.filter((r) => !r.ok).length;
572
+ const summaryLines = results
573
+ .map((r) => r.ok ? `✓ ${shortLabel(r.name)}` : `✗ ${shortLabel(r.name)} — ${r.error}`)
574
+ .join('\n');
575
+ note(summaryLines, `${passed}/${selected.length} complete`);
576
+ if (failed > 0) {
577
+ process.exitCode = 1;
578
+ outro('Some operations failed — see above');
579
+ }
580
+ else {
581
+ outro(`${passed} operation(s) complete`);
582
+ }
583
+ return;
584
+ }
585
+ // Non-interactive (non-JSON) fallback — existing static preview
586
+ process.stdout.write(`${heading('Seed operations')} ${dim(`(${ALL_SEED_COMMAND_ENTRIES.length})`)}\n\n`);
587
+ // Show first 6 entries as a preview
588
+ const preview = ALL_SEED_COMMAND_ENTRIES.slice(0, 6);
589
+ const wName = Math.max(...preview.map((e) => shortLabel(e.name).length));
590
+ for (const e of preview) {
591
+ const label = shortLabel(e.name);
592
+ const flags = e.dryRunSupported ? dim(' dry-run ✓') : '';
593
+ process.stdout.write(` ${cyan(label.padEnd(wName))} ${dim(e.description)}${flags}\n`);
594
+ }
595
+ if (ALL_SEED_COMMAND_ENTRIES.length > 6) {
596
+ process.stdout.write(` ${dim(`... ${ALL_SEED_COMMAND_ENTRIES.length - 6} more — run pb admin seed list`)}\n`);
597
+ }
598
+ process.stdout.write('\n');
599
+ process.stdout.write(` ${cyan('pb admin seed list')} ${dim('Full list with workspace + dry-run flags')}\n`);
600
+ process.stdout.write(` ${cyan('pb admin seed run <name>')} ${dim('Run one operation')}\n`);
601
+ process.stdout.write(` ${cyan('pb admin seed all')} ${dim('Run all in manifest order')}\n`);
602
+ process.stdout.write(` ${cyan('pb admin seed status')} ${dim('Fleet-wide seed health (system admin)')}\n`);
603
+ process.stdout.write('\n');
604
+ });
605
+ seed
606
+ .command('list')
607
+ .description('List registered seed operations (names match server manifest)')
608
+ .action(() => {
609
+ printSeedList();
610
+ });
611
+ // WP-433 S1b D16 — fleet-wide seed status (system-admin command).
612
+ // Default behaviour: scan ALL workspaces in the deployment and report summary + failures.
613
+ // `--workspace-id <id>` drilldown flag triages a single workspace.
614
+ // `--op <slug>` fleet view filtered to one op.
615
+ // `--failed-only` fleet view skipping healthy workspaces.
616
+ // `--legacy-readiness` falls back to the pre-S1b workspace-readiness signals view.
617
+ seed
618
+ .command('status')
619
+ .description('WP-433 S1b D16: Fleet-wide seed health (system admin). Default scans ALL workspaces. ' +
620
+ 'Use --workspace-id to drill down, --op to filter one op, --failed-only for failures only.')
621
+ .option('--workspace-id <id>', 'Drill down to one workspace (operator triage)')
622
+ .option('--op <slug>', 'Filter fleet view to one op slug')
623
+ .option('--failed-only', 'Skip healthy workspaces; show failures only', false)
624
+ .option('--legacy-readiness', 'Use pre-S1b workspace readiness signals view', false)
625
+ .action(async (options) => {
626
+ if (options.legacyReadiness) {
627
+ if (!isJsonMode()) {
628
+ try {
629
+ adminBanner(resolveAdminConfig().siteUrl);
630
+ }
631
+ catch { /* not configured */ }
632
+ intro('Seed: status (legacy readiness)');
633
+ }
634
+ await printSeedStatus(options.workspaceId);
635
+ if (!isJsonMode()) {
636
+ outro('Read-only status check complete');
637
+ }
638
+ return;
639
+ }
640
+ if (!isJsonMode()) {
641
+ try {
642
+ adminBanner(resolveAdminConfig().siteUrl);
643
+ }
644
+ catch { /* not configured */ }
645
+ intro('Seed status — system / fleet view');
646
+ }
647
+ const callArgs = {};
648
+ if (options.workspaceId)
649
+ callArgs.workspaceId = options.workspaceId;
650
+ if (options.op)
651
+ callArgs.opSlug = options.op;
652
+ if (options.failedOnly)
653
+ callArgs.failedOnly = true;
654
+ const data = await withSpinner('Scanning the system', () => adminCall('admin:seed-status', callArgs));
655
+ if (isJsonMode()) {
656
+ process.stdout.write(JSON.stringify(data, null, 2) + '\n');
657
+ return;
658
+ }
659
+ renderSeedStatusReport(data);
660
+ outro('Done');
661
+ });
662
+ seed
663
+ .command('run')
664
+ .description('Run one seed operation by short or full manifest name')
665
+ .argument('<name>', 'e.g. knowledge or seed:knowledge')
666
+ .option('--dry-run', 'Pass dryRun when supported', false)
667
+ .option('--workspace-id <id>', 'Workspace id for workspace-scoped seeds')
668
+ .option('--confirm', 'Non-interactive prod acknowledgment for dangerous ops', false)
669
+ .action(async (name, options) => {
670
+ const { siteUrl } = resolveAdminConfig();
671
+ const manifestName = normalizeSeedCommandName(name);
672
+ const needsConfirm = requiresAdminDestructiveConfirmation(siteUrl);
673
+ // Remote / prod deployments require confirmation — not local or known dev-cloud.
674
+ if (needsConfirm) {
675
+ const ok = await confirmProdAction({
676
+ confirm: options.confirm,
677
+ isProduction: true,
678
+ message: seedRunConfirmMessage(siteUrl, manifestName),
679
+ noteTitle: confirmRiskNoteTitle(siteUrl),
680
+ });
681
+ if (!ok) {
682
+ process.stderr.write('Cancelled.\n');
683
+ process.exitCode = 1;
684
+ return;
685
+ }
686
+ }
687
+ if (!isJsonMode()) {
688
+ adminBanner(siteUrl);
689
+ intro(`seed:${shortLabel(manifestName)}`);
690
+ }
691
+ const data = await withSpinner(`Running ${manifestName}`, () => runSeedOperation(manifestName, {
692
+ workspaceId: options.workspaceId,
693
+ dryRun: options.dryRun,
694
+ }));
695
+ if (isJsonMode()) {
696
+ process.stdout.write(JSON.stringify({ command: manifestName, data }, null, 2) + '\n');
697
+ return;
698
+ }
699
+ const summaryLines = data && typeof data === 'object'
700
+ ? Object.entries(data)
701
+ .map(([k, v]) => `${k}: ${typeof v === 'object' ? JSON.stringify(v) : String(v)}`)
702
+ .slice(0, 8)
703
+ .join('\n')
704
+ : String(data ?? 'No response data');
705
+ note(summaryLines || 'No response data', manifestName);
706
+ outro('Complete');
707
+ });
708
+ // ─── WP-379 S5a: Starter Setup subcommands ─────────────────────────────────
709
+ seed
710
+ .command('show-starter')
711
+ .description('List 18 Starter Setup assets for a workspace with body previews, lockLevel, and gate summary')
712
+ .option('--workspace-id <id>', 'Workspace id (required; defaults to session workspace when set)')
713
+ .action(async (options) => {
714
+ const wsId = requireWorkspaceId(options.workspaceId);
715
+ const { siteUrl } = resolveAdminConfig();
716
+ if (!isJsonMode()) {
717
+ adminBanner(siteUrl);
718
+ intro('seed:show-starter');
719
+ }
720
+ const data = await withSpinner('Fetching starter assets', () => adminCall('seed:show-starter', { workspaceId: wsId }));
721
+ if (isJsonMode()) {
722
+ process.stdout.write(JSON.stringify(data, null, 2) + '\n');
723
+ return;
724
+ }
725
+ const assets = Array.isArray(data?.assets) ? data.assets : [];
726
+ if (assets.length === 0) {
727
+ note('No platform-seeded assets found. Run: pb admin seed run backfill-starter', 'show-starter');
728
+ outro('Done');
729
+ return;
730
+ }
731
+ const wIdx = assets.length.toString().length + 2;
732
+ const wId = Math.max(10, ...assets.map((a) => a.entryId.length));
733
+ const wLock = 10;
734
+ const wGate = 24;
735
+ process.stdout.write(`${bold(`${'#'.padEnd(wIdx)}${' '}${'Entry ID'.padEnd(wId)} ${'Lock'.padEnd(wLock)} ${'Gate'.padEnd(wGate)} Name / Preview`)}\n`);
736
+ process.stdout.write(dim('─'.repeat(wIdx + wId + wLock + wGate + 40)) + '\n');
737
+ assets.forEach((asset, i) => {
738
+ const idx = `${i + 1}.`.padEnd(wIdx);
739
+ const entryId = cyan(asset.entryId.padEnd(wId));
740
+ const lock = dim((asset.lockLevel ?? '—').padEnd(wLock));
741
+ const gateStr = asset.gate
742
+ ? asset.gate.kind === 'always'
743
+ ? 'always'
744
+ : `readiness[${asset.gate.min ?? '0'}–${asset.gate.max ?? '100'}]`
745
+ : '—';
746
+ const gate = dim(gateStr.padEnd(wGate));
747
+ const preview = dim(asset.bodyPreview.slice(0, 60));
748
+ process.stdout.write(`${idx} ${entryId} ${lock} ${gate} ${bold(asset.name)} ${preview}\n`);
749
+ });
750
+ process.stdout.write('\n');
751
+ note(`${assets.length} / 18 starter assets seeded`, 'show-starter');
752
+ outro('Done');
753
+ });
754
+ seed
755
+ .command('backfill-starter')
756
+ .description('Idempotent bulk seed of Starter Setup bundle across workspaces (dry-run by default)')
757
+ .option('--all', 'Required: acknowledge you intend to act on all workspaces in scope', false)
758
+ .option('--dry-run', 'Preview what would be seeded without writing anything (default behavior)', false)
759
+ .option('--workspace-scope <scope>', 'Required when --confirm is passed: dev | prod | all')
760
+ .option('--confirm', 'Execute seeds (requires --all and --workspace-scope)', false)
761
+ .action(async (options) => {
762
+ const { siteUrl } = resolveAdminConfig();
763
+ // CLI-side guard: --confirm requires --all
764
+ if (options.confirm && !options.all) {
765
+ process.stderr.write(red('Error: --confirm requires --all. Pass --all to acknowledge you intend to act on all workspaces in scope.\n'));
766
+ process.exitCode = 1;
767
+ return;
768
+ }
769
+ // Validate args and enforce scope gate via shared helper (also used by tests)
770
+ let callArgs;
771
+ try {
772
+ callArgs = buildBackfillStarterArgs({
773
+ confirm: options.confirm,
774
+ dryRun: options.dryRun,
775
+ workspaceScope: options.workspaceScope,
776
+ });
777
+ }
778
+ catch (e) {
779
+ process.stderr.write(red(`Error: ${e instanceof Error ? e.message : String(e)}\n`));
780
+ process.exitCode = 1;
781
+ return;
782
+ }
783
+ const isConfirm = options.confirm;
784
+ const isDryRun = callArgs.dryRun;
785
+ // Production acknowledgment for destructive confirm path
786
+ const needsConfirm = requiresAdminDestructiveConfirmation(siteUrl);
787
+ if (isConfirm && needsConfirm) {
788
+ const ok = await confirmProdAction({
789
+ confirm: options.confirm,
790
+ isProduction: true,
791
+ message: `Seed Starter Setup across ALL workspaces (scope: ${options.workspaceScope ?? 'all'}) on ${siteUrl}`,
792
+ noteTitle: confirmRiskNoteTitle(siteUrl),
793
+ });
794
+ if (!ok) {
795
+ process.stderr.write('Cancelled.\n');
796
+ process.exitCode = 1;
797
+ return;
798
+ }
799
+ }
800
+ if (!isJsonMode()) {
801
+ adminBanner(siteUrl);
802
+ intro(`seed:backfill-starter (${isDryRun ? 'DRY RUN' : 'EXECUTE'})`);
803
+ }
804
+ const result = await withSpinner(isDryRun ? 'Running dry-run scan' : 'Seeding workspaces', () => adminCall('seed:backfill-starter', callArgs));
805
+ if (isJsonMode()) {
806
+ process.stdout.write(JSON.stringify(result, null, 2) + '\n');
807
+ return;
808
+ }
809
+ // Per-workspace progress
810
+ const rows = Array.isArray(result?.rows) ? result.rows : [];
811
+ for (const row of rows) {
812
+ const statusIcon = row.status === 'seeded' ? green(icons.pass) :
813
+ row.status === 'already-seeded' ? dim(icons.dot) :
814
+ row.status === 'errored' ? red(icons.fail) :
815
+ dim(icons.dot);
816
+ const detail = row.detail ? dim(` ${row.detail}`) : '';
817
+ process.stdout.write(` ${statusIcon} ${bold(row.workspaceName)}${detail}\n`);
818
+ }
819
+ // Summary
820
+ const summaryLines = [
821
+ `Total workspaces: ${result.totalWorkspaces}`,
822
+ result.seededCount > 0 ? `${green(icons.pass)} Seeded: ${result.seededCount}` : null,
823
+ result.alreadySeededCount > 0 ? `${dim(icons.dot)} Already seeded: ${result.alreadySeededCount}` : null,
824
+ result.skippedCount > 0 ? `${dim(icons.dot)} Skipped (dry-run): ${result.skippedCount}` : null,
825
+ `Scope: ${result.workspaceScope}`,
826
+ result.dryRun ? dim('(dry-run — no writes performed)') : green('(writes executed)'),
827
+ ].filter(Boolean).join('\n');
828
+ note(summaryLines, 'backfill-starter');
829
+ outro('Done');
830
+ });
831
+ seed
832
+ .command('migrate-starter-fields')
833
+ .description('STUB (WP-379 S5b): backfill explicit lockLevel + gate columns on existing setup-assets entries')
834
+ .option('--workspace-id <id>', 'Workspace id (required; defaults to session workspace when set)')
835
+ .option('--dry-run', 'Preview changes without writing (default in stub)', false)
836
+ .action(async (options) => {
837
+ const wsId = requireWorkspaceId(options.workspaceId);
838
+ const { siteUrl } = resolveAdminConfig();
839
+ if (!isJsonMode()) {
840
+ adminBanner(siteUrl);
841
+ intro('seed:migrate-starter-fields');
842
+ }
843
+ const result = await withSpinner('Calling migrate-starter-fields', () => adminCall('seed:migrate-starter-fields', { workspaceId: wsId, dryRun: options.dryRun }));
844
+ if (isJsonMode()) {
845
+ process.stdout.write(JSON.stringify({ command: 'seed:migrate-starter-fields', data: result }, null, 2) + '\n');
846
+ return;
847
+ }
848
+ const summaryLines = [
849
+ `Migrated: ${result.migrated}`,
850
+ `Skipped: ${result.skipped}`,
851
+ `Dry-run: ${result.dryRun}`,
852
+ result.note ? dim(result.note) : null,
853
+ ].filter(Boolean).join('\n');
854
+ note(summaryLines, 'migrate-starter-fields');
855
+ outro('Done');
856
+ });
857
+ // ─── End WP-379 S5a Starter Setup subcommands ───────────────────────────────
858
+ seed
859
+ .command('all')
860
+ .description('Run all seed operations in manifest order')
861
+ .option('--workspace-id <id>', 'Workspace id for workspace-scoped seeds')
862
+ .option('--dry-run', 'Pass dryRun to operations that support it', false)
863
+ .option('--confirm', 'Required in production (non-interactive)', false)
864
+ .action(async (options) => {
865
+ const { siteUrl } = resolveAdminConfig();
866
+ const needsConfirm = requiresAdminDestructiveConfirmation(siteUrl);
867
+ if (needsConfirm) {
868
+ const ok = await confirmProdAction({
869
+ confirm: options.confirm,
870
+ isProduction: true,
871
+ message: seedAllConfirmMessage(siteUrl),
872
+ noteTitle: confirmRiskNoteTitle(siteUrl),
873
+ });
874
+ if (!ok) {
875
+ process.stderr.write('Cancelled.\n');
876
+ process.exitCode = 1;
877
+ return;
878
+ }
879
+ }
880
+ const results = [];
881
+ // ── JSON mode: silent execution, structured output ────────────────────
882
+ if (isJsonMode()) {
883
+ for (const cmd of SEED_MANIFEST_ORDER) {
884
+ try {
885
+ const args = buildSeedArgs(cmd, { workspaceId: options.workspaceId, dryRun: options.dryRun });
886
+ await adminCall(toBackendCommand(cmd), args);
887
+ results.push({ command: cmd, ok: true });
888
+ }
889
+ catch (e) {
890
+ const msg = e instanceof Error ? e.message : String(e);
891
+ results.push({ command: cmd, ok: false, error: msg });
892
+ break;
893
+ }
894
+ }
895
+ if (results.some((r) => !r.ok))
896
+ process.exitCode = 1;
897
+ process.stdout.write(JSON.stringify({ results }, null, 2) + '\n');
898
+ return;
899
+ }
900
+ // ── Human mode: spinner per operation + finale summary panel ─────────
901
+ adminBanner(siteUrl);
902
+ intro('Seed All Operations');
903
+ const total = SEED_MANIFEST_ORDER.length;
904
+ let current = 0;
905
+ const startMs = Date.now();
906
+ const s = clack.spinner();
907
+ for (const cmd of SEED_MANIFEST_ORDER) {
908
+ current++;
909
+ const label = shortLabel(cmd);
910
+ s.start(`${current}/${total} ${label}`);
911
+ try {
912
+ const args = buildSeedArgs(cmd, { workspaceId: options.workspaceId, dryRun: options.dryRun });
913
+ await adminCall(toBackendCommand(cmd), args);
914
+ s.stop(`${green(icons.pass)} ${label}`);
915
+ results.push({ command: cmd, ok: true });
916
+ }
917
+ catch (e) {
918
+ const msg = e instanceof Error ? e.message : String(e);
919
+ s.stop(`${red(icons.fail)} ${label} — ${msg}`);
920
+ results.push({ command: cmd, ok: false, error: msg });
921
+ break;
922
+ }
923
+ }
924
+ const elapsed = ((Date.now() - startMs) / 1000).toFixed(1);
925
+ const passed = results.filter((r) => r.ok && !r.skipped).length;
926
+ const skippedCount = results.filter((r) => r.skipped).length;
927
+ const failed = results.filter((r) => !r.ok).length;
928
+ const summaryLines = [
929
+ `${green(icons.pass)} ${passed} succeeded`,
930
+ skippedCount > 0 ? `${dim(icons.dot)} ${skippedCount} skipped` : null,
931
+ failed > 0 ? `${red(icons.fail)} ${failed} failed` : null,
932
+ `${dim(`elapsed: ${elapsed}s`)}`,
933
+ ].filter(Boolean).join('\n');
934
+ note(summaryLines, `${passed + skippedCount}/${total} complete`);
935
+ if (failed > 0) {
936
+ process.exitCode = 1;
937
+ outro('Some operations failed — fix errors and re-run affected seeds individually');
938
+ }
939
+ else {
940
+ outro(`All ${passed} operations complete in ${elapsed}s`);
941
+ }
942
+ });
943
+ }
944
+ //# sourceMappingURL=seed.js.map