@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
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.mjs","names":["version","build","getConfig"],"sources":["../src/get-version.ts","../src/utils/constants.ts","../src/commands/ph-cli-help.ts","../src/commands/access-token.ts","../src/commands/build.ts","../src/commands/connect.ts","../src/commands/generate.ts","../src/commands/init.ts","../src/commands/inspect.ts","../src/commands/install.ts","../src/commands/list.ts","../src/commands/login.ts","../src/commands/logout.ts","../src/commands/migrate.ts","../src/commands/publish.ts","../src/commands/switchboard.ts","../src/commands/uninstall.ts","../src/commands/vetra.ts","../src/commands/ph-cli-commands.ts","../src/commands/ph-cli.ts","../src/cli.ts"],"sourcesContent":["export function getVersion() {\n return (\n process.env.WORKSPACE_VERSION ||\n process.env.npm_package_version ||\n \"unknown\"\n );\n}\n","export const PH_CLI_DESCRIPTION =\n \"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.\" as const;\n","import { phCliHelpCommands } from \"@powerhousedao/shared/clis\";\nimport { subcommands } from \"cmd-ts\";\nimport { getVersion } from \"../get-version.js\";\nimport { PH_CLI_DESCRIPTION } from \"../utils/constants.js\";\n\nconst version = getVersion();\nexport const phCliHelp = subcommands({\n name: \"ph-cli\",\n description: PH_CLI_DESCRIPTION,\n version,\n cmds: phCliHelpCommands,\n});\n","import {\n accessTokenArgs,\n DEFAULT_EXPIRY_SECONDS,\n} from \"@powerhousedao/shared/clis\";\nimport { command } from \"cmd-ts\";\n\nexport const accessToken = command({\n name: \"access-token\",\n description: `\nThe access-token command generates a bearer token for API authentication. This token\ncan be used to authenticate requests to Powerhouse APIs like reactor-api (Switchboard).\n\nThis command:\n1. Uses your CLI's cryptographic identity (DID) to sign a verifiable credential\n2. Creates a JWT bearer token with configurable expiration\n3. Outputs the token to stdout (info to stderr) for easy piping\n\nPrerequisites:\n You must have a cryptographic identity. Run 'ph login' first to:\n - Generate a keypair (stored in .ph/.keypair.json)\n - Optionally link your Ethereum address (stored in .ph/.renown.json)\n\nToken Details:\n The generated token is a JWT (JSON Web Token) containing:\n - Issuer (iss): Your CLI's DID (did:key:...)\n - Subject (sub): Your CLI's DID\n - Credential Subject: Chain ID, network ID, and address (if authenticated)\n - Expiration (exp): Based on --expiry option\n - Audience (aud): If --audience is specified\n\nOutput:\n- Token information (DID, address, expiry) is printed to stderr\n- The token itself is printed to stdout for easy piping/copying\n\nThis allows you to use the command in scripts:\n TOKEN=$(ph access-token)\n curl -H \"Authorization: Bearer $TOKEN\" http://localhost:4001/graphql\n\nUsage with APIs:\n Generate token and use with curl\n TOKEN=$(ph access-token --expiry 1d)\n curl -X POST http://localhost:4001/graphql \\\\\n -H \"Content-Type: application/json\" \\\\\n -H \"Authorization: Bearer $TOKEN\" \\\\\n -d '{\"query\": \"{ drives { id name } }\"}'\n\n Export as environment variable\n export PH_ACCESS_TOKEN=$(ph access-token)\n\nNotes:\n - Tokens are self-signed using your CLI's private key\n - No network request is made; tokens are generated locally\n - The recipient API must trust your CLI's DID to accept the token\n - For reactor-api, ensure AUTH_ENABLED=true to require authentication\n`,\n args: accessTokenArgs,\n handler: async (args) => {\n if (args.debug) {\n console.log(args);\n }\n\n const { generateAccessToken, parseExpiry, formatExpiry } =\n await import(\"@renown/sdk/node\");\n const { getRenown } = await import(\"../services/auth.js\");\n const renown = await getRenown();\n\n let expiresIn = DEFAULT_EXPIRY_SECONDS;\n if (args.expiry) expiresIn = parseExpiry(args.expiry);\n\n const result = await generateAccessToken(renown, {\n expiresIn,\n aud: args.audience,\n });\n\n // Output token info to stderr, token itself to stdout for piping\n console.error(`CLI DID: ${result.did}`);\n console.error(`ETH Address: ${result.address}`);\n console.error(`Token expires in: ${formatExpiry(expiresIn)}`);\n console.error(\"\");\n\n console.log(result.token);\n process.exit(0);\n },\n});\n","import { buildArgs } from \"@powerhousedao/shared/clis\";\nimport { command } from \"cmd-ts\";\nimport { runBuild } from \"../services/build.js\";\n\nexport const build = command({\n name: \"build\",\n args: buildArgs,\n handler: async (args) => {\n if (args.debug) {\n console.log(args);\n }\n try {\n await runBuild(args);\n } catch (error) {\n console.error(error);\n process.exit(1);\n }\n },\n});\n","import {\n connectBuildArgs,\n connectPreviewArgs,\n connectStudioArgs,\n} from \"@powerhousedao/shared/clis\";\nimport { command, subcommands } from \"cmd-ts\";\nexport const studio = command({\n name: \"studio\",\n description: `The studio command starts the Connect Studio, a development environment for building\nand testing Powerhouse applications. It provides a visual interface for working with\nyour project.\n\nThis command:\n1. Starts a local Connect Studio server\n2. Provides a web interface for development\n3. Allows you to interact with your project components\n4. Supports various configuration options for customization\n`,\n args: connectStudioArgs,\n handler: async (args) => {\n if (args.debug) {\n console.log(args);\n }\n const { runConnectStudio } = await import(\"../services/connect-studio.js\");\n await runConnectStudio(args);\n },\n});\n\nexport const build = command({\n name: \"build\",\n description: `The Connect build command creates a production build with the project's local and\nexternal packages included\n`,\n args: connectBuildArgs,\n handler: async (args) => {\n if (args.debug) {\n console.log(args);\n }\n\n const { runConnectBuild } = await import(\"../services/connect-build.js\");\n await runConnectBuild(args);\n process.exit(0);\n },\n});\n\nexport const preview = command({\n name: \"preview\",\n description: `The Connect preview command previews a built Connect project.\nNOTE: You must run \\`ph connect build\\` first\n`,\n args: connectPreviewArgs,\n handler: async (args) => {\n if (args.debug) {\n console.log(args);\n }\n const { runConnectPreview } =\n await import(\"../services/connect-preview.js\");\n await runConnectPreview(args);\n },\n});\n\nexport const connect = subcommands({\n name: \"connect\",\n description: `Powerhouse Connect commands. Use with \\`studio\\`, \\`build\\` or \\`preview\\`. Defaults to \\`studio\\` if not specified.`,\n cmds: {\n studio,\n build,\n preview,\n },\n});\n","import { generateArgs } from \"@powerhousedao/shared/clis\";\nimport { command } from \"cmd-ts\";\n\nexport const generate = command({\n name: \"generate\",\n description: `\nThe generate command creates code from document models. It helps you build editors, \nprocessors, and other components based on your document model files.\n\nThis command:\n1. Reads document model definitions\n2. Generates code for specified components (editors, processors, etc.)\n3. Supports customization of output and generation options\n4. Can watch files for changes and regenerate code automatically\n`,\n args: generateArgs,\n handler: async (args) => {\n if (args.debug) {\n console.log(args);\n }\n const { startGenerate } = await import(\"../services/generate.js\");\n await startGenerate(args);\n process.exit(0);\n },\n});\n","import { initArgs } from \"@powerhousedao/shared/clis\";\nimport { command } from \"cmd-ts\";\n\nexport const init = command({\n name: \"init\",\n description: \"Initialize a new project\",\n args: initArgs,\n handler: async (args) => {\n if (args.debug) {\n console.log({ args });\n }\n const { startInit } = await import(\"../services/init.js\");\n await startInit(args);\n process.exit(0);\n },\n});\n","import { inspectArgs } from \"@powerhousedao/shared/clis\";\nimport { command } from \"cmd-ts\";\n\nexport const inspect = command({\n name: \"inspect\",\n description: `\nThe inspect command examines and provides detailed information about a Powerhouse package.\nIt helps you understand the structure, dependencies, and configuration of packages in\nyour project.\n\nThis command:\n1. Analyzes the specified package\n2. Retrieves detailed information about its structure and configuration\n3. Displays package metadata, dependencies, and other relevant information\n4. Helps troubleshoot package-related issues`,\n aliases: [\"is\"],\n args: inspectArgs,\n handler: async (args) => {\n if (args.debug) {\n console.log(args);\n }\n const { startInspect } = await import(\"../services/inspect.js\");\n startInspect(args);\n process.exit(0);\n },\n});\n","import {\n getPowerhouseProjectInfo,\n installArgs,\n makeDependenciesWithVersions,\n} from \"@powerhousedao/shared/clis\";\nimport { resolveRegistryUrl } from \"@powerhousedao/shared/registry\";\nimport { execSync } from \"child_process\";\nimport { command } from \"cmd-ts\";\nimport { resolveCommand } from \"package-manager-detector\";\nimport { updateConfigFile, updateStylesFile } from \"../utils.js\";\n\nexport const install = command({\n name: \"install\",\n aliases: [\"add\", \"i\"],\n description: `\nThe install command adds Powerhouse dependencies to your project.\n\nBy default it only registers the package in powerhouse.config.json with\nprovider \"registry\" — Connect will load it from the registry CDN at runtime.\n\nWith --local, the package is also installed into node_modules and marked\nas provider \"local\" — it will be bundled into ph connect build so the\npreview works without the registry being reachable.\n\nResolution order for the registry URL:\n --registry flag > PH_REGISTRY_URL env > powerhouse.config.json > default\n `,\n args: installArgs,\n handler: async (args) => {\n if (args.debug) {\n console.log(args);\n }\n\n const {\n projectPath,\n localProjectPath,\n globalProjectPath,\n packageManager,\n isGlobal,\n } = await getPowerhouseProjectInfo(args);\n\n if (!projectPath) {\n throw new Error(`Could not find project path to install from.`);\n }\n\n const registryUrl = resolveRegistryUrl({\n registry: args.registry,\n projectPath,\n });\n\n if (args.debug) {\n console.log(\">>> registryUrl\", registryUrl);\n }\n\n const dependenciesWithVersions = await makeDependenciesWithVersions(\n args.dependencies,\n registryUrl,\n );\n\n if (args.debug) {\n console.log(\">>> parsedDependencies\", dependenciesWithVersions);\n console.log(\"\\n>>> projectInfo\", {\n localProjectPath,\n globalProjectPath,\n packageManager,\n isGlobal,\n });\n }\n\n if (args.local) {\n if (dependenciesWithVersions.length === 0) {\n throw new Error(\n \"--local requires at least one package name (e.g. ph install --local @scope/pkg)\",\n );\n }\n try {\n const specs = dependenciesWithVersions.map((d) =>\n d.version ? `${d.name}@${d.version}` : d.name,\n );\n\n // Route only the scopes of the packages being installed to the\n // resolved registry, leaving transitive deps from other scopes\n // (and unscoped packages) on the package manager's default. This\n // avoids requiring a project-level .npmrc when the user already\n // has packageRegistryUrl in powerhouse.config.json.\n const scopes = new Set<string>();\n for (const dep of dependenciesWithVersions) {\n if (dep.name.startsWith(\"@\")) {\n const scope = dep.name.split(\"/\")[0];\n scopes.add(scope);\n }\n }\n const scopeRegistryArgs = Array.from(scopes).map(\n (scope) => `--${scope}:registry=${registryUrl}`,\n );\n\n const resolved = resolveCommand(packageManager, \"add\", [\n ...specs,\n ...scopeRegistryArgs,\n ]);\n if (!resolved) {\n throw new Error(\n `Failed to resolve install command for package manager \"${packageManager}\".`,\n );\n }\n const installCommand = `${resolved.command} ${resolved.args.join(\" \")}`;\n if (scopeRegistryArgs.length > 0) {\n console.log(\n `Installing dependencies 📦 (routing ${Array.from(scopes).join(\", \")} → ${registryUrl})...`,\n );\n } else {\n console.log(\"Installing dependencies 📦...\");\n }\n console.log(`> ${installCommand}`);\n execSync(installCommand, {\n stdio: \"inherit\",\n cwd: projectPath,\n });\n console.log(\"Dependency installed successfully 🎉\");\n } catch (error) {\n console.error(\"❌ Failed to install dependencies\");\n throw error;\n }\n }\n\n try {\n console.log(\"⚙️ Updating powerhouse config file...\");\n updateConfigFile(\n dependenciesWithVersions,\n projectPath,\n \"install\",\n args.local ? \"local\" : \"registry\",\n );\n console.log(\"Config file updated successfully 🎉\");\n } catch (error) {\n console.error(\"❌ Failed to update config file\");\n throw error;\n }\n\n if (args.local) {\n try {\n console.log(\"⚙️ Updating styles.css file...\");\n updateStylesFile(dependenciesWithVersions, projectPath);\n console.log(\"Styles file updated successfully 🎉\");\n } catch (error) {\n console.error(\"❌ Failed to update styles file\");\n throw error;\n }\n }\n\n process.exit(0);\n },\n});\n","import { getConfig } from \"@powerhousedao/config/node\";\nimport { getPowerhouseProjectInfo, listArgs } from \"@powerhousedao/shared/clis\";\nimport { command } from \"cmd-ts\";\n\nexport const list = command({\n name: \"list\",\n description: `\nThe list command displays information about installed Powerhouse packages in your project.\nIt reads the powerhouse.config.json file and shows the packages that are currently installed.\n\nThis command:\n1. Examines your project configuration\n2. Lists all installed Powerhouse packages\n3. Provides a clear overview of your project's dependencies\n4. Helps you manage and track your Powerhouse components\n`,\n aliases: [\"l\"],\n args: listArgs,\n handler: async (args) => {\n if (args.debug) {\n console.log(args);\n }\n\n try {\n const projectInfo = await getPowerhouseProjectInfo();\n console.log(\"\\n>>> projectInfo\", projectInfo);\n\n const phConfig = getConfig(\n projectInfo.projectPath + \"/powerhouse.config.json\",\n );\n\n if (!phConfig.packages || phConfig.packages.length === 0) {\n console.log(\"No packages found in the project\");\n return;\n }\n\n console.log(\"Installed Packages:\\n\");\n phConfig.packages.forEach((pkg) => {\n console.log(pkg.packageName);\n });\n } catch (e) {\n console.log(\"No packages found in the project\");\n }\n process.exit(0);\n },\n});\n","import { loginArgs } from \"@powerhousedao/shared/clis\";\nimport { command } from \"cmd-ts\";\n\nexport const login = command({\n name: \"login\",\n description: `\nThe login command authenticates you with Renown using your Ethereum wallet. This enables\nthe CLI to act on behalf of your Ethereum identity for authenticated operations.\n\nThis command:\n1. Generates or loads a cryptographic identity (DID) for the CLI\n2. Opens your browser to the Renown authentication page\n3. You authorize the CLI's DID to act on behalf of your Ethereum address\n4. Stores the credentials locally in .ph/.renown.json\n `,\n args: loginArgs,\n handler: async (args) => {\n if (args.debug) {\n console.log(args);\n }\n\n const { getRenown } = await import(\"../services/auth.js\");\n const renown = await getRenown(args.renownUrl);\n\n if (args.showDid) {\n console.log(renown.did);\n process.exit(0);\n }\n\n if (args.status) {\n const { getAuthStatus } = await import(\"@renown/sdk/node\");\n const status = getAuthStatus(renown);\n if (!status.authenticated || !status.address) {\n console.log(\"Not authenticated with an Ethereum address.\");\n console.log('Run \"ph login\" to authenticate.');\n } else {\n console.log(\"Authenticated\");\n console.log(` ETH Address: ${status.address}`);\n console.log(` User DID: ${status.userDid}`);\n console.log(` Chain ID: ${status.chainId}`);\n console.log(` CLI DID: ${status.cliDid}`);\n console.log(\n ` Authenticated at: ${status.authenticatedAt?.toLocaleString()}`,\n );\n console.log(` Renown URL: ${status.baseUrl}`);\n }\n process.exit(0);\n }\n\n if (args.logout) {\n await handleLogout();\n process.exit(0);\n }\n\n const { browserLogin } = await import(\"@renown/sdk/node\");\n\n console.debug(\"Initializing cryptographic identity...\");\n console.log(`CLI DID: ${renown.did}`);\n\n try {\n const timeoutMs = args.timeout ? args.timeout * 1000 : undefined;\n\n const result = await browserLogin(renown, {\n renownUrl: args.renownUrl,\n timeoutMs,\n onLoginUrl: (url, sessionId) => {\n console.log(\"Opening browser for authentication...\");\n console.log(`Session ID: ${sessionId.slice(0, 8)}...`);\n console.log(`Login URL: ${url}`);\n console.log();\n console.log(\"Waiting for authentication in browser\");\n console.log(`(timeout in ${(timeoutMs ?? 300_000) / 1000} seconds)`);\n console.log();\n console.log(\n \"Please connect your wallet and authorize this CLI to act on your behalf.\",\n );\n console.log();\n process.stdout.write(\"Waiting\");\n },\n onPollTick: () => process.stdout.write(\".\"),\n onBrowserOpenFailed: (url) => {\n console.error(\"Failed to open browser automatically.\");\n console.log(`Please open this URL manually: ${url}`);\n },\n });\n\n console.log(); // New line after dots\n console.log();\n console.log(\"Successfully authenticated!\");\n console.log(` ETH Address: ${result.user.address}`);\n console.log(` User DID: ${result.user.did}`);\n console.log(` CLI DID: ${result.cliDid}`);\n console.log();\n console.log(\"The CLI can now act on behalf of your Ethereum identity.\");\n } catch (error) {\n console.log(); // New line after dots\n throw error;\n }\n\n process.exit(0);\n },\n});\n\nexport async function handleLogout() {\n const { getRenown } = await import(\"../services/auth.js\");\n const renown = await getRenown();\n if (!renown.user) {\n console.log(\"Not currently authenticated.\");\n return;\n }\n\n try {\n await renown.logout();\n console.log(\"Successfully logged out.\");\n } catch (error) {\n console.error(\"Failed to clear credentials.\");\n console.debug(error);\n }\n}\n","import { command } from \"cmd-ts\";\nimport { handleLogout } from \"./login.js\";\n\nexport const logout = command({\n name: \"logout\",\n description: `\nThe logout command removes an existing session created with 'ph login'`,\n args: {},\n handler: async () => {\n await handleLogout();\n process.exit(0);\n },\n});\n","import { migrateArgs } from \"@powerhousedao/shared/clis\";\nimport { command } from \"cmd-ts\";\n\nexport const migrate = command({\n name: \"migrate\",\n args: migrateArgs,\n description: \"Run migrations\",\n handler: async (args) => {\n if (args.debug) {\n console.log(args);\n }\n const { startMigrate } = await import(\"../services/migrate.js\");\n await startMigrate(args);\n process.exit(0);\n },\n});\n","import {\n getPowerhouseProjectInfo,\n publishArgs,\n} from \"@powerhousedao/shared/clis\";\nimport {\n checkNpmAuth,\n npmPublish,\n resolveRegistryUrl,\n} from \"@powerhousedao/shared/registry\";\nimport { command } from \"cmd-ts\";\n\nexport const publish = command({\n name: \"publish\",\n description: `\nPublish a package to the Powerhouse registry. This is a thin wrapper around npm publish\nthat automatically sets the registry URL.\n\nThis command:\n1. Resolves the registry URL (--registry flag > PH_REGISTRY_URL env > powerhouse.config.json > default)\n2. Checks authentication with the registry via npm whoami\n3. Forwards all additional arguments to npm publish\n `,\n args: publishArgs,\n handler: async (args) => {\n if (args.debug) {\n console.log(args);\n }\n\n const { projectPath } = await getPowerhouseProjectInfo();\n\n if (!projectPath) {\n throw new Error(\"Could not find project path.\");\n }\n\n const registryUrl = resolveRegistryUrl({\n registry: args.registry,\n projectPath,\n });\n\n if (args.debug) {\n console.log(\">>> registryUrl\", registryUrl);\n }\n\n try {\n await checkNpmAuth(registryUrl);\n } catch {\n console.error(`Not authenticated with registry: ${registryUrl}`);\n console.error(`Run: npm adduser --registry ${registryUrl}`);\n process.exit(1);\n }\n\n if (args.debug) {\n console.log(\n \">>> command\",\n `npm publish --registry ${registryUrl} ${args.forwardedArgs.join(\" \")}`,\n );\n }\n\n console.log(`Publishing to ${registryUrl}...`);\n const result = await npmPublish({\n registryUrl,\n cwd: projectPath,\n args: args.forwardedArgs,\n });\n if (result.stdout) {\n console.log(result.stdout);\n }\n\n process.exit(0);\n },\n});\n","import { switchboardArgs } from \"@powerhousedao/shared/clis\";\nimport { command } from \"cmd-ts\";\n\nexport const switchboard = command({\n name: \"switchboard\",\n aliases: [\"reactor\"],\n description: `\nThe switchboard command starts a local Switchboard instance, which acts as the document\nprocessing engine for Powerhouse projects. It provides the infrastructure for document\nmodels, processors, and real-time updates.\n\nThis command:\n1. Starts a local switchboard server\n2. Loads document models and processors\n3. Provides an API for document operations\n4. Enables real-time document processing\n5. Can authenticate with remote services using your identity from 'ph login'`,\n args: switchboardArgs,\n handler: async (args) => {\n if (args.debug) {\n console.log(args);\n }\n const { basePath, dbPath, migrate, migrateStatus } = args;\n if (basePath) {\n process.env.BASE_PATH = basePath;\n }\n\n if (migrate || migrateStatus) {\n const { runSwitchboardMigrations } =\n await import(\"../services/switchboard-migrate.js\");\n await runSwitchboardMigrations({\n dbPath,\n statusOnly: migrateStatus,\n });\n process.exit(0);\n }\n\n const { startSwitchboard } = await import(\"../services/switchboard.js\");\n const { defaultDriveUrl, renown } = await startSwitchboard(args);\n console.log(\" ➜ Switchboard:\", defaultDriveUrl);\n if (renown) {\n console.log(\" ➜ Identity:\", renown.did);\n }\n },\n});\n","import {\n getPowerhouseProjectInfo,\n getPowerhouseProjectUninstallCommand,\n makeDependenciesWithVersions,\n uninstallArgs,\n} from \"@powerhousedao/shared/clis\";\nimport { execSync } from \"child_process\";\nimport { command } from \"cmd-ts\";\nimport { AGENTS } from \"package-manager-detector\";\nimport { removeStylesImports, updateConfigFile } from \"../utils.js\";\n\nexport const uninstall = command({\n name: \"uninstall\",\n aliases: [\"remove\"],\n description: `\nThe uninstall command removes Powerhouse dependencies from your project. It handles the\nremoval of packages, updates configuration files, and ensures proper cleanup.\n\nThis command:\n1. Uninstalls specified Powerhouse dependencies using your package manager\n2. Updates powerhouse.config.json to remove the dependencies\n3. Supports various uninstallation options and configurations\n4. Works with ${AGENTS.join(\", \")} package managers\n`,\n args: uninstallArgs,\n handler: async (args) => {\n if (args.debug) {\n console.log(args);\n }\n\n const {\n projectPath,\n localProjectPath,\n globalProjectPath,\n packageManager,\n isGlobal,\n } = await getPowerhouseProjectInfo(args);\n\n if (!projectPath) {\n throw new Error(`Could not find project path to uninstall from`);\n }\n\n const dependenciesWithVersions = await makeDependenciesWithVersions(\n args.dependencies,\n );\n\n if (args.debug) {\n console.log(\">>> parsedDependencies\", dependenciesWithVersions);\n }\n\n if (args.debug) {\n console.log(\"\\n>>> projectInfo\", {\n localProjectPath,\n globalProjectPath,\n packageManager,\n isGlobal,\n });\n }\n\n try {\n console.log(\"Uninstalling dependencies 📦 ...\");\n const uninstallCommand =\n await getPowerhouseProjectUninstallCommand(packageManager);\n execSync(uninstallCommand, {\n stdio: \"inherit\",\n cwd: projectPath,\n });\n console.log(\"Dependency uninstalled successfully 🎉\");\n } catch (error) {\n console.error(\"❌ Failed to uninstall dependencies\");\n throw error;\n }\n\n try {\n console.log(\"⚙️ Updating powerhouse config file...\");\n updateConfigFile(dependenciesWithVersions, projectPath, \"uninstall\");\n console.log(\"Config file updated successfully 🎉\");\n } catch (error) {\n console.error(\"❌ Failed to update config file\");\n throw error;\n }\n\n try {\n console.log(\"⚙️ Updating styles.css file...\");\n removeStylesImports(dependenciesWithVersions, projectPath);\n console.log(\"Styles file updated successfully 🎉\");\n } catch (error) {\n console.error(\"❌ Failed to update styles file\");\n throw error;\n }\n\n process.exit(0);\n },\n});\n","import { vetraArgs } from \"@powerhousedao/shared/clis\";\nimport { command } from \"cmd-ts\";\n\nexport const vetra = command({\n name: \"vetra\",\n description: `\nThe vetra command sets up a Vetra development environment for working with Vetra projects.\nIt starts a Vetra Switchboard and optionally Connect Studio, enabling document collaboration \nand real-time processing with a \"Vetra\" drive or connection to remote drives.\n\nThis command:\n1. Starts a Vetra Switchboard with a \"Vetra\" drive for document storage\n2. Optionally connects to remote drives instead of creating a local drive\n3. Starts Connect Studio pointing to the Switchboard for user interaction (unless disabled)\n4. Enables real-time updates, collaboration, and code generation`,\n args: vetraArgs,\n handler: async (args) => {\n if (args.debug) {\n console.log(args);\n }\n const { startVetra } = await import(\"../services/vetra.js\");\n await startVetra(args);\n },\n});\n","import { accessToken } from \"./access-token.js\";\nimport { build } from \"./build.js\";\nimport { connect } from \"./connect.js\";\nimport { generate } from \"./generate.js\";\nimport { init } from \"./init.js\";\nimport { inspect } from \"./inspect.js\";\nimport { install } from \"./install.js\";\nimport { list } from \"./list.js\";\nimport { login } from \"./login.js\";\nimport { logout } from \"./logout.js\";\nimport { migrate } from \"./migrate.js\";\nimport { publish } from \"./publish.js\";\nimport { switchboard } from \"./switchboard.js\";\nimport { uninstall } from \"./uninstall.js\";\nimport { vetra } from \"./vetra.js\";\n\nexport const phCliCommands = {\n init,\n generate,\n vetra,\n connect,\n build,\n publish,\n \"access-token\": accessToken,\n inspect,\n list,\n migrate,\n switchboard,\n login,\n logout,\n install,\n uninstall,\n} as const;\n","import { subcommands } from \"cmd-ts\";\nimport { getVersion } from \"../get-version.js\";\nimport { PH_CLI_DESCRIPTION } from \"../utils/constants.js\";\nimport { phCliCommands } from \"./ph-cli-commands.js\";\n\nconst version = getVersion();\nexport const phCli = subcommands({\n name: \"ph-cli\",\n description: PH_CLI_DESCRIPTION,\n version,\n cmds: phCliCommands,\n});\n","#!/usr/bin/env node\nimport {\n assertNodeVersion,\n captureCliError,\n initCliTelemetry,\n} from \"@powerhousedao/shared/clis\";\nimport { run } from \"cmd-ts\";\nimport { phCliHelp } from \"./commands/ph-cli-help.js\";\nimport { phCli } from \"./commands/ph-cli.js\";\nimport { getVersion } from \"./get-version.js\";\n\nasync function main() {\n assertNodeVersion();\n // Initializes Sentry only if user consented (opt-out by default, asked\n // once on first interactive run). Respects PH_NO_TELEMETRY/DO_NOT_TRACK.\n await initCliTelemetry({ cliName: \"ph-cli\", release: getVersion() });\n const args = process.argv.slice(2);\n const hasNoArgs = args.length === 0;\n const isHelp = args.some((arg) => arg === \"--help\" || arg === \"-h\");\n const isTopLevelHelp = isHelp && args.length === 1;\n const showTopLevelHelp = hasNoArgs || isTopLevelHelp;\n const cli = showTopLevelHelp ? phCliHelp : phCli;\n const [command, ...restArgs] = args;\n if (\n command === \"connect\" &&\n ![\"studio\", \"build\", \"preview\"].includes(args[1]) &&\n !isHelp\n ) {\n const argsWithDefaultConnectSubCommand = [\"connect\", \"studio\", ...restArgs];\n await run(cli, argsWithDefaultConnectSubCommand);\n } else {\n await run(cli, args);\n }\n}\n\nawait main().catch(async (error) => {\n const isDebug = process.argv.slice(2).includes(\"--debug\");\n // Report to Sentry (no-op when telemetry disabled) before exiting.\n await captureCliError(error);\n if (isDebug) {\n throw error;\n }\n if (error instanceof Error) {\n console.error(error.message);\n process.exit(1);\n } else {\n throw error;\n }\n});\n"],"mappings":"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"}
@@ -0,0 +1,35 @@
1
+ import { t as runBuild } from "./build-BflSHYLP.mjs";
2
+ import { t as assignEnvVars } from "./assign-env-vars-CzHgn5ax.mjs";
3
+ import { getConfig } from "@powerhousedao/shared/clis";
4
+ import { join } from "node:path";
5
+ import { existsSync } from "node:fs";
6
+ import { getConnectBaseViteConfig } from "@powerhousedao/builder-tools";
7
+ import { build, mergeConfig } from "vite";
8
+ //#region src/services/connect-build.ts
9
+ async function runConnectBuild(args) {
10
+ const { outDir, debug } = args;
11
+ assignEnvVars(args);
12
+ const mode = "production";
13
+ const dirname = process.cwd();
14
+ assertLocalPackagesInstalled(dirname);
15
+ await runBuild({
16
+ outDir: "dist",
17
+ debug
18
+ });
19
+ await build(mergeConfig(getConnectBaseViteConfig({
20
+ mode,
21
+ dirname
22
+ }), { build: { outDir } }));
23
+ }
24
+ function assertLocalPackagesInstalled(projectPath) {
25
+ const localPackages = (getConfig(join(projectPath, "powerhouse.config.json")).packages ?? []).filter((p) => p.provider === "local");
26
+ if (localPackages.length === 0) return;
27
+ const missing = localPackages.filter((p) => !existsSync(join(projectPath, "node_modules", p.packageName, "package.json")));
28
+ if (missing.length === 0) return;
29
+ const names = missing.map((p) => p.packageName);
30
+ throw new Error(`ph connect build requires these packages to be installed in node_modules (they are declared with provider: "local" in powerhouse.config.json):\n` + names.map((n) => ` - ${n}`).join("\n") + `\n\nInstall them with:\n ph install --local ${names.join(" ")}`);
31
+ }
32
+ //#endregion
33
+ export { runConnectBuild };
34
+
35
+ //# sourceMappingURL=connect-build-oDJKd0aN.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connect-build-oDJKd0aN.mjs","names":[],"sources":["../src/services/connect-build.ts"],"sourcesContent":["import { getConnectBaseViteConfig } from \"@powerhousedao/builder-tools\";\nimport { getConfig } from \"@powerhousedao/shared/clis\";\nimport { existsSync } from \"node:fs\";\nimport { join } from \"node:path\";\nimport type { InlineConfig } from \"vite\";\nimport { build, mergeConfig } from \"vite\";\nimport type { ConnectBuildArgs } from \"../types.js\";\nimport { assignEnvVars } from \"../utils/assign-env-vars.js\";\nimport { runBuild } from \"./build.js\";\n\nexport async function runConnectBuild(args: ConnectBuildArgs) {\n const { outDir, debug } = args;\n assignEnvVars(args);\n\n const mode = \"production\";\n const dirname = process.cwd();\n\n // Fail fast if any package marked as provider: \"local\" is missing from\n // node_modules — the Vite plugin that bundles them needs them on disk.\n assertLocalPackagesInstalled(dirname);\n\n await runBuild({\n outDir: \"dist\",\n debug,\n });\n\n const baseConfig = getConnectBaseViteConfig({\n mode,\n dirname,\n });\n\n const buildConfig: InlineConfig = {\n build: {\n outDir,\n },\n };\n\n const config = mergeConfig(baseConfig, buildConfig);\n\n await build(config);\n}\n\nfunction assertLocalPackagesInstalled(projectPath: string) {\n const config = getConfig(join(projectPath, \"powerhouse.config.json\"));\n const localPackages = (config.packages ?? []).filter(\n (p) => p.provider === \"local\",\n );\n if (localPackages.length === 0) return;\n\n const missing = localPackages.filter(\n (p) =>\n !existsSync(\n join(projectPath, \"node_modules\", p.packageName, \"package.json\"),\n ),\n );\n if (missing.length === 0) return;\n\n const names = missing.map((p) => p.packageName);\n throw new Error(\n `ph connect build requires these packages to be installed in node_modules (they are declared with provider: \"local\" in powerhouse.config.json):\\n` +\n names.map((n) => ` - ${n}`).join(\"\\n\") +\n `\\n\\nInstall them with:\\n ph install --local ${names.join(\" \")}`,\n );\n}\n"],"mappings":";;;;;;;;AAUA,eAAsB,gBAAgB,MAAwB;CAC5D,MAAM,EAAE,QAAQ,UAAU;AAC1B,eAAc,KAAK;CAEnB,MAAM,OAAO;CACb,MAAM,UAAU,QAAQ,KAAK;AAI7B,8BAA6B,QAAQ;AAErC,OAAM,SAAS;EACb,QAAQ;EACR;EACD,CAAC;AAeF,OAAM,MAFS,YAXI,yBAAyB;EAC1C;EACA;EACD,CAAC,EAEgC,EAChC,OAAO,EACL,QACD,EACF,CAEkD,CAEhC;;AAGrB,SAAS,6BAA6B,aAAqB;CAEzD,MAAM,iBADS,UAAU,KAAK,aAAa,yBAAyB,CAAC,CACvC,YAAY,EAAE,EAAE,QAC3C,MAAM,EAAE,aAAa,QACvB;AACD,KAAI,cAAc,WAAW,EAAG;CAEhC,MAAM,UAAU,cAAc,QAC3B,MACC,CAAC,WACC,KAAK,aAAa,gBAAgB,EAAE,aAAa,eAAe,CACjE,CACJ;AACD,KAAI,QAAQ,WAAW,EAAG;CAE1B,MAAM,QAAQ,QAAQ,KAAK,MAAM,EAAE,YAAY;AAC/C,OAAM,IAAI,MACR,qJACE,MAAM,KAAK,MAAM,OAAO,IAAI,CAAC,KAAK,KAAK,GACvC,gDAAgD,MAAM,KAAK,IAAI,GAClE"}
@@ -0,0 +1,27 @@
1
+ import { t as assignEnvVars } from "./assign-env-vars-CzHgn5ax.mjs";
2
+ import { getConnectBaseViteConfig } from "@powerhousedao/builder-tools";
3
+ import { mergeConfig, preview } from "vite";
4
+ //#region src/services/connect-preview.ts
5
+ async function runConnectPreview(args) {
6
+ const { outDir, connectBasePath, port, host, open, cors, strictPort, printUrls, bindCLIShortcuts } = args;
7
+ assignEnvVars(args);
8
+ const server = await preview(mergeConfig(getConnectBaseViteConfig({
9
+ mode: "production",
10
+ dirname: process.cwd()
11
+ }), {
12
+ build: { outDir },
13
+ preview: {
14
+ cors,
15
+ port,
16
+ strictPort,
17
+ host,
18
+ open
19
+ }
20
+ }));
21
+ if (printUrls) server.printUrls();
22
+ if (bindCLIShortcuts) server.bindCLIShortcuts({ print: true });
23
+ }
24
+ //#endregion
25
+ export { runConnectPreview };
26
+
27
+ //# sourceMappingURL=connect-preview-4Xe7Lm1V.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connect-preview-4Xe7Lm1V.mjs","names":[],"sources":["../src/services/connect-preview.ts"],"sourcesContent":["import { getConnectBaseViteConfig } from \"@powerhousedao/builder-tools\";\nimport type { InlineConfig } from \"vite\";\nimport { mergeConfig, preview } from \"vite\";\nimport type { ConnectPreviewArgs } from \"../types.js\";\nimport { assignEnvVars } from \"../utils/assign-env-vars.js\";\n\nexport async function runConnectPreview(args: ConnectPreviewArgs) {\n const {\n outDir,\n connectBasePath,\n port,\n host,\n open,\n cors,\n strictPort,\n printUrls,\n bindCLIShortcuts,\n } = args;\n\n assignEnvVars(args);\n\n const mode = \"production\";\n\n const dirname = process.cwd();\n\n const baseConfig = getConnectBaseViteConfig({\n mode,\n dirname,\n });\n\n const previewConfig: InlineConfig = {\n build: {\n outDir,\n },\n preview: {\n cors,\n port,\n strictPort,\n host,\n open,\n },\n };\n\n const config = mergeConfig(baseConfig, previewConfig);\n\n const server = await preview(config);\n\n if (printUrls) server.printUrls();\n if (bindCLIShortcuts) server.bindCLIShortcuts({ print: true });\n}\n"],"mappings":";;;;AAMA,eAAsB,kBAAkB,MAA0B;CAChE,MAAM,EACJ,QACA,iBACA,MACA,MACA,MACA,MACA,YACA,WACA,qBACE;AAEJ,eAAc,KAAK;CA0BnB,MAAM,SAAS,MAAM,QAFN,YAlBI,yBAAyB;EAC1C,MALW;EAMX,SAJc,QAAQ,KAAK;EAK5B,CAAC,EAEkC;EAClC,OAAO,EACL,QACD;EACD,SAAS;GACP;GACA;GACA;GACA;GACA;GACD;EACF,CAEoD,CAEjB;AAEpC,KAAI,UAAW,QAAO,WAAW;AACjC,KAAI,iBAAkB,QAAO,iBAAiB,EAAE,OAAO,MAAM,CAAC"}
@@ -0,0 +1,28 @@
1
+ import { t as assignEnvVars } from "./assign-env-vars-CzHgn5ax.mjs";
2
+ import { getConnectBaseViteConfig } from "@powerhousedao/builder-tools";
3
+ import { createServer, mergeConfig } from "vite";
4
+ //#region src/services/connect-studio.ts
5
+ async function runConnectStudio(args, customLogger) {
6
+ const { port, host, open, cors, strictPort, printUrls, bindCLIShortcuts } = args;
7
+ assignEnvVars(args);
8
+ const server = await createServer(mergeConfig(getConnectBaseViteConfig({
9
+ mode: "development",
10
+ dirname: process.cwd()
11
+ }), {
12
+ server: {
13
+ port,
14
+ host,
15
+ open,
16
+ cors,
17
+ strictPort
18
+ },
19
+ customLogger
20
+ }));
21
+ await server.listen();
22
+ if (printUrls) server.printUrls();
23
+ if (bindCLIShortcuts) server.bindCLIShortcuts({ print: true });
24
+ }
25
+ //#endregion
26
+ export { runConnectStudio as t };
27
+
28
+ //# sourceMappingURL=connect-studio-38_NrT_a.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connect-studio-38_NrT_a.mjs","names":[],"sources":["../src/services/connect-studio.ts"],"sourcesContent":["import { getConnectBaseViteConfig } from \"@powerhousedao/builder-tools\";\nimport type { InlineConfig, Logger } from \"vite\";\nimport { createServer, mergeConfig } from \"vite\";\nimport type { ConnectStudioArgs } from \"../types.js\";\nimport { assignEnvVars } from \"../utils/assign-env-vars.js\";\n\nexport async function runConnectStudio(\n args: ConnectStudioArgs,\n customLogger?: Logger,\n) {\n const { port, host, open, cors, strictPort, printUrls, bindCLIShortcuts } =\n args;\n assignEnvVars(args);\n const mode = \"development\";\n\n const dirname = process.cwd();\n\n const baseConfig = getConnectBaseViteConfig({\n mode,\n dirname,\n });\n\n const devServerConfig: InlineConfig = {\n server: { port, host, open, cors, strictPort },\n customLogger,\n };\n\n const config = mergeConfig(baseConfig, devServerConfig);\n\n const server = await createServer(config);\n\n await server.listen();\n\n if (printUrls) server.printUrls();\n if (bindCLIShortcuts) server.bindCLIShortcuts({ print: true });\n}\n"],"mappings":";;;;AAMA,eAAsB,iBACpB,MACA,cACA;CACA,MAAM,EAAE,MAAM,MAAM,MAAM,MAAM,YAAY,WAAW,qBACrD;AACF,eAAc,KAAK;CAiBnB,MAAM,SAAS,MAAM,aAFN,YAVI,yBAAyB;EAC1C,MALW;EAMX,SAJc,QAAQ,KAAK;EAK5B,CAAC,EAEoC;EACpC,QAAQ;GAAE;GAAM;GAAM;GAAM;GAAM;GAAY;EAC9C;EACD,CAEsD,CAEd;AAEzC,OAAM,OAAO,QAAQ;AAErB,KAAI,UAAW,QAAO,WAAW;AACjC,KAAI,iBAAkB,QAAO,iBAAiB,EAAE,OAAO,MAAM,CAAC"}
@@ -0,0 +1,3 @@
1
+ import "./assign-env-vars-CzHgn5ax.mjs";
2
+ import { t as runConnectStudio } from "./connect-studio-38_NrT_a.mjs";
3
+ export { runConnectStudio };
@@ -0,0 +1,58 @@
1
+ import { getConfig } from "@powerhousedao/config/node";
2
+ import { generate, generateApp, generateDBSchema, generateEditor, generateFromFile, generateImportScript, generateProcessor, generateSubgraph } from "@powerhousedao/codegen";
3
+ import path from "path";
4
+ //#region src/services/generate.ts
5
+ async function startGenerate(options) {
6
+ const config = getConfig();
7
+ const { skipFormat } = config;
8
+ const { documentModelFilePositional, documentModelFileOption, editorName, editorId, documentType, documentTypes, editorDirName, appName, appId, appDirName, allowedDocumentTypes, disableDragAndDrop, processorName, processorType, processorApps, importScriptName, migrationFile, schemaFile, verbose, force, useVersioning: useVersioningFlag, subgraphName, migrateLegacy } = options;
9
+ const documentModelFile = documentModelFilePositional ?? documentModelFileOption;
10
+ const useVersioning = useVersioningFlag || migrateLegacy;
11
+ const isDragAndDropEnabled = disableDragAndDrop !== true;
12
+ const filePath = Array.isArray(documentModelFile) ? documentModelFile.join(" ") : documentModelFile;
13
+ const documentTypeFromDocumentTypes = documentTypes?.split(",")[0];
14
+ if (documentTypes) console.warn(`[WARNING] --document-types is deprecated. Generated editor code is not set up to use multiple document types. Using the first document type in the list you specified (${documentTypeFromDocumentTypes})`);
15
+ const documentTypeToUse = documentType ?? documentTypeFromDocumentTypes;
16
+ if (editorName !== void 0) {
17
+ if (!documentTypeToUse) throw new Error("Please specify a document type for the generated editor.");
18
+ await generateEditor({
19
+ editorName,
20
+ editorId,
21
+ editorDirName,
22
+ documentTypes: [documentTypeToUse],
23
+ skipFormat
24
+ });
25
+ } else if (appName !== void 0) await generateApp({
26
+ appName,
27
+ appId,
28
+ appDirName,
29
+ allowedDocumentTypes,
30
+ isDragAndDropEnabled,
31
+ skipFormat
32
+ });
33
+ else if (processorName !== void 0) await generateProcessor({
34
+ processorName,
35
+ processorType,
36
+ skipFormat,
37
+ processorApps,
38
+ documentTypes: [documentTypeToUse].filter((t) => t !== void 0)
39
+ });
40
+ else if (subgraphName !== void 0) await generateSubgraph(subgraphName, filePath || null, config);
41
+ else if (importScriptName !== void 0) await generateImportScript(importScriptName, config);
42
+ else if (migrationFile !== void 0) await generateDBSchema({
43
+ migrationFile: path.join(process.cwd(), migrationFile),
44
+ schemaFile: schemaFile ? path.join(process.cwd(), schemaFile) : void 0
45
+ });
46
+ else if (filePath !== void 0) await generateFromFile({
47
+ path: filePath,
48
+ config,
49
+ options,
50
+ useVersioning,
51
+ migrateLegacy
52
+ });
53
+ else await generate(config, useVersioning, migrateLegacy);
54
+ }
55
+ //#endregion
56
+ export { startGenerate as t };
57
+
58
+ //# sourceMappingURL=generate-DXDBhwoJ.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generate-DXDBhwoJ.mjs","names":["generateCode"],"sources":["../src/services/generate.ts"],"sourcesContent":["import {\n generateApp,\n generate as generateCode,\n generateDBSchema,\n generateEditor,\n generateFromFile,\n generateImportScript,\n generateProcessor,\n generateSubgraph,\n} from \"@powerhousedao/codegen\";\nimport { getConfig } from \"@powerhousedao/config/node\";\nimport path from \"path\";\nimport type { GenerateArgs } from \"../types.js\";\n\nexport async function startGenerate(options: GenerateArgs) {\n const config = getConfig();\n const { skipFormat } = config;\n const {\n documentModelFilePositional,\n documentModelFileOption,\n editorName,\n editorId,\n documentType,\n // [DEPRECATED] - should be removed asap\n documentTypes,\n editorDirName,\n appName,\n appId,\n appDirName,\n allowedDocumentTypes,\n disableDragAndDrop,\n processorName,\n processorType,\n processorApps,\n importScriptName,\n migrationFile,\n schemaFile,\n verbose,\n force,\n useVersioning: useVersioningFlag,\n subgraphName,\n migrateLegacy,\n } = options;\n\n const documentModelFile =\n documentModelFilePositional ?? documentModelFileOption;\n\n const useVersioning = useVersioningFlag || migrateLegacy;\n const isDragAndDropEnabled = disableDragAndDrop !== true;\n const filePath = Array.isArray(documentModelFile)\n ? documentModelFile.join(\" \")\n : documentModelFile;\n\n const documentTypeFromDocumentTypes = documentTypes?.split(\",\")[0];\n if (documentTypes) {\n console.warn(\n `[WARNING] --document-types is deprecated. Generated editor code is not set up to use multiple document types. Using the first document type in the list you specified (${documentTypeFromDocumentTypes})`,\n );\n }\n const documentTypeToUse = documentType ?? documentTypeFromDocumentTypes;\n\n if (editorName !== undefined) {\n if (!documentTypeToUse) {\n throw new Error(\n \"Please specify a document type for the generated editor.\",\n );\n }\n await generateEditor({\n editorName,\n editorId,\n editorDirName,\n documentTypes: [documentTypeToUse],\n skipFormat,\n });\n } else if (appName !== undefined) {\n await generateApp({\n appName,\n appId,\n appDirName,\n allowedDocumentTypes,\n isDragAndDropEnabled,\n skipFormat,\n });\n } else if (processorName !== undefined) {\n await generateProcessor({\n processorName,\n processorType,\n skipFormat,\n processorApps,\n documentTypes: [documentTypeToUse].filter((t) => t !== undefined),\n });\n } else if (subgraphName !== undefined) {\n await generateSubgraph(subgraphName, filePath || null, config);\n } else if (importScriptName !== undefined) {\n await generateImportScript(importScriptName, config);\n } else if (migrationFile !== undefined) {\n await generateDBSchema({\n migrationFile: path.join(process.cwd(), migrationFile),\n schemaFile: schemaFile ? path.join(process.cwd(), schemaFile) : undefined,\n });\n } else if (filePath !== undefined) {\n await generateFromFile({\n path: filePath,\n config,\n options,\n useVersioning,\n migrateLegacy,\n });\n } else {\n await generateCode(config, useVersioning, migrateLegacy);\n }\n}\n"],"mappings":";;;;AAcA,eAAsB,cAAc,SAAuB;CACzD,MAAM,SAAS,WAAW;CAC1B,MAAM,EAAE,eAAe;CACvB,MAAM,EACJ,6BACA,yBACA,YACA,UACA,cAEA,eACA,eACA,SACA,OACA,YACA,sBACA,oBACA,eACA,eACA,eACA,kBACA,eACA,YACA,SACA,OACA,eAAe,mBACf,cACA,kBACE;CAEJ,MAAM,oBACJ,+BAA+B;CAEjC,MAAM,gBAAgB,qBAAqB;CAC3C,MAAM,uBAAuB,uBAAuB;CACpD,MAAM,WAAW,MAAM,QAAQ,kBAAkB,GAC7C,kBAAkB,KAAK,IAAI,GAC3B;CAEJ,MAAM,gCAAgC,eAAe,MAAM,IAAI,CAAC;AAChE,KAAI,cACF,SAAQ,KACN,0KAA0K,8BAA8B,GACzM;CAEH,MAAM,oBAAoB,gBAAgB;AAE1C,KAAI,eAAe,KAAA,GAAW;AAC5B,MAAI,CAAC,kBACH,OAAM,IAAI,MACR,2DACD;AAEH,QAAM,eAAe;GACnB;GACA;GACA;GACA,eAAe,CAAC,kBAAkB;GAClC;GACD,CAAC;YACO,YAAY,KAAA,EACrB,OAAM,YAAY;EAChB;EACA;EACA;EACA;EACA;EACA;EACD,CAAC;UACO,kBAAkB,KAAA,EAC3B,OAAM,kBAAkB;EACtB;EACA;EACA;EACA;EACA,eAAe,CAAC,kBAAkB,CAAC,QAAQ,MAAM,MAAM,KAAA,EAAU;EAClE,CAAC;UACO,iBAAiB,KAAA,EAC1B,OAAM,iBAAiB,cAAc,YAAY,MAAM,OAAO;UACrD,qBAAqB,KAAA,EAC9B,OAAM,qBAAqB,kBAAkB,OAAO;UAC3C,kBAAkB,KAAA,EAC3B,OAAM,iBAAiB;EACrB,eAAe,KAAK,KAAK,QAAQ,KAAK,EAAE,cAAc;EACtD,YAAY,aAAa,KAAK,KAAK,QAAQ,KAAK,EAAE,WAAW,GAAG,KAAA;EACjE,CAAC;UACO,aAAa,KAAA,EACtB,OAAM,iBAAiB;EACrB,MAAM;EACN;EACA;EACA;EACA;EACD,CAAC;KAEF,OAAMA,SAAa,QAAQ,eAAe,cAAc"}
@@ -0,0 +1,2 @@
1
+ import { t as startGenerate } from "./generate-DXDBhwoJ.mjs";
2
+ export { startGenerate };
@@ -0,0 +1,124 @@
1
+ import { handleMutuallyExclusiveOptions, parsePackageManager, parseTag } from "@powerhousedao/shared/clis";
2
+ import { createProject } from "@powerhousedao/codegen";
3
+ import chalk from "chalk";
4
+ import { kebabCase } from "change-case";
5
+ import enquirer from "enquirer";
6
+ import { clean, valid } from "semver";
7
+ import { createVetraDocument, getVetraDocuments } from "@powerhousedao/common/utils";
8
+ //#region src/utils/validate-remote-drive.ts
9
+ /**
10
+ * Sets up a remote drive for initialization by validating and creating
11
+ * a Vetra document if needed.
12
+ * Returns true if setup succeeds, false if it should stop execution.
13
+ */
14
+ async function setupRemoteDrive(remoteDriveUrl) {
15
+ try {
16
+ const driveId = remoteDriveUrl.split("/").pop();
17
+ if (!remoteDriveUrl || remoteDriveUrl.trim() === "") {
18
+ console.error("❌ Remote drive URL is required");
19
+ return false;
20
+ }
21
+ const url = new URL(remoteDriveUrl);
22
+ const graphqlEndpoint = `${url.protocol}//${url.host}/graphql`;
23
+ let documents = await getVetraDocuments(graphqlEndpoint, driveId);
24
+ if (documents.length === 0) {
25
+ console.log("No vetra package document found in the provided drive, creating one...");
26
+ try {
27
+ await createVetraDocument(graphqlEndpoint, driveId, "vetra-package");
28
+ documents = await getVetraDocuments(graphqlEndpoint, driveId);
29
+ if (documents.length === 0) {
30
+ console.error("❌ Failed to create vetra package document in the remote drive");
31
+ return false;
32
+ }
33
+ console.log("✅ Vetra package document created successfully");
34
+ } catch (createError) {
35
+ console.error("❌ Failed to create vetra package document:", createError);
36
+ return false;
37
+ }
38
+ }
39
+ if (documents.length > 1) console.warn("⚠️ Multiple vetra package documents were found in the provided remote drive, this might be an error in your remote drive");
40
+ if (documents.some((doc) => doc.githubUrl)) {
41
+ console.error("❌ The remote drive provided already has been configured with a github url, please use the checkout command instead: ph checkout --remote-drive <remote drive url>");
42
+ return false;
43
+ }
44
+ return true;
45
+ } catch (error) {
46
+ console.error("❌ Unable to fetch remote drive info:", error);
47
+ return false;
48
+ }
49
+ }
50
+ //#endregion
51
+ //#region src/services/init.ts
52
+ async function startInit(args) {
53
+ const { namePositional, nameOption, packageManager, npm, pnpm, yarn, bun, tag, version, dev, staging, remoteDrive } = args;
54
+ let name = namePositional ?? nameOption;
55
+ if (!name) {
56
+ const { prompt } = enquirer;
57
+ name = (await prompt([{
58
+ type: "input",
59
+ name: "name",
60
+ message: "What is the project name?",
61
+ required: true,
62
+ result: (value) => kebabCase(value)
63
+ }])).name;
64
+ }
65
+ if (!name) throw new Error("You must provide a name for your project.");
66
+ if (version !== void 0 && !valid(clean(version))) throw new Error(`Invalid version: ${version}`);
67
+ handleMutuallyExclusiveOptions({
68
+ tag,
69
+ version,
70
+ dev,
71
+ staging
72
+ }, "versioning strategy");
73
+ handleMutuallyExclusiveOptions({
74
+ npm,
75
+ pnpm,
76
+ yarn,
77
+ bun,
78
+ packageManager
79
+ }, "package manager");
80
+ const parsedPackageManager = parsePackageManager({
81
+ npm,
82
+ pnpm,
83
+ yarn,
84
+ bun,
85
+ packageManager
86
+ }) ?? "npm";
87
+ const parsedTag = parseTag({
88
+ tag,
89
+ dev,
90
+ staging
91
+ });
92
+ try {
93
+ if (remoteDrive) {
94
+ console.log(chalk.blue("\n⏳ Setting up remote drive...\n"));
95
+ await setupRemoteDrive(remoteDrive);
96
+ console.log(chalk.green("\n✅ Remote drive set up."));
97
+ }
98
+ console.log(chalk.bold("\n🚀 Initializing a new project...\n"));
99
+ await createProject({
100
+ ...args,
101
+ name,
102
+ packageManager: parsedPackageManager,
103
+ tag: parsedTag
104
+ });
105
+ if (remoteDrive) {
106
+ console.log();
107
+ console.log("To link your project to GitHub:");
108
+ console.log();
109
+ console.log(" 1. Create a new repository on GitHub");
110
+ console.log(` 2. cd ${name}`);
111
+ console.log(" 3. git add . && git commit -m 'Initial commit'");
112
+ console.log(" 4. git remote add origin <your-github-url>");
113
+ console.log(` 5. git push -u origin main`);
114
+ console.log();
115
+ }
116
+ } catch (error) {
117
+ console.error("\n❌ Failed to initialize project: \n");
118
+ throw error;
119
+ }
120
+ }
121
+ //#endregion
122
+ export { startInit };
123
+
124
+ //# sourceMappingURL=init-BsmDWu9-.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"init-BsmDWu9-.mjs","names":[],"sources":["../src/utils/validate-remote-drive.ts","../src/services/init.ts"],"sourcesContent":["import {\n createVetraDocument,\n getVetraDocuments,\n} from \"@powerhousedao/common/utils\";\n\n/**\n * Sets up a remote drive for initialization by validating and creating\n * a Vetra document if needed.\n * Returns true if setup succeeds, false if it should stop execution.\n */\nexport async function setupRemoteDrive(\n remoteDriveUrl: string,\n): Promise<boolean> {\n try {\n // Parse driveId from URL\n const driveId = remoteDriveUrl.split(\"/\").pop();\n\n if (!remoteDriveUrl || remoteDriveUrl.trim() === \"\") {\n console.error(\"❌ Remote drive URL is required\");\n return false;\n }\n\n // Construct GraphQL endpoint from base URL\n const url = new URL(remoteDriveUrl);\n const graphqlEndpoint = `${url.protocol}//${url.host}/graphql`;\n\n let documents = await getVetraDocuments(graphqlEndpoint, driveId!);\n\n if (documents.length === 0) {\n console.log(\n \"No vetra package document found in the provided drive, creating one...\",\n );\n try {\n await createVetraDocument(graphqlEndpoint, driveId!, \"vetra-package\");\n\n // Re-fetch documents after creation\n documents = await getVetraDocuments(graphqlEndpoint, driveId!);\n\n if (documents.length === 0) {\n console.error(\n \"❌ Failed to create vetra package document in the remote drive\",\n );\n return false;\n }\n\n console.log(\"✅ Vetra package document created successfully\");\n } catch (createError) {\n console.error(\n \"❌ Failed to create vetra package document:\",\n createError,\n );\n return false;\n }\n }\n\n if (documents.length > 1) {\n console.warn(\n \"⚠️ Multiple vetra package documents were found in the provided remote drive, this might be an error in your remote drive\",\n );\n }\n\n const hasGithubUrl = documents.some((doc) => doc.githubUrl);\n\n if (hasGithubUrl) {\n console.error(\n \"❌ The remote drive provided already has been configured with a github url, please use the checkout command instead: ph checkout --remote-drive <remote drive url>\",\n );\n return false;\n }\n\n return true;\n } catch (error) {\n console.error(\"❌ Unable to fetch remote drive info:\", error);\n return false;\n }\n}\n","import { createProject } from \"@powerhousedao/codegen\";\nimport {\n handleMutuallyExclusiveOptions,\n parsePackageManager,\n parseTag,\n} from \"@powerhousedao/shared/clis\";\nimport chalk from \"chalk\";\nimport { kebabCase } from \"change-case\";\nimport enquirer from \"enquirer\";\nimport { clean, valid } from \"semver\";\nimport type { InitArgs } from \"../types.js\";\nimport { setupRemoteDrive } from \"../utils/validate-remote-drive.js\";\n\nexport async function startInit(args: InitArgs) {\n const {\n namePositional,\n nameOption,\n packageManager,\n npm,\n pnpm,\n yarn,\n bun,\n tag,\n version,\n dev,\n staging,\n remoteDrive,\n } = args;\n\n let name = namePositional ?? nameOption;\n if (!name) {\n const { prompt } = enquirer;\n\n const result = await prompt<{ name: string }>([\n {\n type: \"input\",\n name: \"name\",\n message: \"What is the project name?\",\n required: true,\n result: (value) => kebabCase(value),\n },\n ]);\n name = result.name;\n }\n if (!name) {\n throw new Error(\"You must provide a name for your project.\");\n }\n\n if (version !== undefined && !valid(clean(version))) {\n throw new Error(`Invalid version: ${version}`);\n }\n\n handleMutuallyExclusiveOptions(\n {\n tag,\n version,\n dev,\n staging,\n },\n \"versioning strategy\",\n );\n\n handleMutuallyExclusiveOptions(\n {\n npm,\n pnpm,\n yarn,\n bun,\n packageManager,\n },\n \"package manager\",\n );\n\n const parsedPackageManager =\n parsePackageManager({\n npm,\n pnpm,\n yarn,\n bun,\n packageManager,\n }) ?? \"npm\";\n\n const parsedTag = parseTag({\n tag,\n dev,\n staging,\n });\n\n try {\n if (remoteDrive) {\n console.log(chalk.blue(\"\\n⏳ Setting up remote drive...\\n\"));\n await setupRemoteDrive(remoteDrive);\n console.log(chalk.green(\"\\n✅ Remote drive set up.\"));\n }\n\n console.log(chalk.bold(\"\\n🚀 Initializing a new project...\\n\"));\n await createProject({\n ...args,\n name,\n packageManager: parsedPackageManager,\n tag: parsedTag,\n });\n\n if (remoteDrive) {\n console.log();\n console.log(\"To link your project to GitHub:\");\n console.log();\n console.log(\" 1. Create a new repository on GitHub\");\n console.log(` 2. cd ${name}`);\n console.log(\" 3. git add . && git commit -m 'Initial commit'\");\n console.log(\" 4. git remote add origin <your-github-url>\");\n console.log(` 5. git push -u origin main`);\n console.log();\n }\n } catch (error) {\n console.error(\"\\n❌ Failed to initialize project: \\n\");\n throw error;\n }\n}\n"],"mappings":";;;;;;;;;;;;;AAUA,eAAsB,iBACpB,gBACkB;AAClB,KAAI;EAEF,MAAM,UAAU,eAAe,MAAM,IAAI,CAAC,KAAK;AAE/C,MAAI,CAAC,kBAAkB,eAAe,MAAM,KAAK,IAAI;AACnD,WAAQ,MAAM,iCAAiC;AAC/C,UAAO;;EAIT,MAAM,MAAM,IAAI,IAAI,eAAe;EACnC,MAAM,kBAAkB,GAAG,IAAI,SAAS,IAAI,IAAI,KAAK;EAErD,IAAI,YAAY,MAAM,kBAAkB,iBAAiB,QAAS;AAElE,MAAI,UAAU,WAAW,GAAG;AAC1B,WAAQ,IACN,yEACD;AACD,OAAI;AACF,UAAM,oBAAoB,iBAAiB,SAAU,gBAAgB;AAGrE,gBAAY,MAAM,kBAAkB,iBAAiB,QAAS;AAE9D,QAAI,UAAU,WAAW,GAAG;AAC1B,aAAQ,MACN,gEACD;AACD,YAAO;;AAGT,YAAQ,IAAI,gDAAgD;YACrD,aAAa;AACpB,YAAQ,MACN,8CACA,YACD;AACD,WAAO;;;AAIX,MAAI,UAAU,SAAS,EACrB,SAAQ,KACN,4HACD;AAKH,MAFqB,UAAU,MAAM,QAAQ,IAAI,UAAU,EAEzC;AAChB,WAAQ,MACN,oKACD;AACD,UAAO;;AAGT,SAAO;UACA,OAAO;AACd,UAAQ,MAAM,wCAAwC,MAAM;AAC5D,SAAO;;;;;AC5DX,eAAsB,UAAU,MAAgB;CAC9C,MAAM,EACJ,gBACA,YACA,gBACA,KACA,MACA,MACA,KACA,KACA,SACA,KACA,SACA,gBACE;CAEJ,IAAI,OAAO,kBAAkB;AAC7B,KAAI,CAAC,MAAM;EACT,MAAM,EAAE,WAAW;AAWnB,UATe,MAAM,OAAyB,CAC5C;GACE,MAAM;GACN,MAAM;GACN,SAAS;GACT,UAAU;GACV,SAAS,UAAU,UAAU,MAAM;GACpC,CACF,CAAC,EACY;;AAEhB,KAAI,CAAC,KACH,OAAM,IAAI,MAAM,4CAA4C;AAG9D,KAAI,YAAY,KAAA,KAAa,CAAC,MAAM,MAAM,QAAQ,CAAC,CACjD,OAAM,IAAI,MAAM,oBAAoB,UAAU;AAGhD,gCACE;EACE;EACA;EACA;EACA;EACD,EACD,sBACD;AAED,gCACE;EACE;EACA;EACA;EACA;EACA;EACD,EACD,kBACD;CAED,MAAM,uBACJ,oBAAoB;EAClB;EACA;EACA;EACA;EACA;EACD,CAAC,IAAI;CAER,MAAM,YAAY,SAAS;EACzB;EACA;EACA;EACD,CAAC;AAEF,KAAI;AACF,MAAI,aAAa;AACf,WAAQ,IAAI,MAAM,KAAK,mCAAmC,CAAC;AAC3D,SAAM,iBAAiB,YAAY;AACnC,WAAQ,IAAI,MAAM,MAAM,2BAA2B,CAAC;;AAGtD,UAAQ,IAAI,MAAM,KAAK,uCAAuC,CAAC;AAC/D,QAAM,cAAc;GAClB,GAAG;GACH;GACA,gBAAgB;GAChB,KAAK;GACN,CAAC;AAEF,MAAI,aAAa;AACf,WAAQ,KAAK;AACb,WAAQ,IAAI,kCAAkC;AAC9C,WAAQ,KAAK;AACb,WAAQ,IAAI,yCAAyC;AACrD,WAAQ,IAAI,WAAW,OAAO;AAC9B,WAAQ,IAAI,mDAAmD;AAC/D,WAAQ,IAAI,+CAA+C;AAC3D,WAAQ,IAAI,+BAA+B;AAC3C,WAAQ,KAAK;;UAER,OAAO;AACd,UAAQ,MAAM,uCAAuC;AACrD,QAAM"}
@@ -0,0 +1,45 @@
1
+ import { n as getProjectInfo } from "./utils-CFkM2mAC.mjs";
2
+ import fs from "node:fs";
3
+ //#region src/services/inspect.ts
4
+ function startInspect(args) {
5
+ if (args.debug) console.log(">>> command arguments", args);
6
+ const projectInfo = getProjectInfo(args.debug);
7
+ const { packageName } = args;
8
+ if (args.debug) console.log("\n>>> projectInfo", projectInfo);
9
+ try {
10
+ const loadManifest = (path) => JSON.parse(fs.readFileSync(path, "utf-8"));
11
+ const manifest = loadManifest(`${process.cwd()}/node_modules/${packageName}/dist/powerhouse.manifest.json`);
12
+ console.log(manifest.name);
13
+ if (manifest.documentModels) {
14
+ console.log("\nDocument Models:");
15
+ manifest.documentModels.forEach((model) => {
16
+ console.log(`- ${model.name} (${model.id})`);
17
+ });
18
+ }
19
+ if (manifest.editors) {
20
+ console.log("\nEditors:");
21
+ manifest.editors.forEach((editor) => {
22
+ console.log(`- ${editor.name} (${editor.id})`);
23
+ });
24
+ }
25
+ if (manifest.processors) {
26
+ console.log("\nProcessors:");
27
+ manifest.processors.forEach((processor) => {
28
+ console.log(`- ${processor.name} (${processor.id})`);
29
+ });
30
+ }
31
+ if (manifest.subgraphs) {
32
+ console.log("\nSubgraphs:");
33
+ manifest.subgraphs.forEach((subgraph) => {
34
+ console.log(`- ${subgraph.name} (${subgraph.id})`);
35
+ });
36
+ }
37
+ } catch (e) {
38
+ if (args.debug) console.error(e);
39
+ else console.log("No manifest found in the package");
40
+ }
41
+ }
42
+ //#endregion
43
+ export { startInspect };
44
+
45
+ //# sourceMappingURL=inspect-BMrHr09E.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"inspect-BMrHr09E.mjs","names":[],"sources":["../src/services/inspect.ts"],"sourcesContent":["import type { Manifest } from \"@powerhousedao/shared/document-model\";\nimport fs from \"node:fs\";\nimport type { InspectArgs } from \"../types.js\";\nimport { getProjectInfo } from \"../utils.js\";\nexport function startInspect(args: InspectArgs) {\n if (args.debug) {\n console.log(\">>> command arguments\", args);\n }\n\n const projectInfo = getProjectInfo(args.debug);\n const { packageName } = args;\n\n if (args.debug) {\n console.log(\"\\n>>> projectInfo\", projectInfo);\n }\n\n try {\n const loadManifest = (path: string) =>\n JSON.parse(fs.readFileSync(path, \"utf-8\")) as Manifest;\n const manifest = loadManifest(\n `${process.cwd()}/node_modules/${packageName}/dist/powerhouse.manifest.json`,\n );\n\n console.log(manifest.name);\n if (manifest.documentModels) {\n console.log(\"\\nDocument Models:\");\n manifest.documentModels.forEach((model) => {\n console.log(`- ${model.name} (${model.id})`);\n });\n }\n\n if (manifest.editors) {\n console.log(\"\\nEditors:\");\n manifest.editors.forEach((editor) => {\n console.log(`- ${editor.name} (${editor.id})`);\n });\n }\n\n if (manifest.processors) {\n console.log(\"\\nProcessors:\");\n manifest.processors.forEach((processor) => {\n console.log(`- ${processor.name} (${processor.id})`);\n });\n }\n\n if (manifest.subgraphs) {\n console.log(\"\\nSubgraphs:\");\n manifest.subgraphs.forEach((subgraph) => {\n console.log(`- ${subgraph.name} (${subgraph.id})`);\n });\n }\n } catch (e) {\n if (args.debug) {\n console.error(e);\n } else {\n console.log(\"No manifest found in the package\");\n }\n }\n}\n"],"mappings":";;;AAIA,SAAgB,aAAa,MAAmB;AAC9C,KAAI,KAAK,MACP,SAAQ,IAAI,yBAAyB,KAAK;CAG5C,MAAM,cAAc,eAAe,KAAK,MAAM;CAC9C,MAAM,EAAE,gBAAgB;AAExB,KAAI,KAAK,MACP,SAAQ,IAAI,qBAAqB,YAAY;AAG/C,KAAI;EACF,MAAM,gBAAgB,SACpB,KAAK,MAAM,GAAG,aAAa,MAAM,QAAQ,CAAC;EAC5C,MAAM,WAAW,aACf,GAAG,QAAQ,KAAK,CAAC,gBAAgB,YAAY,gCAC9C;AAED,UAAQ,IAAI,SAAS,KAAK;AAC1B,MAAI,SAAS,gBAAgB;AAC3B,WAAQ,IAAI,qBAAqB;AACjC,YAAS,eAAe,SAAS,UAAU;AACzC,YAAQ,IAAI,KAAK,MAAM,KAAK,IAAI,MAAM,GAAG,GAAG;KAC5C;;AAGJ,MAAI,SAAS,SAAS;AACpB,WAAQ,IAAI,aAAa;AACzB,YAAS,QAAQ,SAAS,WAAW;AACnC,YAAQ,IAAI,KAAK,OAAO,KAAK,IAAI,OAAO,GAAG,GAAG;KAC9C;;AAGJ,MAAI,SAAS,YAAY;AACvB,WAAQ,IAAI,gBAAgB;AAC5B,YAAS,WAAW,SAAS,cAAc;AACzC,YAAQ,IAAI,KAAK,UAAU,KAAK,IAAI,UAAU,GAAG,GAAG;KACpD;;AAGJ,MAAI,SAAS,WAAW;AACtB,WAAQ,IAAI,eAAe;AAC3B,YAAS,UAAU,SAAS,aAAa;AACvC,YAAQ,IAAI,KAAK,SAAS,KAAK,IAAI,SAAS,GAAG,GAAG;KAClD;;UAEG,GAAG;AACV,MAAI,KAAK,MACP,SAAQ,MAAM,EAAE;MAEhB,SAAQ,IAAI,mCAAmC"}