@powerhousedao/ph-cli 6.0.0-dev.255 → 6.0.0-dev.257

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.
package/README.md CHANGED
@@ -97,51 +97,53 @@ ph connect --config-file ./my-config.js
97
97
 
98
98
  ### `ph generate`
99
99
 
100
- Generate code from document models with various options. This command supports multiple generation types including editors, processors, subgraphs, and import scripts.
100
+ `ph generate` is a router; pass a subcommand to generate a specific
101
+ module type. See `ph generate <subcommand> --help` for the full option
102
+ list per subcommand.
101
103
 
102
- #### Options:
104
+ #### Subcommands:
105
+
106
+ - `document-model` (alias `doc`) — generate from a `.phd`/`.json` spec
107
+ - `editor` — generate a document editor
108
+ - `app` — generate a drive app
109
+ - `processor` — generate a reactor processor
110
+ - `subgraph` — generate a GraphQL subgraph
111
+ - `migration-file` — generate migrations for a relational-db processor
112
+ - `all` — re-generate every module in the project
113
+
114
+ Most subcommands share these options:
103
115
 
104
- - `-i, --interactive`: Run the command in interactive mode
105
- - `--editors <type>`: Path to the editors directory
106
- - `-e, --editor <type>`: Editor Name
107
- - `--file <path>`: File path to document model
108
- - `--processors <type>`: Path to the processors directory
109
- - `-p, --processor <type>`: Processor Name
110
- - `--processor-type <type>`: Processor Type (relationalDb/analytics)
111
- - `-s, --subgraph <type>`: Subgraph Name
112
- - `--document-models <type>`: Path to the document models directory
113
- - `--document-types <type>`: Supported document types by the editor
114
- - `-is, --import-script <type>`: Import Script Name
115
- - `-sf, --skip-format`: Skip formatting the generated code
116
- - `-w, --watch`: Watch the generated code
117
- - `-d, --drive-editor <name>`: Generate a drive editor with the specified name
116
+ - `-d, --document <path>`: Path to a document-model spec (`.phd` or `.json`)
117
+ - `--dir <dir>`: Existing module directory to re-generate
118
+ - `-a, --all`: Re-generate every existing module of this type
119
+ - `-x, --extract`: (document-model only) Write a `powerhouse/document-model` spec for each existing model into `specs/document-models/`
118
120
 
119
121
  #### Examples:
120
122
 
121
123
  ```bash
122
- # Generate code from a specific file
123
- ph generate path/to/model.json
124
+ # Generate a document model from a spec file
125
+ ph generate document-model --document path/to/model.phd
124
126
 
125
- # Generate in interactive mode
126
- ph generate -i
127
+ # Re-generate all existing document models in the project
128
+ ph generate document-model --all
127
129
 
128
- # Generate a drive editor
129
- ph generate --drive-editor myEditor
130
+ # Generate an editor for a given document type
131
+ ph generate editor --name myEditor --document-type powerhouse/todo
130
132
 
131
- # Generate an editor with specific document types
132
- ph generate --editor myEditor --document-types "type1,type2"
133
+ # Generate a drive app
134
+ ph generate app --name myApp
133
135
 
134
136
  # Generate a processor
135
- ph generate --processor myProcessor --processor-type relationalDb
137
+ ph generate processor --name myProcessor --processor-type relationalDb
136
138
 
137
139
  # Generate a subgraph
138
- ph generate --subgraph mySubgraph --file path/to/model.json
140
+ ph generate subgraph --name mySubgraph
139
141
 
140
- # Generate an import script
141
- ph generate --import-script myImportScript
142
+ # Generate migration files for a relational-db processor
143
+ ph generate migration-file --processor myProcessor
142
144
 
143
- # Watch mode for continuous generation
144
- ph generate --watch
145
+ # Re-generate everything in the project
146
+ ph generate all
145
147
  ```
146
148
 
147
149
  ### `ph install` (or `ph add`, `ph i`)
package/dist/cli.mjs CHANGED
@@ -1,6 +1,6 @@
1
1
  #!/usr/bin/env node
2
2
 
3
- !function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="19f46d7c-6663-5ffa-ac40-1a71c0a3d790")}catch(e){}}();
3
+ !function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="a2e67adb-542b-5e92-bbfc-4656437ba4d7")}catch(e){}}();
4
4
  import { initCliTelemetry } from "@powerhousedao/shared/clis/telemetry";
5
5
  import { assertNodeVersion } from "@powerhousedao/shared/clis/utils";
6
6
  import { array, boolean, command, flag, multioption, oneOf, option, optional, run, string, subcommands } from "cmd-ts";
@@ -15,7 +15,7 @@ import { createInterface } from "node:readline/promises";
15
15
  import { bold, yellow } from "colorette";
16
16
  //#region src/get-version.ts
17
17
  function getVersion() {
18
- return "6.0.0-dev.255";
18
+ return "6.0.0-dev.257";
19
19
  }
20
20
  //#endregion
21
21
  //#region src/utils/constants.ts
