@tsed/cli-generate-http-client 3.22.5 → 3.24.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/lib/cjs/commands/GenerateHttpClientCmd.js +37 -21
- package/lib/cjs/commands/GenerateHttpClientCmd.js.map +1 -1
- package/lib/esm/commands/GenerateHttpClientCmd.js +37 -21
- package/lib/esm/commands/GenerateHttpClientCmd.js.map +1 -1
- package/lib/types/commands/GenerateHttpClientCmd.d.ts +9 -2
- package/package.json +3 -3
- package/readme.md +12 -4
|
@@ -12,6 +12,7 @@ let GenerateHttpClientCmd = class GenerateHttpClientCmd {
|
|
|
12
12
|
injector;
|
|
13
13
|
fs;
|
|
14
14
|
serverModule;
|
|
15
|
+
options;
|
|
15
16
|
$mapContext($ctx) {
|
|
16
17
|
return { ...$ctx, output: (0, path_1.resolve)((0, path_1.join)(process.cwd(), $ctx.output)) };
|
|
17
18
|
}
|
|
@@ -37,18 +38,22 @@ let GenerateHttpClientCmd = class GenerateHttpClientCmd {
|
|
|
37
38
|
async generate($ctx) {
|
|
38
39
|
const Platform = await this.loadPlatformModule();
|
|
39
40
|
const { SwaggerService } = await (0, core_1.importPackage)("@tsed/swagger");
|
|
40
|
-
const platform = await Platform.bootstrap(this.serverModule, {
|
|
41
|
+
const platform = await Platform.bootstrap(this.serverModule, {
|
|
42
|
+
logger: { level: "off" }
|
|
43
|
+
});
|
|
41
44
|
const swaggerService = platform.injector.get(SwaggerService);
|
|
42
45
|
const confs = platform.injector.settings.get("swagger", []);
|
|
43
46
|
await this.fs.raw.remove($ctx.output);
|
|
44
47
|
await this.fs.ensureDir($ctx.output);
|
|
45
48
|
const promises = confs.map(async (conf) => {
|
|
46
49
|
const spec = await swaggerService.getOpenAPISpec(conf);
|
|
47
|
-
await this.generateFromSpec(spec, $ctx);
|
|
50
|
+
await this.generateFromSpec(spec, conf, $ctx);
|
|
48
51
|
});
|
|
49
52
|
await Promise.all(promises);
|
|
53
|
+
await platform.stop();
|
|
50
54
|
}
|
|
51
|
-
async generateFromSpec(spec, $ctx) {
|
|
55
|
+
async generateFromSpec(spec, conf, $ctx) {
|
|
56
|
+
const operationIdMode = conf.operationId === "%c_%m" ? "underscore" : "default";
|
|
52
57
|
const { files } = await (0, swagger_typescript_api_1.generateApi)({
|
|
53
58
|
name: `${$ctx.name}.ts`,
|
|
54
59
|
httpClientType: $ctx.type,
|
|
@@ -57,24 +62,9 @@ let GenerateHttpClientCmd = class GenerateHttpClientCmd {
|
|
|
57
62
|
typeSuffix: $ctx.suffix,
|
|
58
63
|
unwrapResponseData: true,
|
|
59
64
|
hooks: {
|
|
60
|
-
onCreateRouteName(routeNameInfo,
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
routeNameInfo.usage = name;
|
|
64
|
-
routeNameInfo.original = name;
|
|
65
|
-
raw.operationId = name;
|
|
66
|
-
return routeNameInfo;
|
|
67
|
-
},
|
|
68
|
-
onParseSchema(originalSchema, parsedSchema) {
|
|
69
|
-
const { content } = parsedSchema;
|
|
70
|
-
if ((0, core_1.isString)(content)) {
|
|
71
|
-
if (content.includes("null") && content.includes("any") && content.includes("Record")) {
|
|
72
|
-
parsedSchema.content = "any";
|
|
73
|
-
}
|
|
74
|
-
parsedSchema.content = parsedSchema.content.replace("object", "Record<string, any>");
|
|
75
|
-
}
|
|
76
|
-
return parsedSchema;
|
|
77
|
-
}
|
|
65
|
+
onCreateRouteName: (routeNameInfo, rawRouteInfo) => this.createRouteName(routeNameInfo, rawRouteInfo, operationIdMode),
|
|
66
|
+
onParseSchema: this.onParseSchema.bind(this),
|
|
67
|
+
...this.options.hooks
|
|
78
68
|
}
|
|
79
69
|
});
|
|
80
70
|
const promises = files.map(({ content, name }) => {
|
|
@@ -90,6 +80,28 @@ let GenerateHttpClientCmd = class GenerateHttpClientCmd {
|
|
|
90
80
|
});
|
|
91
81
|
return Promise.all(promises);
|
|
92
82
|
}
|
|
83
|
+
onParseSchema(originalSchema, parsedSchema) {
|
|
84
|
+
const { content } = parsedSchema;
|
|
85
|
+
if ((0, core_1.isString)(content)) {
|
|
86
|
+
if (content.includes("null") && content.includes("any") && content.includes("Record")) {
|
|
87
|
+
parsedSchema.content = "any";
|
|
88
|
+
}
|
|
89
|
+
parsedSchema.content = parsedSchema.content.replace("object", "Record<string, any>");
|
|
90
|
+
}
|
|
91
|
+
return parsedSchema;
|
|
92
|
+
}
|
|
93
|
+
createRouteName(routeNameInfo, raw, mode = "default") {
|
|
94
|
+
let operationId = "";
|
|
95
|
+
if (mode === "underscore") {
|
|
96
|
+
operationId = raw.operationId.split("_")[1];
|
|
97
|
+
}
|
|
98
|
+
operationId = operationId || raw.operationId.replace(raw.moduleName, "");
|
|
99
|
+
const name = (0, change_case_1.camelCase)(this.options.transformOperationId ? this.options.transformOperationId(operationId, routeNameInfo, raw) : operationId);
|
|
100
|
+
routeNameInfo.usage = name;
|
|
101
|
+
routeNameInfo.original = name;
|
|
102
|
+
raw.operationId = name;
|
|
103
|
+
return routeNameInfo;
|
|
104
|
+
}
|
|
93
105
|
};
|
|
94
106
|
tslib_1.__decorate([
|
|
95
107
|
(0, cli_core_1.Inject)(),
|
|
@@ -103,6 +115,10 @@ tslib_1.__decorate([
|
|
|
103
115
|
(0, di_1.Constant)("server"),
|
|
104
116
|
tslib_1.__metadata("design:type", cli_core_1.Type)
|
|
105
117
|
], GenerateHttpClientCmd.prototype, "serverModule", void 0);
|
|
118
|
+
tslib_1.__decorate([
|
|
119
|
+
(0, di_1.Constant)("httpClient", { hooks: {} }),
|
|
120
|
+
tslib_1.__metadata("design:type", Object)
|
|
121
|
+
], GenerateHttpClientCmd.prototype, "options", void 0);
|
|
106
122
|
GenerateHttpClientCmd = tslib_1.__decorate([
|
|
107
123
|
(0, cli_core_1.Command)({
|
|
108
124
|
name: "generate-http-client",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"GenerateHttpClientCmd.js","sourceRoot":"","sources":["../../../src/commands/GenerateHttpClientCmd.ts"],"names":[],"mappings":"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","sourcesContent":["import {CliFs, Command, CommandProvider, Inject, Type} from \"@tsed/cli-core\";\nimport {Constant, InjectorService} from \"@tsed/di\";\nimport {importPackage, isString} from \"@tsed/core\";\nimport {camelCase} from \"change-case\";\nimport path, {join, resolve} from \"path\";\nimport {generateApi} from \"swagger-typescript-api\";\n\ninterface GenerateHttpClientCtx {\n output: string;\n type: \"axios\" | \"fetch\";\n name: string;\n suffix: string;\n}\n\n@Command({\n name: \"generate-http-client\",\n description: \"Generate the client API from swagger spec\",\n options: {\n \"-s, --suffix <suffix>\": {\n required: false,\n type: String,\n defaultValue: \"Model\",\n description: \"The suffix applied on model\"\n },\n \"-t, --type <type>\": {\n required: false,\n type: String,\n defaultValue: \"axios\",\n description: \"The client type by the Http client (axios or fetch)\"\n },\n \"-n, --name <name>\": {\n required: false,\n type: String,\n defaultValue: \"ApiClient\",\n description: \"The class name of the generated client\"\n },\n \"-o, --output <output>\": {\n required: true,\n type: String,\n description: \"Path to generate files\"\n }\n }\n})\nexport class GenerateHttpClientCmd implements CommandProvider {\n @Inject()\n injector: InjectorService;\n\n @Inject()\n protected fs: CliFs;\n\n @Constant(\"server\")\n protected serverModule: Type<any>;\n\n $mapContext($ctx: GenerateHttpClientCtx) {\n return {...$ctx, output: resolve(join(process.cwd(), $ctx.output))};\n }\n\n async $exec($ctx: GenerateHttpClientCtx) {\n return [\n {\n title: \"generate client\",\n task: () => this.generate($ctx)\n }\n ];\n }\n\n private async loadPlatformModule(): Promise<any> {\n let platform = await importPackage(\"@tsed/platform-express\", undefined, true);\n\n if (platform) {\n return platform.PlatformExpress;\n }\n\n platform = await importPackage(\"@tsed/platform-koa\", undefined, true);\n\n if (platform) {\n return platform.PlatformKoa;\n }\n\n throw new Error(\"Unsupported platform. Please use Express.js or Koa.js platform.\");\n }\n\n private async generate($ctx: GenerateHttpClientCtx) {\n const Platform = await this.loadPlatformModule();\n const {SwaggerService} = await importPackage(\"@tsed/swagger\");\n\n const platform: {injector: InjectorService} = await Platform.bootstrap(this.serverModule, {logger: {level: \"off\"}});\n const swaggerService = platform.injector.get<any>(SwaggerService)!;\n const confs = platform.injector.settings.get(\"swagger\", []);\n\n await this.fs.raw.remove($ctx.output);\n await this.fs.ensureDir($ctx.output);\n\n const promises = confs.map(async (conf) => {\n const spec = await swaggerService.getOpenAPISpec(conf);\n\n await this.generateFromSpec(spec, $ctx);\n });\n\n await Promise.all(promises);\n }\n\n private async generateFromSpec(spec: any, $ctx: GenerateHttpClientCtx) {\n const {files} = await generateApi({\n name: `${$ctx.name}.ts`,\n httpClientType: $ctx.type,\n spec: spec as any,\n moduleNameIndex: 1,\n typeSuffix: $ctx.suffix,\n unwrapResponseData: true,\n hooks: {\n onCreateRouteName(routeNameInfo: any, raw: any) {\n const [, operationId] = raw.operationId.split(\"_\");\n\n const name = raw.moduleName === \"oidc\" ? camelCase(routeNameInfo.original.replace(\"oidc\", \"\")) : camelCase(operationId);\n\n routeNameInfo.usage = name;\n routeNameInfo.original = name;\n raw.operationId = name;\n\n return routeNameInfo;\n },\n onParseSchema(originalSchema: any, parsedSchema: any) {\n const {content} = parsedSchema;\n\n if (isString(content)) {\n if (content.includes(\"null\") && content.includes(\"any\") && content.includes(\"Record\")) {\n parsedSchema.content = \"any\";\n }\n\n parsedSchema.content = parsedSchema.content.replace(\"object\", \"Record<string, any>\");\n }\n\n return parsedSchema;\n }\n }\n } as any);\n\n const promises = files.map(({content, name}) => {\n content = content\n .replace(\"class Api\", `class ${$ctx.name}`)\n .replace(\".then((response) => response.data)\", \".then((response) => response.data as T)\")\n .replace('requestParams.headers.common = { Accept: \"*/*\" };', \"\")\n .replace(\"requestParams.headers.post = {};\", \"\")\n .replace(\"requestParams.headers.put = {};\", \"\")\n .replace(\"(this.instance.defaults.headers || {})\", \"((this.instance.defaults.headers || {}) as any)\");\n\n console.log(`${$ctx.output}/${name}`, path.resolve(`${$ctx.output}/${name}`));\n return this.fs.writeFile(`${$ctx.output}/${name}`, content, {encoding: \"utf8\"});\n });\n\n return Promise.all(promises);\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"GenerateHttpClientCmd.js","sourceRoot":"","sources":["../../../src/commands/GenerateHttpClientCmd.ts"],"names":[],"mappings":"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","sourcesContent":["import {CliFs, Command, CommandProvider, Inject, Type} from \"@tsed/cli-core\";\nimport {Constant, InjectorService} from \"@tsed/di\";\nimport {importPackage, isString} from \"@tsed/core\";\nimport {camelCase} from \"change-case\";\nimport path, {join, resolve} from \"path\";\nimport {generateApi, Hooks, RawRouteInfo, RouteNameInfo} from \"swagger-typescript-api\";\n\nexport interface GenerateHttpClientCtx {\n output: string;\n type: \"axios\" | \"fetch\";\n name: string;\n suffix: string;\n}\n\nexport interface GenerateHttpClientOpts {\n hooks?: Partial<Hooks>;\n\n transformOperationId?(operationId: string, routeNameInfo: RouteNameInfo, raw: RawRouteInfo): string;\n}\n\n@Command({\n name: \"generate-http-client\",\n description: \"Generate the client API from swagger spec\",\n options: {\n \"-s, --suffix <suffix>\": {\n required: false,\n type: String,\n defaultValue: \"Model\",\n description: \"The suffix applied on model\"\n },\n \"-t, --type <type>\": {\n required: false,\n type: String,\n defaultValue: \"axios\",\n description: \"The client type by the Http client (axios or fetch)\"\n },\n \"-n, --name <name>\": {\n required: false,\n type: String,\n defaultValue: \"ApiClient\",\n description: \"The class name of the generated client\"\n },\n \"-o, --output <output>\": {\n required: true,\n type: String,\n description: \"Path to generate files\"\n }\n }\n})\nexport class GenerateHttpClientCmd implements CommandProvider {\n @Inject()\n injector: InjectorService;\n\n @Inject()\n protected fs: CliFs;\n\n @Constant(\"server\")\n protected serverModule: Type<any>;\n\n @Constant(\"httpClient\", {hooks: {}})\n protected options: Partial<GenerateHttpClientOpts>;\n\n $mapContext($ctx: GenerateHttpClientCtx) {\n return {...$ctx, output: resolve(join(process.cwd(), $ctx.output))};\n }\n\n async $exec($ctx: GenerateHttpClientCtx) {\n return [\n {\n title: \"generate client\",\n task: () => this.generate($ctx)\n }\n ];\n }\n\n private async loadPlatformModule(): Promise<any> {\n let platform = await importPackage(\"@tsed/platform-express\", undefined, true);\n\n if (platform) {\n return platform.PlatformExpress;\n }\n\n platform = await importPackage(\"@tsed/platform-koa\", undefined, true);\n\n if (platform) {\n return platform.PlatformKoa;\n }\n\n throw new Error(\"Unsupported platform. Please use Express.js or Koa.js platform.\");\n }\n\n private async generate($ctx: GenerateHttpClientCtx) {\n const Platform = await this.loadPlatformModule();\n const {SwaggerService} = await importPackage(\"@tsed/swagger\");\n\n const platform: {injector: InjectorService; stop: () => Promise<any>} = await Platform.bootstrap(this.serverModule, {\n logger: {level: \"off\"}\n });\n const swaggerService = platform.injector.get<any>(SwaggerService)!;\n const confs = platform.injector.settings.get(\"swagger\", []);\n\n await this.fs.raw.remove($ctx.output);\n await this.fs.ensureDir($ctx.output);\n\n const promises = confs.map(async (conf) => {\n const spec = await swaggerService.getOpenAPISpec(conf);\n\n await this.generateFromSpec(spec, conf, $ctx);\n });\n\n await Promise.all(promises);\n\n await platform.stop();\n }\n\n private async generateFromSpec(spec: any, conf: any, $ctx: GenerateHttpClientCtx) {\n const operationIdMode = conf.operationId === \"%c_%m\" ? \"underscore\" : \"default\";\n\n const {files} = await generateApi({\n name: `${$ctx.name}.ts`,\n httpClientType: $ctx.type,\n spec: spec as any,\n moduleNameIndex: 1,\n typeSuffix: $ctx.suffix,\n unwrapResponseData: true,\n hooks: {\n onCreateRouteName: (routeNameInfo: RouteNameInfo, rawRouteInfo: RawRouteInfo) =>\n this.createRouteName(routeNameInfo, rawRouteInfo, operationIdMode),\n onParseSchema: this.onParseSchema.bind(this),\n ...this.options.hooks\n }\n } as any);\n\n const promises = files.map(({content, name}) => {\n content = content\n .replace(\"class Api\", `class ${$ctx.name}`)\n .replace(\".then((response) => response.data)\", \".then((response) => response.data as T)\")\n .replace('requestParams.headers.common = { Accept: \"*/*\" };', \"\")\n .replace(\"requestParams.headers.post = {};\", \"\")\n .replace(\"requestParams.headers.put = {};\", \"\")\n .replace(\"(this.instance.defaults.headers || {})\", \"((this.instance.defaults.headers || {}) as any)\");\n\n console.log(`${$ctx.output}/${name}`, path.resolve(`${$ctx.output}/${name}`));\n return this.fs.writeFile(`${$ctx.output}/${name}`, content, {encoding: \"utf8\"});\n });\n\n return Promise.all(promises);\n }\n\n private onParseSchema(originalSchema: any, parsedSchema: any) {\n const {content} = parsedSchema;\n\n if (isString(content)) {\n if (content.includes(\"null\") && content.includes(\"any\") && content.includes(\"Record\")) {\n parsedSchema.content = \"any\";\n }\n\n parsedSchema.content = parsedSchema.content.replace(\"object\", \"Record<string, any>\");\n }\n\n return parsedSchema;\n }\n\n private createRouteName(routeNameInfo: RouteNameInfo, raw: RawRouteInfo, mode: \"default\" | \"underscore\" = \"default\") {\n let operationId = \"\";\n\n if (mode === \"underscore\") {\n operationId = raw.operationId.split(\"_\")[1];\n }\n\n operationId = operationId || raw.operationId.replace(raw.moduleName, \"\");\n\n const name = camelCase(\n this.options.transformOperationId ? this.options.transformOperationId(operationId, routeNameInfo, raw) : operationId\n );\n\n routeNameInfo.usage = name;\n routeNameInfo.original = name;\n raw.operationId = name;\n\n return routeNameInfo;\n }\n}\n"]}
|
|
@@ -9,6 +9,7 @@ let GenerateHttpClientCmd = class GenerateHttpClientCmd {
|
|
|
9
9
|
injector;
|
|
10
10
|
fs;
|
|
11
11
|
serverModule;
|
|
12
|
+
options;
|
|
12
13
|
$mapContext($ctx) {
|
|
13
14
|
return { ...$ctx, output: resolve(join(process.cwd(), $ctx.output)) };
|
|
14
15
|
}
|
|
@@ -34,18 +35,22 @@ let GenerateHttpClientCmd = class GenerateHttpClientCmd {
|
|
|
34
35
|
async generate($ctx) {
|
|
35
36
|
const Platform = await this.loadPlatformModule();
|
|
36
37
|
const { SwaggerService } = await importPackage("@tsed/swagger");
|
|
37
|
-
const platform = await Platform.bootstrap(this.serverModule, {
|
|
38
|
+
const platform = await Platform.bootstrap(this.serverModule, {
|
|
39
|
+
logger: { level: "off" }
|
|
40
|
+
});
|
|
38
41
|
const swaggerService = platform.injector.get(SwaggerService);
|
|
39
42
|
const confs = platform.injector.settings.get("swagger", []);
|
|
40
43
|
await this.fs.raw.remove($ctx.output);
|
|
41
44
|
await this.fs.ensureDir($ctx.output);
|
|
42
45
|
const promises = confs.map(async (conf) => {
|
|
43
46
|
const spec = await swaggerService.getOpenAPISpec(conf);
|
|
44
|
-
await this.generateFromSpec(spec, $ctx);
|
|
47
|
+
await this.generateFromSpec(spec, conf, $ctx);
|
|
45
48
|
});
|
|
46
49
|
await Promise.all(promises);
|
|
50
|
+
await platform.stop();
|
|
47
51
|
}
|
|
48
|
-
async generateFromSpec(spec, $ctx) {
|
|
52
|
+
async generateFromSpec(spec, conf, $ctx) {
|
|
53
|
+
const operationIdMode = conf.operationId === "%c_%m" ? "underscore" : "default";
|
|
49
54
|
const { files } = await generateApi({
|
|
50
55
|
name: `${$ctx.name}.ts`,
|
|
51
56
|
httpClientType: $ctx.type,
|
|
@@ -54,24 +59,9 @@ let GenerateHttpClientCmd = class GenerateHttpClientCmd {
|
|
|
54
59
|
typeSuffix: $ctx.suffix,
|
|
55
60
|
unwrapResponseData: true,
|
|
56
61
|
hooks: {
|
|
57
|
-
onCreateRouteName(routeNameInfo,
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
routeNameInfo.usage = name;
|
|
61
|
-
routeNameInfo.original = name;
|
|
62
|
-
raw.operationId = name;
|
|
63
|
-
return routeNameInfo;
|
|
64
|
-
},
|
|
65
|
-
onParseSchema(originalSchema, parsedSchema) {
|
|
66
|
-
const { content } = parsedSchema;
|
|
67
|
-
if (isString(content)) {
|
|
68
|
-
if (content.includes("null") && content.includes("any") && content.includes("Record")) {
|
|
69
|
-
parsedSchema.content = "any";
|
|
70
|
-
}
|
|
71
|
-
parsedSchema.content = parsedSchema.content.replace("object", "Record<string, any>");
|
|
72
|
-
}
|
|
73
|
-
return parsedSchema;
|
|
74
|
-
}
|
|
62
|
+
onCreateRouteName: (routeNameInfo, rawRouteInfo) => this.createRouteName(routeNameInfo, rawRouteInfo, operationIdMode),
|
|
63
|
+
onParseSchema: this.onParseSchema.bind(this),
|
|
64
|
+
...this.options.hooks
|
|
75
65
|
}
|
|
76
66
|
});
|
|
77
67
|
const promises = files.map(({ content, name }) => {
|
|
@@ -87,6 +77,28 @@ let GenerateHttpClientCmd = class GenerateHttpClientCmd {
|
|
|
87
77
|
});
|
|
88
78
|
return Promise.all(promises);
|
|
89
79
|
}
|
|
80
|
+
onParseSchema(originalSchema, parsedSchema) {
|
|
81
|
+
const { content } = parsedSchema;
|
|
82
|
+
if (isString(content)) {
|
|
83
|
+
if (content.includes("null") && content.includes("any") && content.includes("Record")) {
|
|
84
|
+
parsedSchema.content = "any";
|
|
85
|
+
}
|
|
86
|
+
parsedSchema.content = parsedSchema.content.replace("object", "Record<string, any>");
|
|
87
|
+
}
|
|
88
|
+
return parsedSchema;
|
|
89
|
+
}
|
|
90
|
+
createRouteName(routeNameInfo, raw, mode = "default") {
|
|
91
|
+
let operationId = "";
|
|
92
|
+
if (mode === "underscore") {
|
|
93
|
+
operationId = raw.operationId.split("_")[1];
|
|
94
|
+
}
|
|
95
|
+
operationId = operationId || raw.operationId.replace(raw.moduleName, "");
|
|
96
|
+
const name = camelCase(this.options.transformOperationId ? this.options.transformOperationId(operationId, routeNameInfo, raw) : operationId);
|
|
97
|
+
routeNameInfo.usage = name;
|
|
98
|
+
routeNameInfo.original = name;
|
|
99
|
+
raw.operationId = name;
|
|
100
|
+
return routeNameInfo;
|
|
101
|
+
}
|
|
90
102
|
};
|
|
91
103
|
__decorate([
|
|
92
104
|
Inject(),
|
|
@@ -100,6 +112,10 @@ __decorate([
|
|
|
100
112
|
Constant("server"),
|
|
101
113
|
__metadata("design:type", Type)
|
|
102
114
|
], GenerateHttpClientCmd.prototype, "serverModule", void 0);
|
|
115
|
+
__decorate([
|
|
116
|
+
Constant("httpClient", { hooks: {} }),
|
|
117
|
+
__metadata("design:type", Object)
|
|
118
|
+
], GenerateHttpClientCmd.prototype, "options", void 0);
|
|
103
119
|
GenerateHttpClientCmd = __decorate([
|
|
104
120
|
Command({
|
|
105
121
|
name: "generate-http-client",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"GenerateHttpClientCmd.js","sourceRoot":"","sources":["../../../src/commands/GenerateHttpClientCmd.ts"],"names":[],"mappings":"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","sourcesContent":["import {CliFs, Command, CommandProvider, Inject, Type} from \"@tsed/cli-core\";\nimport {Constant, InjectorService} from \"@tsed/di\";\nimport {importPackage, isString} from \"@tsed/core\";\nimport {camelCase} from \"change-case\";\nimport path, {join, resolve} from \"path\";\nimport {generateApi} from \"swagger-typescript-api\";\n\ninterface GenerateHttpClientCtx {\n output: string;\n type: \"axios\" | \"fetch\";\n name: string;\n suffix: string;\n}\n\n@Command({\n name: \"generate-http-client\",\n description: \"Generate the client API from swagger spec\",\n options: {\n \"-s, --suffix <suffix>\": {\n required: false,\n type: String,\n defaultValue: \"Model\",\n description: \"The suffix applied on model\"\n },\n \"-t, --type <type>\": {\n required: false,\n type: String,\n defaultValue: \"axios\",\n description: \"The client type by the Http client (axios or fetch)\"\n },\n \"-n, --name <name>\": {\n required: false,\n type: String,\n defaultValue: \"ApiClient\",\n description: \"The class name of the generated client\"\n },\n \"-o, --output <output>\": {\n required: true,\n type: String,\n description: \"Path to generate files\"\n }\n }\n})\nexport class GenerateHttpClientCmd implements CommandProvider {\n @Inject()\n injector: InjectorService;\n\n @Inject()\n protected fs: CliFs;\n\n @Constant(\"server\")\n protected serverModule: Type<any>;\n\n $mapContext($ctx: GenerateHttpClientCtx) {\n return {...$ctx, output: resolve(join(process.cwd(), $ctx.output))};\n }\n\n async $exec($ctx: GenerateHttpClientCtx) {\n return [\n {\n title: \"generate client\",\n task: () => this.generate($ctx)\n }\n ];\n }\n\n private async loadPlatformModule(): Promise<any> {\n let platform = await importPackage(\"@tsed/platform-express\", undefined, true);\n\n if (platform) {\n return platform.PlatformExpress;\n }\n\n platform = await importPackage(\"@tsed/platform-koa\", undefined, true);\n\n if (platform) {\n return platform.PlatformKoa;\n }\n\n throw new Error(\"Unsupported platform. Please use Express.js or Koa.js platform.\");\n }\n\n private async generate($ctx: GenerateHttpClientCtx) {\n const Platform = await this.loadPlatformModule();\n const {SwaggerService} = await importPackage(\"@tsed/swagger\");\n\n const platform: {injector: InjectorService} = await Platform.bootstrap(this.serverModule, {logger: {level: \"off\"}});\n const swaggerService = platform.injector.get<any>(SwaggerService)!;\n const confs = platform.injector.settings.get(\"swagger\", []);\n\n await this.fs.raw.remove($ctx.output);\n await this.fs.ensureDir($ctx.output);\n\n const promises = confs.map(async (conf) => {\n const spec = await swaggerService.getOpenAPISpec(conf);\n\n await this.generateFromSpec(spec, $ctx);\n });\n\n await Promise.all(promises);\n }\n\n private async generateFromSpec(spec: any, $ctx: GenerateHttpClientCtx) {\n const {files} = await generateApi({\n name: `${$ctx.name}.ts`,\n httpClientType: $ctx.type,\n spec: spec as any,\n moduleNameIndex: 1,\n typeSuffix: $ctx.suffix,\n unwrapResponseData: true,\n hooks: {\n onCreateRouteName(routeNameInfo: any, raw: any) {\n const [, operationId] = raw.operationId.split(\"_\");\n\n const name = raw.moduleName === \"oidc\" ? camelCase(routeNameInfo.original.replace(\"oidc\", \"\")) : camelCase(operationId);\n\n routeNameInfo.usage = name;\n routeNameInfo.original = name;\n raw.operationId = name;\n\n return routeNameInfo;\n },\n onParseSchema(originalSchema: any, parsedSchema: any) {\n const {content} = parsedSchema;\n\n if (isString(content)) {\n if (content.includes(\"null\") && content.includes(\"any\") && content.includes(\"Record\")) {\n parsedSchema.content = \"any\";\n }\n\n parsedSchema.content = parsedSchema.content.replace(\"object\", \"Record<string, any>\");\n }\n\n return parsedSchema;\n }\n }\n } as any);\n\n const promises = files.map(({content, name}) => {\n content = content\n .replace(\"class Api\", `class ${$ctx.name}`)\n .replace(\".then((response) => response.data)\", \".then((response) => response.data as T)\")\n .replace('requestParams.headers.common = { Accept: \"*/*\" };', \"\")\n .replace(\"requestParams.headers.post = {};\", \"\")\n .replace(\"requestParams.headers.put = {};\", \"\")\n .replace(\"(this.instance.defaults.headers || {})\", \"((this.instance.defaults.headers || {}) as any)\");\n\n console.log(`${$ctx.output}/${name}`, path.resolve(`${$ctx.output}/${name}`));\n return this.fs.writeFile(`${$ctx.output}/${name}`, content, {encoding: \"utf8\"});\n });\n\n return Promise.all(promises);\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"GenerateHttpClientCmd.js","sourceRoot":"","sources":["../../../src/commands/GenerateHttpClientCmd.ts"],"names":[],"mappings":"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","sourcesContent":["import {CliFs, Command, CommandProvider, Inject, Type} from \"@tsed/cli-core\";\nimport {Constant, InjectorService} from \"@tsed/di\";\nimport {importPackage, isString} from \"@tsed/core\";\nimport {camelCase} from \"change-case\";\nimport path, {join, resolve} from \"path\";\nimport {generateApi, Hooks, RawRouteInfo, RouteNameInfo} from \"swagger-typescript-api\";\n\nexport interface GenerateHttpClientCtx {\n output: string;\n type: \"axios\" | \"fetch\";\n name: string;\n suffix: string;\n}\n\nexport interface GenerateHttpClientOpts {\n hooks?: Partial<Hooks>;\n\n transformOperationId?(operationId: string, routeNameInfo: RouteNameInfo, raw: RawRouteInfo): string;\n}\n\n@Command({\n name: \"generate-http-client\",\n description: \"Generate the client API from swagger spec\",\n options: {\n \"-s, --suffix <suffix>\": {\n required: false,\n type: String,\n defaultValue: \"Model\",\n description: \"The suffix applied on model\"\n },\n \"-t, --type <type>\": {\n required: false,\n type: String,\n defaultValue: \"axios\",\n description: \"The client type by the Http client (axios or fetch)\"\n },\n \"-n, --name <name>\": {\n required: false,\n type: String,\n defaultValue: \"ApiClient\",\n description: \"The class name of the generated client\"\n },\n \"-o, --output <output>\": {\n required: true,\n type: String,\n description: \"Path to generate files\"\n }\n }\n})\nexport class GenerateHttpClientCmd implements CommandProvider {\n @Inject()\n injector: InjectorService;\n\n @Inject()\n protected fs: CliFs;\n\n @Constant(\"server\")\n protected serverModule: Type<any>;\n\n @Constant(\"httpClient\", {hooks: {}})\n protected options: Partial<GenerateHttpClientOpts>;\n\n $mapContext($ctx: GenerateHttpClientCtx) {\n return {...$ctx, output: resolve(join(process.cwd(), $ctx.output))};\n }\n\n async $exec($ctx: GenerateHttpClientCtx) {\n return [\n {\n title: \"generate client\",\n task: () => this.generate($ctx)\n }\n ];\n }\n\n private async loadPlatformModule(): Promise<any> {\n let platform = await importPackage(\"@tsed/platform-express\", undefined, true);\n\n if (platform) {\n return platform.PlatformExpress;\n }\n\n platform = await importPackage(\"@tsed/platform-koa\", undefined, true);\n\n if (platform) {\n return platform.PlatformKoa;\n }\n\n throw new Error(\"Unsupported platform. Please use Express.js or Koa.js platform.\");\n }\n\n private async generate($ctx: GenerateHttpClientCtx) {\n const Platform = await this.loadPlatformModule();\n const {SwaggerService} = await importPackage(\"@tsed/swagger\");\n\n const platform: {injector: InjectorService; stop: () => Promise<any>} = await Platform.bootstrap(this.serverModule, {\n logger: {level: \"off\"}\n });\n const swaggerService = platform.injector.get<any>(SwaggerService)!;\n const confs = platform.injector.settings.get(\"swagger\", []);\n\n await this.fs.raw.remove($ctx.output);\n await this.fs.ensureDir($ctx.output);\n\n const promises = confs.map(async (conf) => {\n const spec = await swaggerService.getOpenAPISpec(conf);\n\n await this.generateFromSpec(spec, conf, $ctx);\n });\n\n await Promise.all(promises);\n\n await platform.stop();\n }\n\n private async generateFromSpec(spec: any, conf: any, $ctx: GenerateHttpClientCtx) {\n const operationIdMode = conf.operationId === \"%c_%m\" ? \"underscore\" : \"default\";\n\n const {files} = await generateApi({\n name: `${$ctx.name}.ts`,\n httpClientType: $ctx.type,\n spec: spec as any,\n moduleNameIndex: 1,\n typeSuffix: $ctx.suffix,\n unwrapResponseData: true,\n hooks: {\n onCreateRouteName: (routeNameInfo: RouteNameInfo, rawRouteInfo: RawRouteInfo) =>\n this.createRouteName(routeNameInfo, rawRouteInfo, operationIdMode),\n onParseSchema: this.onParseSchema.bind(this),\n ...this.options.hooks\n }\n } as any);\n\n const promises = files.map(({content, name}) => {\n content = content\n .replace(\"class Api\", `class ${$ctx.name}`)\n .replace(\".then((response) => response.data)\", \".then((response) => response.data as T)\")\n .replace('requestParams.headers.common = { Accept: \"*/*\" };', \"\")\n .replace(\"requestParams.headers.post = {};\", \"\")\n .replace(\"requestParams.headers.put = {};\", \"\")\n .replace(\"(this.instance.defaults.headers || {})\", \"((this.instance.defaults.headers || {}) as any)\");\n\n console.log(`${$ctx.output}/${name}`, path.resolve(`${$ctx.output}/${name}`));\n return this.fs.writeFile(`${$ctx.output}/${name}`, content, {encoding: \"utf8\"});\n });\n\n return Promise.all(promises);\n }\n\n private onParseSchema(originalSchema: any, parsedSchema: any) {\n const {content} = parsedSchema;\n\n if (isString(content)) {\n if (content.includes(\"null\") && content.includes(\"any\") && content.includes(\"Record\")) {\n parsedSchema.content = \"any\";\n }\n\n parsedSchema.content = parsedSchema.content.replace(\"object\", \"Record<string, any>\");\n }\n\n return parsedSchema;\n }\n\n private createRouteName(routeNameInfo: RouteNameInfo, raw: RawRouteInfo, mode: \"default\" | \"underscore\" = \"default\") {\n let operationId = \"\";\n\n if (mode === \"underscore\") {\n operationId = raw.operationId.split(\"_\")[1];\n }\n\n operationId = operationId || raw.operationId.replace(raw.moduleName, \"\");\n\n const name = camelCase(\n this.options.transformOperationId ? this.options.transformOperationId(operationId, routeNameInfo, raw) : operationId\n );\n\n routeNameInfo.usage = name;\n routeNameInfo.original = name;\n raw.operationId = name;\n\n return routeNameInfo;\n }\n}\n"]}
|
|
@@ -1,15 +1,21 @@
|
|
|
1
1
|
import { CliFs, CommandProvider, Type } from "@tsed/cli-core";
|
|
2
2
|
import { InjectorService } from "@tsed/di";
|
|
3
|
-
|
|
3
|
+
import { Hooks, RawRouteInfo, RouteNameInfo } from "swagger-typescript-api";
|
|
4
|
+
export interface GenerateHttpClientCtx {
|
|
4
5
|
output: string;
|
|
5
6
|
type: "axios" | "fetch";
|
|
6
7
|
name: string;
|
|
7
8
|
suffix: string;
|
|
8
9
|
}
|
|
10
|
+
export interface GenerateHttpClientOpts {
|
|
11
|
+
hooks?: Partial<Hooks>;
|
|
12
|
+
transformOperationId?(operationId: string, routeNameInfo: RouteNameInfo, raw: RawRouteInfo): string;
|
|
13
|
+
}
|
|
9
14
|
export declare class GenerateHttpClientCmd implements CommandProvider {
|
|
10
15
|
injector: InjectorService;
|
|
11
16
|
protected fs: CliFs;
|
|
12
17
|
protected serverModule: Type<any>;
|
|
18
|
+
protected options: Partial<GenerateHttpClientOpts>;
|
|
13
19
|
$mapContext($ctx: GenerateHttpClientCtx): {
|
|
14
20
|
output: string;
|
|
15
21
|
type: "axios" | "fetch";
|
|
@@ -23,5 +29,6 @@ export declare class GenerateHttpClientCmd implements CommandProvider {
|
|
|
23
29
|
private loadPlatformModule;
|
|
24
30
|
private generate;
|
|
25
31
|
private generateFromSpec;
|
|
32
|
+
private onParseSchema;
|
|
33
|
+
private createRouteName;
|
|
26
34
|
}
|
|
27
|
-
export {};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tsed/cli-generate-http-client",
|
|
3
|
-
"version": "3.
|
|
3
|
+
"version": "3.24.1",
|
|
4
4
|
"description": "Ts.ED CLI plugin. Export a command that generate an HTTP Client (axios or fetch) from your Ts.ED controllers and OS3 spec.",
|
|
5
5
|
"source": "./src/index.ts",
|
|
6
6
|
"main": "./lib/cjs/index.js",
|
|
@@ -22,8 +22,8 @@
|
|
|
22
22
|
"tslib": "2.3.1"
|
|
23
23
|
},
|
|
24
24
|
"devDependencies": {
|
|
25
|
-
"@tsed/cli": "3.
|
|
26
|
-
"@tsed/cli-core": "3.
|
|
25
|
+
"@tsed/cli": "3.24.1",
|
|
26
|
+
"@tsed/cli-core": "3.24.1",
|
|
27
27
|
"swagger-typescript-api": "^9.3.1"
|
|
28
28
|
},
|
|
29
29
|
"peerDependencies": {
|
package/readme.md
CHANGED
|
@@ -45,15 +45,23 @@ Then create or edit the `src/bin/index.ts` in your project:
|
|
|
45
45
|
```typescript
|
|
46
46
|
#!/usr/bin/env node
|
|
47
47
|
import { CliCore } from "@tsed/cli-core";
|
|
48
|
-
import {GenerateHttpClientCmd} from "@tsed/cli-generate-http-client";
|
|
49
|
-
import
|
|
48
|
+
import { GenerateHttpClientCmd } from "@tsed/cli-generate-http-client";
|
|
49
|
+
import configuration from "../config";
|
|
50
|
+
import { CronCmd } from "./commands/CronCmd";
|
|
51
|
+
import "./db/connections";
|
|
50
52
|
import { Server } from "../Server";
|
|
51
53
|
|
|
52
54
|
CliCore.bootstrap({
|
|
53
|
-
...
|
|
55
|
+
...configuration,
|
|
54
56
|
server: Server,
|
|
57
|
+
httpClient: {
|
|
58
|
+
hooks: {}, // see swagger-typescript-api hooks options
|
|
59
|
+
transformOperationId(operationId: string, routeNameInfo: any, raw: any) {
|
|
60
|
+
return raw.moduleName === "oidc" ? routeNameInfo.original.replace("oidc", "") : operationId;
|
|
61
|
+
}
|
|
62
|
+
},
|
|
55
63
|
// add your custom commands here
|
|
56
|
-
commands: [GenerateHttpClientCmd]
|
|
64
|
+
commands: [GenerateHttpClientCmd, CronCmd]
|
|
57
65
|
}).catch(console.error);
|
|
58
66
|
```
|
|
59
67
|
|