@powerhousedao/ph-cli 6.0.0-dev.23 → 6.0.0-dev.230

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 (311) hide show
  1. package/README.md +2 -2
  2. package/dist/assign-env-vars-DZMMuzB2.mjs +15 -0
  3. package/dist/assign-env-vars-DZMMuzB2.mjs.map +1 -0
  4. package/dist/auth-Ch5B5mNU.mjs +15 -0
  5. package/dist/auth-Ch5B5mNU.mjs.map +1 -0
  6. package/dist/auth-Dq7JjwYn.mjs +2 -0
  7. package/dist/build-CWcQj0YI.mjs +2 -0
  8. package/dist/build-DCXpFtjA.mjs +46 -0
  9. package/dist/build-DCXpFtjA.mjs.map +1 -0
  10. package/dist/cli-CqlxYVzz.mjs +140 -0
  11. package/dist/cli-CqlxYVzz.mjs.map +1 -0
  12. package/dist/cli.d.mts +1 -0
  13. package/dist/cli.mjs +920 -0
  14. package/dist/cli.mjs.map +1 -0
  15. package/dist/connect-build-6yhCIKkQ.mjs +35 -0
  16. package/dist/connect-build-6yhCIKkQ.mjs.map +1 -0
  17. package/dist/connect-preview-CaEiWmqU.mjs +27 -0
  18. package/dist/connect-preview-CaEiWmqU.mjs.map +1 -0
  19. package/dist/connect-studio-BaqbrWYQ.mjs +28 -0
  20. package/dist/connect-studio-BaqbrWYQ.mjs.map +1 -0
  21. package/dist/connect-studio-Dndkp0Q_.mjs +3 -0
  22. package/dist/generate-all-DaXXjoms.mjs +12 -0
  23. package/dist/generate-all-DaXXjoms.mjs.map +1 -0
  24. package/dist/generate-app-GvQeAG4w.mjs +35 -0
  25. package/dist/generate-app-GvQeAG4w.mjs.map +1 -0
  26. package/dist/generate-document-model-Dnik0rKd.mjs +21 -0
  27. package/dist/generate-document-model-Dnik0rKd.mjs.map +1 -0
  28. package/dist/generate-editor-BNN2OmmX.mjs +35 -0
  29. package/dist/generate-editor-BNN2OmmX.mjs.map +1 -0
  30. package/dist/generate-processor-CCSW2Ed2.mjs +26 -0
  31. package/dist/generate-processor-CCSW2Ed2.mjs.map +1 -0
  32. package/dist/generate-subgraph-B-d3J6hU.mjs +24 -0
  33. package/dist/generate-subgraph-B-d3J6hU.mjs.map +1 -0
  34. package/dist/init-8FtJDKxG.mjs +125 -0
  35. package/dist/init-8FtJDKxG.mjs.map +1 -0
  36. package/dist/inspect-BwkihsT7.mjs +45 -0
  37. package/dist/inspect-BwkihsT7.mjs.map +1 -0
  38. package/dist/logout-BtGDgA5w.mjs +232 -0
  39. package/dist/logout-BtGDgA5w.mjs.map +1 -0
  40. package/dist/migrate-B-O6P7jA.mjs +59 -0
  41. package/dist/migrate-B-O6P7jA.mjs.map +1 -0
  42. package/dist/registry-auth-BX9_n8hE.mjs +22 -0
  43. package/dist/registry-auth-BX9_n8hE.mjs.map +1 -0
  44. package/dist/scripts/generate-commands-docs.ts +16 -8
  45. package/dist/scripts/setup.sh +2 -2
  46. package/dist/switchboard-CJMoMzWx.mjs +72 -0
  47. package/dist/switchboard-CJMoMzWx.mjs.map +1 -0
  48. package/dist/switchboard-iRFugh8I.mjs +2 -0
  49. package/dist/switchboard-migrate-BRgCgg7N.mjs +50 -0
  50. package/dist/switchboard-migrate-BRgCgg7N.mjs.map +1 -0
  51. package/dist/utils-D7x443W6.mjs +162 -0
  52. package/dist/utils-D7x443W6.mjs.map +1 -0
  53. package/dist/utils-DkOZWO0i.mjs +2 -0
  54. package/dist/vetra-xk2hwf6X.mjs +420 -0
  55. package/dist/vetra-xk2hwf6X.mjs.map +1 -0
  56. package/package.json +44 -46
  57. package/dist/scripts/generate-commands-docs.d.ts +0 -2
  58. package/dist/scripts/generate-commands-docs.d.ts.map +0 -1
  59. package/dist/scripts/generate-commands-docs.js +0 -47
  60. package/dist/scripts/generate-commands-docs.js.map +0 -1
  61. package/dist/scripts/generate-docs-legacy.d.ts +0 -2
  62. package/dist/scripts/generate-docs-legacy.d.ts.map +0 -1
  63. package/dist/scripts/generate-docs-legacy.js +0 -72
  64. package/dist/scripts/generate-docs-legacy.js.map +0 -1
  65. package/dist/scripts/generate-docs-legacy.ts +0 -84
  66. package/dist/scripts/generate-version.d.ts +0 -2
  67. package/dist/scripts/generate-version.d.ts.map +0 -1
  68. package/dist/scripts/generate-version.js +0 -13
  69. package/dist/scripts/generate-version.js.map +0 -1
  70. package/dist/scripts/generate-version.ts +0 -22
  71. package/dist/src/cli.d.ts +0 -3
  72. package/dist/src/cli.d.ts.map +0 -1
  73. package/dist/src/cli.js +0 -29
  74. package/dist/src/cli.js.map +0 -1
  75. package/dist/src/cli.old.d.ts +0 -3
  76. package/dist/src/cli.old.d.ts.map +0 -1
  77. package/dist/src/cli.old.js +0 -43
  78. package/dist/src/cli.old.js.map +0 -1
  79. package/dist/src/commands/access-token.d.ts +0 -14
  80. package/dist/src/commands/access-token.d.ts.map +0 -1
  81. package/dist/src/commands/access-token.js +0 -142
  82. package/dist/src/commands/access-token.js.map +0 -1
  83. package/dist/src/commands/connect.d.ts +0 -249
  84. package/dist/src/commands/connect.d.ts.map +0 -1
  85. package/dist/src/commands/connect.js +0 -60
  86. package/dist/src/commands/connect.js.map +0 -1
  87. package/dist/src/commands/generate.d.ts +0 -58
  88. package/dist/src/commands/generate.d.ts.map +0 -1
  89. package/dist/src/commands/generate.js +0 -25
  90. package/dist/src/commands/generate.js.map +0 -1
  91. package/dist/src/commands/get-package-manager.d.ts +0 -30
  92. package/dist/src/commands/get-package-manager.d.ts.map +0 -1
  93. package/dist/src/commands/get-package-manager.js +0 -8
  94. package/dist/src/commands/get-package-manager.js.map +0 -1
  95. package/dist/src/commands/index.d.ts +0 -13
  96. package/dist/src/commands/index.d.ts.map +0 -1
  97. package/dist/src/commands/index.js +0 -25
  98. package/dist/src/commands/index.js.map +0 -1
  99. package/dist/src/commands/inspect.d.ts +0 -12
  100. package/dist/src/commands/inspect.d.ts.map +0 -1
  101. package/dist/src/commands/inspect.js +0 -27
  102. package/dist/src/commands/inspect.js.map +0 -1
  103. package/dist/src/commands/install.d.ts +0 -22
  104. package/dist/src/commands/install.d.ts.map +0 -1
  105. package/dist/src/commands/install.js +0 -75
  106. package/dist/src/commands/install.js.map +0 -1
  107. package/dist/src/commands/legacy/access-token.old.d.ts +0 -9
  108. package/dist/src/commands/legacy/access-token.old.d.ts.map +0 -1
  109. package/dist/src/commands/legacy/access-token.old.js +0 -110
  110. package/dist/src/commands/legacy/access-token.old.js.map +0 -1
  111. package/dist/src/commands/legacy/connect.old.d.ts +0 -19
  112. package/dist/src/commands/legacy/connect.old.d.ts.map +0 -1
  113. package/dist/src/commands/legacy/connect.old.js +0 -85
  114. package/dist/src/commands/legacy/connect.old.js.map +0 -1
  115. package/dist/src/commands/legacy/generate.old.d.ts +0 -9
  116. package/dist/src/commands/legacy/generate.old.d.ts.map +0 -1
  117. package/dist/src/commands/legacy/generate.old.js +0 -41
  118. package/dist/src/commands/legacy/generate.old.js.map +0 -1
  119. package/dist/src/commands/legacy/help.old.d.ts +0 -3
  120. package/dist/src/commands/legacy/help.old.d.ts.map +0 -1
  121. package/dist/src/commands/legacy/help.old.js +0 -9
  122. package/dist/src/commands/legacy/help.old.js.map +0 -1
  123. package/dist/src/commands/legacy/inspect.old.d.ts +0 -6
  124. package/dist/src/commands/legacy/inspect.old.d.ts.map +0 -1
  125. package/dist/src/commands/legacy/inspect.old.js +0 -21
  126. package/dist/src/commands/legacy/inspect.old.js.map +0 -1
  127. package/dist/src/commands/legacy/install.old.d.ts +0 -15
  128. package/dist/src/commands/legacy/install.old.d.ts.map +0 -1
  129. package/dist/src/commands/legacy/install.old.js +0 -127
  130. package/dist/src/commands/legacy/install.old.js.map +0 -1
  131. package/dist/src/commands/legacy/login.old.d.ts +0 -12
  132. package/dist/src/commands/legacy/login.old.d.ts.map +0 -1
  133. package/dist/src/commands/legacy/login.old.js +0 -208
  134. package/dist/src/commands/legacy/login.old.js.map +0 -1
  135. package/dist/src/commands/legacy/migrate.old.d.ts +0 -11
  136. package/dist/src/commands/legacy/migrate.old.d.ts.map +0 -1
  137. package/dist/src/commands/legacy/migrate.old.js +0 -15
  138. package/dist/src/commands/legacy/migrate.old.js.map +0 -1
  139. package/dist/src/commands/legacy/service.old.d.ts +0 -5
  140. package/dist/src/commands/legacy/service.old.d.ts.map +0 -1
  141. package/dist/src/commands/legacy/service.old.js +0 -67
  142. package/dist/src/commands/legacy/service.old.js.map +0 -1
  143. package/dist/src/commands/legacy/switchboard.old.d.ts +0 -9
  144. package/dist/src/commands/legacy/switchboard.old.d.ts.map +0 -1
  145. package/dist/src/commands/legacy/switchboard.old.js +0 -78
  146. package/dist/src/commands/legacy/switchboard.old.js.map +0 -1
  147. package/dist/src/commands/legacy/uninstall.old.d.ts +0 -15
  148. package/dist/src/commands/legacy/uninstall.old.d.ts.map +0 -1
  149. package/dist/src/commands/legacy/uninstall.old.js +0 -120
  150. package/dist/src/commands/legacy/uninstall.old.js.map +0 -1
  151. package/dist/src/commands/legacy/vetra.old.d.ts +0 -23
  152. package/dist/src/commands/legacy/vetra.old.d.ts.map +0 -1
  153. package/dist/src/commands/legacy/vetra.old.js +0 -35
  154. package/dist/src/commands/legacy/vetra.old.js.map +0 -1
  155. package/dist/src/commands/list.d.ts +0 -10
  156. package/dist/src/commands/list.d.ts.map +0 -1
  157. package/dist/src/commands/list.js +0 -42
  158. package/dist/src/commands/list.js.map +0 -1
  159. package/dist/src/commands/list.old.d.ts +0 -9
  160. package/dist/src/commands/list.old.d.ts.map +0 -1
  161. package/dist/src/commands/list.old.js +0 -36
  162. package/dist/src/commands/list.old.js.map +0 -1
  163. package/dist/src/commands/login.d.ts +0 -20
  164. package/dist/src/commands/login.d.ts.map +0 -1
  165. package/dist/src/commands/login.js +0 -209
  166. package/dist/src/commands/login.js.map +0 -1
  167. package/dist/src/commands/migrate.d.ts +0 -12
  168. package/dist/src/commands/migrate.d.ts.map +0 -1
  169. package/dist/src/commands/migrate.js +0 -16
  170. package/dist/src/commands/migrate.js.map +0 -1
  171. package/dist/src/commands/ph-cli-commands.d.ts +0 -410
  172. package/dist/src/commands/ph-cli-commands.d.ts.map +0 -1
  173. package/dist/src/commands/ph-cli-commands.js +0 -25
  174. package/dist/src/commands/ph-cli-commands.js.map +0 -1
  175. package/dist/src/commands/ph-cli-help.d.ts +0 -396
  176. package/dist/src/commands/ph-cli-help.d.ts.map +0 -1
  177. package/dist/src/commands/ph-cli-help.js +0 -12
  178. package/dist/src/commands/ph-cli-help.js.map +0 -1
  179. package/dist/src/commands/ph-cli.d.ts +0 -490
  180. package/dist/src/commands/ph-cli.d.ts.map +0 -1
  181. package/dist/src/commands/ph-cli.js +0 -12
  182. package/dist/src/commands/ph-cli.js.map +0 -1
  183. package/dist/src/commands/register-commands.d.ts +0 -5
  184. package/dist/src/commands/register-commands.d.ts.map +0 -1
  185. package/dist/src/commands/register-commands.js +0 -32
  186. package/dist/src/commands/register-commands.js.map +0 -1
  187. package/dist/src/commands/service.d.ts +0 -12
  188. package/dist/src/commands/service.d.ts.map +0 -1
  189. package/dist/src/commands/service.js +0 -79
  190. package/dist/src/commands/service.js.map +0 -1
  191. package/dist/src/commands/switchboard.d.ts +0 -46
  192. package/dist/src/commands/switchboard.d.ts.map +0 -1
  193. package/dist/src/commands/switchboard.js +0 -43
  194. package/dist/src/commands/switchboard.js.map +0 -1
  195. package/dist/src/commands/uninstall.d.ts +0 -22
  196. package/dist/src/commands/uninstall.d.ts.map +0 -1
  197. package/dist/src/commands/uninstall.js +0 -71
  198. package/dist/src/commands/uninstall.js.map +0 -1
  199. package/dist/src/commands/vetra.d.ts +0 -64
  200. package/dist/src/commands/vetra.d.ts.map +0 -1
  201. package/dist/src/commands/vetra.js +0 -24
  202. package/dist/src/commands/vetra.js.map +0 -1
  203. package/dist/src/get-version.d.ts +0 -2
  204. package/dist/src/get-version.d.ts.map +0 -1
  205. package/dist/src/get-version.js +0 -7
  206. package/dist/src/get-version.js.map +0 -1
  207. package/dist/src/help.d.ts +0 -65
  208. package/dist/src/help.d.ts.map +0 -1
  209. package/dist/src/help.js +0 -770
  210. package/dist/src/help.js.map +0 -1
  211. package/dist/src/index.d.ts +0 -4
  212. package/dist/src/index.d.ts.map +0 -1
  213. package/dist/src/index.js +0 -4
  214. package/dist/src/index.js.map +0 -1
  215. package/dist/src/services/auth.d.ts +0 -69
  216. package/dist/src/services/auth.d.ts.map +0 -1
  217. package/dist/src/services/auth.js +0 -171
  218. package/dist/src/services/auth.js.map +0 -1
  219. package/dist/src/services/connect.d.ts +0 -5
  220. package/dist/src/services/connect.d.ts.map +0 -1
  221. package/dist/src/services/connect.js +0 -90
  222. package/dist/src/services/connect.js.map +0 -1
  223. package/dist/src/services/generate.d.ts +0 -3
  224. package/dist/src/services/generate.d.ts.map +0 -1
  225. package/dist/src/services/generate.js +0 -80
  226. package/dist/src/services/generate.js.map +0 -1
  227. package/dist/src/services/inspect.d.ts +0 -3
  228. package/dist/src/services/inspect.d.ts.map +0 -1
  229. package/dist/src/services/inspect.js +0 -50
  230. package/dist/src/services/inspect.js.map +0 -1
  231. package/dist/src/services/legacy/connect.old.d.ts +0 -2
  232. package/dist/src/services/legacy/connect.old.d.ts.map +0 -1
  233. package/dist/src/services/legacy/connect.old.js +0 -2
  234. package/dist/src/services/legacy/connect.old.js.map +0 -1
  235. package/dist/src/services/legacy/generate.old.d.ts +0 -30
  236. package/dist/src/services/legacy/generate.old.d.ts.map +0 -1
  237. package/dist/src/services/legacy/generate.old.js +0 -107
  238. package/dist/src/services/legacy/generate.old.js.map +0 -1
  239. package/dist/src/services/legacy/inspect.old.d.ts +0 -5
  240. package/dist/src/services/legacy/inspect.old.d.ts.map +0 -1
  241. package/dist/src/services/legacy/inspect.old.js +0 -49
  242. package/dist/src/services/legacy/inspect.old.js.map +0 -1
  243. package/dist/src/services/legacy/migrate.old.d.ts +0 -3
  244. package/dist/src/services/legacy/migrate.old.d.ts.map +0 -1
  245. package/dist/src/services/legacy/migrate.old.js +0 -289
  246. package/dist/src/services/legacy/migrate.old.js.map +0 -1
  247. package/dist/src/services/legacy/switchboard.old.d.ts +0 -54
  248. package/dist/src/services/legacy/switchboard.old.d.ts.map +0 -1
  249. package/dist/src/services/legacy/switchboard.old.js +0 -79
  250. package/dist/src/services/legacy/switchboard.old.js.map +0 -1
  251. package/dist/src/services/legacy/vetra.old.d.ts +0 -15
  252. package/dist/src/services/legacy/vetra.old.d.ts.map +0 -1
  253. package/dist/src/services/legacy/vetra.old.js +0 -176
  254. package/dist/src/services/legacy/vetra.old.js.map +0 -1
  255. package/dist/src/services/migrate.d.ts +0 -3
  256. package/dist/src/services/migrate.d.ts.map +0 -1
  257. package/dist/src/services/migrate.js +0 -327
  258. package/dist/src/services/migrate.js.map +0 -1
  259. package/dist/src/services/switchboard-migrate.d.ts +0 -7
  260. package/dist/src/services/switchboard-migrate.d.ts.map +0 -1
  261. package/dist/src/services/switchboard-migrate.js +0 -60
  262. package/dist/src/services/switchboard-migrate.js.map +0 -1
  263. package/dist/src/services/switchboard.d.ts +0 -22
  264. package/dist/src/services/switchboard.d.ts.map +0 -1
  265. package/dist/src/services/switchboard.js +0 -77
  266. package/dist/src/services/switchboard.js.map +0 -1
  267. package/dist/src/services/vetra.d.ts +0 -3
  268. package/dist/src/services/vetra.d.ts.map +0 -1
  269. package/dist/src/services/vetra.js +0 -169
  270. package/dist/src/services/vetra.js.map +0 -1
  271. package/dist/src/types.d.ts +0 -31
  272. package/dist/src/types.d.ts.map +0 -1
  273. package/dist/src/types.js +0 -2
  274. package/dist/src/types.js.map +0 -1
  275. package/dist/src/utils/configure-vetra-github-url.d.ts +0 -12
  276. package/dist/src/utils/configure-vetra-github-url.d.ts.map +0 -1
  277. package/dist/src/utils/configure-vetra-github-url.js +0 -230
  278. package/dist/src/utils/configure-vetra-github-url.js.map +0 -1
  279. package/dist/src/utils/constants.d.ts +0 -2
  280. package/dist/src/utils/constants.d.ts.map +0 -1
  281. package/dist/src/utils/constants.js +0 -2
  282. package/dist/src/utils/constants.js.map +0 -1
  283. package/dist/src/utils/file-system.d.ts +0 -2
  284. package/dist/src/utils/file-system.d.ts.map +0 -1
  285. package/dist/src/utils/file-system.js +0 -15
  286. package/dist/src/utils/file-system.js.map +0 -1
  287. package/dist/src/utils/index.d.ts +0 -3
  288. package/dist/src/utils/index.d.ts.map +0 -1
  289. package/dist/src/utils/index.js +0 -3
  290. package/dist/src/utils/index.js.map +0 -1
  291. package/dist/src/utils/projects.d.ts +0 -19
  292. package/dist/src/utils/projects.d.ts.map +0 -1
  293. package/dist/src/utils/projects.js +0 -93
  294. package/dist/src/utils/projects.js.map +0 -1
  295. package/dist/src/utils.d.ts +0 -112
  296. package/dist/src/utils.d.ts.map +0 -1
  297. package/dist/src/utils.js +0 -261
  298. package/dist/src/utils.js.map +0 -1
  299. package/dist/src/version.d.ts +0 -2
  300. package/dist/src/version.d.ts.map +0 -1
  301. package/dist/src/version.js +0 -3
  302. package/dist/src/version.js.map +0 -1
  303. package/dist/test/utils.test.d.ts +0 -2
  304. package/dist/test/utils.test.d.ts.map +0 -1
  305. package/dist/test/utils.test.js +0 -133
  306. package/dist/test/utils.test.js.map +0 -1
  307. package/dist/tsconfig.tsbuildinfo +0 -1
  308. package/dist/vitest.config.d.ts +0 -3
  309. package/dist/vitest.config.d.ts.map +0 -1
  310. package/dist/vitest.config.js +0 -7
  311. package/dist/vitest.config.js.map +0 -1
