@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
@@ -1,21 +1,420 @@
1
1
  /**
2
2
  * CLI config — reads PRODUCTBRAIN_API_KEY + CONVEX_SITE_URL from:
3
- * 1. Environment variables
4
- * 2. ~/.config/productbrain/.env (works from any directory)
5
- * 3. CWD .env.mcp / packages/mcp-server/.env.mcp / .env
3
+ * 1. Environment variables (always highest priority)
4
+ * 2. Project local config: .productbrain/config.local.json (walked up from CWD, machine-local)
5
+ * 3. Project config: .productbrain/config.json (walked up from CWD, siteUrl only — committed)
6
+ * 4. Profile system (~/.config/productbrain/profiles/{name}.env)
7
+ * 5. Legacy ~/.config/productbrain/.env (auto-migrated to profiles on first use)
8
+ * 6. CWD .env.mcp / packages/mcp-server/.env.mcp / .env
9
+ *
10
+ * Config loading is lazy — loadEnv() runs on first getConfig()/getConfigOrGuide() call.
11
+ * This enables profile switching without import-time side effects (TEN-1276).
6
12
  *
7
13
  * When key is missing and retry is provided (TTY), runs guided flow per docs/cli-unauthenticated-user-journey.md.
14
+ *
15
+ * Split config design:
16
+ * - config.json (committed): siteUrl only — workspace gateway, safe to share with teammates.
17
+ * - config.local.json (gitignored): profile pin — machine-local, never committed.
8
18
  */
9
19
  import { readFileSync, existsSync, mkdirSync, writeFileSync } from 'fs';
10
20
  import { resolve } from 'path';
11
21
  import { homedir } from 'os';
12
- import { createInterface } from 'readline';
13
- const DEFAULT_SITE_URL = 'https://trustworthy-kangaroo-277.convex.site';
22
+ import { DEFAULT_SITE_URL, isDevMode } from './constants.js';
23
+ import { API_KEY_PREFIX } from './tokenConstants.js';
24
+ import { resolveProfileConfig, resolveNamedProfileConfig, getGlobalActiveProfile } from './profiles.js';
25
+ import { CLIError, ErrorCode } from './errors.js';
26
+ import { confirm as promptConfirm, password as promptPassword } from './prompts.js';
14
27
  const HOME_CONFIG_DIR = resolve(homedir(), '.config', 'productbrain');
15
28
  const HOME_ENV_PATH = resolve(HOME_CONFIG_DIR, '.env');
16
29
  const CWD_ENV_PATHS = ['.env.mcp', 'packages/mcp-server/.env.mcp', '.env'];
17
30
  // Short error when not TTY (scripts/pipes must not hang)
18
31
  const NON_TTY_MESSAGE = 'No API key. Set PRODUCTBRAIN_API_KEY or run pb login.';
