From 6494977f9fad22e3982f5b042b20da83876d7071 Mon Sep 17 00:00:00 2001 From: Lukas Date: Thu, 24 Mar 2022 09:17:52 +0100 Subject: [PATCH 1/2] Adding possebility to extend interfaces with custom class --- index.d.ts | 6 ++++++ index.js | 6 ++++++ src/config.js | 2 ++ src/index.js | 2 ++ src/modelTypes.js | 1 + src/schema.js | 3 +++ templates/base/data-contracts.eta | 11 ++++++++++- 7 files changed, 30 insertions(+), 1 deletion(-) diff --git a/index.d.ts b/index.d.ts index 4673b93c..a7f7abfe 100644 --- a/index.d.ts +++ b/index.d.ts @@ -34,6 +34,11 @@ interface GenerateApiParams { */ generateUnionEnums?: boolean; + /** + * Extend the interfaces with this class + */ + interfaceExtend: ""; + /** * generate type definitions for API routes (default: false) */ @@ -300,6 +305,7 @@ export interface GenerateApiConfiguration { generateRouteTypes: boolean; generateClient: boolean; generateUnionEnums: boolean; + interfaceExtend: string; swaggerSchema: object; originalSchema: object; componentsMap: Record; diff --git a/index.js b/index.js index a42b61a5..b478a27c 100755 --- a/index.js +++ b/index.js @@ -38,6 +38,10 @@ program false, ) .option("--union-enums", 'generate all "enum" types as union types (T1 | T2 | TN)', false) + .option( + "-i --interface-extend ", + "if chosendefines a class that all interfaces will extend ", + ) .option("--route-types", "generate type definitions for API routes", false) .option("--no-client", "do not generate an API class", false) .option( @@ -86,6 +90,7 @@ const { name, templates, unionEnums, + interfaceExtend, routeTypes, client, defaultAsSuccess, @@ -119,6 +124,7 @@ generateApi({ defaultResponseType: defaultResponse, unwrapResponseData: unwrapResponseData, generateUnionEnums: unionEnums, + interfaceExtend: interfaceExtend, generateResponses: responses, extractRequestParams: !!extractRequestParams, extractRequestBody: !!extractRequestBody, diff --git a/src/config.js b/src/config.js index b9f3d63a..8a2982eb 100644 --- a/src/config.js +++ b/src/config.js @@ -14,6 +14,8 @@ const config = { generateClient: true, /** CLI flag */ generateUnionEnums: false, + /** CLI flag */ + interfaceExtend: "", enumNamesAsValues: false, /** parsed swagger schema from getSwaggerObject() */ diff --git a/src/index.js b/src/index.js index 6ccbdd3a..43f7a6e4 100644 --- a/src/index.js +++ b/src/index.js @@ -39,6 +39,7 @@ module.exports = { generateClient = config.generateClient, httpClientType = config.httpClientType, generateUnionEnums = config.generateUnionEnums, + interfaceExtend = config.interfaceExtend, moduleNameIndex = config.moduleNameIndex, moduleNameFirstTag = config.moduleNameFirstTag, extractRequestParams = config.extractRequestParams, @@ -66,6 +67,7 @@ module.exports = { generateResponses, templates, generateUnionEnums, + interfaceExtend, moduleNameIndex, moduleNameFirstTag, prettierOptions, diff --git a/src/modelTypes.js b/src/modelTypes.js index e101e9d4..1280db10 100644 --- a/src/modelTypes.js +++ b/src/modelTypes.js @@ -21,6 +21,7 @@ const prepareModelType = (typeInfo) => { description, rawContent: content, content: resultContent, + interfaceExtend: config.interfaceExtend, typeData, }; }; diff --git a/src/schema.js b/src/schema.js index 8bd40ce7..2b655eb1 100644 --- a/src/schema.js +++ b/src/schema.js @@ -294,6 +294,7 @@ const schemaParsers = { ? TS_KEYWORDS.TYPE : TS_KEYWORDS.ENUM, name: typeName, + interfaceExtend: config.interfaceExtend, description: formatDescription(schema.description), content, }); @@ -308,6 +309,7 @@ const schemaParsers = { type: SCHEMA_TYPES.OBJECT, typeIdentifier: TS_KEYWORDS.INTERFACE, name: typeName, + interfaceExtend: config.interfaceExtend, description: formatDescription(schema.description), allFieldsAreOptional: !_.some(_.values(content), (part) => part.isRequired), content: content, @@ -325,6 +327,7 @@ const schemaParsers = { type: SCHEMA_TYPES.PRIMITIVE, typeIdentifier: TS_KEYWORDS.TYPE, name: typeName, + interfaceExtend: config.interfaceExtend, description: formatDescription( schema.description || _.compact(_.map(schema[complexType], "description"))[0] || "", ), diff --git a/templates/base/data-contracts.eta b/templates/base/data-contracts.eta index 7e3ef4ae..26b80ab4 100644 --- a/templates/base/data-contracts.eta +++ b/templates/base/data-contracts.eta @@ -8,7 +8,10 @@ return `enum ${contract.name} {\r\n${contract.content} \r\n }`; }, interface: (contract) => { - return `interface ${contract.name} {\r\n${contract.content}}`; + if (contract.interfaceExtend.length > 1) + return `interface ${contract.name} extends ${contract.interfaceExtend} {\r\ntype:"${contract.name}";${contract.content}}`; + else + return `interface ${contract.name} {\r\n${contract.content}}`; }, type: (contract) => { return `type ${contract.name} = ${contract.content}`; @@ -30,10 +33,16 @@ ]); } %> + <% modelTypes.forEach((contract) => { %> <% const description = createDescription(contract); %> +/** +<%~ JSON.stringify(contract) %> +*/ <% if (description.length) { %> /** + +<%~ contract.interfaceExtend %> <%~ description.map(part => `* ${part}`).join("\n") %> */ From e3b0d57153cb4b73bc5b4f64b9f5eb90d2fd7967 Mon Sep 17 00:00:00 2001 From: Lukas Date: Thu, 24 Mar 2022 09:29:38 +0100 Subject: [PATCH 2/2] Adding a custom-import tag to be used with the interfaceExtend feature --- index.d.ts | 5 +++++ index.js | 8 +++++++- src/config.js | 2 ++ src/index.js | 2 ++ src/modelTypes.js | 1 - src/schema.js | 3 --- templates/base/data-contracts.eta | 12 ++++++------ 7 files changed, 22 insertions(+), 11 deletions(-) diff --git a/index.d.ts b/index.d.ts index a7f7abfe..045425f9 100644 --- a/index.d.ts +++ b/index.d.ts @@ -39,6 +39,11 @@ interface GenerateApiParams { */ interfaceExtend: ""; + /** + * A custom import string to be used with interface extend + */ + customImport: ""; + /** * generate type definitions for API routes (default: false) */ diff --git a/index.js b/index.js index b478a27c..7ecd2b9f 100755 --- a/index.js +++ b/index.js @@ -39,9 +39,13 @@ program ) .option("--union-enums", 'generate all "enum" types as union types (T1 | T2 | TN)', false) .option( - "-i --interface-extend ", + "--interface-extend ", "if chosendefines a class that all interfaces will extend ", ) + .option( + "--custom-import ", + "Specify a string for custom importstatement (can be used with --interface-extend) ", + ) .option("--route-types", "generate type definitions for API routes", false) .option("--no-client", "do not generate an API class", false) .option( @@ -91,6 +95,7 @@ const { templates, unionEnums, interfaceExtend, + customImport, routeTypes, client, defaultAsSuccess, @@ -125,6 +130,7 @@ generateApi({ unwrapResponseData: unwrapResponseData, generateUnionEnums: unionEnums, interfaceExtend: interfaceExtend, + customImport: customImport, generateResponses: responses, extractRequestParams: !!extractRequestParams, extractRequestBody: !!extractRequestBody, diff --git a/src/config.js b/src/config.js index 8a2982eb..04087360 100644 --- a/src/config.js +++ b/src/config.js @@ -16,6 +16,8 @@ const config = { generateUnionEnums: false, /** CLI flag */ interfaceExtend: "", + /** CLI flag */ + customImport: "", enumNamesAsValues: false, /** parsed swagger schema from getSwaggerObject() */ diff --git a/src/index.js b/src/index.js index 43f7a6e4..f55a6868 100644 --- a/src/index.js +++ b/src/index.js @@ -40,6 +40,7 @@ module.exports = { httpClientType = config.httpClientType, generateUnionEnums = config.generateUnionEnums, interfaceExtend = config.interfaceExtend, + customImport = config.customImport, moduleNameIndex = config.moduleNameIndex, moduleNameFirstTag = config.moduleNameFirstTag, extractRequestParams = config.extractRequestParams, @@ -68,6 +69,7 @@ module.exports = { templates, generateUnionEnums, interfaceExtend, + customImport, moduleNameIndex, moduleNameFirstTag, prettierOptions, diff --git a/src/modelTypes.js b/src/modelTypes.js index 1280db10..e101e9d4 100644 --- a/src/modelTypes.js +++ b/src/modelTypes.js @@ -21,7 +21,6 @@ const prepareModelType = (typeInfo) => { description, rawContent: content, content: resultContent, - interfaceExtend: config.interfaceExtend, typeData, }; }; diff --git a/src/schema.js b/src/schema.js index 2b655eb1..8bd40ce7 100644 --- a/src/schema.js +++ b/src/schema.js @@ -294,7 +294,6 @@ const schemaParsers = { ? TS_KEYWORDS.TYPE : TS_KEYWORDS.ENUM, name: typeName, - interfaceExtend: config.interfaceExtend, description: formatDescription(schema.description), content, }); @@ -309,7 +308,6 @@ const schemaParsers = { type: SCHEMA_TYPES.OBJECT, typeIdentifier: TS_KEYWORDS.INTERFACE, name: typeName, - interfaceExtend: config.interfaceExtend, description: formatDescription(schema.description), allFieldsAreOptional: !_.some(_.values(content), (part) => part.isRequired), content: content, @@ -327,7 +325,6 @@ const schemaParsers = { type: SCHEMA_TYPES.PRIMITIVE, typeIdentifier: TS_KEYWORDS.TYPE, name: typeName, - interfaceExtend: config.interfaceExtend, description: formatDescription( schema.description || _.compact(_.map(schema[complexType], "description"))[0] || "", ), diff --git a/templates/base/data-contracts.eta b/templates/base/data-contracts.eta index 26b80ab4..ca90768a 100644 --- a/templates/base/data-contracts.eta +++ b/templates/base/data-contracts.eta @@ -1,5 +1,5 @@ <% - const { modelTypes, utils } = it; + const { modelTypes, utils, config} = it; const { formatDescription, require, _ } = utils; @@ -8,8 +8,8 @@ return `enum ${contract.name} {\r\n${contract.content} \r\n }`; }, interface: (contract) => { - if (contract.interfaceExtend.length > 1) - return `interface ${contract.name} extends ${contract.interfaceExtend} {\r\ntype:"${contract.name}";${contract.content}}`; + if (config.interfaceExtend.length > 1) + return `interface ${contract.name} extends ${config.interfaceExtend} {\r\ntype:"${contract.name}";${contract.content}}`; else return `interface ${contract.name} {\r\n${contract.content}}`; }, @@ -34,11 +34,11 @@ } %> +<%~ config.customImport %> + + <% modelTypes.forEach((contract) => { %> <% const description = createDescription(contract); %> -/** -<%~ JSON.stringify(contract) %> -*/ <% if (description.length) { %> /**