@powerhousedao/ph-cli 6.0.0-dev.19 → 6.0.0-dev.191

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 (291) hide show
  1. package/dist/assign-env-vars-CzHgn5ax.mjs +15 -0
  2. package/dist/assign-env-vars-CzHgn5ax.mjs.map +1 -0
  3. package/dist/auth-wgUd0D0V.mjs +15 -0
  4. package/dist/auth-wgUd0D0V.mjs.map +1 -0
  5. package/dist/build-BflSHYLP.mjs +33 -0
  6. package/dist/build-BflSHYLP.mjs.map +1 -0
  7. package/dist/cli.d.mts +1 -0
  8. package/dist/cli.mjs +675 -0
  9. package/dist/cli.mjs.map +1 -0
  10. package/dist/connect-build-oDJKd0aN.mjs +35 -0
  11. package/dist/connect-build-oDJKd0aN.mjs.map +1 -0
  12. package/dist/connect-preview-4Xe7Lm1V.mjs +27 -0
  13. package/dist/connect-preview-4Xe7Lm1V.mjs.map +1 -0
  14. package/dist/connect-studio-38_NrT_a.mjs +28 -0
  15. package/dist/connect-studio-38_NrT_a.mjs.map +1 -0
  16. package/dist/connect-studio-DuH6WcoA.mjs +3 -0
  17. package/dist/generate-DXDBhwoJ.mjs +58 -0
  18. package/dist/generate-DXDBhwoJ.mjs.map +1 -0
  19. package/dist/generate-Dokvf5Zu.mjs +2 -0
  20. package/dist/init-BsmDWu9-.mjs +124 -0
  21. package/dist/init-BsmDWu9-.mjs.map +1 -0
  22. package/dist/inspect-BMrHr09E.mjs +45 -0
  23. package/dist/inspect-BMrHr09E.mjs.map +1 -0
  24. package/dist/migrate-N4b2DpVP.mjs +245 -0
  25. package/dist/migrate-N4b2DpVP.mjs.map +1 -0
  26. package/dist/scripts/generate-commands-docs.ts +2 -8
  27. package/dist/switchboard-Bht39Myv.mjs +2 -0
  28. package/dist/switchboard-DBqOSS0c.mjs +72 -0
  29. package/dist/switchboard-DBqOSS0c.mjs.map +1 -0
  30. package/dist/switchboard-migrate-1lOCPmX0.mjs +50 -0
  31. package/dist/switchboard-migrate-1lOCPmX0.mjs.map +1 -0
  32. package/dist/utils-CFkM2mAC.mjs +161 -0
  33. package/dist/utils-CFkM2mAC.mjs.map +1 -0
  34. package/dist/vetra-vUDKNfbX.mjs +360 -0
  35. package/dist/vetra-vUDKNfbX.mjs.map +1 -0
  36. package/package.json +38 -46
  37. package/dist/scripts/generate-commands-docs.d.ts +0 -2
  38. package/dist/scripts/generate-commands-docs.d.ts.map +0 -1
  39. package/dist/scripts/generate-commands-docs.js +0 -47
  40. package/dist/scripts/generate-commands-docs.js.map +0 -1
  41. package/dist/scripts/generate-docs-legacy.d.ts +0 -2
  42. package/dist/scripts/generate-docs-legacy.d.ts.map +0 -1
  43. package/dist/scripts/generate-docs-legacy.js +0 -72
  44. package/dist/scripts/generate-docs-legacy.js.map +0 -1
  45. package/dist/scripts/generate-docs-legacy.ts +0 -84
  46. package/dist/scripts/generate-version.d.ts +0 -2
  47. package/dist/scripts/generate-version.d.ts.map +0 -1
  48. package/dist/scripts/generate-version.js +0 -13
  49. package/dist/scripts/generate-version.js.map +0 -1
  50. package/dist/scripts/generate-version.ts +0 -22
  51. package/dist/src/cli.d.ts +0 -3
  52. package/dist/src/cli.d.ts.map +0 -1
  53. package/dist/src/cli.js +0 -29
  54. package/dist/src/cli.js.map +0 -1
  55. package/dist/src/cli.old.d.ts +0 -3
  56. package/dist/src/cli.old.d.ts.map +0 -1
  57. package/dist/src/cli.old.js +0 -43
  58. package/dist/src/cli.old.js.map +0 -1
  59. package/dist/src/commands/access-token.d.ts +0 -14
  60. package/dist/src/commands/access-token.d.ts.map +0 -1
  61. package/dist/src/commands/access-token.js +0 -142
  62. package/dist/src/commands/access-token.js.map +0 -1
  63. package/dist/src/commands/connect.d.ts +0 -249
  64. package/dist/src/commands/connect.d.ts.map +0 -1
  65. package/dist/src/commands/connect.js +0 -60
  66. package/dist/src/commands/connect.js.map +0 -1
  67. package/dist/src/commands/generate.d.ts +0 -58
  68. package/dist/src/commands/generate.d.ts.map +0 -1
  69. package/dist/src/commands/generate.js +0 -25
  70. package/dist/src/commands/generate.js.map +0 -1
  71. package/dist/src/commands/get-package-manager.d.ts +0 -30
  72. package/dist/src/commands/get-package-manager.d.ts.map +0 -1
  73. package/dist/src/commands/get-package-manager.js +0 -8
  74. package/dist/src/commands/get-package-manager.js.map +0 -1
  75. package/dist/src/commands/index.d.ts +0 -13
  76. package/dist/src/commands/index.d.ts.map +0 -1
  77. package/dist/src/commands/index.js +0 -25
  78. package/dist/src/commands/index.js.map +0 -1
  79. package/dist/src/commands/inspect.d.ts +0 -12
  80. package/dist/src/commands/inspect.d.ts.map +0 -1
  81. package/dist/src/commands/inspect.js +0 -27
  82. package/dist/src/commands/inspect.js.map +0 -1
  83. package/dist/src/commands/install.d.ts +0 -22
  84. package/dist/src/commands/install.d.ts.map +0 -1
  85. package/dist/src/commands/install.js +0 -75
  86. package/dist/src/commands/install.js.map +0 -1
  87. package/dist/src/commands/legacy/access-token.old.d.ts +0 -9
  88. package/dist/src/commands/legacy/access-token.old.d.ts.map +0 -1
  89. package/dist/src/commands/legacy/access-token.old.js +0 -110
  90. package/dist/src/commands/legacy/access-token.old.js.map +0 -1
  91. package/dist/src/commands/legacy/connect.old.d.ts +0 -19
  92. package/dist/src/commands/legacy/connect.old.d.ts.map +0 -1
  93. package/dist/src/commands/legacy/connect.old.js +0 -85
  94. package/dist/src/commands/legacy/connect.old.js.map +0 -1
  95. package/dist/src/commands/legacy/generate.old.d.ts +0 -9
  96. package/dist/src/commands/legacy/generate.old.d.ts.map +0 -1
  97. package/dist/src/commands/legacy/generate.old.js +0 -41
  98. package/dist/src/commands/legacy/generate.old.js.map +0 -1
  99. package/dist/src/commands/legacy/help.old.d.ts +0 -3
  100. package/dist/src/commands/legacy/help.old.d.ts.map +0 -1
  101. package/dist/src/commands/legacy/help.old.js +0 -9
  102. package/dist/src/commands/legacy/help.old.js.map +0 -1
  103. package/dist/src/commands/legacy/inspect.old.d.ts +0 -6
  104. package/dist/src/commands/legacy/inspect.old.d.ts.map +0 -1
  105. package/dist/src/commands/legacy/inspect.old.js +0 -21
  106. package/dist/src/commands/legacy/inspect.old.js.map +0 -1
  107. package/dist/src/commands/legacy/install.old.d.ts +0 -15
  108. package/dist/src/commands/legacy/install.old.d.ts.map +0 -1
  109. package/dist/src/commands/legacy/install.old.js +0 -127
  110. package/dist/src/commands/legacy/install.old.js.map +0 -1
  111. package/dist/src/commands/legacy/login.old.d.ts +0 -12
  112. package/dist/src/commands/legacy/login.old.d.ts.map +0 -1
  113. package/dist/src/commands/legacy/login.old.js +0 -208
  114. package/dist/src/commands/legacy/login.old.js.map +0 -1
  115. package/dist/src/commands/legacy/migrate.old.d.ts +0 -11
  116. package/dist/src/commands/legacy/migrate.old.d.ts.map +0 -1
  117. package/dist/src/commands/legacy/migrate.old.js +0 -15
  118. package/dist/src/commands/legacy/migrate.old.js.map +0 -1
  119. package/dist/src/commands/legacy/service.old.d.ts +0 -5
  120. package/dist/src/commands/legacy/service.old.d.ts.map +0 -1
  121. package/dist/src/commands/legacy/service.old.js +0 -67
  122. package/dist/src/commands/legacy/service.old.js.map +0 -1
  123. package/dist/src/commands/legacy/switchboard.old.d.ts +0 -9
  124. package/dist/src/commands/legacy/switchboard.old.d.ts.map +0 -1
  125. package/dist/src/commands/legacy/switchboard.old.js +0 -78
  126. package/dist/src/commands/legacy/switchboard.old.js.map +0 -1
  127. package/dist/src/commands/legacy/uninstall.old.d.ts +0 -15
  128. package/dist/src/commands/legacy/uninstall.old.d.ts.map +0 -1
  129. package/dist/src/commands/legacy/uninstall.old.js +0 -120
  130. package/dist/src/commands/legacy/uninstall.old.js.map +0 -1
  131. package/dist/src/commands/legacy/vetra.old.d.ts +0 -23
  132. package/dist/src/commands/legacy/vetra.old.d.ts.map +0 -1
  133. package/dist/src/commands/legacy/vetra.old.js +0 -35
  134. package/dist/src/commands/legacy/vetra.old.js.map +0 -1
  135. package/dist/src/commands/list.d.ts +0 -10
  136. package/dist/src/commands/list.d.ts.map +0 -1
  137. package/dist/src/commands/list.js +0 -42
  138. package/dist/src/commands/list.js.map +0 -1
  139. package/dist/src/commands/list.old.d.ts +0 -9
  140. package/dist/src/commands/list.old.d.ts.map +0 -1
  141. package/dist/src/commands/list.old.js +0 -36
  142. package/dist/src/commands/list.old.js.map +0 -1
  143. package/dist/src/commands/login.d.ts +0 -20
  144. package/dist/src/commands/login.d.ts.map +0 -1
  145. package/dist/src/commands/login.js +0 -209
  146. package/dist/src/commands/login.js.map +0 -1
  147. package/dist/src/commands/migrate.d.ts +0 -12
  148. package/dist/src/commands/migrate.d.ts.map +0 -1
  149. package/dist/src/commands/migrate.js +0 -16
  150. package/dist/src/commands/migrate.js.map +0 -1
  151. package/dist/src/commands/ph-cli-commands.d.ts +0 -410
  152. package/dist/src/commands/ph-cli-commands.d.ts.map +0 -1
  153. package/dist/src/commands/ph-cli-commands.js +0 -25
  154. package/dist/src/commands/ph-cli-commands.js.map +0 -1
  155. package/dist/src/commands/ph-cli-help.d.ts +0 -396
  156. package/dist/src/commands/ph-cli-help.d.ts.map +0 -1
  157. package/dist/src/commands/ph-cli-help.js +0 -12
  158. package/dist/src/commands/ph-cli-help.js.map +0 -1
  159. package/dist/src/commands/ph-cli.d.ts +0 -490
  160. package/dist/src/commands/ph-cli.d.ts.map +0 -1
  161. package/dist/src/commands/ph-cli.js +0 -12
  162. package/dist/src/commands/ph-cli.js.map +0 -1
  163. package/dist/src/commands/register-commands.d.ts +0 -5
  164. package/dist/src/commands/register-commands.d.ts.map +0 -1
  165. package/dist/src/commands/register-commands.js +0 -32
  166. package/dist/src/commands/register-commands.js.map +0 -1
  167. package/dist/src/commands/service.d.ts +0 -12
  168. package/dist/src/commands/service.d.ts.map +0 -1
  169. package/dist/src/commands/service.js +0 -79
  170. package/dist/src/commands/service.js.map +0 -1
  171. package/dist/src/commands/switchboard.d.ts +0 -46
  172. package/dist/src/commands/switchboard.d.ts.map +0 -1
  173. package/dist/src/commands/switchboard.js +0 -43
  174. package/dist/src/commands/switchboard.js.map +0 -1
  175. package/dist/src/commands/uninstall.d.ts +0 -22
  176. package/dist/src/commands/uninstall.d.ts.map +0 -1
  177. package/dist/src/commands/uninstall.js +0 -71
  178. package/dist/src/commands/uninstall.js.map +0 -1
  179. package/dist/src/commands/vetra.d.ts +0 -64
  180. package/dist/src/commands/vetra.d.ts.map +0 -1
  181. package/dist/src/commands/vetra.js +0 -24
  182. package/dist/src/commands/vetra.js.map +0 -1
  183. package/dist/src/get-version.d.ts +0 -2
  184. package/dist/src/get-version.d.ts.map +0 -1
  185. package/dist/src/get-version.js +0 -7
  186. package/dist/src/get-version.js.map +0 -1
  187. package/dist/src/help.d.ts +0 -65
  188. package/dist/src/help.d.ts.map +0 -1
  189. package/dist/src/help.js +0 -770
  190. package/dist/src/help.js.map +0 -1
  191. package/dist/src/index.d.ts +0 -4
  192. package/dist/src/index.d.ts.map +0 -1
  193. package/dist/src/index.js +0 -4
  194. package/dist/src/index.js.map +0 -1
  195. package/dist/src/services/auth.d.ts +0 -69
  196. package/dist/src/services/auth.d.ts.map +0 -1
  197. package/dist/src/services/auth.js +0 -171
  198. package/dist/src/services/auth.js.map +0 -1
  199. package/dist/src/services/connect.d.ts +0 -5
  200. package/dist/src/services/connect.d.ts.map +0 -1
  201. package/dist/src/services/connect.js +0 -90
  202. package/dist/src/services/connect.js.map +0 -1
  203. package/dist/src/services/generate.d.ts +0 -3
  204. package/dist/src/services/generate.d.ts.map +0 -1
  205. package/dist/src/services/generate.js +0 -80
  206. package/dist/src/services/generate.js.map +0 -1
  207. package/dist/src/services/inspect.d.ts +0 -3
  208. package/dist/src/services/inspect.d.ts.map +0 -1
  209. package/dist/src/services/inspect.js +0 -50
  210. package/dist/src/services/inspect.js.map +0 -1
  211. package/dist/src/services/legacy/connect.old.d.ts +0 -2
  212. package/dist/src/services/legacy/connect.old.d.ts.map +0 -1
  213. package/dist/src/services/legacy/connect.old.js +0 -2
  214. package/dist/src/services/legacy/connect.old.js.map +0 -1
  215. package/dist/src/services/legacy/generate.old.d.ts +0 -30
  216. package/dist/src/services/legacy/generate.old.d.ts.map +0 -1
  217. package/dist/src/services/legacy/generate.old.js +0 -107
  218. package/dist/src/services/legacy/generate.old.js.map +0 -1
  219. package/dist/src/services/legacy/inspect.old.d.ts +0 -5
  220. package/dist/src/services/legacy/inspect.old.d.ts.map +0 -1
  221. package/dist/src/services/legacy/inspect.old.js +0 -49
  222. package/dist/src/services/legacy/inspect.old.js.map +0 -1
  223. package/dist/src/services/legacy/migrate.old.d.ts +0 -3
  224. package/dist/src/services/legacy/migrate.old.d.ts.map +0 -1
  225. package/dist/src/services/legacy/migrate.old.js +0 -289
  226. package/dist/src/services/legacy/migrate.old.js.map +0 -1
  227. package/dist/src/services/legacy/switchboard.old.d.ts +0 -54
  228. package/dist/src/services/legacy/switchboard.old.d.ts.map +0 -1
  229. package/dist/src/services/legacy/switchboard.old.js +0 -79
  230. package/dist/src/services/legacy/switchboard.old.js.map +0 -1
  231. package/dist/src/services/legacy/vetra.old.d.ts +0 -15
  232. package/dist/src/services/legacy/vetra.old.d.ts.map +0 -1
  233. package/dist/src/services/legacy/vetra.old.js +0 -176
  234. package/dist/src/services/legacy/vetra.old.js.map +0 -1
  235. package/dist/src/services/migrate.d.ts +0 -3
  236. package/dist/src/services/migrate.d.ts.map +0 -1
  237. package/dist/src/services/migrate.js +0 -327
  238. package/dist/src/services/migrate.js.map +0 -1
  239. package/dist/src/services/switchboard-migrate.d.ts +0 -7
  240. package/dist/src/services/switchboard-migrate.d.ts.map +0 -1
  241. package/dist/src/services/switchboard-migrate.js +0 -60
  242. package/dist/src/services/switchboard-migrate.js.map +0 -1
  243. package/dist/src/services/switchboard.d.ts +0 -22
  244. package/dist/src/services/switchboard.d.ts.map +0 -1
  245. package/dist/src/services/switchboard.js +0 -77
  246. package/dist/src/services/switchboard.js.map +0 -1
  247. package/dist/src/services/vetra.d.ts +0 -3
  248. package/dist/src/services/vetra.d.ts.map +0 -1
  249. package/dist/src/services/vetra.js +0 -169
  250. package/dist/src/services/vetra.js.map +0 -1
  251. package/dist/src/types.d.ts +0 -31
  252. package/dist/src/types.d.ts.map +0 -1
  253. package/dist/src/types.js +0 -2
  254. package/dist/src/types.js.map +0 -1
  255. package/dist/src/utils/configure-vetra-github-url.d.ts +0 -12
  256. package/dist/src/utils/configure-vetra-github-url.d.ts.map +0 -1
  257. package/dist/src/utils/configure-vetra-github-url.js +0 -230
  258. package/dist/src/utils/configure-vetra-github-url.js.map +0 -1
  259. package/dist/src/utils/constants.d.ts +0 -2
  260. package/dist/src/utils/constants.d.ts.map +0 -1
  261. package/dist/src/utils/constants.js +0 -2
  262. package/dist/src/utils/constants.js.map +0 -1
  263. package/dist/src/utils/file-system.d.ts +0 -2
  264. package/dist/src/utils/file-system.d.ts.map +0 -1
  265. package/dist/src/utils/file-system.js +0 -15
  266. package/dist/src/utils/file-system.js.map +0 -1
  267. package/dist/src/utils/index.d.ts +0 -3
  268. package/dist/src/utils/index.d.ts.map +0 -1
  269. package/dist/src/utils/index.js +0 -3
  270. package/dist/src/utils/index.js.map +0 -1
  271. package/dist/src/utils/projects.d.ts +0 -19
  272. package/dist/src/utils/projects.d.ts.map +0 -1
  273. package/dist/src/utils/projects.js +0 -93
  274. package/dist/src/utils/projects.js.map +0 -1
  275. package/dist/src/utils.d.ts +0 -112
  276. package/dist/src/utils.d.ts.map +0 -1
  277. package/dist/src/utils.js +0 -261
  278. package/dist/src/utils.js.map +0 -1
  279. package/dist/src/version.d.ts +0 -2
  280. package/dist/src/version.d.ts.map +0 -1
  281. package/dist/src/version.js +0 -3
  282. package/dist/src/version.js.map +0 -1
  283. package/dist/test/utils.test.d.ts +0 -2
  284. package/dist/test/utils.test.d.ts.map +0 -1
  285. package/dist/test/utils.test.js +0 -133
  286. package/dist/test/utils.test.js.map +0 -1
  287. package/dist/tsconfig.tsbuildinfo +0 -1
  288. package/dist/vitest.config.d.ts +0 -3
  289. package/dist/vitest.config.d.ts.map +0 -1
  290. package/dist/vitest.config.js +0 -7
  291. package/dist/vitest.config.js.map +0 -1
