buncargo 1.0.29 → 3.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/bin.d.ts +1 -12
- package/dist/bin.js +261 -253
- package/dist/cli/bin.d.ts +13 -0
- package/dist/cli/bin.js +317 -0
- package/dist/cli/commands/help.d.ts +1 -0
- package/dist/cli/commands/runtime.d.ts +5 -0
- package/dist/cli/commands/version.d.ts +1 -0
- package/dist/cli/index.d.ts +1 -0
- package/dist/cli/index.js +14 -0
- package/dist/cli/run-cli.d.ts +30 -0
- package/dist/cli.d.ts +1 -22
- package/dist/cli.js +5 -13
- package/dist/config/config.d.ts +1 -0
- package/dist/config/define-config.d.ts +13 -0
- package/dist/config/index.d.ts +3 -0
- package/dist/config/index.js +15 -0
- package/dist/config/merge-configs.d.ts +3 -0
- package/dist/config/validate-config.d.ts +3 -0
- package/dist/config.d.ts +1 -72
- package/dist/config.js +12 -12
- package/dist/core/docker.d.ts +1 -83
- package/dist/core/docker.js +35 -32
- package/dist/core/index.d.ts +1 -1
- package/dist/core/index.js +123 -118
- package/dist/core/network.js +2 -2
- package/dist/core/ports.js +1 -1
- package/dist/core/process.js +1 -1
- package/dist/core/quick-tunnel/cloudflared-process.d.ts +10 -0
- package/dist/core/quick-tunnel/constants.d.ts +9 -0
- package/dist/core/quick-tunnel/index.d.ts +17 -0
- package/dist/core/quick-tunnel/install.d.ts +1 -0
- package/dist/core/tunnel.d.ts +34 -0
- package/dist/core/utils.js +2 -2
- package/dist/core/watchdog-runner.js +45 -42
- package/dist/core/watchdog.d.ts +1 -0
- package/dist/core/watchdog.js +4 -2
- package/dist/docker/index.d.ts +1 -0
- package/dist/docker/index.js +38 -0
- package/dist/docker/runtime.d.ts +87 -0
- package/dist/docker/runtime.js +37 -0
- package/dist/docker-compose/compose.d.ts +1 -0
- package/dist/docker-compose/generated-file.d.ts +7 -0
- package/dist/docker-compose/index.d.ts +3 -0
- package/dist/docker-compose/index.js +15 -0
- package/dist/docker-compose/model.d.ts +6 -0
- package/dist/docker-compose/services/clickhouse.d.ts +16 -0
- package/dist/docker-compose/services/define-docker-service.d.ts +41 -0
- package/dist/docker-compose/services/index.d.ts +23 -0
- package/dist/docker-compose/services/index.js +17 -0
- package/dist/docker-compose/services/postgres.d.ts +12 -0
- package/dist/docker-compose/services/redis.d.ts +12 -0
- package/dist/docker-compose/services/shared.d.ts +7 -0
- package/dist/docker-compose/yaml.d.ts +2 -0
- package/dist/environment/create-dev-environment.d.ts +23 -0
- package/dist/environment/index.d.ts +1 -0
- package/dist/environment/index.js +15 -0
- package/dist/environment/logging.d.ts +17 -0
- package/dist/environment/only-apps.d.ts +10 -0
- package/dist/environment/seeding.d.ts +9 -0
- package/dist/environment.d.ts +1 -23
- package/dist/environment.js +12 -14
- package/dist/index-045jksh5.js +147 -0
- package/dist/index-08wa79cs.js +125 -117
- package/dist/index-0kxnae3z.js +335 -0
- package/dist/index-1mdrf7nz.js +51 -43
- package/dist/index-1yvbwj4k.js +262 -242
- package/dist/index-23ev345g.js +475 -0
- package/dist/index-2ckr49sf.js +228 -0
- package/dist/index-2f47khe5.js +376 -369
- package/dist/index-2fr3g85b.js +220 -183
- package/dist/index-38xnzpa6.js +450 -0
- package/dist/index-3eyrdxw9.js +577 -0
- package/dist/index-3h3dhtf2.js +51 -43
- package/dist/index-42x95209.js +51 -43
- package/dist/index-4gp0az1g.js +145 -0
- package/dist/index-4xrxh8yv.js +72 -0
- package/dist/index-5aq985p4.js +250 -0
- package/dist/index-5gmws6ah.js +181 -0
- package/dist/index-5hka0tff.js +78 -76
- package/dist/index-5rfqps4b.js +3 -0
- package/dist/index-5t9jxqm0.js +428 -0
- package/dist/index-6c1w1xk5.js +101 -0
- package/dist/index-6cmex7m5.js +72 -0
- package/dist/index-6d6x175r.js +572 -0
- package/dist/index-6fm7mvwj.js +118 -97
- package/dist/index-6srpc523.js +127 -128
- package/dist/index-731rzzfp.js +157 -142
- package/dist/index-75y4cg2z.js +51 -43
- package/dist/index-7ja4ywyj.js +126 -127
- package/dist/index-7v19es2e.js +666 -0
- package/dist/index-8bw1cmz4.js +531 -0
- package/dist/index-8hbbj1mp.js +120 -121
- package/dist/index-8xj2p5n5.js +118 -97
- package/dist/index-9wyhzw0h.js +574 -0
- package/dist/index-ag90ry8t.js +576 -0
- package/dist/index-bj79tw5w.js +0 -0
- package/dist/index-bnk6nr0g.js +73 -0
- package/dist/index-brbbzyks.js +72 -0
- package/dist/index-byeqyjrz.js +72 -0
- package/dist/index-c0dr6mcv.js +123 -0
- package/dist/index-cty0bcry.js +235 -218
- package/dist/index-d8tyv5se.js +228 -0
- package/dist/index-d9efy0n4.js +176 -150
- package/dist/index-enj4zdma.js +574 -0
- package/dist/index-etfmqjjf.js +427 -0
- package/dist/index-fb29934k.js +172 -0
- package/dist/index-g50jw1yf.js +72 -0
- package/dist/index-g6eb5wdw.js +118 -117
- package/dist/index-ggq3yryx.js +99 -95
- package/dist/index-h70tce00.js +177 -0
- package/dist/index-hkxtfqtc.js +333 -0
- package/dist/index-k370bech.js +72 -0
- package/dist/index-kf3dhser.js +146 -143
- package/dist/index-ma6tgdb2.js +500 -0
- package/dist/index-mam0bcyz.js +123 -0
- package/dist/index-mm412dkp.js +274 -0
- package/dist/index-n8v18aeb.js +0 -0
- package/dist/index-ndnmnsej.js +378 -371
- package/dist/index-p8wty0e2.js +389 -379
- package/dist/index-qa8akv6y.js +666 -0
- package/dist/index-qfphr2fd.js +78 -76
- package/dist/index-qqmms8rs.js +51 -43
- package/dist/index-qw4093g2.js +51 -43
- package/dist/index-qzwpzjbx.js +121 -122
- package/dist/index-segbnm0h.js +146 -143
- package/dist/index-t0fj6gg1.js +112 -0
- package/dist/index-thdkwnv7.js +122 -0
- package/dist/index-tjbx2r2t.js +270 -0
- package/dist/index-tjqw9vtj.js +62 -54
- package/dist/index-vbpb89jy.js +248 -0
- package/dist/index-vg55rq0y.js +250 -0
- package/dist/index-vhs88xhe.js +99 -95
- package/dist/index-vs81yaks.js +244 -0
- package/dist/index-w8zxnjka.js +249 -0
- package/dist/index-wk2na3t9.js +385 -375
- package/dist/index-wz9x8g7z.js +383 -373
- package/dist/index-x249gyde.js +388 -378
- package/dist/index-x54nbgs7.js +355 -0
- package/dist/index-xkvd0nsd.js +187 -0
- package/dist/index-yedqxm1z.js +80 -0
- package/dist/index-yz4jfz7z.js +338 -0
- package/dist/index-zfjzzjkf.js +240 -199
- package/dist/index.d.ts +12 -8
- package/dist/index.js +56 -34
- package/dist/lint.d.ts +1 -46
- package/dist/lint.js +3 -7
- package/dist/loader/cache.d.ts +4 -0
- package/dist/loader/find-config-file.d.ts +2 -0
- package/dist/loader/index.d.ts +5 -0
- package/dist/loader/index.js +24 -0
- package/dist/loader/load-dev-env.d.ts +5 -0
- package/dist/loader/loader.d.ts +1 -0
- package/dist/loader.d.ts +1 -45
- package/dist/loader.js +22 -20
- package/dist/prisma/index.d.ts +1 -0
- package/dist/prisma/prisma.d.ts +29 -0
- package/dist/prisma.d.ts +1 -29
- package/dist/prisma.js +6 -10
- package/dist/src/bin.js +309 -0
- package/dist/src/cli.js +5 -0
- package/dist/src/config.js +15 -0
- package/dist/src/core/docker.js +38 -0
- package/dist/src/core/index.js +130 -0
- package/dist/src/core/network.js +9 -0
- package/dist/src/core/ports.js +23 -0
- package/dist/src/core/process.js +31 -0
- package/dist/src/core/utils.js +11 -0
- package/dist/src/core/watchdog-runner.js +69 -0
- package/dist/src/core/watchdog.js +28 -0
- package/dist/src/docker/runtime.js +37 -0
- package/dist/src/docker-compose/index.js +16 -0
- package/dist/src/docker-compose/services/index.js +17 -0
- package/dist/src/environment.js +12 -0
- package/dist/src/index.js +122 -0
- package/dist/src/lint.js +3 -0
- package/dist/src/loader.js +25 -0
- package/dist/src/prisma.js +6 -0
- package/dist/src/types.js +0 -0
- package/dist/typecheck/index.d.ts +1 -0
- package/dist/typecheck/index.js +7 -0
- package/dist/typecheck/typecheck.d.ts +46 -0
- package/dist/types/all-types.d.ts +544 -0
- package/dist/types/cli.d.ts +1 -0
- package/dist/types/config.d.ts +6 -0
- package/dist/types/docker.d.ts +15 -0
- package/dist/types/environment.d.ts +8 -0
- package/dist/types/hooks.d.ts +9 -0
- package/dist/types/index.d.ts +1 -0
- package/dist/types/index.js +0 -0
- package/dist/types/prisma.d.ts +1 -0
- package/dist/types.d.ts +1 -399
- package/package.json +55 -48
- package/readme.md +365 -109
- package/src/cli/bin.ts +77 -0
- package/src/cli/commands/help.ts +39 -0
- package/src/cli/commands/runtime.ts +72 -0
- package/src/cli/commands/version.ts +4 -0
- package/src/cli/index.ts +1 -0
- package/{cli.ts → src/cli/run-cli.ts} +114 -10
- package/src/config/define-config.ts +30 -0
- package/src/config/index.ts +3 -0
- package/src/config/merge-configs.ts +33 -0
- package/src/config/validate-config.ts +136 -0
- package/{core → src/core}/index.ts +2 -2
- package/{core → src/core}/ports.ts +5 -2
- package/{core → src/core}/process.ts +6 -2
- package/src/core/quick-tunnel/cloudflared-process.ts +83 -0
- package/src/core/quick-tunnel/constants.ts +31 -0
- package/src/core/quick-tunnel/index.ts +96 -0
- package/src/core/quick-tunnel/install.ts +160 -0
- package/src/core/tunnel.ts +165 -0
- package/{core → src/core}/utils.ts +1 -0
- package/{core → src/core}/watchdog.ts +5 -1
- package/src/docker/index.ts +1 -0
- package/{core/docker.ts → src/docker/runtime.ts} +11 -4
- package/src/docker-compose/generated-file.ts +45 -0
- package/src/docker-compose/index.ts +7 -0
- package/src/docker-compose/model.ts +197 -0
- package/src/docker-compose/services/clickhouse.ts +79 -0
- package/src/docker-compose/services/define-docker-service.ts +109 -0
- package/src/docker-compose/services/index.ts +67 -0
- package/src/docker-compose/services/postgres.ts +60 -0
- package/src/docker-compose/services/redis.ts +48 -0
- package/src/docker-compose/services/shared.ts +79 -0
- package/src/docker-compose/yaml.ts +88 -0
- package/{environment.ts → src/environment/create-dev-environment.ts} +214 -141
- package/src/environment/index.ts +1 -0
- package/src/environment/logging.ts +115 -0
- package/src/environment/only-apps.ts +34 -0
- package/src/environment/seeding.ts +57 -0
- package/{index.ts → src/index.ts} +52 -20
- package/src/loader/cache.ts +23 -0
- package/src/loader/find-config-file.ts +29 -0
- package/src/loader/index.ts +17 -0
- package/src/loader/load-dev-env.ts +38 -0
- package/src/prisma/index.ts +1 -0
- package/{prisma.ts → src/prisma/prisma.ts} +4 -2
- package/src/typecheck/index.ts +1 -0
- package/{types.ts → src/types/all-types.ts} +186 -8
- package/src/types/index.ts +1 -0
- package/bin.ts +0 -192
- package/config.ts +0 -194
- package/loader.ts +0 -126
- /package/{core → src/core}/network.ts +0 -0
- /package/{core → src/core}/watchdog-runner.ts +0 -0
- /package/{lint.ts → src/typecheck/typecheck.ts} +0 -0
package/dist/index-segbnm0h.js
CHANGED
|
@@ -1,24 +1,22 @@
|
|
|
1
|
+
// cli.ts
|
|
2
|
+
import { spawn } from "node:child_process";
|
|
3
|
+
import { killProcessesOnAppPorts } from "./index-1yvbwj4k.js";
|
|
1
4
|
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
+
spawnWatchdog,
|
|
6
|
+
startHeartbeat,
|
|
7
|
+
stopHeartbeat,
|
|
5
8
|
} from "./index-ggq3yryx.js";
|
|
6
|
-
import {
|
|
7
|
-
killProcessesOnAppPorts
|
|
8
|
-
} from "./index-1yvbwj4k.js";
|
|
9
9
|
|
|
10
|
-
// cli.ts
|
|
11
|
-
import { spawn } from "node:child_process";
|
|
12
10
|
var ACCEPTED_FLAGS = [
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
11
|
+
"--help",
|
|
12
|
+
"--down",
|
|
13
|
+
"--reset",
|
|
14
|
+
"--migrate",
|
|
15
|
+
"--seed",
|
|
16
|
+
"--up-only",
|
|
19
17
|
];
|
|
20
18
|
function printHelp() {
|
|
21
|
-
|
|
19
|
+
console.log(`
|
|
22
20
|
Usage: buncargo dev [options]
|
|
23
21
|
|
|
24
22
|
Options:
|
|
@@ -37,144 +35,149 @@ Examples:
|
|
|
37
35
|
`);
|
|
38
36
|
}
|
|
39
37
|
function getUnknownFlags(args) {
|
|
40
|
-
|
|
38
|
+
return args.filter(
|
|
39
|
+
(arg) => arg.startsWith("--") && !ACCEPTED_FLAGS.includes(arg),
|
|
40
|
+
);
|
|
41
41
|
}
|
|
42
42
|
async function runCli(env, options = {}) {
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
43
|
+
const {
|
|
44
|
+
args = process.argv.slice(2),
|
|
45
|
+
watchdog = true,
|
|
46
|
+
watchdogTimeout = 10,
|
|
47
|
+
devServersCommand,
|
|
48
|
+
} = options;
|
|
49
|
+
if (args.includes("--help")) {
|
|
50
|
+
printHelp();
|
|
51
|
+
process.exit(0);
|
|
52
|
+
}
|
|
53
|
+
const unknownFlags = getUnknownFlags(args);
|
|
54
|
+
if (unknownFlags.length > 0) {
|
|
55
|
+
console.error(
|
|
56
|
+
`❌ Unknown flag${unknownFlags.length > 1 ? "s" : ""}: ${unknownFlags.join(", ")}`,
|
|
57
|
+
);
|
|
58
|
+
console.error("");
|
|
59
|
+
printHelp();
|
|
60
|
+
process.exit(1);
|
|
61
|
+
}
|
|
62
|
+
if (args.includes("--down")) {
|
|
63
|
+
env.logInfo();
|
|
64
|
+
await env.stop();
|
|
65
|
+
process.exit(0);
|
|
66
|
+
}
|
|
67
|
+
if (args.includes("--reset")) {
|
|
68
|
+
env.logInfo();
|
|
69
|
+
await env.stop({ removeVolumes: true });
|
|
70
|
+
process.exit(0);
|
|
71
|
+
}
|
|
72
|
+
const skipSeed = args.includes("--seed");
|
|
73
|
+
await env.start({ startServers: false, wait: true, skipSeed });
|
|
74
|
+
if (args.includes("--migrate")) {
|
|
75
|
+
console.log("");
|
|
76
|
+
console.log("✅ Migrations applied successfully");
|
|
77
|
+
process.exit(0);
|
|
78
|
+
}
|
|
79
|
+
if (args.includes("--seed")) {
|
|
80
|
+
console.log("\uD83C\uDF31 Running seeders...");
|
|
81
|
+
const result = await env.exec("bun run run:seeder", {
|
|
82
|
+
throwOnError: false,
|
|
83
|
+
});
|
|
84
|
+
if (result.exitCode !== 0) {
|
|
85
|
+
console.error("❌ Seeding failed");
|
|
86
|
+
if (result.stderr) {
|
|
87
|
+
console.error(result.stderr);
|
|
88
|
+
}
|
|
89
|
+
if (result.stdout) {
|
|
90
|
+
console.error(result.stdout);
|
|
91
|
+
}
|
|
92
|
+
process.exit(1);
|
|
93
|
+
}
|
|
94
|
+
console.log("");
|
|
95
|
+
console.log("✅ Seeding complete");
|
|
96
|
+
process.exit(0);
|
|
97
|
+
}
|
|
98
|
+
if (args.includes("--up-only")) {
|
|
99
|
+
console.log("");
|
|
100
|
+
console.log("✅ Containers started. Environment ready.");
|
|
101
|
+
console.log("");
|
|
102
|
+
process.exit(0);
|
|
103
|
+
}
|
|
104
|
+
if (watchdog) {
|
|
105
|
+
await spawnWatchdog(env.projectName, env.root, {
|
|
106
|
+
timeoutMinutes: watchdogTimeout,
|
|
107
|
+
verbose: true,
|
|
108
|
+
});
|
|
109
|
+
startHeartbeat(env.projectName);
|
|
110
|
+
}
|
|
111
|
+
const command = devServersCommand ?? buildDevServersCommand(env.apps);
|
|
112
|
+
if (!command) {
|
|
113
|
+
console.log("✅ Containers ready. No apps configured.");
|
|
114
|
+
await new Promise(() => {});
|
|
115
|
+
return;
|
|
116
|
+
}
|
|
117
|
+
await killProcessesOnAppPorts(env.apps, env.ports);
|
|
118
|
+
console.log("");
|
|
119
|
+
console.log("\uD83D\uDD27 Starting dev servers...");
|
|
120
|
+
console.log("");
|
|
121
|
+
await runCommand(command, env.root, env.buildEnvVars());
|
|
122
|
+
stopHeartbeat();
|
|
121
123
|
}
|
|
122
124
|
function buildDevServersCommand(apps) {
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
125
|
+
const appEntries = Object.entries(apps);
|
|
126
|
+
if (appEntries.length === 0) return null;
|
|
127
|
+
const commands = [];
|
|
128
|
+
const names = [];
|
|
129
|
+
const colors = ["blue", "green", "yellow", "magenta", "cyan", "red"];
|
|
130
|
+
for (const [name, config] of appEntries) {
|
|
131
|
+
names.push(name);
|
|
132
|
+
const cwdPart = config.cwd ? `--cwd ${config.cwd}` : "";
|
|
133
|
+
commands.push(
|
|
134
|
+
`"bun run ${cwdPart} ${config.devCommand}"`.replace(/\s+/g, " ").trim(),
|
|
135
|
+
);
|
|
136
|
+
}
|
|
137
|
+
const namesArg = `-n ${names.join(",")}`;
|
|
138
|
+
const colorsArg = `-c ${colors.slice(0, names.length).join(",")}`;
|
|
139
|
+
const commandsArg = commands.join(" ");
|
|
140
|
+
return `bun concurrently ${namesArg} ${colorsArg} ${commandsArg}`;
|
|
138
141
|
}
|
|
139
142
|
function runCommand(command, cwd, envVars) {
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
143
|
+
return new Promise((resolve, reject) => {
|
|
144
|
+
const proc = spawn(command, [], {
|
|
145
|
+
cwd,
|
|
146
|
+
env: { ...process.env, ...envVars },
|
|
147
|
+
stdio: "inherit",
|
|
148
|
+
shell: true,
|
|
149
|
+
});
|
|
150
|
+
proc.on("close", (code) => {
|
|
151
|
+
if (code === 0 || code === null) {
|
|
152
|
+
resolve();
|
|
153
|
+
} else {
|
|
154
|
+
reject(new Error(`Command exited with code ${code}`));
|
|
155
|
+
}
|
|
156
|
+
});
|
|
157
|
+
proc.on("error", reject);
|
|
158
|
+
const cleanup = () => {
|
|
159
|
+
proc.kill("SIGTERM");
|
|
160
|
+
};
|
|
161
|
+
process.on("SIGINT", cleanup);
|
|
162
|
+
process.on("SIGTERM", cleanup);
|
|
163
|
+
});
|
|
161
164
|
}
|
|
162
165
|
function hasFlag(args, flag) {
|
|
163
|
-
|
|
166
|
+
return args.includes(flag);
|
|
164
167
|
}
|
|
165
168
|
function getFlagValue(args, flag) {
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
169
|
+
const prefixed = args.find((arg) => arg.startsWith(`${flag}=`));
|
|
170
|
+
if (prefixed) {
|
|
171
|
+
return prefixed.split("=")[1];
|
|
172
|
+
}
|
|
173
|
+
const index = args.indexOf(flag);
|
|
174
|
+
if (index !== -1 && index + 1 < args.length) {
|
|
175
|
+
const nextArg = args[index + 1];
|
|
176
|
+
if (nextArg !== undefined && !nextArg.startsWith("-")) {
|
|
177
|
+
return nextArg;
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
return;
|
|
178
181
|
}
|
|
179
182
|
|
|
180
183
|
export { runCli, hasFlag, getFlagValue };
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
// src/config/define-config.ts
|
|
2
|
+
function defineDevConfig(config) {
|
|
3
|
+
return config;
|
|
4
|
+
}
|
|
5
|
+
// src/config/merge-configs.ts
|
|
6
|
+
function mergeConfigs(base, overrides) {
|
|
7
|
+
return {
|
|
8
|
+
...base,
|
|
9
|
+
...overrides,
|
|
10
|
+
services: { ...base.services, ...overrides.services },
|
|
11
|
+
apps: { ...base.apps, ...overrides.apps },
|
|
12
|
+
hooks: { ...base.hooks, ...overrides.hooks },
|
|
13
|
+
migrations: overrides.migrations ?? base.migrations,
|
|
14
|
+
seed: overrides.seed ?? base.seed,
|
|
15
|
+
options: { ...base.options, ...overrides.options },
|
|
16
|
+
docker: { ...base.docker, ...overrides.docker }
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
function definePartialConfig(config) {
|
|
20
|
+
return config;
|
|
21
|
+
}
|
|
22
|
+
// src/config/validate-config.ts
|
|
23
|
+
import { isAbsolute, normalize } from "node:path";
|
|
24
|
+
var BUILTIN_DOCKER_PRESETS = new Set(["postgres", "redis", "clickhouse"]);
|
|
25
|
+
function inferBuiltInPreset(serviceName) {
|
|
26
|
+
const normalized = serviceName.toLowerCase();
|
|
27
|
+
return BUILTIN_DOCKER_PRESETS.has(normalized) ? normalized : null;
|
|
28
|
+
}
|
|
29
|
+
function validateConfig(config) {
|
|
30
|
+
const errors = [];
|
|
31
|
+
const composeServiceNames = new Set;
|
|
32
|
+
if (!config.projectPrefix) {
|
|
33
|
+
errors.push("projectPrefix is required");
|
|
34
|
+
} else if (!/^[a-z][a-z0-9-]*$/.test(config.projectPrefix)) {
|
|
35
|
+
errors.push("projectPrefix must start with a letter and contain only lowercase letters, numbers, and hyphens");
|
|
36
|
+
}
|
|
37
|
+
if (!config.services || Object.keys(config.services).length === 0) {
|
|
38
|
+
errors.push("At least one service is required");
|
|
39
|
+
}
|
|
40
|
+
for (const [name, service] of Object.entries(config.services ?? {})) {
|
|
41
|
+
if (!service.port || typeof service.port !== "number") {
|
|
42
|
+
errors.push(`Service "${name}" must have a valid port number`);
|
|
43
|
+
}
|
|
44
|
+
if (service.port < 1 || service.port > 65535) {
|
|
45
|
+
errors.push(`Service "${name}" port must be between 1 and 65535`);
|
|
46
|
+
}
|
|
47
|
+
if (service.secondaryPort !== undefined && (service.secondaryPort < 1 || service.secondaryPort > 65535)) {
|
|
48
|
+
errors.push(`Service "${name}" secondaryPort must be between 1 and 65535`);
|
|
49
|
+
}
|
|
50
|
+
const composeServiceName = service.serviceName ?? name;
|
|
51
|
+
if (composeServiceNames.has(composeServiceName)) {
|
|
52
|
+
errors.push(`Duplicate compose service name "${composeServiceName}". Use unique serviceName values.`);
|
|
53
|
+
}
|
|
54
|
+
composeServiceNames.add(composeServiceName);
|
|
55
|
+
const dockerConfig = service.docker;
|
|
56
|
+
const preset = inferBuiltInPreset(name);
|
|
57
|
+
if (!dockerConfig && !preset) {
|
|
58
|
+
errors.push(`Service "${name}" must define docker config (helper or raw) because it has no built-in preset.`);
|
|
59
|
+
}
|
|
60
|
+
if (dockerConfig && typeof dockerConfig === "object" && "kind" in dockerConfig && dockerConfig.kind === "preset") {
|
|
61
|
+
const presetName = dockerConfig.preset;
|
|
62
|
+
if (typeof presetName !== "string" || !BUILTIN_DOCKER_PRESETS.has(presetName)) {
|
|
63
|
+
errors.push(`Service "${name}" has invalid docker preset "${presetName}".`);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
if (config.docker?.writeStrategy) {
|
|
68
|
+
const writeStrategy = config.docker.writeStrategy;
|
|
69
|
+
if (writeStrategy !== "always" && writeStrategy !== "if-missing") {
|
|
70
|
+
errors.push(`docker.writeStrategy "${String(writeStrategy)}" is invalid. Use "always" or "if-missing".`);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
if (config.docker?.generatedFile) {
|
|
74
|
+
const generatedFile = config.docker.generatedFile;
|
|
75
|
+
if (isAbsolute(generatedFile)) {
|
|
76
|
+
errors.push("docker.generatedFile must be a relative path inside the repo.");
|
|
77
|
+
}
|
|
78
|
+
const normalized = normalize(generatedFile).replace(/\\/g, "/");
|
|
79
|
+
if (normalized === ".." || normalized.startsWith("../")) {
|
|
80
|
+
errors.push("docker.generatedFile cannot point outside the repository root.");
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
for (const [name, app] of Object.entries(config.apps ?? {})) {
|
|
84
|
+
if (!app.port || typeof app.port !== "number") {
|
|
85
|
+
errors.push(`App "${name}" must have a valid port number`);
|
|
86
|
+
}
|
|
87
|
+
if (!app.devCommand) {
|
|
88
|
+
errors.push(`App "${name}" must have a devCommand`);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
for (const migration of config.migrations ?? []) {
|
|
92
|
+
if (!migration.name) {
|
|
93
|
+
errors.push("Migration must have a name");
|
|
94
|
+
}
|
|
95
|
+
if (!migration.command) {
|
|
96
|
+
errors.push(`Migration "${migration.name}" must have a command`);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
if (config.seed && !config.seed.command) {
|
|
100
|
+
errors.push("Seed must have a command");
|
|
101
|
+
}
|
|
102
|
+
return errors;
|
|
103
|
+
}
|
|
104
|
+
function assertValidConfig(config) {
|
|
105
|
+
const errors = validateConfig(config);
|
|
106
|
+
if (errors.length > 0) {
|
|
107
|
+
throw new Error(`Invalid dev config:
|
|
108
|
+
- ${errors.join(`
|
|
109
|
+
- `)}`);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
export { defineDevConfig, mergeConfigs, definePartialConfig, validateConfig, assertValidConfig };
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
import {
|
|
2
|
+
calculatePortOffset,
|
|
3
|
+
computePorts,
|
|
4
|
+
computeUrls
|
|
5
|
+
} from "./index-fb29934k.js";
|
|
6
|
+
|
|
7
|
+
// src/core/network.ts
|
|
8
|
+
import { networkInterfaces } from "node:os";
|
|
9
|
+
function getLocalIp() {
|
|
10
|
+
const interfaces = networkInterfaces();
|
|
11
|
+
for (const name of Object.keys(interfaces)) {
|
|
12
|
+
const nets = interfaces[name];
|
|
13
|
+
if (!nets)
|
|
14
|
+
continue;
|
|
15
|
+
for (const net of nets) {
|
|
16
|
+
if (net.family === "IPv4" && !net.internal) {
|
|
17
|
+
return net.address;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
return "127.0.0.1";
|
|
22
|
+
}
|
|
23
|
+
async function waitForServer(url, options = {}) {
|
|
24
|
+
const { timeout = 30000, interval = 2000, verbose = false } = options;
|
|
25
|
+
const start = Date.now();
|
|
26
|
+
let attempts = 0;
|
|
27
|
+
while (Date.now() - start < timeout) {
|
|
28
|
+
attempts++;
|
|
29
|
+
const controller = new AbortController;
|
|
30
|
+
const timeoutId = setTimeout(() => controller.abort(), 5000);
|
|
31
|
+
try {
|
|
32
|
+
const response = await fetch(url, {
|
|
33
|
+
signal: controller.signal
|
|
34
|
+
});
|
|
35
|
+
clearTimeout(timeoutId);
|
|
36
|
+
if (response.ok || response.status === 404) {
|
|
37
|
+
if (verbose) {
|
|
38
|
+
console.log(` ✓ ${url} ready after ${attempts} attempts`);
|
|
39
|
+
}
|
|
40
|
+
return;
|
|
41
|
+
}
|
|
42
|
+
} catch {
|
|
43
|
+
clearTimeout(timeoutId);
|
|
44
|
+
if (verbose && attempts % 5 === 0) {
|
|
45
|
+
console.log(` ⏳ Waiting for ${url}... (${Math.round((Date.now() - start) / 1000)}s)`);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
await sleep(interval);
|
|
49
|
+
}
|
|
50
|
+
throw new Error(`Server at ${url} did not respond within ${timeout}ms after ${attempts} attempts`);
|
|
51
|
+
}
|
|
52
|
+
async function waitForDevServers(apps, ports, options = {}) {
|
|
53
|
+
const { timeout = 60000, verbose = true } = options;
|
|
54
|
+
if (verbose)
|
|
55
|
+
console.log("⏳ Waiting for servers to be ready...");
|
|
56
|
+
const promises = [];
|
|
57
|
+
for (const [name, config] of Object.entries(apps)) {
|
|
58
|
+
const port = ports[name];
|
|
59
|
+
const healthPath = config.healthEndpoint ?? "/";
|
|
60
|
+
const url = `http://localhost:${port}${healthPath}`;
|
|
61
|
+
const appTimeout = config.healthTimeout ?? timeout;
|
|
62
|
+
promises.push(waitForServer(url, { timeout: appTimeout, verbose }));
|
|
63
|
+
}
|
|
64
|
+
await Promise.all(promises);
|
|
65
|
+
if (verbose)
|
|
66
|
+
console.log("✓ All servers ready");
|
|
67
|
+
}
|
|
68
|
+
async function isPortAvailable(port) {
|
|
69
|
+
const controller = new AbortController;
|
|
70
|
+
const timeoutId = setTimeout(() => controller.abort(), 500);
|
|
71
|
+
try {
|
|
72
|
+
const _response = await fetch(`http://localhost:${port}/`, {
|
|
73
|
+
signal: controller.signal
|
|
74
|
+
});
|
|
75
|
+
clearTimeout(timeoutId);
|
|
76
|
+
return false;
|
|
77
|
+
} catch (error) {
|
|
78
|
+
clearTimeout(timeoutId);
|
|
79
|
+
if (error instanceof Error) {
|
|
80
|
+
if (error.message.includes("ECONNREFUSED") || error.message.includes("fetch failed")) {
|
|
81
|
+
return true;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
return true;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
// src/core/utils.ts
|
|
89
|
+
function sleep(ms) {
|
|
90
|
+
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
91
|
+
}
|
|
92
|
+
function isCI() {
|
|
93
|
+
return process.env.CI === "true" || process.env.CI === "1" || process.env.GITHUB_ACTIONS === "true" || process.env.GITLAB_CI === "true" || process.env.CIRCLECI === "true" || process.env.JENKINS_URL !== undefined;
|
|
94
|
+
}
|
|
95
|
+
function logFrontendPort(port) {
|
|
96
|
+
console.log(`using_frontend_port:${port}`);
|
|
97
|
+
}
|
|
98
|
+
function getEnvVar(config, name, options = {}) {
|
|
99
|
+
const { log = true } = options;
|
|
100
|
+
const offset = calculatePortOffset();
|
|
101
|
+
const localIp = getLocalIp();
|
|
102
|
+
const ports = computePorts(config.services, config.apps, offset);
|
|
103
|
+
const urls = computeUrls(config.services, config.apps, ports, localIp);
|
|
104
|
+
const envVars = config.envVars?.(ports, urls, {
|
|
105
|
+
projectName: config.projectPrefix,
|
|
106
|
+
localIp,
|
|
107
|
+
portOffset: offset
|
|
108
|
+
});
|
|
109
|
+
const value = envVars?.[name];
|
|
110
|
+
if (log && name === "VITE_PORT" && typeof value === "number") {
|
|
111
|
+
logFrontendPort(value);
|
|
112
|
+
}
|
|
113
|
+
return value;
|
|
114
|
+
}
|
|
115
|
+
function logApiUrl(url) {
|
|
116
|
+
console.log(`using_api_url:${url}`);
|
|
117
|
+
}
|
|
118
|
+
function logExpoApiUrl(url) {
|
|
119
|
+
console.log(`using_expo_api_url:${url}`);
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
export { sleep, isCI, logFrontendPort, getEnvVar, logApiUrl, logExpoApiUrl, getLocalIp, waitForServer, waitForDevServers, isPortAvailable };
|