@@ -168,10 +168,14 @@ NOTE: You must run \`ph connect build\` first
168
168
  const generateAllCmd = command({
169
169
  name: "all",
170
170
  description: "Re-generate all modules in the current project",
171
- args: {},
172
- handler: async () => {
173
- const { startGenerateAll } = await import("./generate-all-Cj8zjFhN.mjs");
174
- await startGenerateAll(process.cwd());
171
+ args: { extract: flag({
172
+ long: "extract",
173
+ short: "x",
174
+ description: "Instead of generating code, write a spec for every module into specs/ (one-shot migration to documents-as-source-of-truth)"
175
+ }) },
176
+ handler: async (args) => {
177
+ const { startGenerateAll } = await import("./generate-all-WiQQo-Nz.mjs");
178
+ await startGenerateAll(args, process.cwd());
175
179
  process.exit(0);
176
180
  }
177
181
  });
@@ -193,10 +197,15 @@ const generateAppCmd = command({
193
197
  short: "t",
194
198
  description: "The document types allowed by the new app"
195
199
  }),
200
+ document: option({
201
+ type: optional(File),
202
+ long: "document",
203
+ short: "d",
204
+ description: "Path to a powerhouse/app spec file (.phd or .json) to drive codegen"
205
+ }),
196
206
  dir: option({
197
207
  type: optional(Directory),
198
208
  long: "dir",
199
- short: "d",
200
209
  description: "Name of the directory of an existing app to re-generate"
201
210
  }),
202
211
  disableDragAndDrop: flag({
@@ -211,10 +220,15 @@ const generateAppCmd = command({
211
220
  short: "a",
212
221
  description: "Re-generate all existing apps in the current project"
213
222
  }),
223
+ extract: flag({
224
+ long: "extract",
225
+ short: "x",
226
+ description: "Write a powerhouse/app spec for each existing drive app into specs/apps/"
227
+ }),
214
228
  ...debugArgs
215
229
  },
216
230
  handler: async (args) => {
217
- const { startGenerateApp } = await import("./generate-app-KE0rbE-b.mjs");
231
+ const { startGenerateApp } = await import("./generate-app-DdmOt6ID.mjs");
218
232
  await startGenerateApp(args, process.cwd());
219
233
  process.exit(0);
220
234
  }
@@ -226,16 +240,15 @@ const generateDocumentModelCmd = command({
226
240
  aliases: ["doc"],
227
241
  description: "Generate a document model",
228
242
  args: {
229
- file: option({
243
+ document: option({
230
244
  type: optional(File),
231
- long: "file",
232
- short: "f",
233
- description: "Path to the file to generate the document model from"
245
+ long: "document",
246
+ short: "d",
247
+ description: "Path to a document model spec (.phd or .json) to generate from"
234
248
  }),
235
249
  dir: option({
236
250
  type: optional(Directory),
237
251
  long: "dir",
238
- short: "d",
239
252
  description: "Name of the directory of an existing document model to re-generate"
240
253
  }),
241
254
  all: flag({
@@ -243,10 +256,15 @@ const generateDocumentModelCmd = command({
243
256
  short: "a",
244
257
  description: "Re-generate all existing document models in the current project"
245
258
  }),
259
+ extract: flag({
260
+ long: "extract",
261
+ short: "x",
262
+ description: "Write a powerhouse/document-model spec for each existing document model into specs/document-models/"
263
+ }),
246
264
  ...debugArgs
247
265
  },
248
266
  handler: async (args) => {
249
- const { startGenerateDocumentModel } = await import("./generate-document-model-Cut44i6D.mjs");
267
+ const { startGenerateDocumentModel } = await import("./generate-document-model-DQ5PVeIH.mjs");
250
268
  await startGenerateDocumentModel(args, process.cwd());
251
269
  process.exit(0);
252
270
  }
@@ -269,10 +287,15 @@ const generateEditorCmd = command({
269
287
  short: "t",
270
288
  description: "The document type for the new editor"
271
289
  }),
290
+ document: option({
291
+ type: optional(File),
292
+ long: "document",
293
+ short: "d",
294
+ description: "Path to a powerhouse/document-editor spec file (.phd or .json) to drive codegen"
295
+ }),
272
296
  dir: option({
273
297
  type: optional(Directory),
274
298
  long: "dir",
275
- short: "d",
276
299
  description: "Name of the directory of an existing editor to re-generate"
277
300
  }),
278
301
  all: flag({
@@ -280,10 +303,15 @@ const generateEditorCmd = command({
280
303
  short: "a",
281
304
  description: "Re-generate all existing editors in the current project"
282
305
  }),
306
+ extract: flag({
307
+ long: "extract",
308
+ short: "x",
309
+ description: "Write a powerhouse/document-editor spec for each existing editor into specs/editors/"
310
+ }),
283
311
  ...debugArgs
284
312
  },
285
313
  handler: async (args) => {
286
- const { startGenerateEditor } = await import("./generate-editor-DmSzWm3W.mjs");
314
+ const { startGenerateEditor } = await import("./generate-editor-DtzVAs6x.mjs");
287
315
  await startGenerateEditor(args, process.cwd());
288
316
  process.exit(0);
289
317
  }
@@ -354,10 +382,15 @@ const generateProcessorCmd = command({
354
382
  defaultValue: () => ["switchboard", "connect"],
355
383
  defaultValueIsSerializable: true
356
384
  }),
385
+ document: option({
386
+ type: optional(File),
387
+ long: "document",
388
+ short: "d",
389
+ description: "Path to a powerhouse/processor spec file (.phd or .json) to drive codegen"
390
+ }),
357
391
  dir: option({
358
392
  type: optional(Directory),
359
393
  long: "dir",
360
- short: "d",
361
394
  description: "Name of the directory of an existing processor to re-generate"
362
395
  }),
363
396
  all: flag({
@@ -365,10 +398,15 @@ const generateProcessorCmd = command({
365
398
  short: "a",
366
399
  description: "Re-generate all existing processors in the current project"
367
400
  }),
401
+ extract: flag({
402
+ long: "extract",
403
+ short: "x",
404
+ description: "Write a powerhouse/processor spec for each existing processor into specs/processors/"
405
+ }),
368
406
  ...debugArgs
369
407
  },
370
408
  handler: async (args) => {
371
- const { startGenerateProcessor } = await import("./generate-processor-B-fChg4W.mjs");
409
+ const { startGenerateProcessor } = await import("./generate-processor-FGtN6BVY.mjs");
372
410
  await startGenerateProcessor(args, process.cwd());
373
411
  process.exit(0);
374
412
  }
@@ -385,10 +423,15 @@ const generateSubgraphCmd = command({
385
423
  short: "n",
386
424
  description: "The name of the subgraph to generate"
387
425
  }),
426
+ document: option({
427
+ type: optional(File),
428
+ long: "document",
429
+ short: "d",
430
+ description: "Path to a powerhouse/subgraph spec file (.phd or .json) to drive codegen"
431
+ }),
388
432
  dir: option({
389
433
  type: optional(Directory),
390
434
  long: "dir",
391
- short: "d",
392
435
  description: "Name of the directory of an existing subgraph to re-generate"
393
436
  }),
394
437
  all: flag({
@@ -396,10 +439,15 @@ const generateSubgraphCmd = command({
396
439
  short: "a",
397
440
  description: "Re-generate all existing subgraphs in the current project"
398
441
  }),
442
+ extract: flag({
443
+ long: "extract",
444
+ short: "x",
445
+ description: "Write a powerhouse/subgraph spec for each existing subgraph into specs/subgraphs/"
446
+ }),
399
447
  ...debugArgs
400
448
  },
401
449
  handler: async (args) => {
402
- const { startGenerateSubgraph } = await import("./generate-subgraph-C6dWIQzP.mjs");
450
+ const { startGenerateSubgraph } = await import("./generate-subgraph-BrzmW_sj.mjs");
403
451
  await startGenerateSubgraph(args, process.cwd());
404
452
  process.exit(0);
405
453
  }
@@ -1196,4 +1244,4 @@ await main().catch(async (error) => {
1196
1244
  export {};
1197
1245
 
1198
1246
  //# sourceMappingURL=cli.mjs.map
1199
- //# debugId=19f46d7c-6663-5ffa-ac40-1a71c0a3d790
1247
+ //# debugId=a2e67adb-542b-5e92-bbfc-4656437ba4d7
package/dist/cli.mjs.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"cli.mjs","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-all.ts","../src/commands/generate-app.ts","../src/commands/generate-document-model.ts","../src/commands/generate-editor.ts","../src/commands/generate-migration-file.ts","../src/commands/generate-processor.ts","../src/commands/generate-subgraph.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/registry-login.ts","../src/commands/switchboard.ts","../src/commands/uninstall.ts","../src/commands/unpublish.ts","../src/commands/vetra.ts","../src/commands/ph-cli-commands.ts","../src/commands/ph-cli.ts","../src/utils/db-error-hint.ts","../src/cli.ts"],"sourcesContent":["declare const CLI_VERSION: string | undefined;\ndeclare const CLI_GIT_SHA: string | undefined;\n\nexport function getVersion() {\n if (typeof CLI_VERSION !== \"undefined\") return CLI_VERSION;\n return (\n process.env.WORKSPACE_VERSION ||\n process.env.npm_package_version ||\n \"unknown\"\n );\n}\n\nexport function getGitHash() {\n if (typeof CLI_GIT_SHA !== \"undefined\") return CLI_GIT_SHA;\n return process.env.WORKSPACE_GIT_SHA || \"unknown\";\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/args\";\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 { accessTokenArgs } from \"@powerhousedao/shared/clis/args\";\nimport { DEFAULT_EXPIRY_SECONDS } from \"@powerhousedao/shared/clis/constants\";\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/args\";\nimport { command } from \"cmd-ts\";\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 const { runBuild } = await import(\"../services/build.js\");\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/args\";\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 { command } from \"cmd-ts\";\n\nexport const generateAllCmd = command({\n name: \"all\",\n description: \"Re-generate all modules in the current project\",\n args: {},\n handler: async () => {\n const { startGenerateAll } = await import(\"../services/generate-all.js\");\n await startGenerateAll(process.cwd());\n process.exit(0);\n },\n});\n","import { debugArgs } from \"@powerhousedao/shared/clis/args\";\nimport {\n array,\n boolean,\n command,\n flag,\n multioption,\n option,\n optional,\n string,\n} from \"cmd-ts\";\nimport { Directory } from \"cmd-ts/dist/cjs/batteries/fs.js\";\n\nexport const generateAppCmd = command({\n name: \"app\",\n description: \"Generate a drive app\",\n args: {\n name: option({\n type: optional(string),\n long: \"name\",\n short: \"n\",\n description: \"The name of the drive app to generate\",\n }),\n allowedDocumentTypes: multioption({\n type: optional(array(string)),\n long: \"document-types\",\n short: \"t\",\n description: \"The document types allowed by the new app\",\n }),\n dir: option({\n type: optional(Directory),\n long: \"dir\",\n short: \"d\",\n description: \"Name of the directory of an existing app to re-generate\",\n }),\n disableDragAndDrop: flag({\n type: boolean,\n long: \"disable-drag-and-drop\",\n description: \"Do not allow drag and drop in this drive app.\",\n defaultValue: () => false as const,\n defaultValueIsSerializable: true,\n }),\n all: flag({\n long: \"all\",\n short: \"a\",\n description: \"Re-generate all existing apps in the current project\",\n }),\n ...debugArgs,\n },\n handler: async (args) => {\n const { startGenerateApp } = await import(\"../services/generate-app.js\");\n await startGenerateApp(args, process.cwd());\n process.exit(0);\n },\n});\n","import { debugArgs } from \"@powerhousedao/shared/clis/args\";\nimport { command, flag, option, optional } from \"cmd-ts\";\nimport { Directory, File } from \"cmd-ts/dist/cjs/batteries/fs.js\";\nexport const generateDocumentModelCmd = command({\n name: \"document-model\",\n aliases: [\"doc\"],\n description: \"Generate a document model\",\n args: {\n file: option({\n type: optional(File),\n long: \"file\",\n short: \"f\",\n description: \"Path to the file to generate the document model from\",\n }),\n dir: option({\n type: optional(Directory),\n long: \"dir\",\n short: \"d\",\n description:\n \"Name of the directory of an existing document model to re-generate\",\n }),\n all: flag({\n long: \"all\",\n short: \"a\",\n description:\n \"Re-generate all existing document models in the current project\",\n }),\n ...debugArgs,\n },\n handler: async (args) => {\n const { startGenerateDocumentModel } =\n await import(\"../services/generate-document-model.js\");\n await startGenerateDocumentModel(args, process.cwd());\n process.exit(0);\n },\n});\n","import { debugArgs } from \"@powerhousedao/shared/clis/args\";\nimport { command, flag, option, optional, string } from \"cmd-ts\";\nimport { Directory } from \"cmd-ts/dist/cjs/batteries/fs.js\";\n\nexport const generateEditorCmd = command({\n name: \"editor\",\n description: \"Generate a document editor\",\n args: {\n name: option({\n type: optional(string),\n long: \"name\",\n short: \"n\",\n description: \"The name of the document editor to generate\",\n }),\n documentType: option({\n type: optional(string),\n long: \"document-type\",\n short: \"t\",\n description: \"The document type for the new editor\",\n }),\n dir: option({\n type: optional(Directory),\n long: \"dir\",\n short: \"d\",\n description: \"Name of the directory of an existing editor to re-generate\",\n }),\n all: flag({\n long: \"all\",\n short: \"a\",\n description: \"Re-generate all existing editors in the current project\",\n }),\n ...debugArgs,\n },\n handler: async (args) => {\n const { startGenerateEditor } =\n await import(\"../services/generate-editor.js\");\n await startGenerateEditor(args, process.cwd());\n process.exit(0);\n },\n});\n","import { debugArgs } from \"@powerhousedao/shared/clis/args\";\nimport { command, option, optional, string } from \"cmd-ts\";\nimport path from \"path\";\n\nexport const generateMigrationFileCmd = command({\n name: \"migration-file\",\n description: \"Generate a migration file\",\n args: {\n migrationFile: option({\n type: string,\n long: \"path\",\n short: \"p\",\n description: \"Path to the migration file\",\n }),\n schemaFile: option({\n type: optional(string),\n long: \"schema-file\",\n description: \"Path to the output file. Defaults to './schema.ts'\",\n }),\n ...debugArgs,\n },\n handler: async ({ migrationFile, schemaFile }) => {\n const { generateDBSchema } = await import(\"@powerhousedao/codegen\");\n await generateDBSchema({\n migrationFile: path.join(process.cwd(), migrationFile),\n schemaFile: schemaFile ? path.join(process.cwd(), schemaFile) : undefined,\n });\n process.exit(0);\n },\n});\n","import { debugArgs } from \"@powerhousedao/shared/clis/args\";\nimport { PROCESSOR_APPS } from \"@powerhousedao/shared/processors\";\nimport type { Type } from \"cmd-ts\";\nimport {\n array,\n command,\n flag,\n multioption,\n oneOf,\n option,\n optional,\n string,\n} from \"cmd-ts\";\nimport { Directory } from \"cmd-ts/dist/cjs/batteries/fs.js\";\n\nconst ProcessorAppType: Type<string[], (\"connect\" | \"switchboard\")[]> = {\n from(processorApps) {\n if (processorApps.length === 0) {\n throw new Error(\n `No arguments provided for processor apps. Must be \"connect\" and/or \"switchboard\"`,\n );\n }\n if (processorApps.length > 2) {\n throw new Error(\n `Too many arguments provided for processor apps. Must be \"connect\" and/or \"switchboard\"`,\n );\n }\n const allowed = new Set(PROCESSOR_APPS);\n if (\n !processorApps.every((p) => allowed.has(p as \"connect\" | \"switchboard\"))\n ) {\n throw new Error(\n `Processor apps can only be \"connect\" and/or \"switchboard\".`,\n );\n }\n return Promise.resolve(processorApps as (\"connect\" | \"switchboard\")[]);\n },\n};\nexport const generateProcessorCmd = command({\n name: \"processor\",\n description: \"Generate a processor\",\n args: {\n name: option({\n type: optional(string),\n long: \"name\",\n short: \"n\",\n description: \"The name of the processor to generate\",\n }),\n type: option({\n type: oneOf([\"analytics\", \"relationalDb\"] as const),\n long: \"type\",\n description: \"The type of processor to generate\",\n defaultValue: () => \"analytics\" as const,\n defaultValueIsSerializable: true,\n }),\n documentTypes: multioption({\n type: array(string),\n long: \"document-types\",\n short: \"t\",\n description: \"The document types the processor will run on\",\n defaultValue: () => [],\n defaultValueIsSerializable: true,\n }),\n apps: multioption({\n long: \"apps\",\n type: ProcessorAppType,\n description:\n \"Whether the processor will run in switchboard (nodejs), connect (browser), or both\",\n defaultValue: () => [\"switchboard\" as const, \"connect\" as const],\n defaultValueIsSerializable: true,\n }),\n dir: option({\n type: optional(Directory),\n long: \"dir\",\n short: \"d\",\n description:\n \"Name of the directory of an existing processor to re-generate\",\n }),\n all: flag({\n long: \"all\",\n short: \"a\",\n description: \"Re-generate all existing processors in the current project\",\n }),\n ...debugArgs,\n },\n handler: async (args) => {\n const { startGenerateProcessor } =\n await import(\"../services/generate-processor.js\");\n await startGenerateProcessor(args, process.cwd());\n process.exit(0);\n },\n});\n","import { debugArgs } from \"@powerhousedao/shared/clis/args\";\nimport { command, flag, option, optional, string } from \"cmd-ts\";\nimport { Directory } from \"cmd-ts/dist/cjs/batteries/fs.js\";\n\nexport const generateSubgraphCmd = command({\n name: \"subgraph\",\n description: \"Generate a subgraph\",\n args: {\n name: option({\n type: optional(string),\n long: \"name\",\n short: \"n\",\n description: \"The name of the subgraph to generate\",\n }),\n dir: option({\n type: optional(Directory),\n long: \"dir\",\n short: \"d\",\n description:\n \"Name of the directory of an existing subgraph to re-generate\",\n }),\n all: flag({\n long: \"all\",\n short: \"a\",\n description: \"Re-generate all existing subgraphs in the current project\",\n }),\n ...debugArgs,\n },\n handler: async (args) => {\n const { startGenerateSubgraph } =\n await import(\"../services/generate-subgraph.js\");\n await startGenerateSubgraph(args, process.cwd());\n process.exit(0);\n },\n});\n","import { subcommands } from \"cmd-ts\";\nimport { generateAllCmd } from \"./generate-all.js\";\nimport { generateAppCmd } from \"./generate-app.js\";\nimport { generateDocumentModelCmd } from \"./generate-document-model.js\";\nimport { generateEditorCmd } from \"./generate-editor.js\";\nimport { generateMigrationFileCmd } from \"./generate-migration-file.js\";\nimport { generateProcessorCmd } from \"./generate-processor.js\";\nimport { generateSubgraphCmd } from \"./generate-subgraph.js\";\n\nexport const generate = subcommands({\n name: \"generate\",\n description: `The generate command creates code for Powerhouse modules. It helps you create new code from scratch, or to re-generate existing code in your project.`,\n cmds: {\n all: generateAllCmd,\n \"document-model\": generateDocumentModelCmd,\n editor: generateEditorCmd,\n app: generateAppCmd,\n processor: generateProcessorCmd,\n subgraph: generateSubgraphCmd,\n \"migration-file\": generateMigrationFileCmd,\n },\n});\n","import { initArgs } from \"@powerhousedao/shared/clis/args\";\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/args\";\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 { installArgs } from \"@powerhousedao/shared/clis/args\";\nimport { execSync } from \"child_process\";\nimport { command } from \"cmd-ts\";\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 { getPowerhouseProjectInfo, makeDependenciesWithVersions } =\n await import(\"@powerhousedao/shared/clis\");\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 { resolveRegistryUrl } =\n await import(\"@powerhousedao/shared/registry\");\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 minReleaseAgeArgs =\n packageManager === \"pnpm\" ? [\"--config.minimum-release-age=0\"] : [];\n\n const allowBuildArgs =\n packageManager === \"pnpm\" && args.allowBuild.length > 0\n ? [`--allow-build=${args.allowBuild.join(\",\")}`]\n : [];\n\n const { resolveCommand } = await import(\"package-manager-detector\");\n const resolved = resolveCommand(packageManager, \"add\", [\n ...specs,\n ...scopeRegistryArgs,\n ...minReleaseAgeArgs,\n ...allowBuildArgs,\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 const { updateConfigFile, updateStylesFile } = await import(\"../utils.js\");\n\n try {\n console.log(\"⚙️ Updating powerhouse config file...\");\n updateConfigFile(\n dependenciesWithVersions,\n projectPath,\n \"install\",\n args.local ? \"local\" : \"registry\",\n registryUrl,\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 { listArgs } from \"@powerhousedao/shared/clis/args\";\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 { getPowerhouseProjectInfo } =\n await import(\"@powerhousedao/shared/clis\");\n const projectInfo = await getPowerhouseProjectInfo();\n console.log(\"\\n>>> projectInfo\", projectInfo);\n\n const { getConfig } = await import(\"@powerhousedao/config/node\");\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/args\";\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/args\";\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 { publishArgs } from \"@powerhousedao/shared/clis/args\";\nimport { command } from \"cmd-ts\";\n\nfunction hasTagFlag(args: string[]): boolean {\n return args.some((a) => a === \"--tag\" || a.startsWith(\"--tag=\"));\n}\n\nfunction isInteractive(): boolean {\n return Boolean(process.stdin.isTTY) && !process.env.CI;\n}\n\nasync function readPrereleaseTag(projectPath: string): Promise<{\n version: string;\n tag: string;\n} | null> {\n try {\n const [{ readPackageSync }, { prerelease }] = await Promise.all([\n import(\"read-pkg\"),\n import(\"semver\"),\n ]);\n const pkg = readPackageSync({ cwd: projectPath });\n if (!pkg.version) return null;\n const parts = prerelease(pkg.version);\n if (!parts || parts.length === 0) return null;\n const label = String(parts[0]);\n // semver may surface numeric-only prerelease ids (e.g. `1.0.0-0`);\n // npm requires an alphanumeric dist-tag, so skip those.\n if (!/^[a-z][a-z0-9-]*$/i.test(label)) return null;\n return { version: pkg.version, tag: label };\n } catch {\n return null;\n }\n}\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 { getPowerhouseProjectInfo } =\n await import(\"@powerhousedao/shared/clis\");\n const { projectPath } = await getPowerhouseProjectInfo();\n\n if (!projectPath) {\n throw new Error(\"Could not find project path.\");\n }\n\n const { checkNpmAuth, npmPublish, resolveRegistryUrl } =\n await import(\"@powerhousedao/shared/registry\");\n const { mintRegistryAuthToken } =\n await import(\"../services/registry-auth.js\");\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 Renown auth first: if the user is logged in via `ph login`, mint a\n // short-lived registry-bound bearer token. Falling back to the legacy\n // `npm adduser` (htpasswd) path keeps existing flows working until the\n // grace period ends.\n let authToken: string | undefined;\n try {\n authToken = await mintRegistryAuthToken(registryUrl, 5 * 60);\n if (args.debug) {\n console.error(`>>> minted renown token for ${registryUrl} (5m TTL)`);\n }\n } catch (err) {\n if (args.debug) {\n console.error(\n `>>> renown token mint skipped: ${(err as Error).message}`,\n );\n }\n try {\n await checkNpmAuth(registryUrl);\n } catch {\n console.error(`Not authenticated with registry: ${registryUrl}`);\n console.error(\n `Run: ph login (recommended) or npm adduser --registry ${registryUrl}`,\n );\n process.exit(1);\n }\n }\n\n let forwardedArgs = args.forwardedArgs;\n\n if (!hasTagFlag(forwardedArgs)) {\n const prereleaseInfo = await readPrereleaseTag(projectPath);\n if (prereleaseInfo) {\n const { version, tag } = prereleaseInfo;\n if (!isInteractive()) {\n console.error(\n `Detected prerelease version ${version}. npm requires an explicit dist-tag for prerelease publishes.`,\n );\n console.error(\n `Re-run with --tag <label> (e.g. --tag ${tag}) to proceed.`,\n );\n process.exit(1);\n }\n\n const enquirer = await import(\"enquirer\");\n\n let confirmed = false;\n try {\n const answer = await enquirer.default.prompt<{ confirmed: boolean }>({\n type: \"confirm\",\n name: \"confirmed\",\n message: `Detected prerelease version ${version}. Publish with --tag ${tag}?`,\n initial: true,\n });\n confirmed = answer.confirmed;\n } catch {\n // user aborted the prompt (Ctrl-C); treat as decline\n confirmed = false;\n }\n\n if (!confirmed) {\n console.error(\n `Aborted. To publish manually: npm publish --registry ${registryUrl} --tag <label>`,\n );\n process.exit(1);\n }\n\n forwardedArgs = [\"--tag\", tag, ...forwardedArgs];\n }\n }\n\n if (args.debug) {\n console.log(\n \">>> command\",\n `npm publish --registry ${registryUrl} ${forwardedArgs.join(\" \")}`,\n );\n }\n\n console.log(`Publishing to ${registryUrl}...`);\n const result = await npmPublish({\n registryUrl,\n cwd: projectPath,\n args: forwardedArgs,\n authToken,\n });\n if (result.stdout) {\n console.log(result.stdout);\n }\n\n process.exit(0);\n },\n});\n","import { registryLoginArgs } from \"@powerhousedao/shared/clis/args\";\nimport { command } from \"cmd-ts\";\n\nexport const registryLogin = command({\n name: \"registry-login\",\n description: `\nLog in to a Powerhouse registry using your Renown identity. Mints a longer-lived\nbearer token (default 30 days) bound to the registry's audience and writes the\ntoken into ~/.npmrc so raw 'npm publish' / 'npm install' work without further\nsetup.\n\nPrerequisites:\n Run 'ph login' first to establish a Renown identity.\n\nUsage:\n ph registry-login # uses powerhouse.config.json / PH_REGISTRY_URL\n ph registry-login --registry https://registry.dev.vetra.io\n ph registry-login --expiry 7d\n `,\n args: registryLoginArgs,\n handler: async (args) => {\n if (args.debug) {\n console.log(args);\n }\n\n const { getPowerhouseProjectInfo } =\n await import(\"@powerhousedao/shared/clis\");\n const projectInfo = await getPowerhouseProjectInfo().catch(() => null);\n const projectPath = projectInfo?.projectPath ?? process.cwd();\n\n const [\n { resolveRegistryUrl, writeRegistryAuthToken },\n { mintRegistryAuthToken },\n { parseExpiry, formatExpiry },\n ] = await Promise.all([\n import(\"@powerhousedao/shared/registry\"),\n import(\"../services/registry-auth.js\"),\n import(\"@renown/sdk/node\"),\n ]);\n\n const registryUrl = resolveRegistryUrl({\n registry: args.registry,\n projectPath,\n });\n\n const expiresIn = parseExpiry(args.expiry);\n\n const token = await mintRegistryAuthToken(registryUrl, expiresIn);\n const npmrcPath = await writeRegistryAuthToken(registryUrl, token);\n\n console.log(`Logged in to ${registryUrl}`);\n console.log(` Token expires in: ${formatExpiry(expiresIn)}`);\n console.log(` Wrote: ${npmrcPath}`);\n process.exit(0);\n },\n});\n","import { switchboardArgs } from \"@powerhousedao/shared/clis/args\";\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, reset, yes } = args;\n if (basePath) {\n process.env.BASE_PATH = basePath;\n }\n\n if (reset) {\n const { resetSwitchboardDatabase } = await import(\n \"../services/switchboard-reset.js\"\n );\n await resetSwitchboardDatabase({ dbPath, yes });\n process.exit(0);\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 { AGENTS, uninstallArgs } from \"@powerhousedao/shared/clis/args\";\nimport { command } from \"cmd-ts\";\nimport { execSync } from \"node:child_process\";\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 getPowerhouseProjectInfo,\n getPowerhouseProjectUninstallCommand,\n makeDependenciesWithVersions,\n } = await import(\"@powerhousedao/shared/clis\");\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 = await getPowerhouseProjectUninstallCommand(\n packageManager,\n args.dependencies,\n );\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 const { removeStylesImports, updateConfigFile } =\n await import(\"../utils.js\");\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 { unpublishArgs } from \"@powerhousedao/shared/clis/args\";\nimport { command } from \"cmd-ts\";\nimport { createInterface } from \"node:readline/promises\";\n\nexport const unpublish = command({\n name: \"unpublish\",\n description: `\nUnpublish a package from the Powerhouse registry. This is a thin wrapper around\nnpm unpublish that automatically targets the Powerhouse registry and never\nreaches npmjs.org.\n\nForms:\n ph unpublish # unpublish <name>@<version> from cwd's package.json\n ph unpublish <name> # unpublish the whole package (all versions)\n ph unpublish <name>@<version> # unpublish a single version\n\nFlags:\n --registry <url> # override registry URL\n --yes, -y # skip the confirmation prompt\n `,\n args: unpublishArgs,\n handler: async (args) => {\n if (args.debug) {\n console.log(args);\n }\n\n const { getPowerhouseProjectInfo } =\n await import(\"@powerhousedao/shared/clis\");\n const { projectPath } = await getPowerhouseProjectInfo();\n\n if (!projectPath) {\n throw new Error(\"Could not find project path.\");\n }\n\n const { checkNpmAuth, npmUnpublish, resolveRegistryUrl } =\n await import(\"@powerhousedao/shared/registry\");\n\n const registryUrl = resolveRegistryUrl({\n registry: args.registry,\n projectPath,\n });\n\n const spec = await resolveSpec(args.spec, projectPath);\n if (!spec) {\n console.error(\n \"No package spec provided and could not read name/version from package.json.\",\n );\n process.exit(1);\n }\n\n if (args.debug) {\n console.log(\">>> registryUrl\", registryUrl);\n console.log(\">>> spec\", spec);\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.yes) {\n const confirmed = await confirm(\n `Unpublish ${spec} from ${registryUrl}? [y/N] `,\n );\n if (!confirmed) {\n console.log(\"Aborted.\");\n process.exit(0);\n }\n }\n\n if (args.debug) {\n console.log(\n \">>> command\",\n `npm unpublish ${spec} --registry ${registryUrl} --force ${args.forwardedArgs.join(\" \")}`,\n );\n }\n\n console.log(`Unpublishing ${spec} from ${registryUrl}...`);\n try {\n const result = await npmUnpublish({\n registryUrl,\n cwd: projectPath,\n spec,\n args: args.forwardedArgs,\n });\n if (result.stdout) {\n console.log(result.stdout);\n }\n process.exit(0);\n } catch (err) {\n console.error(err instanceof Error ? err.message : String(err));\n process.exit(1);\n }\n },\n});\n\nasync function resolveSpec(\n explicit: string | undefined,\n projectPath: string,\n): Promise<string | null> {\n if (explicit) return explicit;\n try {\n const { readPackageSync } = await import(\"read-pkg\");\n const pkg = readPackageSync({ cwd: projectPath });\n if (!pkg.name) return null;\n return pkg.version ? `${pkg.name}@${pkg.version}` : pkg.name;\n } catch {\n return null;\n }\n}\n\nasync function confirm(prompt: string): Promise<boolean> {\n const rl = createInterface({ input: process.stdin, output: process.stdout });\n try {\n const answer = await rl.question(prompt);\n return /^y(es)?$/i.test(answer.trim());\n } finally {\n rl.close();\n }\n}\n","import { vetraArgs } from \"@powerhousedao/shared/clis/args\";\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 { registryLogin } from \"./registry-login.js\";\nimport { switchboard } from \"./switchboard.js\";\nimport { uninstall } from \"./uninstall.js\";\nimport { unpublish } from \"./unpublish.js\";\nimport { vetra } from \"./vetra.js\";\n\nexport const phCliCommands = {\n init,\n generate,\n vetra,\n connect,\n build,\n publish,\n unpublish,\n \"access-token\": accessToken,\n \"registry-login\": registryLogin,\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","import { yellow, bold } from \"colorette\";\n\nconst UNRECOVERABLE_DB_PATTERNS: RegExp[] = [\n /Database migration failed:/i,\n /Migration .* failed/i,\n /relation \"[^\"]+\" already exists/i,\n /column \"[^\"]+\" does not exist/i,\n /schema \"reactor\" does not exist/i,\n /Unsupported PGLite data dir/i,\n /PG_VERSION/i,\n];\n\nfunction collectMessages(err: unknown): string[] {\n const messages: string[] = [];\n let current: unknown = err;\n const seen = new Set<unknown>();\n while (current && !seen.has(current)) {\n seen.add(current);\n if (current instanceof Error) {\n messages.push(current.message);\n current = (current as Error & { cause?: unknown }).cause;\n } else {\n messages.push(String(current));\n break;\n }\n }\n return messages;\n}\n\nexport function isUnrecoverableDbError(err: unknown): boolean {\n const messages = collectMessages(err);\n return messages.some((msg) =>\n UNRECOVERABLE_DB_PATTERNS.some((re) => re.test(msg)),\n );\n}\n\nexport function printDbRecoveryHint(err: unknown): void {\n const messages = collectMessages(err);\n const offending = messages.find((msg) =>\n UNRECOVERABLE_DB_PATTERNS.some((re) => re.test(msg)),\n );\n console.error(\"\");\n console.error(\n yellow(bold(\"Switchboard hit an unrecoverable database error.\")),\n );\n if (offending) {\n console.error(yellow(` ${offending}`));\n }\n console.error(\"\");\n console.error(\n yellow(\n \"If this is a local PGlite store, you can reset it with:\",\n ),\n );\n console.error(yellow(\" ph switchboard --reset\"),);\n console.error(\n yellow(\n \"This is destructive: it wipes the local .ph/reactor-storage and .ph/read-storage directories.\",\n ),\n );\n console.error(\n yellow(\n \"For Postgres-backed deployments (PH_REACTOR_DATABASE_URL / DATABASE_URL), reset the database manually instead.\",\n ),\n );\n console.error(\"\");\n}\n","#!/usr/bin/env node\nimport {\n initCliTelemetry,\n type TelemetryClient,\n} from \"@powerhousedao/shared/clis/telemetry\";\nimport { assertNodeVersion } from \"@powerhousedao/shared/clis/utils\";\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\";\nimport {\n isUnrecoverableDbError,\n printDbRecoveryHint,\n} from \"./utils/db-error-hint.js\";\n\nlet sentryClient: TelemetryClient | undefined = undefined;\n\n// Commands whose second positional is itself a subcommand (vs. a project\n// name / file path). Keeping this explicit avoids high-cardinality tag\n// values like `subcommand:my-package` polluting Sentry.\nconst COMMANDS_WITH_SUBCOMMANDS = new Set([\"connect\", \"vetra\"]);\n\nfunction detectPackageManager(): string | undefined {\n // npm, pnpm, yarn and bun all set npm_config_user_agent like\n // \"pnpm/8.5.0 npm/? node/v20.11.1 darwin arm64\". When the user invokes\n // `ph` directly (not via dlx/exec) it's typically unset — skip the tag\n // in that case rather than mislabel.\n const ua = process.env.npm_config_user_agent;\n if (!ua) return undefined;\n return ua.split(\" \")[0]?.split(\"/\")[0] || undefined;\n}\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 sentryClient = await initCliTelemetry({\n cliName: \"ph-cli\",\n release: getVersion(),\n });\n const args = process.argv.slice(2);\n const command = args[0];\n const subcommand =\n command &&\n COMMANDS_WITH_SUBCOMMANDS.has(command) &&\n args[1] &&\n !args[1].startsWith(\"-\")\n ? args[1]\n : undefined;\n sentryClient?.attachInvocationContext({\n command,\n subcommand,\n pm: detectPackageManager(),\n argv: args,\n cwd: process.cwd(),\n });\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 restArgs = args.slice(1);\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 sentryClient?.captureCliError(error);\n if (isDebug) {\n throw error;\n }\n if (error instanceof Error) {\n console.error(error.message);\n if (isUnrecoverableDbError(error)) {\n printDbRecoveryHint(error);\n }\n process.exit(1);\n } else {\n throw error;\n }\n});\n"],"names":["version","build"],"mappings":"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","debug_id":"19f46d7c-6663-5ffa-ac40-1a71c0a3d790"}
1
+ {"version":3,"file":"cli.mjs","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-all.ts","../src/commands/generate-app.ts","../src/commands/generate-document-model.ts","../src/commands/generate-editor.ts","../src/commands/generate-migration-file.ts","../src/commands/generate-processor.ts","../src/commands/generate-subgraph.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/registry-login.ts","../src/commands/switchboard.ts","../src/commands/uninstall.ts","../src/commands/unpublish.ts","../src/commands/vetra.ts","../src/commands/ph-cli-commands.ts","../src/commands/ph-cli.ts","../src/utils/db-error-hint.ts","../src/cli.ts"],"sourcesContent":["declare const CLI_VERSION: string | undefined;\ndeclare const CLI_GIT_SHA: string | undefined;\n\nexport function getVersion() {\n if (typeof CLI_VERSION !== \"undefined\") return CLI_VERSION;\n return (\n process.env.WORKSPACE_VERSION ||\n process.env.npm_package_version ||\n \"unknown\"\n );\n}\n\nexport function getGitHash() {\n if (typeof CLI_GIT_SHA !== \"undefined\") return CLI_GIT_SHA;\n return process.env.WORKSPACE_GIT_SHA || \"unknown\";\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/args\";\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 { accessTokenArgs } from \"@powerhousedao/shared/clis/args\";\nimport { DEFAULT_EXPIRY_SECONDS } from \"@powerhousedao/shared/clis/constants\";\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/args\";\nimport { command } from \"cmd-ts\";\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 const { runBuild } = await import(\"../services/build.js\");\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/args\";\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 { command, flag } from \"cmd-ts\";\n\nexport const generateAllCmd = command({\n name: \"all\",\n description: \"Re-generate all modules in the current project\",\n args: {\n extract: flag({\n long: \"extract\",\n short: \"x\",\n description:\n \"Instead of generating code, write a spec for every module into specs/ (one-shot migration to documents-as-source-of-truth)\",\n }),\n },\n handler: async (args) => {\n const { startGenerateAll } = await import(\"../services/generate-all.js\");\n await startGenerateAll(args, process.cwd());\n process.exit(0);\n },\n});\n","import { debugArgs } from \"@powerhousedao/shared/clis/args\";\nimport {\n array,\n boolean,\n command,\n flag,\n multioption,\n option,\n optional,\n string,\n} from \"cmd-ts\";\nimport { Directory, File } from \"cmd-ts/dist/cjs/batteries/fs.js\";\n\nexport const generateAppCmd = command({\n name: \"app\",\n description: \"Generate a drive app\",\n args: {\n name: option({\n type: optional(string),\n long: \"name\",\n short: \"n\",\n description: \"The name of the drive app to generate\",\n }),\n allowedDocumentTypes: multioption({\n type: optional(array(string)),\n long: \"document-types\",\n short: \"t\",\n description: \"The document types allowed by the new app\",\n }),\n document: option({\n type: optional(File),\n long: \"document\",\n short: \"d\",\n description:\n \"Path to a powerhouse/app spec file (.phd or .json) to drive codegen\",\n }),\n dir: option({\n type: optional(Directory),\n long: \"dir\",\n description: \"Name of the directory of an existing app to re-generate\",\n }),\n disableDragAndDrop: flag({\n type: boolean,\n long: \"disable-drag-and-drop\",\n description: \"Do not allow drag and drop in this drive app.\",\n defaultValue: () => false as const,\n defaultValueIsSerializable: true,\n }),\n all: flag({\n long: \"all\",\n short: \"a\",\n description: \"Re-generate all existing apps in the current project\",\n }),\n extract: flag({\n long: \"extract\",\n short: \"x\",\n description:\n \"Write a powerhouse/app spec for each existing drive app into specs/apps/\",\n }),\n ...debugArgs,\n },\n handler: async (args) => {\n const { startGenerateApp } = await import(\"../services/generate-app.js\");\n await startGenerateApp(args, process.cwd());\n process.exit(0);\n },\n});\n","import { debugArgs } from \"@powerhousedao/shared/clis/args\";\nimport { command, flag, option, optional } from \"cmd-ts\";\nimport { Directory, File } from \"cmd-ts/dist/cjs/batteries/fs.js\";\nexport const generateDocumentModelCmd = command({\n name: \"document-model\",\n aliases: [\"doc\"],\n description: \"Generate a document model\",\n args: {\n document: option({\n type: optional(File),\n long: \"document\",\n short: \"d\",\n description:\n \"Path to a document model spec (.phd or .json) to generate from\",\n }),\n dir: option({\n type: optional(Directory),\n long: \"dir\",\n description:\n \"Name of the directory of an existing document model to re-generate\",\n }),\n all: flag({\n long: \"all\",\n short: \"a\",\n description:\n \"Re-generate all existing document models in the current project\",\n }),\n extract: flag({\n long: \"extract\",\n short: \"x\",\n description:\n \"Write a powerhouse/document-model spec for each existing document model into specs/document-models/\",\n }),\n ...debugArgs,\n },\n handler: async (args) => {\n const { startGenerateDocumentModel } =\n await import(\"../services/generate-document-model.js\");\n await startGenerateDocumentModel(args, process.cwd());\n process.exit(0);\n },\n});\n","import { debugArgs } from \"@powerhousedao/shared/clis/args\";\nimport { command, flag, option, optional, string } from \"cmd-ts\";\nimport { Directory, File } from \"cmd-ts/dist/cjs/batteries/fs.js\";\n\nexport const generateEditorCmd = command({\n name: \"editor\",\n description: \"Generate a document editor\",\n args: {\n name: option({\n type: optional(string),\n long: \"name\",\n short: \"n\",\n description: \"The name of the document editor to generate\",\n }),\n documentType: option({\n type: optional(string),\n long: \"document-type\",\n short: \"t\",\n description: \"The document type for the new editor\",\n }),\n document: option({\n type: optional(File),\n long: \"document\",\n short: \"d\",\n description:\n \"Path to a powerhouse/document-editor spec file (.phd or .json) to drive codegen\",\n }),\n dir: option({\n type: optional(Directory),\n long: \"dir\",\n description: \"Name of the directory of an existing editor to re-generate\",\n }),\n all: flag({\n long: \"all\",\n short: \"a\",\n description: \"Re-generate all existing editors in the current project\",\n }),\n extract: flag({\n long: \"extract\",\n short: \"x\",\n description:\n \"Write a powerhouse/document-editor spec for each existing editor into specs/editors/\",\n }),\n ...debugArgs,\n },\n handler: async (args) => {\n const { startGenerateEditor } =\n await import(\"../services/generate-editor.js\");\n await startGenerateEditor(args, process.cwd());\n process.exit(0);\n },\n});\n","import { debugArgs } from \"@powerhousedao/shared/clis/args\";\nimport { command, option, optional, string } from \"cmd-ts\";\nimport path from \"path\";\n\nexport const generateMigrationFileCmd = command({\n name: \"migration-file\",\n description: \"Generate a migration file\",\n args: {\n migrationFile: option({\n type: string,\n long: \"path\",\n short: \"p\",\n description: \"Path to the migration file\",\n }),\n schemaFile: option({\n type: optional(string),\n long: \"schema-file\",\n description: \"Path to the output file. Defaults to './schema.ts'\",\n }),\n ...debugArgs,\n },\n handler: async ({ migrationFile, schemaFile }) => {\n const { generateDBSchema } = await import(\"@powerhousedao/codegen\");\n await generateDBSchema({\n migrationFile: path.join(process.cwd(), migrationFile),\n schemaFile: schemaFile ? path.join(process.cwd(), schemaFile) : undefined,\n });\n process.exit(0);\n },\n});\n","import { debugArgs } from \"@powerhousedao/shared/clis/args\";\nimport { PROCESSOR_APPS } from \"@powerhousedao/shared/processors\";\nimport type { Type } from \"cmd-ts\";\nimport {\n array,\n command,\n flag,\n multioption,\n oneOf,\n option,\n optional,\n string,\n} from \"cmd-ts\";\nimport { Directory, File } from \"cmd-ts/dist/cjs/batteries/fs.js\";\n\nconst ProcessorAppType: Type<string[], (\"connect\" | \"switchboard\")[]> = {\n from(processorApps) {\n if (processorApps.length === 0) {\n throw new Error(\n `No arguments provided for processor apps. Must be \"connect\" and/or \"switchboard\"`,\n );\n }\n if (processorApps.length > 2) {\n throw new Error(\n `Too many arguments provided for processor apps. Must be \"connect\" and/or \"switchboard\"`,\n );\n }\n const allowed = new Set(PROCESSOR_APPS);\n if (\n !processorApps.every((p) => allowed.has(p as \"connect\" | \"switchboard\"))\n ) {\n throw new Error(\n `Processor apps can only be \"connect\" and/or \"switchboard\".`,\n );\n }\n return Promise.resolve(processorApps as (\"connect\" | \"switchboard\")[]);\n },\n};\nexport const generateProcessorCmd = command({\n name: \"processor\",\n description: \"Generate a processor\",\n args: {\n name: option({\n type: optional(string),\n long: \"name\",\n short: \"n\",\n description: \"The name of the processor to generate\",\n }),\n type: option({\n type: oneOf([\"analytics\", \"relationalDb\"] as const),\n long: \"type\",\n description: \"The type of processor to generate\",\n defaultValue: () => \"analytics\" as const,\n defaultValueIsSerializable: true,\n }),\n documentTypes: multioption({\n type: array(string),\n long: \"document-types\",\n short: \"t\",\n description: \"The document types the processor will run on\",\n defaultValue: () => [],\n defaultValueIsSerializable: true,\n }),\n apps: multioption({\n long: \"apps\",\n type: ProcessorAppType,\n description:\n \"Whether the processor will run in switchboard (nodejs), connect (browser), or both\",\n defaultValue: () => [\"switchboard\" as const, \"connect\" as const],\n defaultValueIsSerializable: true,\n }),\n document: option({\n type: optional(File),\n long: \"document\",\n short: \"d\",\n description:\n \"Path to a powerhouse/processor spec file (.phd or .json) to drive codegen\",\n }),\n dir: option({\n type: optional(Directory),\n long: \"dir\",\n description:\n \"Name of the directory of an existing processor to re-generate\",\n }),\n all: flag({\n long: \"all\",\n short: \"a\",\n description: \"Re-generate all existing processors in the current project\",\n }),\n extract: flag({\n long: \"extract\",\n short: \"x\",\n description:\n \"Write a powerhouse/processor spec for each existing processor into specs/processors/\",\n }),\n ...debugArgs,\n },\n handler: async (args) => {\n const { startGenerateProcessor } =\n await import(\"../services/generate-processor.js\");\n await startGenerateProcessor(args, process.cwd());\n process.exit(0);\n },\n});\n","import { debugArgs } from \"@powerhousedao/shared/clis/args\";\nimport { command, flag, option, optional, string } from \"cmd-ts\";\nimport { Directory, File } from \"cmd-ts/dist/cjs/batteries/fs.js\";\n\nexport const generateSubgraphCmd = command({\n name: \"subgraph\",\n description: \"Generate a subgraph\",\n args: {\n name: option({\n type: optional(string),\n long: \"name\",\n short: \"n\",\n description: \"The name of the subgraph to generate\",\n }),\n document: option({\n type: optional(File),\n long: \"document\",\n short: \"d\",\n description:\n \"Path to a powerhouse/subgraph spec file (.phd or .json) to drive codegen\",\n }),\n dir: option({\n type: optional(Directory),\n long: \"dir\",\n description:\n \"Name of the directory of an existing subgraph to re-generate\",\n }),\n all: flag({\n long: \"all\",\n short: \"a\",\n description: \"Re-generate all existing subgraphs in the current project\",\n }),\n extract: flag({\n long: \"extract\",\n short: \"x\",\n description:\n \"Write a powerhouse/subgraph spec for each existing subgraph into specs/subgraphs/\",\n }),\n ...debugArgs,\n },\n handler: async (args) => {\n const { startGenerateSubgraph } =\n await import(\"../services/generate-subgraph.js\");\n await startGenerateSubgraph(args, process.cwd());\n process.exit(0);\n },\n});\n","import { subcommands } from \"cmd-ts\";\nimport { generateAllCmd } from \"./generate-all.js\";\nimport { generateAppCmd } from \"./generate-app.js\";\nimport { generateDocumentModelCmd } from \"./generate-document-model.js\";\nimport { generateEditorCmd } from \"./generate-editor.js\";\nimport { generateMigrationFileCmd } from \"./generate-migration-file.js\";\nimport { generateProcessorCmd } from \"./generate-processor.js\";\nimport { generateSubgraphCmd } from \"./generate-subgraph.js\";\n\nexport const generate = subcommands({\n name: \"generate\",\n description: `The generate command creates code for Powerhouse modules. It helps you create new code from scratch, or to re-generate existing code in your project.`,\n cmds: {\n all: generateAllCmd,\n \"document-model\": generateDocumentModelCmd,\n editor: generateEditorCmd,\n app: generateAppCmd,\n processor: generateProcessorCmd,\n subgraph: generateSubgraphCmd,\n \"migration-file\": generateMigrationFileCmd,\n },\n});\n","import { initArgs } from \"@powerhousedao/shared/clis/args\";\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/args\";\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 { installArgs } from \"@powerhousedao/shared/clis/args\";\nimport { execSync } from \"child_process\";\nimport { command } from \"cmd-ts\";\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 { getPowerhouseProjectInfo, makeDependenciesWithVersions } =\n await import(\"@powerhousedao/shared/clis\");\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 { resolveRegistryUrl } =\n await import(\"@powerhousedao/shared/registry\");\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 minReleaseAgeArgs =\n packageManager === \"pnpm\" ? [\"--config.minimum-release-age=0\"] : [];\n\n const allowBuildArgs =\n packageManager === \"pnpm\" && args.allowBuild.length > 0\n ? [`--allow-build=${args.allowBuild.join(\",\")}`]\n : [];\n\n const { resolveCommand } = await import(\"package-manager-detector\");\n const resolved = resolveCommand(packageManager, \"add\", [\n ...specs,\n ...scopeRegistryArgs,\n ...minReleaseAgeArgs,\n ...allowBuildArgs,\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 const { updateConfigFile, updateStylesFile } = await import(\"../utils.js\");\n\n try {\n console.log(\"⚙️ Updating powerhouse config file...\");\n updateConfigFile(\n dependenciesWithVersions,\n projectPath,\n \"install\",\n args.local ? \"local\" : \"registry\",\n registryUrl,\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 { listArgs } from \"@powerhousedao/shared/clis/args\";\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 { getPowerhouseProjectInfo } =\n await import(\"@powerhousedao/shared/clis\");\n const projectInfo = await getPowerhouseProjectInfo();\n console.log(\"\\n>>> projectInfo\", projectInfo);\n\n const { getConfig } = await import(\"@powerhousedao/config/node\");\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/args\";\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/args\";\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 { publishArgs } from \"@powerhousedao/shared/clis/args\";\nimport { command } from \"cmd-ts\";\n\nfunction hasTagFlag(args: string[]): boolean {\n return args.some((a) => a === \"--tag\" || a.startsWith(\"--tag=\"));\n}\n\nfunction isInteractive(): boolean {\n return Boolean(process.stdin.isTTY) && !process.env.CI;\n}\n\nasync function readPrereleaseTag(projectPath: string): Promise<{\n version: string;\n tag: string;\n} | null> {\n try {\n const [{ readPackageSync }, { prerelease }] = await Promise.all([\n import(\"read-pkg\"),\n import(\"semver\"),\n ]);\n const pkg = readPackageSync({ cwd: projectPath });\n if (!pkg.version) return null;\n const parts = prerelease(pkg.version);\n if (!parts || parts.length === 0) return null;\n const label = String(parts[0]);\n // semver may surface numeric-only prerelease ids (e.g. `1.0.0-0`);\n // npm requires an alphanumeric dist-tag, so skip those.\n if (!/^[a-z][a-z0-9-]*$/i.test(label)) return null;\n return { version: pkg.version, tag: label };\n } catch {\n return null;\n }\n}\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 { getPowerhouseProjectInfo } =\n await import(\"@powerhousedao/shared/clis\");\n const { projectPath } = await getPowerhouseProjectInfo();\n\n if (!projectPath) {\n throw new Error(\"Could not find project path.\");\n }\n\n const { checkNpmAuth, npmPublish, resolveRegistryUrl } =\n await import(\"@powerhousedao/shared/registry\");\n const { mintRegistryAuthToken } =\n await import(\"../services/registry-auth.js\");\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 Renown auth first: if the user is logged in via `ph login`, mint a\n // short-lived registry-bound bearer token. Falling back to the legacy\n // `npm adduser` (htpasswd) path keeps existing flows working until the\n // grace period ends.\n let authToken: string | undefined;\n try {\n authToken = await mintRegistryAuthToken(registryUrl, 5 * 60);\n if (args.debug) {\n console.error(`>>> minted renown token for ${registryUrl} (5m TTL)`);\n }\n } catch (err) {\n if (args.debug) {\n console.error(\n `>>> renown token mint skipped: ${(err as Error).message}`,\n );\n }\n try {\n await checkNpmAuth(registryUrl);\n } catch {\n console.error(`Not authenticated with registry: ${registryUrl}`);\n console.error(\n `Run: ph login (recommended) or npm adduser --registry ${registryUrl}`,\n );\n process.exit(1);\n }\n }\n\n let forwardedArgs = args.forwardedArgs;\n\n if (!hasTagFlag(forwardedArgs)) {\n const prereleaseInfo = await readPrereleaseTag(projectPath);\n if (prereleaseInfo) {\n const { version, tag } = prereleaseInfo;\n if (!isInteractive()) {\n console.error(\n `Detected prerelease version ${version}. npm requires an explicit dist-tag for prerelease publishes.`,\n );\n console.error(\n `Re-run with --tag <label> (e.g. --tag ${tag}) to proceed.`,\n );\n process.exit(1);\n }\n\n const enquirer = await import(\"enquirer\");\n\n let confirmed = false;\n try {\n const answer = await enquirer.default.prompt<{ confirmed: boolean }>({\n type: \"confirm\",\n name: \"confirmed\",\n message: `Detected prerelease version ${version}. Publish with --tag ${tag}?`,\n initial: true,\n });\n confirmed = answer.confirmed;\n } catch {\n // user aborted the prompt (Ctrl-C); treat as decline\n confirmed = false;\n }\n\n if (!confirmed) {\n console.error(\n `Aborted. To publish manually: npm publish --registry ${registryUrl} --tag <label>`,\n );\n process.exit(1);\n }\n\n forwardedArgs = [\"--tag\", tag, ...forwardedArgs];\n }\n }\n\n if (args.debug) {\n console.log(\n \">>> command\",\n `npm publish --registry ${registryUrl} ${forwardedArgs.join(\" \")}`,\n );\n }\n\n console.log(`Publishing to ${registryUrl}...`);\n const result = await npmPublish({\n registryUrl,\n cwd: projectPath,\n args: forwardedArgs,\n authToken,\n });\n if (result.stdout) {\n console.log(result.stdout);\n }\n\n process.exit(0);\n },\n});\n","import { registryLoginArgs } from \"@powerhousedao/shared/clis/args\";\nimport { command } from \"cmd-ts\";\n\nexport const registryLogin = command({\n name: \"registry-login\",\n description: `\nLog in to a Powerhouse registry using your Renown identity. Mints a longer-lived\nbearer token (default 30 days) bound to the registry's audience and writes the\ntoken into ~/.npmrc so raw 'npm publish' / 'npm install' work without further\nsetup.\n\nPrerequisites:\n Run 'ph login' first to establish a Renown identity.\n\nUsage:\n ph registry-login # uses powerhouse.config.json / PH_REGISTRY_URL\n ph registry-login --registry https://registry.dev.vetra.io\n ph registry-login --expiry 7d\n `,\n args: registryLoginArgs,\n handler: async (args) => {\n if (args.debug) {\n console.log(args);\n }\n\n const { getPowerhouseProjectInfo } =\n await import(\"@powerhousedao/shared/clis\");\n const projectInfo = await getPowerhouseProjectInfo().catch(() => null);\n const projectPath = projectInfo?.projectPath ?? process.cwd();\n\n const [\n { resolveRegistryUrl, writeRegistryAuthToken },\n { mintRegistryAuthToken },\n { parseExpiry, formatExpiry },\n ] = await Promise.all([\n import(\"@powerhousedao/shared/registry\"),\n import(\"../services/registry-auth.js\"),\n import(\"@renown/sdk/node\"),\n ]);\n\n const registryUrl = resolveRegistryUrl({\n registry: args.registry,\n projectPath,\n });\n\n const expiresIn = parseExpiry(args.expiry);\n\n const token = await mintRegistryAuthToken(registryUrl, expiresIn);\n const npmrcPath = await writeRegistryAuthToken(registryUrl, token);\n\n console.log(`Logged in to ${registryUrl}`);\n console.log(` Token expires in: ${formatExpiry(expiresIn)}`);\n console.log(` Wrote: ${npmrcPath}`);\n process.exit(0);\n },\n});\n","import { switchboardArgs } from \"@powerhousedao/shared/clis/args\";\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, reset, yes } = args;\n if (basePath) {\n process.env.BASE_PATH = basePath;\n }\n\n if (reset) {\n const { resetSwitchboardDatabase } = await import(\n \"../services/switchboard-reset.js\"\n );\n await resetSwitchboardDatabase({ dbPath, yes });\n process.exit(0);\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 { AGENTS, uninstallArgs } from \"@powerhousedao/shared/clis/args\";\nimport { command } from \"cmd-ts\";\nimport { execSync } from \"node:child_process\";\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 getPowerhouseProjectInfo,\n getPowerhouseProjectUninstallCommand,\n makeDependenciesWithVersions,\n } = await import(\"@powerhousedao/shared/clis\");\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 = await getPowerhouseProjectUninstallCommand(\n packageManager,\n args.dependencies,\n );\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 const { removeStylesImports, updateConfigFile } =\n await import(\"../utils.js\");\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 { unpublishArgs } from \"@powerhousedao/shared/clis/args\";\nimport { command } from \"cmd-ts\";\nimport { createInterface } from \"node:readline/promises\";\n\nexport const unpublish = command({\n name: \"unpublish\",\n description: `\nUnpublish a package from the Powerhouse registry. This is a thin wrapper around\nnpm unpublish that automatically targets the Powerhouse registry and never\nreaches npmjs.org.\n\nForms:\n ph unpublish # unpublish <name>@<version> from cwd's package.json\n ph unpublish <name> # unpublish the whole package (all versions)\n ph unpublish <name>@<version> # unpublish a single version\n\nFlags:\n --registry <url> # override registry URL\n --yes, -y # skip the confirmation prompt\n `,\n args: unpublishArgs,\n handler: async (args) => {\n if (args.debug) {\n console.log(args);\n }\n\n const { getPowerhouseProjectInfo } =\n await import(\"@powerhousedao/shared/clis\");\n const { projectPath } = await getPowerhouseProjectInfo();\n\n if (!projectPath) {\n throw new Error(\"Could not find project path.\");\n }\n\n const { checkNpmAuth, npmUnpublish, resolveRegistryUrl } =\n await import(\"@powerhousedao/shared/registry\");\n\n const registryUrl = resolveRegistryUrl({\n registry: args.registry,\n projectPath,\n });\n\n const spec = await resolveSpec(args.spec, projectPath);\n if (!spec) {\n console.error(\n \"No package spec provided and could not read name/version from package.json.\",\n );\n process.exit(1);\n }\n\n if (args.debug) {\n console.log(\">>> registryUrl\", registryUrl);\n console.log(\">>> spec\", spec);\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.yes) {\n const confirmed = await confirm(\n `Unpublish ${spec} from ${registryUrl}? [y/N] `,\n );\n if (!confirmed) {\n console.log(\"Aborted.\");\n process.exit(0);\n }\n }\n\n if (args.debug) {\n console.log(\n \">>> command\",\n `npm unpublish ${spec} --registry ${registryUrl} --force ${args.forwardedArgs.join(\" \")}`,\n );\n }\n\n console.log(`Unpublishing ${spec} from ${registryUrl}...`);\n try {\n const result = await npmUnpublish({\n registryUrl,\n cwd: projectPath,\n spec,\n args: args.forwardedArgs,\n });\n if (result.stdout) {\n console.log(result.stdout);\n }\n process.exit(0);\n } catch (err) {\n console.error(err instanceof Error ? err.message : String(err));\n process.exit(1);\n }\n },\n});\n\nasync function resolveSpec(\n explicit: string | undefined,\n projectPath: string,\n): Promise<string | null> {\n if (explicit) return explicit;\n try {\n const { readPackageSync } = await import(\"read-pkg\");\n const pkg = readPackageSync({ cwd: projectPath });\n if (!pkg.name) return null;\n return pkg.version ? `${pkg.name}@${pkg.version}` : pkg.name;\n } catch {\n return null;\n }\n}\n\nasync function confirm(prompt: string): Promise<boolean> {\n const rl = createInterface({ input: process.stdin, output: process.stdout });\n try {\n const answer = await rl.question(prompt);\n return /^y(es)?$/i.test(answer.trim());\n } finally {\n rl.close();\n }\n}\n","import { vetraArgs } from \"@powerhousedao/shared/clis/args\";\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 { registryLogin } from \"./registry-login.js\";\nimport { switchboard } from \"./switchboard.js\";\nimport { uninstall } from \"./uninstall.js\";\nimport { unpublish } from \"./unpublish.js\";\nimport { vetra } from \"./vetra.js\";\n\nexport const phCliCommands = {\n init,\n generate,\n vetra,\n connect,\n build,\n publish,\n unpublish,\n \"access-token\": accessToken,\n \"registry-login\": registryLogin,\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","import { yellow, bold } from \"colorette\";\n\nconst UNRECOVERABLE_DB_PATTERNS: RegExp[] = [\n /Database migration failed:/i,\n /Migration .* failed/i,\n /relation \"[^\"]+\" already exists/i,\n /column \"[^\"]+\" does not exist/i,\n /schema \"reactor\" does not exist/i,\n /Unsupported PGLite data dir/i,\n /PG_VERSION/i,\n];\n\nfunction collectMessages(err: unknown): string[] {\n const messages: string[] = [];\n let current: unknown = err;\n const seen = new Set<unknown>();\n while (current && !seen.has(current)) {\n seen.add(current);\n if (current instanceof Error) {\n messages.push(current.message);\n current = (current as Error & { cause?: unknown }).cause;\n } else {\n messages.push(String(current));\n break;\n }\n }\n return messages;\n}\n\nexport function isUnrecoverableDbError(err: unknown): boolean {\n const messages = collectMessages(err);\n return messages.some((msg) =>\n UNRECOVERABLE_DB_PATTERNS.some((re) => re.test(msg)),\n );\n}\n\nexport function printDbRecoveryHint(err: unknown): void {\n const messages = collectMessages(err);\n const offending = messages.find((msg) =>\n UNRECOVERABLE_DB_PATTERNS.some((re) => re.test(msg)),\n );\n console.error(\"\");\n console.error(\n yellow(bold(\"Switchboard hit an unrecoverable database error.\")),\n );\n if (offending) {\n console.error(yellow(` ${offending}`));\n }\n console.error(\"\");\n console.error(\n yellow(\n \"If this is a local PGlite store, you can reset it with:\",\n ),\n );\n console.error(yellow(\" ph switchboard --reset\"),);\n console.error(\n yellow(\n \"This is destructive: it wipes the local .ph/reactor-storage and .ph/read-storage directories.\",\n ),\n );\n console.error(\n yellow(\n \"For Postgres-backed deployments (PH_REACTOR_DATABASE_URL / DATABASE_URL), reset the database manually instead.\",\n ),\n );\n console.error(\"\");\n}\n","#!/usr/bin/env node\nimport {\n initCliTelemetry,\n type TelemetryClient,\n} from \"@powerhousedao/shared/clis/telemetry\";\nimport { assertNodeVersion } from \"@powerhousedao/shared/clis/utils\";\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\";\nimport {\n isUnrecoverableDbError,\n printDbRecoveryHint,\n} from \"./utils/db-error-hint.js\";\n\nlet sentryClient: TelemetryClient | undefined = undefined;\n\n// Commands whose second positional is itself a subcommand (vs. a project\n// name / file path). Keeping this explicit avoids high-cardinality tag\n// values like `subcommand:my-package` polluting Sentry.\nconst COMMANDS_WITH_SUBCOMMANDS = new Set([\"connect\", \"vetra\"]);\n\nfunction detectPackageManager(): string | undefined {\n // npm, pnpm, yarn and bun all set npm_config_user_agent like\n // \"pnpm/8.5.0 npm/? node/v20.11.1 darwin arm64\". When the user invokes\n // `ph` directly (not via dlx/exec) it's typically unset — skip the tag\n // in that case rather than mislabel.\n const ua = process.env.npm_config_user_agent;\n if (!ua) return undefined;\n return ua.split(\" \")[0]?.split(\"/\")[0] || undefined;\n}\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 sentryClient = await initCliTelemetry({\n cliName: \"ph-cli\",\n release: getVersion(),\n });\n const args = process.argv.slice(2);\n const command = args[0];\n const subcommand =\n command &&\n COMMANDS_WITH_SUBCOMMANDS.has(command) &&\n args[1] &&\n !args[1].startsWith(\"-\")\n ? args[1]\n : undefined;\n sentryClient?.attachInvocationContext({\n command,\n subcommand,\n pm: detectPackageManager(),\n argv: args,\n cwd: process.cwd(),\n });\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 restArgs = args.slice(1);\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 sentryClient?.captureCliError(error);\n if (isDebug) {\n throw error;\n }\n if (error instanceof Error) {\n console.error(error.message);\n if (isUnrecoverableDbError(error)) {\n printDbRecoveryHint(error);\n }\n process.exit(1);\n } else {\n throw error;\n }\n});\n"],"names":["version","build"],"mappings":"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","debug_id":"a2e67adb-542b-5e92-bbfc-4656437ba4d7"}
@@ -0,0 +1,30 @@
1
+
2
+ !function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="709ef284-6ac4-5626-b591-995758ee326f")}catch(e){}}();
3
+ import { generateAll } from "@powerhousedao/codegen";
4
+ import { buildTsMorphProject } from "@powerhousedao/codegen/utils";
5
+ import { extractAllDocuments, saveSpec } from "@powerhousedao/vetra/codegen";
6
+ //#region src/services/generate-all.ts
7
+ async function startGenerateAll(args, projectDir) {
8
+ const project = buildTsMorphProject(projectDir);
9
+ if (args.extract) {
10
+ const all = extractAllDocuments(project);
11
+ for (const doc of [
12
+ ...all.documentModels,
13
+ ...all.editors,
14
+ ...all.processors,
15
+ ...all.subgraphs,
16
+ ...all.apps
17
+ ]) {
18
+ const path = await saveSpec(doc, projectDir);
19
+ console.log(`Wrote ${path}`);
20
+ }
21
+ return;
22
+ }
23
+ await generateAll(project);
24
+ await project.save();
25
+ }
26
+ //#endregion
27
+ export { startGenerateAll };
28
+
29
+ //# sourceMappingURL=generate-all-WiQQo-Nz.mjs.map
30
+ //# debugId=709ef284-6ac4-5626-b591-995758ee326f
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generate-all-WiQQo-Nz.mjs","sources":["../src/services/generate-all.ts"],"sourcesContent":["import { generateAll } from \"@powerhousedao/codegen\";\nimport { buildTsMorphProject } from \"@powerhousedao/codegen/utils\";\nimport { extractAllDocuments, saveSpec } from \"@powerhousedao/vetra/codegen\";\n\nexport async function startGenerateAll(\n args: { extract?: boolean },\n projectDir: string,\n) {\n const project = buildTsMorphProject(projectDir);\n if (args.extract) {\n const all = extractAllDocuments(project);\n for (const doc of [\n ...all.documentModels,\n ...all.editors,\n ...all.processors,\n ...all.subgraphs,\n ...all.apps,\n ]) {\n const path = await saveSpec(doc, projectDir);\n console.log(`Wrote ${path}`);\n }\n return;\n }\n await generateAll(project);\n await project.save();\n}\n"],"names":[],"mappings":";;;;;;AAIA,eAAsB,iBACpB,MACA,YACA;CACA,MAAM,UAAU,oBAAoB,WAAW;AAC/C,KAAI,KAAK,SAAS;EAChB,MAAM,MAAM,oBAAoB,QAAQ;AACxC,OAAK,MAAM,OAAO;GAChB,GAAG,IAAI;GACP,GAAG,IAAI;GACP,GAAG,IAAI;GACP,GAAG,IAAI;GACP,GAAG,IAAI;GACR,EAAE;GACD,MAAM,OAAO,MAAM,SAAS,KAAK,WAAW;AAC5C,WAAQ,IAAI,SAAS,OAAO;;AAE9B;;AAEF,OAAM,YAAY,QAAQ;AAC1B,OAAM,QAAQ,MAAM","debug_id":"709ef284-6ac4-5626-b591-995758ee326f"}
@@ -1,14 +1,24 @@
1
1
 