package/dist/cli.mjs ADDED
@@ -0,0 +1,675 @@
1
+ #!/usr/bin/env node
2
+ import { t as runBuild } from "./build-BflSHYLP.mjs";
3
+ import { a as updateStylesFile, i as updateConfigFile, r as removeStylesImports } from "./utils-CFkM2mAC.mjs";
4
+ import { DEFAULT_EXPIRY_SECONDS, accessTokenArgs, assertNodeVersion, buildArgs, captureCliError, connectBuildArgs, connectPreviewArgs, connectStudioArgs, generateArgs, getPowerhouseProjectInfo, getPowerhouseProjectUninstallCommand, initArgs, initCliTelemetry, inspectArgs, installArgs, listArgs, loginArgs, makeDependenciesWithVersions, migrateArgs, phCliHelpCommands, publishArgs, switchboardArgs, uninstallArgs, vetraArgs } from "@powerhousedao/shared/clis";
5
+ import { command, run, subcommands } from "cmd-ts";
6
+ import { AGENTS, resolveCommand } from "package-manager-detector";
7
+ import { checkNpmAuth, npmPublish, resolveRegistryUrl } from "@powerhousedao/shared/registry";
8
+ import { execSync } from "child_process";
9
+ import { getConfig as getConfig$1 } from "@powerhousedao/config/node";
10
+ //#region src/get-version.ts
11
+ function getVersion() {
12
+ return process.env.WORKSPACE_VERSION || process.env.npm_package_version || "unknown";
13
+ }
14
+ //#endregion
15
+ //#region src/utils/constants.ts
16
+ 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.";
17
+ const phCliHelp = subcommands({
18
+ name: "ph-cli",
19
+ description: PH_CLI_DESCRIPTION,
20
+ version: getVersion(),
21
+ cmds: phCliHelpCommands
22
+ });
23
+ //#endregion
24
+ //#region src/commands/access-token.ts
25
+ const accessToken = command({
26
+ name: "access-token",
27
+ description: `
28
+ The access-token command generates a bearer token for API authentication. This token
29
+ can be used to authenticate requests to Powerhouse APIs like reactor-api (Switchboard).
30
+
31
+ This command:
32
+ 1. Uses your CLI's cryptographic identity (DID) to sign a verifiable credential
33
+ 2. Creates a JWT bearer token with configurable expiration
34
+ 3. Outputs the token to stdout (info to stderr) for easy piping
35
+
36
+ Prerequisites:
37
+ You must have a cryptographic identity. Run 'ph login' first to:
38
+ - Generate a keypair (stored in .ph/.keypair.json)
39
+ - Optionally link your Ethereum address (stored in .ph/.renown.json)
40
+
41
+ Token Details:
42
+ The generated token is a JWT (JSON Web Token) containing:
43
+ - Issuer (iss): Your CLI's DID (did:key:...)
44
+ - Subject (sub): Your CLI's DID
45
+ - Credential Subject: Chain ID, network ID, and address (if authenticated)
46
+ - Expiration (exp): Based on --expiry option
47
+ - Audience (aud): If --audience is specified
48
+
49
+ Output:
50
+ - Token information (DID, address, expiry) is printed to stderr
51
+ - The token itself is printed to stdout for easy piping/copying
52
+
53
+ This allows you to use the command in scripts:
54
+ TOKEN=$(ph access-token)
55
+ curl -H "Authorization: Bearer $TOKEN" http://localhost:4001/graphql
56
+
57
+ Usage with APIs:
58
+ Generate token and use with curl
59
+ TOKEN=$(ph access-token --expiry 1d)
60
+ curl -X POST http://localhost:4001/graphql \\
61
+ -H "Content-Type: application/json" \\
62
+ -H "Authorization: Bearer $TOKEN" \\
63
+ -d '{"query": "{ drives { id name } }"}'
64
+
65
+ Export as environment variable
66
+ export PH_ACCESS_TOKEN=$(ph access-token)
67
+
68
+ Notes:
69
+ - Tokens are self-signed using your CLI's private key
70
+ - No network request is made; tokens are generated locally
71
+ - The recipient API must trust your CLI's DID to accept the token
72
+ - For reactor-api, ensure AUTH_ENABLED=true to require authentication
73
+ `,
74
+ args: accessTokenArgs,
75
+ handler: async (args) => {
76
+ if (args.debug) console.log(args);
77
+ const { generateAccessToken, parseExpiry, formatExpiry } = await import("@renown/sdk/node");
78
+ const { getRenown } = await import("./auth-wgUd0D0V.mjs");
79
+ const renown = await getRenown();
80
+ let expiresIn = DEFAULT_EXPIRY_SECONDS;
81
+ if (args.expiry) expiresIn = parseExpiry(args.expiry);
82
+ const result = await generateAccessToken(renown, {
83
+ expiresIn,
84
+ aud: args.audience
85
+ });
86
+ console.error(`CLI DID: ${result.did}`);
87
+ console.error(`ETH Address: ${result.address}`);
88
+ console.error(`Token expires in: ${formatExpiry(expiresIn)}`);
89
+ console.error("");
90
+ console.log(result.token);
91
+ process.exit(0);
92
+ }
93
+ });
94
+ //#endregion
95
+ //#region src/commands/build.ts
96
+ const build$1 = command({
97
+ name: "build",
98
+ args: buildArgs,
99
+ handler: async (args) => {
100
+ if (args.debug) console.log(args);
101
+ try {
102
+ await runBuild(args);
103
+ } catch (error) {
104
+ console.error(error);
105
+ process.exit(1);
106
+ }
107
+ }
108
+ });
109
+ const connect = subcommands({
110
+ name: "connect",
111
+ description: `Powerhouse Connect commands. Use with \`studio\`, \`build\` or \`preview\`. Defaults to \`studio\` if not specified.`,
112
+ cmds: {
113
+ studio: command({
114
+ name: "studio",
115
+ description: `The studio command starts the Connect Studio, a development environment for building
116
+ and testing Powerhouse applications. It provides a visual interface for working with
117
+ your project.
118
+
119
+ This command:
120
+ 1. Starts a local Connect Studio server
121
+ 2. Provides a web interface for development
122
+ 3. Allows you to interact with your project components
123
+ 4. Supports various configuration options for customization
124
+ `,
125
+ args: connectStudioArgs,
126
+ handler: async (args) => {
127
+ if (args.debug) console.log(args);
128
+ const { runConnectStudio } = await import("./connect-studio-DuH6WcoA.mjs");
129
+ await runConnectStudio(args);
130
+ }
131
+ }),
132
+ build: command({
133
+ name: "build",
134
+ description: `The Connect build command creates a production build with the project's local and
135
+ external packages included
136
+ `,
137
+ args: connectBuildArgs,
138
+ handler: async (args) => {
139
+ if (args.debug) console.log(args);
140
+ const { runConnectBuild } = await import("./connect-build-oDJKd0aN.mjs");
141
+ await runConnectBuild(args);
142
+ process.exit(0);
143
+ }
144
+ }),
145
+ preview: command({
146
+ name: "preview",
147
+ description: `The Connect preview command previews a built Connect project.
148
+ NOTE: You must run \`ph connect build\` first
149
+ `,
150
+ args: connectPreviewArgs,
151
+ handler: async (args) => {
152
+ if (args.debug) console.log(args);
153
+ const { runConnectPreview } = await import("./connect-preview-4Xe7Lm1V.mjs");
154
+ await runConnectPreview(args);
155
+ }
156
+ })
157
+ }
158
+ });
159
+ //#endregion
160
+ //#region src/commands/generate.ts
161
+ const generate = command({
162
+ name: "generate",
163
+ description: `
164
+ The generate command creates code from document models. It helps you build editors,
165
+ processors, and other components based on your document model files.
166
+
167
+ This command:
168
+ 1. Reads document model definitions
169
+ 2. Generates code for specified components (editors, processors, etc.)
170
+ 3. Supports customization of output and generation options
171
+ 4. Can watch files for changes and regenerate code automatically
172
+ `,
173
+ args: generateArgs,
174
+ handler: async (args) => {
175
+ if (args.debug) console.log(args);
176
+ const { startGenerate } = await import("./generate-Dokvf5Zu.mjs");
177
+ await startGenerate(args);
178
+ process.exit(0);
179
+ }
180
+ });
181
+ //#endregion
182
+ //#region src/commands/init.ts
183
+ const init = command({
184
+ name: "init",
185
+ description: "Initialize a new project",
186
+ args: initArgs,
187
+ handler: async (args) => {
188
+ if (args.debug) console.log({ args });
189
+ const { startInit } = await import("./init-BsmDWu9-.mjs");
190
+ await startInit(args);
191
+ process.exit(0);
192
+ }
193
+ });
194
+ //#endregion
195
+ //#region src/commands/inspect.ts
196
+ const inspect = command({
197
+ name: "inspect",
198
+ description: `
199
+ The inspect command examines and provides detailed information about a Powerhouse package.
200
+ It helps you understand the structure, dependencies, and configuration of packages in
201
+ your project.
202
+
203
+ This command:
204
+ 1. Analyzes the specified package
205
+ 2. Retrieves detailed information about its structure and configuration
206
+ 3. Displays package metadata, dependencies, and other relevant information
207
+ 4. Helps troubleshoot package-related issues`,
208
+ aliases: ["is"],
209
+ args: inspectArgs,
210
+ handler: async (args) => {
211
+ if (args.debug) console.log(args);
212
+ const { startInspect } = await import("./inspect-BMrHr09E.mjs");
213
+ startInspect(args);
214
+ process.exit(0);
215
+ }
216
+ });
217
+ //#endregion
218
+ //#region src/commands/install.ts
219
+ const install = command({
220
+ name: "install",
221
+ aliases: ["add", "i"],
222
+ description: `
223
+ The install command adds Powerhouse dependencies to your project.
224
+
225
+ By default it only registers the package in powerhouse.config.json with
226
+ provider "registry" — Connect will load it from the registry CDN at runtime.
227
+
228
+ With --local, the package is also installed into node_modules and marked
229
+ as provider "local" — it will be bundled into ph connect build so the
230
+ preview works without the registry being reachable.
231
+
232
+ Resolution order for the registry URL:
233
+ --registry flag > PH_REGISTRY_URL env > powerhouse.config.json > default
234
+ `,
235
+ args: installArgs,
236
+ handler: async (args) => {
237
+ if (args.debug) console.log(args);
238
+ const { projectPath, localProjectPath, globalProjectPath, packageManager, isGlobal } = await getPowerhouseProjectInfo(args);
239
+ if (!projectPath) throw new Error(`Could not find project path to install from.`);
240
+ const registryUrl = resolveRegistryUrl({
241
+ registry: args.registry,
242
+ projectPath
243
+ });
244
+ if (args.debug) console.log(">>> registryUrl", registryUrl);
245
+ const dependenciesWithVersions = await makeDependenciesWithVersions(args.dependencies, registryUrl);
246
+ if (args.debug) {
247
+ console.log(">>> parsedDependencies", dependenciesWithVersions);
248
+ console.log("\n>>> projectInfo", {
249
+ localProjectPath,
250
+ globalProjectPath,
251
+ packageManager,
252
+ isGlobal
253
+ });
254
+ }
255
+ if (args.local) {
256
+ if (dependenciesWithVersions.length === 0) throw new Error("--local requires at least one package name (e.g. ph install --local @scope/pkg)");
257
+ try {
258
+ const specs = dependenciesWithVersions.map((d) => d.version ? `${d.name}@${d.version}` : d.name);
259
+ const scopes = /* @__PURE__ */ new Set();
260
+ for (const dep of dependenciesWithVersions) if (dep.name.startsWith("@")) {
261
+ const scope = dep.name.split("/")[0];
262
+ scopes.add(scope);
263
+ }
264
+ const scopeRegistryArgs = Array.from(scopes).map((scope) => `--${scope}:registry=${registryUrl}`);
265
+ const resolved = resolveCommand(packageManager, "add", [...specs, ...scopeRegistryArgs]);
266
+ if (!resolved) throw new Error(`Failed to resolve install command for package manager "${packageManager}".`);
267
+ const installCommand = `${resolved.command} ${resolved.args.join(" ")}`;
268
+ if (scopeRegistryArgs.length > 0) console.log(`Installing dependencies 📦 (routing ${Array.from(scopes).join(", ")} → ${registryUrl})...`);
269
+ else console.log("Installing dependencies 📦...");
270
+ console.log(`> ${installCommand}`);
271
+ execSync(installCommand, {
272
+ stdio: "inherit",
273
+ cwd: projectPath
274
+ });
275
+ console.log("Dependency installed successfully 🎉");
276
+ } catch (error) {
277
+ console.error("❌ Failed to install dependencies");
278
+ throw error;
279
+ }
280
+ }
281
+ try {
282
+ console.log("⚙️ Updating powerhouse config file...");
283
+ updateConfigFile(dependenciesWithVersions, projectPath, "install", args.local ? "local" : "registry");
284
+ console.log("Config file updated successfully 🎉");
285
+ } catch (error) {
286
+ console.error("❌ Failed to update config file");
287
+ throw error;
288
+ }
289
+ if (args.local) try {
290
+ console.log("⚙️ Updating styles.css file...");
291
+ updateStylesFile(dependenciesWithVersions, projectPath);
292
+ console.log("Styles file updated successfully 🎉");
293
+ } catch (error) {
294
+ console.error("❌ Failed to update styles file");
295
+ throw error;
296
+ }
297
+ process.exit(0);
298
+ }
299
+ });
300
+ //#endregion
301
+ //#region src/commands/list.ts
302
+ const list = command({
303
+ name: "list",
304
+ description: `
305
+ The list command displays information about installed Powerhouse packages in your project.
306
+ It reads the powerhouse.config.json file and shows the packages that are currently installed.
307
+
308
+ This command:
309
+ 1. Examines your project configuration
310
+ 2. Lists all installed Powerhouse packages
311
+ 3. Provides a clear overview of your project's dependencies
312
+ 4. Helps you manage and track your Powerhouse components
313
+ `,
314
+ aliases: ["l"],
315
+ args: listArgs,
316
+ handler: async (args) => {
317
+ if (args.debug) console.log(args);
318
+ try {
319
+ const projectInfo = await getPowerhouseProjectInfo();
320
+ console.log("\n>>> projectInfo", projectInfo);
321
+ const phConfig = getConfig$1(projectInfo.projectPath + "/powerhouse.config.json");
322
+ if (!phConfig.packages || phConfig.packages.length === 0) {
323
+ console.log("No packages found in the project");
324
+ return;
325
+ }
326
+ console.log("Installed Packages:\n");
327
+ phConfig.packages.forEach((pkg) => {
328
+ console.log(pkg.packageName);
329
+ });
330
+ } catch (e) {
331
+ console.log("No packages found in the project");
332
+ }
333
+ process.exit(0);
334
+ }
335
+ });
336
+ //#endregion
337
+ //#region src/commands/login.ts
338
+ const login = command({
339
+ name: "login",
340
+ description: `
341
+ The login command authenticates you with Renown using your Ethereum wallet. This enables
342
+ the CLI to act on behalf of your Ethereum identity for authenticated operations.
343
+
344
+ This command:
345
+ 1. Generates or loads a cryptographic identity (DID) for the CLI
346
+ 2. Opens your browser to the Renown authentication page
347
+ 3. You authorize the CLI's DID to act on behalf of your Ethereum address
348
+ 4. Stores the credentials locally in .ph/.renown.json
349
+ `,
350
+ args: loginArgs,
351
+ handler: async (args) => {
352
+ if (args.debug) console.log(args);
353
+ const { getRenown } = await import("./auth-wgUd0D0V.mjs");
354
+ const renown = await getRenown(args.renownUrl);
355
+ if (args.showDid) {
356
+ console.log(renown.did);
357
+ process.exit(0);
358
+ }
359
+ if (args.status) {
360
+ const { getAuthStatus } = await import("@renown/sdk/node");
361
+ const status = getAuthStatus(renown);
362
+ if (!status.authenticated || !status.address) {
363
+ console.log("Not authenticated with an Ethereum address.");
364
+ console.log("Run \"ph login\" to authenticate.");
365
+ } else {
366
+ console.log("Authenticated");
367
+ console.log(` ETH Address: ${status.address}`);
368
+ console.log(` User DID: ${status.userDid}`);
369
+ console.log(` Chain ID: ${status.chainId}`);
370
+ console.log(` CLI DID: ${status.cliDid}`);
371
+ console.log(` Authenticated at: ${status.authenticatedAt?.toLocaleString()}`);
372
+ console.log(` Renown URL: ${status.baseUrl}`);
373
+ }
374
+ process.exit(0);
375
+ }
376
+ if (args.logout) {
377
+ await handleLogout();
378
+ process.exit(0);
379
+ }
380
+ const { browserLogin } = await import("@renown/sdk/node");
381
+ console.debug("Initializing cryptographic identity...");
382
+ console.log(`CLI DID: ${renown.did}`);
383
+ try {
384
+ const timeoutMs = args.timeout ? args.timeout * 1e3 : void 0;
385
+ const result = await browserLogin(renown, {
386
+ renownUrl: args.renownUrl,
387
+ timeoutMs,
388
+ onLoginUrl: (url, sessionId) => {
389
+ console.log("Opening browser for authentication...");
390
+ console.log(`Session ID: ${sessionId.slice(0, 8)}...`);
391
+ console.log(`Login URL: ${url}`);
392
+ console.log();
393
+ console.log("Waiting for authentication in browser");
394
+ console.log(`(timeout in ${(timeoutMs ?? 3e5) / 1e3} seconds)`);
395
+ console.log();
396
+ console.log("Please connect your wallet and authorize this CLI to act on your behalf.");
397
+ console.log();
398
+ process.stdout.write("Waiting");
399
+ },
400
+ onPollTick: () => process.stdout.write("."),
401
+ onBrowserOpenFailed: (url) => {
402
+ console.error("Failed to open browser automatically.");
403
+ console.log(`Please open this URL manually: ${url}`);
404
+ }
405
+ });
406
+ console.log();
407
+ console.log();
408
+ console.log("Successfully authenticated!");
409
+ console.log(` ETH Address: ${result.user.address}`);
410
+ console.log(` User DID: ${result.user.did}`);
411
+ console.log(` CLI DID: ${result.cliDid}`);
412
+ console.log();
413
+ console.log("The CLI can now act on behalf of your Ethereum identity.");
414
+ } catch (error) {
415
+ console.log();
416
+ throw error;
417
+ }
418
+ process.exit(0);
419
+ }
420
+ });
421
+ async function handleLogout() {
422
+ const { getRenown } = await import("./auth-wgUd0D0V.mjs");
423
+ const renown = await getRenown();
424
+ if (!renown.user) {
425
+ console.log("Not currently authenticated.");
426
+ return;
427
+ }
428
+ try {
429
+ await renown.logout();
430
+ console.log("Successfully logged out.");
431
+ } catch (error) {
432
+ console.error("Failed to clear credentials.");
433
+ console.debug(error);
434
+ }
435
+ }
436
+ //#endregion
437
+ //#region src/commands/logout.ts
438
+ const logout = command({
439
+ name: "logout",
440
+ description: `
441
+ The logout command removes an existing session created with 'ph login'`,
442
+ args: {},
443
+ handler: async () => {
444
+ await handleLogout();
445
+ process.exit(0);
446
+ }
447
+ });
448
+ //#endregion
449
+ //#region src/commands/migrate.ts
450
+ const migrate = command({
451
+ name: "migrate",
452
+ args: migrateArgs,
453
+ description: "Run migrations",
454
+ handler: async (args) => {
455
+ if (args.debug) console.log(args);
456
+ const { startMigrate } = await import("./migrate-N4b2DpVP.mjs");
457
+ await startMigrate(args);
458
+ process.exit(0);
459
+ }
460
+ });
461
+ //#endregion
462
+ //#region src/commands/publish.ts
463
+ const publish = command({
464
+ name: "publish",
465
+ description: `
466
+ Publish a package to the Powerhouse registry. This is a thin wrapper around npm publish
467
+ that automatically sets the registry URL.
468
+
469
+ This command:
470
+ 1. Resolves the registry URL (--registry flag > PH_REGISTRY_URL env > powerhouse.config.json > default)
471
+ 2. Checks authentication with the registry via npm whoami
472
+ 3. Forwards all additional arguments to npm publish
473
+ `,
474
+ args: publishArgs,
475
+ handler: async (args) => {
476
+ if (args.debug) console.log(args);
477
+ const { projectPath } = await getPowerhouseProjectInfo();
478
+ if (!projectPath) throw new Error("Could not find project path.");
479
+ const registryUrl = resolveRegistryUrl({
480
+ registry: args.registry,
481
+ projectPath
482
+ });
483
+ if (args.debug) console.log(">>> registryUrl", registryUrl);
484
+ try {
485
+ await checkNpmAuth(registryUrl);
486
+ } catch {
487
+ console.error(`Not authenticated with registry: ${registryUrl}`);
488
+ console.error(`Run: npm adduser --registry ${registryUrl}`);
489
+ process.exit(1);
490
+ }
491
+ if (args.debug) console.log(">>> command", `npm publish --registry ${registryUrl} ${args.forwardedArgs.join(" ")}`);
492
+ console.log(`Publishing to ${registryUrl}...`);
493
+ const result = await npmPublish({
494
+ registryUrl,
495
+ cwd: projectPath,
496
+ args: args.forwardedArgs
497
+ });
498
+ if (result.stdout) console.log(result.stdout);
499
+ process.exit(0);
500
+ }
501
+ });
502
+ //#endregion
503
+ //#region src/commands/switchboard.ts
504
+ const switchboard = command({
505
+ name: "switchboard",
506
+ aliases: ["reactor"],
507
+ description: `
508
+ The switchboard command starts a local Switchboard instance, which acts as the document
509
+ processing engine for Powerhouse projects. It provides the infrastructure for document
510
+ models, processors, and real-time updates.
511
+
512
+ This command:
513
+ 1. Starts a local switchboard server
514
+ 2. Loads document models and processors
515
+ 3. Provides an API for document operations
516
+ 4. Enables real-time document processing
517
+ 5. Can authenticate with remote services using your identity from 'ph login'`,
518
+ args: switchboardArgs,
519
+ handler: async (args) => {
520
+ if (args.debug) console.log(args);
521
+ const { basePath, dbPath, migrate, migrateStatus } = args;
522
+ if (basePath) process.env.BASE_PATH = basePath;
523
+ if (migrate || migrateStatus) {
524
+ const { runSwitchboardMigrations } = await import("./switchboard-migrate-1lOCPmX0.mjs");
525
+ await runSwitchboardMigrations({
526
+ dbPath,
527
+ statusOnly: migrateStatus
528
+ });
529
+ process.exit(0);
530
+ }
531
+ const { startSwitchboard } = await import("./switchboard-Bht39Myv.mjs");
532
+ const { defaultDriveUrl, renown } = await startSwitchboard(args);
533
+ console.log(" ➜ Switchboard:", defaultDriveUrl);
534
+ if (renown) console.log(" ➜ Identity:", renown.did);
535
+ }
536
+ });
537
+ //#endregion
538
+ //#region src/commands/uninstall.ts
539
+ const uninstall = command({
540
+ name: "uninstall",
541
+ aliases: ["remove"],
542
+ description: `
543
+ The uninstall command removes Powerhouse dependencies from your project. It handles the
544
+ removal of packages, updates configuration files, and ensures proper cleanup.
545
+
546
+ This command:
547
+ 1. Uninstalls specified Powerhouse dependencies using your package manager
548
+ 2. Updates powerhouse.config.json to remove the dependencies
549
+ 3. Supports various uninstallation options and configurations
550
+ 4. Works with ${AGENTS.join(", ")} package managers
551
+ `,
552
+ args: uninstallArgs,
553
+ handler: async (args) => {
554
+ if (args.debug) console.log(args);
555
+ const { projectPath, localProjectPath, globalProjectPath, packageManager, isGlobal } = await getPowerhouseProjectInfo(args);
556
+ if (!projectPath) throw new Error(`Could not find project path to uninstall from`);
557
+ const dependenciesWithVersions = await makeDependenciesWithVersions(args.dependencies);
558
+ if (args.debug) console.log(">>> parsedDependencies", dependenciesWithVersions);
559
+ if (args.debug) console.log("\n>>> projectInfo", {
560
+ localProjectPath,
561
+ globalProjectPath,
562
+ packageManager,
563
+ isGlobal
564
+ });
565
+ try {
566
+ console.log("Uninstalling dependencies 📦 ...");
567
+ execSync(await getPowerhouseProjectUninstallCommand(packageManager), {
568
+ stdio: "inherit",
569
+ cwd: projectPath
570
+ });
571
+ console.log("Dependency uninstalled successfully 🎉");
572
+ } catch (error) {
573
+ console.error("❌ Failed to uninstall dependencies");
574
+ throw error;
575
+ }
576
+ try {
577
+ console.log("⚙️ Updating powerhouse config file...");
578
+ updateConfigFile(dependenciesWithVersions, projectPath, "uninstall");
579
+ console.log("Config file updated successfully 🎉");
580
+ } catch (error) {
581
+ console.error("❌ Failed to update config file");
582
+ throw error;
583
+ }
584
+ try {
585
+ console.log("⚙️ Updating styles.css file...");
586
+ removeStylesImports(dependenciesWithVersions, projectPath);
587
+ console.log("Styles file updated successfully 🎉");
588
+ } catch (error) {
589
+ console.error("❌ Failed to update styles file");
590
+ throw error;
591
+ }
592
+ process.exit(0);
593
+ }
594
+ });
595
+ //#endregion
596
+ //#region src/commands/ph-cli-commands.ts
597
+ const phCliCommands = {
598
+ init,
599
+ generate,
600
+ vetra: command({
601
+ name: "vetra",
602
+ description: `
603
+ The vetra command sets up a Vetra development environment for working with Vetra projects.
604
+ It starts a Vetra Switchboard and optionally Connect Studio, enabling document collaboration
605
+ and real-time processing with a "Vetra" drive or connection to remote drives.
606
+
607
+ This command:
608
+ 1. Starts a Vetra Switchboard with a "Vetra" drive for document storage
609
+ 2. Optionally connects to remote drives instead of creating a local drive
610
+ 3. Starts Connect Studio pointing to the Switchboard for user interaction (unless disabled)
611
+ 4. Enables real-time updates, collaboration, and code generation`,
612
+ args: vetraArgs,
613
+ handler: async (args) => {
614
+ if (args.debug) console.log(args);
615
+ const { startVetra } = await import("./vetra-vUDKNfbX.mjs");
616
+ await startVetra(args);
617
+ }
618
+ }),
619
+ connect,
620
+ build: build$1,
621
+ publish,
622
+ "access-token": accessToken,
623
+ inspect,
624
+ list,
625
+ migrate,
626
+ switchboard,
627
+ login,
628
+ logout,
629
+ install,
630
+ uninstall
631
+ };
632
+ const phCli = subcommands({
633
+ name: "ph-cli",
634
+ description: PH_CLI_DESCRIPTION,
635
+ version: getVersion(),
636
+ cmds: phCliCommands
637
+ });
638
+ //#endregion
639
+ //#region src/cli.ts
640
+ async function main() {
641
+ assertNodeVersion();
642
+ await initCliTelemetry({
643
+ cliName: "ph-cli",
644
+ release: getVersion()
645
+ });
646
+ const args = process.argv.slice(2);
647
+ const hasNoArgs = args.length === 0;
648
+ const isHelp = args.some((arg) => arg === "--help" || arg === "-h");
649
+ const isTopLevelHelp = isHelp && args.length === 1;
650
+ const cli = hasNoArgs || isTopLevelHelp ? phCliHelp : phCli;
651
+ const [command, ...restArgs] = args;
652
+ if (command === "connect" && ![
653
+ "studio",
654
+ "build",
655
+ "preview"
656
+ ].includes(args[1]) && !isHelp) await run(cli, [
657
+ "connect",
658
+ "studio",
659
+ ...restArgs
660
+ ]);
661
+ else await run(cli, args);
662
+ }
663
+ await main().catch(async (error) => {
664
+ const isDebug = process.argv.slice(2).includes("--debug");
665
+ await captureCliError(error);
666
+ if (isDebug) throw error;
667
+ if (error instanceof Error) {
668
+ console.error(error.message);
669
+ process.exit(1);
670
+ } else throw error;
671
+ });
672
+ //#endregion
673
+ export {};
674
+
675
+ //# sourceMappingURL=cli.mjs.map