@powerhousedao/ph-cli 6.1.0-staging.0 → 6.1.0
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/dist/{build-vccTv_Jp.mjs → build-B5LEeRPm.mjs} +4 -4
- package/dist/build-B5LEeRPm.mjs.map +1 -0
- package/dist/build-CMgv-erS.mjs +4 -0
- package/dist/cli.mjs +11 -11
- package/dist/cli.mjs.map +1 -1
- package/dist/{connect-build-B7I7HJu0.mjs → connect-build-DA5QOP5h.mjs} +4 -4
- package/dist/{connect-build-B7I7HJu0.mjs.map → connect-build-DA5QOP5h.mjs.map} +1 -1
- package/dist/{connect-preview-CNJkhtxL.mjs → connect-preview-DQnzviwA.mjs} +4 -4
- package/dist/connect-preview-DQnzviwA.mjs.map +1 -0
- package/dist/{init-Cw_5H_Z1.mjs → init-Cu3_NRHL.mjs} +5 -4
- package/dist/init-Cu3_NRHL.mjs.map +1 -0
- package/dist/{vetra-yCsUKy_u.mjs → vetra-BgmlqLmN.mjs} +4 -4
- package/dist/vetra-BgmlqLmN.mjs.map +1 -0
- package/package.json +11 -11
- package/dist/build-CqtYNjiI.mjs +0 -4
- package/dist/build-vccTv_Jp.mjs.map +0 -1
- package/dist/connect-preview-CNJkhtxL.mjs.map +0 -1
- package/dist/init-Cw_5H_Z1.mjs.map +0 -1
- package/dist/vetra-yCsUKy_u.mjs.map +0 -1
|
@@ -1,5 +1,5 @@
|
|
|
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]="
|
|
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]="53802aa9-82a4-5f73-8876-9bf4310ea58e")}catch(e){}}();
|
|
3
3
|
import { execSync } from "node:child_process";
|
|
4
4
|
import { browserBuildConfig, nodeBuildConfig } from "@powerhousedao/shared/build-config";
|
|
5
5
|
import { join } from "node:path";
|
|
@@ -17,7 +17,7 @@ async function runBuild(args) {
|
|
|
17
17
|
outDir: join(outDir, "node")
|
|
18
18
|
});
|
|
19
19
|
const agent = (await detect())?.agent ?? "npm";
|
|
20
|
-
const tscCommand = resolveCommand(agent, "execute-local", ["tsc"]);
|
|
20
|
+
const tscCommand = resolveCommand(agent, "execute-local", ["tsc", "--build"]);
|
|
21
21
|
if (tscCommand === null) {
|
|
22
22
|
console.error("You need to have typescript installed to use the `build` command.");
|
|
23
23
|
process.exit(1);
|
|
@@ -45,5 +45,5 @@ async function runBuild(args) {
|
|
|
45
45
|
//#endregion
|
|
46
46
|
export { runBuild as t };
|
|
47
47
|
|
|
48
|
-
//# sourceMappingURL=build-
|
|
49
|
-
//# debugId=
|
|
48
|
+
//# sourceMappingURL=build-B5LEeRPm.mjs.map
|
|
49
|
+
//# debugId=53802aa9-82a4-5f73-8876-9bf4310ea58e
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"build-B5LEeRPm.mjs","sources":["../src/services/build.ts"],"sourcesContent":["import {\n browserBuildConfig,\n nodeBuildConfig,\n} from \"@powerhousedao/shared/build-config\";\nimport { execSync } from \"node:child_process\";\nimport { join } from \"node:path\";\nimport { detect, resolveCommand } from \"package-manager-detector\";\nimport { build as tsdownBuild } from \"tsdown\";\nimport type { BuildArgs } from \"../types.js\";\n\nexport async function runBuild(args: BuildArgs) {\n const { outDir } = args;\n\n await tsdownBuild({\n ...browserBuildConfig,\n outDir: join(outDir, \"browser\"),\n });\n\n await tsdownBuild({\n ...nodeBuildConfig,\n outDir: join(outDir, \"node\"),\n });\n\n const detectResult = await detect();\n const agent = detectResult?.agent ?? \"npm\";\n\n // Emit types with tsc\n const tscCommand = resolveCommand(agent, \"execute-local\", [\"tsc\", \"--build\"]);\n if (tscCommand === null) {\n console.error(\n \"You need to have typescript installed to use the `build` command.\",\n );\n process.exit(1);\n }\n console.log(\"\\n▶ Emitting types via tsc...\");\n try {\n execSync(`${tscCommand.command} ${tscCommand.args.join(\" \")}`, {\n stdio: \"inherit\",\n });\n console.log(\"✔ Types emitted to\", join(outDir, \"types\"));\n } catch {\n console.warn(\n \"✘ tsc reported errors above; declarations were still written. Fix the errors to keep types accurate.\",\n );\n }\n\n const executeLocalCommand = resolveCommand(agent, \"execute-local\", [\n \"tailwindcss\",\n \"-i\",\n \"./style.css\",\n \"-o\",\n \"./dist/style.css\",\n ]);\n if (executeLocalCommand === null) {\n console.error(\n \"You need to have tailwindcss installed to use the `build` command.\",\n );\n process.exit(1);\n }\n execSync(\n `${executeLocalCommand.command} ${executeLocalCommand.args.join(\" \")}`,\n );\n}\n"],"names":["tsdownBuild"],"mappings":";;;;;;;;AAUA,eAAsB,SAAS,MAAiB;CAC9C,MAAM,EAAE,WAAW;AAEnB,OAAMA,MAAY;EAChB,GAAG;EACH,QAAQ,KAAK,QAAQ,UAAU;EAChC,CAAC;AAEF,OAAMA,MAAY;EAChB,GAAG;EACH,QAAQ,KAAK,QAAQ,OAAO;EAC7B,CAAC;CAGF,MAAM,SADe,MAAM,QAAQ,GACP,SAAS;CAGrC,MAAM,aAAa,eAAe,OAAO,iBAAiB,CAAC,OAAO,UAAU,CAAC;AAC7E,KAAI,eAAe,MAAM;AACvB,UAAQ,MACN,oEACD;AACD,UAAQ,KAAK,EAAE;;AAEjB,SAAQ,IAAI,gCAAgC;AAC5C,KAAI;AACF,WAAS,GAAG,WAAW,QAAQ,GAAG,WAAW,KAAK,KAAK,IAAI,IAAI,EAC7D,OAAO,WACR,CAAC;AACF,UAAQ,IAAI,sBAAsB,KAAK,QAAQ,QAAQ,CAAC;SAClD;AACN,UAAQ,KACN,uGACD;;CAGH,MAAM,sBAAsB,eAAe,OAAO,iBAAiB;EACjE;EACA;EACA;EACA;EACA;EACD,CAAC;AACF,KAAI,wBAAwB,MAAM;AAChC,UAAQ,MACN,qEACD;AACD,UAAQ,KAAK,EAAE;;AAEjB,UACE,GAAG,oBAAoB,QAAQ,GAAG,oBAAoB,KAAK,KAAK,IAAI,GACrE","debug_id":"53802aa9-82a4-5f73-8876-9bf4310ea58e"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { t as runBuild } from "./build-B5LEeRPm.mjs";
|
|
2
|
+
export { runBuild };
|
|
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]="03c7575f-6904-5af5-be74-46221d2b3a6f")}catch(e){}}();
|
|
4
|
+
//# debugId=03c7575f-6904-5af5-be74-46221d2b3a6f
|
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]="
|
|
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]="d5bdee00-0bc7-551b-9930-8d2d40d45723")}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.1.0
|
|
18
|
+
return "6.1.0";
|
|
19
19
|
}
|
|
20
20
|
//#endregion
|
|
21
21
|
//#region src/utils/constants.ts
|
|
@@ -105,7 +105,7 @@ const build$1 = command({
|
|
|
105
105
|
handler: async (args) => {
|
|
106
106
|
if (args.debug) console.log(args);
|
|
107
107
|
try {
|
|
108
|
-
const { runBuild } = await import("./build-
|
|
108
|
+
const { runBuild } = await import("./build-CMgv-erS.mjs");
|
|
109
109
|
await runBuild(args);
|
|
110
110
|
} catch (error) {
|
|
111
111
|
console.error(error);
|
|
@@ -144,7 +144,7 @@ external packages included
|
|
|
144
144
|
args: connectBuildArgs,
|
|
145
145
|
handler: async (args) => {
|
|
146
146
|
if (args.debug) console.log(args);
|
|
147
|
-
const { runConnectBuild } = await import("./connect-build-
|
|
147
|
+
const { runConnectBuild } = await import("./connect-build-DA5QOP5h.mjs");
|
|
148
148
|
await runConnectBuild(args);
|
|
149
149
|
process.exit(0);
|
|
150
150
|
}
|
|
@@ -157,7 +157,7 @@ NOTE: You must run \`ph connect build\` first
|
|
|
157
157
|
args: connectPreviewArgs,
|
|
158
158
|
handler: async (args) => {
|
|
159
159
|
if (args.debug) console.log(args);
|
|
160
|
-
const { runConnectPreview } = await import("./connect-preview-
|
|
160
|
+
const { runConnectPreview } = await import("./connect-preview-DQnzviwA.mjs");
|
|
161
161
|
await runConnectPreview(args);
|
|
162
162
|
}
|
|
163
163
|
})
|
|
@@ -475,7 +475,7 @@ const init = command({
|
|
|
475
475
|
args: initArgs,
|
|
476
476
|
handler: async (args) => {
|
|
477
477
|
if (args.debug) console.log({ args });
|
|
478
|
-
const { startInit } = await import("./init-
|
|
478
|
+
const { startInit } = await import("./init-Cu3_NRHL.mjs");
|
|
479
479
|
await startInit(args);
|
|
480
480
|
process.exit(0);
|
|
481
481
|
}
|
|
@@ -629,7 +629,7 @@ This command:
|
|
|
629
629
|
phConfig.packages.forEach((pkg) => {
|
|
630
630
|
console.log(pkg.packageName);
|
|
631
631
|
});
|
|
632
|
-
} catch (
|
|
632
|
+
} catch (_e) {
|
|
633
633
|
console.log("No packages found in the project");
|
|
634
634
|
}
|
|
635
635
|
process.exit(0);
|
|
@@ -834,7 +834,7 @@ This command:
|
|
|
834
834
|
process.exit(1);
|
|
835
835
|
}
|
|
836
836
|
const enquirer = await import("enquirer");
|
|
837
|
-
let confirmed
|
|
837
|
+
let confirmed;
|
|
838
838
|
try {
|
|
839
839
|
confirmed = (await enquirer.default.prompt({
|
|
840
840
|
type: "confirm",
|
|
@@ -1122,7 +1122,7 @@ This command:
|
|
|
1122
1122
|
args: vetraArgs,
|
|
1123
1123
|
handler: async (args) => {
|
|
1124
1124
|
if (args.debug) console.log(args);
|
|
1125
|
-
const { startVetra } = await import("./vetra-
|
|
1125
|
+
const { startVetra } = await import("./vetra-BgmlqLmN.mjs");
|
|
1126
1126
|
await startVetra(args);
|
|
1127
1127
|
}
|
|
1128
1128
|
}),
|
|
@@ -1168,7 +1168,7 @@ function collectMessages(err) {
|
|
|
1168
1168
|
messages.push(current.message);
|
|
1169
1169
|
current = current.cause;
|
|
1170
1170
|
} else {
|
|
1171
|
-
messages.push(
|
|
1171
|
+
messages.push(typeof current === "string" ? current : JSON.stringify(current));
|
|
1172
1172
|
break;
|
|
1173
1173
|
}
|
|
1174
1174
|
}
|
|
@@ -1244,4 +1244,4 @@ await main().catch(async (error) => {
|
|
|
1244
1244
|
export {};
|
|
1245
1245
|
|
|
1246
1246
|
//# sourceMappingURL=cli.mjs.map
|
|
1247
|
-
//# debugId=
|
|
1247
|
+
//# debugId=d5bdee00-0bc7-551b-9930-8d2d40d45723
|
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, 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":";;;;;;;;;;;;;;;;AAGA,SAAgB,aAAa;AACa,QAAA;;;;ACJ1C,MAAa,qBACX;ACKF,MAAa,YAAY,YAAY;CACnC,MAAM;CACN,aAAa;CACb,SAJc,YAAY;CAK1B,MAAM;CACP,CAAC;;;ACPF,MAAa,cAAc,QAAQ;CACjC,MAAM;CACN,aAAa;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA+Cb,MAAM;CACN,SAAS,OAAO,SAAS;AACvB,MAAI,KAAK,MACP,SAAQ,IAAI,KAAK;EAGnB,MAAM,EAAE,qBAAqB,aAAa,iBACxC,MAAM,OAAO;EACf,MAAM,EAAE,cAAc,MAAM,OAAO;EACnC,MAAM,SAAS,MAAM,WAAW;EAEhC,IAAI,YAAY;AAChB,MAAI,KAAK,OAAQ,aAAY,YAAY,KAAK,OAAO;EAErD,MAAM,SAAS,MAAM,oBAAoB,QAAQ;GAC/C;GACA,KAAK,KAAK;GACX,CAAC;AAGF,UAAQ,MAAM,YAAY,OAAO,MAAM;AACvC,UAAQ,MAAM,gBAAgB,OAAO,UAAU;AAC/C,UAAQ,MAAM,qBAAqB,aAAa,UAAU,GAAG;AAC7D,UAAQ,MAAM,GAAG;AAEjB,UAAQ,IAAI,OAAO,MAAM;AACzB,UAAQ,KAAK,EAAE;;CAElB,CAAC;;;AC9EF,MAAaC,UAAQ,QAAQ;CAC3B,MAAM;CACN,MAAM;CACN,SAAS,OAAO,SAAS;AACvB,MAAI,KAAK,MACP,SAAQ,IAAI,KAAK;AAEnB,MAAI;GACF,MAAM,EAAE,aAAa,MAAM,OAAO;AAClC,SAAM,SAAS,KAAK;WACb,OAAO;AACd,WAAQ,MAAM,MAAM;AACpB,WAAQ,KAAK,EAAE;;;CAGpB,CAAC;AC2CF,MAAa,UAAU,YAAY;CACjC,MAAM;CACN,aAAa;CACb,MAAM;EACJ,QA3DkB,QAAQ;GAC5B,MAAM;GACN,aAAa;;;;;;;;;;GAUb,MAAM;GACN,SAAS,OAAO,SAAS;AACvB,QAAI,KAAK,MACP,SAAQ,IAAI,KAAK;IAEnB,MAAM,EAAE,qBAAqB,MAAM,OAAO;AAC1C,UAAM,iBAAiB,KAAK;;GAE/B,CAAC;EAwCE,OAtCiB,QAAQ;GAC3B,MAAM;GACN,aAAa;;;GAGb,MAAM;GACN,SAAS,OAAO,SAAS;AACvB,QAAI,KAAK,MACP,SAAQ,IAAI,KAAK;IAGnB,MAAM,EAAE,oBAAoB,MAAM,OAAO;AACzC,UAAM,gBAAgB,KAAK;AAC3B,YAAQ,KAAK,EAAE;;GAElB,CAAC;EAwBE,SAtBmB,QAAQ;GAC7B,MAAM;GACN,aAAa;;;GAGb,MAAM;GACN,SAAS,OAAO,SAAS;AACvB,QAAI,KAAK,MACP,SAAQ,IAAI,KAAK;IAEnB,MAAM,EAAE,sBACN,MAAM,OAAO;AACf,UAAM,kBAAkB,KAAK;;GAEhC,CAAC;EASC;CACF,CAAC;;;ACnEF,MAAa,iBAAiB,QAAQ;CACpC,MAAM;CACN,aAAa;CACb,MAAM,EACJ,SAAS,KAAK;EACZ,MAAM;EACN,OAAO;EACP,aACE;EACH,CAAC,EACH;CACD,SAAS,OAAO,SAAS;EACvB,MAAM,EAAE,qBAAqB,MAAM,OAAO;AAC1C,QAAM,iBAAiB,MAAM,QAAQ,KAAK,CAAC;AAC3C,UAAQ,KAAK,EAAE;;CAElB,CAAC;;;ACLF,MAAa,iBAAiB,QAAQ;CACpC,MAAM;CACN,aAAa;CACb,MAAM;EACJ,MAAM,OAAO;GACX,MAAM,SAAS,OAAO;GACtB,MAAM;GACN,OAAO;GACP,aAAa;GACd,CAAC;EACF,sBAAsB,YAAY;GAChC,MAAM,SAAS,MAAM,OAAO,CAAC;GAC7B,MAAM;GACN,OAAO;GACP,aAAa;GACd,CAAC;EACF,UAAU,OAAO;GACf,MAAM,SAAS,KAAK;GACpB,MAAM;GACN,OAAO;GACP,aACE;GACH,CAAC;EACF,KAAK,OAAO;GACV,MAAM,SAAS,UAAU;GACzB,MAAM;GACN,aAAa;GACd,CAAC;EACF,oBAAoB,KAAK;GACvB,MAAM;GACN,MAAM;GACN,aAAa;GACb,oBAAoB;GACpB,4BAA4B;GAC7B,CAAC;EACF,KAAK,KAAK;GACR,MAAM;GACN,OAAO;GACP,aAAa;GACd,CAAC;EACF,SAAS,KAAK;GACZ,MAAM;GACN,OAAO;GACP,aACE;GACH,CAAC;EACF,GAAG;EACJ;CACD,SAAS,OAAO,SAAS;EACvB,MAAM,EAAE,qBAAqB,MAAM,OAAO;AAC1C,QAAM,iBAAiB,MAAM,QAAQ,KAAK,CAAC;AAC3C,UAAQ,KAAK,EAAE;;CAElB,CAAC;;;AC/DF,MAAa,2BAA2B,QAAQ;CAC9C,MAAM;CACN,SAAS,CAAC,MAAM;CAChB,aAAa;CACb,MAAM;EACJ,UAAU,OAAO;GACf,MAAM,SAAS,KAAK;GACpB,MAAM;GACN,OAAO;GACP,aACE;GACH,CAAC;EACF,KAAK,OAAO;GACV,MAAM,SAAS,UAAU;GACzB,MAAM;GACN,aACE;GACH,CAAC;EACF,KAAK,KAAK;GACR,MAAM;GACN,OAAO;GACP,aACE;GACH,CAAC;EACF,SAAS,KAAK;GACZ,MAAM;GACN,OAAO;GACP,aACE;GACH,CAAC;EACF,GAAG;EACJ;CACD,SAAS,OAAO,SAAS;EACvB,MAAM,EAAE,+BACN,MAAM,OAAO;AACf,QAAM,2BAA2B,MAAM,QAAQ,KAAK,CAAC;AACrD,UAAQ,KAAK,EAAE;;CAElB,CAAC;;;ACrCF,MAAa,oBAAoB,QAAQ;CACvC,MAAM;CACN,aAAa;CACb,MAAM;EACJ,MAAM,OAAO;GACX,MAAM,SAAS,OAAO;GACtB,MAAM;GACN,OAAO;GACP,aAAa;GACd,CAAC;EACF,cAAc,OAAO;GACnB,MAAM,SAAS,OAAO;GACtB,MAAM;GACN,OAAO;GACP,aAAa;GACd,CAAC;EACF,UAAU,OAAO;GACf,MAAM,SAAS,KAAK;GACpB,MAAM;GACN,OAAO;GACP,aACE;GACH,CAAC;EACF,KAAK,OAAO;GACV,MAAM,SAAS,UAAU;GACzB,MAAM;GACN,aAAa;GACd,CAAC;EACF,KAAK,KAAK;GACR,MAAM;GACN,OAAO;GACP,aAAa;GACd,CAAC;EACF,SAAS,KAAK;GACZ,MAAM;GACN,OAAO;GACP,aACE;GACH,CAAC;EACF,GAAG;EACJ;CACD,SAAS,OAAO,SAAS;EACvB,MAAM,EAAE,wBACN,MAAM,OAAO;AACf,QAAM,oBAAoB,MAAM,QAAQ,KAAK,CAAC;AAC9C,UAAQ,KAAK,EAAE;;CAElB,CAAC;;;AC/CF,MAAa,2BAA2B,QAAQ;CAC9C,MAAM;CACN,aAAa;CACb,MAAM;EACJ,eAAe,OAAO;GACpB,MAAM;GACN,MAAM;GACN,OAAO;GACP,aAAa;GACd,CAAC;EACF,YAAY,OAAO;GACjB,MAAM,SAAS,OAAO;GACtB,MAAM;GACN,aAAa;GACd,CAAC;EACF,GAAG;EACJ;CACD,SAAS,OAAO,EAAE,eAAe,iBAAiB;EAChD,MAAM,EAAE,qBAAqB,MAAM,OAAO;AAC1C,QAAM,iBAAiB;GACrB,eAAe,KAAK,KAAK,QAAQ,KAAK,EAAE,cAAc;GACtD,YAAY,aAAa,KAAK,KAAK,QAAQ,KAAK,EAAE,WAAW,GAAG,KAAA;GACjE,CAAC;AACF,UAAQ,KAAK,EAAE;;CAElB,CAAC;ACSF,MAAa,uBAAuB,QAAQ;CAC1C,MAAM;CACN,aAAa;CACb,MAAM;EACJ,MAAM,OAAO;GACX,MAAM,SAAS,OAAO;GACtB,MAAM;GACN,OAAO;GACP,aAAa;GACd,CAAC;EACF,MAAM,OAAO;GACX,MAAM,MAAM,CAAC,aAAa,eAAe,CAAU;GACnD,MAAM;GACN,aAAa;GACb,oBAAoB;GACpB,4BAA4B;GAC7B,CAAC;EACF,eAAe,YAAY;GACzB,MAAM,MAAM,OAAO;GACnB,MAAM;GACN,OAAO;GACP,aAAa;GACb,oBAAoB,EAAE;GACtB,4BAA4B;GAC7B,CAAC;EACF,MAAM,YAAY;GAChB,MAAM;GACN,MAlDkE,EACtE,KAAK,eAAe;AAClB,QAAI,cAAc,WAAW,EAC3B,OAAM,IAAI,MACR,mFACD;AAEH,QAAI,cAAc,SAAS,EACzB,OAAM,IAAI,MACR,yFACD;IAEH,MAAM,UAAU,IAAI,IAAI,eAAe;AACvC,QACE,CAAC,cAAc,OAAO,MAAM,QAAQ,IAAI,EAA+B,CAAC,CAExE,OAAM,IAAI,MACR,6DACD;AAEH,WAAO,QAAQ,QAAQ,cAA+C;MAEzE;GA6BK,aACE;GACF,oBAAoB,CAAC,eAAwB,UAAmB;GAChE,4BAA4B;GAC7B,CAAC;EACF,UAAU,OAAO;GACf,MAAM,SAAS,KAAK;GACpB,MAAM;GACN,OAAO;GACP,aACE;GACH,CAAC;EACF,KAAK,OAAO;GACV,MAAM,SAAS,UAAU;GACzB,MAAM;GACN,aACE;GACH,CAAC;EACF,KAAK,KAAK;GACR,MAAM;GACN,OAAO;GACP,aAAa;GACd,CAAC;EACF,SAAS,KAAK;GACZ,MAAM;GACN,OAAO;GACP,aACE;GACH,CAAC;EACF,GAAG;EACJ;CACD,SAAS,OAAO,SAAS;EACvB,MAAM,EAAE,2BACN,MAAM,OAAO;AACf,QAAM,uBAAuB,MAAM,QAAQ,KAAK,CAAC;AACjD,UAAQ,KAAK,EAAE;;CAElB,CAAC;;;ACnGF,MAAa,sBAAsB,QAAQ;CACzC,MAAM;CACN,aAAa;CACb,MAAM;EACJ,MAAM,OAAO;GACX,MAAM,SAAS,OAAO;GACtB,MAAM;GACN,OAAO;GACP,aAAa;GACd,CAAC;EACF,UAAU,OAAO;GACf,MAAM,SAAS,KAAK;GACpB,MAAM;GACN,OAAO;GACP,aACE;GACH,CAAC;EACF,KAAK,OAAO;GACV,MAAM,SAAS,UAAU;GACzB,MAAM;GACN,aACE;GACH,CAAC;EACF,KAAK,KAAK;GACR,MAAM;GACN,OAAO;GACP,aAAa;GACd,CAAC;EACF,SAAS,KAAK;GACZ,MAAM;GACN,OAAO;GACP,aACE;GACH,CAAC;EACF,GAAG;EACJ;CACD,SAAS,OAAO,SAAS;EACvB,MAAM,EAAE,0BACN,MAAM,OAAO;AACf,QAAM,sBAAsB,MAAM,QAAQ,KAAK,CAAC;AAChD,UAAQ,KAAK,EAAE;;CAElB,CAAC;;;ACrCF,MAAa,WAAW,YAAY;CAClC,MAAM;CACN,aAAa;CACb,MAAM;EACJ,KAAK;EACL,kBAAkB;EAClB,QAAQ;EACR,KAAK;EACL,WAAW;EACX,UAAU;EACV,kBAAkB;EACnB;CACF,CAAC;;;AClBF,MAAa,OAAO,QAAQ;CAC1B,MAAM;CACN,aAAa;CACb,MAAM;CACN,SAAS,OAAO,SAAS;AACvB,MAAI,KAAK,MACP,SAAQ,IAAI,EAAE,MAAM,CAAC;EAEvB,MAAM,EAAE,cAAc,MAAM,OAAO;AACnC,QAAM,UAAU,KAAK;AACrB,UAAQ,KAAK,EAAE;;CAElB,CAAC;;;ACZF,MAAa,UAAU,QAAQ;CAC7B,MAAM;CACN,aAAa;;;;;;;;;;CAUb,SAAS,CAAC,KAAK;CACf,MAAM;CACN,SAAS,OAAO,SAAS;AACvB,MAAI,KAAK,MACP,SAAQ,IAAI,KAAK;EAEnB,MAAM,EAAE,iBAAiB,MAAM,OAAO;AACtC,eAAa,KAAK;AAClB,UAAQ,KAAK,EAAE;;CAElB,CAAC;;;ACrBF,MAAa,UAAU,QAAQ;CAC7B,MAAM;CACN,SAAS,CAAC,OAAO,IAAI;CACrB,aAAa;;;;;;;;;;;;;CAab,MAAM;CACN,SAAS,OAAO,SAAS;AACvB,MAAI,KAAK,MACP,SAAQ,IAAI,KAAK;EAGnB,MAAM,EAAE,0BAA0B,iCAChC,MAAM,OAAO;EAEf,MAAM,EACJ,aACA,kBACA,mBACA,gBACA,aACE,MAAM,yBAAyB,KAAK;AAExC,MAAI,CAAC,YACH,OAAM,IAAI,MAAM,+CAA+C;EAGjE,MAAM,EAAE,uBACN,MAAM,OAAO;EACf,MAAM,cAAc,mBAAmB;GACrC,UAAU,KAAK;GACf;GACD,CAAC;AAEF,MAAI,KAAK,MACP,SAAQ,IAAI,mBAAmB,YAAY;EAG7C,MAAM,2BAA2B,MAAM,6BACrC,KAAK,cACL,YACD;AAED,MAAI,KAAK,OAAO;AACd,WAAQ,IAAI,0BAA0B,yBAAyB;AAC/D,WAAQ,IAAI,qBAAqB;IAC/B;IACA;IACA;IACA;IACD,CAAC;;AAGJ,MAAI,KAAK,OAAO;AACd,OAAI,yBAAyB,WAAW,EACtC,OAAM,IAAI,MACR,kFACD;AAEH,OAAI;IACF,MAAM,QAAQ,yBAAyB,KAAK,MAC1C,EAAE,UAAU,GAAG,EAAE,KAAK,GAAG,EAAE,YAAY,EAAE,KAC1C;IAOD,MAAM,yBAAS,IAAI,KAAa;AAChC,SAAK,MAAM,OAAO,yBAChB,KAAI,IAAI,KAAK,WAAW,IAAI,EAAE;KAC5B,MAAM,QAAQ,IAAI,KAAK,MAAM,IAAI,CAAC;AAClC,YAAO,IAAI,MAAM;;IAGrB,MAAM,oBAAoB,MAAM,KAAK,OAAO,CAAC,KAC1C,UAAU,KAAK,MAAM,YAAY,cACnC;IAED,MAAM,oBACJ,mBAAmB,SAAS,CAAC,iCAAiC,GAAG,EAAE;IAErE,MAAM,iBACJ,mBAAmB,UAAU,KAAK,WAAW,SAAS,IAClD,CAAC,iBAAiB,KAAK,WAAW,KAAK,IAAI,GAAG,GAC9C,EAAE;IAER,MAAM,EAAE,mBAAmB,MAAM,OAAO;IACxC,MAAM,WAAW,eAAe,gBAAgB,OAAO;KACrD,GAAG;KACH,GAAG;KACH,GAAG;KACH,GAAG;KACJ,CAAC;AACF,QAAI,CAAC,SACH,OAAM,IAAI,MACR,0DAA0D,eAAe,IAC1E;IAEH,MAAM,iBAAiB,GAAG,SAAS,QAAQ,GAAG,SAAS,KAAK,KAAK,IAAI;AACrE,QAAI,kBAAkB,SAAS,EAC7B,SAAQ,IACN,uCAAuC,MAAM,KAAK,OAAO,CAAC,KAAK,KAAK,CAAC,KAAK,YAAY,MACvF;QAED,SAAQ,IAAI,gCAAgC;AAE9C,YAAQ,IAAI,KAAK,iBAAiB;AAClC,aAAS,gBAAgB;KACvB,OAAO;KACP,KAAK;KACN,CAAC;AACF,YAAQ,IAAI,uCAAuC;YAC5C,OAAO;AACd,YAAQ,MAAM,mCAAmC;AACjD,UAAM;;;EAIV,MAAM,EAAE,kBAAkB,qBAAqB,MAAM,OAAO;AAE5D,MAAI;AACF,WAAQ,IAAI,wCAAwC;AACpD,oBACE,0BACA,aACA,WACA,KAAK,QAAQ,UAAU,YACvB,YACD;AACD,WAAQ,IAAI,sCAAsC;WAC3C,OAAO;AACd,WAAQ,MAAM,iCAAiC;AAC/C,SAAM;;AAGR,MAAI,KAAK,MACP,KAAI;AACF,WAAQ,IAAI,iCAAiC;AAC7C,oBAAiB,0BAA0B,YAAY;AACvD,WAAQ,IAAI,sCAAsC;WAC3C,OAAO;AACd,WAAQ,MAAM,iCAAiC;AAC/C,SAAM;;AAIV,UAAQ,KAAK,EAAE;;CAElB,CAAC;;;ACjKF,MAAa,OAAO,QAAQ;CAC1B,MAAM;CACN,aAAa;;;;;;;;;;CAUb,SAAS,CAAC,IAAI;CACd,MAAM;CACN,SAAS,OAAO,SAAS;AACvB,MAAI,KAAK,MACP,SAAQ,IAAI,KAAK;AAGnB,MAAI;GACF,MAAM,EAAE,6BACN,MAAM,OAAO;GACf,MAAM,cAAc,MAAM,0BAA0B;AACpD,WAAQ,IAAI,qBAAqB,YAAY;GAE7C,MAAM,EAAE,cAAc,MAAM,OAAO;GACnC,MAAM,WAAW,UACf,YAAY,cAAc,0BAC3B;AAED,OAAI,CAAC,SAAS,YAAY,SAAS,SAAS,WAAW,GAAG;AACxD,YAAQ,IAAI,mCAAmC;AAC/C;;AAGF,WAAQ,IAAI,wBAAwB;AACpC,YAAS,SAAS,SAAS,QAAQ;AACjC,YAAQ,IAAI,IAAI,YAAY;KAC5B;WACK,GAAG;AACV,WAAQ,IAAI,mCAAmC;;AAEjD,UAAQ,KAAK,EAAE;;CAElB,CAAC;;;AC5CF,MAAa,QAAQ,QAAQ;CAC3B,MAAM;CACN,aAAa;;;;;;;;;;CAUb,MAAM;CACN,SAAS,OAAO,SAAS;AACvB,MAAI,KAAK,MACP,SAAQ,IAAI,KAAK;EAGnB,MAAM,EAAE,cAAc,MAAM,OAAO;EACnC,MAAM,SAAS,MAAM,UAAU,KAAK,UAAU;AAE9C,MAAI,KAAK,SAAS;AAChB,WAAQ,IAAI,OAAO,IAAI;AACvB,WAAQ,KAAK,EAAE;;AAGjB,MAAI,KAAK,QAAQ;GACf,MAAM,EAAE,kBAAkB,MAAM,OAAO;GACvC,MAAM,SAAS,cAAc,OAAO;AACpC,OAAI,CAAC,OAAO,iBAAiB,CAAC,OAAO,SAAS;AAC5C,YAAQ,IAAI,8CAA8C;AAC1D,YAAQ,IAAI,oCAAkC;UACzC;AACL,YAAQ,IAAI,gBAAgB;AAC5B,YAAQ,IAAI,kBAAkB,OAAO,UAAU;AAC/C,YAAQ,IAAI,eAAe,OAAO,UAAU;AAC5C,YAAQ,IAAI,eAAe,OAAO,UAAU;AAC5C,YAAQ,IAAI,cAAc,OAAO,SAAS;AAC1C,YAAQ,IACN,uBAAuB,OAAO,iBAAiB,gBAAgB,GAChE;AACD,YAAQ,IAAI,iBAAiB,OAAO,UAAU;;AAEhD,WAAQ,KAAK,EAAE;;AAGjB,MAAI,KAAK,QAAQ;AACf,SAAM,cAAc;AACpB,WAAQ,KAAK,EAAE;;EAGjB,MAAM,EAAE,iBAAiB,MAAM,OAAO;AAEtC,UAAQ,MAAM,yCAAyC;AACvD,UAAQ,IAAI,YAAY,OAAO,MAAM;AAErC,MAAI;GACF,MAAM,YAAY,KAAK,UAAU,KAAK,UAAU,MAAO,KAAA;GAEvD,MAAM,SAAS,MAAM,aAAa,QAAQ;IACxC,WAAW,KAAK;IAChB;IACA,aAAa,KAAK,cAAc;AAC9B,aAAQ,IAAI,wCAAwC;AACpD,aAAQ,IAAI,eAAe,UAAU,MAAM,GAAG,EAAE,CAAC,KAAK;AACtD,aAAQ,IAAI,cAAc,MAAM;AAChC,aAAQ,KAAK;AACb,aAAQ,IAAI,wCAAwC;AACpD,aAAQ,IAAI,gBAAgB,aAAa,OAAW,IAAK,WAAW;AACpE,aAAQ,KAAK;AACb,aAAQ,IACN,2EACD;AACD,aAAQ,KAAK;AACb,aAAQ,OAAO,MAAM,UAAU;;IAEjC,kBAAkB,QAAQ,OAAO,MAAM,IAAI;IAC3C,sBAAsB,QAAQ;AAC5B,aAAQ,MAAM,wCAAwC;AACtD,aAAQ,IAAI,kCAAkC,MAAM;;IAEvD,CAAC;AAEF,WAAQ,KAAK;AACb,WAAQ,KAAK;AACb,WAAQ,IAAI,8BAA8B;AAC1C,WAAQ,IAAI,kBAAkB,OAAO,KAAK,UAAU;AACpD,WAAQ,IAAI,eAAe,OAAO,KAAK,MAAM;AAC7C,WAAQ,IAAI,cAAc,OAAO,SAAS;AAC1C,WAAQ,KAAK;AACb,WAAQ,IAAI,2DAA2D;WAChE,OAAO;AACd,WAAQ,KAAK;AACb,SAAM;;AAGR,UAAQ,KAAK,EAAE;;CAElB,CAAC;AAEF,eAAsB,eAAe;CACnC,MAAM,EAAE,cAAc,MAAM,OAAO;CACnC,MAAM,SAAS,MAAM,WAAW;AAChC,KAAI,CAAC,OAAO,MAAM;AAChB,UAAQ,IAAI,+BAA+B;AAC3C;;AAGF,KAAI;AACF,QAAM,OAAO,QAAQ;AACrB,UAAQ,IAAI,2BAA2B;UAChC,OAAO;AACd,UAAQ,MAAM,+BAA+B;AAC7C,UAAQ,MAAM,MAAM;;;;;ACjHxB,MAAa,SAAS,QAAQ;CAC5B,MAAM;CACN,aAAa;;CAEb,MAAM,EAAE;CACR,SAAS,YAAY;AACnB,QAAM,cAAc;AACpB,UAAQ,KAAK,EAAE;;CAElB,CAAC;;;ACTF,MAAa,UAAU,QAAQ;CAC7B,MAAM;CACN,MAAM;CACN,aAAa;CACb,SAAS,OAAO,SAAS;AACvB,MAAI,KAAK,MACP,SAAQ,IAAI,KAAK;EAEnB,MAAM,EAAE,iBAAiB,MAAM,OAAO;AACtC,QAAM,aAAa,KAAK;AACxB,UAAQ,KAAK,EAAE;;CAElB,CAAC;;;ACZF,SAAS,WAAW,MAAyB;AAC3C,QAAO,KAAK,MAAM,MAAM,MAAM,WAAW,EAAE,WAAW,SAAS,CAAC;;AAGlE,SAAS,gBAAyB;AAChC,QAAO,QAAQ,QAAQ,MAAM,MAAM,IAAI,CAAC,QAAQ,IAAI;;AAGtD,eAAe,kBAAkB,aAGvB;AACR,KAAI;EACF,MAAM,CAAC,EAAE,mBAAmB,EAAE,gBAAgB,MAAM,QAAQ,IAAI,CAC9D,OAAO,aACP,OAAO,UACR,CAAC;EACF,MAAM,MAAM,gBAAgB,EAAE,KAAK,aAAa,CAAC;AACjD,MAAI,CAAC,IAAI,QAAS,QAAO;EACzB,MAAM,QAAQ,WAAW,IAAI,QAAQ;AACrC,MAAI,CAAC,SAAS,MAAM,WAAW,EAAG,QAAO;EACzC,MAAM,QAAQ,OAAO,MAAM,GAAG;AAG9B,MAAI,CAAC,qBAAqB,KAAK,MAAM,CAAE,QAAO;AAC9C,SAAO;GAAE,SAAS,IAAI;GAAS,KAAK;GAAO;SACrC;AACN,SAAO;;;AAIX,MAAa,UAAU,QAAQ;CAC7B,MAAM;CACN,aAAa;;;;;;;;;CASb,MAAM;CACN,SAAS,OAAO,SAAS;AACvB,MAAI,KAAK,MACP,SAAQ,IAAI,KAAK;EAGnB,MAAM,EAAE,6BACN,MAAM,OAAO;EACf,MAAM,EAAE,gBAAgB,MAAM,0BAA0B;AAExD,MAAI,CAAC,YACH,OAAM,IAAI,MAAM,+BAA+B;EAGjD,MAAM,EAAE,cAAc,YAAY,uBAChC,MAAM,OAAO;EACf,MAAM,EAAE,0BACN,MAAM,OAAO;EAEf,MAAM,cAAc,mBAAmB;GACrC,UAAU,KAAK;GACf;GACD,CAAC;AAEF,MAAI,KAAK,MACP,SAAQ,IAAI,mBAAmB,YAAY;EAO7C,IAAI;AACJ,MAAI;AACF,eAAY,MAAM,sBAAsB,aAAa,IAAO;AAC5D,OAAI,KAAK,MACP,SAAQ,MAAM,+BAA+B,YAAY,WAAW;WAE/D,KAAK;AACZ,OAAI,KAAK,MACP,SAAQ,MACN,kCAAmC,IAAc,UAClD;AAEH,OAAI;AACF,UAAM,aAAa,YAAY;WACzB;AACN,YAAQ,MAAM,oCAAoC,cAAc;AAChE,YAAQ,MACN,yDAAyD,cAC1D;AACD,YAAQ,KAAK,EAAE;;;EAInB,IAAI,gBAAgB,KAAK;AAEzB,MAAI,CAAC,WAAW,cAAc,EAAE;GAC9B,MAAM,iBAAiB,MAAM,kBAAkB,YAAY;AAC3D,OAAI,gBAAgB;IAClB,MAAM,EAAE,SAAS,QAAQ;AACzB,QAAI,CAAC,eAAe,EAAE;AACpB,aAAQ,MACN,+BAA+B,QAAQ,+DACxC;AACD,aAAQ,MACN,yCAAyC,IAAI,eAC9C;AACD,aAAQ,KAAK,EAAE;;IAGjB,MAAM,WAAW,MAAM,OAAO;IAE9B,IAAI,YAAY;AAChB,QAAI;AAOF,kBANe,MAAM,SAAS,QAAQ,OAA+B;MACnE,MAAM;MACN,MAAM;MACN,SAAS,+BAA+B,QAAQ,uBAAuB,IAAI;MAC3E,SAAS;MACV,CAAC,EACiB;YACb;AAEN,iBAAY;;AAGd,QAAI,CAAC,WAAW;AACd,aAAQ,MACN,wDAAwD,YAAY,gBACrE;AACD,aAAQ,KAAK,EAAE;;AAGjB,oBAAgB;KAAC;KAAS;KAAK,GAAG;KAAc;;;AAIpD,MAAI,KAAK,MACP,SAAQ,IACN,eACA,0BAA0B,YAAY,GAAG,cAAc,KAAK,IAAI,GACjE;AAGH,UAAQ,IAAI,iBAAiB,YAAY,KAAK;EAC9C,MAAM,SAAS,MAAM,WAAW;GAC9B;GACA,KAAK;GACL,MAAM;GACN;GACD,CAAC;AACF,MAAI,OAAO,OACT,SAAQ,IAAI,OAAO,OAAO;AAG5B,UAAQ,KAAK,EAAE;;CAElB,CAAC;;;AChKF,MAAa,gBAAgB,QAAQ;CACnC,MAAM;CACN,aAAa;;;;;;;;;;;;;;CAcb,MAAM;CACN,SAAS,OAAO,SAAS;AACvB,MAAI,KAAK,MACP,SAAQ,IAAI,KAAK;EAGnB,MAAM,EAAE,6BACN,MAAM,OAAO;EAEf,MAAM,eADc,MAAM,0BAA0B,CAAC,YAAY,KAAK,GACrC,eAAe,QAAQ,KAAK;EAE7D,MAAM,CACJ,EAAE,oBAAoB,0BACtB,EAAE,yBACF,EAAE,aAAa,kBACb,MAAM,QAAQ,IAAI;GACpB,OAAO;GACP,OAAO;GACP,OAAO;GACR,CAAC;EAEF,MAAM,cAAc,mBAAmB;GACrC,UAAU,KAAK;GACf;GACD,CAAC;EAEF,MAAM,YAAY,YAAY,KAAK,OAAO;EAG1C,MAAM,YAAY,MAAM,uBAAuB,aADjC,MAAM,sBAAsB,aAAa,UAAU,CACC;AAElE,UAAQ,IAAI,gBAAgB,cAAc;AAC1C,UAAQ,IAAI,uBAAuB,aAAa,UAAU,GAAG;AAC7D,UAAQ,IAAI,YAAY,YAAY;AACpC,UAAQ,KAAK,EAAE;;CAElB,CAAC;;;ACpDF,MAAa,cAAc,QAAQ;CACjC,MAAM;CACN,SAAS,CAAC,UAAU;CACpB,aAAa;;;;;;;;;;;CAWb,MAAM;CACN,SAAS,OAAO,SAAS;AACvB,MAAI,KAAK,MACP,SAAQ,IAAI,KAAK;EAEnB,MAAM,EAAE,UAAU,QAAQ,SAAS,eAAe,OAAO,QAAQ;AACjE,MAAI,SACF,SAAQ,IAAI,YAAY;AAG1B,MAAI,OAAO;GACT,MAAM,EAAE,6BAA6B,MAAM,OACzC;AAEF,SAAM,yBAAyB;IAAE;IAAQ;IAAK,CAAC;AAC/C,WAAQ,KAAK,EAAE;;AAGjB,MAAI,WAAW,eAAe;GAC5B,MAAM,EAAE,6BACN,MAAM,OAAO;AACf,SAAM,yBAAyB;IAC7B;IACA,YAAY;IACb,CAAC;AACF,WAAQ,KAAK,EAAE;;EAGjB,MAAM,EAAE,qBAAqB,MAAM,OAAO;EAC1C,MAAM,EAAE,iBAAiB,WAAW,MAAM,iBAAiB,KAAK;AAChE,UAAQ,IAAI,sBAAsB,gBAAgB;AAClD,MAAI,OACF,SAAQ,IAAI,mBAAmB,OAAO,IAAI;;CAG/C,CAAC;;;AChDF,MAAa,YAAY,QAAQ;CAC/B,MAAM;CACN,SAAS,CAAC,SAAS;CACnB,aAAa;;;;;;;;gBAQC,OAAO,KAAK,KAAK,CAAC;;CAEhC,MAAM;CACN,SAAS,OAAO,SAAS;AACvB,MAAI,KAAK,MACP,SAAQ,IAAI,KAAK;EAGnB,MAAM,EACJ,0BACA,sCACA,iCACE,MAAM,OAAO;EAEjB,MAAM,EACJ,aACA,kBACA,mBACA,gBACA,aACE,MAAM,yBAAyB,KAAK;AAExC,MAAI,CAAC,YACH,OAAM,IAAI,MAAM,gDAAgD;EAGlE,MAAM,2BAA2B,MAAM,6BACrC,KAAK,aACN;AAED,MAAI,KAAK,MACP,SAAQ,IAAI,0BAA0B,yBAAyB;AAGjE,MAAI,KAAK,MACP,SAAQ,IAAI,qBAAqB;GAC/B;GACA;GACA;GACA;GACD,CAAC;AAGJ,MAAI;AACF,WAAQ,IAAI,mCAAmC;AAK/C,cAJyB,MAAM,qCAC7B,gBACA,KAAK,aACN,EAC0B;IACzB,OAAO;IACP,KAAK;IACN,CAAC;AACF,WAAQ,IAAI,yCAAyC;WAC9C,OAAO;AACd,WAAQ,MAAM,qCAAqC;AACnD,SAAM;;EAGR,MAAM,EAAE,qBAAqB,qBAC3B,MAAM,OAAO;AAEf,MAAI;AACF,WAAQ,IAAI,wCAAwC;AACpD,oBAAiB,0BAA0B,aAAa,YAAY;AACpE,WAAQ,IAAI,sCAAsC;WAC3C,OAAO;AACd,WAAQ,MAAM,iCAAiC;AAC/C,SAAM;;AAGR,MAAI;AACF,WAAQ,IAAI,iCAAiC;AAC7C,uBAAoB,0BAA0B,YAAY;AAC1D,WAAQ,IAAI,sCAAsC;WAC3C,OAAO;AACd,WAAQ,MAAM,iCAAiC;AAC/C,SAAM;;AAGR,UAAQ,KAAK,EAAE;;CAElB,CAAC;;;AC7FF,MAAa,YAAY,QAAQ;CAC/B,MAAM;CACN,aAAa;;;;;;;;;;;;;;CAcb,MAAM;CACN,SAAS,OAAO,SAAS;AACvB,MAAI,KAAK,MACP,SAAQ,IAAI,KAAK;EAGnB,MAAM,EAAE,6BACN,MAAM,OAAO;EACf,MAAM,EAAE,gBAAgB,MAAM,0BAA0B;AAExD,MAAI,CAAC,YACH,OAAM,IAAI,MAAM,+BAA+B;EAGjD,MAAM,EAAE,cAAc,cAAc,uBAClC,MAAM,OAAO;EAEf,MAAM,cAAc,mBAAmB;GACrC,UAAU,KAAK;GACf;GACD,CAAC;EAEF,MAAM,OAAO,MAAM,YAAY,KAAK,MAAM,YAAY;AACtD,MAAI,CAAC,MAAM;AACT,WAAQ,MACN,8EACD;AACD,WAAQ,KAAK,EAAE;;AAGjB,MAAI,KAAK,OAAO;AACd,WAAQ,IAAI,mBAAmB,YAAY;AAC3C,WAAQ,IAAI,YAAY,KAAK;;AAG/B,MAAI;AACF,SAAM,aAAa,YAAY;UACzB;AACN,WAAQ,MAAM,oCAAoC,cAAc;AAChE,WAAQ,MAAM,+BAA+B,cAAc;AAC3D,WAAQ,KAAK,EAAE;;AAGjB,MAAI,CAAC,KAAK;OAIJ,CAHc,MAAM,QACtB,aAAa,KAAK,QAAQ,YAAY,UACvC,EACe;AACd,YAAQ,IAAI,WAAW;AACvB,YAAQ,KAAK,EAAE;;;AAInB,MAAI,KAAK,MACP,SAAQ,IACN,eACA,iBAAiB,KAAK,cAAc,YAAY,WAAW,KAAK,cAAc,KAAK,IAAI,GACxF;AAGH,UAAQ,IAAI,gBAAgB,KAAK,QAAQ,YAAY,KAAK;AAC1D,MAAI;GACF,MAAM,SAAS,MAAM,aAAa;IAChC;IACA,KAAK;IACL;IACA,MAAM,KAAK;IACZ,CAAC;AACF,OAAI,OAAO,OACT,SAAQ,IAAI,OAAO,OAAO;AAE5B,WAAQ,KAAK,EAAE;WACR,KAAK;AACZ,WAAQ,MAAM,eAAe,QAAQ,IAAI,UAAU,OAAO,IAAI,CAAC;AAC/D,WAAQ,KAAK,EAAE;;;CAGpB,CAAC;AAEF,eAAe,YACb,UACA,aACwB;AACxB,KAAI,SAAU,QAAO;AACrB,KAAI;EACF,MAAM,EAAE,oBAAoB,MAAM,OAAO;EACzC,MAAM,MAAM,gBAAgB,EAAE,KAAK,aAAa,CAAC;AACjD,MAAI,CAAC,IAAI,KAAM,QAAO;AACtB,SAAO,IAAI,UAAU,GAAG,IAAI,KAAK,GAAG,IAAI,YAAY,IAAI;SAClD;AACN,SAAO;;;AAIX,eAAe,QAAQ,QAAkC;CACvD,MAAM,KAAK,gBAAgB;EAAE,OAAO,QAAQ;EAAO,QAAQ,QAAQ;EAAQ,CAAC;AAC5E,KAAI;EACF,MAAM,SAAS,MAAM,GAAG,SAAS,OAAO;AACxC,SAAO,YAAY,KAAK,OAAO,MAAM,CAAC;WAC9B;AACR,KAAG,OAAO;;;;;AEtGd,MAAa,gBAAgB;CAC3B;CACA;CACA,ODlBmB,QAAQ;EAC3B,MAAM;EACN,aAAa;;;;;;;;;;EAUb,MAAM;EACN,SAAS,OAAO,SAAS;AACvB,OAAI,KAAK,MACP,SAAQ,IAAI,KAAK;GAEnB,MAAM,EAAE,eAAe,MAAM,OAAO;AACpC,SAAM,WAAW,KAAK;;EAEzB,CAAC;CCDA;CACA,OAAA;CACA;CACA;CACA,gBAAgB;CAChB,kBAAkB;CAClB;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACD;AC9BD,MAAa,QAAQ,YAAY;CAC/B,MAAM;CACN,aAAa;CACb,SAJc,YAAY;CAK1B,MAAM;CACP,CAAC;;;ACTF,MAAM,4BAAsC;CAC1C;CACA;CACA;CACA;CACA;CACA;CACA;CACD;AAED,SAAS,gBAAgB,KAAwB;CAC/C,MAAM,WAAqB,EAAE;CAC7B,IAAI,UAAmB;CACvB,MAAM,uBAAO,IAAI,KAAc;AAC/B,QAAO,WAAW,CAAC,KAAK,IAAI,QAAQ,EAAE;AACpC,OAAK,IAAI,QAAQ;AACjB,MAAI,mBAAmB,OAAO;AAC5B,YAAS,KAAK,QAAQ,QAAQ;AAC9B,aAAW,QAAwC;SAC9C;AACL,YAAS,KAAK,OAAO,QAAQ,CAAC;AAC9B;;;AAGJ,QAAO;;AAGT,SAAgB,uBAAuB,KAAuB;AAE5D,QADiB,gBAAgB,IAAI,CACrB,MAAM,QACpB,0BAA0B,MAAM,OAAO,GAAG,KAAK,IAAI,CAAC,CACrD;;AAGH,SAAgB,oBAAoB,KAAoB;CAEtD,MAAM,YADW,gBAAgB,IAAI,CACV,MAAM,QAC/B,0BAA0B,MAAM,OAAO,GAAG,KAAK,IAAI,CAAC,CACrD;AACD,SAAQ,MAAM,GAAG;AACjB,SAAQ,MACN,OAAO,KAAK,mDAAmD,CAAC,CACjE;AACD,KAAI,UACF,SAAQ,MAAM,OAAO,KAAK,YAAY,CAAC;AAEzC,SAAQ,MAAM,GAAG;AACjB,SAAQ,MACN,OACE,0DACD,CACF;AACD,SAAQ,MAAM,OAAO,2BAA2B,CAAE;AAClD,SAAQ,MACN,OACE,gGACD,CACF;AACD,SAAQ,MACN,OACE,iHACD,CACF;AACD,SAAQ,MAAM,GAAG;;;;AClDnB,IAAI,eAA4C,KAAA;AAKhD,MAAM,4BAA4B,IAAI,IAAI,CAAC,WAAW,QAAQ,CAAC;AAE/D,SAAS,uBAA2C;CAKlD,MAAM,KAAK,QAAQ,IAAI;AACvB,KAAI,CAAC,GAAI,QAAO,KAAA;AAChB,QAAO,GAAG,MAAM,IAAI,CAAC,IAAI,MAAM,IAAI,CAAC,MAAM,KAAA;;AAG5C,eAAe,OAAO;AACpB,oBAAmB;AAGnB,gBAAe,MAAM,iBAAiB;EACpC,SAAS;EACT,SAAS,YAAY;EACtB,CAAC;CACF,MAAM,OAAO,QAAQ,KAAK,MAAM,EAAE;CAClC,MAAM,UAAU,KAAK;CACrB,MAAM,aACJ,WACA,0BAA0B,IAAI,QAAQ,IACtC,KAAK,MACL,CAAC,KAAK,GAAG,WAAW,IAAI,GACpB,KAAK,KACL,KAAA;AACN,eAAc,wBAAwB;EACpC;EACA;EACA,IAAI,sBAAsB;EAC1B,MAAM;EACN,KAAK,QAAQ,KAAK;EACnB,CAAC;CACF,MAAM,YAAY,KAAK,WAAW;CAClC,MAAM,SAAS,KAAK,MAAM,QAAQ,QAAQ,YAAY,QAAQ,KAAK;CACnE,MAAM,iBAAiB,UAAU,KAAK,WAAW;CAEjD,MAAM,MADmB,aAAa,iBACP,YAAY;CAC3C,MAAM,WAAW,KAAK,MAAM,EAAE;AAC9B,KACE,YAAY,aACZ,CAAC;EAAC;EAAU;EAAS;EAAU,CAAC,SAAS,KAAK,GAAG,IACjD,CAAC,OAGD,OAAM,IAAI,KAD+B;EAAC;EAAW;EAAU,GAAG;EAAS,CAC3B;KAEhD,OAAM,IAAI,KAAK,KAAK;;AAIxB,MAAM,MAAM,CAAC,MAAM,OAAO,UAAU;CAClC,MAAM,UAAU,QAAQ,KAAK,MAAM,EAAE,CAAC,SAAS,UAAU;AAEzD,OAAM,cAAc,gBAAgB,MAAM;AAC1C,KAAI,QACF,OAAM;AAER,KAAI,iBAAiB,OAAO;AAC1B,UAAQ,MAAM,MAAM,QAAQ;AAC5B,MAAI,uBAAuB,MAAM,CAC/B,qBAAoB,MAAM;AAE5B,UAAQ,KAAK,EAAE;OAEf,OAAM;EAER","debug_id":"a2e67adb-542b-5e92-bbfc-4656437ba4d7"}
|
|
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: boolean;\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 } =\n await import(\"../services/switchboard-reset.js\");\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(\n typeof current === \"string\" ? current : JSON.stringify(current),\n );\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(\"If this is a local PGlite store, you can reset it with:\"),\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":"d5bdee00-0bc7-551b-9930-8d2d40d45723"}
|
|
@@ -1,6 +1,6 @@
|
|
|
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]="
|
|
3
|
-
import { t as runBuild } from "./build-
|
|
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]="b932c8b6-b646-54f8-8bb1-445b95fc1b70")}catch(e){}}();
|
|
3
|
+
import { t as runBuild } from "./build-B5LEeRPm.mjs";
|
|
4
4
|
import { t as assignEnvVars } from "./assign-env-vars-W-lZmdMi.mjs";
|
|
5
5
|
import { join } from "node:path";
|
|
6
6
|
import { getConnectBaseViteConfig } from "@powerhousedao/builder-tools";
|
|
@@ -34,5 +34,5 @@ function assertLocalPackagesInstalled(projectPath) {
|
|
|
34
34
|
//#endregion
|
|
35
35
|
export { runConnectBuild };
|
|
36
36
|
|
|
37
|
-
//# sourceMappingURL=connect-build-
|
|
38
|
-
//# debugId=
|
|
37
|
+
//# sourceMappingURL=connect-build-DA5QOP5h.mjs.map
|
|
38
|
+
//# debugId=b932c8b6-b646-54f8-8bb1-445b95fc1b70
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"connect-build-
|
|
1
|
+
{"version":3,"file":"connect-build-DA5QOP5h.mjs","sources":["../src/services/connect-build.ts"],"sourcesContent":["import { getConnectBaseViteConfig } from \"@powerhousedao/builder-tools\";\nimport { getConfig } from \"@powerhousedao/shared/clis\";\nimport { existsSync } from \"node:fs\";\nimport { join } from \"node:path\";\nimport type { InlineConfig } from \"vite\";\nimport { build, mergeConfig } from \"vite\";\nimport type { ConnectBuildArgs } from \"../types.js\";\nimport { assignEnvVars } from \"../utils/assign-env-vars.js\";\nimport { runBuild } from \"./build.js\";\n\nexport async function runConnectBuild(args: ConnectBuildArgs) {\n const { outDir, debug } = args;\n assignEnvVars(args);\n\n const mode = \"production\";\n const dirname = process.cwd();\n\n // Fail fast if any package marked as provider: \"local\" is missing from\n // node_modules — the Vite plugin that bundles them needs them on disk.\n assertLocalPackagesInstalled(dirname);\n\n await runBuild({\n outDir: \"dist\",\n debug,\n });\n\n const baseConfig = getConnectBaseViteConfig({\n mode,\n dirname,\n });\n\n const buildConfig: InlineConfig = {\n build: {\n outDir,\n },\n };\n\n const config = mergeConfig(baseConfig, buildConfig);\n\n await build(config);\n}\n\nfunction assertLocalPackagesInstalled(projectPath: string) {\n const config = getConfig(join(projectPath, \"powerhouse.config.json\"));\n const localPackages = (config.packages ?? []).filter(\n (p) => p.provider === \"local\",\n );\n if (localPackages.length === 0) return;\n\n const missing = localPackages.filter(\n (p) =>\n !existsSync(\n join(projectPath, \"node_modules\", p.packageName, \"package.json\"),\n ),\n );\n if (missing.length === 0) return;\n\n const names = missing.map((p) => p.packageName);\n throw new Error(\n `ph connect build requires these packages to be installed in node_modules (they are declared with provider: \"local\" in powerhouse.config.json):\\n` +\n names.map((n) => ` - ${n}`).join(\"\\n\") +\n `\\n\\nInstall them with:\\n ph install --local ${names.join(\" \")}`,\n );\n}\n"],"names":[],"mappings":";;;;;;;;;;AAUA,eAAsB,gBAAgB,MAAwB;CAC5D,MAAM,EAAE,QAAQ,UAAU;AAC1B,eAAc,KAAK;CAEnB,MAAM,OAAO;CACb,MAAM,UAAU,QAAQ,KAAK;AAI7B,8BAA6B,QAAQ;AAErC,OAAM,SAAS;EACb,QAAQ;EACR;EACD,CAAC;AAeF,OAAM,MAFS,YAXI,yBAAyB;EAC1C;EACA;EACD,CAAC,EAEgC,EAChC,OAAO,EACL,QACD,EACF,CAEkD,CAEhC;;AAGrB,SAAS,6BAA6B,aAAqB;CAEzD,MAAM,iBADS,UAAU,KAAK,aAAa,yBAAyB,CAAC,CACvC,YAAY,EAAE,EAAE,QAC3C,MAAM,EAAE,aAAa,QACvB;AACD,KAAI,cAAc,WAAW,EAAG;CAEhC,MAAM,UAAU,cAAc,QAC3B,MACC,CAAC,WACC,KAAK,aAAa,gBAAgB,EAAE,aAAa,eAAe,CACjE,CACJ;AACD,KAAI,QAAQ,WAAW,EAAG;CAE1B,MAAM,QAAQ,QAAQ,KAAK,MAAM,EAAE,YAAY;AAC/C,OAAM,IAAI,MACR,qJACE,MAAM,KAAK,MAAM,OAAO,IAAI,CAAC,KAAK,KAAK,GACvC,gDAAgD,MAAM,KAAK,IAAI,GAClE","debug_id":"b932c8b6-b646-54f8-8bb1-445b95fc1b70"}
|
|
@@ -1,11 +1,11 @@
|
|
|
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]="
|
|
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]="75e0429b-f227-584e-aca7-692626e058f1")}catch(e){}}();
|
|
3
3
|
import { t as assignEnvVars } from "./assign-env-vars-W-lZmdMi.mjs";
|
|
4
4
|
import { getConnectBaseViteConfig } from "@powerhousedao/builder-tools";
|
|
5
5
|
import { mergeConfig, preview } from "vite";
|
|
6
6
|
//#region src/services/connect-preview.ts
|
|
7
7
|
async function runConnectPreview(args) {
|
|
8
|
-
const { outDir, connectBasePath, port, host, open, cors, strictPort, printUrls, bindCLIShortcuts } = args;
|
|
8
|
+
const { outDir, connectBasePath: _connectBasePath, port, host, open, cors, strictPort, printUrls, bindCLIShortcuts } = args;
|
|
9
9
|
assignEnvVars(args);
|
|
10
10
|
const server = await preview(mergeConfig(getConnectBaseViteConfig({
|
|
11
11
|
mode: "production",
|
|
@@ -26,5 +26,5 @@ async function runConnectPreview(args) {
|
|
|
26
26
|
//#endregion
|
|
27
27
|
export { runConnectPreview };
|
|
28
28
|
|
|
29
|
-
//# sourceMappingURL=connect-preview-
|
|
30
|
-
//# debugId=
|
|
29
|
+
//# sourceMappingURL=connect-preview-DQnzviwA.mjs.map
|
|
30
|
+
//# debugId=75e0429b-f227-584e-aca7-692626e058f1
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connect-preview-DQnzviwA.mjs","sources":["../src/services/connect-preview.ts"],"sourcesContent":["import { getConnectBaseViteConfig } from \"@powerhousedao/builder-tools\";\nimport type { InlineConfig } from \"vite\";\nimport { mergeConfig, preview } from \"vite\";\nimport type { ConnectPreviewArgs } from \"../types.js\";\nimport { assignEnvVars } from \"../utils/assign-env-vars.js\";\n\nexport async function runConnectPreview(args: ConnectPreviewArgs) {\n const {\n outDir,\n connectBasePath: _connectBasePath,\n port,\n host,\n open,\n cors,\n strictPort,\n printUrls,\n bindCLIShortcuts,\n } = args;\n\n assignEnvVars(args);\n\n const mode = \"production\";\n\n const dirname = process.cwd();\n\n const baseConfig = getConnectBaseViteConfig({\n mode,\n dirname,\n });\n\n const previewConfig: InlineConfig = {\n build: {\n outDir,\n },\n preview: {\n cors,\n port,\n strictPort,\n host,\n open,\n },\n };\n\n const config = mergeConfig(baseConfig, previewConfig);\n\n const server = await preview(config);\n\n if (printUrls) server.printUrls();\n if (bindCLIShortcuts) server.bindCLIShortcuts({ print: true });\n}\n"],"names":[],"mappings":";;;;;;AAMA,eAAsB,kBAAkB,MAA0B;CAChE,MAAM,EACJ,QACA,iBAAiB,kBACjB,MACA,MACA,MACA,MACA,YACA,WACA,qBACE;AAEJ,eAAc,KAAK;CA0BnB,MAAM,SAAS,MAAM,QAFN,YAlBI,yBAAyB;EAC1C,MALW;EAMX,SAJc,QAAQ,KAAK;EAK5B,CAAC,EAEkC;EAClC,OAAO,EACL,QACD;EACD,SAAS;GACP;GACA;GACA;GACA;GACA;GACD;EACF,CAEoD,CAEjB;AAEpC,KAAI,UAAW,QAAO,WAAW;AACjC,KAAI,iBAAkB,QAAO,iBAAiB,EAAE,OAAO,MAAM,CAAC","debug_id":"75e0429b-f227-584e-aca7-692626e058f1"}
|
|
@@ -1,5 +1,5 @@
|
|
|
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]="
|
|
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]="1a699c92-4b51-5e06-b512-74e77e62abb6")}catch(e){}}();
|
|
3
3
|
import { handleMutuallyExclusiveOptions, parsePackageManager, parseTag } from "@powerhousedao/shared/clis";
|
|
4
4
|
import { createProject } from "@powerhousedao/codegen";
|
|
5
5
|
import chalk from "chalk";
|
|
@@ -53,7 +53,7 @@ async function setupRemoteDrive(remoteDriveUrl) {
|
|
|
53
53
|
//#endregion
|
|
54
54
|
//#region src/services/init.ts
|
|
55
55
|
async function startInit(args) {
|
|
56
|
-
const { namePositional, nameOption, packageManager, npm, pnpm, yarn, bun, tag, version, dev, staging, remoteDrive } = args;
|
|
56
|
+
const { namePositional, nameOption, packageManager, npm, pnpm, yarn, bun, tag, version, dev, staging, remoteDrive, clone } = args;
|
|
57
57
|
let name = namePositional ?? nameOption;
|
|
58
58
|
if (!name) {
|
|
59
59
|
const { prompt } = enquirer;
|
|
@@ -92,6 +92,7 @@ async function startInit(args) {
|
|
|
92
92
|
dev,
|
|
93
93
|
staging
|
|
94
94
|
});
|
|
95
|
+
if (clone && (tag || version || dev || staging)) console.log(chalk.yellow("⚠️ --clone is set; --version/--tag/--dev/--staging are ignored (the cloned project's dependency set is authoritative)."));
|
|
95
96
|
try {
|
|
96
97
|
if (remoteDrive) {
|
|
97
98
|
console.log(chalk.blue("\n⏳ Setting up remote drive...\n"));
|
|
@@ -124,5 +125,5 @@ async function startInit(args) {
|
|
|
124
125
|
//#endregion
|
|
125
126
|
export { startInit };
|
|
126
127
|
|
|
127
|
-
//# sourceMappingURL=init-
|
|
128
|
-
//# debugId=
|
|
128
|
+
//# sourceMappingURL=init-Cu3_NRHL.mjs.map
|
|
129
|
+
//# debugId=1a699c92-4b51-5e06-b512-74e77e62abb6
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"init-Cu3_NRHL.mjs","sources":["../src/utils/validate-remote-drive.ts","../src/services/init.ts"],"sourcesContent":["import {\n createVetraDocument,\n getVetraDocuments,\n} from \"@powerhousedao/common/utils\";\n\n/**\n * Sets up a remote drive for initialization by validating and creating\n * a Vetra document if needed.\n * Returns true if setup succeeds, false if it should stop execution.\n */\nexport async function setupRemoteDrive(\n remoteDriveUrl: string,\n): Promise<boolean> {\n try {\n // Parse driveId from URL\n const driveId = remoteDriveUrl.split(\"/\").pop();\n\n if (!remoteDriveUrl || remoteDriveUrl.trim() === \"\") {\n console.error(\"❌ Remote drive URL is required\");\n return false;\n }\n\n // Construct GraphQL endpoint from base URL, preserving any subpath\n // prefix (e.g. when the reactor is served behind a proxy at /api/reactor).\n const url = new URL(remoteDriveUrl);\n const basePath = url.pathname.replace(/\\/d\\/[^/]+\\/?$/, \"\");\n const graphqlEndpoint = `${url.protocol}//${url.host}${basePath}/graphql`;\n\n let documents = await getVetraDocuments(graphqlEndpoint, driveId!);\n\n if (documents.length === 0) {\n console.log(\n \"No vetra package document found in the provided drive, creating one...\",\n );\n try {\n await createVetraDocument(graphqlEndpoint, driveId!, \"vetra-package\");\n\n // Re-fetch documents after creation\n documents = await getVetraDocuments(graphqlEndpoint, driveId!);\n\n if (documents.length === 0) {\n console.error(\n \"❌ Failed to create vetra package document in the remote drive\",\n );\n return false;\n }\n\n console.log(\"✅ Vetra package document created successfully\");\n } catch (createError) {\n console.error(\n \"❌ Failed to create vetra package document:\",\n createError,\n );\n return false;\n }\n }\n\n if (documents.length > 1) {\n console.warn(\n \"⚠️ Multiple vetra package documents were found in the provided remote drive, this might be an error in your remote drive\",\n );\n }\n\n const hasGithubUrl = documents.some((doc) => doc.githubUrl);\n\n if (hasGithubUrl) {\n console.error(\n \"❌ The remote drive provided already has been configured with a github url, please use the checkout command instead: ph checkout --remote-drive <remote drive url>\",\n );\n return false;\n }\n\n return true;\n } catch (error) {\n console.error(\"❌ Unable to fetch remote drive info:\", error);\n return false;\n }\n}\n","import { createProject } from \"@powerhousedao/codegen\";\nimport {\n handleMutuallyExclusiveOptions,\n parsePackageManager,\n parseTag,\n} from \"@powerhousedao/shared/clis\";\nimport chalk from \"chalk\";\nimport { kebabCase } from \"change-case\";\nimport enquirer from \"enquirer\";\nimport { clean, valid } from \"semver\";\nimport type { InitArgs } from \"../types.js\";\nimport { setupRemoteDrive } from \"../utils/validate-remote-drive.js\";\n\nexport async function startInit(args: InitArgs) {\n const {\n namePositional,\n nameOption,\n packageManager,\n npm,\n pnpm,\n yarn,\n bun,\n tag,\n version,\n dev,\n staging,\n remoteDrive,\n clone,\n } = args;\n\n let name = namePositional ?? nameOption;\n if (!name) {\n const { prompt } = enquirer;\n\n const result = await prompt<{ name: string }>([\n {\n type: \"input\",\n name: \"name\",\n message: \"What is the project name?\",\n required: true,\n result: (value) => kebabCase(value),\n },\n ]);\n name = result.name;\n }\n if (!name) {\n throw new Error(\"You must provide a name for your project.\");\n }\n\n if (version !== undefined && !valid(clean(version))) {\n throw new Error(`Invalid version: ${version}`);\n }\n\n handleMutuallyExclusiveOptions(\n {\n tag,\n version,\n dev,\n staging,\n },\n \"versioning strategy\",\n );\n\n handleMutuallyExclusiveOptions(\n {\n npm,\n pnpm,\n yarn,\n bun,\n packageManager,\n },\n \"package manager\",\n );\n\n const parsedPackageManager =\n parsePackageManager({\n npm,\n pnpm,\n yarn,\n bun,\n packageManager,\n }) ?? \"npm\";\n\n const parsedTag = parseTag({\n tag,\n dev,\n staging,\n });\n\n if (clone && (tag || version || dev || staging)) {\n console.log(\n chalk.yellow(\n \"⚠️ --clone is set; --version/--tag/--dev/--staging are ignored (the cloned project's dependency set is authoritative).\",\n ),\n );\n }\n\n try {\n if (remoteDrive) {\n console.log(chalk.blue(\"\\n⏳ Setting up remote drive...\\n\"));\n await setupRemoteDrive(remoteDrive);\n console.log(chalk.green(\"\\n✅ Remote drive set up.\"));\n }\n\n console.log(chalk.bold(\"\\n🚀 Initializing a new project...\\n\"));\n await createProject({\n ...args,\n name,\n packageManager: parsedPackageManager,\n tag: parsedTag,\n });\n\n if (remoteDrive) {\n console.log();\n console.log(\"To link your project to GitHub:\");\n console.log();\n console.log(\" 1. Create a new repository on GitHub\");\n console.log(` 2. cd ${name}`);\n console.log(\" 3. git add . && git commit -m 'Initial commit'\");\n console.log(\" 4. git remote add origin <your-github-url>\");\n console.log(` 5. git push -u origin main`);\n console.log();\n }\n } catch (error) {\n console.error(\"\\n❌ Failed to initialize project: \\n\");\n throw error;\n }\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;AAUA,eAAsB,iBACpB,gBACkB;AAClB,KAAI;EAEF,MAAM,UAAU,eAAe,MAAM,IAAI,CAAC,KAAK;AAE/C,MAAI,CAAC,kBAAkB,eAAe,MAAM,KAAK,IAAI;AACnD,WAAQ,MAAM,iCAAiC;AAC/C,UAAO;;EAKT,MAAM,MAAM,IAAI,IAAI,eAAe;EACnC,MAAM,WAAW,IAAI,SAAS,QAAQ,kBAAkB,GAAG;EAC3D,MAAM,kBAAkB,GAAG,IAAI,SAAS,IAAI,IAAI,OAAO,SAAS;EAEhE,IAAI,YAAY,MAAM,kBAAkB,iBAAiB,QAAS;AAElE,MAAI,UAAU,WAAW,GAAG;AAC1B,WAAQ,IACN,yEACD;AACD,OAAI;AACF,UAAM,oBAAoB,iBAAiB,SAAU,gBAAgB;AAGrE,gBAAY,MAAM,kBAAkB,iBAAiB,QAAS;AAE9D,QAAI,UAAU,WAAW,GAAG;AAC1B,aAAQ,MACN,gEACD;AACD,YAAO;;AAGT,YAAQ,IAAI,gDAAgD;YACrD,aAAa;AACpB,YAAQ,MACN,8CACA,YACD;AACD,WAAO;;;AAIX,MAAI,UAAU,SAAS,EACrB,SAAQ,KACN,4HACD;AAKH,MAFqB,UAAU,MAAM,QAAQ,IAAI,UAAU,EAEzC;AAChB,WAAQ,MACN,oKACD;AACD,UAAO;;AAGT,SAAO;UACA,OAAO;AACd,UAAQ,MAAM,wCAAwC,MAAM;AAC5D,SAAO;;;;;AC9DX,eAAsB,UAAU,MAAgB;CAC9C,MAAM,EACJ,gBACA,YACA,gBACA,KACA,MACA,MACA,KACA,KACA,SACA,KACA,SACA,aACA,UACE;CAEJ,IAAI,OAAO,kBAAkB;AAC7B,KAAI,CAAC,MAAM;EACT,MAAM,EAAE,WAAW;AAWnB,UATe,MAAM,OAAyB,CAC5C;GACE,MAAM;GACN,MAAM;GACN,SAAS;GACT,UAAU;GACV,SAAS,UAAU,UAAU,MAAM;GACpC,CACF,CAAC,EACY;;AAEhB,KAAI,CAAC,KACH,OAAM,IAAI,MAAM,4CAA4C;AAG9D,KAAI,YAAY,KAAA,KAAa,CAAC,MAAM,MAAM,QAAQ,CAAC,CACjD,OAAM,IAAI,MAAM,oBAAoB,UAAU;AAGhD,gCACE;EACE;EACA;EACA;EACA;EACD,EACD,sBACD;AAED,gCACE;EACE;EACA;EACA;EACA;EACA;EACD,EACD,kBACD;CAED,MAAM,uBACJ,oBAAoB;EAClB;EACA;EACA;EACA;EACA;EACD,CAAC,IAAI;CAER,MAAM,YAAY,SAAS;EACzB;EACA;EACA;EACD,CAAC;AAEF,KAAI,UAAU,OAAO,WAAW,OAAO,SACrC,SAAQ,IACN,MAAM,OACJ,0HACD,CACF;AAGH,KAAI;AACF,MAAI,aAAa;AACf,WAAQ,IAAI,MAAM,KAAK,mCAAmC,CAAC;AAC3D,SAAM,iBAAiB,YAAY;AACnC,WAAQ,IAAI,MAAM,MAAM,2BAA2B,CAAC;;AAGtD,UAAQ,IAAI,MAAM,KAAK,uCAAuC,CAAC;AAC/D,QAAM,cAAc;GAClB,GAAG;GACH;GACA,gBAAgB;GAChB,KAAK;GACN,CAAC;AAEF,MAAI,aAAa;AACf,WAAQ,KAAK;AACb,WAAQ,IAAI,kCAAkC;AAC9C,WAAQ,KAAK;AACb,WAAQ,IAAI,yCAAyC;AACrD,WAAQ,IAAI,WAAW,OAAO;AAC9B,WAAQ,IAAI,mDAAmD;AAC/D,WAAQ,IAAI,+CAA+C;AAC3D,WAAQ,IAAI,+BAA+B;AAC3C,WAAQ,KAAK;;UAER,OAAO;AACd,UAAQ,MAAM,uCAAuC;AACrD,QAAM","debug_id":"1a699c92-4b51-5e06-b512-74e77e62abb6"}
|
|
@@ -1,5 +1,5 @@
|
|
|
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]="
|
|
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]="df0f8142-c3a0-519e-96b4-ba20ca0556da")}catch(e){}}();
|
|
3
3
|
import "./assign-env-vars-W-lZmdMi.mjs";
|
|
4
4
|
import { t as runConnectStudio } from "./connect-studio-DTdSFftL.mjs";
|
|
5
5
|
import { a as generateProjectDriveId } from "./utils-mth8NsDA.mjs";
|
|
@@ -234,7 +234,7 @@ async function resolveSwitchboardPort(requested) {
|
|
|
234
234
|
return candidate;
|
|
235
235
|
}
|
|
236
236
|
const enquirer = await import("enquirer");
|
|
237
|
-
let confirmed
|
|
237
|
+
let confirmed;
|
|
238
238
|
try {
|
|
239
239
|
confirmed = (await enquirer.default.prompt({
|
|
240
240
|
type: "confirm",
|
|
@@ -421,5 +421,5 @@ async function startVetra(args) {
|
|
|
421
421
|
//#endregion
|
|
422
422
|
export { startVetra };
|
|
423
423
|
|
|
424
|
-
//# sourceMappingURL=vetra-
|
|
425
|
-
//# debugId=
|
|
424
|
+
//# sourceMappingURL=vetra-BgmlqLmN.mjs.map
|
|
425
|
+
//# debugId=df0f8142-c3a0-519e-96b4-ba20ca0556da
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vetra-BgmlqLmN.mjs","sources":["../src/utils/configure-vetra-github-url.ts","../src/utils/resolve-switchboard-port.ts","../src/services/vetra.ts"],"sourcesContent":["import {\n createVetraDocument,\n getVetraDocuments,\n setPackageGithubUrl,\n} from \"@powerhousedao/common/utils\";\nimport { red } from \"colorette\";\nimport { execSync } from \"node:child_process\";\nimport { createInterface } from \"node:readline\";\n\n/**\n * Get git remote URL (origin)\n * @returns Git remote URL or null if not configured\n */\nfunction getGitRemoteUrl(): string | null {\n try {\n const url = execSync(\"git remote get-url origin\", {\n encoding: \"utf-8\",\n stdio: [\"pipe\", \"pipe\", \"pipe\"],\n }).trim();\n return url || null;\n } catch {\n return null;\n }\n}\n\n/**\n * Prompt user to enter a custom GitHub URL\n */\nasync function promptForCustomUrl(): Promise<string | null> {\n return new Promise((resolve) => {\n const rl = createInterface({\n input: process.stdin,\n output: process.stdout,\n });\n\n process.stdout.write(\"\\nEnter GitHub URL (or press Enter to skip): \");\n\n rl.on(\"line\", (answer: string) => {\n rl.close();\n const url = answer.trim();\n resolve(url || null);\n });\n });\n}\n\n/**\n * Prompt yes/no question\n */\nasync function promptYesNo(question: string): Promise<boolean> {\n return new Promise((resolve) => {\n const rl = createInterface({\n input: process.stdin,\n output: process.stdout,\n });\n\n process.stdout.write(`\\n${question} (y/n): `);\n\n rl.on(\"line\", (answer: string) => {\n rl.close();\n const response = answer.trim().toLowerCase();\n resolve(response === \"y\" || response === \"yes\");\n });\n });\n}\n\n/**\n * Prompt user to select or enter GitHub URL\n * @param gitRemoteUrl - Git remote URL if available\n * @returns Selected URL or null if skipped\n */\nasync function promptForGithubUrl(\n gitRemoteUrl: string | null,\n): Promise<string | null> {\n return new Promise((resolve) => {\n const rl = createInterface({\n input: process.stdin,\n output: process.stdout,\n });\n\n console.log(\"\\n\" + \"=\".repeat(50));\n console.log(\"🔍 Vetra Package Configuration\");\n console.log(\"=\".repeat(50));\n console.log(\n \"\\nWe detected a Vetra package document in your remote drive without a GitHub URL configured.\",\n );\n console.log(\"\\nWould you like to configure the GitHub URL now?\");\n\n if (gitRemoteUrl) {\n console.log(`\\nGit remote URL detected: ${gitRemoteUrl}`);\n console.log(\"\\nOptions:\");\n console.log(\"1. Use detected URL\");\n console.log(\"2. Enter a different URL\");\n console.log(\"3. Skip configuration\");\n\n process.stdout.write(\"\\nSelect an option (1-3): \");\n\n const handleAnswer = (answer: string) => {\n const choice = answer.trim();\n\n if (choice === \"1\") {\n rl.close();\n resolve(gitRemoteUrl);\n } else if (choice === \"2\") {\n rl.close();\n promptForCustomUrl()\n .then(resolve)\n .catch(() => resolve(null));\n } else if (choice === \"3\") {\n rl.close();\n resolve(null);\n } else {\n process.stdout.write(\"Invalid choice. Select an option (1-3): \");\n }\n };\n\n rl.on(\"line\", handleAnswer);\n } else {\n console.log(\"\\nNo git remote URL detected.\");\n console.log(\"\\nOptions:\");\n console.log(\"1. Enter GitHub URL manually\");\n console.log(\"2. Skip configuration\");\n\n process.stdout.write(\"\\nSelect an option (1-2): \");\n\n const handleAnswer = (answer: string) => {\n const choice = answer.trim();\n\n if (choice === \"1\") {\n rl.close();\n promptForCustomUrl()\n .then(resolve)\n .catch(() => resolve(null));\n } else if (choice === \"2\") {\n rl.close();\n resolve(null);\n } else {\n process.stdout.write(\"Invalid choice. Select an option (1-2): \");\n }\n };\n\n rl.on(\"line\", handleAnswer);\n }\n });\n}\n\n/**\n * Set git remote URL (origin)\n */\nfunction setGitRemoteUrl(url: string): void {\n try {\n execSync(`git remote add origin ${url}`, {\n stdio: \"inherit\",\n });\n console.log(`✅ Git remote origin set to: ${url}`);\n } catch {\n try {\n execSync(`git remote set-url origin ${url}`, {\n stdio: \"inherit\",\n });\n console.log(`✅ Git remote origin updated to: ${url}`);\n } catch {\n console.error(red(`❌ Failed to set git remote URL`));\n }\n }\n}\n\n/**\n * Validates documents and returns the target document to use\n * Warns if multiple documents found\n */\nfunction validateAndSelectDocument<T>(documents: T[]): T | null {\n if (documents.length === 0) {\n return null;\n }\n\n if (documents.length > 1) {\n console.warn(\n `⚠️ Warning: Multiple Vetra documents found (${documents.length}). Using first document.`,\n );\n }\n\n return documents[0];\n}\n\nasync function applyGithubUrlConfiguration(\n graphqlEndpoint: string,\n vetraDriveId: string,\n documentId: string,\n selectedUrl: string,\n shouldSetRemote: boolean,\n): Promise<void> {\n // Set package GitHub URL\n await setPackageGithubUrl(\n graphqlEndpoint,\n vetraDriveId,\n documentId,\n selectedUrl,\n );\n\n console.log(`✅ GitHub URL configured: ${selectedUrl}`);\n\n // Set git remote URL if requested\n if (shouldSetRemote) {\n setGitRemoteUrl(selectedUrl);\n }\n}\n\nfunction logVerbose(message: string, verbose?: boolean): void {\n if (verbose) {\n console.log(message);\n }\n}\n\n/**\n * Sleep for a specified number of milliseconds\n */\nexport function sleep(ms: number): Promise<void> {\n return new Promise((resolve) => setTimeout(resolve, ms));\n}\n\n/**\n * Configure GitHub URL for Vetra documents\n * @param switchboardPort - Port where switchboard is running\n * @param vetraDriveUrl - Remote drive URL\n * @param verbose - Enable verbose logging\n */\nexport async function configureVetraGithubUrl(\n switchboardPort: number,\n vetraDriveUrl: string,\n verbose?: boolean,\n): Promise<void> {\n logVerbose(\"Checking GitHub URL configuration...\", verbose);\n\n try {\n const graphqlEndpoint = `http://localhost:${switchboardPort}/graphql`;\n const vetraDriveId = vetraDriveUrl.split(\"/\").pop();\n if (!vetraDriveId) {\n throw new Error(\"Invalid vetraDriveUrl: unable to extract drive ID\");\n }\n\n const documents = await getVetraDocuments(graphqlEndpoint, vetraDriveId);\n\n // Skip if already configured\n if (documents.some((doc) => doc.githubUrl)) {\n logVerbose(\"GitHub URL already configured, skipping setup\", verbose);\n return;\n }\n\n // Get or create target document\n let targetDocumentId: string;\n const targetDocument = validateAndSelectDocument(documents);\n\n // Collect user input\n const gitRemoteUrl = getGitRemoteUrl();\n const selectedUrl = await promptForGithubUrl(gitRemoteUrl);\n\n if (!selectedUrl) {\n logVerbose(\"GitHub URL configuration skipped\", verbose);\n return;\n }\n\n let shouldSetRemote = false;\n if (selectedUrl !== gitRemoteUrl && !gitRemoteUrl) {\n shouldSetRemote = await promptYesNo(\"Set this as your git remote URL?\");\n }\n\n if (!targetDocument) {\n logVerbose(\"No Vetra documents found, creating new document...\", verbose);\n\n targetDocumentId = await createVetraDocument(\n graphqlEndpoint,\n vetraDriveId,\n \"vetra-package\",\n );\n\n logVerbose(`Created new document: ${targetDocumentId}`, verbose);\n } else {\n targetDocumentId = targetDocument.id;\n }\n\n await applyGithubUrlConfiguration(\n graphqlEndpoint,\n vetraDriveId,\n targetDocumentId,\n selectedUrl,\n shouldSetRemote,\n );\n } catch (error) {\n console.error(\n red(\n `⚠️ GitHub URL configuration failed: ${error instanceof Error ? error.message : String(error)}`,\n ),\n );\n logVerbose(String(error), verbose);\n }\n}\n","import { isPortAvailable } from \"@powerhousedao/switchboard/server\";\nimport { yellow } from \"colorette\";\n\nconst MAX_FALLBACK_ATTEMPTS = 20;\n\nfunction isInteractive(): boolean {\n return Boolean(process.stdin.isTTY) && !process.env.CI;\n}\n\nasync function findFreePort(start: number): Promise<number | null> {\n for (let i = 0; i < MAX_FALLBACK_ATTEMPTS; i++) {\n const candidate = start + i;\n if (await isPortAvailable(candidate)) return candidate;\n }\n return null;\n}\n\n/**\n * Resolve the port switchboard should bind to. If the requested port is free,\n * returns it unchanged. If it's in use, walks forward for the next free port\n * and — in an interactive terminal — asks the user to confirm the fallback.\n * In CI / piped contexts the fallback is applied automatically so scripts\n * don't hang on an unanswered prompt.\n *\n * Throws a process.exit(1) when the user declines the prompt or when no free\n * port is available in the search window.\n */\nexport async function resolveSwitchboardPort(\n requested: number,\n): Promise<number> {\n if (await isPortAvailable(requested)) return requested;\n\n const candidate = await findFreePort(requested + 1);\n if (candidate === null) {\n console.error(\n `Port ${requested} is in use and no free port was found in the range ${requested}-${requested + MAX_FALLBACK_ATTEMPTS - 1}.`,\n );\n process.exit(1);\n }\n\n if (!isInteractive()) {\n console.log(\n yellow(\n `Port ${requested} is in use. Falling back to port ${candidate} (non-interactive; skipping confirmation).`,\n ),\n );\n return candidate;\n }\n\n const enquirer = await import(\"enquirer\");\n\n let confirmed: boolean;\n try {\n const answer = await enquirer.default.prompt<{ confirmed: boolean }>({\n type: \"confirm\",\n name: \"confirmed\",\n message: `Port ${requested} is in use. Use port ${candidate} instead?`,\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. Free port ${requested} or pass --switchboard-port <port> to choose a different port.`,\n );\n process.exit(1);\n }\n\n return candidate;\n}\n","import type { VetraProcessorConfigType } from \"@powerhousedao/config\";\nimport { VETRA_PROCESSOR_CONFIG_KEY } from \"@powerhousedao/config\";\nimport type { IReactorClient } from \"@powerhousedao/reactor\";\nimport { addDefaultDrive } from \"@powerhousedao/switchboard/utils\";\nimport { blue, green, red, yellow, type Color } from \"colorette\";\nimport type { ILogger } from \"document-model\";\nimport { childLogger, setLogLevel } from \"document-model\";\nimport { createLogger } from \"vite\";\nimport type { VetraArgs } from \"../types.js\";\nimport { generateProjectDriveId } from \"../utils.js\";\nimport {\n configureVetraGithubUrl,\n sleep,\n} from \"../utils/configure-vetra-github-url.js\";\nimport { resolveSwitchboardPort } from \"../utils/resolve-switchboard-port.js\";\nimport { runConnectStudio } from \"./connect-studio.js\";\nimport { startSwitchboard } from \"./switchboard.js\";\n\nconst VETRA_DRIVE_NAME = \"vetra\";\n\nconst getDefaultVetraUrl = (port: number) =>\n `http://localhost:${port}/d/${generateProjectDriveId(VETRA_DRIVE_NAME)}`;\n\nconst getDriveId = (driveUrl: string | undefined): string =>\n driveUrl?.split(\"/\").pop() ?? generateProjectDriveId(VETRA_DRIVE_NAME);\n\nfunction createViteLogger(color: Color) {\n const customLogger = createLogger(\"info\");\n const loggerInfo = customLogger.info.bind(customLogger);\n customLogger.info = (msg, options) => {\n loggerInfo(color(msg), options);\n };\n const loggerWarn = customLogger.warn.bind(customLogger);\n customLogger.warn = (msg, options) => {\n loggerWarn(yellow(msg), options);\n };\n const loggerError = customLogger.error.bind(customLogger);\n customLogger.error = (msg, options) => {\n loggerError(red(msg), options);\n };\n\n const loggerWarnOnce = customLogger.warnOnce.bind(customLogger);\n customLogger.warnOnce = (msg, options) => {\n loggerWarnOnce(yellow(msg), options);\n };\n return customLogger;\n}\n\nasync function startVetraPreviewDrive(\n reactor: IReactorClient,\n port: number,\n verbose?: boolean,\n): Promise<string> {\n const previewDriveId = generateProjectDriveId(\"preview\");\n\n const previewDrive = {\n id: previewDriveId,\n slug: previewDriveId,\n global: {\n name: \"Vetra Preview\",\n icon: \"https://azure-elderly-tortoise-212.mypinata.cloud/ipfs/bafkreifddkbopiyvcirf7vaqar74th424r5phlxkdxniirdyg3qgu2ajha\",\n nodes: [],\n },\n local: {\n availableOffline: true,\n listeners: [],\n sharingType: \"public\" as const,\n triggers: [],\n },\n };\n\n const driveUrl = await addDefaultDrive(reactor, previewDrive, port);\n\n if (verbose) {\n console.log(blue(`Vetra Switchboard: Preview drive: ${driveUrl}`));\n }\n return driveUrl;\n}\nasync function startLocalVetraSwitchboard(args: VetraArgs, logger?: ILogger) {\n const {\n connectPort,\n switchboardPort,\n dev,\n packages,\n disableLocalPackages,\n debug,\n httpsKeyFile,\n httpsCertFile,\n remoteDrive,\n interactive,\n watch,\n verbose,\n } = args;\n\n // Convert single remote drive to array if provided\n const remoteDrives = remoteDrive ? [remoteDrive] : [];\n\n const vetraProcessorConfig: VetraProcessorConfigType = {\n interactive,\n driveUrl: remoteDrive ?? getDefaultVetraUrl(connectPort),\n driveId: getDriveId(remoteDrive),\n };\n\n const processorConfig = new Map<string, unknown>();\n processorConfig.set(VETRA_PROCESSOR_CONFIG_KEY, vetraProcessorConfig);\n\n const vetraDriveId = generateProjectDriveId(VETRA_DRIVE_NAME);\n\n // When the user didn't opt into strict-port semantics, check for a port\n // conflict up front and ask for confirmation before binding a fallback.\n // Doing this in the CLI layer keeps the interactive prompt out of the\n // switchboard server package and aligns with the existing prerelease-tag\n // confirmation flow in `ph publish`.\n const resolvedSwitchboardPort = args.strictPort\n ? switchboardPort\n : await resolveSwitchboardPort(switchboardPort);\n\n try {\n const switchboard = await startSwitchboard(\n {\n ...args,\n useVetraDrive: true, // Use Vetra drive instead of Powerhouse drive\n mcp: true,\n port: resolvedSwitchboardPort,\n // We've already probed and (when interactive) confirmed the port with\n // the user, so keep the server from running its own fallback on top.\n strictPort: true,\n dev,\n packages,\n remoteDrives,\n vetraDriveId,\n disableLocalPackages,\n debug,\n httpsKeyFile,\n httpsCertFile,\n processorConfig,\n basePath: undefined,\n keypairPath: undefined,\n dbPath: args.dbPath,\n useIdentity: undefined,\n migrate: undefined,\n migrateStatus: undefined,\n reset: undefined,\n yes: undefined,\n requireIdentity: undefined,\n },\n logger,\n );\n\n const actualSwitchboardPort = switchboard.port;\n\n // Add preview drive (only in watch mode)\n let previewDriveUrl: string | null = null;\n if (watch) {\n try {\n previewDriveUrl = await startVetraPreviewDrive(\n switchboard.reactor,\n actualSwitchboardPort,\n verbose,\n );\n } catch (error) {\n console.error(error);\n }\n }\n\n if (verbose) {\n console.log(blue(`Vetra Switchboard: Started successfully`));\n if (remoteDrive) {\n console.log(\n blue(`Vetra Switchboard: Syncing with remote drive: ${remoteDrive}`),\n );\n }\n } else {\n console.log();\n console.log(\n blue(\n `Vetra Switchboard: http://localhost:${actualSwitchboardPort}/graphql`,\n ),\n );\n console.log(blue(` ➜ Drive URL: ${switchboard.defaultDriveUrl}`));\n if (previewDriveUrl) {\n console.log(blue(` ➜ Preview Drive URL: ${previewDriveUrl}`));\n }\n }\n return {\n driveUrl: switchboard.defaultDriveUrl || \"\",\n previewDriveUrl: previewDriveUrl,\n switchboardPort: actualSwitchboardPort,\n };\n } catch (error) {\n console.error(\n red(\n `Vetra Switchboard: ${error instanceof Error ? error.message : String(error)}`,\n ),\n );\n throw error instanceof Error ? error : new Error(String(error));\n }\n}\n\nexport async function startVetra(args: VetraArgs) {\n const {\n connectPort,\n verbose,\n remoteDrive,\n disableConnect,\n debug,\n httpsCertFile,\n httpsKeyFile,\n disableLocalPackages,\n host,\n open,\n cors,\n strictPort,\n printUrls,\n bindCLIShortcuts,\n watchTimeout,\n } = args;\n\n const switchboardLogger = childLogger([\"vetra\", \"switchboard\"]);\n\n try {\n // Set default log level to info if not already specified\n if (!process.env.LOG_LEVEL) {\n setLogLevel(\"info\");\n }\n\n if (verbose) {\n switchboardLogger.info(\"Starting Vetra Switchboard...\");\n if (remoteDrive) {\n const source = remoteDrive\n ? \"command line argument\"\n : \"powerhouse.config.json\";\n switchboardLogger.info(`Using vetraUrl from ${source}: ${remoteDrive}`);\n }\n }\n const switchboardResult = await startLocalVetraSwitchboard(\n {\n ...args,\n dev: true, // Vetra always runs in dev mode to load local packages\n httpsKeyFile,\n httpsCertFile,\n disableLocalPackages,\n debug,\n },\n switchboardLogger,\n );\n const driveUrl: string = switchboardResult.driveUrl || remoteDrive || \"\";\n const previewDriveUrl = switchboardResult.previewDriveUrl;\n const actualSwitchboardPort = switchboardResult.switchboardPort;\n\n // Configure GitHub URL if remote drive is set\n if (remoteDrive) {\n // give some time for the drive to process initial strands\n await sleep(3000);\n\n await configureVetraGithubUrl(\n actualSwitchboardPort,\n remoteDrive,\n verbose,\n );\n\n // give some time for the user to read log messages\n await sleep(2000);\n }\n\n if (verbose) {\n console.log(\"Starting Codegen Reactor...\");\n }\n\n // Start Connect pointing to the drive (unless disabled)\n if (!disableConnect) {\n if (verbose) {\n console.log(\"Starting Connect...\");\n const drives = previewDriveUrl\n ? `${driveUrl}, ${previewDriveUrl}`\n : driveUrl;\n console.log(` ➜ Connect will use drives: ${drives}`);\n }\n console.log();\n console.log(green(`Vetra Connect: http://localhost:${connectPort}`));\n\n const customViteLogger = createViteLogger(green);\n\n await runConnectStudio(\n {\n ...args,\n defaultDrivesUrl: previewDriveUrl\n ? [driveUrl, previewDriveUrl].join(\",\")\n : driveUrl,\n drivesPreserveStrategy: \"preserve-all\",\n port: connectPort,\n disableLocalPackages,\n debug,\n host: host,\n open: open,\n cors: cors,\n strictPort: strictPort,\n printUrls: printUrls,\n bindCLIShortcuts: bindCLIShortcuts,\n watchTimeout: watchTimeout,\n },\n customViteLogger,\n );\n }\n } catch (error) {\n console.error(error);\n }\n}\n"],"names":["startSwitchboard"],"mappings":"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","debug_id":"df0f8142-c3a0-519e-96b4-ba20ca0556da"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@powerhousedao/ph-cli",
|
|
3
|
-
"version": "6.1.0
|
|
3
|
+
"version": "6.1.0",
|
|
4
4
|
"description": "",
|
|
5
5
|
"license": "AGPL-3.0-only",
|
|
6
6
|
"type": "module",
|
|
@@ -38,16 +38,16 @@
|
|
|
38
38
|
"semver": "7.7.4",
|
|
39
39
|
"tsdown": "0.21.1",
|
|
40
40
|
"vite": "8.0.8",
|
|
41
|
-
"@powerhousedao/
|
|
42
|
-
"@powerhousedao/
|
|
43
|
-
"@powerhousedao/
|
|
44
|
-
"@powerhousedao/common": "6.1.0
|
|
45
|
-
"@powerhousedao/
|
|
46
|
-
"@powerhousedao/
|
|
47
|
-
"@powerhousedao/
|
|
48
|
-
"@
|
|
49
|
-
"
|
|
50
|
-
"
|
|
41
|
+
"@powerhousedao/builder-tools": "6.1.0",
|
|
42
|
+
"@powerhousedao/codegen": "6.1.0",
|
|
43
|
+
"@powerhousedao/reactor": "6.1.0",
|
|
44
|
+
"@powerhousedao/common": "6.1.0",
|
|
45
|
+
"@powerhousedao/config": "6.1.0",
|
|
46
|
+
"@powerhousedao/switchboard": "6.1.0",
|
|
47
|
+
"@powerhousedao/vetra": "6.1.0",
|
|
48
|
+
"@renown/sdk": "6.1.0",
|
|
49
|
+
"document-model": "6.1.0",
|
|
50
|
+
"@powerhousedao/shared": "6.1.0"
|
|
51
51
|
},
|
|
52
52
|
"devDependencies": {
|
|
53
53
|
"@types/node": "25.2.3",
|
package/dist/build-CqtYNjiI.mjs
DELETED
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import { t as runBuild } from "./build-vccTv_Jp.mjs";
|
|
2
|
-
export { runBuild };
|
|
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]="4960d4f7-96d4-5e0a-8c0e-5a1543051775")}catch(e){}}();
|
|
4
|
-
//# debugId=4960d4f7-96d4-5e0a-8c0e-5a1543051775
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"build-vccTv_Jp.mjs","sources":["../src/services/build.ts"],"sourcesContent":["import {\n browserBuildConfig,\n nodeBuildConfig,\n} from \"@powerhousedao/shared/build-config\";\nimport { execSync } from \"node:child_process\";\nimport { join } from \"node:path\";\nimport { detect, resolveCommand } from \"package-manager-detector\";\nimport { build as tsdownBuild } from \"tsdown\";\nimport type { BuildArgs } from \"../types.js\";\n\nexport async function runBuild(args: BuildArgs) {\n const { outDir } = args;\n\n await tsdownBuild({\n ...browserBuildConfig,\n outDir: join(outDir, \"browser\"),\n });\n\n await tsdownBuild({\n ...nodeBuildConfig,\n outDir: join(outDir, \"node\"),\n });\n\n const detectResult = await detect();\n const agent = detectResult?.agent ?? \"npm\";\n\n // Emit types with tsc\n const tscCommand = resolveCommand(agent, \"execute-local\", [\"tsc\"]);\n if (tscCommand === null) {\n console.error(\n \"You need to have typescript installed to use the `build` command.\",\n );\n process.exit(1);\n }\n console.log(\"\\n▶ Emitting types via tsc...\");\n try {\n execSync(`${tscCommand.command} ${tscCommand.args.join(\" \")}`, {\n stdio: \"inherit\",\n });\n console.log(\"✔ Types emitted to\", join(outDir, \"types\"));\n } catch {\n console.warn(\n \"✘ tsc reported errors above; declarations were still written. Fix the errors to keep types accurate.\",\n );\n }\n\n const executeLocalCommand = resolveCommand(agent, \"execute-local\", [\n \"tailwindcss\",\n \"-i\",\n \"./style.css\",\n \"-o\",\n \"./dist/style.css\",\n ]);\n if (executeLocalCommand === null) {\n console.error(\n \"You need to have tailwindcss installed to use the `build` command.\",\n );\n process.exit(1);\n }\n execSync(\n `${executeLocalCommand.command} ${executeLocalCommand.args.join(\" \")}`,\n );\n}\n"],"names":["tsdownBuild"],"mappings":";;;;;;;;AAUA,eAAsB,SAAS,MAAiB;CAC9C,MAAM,EAAE,WAAW;AAEnB,OAAMA,MAAY;EAChB,GAAG;EACH,QAAQ,KAAK,QAAQ,UAAU;EAChC,CAAC;AAEF,OAAMA,MAAY;EAChB,GAAG;EACH,QAAQ,KAAK,QAAQ,OAAO;EAC7B,CAAC;CAGF,MAAM,SADe,MAAM,QAAQ,GACP,SAAS;CAGrC,MAAM,aAAa,eAAe,OAAO,iBAAiB,CAAC,MAAM,CAAC;AAClE,KAAI,eAAe,MAAM;AACvB,UAAQ,MACN,oEACD;AACD,UAAQ,KAAK,EAAE;;AAEjB,SAAQ,IAAI,gCAAgC;AAC5C,KAAI;AACF,WAAS,GAAG,WAAW,QAAQ,GAAG,WAAW,KAAK,KAAK,IAAI,IAAI,EAC7D,OAAO,WACR,CAAC;AACF,UAAQ,IAAI,sBAAsB,KAAK,QAAQ,QAAQ,CAAC;SAClD;AACN,UAAQ,KACN,uGACD;;CAGH,MAAM,sBAAsB,eAAe,OAAO,iBAAiB;EACjE;EACA;EACA;EACA;EACA;EACD,CAAC;AACF,KAAI,wBAAwB,MAAM;AAChC,UAAQ,MACN,qEACD;AACD,UAAQ,KAAK,EAAE;;AAEjB,UACE,GAAG,oBAAoB,QAAQ,GAAG,oBAAoB,KAAK,KAAK,IAAI,GACrE","debug_id":"371420a3-9d9d-5dfe-9cd5-4781b4d100ee"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"connect-preview-CNJkhtxL.mjs","sources":["../src/services/connect-preview.ts"],"sourcesContent":["import { getConnectBaseViteConfig } from \"@powerhousedao/builder-tools\";\nimport type { InlineConfig } from \"vite\";\nimport { mergeConfig, preview } from \"vite\";\nimport type { ConnectPreviewArgs } from \"../types.js\";\nimport { assignEnvVars } from \"../utils/assign-env-vars.js\";\n\nexport async function runConnectPreview(args: ConnectPreviewArgs) {\n const {\n outDir,\n connectBasePath,\n port,\n host,\n open,\n cors,\n strictPort,\n printUrls,\n bindCLIShortcuts,\n } = args;\n\n assignEnvVars(args);\n\n const mode = \"production\";\n\n const dirname = process.cwd();\n\n const baseConfig = getConnectBaseViteConfig({\n mode,\n dirname,\n });\n\n const previewConfig: InlineConfig = {\n build: {\n outDir,\n },\n preview: {\n cors,\n port,\n strictPort,\n host,\n open,\n },\n };\n\n const config = mergeConfig(baseConfig, previewConfig);\n\n const server = await preview(config);\n\n if (printUrls) server.printUrls();\n if (bindCLIShortcuts) server.bindCLIShortcuts({ print: true });\n}\n"],"names":[],"mappings":";;;;;;AAMA,eAAsB,kBAAkB,MAA0B;CAChE,MAAM,EACJ,QACA,iBACA,MACA,MACA,MACA,MACA,YACA,WACA,qBACE;AAEJ,eAAc,KAAK;CA0BnB,MAAM,SAAS,MAAM,QAFN,YAlBI,yBAAyB;EAC1C,MALW;EAMX,SAJc,QAAQ,KAAK;EAK5B,CAAC,EAEkC;EAClC,OAAO,EACL,QACD;EACD,SAAS;GACP;GACA;GACA;GACA;GACA;GACD;EACF,CAEoD,CAEjB;AAEpC,KAAI,UAAW,QAAO,WAAW;AACjC,KAAI,iBAAkB,QAAO,iBAAiB,EAAE,OAAO,MAAM,CAAC","debug_id":"445cdee7-0b65-5aa9-b920-450f0c4535ed"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"init-Cw_5H_Z1.mjs","sources":["../src/utils/validate-remote-drive.ts","../src/services/init.ts"],"sourcesContent":["import {\n createVetraDocument,\n getVetraDocuments,\n} from \"@powerhousedao/common/utils\";\n\n/**\n * Sets up a remote drive for initialization by validating and creating\n * a Vetra document if needed.\n * Returns true if setup succeeds, false if it should stop execution.\n */\nexport async function setupRemoteDrive(\n remoteDriveUrl: string,\n): Promise<boolean> {\n try {\n // Parse driveId from URL\n const driveId = remoteDriveUrl.split(\"/\").pop();\n\n if (!remoteDriveUrl || remoteDriveUrl.trim() === \"\") {\n console.error(\"❌ Remote drive URL is required\");\n return false;\n }\n\n // Construct GraphQL endpoint from base URL, preserving any subpath\n // prefix (e.g. when the reactor is served behind a proxy at /api/reactor).\n const url = new URL(remoteDriveUrl);\n const basePath = url.pathname.replace(/\\/d\\/[^/]+\\/?$/, \"\");\n const graphqlEndpoint = `${url.protocol}//${url.host}${basePath}/graphql`;\n\n let documents = await getVetraDocuments(graphqlEndpoint, driveId!);\n\n if (documents.length === 0) {\n console.log(\n \"No vetra package document found in the provided drive, creating one...\",\n );\n try {\n await createVetraDocument(graphqlEndpoint, driveId!, \"vetra-package\");\n\n // Re-fetch documents after creation\n documents = await getVetraDocuments(graphqlEndpoint, driveId!);\n\n if (documents.length === 0) {\n console.error(\n \"❌ Failed to create vetra package document in the remote drive\",\n );\n return false;\n }\n\n console.log(\"✅ Vetra package document created successfully\");\n } catch (createError) {\n console.error(\n \"❌ Failed to create vetra package document:\",\n createError,\n );\n return false;\n }\n }\n\n if (documents.length > 1) {\n console.warn(\n \"⚠️ Multiple vetra package documents were found in the provided remote drive, this might be an error in your remote drive\",\n );\n }\n\n const hasGithubUrl = documents.some((doc) => doc.githubUrl);\n\n if (hasGithubUrl) {\n console.error(\n \"❌ The remote drive provided already has been configured with a github url, please use the checkout command instead: ph checkout --remote-drive <remote drive url>\",\n );\n return false;\n }\n\n return true;\n } catch (error) {\n console.error(\"❌ Unable to fetch remote drive info:\", error);\n return false;\n }\n}\n","import { createProject } from \"@powerhousedao/codegen\";\nimport {\n handleMutuallyExclusiveOptions,\n parsePackageManager,\n parseTag,\n} from \"@powerhousedao/shared/clis\";\nimport chalk from \"chalk\";\nimport { kebabCase } from \"change-case\";\nimport enquirer from \"enquirer\";\nimport { clean, valid } from \"semver\";\nimport type { InitArgs } from \"../types.js\";\nimport { setupRemoteDrive } from \"../utils/validate-remote-drive.js\";\n\nexport async function startInit(args: InitArgs) {\n const {\n namePositional,\n nameOption,\n packageManager,\n npm,\n pnpm,\n yarn,\n bun,\n tag,\n version,\n dev,\n staging,\n remoteDrive,\n } = args;\n\n let name = namePositional ?? nameOption;\n if (!name) {\n const { prompt } = enquirer;\n\n const result = await prompt<{ name: string }>([\n {\n type: \"input\",\n name: \"name\",\n message: \"What is the project name?\",\n required: true,\n result: (value) => kebabCase(value),\n },\n ]);\n name = result.name;\n }\n if (!name) {\n throw new Error(\"You must provide a name for your project.\");\n }\n\n if (version !== undefined && !valid(clean(version))) {\n throw new Error(`Invalid version: ${version}`);\n }\n\n handleMutuallyExclusiveOptions(\n {\n tag,\n version,\n dev,\n staging,\n },\n \"versioning strategy\",\n );\n\n handleMutuallyExclusiveOptions(\n {\n npm,\n pnpm,\n yarn,\n bun,\n packageManager,\n },\n \"package manager\",\n );\n\n const parsedPackageManager =\n parsePackageManager({\n npm,\n pnpm,\n yarn,\n bun,\n packageManager,\n }) ?? \"npm\";\n\n const parsedTag = parseTag({\n tag,\n dev,\n staging,\n });\n\n try {\n if (remoteDrive) {\n console.log(chalk.blue(\"\\n⏳ Setting up remote drive...\\n\"));\n await setupRemoteDrive(remoteDrive);\n console.log(chalk.green(\"\\n✅ Remote drive set up.\"));\n }\n\n console.log(chalk.bold(\"\\n🚀 Initializing a new project...\\n\"));\n await createProject({\n ...args,\n name,\n packageManager: parsedPackageManager,\n tag: parsedTag,\n });\n\n if (remoteDrive) {\n console.log();\n console.log(\"To link your project to GitHub:\");\n console.log();\n console.log(\" 1. Create a new repository on GitHub\");\n console.log(` 2. cd ${name}`);\n console.log(\" 3. git add . && git commit -m 'Initial commit'\");\n console.log(\" 4. git remote add origin <your-github-url>\");\n console.log(` 5. git push -u origin main`);\n console.log();\n }\n } catch (error) {\n console.error(\"\\n❌ Failed to initialize project: \\n\");\n throw error;\n }\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;AAUA,eAAsB,iBACpB,gBACkB;AAClB,KAAI;EAEF,MAAM,UAAU,eAAe,MAAM,IAAI,CAAC,KAAK;AAE/C,MAAI,CAAC,kBAAkB,eAAe,MAAM,KAAK,IAAI;AACnD,WAAQ,MAAM,iCAAiC;AAC/C,UAAO;;EAKT,MAAM,MAAM,IAAI,IAAI,eAAe;EACnC,MAAM,WAAW,IAAI,SAAS,QAAQ,kBAAkB,GAAG;EAC3D,MAAM,kBAAkB,GAAG,IAAI,SAAS,IAAI,IAAI,OAAO,SAAS;EAEhE,IAAI,YAAY,MAAM,kBAAkB,iBAAiB,QAAS;AAElE,MAAI,UAAU,WAAW,GAAG;AAC1B,WAAQ,IACN,yEACD;AACD,OAAI;AACF,UAAM,oBAAoB,iBAAiB,SAAU,gBAAgB;AAGrE,gBAAY,MAAM,kBAAkB,iBAAiB,QAAS;AAE9D,QAAI,UAAU,WAAW,GAAG;AAC1B,aAAQ,MACN,gEACD;AACD,YAAO;;AAGT,YAAQ,IAAI,gDAAgD;YACrD,aAAa;AACpB,YAAQ,MACN,8CACA,YACD;AACD,WAAO;;;AAIX,MAAI,UAAU,SAAS,EACrB,SAAQ,KACN,4HACD;AAKH,MAFqB,UAAU,MAAM,QAAQ,IAAI,UAAU,EAEzC;AAChB,WAAQ,MACN,oKACD;AACD,UAAO;;AAGT,SAAO;UACA,OAAO;AACd,UAAQ,MAAM,wCAAwC,MAAM;AAC5D,SAAO;;;;;AC9DX,eAAsB,UAAU,MAAgB;CAC9C,MAAM,EACJ,gBACA,YACA,gBACA,KACA,MACA,MACA,KACA,KACA,SACA,KACA,SACA,gBACE;CAEJ,IAAI,OAAO,kBAAkB;AAC7B,KAAI,CAAC,MAAM;EACT,MAAM,EAAE,WAAW;AAWnB,UATe,MAAM,OAAyB,CAC5C;GACE,MAAM;GACN,MAAM;GACN,SAAS;GACT,UAAU;GACV,SAAS,UAAU,UAAU,MAAM;GACpC,CACF,CAAC,EACY;;AAEhB,KAAI,CAAC,KACH,OAAM,IAAI,MAAM,4CAA4C;AAG9D,KAAI,YAAY,KAAA,KAAa,CAAC,MAAM,MAAM,QAAQ,CAAC,CACjD,OAAM,IAAI,MAAM,oBAAoB,UAAU;AAGhD,gCACE;EACE;EACA;EACA;EACA;EACD,EACD,sBACD;AAED,gCACE;EACE;EACA;EACA;EACA;EACA;EACD,EACD,kBACD;CAED,MAAM,uBACJ,oBAAoB;EAClB;EACA;EACA;EACA;EACA;EACD,CAAC,IAAI;CAER,MAAM,YAAY,SAAS;EACzB;EACA;EACA;EACD,CAAC;AAEF,KAAI;AACF,MAAI,aAAa;AACf,WAAQ,IAAI,MAAM,KAAK,mCAAmC,CAAC;AAC3D,SAAM,iBAAiB,YAAY;AACnC,WAAQ,IAAI,MAAM,MAAM,2BAA2B,CAAC;;AAGtD,UAAQ,IAAI,MAAM,KAAK,uCAAuC,CAAC;AAC/D,QAAM,cAAc;GAClB,GAAG;GACH;GACA,gBAAgB;GAChB,KAAK;GACN,CAAC;AAEF,MAAI,aAAa;AACf,WAAQ,KAAK;AACb,WAAQ,IAAI,kCAAkC;AAC9C,WAAQ,KAAK;AACb,WAAQ,IAAI,yCAAyC;AACrD,WAAQ,IAAI,WAAW,OAAO;AAC9B,WAAQ,IAAI,mDAAmD;AAC/D,WAAQ,IAAI,+CAA+C;AAC3D,WAAQ,IAAI,+BAA+B;AAC3C,WAAQ,KAAK;;UAER,OAAO;AACd,UAAQ,MAAM,uCAAuC;AACrD,QAAM","debug_id":"1835da68-34a4-5f33-9a4c-08c3b7cb5d9c"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"vetra-yCsUKy_u.mjs","sources":["../src/utils/configure-vetra-github-url.ts","../src/utils/resolve-switchboard-port.ts","../src/services/vetra.ts"],"sourcesContent":["import {\n createVetraDocument,\n getVetraDocuments,\n setPackageGithubUrl,\n} from \"@powerhousedao/common/utils\";\nimport { red } from \"colorette\";\nimport { execSync } from \"node:child_process\";\nimport { createInterface } from \"node:readline\";\n\n/**\n * Get git remote URL (origin)\n * @returns Git remote URL or null if not configured\n */\nfunction getGitRemoteUrl(): string | null {\n try {\n const url = execSync(\"git remote get-url origin\", {\n encoding: \"utf-8\",\n stdio: [\"pipe\", \"pipe\", \"pipe\"],\n }).trim();\n return url || null;\n } catch {\n return null;\n }\n}\n\n/**\n * Prompt user to enter a custom GitHub URL\n */\nasync function promptForCustomUrl(): Promise<string | null> {\n return new Promise((resolve) => {\n const rl = createInterface({\n input: process.stdin,\n output: process.stdout,\n });\n\n process.stdout.write(\"\\nEnter GitHub URL (or press Enter to skip): \");\n\n rl.on(\"line\", (answer: string) => {\n rl.close();\n const url = answer.trim();\n resolve(url || null);\n });\n });\n}\n\n/**\n * Prompt yes/no question\n */\nasync function promptYesNo(question: string): Promise<boolean> {\n return new Promise((resolve) => {\n const rl = createInterface({\n input: process.stdin,\n output: process.stdout,\n });\n\n process.stdout.write(`\\n${question} (y/n): `);\n\n rl.on(\"line\", (answer: string) => {\n rl.close();\n const response = answer.trim().toLowerCase();\n resolve(response === \"y\" || response === \"yes\");\n });\n });\n}\n\n/**\n * Prompt user to select or enter GitHub URL\n * @param gitRemoteUrl - Git remote URL if available\n * @returns Selected URL or null if skipped\n */\nasync function promptForGithubUrl(\n gitRemoteUrl: string | null,\n): Promise<string | null> {\n return new Promise((resolve) => {\n const rl = createInterface({\n input: process.stdin,\n output: process.stdout,\n });\n\n console.log(\"\\n\" + \"=\".repeat(50));\n console.log(\"🔍 Vetra Package Configuration\");\n console.log(\"=\".repeat(50));\n console.log(\n \"\\nWe detected a Vetra package document in your remote drive without a GitHub URL configured.\",\n );\n console.log(\"\\nWould you like to configure the GitHub URL now?\");\n\n if (gitRemoteUrl) {\n console.log(`\\nGit remote URL detected: ${gitRemoteUrl}`);\n console.log(\"\\nOptions:\");\n console.log(\"1. Use detected URL\");\n console.log(\"2. Enter a different URL\");\n console.log(\"3. Skip configuration\");\n\n process.stdout.write(\"\\nSelect an option (1-3): \");\n\n const handleAnswer = (answer: string) => {\n const choice = answer.trim();\n\n if (choice === \"1\") {\n rl.close();\n resolve(gitRemoteUrl);\n } else if (choice === \"2\") {\n rl.close();\n promptForCustomUrl()\n .then(resolve)\n .catch(() => resolve(null));\n } else if (choice === \"3\") {\n rl.close();\n resolve(null);\n } else {\n process.stdout.write(\"Invalid choice. Select an option (1-3): \");\n }\n };\n\n rl.on(\"line\", handleAnswer);\n } else {\n console.log(\"\\nNo git remote URL detected.\");\n console.log(\"\\nOptions:\");\n console.log(\"1. Enter GitHub URL manually\");\n console.log(\"2. Skip configuration\");\n\n process.stdout.write(\"\\nSelect an option (1-2): \");\n\n const handleAnswer = (answer: string) => {\n const choice = answer.trim();\n\n if (choice === \"1\") {\n rl.close();\n promptForCustomUrl()\n .then(resolve)\n .catch(() => resolve(null));\n } else if (choice === \"2\") {\n rl.close();\n resolve(null);\n } else {\n process.stdout.write(\"Invalid choice. Select an option (1-2): \");\n }\n };\n\n rl.on(\"line\", handleAnswer);\n }\n });\n}\n\n/**\n * Set git remote URL (origin)\n */\nfunction setGitRemoteUrl(url: string): void {\n try {\n execSync(`git remote add origin ${url}`, {\n stdio: \"inherit\",\n });\n console.log(`✅ Git remote origin set to: ${url}`);\n } catch {\n try {\n execSync(`git remote set-url origin ${url}`, {\n stdio: \"inherit\",\n });\n console.log(`✅ Git remote origin updated to: ${url}`);\n } catch {\n console.error(red(`❌ Failed to set git remote URL`));\n }\n }\n}\n\n/**\n * Validates documents and returns the target document to use\n * Warns if multiple documents found\n */\nfunction validateAndSelectDocument<T>(documents: T[]): T | null {\n if (documents.length === 0) {\n return null;\n }\n\n if (documents.length > 1) {\n console.warn(\n `⚠️ Warning: Multiple Vetra documents found (${documents.length}). Using first document.`,\n );\n }\n\n return documents[0];\n}\n\nasync function applyGithubUrlConfiguration(\n graphqlEndpoint: string,\n vetraDriveId: string,\n documentId: string,\n selectedUrl: string,\n shouldSetRemote: boolean,\n): Promise<void> {\n // Set package GitHub URL\n await setPackageGithubUrl(\n graphqlEndpoint,\n vetraDriveId,\n documentId,\n selectedUrl,\n );\n\n console.log(`✅ GitHub URL configured: ${selectedUrl}`);\n\n // Set git remote URL if requested\n if (shouldSetRemote) {\n setGitRemoteUrl(selectedUrl);\n }\n}\n\nfunction logVerbose(message: string, verbose?: boolean): void {\n if (verbose) {\n console.log(message);\n }\n}\n\n/**\n * Sleep for a specified number of milliseconds\n */\nexport function sleep(ms: number): Promise<void> {\n return new Promise((resolve) => setTimeout(resolve, ms));\n}\n\n/**\n * Configure GitHub URL for Vetra documents\n * @param switchboardPort - Port where switchboard is running\n * @param vetraDriveUrl - Remote drive URL\n * @param verbose - Enable verbose logging\n */\nexport async function configureVetraGithubUrl(\n switchboardPort: number,\n vetraDriveUrl: string,\n verbose?: boolean,\n): Promise<void> {\n logVerbose(\"Checking GitHub URL configuration...\", verbose);\n\n try {\n const graphqlEndpoint = `http://localhost:${switchboardPort}/graphql`;\n const vetraDriveId = vetraDriveUrl.split(\"/\").pop();\n if (!vetraDriveId) {\n throw new Error(\"Invalid vetraDriveUrl: unable to extract drive ID\");\n }\n\n const documents = await getVetraDocuments(graphqlEndpoint, vetraDriveId);\n\n // Skip if already configured\n if (documents.some((doc) => doc.githubUrl)) {\n logVerbose(\"GitHub URL already configured, skipping setup\", verbose);\n return;\n }\n\n // Get or create target document\n let targetDocumentId: string;\n const targetDocument = validateAndSelectDocument(documents);\n\n // Collect user input\n const gitRemoteUrl = getGitRemoteUrl();\n const selectedUrl = await promptForGithubUrl(gitRemoteUrl);\n\n if (!selectedUrl) {\n logVerbose(\"GitHub URL configuration skipped\", verbose);\n return;\n }\n\n let shouldSetRemote = false;\n if (selectedUrl !== gitRemoteUrl && !gitRemoteUrl) {\n shouldSetRemote = await promptYesNo(\"Set this as your git remote URL?\");\n }\n\n if (!targetDocument) {\n logVerbose(\"No Vetra documents found, creating new document...\", verbose);\n\n targetDocumentId = await createVetraDocument(\n graphqlEndpoint,\n vetraDriveId,\n \"vetra-package\",\n );\n\n logVerbose(`Created new document: ${targetDocumentId}`, verbose);\n } else {\n targetDocumentId = targetDocument.id;\n }\n\n await applyGithubUrlConfiguration(\n graphqlEndpoint,\n vetraDriveId,\n targetDocumentId,\n selectedUrl,\n shouldSetRemote,\n );\n } catch (error) {\n console.error(\n red(\n `⚠️ GitHub URL configuration failed: ${error instanceof Error ? error.message : String(error)}`,\n ),\n );\n logVerbose(String(error), verbose);\n }\n}\n","import { isPortAvailable } from \"@powerhousedao/switchboard/server\";\nimport { yellow } from \"colorette\";\n\nconst MAX_FALLBACK_ATTEMPTS = 20;\n\nfunction isInteractive(): boolean {\n return Boolean(process.stdin.isTTY) && !process.env.CI;\n}\n\nasync function findFreePort(start: number): Promise<number | null> {\n for (let i = 0; i < MAX_FALLBACK_ATTEMPTS; i++) {\n const candidate = start + i;\n if (await isPortAvailable(candidate)) return candidate;\n }\n return null;\n}\n\n/**\n * Resolve the port switchboard should bind to. If the requested port is free,\n * returns it unchanged. If it's in use, walks forward for the next free port\n * and — in an interactive terminal — asks the user to confirm the fallback.\n * In CI / piped contexts the fallback is applied automatically so scripts\n * don't hang on an unanswered prompt.\n *\n * Throws a process.exit(1) when the user declines the prompt or when no free\n * port is available in the search window.\n */\nexport async function resolveSwitchboardPort(\n requested: number,\n): Promise<number> {\n if (await isPortAvailable(requested)) return requested;\n\n const candidate = await findFreePort(requested + 1);\n if (candidate === null) {\n console.error(\n `Port ${requested} is in use and no free port was found in the range ${requested}-${requested + MAX_FALLBACK_ATTEMPTS - 1}.`,\n );\n process.exit(1);\n }\n\n if (!isInteractive()) {\n console.log(\n yellow(\n `Port ${requested} is in use. Falling back to port ${candidate} (non-interactive; skipping confirmation).`,\n ),\n );\n return candidate;\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: `Port ${requested} is in use. Use port ${candidate} instead?`,\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. Free port ${requested} or pass --switchboard-port <port> to choose a different port.`,\n );\n process.exit(1);\n }\n\n return candidate;\n}\n","import type { VetraProcessorConfigType } from \"@powerhousedao/config\";\nimport { VETRA_PROCESSOR_CONFIG_KEY } from \"@powerhousedao/config\";\nimport type { IReactorClient } from \"@powerhousedao/reactor\";\nimport { addDefaultDrive } from \"@powerhousedao/switchboard/utils\";\nimport { blue, green, red, yellow, type Color } from \"colorette\";\nimport type { ILogger } from \"document-model\";\nimport { childLogger, setLogLevel } from \"document-model\";\nimport { createLogger } from \"vite\";\nimport type { VetraArgs } from \"../types.js\";\nimport { generateProjectDriveId } from \"../utils.js\";\nimport {\n configureVetraGithubUrl,\n sleep,\n} from \"../utils/configure-vetra-github-url.js\";\nimport { resolveSwitchboardPort } from \"../utils/resolve-switchboard-port.js\";\nimport { runConnectStudio } from \"./connect-studio.js\";\nimport { startSwitchboard } from \"./switchboard.js\";\n\nconst VETRA_DRIVE_NAME = \"vetra\";\n\nconst getDefaultVetraUrl = (port: number) =>\n `http://localhost:${port}/d/${generateProjectDriveId(VETRA_DRIVE_NAME)}`;\n\nconst getDriveId = (driveUrl: string | undefined): string =>\n driveUrl?.split(\"/\").pop() ?? generateProjectDriveId(VETRA_DRIVE_NAME);\n\nfunction createViteLogger(color: Color) {\n const customLogger = createLogger(\"info\");\n const loggerInfo = customLogger.info.bind(customLogger);\n customLogger.info = (msg, options) => {\n loggerInfo(color(msg), options);\n };\n const loggerWarn = customLogger.warn.bind(customLogger);\n customLogger.warn = (msg, options) => {\n loggerWarn(yellow(msg), options);\n };\n const loggerError = customLogger.error.bind(customLogger);\n customLogger.error = (msg, options) => {\n loggerError(red(msg), options);\n };\n\n const loggerWarnOnce = customLogger.warnOnce.bind(customLogger);\n customLogger.warnOnce = (msg, options) => {\n loggerWarnOnce(yellow(msg), options);\n };\n return customLogger;\n}\n\nasync function startVetraPreviewDrive(\n reactor: IReactorClient,\n port: number,\n verbose?: boolean,\n): Promise<string> {\n const previewDriveId = generateProjectDriveId(\"preview\");\n\n const previewDrive = {\n id: previewDriveId,\n slug: previewDriveId,\n global: {\n name: \"Vetra Preview\",\n icon: \"https://azure-elderly-tortoise-212.mypinata.cloud/ipfs/bafkreifddkbopiyvcirf7vaqar74th424r5phlxkdxniirdyg3qgu2ajha\",\n nodes: [],\n },\n local: {\n availableOffline: true,\n listeners: [],\n sharingType: \"public\" as const,\n triggers: [],\n },\n };\n\n const driveUrl = await addDefaultDrive(reactor, previewDrive, port);\n\n if (verbose) {\n console.log(blue(`Vetra Switchboard: Preview drive: ${driveUrl}`));\n }\n return driveUrl;\n}\nasync function startLocalVetraSwitchboard(args: VetraArgs, logger?: ILogger) {\n const {\n connectPort,\n switchboardPort,\n dev,\n packages,\n disableLocalPackages,\n debug,\n httpsKeyFile,\n httpsCertFile,\n remoteDrive,\n interactive,\n watch,\n verbose,\n } = args;\n\n // Convert single remote drive to array if provided\n const remoteDrives = remoteDrive ? [remoteDrive] : [];\n\n const vetraProcessorConfig: VetraProcessorConfigType = {\n interactive,\n driveUrl: remoteDrive ?? getDefaultVetraUrl(connectPort),\n driveId: getDriveId(remoteDrive),\n };\n\n const processorConfig = new Map<string, unknown>();\n processorConfig.set(VETRA_PROCESSOR_CONFIG_KEY, vetraProcessorConfig);\n\n const vetraDriveId = generateProjectDriveId(VETRA_DRIVE_NAME);\n\n // When the user didn't opt into strict-port semantics, check for a port\n // conflict up front and ask for confirmation before binding a fallback.\n // Doing this in the CLI layer keeps the interactive prompt out of the\n // switchboard server package and aligns with the existing prerelease-tag\n // confirmation flow in `ph publish`.\n const resolvedSwitchboardPort = args.strictPort\n ? switchboardPort\n : await resolveSwitchboardPort(switchboardPort);\n\n try {\n const switchboard = await startSwitchboard(\n {\n ...args,\n useVetraDrive: true, // Use Vetra drive instead of Powerhouse drive\n mcp: true,\n port: resolvedSwitchboardPort,\n // We've already probed and (when interactive) confirmed the port with\n // the user, so keep the server from running its own fallback on top.\n strictPort: true,\n dev,\n packages,\n remoteDrives,\n vetraDriveId,\n disableLocalPackages,\n debug,\n httpsKeyFile,\n httpsCertFile,\n processorConfig,\n basePath: undefined,\n keypairPath: undefined,\n dbPath: args.dbPath,\n useIdentity: undefined,\n migrate: undefined,\n migrateStatus: undefined,\n reset: undefined,\n yes: undefined,\n requireIdentity: undefined,\n },\n logger,\n );\n\n const actualSwitchboardPort = switchboard.port;\n\n // Add preview drive (only in watch mode)\n let previewDriveUrl: string | null = null;\n if (watch) {\n try {\n previewDriveUrl = await startVetraPreviewDrive(\n switchboard.reactor,\n actualSwitchboardPort,\n verbose,\n );\n } catch (error) {\n console.error(error);\n }\n }\n\n if (verbose) {\n console.log(blue(`Vetra Switchboard: Started successfully`));\n if (remoteDrive) {\n console.log(\n blue(`Vetra Switchboard: Syncing with remote drive: ${remoteDrive}`),\n );\n }\n } else {\n console.log();\n console.log(\n blue(\n `Vetra Switchboard: http://localhost:${actualSwitchboardPort}/graphql`,\n ),\n );\n console.log(blue(` ➜ Drive URL: ${switchboard.defaultDriveUrl}`));\n if (previewDriveUrl) {\n console.log(blue(` ➜ Preview Drive URL: ${previewDriveUrl}`));\n }\n }\n return {\n driveUrl: switchboard.defaultDriveUrl || \"\",\n previewDriveUrl: previewDriveUrl,\n switchboardPort: actualSwitchboardPort,\n };\n } catch (error) {\n console.error(\n red(\n `Vetra Switchboard: ${error instanceof Error ? error.message : String(error)}`,\n ),\n );\n throw error instanceof Error ? error : new Error(String(error));\n }\n}\n\nexport async function startVetra(args: VetraArgs) {\n const {\n connectPort,\n verbose,\n remoteDrive,\n disableConnect,\n debug,\n httpsCertFile,\n httpsKeyFile,\n disableLocalPackages,\n host,\n open,\n cors,\n strictPort,\n printUrls,\n bindCLIShortcuts,\n watchTimeout,\n } = args;\n\n const switchboardLogger = childLogger([\"vetra\", \"switchboard\"]);\n\n try {\n // Set default log level to info if not already specified\n if (!process.env.LOG_LEVEL) {\n setLogLevel(\"info\");\n }\n\n if (verbose) {\n switchboardLogger.info(\"Starting Vetra Switchboard...\");\n if (remoteDrive) {\n const source = remoteDrive\n ? \"command line argument\"\n : \"powerhouse.config.json\";\n switchboardLogger.info(`Using vetraUrl from ${source}: ${remoteDrive}`);\n }\n }\n const switchboardResult = await startLocalVetraSwitchboard(\n {\n ...args,\n dev: true, // Vetra always runs in dev mode to load local packages\n httpsKeyFile,\n httpsCertFile,\n disableLocalPackages,\n debug,\n },\n switchboardLogger,\n );\n const driveUrl: string = switchboardResult.driveUrl || remoteDrive || \"\";\n const previewDriveUrl = switchboardResult.previewDriveUrl;\n const actualSwitchboardPort = switchboardResult.switchboardPort;\n\n // Configure GitHub URL if remote drive is set\n if (remoteDrive) {\n // give some time for the drive to process initial strands\n await sleep(3000);\n\n await configureVetraGithubUrl(\n actualSwitchboardPort,\n remoteDrive,\n verbose,\n );\n\n // give some time for the user to read log messages\n await sleep(2000);\n }\n\n if (verbose) {\n console.log(\"Starting Codegen Reactor...\");\n }\n\n // Start Connect pointing to the drive (unless disabled)\n if (!disableConnect) {\n if (verbose) {\n console.log(\"Starting Connect...\");\n const drives = previewDriveUrl\n ? `${driveUrl}, ${previewDriveUrl}`\n : driveUrl;\n console.log(` ➜ Connect will use drives: ${drives}`);\n }\n console.log();\n console.log(green(`Vetra Connect: http://localhost:${connectPort}`));\n\n const customViteLogger = createViteLogger(green);\n\n await runConnectStudio(\n {\n ...args,\n defaultDrivesUrl: previewDriveUrl\n ? [driveUrl, previewDriveUrl].join(\",\")\n : driveUrl,\n drivesPreserveStrategy: \"preserve-all\",\n port: connectPort,\n disableLocalPackages,\n debug,\n host: host,\n open: open,\n cors: cors,\n strictPort: strictPort,\n printUrls: printUrls,\n bindCLIShortcuts: bindCLIShortcuts,\n watchTimeout: watchTimeout,\n },\n customViteLogger,\n );\n }\n } catch (error) {\n console.error(error);\n }\n}\n"],"names":["startSwitchboard"],"mappings":"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","debug_id":"e6ca579f-2bd8-58c9-b5c8-e32c226e24de"}
|