@sdk-it/generic 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,3 @@
1
+ export * from './lib/generic.ts';
2
+ export * from './lib/response-analyzer.ts';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,4BAA4B,CAAC"}
package/dist/index.js ADDED
@@ -0,0 +1,202 @@
1
+ // packages/generic/src/lib/generic.ts
2
+ import debug from "debug";
3
+ import { camelcase } from "stringcase";
4
+ import ts from "typescript";
5
+ import {
6
+ Paths,
7
+ TypeDeriver,
8
+ getProgram,
9
+ isCallExpression,
10
+ isHttpMethod,
11
+ toSchema
12
+ } from "@sdk-it/core";
13
+ var logger = debug("@sdk-it/generic");
14
+ var jsDocsTags = ["openapi", "tags", "description"];
15
+ function parseJSDocComment(node) {
16
+ let tags = [];
17
+ let name = "";
18
+ let description = "";
19
+ for (const tag of ts.getAllJSDocTags(
20
+ node,
21
+ (tag2) => jsDocsTags.includes(tag2.tagName.text)
22
+ )) {
23
+ if (typeof tag.comment !== "string") {
24
+ continue;
25
+ }
26
+ switch (tag.tagName.text) {
27
+ case "openapi":
28
+ name = tag.comment;
29
+ break;
30
+ case "tags":
31
+ tags = tag.comment.split(",").map((tag2) => tag2.trim());
32
+ break;
33
+ case "description":
34
+ description = tag.comment;
35
+ break;
36
+ }
37
+ }
38
+ return {
39
+ name,
40
+ tags,
41
+ description
42
+ };
43
+ }
44
+ function visit(node, responseAnalyzer2, paths) {
45
+ if (!ts.isCallExpression(node) || node.arguments.length < 2) {
46
+ return moveOn();
47
+ }
48
+ if (!ts.isPropertyAccessExpression(node.expression) || !ts.isIdentifier(node.expression.name) || !isHttpMethod(node.expression.name.text)) {
49
+ return moveOn();
50
+ }
51
+ const [pathNode] = node.arguments;
52
+ if (!ts.isStringLiteral(pathNode)) {
53
+ return moveOn();
54
+ }
55
+ const method = node.expression.name.text;
56
+ const path = pathNode.text;
57
+ const validate = node.arguments.find(
58
+ (arg) => isCallExpression(arg, "validate")
59
+ );
60
+ if (!validate) {
61
+ return moveOn();
62
+ }
63
+ const handler = node.arguments.at(-1);
64
+ if (!handler || !ts.isArrowFunction(handler)) {
65
+ return moveOn();
66
+ }
67
+ const metadata = parseJSDocComment(node.parent);
68
+ const operationName = metadata.name || camelcase(`${method} ${path.replace(/[^a-zA-Z0-9]/g, "")}`);
69
+ const selector = validate.arguments.find((arg) => ts.isArrowFunction(arg));
70
+ if (!selector || !ts.isParenthesizedExpression(selector.body) || !ts.isObjectLiteralExpression(selector.body.expression)) {
71
+ return moveOn();
72
+ }
73
+ const props = selector.body.expression.properties.filter(
74
+ ts.isPropertyAssignment
75
+ );
76
+ paths.addPath(
77
+ operationName,
78
+ path,
79
+ method,
80
+ toSelectors(props),
81
+ responseAnalyzer2(handler),
82
+ metadata.tags,
83
+ metadata.description
84
+ );
85
+ function moveOn() {
86
+ ts.forEachChild(node, (node2) => visit(node2, responseAnalyzer2, paths));
87
+ }
88
+ }
89
+ function toSelectors(props) {
90
+ const selectors = [];
91
+ for (const prop of props) {
92
+ if (!ts.isObjectLiteralExpression(prop.initializer)) {
93
+ continue;
94
+ }
95
+ const name = prop.name.getText();
96
+ const select = prop.initializer.properties.filter(ts.isPropertyAssignment).find((prop2) => prop2.name.getText() === "select");
97
+ if (!select) {
98
+ console.warn(`No select found in ${name}`);
99
+ continue;
100
+ }
101
+ const against = prop.initializer.properties.filter(ts.isPropertyAssignment).find((prop2) => prop2.name.getText() === "against");
102
+ if (!against) {
103
+ console.warn(`No against found in ${name}`);
104
+ continue;
105
+ }
106
+ const [, source, selectText] = select.initializer.getText().split(".");
107
+ selectors.push({
108
+ name,
109
+ nullable: against.initializer.getText().includes("nullable"),
110
+ required: !against.initializer.getText().includes("optional"),
111
+ select: selectText,
112
+ against: against.initializer.getText(),
113
+ source
114
+ });
115
+ }
116
+ return selectors;
117
+ }
118
+ async function analyze(tsconfigPath, config) {
119
+ logger(`Parsing tsconfig`);
120
+ const program = getProgram(tsconfigPath);
121
+ logger(`Program created`);
122
+ const typeChecker = program.getTypeChecker();
123
+ logger(`Type checker created`);
124
+ const typeDeriver = new TypeDeriver(typeChecker);
125
+ const paths = new Paths({
126
+ commonZodImport: config.commonZodImport
127
+ });
128
+ for (const sourceFile of program.getSourceFiles()) {
129
+ if (!sourceFile.isDeclarationFile) {
130
+ logger(`Visiting ${sourceFile.fileName}`);
131
+ visit(
132
+ sourceFile,
133
+ (handler) => config.responseAnalyzer(handler, typeDeriver),
134
+ paths
135
+ );
136
+ }
137
+ }
138
+ const components = {
139
+ schemas: Object.entries(typeDeriver.collector).reduce(
140
+ (acc, [key, value]) => ({ ...acc, [key]: toSchema(value) }),
141
+ {}
142
+ )
143
+ };
144
+ return {
145
+ paths: await paths.getPaths(),
146
+ components
147
+ };
148
+ }
149
+
150
+ // packages/generic/src/lib/response-analyzer.ts
151
+ import ts2 from "typescript";
152
+ var visitor = (callback) => {
153
+ return (node) => {
154
+ if (ts2.isReturnStatement(node) && node.expression) {
155
+ if (ts2.isCallExpression(node.expression) && ts2.isPropertyAccessExpression(node.expression.expression)) {
156
+ const propAccess = node.expression.expression;
157
+ if (ts2.isIdentifier(propAccess.expression) && propAccess.expression.text === "output") {
158
+ let contentType = "application/json";
159
+ const callerMethod = propAccess.name.text;
160
+ if (callerMethod === "attachment") {
161
+ contentType = "application/octet-stream";
162
+ }
163
+ const [body, statusCode, headers] = node.expression.arguments;
164
+ callback(body, statusCode, headers, contentType);
165
+ }
166
+ }
167
+ }
168
+ return ts2.forEachChild(node, visitor(callback));
169
+ };
170
+ };
171
+ function toResponses(handler, deriver) {
172
+ const responsesList = [];
173
+ const visit2 = visitor((node, statusCode, headers, contentType) => {
174
+ responsesList.push({
175
+ headers: headers ? Object.keys(deriver.serializeNode(headers)) : [],
176
+ contentType,
177
+ statusCode: statusCode ? resolveStatusCode(statusCode) : "200",
178
+ response: node ? deriver.serializeNode(node) : void 0
179
+ });
180
+ });
181
+ visit2(handler.body);
182
+ return responsesList;
183
+ }
184
+ function resolveStatusCode(node) {
185
+ if (ts2.isNumericLiteral(node)) {
186
+ return node.text;
187
+ }
188
+ throw new Error(`Could not resolve status code`);
189
+ }
190
+ function responseAnalyzer(handler, deriver) {
191
+ try {
192
+ return toResponses(handler, deriver);
193
+ } catch (error) {
194
+ console.error("Error analyzing response\n", handler.getText());
195
+ throw error;
196
+ }
197
+ }
198
+ export {
199
+ analyze,
200
+ responseAnalyzer
201
+ };
202
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/lib/generic.ts", "../src/lib/response-analyzer.ts"],
4
+ "sourcesContent": ["import debug from 'debug';\nimport { readFile } from 'node:fs/promises';\nimport type { ComponentsObject } from 'openapi3-ts/oas31';\nimport { camelcase } from 'stringcase';\nimport ts from 'typescript';\n\nimport {\n Paths,\n type ResponseItem,\n type Selector,\n type SemanticSource,\n TypeDeriver,\n getProgram,\n isCallExpression,\n isHttpMethod,\n toSchema,\n} from '@sdk-it/core';\n\nconst logger = debug('@sdk-it/generic');\n\nconst jsDocsTags = ['openapi', 'tags', 'description'];\n\nfunction parseJSDocComment(node: ts.Node) {\n let tags: string[] = [];\n let name = '';\n let description = '';\n for (const tag of ts.getAllJSDocTags(node, (tag): tag is ts.JSDocTag =>\n jsDocsTags.includes(tag.tagName.text),\n )) {\n if (typeof tag.comment !== 'string') {\n continue;\n }\n switch (tag.tagName.text) {\n case 'openapi':\n name = tag.comment;\n break;\n case 'tags':\n tags = tag.comment.split(',').map((tag) => tag.trim());\n break;\n case 'description':\n description = tag.comment;\n break;\n }\n }\n return {\n name,\n tags,\n description,\n };\n}\n\nfunction visit(\n node: ts.Node,\n responseAnalyzer: (handler: ts.ArrowFunction) => ResponseItem[],\n paths: Paths,\n) {\n if (!ts.isCallExpression(node) || node.arguments.length < 2) {\n return moveOn();\n }\n if (\n !ts.isPropertyAccessExpression(node.expression) ||\n !ts.isIdentifier(node.expression.name) ||\n !isHttpMethod(node.expression.name.text)\n ) {\n return moveOn();\n }\n\n const [pathNode] = node.arguments;\n if (!ts.isStringLiteral(pathNode)) {\n return moveOn();\n }\n const method = node.expression.name.text;\n const path = pathNode.text;\n const validate = node.arguments.find((arg) =>\n isCallExpression(arg, 'validate'),\n );\n if (!validate) {\n return moveOn();\n }\n const handler = node.arguments.at(-1);\n if (!handler || !ts.isArrowFunction(handler)) {\n return moveOn();\n }\n\n const metadata = parseJSDocComment(node.parent);\n const operationName =\n metadata.name ||\n camelcase(`${method} ${path.replace(/[^a-zA-Z0-9]/g, '')}`);\n const selector = validate.arguments.find((arg) => ts.isArrowFunction(arg));\n if (\n !selector ||\n !ts.isParenthesizedExpression(selector.body) ||\n !ts.isObjectLiteralExpression(selector.body.expression)\n ) {\n return moveOn();\n }\n const props = selector.body.expression.properties.filter(\n ts.isPropertyAssignment,\n );\n\n paths.addPath(\n operationName,\n path,\n method,\n toSelectors(props),\n responseAnalyzer(handler),\n metadata.tags,\n metadata.description,\n );\n\n function moveOn() {\n ts.forEachChild(node, (node) => visit(node, responseAnalyzer, paths));\n }\n}\n\nfunction toSelectors(props: ts.PropertyAssignment[]) {\n const selectors: Selector[] = [];\n for (const prop of props) {\n if (!ts.isObjectLiteralExpression(prop.initializer)) {\n continue;\n }\n const name = prop.name.getText();\n const select = prop.initializer.properties\n .filter(ts.isPropertyAssignment)\n .find((prop) => prop.name.getText() === 'select');\n if (!select) {\n console.warn(`No select found in ${name}`);\n continue;\n }\n const against = prop.initializer.properties\n .filter(ts.isPropertyAssignment)\n .find((prop) => prop.name.getText() === 'against');\n if (!against) {\n console.warn(`No against found in ${name}`);\n continue;\n }\n const [, source, selectText] = select.initializer.getText().split('.');\n selectors.push({\n name,\n nullable: against.initializer.getText().includes('nullable'),\n required: !against.initializer.getText().includes('optional'),\n select: selectText,\n against: against.initializer.getText(),\n source: source as SemanticSource,\n });\n }\n return selectors;\n}\n\nexport async function analyze(\n tsconfigPath: string,\n config: {\n /**\n * Additional code to inject before resolving zod schemas\n */\n commonZodImport?: string;\n responseAnalyzer: (\n handler: ts.ArrowFunction,\n deriver: TypeDeriver,\n ) => ResponseItem[];\n },\n) {\n logger(`Parsing tsconfig`);\n const program = getProgram(tsconfigPath);\n logger(`Program created`);\n const typeChecker = program.getTypeChecker();\n logger(`Type checker created`);\n const typeDeriver = new TypeDeriver(typeChecker);\n const paths = new Paths({\n commonZodImport: config.commonZodImport,\n });\n for (const sourceFile of program.getSourceFiles()) {\n if (!sourceFile.isDeclarationFile) {\n logger(`Visiting ${sourceFile.fileName}`);\n visit(\n sourceFile,\n (handler) => config.responseAnalyzer(handler, typeDeriver),\n paths,\n );\n }\n }\n\n const components: ComponentsObject = {\n schemas: Object.entries(typeDeriver.collector).reduce(\n (acc, [key, value]) => ({ ...acc, [key]: toSchema(value) }),\n {},\n ),\n };\n\n return {\n paths: await paths.getPaths(),\n components,\n };\n}\n\nexport type Serialized = ReturnType<typeof analyze>;\n", "import ts from 'typescript';\n\nimport type { ResponseItem, TypeDeriver } from '@sdk-it/core';\n\nconst visitor: (\n on: (\n node: ts.Node,\n statusCode: ts.Node | undefined,\n headers: ts.Node | undefined,\n contentType: string,\n ) => void,\n) => ts.Visitor = (callback) => {\n return (node: ts.Node) => {\n if (ts.isReturnStatement(node) && node.expression) {\n if (\n ts.isCallExpression(node.expression) &&\n ts.isPropertyAccessExpression(node.expression.expression)\n ) {\n const propAccess = node.expression.expression;\n if (\n ts.isIdentifier(propAccess.expression) &&\n propAccess.expression.text === 'output'\n ) {\n let contentType = 'application/json';\n const callerMethod = propAccess.name.text;\n if (callerMethod === 'attachment') {\n contentType = 'application/octet-stream';\n }\n const [body, statusCode, headers] = node.expression.arguments;\n callback(body, statusCode, headers, contentType);\n }\n }\n }\n return ts.forEachChild(node, visitor(callback));\n };\n};\n\nfunction toResponses(handler: ts.ArrowFunction, deriver: TypeDeriver) {\n const responsesList: ResponseItem[] = [];\n const visit = visitor((node, statusCode, headers, contentType) => {\n responsesList.push({\n headers: headers ? Object.keys(deriver.serializeNode(headers)) : [],\n contentType,\n statusCode: statusCode ? resolveStatusCode(statusCode) : '200',\n response: node ? deriver.serializeNode(node) : undefined,\n });\n });\n visit(handler.body);\n return responsesList;\n}\n\nfunction resolveStatusCode(node: ts.Node) {\n if (ts.isNumericLiteral(node)) {\n return node.text;\n }\n throw new Error(`Could not resolve status code`);\n}\n\nexport function responseAnalyzer(\n handler: ts.ArrowFunction,\n deriver: TypeDeriver,\n) {\n try {\n return toResponses(handler, deriver);\n } catch (error) {\n console.error('Error analyzing response\\n', handler.getText());\n throw error;\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["tag", "responseAnalyzer", "node", "prop", "ts", "visit"]
7
+ }
@@ -0,0 +1,15 @@
1
+ import type { ComponentsObject } from 'openapi3-ts/oas31';
2
+ import ts from 'typescript';
3
+ import { type ResponseItem, TypeDeriver } from '@sdk-it/core';
4
+ export declare function analyze(tsconfigPath: string, config: {
5
+ /**
6
+ * Additional code to inject before resolving zod schemas
7
+ */
8
+ commonZodImport?: string;
9
+ responseAnalyzer: (handler: ts.ArrowFunction, deriver: TypeDeriver) => ResponseItem[];
10
+ }): Promise<{
11
+ paths: import("openapi3-ts/oas31").PathsObject;
12
+ components: ComponentsObject;
13
+ }>;
14
+ export type Serialized = ReturnType<typeof analyze>;
15
+ //# sourceMappingURL=generic.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generic.d.ts","sourceRoot":"","sources":["../../src/lib/generic.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAE1D,OAAO,EAAE,MAAM,YAAY,CAAC;AAE5B,OAAO,EAEL,KAAK,YAAY,EAGjB,WAAW,EAKZ,MAAM,cAAc,CAAC;AAqItB,wBAAsB,OAAO,CAC3B,YAAY,EAAE,MAAM,EACpB,MAAM,EAAE;IACN;;OAEG;IACH,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,gBAAgB,EAAE,CAChB,OAAO,EAAE,EAAE,CAAC,aAAa,EACzB,OAAO,EAAE,WAAW,KACjB,YAAY,EAAE,CAAC;CACrB;;;GAiCF;AAED,MAAM,MAAM,UAAU,GAAG,UAAU,CAAC,OAAO,OAAO,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import ts from 'typescript';
2
+ import type { ResponseItem, TypeDeriver } from '@sdk-it/core';
3
+ export declare function responseAnalyzer(handler: ts.ArrowFunction, deriver: TypeDeriver): ResponseItem[];
4
+ //# sourceMappingURL=response-analyzer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"response-analyzer.d.ts","sourceRoot":"","sources":["../../src/lib/response-analyzer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,YAAY,CAAC;AAE5B,OAAO,KAAK,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAwD9D,wBAAgB,gBAAgB,CAC9B,OAAO,EAAE,EAAE,CAAC,aAAa,EACzB,OAAO,EAAE,WAAW,kBAQrB"}
package/package.json ADDED
@@ -0,0 +1,26 @@
1
+ {
2
+ "name": "@sdk-it/generic",
3
+ "version": "0.2.0",
4
+ "type": "module",
5
+ "main": "./dist/index.js",
6
+ "module": "./dist/index.js",
7
+ "types": "./dist/index.d.ts",
8
+ "publishConfig": {
9
+ "access": "public"
10
+ },
11
+ "exports": {
12
+ "./package.json": "./package.json",
13
+ ".": {
14
+ "types": "./dist/index.d.ts",
15
+ "import": "./dist/index.js",
16
+ "default": "./dist/index.js"
17
+ }
18
+ },
19
+ "files": [
20
+ "dist",
21
+ "!**/*.tsbuildinfo"
22
+ ],
23
+ "dependencies": {
24
+ "@sdk-it/core": "0.2.0"
25
+ }
26
+ }