2
- !function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="e0e6b657-1568-5237-863c-b7ee06da40ae")}catch(e){}}();
2
+ !function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="4f6a5431-463c-5901-852e-2dcbe4c02454")}catch(e){}}();
3
3
  import { dirname } from "node:path";
4
4
  import { generateAllApps, generateApp } from "@powerhousedao/codegen";
5
5
  import { buildTsMorphProject, getAppMetadata } from "@powerhousedao/codegen/utils";
6
+ import { extractAppDocuments, generateAppFromDocument, getDocument, saveSpec } from "@powerhousedao/vetra/codegen";
6
7
  //#region src/services/generate-app.ts
7
8
  async function startGenerateApp(args, projectDir) {
8
- const { name, allowedDocumentTypes = [], disableDragAndDrop, dir, all, debug } = args;
9
+ const { name, allowedDocumentTypes = [], disableDragAndDrop, document, dir, all, extract, debug } = args;
9
10
  if (debug) console.log({ args });
10
11
  const project = buildTsMorphProject(projectDir);
12
+ if (extract) {
13
+ const docs = extractAppDocuments(project);
14
+ for (const doc of docs) {
15
+ const path = await saveSpec(doc, projectDir);
16
+ console.log(`Wrote ${path}`);
17
+ }
18
+ return;
19
+ }
11
20
  if (all) await generateAllApps(project);
21
+ else if (document) await generateAppFromDocument(await getDocument(document), project);
12
22
  else if (name) await generateApp({
13
23
  appName: name,
14
24
  allowedDocumentTypes,
@@ -26,7 +36,7 @@ async function startGenerateApp(args, projectDir) {
26
36
  isDragAndDropEnabled
27
37
  }, project);
28
38
  } else {
29
- console.log("Please specify either `name`, `dir`, or `all`.");
39
+ console.log("Please specify one of `name`, `document`, `dir`, `all`, or `extract`.");
30
40
  return;
31
41
  }
32
42
  await project.save();
@@ -34,5 +44,5 @@ async function startGenerateApp(args, projectDir) {
34
44
  //#endregion
35
45
  export { startGenerateApp };
36
46
 
37
- //# sourceMappingURL=generate-app-KE0rbE-b.mjs.map
38
- //# debugId=e0e6b657-1568-5237-863c-b7ee06da40ae
47
+ //# sourceMappingURL=generate-app-DdmOt6ID.mjs.map
48
+ //# debugId=4f6a5431-463c-5901-852e-2dcbe4c02454
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generate-app-DdmOt6ID.mjs","sources":["../src/services/generate-app.ts"],"sourcesContent":["import { generateAllApps, generateApp } from \"@powerhousedao/codegen\";\nimport {\n buildTsMorphProject,\n getAppMetadata,\n} from \"@powerhousedao/codegen/utils\";\nimport {\n extractAppDocuments,\n generateAppFromDocument,\n getDocument,\n saveSpec,\n} from \"@powerhousedao/vetra/codegen\";\nimport type { AppModuleDocument } from \"@powerhousedao/vetra/document-models/app-module\";\nimport { dirname } from \"node:path\";\nimport type { GenerateAppArgs } from \"../types.js\";\n\nexport async function startGenerateApp(\n args: GenerateAppArgs,\n projectDir: string,\n) {\n const {\n name,\n allowedDocumentTypes = [],\n disableDragAndDrop,\n document,\n dir,\n all,\n extract,\n debug,\n } = args;\n if (debug) {\n console.log({ args });\n }\n const project = buildTsMorphProject(projectDir);\n if (extract) {\n const docs = extractAppDocuments(project);\n for (const doc of docs) {\n const path = await saveSpec(doc, projectDir);\n console.log(`Wrote ${path}`);\n }\n return;\n }\n if (all) {\n await generateAllApps(project);\n } else if (document) {\n const doc = (await getDocument(document)) as AppModuleDocument;\n await generateAppFromDocument(doc, project);\n } else if (name) {\n await generateApp(\n {\n appName: name,\n allowedDocumentTypes,\n isDragAndDropEnabled: !disableDragAndDrop,\n },\n project,\n );\n } else if (dir) {\n const appMetadata = getAppMetadata(project, dirname(dir));\n if (!appMetadata) {\n throw new Error(`Failed to get data for app in dir \"${dir}\"`);\n }\n const {\n name: appName,\n id: appId,\n dirName: appDirName,\n allowedDocumentTypes,\n isDragAndDropEnabled,\n } = appMetadata;\n\n await generateApp(\n {\n appName,\n appId,\n appDirName,\n allowedDocumentTypes,\n isDragAndDropEnabled,\n },\n project,\n );\n } else {\n console.log(\n \"Please specify one of `name`, `document`, `dir`, `all`, or `extract`.\",\n );\n return;\n }\n await project.save();\n}\n"],"names":[],"mappings":";;;;;;;AAeA,eAAsB,iBACpB,MACA,YACA;CACA,MAAM,EACJ,MACA,uBAAuB,EAAE,EACzB,oBACA,UACA,KACA,KACA,SACA,UACE;AACJ,KAAI,MACF,SAAQ,IAAI,EAAE,MAAM,CAAC;CAEvB,MAAM,UAAU,oBAAoB,WAAW;AAC/C,KAAI,SAAS;EACX,MAAM,OAAO,oBAAoB,QAAQ;AACzC,OAAK,MAAM,OAAO,MAAM;GACtB,MAAM,OAAO,MAAM,SAAS,KAAK,WAAW;AAC5C,WAAQ,IAAI,SAAS,OAAO;;AAE9B;;AAEF,KAAI,IACF,OAAM,gBAAgB,QAAQ;UACrB,SAET,OAAM,wBADO,MAAM,YAAY,SAAS,EACL,QAAQ;UAClC,KACT,OAAM,YACJ;EACE,SAAS;EACT;EACA,sBAAsB,CAAC;EACxB,EACD,QACD;UACQ,KAAK;EACd,MAAM,cAAc,eAAe,SAAS,QAAQ,IAAI,CAAC;AACzD,MAAI,CAAC,YACH,OAAM,IAAI,MAAM,sCAAsC,IAAI,GAAG;EAE/D,MAAM,EACJ,MAAM,SACN,IAAI,OACJ,SAAS,YACT,sBACA,yBACE;AAEJ,QAAM,YACJ;GACE;GACA;GACA;GACA;GACA;GACD,EACD,QACD;QACI;AACL,UAAQ,IACN,wEACD;AACD;;AAEF,OAAM,QAAQ,MAAM","debug_id":"4f6a5431-463c-5901-852e-2dcbe4c02454"}
@@ -0,0 +1,34 @@
1
+
2
+ !function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="cdd55957-3704-5299-95c0-a314c9a50621")}catch(e){}}();
3
+ import { dirname, join } from "node:path";
4
+ import { generateAllDocumentModels, generateDocumentModel, loadDocumentModel } from "@powerhousedao/codegen";
5
+ import { buildTsMorphProject } from "@powerhousedao/codegen/utils";
6
+ import { extractDocumentModelDocuments, generateDocumentModelFromDocument, getDocument, saveSpec } from "@powerhousedao/vetra/codegen";
7
+ //#region src/services/generate-document-model.ts
8
+ async function startGenerateDocumentModel(args, projectDir) {
9
+ const { document, dir, all, extract, debug } = args;
10
+ if (debug) console.log({ args });
11
+ const project = buildTsMorphProject(projectDir);
12
+ if (extract) {
13
+ const docs = extractDocumentModelDocuments(project);
14
+ for (const doc of docs) {
15
+ const path = await saveSpec(doc, projectDir);
16
+ console.log(`Wrote ${path}`);
17
+ }
18
+ return;
19
+ }
20
+ if (all) await generateAllDocumentModels(project);
21
+ else if (document) if (document.endsWith(".phd")) await generateDocumentModelFromDocument(await getDocument(document), project);
22
+ else await generateDocumentModel(await loadDocumentModel(document), project);
23
+ else if (dir) await generateDocumentModel(await loadDocumentModel(join(dir, `${dirname(dir)}.json`)), project);
24
+ else {
25
+ console.log("Please specify one of `document`, `dir`, `all`, or `extract`.");
26
+ return;
27
+ }
28
+ await project.save();
29
+ }
30
+ //#endregion
31
+ export { startGenerateDocumentModel };
32
+
33
+ //# sourceMappingURL=generate-document-model-DQ5PVeIH.mjs.map
34
+ //# debugId=cdd55957-3704-5299-95c0-a314c9a50621
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generate-document-model-DQ5PVeIH.mjs","sources":["../src/services/generate-document-model.ts"],"sourcesContent":["import {\n generateAllDocumentModels,\n generateDocumentModel,\n loadDocumentModel,\n} from \"@powerhousedao/codegen\";\nimport { buildTsMorphProject } from \"@powerhousedao/codegen/utils\";\nimport {\n extractDocumentModelDocuments,\n generateDocumentModelFromDocument,\n getDocument,\n saveSpec,\n} from \"@powerhousedao/vetra/codegen\";\nimport type { DocumentModelDocument } from \"@powerhousedao/shared/document-model\";\nimport { dirname, join } from \"node:path\";\nimport type { GenerateDocumentModelArgs } from \"../types.js\";\n\nexport async function startGenerateDocumentModel(\n args: GenerateDocumentModelArgs,\n projectDir: string,\n) {\n const { document, dir, all, extract, debug } = args;\n if (debug) {\n console.log({ args });\n }\n const project = buildTsMorphProject(projectDir);\n if (extract) {\n const docs = extractDocumentModelDocuments(project);\n for (const doc of docs) {\n const path = await saveSpec(doc, projectDir);\n console.log(`Wrote ${path}`);\n }\n return;\n }\n if (all) {\n await generateAllDocumentModels(project);\n } else if (document) {\n if (document.endsWith(\".phd\")) {\n const doc = (await getDocument(document)) as DocumentModelDocument;\n await generateDocumentModelFromDocument(doc, project);\n } else {\n const state = await loadDocumentModel(document);\n await generateDocumentModel(state, project);\n }\n } else if (dir) {\n const documentModelDirName = dirname(dir);\n const documentModelFileName = `${documentModelDirName}.json`;\n const documentModelFilePath = join(dir, documentModelFileName);\n const state = await loadDocumentModel(documentModelFilePath);\n await generateDocumentModel(state, project);\n } else {\n console.log(\n \"Please specify one of `document`, `dir`, `all`, or `extract`.\",\n );\n return;\n }\n await project.save();\n}\n"],"names":[],"mappings":";;;;;;;AAgBA,eAAsB,2BACpB,MACA,YACA;CACA,MAAM,EAAE,UAAU,KAAK,KAAK,SAAS,UAAU;AAC/C,KAAI,MACF,SAAQ,IAAI,EAAE,MAAM,CAAC;CAEvB,MAAM,UAAU,oBAAoB,WAAW;AAC/C,KAAI,SAAS;EACX,MAAM,OAAO,8BAA8B,QAAQ;AACnD,OAAK,MAAM,OAAO,MAAM;GACtB,MAAM,OAAO,MAAM,SAAS,KAAK,WAAW;AAC5C,WAAQ,IAAI,SAAS,OAAO;;AAE9B;;AAEF,KAAI,IACF,OAAM,0BAA0B,QAAQ;UAC/B,SACT,KAAI,SAAS,SAAS,OAAO,CAE3B,OAAM,kCADO,MAAM,YAAY,SAAS,EACK,QAAQ;KAGrD,OAAM,sBADQ,MAAM,kBAAkB,SAAS,EACZ,QAAQ;UAEpC,IAKT,OAAM,sBADQ,MAAM,kBADU,KAAK,KADL,GADD,QAAQ,IAAI,CACa,OACQ,CACF,EACzB,QAAQ;MACtC;AACL,UAAQ,IACN,gEACD;AACD;;AAEF,OAAM,QAAQ,MAAM","debug_id":"cdd55957-3704-5299-95c0-a314c9a50621"}
@@ -1,14 +1,24 @@
1
1
 
