@powerhousedao/ph-cli 6.0.0-dev.22 → 6.0.0-dev.221

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 (305) hide show
  1. package/dist/assign-env-vars-DZMMuzB2.mjs +15 -0
  2. package/dist/assign-env-vars-DZMMuzB2.mjs.map +1 -0
  3. package/dist/auth-BtzNlVSv.mjs +2 -0
  4. package/dist/auth-DFjfbgA-.mjs +15 -0
  5. package/dist/auth-DFjfbgA-.mjs.map +1 -0
  6. package/dist/build-DIv8xMX2.mjs +46 -0
  7. package/dist/build-DIv8xMX2.mjs.map +1 -0
  8. package/dist/cli-CFWMyGVU.mjs +140 -0
  9. package/dist/cli-CFWMyGVU.mjs.map +1 -0
  10. package/dist/cli.d.mts +1 -0
  11. package/dist/cli.mjs +923 -0
  12. package/dist/cli.mjs.map +1 -0
  13. package/dist/connect-build-BXuIuTCu.mjs +35 -0
  14. package/dist/connect-build-BXuIuTCu.mjs.map +1 -0
  15. package/dist/connect-preview-CaEiWmqU.mjs +27 -0
  16. package/dist/connect-preview-CaEiWmqU.mjs.map +1 -0
  17. package/dist/connect-studio-BaqbrWYQ.mjs +28 -0
  18. package/dist/connect-studio-BaqbrWYQ.mjs.map +1 -0
  19. package/dist/connect-studio-Dndkp0Q_.mjs +3 -0
  20. package/dist/generate-all-DaXXjoms.mjs +12 -0
  21. package/dist/generate-all-DaXXjoms.mjs.map +1 -0
  22. package/dist/generate-app-GvQeAG4w.mjs +35 -0
  23. package/dist/generate-app-GvQeAG4w.mjs.map +1 -0
  24. package/dist/generate-document-model-Dnik0rKd.mjs +21 -0
  25. package/dist/generate-document-model-Dnik0rKd.mjs.map +1 -0
  26. package/dist/generate-editor-BNN2OmmX.mjs +35 -0
  27. package/dist/generate-editor-BNN2OmmX.mjs.map +1 -0
  28. package/dist/generate-processor-CCSW2Ed2.mjs +26 -0
  29. package/dist/generate-processor-CCSW2Ed2.mjs.map +1 -0
  30. package/dist/generate-subgraph-B-d3J6hU.mjs +24 -0
  31. package/dist/generate-subgraph-B-d3J6hU.mjs.map +1 -0
  32. package/dist/init-BgKiiFju.mjs +124 -0
  33. package/dist/init-BgKiiFju.mjs.map +1 -0
  34. package/dist/inspect-czss6pZb.mjs +45 -0
  35. package/dist/inspect-czss6pZb.mjs.map +1 -0
  36. package/dist/logout-DcpByE5i.mjs +230 -0
  37. package/dist/logout-DcpByE5i.mjs.map +1 -0
  38. package/dist/migrate-DLEG7ehb.mjs +11 -0
  39. package/dist/migrate-DLEG7ehb.mjs.map +1 -0
  40. package/dist/scripts/generate-commands-docs.ts +16 -8
  41. package/dist/switchboard-2B5VC_cr.mjs +2 -0
  42. package/dist/switchboard-DGbd-EPx.mjs +72 -0
  43. package/dist/switchboard-DGbd-EPx.mjs.map +1 -0
  44. package/dist/switchboard-migrate-81jhmuWu.mjs +50 -0
  45. package/dist/switchboard-migrate-81jhmuWu.mjs.map +1 -0
  46. package/dist/utils-C6_gv4nB.mjs +162 -0
  47. package/dist/utils-C6_gv4nB.mjs.map +1 -0
  48. package/dist/vetra--a0x272X.mjs +420 -0
  49. package/dist/vetra--a0x272X.mjs.map +1 -0
  50. package/package.json +44 -46
  51. package/dist/scripts/generate-commands-docs.d.ts +0 -2
  52. package/dist/scripts/generate-commands-docs.d.ts.map +0 -1
  53. package/dist/scripts/generate-commands-docs.js +0 -47
  54. package/dist/scripts/generate-commands-docs.js.map +0 -1
  55. package/dist/scripts/generate-docs-legacy.d.ts +0 -2
  56. package/dist/scripts/generate-docs-legacy.d.ts.map +0 -1
  57. package/dist/scripts/generate-docs-legacy.js +0 -72
  58. package/dist/scripts/generate-docs-legacy.js.map +0 -1
  59. package/dist/scripts/generate-docs-legacy.ts +0 -84
  60. package/dist/scripts/generate-version.d.ts +0 -2
  61. package/dist/scripts/generate-version.d.ts.map +0 -1
  62. package/dist/scripts/generate-version.js +0 -13
  63. package/dist/scripts/generate-version.js.map +0 -1
  64. package/dist/scripts/generate-version.ts +0 -22
  65. package/dist/src/cli.d.ts +0 -3
  66. package/dist/src/cli.d.ts.map +0 -1
  67. package/dist/src/cli.js +0 -29
  68. package/dist/src/cli.js.map +0 -1
  69. package/dist/src/cli.old.d.ts +0 -3
  70. package/dist/src/cli.old.d.ts.map +0 -1
  71. package/dist/src/cli.old.js +0 -43
  72. package/dist/src/cli.old.js.map +0 -1
  73. package/dist/src/commands/access-token.d.ts +0 -14
  74. package/dist/src/commands/access-token.d.ts.map +0 -1
  75. package/dist/src/commands/access-token.js +0 -142
  76. package/dist/src/commands/access-token.js.map +0 -1
  77. package/dist/src/commands/connect.d.ts +0 -249
  78. package/dist/src/commands/connect.d.ts.map +0 -1
  79. package/dist/src/commands/connect.js +0 -60
  80. package/dist/src/commands/connect.js.map +0 -1
  81. package/dist/src/commands/generate.d.ts +0 -58
  82. package/dist/src/commands/generate.d.ts.map +0 -1
  83. package/dist/src/commands/generate.js +0 -25
  84. package/dist/src/commands/generate.js.map +0 -1
  85. package/dist/src/commands/get-package-manager.d.ts +0 -30
  86. package/dist/src/commands/get-package-manager.d.ts.map +0 -1
  87. package/dist/src/commands/get-package-manager.js +0 -8
  88. package/dist/src/commands/get-package-manager.js.map +0 -1
  89. package/dist/src/commands/index.d.ts +0 -13
  90. package/dist/src/commands/index.d.ts.map +0 -1
  91. package/dist/src/commands/index.js +0 -25
  92. package/dist/src/commands/index.js.map +0 -1
  93. package/dist/src/commands/inspect.d.ts +0 -12
  94. package/dist/src/commands/inspect.d.ts.map +0 -1
  95. package/dist/src/commands/inspect.js +0 -27
  96. package/dist/src/commands/inspect.js.map +0 -1
  97. package/dist/src/commands/install.d.ts +0 -22
  98. package/dist/src/commands/install.d.ts.map +0 -1
  99. package/dist/src/commands/install.js +0 -75
  100. package/dist/src/commands/install.js.map +0 -1
  101. package/dist/src/commands/legacy/access-token.old.d.ts +0 -9
  102. package/dist/src/commands/legacy/access-token.old.d.ts.map +0 -1
  103. package/dist/src/commands/legacy/access-token.old.js +0 -110
  104. package/dist/src/commands/legacy/access-token.old.js.map +0 -1
  105. package/dist/src/commands/legacy/connect.old.d.ts +0 -19
  106. package/dist/src/commands/legacy/connect.old.d.ts.map +0 -1
  107. package/dist/src/commands/legacy/connect.old.js +0 -85
  108. package/dist/src/commands/legacy/connect.old.js.map +0 -1
  109. package/dist/src/commands/legacy/generate.old.d.ts +0 -9
  110. package/dist/src/commands/legacy/generate.old.d.ts.map +0 -1
  111. package/dist/src/commands/legacy/generate.old.js +0 -41
  112. package/dist/src/commands/legacy/generate.old.js.map +0 -1
  113. package/dist/src/commands/legacy/help.old.d.ts +0 -3
  114. package/dist/src/commands/legacy/help.old.d.ts.map +0 -1
  115. package/dist/src/commands/legacy/help.old.js +0 -9
  116. package/dist/src/commands/legacy/help.old.js.map +0 -1
  117. package/dist/src/commands/legacy/inspect.old.d.ts +0 -6
  118. package/dist/src/commands/legacy/inspect.old.d.ts.map +0 -1
  119. package/dist/src/commands/legacy/inspect.old.js +0 -21
  120. package/dist/src/commands/legacy/inspect.old.js.map +0 -1
  121. package/dist/src/commands/legacy/install.old.d.ts +0 -15
  122. package/dist/src/commands/legacy/install.old.d.ts.map +0 -1
  123. package/dist/src/commands/legacy/install.old.js +0 -127
  124. package/dist/src/commands/legacy/install.old.js.map +0 -1
  125. package/dist/src/commands/legacy/login.old.d.ts +0 -12
  126. package/dist/src/commands/legacy/login.old.d.ts.map +0 -1
  127. package/dist/src/commands/legacy/login.old.js +0 -208
  128. package/dist/src/commands/legacy/login.old.js.map +0 -1
  129. package/dist/src/commands/legacy/migrate.old.d.ts +0 -11
  130. package/dist/src/commands/legacy/migrate.old.d.ts.map +0 -1
  131. package/dist/src/commands/legacy/migrate.old.js +0 -15
  132. package/dist/src/commands/legacy/migrate.old.js.map +0 -1
  133. package/dist/src/commands/legacy/service.old.d.ts +0 -5
  134. package/dist/src/commands/legacy/service.old.d.ts.map +0 -1
  135. package/dist/src/commands/legacy/service.old.js +0 -67
  136. package/dist/src/commands/legacy/service.old.js.map +0 -1
  137. package/dist/src/commands/legacy/switchboard.old.d.ts +0 -9
  138. package/dist/src/commands/legacy/switchboard.old.d.ts.map +0 -1
  139. package/dist/src/commands/legacy/switchboard.old.js +0 -78
  140. package/dist/src/commands/legacy/switchboard.old.js.map +0 -1
  141. package/dist/src/commands/legacy/uninstall.old.d.ts +0 -15
  142. package/dist/src/commands/legacy/uninstall.old.d.ts.map +0 -1
  143. package/dist/src/commands/legacy/uninstall.old.js +0 -120
  144. package/dist/src/commands/legacy/uninstall.old.js.map +0 -1
  145. package/dist/src/commands/legacy/vetra.old.d.ts +0 -23
  146. package/dist/src/commands/legacy/vetra.old.d.ts.map +0 -1
  147. package/dist/src/commands/legacy/vetra.old.js +0 -35
  148. package/dist/src/commands/legacy/vetra.old.js.map +0 -1
  149. package/dist/src/commands/list.d.ts +0 -10
  150. package/dist/src/commands/list.d.ts.map +0 -1
  151. package/dist/src/commands/list.js +0 -42
  152. package/dist/src/commands/list.js.map +0 -1
  153. package/dist/src/commands/list.old.d.ts +0 -9
  154. package/dist/src/commands/list.old.d.ts.map +0 -1
  155. package/dist/src/commands/list.old.js +0 -36
  156. package/dist/src/commands/list.old.js.map +0 -1
  157. package/dist/src/commands/login.d.ts +0 -20
  158. package/dist/src/commands/login.d.ts.map +0 -1
  159. package/dist/src/commands/login.js +0 -209
  160. package/dist/src/commands/login.js.map +0 -1
  161. package/dist/src/commands/migrate.d.ts +0 -12
  162. package/dist/src/commands/migrate.d.ts.map +0 -1
  163. package/dist/src/commands/migrate.js +0 -16
  164. package/dist/src/commands/migrate.js.map +0 -1
  165. package/dist/src/commands/ph-cli-commands.d.ts +0 -410
  166. package/dist/src/commands/ph-cli-commands.d.ts.map +0 -1
  167. package/dist/src/commands/ph-cli-commands.js +0 -25
  168. package/dist/src/commands/ph-cli-commands.js.map +0 -1
  169. package/dist/src/commands/ph-cli-help.d.ts +0 -396
  170. package/dist/src/commands/ph-cli-help.d.ts.map +0 -1
  171. package/dist/src/commands/ph-cli-help.js +0 -12
  172. package/dist/src/commands/ph-cli-help.js.map +0 -1
  173. package/dist/src/commands/ph-cli.d.ts +0 -490
  174. package/dist/src/commands/ph-cli.d.ts.map +0 -1
  175. package/dist/src/commands/ph-cli.js +0 -12
  176. package/dist/src/commands/ph-cli.js.map +0 -1
  177. package/dist/src/commands/register-commands.d.ts +0 -5
  178. package/dist/src/commands/register-commands.d.ts.map +0 -1
  179. package/dist/src/commands/register-commands.js +0 -32
  180. package/dist/src/commands/register-commands.js.map +0 -1
  181. package/dist/src/commands/service.d.ts +0 -12
  182. package/dist/src/commands/service.d.ts.map +0 -1
  183. package/dist/src/commands/service.js +0 -79
  184. package/dist/src/commands/service.js.map +0 -1
  185. package/dist/src/commands/switchboard.d.ts +0 -46
  186. package/dist/src/commands/switchboard.d.ts.map +0 -1
  187. package/dist/src/commands/switchboard.js +0 -43
  188. package/dist/src/commands/switchboard.js.map +0 -1
  189. package/dist/src/commands/uninstall.d.ts +0 -22
  190. package/dist/src/commands/uninstall.d.ts.map +0 -1
  191. package/dist/src/commands/uninstall.js +0 -71
  192. package/dist/src/commands/uninstall.js.map +0 -1
  193. package/dist/src/commands/vetra.d.ts +0 -64
  194. package/dist/src/commands/vetra.d.ts.map +0 -1
  195. package/dist/src/commands/vetra.js +0 -24
  196. package/dist/src/commands/vetra.js.map +0 -1
  197. package/dist/src/get-version.d.ts +0 -2
  198. package/dist/src/get-version.d.ts.map +0 -1
  199. package/dist/src/get-version.js +0 -7
  200. package/dist/src/get-version.js.map +0 -1
  201. package/dist/src/help.d.ts +0 -65
  202. package/dist/src/help.d.ts.map +0 -1
  203. package/dist/src/help.js +0 -770
  204. package/dist/src/help.js.map +0 -1
  205. package/dist/src/index.d.ts +0 -4
  206. package/dist/src/index.d.ts.map +0 -1
  207. package/dist/src/index.js +0 -4
  208. package/dist/src/index.js.map +0 -1
  209. package/dist/src/services/auth.d.ts +0 -69
  210. package/dist/src/services/auth.d.ts.map +0 -1
  211. package/dist/src/services/auth.js +0 -171
  212. package/dist/src/services/auth.js.map +0 -1
  213. package/dist/src/services/connect.d.ts +0 -5
  214. package/dist/src/services/connect.d.ts.map +0 -1
  215. package/dist/src/services/connect.js +0 -90
  216. package/dist/src/services/connect.js.map +0 -1
  217. package/dist/src/services/generate.d.ts +0 -3
  218. package/dist/src/services/generate.d.ts.map +0 -1
  219. package/dist/src/services/generate.js +0 -80
  220. package/dist/src/services/generate.js.map +0 -1
  221. package/dist/src/services/inspect.d.ts +0 -3
  222. package/dist/src/services/inspect.d.ts.map +0 -1
  223. package/dist/src/services/inspect.js +0 -50
  224. package/dist/src/services/inspect.js.map +0 -1
  225. package/dist/src/services/legacy/connect.old.d.ts +0 -2
  226. package/dist/src/services/legacy/connect.old.d.ts.map +0 -1
  227. package/dist/src/services/legacy/connect.old.js +0 -2
  228. package/dist/src/services/legacy/connect.old.js.map +0 -1
  229. package/dist/src/services/legacy/generate.old.d.ts +0 -30
  230. package/dist/src/services/legacy/generate.old.d.ts.map +0 -1
  231. package/dist/src/services/legacy/generate.old.js +0 -107
  232. package/dist/src/services/legacy/generate.old.js.map +0 -1
  233. package/dist/src/services/legacy/inspect.old.d.ts +0 -5
  234. package/dist/src/services/legacy/inspect.old.d.ts.map +0 -1
  235. package/dist/src/services/legacy/inspect.old.js +0 -49
  236. package/dist/src/services/legacy/inspect.old.js.map +0 -1
  237. package/dist/src/services/legacy/migrate.old.d.ts +0 -3
  238. package/dist/src/services/legacy/migrate.old.d.ts.map +0 -1
  239. package/dist/src/services/legacy/migrate.old.js +0 -289
  240. package/dist/src/services/legacy/migrate.old.js.map +0 -1
  241. package/dist/src/services/legacy/switchboard.old.d.ts +0 -54
  242. package/dist/src/services/legacy/switchboard.old.d.ts.map +0 -1
  243. package/dist/src/services/legacy/switchboard.old.js +0 -79
  244. package/dist/src/services/legacy/switchboard.old.js.map +0 -1
  245. package/dist/src/services/legacy/vetra.old.d.ts +0 -15
  246. package/dist/src/services/legacy/vetra.old.d.ts.map +0 -1
  247. package/dist/src/services/legacy/vetra.old.js +0 -176
  248. package/dist/src/services/legacy/vetra.old.js.map +0 -1
  249. package/dist/src/services/migrate.d.ts +0 -3
  250. package/dist/src/services/migrate.d.ts.map +0 -1
  251. package/dist/src/services/migrate.js +0 -327
  252. package/dist/src/services/migrate.js.map +0 -1
  253. package/dist/src/services/switchboard-migrate.d.ts +0 -7
  254. package/dist/src/services/switchboard-migrate.d.ts.map +0 -1
  255. package/dist/src/services/switchboard-migrate.js +0 -60
  256. package/dist/src/services/switchboard-migrate.js.map +0 -1
  257. package/dist/src/services/switchboard.d.ts +0 -22
  258. package/dist/src/services/switchboard.d.ts.map +0 -1
  259. package/dist/src/services/switchboard.js +0 -77
  260. package/dist/src/services/switchboard.js.map +0 -1
  261. package/dist/src/services/vetra.d.ts +0 -3
  262. package/dist/src/services/vetra.d.ts.map +0 -1
  263. package/dist/src/services/vetra.js +0 -169
  264. package/dist/src/services/vetra.js.map +0 -1
  265. package/dist/src/types.d.ts +0 -31
  266. package/dist/src/types.d.ts.map +0 -1
  267. package/dist/src/types.js +0 -2
  268. package/dist/src/types.js.map +0 -1
  269. package/dist/src/utils/configure-vetra-github-url.d.ts +0 -12
  270. package/dist/src/utils/configure-vetra-github-url.d.ts.map +0 -1
  271. package/dist/src/utils/configure-vetra-github-url.js +0 -230
  272. package/dist/src/utils/configure-vetra-github-url.js.map +0 -1
  273. package/dist/src/utils/constants.d.ts +0 -2
  274. package/dist/src/utils/constants.d.ts.map +0 -1
  275. package/dist/src/utils/constants.js +0 -2
  276. package/dist/src/utils/constants.js.map +0 -1
  277. package/dist/src/utils/file-system.d.ts +0 -2
  278. package/dist/src/utils/file-system.d.ts.map +0 -1
  279. package/dist/src/utils/file-system.js +0 -15
  280. package/dist/src/utils/file-system.js.map +0 -1
  281. package/dist/src/utils/index.d.ts +0 -3
  282. package/dist/src/utils/index.d.ts.map +0 -1
  283. package/dist/src/utils/index.js +0 -3
  284. package/dist/src/utils/index.js.map +0 -1
  285. package/dist/src/utils/projects.d.ts +0 -19
  286. package/dist/src/utils/projects.d.ts.map +0 -1
  287. package/dist/src/utils/projects.js +0 -93
  288. package/dist/src/utils/projects.js.map +0 -1
  289. package/dist/src/utils.d.ts +0 -112
  290. package/dist/src/utils.d.ts.map +0 -1
  291. package/dist/src/utils.js +0 -261
  292. package/dist/src/utils.js.map +0 -1
  293. package/dist/src/version.d.ts +0 -2
  294. package/dist/src/version.d.ts.map +0 -1
  295. package/dist/src/version.js +0 -3
  296. package/dist/src/version.js.map +0 -1
  297. package/dist/test/utils.test.d.ts +0 -2
  298. package/dist/test/utils.test.d.ts.map +0 -1
  299. package/dist/test/utils.test.js +0 -133
  300. package/dist/test/utils.test.js.map +0 -1
  301. package/dist/tsconfig.tsbuildinfo +0 -1
  302. package/dist/vitest.config.d.ts +0 -3
  303. package/dist/vitest.config.d.ts.map +0 -1
  304. package/dist/vitest.config.js +0 -7
  305. package/dist/vitest.config.js.map +0 -1