package/dist/cli.mjs ADDED
@@ -0,0 +1,920 @@
1
+ #!/usr/bin/env node
2
+ import { a as getVersion, i as accessToken, n as login, r as list, t as logout } from "./logout-BtGDgA5w.mjs";
3
+ import { assertNodeVersion } from "@powerhousedao/shared/clis/utils";
4
+ import { captureCliError, initCliTelemetry } from "@powerhousedao/shared/clis/telemetry";
5
+ import { array, boolean, command, flag, multioption, oneOf, option, optional, run, string, subcommands } from "cmd-ts";
6
+ import { AGENTS, buildArgs, codeArgs, connectBuildArgs, connectPreviewArgs, connectStudioArgs, debugArgs, initArgs, inspectArgs, installArgs, migrateArgs, phCliHelpCommands, publishArgs, registryLoginArgs, switchboardArgs, uninstallArgs, unpublishArgs, vetraArgs } from "@powerhousedao/shared/clis/args";
7
+ import { Directory, File } from "cmd-ts/dist/cjs/batteries/fs.js";
8
+ import path from "path";
9
+ import { PROCESSOR_APPS } from "@powerhousedao/shared/processors";
10
+ import { execSync } from "child_process";
11
+ import { execSync as execSync$1 } from "node:child_process";
12
+ import { createInterface } from "node:readline/promises";
13
+ //#region src/utils/constants.ts
14
+ const PH_CLI_DESCRIPTION = "The Powerhouse CLI (ph-cli) is a command-line interface tool that provides essential commands for managing Powerhouse projects. The tool and it's commands are fundamental for creating, building, and running Document Models as a builder in studio mode.";
15
+ const phCliHelp = subcommands({
16
+ name: "ph-cli",
17
+ description: PH_CLI_DESCRIPTION,
18
+ version: getVersion(),
19
+ cmds: phCliHelpCommands
20
+ });
21
+ //#endregion
22
+ //#region src/commands/build.ts
23
+ const build$1 = command({
24
+ name: "build",
25
+ args: buildArgs,
26
+ handler: async (args) => {
27
+ if (args.debug) console.log(args);
28
+ try {
29
+ const { runBuild } = await import("./build-CWcQj0YI.mjs");
30
+ await runBuild(args);
31
+ } catch (error) {
32
+ console.error(error);
33
+ process.exit(1);
34
+ }
35
+ }
36
+ });
37
+ //#endregion
38
+ //#region src/commands/code.ts
39
+ const code = command({
40
+ name: "code",
41
+ description: `
42
+ Open the Powerhouse coding agent — a REPL backed by Mastra that has every
43
+ installed Powerhouse tool available as an agent tool.
44
+
45
+ Examples:
46
+ ph code Start the interactive REPL.
47
+ ph code "list my installed packs" One-shot agent prompt.
48
+ `,
49
+ args: codeArgs,
50
+ handler: async (args) => {
51
+ const { buildPhCodeCli } = await import("./cli-CqlxYVzz.mjs");
52
+ const cli = buildPhCodeCli();
53
+ const argv = [
54
+ "node",
55
+ "ph-code",
56
+ ...args.rest.length === 0 ? ["-i"] : args.rest
57
+ ];
58
+ await cli.run(argv);
59
+ }
60
+ });
61
+ const connect = subcommands({
62
+ name: "connect",
63
+ description: `Powerhouse Connect commands. Use with \`studio\`, \`build\` or \`preview\`. Defaults to \`studio\` if not specified.`,
64
+ cmds: {
65
+ studio: command({
66
+ name: "studio",
67
+ description: `The studio command starts the Connect Studio, a development environment for building
68
+ and testing Powerhouse applications. It provides a visual interface for working with
69
+ your project.
70
+
71
+ This command:
72
+ 1. Starts a local Connect Studio server
73
+ 2. Provides a web interface for development
74
+ 3. Allows you to interact with your project components
75
+ 4. Supports various configuration options for customization
76
+ `,
77
+ args: connectStudioArgs,
78
+ handler: async (args) => {
79
+ if (args.debug) console.log(args);
80
+ const { runConnectStudio } = await import("./connect-studio-Dndkp0Q_.mjs");
81
+ await runConnectStudio(args);
82
+ }
83
+ }),
84
+ build: command({
85
+ name: "build",
86
+ description: `The Connect build command creates a production build with the project's local and
87
+ external packages included
88
+ `,
89
+ args: connectBuildArgs,
90
+ handler: async (args) => {
91
+ if (args.debug) console.log(args);
92
+ const { runConnectBuild } = await import("./connect-build-6yhCIKkQ.mjs");
93
+ await runConnectBuild(args);
94
+ process.exit(0);
95
+ }
96
+ }),
97
+ preview: command({
98
+ name: "preview",
99
+ description: `The Connect preview command previews a built Connect project.
100
+ NOTE: You must run \`ph connect build\` first
101
+ `,
102
+ args: connectPreviewArgs,
103
+ handler: async (args) => {
104
+ if (args.debug) console.log(args);
105
+ const { runConnectPreview } = await import("./connect-preview-CaEiWmqU.mjs");
106
+ await runConnectPreview(args);
107
+ }
108
+ })
109
+ }
110
+ });
111
+ //#endregion
112
+ //#region src/commands/generate-all.ts
113
+ const generateAllCmd = command({
114
+ name: "all",
115
+ description: "Re-generate all modules in the current project",
116
+ args: {},
117
+ handler: async () => {
118
+ const { startGenerateAll } = await import("./generate-all-DaXXjoms.mjs");
119
+ await startGenerateAll(process.cwd());
120
+ process.exit(0);
121
+ }
122
+ });
123
+ //#endregion
124
+ //#region src/commands/generate-app.ts
125
+ const generateAppCmd = command({
126
+ name: "app",
127
+ description: "Generate a drive app",
128
+ args: {
129
+ name: option({
130
+ type: optional(string),
131
+ long: "name",
132
+ short: "n",
133
+ description: "The name of the drive app to generate"
134
+ }),
135
+ allowedDocumentTypes: multioption({
136
+ type: optional(array(string)),
137
+ long: "document-types",
138
+ short: "t",
139
+ description: "The document types allowed by the new app"
140
+ }),
141
+ dir: option({
142
+ type: optional(Directory),
143
+ long: "dir",
144
+ short: "d",
145
+ description: "Name of the directory of an existing app to re-generate"
146
+ }),
147
+ disableDragAndDrop: flag({
148
+ type: boolean,
149
+ long: "disable-drag-and-drop",
150
+ description: "Do not allow drag and drop in this drive app.",
151
+ defaultValue: () => false,
152
+ defaultValueIsSerializable: true
153
+ }),
154
+ all: flag({
155
+ long: "all",
156
+ short: "a",
157
+ description: "Re-generate all existing apps in the current project"
158
+ }),
159
+ ...debugArgs
160
+ },
161
+ handler: async (args) => {
162
+ const { startGenerateApp } = await import("./generate-app-GvQeAG4w.mjs");
163
+ await startGenerateApp(args, process.cwd());
164
+ process.exit(0);
165
+ }
166
+ });
167
+ //#endregion
168
+ //#region src/commands/generate-document-model.ts
169
+ const generateDocumentModelCmd = command({
170
+ name: "document-model",
171
+ aliases: ["doc"],
172
+ description: "Generate a document model",
173
+ args: {
174
+ file: option({
175
+ type: optional(File),
176
+ long: "file",
177
+ short: "f",
178
+ description: "Path to the file to generate the document model from"
179
+ }),
180
+ dir: option({
181
+ type: optional(Directory),
182
+ long: "dir",
183
+ short: "d",
184
+ description: "Name of the directory of an existing document model to re-generate"
185
+ }),
186
+ all: flag({
187
+ long: "all",
188
+ short: "a",
189
+ description: "Re-generate all existing document models in the current project"
190
+ }),
191
+ ...debugArgs
192
+ },
193
+ handler: async (args) => {
194
+ const { startGenerateDocumentModel } = await import("./generate-document-model-Dnik0rKd.mjs");
195
+ await startGenerateDocumentModel(args, process.cwd());
196
+ process.exit(0);
197
+ }
198
+ });
199
+ //#endregion
200
+ //#region src/commands/generate-editor.ts
201
+ const generateEditorCmd = command({
202
+ name: "editor",
203
+ description: "Generate a document editor",
204
+ args: {
205
+ name: option({
206
+ type: optional(string),
207
+ long: "name",
208
+ short: "n",
209
+ description: "The name of the document editor to generate"
210
+ }),
211
+ documentType: option({
212
+ type: optional(string),
213
+ long: "document-type",
214
+ short: "t",
215
+ description: "The document type for the new editor"
216
+ }),
217
+ dir: option({
218
+ type: optional(Directory),
219
+ long: "dir",
220
+ short: "d",
221
+ description: "Name of the directory of an existing editor to re-generate"
222
+ }),
223
+ all: flag({
224
+ long: "all",
225
+ short: "a",
226
+ description: "Re-generate all existing editors in the current project"
227
+ }),
228
+ ...debugArgs
229
+ },
230
+ handler: async (args) => {
231
+ const { startGenerateEditor } = await import("./generate-editor-BNN2OmmX.mjs");
232
+ await startGenerateEditor(args, process.cwd());
233
+ process.exit(0);
234
+ }
235
+ });
236
+ //#endregion
237
+ //#region src/commands/generate-migration-file.ts
238
+ const generateMigrationFileCmd = command({
239
+ name: "migration-file",
240
+ description: "Generate a migration file",
241
+ args: {
242
+ migrationFile: option({
243
+ type: string,
244
+ long: "path",
245
+ short: "p",
246
+ description: "Path to the migration file"
247
+ }),
248
+ schemaFile: option({
249
+ type: optional(string),
250
+ long: "schema-file",
251
+ description: "Path to the output file. Defaults to './schema.ts'"
252
+ }),
253
+ ...debugArgs
254
+ },
255
+ handler: async ({ migrationFile, schemaFile }) => {
256
+ const { generateDBSchema } = await import("@powerhousedao/codegen");
257
+ await generateDBSchema({
258
+ migrationFile: path.join(process.cwd(), migrationFile),
259
+ schemaFile: schemaFile ? path.join(process.cwd(), schemaFile) : void 0
260
+ });
261
+ process.exit(0);
262
+ }
263
+ });
264
+ const generateProcessorCmd = command({
265
+ name: "processor",
266
+ description: "Generate a processor",
267
+ args: {
268
+ name: option({
269
+ type: optional(string),
270
+ long: "name",
271
+ short: "n",
272
+ description: "The name of the processor to generate"
273
+ }),
274
+ type: option({
275
+ type: oneOf(["analytics", "relationalDb"]),
276
+ long: "type",
277
+ description: "The type of processor to generate",
278
+ defaultValue: () => "analytics",
279
+ defaultValueIsSerializable: true
280
+ }),
281
+ documentTypes: multioption({
282
+ type: array(string),
283
+ long: "document-types",
284
+ short: "t",
285
+ description: "The document types the processor will run on",
286
+ defaultValue: () => [],
287
+ defaultValueIsSerializable: true
288
+ }),
289
+ apps: multioption({
290
+ long: "apps",
291
+ type: { from(processorApps) {
292
+ if (processorApps.length === 0) throw new Error(`No arguments provided for processor apps. Must be "connect" and/or "switchboard"`);
293
+ if (processorApps.length > 2) throw new Error(`Too many arguments provided for processor apps. Must be "connect" and/or "switchboard"`);
294
+ const allowed = new Set(PROCESSOR_APPS);
295
+ if (!processorApps.every((p) => allowed.has(p))) throw new Error(`Processor apps can only be "connect" and/or "switchboard".`);
296
+ return Promise.resolve(processorApps);
297
+ } },
298
+ description: "Whether the processor will run in switchboard (nodejs), connect (browser), or both",
299
+ defaultValue: () => ["switchboard", "connect"],
300
+ defaultValueIsSerializable: true
301
+ }),
302
+ dir: option({
303
+ type: optional(Directory),
304
+ long: "dir",
305
+ short: "d",
306
+ description: "Name of the directory of an existing processor to re-generate"
307
+ }),
308
+ all: flag({
309
+ long: "all",
310
+ short: "a",
311
+ description: "Re-generate all existing processors in the current project"
312
+ }),
313
+ ...debugArgs
314
+ },
315
+ handler: async (args) => {
316
+ const { startGenerateProcessor } = await import("./generate-processor-CCSW2Ed2.mjs");
317
+ await startGenerateProcessor(args, process.cwd());
318
+ process.exit(0);
319
+ }
320
+ });
321
+ //#endregion
322
+ //#region src/commands/generate-subgraph.ts
323
+ const generateSubgraphCmd = command({
324
+ name: "subgraph",
325
+ description: "Generate a subgraph",
326
+ args: {
327
+ name: option({
328
+ type: optional(string),
329
+ long: "name",
330
+ short: "n",
331
+ description: "The name of the subgraph to generate"
332
+ }),
333
+ dir: option({
334
+ type: optional(Directory),
335
+ long: "dir",
336
+ short: "d",
337
+ description: "Name of the directory of an existing subgraph to re-generate"
338
+ }),
339
+ all: flag({
340
+ long: "all",
341
+ short: "a",
342
+ description: "Re-generate all existing subgraphs in the current project"
343
+ }),
344
+ ...debugArgs
345
+ },
346
+ handler: async (args) => {
347
+ const { startGenerateSubgraph } = await import("./generate-subgraph-B-d3J6hU.mjs");
348
+ await startGenerateSubgraph(args, process.cwd());
349
+ process.exit(0);
350
+ }
351
+ });
352
+ //#endregion
353
+ //#region src/commands/generate.ts
354
+ const generate = subcommands({
355
+ name: "generate",
356
+ description: `The generate command creates code for Powerhouse modules. It helps you create new code from scratch, or to re-generate existing code in your project.`,
357
+ cmds: {
358
+ all: generateAllCmd,
359
+ "document-model": generateDocumentModelCmd,
360
+ editor: generateEditorCmd,
361
+ app: generateAppCmd,
362
+ processor: generateProcessorCmd,
363
+ subgraph: generateSubgraphCmd,
364
+ "migration-file": generateMigrationFileCmd
365
+ }
366
+ });
367
+ //#endregion
368
+ //#region src/commands/init.ts
369
+ const init = command({
370
+ name: "init",
371
+ description: "Initialize a new project",
372
+ args: initArgs,
373
+ handler: async (args) => {
374
+ if (args.debug) console.log({ args });
375
+ const { startInit } = await import("./init-8FtJDKxG.mjs");
376
+ await startInit(args);
377
+ process.exit(0);
378
+ }
379
+ });
380
+ //#endregion
381
+ //#region src/commands/inspect.ts
382
+ const inspect = command({
383
+ name: "inspect",
384
+ description: `
385
+ The inspect command examines and provides detailed information about a Powerhouse package.
386
+ It helps you understand the structure, dependencies, and configuration of packages in
387
+ your project.
388
+
389
+ This command:
390
+ 1. Analyzes the specified package
391
+ 2. Retrieves detailed information about its structure and configuration
392
+ 3. Displays package metadata, dependencies, and other relevant information
393
+ 4. Helps troubleshoot package-related issues`,
394
+ aliases: ["is"],
395
+ args: inspectArgs,
396
+ handler: async (args) => {
397
+ if (args.debug) console.log(args);
398
+ const { startInspect } = await import("./inspect-BwkihsT7.mjs");
399
+ startInspect(args);
400
+ process.exit(0);
401
+ }
402
+ });
403
+ //#endregion
404
+ //#region src/commands/install.ts
405
+ const install = command({
406
+ name: "install",
407
+ aliases: ["add", "i"],
408
+ description: `
409
+ The install command adds Powerhouse dependencies to your project.
410
+
411
+ By default it only registers the package in powerhouse.config.json with
412
+ provider "registry" — Connect will load it from the registry CDN at runtime.
413
+
414
+ With --local, the package is also installed into node_modules and marked
415
+ as provider "local" — it will be bundled into ph connect build so the
416
+ preview works without the registry being reachable.
417
+
418
+ Resolution order for the registry URL:
419
+ --registry flag > PH_REGISTRY_URL env > powerhouse.config.json > default
420
+ `,
421
+ args: installArgs,
422
+ handler: async (args) => {
423
+ if (args.debug) console.log(args);
424
+ const { getPowerhouseProjectInfo, makeDependenciesWithVersions } = await import("@powerhousedao/shared/clis");
425
+ const { projectPath, localProjectPath, globalProjectPath, packageManager, isGlobal } = await getPowerhouseProjectInfo(args);
426
+ if (!projectPath) throw new Error(`Could not find project path to install from.`);
427
+ const { resolveRegistryUrl } = await import("@powerhousedao/shared/registry");
428
+ const registryUrl = resolveRegistryUrl({
429
+ registry: args.registry,
430
+ projectPath
431
+ });
432
+ if (args.debug) console.log(">>> registryUrl", registryUrl);
433
+ const dependenciesWithVersions = await makeDependenciesWithVersions(args.dependencies, registryUrl);
434
+ if (args.debug) {
435
+ console.log(">>> parsedDependencies", dependenciesWithVersions);
436
+ console.log("\n>>> projectInfo", {
437
+ localProjectPath,
438
+ globalProjectPath,
439
+ packageManager,
440
+ isGlobal
441
+ });
442
+ }
443
+ if (args.local) {
444
+ if (dependenciesWithVersions.length === 0) throw new Error("--local requires at least one package name (e.g. ph install --local @scope/pkg)");
445
+ try {
446
+ const specs = dependenciesWithVersions.map((d) => d.version ? `${d.name}@${d.version}` : d.name);
447
+ const scopes = /* @__PURE__ */ new Set();
448
+ for (const dep of dependenciesWithVersions) if (dep.name.startsWith("@")) {
449
+ const scope = dep.name.split("/")[0];
450
+ scopes.add(scope);
451
+ }
452
+ const scopeRegistryArgs = Array.from(scopes).map((scope) => `--${scope}:registry=${registryUrl}`);
453
+ const { resolveCommand } = await import("package-manager-detector");
454
+ const resolved = resolveCommand(packageManager, "add", [...specs, ...scopeRegistryArgs]);
455
+ if (!resolved) throw new Error(`Failed to resolve install command for package manager "${packageManager}".`);
456
+ const installCommand = `${resolved.command} ${resolved.args.join(" ")}`;
457
+ if (scopeRegistryArgs.length > 0) console.log(`Installing dependencies 📦 (routing ${Array.from(scopes).join(", ")} → ${registryUrl})...`);
458
+ else console.log("Installing dependencies 📦...");
459
+ console.log(`> ${installCommand}`);
460
+ execSync(installCommand, {
461
+ stdio: "inherit",
462
+ cwd: projectPath
463
+ });
464
+ console.log("Dependency installed successfully 🎉");
465
+ } catch (error) {
466
+ console.error("❌ Failed to install dependencies");
467
+ throw error;
468
+ }
469
+ }
470
+ const { updateConfigFile, updateStylesFile } = await import("./utils-DkOZWO0i.mjs");
471
+ try {
472
+ console.log("⚙️ Updating powerhouse config file...");
473
+ updateConfigFile(dependenciesWithVersions, projectPath, "install", args.local ? "local" : "registry", registryUrl);
474
+ console.log("Config file updated successfully 🎉");
475
+ } catch (error) {
476
+ console.error("❌ Failed to update config file");
477
+ throw error;
478
+ }
479
+ if (args.local) try {
480
+ console.log("⚙️ Updating styles.css file...");
481
+ updateStylesFile(dependenciesWithVersions, projectPath);
482
+ console.log("Styles file updated successfully 🎉");
483
+ } catch (error) {
484
+ console.error("❌ Failed to update styles file");
485
+ throw error;
486
+ }
487
+ process.exit(0);
488
+ }
489
+ });
490
+ //#endregion
491
+ //#region src/commands/migrate.ts
492
+ const migrate = command({
493
+ name: "migrate",
494
+ args: migrateArgs,
495
+ description: "Run migrations",
496
+ handler: async (args) => {
497
+ if (args.debug) console.log(args);
498
+ const { startMigrate } = await import("./migrate-B-O6P7jA.mjs");
499
+ await startMigrate(args);
500
+ process.exit(0);
501
+ }
502
+ });
503
+ //#endregion
504
+ //#region src/commands/publish.ts
505
+ function hasTagFlag(args) {
506
+ return args.some((a) => a === "--tag" || a.startsWith("--tag="));
507
+ }
508
+ function isInteractive() {
509
+ return Boolean(process.stdin.isTTY) && !process.env.CI;
510
+ }
511
+ async function readPrereleaseTag(projectPath) {
512
+ try {
513
+ const [{ readPackageSync }, { prerelease }] = await Promise.all([import("read-pkg"), import("semver")]);
514
+ const pkg = readPackageSync({ cwd: projectPath });
515
+ if (!pkg.version) return null;
516
+ const parts = prerelease(pkg.version);
517
+ if (!parts || parts.length === 0) return null;
518
+ const label = String(parts[0]);
519
+ if (!/^[a-z][a-z0-9-]*$/i.test(label)) return null;
520
+ return {
521
+ version: pkg.version,
522
+ tag: label
523
+ };
524
+ } catch {
525
+ return null;
526
+ }
527
+ }
528
+ const publish = command({
529
+ name: "publish",
530
+ description: `
531
+ Publish a package to the Powerhouse registry. This is a thin wrapper around npm publish
532
+ that automatically sets the registry URL.
533
+
534
+ This command:
535
+ 1. Resolves the registry URL (--registry flag > PH_REGISTRY_URL env > powerhouse.config.json > default)
536
+ 2. Checks authentication with the registry via npm whoami
537
+ 3. Forwards all additional arguments to npm publish
538
+ `,
539
+ args: publishArgs,
540
+ handler: async (args) => {
541
+ if (args.debug) console.log(args);
542
+ const { getPowerhouseProjectInfo } = await import("@powerhousedao/shared/clis");
543
+ const { projectPath } = await getPowerhouseProjectInfo();
544
+ if (!projectPath) throw new Error("Could not find project path.");
545
+ const { checkNpmAuth, npmPublish, resolveRegistryUrl } = await import("@powerhousedao/shared/registry");
546
+ const { mintRegistryAuthToken } = await import("./registry-auth-BX9_n8hE.mjs");
547
+ const registryUrl = resolveRegistryUrl({
548
+ registry: args.registry,
549
+ projectPath
550
+ });
551
+ if (args.debug) console.log(">>> registryUrl", registryUrl);
552
+ let authToken;
553
+ try {
554
+ authToken = await mintRegistryAuthToken(registryUrl, 300);
555
+ if (args.debug) console.error(`>>> minted renown token for ${registryUrl} (5m TTL)`);
556
+ } catch (err) {
557
+ if (args.debug) console.error(`>>> renown token mint skipped: ${err.message}`);
558
+ try {
559
+ await checkNpmAuth(registryUrl);
560
+ } catch {
561
+ console.error(`Not authenticated with registry: ${registryUrl}`);
562
+ console.error(`Run: ph login (recommended) or npm adduser --registry ${registryUrl}`);
563
+ process.exit(1);
564
+ }
565
+ }
566
+ let forwardedArgs = args.forwardedArgs;
567
+ if (!hasTagFlag(forwardedArgs)) {
568
+ const prereleaseInfo = await readPrereleaseTag(projectPath);
569
+ if (prereleaseInfo) {
570
+ const { version, tag } = prereleaseInfo;
571
+ if (!isInteractive()) {
572
+ console.error(`Detected prerelease version ${version}. npm requires an explicit dist-tag for prerelease publishes.`);
573
+ console.error(`Re-run with --tag <label> (e.g. --tag ${tag}) to proceed.`);
574
+ process.exit(1);
575
+ }
576
+ const enquirer = await import("enquirer");
577
+ let confirmed = false;
578
+ try {
579
+ confirmed = (await enquirer.default.prompt({
580
+ type: "confirm",
581
+ name: "confirmed",
582
+ message: `Detected prerelease version ${version}. Publish with --tag ${tag}?`,
583
+ initial: true
584
+ })).confirmed;
585
+ } catch {
586
+ confirmed = false;
587
+ }
588
+ if (!confirmed) {
589
+ console.error(`Aborted. To publish manually: npm publish --registry ${registryUrl} --tag <label>`);
590
+ process.exit(1);
591
+ }
592
+ forwardedArgs = [
593
+ "--tag",
594
+ tag,
595
+ ...forwardedArgs
596
+ ];
597
+ }
598
+ }
599
+ if (args.debug) console.log(">>> command", `npm publish --registry ${registryUrl} ${forwardedArgs.join(" ")}`);
600
+ console.log(`Publishing to ${registryUrl}...`);
601
+ const result = await npmPublish({
602
+ registryUrl,
603
+ cwd: projectPath,
604
+ args: forwardedArgs,
605
+ authToken
606
+ });
607
+ if (result.stdout) console.log(result.stdout);
608
+ process.exit(0);
609
+ }
610
+ });
611
+ //#endregion
612
+ //#region src/commands/registry-login.ts
613
+ const registryLogin = command({
614
+ name: "registry-login",
615
+ description: `
616
+ Log in to a Powerhouse registry using your Renown identity. Mints a longer-lived
617
+ bearer token (default 30 days) bound to the registry's audience and writes the
618
+ token into ~/.npmrc so raw 'npm publish' / 'npm install' work without further
619
+ setup.
620
+
621
+ Prerequisites:
622
+ Run 'ph login' first to establish a Renown identity.
623
+
624
+ Usage:
625
+ ph registry-login # uses powerhouse.config.json / PH_REGISTRY_URL
626
+ ph registry-login --registry https://registry.dev.vetra.io
627
+ ph registry-login --expiry 7d
628
+ `,
629
+ args: registryLoginArgs,
630
+ handler: async (args) => {
631
+ if (args.debug) console.log(args);
632
+ const { getPowerhouseProjectInfo } = await import("@powerhousedao/shared/clis");
633
+ const projectPath = (await getPowerhouseProjectInfo().catch(() => null))?.projectPath ?? process.cwd();
634
+ const [{ resolveRegistryUrl, writeRegistryAuthToken }, { mintRegistryAuthToken }, { parseExpiry, formatExpiry }] = await Promise.all([
635
+ import("@powerhousedao/shared/registry"),
636
+ import("./registry-auth-BX9_n8hE.mjs"),
637
+ import("@renown/sdk/node")
638
+ ]);
639
+ const registryUrl = resolveRegistryUrl({
640
+ registry: args.registry,
641
+ projectPath
642
+ });
643
+ const expiresIn = parseExpiry(args.expiry);
644
+ const npmrcPath = await writeRegistryAuthToken(registryUrl, await mintRegistryAuthToken(registryUrl, expiresIn));
645
+ console.log(`Logged in to ${registryUrl}`);
646
+ console.log(` Token expires in: ${formatExpiry(expiresIn)}`);
647
+ console.log(` Wrote: ${npmrcPath}`);
648
+ process.exit(0);
649
+ }
650
+ });
651
+ //#endregion
652
+ //#region src/commands/switchboard.ts
653
+ const switchboard = command({
654
+ name: "switchboard",
655
+ aliases: ["reactor"],
656
+ description: `
657
+ The switchboard command starts a local Switchboard instance, which acts as the document
658
+ processing engine for Powerhouse projects. It provides the infrastructure for document
659
+ models, processors, and real-time updates.
660
+
661
+ This command:
662
+ 1. Starts a local switchboard server
663
+ 2. Loads document models and processors
664
+ 3. Provides an API for document operations
665
+ 4. Enables real-time document processing
666
+ 5. Can authenticate with remote services using your identity from 'ph login'`,
667
+ args: switchboardArgs,
668
+ handler: async (args) => {
669
+ if (args.debug) console.log(args);
670
+ const { basePath, dbPath, migrate, migrateStatus } = args;
671
+ if (basePath) process.env.BASE_PATH = basePath;
672
+ if (migrate || migrateStatus) {
673
+ const { runSwitchboardMigrations } = await import("./switchboard-migrate-BRgCgg7N.mjs");
674
+ await runSwitchboardMigrations({
675
+ dbPath,
676
+ statusOnly: migrateStatus
677
+ });
678
+ process.exit(0);
679
+ }
680
+ const { startSwitchboard } = await import("./switchboard-iRFugh8I.mjs");
681
+ const { defaultDriveUrl, renown } = await startSwitchboard(args);
682
+ console.log(" ➜ Switchboard:", defaultDriveUrl);
683
+ if (renown) console.log(" ➜ Identity:", renown.did);
684
+ }
685
+ });
686
+ //#endregion
687
+ //#region src/commands/uninstall.ts
688
+ const uninstall = command({
689
+ name: "uninstall",
690
+ aliases: ["remove"],
691
+ description: `
692
+ The uninstall command removes Powerhouse dependencies from your project. It handles the
693
+ removal of packages, updates configuration files, and ensures proper cleanup.
694
+
695
+ This command:
696
+ 1. Uninstalls specified Powerhouse dependencies using your package manager
697
+ 2. Updates powerhouse.config.json to remove the dependencies
698
+ 3. Supports various uninstallation options and configurations
699
+ 4. Works with ${AGENTS.join(", ")} package managers
700
+ `,
701
+ args: uninstallArgs,
702
+ handler: async (args) => {
703
+ if (args.debug) console.log(args);
704
+ const { getPowerhouseProjectInfo, getPowerhouseProjectUninstallCommand, makeDependenciesWithVersions } = await import("@powerhousedao/shared/clis");
705
+ const { projectPath, localProjectPath, globalProjectPath, packageManager, isGlobal } = await getPowerhouseProjectInfo(args);
706
+ if (!projectPath) throw new Error(`Could not find project path to uninstall from`);
707
+ const dependenciesWithVersions = await makeDependenciesWithVersions(args.dependencies);
708
+ if (args.debug) console.log(">>> parsedDependencies", dependenciesWithVersions);
709
+ if (args.debug) console.log("\n>>> projectInfo", {
710
+ localProjectPath,
711
+ globalProjectPath,
712
+ packageManager,
713
+ isGlobal
714
+ });
715
+ try {
716
+ console.log("Uninstalling dependencies 📦 ...");
717
+ execSync$1(await getPowerhouseProjectUninstallCommand(packageManager), {
718
+ stdio: "inherit",
719
+ cwd: projectPath
720
+ });
721
+ console.log("Dependency uninstalled successfully 🎉");
722
+ } catch (error) {
723
+ console.error("❌ Failed to uninstall dependencies");
724
+ throw error;
725
+ }
726
+ const { removeStylesImports, updateConfigFile } = await import("./utils-DkOZWO0i.mjs");
727
+ try {
728
+ console.log("⚙️ Updating powerhouse config file...");
729
+ updateConfigFile(dependenciesWithVersions, projectPath, "uninstall");
730
+ console.log("Config file updated successfully 🎉");
731
+ } catch (error) {
732
+ console.error("❌ Failed to update config file");
733
+ throw error;
734
+ }
735
+ try {
736
+ console.log("⚙️ Updating styles.css file...");
737
+ removeStylesImports(dependenciesWithVersions, projectPath);
738
+ console.log("Styles file updated successfully 🎉");
739
+ } catch (error) {
740
+ console.error("❌ Failed to update styles file");
741
+ throw error;
742
+ }
743
+ process.exit(0);
744
+ }
745
+ });
746
+ //#endregion
747
+ //#region src/commands/unpublish.ts
748
+ const unpublish = command({
749
+ name: "unpublish",
750
+ description: `
751
+ Unpublish a package from the Powerhouse registry. This is a thin wrapper around
752
+ npm unpublish that automatically targets the Powerhouse registry and never
753
+ reaches npmjs.org.
754
+
755
+ Forms:
756
+ ph unpublish # unpublish <name>@<version> from cwd's package.json
757
+ ph unpublish <name> # unpublish the whole package (all versions)
758
+ ph unpublish <name>@<version> # unpublish a single version
759
+
760
+ Flags:
761
+ --registry <url> # override registry URL
762
+ --yes, -y # skip the confirmation prompt
763
+ `,
764
+ args: unpublishArgs,
765
+ handler: async (args) => {
766
+ if (args.debug) console.log(args);
767
+ const { getPowerhouseProjectInfo } = await import("@powerhousedao/shared/clis");
768
+ const { projectPath } = await getPowerhouseProjectInfo();
769
+ if (!projectPath) throw new Error("Could not find project path.");
770
+ const { checkNpmAuth, npmUnpublish, resolveRegistryUrl } = await import("@powerhousedao/shared/registry");
771
+ const registryUrl = resolveRegistryUrl({
772
+ registry: args.registry,
773
+ projectPath
774
+ });
775
+ const spec = await resolveSpec(args.spec, projectPath);
776
+ if (!spec) {
777
+ console.error("No package spec provided and could not read name/version from package.json.");
778
+ process.exit(1);
779
+ }
780
+ if (args.debug) {
781
+ console.log(">>> registryUrl", registryUrl);
782
+ console.log(">>> spec", spec);
783
+ }
784
+ try {
785
+ await checkNpmAuth(registryUrl);
786
+ } catch {
787
+ console.error(`Not authenticated with registry: ${registryUrl}`);
788
+ console.error(`Run: npm adduser --registry ${registryUrl}`);
789
+ process.exit(1);
790
+ }
791
+ if (!args.yes) {
792
+ if (!await confirm(`Unpublish ${spec} from ${registryUrl}? [y/N] `)) {
793
+ console.log("Aborted.");
794
+ process.exit(0);
795
+ }
796
+ }
797
+ if (args.debug) console.log(">>> command", `npm unpublish ${spec} --registry ${registryUrl} --force ${args.forwardedArgs.join(" ")}`);
798
+ console.log(`Unpublishing ${spec} from ${registryUrl}...`);
799
+ try {
800
+ const result = await npmUnpublish({
801
+ registryUrl,
802
+ cwd: projectPath,
803
+ spec,
804
+ args: args.forwardedArgs
805
+ });
806
+ if (result.stdout) console.log(result.stdout);
807
+ process.exit(0);
808
+ } catch (err) {
809
+ console.error(err instanceof Error ? err.message : String(err));
810
+ process.exit(1);
811
+ }
812
+ }
813
+ });
814
+ async function resolveSpec(explicit, projectPath) {
815
+ if (explicit) return explicit;
816
+ try {
817
+ const { readPackageSync } = await import("read-pkg");
818
+ const pkg = readPackageSync({ cwd: projectPath });
819
+ if (!pkg.name) return null;
820
+ return pkg.version ? `${pkg.name}@${pkg.version}` : pkg.name;
821
+ } catch {
822
+ return null;
823
+ }
824
+ }
825
+ async function confirm(prompt) {
826
+ const rl = createInterface({
827
+ input: process.stdin,
828
+ output: process.stdout
829
+ });
830
+ try {
831
+ const answer = await rl.question(prompt);
832
+ return /^y(es)?$/i.test(answer.trim());
833
+ } finally {
834
+ rl.close();
835
+ }
836
+ }
837
+ //#endregion
838
+ //#region src/commands/ph-cli-commands.ts
839
+ const phCliCommands = {
840
+ init,
841
+ code,
842
+ generate,
843
+ vetra: command({
844
+ name: "vetra",
845
+ description: `
846
+ The vetra command sets up a Vetra development environment for working with Vetra projects.
847
+ It starts a Vetra Switchboard and optionally Connect Studio, enabling document collaboration
848
+ and real-time processing with a "Vetra" drive or connection to remote drives.
849
+
850
+ This command:
851
+ 1. Starts a Vetra Switchboard with a "Vetra" drive for document storage
852
+ 2. Optionally connects to remote drives instead of creating a local drive
853
+ 3. Starts Connect Studio pointing to the Switchboard for user interaction (unless disabled)
854
+ 4. Enables real-time updates, collaboration, and code generation`,
855
+ args: vetraArgs,
856
+ handler: async (args) => {
857
+ if (args.debug) console.log(args);
858
+ const { startVetra } = await import("./vetra-xk2hwf6X.mjs");
859
+ await startVetra(args);
860
+ }
861
+ }),
862
+ connect,
863
+ build: build$1,
864
+ publish,
865
+ unpublish,
866
+ "access-token": accessToken,
867
+ "registry-login": registryLogin,
868
+ inspect,
869
+ list,
870
+ migrate,
871
+ switchboard,
872
+ login,
873
+ logout,
874
+ install,
875
+ uninstall
876
+ };
877
+ const phCli = subcommands({
878
+ name: "ph-cli",
879
+ description: PH_CLI_DESCRIPTION,
880
+ version: getVersion(),
881
+ cmds: phCliCommands
882
+ });
883
+ //#endregion
884
+ //#region src/cli.ts
885
+ async function main() {
886
+ assertNodeVersion();
887
+ await initCliTelemetry({
888
+ cliName: "ph-cli",
889
+ release: getVersion()
890
+ });
891
+ const args = process.argv.slice(2);
892
+ const hasNoArgs = args.length === 0;
893
+ const isHelp = args.some((arg) => arg === "--help" || arg === "-h");
894
+ const isTopLevelHelp = isHelp && args.length === 1;
895
+ const cli = hasNoArgs || isTopLevelHelp ? phCliHelp : phCli;
896
+ const [command, ...restArgs] = args;
897
+ if (command === "connect" && ![
898
+ "studio",
899
+ "build",
900
+ "preview"
901
+ ].includes(args[1]) && !isHelp) await run(cli, [
902
+ "connect",
903
+ "studio",
904
+ ...restArgs
905
+ ]);
906
+ else await run(cli, args);
907
+ }
908
+ await main().catch(async (error) => {
909
+ const isDebug = process.argv.slice(2).includes("--debug");
910
+ await captureCliError(error);
911
+ if (isDebug) throw error;
912
+ if (error instanceof Error) {
913
+ console.error(error.message);
914
+ process.exit(1);
915
+ } else throw error;
916
+ });
917
+ //#endregion
918
+ export {};
919
+
920
+ //# sourceMappingURL=cli.mjs.map