2
- !function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="f3610574-fc94-59bf-ae3d-ea3430b3aec9")}catch(e){}}();
2
+ !function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="79754c67-40d2-5aef-b637-10f993c259c2")}catch(e){}}();
3
3
  import { dirname } from "node:path";
4
4
  import { generateAllEditors, generateEditor } from "@powerhousedao/codegen";
5
5
  import { buildTsMorphProject, getEditorMetadata } from "@powerhousedao/codegen/utils";
6
+ import { extractEditorDocuments, generateEditorFromDocument, getDocument, saveSpec } from "@powerhousedao/vetra/codegen";
6
7
  //#region src/services/generate-editor.ts
7
8
  async function startGenerateEditor(args, projectDir) {
8
- const { name, documentType, dir, all, debug } = args;
9
+ const { name, documentType, document, dir, all, extract, debug } = args;
9
10
  if (debug) console.log({ args });
10
11
  const project = buildTsMorphProject(projectDir);
12
+ if (extract) {
13
+ const docs = extractEditorDocuments(project);
14
+ for (const doc of docs) {
15
+ const path = await saveSpec(doc, projectDir);
16
+ console.log(`Wrote ${path}`);
17
+ }
18
+ return;
19
+ }
11
20
  if (all) await generateAllEditors(project);
21
+ else if (document) await generateEditorFromDocument(await getDocument(document), project);
12
22
  else if (name) {
13
23
  if (!documentType) throw new Error("Please specify a document type for the new editor to generate.");
14
24
  await generateEditor({
@@ -26,7 +36,7 @@ async function startGenerateEditor(args, projectDir) {
26
36
  documentTypes
27
37
  }, project);
28
38
  } else {
29
- console.log("Please specify either `name`, `dir`, or `all`.");
39
+ console.log("Please specify one of `name`, `document`, `dir`, `all`, or `extract`.");
30
40
  return;
31
41
  }
32
42
  await project.save();
@@ -34,5 +44,5 @@ async function startGenerateEditor(args, projectDir) {
34
44
  //#endregion
35
45
  export { startGenerateEditor };
36
46
 
37
- //# sourceMappingURL=generate-editor-DmSzWm3W.mjs.map
38
- //# debugId=f3610574-fc94-59bf-ae3d-ea3430b3aec9
47
+ //# sourceMappingURL=generate-editor-DtzVAs6x.mjs.map
48
+ //# debugId=79754c67-40d2-5aef-b637-10f993c259c2
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generate-editor-DtzVAs6x.mjs","sources":["../src/services/generate-editor.ts"],"sourcesContent":["import { generateAllEditors, generateEditor } from \"@powerhousedao/codegen\";\nimport {\n buildTsMorphProject,\n getEditorMetadata,\n} from \"@powerhousedao/codegen/utils\";\nimport {\n extractEditorDocuments,\n generateEditorFromDocument,\n getDocument,\n saveSpec,\n} from \"@powerhousedao/vetra/codegen\";\nimport type { DocumentEditorDocument } from \"@powerhousedao/vetra/document-models/document-editor\";\nimport { dirname } from \"node:path\";\nimport type { GenerateEditorArgs } from \"../types.js\";\n\nexport async function startGenerateEditor(\n args: GenerateEditorArgs,\n projectDir: string,\n) {\n const { name, documentType, document, dir, all, extract, debug } = args;\n if (debug) {\n console.log({ args });\n }\n const project = buildTsMorphProject(projectDir);\n if (extract) {\n const docs = extractEditorDocuments(project);\n for (const doc of docs) {\n const path = await saveSpec(doc, projectDir);\n console.log(`Wrote ${path}`);\n }\n return;\n }\n if (all) {\n await generateAllEditors(project);\n } else if (document) {\n const doc = (await getDocument(document)) as DocumentEditorDocument;\n await generateEditorFromDocument(doc, project);\n } else if (name) {\n if (!documentType) {\n throw new Error(\n \"Please specify a document type for the new editor to generate.\",\n );\n }\n await generateEditor(\n { editorName: name, documentTypes: [documentType] },\n project,\n );\n } else if (dir) {\n const editorArgs = getEditorMetadata(project, dirname(dir));\n if (!editorArgs) {\n throw new Error(`Failed to get data for editor in dir \"${dir}\"`);\n }\n const {\n name: editorName,\n id: editorId,\n dirName: editorDirName,\n documentTypes,\n } = editorArgs;\n await generateEditor(\n {\n editorName,\n editorId,\n editorDirName,\n documentTypes,\n },\n project,\n );\n } else {\n console.log(\n \"Please specify one of `name`, `document`, `dir`, `all`, or `extract`.\",\n );\n return;\n }\n await project.save();\n}\n"],"names":[],"mappings":";;;;;;;AAeA,eAAsB,oBACpB,MACA,YACA;CACA,MAAM,EAAE,MAAM,cAAc,UAAU,KAAK,KAAK,SAAS,UAAU;AACnE,KAAI,MACF,SAAQ,IAAI,EAAE,MAAM,CAAC;CAEvB,MAAM,UAAU,oBAAoB,WAAW;AAC/C,KAAI,SAAS;EACX,MAAM,OAAO,uBAAuB,QAAQ;AAC5C,OAAK,MAAM,OAAO,MAAM;GACtB,MAAM,OAAO,MAAM,SAAS,KAAK,WAAW;AAC5C,WAAQ,IAAI,SAAS,OAAO;;AAE9B;;AAEF,KAAI,IACF,OAAM,mBAAmB,QAAQ;UACxB,SAET,OAAM,2BADO,MAAM,YAAY,SAAS,EACF,QAAQ;UACrC,MAAM;AACf,MAAI,CAAC,aACH,OAAM,IAAI,MACR,iEACD;AAEH,QAAM,eACJ;GAAE,YAAY;GAAM,eAAe,CAAC,aAAa;GAAE,EACnD,QACD;YACQ,KAAK;EACd,MAAM,aAAa,kBAAkB,SAAS,QAAQ,IAAI,CAAC;AAC3D,MAAI,CAAC,WACH,OAAM,IAAI,MAAM,yCAAyC,IAAI,GAAG;EAElE,MAAM,EACJ,MAAM,YACN,IAAI,UACJ,SAAS,eACT,kBACE;AACJ,QAAM,eACJ;GACE;GACA;GACA;GACA;GACD,EACD,QACD;QACI;AACL,UAAQ,IACN,wEACD;AACD;;AAEF,OAAM,QAAQ,MAAM","debug_id":"79754c67-40d2-5aef-b637-10f993c259c2"}
@@ -1,14 +1,24 @@
1
1
 
2
- !function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="75666556-a149-5fb2-b7ad-93df8d302b27")}catch(e){}}();
2
+ !function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="b28d8f47-ef48-5bf9-bd2e-d0f13fa5e0e4")}catch(e){}}();
3
3
  import { dirname } from "node:path";
