@simplysm/sd-cli 14.0.66 → 14.0.69
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/commands/init/generators/client-common.d.ts +3 -0
- package/dist/commands/init/generators/client-common.d.ts.map +1 -0
- package/dist/commands/init/generators/client-common.js +17 -0
- package/dist/commands/init/generators/client-common.js.map +1 -0
- package/dist/commands/init/generators/client.d.ts +3 -0
- package/dist/commands/init/generators/client.d.ts.map +1 -0
- package/dist/commands/init/generators/client.js +20 -0
- package/dist/commands/init/generators/client.js.map +1 -0
- package/dist/commands/init/generators/common.d.ts +3 -0
- package/dist/commands/init/generators/common.d.ts.map +1 -0
- package/dist/commands/init/generators/common.js +14 -0
- package/dist/commands/init/generators/common.js.map +1 -0
- package/dist/commands/init/generators/root.d.ts +3 -0
- package/dist/commands/init/generators/root.d.ts.map +1 -0
- package/dist/commands/init/generators/root.js +28 -0
- package/dist/commands/init/generators/root.js.map +1 -0
- package/dist/commands/init/generators/server.d.ts +3 -0
- package/dist/commands/init/generators/server.d.ts.map +1 -0
- package/dist/commands/init/generators/server.js +12 -0
- package/dist/commands/init/generators/server.js.map +1 -0
- package/dist/commands/init/init.d.ts +5 -0
- package/dist/commands/init/init.d.ts.map +1 -0
- package/dist/commands/init/init.js +44 -0
- package/dist/commands/init/init.js.map +1 -0
- package/dist/commands/init/normalize.d.ts +3 -0
- package/dist/commands/init/normalize.d.ts.map +1 -0
- package/dist/commands/init/normalize.js +42 -0
- package/dist/commands/init/normalize.js.map +1 -0
- package/dist/commands/init/prompts.d.ts +3 -0
- package/dist/commands/init/prompts.d.ts.map +1 -0
- package/dist/commands/init/prompts.js +89 -0
- package/dist/commands/init/prompts.js.map +1 -0
- package/dist/commands/init/render.d.ts +4 -0
- package/dist/commands/init/render.d.ts.map +1 -0
- package/dist/commands/init/render.js +20 -0
- package/dist/commands/init/render.js.map +1 -0
- package/dist/commands/init/template-paths.d.ts +2 -0
- package/dist/commands/init/template-paths.d.ts.map +1 -0
- package/dist/commands/init/template-paths.js +7 -0
- package/dist/commands/init/template-paths.js.map +1 -0
- package/dist/commands/init/types.d.ts +47 -0
- package/dist/commands/init/types.d.ts.map +1 -0
- package/dist/commands/init/types.js +2 -0
- package/dist/commands/init/types.js.map +1 -0
- package/dist/commands/init/validate.d.ts +4 -0
- package/dist/commands/init/validate.d.ts.map +1 -0
- package/dist/commands/init/validate.js +31 -0
- package/dist/commands/init/validate.js.map +1 -0
- package/dist/sd-cli-entry.d.ts.map +1 -1
- package/dist/sd-cli-entry.js +14 -1
- package/dist/sd-cli-entry.js.map +1 -1
- package/package.json +5 -4
- package/src/commands/init/generators/client-common.ts +29 -0
- package/src/commands/init/generators/client.ts +29 -0
- package/src/commands/init/generators/common.ts +22 -0
- package/src/commands/init/generators/root.ts +32 -0
- package/src/commands/init/generators/server.ts +16 -0
- package/src/commands/init/init.ts +54 -0
- package/src/commands/init/normalize.ts +46 -0
- package/src/commands/init/prompts.ts +101 -0
- package/src/commands/init/render.ts +25 -0
- package/src/commands/init/template-paths.ts +8 -0
- package/src/commands/init/templates/client/ngsw-config.json +27 -0
- package/src/commands/init/templates/client/package.json.hbs +29 -0
- package/src/commands/init/templates/client/src/AppPage.ts.hbs +18 -0
- package/src/commands/init/templates/client/src/index.html.hbs +12 -0
- package/src/commands/init/templates/client/src/main.ts.hbs +28 -0
- package/src/commands/init/templates/client/src/polyfills.ts +2 -0
- package/src/commands/init/templates/client/src/routes.ts +3 -0
- package/src/commands/init/templates/client/src/styles.scss +1 -0
- package/src/commands/init/templates/client/tsconfig.json +20 -0
- package/src/commands/init/templates/client-common/package.json.hbs +20 -0
- package/src/commands/init/templates/client-common/src/index.ts.hbs +11 -0
- package/src/commands/init/templates/client-common/src/providers/AppOrmProvider.ts.hbs +36 -0
- package/src/commands/init/templates/client-common/src/providers/AppServiceProvider.ts +27 -0
- package/src/commands/init/templates/client-common/tsconfig.json +20 -0
- package/src/commands/init/templates/common/package.json.hbs +10 -0
- package/src/commands/init/templates/common/src/MainDbContext.ts +4 -0
- package/src/commands/init/templates/common/src/index.ts.hbs +5 -0
- package/src/commands/init/templates/common/tsconfig.json +8 -0
- package/src/commands/init/templates/server/package.json.hbs +23 -0
- package/src/commands/init/templates/server/src/index.ts +1 -0
- package/src/commands/init/templates/server/src/main.ts.hbs +25 -0
- package/src/commands/init/templates/server/tsconfig.json +8 -0
- package/src/commands/init/templates/workspace-root/.prettierignore +1 -0
- package/src/commands/init/templates/workspace-root/.prettierrc.yaml +12 -0
- package/src/commands/init/templates/workspace-root/eslint.config.ts +4 -0
- package/src/commands/init/templates/workspace-root/mise.toml.hbs +7 -0
- package/src/commands/init/templates/workspace-root/package.json.hbs +43 -0
- package/src/commands/init/templates/workspace-root/pnpm-workspace.yaml +17 -0
- package/src/commands/init/templates/workspace-root/sd.config.ts.hbs +63 -0
- package/src/commands/init/templates/workspace-root/tsconfig.json.hbs +30 -0
- package/src/commands/init/templates/workspace-root/vitest.config.ts.hbs +72 -0
- package/src/commands/init/types.ts +51 -0
- package/src/commands/init/validate.ts +41 -0
- package/src/sd-cli-entry.ts +19 -1
- package/tests/init/__snapshots__/render.spec.ts.snap +213 -0
- package/tests/init/normalize.spec.ts +114 -0
- package/tests/init/render.spec.ts +216 -0
- package/tests/init/validate.spec.ts +80 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client-common.d.ts","sourceRoot":"","sources":["../../../../src/commands/init/generators/client-common.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAI3C,wBAAsB,oBAAoB,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,CAqBvF"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import path from "path";
|
|
2
|
+
import { copyFixed, renderToFile } from "../render.js";
|
|
3
|
+
import { TEMPLATES_ROOT } from "../template-paths.js";
|
|
4
|
+
const TPL = path.join(TEMPLATES_ROOT, "client-common");
|
|
5
|
+
export async function generateClientCommon(cwd, data) {
|
|
6
|
+
const out = path.resolve(cwd, "packages/client-common");
|
|
7
|
+
await copyFixed(path.join(TPL, "tsconfig.json"), path.join(out, "tsconfig.json"));
|
|
8
|
+
await renderToFile(path.join(TPL, "package.json.hbs"), path.join(out, "package.json"), data);
|
|
9
|
+
await renderToFile(path.join(TPL, "src/index.ts.hbs"), path.join(out, "src/index.ts"), data);
|
|
10
|
+
if (data.hasServer) {
|
|
11
|
+
await copyFixed(path.join(TPL, "src/providers/AppServiceProvider.ts"), path.join(out, "src/providers/AppServiceProvider.ts"));
|
|
12
|
+
}
|
|
13
|
+
if (data.hasDb) {
|
|
14
|
+
await renderToFile(path.join(TPL, "src/providers/AppOrmProvider.ts.hbs"), path.join(out, "src/providers/AppOrmProvider.ts"), data);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=client-common.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client-common.js","sourceRoot":"","sources":["../../../../src/commands/init/generators/client-common.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAGnD,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,eAAe,CAAC,CAAC;AAEvD,MAAM,CAAC,KAAK,UAAU,oBAAoB,CAAC,GAAW,EAAE,IAAgB;IACtE,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,wBAAwB,CAAC,CAAC;IAExD,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,eAAe,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,eAAe,CAAC,CAAC,CAAC;IAElF,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,cAAc,CAAC,EAAE,IAAI,CAAC,CAAC;IAC7F,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,cAAc,CAAC,EAAE,IAAI,CAAC,CAAC;IAE7F,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;QACnB,MAAM,SAAS,CACb,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,qCAAqC,CAAC,EACrD,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,qCAAqC,CAAC,CACtD,CAAC;IACJ,CAAC;IACD,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,MAAM,YAAY,CAChB,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,qCAAqC,CAAC,EACrD,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,iCAAiC,CAAC,EACjD,IAAI,CACL,CAAC;IACJ,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../../../src/commands/init/generators/client.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAIvD,wBAAsB,cAAc,CAClC,GAAG,EAAE,MAAM,EACX,IAAI,EAAE,UAAU,EAChB,MAAM,EAAE,UAAU,GACjB,OAAO,CAAC,IAAI,CAAC,CAiBf"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import path from "path";
|
|
2
|
+
import { copyFixed, renderToFile } from "../render.js";
|
|
3
|
+
import { TEMPLATES_ROOT } from "../template-paths.js";
|
|
4
|
+
const TPL = path.join(TEMPLATES_ROOT, "client");
|
|
5
|
+
export async function generateClient(cwd, base, client) {
|
|
6
|
+
const out = path.resolve(cwd, "packages", client.name);
|
|
7
|
+
const data = { ...base, client };
|
|
8
|
+
await copyFixed(path.join(TPL, "tsconfig.json"), path.join(out, "tsconfig.json"));
|
|
9
|
+
await copyFixed(path.join(TPL, "ngsw-config.json"), path.join(out, "ngsw-config.json"));
|
|
10
|
+
await copyFixed(path.join(TPL, "src/polyfills.ts"), path.join(out, "src/polyfills.ts"));
|
|
11
|
+
await copyFixed(path.join(TPL, "src/styles.scss"), path.join(out, "src/styles.scss"));
|
|
12
|
+
await renderToFile(path.join(TPL, "package.json.hbs"), path.join(out, "package.json"), data);
|
|
13
|
+
await renderToFile(path.join(TPL, "src/main.ts.hbs"), path.join(out, "src/main.ts"), data);
|
|
14
|
+
await renderToFile(path.join(TPL, "src/AppPage.ts.hbs"), path.join(out, "src/AppPage.ts"), data);
|
|
15
|
+
await renderToFile(path.join(TPL, "src/index.html.hbs"), path.join(out, "src/index.html"), data);
|
|
16
|
+
if (client.hasRouter) {
|
|
17
|
+
await copyFixed(path.join(TPL, "src/routes.ts"), path.join(out, "src/routes.ts"));
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=client.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client.js","sourceRoot":"","sources":["../../../../src/commands/init/generators/client.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAGnD,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,QAAQ,CAAC,CAAC;AAEhD,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,GAAW,EACX,IAAgB,EAChB,MAAkB;IAElB,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,UAAU,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;IACvD,MAAM,IAAI,GAAG,EAAE,GAAG,IAAI,EAAE,MAAM,EAAE,CAAC;IAEjC,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,eAAe,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,eAAe,CAAC,CAAC,CAAC;IAClF,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,CAAC,CAAC;IACxF,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,CAAC,CAAC;IACxF,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,iBAAiB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,iBAAiB,CAAC,CAAC,CAAC;IAEtF,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,cAAc,CAAC,EAAE,IAAI,CAAC,CAAC;IAC7F,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,iBAAiB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,aAAa,CAAC,EAAE,IAAI,CAAC,CAAC;IAC3F,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,oBAAoB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,gBAAgB,CAAC,EAAE,IAAI,CAAC,CAAC;IACjG,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,oBAAoB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,gBAAgB,CAAC,EAAE,IAAI,CAAC,CAAC;IAEjG,IAAI,MAAM,CAAC,SAAS,EAAE,CAAC;QACrB,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,eAAe,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,eAAe,CAAC,CAAC,CAAC;IACpF,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"common.d.ts","sourceRoot":"","sources":["../../../../src/commands/init/generators/common.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAI3C,wBAAsB,cAAc,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,CAcjF"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import path from "path";
|
|
2
|
+
import { copyFixed, renderToFile } from "../render.js";
|
|
3
|
+
import { TEMPLATES_ROOT } from "../template-paths.js";
|
|
4
|
+
const TPL = path.join(TEMPLATES_ROOT, "common");
|
|
5
|
+
export async function generateCommon(cwd, data) {
|
|
6
|
+
const out = path.resolve(cwd, "packages/common");
|
|
7
|
+
await copyFixed(path.join(TPL, "tsconfig.json"), path.join(out, "tsconfig.json"));
|
|
8
|
+
await renderToFile(path.join(TPL, "package.json.hbs"), path.join(out, "package.json"), data);
|
|
9
|
+
await renderToFile(path.join(TPL, "src/index.ts.hbs"), path.join(out, "src/index.ts"), data);
|
|
10
|
+
if (data.hasDb) {
|
|
11
|
+
await copyFixed(path.join(TPL, "src/MainDbContext.ts"), path.join(out, "src/MainDbContext.ts"));
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=common.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"common.js","sourceRoot":"","sources":["../../../../src/commands/init/generators/common.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAGnD,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,QAAQ,CAAC,CAAC;AAEhD,MAAM,CAAC,KAAK,UAAU,cAAc,CAAC,GAAW,EAAE,IAAgB;IAChE,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,iBAAiB,CAAC,CAAC;IAEjD,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,eAAe,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,eAAe,CAAC,CAAC,CAAC;IAElF,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,cAAc,CAAC,EAAE,IAAI,CAAC,CAAC;IAC7F,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,cAAc,CAAC,EAAE,IAAI,CAAC,CAAC;IAE7F,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,MAAM,SAAS,CACb,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,sBAAsB,CAAC,EACtC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,sBAAsB,CAAC,CACvC,CAAC;IACJ,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"root.d.ts","sourceRoot":"","sources":["../../../../src/commands/init/generators/root.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAqB3C,wBAAsB,YAAY,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,CAO/E"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import path from "path";
|
|
2
|
+
import { copyFixed, renderToFile } from "../render.js";
|
|
3
|
+
import { TEMPLATES_ROOT } from "../template-paths.js";
|
|
4
|
+
const TPL = path.join(TEMPLATES_ROOT, "workspace-root");
|
|
5
|
+
const FIXED = [
|
|
6
|
+
".gitignore",
|
|
7
|
+
".npmrc",
|
|
8
|
+
".prettierignore",
|
|
9
|
+
".prettierrc.yaml",
|
|
10
|
+
"eslint.config.ts",
|
|
11
|
+
"pnpm-workspace.yaml",
|
|
12
|
+
];
|
|
13
|
+
const HBS = [
|
|
14
|
+
"mise.toml",
|
|
15
|
+
"package.json",
|
|
16
|
+
"tsconfig.json",
|
|
17
|
+
"sd.config.ts",
|
|
18
|
+
"vitest.config.ts",
|
|
19
|
+
];
|
|
20
|
+
export async function generateRoot(cwd, data) {
|
|
21
|
+
for (const name of FIXED) {
|
|
22
|
+
await copyFixed(path.join(TPL, name), path.join(cwd, name));
|
|
23
|
+
}
|
|
24
|
+
for (const name of HBS) {
|
|
25
|
+
await renderToFile(path.join(TPL, `${name}.hbs`), path.join(cwd, name), data);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=root.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"root.js","sourceRoot":"","sources":["../../../../src/commands/init/generators/root.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAGnD,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,gBAAgB,CAAC,CAAC;AAExD,MAAM,KAAK,GAAG;IACZ,YAAY;IACZ,QAAQ;IACR,iBAAiB;IACjB,kBAAkB;IAClB,kBAAkB;IAClB,qBAAqB;CACtB,CAAC;AAEF,MAAM,GAAG,GAAG;IACV,WAAW;IACX,cAAc;IACd,eAAe;IACf,cAAc;IACd,kBAAkB;CACnB,CAAC;AAEF,MAAM,CAAC,KAAK,UAAU,YAAY,CAAC,GAAW,EAAE,IAAgB;IAC9D,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC;IAC9D,CAAC;IACD,KAAK,MAAM,IAAI,IAAI,GAAG,EAAE,CAAC;QACvB,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,MAAM,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC;IAChF,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../../../src/commands/init/generators/server.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAI3C,wBAAsB,cAAc,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,CAQjF"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import path from "path";
|
|
2
|
+
import { copyFixed, renderToFile } from "../render.js";
|
|
3
|
+
import { TEMPLATES_ROOT } from "../template-paths.js";
|
|
4
|
+
const TPL = path.join(TEMPLATES_ROOT, "server");
|
|
5
|
+
export async function generateServer(cwd, data) {
|
|
6
|
+
const out = path.resolve(cwd, "packages/server");
|
|
7
|
+
await copyFixed(path.join(TPL, "tsconfig.json"), path.join(out, "tsconfig.json"));
|
|
8
|
+
await copyFixed(path.join(TPL, "src/index.ts"), path.join(out, "src/index.ts"));
|
|
9
|
+
await renderToFile(path.join(TPL, "package.json.hbs"), path.join(out, "package.json"), data);
|
|
10
|
+
await renderToFile(path.join(TPL, "src/main.ts.hbs"), path.join(out, "src/main.ts"), data);
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=server.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"server.js","sourceRoot":"","sources":["../../../../src/commands/init/generators/server.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAGnD,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,QAAQ,CAAC,CAAC;AAEhD,MAAM,CAAC,KAAK,UAAU,cAAc,CAAC,GAAW,EAAE,IAAgB;IAChE,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,iBAAiB,CAAC,CAAC;IAEjD,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,eAAe,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,eAAe,CAAC,CAAC,CAAC;IAClF,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,cAAc,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,cAAc,CAAC,CAAC,CAAC;IAEhF,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,cAAc,CAAC,EAAE,IAAI,CAAC,CAAC;IAC7F,MAAM,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,iBAAiB,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,aAAa,CAAC,EAAE,IAAI,CAAC,CAAC;AAC7F,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"init.d.ts","sourceRoot":"","sources":["../../../src/commands/init/init.ts"],"names":[],"mappings":"AAcA,MAAM,WAAW,WAAW;IAC1B,GAAG,EAAE,MAAM,CAAC;CACb;AAED,wBAAsB,OAAO,CAAC,IAAI,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,CAmC9D"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import crypto from "crypto";
|
|
2
|
+
import { createLazyLogger } from "../../runtime/lazy-logger.js";
|
|
3
|
+
import { generateClient } from "./generators/client.js";
|
|
4
|
+
import { generateClientCommon } from "./generators/client-common.js";
|
|
5
|
+
import { generateCommon } from "./generators/common.js";
|
|
6
|
+
import { generateRoot } from "./generators/root.js";
|
|
7
|
+
import { generateServer } from "./generators/server.js";
|
|
8
|
+
import { normalize } from "./normalize.js";
|
|
9
|
+
import { promptInit } from "./prompts.js";
|
|
10
|
+
import { validateBeforePrompt, validateInput } from "./validate.js";
|
|
11
|
+
const logger = createLazyLogger("sd:cli:init");
|
|
12
|
+
export async function runInit(opts) {
|
|
13
|
+
await validateBeforePrompt(opts.cwd);
|
|
14
|
+
const input = await promptInit();
|
|
15
|
+
validateInput(input);
|
|
16
|
+
const normalized = normalize(input);
|
|
17
|
+
const data = {
|
|
18
|
+
...normalized,
|
|
19
|
+
jwtSecret: crypto.randomBytes(32).toString("hex"),
|
|
20
|
+
};
|
|
21
|
+
logger.info(`워크스페이스 부트스트랩 시작: ${opts.cwd}`);
|
|
22
|
+
await generateRoot(opts.cwd, data);
|
|
23
|
+
if (data.hasServer)
|
|
24
|
+
await generateServer(opts.cwd, data);
|
|
25
|
+
if (data.hasCommon)
|
|
26
|
+
await generateCommon(opts.cwd, data);
|
|
27
|
+
if (data.hasClientCommon)
|
|
28
|
+
await generateClientCommon(opts.cwd, data);
|
|
29
|
+
for (const client of data.clients) {
|
|
30
|
+
await generateClient(opts.cwd, data, client);
|
|
31
|
+
}
|
|
32
|
+
logger.info("워크스페이스 부트스트랩 완료.");
|
|
33
|
+
const steps = ["pnpm install"];
|
|
34
|
+
if (data.hasDb) {
|
|
35
|
+
steps.push("sd.config.ts 의 configs.orm.MAIN 접속 정보 (host/port/user/password/database) 를 실제 값으로 수정");
|
|
36
|
+
}
|
|
37
|
+
if (data.hasMobile) {
|
|
38
|
+
steps.push(`(prod 빌드 필요 시) capacitor 키스토어를 packages/${data.firstMobileClientName}/res/ 에 배치 후 sd.config.ts 의 capacitor.platform.android.sign 블록 수동 추가`);
|
|
39
|
+
}
|
|
40
|
+
steps.push("CLAUDE.md 가 필요하면 Claude Code 내장 /init 으로 작성");
|
|
41
|
+
logger.info("다음 단계:");
|
|
42
|
+
steps.forEach((s, i) => logger.info(` ${i + 1}. ${s}`));
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=init.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"init.js","sourceRoot":"","sources":["../../../src/commands/init/init.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;AAClE,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAEvC,OAAO,EAAE,oBAAoB,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAEjE,MAAM,MAAM,GAAG,gBAAgB,CAAC,aAAa,CAAC,CAAC;AAM/C,MAAM,CAAC,KAAK,UAAU,OAAO,CAAC,IAAiB;IAC7C,MAAM,oBAAoB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAErC,MAAM,KAAK,GAAG,MAAM,UAAU,EAAE,CAAC;IACjC,aAAa,CAAC,KAAK,CAAC,CAAC;IAErB,MAAM,UAAU,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC;IACpC,MAAM,IAAI,GAAe;QACvB,GAAG,UAAU;QACb,SAAS,EAAE,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC;KAClD,CAAC;IAEF,MAAM,CAAC,IAAI,CAAC,oBAAoB,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;IAE5C,MAAM,YAAY,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IACnC,IAAI,IAAI,CAAC,SAAS;QAAE,MAAM,cAAc,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IACzD,IAAI,IAAI,CAAC,SAAS;QAAE,MAAM,cAAc,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IACzD,IAAI,IAAI,CAAC,eAAe;QAAE,MAAM,oBAAoB,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IACrE,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;QAClC,MAAM,cAAc,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;IAC/C,CAAC;IAED,MAAM,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;IAEhC,MAAM,KAAK,GAAa,CAAC,cAAc,CAAC,CAAC;IACzC,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,KAAK,CAAC,IAAI,CAAC,sFAAsF,CAAC,CAAC;IACrG,CAAC;IACD,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;QACnB,KAAK,CAAC,IAAI,CAAC,2CAA2C,IAAI,CAAC,qBAAsB,sEAAsE,CAAC,CAAC;IAC3J,CAAC;IACD,KAAK,CAAC,IAAI,CAAC,6CAA6C,CAAC,CAAC;IAE1D,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACtB,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;AAC3D,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"normalize.d.ts","sourceRoot":"","sources":["../../../src/commands/init/normalize.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAc,SAAS,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAQtE,wBAAgB,SAAS,CAAC,KAAK,EAAE,SAAS,GAAG,eAAe,CAqC3D"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
const DB_PORTS = {
|
|
2
|
+
mysql: 3306,
|
|
3
|
+
postgres: 5432,
|
|
4
|
+
mssql: 1433,
|
|
5
|
+
};
|
|
6
|
+
export function normalize(input) {
|
|
7
|
+
const clients = input.clients.map((c) => {
|
|
8
|
+
const name = c.name.startsWith("client-") ? c.name : `client-${c.name}`;
|
|
9
|
+
const isMobile = c.type === "mobile";
|
|
10
|
+
return {
|
|
11
|
+
name,
|
|
12
|
+
type: c.type,
|
|
13
|
+
hasRouter: isMobile ? false : c.hasRouter,
|
|
14
|
+
isMobile,
|
|
15
|
+
};
|
|
16
|
+
});
|
|
17
|
+
const hasDb = input.hasServer && input.hasDb;
|
|
18
|
+
const hasCommon = input.hasServer;
|
|
19
|
+
const hasClientCommon = input.hasServer || clients.length >= 2;
|
|
20
|
+
const hasMobile = clients.some((c) => c.isMobile);
|
|
21
|
+
return {
|
|
22
|
+
workspaceName: input.workspaceName,
|
|
23
|
+
workspaceNameUpper: input.workspaceName.toUpperCase().replace(/-/g, "_"),
|
|
24
|
+
description: input.description,
|
|
25
|
+
hasServer: input.hasServer,
|
|
26
|
+
hasDb,
|
|
27
|
+
dbDialect: hasDb ? input.dbDialect : undefined,
|
|
28
|
+
dbPort: hasDb && input.dbDialect != null ? DB_PORTS[input.dbDialect] : 0,
|
|
29
|
+
isMysql: hasDb && input.dbDialect === "mysql",
|
|
30
|
+
isPostgres: hasDb && input.dbDialect === "postgres",
|
|
31
|
+
isMssql: hasDb && input.dbDialect === "mssql",
|
|
32
|
+
serverPort: input.serverPort ?? 40080,
|
|
33
|
+
mobileAppId: hasMobile ? input.mobileAppId : undefined,
|
|
34
|
+
firstMobileClientName: clients.find((c) => c.isMobile)?.name,
|
|
35
|
+
clients,
|
|
36
|
+
hasCommon,
|
|
37
|
+
hasClientCommon,
|
|
38
|
+
hasMobile,
|
|
39
|
+
hasAnyClient: clients.length > 0,
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=normalize.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"normalize.js","sourceRoot":"","sources":["../../../src/commands/init/normalize.ts"],"names":[],"mappings":"AAEA,MAAM,QAAQ,GAAwD;IACpE,KAAK,EAAE,IAAI;IACX,QAAQ,EAAE,IAAI;IACd,KAAK,EAAE,IAAI;CACZ,CAAC;AAEF,MAAM,UAAU,SAAS,CAAC,KAAgB;IACxC,MAAM,OAAO,GAAiB,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;QACpD,MAAM,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,IAAI,EAAE,CAAC;QACxE,MAAM,QAAQ,GAAG,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC;QACrC,OAAO;YACL,IAAI;YACJ,IAAI,EAAE,CAAC,CAAC,IAAI;YACZ,SAAS,EAAE,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS;YACzC,QAAQ;SACT,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,MAAM,KAAK,GAAG,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,KAAK,CAAC;IAC7C,MAAM,SAAS,GAAG,KAAK,CAAC,SAAS,CAAC;IAClC,MAAM,eAAe,GAAG,KAAK,CAAC,SAAS,IAAI,OAAO,CAAC,MAAM,IAAI,CAAC,CAAC;IAC/D,MAAM,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;IAElD,OAAO;QACL,aAAa,EAAE,KAAK,CAAC,aAAa;QAClC,kBAAkB,EAAE,KAAK,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC;QACxE,WAAW,EAAE,KAAK,CAAC,WAAW;QAC9B,SAAS,EAAE,KAAK,CAAC,SAAS;QAC1B,KAAK;QACL,SAAS,EAAE,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS;QAC9C,MAAM,EAAE,KAAK,IAAI,KAAK,CAAC,SAAS,IAAI,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;QACxE,OAAO,EAAE,KAAK,IAAI,KAAK,CAAC,SAAS,KAAK,OAAO;QAC7C,UAAU,EAAE,KAAK,IAAI,KAAK,CAAC,SAAS,KAAK,UAAU;QACnD,OAAO,EAAE,KAAK,IAAI,KAAK,CAAC,SAAS,KAAK,OAAO;QAC7C,UAAU,EAAE,KAAK,CAAC,UAAU,IAAI,KAAK;QACrC,WAAW,EAAE,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS;QACtD,qBAAqB,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,IAAI;QAC5D,OAAO;QACP,SAAS;QACT,eAAe;QACf,SAAS;QACT,YAAY,EAAE,OAAO,CAAC,MAAM,GAAG,CAAC;KACjC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prompts.d.ts","sourceRoot":"","sources":["../../../src/commands/init/prompts.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAA0C,SAAS,EAAE,MAAM,SAAS,CAAC;AAKjF,wBAAsB,UAAU,IAAI,OAAO,CAAC,SAAS,CAAC,CA8FrD"}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { confirm, input, select } from "@inquirer/prompts";
|
|
2
|
+
const KEBAB_CASE_RE = /^[a-z][a-z0-9]*(-[a-z0-9]+)*$/;
|
|
3
|
+
const APPID_RE = /^[a-z][a-z0-9]*(\.[a-z][a-z0-9]*)+$/;
|
|
4
|
+
export async function promptInit() {
|
|
5
|
+
const workspaceName = await input({
|
|
6
|
+
message: "워크스페이스 이름 (영문 kebab-case, 예: my-project):",
|
|
7
|
+
validate: (v) => KEBAB_CASE_RE.test(v) || "영문 kebab-case 만 허용됩니다.",
|
|
8
|
+
});
|
|
9
|
+
const description = await input({
|
|
10
|
+
message: "한 줄 설명:",
|
|
11
|
+
});
|
|
12
|
+
const hasServer = await confirm({
|
|
13
|
+
message: "server 패키지를 만들까요?",
|
|
14
|
+
default: true,
|
|
15
|
+
});
|
|
16
|
+
let hasDb = false;
|
|
17
|
+
let dbDialect;
|
|
18
|
+
let serverPort;
|
|
19
|
+
if (hasServer) {
|
|
20
|
+
hasDb = await confirm({
|
|
21
|
+
message: "DB 를 사용할까요? (ORM 부트스트랩 포함)",
|
|
22
|
+
default: true,
|
|
23
|
+
});
|
|
24
|
+
if (hasDb) {
|
|
25
|
+
dbDialect = await select({
|
|
26
|
+
message: "DB dialect 를 선택하세요:",
|
|
27
|
+
choices: [
|
|
28
|
+
{ name: "MySQL", value: "mysql" },
|
|
29
|
+
{ name: "PostgreSQL", value: "postgres" },
|
|
30
|
+
{ name: "MSSQL", value: "mssql" },
|
|
31
|
+
],
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
const portStr = await input({
|
|
35
|
+
message: "server port (dev/prod 동일):",
|
|
36
|
+
default: "40080",
|
|
37
|
+
validate: (v) => {
|
|
38
|
+
const n = Number(v);
|
|
39
|
+
return (Number.isInteger(n) && n > 0 && n < 65536) || "유효한 포트 번호 (1-65535)";
|
|
40
|
+
},
|
|
41
|
+
});
|
|
42
|
+
serverPort = Number(portStr);
|
|
43
|
+
}
|
|
44
|
+
const clients = [];
|
|
45
|
+
for (;;) {
|
|
46
|
+
const shouldAdd = clients.length === 0
|
|
47
|
+
? await confirm({ message: "client 를 추가할까요?", default: true })
|
|
48
|
+
: await confirm({ message: "다른 client 를 더 추가할까요?", default: false });
|
|
49
|
+
if (!shouldAdd)
|
|
50
|
+
break;
|
|
51
|
+
const clientName = await input({
|
|
52
|
+
message: "client 이름 (예: admin → 자동으로 client-admin):",
|
|
53
|
+
validate: (v) => KEBAB_CASE_RE.test(v) || "영문 kebab-case 만 허용됩니다.",
|
|
54
|
+
});
|
|
55
|
+
const clientType = await select({
|
|
56
|
+
message: "client 타입:",
|
|
57
|
+
choices: [
|
|
58
|
+
{ name: "일반 웹", value: "web" },
|
|
59
|
+
{ name: "모바일 (capacitor)", value: "mobile" },
|
|
60
|
+
],
|
|
61
|
+
});
|
|
62
|
+
let hasRouter = false;
|
|
63
|
+
if (clientType !== "mobile") {
|
|
64
|
+
hasRouter = await confirm({
|
|
65
|
+
message: `${clientName}: 라우팅 (@angular/router) 을 쓸까요?`,
|
|
66
|
+
default: true,
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
clients.push({ name: clientName, type: clientType, hasRouter });
|
|
70
|
+
}
|
|
71
|
+
let mobileAppId;
|
|
72
|
+
if (clients.some((c) => c.type === "mobile")) {
|
|
73
|
+
mobileAppId = await input({
|
|
74
|
+
message: "capacitor appId (reverse-DNS, 예: kr.co.example.app):",
|
|
75
|
+
validate: (v) => APPID_RE.test(v) || "reverse-DNS 형식이어야 합니다.",
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
return {
|
|
79
|
+
workspaceName,
|
|
80
|
+
description,
|
|
81
|
+
hasServer,
|
|
82
|
+
clients,
|
|
83
|
+
hasDb,
|
|
84
|
+
dbDialect,
|
|
85
|
+
mobileAppId,
|
|
86
|
+
serverPort,
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
//# sourceMappingURL=prompts.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prompts.js","sourceRoot":"","sources":["../../../src/commands/init/prompts.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export declare function renderTemplate(tplPath: string, data: unknown): Promise<string>;
|
|
2
|
+
export declare function renderToFile(tplPath: string, outPath: string, data: unknown): Promise<void>;
|
|
3
|
+
export declare function copyFixed(sourcePath: string, outPath: string): Promise<void>;
|
|
4
|
+
//# sourceMappingURL=render.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"render.d.ts","sourceRoot":"","sources":["../../../src/commands/init/render.ts"],"names":[],"mappings":"AAOA,wBAAsB,cAAc,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,CAQpF;AAED,wBAAsB,YAAY,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,CAGjG;AAED,wBAAsB,SAAS,CAAC,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAElF"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import Handlebars from "handlebars";
|
|
2
|
+
import { fsx } from "@simplysm/core-node";
|
|
3
|
+
const compileCache = new Map();
|
|
4
|
+
export async function renderTemplate(tplPath, data) {
|
|
5
|
+
let tpl = compileCache.get(tplPath);
|
|
6
|
+
if (tpl == null) {
|
|
7
|
+
const source = await fsx.read(tplPath);
|
|
8
|
+
tpl = Handlebars.compile(source, { noEscape: true });
|
|
9
|
+
compileCache.set(tplPath, tpl);
|
|
10
|
+
}
|
|
11
|
+
return tpl(data);
|
|
12
|
+
}
|
|
13
|
+
export async function renderToFile(tplPath, outPath, data) {
|
|
14
|
+
const rendered = await renderTemplate(tplPath, data);
|
|
15
|
+
await fsx.write(outPath, rendered);
|
|
16
|
+
}
|
|
17
|
+
export async function copyFixed(sourcePath, outPath) {
|
|
18
|
+
await fsx.copy(sourcePath, outPath);
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=render.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"render.js","sourceRoot":"","sources":["../../../src/commands/init/render.ts"],"names":[],"mappings":"AAAA,OAAO,UAAU,MAAM,YAAY,CAAC;AACpC,OAAO,EAAE,GAAG,EAAE,MAAM,qBAAqB,CAAC;AAI1C,MAAM,YAAY,GAAG,IAAI,GAAG,EAAoB,CAAC;AAEjD,MAAM,CAAC,KAAK,UAAU,cAAc,CAAC,OAAe,EAAE,IAAa;IACjE,IAAI,GAAG,GAAG,YAAY,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IACpC,IAAI,GAAG,IAAI,IAAI,EAAE,CAAC;QAChB,MAAM,MAAM,GAAG,MAAM,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACvC,GAAG,GAAG,UAAU,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QACrD,YAAY,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;IACjC,CAAC;IACD,OAAO,GAAG,CAAC,IAAI,CAAC,CAAC;AACnB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,YAAY,CAAC,OAAe,EAAE,OAAe,EAAE,IAAa;IAChF,MAAM,QAAQ,GAAG,MAAM,cAAc,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;IACrD,MAAM,GAAG,CAAC,KAAK,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;AACrC,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,SAAS,CAAC,UAAkB,EAAE,OAAe;IACjE,MAAM,GAAG,CAAC,IAAI,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;AACtC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"template-paths.d.ts","sourceRoot":"","sources":["../../../src/commands/init/template-paths.ts"],"names":[],"mappings":"AAOA,eAAO,MAAM,cAAc,QAA6D,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import path from "node:path";
|
|
2
|
+
import { fileURLToPath } from "node:url";
|
|
3
|
+
const here = path.dirname(fileURLToPath(import.meta.url));
|
|
4
|
+
const isProd = here.includes(`${path.sep}dist${path.sep}`);
|
|
5
|
+
const pkgRoot = path.resolve(here, isProd ? "../../.." : "../../..");
|
|
6
|
+
export const TEMPLATES_ROOT = path.join(pkgRoot, "src", "commands", "init", "templates");
|
|
7
|
+
//# sourceMappingURL=template-paths.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"template-paths.js","sourceRoot":"","sources":["../../../src/commands/init/template-paths.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAEzC,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;AAC1D,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,GAAG,OAAO,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;AAC3D,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC;AAErE,MAAM,CAAC,MAAM,cAAc,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
export type ClientType = "web" | "mobile";
|
|
2
|
+
export type DbDialect = "mysql" | "postgres" | "mssql";
|
|
3
|
+
export interface ClientInputSpec {
|
|
4
|
+
name: string;
|
|
5
|
+
type: ClientType;
|
|
6
|
+
hasRouter: boolean;
|
|
7
|
+
}
|
|
8
|
+
export interface InitInput {
|
|
9
|
+
workspaceName: string;
|
|
10
|
+
description: string;
|
|
11
|
+
hasServer: boolean;
|
|
12
|
+
clients: ClientInputSpec[];
|
|
13
|
+
hasDb: boolean;
|
|
14
|
+
dbDialect?: DbDialect;
|
|
15
|
+
mobileAppId?: string;
|
|
16
|
+
serverPort?: number;
|
|
17
|
+
}
|
|
18
|
+
export interface ClientSpec {
|
|
19
|
+
name: string;
|
|
20
|
+
type: ClientType;
|
|
21
|
+
hasRouter: boolean;
|
|
22
|
+
isMobile: boolean;
|
|
23
|
+
}
|
|
24
|
+
export interface NormalizedInput {
|
|
25
|
+
workspaceName: string;
|
|
26
|
+
workspaceNameUpper: string;
|
|
27
|
+
description: string;
|
|
28
|
+
hasServer: boolean;
|
|
29
|
+
hasDb: boolean;
|
|
30
|
+
dbDialect?: DbDialect;
|
|
31
|
+
dbPort: number;
|
|
32
|
+
isMysql: boolean;
|
|
33
|
+
isPostgres: boolean;
|
|
34
|
+
isMssql: boolean;
|
|
35
|
+
serverPort: number;
|
|
36
|
+
mobileAppId?: string;
|
|
37
|
+
firstMobileClientName?: string;
|
|
38
|
+
clients: ClientSpec[];
|
|
39
|
+
hasCommon: boolean;
|
|
40
|
+
hasClientCommon: boolean;
|
|
41
|
+
hasMobile: boolean;
|
|
42
|
+
hasAnyClient: boolean;
|
|
43
|
+
}
|
|
44
|
+
export interface RenderData extends NormalizedInput {
|
|
45
|
+
jwtSecret: string;
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/commands/init/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,UAAU,GAAG,KAAK,GAAG,QAAQ,CAAC;AAC1C,MAAM,MAAM,SAAS,GAAG,OAAO,GAAG,UAAU,GAAG,OAAO,CAAC;AAEvD,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,UAAU,CAAC;IACjB,SAAS,EAAE,OAAO,CAAC;CACpB;AAED,MAAM,WAAW,SAAS;IACxB,aAAa,EAAE,MAAM,CAAC;IACtB,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,OAAO,CAAC;IACnB,OAAO,EAAE,eAAe,EAAE,CAAC;IAC3B,KAAK,EAAE,OAAO,CAAC;IACf,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,UAAU;IACzB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,UAAU,CAAC;IACjB,SAAS,EAAE,OAAO,CAAC;IACnB,QAAQ,EAAE,OAAO,CAAC;CACnB;AAED,MAAM,WAAW,eAAe;IAC9B,aAAa,EAAE,MAAM,CAAC;IACtB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,OAAO,CAAC;IACf,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,OAAO,CAAC;IACjB,UAAU,EAAE,OAAO,CAAC;IACpB,OAAO,EAAE,OAAO,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,qBAAqB,CAAC,EAAE,MAAM,CAAC;IAC/B,OAAO,EAAE,UAAU,EAAE,CAAC;IACtB,SAAS,EAAE,OAAO,CAAC;IACnB,eAAe,EAAE,OAAO,CAAC;IACzB,SAAS,EAAE,OAAO,CAAC;IACnB,YAAY,EAAE,OAAO,CAAC;CACvB;AAED,MAAM,WAAW,UAAW,SAAQ,eAAe;IACjD,SAAS,EAAE,MAAM,CAAC;CACnB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/commands/init/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validate.d.ts","sourceRoot":"","sources":["../../../src/commands/init/validate.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAIzC,wBAAsB,oBAAoB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CASrE;AAED,wBAAgB,aAAa,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI,CAwBpD"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { fsx } from "@simplysm/core-node";
|
|
2
|
+
const KEBAB_CASE_RE = /^[a-z][a-z0-9]*(-[a-z0-9]+)*$/;
|
|
3
|
+
export async function validateBeforePrompt(cwd) {
|
|
4
|
+
if (!(await fsx.exists(cwd)))
|
|
5
|
+
return;
|
|
6
|
+
const children = await fsx.readdir(cwd);
|
|
7
|
+
const significant = children.filter((n) => n !== ".git");
|
|
8
|
+
if (significant.length > 0) {
|
|
9
|
+
throw new Error(`작업 디렉토리가 비어있지 않습니다 (감지된 항목: ${significant.join(", ")}). 빈 디렉토리에서 다시 실행하세요.`);
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
export function validateInput(input) {
|
|
13
|
+
if (!input.hasServer && input.clients.length === 0) {
|
|
14
|
+
throw new Error("server 도 client 도 없는 워크스페이스는 만들 수 없습니다.");
|
|
15
|
+
}
|
|
16
|
+
if (!KEBAB_CASE_RE.test(input.workspaceName)) {
|
|
17
|
+
throw new Error(`워크스페이스 이름은 영문 kebab-case 여야 합니다 (예: my-workspace). 입력값: "${input.workspaceName}"`);
|
|
18
|
+
}
|
|
19
|
+
const clientNames = new Set();
|
|
20
|
+
for (const c of input.clients) {
|
|
21
|
+
if (!KEBAB_CASE_RE.test(c.name)) {
|
|
22
|
+
throw new Error(`client 이름은 영문 kebab-case 여야 합니다. 입력값: "${c.name}"`);
|
|
23
|
+
}
|
|
24
|
+
const normalized = c.name.startsWith("client-") ? c.name : `client-${c.name}`;
|
|
25
|
+
if (clientNames.has(normalized)) {
|
|
26
|
+
throw new Error(`client 이름이 중복됩니다: "${normalized}"`);
|
|
27
|
+
}
|
|
28
|
+
clientNames.add(normalized);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=validate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validate.js","sourceRoot":"","sources":["../../../src/commands/init/validate.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,qBAAqB,CAAC;AAG1C,MAAM,aAAa,GAAG,+BAA+B,CAAC;AAEtD,MAAM,CAAC,KAAK,UAAU,oBAAoB,CAAC,GAAW;IACpD,IAAI,CAAC,CAAC,MAAM,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QAAE,OAAO;IACrC,MAAM,QAAQ,GAAG,MAAM,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IACxC,MAAM,WAAW,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,MAAM,CAAC,CAAC;IACzD,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC3B,MAAM,IAAI,KAAK,CACb,+BAA+B,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,uBAAuB,CAC7E,CAAC;IACJ,CAAC;AACH,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,KAAgB;IAC5C,IAAI,CAAC,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACnD,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC;IAC7D,CAAC;IAED,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,EAAE,CAAC;QAC7C,MAAM,IAAI,KAAK,CACb,4DAA4D,KAAK,CAAC,aAAa,GAAG,CACnF,CAAC;IACJ,CAAC;IAED,MAAM,WAAW,GAAG,IAAI,GAAG,EAAU,CAAC;IACtC,KAAK,MAAM,CAAC,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC;QAC9B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;YAChC,MAAM,IAAI,KAAK,CACb,0CAA0C,CAAC,CAAC,IAAI,GAAG,CACpD,CAAC;QACJ,CAAC;QACD,MAAM,UAAU,GAAG,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,IAAI,EAAE,CAAC;QAC9E,IAAI,WAAW,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC;YAChC,MAAM,IAAI,KAAK,CAAC,sBAAsB,UAAU,GAAG,CAAC,CAAC;QACvD,CAAC;QACD,WAAW,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IAC9B,CAAC;AACH,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sd-cli-entry.d.ts","sourceRoot":"","sources":["../src/sd-cli-entry.ts"],"names":[],"mappings":";AAKA,OAAc,EAAE,KAAK,IAAI,EAAE,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"sd-cli-entry.d.ts","sourceRoot":"","sources":["../src/sd-cli-entry.ts"],"names":[],"mappings":";AAKA,OAAc,EAAE,KAAK,IAAI,EAAE,MAAM,OAAO,CAAC;AAgDzC;;;GAGG;AACH,wBAAgB,eAAe,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAsSpD"}
|
package/dist/sd-cli-entry.js
CHANGED
|
@@ -8,6 +8,7 @@ import { runCheck } from "./commands/check.js";
|
|
|
8
8
|
import { runWatch } from "./commands/watch.js";
|
|
9
9
|
import { runDev } from "./commands/dev.js";
|
|
10
10
|
import { runBuild } from "./commands/build.js";
|
|
11
|
+
import { runInit } from "./commands/init/init.js";
|
|
11
12
|
import { runPublish } from "./commands/publish/publish-command.js";
|
|
12
13
|
import { runReplaceDeps } from "./commands/replace-deps.js";
|
|
13
14
|
import path from "path";
|
|
@@ -19,7 +20,16 @@ import { createLazyLogger } from "./runtime/lazy-logger.js";
|
|
|
19
20
|
const logger = createLazyLogger("sd:cli:entry");
|
|
20
21
|
Error.stackTraceLimit = Infinity;
|
|
21
22
|
EventEmitter.defaultMaxListeners = 100;
|
|
22
|
-
const COMMAND_NAMES = [
|
|
23
|
+
const COMMAND_NAMES = [
|
|
24
|
+
"check",
|
|
25
|
+
"watch",
|
|
26
|
+
"dev",
|
|
27
|
+
"device",
|
|
28
|
+
"build",
|
|
29
|
+
"publish",
|
|
30
|
+
"replace-deps",
|
|
31
|
+
"init",
|
|
32
|
+
];
|
|
23
33
|
async function collectYargsHelp(argv) {
|
|
24
34
|
const lines = [];
|
|
25
35
|
const orig = console.log;
|
|
@@ -255,6 +265,9 @@ export function createCliParser(argv) {
|
|
|
255
265
|
await runReplaceDeps({
|
|
256
266
|
options: args.opt,
|
|
257
267
|
});
|
|
268
|
+
})
|
|
269
|
+
.command("init", "Bootstrap a new SI workspace via interactive prompts", (cmd) => cmd.version(false).hide("help"), async () => {
|
|
270
|
+
await runInit({ cwd: process.cwd() });
|
|
258
271
|
})
|
|
259
272
|
.demandCommand(1, "Please specify a command.")
|
|
260
273
|
.strict()
|