@@ -0,0 +1,162 @@
1
+ import path, { dirname } from "node:path";
2
+ import crypto from "node:crypto";
3
+ import fs from "node:fs";
4
+ import { homedir } from "node:os";
5
+ //#region src/utils.ts
6
+ const POWERHOUSE_CONFIG_FILE = "powerhouse.config.json";
7
+ const POWERHOUSE_GLOBAL_DIR = path.join(homedir(), ".ph");
8
+ const packageManagers = {
9
+ bun: {
10
+ globalPathRegexp: /[\\/].bun[\\/]/,
11
+ installCommand: "bun add {{dependency}}",
12
+ uninstallCommand: "bun remove {{dependency}}",
13
+ workspaceOption: "",
14
+ lockfile: "bun.lock",
15
+ updateCommand: "bun update {{dependency}}",
16
+ buildAffected: "bun run build:affected"
17
+ },
18
+ pnpm: {
19
+ globalPathRegexp: /[\\/]pnpm[\\/]/,
20
+ installCommand: "pnpm add {{dependency}}",
21
+ uninstallCommand: "pnpm remove {{dependency}}",
22
+ workspaceOption: "--workspace-root",
23
+ lockfile: "pnpm-lock.yaml",
24
+ updateCommand: "pnpm update {{dependency}}",
25
+ buildAffected: "pnpm run build:affected"
26
+ },
27
+ yarn: {
28
+ globalPathRegexp: /[\\/]yarn[\\/]/,
29
+ installCommand: "yarn add {{dependency}}",
30
+ uninstallCommand: "yarn remove {{dependency}}",
31
+ workspaceOption: "-W",
32
+ lockfile: "yarn.lock",
33
+ updateCommand: "yarn upgrade {{dependency}}",
34
+ buildAffected: "yarn run build:affected"
35
+ },
36
+ npm: {
37
+ installCommand: "npm install {{dependency}}",
38
+ uninstallCommand: "npm uninstall {{dependency}}",
39
+ workspaceOption: "",
40
+ lockfile: "package-lock.json",
41
+ updateCommand: "npm update {{dependency}} --save",
42
+ buildAffected: "npm run build:affected"
43
+ }
44
+ };
45
+ function defaultPathValidation() {
46
+ return true;
47
+ }
48
+ function isPowerhouseProject(dir) {
49
+ const powerhouseConfigPath = path.join(dir, POWERHOUSE_CONFIG_FILE);
50
+ return fs.existsSync(powerhouseConfigPath);
51
+ }
52
+ function findNodeProjectRoot(dir, pathValidation = defaultPathValidation) {
53
+ const packageJsonPath = path.join(dir, "package.json");
54
+ if (fs.existsSync(packageJsonPath) && pathValidation(dir)) return dir;
55
+ const parentDir = dirname(dir);
56
+ if (parentDir === dir) return null;
57
+ return findNodeProjectRoot(parentDir, pathValidation);
58
+ }
59
+ function getProjectInfo(debug) {
60
+ const currentPath = process.cwd();
61
+ if (debug) console.log(">>> currentPath", currentPath);
62
+ const projectPath = findNodeProjectRoot(currentPath, isPowerhouseProject);
63
+ if (!projectPath) return {
64
+ isGlobal: true,
65
+ path: POWERHOUSE_GLOBAL_DIR,
66
+ packageManager: getPackageManagerFromLockfile(POWERHOUSE_GLOBAL_DIR)
67
+ };
68
+ return {
69
+ isGlobal: false,
70
+ path: projectPath,
71
+ packageManager: getPackageManagerFromLockfile(projectPath)
72
+ };
73
+ }
74
+ /**
75
+ * Generates a unique drive ID based on the project path.
76
+ * The same project path will always generate the same ID.
77
+ * @param name - The name prefix for the drive ID (e.g., "vetra", "powerhouse")
78
+ * @returns A unique drive ID in the format "{name}-{hash}"
79
+ */
80
+ function generateProjectDriveId(name) {
81
+ const projectInfo = getProjectInfo();
82
+ return `${name}-${crypto.createHash("sha256").update(projectInfo.path).digest("hex").substring(0, 8)}`;
83
+ }
84
+ function getPackageManagerFromLockfile(dir) {
85
+ if (fs.existsSync(path.join(dir, packageManagers.pnpm.lockfile))) return "pnpm";
86
+ else if (fs.existsSync(path.join(dir, packageManagers.yarn.lockfile))) return "yarn";
87
+ else if (fs.existsSync(path.join(dir, packageManagers.bun.lockfile))) return "bun";
88
+ return "npm";
89
+ }
90
+ function updatePackagesArray(currentPackages = [], dependencies, task = "install", provider = "registry") {
91
+ const isInstall = task === "install";
92
+ const mappedPackages = dependencies.map((dep) => ({
93
+ packageName: dep.name,
94
+ version: dep.version,
95
+ provider
96
+ }));
97
+ if (isInstall) return [...currentPackages.filter((pkg) => !dependencies.find((dep) => dep.name === pkg.packageName)), ...mappedPackages];
98
+ return currentPackages.filter((pkg) => !dependencies.map((dep) => dep.name).includes(pkg.packageName));
99
+ }
100
+ function updateConfigFile(dependencies, projectPath, task = "install", provider = "registry", registryUrl) {
101
+ const configPath = path.join(projectPath, POWERHOUSE_CONFIG_FILE);
102
+ if (!fs.existsSync(configPath)) throw new Error(`powerhouse.config.json file not found. projectPath: ${projectPath}`);
103
+ const config = JSON.parse(fs.readFileSync(configPath, "utf-8"));
104
+ const updatedConfig = {
105
+ ...config,
106
+ packages: updatePackagesArray(config.packages, dependencies, task, provider)
107
+ };
108
+ if (task === "install" && registryUrl && !config.packageRegistryUrl && dependencies.length > 0) updatedConfig.packageRegistryUrl = registryUrl;
109
+ fs.writeFileSync(configPath, JSON.stringify(updatedConfig, null, 2));
110
+ }
111
+ /**
112
+ * Updates the styles.css file to include imports for newly installed packages
113
+ * @param dependencies - Array of dependencies that were installed
114
+ * @param projectPath - Path to the project root
115
+ */
116
+ function updateStylesFile(dependencies, projectPath) {
117
+ const stylesPath = path.join(projectPath, "style.css");
118
+ if (!fs.existsSync(stylesPath)) {
119
+ console.warn("⚠️ Warning: style.css file not found in project root");
120
+ return;
121
+ }
122
+ const currentStyles = fs.readFileSync(stylesPath, "utf-8");
123
+ let updatedStyles = currentStyles;
124
+ for (const dep of dependencies) {
125
+ const cssPath = `./node_modules/${dep.name}/dist/style.css`;
126
+ const fullCssPath = path.join(projectPath, cssPath);
127
+ const importStatement = `@import '${cssPath}';`;
128
+ if (!fs.existsSync(fullCssPath)) {
129
+ console.warn(`⚠️ Warning: CSS file not found at ${cssPath}`);
130
+ continue;
131
+ }
132
+ if (currentStyles.includes(importStatement)) continue;
133
+ const importLines = currentStyles.split("\n").filter((line) => line.trim().startsWith("@import"));
134
+ const lastImport = importLines[importLines.length - 1];
135
+ if (lastImport) updatedStyles = currentStyles.replace(lastImport, `${lastImport}\n${importStatement}`);
136
+ else updatedStyles = `${importStatement}\n${currentStyles}`;
137
+ }
138
+ if (updatedStyles !== currentStyles) fs.writeFileSync(stylesPath, updatedStyles);
139
+ }
140
+ /**
141
+ * Removes CSS imports for uninstalled packages from styles.css
142
+ */
143
+ function removeStylesImports(dependencies, projectPath) {
144
+ const stylesPath = path.join(projectPath, "style.css");
145
+ if (!fs.existsSync(stylesPath)) {
146
+ console.warn("⚠️ Warning: style.css file not found in project root");
147
+ return;
148
+ }
149
+ const currentStyles = fs.readFileSync(stylesPath, "utf-8");
150
+ let updatedStyles = currentStyles;
151
+ for (const dep of dependencies) {
152
+ const importStatement = `@import '${`./node_modules/${dep.name}/dist/style.css`}';`;
153
+ const lines = updatedStyles.split("\n");
154
+ const filteredLines = lines.filter((line) => !line.trim().includes(importStatement));
155
+ if (filteredLines.length !== lines.length) updatedStyles = filteredLines.join("\n");
156
+ }
157
+ if (updatedStyles !== currentStyles) fs.writeFileSync(stylesPath, updatedStyles);
158
+ }
159
+ //#endregion
160
+ export { updateStylesFile as a, updateConfigFile as i, getProjectInfo as n, removeStylesImports as r, generateProjectDriveId as t };
161
+
162
+ //# sourceMappingURL=utils-C6_gv4nB.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils-C6_gv4nB.mjs","names":[],"sources":["../src/utils.ts"],"sourcesContent":["import type { PowerhouseConfig } from \"@powerhousedao/config\";\nimport crypto from \"node:crypto\";\nimport fs from \"node:fs\";\nimport { homedir } from \"node:os\";\nimport path, { dirname } from \"node:path\";\nexport const POWERHOUSE_CONFIG_FILE = \"powerhouse.config.json\";\nexport const POWERHOUSE_GLOBAL_DIR = path.join(homedir(), \".ph\");\nexport const SUPPORTED_PACKAGE_MANAGERS = [\"npm\", \"yarn\", \"pnpm\", \"bun\"];\n\nexport const packageManagers = {\n bun: {\n globalPathRegexp: /[\\\\/].bun[\\\\/]/,\n installCommand: \"bun add {{dependency}}\",\n uninstallCommand: \"bun remove {{dependency}}\",\n workspaceOption: \"\",\n lockfile: \"bun.lock\",\n updateCommand: \"bun update {{dependency}}\",\n buildAffected: \"bun run build:affected\",\n },\n pnpm: {\n globalPathRegexp: /[\\\\/]pnpm[\\\\/]/,\n installCommand: \"pnpm add {{dependency}}\",\n uninstallCommand: \"pnpm remove {{dependency}}\",\n workspaceOption: \"--workspace-root\",\n lockfile: \"pnpm-lock.yaml\",\n updateCommand: \"pnpm update {{dependency}}\",\n buildAffected: \"pnpm run build:affected\",\n },\n yarn: {\n globalPathRegexp: /[\\\\/]yarn[\\\\/]/,\n installCommand: \"yarn add {{dependency}}\",\n uninstallCommand: \"yarn remove {{dependency}}\",\n workspaceOption: \"-W\",\n lockfile: \"yarn.lock\",\n updateCommand: \"yarn upgrade {{dependency}}\",\n buildAffected: \"yarn run build:affected\",\n },\n npm: {\n installCommand: \"npm install {{dependency}}\",\n uninstallCommand: \"npm uninstall {{dependency}}\",\n workspaceOption: \"\",\n lockfile: \"package-lock.json\",\n updateCommand: \"npm update {{dependency}} --save\",\n buildAffected: \"npm run build:affected\",\n },\n};\n\ntype PathValidation = (dir: string) => boolean;\n\nexport type PackageManager = \"npm\" | \"yarn\" | \"pnpm\" | \"bun\";\n\nexport type ProjectInfo = {\n isGlobal: boolean;\n path: string;\n packageManager: PackageManager;\n};\n\nexport function defaultPathValidation() {\n return true;\n}\n\nexport function isPowerhouseProject(dir: string) {\n const powerhouseConfigPath = path.join(dir, POWERHOUSE_CONFIG_FILE);\n\n return fs.existsSync(powerhouseConfigPath);\n}\n\nexport function findNodeProjectRoot(\n dir: string,\n pathValidation: PathValidation = defaultPathValidation,\n) {\n const packageJsonPath = path.join(dir, \"package.json\");\n\n if (fs.existsSync(packageJsonPath) && pathValidation(dir)) {\n return dir;\n }\n\n const parentDir = dirname(dir);\n\n if (parentDir === dir) {\n return null;\n }\n\n return findNodeProjectRoot(parentDir, pathValidation);\n}\n\nexport function getProjectInfo(debug?: boolean): ProjectInfo {\n const currentPath = process.cwd();\n\n if (debug) {\n console.log(\">>> currentPath\", currentPath);\n }\n\n const projectPath = findNodeProjectRoot(currentPath, isPowerhouseProject);\n\n if (!projectPath) {\n return {\n isGlobal: true,\n path: POWERHOUSE_GLOBAL_DIR,\n packageManager: getPackageManagerFromLockfile(POWERHOUSE_GLOBAL_DIR),\n };\n }\n\n return {\n isGlobal: false,\n path: projectPath,\n packageManager: getPackageManagerFromLockfile(projectPath),\n };\n}\n\n/**\n * Generates a unique drive ID based on the project path.\n * The same project path will always generate the same ID.\n * @param name - The name prefix for the drive ID (e.g., \"vetra\", \"powerhouse\")\n * @returns A unique drive ID in the format \"{name}-{hash}\"\n */\nexport function generateProjectDriveId(name: string): string {\n const projectInfo = getProjectInfo();\n const hash = crypto\n .createHash(\"sha256\")\n .update(projectInfo.path)\n .digest(\"hex\");\n const shortHash = hash.substring(0, 8);\n return `${name}-${shortHash}`;\n}\n\nexport function getPackageManagerFromLockfile(dir: string): PackageManager {\n if (fs.existsSync(path.join(dir, packageManagers.pnpm.lockfile))) {\n return \"pnpm\";\n } else if (fs.existsSync(path.join(dir, packageManagers.yarn.lockfile))) {\n return \"yarn\";\n } else if (fs.existsSync(path.join(dir, packageManagers.bun.lockfile))) {\n return \"bun\";\n }\n\n return \"npm\";\n}\n\nexport function updatePackagesArray(\n currentPackages: PowerhouseConfig[\"packages\"] = [],\n dependencies: { name: string; version: string | undefined }[],\n task: \"install\" | \"uninstall\" = \"install\",\n provider: \"registry\" | \"local\" = \"registry\",\n): PowerhouseConfig[\"packages\"] {\n const isInstall = task === \"install\";\n const mappedPackages = dependencies.map((dep) => ({\n packageName: dep.name,\n version: dep.version,\n provider,\n }));\n\n if (isInstall) {\n // Overwrite existing package if version is different\n const filteredPackages = currentPackages.filter(\n (pkg) => !dependencies.find((dep) => dep.name === pkg.packageName),\n );\n return [...filteredPackages, ...mappedPackages];\n }\n\n return currentPackages.filter(\n (pkg) => !dependencies.map((dep) => dep.name).includes(pkg.packageName),\n );\n}\n\n// Modify updateConfigFile to use the new function\nexport function updateConfigFile(\n dependencies: { name: string; version: string | undefined }[],\n projectPath: string,\n task: \"install\" | \"uninstall\" = \"install\",\n provider: \"registry\" | \"local\" = \"registry\",\n registryUrl?: string,\n) {\n const configPath = path.join(projectPath, POWERHOUSE_CONFIG_FILE);\n\n if (!fs.existsSync(configPath)) {\n throw new Error(\n `powerhouse.config.json file not found. projectPath: ${projectPath}`,\n );\n }\n\n const config = JSON.parse(\n fs.readFileSync(configPath, \"utf-8\"),\n ) as PowerhouseConfig;\n\n const updatedConfig: PowerhouseConfig = {\n ...config,\n packages: updatePackagesArray(\n config.packages,\n dependencies,\n task,\n provider,\n ),\n };\n\n if (\n task === \"install\" &&\n registryUrl &&\n !config.packageRegistryUrl &&\n dependencies.length > 0\n ) {\n updatedConfig.packageRegistryUrl = registryUrl;\n }\n\n fs.writeFileSync(configPath, JSON.stringify(updatedConfig, null, 2));\n}\n\n/**\n * Recursively searches for a specific file by traversing up the directory tree.\n * Starting from the given path, it checks each parent directory until it finds\n * the target file or reaches the root directory.\n *\n * @param startPath - The absolute path of the directory to start searching from\n * @param targetFile - The name of the file to search for (e.g., 'package.json', 'pnpm-workspace.yaml')\n * @returns The absolute path of the directory containing the target file, or null if not found\n *\n * @example\n * // Find the workspace root directory\n * const workspaceRoot = findContainerDirectory('/path/to/project/src', 'pnpm-workspace.yaml');\n *\n * // Find the nearest package.json\n * const packageDir = findContainerDirectory('/path/to/project/src/components', 'package.json');\n */\nexport const findContainerDirectory = (\n startPath: string,\n targetFile: string,\n): string | null => {\n const filePath = path.join(startPath, targetFile);\n\n if (fs.existsSync(filePath)) {\n return startPath;\n }\n\n const parentDir = path.dirname(startPath);\n\n //reached the root directory and haven't found the file\n if (parentDir === startPath) {\n return null;\n }\n\n return findContainerDirectory(parentDir, targetFile);\n};\n\n/**\n * Updates the styles.css file to include imports for newly installed packages\n * @param dependencies - Array of dependencies that were installed\n * @param projectPath - Path to the project root\n */\nexport function updateStylesFile(\n dependencies: { name: string; version: string | undefined }[],\n projectPath: string,\n) {\n const stylesPath = path.join(projectPath, \"style.css\");\n\n // Check if styles.css exists\n if (!fs.existsSync(stylesPath)) {\n console.warn(\"⚠️ Warning: style.css file not found in project root\");\n return;\n }\n\n const currentStyles = fs.readFileSync(stylesPath, \"utf-8\");\n let updatedStyles = currentStyles;\n\n for (const dep of dependencies) {\n const cssPath = `./node_modules/${dep.name}/dist/style.css`;\n const fullCssPath = path.join(projectPath, cssPath);\n const importStatement = `@import '${cssPath}';`;\n\n // Check if the CSS file exists\n if (!fs.existsSync(fullCssPath)) {\n console.warn(`⚠️ Warning: CSS file not found at ${cssPath}`);\n continue;\n }\n\n // Check if import already exists\n if (currentStyles.includes(importStatement)) {\n continue;\n }\n\n // Find the last @import statement\n const importLines = currentStyles\n .split(\"\\n\")\n .filter((line) => line.trim().startsWith(\"@import\"));\n const lastImport = importLines[importLines.length - 1];\n\n if (lastImport) {\n // Insert new import after the last existing import\n updatedStyles = currentStyles.replace(\n lastImport,\n `${lastImport}\\n${importStatement}`,\n );\n } else {\n // If no imports exist, add at the top of the file\n updatedStyles = `${importStatement}\\n${currentStyles}`;\n }\n }\n\n // Only write if changes were made\n if (updatedStyles !== currentStyles) {\n fs.writeFileSync(stylesPath, updatedStyles);\n }\n}\n\n/**\n * Removes CSS imports for uninstalled packages from styles.css\n */\nexport function removeStylesImports(\n dependencies: { name: string; version: string | undefined }[],\n projectPath: string,\n) {\n const stylesPath = path.join(projectPath, \"style.css\");\n\n // Check if styles.css exists\n if (!fs.existsSync(stylesPath)) {\n console.warn(\"⚠️ Warning: style.css file not found in project root\");\n return;\n }\n\n const currentStyles = fs.readFileSync(stylesPath, \"utf-8\");\n let updatedStyles = currentStyles;\n\n for (const dep of dependencies) {\n const cssPath = `./node_modules/${dep.name}/dist/style.css`;\n const importStatement = `@import '${cssPath}';`;\n\n // Remove the import line if it exists\n const lines = updatedStyles.split(\"\\n\");\n const filteredLines = lines.filter(\n (line) => !line.trim().includes(importStatement),\n );\n\n if (filteredLines.length !== lines.length) {\n updatedStyles = filteredLines.join(\"\\n\");\n }\n }\n\n // Only write if changes were made\n if (updatedStyles !== currentStyles) {\n fs.writeFileSync(stylesPath, updatedStyles);\n }\n}\n"],"mappings":"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"}
@@ -0,0 +1,420 @@
1
+ import { t as generateProjectDriveId } from "./utils-C6_gv4nB.mjs";
2
+ import "./assign-env-vars-DZMMuzB2.mjs";
3
+ import { t as runConnectStudio } from "./connect-studio-BaqbrWYQ.mjs";
4
+ import { n as startSwitchboard$1 } from "./switchboard-DGbd-EPx.mjs";
5
+ import { execSync } from "node:child_process";
6
+ import { createLogger } from "vite";
7
+ import { createVetraDocument, getVetraDocuments, setPackageGithubUrl } from "@powerhousedao/common/utils";
8
+ import { isPortAvailable } from "@powerhousedao/switchboard/server";
9
+ import { VETRA_PROCESSOR_CONFIG_KEY } from "@powerhousedao/config";
10
+ import { addDefaultDrive } from "@powerhousedao/switchboard/utils";
11
+ import { blue, green, red, yellow } from "colorette";
12
+ import { childLogger, setLogLevel } from "document-model";
13
+ import { createInterface } from "node:readline";
14
+ //#region src/utils/configure-vetra-github-url.ts
15
+ /**
16
+ * Get git remote URL (origin)
17
+ * @returns Git remote URL or null if not configured
18
+ */
19
+ function getGitRemoteUrl() {
20
+ try {
21
+ return execSync("git remote get-url origin", {
22
+ encoding: "utf-8",
23
+ stdio: [
24
+ "pipe",
25
+ "pipe",
26
+ "pipe"
27
+ ]
28
+ }).trim() || null;
29
+ } catch {
30
+ return null;
31
+ }
32
+ }
33
+ /**
34
+ * Prompt user to enter a custom GitHub URL
35
+ */
36
+ async function promptForCustomUrl() {
37
+ return new Promise((resolve) => {
38
+ const rl = createInterface({
39
+ input: process.stdin,
40
+ output: process.stdout
41
+ });
42
+ process.stdout.write("\nEnter GitHub URL (or press Enter to skip): ");
43
+ rl.on("line", (answer) => {
44
+ rl.close();
45
+ resolve(answer.trim() || null);
46
+ });
47
+ });
48
+ }
49
+ /**
50
+ * Prompt yes/no question
51
+ */
52
+ async function promptYesNo(question) {
53
+ return new Promise((resolve) => {
54
+ const rl = createInterface({
55
+ input: process.stdin,
56
+ output: process.stdout
57
+ });
58
+ process.stdout.write(`\n${question} (y/n): `);
59
+ rl.on("line", (answer) => {
60
+ rl.close();
61
+ const response = answer.trim().toLowerCase();
62
+ resolve(response === "y" || response === "yes");
63
+ });
64
+ });
65
+ }
66
+ /**
67
+ * Prompt user to select or enter GitHub URL
68
+ * @param gitRemoteUrl - Git remote URL if available
69
+ * @returns Selected URL or null if skipped
70
+ */
71
+ async function promptForGithubUrl(gitRemoteUrl) {
72
+ return new Promise((resolve) => {
73
+ const rl = createInterface({
74
+ input: process.stdin,
75
+ output: process.stdout
76
+ });
77
+ console.log("\n" + "=".repeat(50));
78
+ console.log("🔍 Vetra Package Configuration");
79
+ console.log("=".repeat(50));
80
+ console.log("\nWe detected a Vetra package document in your remote drive without a GitHub URL configured.");
81
+ console.log("\nWould you like to configure the GitHub URL now?");
82
+ if (gitRemoteUrl) {
83
+ console.log(`\nGit remote URL detected: ${gitRemoteUrl}`);
84
+ console.log("\nOptions:");
85
+ console.log("1. Use detected URL");
86
+ console.log("2. Enter a different URL");
87
+ console.log("3. Skip configuration");
88
+ process.stdout.write("\nSelect an option (1-3): ");
89
+ const handleAnswer = (answer) => {
90
+ const choice = answer.trim();
91
+ if (choice === "1") {
92
+ rl.close();
93
+ resolve(gitRemoteUrl);
94
+ } else if (choice === "2") {
95
+ rl.close();
96
+ promptForCustomUrl().then(resolve).catch(() => resolve(null));
97
+ } else if (choice === "3") {
98
+ rl.close();
99
+ resolve(null);
100
+ } else process.stdout.write("Invalid choice. Select an option (1-3): ");
101
+ };
102
+ rl.on("line", handleAnswer);
103
+ } else {
104
+ console.log("\nNo git remote URL detected.");
105
+ console.log("\nOptions:");
106
+ console.log("1. Enter GitHub URL manually");
107
+ console.log("2. Skip configuration");
108
+ process.stdout.write("\nSelect an option (1-2): ");
109
+ const handleAnswer = (answer) => {
110
+ const choice = answer.trim();
111
+ if (choice === "1") {
112
+ rl.close();
113
+ promptForCustomUrl().then(resolve).catch(() => resolve(null));
114
+ } else if (choice === "2") {
115
+ rl.close();
116
+ resolve(null);
117
+ } else process.stdout.write("Invalid choice. Select an option (1-2): ");
118
+ };
119
+ rl.on("line", handleAnswer);
120
+ }
121
+ });
122
+ }
123
+ /**
124
+ * Set git remote URL (origin)
125
+ */
126
+ function setGitRemoteUrl(url) {
127
+ try {
128
+ execSync(`git remote add origin ${url}`, { stdio: "inherit" });
129
+ console.log(`✅ Git remote origin set to: ${url}`);
130
+ } catch {
131
+ try {
132
+ execSync(`git remote set-url origin ${url}`, { stdio: "inherit" });
133
+ console.log(`✅ Git remote origin updated to: ${url}`);
134
+ } catch {
135
+ console.error(red(`❌ Failed to set git remote URL`));
136
+ }
137
+ }
138
+ }
139
+ /**
140
+ * Validates documents and returns the target document to use
141
+ * Warns if multiple documents found
142
+ */
143
+ function validateAndSelectDocument(documents) {
144
+ if (documents.length === 0) return null;
145
+ if (documents.length > 1) console.warn(`⚠️ Warning: Multiple Vetra documents found (${documents.length}). Using first document.`);
146
+ return documents[0];
147
+ }
148
+ async function applyGithubUrlConfiguration(graphqlEndpoint, vetraDriveId, documentId, selectedUrl, shouldSetRemote) {
149
+ await setPackageGithubUrl(graphqlEndpoint, vetraDriveId, documentId, selectedUrl);
150
+ console.log(`✅ GitHub URL configured: ${selectedUrl}`);
151
+ if (shouldSetRemote) setGitRemoteUrl(selectedUrl);
152
+ }
153
+ function logVerbose(message, verbose) {
154
+ if (verbose) console.log(message);
155
+ }
156
+ /**
157
+ * Sleep for a specified number of milliseconds
158
+ */
159
+ function sleep(ms) {
160
+ return new Promise((resolve) => setTimeout(resolve, ms));
161
+ }
162
+ /**
163
+ * Configure GitHub URL for Vetra documents
164
+ * @param switchboardPort - Port where switchboard is running
165
+ * @param vetraDriveUrl - Remote drive URL
166
+ * @param verbose - Enable verbose logging
167
+ */
168
+ async function configureVetraGithubUrl(switchboardPort, vetraDriveUrl, verbose) {
169
+ logVerbose("Checking GitHub URL configuration...", verbose);
170
+ try {
171
+ const graphqlEndpoint = `http://localhost:${switchboardPort}/graphql`;
172
+ const vetraDriveId = vetraDriveUrl.split("/").pop();
173
+ if (!vetraDriveId) throw new Error("Invalid vetraDriveUrl: unable to extract drive ID");
174
+ const documents = await getVetraDocuments(graphqlEndpoint, vetraDriveId);
175
+ if (documents.some((doc) => doc.githubUrl)) {
176
+ logVerbose("GitHub URL already configured, skipping setup", verbose);
177
+ return;
178
+ }
179
+ let targetDocumentId;
180
+ const targetDocument = validateAndSelectDocument(documents);
181
+ const gitRemoteUrl = getGitRemoteUrl();
182
+ const selectedUrl = await promptForGithubUrl(gitRemoteUrl);
183
+ if (!selectedUrl) {
184
+ logVerbose("GitHub URL configuration skipped", verbose);
185
+ return;
186
+ }
187
+ let shouldSetRemote = false;
188
+ if (selectedUrl !== gitRemoteUrl && !gitRemoteUrl) shouldSetRemote = await promptYesNo("Set this as your git remote URL?");
189
+ if (!targetDocument) {
190
+ logVerbose("No Vetra documents found, creating new document...", verbose);
191
+ targetDocumentId = await createVetraDocument(graphqlEndpoint, vetraDriveId, "vetra-package");
192
+ logVerbose(`Created new document: ${targetDocumentId}`, verbose);
193
+ } else targetDocumentId = targetDocument.id;
194
+ await applyGithubUrlConfiguration(graphqlEndpoint, vetraDriveId, targetDocumentId, selectedUrl, shouldSetRemote);
195
+ } catch (error) {
196
+ console.error(red(`⚠️ GitHub URL configuration failed: ${error instanceof Error ? error.message : String(error)}`));
197
+ logVerbose(String(error), verbose);
198
+ }
199
+ }
200
+ //#endregion
201
+ //#region src/utils/resolve-switchboard-port.ts
202
+ const MAX_FALLBACK_ATTEMPTS = 20;
203
+ function isInteractive() {
204
+ return Boolean(process.stdin.isTTY) && !process.env.CI;
205
+ }
206
+ async function findFreePort(start) {
207
+ for (let i = 0; i < MAX_FALLBACK_ATTEMPTS; i++) {
208
+ const candidate = start + i;
209
+ if (await isPortAvailable(candidate)) return candidate;
210
+ }
211
+ return null;
212
+ }
213
+ /**
214
+ * Resolve the port switchboard should bind to. If the requested port is free,
215
+ * returns it unchanged. If it's in use, walks forward for the next free port
216
+ * and — in an interactive terminal — asks the user to confirm the fallback.
217
+ * In CI / piped contexts the fallback is applied automatically so scripts
218
+ * don't hang on an unanswered prompt.
219
+ *
220
+ * Throws a process.exit(1) when the user declines the prompt or when no free
221
+ * port is available in the search window.
222
+ */
223
+ async function resolveSwitchboardPort(requested) {
224
+ if (await isPortAvailable(requested)) return requested;
225
+ const candidate = await findFreePort(requested + 1);
226
+ if (candidate === null) {
227
+ console.error(`Port ${requested} is in use and no free port was found in the range ${requested}-${requested + MAX_FALLBACK_ATTEMPTS - 1}.`);
228
+ process.exit(1);
229
+ }
230
+ if (!isInteractive()) {
231
+ console.log(yellow(`Port ${requested} is in use. Falling back to port ${candidate} (non-interactive; skipping confirmation).`));
232
+ return candidate;
233
+ }
234
+ const enquirer = await import("enquirer");
235
+ let confirmed = false;
236
+ try {
237
+ confirmed = (await enquirer.default.prompt({
238
+ type: "confirm",
239
+ name: "confirmed",
240
+ message: `Port ${requested} is in use. Use port ${candidate} instead?`,
241
+ initial: true
242
+ })).confirmed;
243
+ } catch {
244
+ confirmed = false;
245
+ }
246
+ if (!confirmed) {
247
+ console.error(`Aborted. Free port ${requested} or pass --switchboard-port <port> to choose a different port.`);
248
+ process.exit(1);
249
+ }
250
+ return candidate;
251
+ }
252
+ //#endregion
253
+ //#region src/services/vetra.ts
254
+ const VETRA_DRIVE_NAME = "vetra";
255
+ const getDefaultVetraUrl = (port) => `http://localhost:${port}/d/${generateProjectDriveId(VETRA_DRIVE_NAME)}`;
256
+ const getDriveId = (driveUrl) => driveUrl?.split("/").pop() ?? generateProjectDriveId(VETRA_DRIVE_NAME);
257
+ function createViteLogger(color) {
258
+ const customLogger = createLogger("info");
259
+ const loggerInfo = customLogger.info.bind(customLogger);
260
+ customLogger.info = (msg, options) => {
261
+ loggerInfo(color(msg), options);
262
+ };
263
+ const loggerWarn = customLogger.warn.bind(customLogger);
264
+ customLogger.warn = (msg, options) => {
265
+ loggerWarn(yellow(msg), options);
266
+ };
267
+ const loggerError = customLogger.error.bind(customLogger);
268
+ customLogger.error = (msg, options) => {
269
+ loggerError(red(msg), options);
270
+ };
271
+ const loggerWarnOnce = customLogger.warnOnce.bind(customLogger);
272
+ customLogger.warnOnce = (msg, options) => {
273
+ loggerWarnOnce(yellow(msg), options);
274
+ };
275
+ return customLogger;
276
+ }
277
+ async function startVetraPreviewDrive(reactor, port, verbose) {
278
+ const previewDriveId = generateProjectDriveId("preview");
279
+ const driveUrl = await addDefaultDrive(reactor, {
280
+ id: previewDriveId,
281
+ slug: previewDriveId,
282
+ global: {
283
+ name: "Vetra Preview",
284
+ icon: "https://azure-elderly-tortoise-212.mypinata.cloud/ipfs/bafkreifddkbopiyvcirf7vaqar74th424r5phlxkdxniirdyg3qgu2ajha",
285
+ nodes: []
286
+ },
287
+ local: {
288
+ availableOffline: true,
289
+ listeners: [],
290
+ sharingType: "public",
291
+ triggers: []
292
+ }
293
+ }, port);
294
+ if (verbose) console.log(blue(`Vetra Switchboard: Preview drive: ${driveUrl}`));
295
+ return driveUrl;
296
+ }
297
+ async function startLocalVetraSwitchboard(args, logger) {
298
+ const { connectPort, switchboardPort, dev, packages, disableLocalPackages, debug, httpsKeyFile, httpsCertFile, remoteDrive, interactive, watch, verbose } = args;
299
+ const remoteDrives = remoteDrive ? [remoteDrive] : [];
300
+ const vetraProcessorConfig = {
301
+ interactive,
302
+ driveUrl: remoteDrive ?? getDefaultVetraUrl(connectPort),
303
+ driveId: getDriveId(remoteDrive)
304
+ };
305
+ const processorConfig = /* @__PURE__ */ new Map();
306
+ processorConfig.set(VETRA_PROCESSOR_CONFIG_KEY, vetraProcessorConfig);
307
+ const vetraDriveId = generateProjectDriveId(VETRA_DRIVE_NAME);
308
+ const resolvedSwitchboardPort = args.strictPort ? switchboardPort : await resolveSwitchboardPort(switchboardPort);
309
+ try {
310
+ const switchboard = await startSwitchboard$1({
311
+ ...args,
312
+ useVetraDrive: true,
313
+ mcp: true,
314
+ port: resolvedSwitchboardPort,
315
+ strictPort: true,
316
+ dev,
317
+ packages,
318
+ remoteDrives,
319
+ vetraDriveId,
320
+ disableLocalPackages,
321
+ debug,
322
+ httpsKeyFile,
323
+ httpsCertFile,
324
+ processorConfig,
325
+ basePath: void 0,
326
+ keypairPath: void 0,
327
+ dbPath: void 0,
328
+ useIdentity: void 0,
329
+ migrate: void 0,
330
+ migrateStatus: void 0,
331
+ requireIdentity: void 0
332
+ }, logger);
333
+ const actualSwitchboardPort = switchboard.port;
334
+ let previewDriveUrl = null;
335
+ if (watch) try {
336
+ previewDriveUrl = await startVetraPreviewDrive(switchboard.reactor, actualSwitchboardPort, verbose);
337
+ } catch (error) {
338
+ console.error(error);
339
+ }
340
+ if (verbose) {
341
+ console.log(blue(`Vetra Switchboard: Started successfully`));
342
+ if (remoteDrive) console.log(blue(`Vetra Switchboard: Syncing with remote drive: ${remoteDrive}`));
343
+ } else {
344
+ console.log();
345
+ console.log(blue(`Vetra Switchboard: http://localhost:${actualSwitchboardPort}/graphql`));
346
+ console.log(blue(` ➜ Drive URL: ${switchboard.defaultDriveUrl}`));
347
+ if (previewDriveUrl) console.log(blue(` ➜ Preview Drive URL: ${previewDriveUrl}`));
348
+ }
349
+ return {
350
+ driveUrl: switchboard.defaultDriveUrl || "",
351
+ previewDriveUrl,
352
+ switchboardPort: actualSwitchboardPort
353
+ };
354
+ } catch (error) {
355
+ console.error(red(`Vetra Switchboard: ${error instanceof Error ? error.message : String(error)}`));
356
+ throw error instanceof Error ? error : new Error(String(error));
357
+ }
358
+ }
359
+ async function startVetra(args) {
360
+ const { connectPort, verbose, remoteDrive, disableConnect, debug, httpsCertFile, httpsKeyFile, disableLocalPackages, host, open, cors, strictPort, printUrls, bindCLIShortcuts, watchTimeout } = args;
361
+ const switchboardLogger = childLogger(["vetra", "switchboard"]);
362
+ try {
363
+ if (!process.env.LOG_LEVEL) setLogLevel("info");
364
+ if (verbose) {
365
+ switchboardLogger.info("Starting Vetra Switchboard...");
366
+ if (remoteDrive) {
367
+ const source = remoteDrive ? "command line argument" : "powerhouse.config.json";
368
+ switchboardLogger.info(`Using vetraUrl from ${source}: ${remoteDrive}`);
369
+ }
370
+ }
371
+ const switchboardResult = await startLocalVetraSwitchboard({
372
+ ...args,
373
+ dev: true,
374
+ httpsKeyFile,
375
+ httpsCertFile,
376
+ disableLocalPackages,
377
+ debug
378
+ }, switchboardLogger);
379
+ const driveUrl = switchboardResult.driveUrl || remoteDrive || "";
380
+ const previewDriveUrl = switchboardResult.previewDriveUrl;
381
+ const actualSwitchboardPort = switchboardResult.switchboardPort;
382
+ if (remoteDrive) {
383
+ await sleep(3e3);
384
+ await configureVetraGithubUrl(actualSwitchboardPort, remoteDrive, verbose);
385
+ await sleep(2e3);
386
+ }
387
+ if (verbose) console.log("Starting Codegen Reactor...");
388
+ if (!disableConnect) {
389
+ if (verbose) {
390
+ console.log("Starting Connect...");
391
+ const drives = previewDriveUrl ? `${driveUrl}, ${previewDriveUrl}` : driveUrl;
392
+ console.log(` ➜ Connect will use drives: ${drives}`);
393
+ }
394
+ console.log();
395
+ console.log(green(`Vetra Connect: http://localhost:${connectPort}`));
396
+ const customViteLogger = createViteLogger(green);
397
+ await runConnectStudio({
398
+ ...args,
399
+ defaultDrivesUrl: previewDriveUrl ? [driveUrl, previewDriveUrl].join(",") : driveUrl,
400
+ drivesPreserveStrategy: "preserve-all",
401
+ port: connectPort,
402
+ disableLocalPackages,
403
+ debug,
404
+ host,
405
+ open,
406
+ cors,
407
+ strictPort,
408
+ printUrls,
409
+ bindCLIShortcuts,
410
+ watchTimeout
411
+ }, customViteLogger);
412
+ }
413
+ } catch (error) {
414
+ console.error(error);
415
+ }
416
+ }
417
+ //#endregion
418
+ export { startVetra };
419
+
420
+ //# sourceMappingURL=vetra--a0x272X.mjs.map