4
4
  import { detectFeatures, generateAllProcessors, generateProcessor, syncFeatureDependencies } from "@powerhousedao/codegen";
5
5
  import { buildTsMorphProject, getProcessorMetadata } from "@powerhousedao/codegen/utils";
6
+ import { extractProcessorDocuments, generateProcessorFromDocument, getDocument, saveSpec } from "@powerhousedao/vetra/codegen";
6
7
  //#region src/services/generate-processor.ts
7
8
  async function startGenerateProcessor(args, projectDir) {
8
- const { name: processorName, type: processorType, apps: processorApps, documentTypes, dir, all, debug } = args;
9
+ const { name: processorName, type: processorType, apps: processorApps, documentTypes, document, dir, all, extract, debug } = args;
9
10
  if (debug) console.log({ args });
10
11
  const project = buildTsMorphProject(projectDir);
12
+ if (extract) {
13
+ const docs = extractProcessorDocuments(project);
14
+ for (const doc of docs) {
15
+ const path = await saveSpec(doc, projectDir);
16
+ console.log(`Wrote ${path}`);
17
+ }
18
+ return;
19
+ }
11
20
  if (all) await generateAllProcessors(project);
21
+ else if (document) await generateProcessorFromDocument(await getDocument(document), project);
12
22
  else if (processorName) await generateProcessor({
13
23
  processorName,
14
24
  processorApps,
@@ -17,7 +27,7 @@ async function startGenerateProcessor(args, projectDir) {
17
27
  }, project);
18
28
  else if (dir) await generateProcessor(getProcessorMetadata(project, dirname(dir)), project);
19
29
  else {
20
- console.log("Please specify either `name`, `dir`, or `all`.");
30
+ console.log("Please specify one of `name`, `document`, `dir`, `all`, or `extract`.");
21
31
  return;
22
32
  }
23
33
  await project.save();
@@ -26,5 +36,5 @@ async function startGenerateProcessor(args, projectDir) {
26
36
  //#endregion
27
37
  export { startGenerateProcessor };
28
38
 
29
- //# sourceMappingURL=generate-processor-B-fChg4W.mjs.map
30
- //# debugId=75666556-a149-5fb2-b7ad-93df8d302b27
39
+ //# sourceMappingURL=generate-processor-FGtN6BVY.mjs.map
40
+ //# debugId=b28d8f47-ef48-5bf9-bd2e-d0f13fa5e0e4
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generate-processor-FGtN6BVY.mjs","sources":["../src/services/generate-processor.ts"],"sourcesContent":["import {\n detectFeatures,\n generateAllProcessors,\n generateProcessor,\n syncFeatureDependencies,\n} from \"@powerhousedao/codegen\";\nimport {\n buildTsMorphProject,\n getProcessorMetadata,\n} from \"@powerhousedao/codegen/utils\";\nimport {\n extractProcessorDocuments,\n generateProcessorFromDocument,\n getDocument,\n saveSpec,\n} from \"@powerhousedao/vetra/codegen\";\nimport type { ProcessorModuleDocument } from \"@powerhousedao/vetra/document-models/processor-module\";\nimport { dirname } from \"node:path\";\nimport type { GenerateProcessorArgs } from \"../types.js\";\n\nexport async function startGenerateProcessor(\n args: GenerateProcessorArgs,\n projectDir: string,\n) {\n const {\n name: processorName,\n type: processorType,\n apps: processorApps,\n documentTypes,\n document,\n dir,\n all,\n extract,\n debug,\n } = args;\n if (debug) {\n console.log({ args });\n }\n const project = buildTsMorphProject(projectDir);\n if (extract) {\n const docs = extractProcessorDocuments(project);\n for (const doc of docs) {\n const path = await saveSpec(doc, projectDir);\n console.log(`Wrote ${path}`);\n }\n return;\n }\n if (all) {\n await generateAllProcessors(project);\n } else if (document) {\n const doc = (await getDocument(document)) as ProcessorModuleDocument;\n await generateProcessorFromDocument(doc, project);\n } else if (processorName) {\n await generateProcessor(\n {\n processorName,\n processorApps,\n processorType,\n documentTypes,\n },\n project,\n );\n } else if (dir) {\n const processorDirName = dirname(dir);\n const processorArgs = getProcessorMetadata(project, processorDirName);\n await generateProcessor(processorArgs, project);\n } else {\n console.log(\n \"Please specify one of `name`, `document`, `dir`, `all`, or `extract`.\",\n );\n return;\n }\n await project.save();\n await syncFeatureDependencies(detectFeatures(projectDir), projectDir);\n}\n"],"names":[],"mappings":";;;;;;;AAoBA,eAAsB,uBACpB,MACA,YACA;CACA,MAAM,EACJ,MAAM,eACN,MAAM,eACN,MAAM,eACN,eACA,UACA,KACA,KACA,SACA,UACE;AACJ,KAAI,MACF,SAAQ,IAAI,EAAE,MAAM,CAAC;CAEvB,MAAM,UAAU,oBAAoB,WAAW;AAC/C,KAAI,SAAS;EACX,MAAM,OAAO,0BAA0B,QAAQ;AAC/C,OAAK,MAAM,OAAO,MAAM;GACtB,MAAM,OAAO,MAAM,SAAS,KAAK,WAAW;AAC5C,WAAQ,IAAI,SAAS,OAAO;;AAE9B;;AAEF,KAAI,IACF,OAAM,sBAAsB,QAAQ;UAC3B,SAET,OAAM,8BADO,MAAM,YAAY,SAAS,EACC,QAAQ;UACxC,cACT,OAAM,kBACJ;EACE;EACA;EACA;EACA;EACD,EACD,QACD;UACQ,IAGT,OAAM,kBADgB,qBAAqB,SADlB,QAAQ,IAAI,CACgC,EAC9B,QAAQ;MAC1C;AACL,UAAQ,IACN,wEACD;AACD;;AAEF,OAAM,QAAQ,MAAM;AACpB,OAAM,wBAAwB,eAAe,WAAW,EAAE,WAAW","debug_id":"b28d8f47-ef48-5bf9-bd2e-d0f13fa5e0e4"}
@@ -1,21 +1,31 @@
1
1
 
2
- !function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="c9380323-18ba-5262-a920-184315ae0180")}catch(e){}}();
2
+ !function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="5b43e7af-aa94-5748-a185-200bc7bd475a")}catch(e){}}();
3
3
  import { dirname } from "node:path";
