@powerhousedao/ph-cli 6.0.0-dev.16 → 6.0.0-dev.160
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/assign-env-vars-CzHgn5ax.mjs +15 -0
- package/dist/assign-env-vars-CzHgn5ax.mjs.map +1 -0
- package/dist/auth-BeA5gDPQ.mjs +23 -0
- package/dist/auth-BeA5gDPQ.mjs.map +1 -0
- package/dist/build-BflSHYLP.mjs +33 -0
- package/dist/build-BflSHYLP.mjs.map +1 -0
- package/dist/cli.d.mts +1 -0
- package/dist/cli.mjs +731 -0
- package/dist/cli.mjs.map +1 -0
- package/dist/connect-build-CrnmJlav.mjs +21 -0
- package/dist/connect-build-CrnmJlav.mjs.map +1 -0
- package/dist/connect-preview-4Xe7Lm1V.mjs +27 -0
- package/dist/connect-preview-4Xe7Lm1V.mjs.map +1 -0
- package/dist/connect-studio-38_NrT_a.mjs +28 -0
- package/dist/connect-studio-38_NrT_a.mjs.map +1 -0
- package/dist/connect-studio-DuH6WcoA.mjs +3 -0
- package/dist/generate-CMQGYRrW.mjs +2 -0
- package/dist/generate-Dq80G8n4.mjs +58 -0
- package/dist/generate-Dq80G8n4.mjs.map +1 -0
- package/dist/inspect-nPp5CN8a.mjs +45 -0
- package/dist/inspect-nPp5CN8a.mjs.map +1 -0
- package/dist/migrate-DzLTX506.mjs +245 -0
- package/dist/migrate-DzLTX506.mjs.map +1 -0
- package/dist/scripts/generate-commands-docs.ts +45 -0
- package/dist/switchboard-BclxuF4j.mjs +72 -0
- package/dist/switchboard-BclxuF4j.mjs.map +1 -0
- package/dist/switchboard-DXF1APL1.mjs +2 -0
- package/dist/switchboard-migrate-Cwx-8MnF.mjs +50 -0
- package/dist/switchboard-migrate-Cwx-8MnF.mjs.map +1 -0
- package/dist/utils-DbFSkp_Q.mjs +161 -0
- package/dist/utils-DbFSkp_Q.mjs.map +1 -0
- package/dist/vetra-CjawXTZJ.mjs +360 -0
- package/dist/vetra-CjawXTZJ.mjs.map +1 -0
- package/package.json +34 -33
- package/dist/scripts/generate-commands-md.d.ts +0 -2
- package/dist/scripts/generate-commands-md.d.ts.map +0 -1
- package/dist/scripts/generate-commands-md.js +0 -72
- package/dist/scripts/generate-commands-md.js.map +0 -1
- package/dist/scripts/generate-commands-md.ts +0 -84
- package/dist/scripts/generate-version.d.ts +0 -2
- package/dist/scripts/generate-version.d.ts.map +0 -1
- package/dist/scripts/generate-version.js +0 -13
- package/dist/scripts/generate-version.js.map +0 -1
- package/dist/scripts/generate-version.ts +0 -22
- package/dist/src/cli.d.ts +0 -3
- package/dist/src/cli.d.ts.map +0 -1
- package/dist/src/cli.js +0 -42
- package/dist/src/cli.js.map +0 -1
- package/dist/src/commands/access-token.d.ts +0 -9
- package/dist/src/commands/access-token.d.ts.map +0 -1
- package/dist/src/commands/access-token.js +0 -110
- package/dist/src/commands/access-token.js.map +0 -1
- package/dist/src/commands/connect.d.ts +0 -19
- package/dist/src/commands/connect.d.ts.map +0 -1
- package/dist/src/commands/connect.js +0 -85
- package/dist/src/commands/connect.js.map +0 -1
- package/dist/src/commands/generate.d.ts +0 -9
- package/dist/src/commands/generate.d.ts.map +0 -1
- package/dist/src/commands/generate.js +0 -41
- package/dist/src/commands/generate.js.map +0 -1
- package/dist/src/commands/help.d.ts +0 -3
- package/dist/src/commands/help.d.ts.map +0 -1
- package/dist/src/commands/help.js +0 -9
- package/dist/src/commands/help.js.map +0 -1
- package/dist/src/commands/index.d.ts +0 -14
- package/dist/src/commands/index.d.ts.map +0 -1
- package/dist/src/commands/index.js +0 -14
- package/dist/src/commands/index.js.map +0 -1
- package/dist/src/commands/inspect.d.ts +0 -6
- package/dist/src/commands/inspect.d.ts.map +0 -1
- package/dist/src/commands/inspect.js +0 -21
- package/dist/src/commands/inspect.js.map +0 -1
- package/dist/src/commands/install.d.ts +0 -15
- package/dist/src/commands/install.d.ts.map +0 -1
- package/dist/src/commands/install.js +0 -127
- package/dist/src/commands/install.js.map +0 -1
- package/dist/src/commands/list.d.ts +0 -9
- package/dist/src/commands/list.d.ts.map +0 -1
- package/dist/src/commands/list.js +0 -36
- package/dist/src/commands/list.js.map +0 -1
- package/dist/src/commands/login.d.ts +0 -12
- package/dist/src/commands/login.d.ts.map +0 -1
- package/dist/src/commands/login.js +0 -208
- package/dist/src/commands/login.js.map +0 -1
- package/dist/src/commands/migrate.d.ts +0 -10
- package/dist/src/commands/migrate.d.ts.map +0 -1
- package/dist/src/commands/migrate.js +0 -12
- package/dist/src/commands/migrate.js.map +0 -1
- package/dist/src/commands/register-commands.d.ts +0 -5
- package/dist/src/commands/register-commands.d.ts.map +0 -1
- package/dist/src/commands/register-commands.js +0 -32
- package/dist/src/commands/register-commands.js.map +0 -1
- package/dist/src/commands/service.d.ts +0 -5
- package/dist/src/commands/service.d.ts.map +0 -1
- package/dist/src/commands/service.js +0 -67
- package/dist/src/commands/service.js.map +0 -1
- package/dist/src/commands/switchboard.d.ts +0 -9
- package/dist/src/commands/switchboard.d.ts.map +0 -1
- package/dist/src/commands/switchboard.js +0 -78
- package/dist/src/commands/switchboard.js.map +0 -1
- package/dist/src/commands/uninstall.d.ts +0 -15
- package/dist/src/commands/uninstall.d.ts.map +0 -1
- package/dist/src/commands/uninstall.js +0 -120
- package/dist/src/commands/uninstall.js.map +0 -1
- package/dist/src/commands/vetra.d.ts +0 -11
- package/dist/src/commands/vetra.d.ts.map +0 -1
- package/dist/src/commands/vetra.js +0 -35
- package/dist/src/commands/vetra.js.map +0 -1
- package/dist/src/help.d.ts +0 -65
- package/dist/src/help.d.ts.map +0 -1
- package/dist/src/help.js +0 -770
- package/dist/src/help.js.map +0 -1
- package/dist/src/index.d.ts +0 -5
- package/dist/src/index.d.ts.map +0 -1
- package/dist/src/index.js +0 -5
- package/dist/src/index.js.map +0 -1
- package/dist/src/services/auth.d.ts +0 -69
- package/dist/src/services/auth.d.ts.map +0 -1
- package/dist/src/services/auth.js +0 -171
- package/dist/src/services/auth.js.map +0 -1
- package/dist/src/services/connect.d.ts +0 -2
- package/dist/src/services/connect.d.ts.map +0 -1
- package/dist/src/services/connect.js +0 -2
- package/dist/src/services/connect.js.map +0 -1
- package/dist/src/services/generate.d.ts +0 -30
- package/dist/src/services/generate.d.ts.map +0 -1
- package/dist/src/services/generate.js +0 -106
- package/dist/src/services/generate.js.map +0 -1
- package/dist/src/services/inspect.d.ts +0 -5
- package/dist/src/services/inspect.d.ts.map +0 -1
- package/dist/src/services/inspect.js +0 -49
- package/dist/src/services/inspect.js.map +0 -1
- package/dist/src/services/migrate.d.ts +0 -7
- package/dist/src/services/migrate.d.ts.map +0 -1
- package/dist/src/services/migrate.js +0 -289
- package/dist/src/services/migrate.js.map +0 -1
- package/dist/src/services/switchboard-migrate.d.ts +0 -7
- package/dist/src/services/switchboard-migrate.d.ts.map +0 -1
- package/dist/src/services/switchboard-migrate.js +0 -60
- package/dist/src/services/switchboard-migrate.js.map +0 -1
- package/dist/src/services/switchboard.d.ts +0 -54
- package/dist/src/services/switchboard.d.ts.map +0 -1
- package/dist/src/services/switchboard.js +0 -79
- package/dist/src/services/switchboard.js.map +0 -1
- package/dist/src/services/vetra.d.ts +0 -15
- package/dist/src/services/vetra.d.ts.map +0 -1
- package/dist/src/services/vetra.js +0 -176
- package/dist/src/services/vetra.js.map +0 -1
- package/dist/src/types.d.ts +0 -2
- package/dist/src/types.d.ts.map +0 -1
- package/dist/src/types.js +0 -2
- package/dist/src/types.js.map +0 -1
- package/dist/src/utils/configure-vetra-github-url.d.ts +0 -12
- package/dist/src/utils/configure-vetra-github-url.d.ts.map +0 -1
- package/dist/src/utils/configure-vetra-github-url.js +0 -230
- package/dist/src/utils/configure-vetra-github-url.js.map +0 -1
- package/dist/src/utils.d.ts +0 -116
- package/dist/src/utils.d.ts.map +0 -1
- package/dist/src/utils.js +0 -261
- package/dist/src/utils.js.map +0 -1
- package/dist/src/version.d.ts +0 -2
- package/dist/src/version.d.ts.map +0 -1
- package/dist/src/version.js +0 -3
- package/dist/src/version.js.map +0 -1
- package/dist/test/utils.test.d.ts +0 -2
- package/dist/test/utils.test.d.ts.map +0 -1
- package/dist/test/utils.test.js +0 -132
- package/dist/test/utils.test.js.map +0 -1
- package/dist/tsconfig.tsbuildinfo +0 -1
- package/dist/vitest.config.d.ts +0 -3
- package/dist/vitest.config.d.ts.map +0 -1
- package/dist/vitest.config.js +0 -7
- package/dist/vitest.config.js.map +0 -1
|
@@ -0,0 +1,360 @@
|
|
|
1
|
+
import { t as generateProjectDriveId } from "./utils-DbFSkp_Q.mjs";
|
|
2
|
+
import "./assign-env-vars-CzHgn5ax.mjs";
|
|
3
|
+
import { t as runConnectStudio } from "./connect-studio-38_NrT_a.mjs";
|
|
4
|
+
import { n as startSwitchboard } from "./switchboard-BclxuF4j.mjs";
|
|
5
|
+
import { execSync } from "node:child_process";
|
|
6
|
+
import { VETRA_PROCESSOR_CONFIG_KEY } from "@powerhousedao/config";
|
|
7
|
+
import { createLogger } from "vite";
|
|
8
|
+
import { addDefaultDrive } from "@powerhousedao/switchboard/utils";
|
|
9
|
+
import { blue, green, red, yellow } from "colorette";
|
|
10
|
+
import { childLogger, setLogLevel } from "document-model";
|
|
11
|
+
import { createVetraDocument, getVetraDocuments, setPackageGithubUrl } from "@powerhousedao/common/utils";
|
|
12
|
+
import { createInterface } from "node:readline";
|
|
13
|
+
//#region src/utils/configure-vetra-github-url.ts
|
|
14
|
+
/**
|
|
15
|
+
* Get git remote URL (origin)
|
|
16
|
+
* @returns Git remote URL or null if not configured
|
|
17
|
+
*/
|
|
18
|
+
function getGitRemoteUrl() {
|
|
19
|
+
try {
|
|
20
|
+
return execSync("git remote get-url origin", {
|
|
21
|
+
encoding: "utf-8",
|
|
22
|
+
stdio: [
|
|
23
|
+
"pipe",
|
|
24
|
+
"pipe",
|
|
25
|
+
"pipe"
|
|
26
|
+
]
|
|
27
|
+
}).trim() || null;
|
|
28
|
+
} catch {
|
|
29
|
+
return null;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Prompt user to enter a custom GitHub URL
|
|
34
|
+
*/
|
|
35
|
+
async function promptForCustomUrl() {
|
|
36
|
+
return new Promise((resolve) => {
|
|
37
|
+
const rl = createInterface({
|
|
38
|
+
input: process.stdin,
|
|
39
|
+
output: process.stdout
|
|
40
|
+
});
|
|
41
|
+
process.stdout.write("\nEnter GitHub URL (or press Enter to skip): ");
|
|
42
|
+
rl.on("line", (answer) => {
|
|
43
|
+
rl.close();
|
|
44
|
+
resolve(answer.trim() || null);
|
|
45
|
+
});
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Prompt yes/no question
|
|
50
|
+
*/
|
|
51
|
+
async function promptYesNo(question) {
|
|
52
|
+
return new Promise((resolve) => {
|
|
53
|
+
const rl = createInterface({
|
|
54
|
+
input: process.stdin,
|
|
55
|
+
output: process.stdout
|
|
56
|
+
});
|
|
57
|
+
process.stdout.write(`\n${question} (y/n): `);
|
|
58
|
+
rl.on("line", (answer) => {
|
|
59
|
+
rl.close();
|
|
60
|
+
const response = answer.trim().toLowerCase();
|
|
61
|
+
resolve(response === "y" || response === "yes");
|
|
62
|
+
});
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Prompt user to select or enter GitHub URL
|
|
67
|
+
* @param gitRemoteUrl - Git remote URL if available
|
|
68
|
+
* @returns Selected URL or null if skipped
|
|
69
|
+
*/
|
|
70
|
+
async function promptForGithubUrl(gitRemoteUrl) {
|
|
71
|
+
return new Promise((resolve) => {
|
|
72
|
+
const rl = createInterface({
|
|
73
|
+
input: process.stdin,
|
|
74
|
+
output: process.stdout
|
|
75
|
+
});
|
|
76
|
+
console.log("\n" + "=".repeat(50));
|
|
77
|
+
console.log("🔍 Vetra Package Configuration");
|
|
78
|
+
console.log("=".repeat(50));
|
|
79
|
+
console.log("\nWe detected a Vetra package document in your remote drive without a GitHub URL configured.");
|
|
80
|
+
console.log("\nWould you like to configure the GitHub URL now?");
|
|
81
|
+
if (gitRemoteUrl) {
|
|
82
|
+
console.log(`\nGit remote URL detected: ${gitRemoteUrl}`);
|
|
83
|
+
console.log("\nOptions:");
|
|
84
|
+
console.log("1. Use detected URL");
|
|
85
|
+
console.log("2. Enter a different URL");
|
|
86
|
+
console.log("3. Skip configuration");
|
|
87
|
+
process.stdout.write("\nSelect an option (1-3): ");
|
|
88
|
+
const handleAnswer = (answer) => {
|
|
89
|
+
const choice = answer.trim();
|
|
90
|
+
if (choice === "1") {
|
|
91
|
+
rl.close();
|
|
92
|
+
resolve(gitRemoteUrl);
|
|
93
|
+
} else if (choice === "2") {
|
|
94
|
+
rl.close();
|
|
95
|
+
promptForCustomUrl().then(resolve).catch(() => resolve(null));
|
|
96
|
+
} else if (choice === "3") {
|
|
97
|
+
rl.close();
|
|
98
|
+
resolve(null);
|
|
99
|
+
} else process.stdout.write("Invalid choice. Select an option (1-3): ");
|
|
100
|
+
};
|
|
101
|
+
rl.on("line", handleAnswer);
|
|
102
|
+
} else {
|
|
103
|
+
console.log("\nNo git remote URL detected.");
|
|
104
|
+
console.log("\nOptions:");
|
|
105
|
+
console.log("1. Enter GitHub URL manually");
|
|
106
|
+
console.log("2. Skip configuration");
|
|
107
|
+
process.stdout.write("\nSelect an option (1-2): ");
|
|
108
|
+
const handleAnswer = (answer) => {
|
|
109
|
+
const choice = answer.trim();
|
|
110
|
+
if (choice === "1") {
|
|
111
|
+
rl.close();
|
|
112
|
+
promptForCustomUrl().then(resolve).catch(() => resolve(null));
|
|
113
|
+
} else if (choice === "2") {
|
|
114
|
+
rl.close();
|
|
115
|
+
resolve(null);
|
|
116
|
+
} else process.stdout.write("Invalid choice. Select an option (1-2): ");
|
|
117
|
+
};
|
|
118
|
+
rl.on("line", handleAnswer);
|
|
119
|
+
}
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* Set git remote URL (origin)
|
|
124
|
+
*/
|
|
125
|
+
function setGitRemoteUrl(url) {
|
|
126
|
+
try {
|
|
127
|
+
execSync(`git remote add origin ${url}`, { stdio: "inherit" });
|
|
128
|
+
console.log(`✅ Git remote origin set to: ${url}`);
|
|
129
|
+
} catch {
|
|
130
|
+
try {
|
|
131
|
+
execSync(`git remote set-url origin ${url}`, { stdio: "inherit" });
|
|
132
|
+
console.log(`✅ Git remote origin updated to: ${url}`);
|
|
133
|
+
} catch {
|
|
134
|
+
console.error(red(`❌ Failed to set git remote URL`));
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
/**
|
|
139
|
+
* Validates documents and returns the target document to use
|
|
140
|
+
* Warns if multiple documents found
|
|
141
|
+
*/
|
|
142
|
+
function validateAndSelectDocument(documents) {
|
|
143
|
+
if (documents.length === 0) return null;
|
|
144
|
+
if (documents.length > 1) console.warn(`⚠️ Warning: Multiple Vetra documents found (${documents.length}). Using first document.`);
|
|
145
|
+
return documents[0];
|
|
146
|
+
}
|
|
147
|
+
async function applyGithubUrlConfiguration(graphqlEndpoint, vetraDriveId, documentId, selectedUrl, shouldSetRemote) {
|
|
148
|
+
await setPackageGithubUrl(graphqlEndpoint, vetraDriveId, documentId, selectedUrl);
|
|
149
|
+
console.log(`✅ GitHub URL configured: ${selectedUrl}`);
|
|
150
|
+
if (shouldSetRemote) setGitRemoteUrl(selectedUrl);
|
|
151
|
+
}
|
|
152
|
+
function logVerbose(message, verbose) {
|
|
153
|
+
if (verbose) console.log(message);
|
|
154
|
+
}
|
|
155
|
+
/**
|
|
156
|
+
* Sleep for a specified number of milliseconds
|
|
157
|
+
*/
|
|
158
|
+
function sleep(ms) {
|
|
159
|
+
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
160
|
+
}
|
|
161
|
+
/**
|
|
162
|
+
* Configure GitHub URL for Vetra documents
|
|
163
|
+
* @param switchboardPort - Port where switchboard is running
|
|
164
|
+
* @param vetraDriveUrl - Remote drive URL
|
|
165
|
+
* @param verbose - Enable verbose logging
|
|
166
|
+
*/
|
|
167
|
+
async function configureVetraGithubUrl(switchboardPort, vetraDriveUrl, verbose) {
|
|
168
|
+
logVerbose("Checking GitHub URL configuration...", verbose);
|
|
169
|
+
try {
|
|
170
|
+
const graphqlEndpoint = `http://localhost:${switchboardPort}/graphql`;
|
|
171
|
+
const vetraDriveId = vetraDriveUrl.split("/").pop();
|
|
172
|
+
if (!vetraDriveId) throw new Error("Invalid vetraDriveUrl: unable to extract drive ID");
|
|
173
|
+
const documents = await getVetraDocuments(graphqlEndpoint, vetraDriveId);
|
|
174
|
+
if (documents.some((doc) => doc.githubUrl)) {
|
|
175
|
+
logVerbose("GitHub URL already configured, skipping setup", verbose);
|
|
176
|
+
return;
|
|
177
|
+
}
|
|
178
|
+
let targetDocumentId;
|
|
179
|
+
const targetDocument = validateAndSelectDocument(documents);
|
|
180
|
+
const gitRemoteUrl = getGitRemoteUrl();
|
|
181
|
+
const selectedUrl = await promptForGithubUrl(gitRemoteUrl);
|
|
182
|
+
if (!selectedUrl) {
|
|
183
|
+
logVerbose("GitHub URL configuration skipped", verbose);
|
|
184
|
+
return;
|
|
185
|
+
}
|
|
186
|
+
let shouldSetRemote = false;
|
|
187
|
+
if (selectedUrl !== gitRemoteUrl && !gitRemoteUrl) shouldSetRemote = await promptYesNo("Set this as your git remote URL?");
|
|
188
|
+
if (!targetDocument) {
|
|
189
|
+
logVerbose("No Vetra documents found, creating new document...", verbose);
|
|
190
|
+
targetDocumentId = await createVetraDocument(graphqlEndpoint, vetraDriveId, "vetra-package");
|
|
191
|
+
logVerbose(`Created new document: ${targetDocumentId}`, verbose);
|
|
192
|
+
} else targetDocumentId = targetDocument.id;
|
|
193
|
+
await applyGithubUrlConfiguration(graphqlEndpoint, vetraDriveId, targetDocumentId, selectedUrl, shouldSetRemote);
|
|
194
|
+
} catch (error) {
|
|
195
|
+
console.error(red(`⚠️ GitHub URL configuration failed: ${error instanceof Error ? error.message : String(error)}`));
|
|
196
|
+
logVerbose(String(error), verbose);
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
//#endregion
|
|
200
|
+
//#region src/services/vetra.ts
|
|
201
|
+
const VETRA_DRIVE_NAME = "vetra";
|
|
202
|
+
const getDefaultVetraUrl = (port) => `http://localhost:${port}/d/${generateProjectDriveId(VETRA_DRIVE_NAME)}`;
|
|
203
|
+
const getDriveId = (driveUrl) => driveUrl?.split("/").pop() ?? generateProjectDriveId(VETRA_DRIVE_NAME);
|
|
204
|
+
function createViteLogger(color) {
|
|
205
|
+
const customLogger = createLogger("info");
|
|
206
|
+
const loggerInfo = customLogger.info.bind(customLogger);
|
|
207
|
+
customLogger.info = (msg, options) => {
|
|
208
|
+
loggerInfo(color(msg), options);
|
|
209
|
+
};
|
|
210
|
+
const loggerWarn = customLogger.warn.bind(customLogger);
|
|
211
|
+
customLogger.warn = (msg, options) => {
|
|
212
|
+
loggerWarn(yellow(msg), options);
|
|
213
|
+
};
|
|
214
|
+
const loggerError = customLogger.error.bind(customLogger);
|
|
215
|
+
customLogger.error = (msg, options) => {
|
|
216
|
+
loggerError(red(msg), options);
|
|
217
|
+
};
|
|
218
|
+
const loggerWarnOnce = customLogger.warnOnce.bind(customLogger);
|
|
219
|
+
customLogger.warnOnce = (msg, options) => {
|
|
220
|
+
loggerWarnOnce(yellow(msg), options);
|
|
221
|
+
};
|
|
222
|
+
return customLogger;
|
|
223
|
+
}
|
|
224
|
+
async function startVetraPreviewDrive(reactor, port, verbose) {
|
|
225
|
+
const previewDriveId = generateProjectDriveId("preview");
|
|
226
|
+
const driveUrl = await addDefaultDrive(reactor, {
|
|
227
|
+
id: previewDriveId,
|
|
228
|
+
slug: previewDriveId,
|
|
229
|
+
global: {
|
|
230
|
+
name: "Vetra Preview",
|
|
231
|
+
icon: "https://azure-elderly-tortoise-212.mypinata.cloud/ipfs/bafkreifddkbopiyvcirf7vaqar74th424r5phlxkdxniirdyg3qgu2ajha",
|
|
232
|
+
nodes: []
|
|
233
|
+
},
|
|
234
|
+
local: {
|
|
235
|
+
availableOffline: true,
|
|
236
|
+
listeners: [],
|
|
237
|
+
sharingType: "public",
|
|
238
|
+
triggers: []
|
|
239
|
+
}
|
|
240
|
+
}, port);
|
|
241
|
+
if (verbose) console.log(blue(`Vetra Switchboard: Preview drive: ${driveUrl}`));
|
|
242
|
+
return driveUrl;
|
|
243
|
+
}
|
|
244
|
+
async function startLocalVetraSwitchboard(args, logger) {
|
|
245
|
+
const { connectPort, switchboardPort, dev, packages, disableLocalPackages, debug, httpsKeyFile, httpsCertFile, remoteDrive, interactive, watch, verbose } = args;
|
|
246
|
+
const remoteDrives = remoteDrive ? [remoteDrive] : [];
|
|
247
|
+
const vetraProcessorConfig = {
|
|
248
|
+
interactive,
|
|
249
|
+
driveUrl: remoteDrive ?? getDefaultVetraUrl(connectPort),
|
|
250
|
+
driveId: getDriveId(remoteDrive)
|
|
251
|
+
};
|
|
252
|
+
(/* @__PURE__ */ new Map()).set(VETRA_PROCESSOR_CONFIG_KEY, vetraProcessorConfig);
|
|
253
|
+
const vetraDriveId = generateProjectDriveId(VETRA_DRIVE_NAME);
|
|
254
|
+
try {
|
|
255
|
+
const switchboard = await startSwitchboard({
|
|
256
|
+
...args,
|
|
257
|
+
useVetraDrive: true,
|
|
258
|
+
mcp: true,
|
|
259
|
+
port: switchboardPort,
|
|
260
|
+
dev,
|
|
261
|
+
packages,
|
|
262
|
+
remoteDrives,
|
|
263
|
+
vetraDriveId,
|
|
264
|
+
disableLocalPackages,
|
|
265
|
+
debug,
|
|
266
|
+
httpsKeyFile,
|
|
267
|
+
httpsCertFile,
|
|
268
|
+
basePath: void 0,
|
|
269
|
+
keypairPath: void 0,
|
|
270
|
+
dbPath: void 0,
|
|
271
|
+
useIdentity: void 0,
|
|
272
|
+
migrate: void 0,
|
|
273
|
+
migrateStatus: void 0,
|
|
274
|
+
requireIdentity: void 0
|
|
275
|
+
}, logger);
|
|
276
|
+
let previewDriveUrl = null;
|
|
277
|
+
if (watch) try {
|
|
278
|
+
previewDriveUrl = await startVetraPreviewDrive(switchboard.reactor, switchboardPort, verbose);
|
|
279
|
+
} catch (error) {
|
|
280
|
+
console.error(error);
|
|
281
|
+
}
|
|
282
|
+
if (verbose) {
|
|
283
|
+
console.log(blue(`Vetra Switchboard: Started successfully`));
|
|
284
|
+
if (remoteDrive) console.log(blue(`Vetra Switchboard: Syncing with remote drive: ${remoteDrive}`));
|
|
285
|
+
} else {
|
|
286
|
+
console.log();
|
|
287
|
+
console.log(blue(`Vetra Switchboard: http://localhost:${switchboardPort}/graphql`));
|
|
288
|
+
console.log(blue(` ➜ Drive URL: ${switchboard.defaultDriveUrl}`));
|
|
289
|
+
if (previewDriveUrl) console.log(blue(` ➜ Preview Drive URL: ${previewDriveUrl}`));
|
|
290
|
+
}
|
|
291
|
+
return {
|
|
292
|
+
driveUrl: switchboard.defaultDriveUrl || "",
|
|
293
|
+
previewDriveUrl
|
|
294
|
+
};
|
|
295
|
+
} catch (error) {
|
|
296
|
+
console.error(red(`Vetra Switchboard: ${error instanceof Error ? error.message : String(error)}`));
|
|
297
|
+
throw error instanceof Error ? error : new Error(String(error));
|
|
298
|
+
}
|
|
299
|
+
}
|
|
300
|
+
async function startVetra(args) {
|
|
301
|
+
const { switchboardPort, connectPort, verbose, remoteDrive, disableConnect, debug, httpsCertFile, httpsKeyFile, disableLocalPackages, host, open, cors, strictPort, printUrls, bindCLIShortcuts, watchTimeout } = args;
|
|
302
|
+
const switchboardLogger = childLogger(["vetra", "switchboard"]);
|
|
303
|
+
try {
|
|
304
|
+
if (!process.env.LOG_LEVEL) setLogLevel("info");
|
|
305
|
+
if (verbose) {
|
|
306
|
+
switchboardLogger.info("Starting Vetra Switchboard...");
|
|
307
|
+
if (remoteDrive) {
|
|
308
|
+
const source = remoteDrive ? "command line argument" : "powerhouse.config.json";
|
|
309
|
+
switchboardLogger.info(`Using vetraUrl from ${source}: ${remoteDrive}`);
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
const switchboardResult = await startLocalVetraSwitchboard({
|
|
313
|
+
...args,
|
|
314
|
+
dev: true,
|
|
315
|
+
httpsKeyFile,
|
|
316
|
+
httpsCertFile,
|
|
317
|
+
disableLocalPackages,
|
|
318
|
+
debug
|
|
319
|
+
}, switchboardLogger);
|
|
320
|
+
const driveUrl = switchboardResult.driveUrl || remoteDrive || "";
|
|
321
|
+
const previewDriveUrl = switchboardResult.previewDriveUrl;
|
|
322
|
+
if (remoteDrive) {
|
|
323
|
+
await sleep(3e3);
|
|
324
|
+
await configureVetraGithubUrl(switchboardPort, remoteDrive, verbose);
|
|
325
|
+
await sleep(2e3);
|
|
326
|
+
}
|
|
327
|
+
if (verbose) console.log("Starting Codegen Reactor...");
|
|
328
|
+
if (!disableConnect) {
|
|
329
|
+
if (verbose) {
|
|
330
|
+
console.log("Starting Connect...");
|
|
331
|
+
const drives = previewDriveUrl ? `${driveUrl}, ${previewDriveUrl}` : driveUrl;
|
|
332
|
+
console.log(` ➜ Connect will use drives: ${drives}`);
|
|
333
|
+
}
|
|
334
|
+
console.log();
|
|
335
|
+
console.log(green(`Vetra Connect: http://localhost:${connectPort}`));
|
|
336
|
+
const customViteLogger = createViteLogger(green);
|
|
337
|
+
await runConnectStudio({
|
|
338
|
+
...args,
|
|
339
|
+
defaultDrivesUrl: previewDriveUrl ? [driveUrl, previewDriveUrl].join(",") : driveUrl,
|
|
340
|
+
drivesPreserveStrategy: "preserve-all",
|
|
341
|
+
port: connectPort,
|
|
342
|
+
disableLocalPackages,
|
|
343
|
+
debug,
|
|
344
|
+
host,
|
|
345
|
+
open,
|
|
346
|
+
cors,
|
|
347
|
+
strictPort,
|
|
348
|
+
printUrls,
|
|
349
|
+
bindCLIShortcuts,
|
|
350
|
+
watchTimeout
|
|
351
|
+
}, customViteLogger);
|
|
352
|
+
}
|
|
353
|
+
} catch (error) {
|
|
354
|
+
console.error(error);
|
|
355
|
+
}
|
|
356
|
+
}
|
|
357
|
+
//#endregion
|
|
358
|
+
export { startVetra };
|
|
359
|
+
|
|
360
|
+
//# sourceMappingURL=vetra-CjawXTZJ.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vetra-CjawXTZJ.mjs","names":[],"sources":["../src/utils/configure-vetra-github-url.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 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 { 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 try {\n const switchboard = await startSwitchboard(\n {\n ...args,\n useVetraDrive: true, // Use Vetra drive instead of Powerhouse drive\n mcp: true,\n port: switchboardPort,\n dev,\n packages,\n remoteDrives,\n vetraDriveId,\n disableLocalPackages,\n debug,\n httpsKeyFile,\n httpsCertFile,\n basePath: undefined,\n keypairPath: undefined,\n dbPath: undefined,\n useIdentity: undefined,\n migrate: undefined,\n migrateStatus: undefined,\n requireIdentity: undefined,\n },\n logger,\n );\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 switchboardPort,\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(`Vetra Switchboard: http://localhost:${switchboardPort}/graphql`),\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 };\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 switchboardPort,\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\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(switchboardPort, remoteDrive, verbose);\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"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@powerhousedao/ph-cli",
|
|
3
|
-
"version": "6.0.0-dev.
|
|
3
|
+
"version": "6.0.0-dev.160",
|
|
4
4
|
"description": "",
|
|
5
5
|
"license": "AGPL-3.0-only",
|
|
6
6
|
"type": "module",
|
|
@@ -11,50 +11,51 @@
|
|
|
11
11
|
"publishConfig": {
|
|
12
12
|
"access": "public"
|
|
13
13
|
},
|
|
14
|
+
"engines": {
|
|
15
|
+
"node": ">=24.0.0"
|
|
16
|
+
},
|
|
14
17
|
"bin": {
|
|
15
|
-
"ph-cli": "dist/
|
|
18
|
+
"ph-cli": "./dist/cli.mjs"
|
|
16
19
|
},
|
|
17
20
|
"files": [
|
|
18
21
|
"dist"
|
|
19
22
|
],
|
|
20
|
-
"exports": "./dist/src/index.js",
|
|
21
|
-
"types": "./dist/src/index.d.ts",
|
|
22
23
|
"keywords": [],
|
|
23
24
|
"author": "",
|
|
24
|
-
"devDependencies": {
|
|
25
|
-
"@types/node": "^24.6.1",
|
|
26
|
-
"@types/pg": "^8.11.10",
|
|
27
|
-
"concurrently": "^9.1.2",
|
|
28
|
-
"copyfiles": "^2.4.1",
|
|
29
|
-
"nodemon": "^3.1.9",
|
|
30
|
-
"vitest": "^3.2.4",
|
|
31
|
-
"document-drive": "6.0.0-dev.16",
|
|
32
|
-
"document-model": "6.0.0-dev.16"
|
|
33
|
-
},
|
|
34
25
|
"dependencies": {
|
|
35
|
-
"
|
|
36
|
-
"
|
|
37
|
-
"
|
|
38
|
-
"
|
|
39
|
-
"
|
|
40
|
-
"
|
|
41
|
-
"
|
|
42
|
-
"
|
|
43
|
-
"
|
|
44
|
-
"
|
|
45
|
-
"@powerhousedao/
|
|
46
|
-
"
|
|
47
|
-
"@powerhousedao/
|
|
48
|
-
"@
|
|
26
|
+
"tsdown": "0.21.0",
|
|
27
|
+
"vite": "8.0.2",
|
|
28
|
+
"cmd-ts": "0.15.0",
|
|
29
|
+
"colorette": "2.0.20",
|
|
30
|
+
"kysely": "0.28.11",
|
|
31
|
+
"package-manager-detector": "1.6.0",
|
|
32
|
+
"pg": "8.18.0",
|
|
33
|
+
"read-pkg": "10.1.0",
|
|
34
|
+
"ts-morph": "27.0.2",
|
|
35
|
+
"write-package": "7.2.0",
|
|
36
|
+
"@powerhousedao/codegen": "6.0.0-dev.160",
|
|
37
|
+
"document-model": "6.0.0-dev.160",
|
|
38
|
+
"@powerhousedao/common": "6.0.0-dev.160",
|
|
39
|
+
"@powerhousedao/shared": "6.0.0-dev.160",
|
|
40
|
+
"@powerhousedao/config": "6.0.0-dev.160",
|
|
41
|
+
"@powerhousedao/switchboard": "6.0.0-dev.160",
|
|
42
|
+
"@powerhousedao/builder-tools": "6.0.0-dev.160",
|
|
43
|
+
"@renown/sdk": "6.0.0-dev.160",
|
|
44
|
+
"@powerhousedao/reactor": "6.0.0-dev.160"
|
|
45
|
+
},
|
|
46
|
+
"devDependencies": {
|
|
47
|
+
"@types/node": "25.2.3",
|
|
48
|
+
"@types/pg": "8.16.0",
|
|
49
|
+
"copyfiles": "2.4.1"
|
|
49
50
|
},
|
|
50
51
|
"scripts": {
|
|
51
52
|
"tsc": "tsc",
|
|
52
53
|
"lint": "eslint",
|
|
53
|
-
"generate-
|
|
54
|
-
"
|
|
55
|
-
"
|
|
54
|
+
"generate-docs": "bun run scripts/generate-commands-docs.ts",
|
|
55
|
+
"build": "tsdown",
|
|
56
|
+
"postbuild": "bun generate-docs && bun copy-scripts",
|
|
56
57
|
"copy-scripts": "copyfiles scripts/* dist/",
|
|
57
|
-
"dev": "
|
|
58
|
-
"
|
|
58
|
+
"dev": "bun run ./src/cli.ts",
|
|
59
|
+
"cli": "node ./dist/cli.mjs"
|
|
59
60
|
}
|
|
60
61
|
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"generate-commands-md.d.ts","sourceRoot":"","sources":["../../scripts/generate-commands-md.ts"],"names":[],"mappings":""}
|
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
import * as fs from "fs";
|
|
2
|
-
import * as path from "path";
|
|
3
|
-
import { fileURLToPath } from "url";
|
|
4
|
-
/**
|
|
5
|
-
* Generate COMMANDS.md file from the help texts in help.ts
|
|
6
|
-
*/
|
|
7
|
-
async function generateCommandsMd() {
|
|
8
|
-
try {
|
|
9
|
-
// Define paths for ES modules
|
|
10
|
-
const __filename = fileURLToPath(import.meta.url);
|
|
11
|
-
const __dirname = path.dirname(__filename);
|
|
12
|
-
const rootDir = path.resolve(__dirname, "..");
|
|
13
|
-
const helpFilePath = path.join(rootDir, "src", "help.ts");
|
|
14
|
-
const outputPath = path.join(rootDir, "COMMANDS.md");
|
|
15
|
-
// Read the help.ts file
|
|
16
|
-
const helpFileContent = fs.readFileSync(helpFilePath, "utf8");
|
|
17
|
-
// Extract all help text constants using regex
|
|
18
|
-
const helpTextRegex = /export const (\w+)Help = `([\s\S]+?)`;/g;
|
|
19
|
-
const commands = [];
|
|
20
|
-
let match;
|
|
21
|
-
while ((match = helpTextRegex.exec(helpFileContent)) !== null) {
|
|
22
|
-
const commandName = match[1];
|
|
23
|
-
const helpContent = match[2];
|
|
24
|
-
commands.push({ name: commandName, content: helpContent });
|
|
25
|
-
}
|
|
26
|
-
// Sort commands alphabetically
|
|
27
|
-
commands.sort((a, b) => a.name.localeCompare(b.name));
|
|
28
|
-
// Generate the markdown content
|
|
29
|
-
let markdown = "# Powerhouse CLI Commands\n\n";
|
|
30
|
-
markdown +=
|
|
31
|
-
"This document provides detailed information about the available commands in the Powerhouse CLI.\n\n";
|
|
32
|
-
markdown += "## Table of Contents\n\n";
|
|
33
|
-
// Add table of contents
|
|
34
|
-
commands.forEach((command) => {
|
|
35
|
-
const displayName = formatCommandName(command.name);
|
|
36
|
-
const anchor = displayName.toLowerCase().replace(/\s+/g, "-");
|
|
37
|
-
markdown += `- [${displayName}](#${anchor})\n`;
|
|
38
|
-
});
|
|
39
|
-
markdown += "\n";
|
|
40
|
-
// Add command details
|
|
41
|
-
commands.forEach((command) => {
|
|
42
|
-
const displayName = formatCommandName(command.name);
|
|
43
|
-
markdown += `## ${displayName}\n\n`;
|
|
44
|
-
markdown += "```\n";
|
|
45
|
-
markdown += command.content.trim();
|
|
46
|
-
markdown += "\n```\n\n";
|
|
47
|
-
});
|
|
48
|
-
// Add footer
|
|
49
|
-
markdown += "---\n\n";
|
|
50
|
-
markdown +=
|
|
51
|
-
"*This document was automatically generated from the help text in the codebase.*\n";
|
|
52
|
-
// Write to COMMANDS.md
|
|
53
|
-
fs.writeFileSync(outputPath, markdown);
|
|
54
|
-
console.log(`✅ COMMANDS.md has been generated at ${outputPath}`);
|
|
55
|
-
}
|
|
56
|
-
catch (error) {
|
|
57
|
-
console.error("Failed to generate COMMANDS.md:", error);
|
|
58
|
-
process.exit(1);
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
/**
|
|
62
|
-
* Format command name for display (e.g., "setupGlobals" -> "Setup Globals")
|
|
63
|
-
*/
|
|
64
|
-
function formatCommandName(commandName) {
|
|
65
|
-
// Convert camelCase to separate words with spaces
|
|
66
|
-
const name = commandName.replace(/([A-Z])/g, " $1").trim();
|
|
67
|
-
// Capitalize first letter and convert the rest to lowercase
|
|
68
|
-
return name.charAt(0).toUpperCase() + name.slice(1);
|
|
69
|
-
}
|
|
70
|
-
// Run the script
|
|
71
|
-
generateCommandsMd();
|
|
72
|
-
//# sourceMappingURL=generate-commands-md.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"generate-commands-md.js","sourceRoot":"","sources":["../../scripts/generate-commands-md.ts"],"names":[],"mappings":"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"}
|