32
+ /** Track whether env has been loaded to avoid redundant file reads. */
33
+ let envLoaded = false;
34
+ /**
35
+ * Walk up the directory tree (git-style) to find the nearest CLI project root.
36
+ *
37
+ * A `.productbrain/` directory only counts as a CLI project root when it carries
38
+ * CLI configuration — `config.json` (committed siteUrl gateway) or
39
+ * `config.local.json` (machine-local profile pin or preview binding). A
40
+ * projection-only `.productbrain/` written by `pb handshake` (briefing.md,
41
+ * context.md, rules/, etc.) does NOT count — otherwise a subrepo like
42
+ * `packages/cli/.productbrain/` would shadow the real configuring root and
43
+ * `npm run pb:preview` writes (which always land at the repo-root
44
+ * `.productbrain/`) would be invisible to commands run from the subrepo.
45
+ *
46
+ * Stops at home directory or filesystem root. Returns the directory containing
47
+ * a config-bearing `.productbrain/`, or null if not found.
48
+ */
49
+ export function findProjectRoot(startDir) {
50
+ let dir = startDir;
51
+ const home = homedir();
52
+ while (true) {
53
+ const pbDir = resolve(dir, '.productbrain');
54
+ if (existsSync(pbDir) &&
55
+ (existsSync(resolve(pbDir, 'config.json')) ||
56
+ existsSync(resolve(pbDir, 'config.local.json')))) {
57
+ return dir;
58
+ }
59
+ const parent = resolve(dir, '..');
60
+ if (parent === dir || dir === home)
61
+ return null;
62
+ dir = parent;
63
+ }
64
+ }
65
+ /**
66
+ * Read .productbrain/config.json from the walked-up project root.
67
+ * Only reads siteUrl — profile and apiKey fields are ignored (legacy or misplaced).
68
+ * Returns null if file missing or project root not found.
69
+ * Warns to stderr on invalid JSON but does not throw.
70
+ */
71
+ function readProjectConfig() {
72
+ const projectRoot = findProjectRoot(process.cwd());
73
+ if (!projectRoot)
74
+ return null;
75
+ const configPath = resolve(projectRoot, '.productbrain', 'config.json');
76
+ if (!existsSync(configPath))
77
+ return null;
78
+ try {
79
+ const raw = readFileSync(configPath, 'utf8');
80
+ const parsed = JSON.parse(raw);
81
+ if (typeof parsed !== 'object' || parsed === null || Array.isArray(parsed)) {
82
+ process.stderr.write('Warning: .productbrain/config.json is not a JSON object, skipping.\n');
83
+ return null;
84
+ }
85
+ const result = {};
86
+ if (typeof parsed.siteUrl === 'string' && parsed.siteUrl) {
87
+ result.siteUrl = parsed.siteUrl;
88
+ }
89
+ // Silently ignore `profile` and `apiKey` in config.json — those must be in config.local.json
90
+ return result;
91
+ }
92
+ catch {
93
+ process.stderr.write('Warning: .productbrain/config.json contains invalid JSON, skipping.\n');
94
+ return null;
95
+ }
96
+ }
97
+ /**
98
+ * Read .productbrain/config.local.json from the walked-up project root.
99
+ * Returns the machine-local pin (`profile`) and any preview-binding fields
100
+ * (`apiKey`, `siteUrl`, `preview`, `workspaceName`) written by
101
+ * `npm run pb:preview` — all gitignored, never committed.
102
+ * Returns null if file missing or project root not found.
103
+ * Warns to stderr on invalid JSON but does not throw.
104
+ */
105
+ export function readLocalProjectConfig() {
106
+ const projectRoot = findProjectRoot(process.cwd());
107
+ if (!projectRoot)
108
+ return null;
109
+ const configPath = resolve(projectRoot, '.productbrain', 'config.local.json');
110
+ if (!existsSync(configPath))
111
+ return null;
112
+ try {
113
+ const raw = readFileSync(configPath, 'utf8');
114
+ const parsed = JSON.parse(raw);
115
+ if (typeof parsed !== 'object' || parsed === null || Array.isArray(parsed)) {
116
+ process.stderr.write('Warning: .productbrain/config.local.json is not a JSON object, skipping.\n');
117
+ return null;
118
+ }
119
+ const result = {};
120
+ if (typeof parsed.profile === 'string' && parsed.profile) {
121
+ result.profile = parsed.profile;
122
+ }
123
+ // Preview binding fields — written by `npm run pb:preview`, cleared by `npm run pb:real`.
124
+ if (typeof parsed.apiKey === 'string' && parsed.apiKey.startsWith(API_KEY_PREFIX)) {
125
+ result.apiKey = parsed.apiKey;
126
+ }
127
+ if (typeof parsed.siteUrl === 'string' && parsed.siteUrl) {
128
+ result.siteUrl = parsed.siteUrl;
129
+ }
130
+ if (parsed.preview === true) {
131
+ result.preview = true;
132
+ }
133
+ if (typeof parsed.workspaceName === 'string' && parsed.workspaceName) {
134
+ result.workspaceName = parsed.workspaceName;
135
+ }
136
+ return result;
137
+ }
138
+ catch {
139
+ process.stderr.write('Warning: .productbrain/config.local.json contains invalid JSON, skipping.\n');
140
+ return null;
141
+ }
142
+ }
143
+ /**
144
+ * Returns the preview binding metadata when pb is currently bound to a throwaway preview,
145
+ * or null when bound to the real Chain (the default).
146
+ *
147
+ * Effective-binding mirror: this only reports a preview binding when
148
+ * `resolveConfig()`/`loadEnv()` would actually honor it — `preview === true` AND
149
+ * an atomic apiKey+siteUrl pair (SF-3) AND no `PRODUCTBRAIN_API_KEY` env override
150
+ * (env always wins in resolveConfig step 1). Without these guards the PREVIEW
151
+ * banner could fire while writes still hit the real Chain, defeating the safety
152
+ * warning. Used by the PREVIEW banner (index.ts preAction hook) and the
153
+ * capture/update advisory.
154
+ *
155
+ * Security classification: reads only the gitignored machine-local config.local.json.
156
+ * The preview key in that file is a throwaway preview-scoped key, set by explicit
157
+ * `npm run pb:preview` opt-in and reversed by `npm run pb:real`. Never throws — returns
158
+ * null on any error so the banner/advisory path is never the source of a CLI crash.
159
+ */
160
+ export function getPreviewBinding() {
161
+ try {
162
+ if (process.env.PRODUCTBRAIN_API_KEY)
163
+ return null;
164
+ const localConfig = readLocalProjectConfig();
165
+ if (localConfig?.preview === true && localConfig.apiKey && localConfig.siteUrl) {
166
+ return { workspaceName: localConfig.workspaceName ?? null };
167
+ }
168
+ return null;
169
+ }
170
+ catch {
171
+ return null;
172
+ }
173
+ }
174
+ /**
175
+ * Write/merge the profile pin into <projectRoot>/.productbrain/config.local.json,
176
+ * preserving any sibling keys. Single source of truth for the local pin write —
177
+ * used by `pb profile use --local`, the default reconcile path, and `pb connect`.
178
+ *
179
+ * Co-writer note (SF-2): scripts/pb-binding.mjs is the OTHER writer of config.local.json — it
180
+ * merges/strips the preview-binding keys (apiKey, siteUrl, preview, workspaceName) for
181
+ * `npm run pb:preview` / `npm run pb:real`. Both writers preserve the `profile` pin. If you add
182
+ * a preview-scoped key here or in readLocalProjectConfig(), update pb-binding.mjs's PREVIEW_KEYS.
183
+ */
184
+ export function setLocalProfilePin(projectRoot, profile) {
185
+ const configDir = resolve(projectRoot, '.productbrain');
186
+ const localConfigPath = resolve(configDir, 'config.local.json');
187
+ let existing = {};
188
+ if (existsSync(localConfigPath)) {
189
+ try {
190
+ const parsed = JSON.parse(readFileSync(localConfigPath, 'utf8'));
191
+ if (parsed && typeof parsed === 'object' && !Array.isArray(parsed))
192
+ existing = parsed;
193
+ }
194
+ catch { /* ignore parse errors — we overwrite the pin below */ }
195
+ }
196
+ mkdirSync(configDir, { recursive: true });
197
+ writeFileSync(localConfigPath, JSON.stringify({ ...existing, profile }, null, 2) + '\n');
198
+ }
199
+ /**
200
+ * WP-458 E2 — one-shot preview apiKey refresh from disk.
201
+ *
202
+ * After a worktree preview is reseeded, seed-preview.mjs Step 6 mints a NEW apiKey into
203
+ * `.productbrain/preview.json`, but `config.local.json` (and the live `process.env` binding it
204
+ * seeded via loadEnv) still carry the PRE-reseed key — so the next `pb session start` fails auth
205
+ * with an opaque INTERNAL. This re-reads the fresh key from preview.json so the caller can retry
206
+ * ONCE (session.ts). It is deliberately disk-to-disk: it compares preview.json's key against
207
+ * config.local.json's bound key, NOT against process.env (which loadEnv already populated from the
208
+ * stale binding), so it can't be confused by its own prior population. Never throws — any error
209
+ * degrades to 'unavailable'/'not-bound' so it can sit on the session-start path.
210
+ *
211
+ * Co-writer note (SF-2): mirrors pb-binding.mjs / setLocalProfilePin — preserves every sibling key
212
+ * in config.local.json (profile, preview, workspaceName) and only rewrites apiKey + siteUrl.
213
+ */
214
+ export function refreshPreviewApiKeyFromDisk() {
215
+ try {
216
+ const projectRoot = findProjectRoot(process.cwd());
217
+ if (!projectRoot)
218
+ return 'not-bound';
219
+ const local = readLocalProjectConfig();
220
+ // Only act on a real preview binding (preview:true + atomic apiKey+siteUrl pair, SF-3).
221
+ if (!local?.preview || !local.apiKey || !local.siteUrl)
222
+ return 'not-bound';
223
+ // Never clobber a genuine env override: if the live key is NOT the bound preview key, either
224
+ // the user exported their own PRODUCTBRAIN_API_KEY (env wins in resolveConfig) or a refresh
225
+ // already happened — bail either way. An unset env key is fine (loadEnv may not have run yet).
226
+ const liveKey = process.env.PRODUCTBRAIN_API_KEY;
227
+ if (liveKey && liveKey !== local.apiKey)
228
+ return 'not-bound';
229
+ // Read the freshly-minted key from preview.json (seed-preview.mjs Step 6).
230
+ const previewPath = resolve(projectRoot, '.productbrain', 'preview.json');
231
+ if (!existsSync(previewPath))
232
+ return 'unavailable';
233
+ let fresh;
234
+ try {
235
+ const parsed = JSON.parse(readFileSync(previewPath, 'utf8'));
236
+ if (typeof parsed !== 'object' || parsed === null || Array.isArray(parsed))
237
+ return 'unavailable';
238
+ fresh = parsed;
239
+ }
240
+ catch {
241
+ return 'unavailable';
242
+ }
243
+ const freshKey = typeof fresh.apiKey === 'string' ? fresh.apiKey : '';
244
+ if (!freshKey.startsWith(API_KEY_PREFIX))
245
+ return 'unavailable';
246
+ // Same key as the one already bound — retrying would just fail again; the failure is not a
247
+ // stale key, so the caller surfaces the real error rather than relabelling it.
248
+ if (freshKey === local.apiKey)
249
+ return 'unchanged';
250
+ const freshSite = typeof fresh.siteUrl === 'string' && fresh.siteUrl ? fresh.siteUrl : local.siteUrl;
251
+ // Merge the fresh preview key into config.local.json, preserving siblings.
252
+ const localConfigPath = resolve(projectRoot, '.productbrain', 'config.local.json');
253
+ let existing = {};
254
+ if (existsSync(localConfigPath)) {
255
+ try {
256
+ const parsed = JSON.parse(readFileSync(localConfigPath, 'utf8'));
257
+ if (parsed && typeof parsed === 'object' && !Array.isArray(parsed))
258
+ existing = parsed;
259
+ }
260
+ catch { /* overwrite below */ }
261
+ }
262
+ writeFileSync(localConfigPath, JSON.stringify({ ...existing, apiKey: freshKey, siteUrl: freshSite }, null, 2) + '\n');
263
+ // Update the live binding + drop the load cache so the next getConfig() uses the fresh key.
264
+ process.env.PRODUCTBRAIN_API_KEY = freshKey;
265
+ process.env.CONVEX_SITE_URL = freshSite.replace(/\/$/, '');
266
+ resetConfigCache();
267
+ return 'refreshed';
268
+ }
269
+ catch {
270
+ return 'unavailable';
271
+ }
272
+ }
273
+ /**
274
+ * Resolve the effective profile NAME + where it came from. The SOURCE-PRECEDENCE
275
+ * ORDER matches resolveConfig() (env > local pin > global > default), but unlike
276
+ * resolveConfig() this reports the *configured* pin name even when that profile is
277
+ * unresolvable (deleted / missing key). That divergence is intentional: a dangling
278
+ * repo pin must be surfaced by `pb whoami`, not silently masked by the global
279
+ * profile — masking it is the TEN-2163 silent-drift bug. Used by `pb whoami` and
280
+ * the inline "now using" prints.
281
+ */
282
+ export function resolveEffectiveProfile() {
283
+ const envProfile = process.env.PB_PROFILE?.trim();
284
+ if (envProfile)
285
+ return { profile: envProfile, source: 'env' };
286
+ const localProfile = readLocalProjectConfig()?.profile;
287
+ if (localProfile)
288
+ return { profile: localProfile, source: 'local' };
289
+ const globalProfile = getGlobalActiveProfile();
290
+ if (globalProfile)
291
+ return { profile: globalProfile, source: 'global' };
292
+ if (resolveNamedProfileConfig('default'))
293
+ return { profile: 'default', source: 'default' };
294
+ return { profile: null, source: 'none' };
295
+ }
296
+ /**
297
+ * Run the full config resolution cascade and return a typed result.
298
+ * Resolution order:
299
+ * 1. Environment variables (highest priority)
300
+ * 2. config.local.json profile → resolveNamedProfileConfig(profile) for apiKey + siteUrl
301
+ * 2b. config.json siteUrl (gateway override only — no apiKey, no profile)
302
+ * 3. Profile system (~/.config/productbrain/profiles/{name}.env)
303
+ * 4. Legacy home config (~/.config/productbrain/.env)
304
+ * 5. CWD .env files (.env.mcp, packages/mcp-server/.env.mcp, .env)
305
+ *
306
+ * siteUrl always has a value (falls back to DEFAULT_SITE_URL).
307
+ */
308
+ export function resolveConfig() {
309
+ // 1. Env vars — check directly, don't mutate process.env
310
+ const envKey = process.env.PRODUCTBRAIN_API_KEY;
311
+ const envSite = process.env.CONVEX_SITE_URL;
312
+ if (envKey) {
313
+ return {
314
+ apiKey: envKey,
315
+ siteUrl: (envSite || DEFAULT_SITE_URL).replace(/\/$/, ''),
316
+ source: 'env',
317
+ };
318
+ }
319
+ // 2. Local project config — check for direct preview binding first, then profile pin.
320
+ const localConfig = readLocalProjectConfig();
321
+ // 2a. Direct preview binding (config.local.json apiKey) — set by `npm run pb:preview`.
322
+ // Security classification: gitignored machine-local file; throwaway preview-scoped key;
323
+ // explicit opt-in via `npm run pb:preview`; reversible via `npm run pb:real`;
324
+ // loud PREVIEW banner on every command makes it un-missable (index.ts preAction hook).
325
+ //
326
+ // Atomic apiKey+siteUrl (SF-3): only honor the preview key when its OWN siteUrl is present.
327
+ // Never let a preview key borrow config.json's (real-dev) siteUrl — that would send a
328
+ // preview credential to a non-preview gateway (STD-261). If siteUrl is absent we skip this
329
+ // branch and fall through to the profile pin / default, so it is impossible by construction
330
+ // for a `preview:true` key to be paired with the committed real-dev gateway.
331
+ if (localConfig?.apiKey && localConfig.siteUrl) {
332
+ return {
333
+ apiKey: localConfig.apiKey,
334
+ siteUrl: localConfig.siteUrl.replace(/\/$/, ''),
335
+ source: 'project',
336
+ };
337
+ }
338
+ // 2b. Profile pin (config.local.json profile field, gitignored)
339
+ if (localConfig?.profile) {
340
+ const namedConfig = resolveNamedProfileConfig(localConfig.profile);
341
+ if (namedConfig?.apiKey) {
342
+ // siteUrl: local.profile.siteUrl || config.json.siteUrl || env || default
343
+ const projectConfig = readProjectConfig();
344
+ return {
345
+ apiKey: namedConfig.apiKey,
346
+ siteUrl: (namedConfig.siteUrl || projectConfig?.siteUrl || envSite || DEFAULT_SITE_URL).replace(/\/$/, ''),
347
+ source: 'project',
348
+ };
349
+ }
350
+ }
351
+ // 2b. config.json — siteUrl gateway override only (no apiKey, no profile)
352
+ // Falls through; siteUrl from config.json is used as a tiebreaker below in step 3.
353
+ // 3. Profile system
354
+ const projectConfig = readProjectConfig();
355
+ const profileConfig = resolveProfileConfig();
356
+ if (profileConfig?.apiKey) {
357
+ return {
358
+ apiKey: profileConfig.apiKey,
359
+ siteUrl: (projectConfig?.siteUrl || profileConfig.siteUrl || envSite || DEFAULT_SITE_URL).replace(/\/$/, ''),
360
+ source: 'profile',
361
+ };
362
+ }
363
+ // 4. Legacy home config
364
+ if (existsSync(HOME_ENV_PATH)) {
365
+ const vars = parseEnvVars(readFileSync(HOME_ENV_PATH, 'utf8'));
366
+ if (vars['PRODUCTBRAIN_API_KEY']) {
367
+ return {
368
+ apiKey: vars['PRODUCTBRAIN_API_KEY'],
369
+ siteUrl: (projectConfig?.siteUrl || vars['CONVEX_SITE_URL'] || envSite || DEFAULT_SITE_URL).replace(/\/$/, ''),
370
+ source: 'profile',
371
+ };
372
+ }
373
+ }
374
+ // 5. CWD .env files
375
+ for (const p of CWD_ENV_PATHS) {
376
+ const full = resolve(process.cwd(), p);
377
+ if (existsSync(full)) {
378
+ const vars = parseEnvVars(readFileSync(full, 'utf8'));
379
+ if (vars['PRODUCTBRAIN_API_KEY']) {
380
+ return {
381
+ apiKey: vars['PRODUCTBRAIN_API_KEY'],
382
+ siteUrl: (projectConfig?.siteUrl || vars['CONVEX_SITE_URL'] || envSite || DEFAULT_SITE_URL).replace(/\/$/, ''),
383
+ source: 'cwd',
384
+ };
385
+ }
386
+ break;
387
+ }
388
+ }
389
+ // 6. No API key found anywhere — return with siteUrl default
390
+ const resolvedSiteUrl = (projectConfig?.siteUrl || envSite || DEFAULT_SITE_URL).replace(/\/$/, '');
391
+ // TEN-2382: the published CLI's prod default is intended (WP-301), so we do NOT
392
+ // warn on prod fall-through in general. The ONE exception is the preview-scrub
393
+ // misroute — a preview binding whose apiKey is present but whose siteUrl was
394
+ // scrubbed (the STD-261 atomic guard at step 2a dropped the key), now silently
395
+ // resolving to the production gateway. That single case is a real misroute.
396
+ if (localConfig?.apiKey && resolvedSiteUrl === DEFAULT_SITE_URL.replace(/\/$/, '')) {
397
+ process.stderr.write(`Warning: a preview API key is configured but its deployment URL is missing — ` +
398
+ `defaulting to the production gateway ${DEFAULT_SITE_URL}. Run ` +
399
+ `\`npm run pb:preview\` to rebind the preview, or set CONVEX_SITE_URL.\n`);
400
+ }
401
+ return {
402
+ apiKey: undefined,
403
+ siteUrl: resolvedSiteUrl,
404
+ source: 'default',
405
+ };
406
+ }
407
+ /** Parse env file content and return key-value pairs (without mutating process.env). */
408
+ function parseEnvVars(content) {
409
+ const vars = {};
410
+ for (const line of content.split('\n')) {
411
+ const m = line.match(/^([^#=]+)=(.*)$/);
412
+ if (m) {
413
+ vars[m[1].trim()] = m[2].trim().replace(/^["']|["']$/g, '');
414
+ }
415
+ }
416
+ return vars;
417
+ }
19
418
  function parseEnvContent(content) {
20
419
  for (const line of content.split('\n')) {
21
420
  const m = line.match(/^([^#=]+)=(.*)$/);
@@ -25,9 +424,55 @@ function parseEnvContent(content) {
25
424
  }
26
425
  }
27
426
  function loadEnv() {
427
+ if (envLoaded)
428
+ return;
429
+ envLoaded = true;
430
+ // 1. Try local project config first (preview binding or profile pin, config.local.json)
431
+ const localConfig = readLocalProjectConfig();
432
+ // 1a. Direct preview binding — set by `npm run pb:preview`, takes priority over profile pin.
433
+ // Atomic apiKey+siteUrl (SF-3): only bind the preview key when its OWN siteUrl is present —
434
+ // never let it fall through to config.json's (real-dev) siteUrl (STD-261). Mirror of the
435
+ // resolveConfig() 2a guard so loadEnv() and resolveConfig() agree on what counts as a binding.
436
+ if (localConfig?.apiKey && localConfig.siteUrl && !process.env.PRODUCTBRAIN_API_KEY) {
437
+ process.env.PRODUCTBRAIN_API_KEY = localConfig.apiKey;
438
+ // SF-3 atomic pair: when we accept the preview key, we MUST pair it with
439
+ // its OWN siteUrl — even if CONVEX_SITE_URL is already exported. Otherwise
440
+ // a stale/real exported CONVEX_SITE_URL would silently route the preview
441
+ // credential to a non-preview gateway. Mirror of resolveConfig() step 2a,
442
+ // which returns localConfig.siteUrl unconditionally inside this branch.
443
+ process.env.CONVEX_SITE_URL = localConfig.siteUrl.replace(/\/$/, '');
444
+ }
445
+ // 1b. Profile pin
446
+ if (localConfig?.profile && !process.env.PRODUCTBRAIN_API_KEY) {
447
+ const namedConfig = resolveNamedProfileConfig(localConfig.profile);
448
+ if (namedConfig?.apiKey) {
449
+ process.env.PRODUCTBRAIN_API_KEY = namedConfig.apiKey;
450
+ if (!process.env.CONVEX_SITE_URL && namedConfig.siteUrl) {
451
+ process.env.CONVEX_SITE_URL = namedConfig.siteUrl.replace(/\/$/, '');
452
+ }
453
+ }
454
+ }
455
+ // 1b. Apply siteUrl from config.json (gateway override — no apiKey reading here)
456
+ const projectConfig = readProjectConfig();
457
+ if (projectConfig?.siteUrl && !process.env.CONVEX_SITE_URL) {
458
+ process.env.CONVEX_SITE_URL = projectConfig.siteUrl.replace(/\/$/, '');
459
+ }
460
+ // 2. Try profile system (handles auto-migration from legacy .env)
461
+ const profileConfig = resolveProfileConfig();
462
+ if (profileConfig) {
463
+ // Only set if not already set by env vars or project config
464
+ if (!process.env.PRODUCTBRAIN_API_KEY) {
465
+ process.env.PRODUCTBRAIN_API_KEY = profileConfig.apiKey;
466
+ }
467
+ if (!process.env.CONVEX_SITE_URL && profileConfig.siteUrl) {
468
+ process.env.CONVEX_SITE_URL = profileConfig.siteUrl.replace(/\/$/, '');
469
+ }
470
+ }
471
+ // 3. Legacy home config (in case profiles didn't find it)
28
472
  if (existsSync(HOME_ENV_PATH)) {
29
473
  parseEnvContent(readFileSync(HOME_ENV_PATH, 'utf8'));
30
474
  }
475
+ // 4. CWD env files
31
476
  for (const p of CWD_ENV_PATHS) {
32
477
  const full = resolve(process.cwd(), p);
33
478
  if (existsSync(full)) {
@@ -36,49 +481,55 @@ function loadEnv() {
36
481
  }
37
482
  }
38
483
  }
39
- loadEnv();
40
- function question(rl, prompt) {
41
- return new Promise((resolve) => {
42
- rl.question(prompt, (answer) => resolve((answer ?? '').trim().toLowerCase()));
43
- });
44
- }
45
- function questionRaw(rl, prompt) {
46
- return new Promise((resolve) => {
47
- rl.question(prompt, (answer) => resolve((answer ?? '').trim()));
48
- });
484
+ /** Reset env loaded state — used for profile switching. */
485
+ export function resetConfigCache() {
486
+ envLoaded = false;
49
487
  }
50
488
  /**
51
489
  * Guided flow when key is missing (TTY only). Per docs/cli-unauthenticated-user-journey.md.
52
490
  * Returns true if we saved and ran retry; false if user said No (caller should exit).
53
491
  */
54
492
  async function runGuidedFlow(retry) {
55
- const rl = createInterface({ input: process.stdin, output: process.stdout });
56
- console.log('Do you have an API key from Product Brain? (y/n)');
57
- console.log(' Get one: Product Brain app → Settings → API Keys');
58
- const hasKey = await question(rl, '> ');
59
- if (hasKey !== 'y' && hasKey !== 'yes') {
493
+ const hasKey = await promptConfirm({
494
+ message: 'Do you have an API key from Product Brain?',
495
+ initialValue: false,
496
+ });
497
+ if (!hasKey) {
60
498
  console.log('Get your key: Product Brain app → Settings → API Keys. Then run: pb login');
61
- rl.close();
62
499
  process.exit(0);
63
500
  }
64
- let apiKey = await questionRaw(rl, 'Paste your API key (pb_sk_...): ');
65
- if (!apiKey || !apiKey.startsWith('pb_sk_')) {
66
- console.log('Key must start with pb_sk_. Try again or run pb login.');
67
- apiKey = await questionRaw(rl, 'Paste your API key (pb_sk_...): ');
501
+ let apiKey = await promptPassword({
502
+ message: `Paste your API key (${API_KEY_PREFIX}...)`,
503
+ validate: (v) => (!v ? 'Key is required' : undefined),
504
+ });
505
+ if (!apiKey.startsWith(API_KEY_PREFIX)) {
506
+ console.log(`Key must start with ${API_KEY_PREFIX}. Try again or run pb login.`);
507
+ apiKey = await promptPassword({
508
+ message: `Paste your API key (${API_KEY_PREFIX}...)`,
509
+ validate: (v) => (!v || !v.startsWith(API_KEY_PREFIX) ? `Key must start with ${API_KEY_PREFIX}` : undefined),
510
+ });
68
511
  }
69
- rl.close();
70
- if (!apiKey || !apiKey.startsWith('pb_sk_')) {
512
+ if (!apiKey || !apiKey.startsWith(API_KEY_PREFIX)) {
71
513
  console.log('Get your key: Product Brain app → Settings → API Keys. Then run: pb login');
72
514
  process.exit(0);
73
515
  }
74
- const content = [
75
- `# Product Brain CLI saved by guided setup`,
76
- `PRODUCTBRAIN_API_KEY=${apiKey}`,
77
- `CONVEX_SITE_URL=${DEFAULT_SITE_URL.replace(/\/$/, '')}`,
78
- '',
79
- ].join('\n');
80
- mkdirSync(HOME_CONFIG_DIR, { recursive: true });
81
- writeFileSync(HOME_ENV_PATH, content, { mode: 0o600 });
516
+ // Save as a named profile via the profile system
517
+ const { createProfile, getActiveProfile } = await import('./profiles.js');
518
+ const profileName = getActiveProfile() || 'default';
519
+ try {
520
+ createProfile(profileName, apiKey, DEFAULT_SITE_URL.replace(/\/$/, ''));
521
+ }
522
+ catch {
523
+ // Profile already exists fall back to legacy path
524
+ const content = [
525
+ `# Product Brain CLI — saved by guided setup`,
526
+ `PRODUCTBRAIN_API_KEY=${apiKey}`,
527
+ `CONVEX_SITE_URL=${DEFAULT_SITE_URL.replace(/\/$/, '')}`,
528
+ '',
529
+ ].join('\n');
530
+ mkdirSync(HOME_CONFIG_DIR, { recursive: true });
531
+ writeFileSync(HOME_ENV_PATH, content, { mode: 0o600 });
532
+ }
82
533
  process.env.PRODUCTBRAIN_API_KEY = apiKey;
83
534
  process.env.CONVEX_SITE_URL = DEFAULT_SITE_URL.replace(/\/$/, '');
84
535
  console.log('Saved your key. Running your command…\n');
@@ -86,32 +537,133 @@ async function runGuidedFlow(retry) {
86
537
  return true;
87
538
  }
88
539
  export function getConfig() {
540
+ loadEnv();
89
541
  const apiKey = process.env.PRODUCTBRAIN_API_KEY ?? '';
90
542
  const siteUrl = (process.env.CONVEX_SITE_URL ?? DEFAULT_SITE_URL).replace(/\/$/, '');
91
- if (!apiKey || !apiKey.startsWith('pb_sk_')) {
92
- throw new Error(NON_TTY_MESSAGE);
543
+ if (!apiKey || !apiKey.startsWith(API_KEY_PREFIX)) {
544
+ throw new CLIError(NON_TTY_MESSAGE, {
545
+ code: ErrorCode.AUTH_MISSING,
546
+ category: 'auth',
547
+ guidance: 'Set PRODUCTBRAIN_API_KEY or run `pb login`.',
548
+ });
93
549
  }
94
- if (!siteUrl.startsWith('https://')) {
95
- throw new Error(`CONVEX_SITE_URL must use HTTPS (got "${siteUrl.slice(0, 30)}…"). API keys must not be sent over unencrypted connections.`);
550
+ const allowHttp = isDevMode() && siteUrl.startsWith('http://localhost');
551
+ if (!siteUrl.startsWith('https://') && !allowHttp) {
552
+ throw new CLIError(`CONVEX_SITE_URL must use HTTPS (got "${siteUrl.slice(0, 30)}…"). API keys must not be sent over unencrypted connections.`, {
553
+ code: ErrorCode.CONFIG_INVALID,
554
+ category: 'config',
555
+ guidance: 'Set CONVEX_SITE_URL to an https:// URL.',
556
+ });
96
557
  }
97
558
  return { apiKey, siteUrl };
98
559
  }
560
+ /**
561
+ * Non-throwing alternative to getConfig().
562
+ *
563
+ * Architecture: getConfig() is the primary path for commands that require auth — it
564
+ * throws CLIError when the key is missing, which is correct for API call paths.
565
+ * getConfigSafe() is for status/probe surfaces (no-args dashboard, init) that need
566
+ * to check config availability without crashing. Both paths are intentional and
567
+ * coexist by design — see WP-303 review (DW#5).
568
+ *
569
+ * Uses resolveConfig() directly (no loadEnv) to avoid env var pollution affecting source attribution.
570
+ */
571
+ export function getConfigSafe() {
572
+ const resolved = resolveConfig();
573
+ if (!resolved.apiKey || !resolved.apiKey.startsWith(API_KEY_PREFIX)) {
574
+ return { ok: false, reason: 'No API key. Run pb login or set PRODUCTBRAIN_API_KEY.' };
575
+ }
576
+ const siteUrl = resolved.siteUrl;
577
+ const allowHttp = isDevMode() && siteUrl.startsWith('http://localhost');
578
+ if (!siteUrl.startsWith('https://') && !allowHttp) {
579
+ return {
580
+ ok: false,
581
+ reason: `CONVEX_SITE_URL must use HTTPS (got "${siteUrl.slice(0, 30)}…"). API keys must not be sent over unencrypted connections.`,
582
+ };
583
+ }
584
+ return { ok: true, apiKey: resolved.apiKey, siteUrl, source: resolved.source };
585
+ }
99
586
  /**
100
587
  * Get config; if key is missing and stdin is a TTY, run guided flow (y/n → paste key → save → retry).
101
588
  * @param retry Called after saving key so the original command runs in-process.
102
589
  * @returns Config, or null if we ran retry (caller should return without running again).
103
590
  */
104
591
  export async function getConfigOrGuide(retry) {
592
+ loadEnv();
105
593
  const apiKey = process.env.PRODUCTBRAIN_API_KEY ?? '';
106
594
  const siteUrl = (process.env.CONVEX_SITE_URL ?? DEFAULT_SITE_URL).replace(/\/$/, '');
107
- if (apiKey.startsWith('pb_sk_') && siteUrl.startsWith('https://')) {
595
+ const allowHttp = isDevMode() && siteUrl.startsWith('http://localhost');
596
+ if (apiKey.startsWith(API_KEY_PREFIX) && (siteUrl.startsWith('https://') || allowHttp)) {
108
597
  return { apiKey, siteUrl };
109
598
  }
110
599
  if (!process.stdin.isTTY) {
111
- throw new Error(NON_TTY_MESSAGE);
600
+ throw new CLIError(NON_TTY_MESSAGE, {
601
+ code: ErrorCode.AUTH_MISSING,
602
+ category: 'auth',
603
+ guidance: 'Set PRODUCTBRAIN_API_KEY or run `pb login`.',
604
+ });
112
605
  }
113
606
  const didRetry = await runGuidedFlow(retry);
114
607
  return didRetry ? null : null;
115
608
  }
116
- export { HOME_CONFIG_DIR, HOME_ENV_PATH };
609
+ /**
610
+ * Resolve config for admin operations — profile-only resolution.
611
+ *
612
+ * Admin commands (pb admin ...) must NOT read .productbrain/config.json or CWD env files.
613
+ * The project config intentionally pins the repo to a dev Convex site; admin operations
614
+ * target PROD workspaces via the operator's active profile. Reading project config here
615
+ * would silently route admin calls to the wrong gateway (TEN-1334).
616
+ *
617
+ * Resolution order:
618
+ * 1. Shell env vars (PRODUCTBRAIN_API_KEY / CONVEX_SITE_URL) — always win
619
+ * 2. Active named profile (~/.config/productbrain/profiles/{name}.env)
620
+ * 3. Legacy home config (~/.config/productbrain/.env)
621
+ * 4. DEFAULT_SITE_URL as fallback for siteUrl
622
+ *
623
+ * Throws CLIError with AUTH_MISSING if no API key is found.
624
+ */
625
+ export function resolveAdminConfig() {
626
+ let apiKey;
627
+ let rawSiteUrl;
628
+ // 1. Shell env vars — always highest priority
629
+ const envKey = process.env.PRODUCTBRAIN_API_KEY;
630
+ if (envKey?.startsWith(API_KEY_PREFIX)) {
631
+ apiKey = envKey;
632
+ rawSiteUrl = process.env.CONVEX_SITE_URL;
633
+ }
634
+ // 2. Active profile (no project config, no CWD files)
635
+ if (!apiKey) {
636
+ const profileConfig = resolveProfileConfig();
637
+ if (profileConfig?.apiKey?.startsWith(API_KEY_PREFIX)) {
638
+ apiKey = profileConfig.apiKey;
639
+ rawSiteUrl = profileConfig.siteUrl;
640
+ }
641
+ }
642
+ // 3. Legacy ~/.config/productbrain/.env
643
+ if (!apiKey && existsSync(HOME_ENV_PATH)) {
644
+ const vars = parseEnvVars(readFileSync(HOME_ENV_PATH, 'utf8'));
645
+ if (vars['PRODUCTBRAIN_API_KEY']?.startsWith(API_KEY_PREFIX)) {
646
+ apiKey = vars['PRODUCTBRAIN_API_KEY'];
647
+ rawSiteUrl = vars['CONVEX_SITE_URL'];
648
+ }
649
+ }
650
+ if (!apiKey) {
651
+ throw new CLIError('No API key found. Run pb login or set PRODUCTBRAIN_API_KEY.', {
652
+ code: ErrorCode.AUTH_MISSING,
653
+ category: 'auth',
654
+ guidance: 'Run `pb login` to set your API key.',
655
+ });
656
+ }
657
+ const siteUrl = (rawSiteUrl || DEFAULT_SITE_URL).replace(/\/$/, '');
658
+ const allowHttp = isDevMode() && siteUrl.startsWith('http://localhost');
659
+ if (!siteUrl.startsWith('https://') && !allowHttp) {
660
+ throw new CLIError(`CONVEX_SITE_URL must use HTTPS for admin operations (got "${siteUrl.slice(0, 30)}…").`, {
661
+ code: ErrorCode.CONFIG_INVALID,
662
+ category: 'config',
663
+ guidance: 'Set CONVEX_SITE_URL to an https:// URL.',
664
+ });
665
+ }
666
+ return { apiKey, siteUrl };
667
+ }
668
+ export { HOME_CONFIG_DIR, HOME_ENV_PATH, readProjectConfig };
117
669
  //# sourceMappingURL=config.js.map