4
4
  import { detectFeatures, generateAllSubgraphs, generateSubgraph, syncFeatureDependencies } from "@powerhousedao/codegen";
5
5
  import { buildTsMorphProject, getSubgraphMetadata } from "@powerhousedao/codegen/utils";
6
+ import { extractSubgraphDocuments, generateSubgraphFromDocument, getDocument, saveSpec } from "@powerhousedao/vetra/codegen";
6
7
  //#region src/services/generate-subgraph.ts
7
8
  async function startGenerateSubgraph(args, projectDir) {
8
- const { name, dir, all, debug } = args;
9
+ const { name, document, dir, all, extract, debug } = args;
9
10
  if (debug) console.log({ args });
10
11
  const project = buildTsMorphProject(projectDir);
12
+ if (extract) {
13
+ const docs = extractSubgraphDocuments(project);
14
+ for (const doc of docs) {
15
+ const path = await saveSpec(doc, projectDir);
16
+ console.log(`Wrote ${path}`);
17
+ }
18
+ return;
19
+ }
11
20
  if (all) await generateAllSubgraphs(project);
21
+ else if (document) await generateSubgraphFromDocument(await getDocument(document), project);
12
22
  else if (name) await generateSubgraph(name, project);
13
23
  else if (dir) {
14
24
  const { subgraphName } = getSubgraphMetadata(project, dirname(dir));
15
25
  if (!subgraphName) throw new Error(`Failed to get data for subgraph in dir "${dir}"`);
16
26
  await generateSubgraph(subgraphName, project);
17
27
  } else {
18
- console.log("Please specify either `name`, `dir`, or `all`.");
28
+ console.log("Please specify one of `name`, `document`, `dir`, `all`, or `extract`.");
19
29
  return;
20
30
  }
21
31
  await project.save();
@@ -24,5 +34,5 @@ async function startGenerateSubgraph(args, projectDir) {
24
34
  //#endregion
25
35
  export { startGenerateSubgraph };
26
36
 
27
- //# sourceMappingURL=generate-subgraph-C6dWIQzP.mjs.map
28
- //# debugId=c9380323-18ba-5262-a920-184315ae0180
37
+ //# sourceMappingURL=generate-subgraph-BrzmW_sj.mjs.map
38
+ //# debugId=5b43e7af-aa94-5748-a185-200bc7bd475a
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generate-subgraph-BrzmW_sj.mjs","sources":["../src/services/generate-subgraph.ts"],"sourcesContent":["import {\n detectFeatures,\n generateAllSubgraphs,\n generateSubgraph,\n syncFeatureDependencies,\n} from \"@powerhousedao/codegen\";\nimport {\n buildTsMorphProject,\n getSubgraphMetadata,\n} from \"@powerhousedao/codegen/utils\";\nimport {\n extractSubgraphDocuments,\n generateSubgraphFromDocument,\n getDocument,\n saveSpec,\n} from \"@powerhousedao/vetra/codegen\";\nimport type { SubgraphModuleDocument } from \"@powerhousedao/vetra/document-models/subgraph-module\";\nimport { dirname } from \"node:path\";\nimport type { GenerateSubgraphArgs } from \"../types.js\";\n\nexport async function startGenerateSubgraph(\n args: GenerateSubgraphArgs,\n projectDir: string,\n) {\n const { name, document, dir, all, extract, debug } = args;\n if (debug) {\n console.log({ args });\n }\n const project = buildTsMorphProject(projectDir);\n if (extract) {\n const docs = extractSubgraphDocuments(project);\n for (const doc of docs) {\n const path = await saveSpec(doc, projectDir);\n console.log(`Wrote ${path}`);\n }\n return;\n }\n if (all) {\n await generateAllSubgraphs(project);\n } else if (document) {\n const doc = (await getDocument(document)) as SubgraphModuleDocument;\n await generateSubgraphFromDocument(doc, project);\n } else if (name) {\n await generateSubgraph(name, project);\n } else if (dir) {\n const { subgraphName } = getSubgraphMetadata(project, dirname(dir));\n if (!subgraphName) {\n throw new Error(`Failed to get data for subgraph in dir \"${dir}\"`);\n }\n await generateSubgraph(subgraphName, project);\n } else {\n console.log(\n \"Please specify one of `name`, `document`, `dir`, `all`, or `extract`.\",\n );\n return;\n }\n await project.save();\n await syncFeatureDependencies(detectFeatures(projectDir), projectDir);\n}\n"],"names":[],"mappings":";;;;;;;AAoBA,eAAsB,sBACpB,MACA,YACA;CACA,MAAM,EAAE,MAAM,UAAU,KAAK,KAAK,SAAS,UAAU;AACrD,KAAI,MACF,SAAQ,IAAI,EAAE,MAAM,CAAC;CAEvB,MAAM,UAAU,oBAAoB,WAAW;AAC/C,KAAI,SAAS;EACX,MAAM,OAAO,yBAAyB,QAAQ;AAC9C,OAAK,MAAM,OAAO,MAAM;GACtB,MAAM,OAAO,MAAM,SAAS,KAAK,WAAW;AAC5C,WAAQ,IAAI,SAAS,OAAO;;AAE9B;;AAEF,KAAI,IACF,OAAM,qBAAqB,QAAQ;UAC1B,SAET,OAAM,6BADO,MAAM,YAAY,SAAS,EACA,QAAQ;UACvC,KACT,OAAM,iBAAiB,MAAM,QAAQ;UAC5B,KAAK;EACd,MAAM,EAAE,iBAAiB,oBAAoB,SAAS,QAAQ,IAAI,CAAC;AACnE,MAAI,CAAC,aACH,OAAM,IAAI,MAAM,2CAA2C,IAAI,GAAG;AAEpE,QAAM,iBAAiB,cAAc,QAAQ;QACxC;AACL,UAAQ,IACN,wEACD;AACD;;AAEF,OAAM,QAAQ,MAAM;AACpB,OAAM,wBAAwB,eAAe,WAAW,EAAE,WAAW","debug_id":"5b43e7af-aa94-5748-a185-200bc7bd475a"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@powerhousedao/ph-cli",
3
- "version": "6.0.0-dev.255",
3
+ "version": "6.0.0-dev.257",
4
4
  "description": "",
5
5
  "license": "AGPL-3.0-only",
6
6
  "type": "module",
@@ -36,15 +36,16 @@
36
36
  "semver": "7.7.4",
37
37
  "tsdown": "0.21.1",
38
38
  "vite": "8.0.8",
39
- "@powerhousedao/builder-tools": "6.0.0-dev.255",
40
- "@powerhousedao/codegen": "6.0.0-dev.255",
41
- "@powerhousedao/common": "6.0.0-dev.255",
42
- "@powerhousedao/reactor": "6.0.0-dev.255",
43
- "@powerhousedao/config": "6.0.0-dev.255",
44
- "@powerhousedao/shared": "6.0.0-dev.255",
45
- "@renown/sdk": "6.0.0-dev.255",
46
- "@powerhousedao/switchboard": "6.0.0-dev.255",
47
- "document-model": "6.0.0-dev.255"
39
+ "@powerhousedao/builder-tools": "6.0.0-dev.257",
40
+ "@powerhousedao/codegen": "6.0.0-dev.257",
41
+ "@powerhousedao/common": "6.0.0-dev.257",
42
+ "@powerhousedao/config": "6.0.0-dev.257",
43
+ "@powerhousedao/reactor": "6.0.0-dev.257",
44
+ "@powerhousedao/shared": "6.0.0-dev.257",
45
+ "@powerhousedao/switchboard": "6.0.0-dev.257",
46
+ "@powerhousedao/vetra": "6.0.0-dev.257",
47
+ "@renown/sdk": "6.0.0-dev.257",
48
+ "document-model": "6.0.0-dev.257"
48
49
  },
