@powerhousedao/ph-cli 6.0.2-staging.9 → 6.1.0-staging.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/README.md +32 -30
- package/dist/cli.mjs +124 -24
- package/dist/cli.mjs.map +1 -1
- package/dist/generate-all-WiQQo-Nz.mjs +30 -0
- package/dist/generate-all-WiQQo-Nz.mjs.map +1 -0
- package/dist/{generate-app-KE0rbE-b.mjs → generate-app-DdmOt6ID.mjs} +15 -5
- package/dist/generate-app-DdmOt6ID.mjs.map +1 -0
- package/dist/generate-document-model-DQ5PVeIH.mjs +34 -0
- package/dist/generate-document-model-DQ5PVeIH.mjs.map +1 -0
- package/dist/{generate-editor-DmSzWm3W.mjs → generate-editor-DtzVAs6x.mjs} +15 -5
- package/dist/generate-editor-DtzVAs6x.mjs.map +1 -0
- package/dist/{generate-processor-B-fChg4W.mjs → generate-processor-FGtN6BVY.mjs} +15 -5
- package/dist/generate-processor-FGtN6BVY.mjs.map +1 -0
- package/dist/{generate-subgraph-C6dWIQzP.mjs → generate-subgraph-BrzmW_sj.mjs} +15 -5
- package/dist/generate-subgraph-BrzmW_sj.mjs.map +1 -0
- package/dist/{switchboard-BsdbF-rL.mjs → switchboard-CERuSM8r.mjs} +3 -3
- package/dist/{switchboard-BsdbF-rL.mjs.map → switchboard-CERuSM8r.mjs.map} +1 -1
- package/dist/switchboard-ChH1PMaE.mjs +4 -0
- package/dist/switchboard-reset-1YcJEVqc.mjs +87 -0
- package/dist/switchboard-reset-1YcJEVqc.mjs.map +1 -0
- package/dist/{vetra-BUcRFup0.mjs → vetra-yCsUKy_u.mjs} +7 -5
- package/dist/{vetra-BUcRFup0.mjs.map → vetra-yCsUKy_u.mjs.map} +1 -1
- package/package.json +13 -10
- package/dist/generate-all-Cj8zjFhN.mjs +0 -15
- package/dist/generate-all-Cj8zjFhN.mjs.map +0 -1
- package/dist/generate-app-KE0rbE-b.mjs.map +0 -1
- package/dist/generate-document-model-Cut44i6D.mjs +0 -24
- package/dist/generate-document-model-Cut44i6D.mjs.map +0 -1
- package/dist/generate-editor-DmSzWm3W.mjs.map +0 -1
- package/dist/generate-processor-B-fChg4W.mjs.map +0 -1
- package/dist/generate-subgraph-C6dWIQzP.mjs.map +0 -1
- package/dist/switchboard-GTBlxiJZ.mjs +0 -4
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generate-processor-FGtN6BVY.mjs","sources":["../src/services/generate-processor.ts"],"sourcesContent":["import {\n detectFeatures,\n generateAllProcessors,\n generateProcessor,\n syncFeatureDependencies,\n} from \"@powerhousedao/codegen\";\nimport {\n buildTsMorphProject,\n getProcessorMetadata,\n} from \"@powerhousedao/codegen/utils\";\nimport {\n extractProcessorDocuments,\n generateProcessorFromDocument,\n getDocument,\n saveSpec,\n} from \"@powerhousedao/vetra/codegen\";\nimport type { ProcessorModuleDocument } from \"@powerhousedao/vetra/document-models/processor-module\";\nimport { dirname } from \"node:path\";\nimport type { GenerateProcessorArgs } from \"../types.js\";\n\nexport async function startGenerateProcessor(\n args: GenerateProcessorArgs,\n projectDir: string,\n) {\n const {\n name: processorName,\n type: processorType,\n apps: processorApps,\n documentTypes,\n document,\n dir,\n all,\n extract,\n debug,\n } = args;\n if (debug) {\n console.log({ args });\n }\n const project = buildTsMorphProject(projectDir);\n if (extract) {\n const docs = extractProcessorDocuments(project);\n for (const doc of docs) {\n const path = await saveSpec(doc, projectDir);\n console.log(`Wrote ${path}`);\n }\n return;\n }\n if (all) {\n await generateAllProcessors(project);\n } else if (document) {\n const doc = (await getDocument(document)) as ProcessorModuleDocument;\n await generateProcessorFromDocument(doc, project);\n } else if (processorName) {\n await generateProcessor(\n {\n processorName,\n processorApps,\n processorType,\n documentTypes,\n },\n project,\n );\n } else if (dir) {\n const processorDirName = dirname(dir);\n const processorArgs = getProcessorMetadata(project, processorDirName);\n await generateProcessor(processorArgs, project);\n } else {\n console.log(\n \"Please specify one of `name`, `document`, `dir`, `all`, or `extract`.\",\n );\n return;\n }\n await project.save();\n await syncFeatureDependencies(detectFeatures(projectDir), projectDir);\n}\n"],"names":[],"mappings":";;;;;;;AAoBA,eAAsB,uBACpB,MACA,YACA;CACA,MAAM,EACJ,MAAM,eACN,MAAM,eACN,MAAM,eACN,eACA,UACA,KACA,KACA,SACA,UACE;AACJ,KAAI,MACF,SAAQ,IAAI,EAAE,MAAM,CAAC;CAEvB,MAAM,UAAU,oBAAoB,WAAW;AAC/C,KAAI,SAAS;EACX,MAAM,OAAO,0BAA0B,QAAQ;AAC/C,OAAK,MAAM,OAAO,MAAM;GACtB,MAAM,OAAO,MAAM,SAAS,KAAK,WAAW;AAC5C,WAAQ,IAAI,SAAS,OAAO;;AAE9B;;AAEF,KAAI,IACF,OAAM,sBAAsB,QAAQ;UAC3B,SAET,OAAM,8BADO,MAAM,YAAY,SAAS,EACC,QAAQ;UACxC,cACT,OAAM,kBACJ;EACE;EACA;EACA;EACA;EACD,EACD,QACD;UACQ,IAGT,OAAM,kBADgB,qBAAqB,SADlB,QAAQ,IAAI,CACgC,EAC9B,QAAQ;MAC1C;AACL,UAAQ,IACN,wEACD;AACD;;AAEF,OAAM,QAAQ,MAAM;AACpB,OAAM,wBAAwB,eAAe,WAAW,EAAE,WAAW","debug_id":"b28d8f47-ef48-5bf9-bd2e-d0f13fa5e0e4"}
|
|
@@ -1,21 +1,31 @@
|
|
|
1
1
|
|
|
2
|
-
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="
|
|
2
|
+
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="5b43e7af-aa94-5748-a185-200bc7bd475a")}catch(e){}}();
|
|
3
3
|
import { dirname } from "node:path";
|
|
4
4
|
import { detectFeatures, generateAllSubgraphs, generateSubgraph, syncFeatureDependencies } from "@powerhousedao/codegen";
|
|
5
5
|
import { buildTsMorphProject, getSubgraphMetadata } from "@powerhousedao/codegen/utils";
|
|
6
|
+
import { extractSubgraphDocuments, generateSubgraphFromDocument, getDocument, saveSpec } from "@powerhousedao/vetra/codegen";
|
|
6
7
|
//#region src/services/generate-subgraph.ts
|
|
7
8
|
async function startGenerateSubgraph(args, projectDir) {
|
|
8
|
-
const { name, dir, all, debug } = args;
|
|
9
|
+
const { name, document, dir, all, extract, debug } = args;
|
|
9
10
|
if (debug) console.log({ args });
|
|
10
11
|
const project = buildTsMorphProject(projectDir);
|
|
12
|
+
if (extract) {
|
|
13
|
+
const docs = extractSubgraphDocuments(project);
|
|
14
|
+
for (const doc of docs) {
|
|
15
|
+
const path = await saveSpec(doc, projectDir);
|
|
16
|
+
console.log(`Wrote ${path}`);
|
|
17
|
+
}
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
11
20
|
if (all) await generateAllSubgraphs(project);
|
|
21
|
+
else if (document) await generateSubgraphFromDocument(await getDocument(document), project);
|
|
12
22
|
else if (name) await generateSubgraph(name, project);
|
|
13
23
|
else if (dir) {
|
|
14
24
|
const { subgraphName } = getSubgraphMetadata(project, dirname(dir));
|
|
15
25
|
if (!subgraphName) throw new Error(`Failed to get data for subgraph in dir "${dir}"`);
|
|
16
26
|
await generateSubgraph(subgraphName, project);
|
|
17
27
|
} else {
|
|
18
|
-
console.log("Please specify
|
|
28
|
+
console.log("Please specify one of `name`, `document`, `dir`, `all`, or `extract`.");
|
|
19
29
|
return;
|
|
20
30
|
}
|
|
21
31
|
await project.save();
|
|
@@ -24,5 +34,5 @@ async function startGenerateSubgraph(args, projectDir) {
|
|
|
24
34
|
//#endregion
|
|
25
35
|
export { startGenerateSubgraph };
|
|
26
36
|
|
|
27
|
-
//# sourceMappingURL=generate-subgraph-
|
|
28
|
-
//# debugId=
|
|
37
|
+
//# sourceMappingURL=generate-subgraph-BrzmW_sj.mjs.map
|
|
38
|
+
//# debugId=5b43e7af-aa94-5748-a185-200bc7bd475a
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generate-subgraph-BrzmW_sj.mjs","sources":["../src/services/generate-subgraph.ts"],"sourcesContent":["import {\n detectFeatures,\n generateAllSubgraphs,\n generateSubgraph,\n syncFeatureDependencies,\n} from \"@powerhousedao/codegen\";\nimport {\n buildTsMorphProject,\n getSubgraphMetadata,\n} from \"@powerhousedao/codegen/utils\";\nimport {\n extractSubgraphDocuments,\n generateSubgraphFromDocument,\n getDocument,\n saveSpec,\n} from \"@powerhousedao/vetra/codegen\";\nimport type { SubgraphModuleDocument } from \"@powerhousedao/vetra/document-models/subgraph-module\";\nimport { dirname } from \"node:path\";\nimport type { GenerateSubgraphArgs } from \"../types.js\";\n\nexport async function startGenerateSubgraph(\n args: GenerateSubgraphArgs,\n projectDir: string,\n) {\n const { name, document, dir, all, extract, debug } = args;\n if (debug) {\n console.log({ args });\n }\n const project = buildTsMorphProject(projectDir);\n if (extract) {\n const docs = extractSubgraphDocuments(project);\n for (const doc of docs) {\n const path = await saveSpec(doc, projectDir);\n console.log(`Wrote ${path}`);\n }\n return;\n }\n if (all) {\n await generateAllSubgraphs(project);\n } else if (document) {\n const doc = (await getDocument(document)) as SubgraphModuleDocument;\n await generateSubgraphFromDocument(doc, project);\n } else if (name) {\n await generateSubgraph(name, project);\n } else if (dir) {\n const { subgraphName } = getSubgraphMetadata(project, dirname(dir));\n if (!subgraphName) {\n throw new Error(`Failed to get data for subgraph in dir \"${dir}\"`);\n }\n await generateSubgraph(subgraphName, project);\n } else {\n console.log(\n \"Please specify one of `name`, `document`, `dir`, `all`, or `extract`.\",\n );\n return;\n }\n await project.save();\n await syncFeatureDependencies(detectFeatures(projectDir), projectDir);\n}\n"],"names":[],"mappings":";;;;;;;AAoBA,eAAsB,sBACpB,MACA,YACA;CACA,MAAM,EAAE,MAAM,UAAU,KAAK,KAAK,SAAS,UAAU;AACrD,KAAI,MACF,SAAQ,IAAI,EAAE,MAAM,CAAC;CAEvB,MAAM,UAAU,oBAAoB,WAAW;AAC/C,KAAI,SAAS;EACX,MAAM,OAAO,yBAAyB,QAAQ;AAC9C,OAAK,MAAM,OAAO,MAAM;GACtB,MAAM,OAAO,MAAM,SAAS,KAAK,WAAW;AAC5C,WAAQ,IAAI,SAAS,OAAO;;AAE9B;;AAEF,KAAI,IACF,OAAM,qBAAqB,QAAQ;UAC1B,SAET,OAAM,6BADO,MAAM,YAAY,SAAS,EACA,QAAQ;UACvC,KACT,OAAM,iBAAiB,MAAM,QAAQ;UAC5B,KAAK;EACd,MAAM,EAAE,iBAAiB,oBAAoB,SAAS,QAAQ,IAAI,CAAC;AACnE,MAAI,CAAC,aACH,OAAM,IAAI,MAAM,2CAA2C,IAAI,GAAG;AAEpE,QAAM,iBAAiB,cAAc,QAAQ;QACxC;AACL,UAAQ,IACN,wEACD;AACD;;AAEF,OAAM,QAAQ,MAAM;AACpB,OAAM,wBAAwB,eAAe,WAAW,EAAE,WAAW","debug_id":"5b43e7af-aa94-5748-a185-200bc7bd475a"}
|
|
@@ -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]="2b112076-440d-59d6-ac2e-84dc0ffb3cfd")}catch(e){}}();
|
|
3
3
|
import path from "node:path";
|
|
4
4
|
import { startSwitchboard } from "@powerhousedao/switchboard/server";
|
|
5
5
|
//#region src/services/switchboard.ts
|
|
@@ -71,5 +71,5 @@ async function startSwitchboard$1(options, logger) {
|
|
|
71
71
|
//#endregion
|
|
72
72
|
export { startSwitchboard$1 as n, defaultSwitchboardOptions as t };
|
|
73
73
|
|
|
74
|
-
//# sourceMappingURL=switchboard-
|
|
75
|
-
//# debugId=
|
|
74
|
+
//# sourceMappingURL=switchboard-CERuSM8r.mjs.map
|
|
75
|
+
//# debugId=2b112076-440d-59d6-ac2e-84dc0ffb3cfd
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"switchboard-
|
|
1
|
+
{"version":3,"file":"switchboard-CERuSM8r.mjs","sources":["../src/services/switchboard.ts"],"sourcesContent":["import type {\n IdentityOptions,\n StartServerOptions,\n} from \"@powerhousedao/switchboard/server\";\nimport { startSwitchboard as startSwitchboardServer } from \"@powerhousedao/switchboard/server\";\nimport type { ILogger } from \"document-model\";\nimport path from \"node:path\";\nimport type { SwitchboardArgs } from \"../types.js\";\n\nexport const defaultSwitchboardOptions = {\n port: 4001,\n dbPath: path.join(process.cwd(), \".ph/read-model.db\"),\n drive: {\n id: \"powerhouse\",\n slug: \"powerhouse\",\n global: {\n name: \"Powerhouse\",\n icon: \"https://ipfs.io/ipfs/QmcaTDBYn8X2psGaXe7iQ6qd8q6oqHLgxvMX9yXf7f9uP7\",\n },\n local: {\n availableOffline: true,\n listeners: [],\n sharingType: \"public\",\n triggers: [],\n },\n },\n mcp: true,\n} satisfies StartServerOptions;\n\nfunction getDefaultVetraSwitchboardOptions(\n vetraDriveId: string,\n): Partial<StartServerOptions> {\n return {\n port: 4001,\n dbPath: path.join(process.cwd(), \".ph/read-model.db\"),\n drive: {\n id: vetraDriveId,\n slug: vetraDriveId,\n global: {\n name: \"Vetra\",\n icon: \"https://azure-elderly-tortoise-212.mypinata.cloud/ipfs/bafkreibf2xokjqqtomqjd2w2xxmmhvogq4262csevclxh6sbrjgmjfre5u\",\n },\n preferredEditor: \"vetra-drive-app\",\n local: {\n availableOffline: true,\n listeners: [],\n sharingType: \"public\",\n triggers: [],\n },\n },\n };\n}\n\nexport async function startSwitchboard(\n options: SwitchboardArgs & {\n strictPort?: boolean;\n processorConfig?: Map<string, unknown>;\n },\n logger?: ILogger,\n) {\n const {\n packages: packagesString,\n remoteDrives,\n useVetraDrive,\n vetraDriveId,\n useIdentity,\n keypairPath,\n requireIdentity,\n ...serverOptions\n } = options;\n\n // Choose the appropriate default configuration\n const defaultOptions = useVetraDrive\n ? getDefaultVetraSwitchboardOptions(vetraDriveId)\n : defaultSwitchboardOptions;\n\n // Build identity options if enabled\n const identity: IdentityOptions | undefined =\n useIdentity || keypairPath || requireIdentity\n ? {\n keypairPath,\n requireExisting: requireIdentity,\n }\n : undefined;\n\n const packages = packagesString?.split(\",\");\n\n // Only include the default drive if no remote drives are provided\n const finalOptions =\n remoteDrives.length > 0\n ? {\n ...defaultOptions,\n drive: undefined, // Don't create default drive when syncing with remote\n ...serverOptions,\n remoteDrives,\n identity,\n packages,\n logger,\n }\n : {\n ...defaultOptions,\n ...serverOptions,\n remoteDrives,\n identity,\n packages,\n logger,\n };\n\n const reactor = await startSwitchboardServer(finalOptions);\n\n return reactor;\n}\n"],"names":["startSwitchboard","startSwitchboardServer"],"mappings":";;;;;AASA,MAAa,4BAA4B;CACvC,MAAM;CACN,QAAQ,KAAK,KAAK,QAAQ,KAAK,EAAE,oBAAoB;CACrD,OAAO;EACL,IAAI;EACJ,MAAM;EACN,QAAQ;GACN,MAAM;GACN,MAAM;GACP;EACD,OAAO;GACL,kBAAkB;GAClB,WAAW,EAAE;GACb,aAAa;GACb,UAAU,EAAE;GACb;EACF;CACD,KAAK;CACN;AAED,SAAS,kCACP,cAC6B;AAC7B,QAAO;EACL,MAAM;EACN,QAAQ,KAAK,KAAK,QAAQ,KAAK,EAAE,oBAAoB;EACrD,OAAO;GACL,IAAI;GACJ,MAAM;GACN,QAAQ;IACN,MAAM;IACN,MAAM;IACP;GACD,iBAAiB;GACjB,OAAO;IACL,kBAAkB;IAClB,WAAW,EAAE;IACb,aAAa;IACb,UAAU,EAAE;IACb;GACF;EACF;;AAGH,eAAsBA,mBACpB,SAIA,QACA;CACA,MAAM,EACJ,UAAU,gBACV,cACA,eACA,cACA,aACA,aACA,iBACA,GAAG,kBACD;CAGJ,MAAM,iBAAiB,gBACnB,kCAAkC,aAAa,GAC/C;CAGJ,MAAM,WACJ,eAAe,eAAe,kBAC1B;EACE;EACA,iBAAiB;EAClB,GACD,KAAA;CAEN,MAAM,WAAW,gBAAgB,MAAM,IAAI;AAyB3C,QAFgB,MAAMC,iBAnBpB,aAAa,SAAS,IAClB;EACE,GAAG;EACH,OAAO,KAAA;EACP,GAAG;EACH;EACA;EACA;EACA;EACD,GACD;EACE,GAAG;EACH,GAAG;EACH;EACA;EACA;EACA;EACD,CAEmD","debug_id":"2b112076-440d-59d6-ac2e-84dc0ffb3cfd"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { n as startSwitchboard } from "./switchboard-CERuSM8r.mjs";
|
|
2
|
+
export { startSwitchboard };
|
|
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]="af9813d0-a104-5bb7-8b08-a5926d55691e")}catch(e){}}();
|
|
4
|
+
//# debugId=af9813d0-a104-5bb7-8b08-a5926d55691e
|
|
@@ -0,0 +1,87 @@
|
|
|
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]="4438a63d-24ec-57f5-8ae6-4ae3a40a8c6f")}catch(e){}}();
|
|
3
|
+
import { cyan, green, red, yellow } from "colorette";
|
|
4
|
+
import { promises } from "node:fs";
|
|
5
|
+
//#region src/services/switchboard-reset.ts
|
|
6
|
+
const CONFIRMATION_TOKEN = "reset";
|
|
7
|
+
function isPostgresUrl(url) {
|
|
8
|
+
return url.startsWith("postgresql://") || url.startsWith("postgres://");
|
|
9
|
+
}
|
|
10
|
+
function isInteractive() {
|
|
11
|
+
return Boolean(process.stdin.isTTY) && !process.env.CI;
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* Resolves the on-disk PGlite directories that `--reset` would delete.
|
|
15
|
+
* Mirrors the resolution in apps/switchboard/src/server.mts so we touch the
|
|
16
|
+
* same paths the running switchboard uses. When a Postgres URL is configured
|
|
17
|
+
* the corresponding directory is null and `postgresUrl` is populated so the
|
|
18
|
+
* caller can refuse.
|
|
19
|
+
*/
|
|
20
|
+
function resolveResetPaths(options, env = process.env) {
|
|
21
|
+
const readModelDbPath = options.dbPath ?? env.DATABASE_URL ?? env.PH_SWITCHBOARD_DATABASE_URL;
|
|
22
|
+
const readModelPath = readModelDbPath || ".ph/read-storage";
|
|
23
|
+
const reactorDbUrl = options.dbPath ?? env.PH_REACTOR_DATABASE_URL ?? env.PH_SWITCHBOARD_DATABASE_URL;
|
|
24
|
+
const reactorPath = reactorDbUrl || "./.ph/reactor-storage";
|
|
25
|
+
const reactorIsPostgres = !!reactorDbUrl && isPostgresUrl(reactorDbUrl);
|
|
26
|
+
const readModelIsPostgres = !!readModelDbPath && isPostgresUrl(readModelDbPath);
|
|
27
|
+
let postgresUrl = null;
|
|
28
|
+
if (reactorIsPostgres) postgresUrl = reactorDbUrl;
|
|
29
|
+
else if (readModelIsPostgres) postgresUrl = readModelDbPath;
|
|
30
|
+
return {
|
|
31
|
+
reactorDir: reactorIsPostgres ? null : reactorPath,
|
|
32
|
+
readModelDir: readModelIsPostgres ? null : readModelPath,
|
|
33
|
+
postgresUrl
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
async function promptForConfirmation() {
|
|
37
|
+
const enquirer = await import("enquirer");
|
|
38
|
+
try {
|
|
39
|
+
return (await enquirer.default.prompt({
|
|
40
|
+
type: "input",
|
|
41
|
+
name: "confirmation",
|
|
42
|
+
message: `Type "${CONFIRMATION_TOKEN}" to confirm wiping the local switchboard databases:`
|
|
43
|
+
})).confirmation.trim() === CONFIRMATION_TOKEN;
|
|
44
|
+
} catch {
|
|
45
|
+
return false;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
async function resetSwitchboardDatabase(options) {
|
|
49
|
+
const paths = resolveResetPaths(options);
|
|
50
|
+
if (paths.postgresUrl) {
|
|
51
|
+
console.error(red(`Refusing to reset: a PostgreSQL URL is configured (${paths.postgresUrl}).`));
|
|
52
|
+
console.error(yellow("`ph switchboard --reset` only wipes the local PGlite stores. To reset a Postgres-backed switchboard, drop/recreate the database manually."));
|
|
53
|
+
process.exit(1);
|
|
54
|
+
}
|
|
55
|
+
const targets = [paths.reactorDir, paths.readModelDir].filter((d) => d !== null);
|
|
56
|
+
if (targets.length === 0) {
|
|
57
|
+
console.error(red("No local PGlite directories resolved; nothing to do."));
|
|
58
|
+
process.exit(1);
|
|
59
|
+
}
|
|
60
|
+
console.log(yellow("The following directories will be permanently deleted:"));
|
|
61
|
+
for (const dir of targets) console.log(` - ${dir}`);
|
|
62
|
+
console.log(yellow("This will wipe all local switchboard state. Migrations will re-run on next `ph switchboard`."));
|
|
63
|
+
let confirmed = false;
|
|
64
|
+
if (options.yes) confirmed = true;
|
|
65
|
+
else if (isInteractive()) confirmed = await promptForConfirmation();
|
|
66
|
+
else {
|
|
67
|
+
console.error(red("Refusing to reset in a non-interactive context without --yes. Re-run with --yes to confirm."));
|
|
68
|
+
process.exit(1);
|
|
69
|
+
}
|
|
70
|
+
if (!confirmed) {
|
|
71
|
+
console.error(red("Aborted: confirmation not provided."));
|
|
72
|
+
process.exit(1);
|
|
73
|
+
}
|
|
74
|
+
for (const dir of targets) {
|
|
75
|
+
await promises.rm(dir, {
|
|
76
|
+
recursive: true,
|
|
77
|
+
force: true
|
|
78
|
+
});
|
|
79
|
+
console.log(cyan(`Removed ${dir}`));
|
|
80
|
+
}
|
|
81
|
+
console.log(green("Switchboard local storage reset. Run `ph switchboard` to re-initialize."));
|
|
82
|
+
}
|
|
83
|
+
//#endregion
|
|
84
|
+
export { resetSwitchboardDatabase };
|
|
85
|
+
|
|
86
|
+
//# sourceMappingURL=switchboard-reset-1YcJEVqc.mjs.map
|
|
87
|
+
//# debugId=4438a63d-24ec-57f5-8ae6-4ae3a40a8c6f
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"switchboard-reset-1YcJEVqc.mjs","sources":["../src/services/switchboard-reset.ts"],"sourcesContent":["import { yellow, red, green, cyan } from \"colorette\";\nimport { promises as fs } from \"node:fs\";\n\nexport interface ResetSwitchboardOptions {\n dbPath?: string;\n yes?: boolean;\n}\n\nexport interface ResolvedResetPaths {\n reactorDir: string | null;\n readModelDir: string | null;\n postgresUrl: string | null;\n}\n\nconst CONFIRMATION_TOKEN = \"reset\";\n\nexport function isPostgresUrl(url: string): boolean {\n return url.startsWith(\"postgresql://\") || url.startsWith(\"postgres://\");\n}\n\nfunction isInteractive(): boolean {\n return Boolean(process.stdin.isTTY) && !process.env.CI;\n}\n\n/**\n * Resolves the on-disk PGlite directories that `--reset` would delete.\n * Mirrors the resolution in apps/switchboard/src/server.mts so we touch the\n * same paths the running switchboard uses. When a Postgres URL is configured\n * the corresponding directory is null and `postgresUrl` is populated so the\n * caller can refuse.\n */\nexport function resolveResetPaths(\n options: ResetSwitchboardOptions,\n env: NodeJS.ProcessEnv = process.env,\n): ResolvedResetPaths {\n const readModelDbPath =\n options.dbPath ?? env.DATABASE_URL ?? env.PH_SWITCHBOARD_DATABASE_URL;\n const readModelPath = readModelDbPath || \".ph/read-storage\";\n const reactorDbUrl =\n options.dbPath ??\n env.PH_REACTOR_DATABASE_URL ??\n env.PH_SWITCHBOARD_DATABASE_URL;\n const reactorPath = reactorDbUrl || \"./.ph/reactor-storage\";\n\n const reactorIsPostgres = !!reactorDbUrl && isPostgresUrl(reactorDbUrl);\n const readModelIsPostgres =\n !!readModelDbPath && isPostgresUrl(readModelDbPath);\n\n let postgresUrl: string | null = null;\n if (reactorIsPostgres) postgresUrl = reactorDbUrl as string;\n else if (readModelIsPostgres) postgresUrl = readModelDbPath as string;\n\n return {\n reactorDir: reactorIsPostgres ? null : reactorPath,\n readModelDir: readModelIsPostgres ? null : readModelPath,\n postgresUrl,\n };\n}\n\nasync function promptForConfirmation(): Promise<boolean> {\n const enquirer = await import(\"enquirer\");\n try {\n const answer = await enquirer.default.prompt<{ confirmation: string }>({\n type: \"input\",\n name: \"confirmation\",\n message: `Type \"${CONFIRMATION_TOKEN}\" to confirm wiping the local switchboard databases:`,\n });\n return answer.confirmation.trim() === CONFIRMATION_TOKEN;\n } catch {\n return false;\n }\n}\n\nexport async function resetSwitchboardDatabase(\n options: ResetSwitchboardOptions,\n): Promise<void> {\n const paths = resolveResetPaths(options);\n\n if (paths.postgresUrl) {\n console.error(\n red(\n `Refusing to reset: a PostgreSQL URL is configured (${paths.postgresUrl}).`,\n ),\n );\n console.error(\n yellow(\n \"`ph switchboard --reset` only wipes the local PGlite stores. \" +\n \"To reset a Postgres-backed switchboard, drop/recreate the database manually.\",\n ),\n );\n process.exit(1);\n }\n\n const targets = [paths.reactorDir, paths.readModelDir].filter(\n (d): d is string => d !== null,\n );\n\n if (targets.length === 0) {\n console.error(red(\"No local PGlite directories resolved; nothing to do.\"));\n process.exit(1);\n }\n\n console.log(yellow(\"The following directories will be permanently deleted:\"));\n for (const dir of targets) {\n console.log(` - ${dir}`);\n }\n console.log(\n yellow(\n \"This will wipe all local switchboard state. Migrations will re-run on next `ph switchboard`.\",\n ),\n );\n\n let confirmed = false;\n if (options.yes) {\n confirmed = true;\n } else if (isInteractive()) {\n confirmed = await promptForConfirmation();\n } else {\n console.error(\n red(\n \"Refusing to reset in a non-interactive context without --yes. Re-run with --yes to confirm.\",\n ),\n );\n process.exit(1);\n }\n\n if (!confirmed) {\n console.error(red(\"Aborted: confirmation not provided.\"));\n process.exit(1);\n }\n\n for (const dir of targets) {\n await fs.rm(dir, { recursive: true, force: true });\n console.log(cyan(`Removed ${dir}`));\n }\n\n console.log(\n green(\n \"Switchboard local storage reset. Run `ph switchboard` to re-initialize.\",\n ),\n );\n}\n"],"names":["fs"],"mappings":";;;;;AAcA,MAAM,qBAAqB;AAE3B,SAAgB,cAAc,KAAsB;AAClD,QAAO,IAAI,WAAW,gBAAgB,IAAI,IAAI,WAAW,cAAc;;AAGzE,SAAS,gBAAyB;AAChC,QAAO,QAAQ,QAAQ,MAAM,MAAM,IAAI,CAAC,QAAQ,IAAI;;;;;;;;;AAUtD,SAAgB,kBACd,SACA,MAAyB,QAAQ,KACb;CACpB,MAAM,kBACJ,QAAQ,UAAU,IAAI,gBAAgB,IAAI;CAC5C,MAAM,gBAAgB,mBAAmB;CACzC,MAAM,eACJ,QAAQ,UACR,IAAI,2BACJ,IAAI;CACN,MAAM,cAAc,gBAAgB;CAEpC,MAAM,oBAAoB,CAAC,CAAC,gBAAgB,cAAc,aAAa;CACvE,MAAM,sBACJ,CAAC,CAAC,mBAAmB,cAAc,gBAAgB;CAErD,IAAI,cAA6B;AACjC,KAAI,kBAAmB,eAAc;UAC5B,oBAAqB,eAAc;AAE5C,QAAO;EACL,YAAY,oBAAoB,OAAO;EACvC,cAAc,sBAAsB,OAAO;EAC3C;EACD;;AAGH,eAAe,wBAA0C;CACvD,MAAM,WAAW,MAAM,OAAO;AAC9B,KAAI;AAMF,UALe,MAAM,SAAS,QAAQ,OAAiC;GACrE,MAAM;GACN,MAAM;GACN,SAAS,SAAS,mBAAmB;GACtC,CAAC,EACY,aAAa,MAAM,KAAK;SAChC;AACN,SAAO;;;AAIX,eAAsB,yBACpB,SACe;CACf,MAAM,QAAQ,kBAAkB,QAAQ;AAExC,KAAI,MAAM,aAAa;AACrB,UAAQ,MACN,IACE,sDAAsD,MAAM,YAAY,IACzE,CACF;AACD,UAAQ,MACN,OACE,4IAED,CACF;AACD,UAAQ,KAAK,EAAE;;CAGjB,MAAM,UAAU,CAAC,MAAM,YAAY,MAAM,aAAa,CAAC,QACpD,MAAmB,MAAM,KAC3B;AAED,KAAI,QAAQ,WAAW,GAAG;AACxB,UAAQ,MAAM,IAAI,uDAAuD,CAAC;AAC1E,UAAQ,KAAK,EAAE;;AAGjB,SAAQ,IAAI,OAAO,yDAAyD,CAAC;AAC7E,MAAK,MAAM,OAAO,QAChB,SAAQ,IAAI,OAAO,MAAM;AAE3B,SAAQ,IACN,OACE,+FACD,CACF;CAED,IAAI,YAAY;AAChB,KAAI,QAAQ,IACV,aAAY;UACH,eAAe,CACxB,aAAY,MAAM,uBAAuB;MACpC;AACL,UAAQ,MACN,IACE,8FACD,CACF;AACD,UAAQ,KAAK,EAAE;;AAGjB,KAAI,CAAC,WAAW;AACd,UAAQ,MAAM,IAAI,sCAAsC,CAAC;AACzD,UAAQ,KAAK,EAAE;;AAGjB,MAAK,MAAM,OAAO,SAAS;AACzB,QAAMA,SAAG,GAAG,KAAK;GAAE,WAAW;GAAM,OAAO;GAAM,CAAC;AAClD,UAAQ,IAAI,KAAK,WAAW,MAAM,CAAC;;AAGrC,SAAQ,IACN,MACE,0EACD,CACF","debug_id":"4438a63d-24ec-57f5-8ae6-4ae3a40a8c6f"}
|
|
@@ -1,16 +1,16 @@
|
|
|
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]="e6ca579f-2bd8-58c9-b5c8-e32c226e24de")}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";
|
|
6
|
-
import { n as startSwitchboard$1 } from "./switchboard-
|
|
6
|
+
import { n as startSwitchboard$1 } from "./switchboard-CERuSM8r.mjs";
|
|
7
7
|
import { execSync } from "node:child_process";
|
|
8
|
+
import { blue, green, red, yellow } from "colorette";
|
|
8
9
|
import { createLogger } from "vite";
|
|
9
10
|
import { createVetraDocument, getVetraDocuments, setPackageGithubUrl } from "@powerhousedao/common/utils";
|
|
10
11
|
import { isPortAvailable } from "@powerhousedao/switchboard/server";
|
|
11
12
|
import { VETRA_PROCESSOR_CONFIG_KEY } from "@powerhousedao/config";
|
|
12
13
|
import { addDefaultDrive } from "@powerhousedao/switchboard/utils";
|
|
13
|
-
import { blue, green, red, yellow } from "colorette";
|
|
14
14
|
import { childLogger, setLogLevel } from "document-model";
|
|
15
15
|
import { createInterface } from "node:readline";
|
|
16
16
|
//#region src/utils/configure-vetra-github-url.ts
|
|
@@ -330,6 +330,8 @@ async function startLocalVetraSwitchboard(args, logger) {
|
|
|
330
330
|
useIdentity: void 0,
|
|
331
331
|
migrate: void 0,
|
|
332
332
|
migrateStatus: void 0,
|
|
333
|
+
reset: void 0,
|
|
334
|
+
yes: void 0,
|
|
333
335
|
requireIdentity: void 0
|
|
334
336
|
}, logger);
|
|
335
337
|
const actualSwitchboardPort = switchboard.port;
|
|
@@ -419,5 +421,5 @@ async function startVetra(args) {
|
|
|
419
421
|
//#endregion
|
|
420
422
|
export { startVetra };
|
|
421
423
|
|
|
422
|
-
//# sourceMappingURL=vetra-
|
|
423
|
-
//# debugId=
|
|
424
|
+
//# sourceMappingURL=vetra-yCsUKy_u.mjs.map
|
|
425
|
+
//# debugId=e6ca579f-2bd8-58c9-b5c8-e32c226e24de
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"vetra-BUcRFup0.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 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":"cb069c00-b527-5d4a-9f33-86fe6e8b854d"}
|
|
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":";;;;;;;;;;;;;;;;;;;;AAaA,SAAS,kBAAiC;AACxC,KAAI;AAKF,SAJY,SAAS,6BAA6B;GAChD,UAAU;GACV,OAAO;IAAC;IAAQ;IAAQ;IAAO;GAChC,CAAC,CAAC,MAAM,IACK;SACR;AACN,SAAO;;;;;;AAOX,eAAe,qBAA6C;AAC1D,QAAO,IAAI,SAAS,YAAY;EAC9B,MAAM,KAAK,gBAAgB;GACzB,OAAO,QAAQ;GACf,QAAQ,QAAQ;GACjB,CAAC;AAEF,UAAQ,OAAO,MAAM,gDAAgD;AAErE,KAAG,GAAG,SAAS,WAAmB;AAChC,MAAG,OAAO;AAEV,WADY,OAAO,MAAM,IACV,KAAK;IACpB;GACF;;;;;AAMJ,eAAe,YAAY,UAAoC;AAC7D,QAAO,IAAI,SAAS,YAAY;EAC9B,MAAM,KAAK,gBAAgB;GACzB,OAAO,QAAQ;GACf,QAAQ,QAAQ;GACjB,CAAC;AAEF,UAAQ,OAAO,MAAM,KAAK,SAAS,UAAU;AAE7C,KAAG,GAAG,SAAS,WAAmB;AAChC,MAAG,OAAO;GACV,MAAM,WAAW,OAAO,MAAM,CAAC,aAAa;AAC5C,WAAQ,aAAa,OAAO,aAAa,MAAM;IAC/C;GACF;;;;;;;AAQJ,eAAe,mBACb,cACwB;AACxB,QAAO,IAAI,SAAS,YAAY;EAC9B,MAAM,KAAK,gBAAgB;GACzB,OAAO,QAAQ;GACf,QAAQ,QAAQ;GACjB,CAAC;AAEF,UAAQ,IAAI,OAAO,IAAI,OAAO,GAAG,CAAC;AAClC,UAAQ,IAAI,iCAAiC;AAC7C,UAAQ,IAAI,IAAI,OAAO,GAAG,CAAC;AAC3B,UAAQ,IACN,+FACD;AACD,UAAQ,IAAI,oDAAoD;AAEhE,MAAI,cAAc;AAChB,WAAQ,IAAI,8BAA8B,eAAe;AACzD,WAAQ,IAAI,aAAa;AACzB,WAAQ,IAAI,sBAAsB;AAClC,WAAQ,IAAI,2BAA2B;AACvC,WAAQ,IAAI,wBAAwB;AAEpC,WAAQ,OAAO,MAAM,6BAA6B;GAElD,MAAM,gBAAgB,WAAmB;IACvC,MAAM,SAAS,OAAO,MAAM;AAE5B,QAAI,WAAW,KAAK;AAClB,QAAG,OAAO;AACV,aAAQ,aAAa;eACZ,WAAW,KAAK;AACzB,QAAG,OAAO;AACV,yBAAoB,CACjB,KAAK,QAAQ,CACb,YAAY,QAAQ,KAAK,CAAC;eACpB,WAAW,KAAK;AACzB,QAAG,OAAO;AACV,aAAQ,KAAK;UAEb,SAAQ,OAAO,MAAM,2CAA2C;;AAIpE,MAAG,GAAG,QAAQ,aAAa;SACtB;AACL,WAAQ,IAAI,gCAAgC;AAC5C,WAAQ,IAAI,aAAa;AACzB,WAAQ,IAAI,+BAA+B;AAC3C,WAAQ,IAAI,wBAAwB;AAEpC,WAAQ,OAAO,MAAM,6BAA6B;GAElD,MAAM,gBAAgB,WAAmB;IACvC,MAAM,SAAS,OAAO,MAAM;AAE5B,QAAI,WAAW,KAAK;AAClB,QAAG,OAAO;AACV,yBAAoB,CACjB,KAAK,QAAQ,CACb,YAAY,QAAQ,KAAK,CAAC;eACpB,WAAW,KAAK;AACzB,QAAG,OAAO;AACV,aAAQ,KAAK;UAEb,SAAQ,OAAO,MAAM,2CAA2C;;AAIpE,MAAG,GAAG,QAAQ,aAAa;;GAE7B;;;;;AAMJ,SAAS,gBAAgB,KAAmB;AAC1C,KAAI;AACF,WAAS,yBAAyB,OAAO,EACvC,OAAO,WACR,CAAC;AACF,UAAQ,IAAI,+BAA+B,MAAM;SAC3C;AACN,MAAI;AACF,YAAS,6BAA6B,OAAO,EAC3C,OAAO,WACR,CAAC;AACF,WAAQ,IAAI,mCAAmC,MAAM;UAC/C;AACN,WAAQ,MAAM,IAAI,iCAAiC,CAAC;;;;;;;;AAS1D,SAAS,0BAA6B,WAA0B;AAC9D,KAAI,UAAU,WAAW,EACvB,QAAO;AAGT,KAAI,UAAU,SAAS,EACrB,SAAQ,KACN,gDAAgD,UAAU,OAAO,0BAClE;AAGH,QAAO,UAAU;;AAGnB,eAAe,4BACb,iBACA,cACA,YACA,aACA,iBACe;AAEf,OAAM,oBACJ,iBACA,cACA,YACA,YACD;AAED,SAAQ,IAAI,4BAA4B,cAAc;AAGtD,KAAI,gBACF,iBAAgB,YAAY;;AAIhC,SAAS,WAAW,SAAiB,SAAyB;AAC5D,KAAI,QACF,SAAQ,IAAI,QAAQ;;;;;AAOxB,SAAgB,MAAM,IAA2B;AAC/C,QAAO,IAAI,SAAS,YAAY,WAAW,SAAS,GAAG,CAAC;;;;;;;;AAS1D,eAAsB,wBACpB,iBACA,eACA,SACe;AACf,YAAW,wCAAwC,QAAQ;AAE3D,KAAI;EACF,MAAM,kBAAkB,oBAAoB,gBAAgB;EAC5D,MAAM,eAAe,cAAc,MAAM,IAAI,CAAC,KAAK;AACnD,MAAI,CAAC,aACH,OAAM,IAAI,MAAM,oDAAoD;EAGtE,MAAM,YAAY,MAAM,kBAAkB,iBAAiB,aAAa;AAGxE,MAAI,UAAU,MAAM,QAAQ,IAAI,UAAU,EAAE;AAC1C,cAAW,iDAAiD,QAAQ;AACpE;;EAIF,IAAI;EACJ,MAAM,iBAAiB,0BAA0B,UAAU;EAG3D,MAAM,eAAe,iBAAiB;EACtC,MAAM,cAAc,MAAM,mBAAmB,aAAa;AAE1D,MAAI,CAAC,aAAa;AAChB,cAAW,oCAAoC,QAAQ;AACvD;;EAGF,IAAI,kBAAkB;AACtB,MAAI,gBAAgB,gBAAgB,CAAC,aACnC,mBAAkB,MAAM,YAAY,mCAAmC;AAGzE,MAAI,CAAC,gBAAgB;AACnB,cAAW,sDAAsD,QAAQ;AAEzE,sBAAmB,MAAM,oBACvB,iBACA,cACA,gBACD;AAED,cAAW,yBAAyB,oBAAoB,QAAQ;QAEhE,oBAAmB,eAAe;AAGpC,QAAM,4BACJ,iBACA,cACA,kBACA,aACA,gBACD;UACM,OAAO;AACd,UAAQ,MACN,IACE,wCAAwC,iBAAiB,QAAQ,MAAM,UAAU,OAAO,MAAM,GAC/F,CACF;AACD,aAAW,OAAO,MAAM,EAAE,QAAQ;;;;;AClStC,MAAM,wBAAwB;AAE9B,SAAS,gBAAyB;AAChC,QAAO,QAAQ,QAAQ,MAAM,MAAM,IAAI,CAAC,QAAQ,IAAI;;AAGtD,eAAe,aAAa,OAAuC;AACjE,MAAK,IAAI,IAAI,GAAG,IAAI,uBAAuB,KAAK;EAC9C,MAAM,YAAY,QAAQ;AAC1B,MAAI,MAAM,gBAAgB,UAAU,CAAE,QAAO;;AAE/C,QAAO;;;;;;;;;;;;AAaT,eAAsB,uBACpB,WACiB;AACjB,KAAI,MAAM,gBAAgB,UAAU,CAAE,QAAO;CAE7C,MAAM,YAAY,MAAM,aAAa,YAAY,EAAE;AACnD,KAAI,cAAc,MAAM;AACtB,UAAQ,MACN,QAAQ,UAAU,qDAAqD,UAAU,GAAG,YAAY,wBAAwB,EAAE,GAC3H;AACD,UAAQ,KAAK,EAAE;;AAGjB,KAAI,CAAC,eAAe,EAAE;AACpB,UAAQ,IACN,OACE,QAAQ,UAAU,mCAAmC,UAAU,4CAChE,CACF;AACD,SAAO;;CAGT,MAAM,WAAW,MAAM,OAAO;CAE9B,IAAI,YAAY;AAChB,KAAI;AAOF,eANe,MAAM,SAAS,QAAQ,OAA+B;GACnE,MAAM;GACN,MAAM;GACN,SAAS,QAAQ,UAAU,uBAAuB,UAAU;GAC5D,SAAS;GACV,CAAC,EACiB;SACb;AAEN,cAAY;;AAGd,KAAI,CAAC,WAAW;AACd,UAAQ,MACN,sBAAsB,UAAU,gEACjC;AACD,UAAQ,KAAK,EAAE;;AAGjB,QAAO;;;;ACtDT,MAAM,mBAAmB;AAEzB,MAAM,sBAAsB,SAC1B,oBAAoB,KAAK,KAAK,uBAAuB,iBAAiB;AAExE,MAAM,cAAc,aAClB,UAAU,MAAM,IAAI,CAAC,KAAK,IAAI,uBAAuB,iBAAiB;AAExE,SAAS,iBAAiB,OAAc;CACtC,MAAM,eAAe,aAAa,OAAO;CACzC,MAAM,aAAa,aAAa,KAAK,KAAK,aAAa;AACvD,cAAa,QAAQ,KAAK,YAAY;AACpC,aAAW,MAAM,IAAI,EAAE,QAAQ;;CAEjC,MAAM,aAAa,aAAa,KAAK,KAAK,aAAa;AACvD,cAAa,QAAQ,KAAK,YAAY;AACpC,aAAW,OAAO,IAAI,EAAE,QAAQ;;CAElC,MAAM,cAAc,aAAa,MAAM,KAAK,aAAa;AACzD,cAAa,SAAS,KAAK,YAAY;AACrC,cAAY,IAAI,IAAI,EAAE,QAAQ;;CAGhC,MAAM,iBAAiB,aAAa,SAAS,KAAK,aAAa;AAC/D,cAAa,YAAY,KAAK,YAAY;AACxC,iBAAe,OAAO,IAAI,EAAE,QAAQ;;AAEtC,QAAO;;AAGT,eAAe,uBACb,SACA,MACA,SACiB;CACjB,MAAM,iBAAiB,uBAAuB,UAAU;CAkBxD,MAAM,WAAW,MAAM,gBAAgB,SAhBlB;EACnB,IAAI;EACJ,MAAM;EACN,QAAQ;GACN,MAAM;GACN,MAAM;GACN,OAAO,EAAE;GACV;EACD,OAAO;GACL,kBAAkB;GAClB,WAAW,EAAE;GACb,aAAa;GACb,UAAU,EAAE;GACb;EACF,EAE6D,KAAK;AAEnE,KAAI,QACF,SAAQ,IAAI,KAAK,qCAAqC,WAAW,CAAC;AAEpE,QAAO;;AAET,eAAe,2BAA2B,MAAiB,QAAkB;CAC3E,MAAM,EACJ,aACA,iBACA,KACA,UACA,sBACA,OACA,cACA,eACA,aACA,aACA,OACA,YACE;CAGJ,MAAM,eAAe,cAAc,CAAC,YAAY,GAAG,EAAE;CAErD,MAAM,uBAAiD;EACrD;EACA,UAAU,eAAe,mBAAmB,YAAY;EACxD,SAAS,WAAW,YAAY;EACjC;CAED,MAAM,kCAAkB,IAAI,KAAsB;AAClD,iBAAgB,IAAI,4BAA4B,qBAAqB;CAErE,MAAM,eAAe,uBAAuB,iBAAiB;CAO7D,MAAM,0BAA0B,KAAK,aACjC,kBACA,MAAM,uBAAuB,gBAAgB;AAEjD,KAAI;EACF,MAAM,cAAc,MAAMA,mBACxB;GACE,GAAG;GACH,eAAe;GACf,KAAK;GACL,MAAM;GAGN,YAAY;GACZ;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA,UAAU,KAAA;GACV,aAAa,KAAA;GACb,QAAQ,KAAK;GACb,aAAa,KAAA;GACb,SAAS,KAAA;GACT,eAAe,KAAA;GACf,OAAO,KAAA;GACP,KAAK,KAAA;GACL,iBAAiB,KAAA;GAClB,EACD,OACD;EAED,MAAM,wBAAwB,YAAY;EAG1C,IAAI,kBAAiC;AACrC,MAAI,MACF,KAAI;AACF,qBAAkB,MAAM,uBACtB,YAAY,SACZ,uBACA,QACD;WACM,OAAO;AACd,WAAQ,MAAM,MAAM;;AAIxB,MAAI,SAAS;AACX,WAAQ,IAAI,KAAK,0CAA0C,CAAC;AAC5D,OAAI,YACF,SAAQ,IACN,KAAK,iDAAiD,cAAc,CACrE;SAEE;AACL,WAAQ,KAAK;AACb,WAAQ,IACN,KACE,uCAAuC,sBAAsB,UAC9D,CACF;AACD,WAAQ,IAAI,KAAK,mBAAmB,YAAY,kBAAkB,CAAC;AACnE,OAAI,gBACF,SAAQ,IAAI,KAAK,2BAA2B,kBAAkB,CAAC;;AAGnE,SAAO;GACL,UAAU,YAAY,mBAAmB;GACxB;GACjB,iBAAiB;GAClB;UACM,OAAO;AACd,UAAQ,MACN,IACE,sBAAsB,iBAAiB,QAAQ,MAAM,UAAU,OAAO,MAAM,GAC7E,CACF;AACD,QAAM,iBAAiB,QAAQ,QAAQ,IAAI,MAAM,OAAO,MAAM,CAAC;;;AAInE,eAAsB,WAAW,MAAiB;CAChD,MAAM,EACJ,aACA,SACA,aACA,gBACA,OACA,eACA,cACA,sBACA,MACA,MACA,MACA,YACA,WACA,kBACA,iBACE;CAEJ,MAAM,oBAAoB,YAAY,CAAC,SAAS,cAAc,CAAC;AAE/D,KAAI;AAEF,MAAI,CAAC,QAAQ,IAAI,UACf,aAAY,OAAO;AAGrB,MAAI,SAAS;AACX,qBAAkB,KAAK,gCAAgC;AACvD,OAAI,aAAa;IACf,MAAM,SAAS,cACX,0BACA;AACJ,sBAAkB,KAAK,uBAAuB,OAAO,IAAI,cAAc;;;EAG3E,MAAM,oBAAoB,MAAM,2BAC9B;GACE,GAAG;GACH,KAAK;GACL;GACA;GACA;GACA;GACD,EACD,kBACD;EACD,MAAM,WAAmB,kBAAkB,YAAY,eAAe;EACtE,MAAM,kBAAkB,kBAAkB;EAC1C,MAAM,wBAAwB,kBAAkB;AAGhD,MAAI,aAAa;AAEf,SAAM,MAAM,IAAK;AAEjB,SAAM,wBACJ,uBACA,aACA,QACD;AAGD,SAAM,MAAM,IAAK;;AAGnB,MAAI,QACF,SAAQ,IAAI,8BAA8B;AAI5C,MAAI,CAAC,gBAAgB;AACnB,OAAI,SAAS;AACX,YAAQ,IAAI,sBAAsB;IAClC,MAAM,SAAS,kBACX,GAAG,SAAS,IAAI,oBAChB;AACJ,YAAQ,IAAI,iCAAiC,SAAS;;AAExD,WAAQ,KAAK;AACb,WAAQ,IAAI,MAAM,mCAAmC,cAAc,CAAC;GAEpE,MAAM,mBAAmB,iBAAiB,MAAM;AAEhD,SAAM,iBACJ;IACE,GAAG;IACH,kBAAkB,kBACd,CAAC,UAAU,gBAAgB,CAAC,KAAK,IAAI,GACrC;IACJ,wBAAwB;IACxB,MAAM;IACN;IACA;IACM;IACA;IACA;IACM;IACD;IACO;IACJ;IACf,EACD,iBACD;;UAEI,OAAO;AACd,UAAQ,MAAM,MAAM","debug_id":"e6ca579f-2bd8-58c9-b5c8-e32c226e24de"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@powerhousedao/ph-cli",
|
|
3
|
-
"version": "6.0
|
|
3
|
+
"version": "6.1.0-staging.0",
|
|
4
4
|
"description": "",
|
|
5
5
|
"license": "AGPL-3.0-only",
|
|
6
6
|
"type": "module",
|
|
@@ -23,6 +23,7 @@
|
|
|
23
23
|
"keywords": [],
|
|
24
24
|
"author": "",
|
|
25
25
|
"dependencies": {
|
|
26
|
+
"@sentry/node-core": "^10.52.0",
|
|
26
27
|
"@tsdown/css": "0.21.1",
|
|
27
28
|
"chalk": "5.6.2",
|
|
28
29
|
"change-case": "5.4.4",
|
|
@@ -33,18 +34,20 @@
|
|
|
33
34
|
"package-manager-detector": "1.6.0",
|
|
34
35
|
"pg": "8.18.0",
|
|
35
36
|
"read-pkg": "10.1.0",
|
|
37
|
+
"rolldown": "1.0.0-rc.8",
|
|
36
38
|
"semver": "7.7.4",
|
|
37
39
|
"tsdown": "0.21.1",
|
|
38
40
|
"vite": "8.0.8",
|
|
39
|
-
"@powerhousedao/
|
|
40
|
-
"@powerhousedao/
|
|
41
|
-
"@powerhousedao/
|
|
42
|
-
"@powerhousedao/
|
|
43
|
-
"@powerhousedao/
|
|
44
|
-
"@powerhousedao/shared": "6.0
|
|
45
|
-
"@powerhousedao/switchboard": "6.0
|
|
46
|
-
"@
|
|
47
|
-
"
|
|
41
|
+
"@powerhousedao/codegen": "6.1.0-staging.0",
|
|
42
|
+
"@powerhousedao/builder-tools": "6.1.0-staging.0",
|
|
43
|
+
"@powerhousedao/config": "6.1.0-staging.0",
|
|
44
|
+
"@powerhousedao/common": "6.1.0-staging.0",
|
|
45
|
+
"@powerhousedao/reactor": "6.1.0-staging.0",
|
|
46
|
+
"@powerhousedao/shared": "6.1.0-staging.0",
|
|
47
|
+
"@powerhousedao/switchboard": "6.1.0-staging.0",
|
|
48
|
+
"@powerhousedao/vetra": "6.1.0-staging.0",
|
|
49
|
+
"@renown/sdk": "6.1.0-staging.0",
|
|
50
|
+
"document-model": "6.1.0-staging.0"
|
|
48
51
|
},
|
|
49
52
|
"devDependencies": {
|
|
50
53
|
"@types/node": "25.2.3",
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="a2438c08-9f88-5904-af8b-ac3552eff7c3")}catch(e){}}();
|
|
3
|
-
import { generateAll } from "@powerhousedao/codegen";
|
|
4
|
-
import { buildTsMorphProject } from "@powerhousedao/codegen/utils";
|
|
5
|
-
//#region src/services/generate-all.ts
|
|
6
|
-
async function startGenerateAll(projectDir) {
|
|
7
|
-
const project = buildTsMorphProject(projectDir);
|
|
8
|
-
await generateAll(project);
|
|
9
|
-
await project.save();
|
|
10
|
-
}
|
|
11
|
-
//#endregion
|
|
12
|
-
export { startGenerateAll };
|
|
13
|
-
|
|
14
|
-
//# sourceMappingURL=generate-all-Cj8zjFhN.mjs.map
|
|
15
|
-
//# debugId=a2438c08-9f88-5904-af8b-ac3552eff7c3
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"generate-all-Cj8zjFhN.mjs","sources":["../src/services/generate-all.ts"],"sourcesContent":["import { generateAll } from \"@powerhousedao/codegen\";\nimport { buildTsMorphProject } from \"@powerhousedao/codegen/utils\";\n\nexport async function startGenerateAll(projectDir: string) {\n const project = buildTsMorphProject(projectDir);\n await generateAll(project);\n await project.save();\n}\n"],"names":[],"mappings":";;;;;AAGA,eAAsB,iBAAiB,YAAoB;CACzD,MAAM,UAAU,oBAAoB,WAAW;AAC/C,OAAM,YAAY,QAAQ;AAC1B,OAAM,QAAQ,MAAM","debug_id":"a2438c08-9f88-5904-af8b-ac3552eff7c3"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"generate-app-KE0rbE-b.mjs","sources":["../src/services/generate-app.ts"],"sourcesContent":["import { generateAllApps, generateApp } from \"@powerhousedao/codegen\";\nimport {\n buildTsMorphProject,\n getAppMetadata,\n} from \"@powerhousedao/codegen/utils\";\nimport { dirname } from \"node:path\";\nimport type { GenerateAppArgs } from \"../types.js\";\n\nexport async function startGenerateApp(\n args: GenerateAppArgs,\n projectDir: string,\n) {\n const {\n name,\n allowedDocumentTypes = [],\n disableDragAndDrop,\n dir,\n all,\n debug,\n } = args;\n if (debug) {\n console.log({ args });\n }\n const project = buildTsMorphProject(projectDir);\n if (all) {\n await generateAllApps(project);\n } else if (name) {\n await generateApp(\n {\n appName: name,\n allowedDocumentTypes,\n isDragAndDropEnabled: !disableDragAndDrop,\n },\n project,\n );\n } else if (dir) {\n const appMetadata = getAppMetadata(project, dirname(dir));\n if (!appMetadata) {\n throw new Error(`Failed to get data for app in dir \"${dir}\"`);\n }\n const {\n name: appName,\n id: appId,\n dirName: appDirName,\n allowedDocumentTypes,\n isDragAndDropEnabled,\n } = appMetadata;\n\n await generateApp(\n {\n appName,\n appId,\n appDirName,\n allowedDocumentTypes,\n isDragAndDropEnabled,\n },\n project,\n );\n } else {\n console.log(\"Please specify either `name`, `dir`, or `all`.\");\n return;\n }\n await project.save();\n}\n"],"names":[],"mappings":";;;;;;AAQA,eAAsB,iBACpB,MACA,YACA;CACA,MAAM,EACJ,MACA,uBAAuB,EAAE,EACzB,oBACA,KACA,KACA,UACE;AACJ,KAAI,MACF,SAAQ,IAAI,EAAE,MAAM,CAAC;CAEvB,MAAM,UAAU,oBAAoB,WAAW;AAC/C,KAAI,IACF,OAAM,gBAAgB,QAAQ;UACrB,KACT,OAAM,YACJ;EACE,SAAS;EACT;EACA,sBAAsB,CAAC;EACxB,EACD,QACD;UACQ,KAAK;EACd,MAAM,cAAc,eAAe,SAAS,QAAQ,IAAI,CAAC;AACzD,MAAI,CAAC,YACH,OAAM,IAAI,MAAM,sCAAsC,IAAI,GAAG;EAE/D,MAAM,EACJ,MAAM,SACN,IAAI,OACJ,SAAS,YACT,sBACA,yBACE;AAEJ,QAAM,YACJ;GACE;GACA;GACA;GACA;GACA;GACD,EACD,QACD;QACI;AACL,UAAQ,IAAI,iDAAiD;AAC7D;;AAEF,OAAM,QAAQ,MAAM","debug_id":"e0e6b657-1568-5237-863c-b7ee06da40ae"}
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="bdd2f811-3145-5018-8a96-767f4263e2bc")}catch(e){}}();
|
|
3
|
-
import { dirname, join } from "node:path";
|
|
4
|
-
import { generateAllDocumentModels, generateDocumentModel, loadDocumentModel } from "@powerhousedao/codegen";
|
|
5
|
-
import { buildTsMorphProject } from "@powerhousedao/codegen/utils";
|
|
6
|
-
//#region src/services/generate-document-model.ts
|
|
7
|
-
async function startGenerateDocumentModel(args, projectDir) {
|
|
8
|
-
const { file, dir, all, debug } = args;
|
|
9
|
-
if (debug) console.log({ args });
|
|
10
|
-
const project = buildTsMorphProject(projectDir);
|
|
11
|
-
if (all) await generateAllDocumentModels(project);
|
|
12
|
-
else if (file) await generateDocumentModel(await loadDocumentModel(file), project);
|
|
13
|
-
else if (dir) await generateDocumentModel(await loadDocumentModel(join(dir, `${dirname(dir)}.json`)), project);
|
|
14
|
-
else {
|
|
15
|
-
console.log("Please specify either `file`, `dir`, or `all`.");
|
|
16
|
-
return;
|
|
17
|
-
}
|
|
18
|
-
await project.save();
|
|
19
|
-
}
|
|
20
|
-
//#endregion
|
|
21
|
-
export { startGenerateDocumentModel };
|
|
22
|
-
|
|
23
|
-
//# sourceMappingURL=generate-document-model-Cut44i6D.mjs.map
|
|
24
|
-
//# debugId=bdd2f811-3145-5018-8a96-767f4263e2bc
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"generate-document-model-Cut44i6D.mjs","sources":["../src/services/generate-document-model.ts"],"sourcesContent":["import {\n generateAllDocumentModels,\n generateDocumentModel,\n loadDocumentModel,\n} from \"@powerhousedao/codegen\";\nimport { buildTsMorphProject } from \"@powerhousedao/codegen/utils\";\nimport { dirname, join } from \"node:path\";\nimport type { GenerateDocumentModelArgs } from \"../types.js\";\n\nexport async function startGenerateDocumentModel(\n args: GenerateDocumentModelArgs,\n projectDir: string,\n) {\n const { file, dir, all, debug } = args;\n if (debug) {\n console.log({ args });\n }\n const project = buildTsMorphProject(projectDir);\n if (all) {\n await generateAllDocumentModels(project);\n } else if (file) {\n const documentModelState = await loadDocumentModel(file);\n await generateDocumentModel(documentModelState, project);\n } else if (dir) {\n const documentModelDirName = dirname(dir);\n const documentModelFileName = `${documentModelDirName}.json`;\n const documentModelFilePath = join(dir, documentModelFileName);\n const documentModelState = await loadDocumentModel(documentModelFilePath);\n await generateDocumentModel(documentModelState, project);\n } else {\n console.log(\"Please specify either `file`, `dir`, or `all`.\");\n return;\n }\n await project.save();\n}\n"],"names":[],"mappings":";;;;;;AASA,eAAsB,2BACpB,MACA,YACA;CACA,MAAM,EAAE,MAAM,KAAK,KAAK,UAAU;AAClC,KAAI,MACF,SAAQ,IAAI,EAAE,MAAM,CAAC;CAEvB,MAAM,UAAU,oBAAoB,WAAW;AAC/C,KAAI,IACF,OAAM,0BAA0B,QAAQ;UAC/B,KAET,OAAM,sBADqB,MAAM,kBAAkB,KAAK,EACR,QAAQ;UAC/C,IAKT,OAAM,sBADqB,MAAM,kBADH,KAAK,KADL,GADD,QAAQ,IAAI,CACa,OACQ,CACW,EACzB,QAAQ;MACnD;AACL,UAAQ,IAAI,iDAAiD;AAC7D;;AAEF,OAAM,QAAQ,MAAM","debug_id":"bdd2f811-3145-5018-8a96-767f4263e2bc"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"generate-editor-DmSzWm3W.mjs","sources":["../src/services/generate-editor.ts"],"sourcesContent":["import { generateAllEditors, generateEditor } from \"@powerhousedao/codegen\";\nimport {\n buildTsMorphProject,\n getEditorMetadata,\n} from \"@powerhousedao/codegen/utils\";\nimport { dirname } from \"node:path\";\nimport type { GenerateEditorArgs } from \"../types.js\";\n\nexport async function startGenerateEditor(\n args: GenerateEditorArgs,\n projectDir: string,\n) {\n const { name, documentType, dir, all, debug } = args;\n if (debug) {\n console.log({ args });\n }\n const project = buildTsMorphProject(projectDir);\n if (all) {\n await generateAllEditors(project);\n } else if (name) {\n if (!documentType) {\n throw new Error(\n \"Please specify a document type for the new editor to generate.\",\n );\n }\n await generateEditor(\n { editorName: name, documentTypes: [documentType] },\n project,\n );\n } else if (dir) {\n const editorArgs = getEditorMetadata(project, dirname(dir));\n if (!editorArgs) {\n throw new Error(`Failed to get data for editor in dir \"${dir}\"`);\n }\n const {\n name: editorName,\n id: editorId,\n dirName: editorDirName,\n documentTypes,\n } = editorArgs;\n await generateEditor(\n {\n editorName,\n editorId,\n editorDirName,\n documentTypes,\n },\n project,\n );\n } else {\n console.log(\"Please specify either `name`, `dir`, or `all`.\");\n return;\n }\n await project.save();\n}\n"],"names":[],"mappings":";;;;;;AAQA,eAAsB,oBACpB,MACA,YACA;CACA,MAAM,EAAE,MAAM,cAAc,KAAK,KAAK,UAAU;AAChD,KAAI,MACF,SAAQ,IAAI,EAAE,MAAM,CAAC;CAEvB,MAAM,UAAU,oBAAoB,WAAW;AAC/C,KAAI,IACF,OAAM,mBAAmB,QAAQ;UACxB,MAAM;AACf,MAAI,CAAC,aACH,OAAM,IAAI,MACR,iEACD;AAEH,QAAM,eACJ;GAAE,YAAY;GAAM,eAAe,CAAC,aAAa;GAAE,EACnD,QACD;YACQ,KAAK;EACd,MAAM,aAAa,kBAAkB,SAAS,QAAQ,IAAI,CAAC;AAC3D,MAAI,CAAC,WACH,OAAM,IAAI,MAAM,yCAAyC,IAAI,GAAG;EAElE,MAAM,EACJ,MAAM,YACN,IAAI,UACJ,SAAS,eACT,kBACE;AACJ,QAAM,eACJ;GACE;GACA;GACA;GACA;GACD,EACD,QACD;QACI;AACL,UAAQ,IAAI,iDAAiD;AAC7D;;AAEF,OAAM,QAAQ,MAAM","debug_id":"f3610574-fc94-59bf-ae3d-ea3430b3aec9"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"generate-processor-B-fChg4W.mjs","sources":["../src/services/generate-processor.ts"],"sourcesContent":["import {\n detectFeatures,\n generateAllProcessors,\n generateProcessor,\n syncFeatureDependencies,\n} from \"@powerhousedao/codegen\";\nimport {\n buildTsMorphProject,\n getProcessorMetadata,\n} from \"@powerhousedao/codegen/utils\";\nimport { dirname } from \"node:path\";\nimport type { GenerateProcessorArgs } from \"../types.js\";\n\nexport async function startGenerateProcessor(\n args: GenerateProcessorArgs,\n projectDir: string,\n) {\n const {\n name: processorName,\n type: processorType,\n apps: processorApps,\n documentTypes,\n dir,\n all,\n debug,\n } = args;\n if (debug) {\n console.log({ args });\n }\n const project = buildTsMorphProject(projectDir);\n if (all) {\n await generateAllProcessors(project);\n } else if (processorName) {\n await generateProcessor(\n {\n processorName,\n processorApps,\n processorType,\n documentTypes,\n },\n project,\n );\n } else if (dir) {\n const processorDirName = dirname(dir);\n const processorArgs = getProcessorMetadata(project, processorDirName);\n await generateProcessor(processorArgs, project);\n } else {\n console.log(\"Please specify either `name`, `dir`, or `all`.\");\n return;\n }\n await project.save();\n await syncFeatureDependencies(detectFeatures(projectDir), projectDir);\n}\n"],"names":[],"mappings":";;;;;;AAaA,eAAsB,uBACpB,MACA,YACA;CACA,MAAM,EACJ,MAAM,eACN,MAAM,eACN,MAAM,eACN,eACA,KACA,KACA,UACE;AACJ,KAAI,MACF,SAAQ,IAAI,EAAE,MAAM,CAAC;CAEvB,MAAM,UAAU,oBAAoB,WAAW;AAC/C,KAAI,IACF,OAAM,sBAAsB,QAAQ;UAC3B,cACT,OAAM,kBACJ;EACE;EACA;EACA;EACA;EACD,EACD,QACD;UACQ,IAGT,OAAM,kBADgB,qBAAqB,SADlB,QAAQ,IAAI,CACgC,EAC9B,QAAQ;MAC1C;AACL,UAAQ,IAAI,iDAAiD;AAC7D;;AAEF,OAAM,QAAQ,MAAM;AACpB,OAAM,wBAAwB,eAAe,WAAW,EAAE,WAAW","debug_id":"75666556-a149-5fb2-b7ad-93df8d302b27"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"generate-subgraph-C6dWIQzP.mjs","sources":["../src/services/generate-subgraph.ts"],"sourcesContent":["import {\n detectFeatures,\n generateAllSubgraphs,\n generateSubgraph,\n syncFeatureDependencies,\n} from \"@powerhousedao/codegen\";\nimport {\n buildTsMorphProject,\n getSubgraphMetadata,\n} from \"@powerhousedao/codegen/utils\";\nimport { dirname } from \"node:path\";\nimport type { GenerateSubgraphArgs } from \"../types.js\";\n\nexport async function startGenerateSubgraph(\n args: GenerateSubgraphArgs,\n projectDir: string,\n) {\n const { name, dir, all, debug } = args;\n if (debug) {\n console.log({ args });\n }\n const project = buildTsMorphProject(projectDir);\n if (all) {\n await generateAllSubgraphs(project);\n } else if (name) {\n await generateSubgraph(name, project);\n } else if (dir) {\n const { subgraphName } = getSubgraphMetadata(project, dirname(dir));\n if (!subgraphName) {\n throw new Error(`Failed to get data for subgraph in dir \"${dir}\"`);\n }\n await generateSubgraph(subgraphName, project);\n } else {\n console.log(\"Please specify either `name`, `dir`, or `all`.\");\n return;\n }\n await project.save();\n await syncFeatureDependencies(detectFeatures(projectDir), projectDir);\n}\n"],"names":[],"mappings":";;;;;;AAaA,eAAsB,sBACpB,MACA,YACA;CACA,MAAM,EAAE,MAAM,KAAK,KAAK,UAAU;AAClC,KAAI,MACF,SAAQ,IAAI,EAAE,MAAM,CAAC;CAEvB,MAAM,UAAU,oBAAoB,WAAW;AAC/C,KAAI,IACF,OAAM,qBAAqB,QAAQ;UAC1B,KACT,OAAM,iBAAiB,MAAM,QAAQ;UAC5B,KAAK;EACd,MAAM,EAAE,iBAAiB,oBAAoB,SAAS,QAAQ,IAAI,CAAC;AACnE,MAAI,CAAC,aACH,OAAM,IAAI,MAAM,2CAA2C,IAAI,GAAG;AAEpE,QAAM,iBAAiB,cAAc,QAAQ;QACxC;AACL,UAAQ,IAAI,iDAAiD;AAC7D;;AAEF,OAAM,QAAQ,MAAM;AACpB,OAAM,wBAAwB,eAAe,WAAW,EAAE,WAAW","debug_id":"c9380323-18ba-5262-a920-184315ae0180"}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import { n as startSwitchboard } from "./switchboard-BsdbF-rL.mjs";
|
|
2
|
-
export { startSwitchboard };
|
|
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]="b723e0a9-0558-5c56-b8bb-1b5785fd8633")}catch(e){}}();
|
|
4
|
-
//# debugId=b723e0a9-0558-5c56-b8bb-1b5785fd8633
|