@bogomolcompany/bogo 0.1.1 → 0.2.1
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/LICENSE +21 -0
- package/README.md +178 -35
- package/README.ru.md +266 -0
- package/dist/cli.js +148 -15
- package/dist/cli.js.map +1 -1
- package/dist/commands/add-method.d.ts +3 -0
- package/dist/commands/add-method.d.ts.map +1 -0
- package/dist/commands/add-method.js +47 -0
- package/dist/commands/add-method.js.map +1 -0
- package/dist/commands/create-app.d.ts +2 -1
- package/dist/commands/create-app.d.ts.map +1 -1
- package/dist/commands/create-app.js +2 -2
- package/dist/commands/create-app.js.map +1 -1
- package/dist/commands/doctor.d.ts +2 -0
- package/dist/commands/doctor.d.ts.map +1 -0
- package/dist/commands/doctor.js +53 -0
- package/dist/commands/doctor.js.map +1 -0
- package/dist/commands/generate-module.d.ts +2 -1
- package/dist/commands/generate-module.d.ts.map +1 -1
- package/dist/commands/generate-module.js +41 -26
- package/dist/commands/generate-module.js.map +1 -1
- package/dist/commands/interactive.d.ts +3 -0
- package/dist/commands/interactive.d.ts.map +1 -0
- package/dist/commands/interactive.js +65 -0
- package/dist/commands/interactive.js.map +1 -0
- package/dist/commands/list-modules.d.ts +2 -0
- package/dist/commands/list-modules.d.ts.map +1 -0
- package/dist/commands/list-modules.js +36 -0
- package/dist/commands/list-modules.js.map +1 -0
- package/dist/commands/remove-module.d.ts +5 -0
- package/dist/commands/remove-module.d.ts.map +1 -0
- package/dist/commands/remove-module.js +99 -0
- package/dist/commands/remove-module.js.map +1 -0
- package/dist/templates/module.d.ts +15 -7
- package/dist/templates/module.d.ts.map +1 -1
- package/dist/templates/module.js +51 -74
- package/dist/templates/module.js.map +1 -1
- package/dist/templates/project.d.ts +2 -1
- package/dist/templates/project.d.ts.map +1 -1
- package/dist/templates/project.js +85 -17
- package/dist/templates/project.js.map +1 -1
- package/dist/templates/render-helpers.d.ts +9 -0
- package/dist/templates/render-helpers.d.ts.map +1 -0
- package/dist/templates/render-helpers.js +78 -0
- package/dist/templates/render-helpers.js.map +1 -0
- package/dist/utils/config.d.ts.map +1 -1
- package/dist/utils/config.js +6 -2
- package/dist/utils/config.js.map +1 -1
- package/dist/utils/http.d.ts +5 -0
- package/dist/utils/http.d.ts.map +1 -0
- package/dist/utils/http.js +13 -0
- package/dist/utils/http.js.map +1 -0
- package/dist/utils/index-path.d.ts +7 -0
- package/dist/utils/index-path.d.ts.map +1 -0
- package/dist/utils/index-path.js +25 -0
- package/dist/utils/index-path.js.map +1 -0
- package/dist/utils/io.d.ts +8 -0
- package/dist/utils/io.d.ts.map +1 -0
- package/dist/utils/io.js +31 -0
- package/dist/utils/io.js.map +1 -0
- package/dist/utils/method-spec.d.ts +4 -0
- package/dist/utils/method-spec.d.ts.map +1 -0
- package/dist/utils/method-spec.js +49 -0
- package/dist/utils/method-spec.js.map +1 -0
- package/dist/utils/parts.d.ts +4 -0
- package/dist/utils/parts.d.ts.map +1 -0
- package/dist/utils/parts.js +9 -0
- package/dist/utils/parts.js.map +1 -0
- package/dist/utils/patch-index.d.ts +8 -3
- package/dist/utils/patch-index.d.ts.map +1 -1
- package/dist/utils/patch-index.js +45 -25
- package/dist/utils/patch-index.js.map +1 -1
- package/dist/utils/patch-method.d.ts +14 -0
- package/dist/utils/patch-method.d.ts.map +1 -0
- package/dist/utils/patch-method.js +128 -0
- package/dist/utils/patch-method.js.map +1 -0
- package/dist/utils/template-loader.d.ts +3 -0
- package/dist/utils/template-loader.d.ts.map +1 -0
- package/dist/utils/template-loader.js +17 -0
- package/dist/utils/template-loader.js.map +1 -0
- package/package.json +28 -4
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.runList = runList;
|
|
4
|
+
const fs_1 = require("fs");
|
|
5
|
+
const path_1 = require("path");
|
|
6
|
+
const config_1 = require("../utils/config");
|
|
7
|
+
function parseControllerMethods(filePath) {
|
|
8
|
+
if (!(0, fs_1.existsSync)(filePath)) {
|
|
9
|
+
return [];
|
|
10
|
+
}
|
|
11
|
+
const content = (0, fs_1.readFileSync)(filePath, "utf-8");
|
|
12
|
+
const matches = content.matchAll(/async (\w+)\(req: e\.Request, res: e\.Response\)/g);
|
|
13
|
+
return [...matches].map(match => match[1]);
|
|
14
|
+
}
|
|
15
|
+
function runList(cwd) {
|
|
16
|
+
const config = (0, config_1.loadConfig)(cwd);
|
|
17
|
+
const apiRoot = (0, path_1.join)(cwd, config.apiDir);
|
|
18
|
+
if (!(0, fs_1.existsSync)(apiRoot)) {
|
|
19
|
+
console.log(`No modules found. Directory does not exist: ${apiRoot}`);
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
const modules = (0, fs_1.readdirSync)(apiRoot, { withFileTypes: true }).filter(entry => entry.isDirectory());
|
|
23
|
+
if (modules.length === 0) {
|
|
24
|
+
console.log("No modules found.");
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
console.log("Modules:\n");
|
|
28
|
+
for (const moduleDir of modules) {
|
|
29
|
+
const kebab = moduleDir.name;
|
|
30
|
+
const controllerPath = (0, path_1.join)(apiRoot, kebab, `${kebab}.controller.ts`);
|
|
31
|
+
const methods = parseControllerMethods(controllerPath);
|
|
32
|
+
const methodLabel = methods.length > 0 ? methods.join(", ") : "no methods detected";
|
|
33
|
+
console.log(` ${kebab} → ${methodLabel}`);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=list-modules.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"list-modules.js","sourceRoot":"","sources":["../../src/commands/list-modules.ts"],"names":[],"mappings":";;AAcA,0BAuBC;AArCD,2BAA2D;AAC3D,+BAA4B;AAC5B,4CAA6C;AAE7C,SAAS,sBAAsB,CAAC,QAAgB;IAC9C,IAAI,CAAC,IAAA,eAAU,EAAC,QAAQ,CAAC,EAAE,CAAC;QAC1B,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,MAAM,OAAO,GAAG,IAAA,iBAAY,EAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;IAChD,MAAM,OAAO,GAAG,OAAO,CAAC,QAAQ,CAAC,mDAAmD,CAAC,CAAC;IACtF,OAAO,CAAC,GAAG,OAAO,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;AAC7C,CAAC;AAED,SAAgB,OAAO,CAAC,GAAW;IACjC,MAAM,MAAM,GAAG,IAAA,mBAAU,EAAC,GAAG,CAAC,CAAC;IAC/B,MAAM,OAAO,GAAG,IAAA,WAAI,EAAC,GAAG,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;IAEzC,IAAI,CAAC,IAAA,eAAU,EAAC,OAAO,CAAC,EAAE,CAAC;QACzB,OAAO,CAAC,GAAG,CAAC,+CAA+C,OAAO,EAAE,CAAC,CAAC;QACtE,OAAO;IACT,CAAC;IAED,MAAM,OAAO,GAAG,IAAA,gBAAW,EAAC,OAAO,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,CAAC;IACnG,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACzB,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;QACjC,OAAO;IACT,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;IAC1B,KAAK,MAAM,SAAS,IAAI,OAAO,EAAE,CAAC;QAChC,MAAM,KAAK,GAAG,SAAS,CAAC,IAAI,CAAC;QAC7B,MAAM,cAAc,GAAG,IAAA,WAAI,EAAC,OAAO,EAAE,KAAK,EAAE,GAAG,KAAK,gBAAgB,CAAC,CAAC;QACtE,MAAM,OAAO,GAAG,sBAAsB,CAAC,cAAc,CAAC,CAAC;QACvD,MAAM,WAAW,GAAG,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,qBAAqB,CAAC;QACpF,OAAO,CAAC,GAAG,CAAC,KAAK,KAAK,QAAQ,WAAW,EAAE,CAAC,CAAC;IAC/C,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { ModulePart, RemoveMethodOptions, RemoveModuleOptions } from "../interfaces";
|
|
2
|
+
export declare function runRemoveModule(cwd: string, moduleName: string, options: RemoveModuleOptions): void;
|
|
3
|
+
export declare function runRemovePart(cwd: string, part: ModulePart, moduleName: string, options: RemoveModuleOptions): void;
|
|
4
|
+
export declare function runRemoveMethod(cwd: string, moduleName: string, options: RemoveMethodOptions): void;
|
|
5
|
+
//# sourceMappingURL=remove-module.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"remove-module.d.ts","sourceRoot":"","sources":["../../src/commands/remove-module.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AAiCrF,wBAAgB,eAAe,CAAC,GAAG,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,mBAAmB,GAAG,IAAI,CAiBnG;AAED,wBAAgB,aAAa,CAC3B,GAAG,EAAE,MAAM,EACX,IAAI,EAAE,UAAU,EAChB,UAAU,EAAE,MAAM,EAClB,OAAO,EAAE,mBAAmB,GAC3B,IAAI,CAiBN;AAED,wBAAgB,eAAe,CAAC,GAAG,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,mBAAmB,GAAG,IAAI,CAyCnG"}
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.runRemoveModule = runRemoveModule;
|
|
4
|
+
exports.runRemovePart = runRemovePart;
|
|
5
|
+
exports.runRemoveMethod = runRemoveMethod;
|
|
6
|
+
const fs_1 = require("fs");
|
|
7
|
+
const path_1 = require("path");
|
|
8
|
+
const config_1 = require("../utils/config");
|
|
9
|
+
const method_spec_1 = require("../utils/method-spec");
|
|
10
|
+
const naming_1 = require("../utils/naming");
|
|
11
|
+
const patch_index_1 = require("../utils/patch-index");
|
|
12
|
+
const patch_method_1 = require("../utils/patch-method");
|
|
13
|
+
const parts_1 = require("../utils/parts");
|
|
14
|
+
function unpatchIndexIfNeeded(cwd, moduleName, options, part) {
|
|
15
|
+
if (options.skipIndex || options.dryRun) {
|
|
16
|
+
if (options.skipIndex) {
|
|
17
|
+
console.log("\nSkipped index patch (--skip-index)");
|
|
18
|
+
}
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
if (part && part !== "routes") {
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
const config = (0, config_1.loadConfig)(cwd);
|
|
25
|
+
const names = (0, naming_1.resolveModuleNames)(moduleName);
|
|
26
|
+
const unpatchd = (0, patch_index_1.unpatchIndexFile)(cwd, config, names, { dryRun: options.dryRun });
|
|
27
|
+
if (unpatchd) {
|
|
28
|
+
console.log(`\nUpdated ${(0, path_1.join)(cwd, config.indexFile)}`);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
function runRemoveModule(cwd, moduleName, options) {
|
|
32
|
+
const config = (0, config_1.loadConfig)(cwd);
|
|
33
|
+
const names = (0, naming_1.resolveModuleNames)(moduleName);
|
|
34
|
+
const targetDir = (0, path_1.join)(cwd, config.apiDir, names.kebab);
|
|
35
|
+
if (!(0, fs_1.existsSync)(targetDir)) {
|
|
36
|
+
throw new Error(`Module directory not found: ${targetDir}`);
|
|
37
|
+
}
|
|
38
|
+
if (options.dryRun) {
|
|
39
|
+
console.log(`[dry-run] remove ${targetDir}`);
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
(0, fs_1.rmSync)(targetDir, { recursive: true, force: true });
|
|
43
|
+
}
|
|
44
|
+
console.log(`Module "${names.kebab}" removed:\n ${targetDir}`);
|
|
45
|
+
unpatchIndexIfNeeded(cwd, moduleName, options);
|
|
46
|
+
}
|
|
47
|
+
function runRemovePart(cwd, part, moduleName, options) {
|
|
48
|
+
const config = (0, config_1.loadConfig)(cwd);
|
|
49
|
+
const names = (0, naming_1.resolveModuleNames)(moduleName);
|
|
50
|
+
const filePath = (0, path_1.join)(cwd, config.apiDir, names.kebab, `${names.kebab}.${part}.ts`);
|
|
51
|
+
if (!(0, fs_1.existsSync)(filePath)) {
|
|
52
|
+
throw new Error(`File not found: ${filePath}`);
|
|
53
|
+
}
|
|
54
|
+
if (options.dryRun) {
|
|
55
|
+
console.log(`[dry-run] remove ${filePath}`);
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
(0, fs_1.rmSync)(filePath);
|
|
59
|
+
}
|
|
60
|
+
console.log(`${part} for "${names.kebab}" removed:\n ${filePath}`);
|
|
61
|
+
unpatchIndexIfNeeded(cwd, moduleName, options, part);
|
|
62
|
+
}
|
|
63
|
+
function runRemoveMethod(cwd, moduleName, options) {
|
|
64
|
+
const config = (0, config_1.loadConfig)(cwd);
|
|
65
|
+
const names = (0, naming_1.resolveModuleNames)(moduleName);
|
|
66
|
+
const methods = options.methods.map(method_spec_1.parseMethodSpec);
|
|
67
|
+
const targetDir = (0, path_1.join)(cwd, config.apiDir, names.kebab);
|
|
68
|
+
if (!(0, fs_1.existsSync)(targetDir)) {
|
|
69
|
+
throw new Error(`Module directory not found: ${targetDir}`);
|
|
70
|
+
}
|
|
71
|
+
const parts = options.parts.length > 0 ? options.parts : parts_1.MODULE_PARTS;
|
|
72
|
+
const ctx = { names, methods: [], middleware: [] };
|
|
73
|
+
const updated = [];
|
|
74
|
+
for (const part of parts) {
|
|
75
|
+
const filePath = (0, path_1.join)(targetDir, `${names.kebab}.${part}.ts`);
|
|
76
|
+
if (!(0, fs_1.existsSync)(filePath)) {
|
|
77
|
+
continue;
|
|
78
|
+
}
|
|
79
|
+
let content = (0, fs_1.readFileSync)(filePath, "utf-8");
|
|
80
|
+
for (const method of methods) {
|
|
81
|
+
content = patch_method_1.REMOVERS[part](content, ctx, method);
|
|
82
|
+
}
|
|
83
|
+
if (options.dryRun) {
|
|
84
|
+
console.log(`[dry-run] patch ${filePath}`);
|
|
85
|
+
}
|
|
86
|
+
else {
|
|
87
|
+
(0, fs_1.writeFileSync)(filePath, content, "utf-8");
|
|
88
|
+
}
|
|
89
|
+
updated.push(filePath);
|
|
90
|
+
}
|
|
91
|
+
if (updated.length === 0) {
|
|
92
|
+
throw new Error(`No module files found to update in ${targetDir}`);
|
|
93
|
+
}
|
|
94
|
+
console.log(`Method(s) removed from "${names.kebab}":\n`);
|
|
95
|
+
for (const file of updated) {
|
|
96
|
+
console.log(` ${file}`);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
//# sourceMappingURL=remove-module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"remove-module.js","sourceRoot":"","sources":["../../src/commands/remove-module.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,8 +1,16 @@
|
|
|
1
|
-
import { ModuleTemplateContext } from "../interfaces";
|
|
2
|
-
export declare function renderController(ctx: ModuleTemplateContext): string;
|
|
3
|
-
export declare function renderService(ctx: ModuleTemplateContext): string;
|
|
4
|
-
export declare function renderDto(ctx: ModuleTemplateContext): string;
|
|
5
|
-
export declare function renderValidator(ctx: ModuleTemplateContext): string;
|
|
6
|
-
export declare function renderRoutes(ctx: ModuleTemplateContext): string;
|
|
7
|
-
export declare function
|
|
1
|
+
import { ModulePart, ModuleTemplateContext } from "../interfaces";
|
|
2
|
+
export declare function renderController(ctx: ModuleTemplateContext, templatesDir?: string): string;
|
|
3
|
+
export declare function renderService(ctx: ModuleTemplateContext, templatesDir?: string): string;
|
|
4
|
+
export declare function renderDto(ctx: ModuleTemplateContext, templatesDir?: string): string;
|
|
5
|
+
export declare function renderValidator(ctx: ModuleTemplateContext, templatesDir?: string): string;
|
|
6
|
+
export declare function renderRoutes(ctx: ModuleTemplateContext, templatesDir?: string): string;
|
|
7
|
+
export declare function renderPart(part: ModulePart, ctx: ModuleTemplateContext, templatesDir?: string): string;
|
|
8
|
+
export declare function writePartFile(targetDir: string, part: ModulePart, ctx: ModuleTemplateContext, templatesDir?: string, options?: {
|
|
9
|
+
dryRun?: boolean;
|
|
10
|
+
force?: boolean;
|
|
11
|
+
}): string;
|
|
12
|
+
export declare function writeModuleFiles(targetDir: string, ctx: ModuleTemplateContext, templatesDir?: string, options?: {
|
|
13
|
+
dryRun?: boolean;
|
|
14
|
+
force?: boolean;
|
|
15
|
+
}): string[];
|
|
8
16
|
//# sourceMappingURL=module.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"module.d.ts","sourceRoot":"","sources":["../../src/templates/module.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"module.d.ts","sourceRoot":"","sources":["../../src/templates/module.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,qBAAqB,EAAE,MAAM,eAAe,CAAC;AAYlE,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,qBAAqB,EAAE,YAAY,CAAC,EAAE,MAAM,GAAG,MAAM,CAY1F;AAED,wBAAgB,aAAa,CAAC,GAAG,EAAE,qBAAqB,EAAE,YAAY,CAAC,EAAE,MAAM,GAAG,MAAM,CAcvF;AAED,wBAAgB,SAAS,CAAC,GAAG,EAAE,qBAAqB,EAAE,YAAY,CAAC,EAAE,MAAM,GAAG,MAAM,CAEnF;AAED,wBAAgB,eAAe,CAAC,GAAG,EAAE,qBAAqB,EAAE,YAAY,CAAC,EAAE,MAAM,GAAG,MAAM,CAMzF;AAED,wBAAgB,YAAY,CAAC,GAAG,EAAE,qBAAqB,EAAE,YAAY,CAAC,EAAE,MAAM,GAAG,MAAM,CAiBtF;AAUD,wBAAgB,UAAU,CAAC,IAAI,EAAE,UAAU,EAAE,GAAG,EAAE,qBAAqB,EAAE,YAAY,CAAC,EAAE,MAAM,GAAG,MAAM,CAEtG;AAED,wBAAgB,aAAa,CAC3B,SAAS,EAAE,MAAM,EACjB,IAAI,EAAE,UAAU,EAChB,GAAG,EAAE,qBAAqB,EAC1B,YAAY,CAAC,EAAE,MAAM,EACrB,OAAO,GAAE;IAAE,MAAM,CAAC,EAAE,OAAO,CAAC;IAAC,KAAK,CAAC,EAAE,OAAO,CAAA;CAAO,GAClD,MAAM,CAOR;AAED,wBAAgB,gBAAgB,CAC9B,SAAS,EAAE,MAAM,EACjB,GAAG,EAAE,qBAAqB,EAC1B,YAAY,CAAC,EAAE,MAAM,EACrB,OAAO,GAAE;IAAE,MAAM,CAAC,EAAE,OAAO,CAAC;IAAC,KAAK,CAAC,EAAE,OAAO,CAAA;CAAO,GAClD,MAAM,EAAE,CAGV"}
|
package/dist/templates/module.js
CHANGED
|
@@ -5,24 +5,17 @@ exports.renderService = renderService;
|
|
|
5
5
|
exports.renderDto = renderDto;
|
|
6
6
|
exports.renderValidator = renderValidator;
|
|
7
7
|
exports.renderRoutes = renderRoutes;
|
|
8
|
+
exports.renderPart = renderPart;
|
|
9
|
+
exports.writePartFile = writePartFile;
|
|
8
10
|
exports.writeModuleFiles = writeModuleFiles;
|
|
9
|
-
const fs_1 = require("fs");
|
|
10
11
|
const path_1 = require("path");
|
|
11
|
-
const
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
const result = await ${names.pascal}Service.${method.name}(req.body);
|
|
19
|
-
return res.success(result);
|
|
20
|
-
} catch (error) {
|
|
21
|
-
return res.error(error);
|
|
22
|
-
}
|
|
23
|
-
}`)
|
|
24
|
-
.join("\n");
|
|
25
|
-
return `import e from "express";
|
|
12
|
+
const io_1 = require("../utils/io");
|
|
13
|
+
const render_helpers_1 = require("./render-helpers");
|
|
14
|
+
const template_loader_1 = require("../utils/template-loader");
|
|
15
|
+
function renderController(ctx, templatesDir) {
|
|
16
|
+
return (0, template_loader_1.renderWithTemplate)("controller", ctx, templatesDir, ({ names, methods }) => {
|
|
17
|
+
const methodsCode = methods.map(method => (0, render_helpers_1.renderControllerMethod)(names, method)).join("\n");
|
|
18
|
+
return `import e from "express";
|
|
26
19
|
import ${names.pascal}Service from "./${names.kebab}.service";
|
|
27
20
|
|
|
28
21
|
class ${names.pascal}Controller {${methodsCode}
|
|
@@ -30,53 +23,37 @@ class ${names.pascal}Controller {${methodsCode}
|
|
|
30
23
|
|
|
31
24
|
export default new ${names.pascal}Controller();
|
|
32
25
|
`;
|
|
26
|
+
});
|
|
33
27
|
}
|
|
34
|
-
function renderService(ctx) {
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
async ${method.name}(body: ${method.name}DTO) {
|
|
42
|
-
throw new Error("${names.pascal}Service.${method.name} is not implemented");
|
|
43
|
-
}`)
|
|
44
|
-
.join("\n");
|
|
45
|
-
return `${imports}
|
|
28
|
+
function renderService(ctx, templatesDir) {
|
|
29
|
+
return (0, template_loader_1.renderWithTemplate)("service", ctx, templatesDir, ({ names, methods }) => {
|
|
30
|
+
const imports = methods.length > 0
|
|
31
|
+
? `import { ${methods.map(m => `${m.name}DTO`).join(", ")} } from "./${names.kebab}.dto";\n`
|
|
32
|
+
: "";
|
|
33
|
+
const methodsCode = methods.map(method => (0, render_helpers_1.renderServiceMethod)(names, method)).join("\n");
|
|
34
|
+
return `${imports}
|
|
46
35
|
class ${names.pascal}Service {${methodsCode}
|
|
47
36
|
}
|
|
48
37
|
|
|
49
38
|
export default new ${names.pascal}Service();
|
|
50
39
|
`;
|
|
40
|
+
});
|
|
51
41
|
}
|
|
52
|
-
function renderDto(ctx) {
|
|
53
|
-
|
|
54
|
-
// TODO: define fields
|
|
55
|
-
}
|
|
56
|
-
`);
|
|
57
|
-
return blocks.join("\n");
|
|
42
|
+
function renderDto(ctx, templatesDir) {
|
|
43
|
+
return (0, template_loader_1.renderWithTemplate)("dto", ctx, templatesDir, ({ methods }) => methods.map(render_helpers_1.renderDtoBlock).join("\n"));
|
|
58
44
|
}
|
|
59
|
-
function renderValidator(ctx) {
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
// TODO: define validation schema
|
|
63
|
-
}),
|
|
64
|
-
});
|
|
65
|
-
`);
|
|
66
|
-
return `import { z } from "zod";
|
|
45
|
+
function renderValidator(ctx, templatesDir) {
|
|
46
|
+
return (0, template_loader_1.renderWithTemplate)("validator", ctx, templatesDir, ({ methods }) => {
|
|
47
|
+
return `import { z } from "zod";
|
|
67
48
|
|
|
68
|
-
${
|
|
49
|
+
${methods.map(render_helpers_1.renderValidatorBlock).join("\n")}`;
|
|
50
|
+
});
|
|
69
51
|
}
|
|
70
|
-
function renderRoutes(ctx) {
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
.
|
|
75
|
-
const routePath = (0, naming_1.methodToRoutePath)(method.name, method.route);
|
|
76
|
-
return `router.post("${routePath}", validate(${method.name}), (req: Request, res: Response) => controller.${method.name}(req, res));`;
|
|
77
|
-
})
|
|
78
|
-
.join("\n");
|
|
79
|
-
return `import { Request, Response, Router } from "express";
|
|
52
|
+
function renderRoutes(ctx, templatesDir) {
|
|
53
|
+
return (0, template_loader_1.renderWithTemplate)("routes", ctx, templatesDir, ({ names, methods, middleware }) => {
|
|
54
|
+
const validatorImports = methods.map(method => method.name).join(", ");
|
|
55
|
+
const routes = methods.map(method => (0, render_helpers_1.renderRouteLine)(method, middleware)).join("\n");
|
|
56
|
+
return `${(0, render_helpers_1.renderMiddlewareImports)(middleware)}import { Request, Response, Router } from "express";
|
|
80
57
|
import { validate } from "../../middlewares/validate";
|
|
81
58
|
import ${names.pascal}Controller from "./${names.kebab}.controller";
|
|
82
59
|
import { ${validatorImports} } from "./${names.kebab}.validator";
|
|
@@ -88,27 +65,27 @@ ${routes}
|
|
|
88
65
|
|
|
89
66
|
export default router;
|
|
90
67
|
`;
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
const PART_RENDERERS = {
|
|
71
|
+
controller: renderController,
|
|
72
|
+
service: renderService,
|
|
73
|
+
dto: renderDto,
|
|
74
|
+
validator: renderValidator,
|
|
75
|
+
routes: renderRoutes,
|
|
76
|
+
};
|
|
77
|
+
function renderPart(part, ctx, templatesDir) {
|
|
78
|
+
return PART_RENDERERS[part](ctx, templatesDir);
|
|
79
|
+
}
|
|
80
|
+
function writePartFile(targetDir, part, ctx, templatesDir, options = {}) {
|
|
81
|
+
(0, io_1.ensureDir)(targetDir, options);
|
|
82
|
+
const fileName = `${ctx.names.kebab}.${part}.ts`;
|
|
83
|
+
const filePath = (0, path_1.join)(targetDir, fileName);
|
|
84
|
+
(0, io_1.writeTextFile)(filePath, renderPart(part, ctx, templatesDir), options);
|
|
85
|
+
return filePath;
|
|
91
86
|
}
|
|
92
|
-
function writeModuleFiles(targetDir, ctx) {
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
}
|
|
96
|
-
const files = [
|
|
97
|
-
[`${ctx.names.kebab}.controller.ts`, renderController(ctx)],
|
|
98
|
-
[`${ctx.names.kebab}.service.ts`, renderService(ctx)],
|
|
99
|
-
[`${ctx.names.kebab}.dto.ts`, renderDto(ctx)],
|
|
100
|
-
[`${ctx.names.kebab}.validator.ts`, renderValidator(ctx)],
|
|
101
|
-
[`${ctx.names.kebab}.routes.ts`, renderRoutes(ctx)],
|
|
102
|
-
];
|
|
103
|
-
const written = [];
|
|
104
|
-
for (const [fileName, content] of files) {
|
|
105
|
-
const filePath = (0, path_1.join)(targetDir, fileName);
|
|
106
|
-
if ((0, fs_1.existsSync)(filePath)) {
|
|
107
|
-
throw new Error(`File already exists: ${filePath}`);
|
|
108
|
-
}
|
|
109
|
-
(0, fs_1.writeFileSync)(filePath, content, "utf-8");
|
|
110
|
-
written.push(filePath);
|
|
111
|
-
}
|
|
112
|
-
return written;
|
|
87
|
+
function writeModuleFiles(targetDir, ctx, templatesDir, options = {}) {
|
|
88
|
+
const parts = ["controller", "service", "dto", "validator", "routes"];
|
|
89
|
+
return parts.map(part => writePartFile(targetDir, part, ctx, templatesDir, options));
|
|
113
90
|
}
|
|
114
91
|
//# sourceMappingURL=module.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"module.js","sourceRoot":"","sources":["../../src/templates/module.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"module.js","sourceRoot":"","sources":["../../src/templates/module.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,2 +1,3 @@
|
|
|
1
|
-
|
|
1
|
+
import { CreateAppOptions } from "../interfaces";
|
|
2
|
+
export declare function writeProjectFiles(targetDir: string, projectName: string, options: CreateAppOptions): string[];
|
|
2
3
|
//# sourceMappingURL=project.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"project.d.ts","sourceRoot":"","sources":["../../src/templates/project.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"project.d.ts","sourceRoot":"","sources":["../../src/templates/project.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAmPjD,wBAAgB,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,OAAO,EAAE,gBAAgB,GAAG,MAAM,EAAE,CA0C7G"}
|
|
@@ -4,15 +4,17 @@ exports.writeProjectFiles = writeProjectFiles;
|
|
|
4
4
|
const fs_1 = require("fs");
|
|
5
5
|
const path_1 = require("path");
|
|
6
6
|
const config_1 = require("../utils/config");
|
|
7
|
+
const io_1 = require("../utils/io");
|
|
7
8
|
const PROJECT_FILES = {
|
|
8
9
|
"package.json": `{
|
|
9
10
|
"name": "express-api",
|
|
10
11
|
"version": "0.1.0",
|
|
11
12
|
"private": true,
|
|
12
13
|
"scripts": {
|
|
13
|
-
"dev": "ts-node src/index.ts",
|
|
14
|
+
"dev": "nodemon --watch src --exec ts-node src/index.ts",
|
|
14
15
|
"build": "tsc",
|
|
15
|
-
"start": "node dist/index.js"
|
|
16
|
+
"start": "node dist/index.js",
|
|
17
|
+
"lint": "eslint src --ext .ts"
|
|
16
18
|
},
|
|
17
19
|
"dependencies": {
|
|
18
20
|
"body-parser": "^1.20.3",
|
|
@@ -26,6 +28,7 @@ const PROJECT_FILES = {
|
|
|
26
28
|
"@types/body-parser": "^1.19.5",
|
|
27
29
|
"@types/express": "^4.17.21",
|
|
28
30
|
"@types/node": "^22.5.0",
|
|
31
|
+
"nodemon": "^3.1.4",
|
|
29
32
|
"ts-node": "^10.9.2",
|
|
30
33
|
"typescript": "^5.5.4"
|
|
31
34
|
},
|
|
@@ -67,8 +70,10 @@ import "log-timestamp";
|
|
|
67
70
|
import { formatResponse } from "./middlewares/formatResponse";
|
|
68
71
|
import { logger } from "./middlewares/logger";
|
|
69
72
|
import { getAllowedIps } from "./utils/getAllowedIps";
|
|
73
|
+
import { validateEnv } from "./utils/env";
|
|
70
74
|
|
|
71
75
|
config.config();
|
|
76
|
+
validateEnv();
|
|
72
77
|
|
|
73
78
|
const app = express();
|
|
74
79
|
|
|
@@ -173,32 +178,95 @@ export function validate(schema: ZodSchema) {
|
|
|
173
178
|
"src/utils/getAllowedIps.ts": `export function getAllowedIps(raw: string): string[] {
|
|
174
179
|
return raw.split(",").map(ip => ip.trim()).filter(Boolean);
|
|
175
180
|
}
|
|
181
|
+
`,
|
|
182
|
+
"src/utils/env.ts": `import { z } from "zod";
|
|
183
|
+
|
|
184
|
+
const envSchema = z.object({
|
|
185
|
+
PORT: z.coerce.number().default(3000),
|
|
186
|
+
ALLOWED_IPS: z.string().optional(),
|
|
187
|
+
});
|
|
188
|
+
|
|
189
|
+
export function validateEnv() {
|
|
190
|
+
const parsed = envSchema.safeParse(process.env);
|
|
191
|
+
if (!parsed.success) {
|
|
192
|
+
throw new Error(parsed.error.message);
|
|
193
|
+
}
|
|
194
|
+
return parsed.data;
|
|
195
|
+
}
|
|
196
|
+
`,
|
|
197
|
+
};
|
|
198
|
+
const ESLINT_FILES = {
|
|
199
|
+
".eslintrc.json": `{
|
|
200
|
+
"env": { "es2022": true, "node": true },
|
|
201
|
+
"parser": "@typescript-eslint/parser",
|
|
202
|
+
"plugins": ["@typescript-eslint"],
|
|
203
|
+
"extends": ["eslint:recommended", "plugin:@typescript-eslint/recommended"],
|
|
204
|
+
"ignorePatterns": ["dist"]
|
|
205
|
+
}
|
|
176
206
|
`,
|
|
177
207
|
};
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
208
|
+
const DOCKER_FILES = {
|
|
209
|
+
Dockerfile: `FROM node:22-alpine
|
|
210
|
+
WORKDIR /app
|
|
211
|
+
COPY package*.json ./
|
|
212
|
+
RUN npm install
|
|
213
|
+
COPY . .
|
|
214
|
+
RUN npm run build
|
|
215
|
+
EXPOSE 3000
|
|
216
|
+
CMD ["npm", "start"]
|
|
217
|
+
`,
|
|
218
|
+
"docker-compose.yml": `services:
|
|
219
|
+
api:
|
|
220
|
+
build: .
|
|
221
|
+
ports:
|
|
222
|
+
- "3000:3000"
|
|
223
|
+
env_file:
|
|
224
|
+
- .env
|
|
225
|
+
`,
|
|
226
|
+
};
|
|
227
|
+
function renderPackageJson(projectName, options) {
|
|
228
|
+
let content = PROJECT_FILES["package.json"].replace('"name": "express-api"', `"name": "${projectName}"`);
|
|
229
|
+
if (options.withEslint) {
|
|
230
|
+
content = content.replace(`"typescript": "^5.5.4"\n }`, `"typescript": "^5.5.4",\n "@typescript-eslint/eslint-plugin": "^8.3.0",\n "@typescript-eslint/parser": "^8.3.0",\n "eslint": "^8.57.0"\n }`);
|
|
231
|
+
}
|
|
232
|
+
if (!options.withEslint) {
|
|
233
|
+
content = content.replace(` "lint": "eslint src --ext .ts"\n`, "");
|
|
234
|
+
}
|
|
235
|
+
return content;
|
|
181
236
|
}
|
|
182
|
-
function writeProjectFiles(targetDir, projectName) {
|
|
183
|
-
if ((0, fs_1.existsSync)((0, path_1.join)(targetDir, "package.json"))) {
|
|
237
|
+
function writeProjectFiles(targetDir, projectName, options) {
|
|
238
|
+
if ((0, fs_1.existsSync)((0, path_1.join)(targetDir, "package.json")) && !options.force) {
|
|
184
239
|
throw new Error(`Directory already contains package.json: ${targetDir}`);
|
|
185
240
|
}
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
(0,
|
|
190
|
-
(0,
|
|
191
|
-
(0, fs_1.mkdirSync)((0, path_1.join)(targetDir, "src", "utils"), { recursive: true });
|
|
192
|
-
(0, fs_1.mkdirSync)((0, path_1.join)(targetDir, "src", "types"), { recursive: true });
|
|
241
|
+
(0, io_1.ensureDir)(targetDir, options);
|
|
242
|
+
(0, io_1.ensureDir)((0, path_1.join)(targetDir, "src", "api"), options);
|
|
243
|
+
(0, io_1.ensureDir)((0, path_1.join)(targetDir, "src", "middlewares"), options);
|
|
244
|
+
(0, io_1.ensureDir)((0, path_1.join)(targetDir, "src", "utils"), options);
|
|
245
|
+
(0, io_1.ensureDir)((0, path_1.join)(targetDir, "src", "types"), options);
|
|
193
246
|
const written = [];
|
|
247
|
+
const io = { dryRun: options.dryRun, force: options.force };
|
|
194
248
|
for (const [relativePath, content] of Object.entries(PROJECT_FILES)) {
|
|
195
249
|
const filePath = (0, path_1.join)(targetDir, relativePath);
|
|
196
|
-
const fileContent = relativePath === "package.json" ? renderPackageJson(projectName) : content;
|
|
197
|
-
(0,
|
|
250
|
+
const fileContent = relativePath === "package.json" ? renderPackageJson(projectName, options) : content;
|
|
251
|
+
(0, io_1.writeTextFile)(filePath, fileContent, io);
|
|
198
252
|
written.push(filePath);
|
|
199
253
|
}
|
|
254
|
+
if (options.withEslint) {
|
|
255
|
+
for (const [relativePath, content] of Object.entries(ESLINT_FILES)) {
|
|
256
|
+
const filePath = (0, path_1.join)(targetDir, relativePath);
|
|
257
|
+
(0, io_1.writeTextFile)(filePath, content, io);
|
|
258
|
+
written.push(filePath);
|
|
259
|
+
}
|
|
260
|
+
}
|
|
261
|
+
if (options.withDocker) {
|
|
262
|
+
for (const [relativePath, content] of Object.entries(DOCKER_FILES)) {
|
|
263
|
+
const filePath = (0, path_1.join)(targetDir, relativePath);
|
|
264
|
+
(0, io_1.writeTextFile)(filePath, content, io);
|
|
265
|
+
written.push(filePath);
|
|
266
|
+
}
|
|
267
|
+
}
|
|
200
268
|
const configPath = (0, path_1.join)(targetDir, ".bogorc.json");
|
|
201
|
-
(0,
|
|
269
|
+
(0, io_1.writeTextFile)(configPath, (0, config_1.getDefaultConfigContent)(), io);
|
|
202
270
|
written.push(configPath);
|
|
203
271
|
return written;
|
|
204
272
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"project.js","sourceRoot":"","sources":["../../src/templates/project.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"project.js","sourceRoot":"","sources":["../../src/templates/project.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { MethodSpec, ModuleNames, ModuleTemplateContext } from "../interfaces";
|
|
2
|
+
export declare function renderControllerMethod(names: ModuleNames, method: MethodSpec): string;
|
|
3
|
+
export declare function renderServiceMethod(names: ModuleNames, method: MethodSpec): string;
|
|
4
|
+
export declare function renderDtoBlock(method: MethodSpec): string;
|
|
5
|
+
export declare function renderValidatorBlock(method: MethodSpec): string;
|
|
6
|
+
export declare function renderRouteLine(method: MethodSpec, middleware: string[]): string;
|
|
7
|
+
export declare function renderMiddlewareImports(middleware: string[]): string;
|
|
8
|
+
export declare function applyTemplate(template: string, ctx: ModuleTemplateContext, part: string): string;
|
|
9
|
+
//# sourceMappingURL=render-helpers.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"render-helpers.d.ts","sourceRoot":"","sources":["../../src/templates/render-helpers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,qBAAqB,EAAE,MAAM,eAAe,CAAC;AAI/E,wBAAgB,sBAAsB,CAAC,KAAK,EAAE,WAAW,EAAE,MAAM,EAAE,UAAU,GAAG,MAAM,CAcrF;AAED,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,WAAW,EAAE,MAAM,EAAE,UAAU,GAAG,MAAM,CAKlF;AAED,wBAAgB,cAAc,CAAC,MAAM,EAAE,UAAU,GAAG,MAAM,CAOzD;AAED,wBAAgB,oBAAoB,CAAC,MAAM,EAAE,UAAU,GAAG,MAAM,CAO/D;AAED,wBAAgB,eAAe,CAAC,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,EAAE,GAAG,MAAM,CAIhF;AAED,wBAAgB,uBAAuB,CAAC,UAAU,EAAE,MAAM,EAAE,GAAG,MAAM,CAMpE;AAED,wBAAgB,aAAa,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,EAAE,qBAAqB,EAAE,IAAI,EAAE,MAAM,GAAG,MAAM,CAmBhG"}
|