49
50
  "devDependencies": {
50
51
  "@types/node": "25.2.3",
@@ -1,15 +0,0 @@
1
-
2
- !function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="a2438c08-9f88-5904-af8b-ac3552eff7c3")}catch(e){}}();
3
- import { generateAll } from "@powerhousedao/codegen";
4
- import { buildTsMorphProject } from "@powerhousedao/codegen/utils";
5
- //#region src/services/generate-all.ts
6
- async function startGenerateAll(projectDir) {
7
- const project = buildTsMorphProject(projectDir);
8
- await generateAll(project);
9
- await project.save();
10
- }
11
- //#endregion
12
- export { startGenerateAll };
13
-
14
- //# sourceMappingURL=generate-all-Cj8zjFhN.mjs.map
15
- //# debugId=a2438c08-9f88-5904-af8b-ac3552eff7c3
@@ -1 +0,0 @@
1
- {"version":3,"file":"generate-all-Cj8zjFhN.mjs","sources":["../src/services/generate-all.ts"],"sourcesContent":["import { generateAll } from \"@powerhousedao/codegen\";\nimport { buildTsMorphProject } from \"@powerhousedao/codegen/utils\";\n\nexport async function startGenerateAll(projectDir: string) {\n const project = buildTsMorphProject(projectDir);\n await generateAll(project);\n await project.save();\n}\n"],"names":[],"mappings":";;;;;AAGA,eAAsB,iBAAiB,YAAoB;CACzD,MAAM,UAAU,oBAAoB,WAAW;AAC/C,OAAM,YAAY,QAAQ;AAC1B,OAAM,QAAQ,MAAM","debug_id":"a2438c08-9f88-5904-af8b-ac3552eff7c3"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"generate-app-KE0rbE-b.mjs","sources":["../src/services/generate-app.ts"],"sourcesContent":["import { generateAllApps, generateApp } from \"@powerhousedao/codegen\";\nimport {\n buildTsMorphProject,\n getAppMetadata,\n} from \"@powerhousedao/codegen/utils\";\nimport { dirname } from \"node:path\";\nimport type { GenerateAppArgs } from \"../types.js\";\n\nexport async function startGenerateApp(\n args: GenerateAppArgs,\n projectDir: string,\n) {\n const {\n name,\n allowedDocumentTypes = [],\n disableDragAndDrop,\n dir,\n all,\n debug,\n } = args;\n if (debug) {\n console.log({ args });\n }\n const project = buildTsMorphProject(projectDir);\n if (all) {\n await generateAllApps(project);\n } else if (name) {\n await generateApp(\n {\n appName: name,\n allowedDocumentTypes,\n isDragAndDropEnabled: !disableDragAndDrop,\n },\n project,\n );\n } else if (dir) {\n const appMetadata = getAppMetadata(project, dirname(dir));\n if (!appMetadata) {\n throw new Error(`Failed to get data for app in dir \"${dir}\"`);\n }\n const {\n name: appName,\n id: appId,\n dirName: appDirName,\n allowedDocumentTypes,\n isDragAndDropEnabled,\n } = appMetadata;\n\n await generateApp(\n {\n appName,\n appId,\n appDirName,\n allowedDocumentTypes,\n isDragAndDropEnabled,\n },\n project,\n );\n } else {\n console.log(\"Please specify either `name`, `dir`, or `all`.\");\n return;\n }\n await project.save();\n}\n"],"names":[],"mappings":";;;;;;AAQA,eAAsB,iBACpB,MACA,YACA;CACA,MAAM,EACJ,MACA,uBAAuB,EAAE,EACzB,oBACA,KACA,KACA,UACE;AACJ,KAAI,MACF,SAAQ,IAAI,EAAE,MAAM,CAAC;CAEvB,MAAM,UAAU,oBAAoB,WAAW;AAC/C,KAAI,IACF,OAAM,gBAAgB,QAAQ;UACrB,KACT,OAAM,YACJ;EACE,SAAS;EACT;EACA,sBAAsB,CAAC;EACxB,EACD,QACD;UACQ,KAAK;EACd,MAAM,cAAc,eAAe,SAAS,QAAQ,IAAI,CAAC;AACzD,MAAI,CAAC,YACH,OAAM,IAAI,MAAM,sCAAsC,IAAI,GAAG;EAE/D,MAAM,EACJ,MAAM,SACN,IAAI,OACJ,SAAS,YACT,sBACA,yBACE;AAEJ,QAAM,YACJ;GACE;GACA;GACA;GACA;GACA;GACD,EACD,QACD;QACI;AACL,UAAQ,IAAI,iDAAiD;AAC7D;;AAEF,OAAM,QAAQ,MAAM","debug_id":"e0e6b657-1568-5237-863c-b7ee06da40ae"}
@@ -1,24 +0,0 @@
1
-
2
- !function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="bdd2f811-3145-5018-8a96-767f4263e2bc")}catch(e){}}();
3
- import { dirname, join } from "node:path";
4
- import { generateAllDocumentModels, generateDocumentModel, loadDocumentModel } from "@powerhousedao/codegen";
5
- import { buildTsMorphProject } from "@powerhousedao/codegen/utils";
6
- //#region src/services/generate-document-model.ts
7
- async function startGenerateDocumentModel(args, projectDir) {
8
- const { file, dir, all, debug } = args;
9
- if (debug) console.log({ args });
10
- const project = buildTsMorphProject(projectDir);
11
- if (all) await generateAllDocumentModels(project);
12
- else if (file) await generateDocumentModel(await loadDocumentModel(file), project);
13
- else if (dir) await generateDocumentModel(await loadDocumentModel(join(dir, `${dirname(dir)}.json`)), project);
14
- else {
15
- console.log("Please specify either `file`, `dir`, or `all`.");
16
- return;
17
- }
18
- await project.save();
19
- }
20
- //#endregion
21
- export { startGenerateDocumentModel };
22
-
23
- //# sourceMappingURL=generate-document-model-Cut44i6D.mjs.map
24
- //# debugId=bdd2f811-3145-5018-8a96-767f4263e2bc
@@ -1 +0,0 @@
1
- {"version":3,"file":"generate-document-model-Cut44i6D.mjs","sources":["../src/services/generate-document-model.ts"],"sourcesContent":["import {\n generateAllDocumentModels,\n generateDocumentModel,\n loadDocumentModel,\n} from \"@powerhousedao/codegen\";\nimport { buildTsMorphProject } from \"@powerhousedao/codegen/utils\";\nimport { dirname, join } from \"node:path\";\nimport type { GenerateDocumentModelArgs } from \"../types.js\";\n\nexport async function startGenerateDocumentModel(\n args: GenerateDocumentModelArgs,\n projectDir: string,\n) {\n const { file, dir, all, debug } = args;\n if (debug) {\n console.log({ args });\n }\n const project = buildTsMorphProject(projectDir);\n if (all) {\n await generateAllDocumentModels(project);\n } else if (file) {\n const documentModelState = await loadDocumentModel(file);\n await generateDocumentModel(documentModelState, project);\n } else if (dir) {\n const documentModelDirName = dirname(dir);\n const documentModelFileName = `${documentModelDirName}.json`;\n const documentModelFilePath = join(dir, documentModelFileName);\n const documentModelState = await loadDocumentModel(documentModelFilePath);\n await generateDocumentModel(documentModelState, project);\n } else {\n console.log(\"Please specify either `file`, `dir`, or `all`.\");\n return;\n }\n await project.save();\n}\n"],"names":[],"mappings":";;;;;;AASA,eAAsB,2BACpB,MACA,YACA;CACA,MAAM,EAAE,MAAM,KAAK,KAAK,UAAU;AAClC,KAAI,MACF,SAAQ,IAAI,EAAE,MAAM,CAAC;CAEvB,MAAM,UAAU,oBAAoB,WAAW;AAC/C,KAAI,IACF,OAAM,0BAA0B,QAAQ;UAC/B,KAET,OAAM,sBADqB,MAAM,kBAAkB,KAAK,EACR,QAAQ;UAC/C,IAKT,OAAM,sBADqB,MAAM,kBADH,KAAK,KADL,GADD,QAAQ,IAAI,CACa,OACQ,CACW,EACzB,QAAQ;MACnD;AACL,UAAQ,IAAI,iDAAiD;AAC7D;;AAEF,OAAM,QAAQ,MAAM","debug_id":"bdd2f811-3145-5018-8a96-767f4263e2bc"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"generate-editor-DmSzWm3W.mjs","sources":["../src/services/generate-editor.ts"],"sourcesContent":["import { generateAllEditors, generateEditor } from \"@powerhousedao/codegen\";\nimport {\n buildTsMorphProject,\n getEditorMetadata,\n} from \"@powerhousedao/codegen/utils\";\nimport { dirname } from \"node:path\";\nimport type { GenerateEditorArgs } from \"../types.js\";\n\nexport async function startGenerateEditor(\n args: GenerateEditorArgs,\n projectDir: string,\n) {\n const { name, documentType, dir, all, debug } = args;\n if (debug) {\n console.log({ args });\n }\n const project = buildTsMorphProject(projectDir);\n if (all) {\n await generateAllEditors(project);\n } else if (name) {\n if (!documentType) {\n throw new Error(\n \"Please specify a document type for the new editor to generate.\",\n );\n }\n await generateEditor(\n { editorName: name, documentTypes: [documentType] },\n project,\n );\n } else if (dir) {\n const editorArgs = getEditorMetadata(project, dirname(dir));\n if (!editorArgs) {\n throw new Error(`Failed to get data for editor in dir \"${dir}\"`);\n }\n const {\n name: editorName,\n id: editorId,\n dirName: editorDirName,\n documentTypes,\n } = editorArgs;\n await generateEditor(\n {\n editorName,\n editorId,\n editorDirName,\n documentTypes,\n },\n project,\n );\n } else {\n console.log(\"Please specify either `name`, `dir`, or `all`.\");\n return;\n }\n await project.save();\n}\n"],"names":[],"mappings":";;;;;;AAQA,eAAsB,oBACpB,MACA,YACA;CACA,MAAM,EAAE,MAAM,cAAc,KAAK,KAAK,UAAU;AAChD,KAAI,MACF,SAAQ,IAAI,EAAE,MAAM,CAAC;CAEvB,MAAM,UAAU,oBAAoB,WAAW;AAC/C,KAAI,IACF,OAAM,mBAAmB,QAAQ;UACxB,MAAM;AACf,MAAI,CAAC,aACH,OAAM,IAAI,MACR,iEACD;AAEH,QAAM,eACJ;GAAE,YAAY;GAAM,eAAe,CAAC,aAAa;GAAE,EACnD,QACD;YACQ,KAAK;EACd,MAAM,aAAa,kBAAkB,SAAS,QAAQ,IAAI,CAAC;AAC3D,MAAI,CAAC,WACH,OAAM,IAAI,MAAM,yCAAyC,IAAI,GAAG;EAElE,MAAM,EACJ,MAAM,YACN,IAAI,UACJ,SAAS,eACT,kBACE;AACJ,QAAM,eACJ;GACE;GACA;GACA;GACA;GACD,EACD,QACD;QACI;AACL,UAAQ,IAAI,iDAAiD;AAC7D;;AAEF,OAAM,QAAQ,MAAM","debug_id":"f3610574-fc94-59bf-ae3d-ea3430b3aec9"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"generate-processor-B-fChg4W.mjs","sources":["../src/services/generate-processor.ts"],"sourcesContent":["import {\n detectFeatures,\n generateAllProcessors,\n generateProcessor,\n syncFeatureDependencies,\n} from \"@powerhousedao/codegen\";\nimport {\n buildTsMorphProject,\n getProcessorMetadata,\n} from \"@powerhousedao/codegen/utils\";\nimport { dirname } from \"node:path\";\nimport type { GenerateProcessorArgs } from \"../types.js\";\n\nexport async function startGenerateProcessor(\n args: GenerateProcessorArgs,\n projectDir: string,\n) {\n const {\n name: processorName,\n type: processorType,\n apps: processorApps,\n documentTypes,\n dir,\n all,\n debug,\n } = args;\n if (debug) {\n console.log({ args });\n }\n const project = buildTsMorphProject(projectDir);\n if (all) {\n await generateAllProcessors(project);\n } else if (processorName) {\n await generateProcessor(\n {\n processorName,\n processorApps,\n processorType,\n documentTypes,\n },\n project,\n );\n } else if (dir) {\n const processorDirName = dirname(dir);\n const processorArgs = getProcessorMetadata(project, processorDirName);\n await generateProcessor(processorArgs, project);\n } else {\n console.log(\"Please specify either `name`, `dir`, or `all`.\");\n return;\n }\n await project.save();\n await syncFeatureDependencies(detectFeatures(projectDir), projectDir);\n}\n"],"names":[],"mappings":";;;;;;AAaA,eAAsB,uBACpB,MACA,YACA;CACA,MAAM,EACJ,MAAM,eACN,MAAM,eACN,MAAM,eACN,eACA,KACA,KACA,UACE;AACJ,KAAI,MACF,SAAQ,IAAI,EAAE,MAAM,CAAC;CAEvB,MAAM,UAAU,oBAAoB,WAAW;AAC/C,KAAI,IACF,OAAM,sBAAsB,QAAQ;UAC3B,cACT,OAAM,kBACJ;EACE;EACA;EACA;EACA;EACD,EACD,QACD;UACQ,IAGT,OAAM,kBADgB,qBAAqB,SADlB,QAAQ,IAAI,CACgC,EAC9B,QAAQ;MAC1C;AACL,UAAQ,IAAI,iDAAiD;AAC7D;;AAEF,OAAM,QAAQ,MAAM;AACpB,OAAM,wBAAwB,eAAe,WAAW,EAAE,WAAW","debug_id":"75666556-a149-5fb2-b7ad-93df8d302b27"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"generate-subgraph-C6dWIQzP.mjs","sources":["../src/services/generate-subgraph.ts"],"sourcesContent":["import {\n detectFeatures,\n generateAllSubgraphs,\n generateSubgraph,\n syncFeatureDependencies,\n} from \"@powerhousedao/codegen\";\nimport {\n buildTsMorphProject,\n getSubgraphMetadata,\n} from \"@powerhousedao/codegen/utils\";\nimport { dirname } from \"node:path\";\nimport type { GenerateSubgraphArgs } from \"../types.js\";\n\nexport async function startGenerateSubgraph(\n args: GenerateSubgraphArgs,\n projectDir: string,\n) {\n const { name, dir, all, debug } = args;\n if (debug) {\n console.log({ args });\n }\n const project = buildTsMorphProject(projectDir);\n if (all) {\n await generateAllSubgraphs(project);\n } else if (name) {\n await generateSubgraph(name, project);\n } else if (dir) {\n const { subgraphName } = getSubgraphMetadata(project, dirname(dir));\n if (!subgraphName) {\n throw new Error(`Failed to get data for subgraph in dir \"${dir}\"`);\n }\n await generateSubgraph(subgraphName, project);\n } else {\n console.log(\"Please specify either `name`, `dir`, or `all`.\");\n return;\n }\n await project.save();\n await syncFeatureDependencies(detectFeatures(projectDir), projectDir);\n}\n"],"names":[],"mappings":";;;;;;AAaA,eAAsB,sBACpB,MACA,YACA;CACA,MAAM,EAAE,MAAM,KAAK,KAAK,UAAU;AAClC,KAAI,MACF,SAAQ,IAAI,EAAE,MAAM,CAAC;CAEvB,MAAM,UAAU,oBAAoB,WAAW;AAC/C,KAAI,IACF,OAAM,qBAAqB,QAAQ;UAC1B,KACT,OAAM,iBAAiB,MAAM,QAAQ;UAC5B,KAAK;EACd,MAAM,EAAE,iBAAiB,oBAAoB,SAAS,QAAQ,IAAI,CAAC;AACnE,MAAI,CAAC,aACH,OAAM,IAAI,MAAM,2CAA2C,IAAI,GAAG;AAEpE,QAAM,iBAAiB,cAAc,QAAQ;QACxC;AACL,UAAQ,IAAI,iDAAiD;AAC7D;;AAEF,OAAM,QAAQ,MAAM;AACpB,OAAM,wBAAwB,eAAe,WAAW,EAAE,WAAW","debug_id":"c9380323-18ba-5262-a920-184315ae0180"}