@kubb/plugin-oas 4.20.5 → 4.21.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.
- package/dist/utils.cjs +61 -3
- package/dist/utils.cjs.map +1 -1
- package/dist/utils.d.cts +20 -1
- package/dist/utils.d.ts +20 -1
- package/dist/utils.js +59 -5
- package/dist/utils.js.map +1 -1
- package/package.json +3 -3
- package/src/utils/getParams.ts +47 -2
- package/src/utils/index.ts +8 -1
- package/src/utils/paramsCasing.ts +60 -0
package/dist/utils.cjs
CHANGED
|
@@ -3,6 +3,7 @@ const require_SchemaGenerator = require('./SchemaGenerator-m8ILeAM0.cjs');
|
|
|
3
3
|
const require_SchemaMapper = require('./SchemaMapper-CzH82C7C.cjs');
|
|
4
4
|
const require_getFooter = require('./getFooter-C_dFbEs9.cjs');
|
|
5
5
|
let _kubb_core_transformers = require("@kubb/core/transformers");
|
|
6
|
+
_kubb_core_transformers = require_chunk.__toESM(_kubb_core_transformers);
|
|
6
7
|
let _kubb_core_utils = require("@kubb/core/utils");
|
|
7
8
|
let _kubb_oas = require("@kubb/oas");
|
|
8
9
|
|
|
@@ -40,15 +41,16 @@ function getImports(tree) {
|
|
|
40
41
|
* @deprecated
|
|
41
42
|
* TODO move to operationManager hook
|
|
42
43
|
*/
|
|
43
|
-
function getASTParams(operationSchema, { typed = false, override } = {}) {
|
|
44
|
+
function getASTParams(operationSchema, { typed = false, casing, override } = {}) {
|
|
44
45
|
if (!operationSchema || !operationSchema.schema.properties || !operationSchema.name) return [];
|
|
45
46
|
const requiredFields = Array.isArray(operationSchema.schema.required) ? operationSchema.schema.required : [];
|
|
46
47
|
return Object.entries(operationSchema.schema.properties).map(([name]) => {
|
|
48
|
+
const accessName = casing === "camelcase" ? (0, _kubb_core_transformers.camelCase)(name) : name;
|
|
47
49
|
const data = {
|
|
48
50
|
name,
|
|
49
51
|
enabled: !!name,
|
|
50
52
|
required: requiredFields.includes(name),
|
|
51
|
-
type: typed ? `${operationSchema.name}["${
|
|
53
|
+
type: typed ? `${operationSchema.name}["${accessName}"]` : void 0
|
|
52
54
|
};
|
|
53
55
|
return override ? override(data) : data;
|
|
54
56
|
});
|
|
@@ -56,8 +58,9 @@ function getASTParams(operationSchema, { typed = false, override } = {}) {
|
|
|
56
58
|
function getPathParams(operationSchema, options = {}) {
|
|
57
59
|
return getASTParams(operationSchema, options).reduce((acc, curr) => {
|
|
58
60
|
if (curr.name && curr.enabled) {
|
|
59
|
-
let name =
|
|
61
|
+
let name = curr.name;
|
|
60
62
|
if (options.casing === "camelcase") name = (0, _kubb_core_transformers.camelCase)(name);
|
|
63
|
+
else if (!(0, _kubb_core_transformers.isValidVarName)(name)) name = (0, _kubb_core_transformers.camelCase)(name);
|
|
61
64
|
acc[name] = {
|
|
62
65
|
default: curr.default,
|
|
63
66
|
type: curr.type,
|
|
@@ -67,6 +70,21 @@ function getPathParams(operationSchema, options = {}) {
|
|
|
67
70
|
return acc;
|
|
68
71
|
}, {});
|
|
69
72
|
}
|
|
73
|
+
/**
|
|
74
|
+
* Get a mapping of camelCase parameter names to their original names
|
|
75
|
+
* Used for mapping function parameters to backend parameter names
|
|
76
|
+
*/
|
|
77
|
+
function getParamsMapping(operationSchema, options = {}) {
|
|
78
|
+
if (!operationSchema || !operationSchema.schema.properties) return;
|
|
79
|
+
const mapping = {};
|
|
80
|
+
Object.entries(operationSchema.schema.properties).forEach(([originalName]) => {
|
|
81
|
+
let transformedName = originalName;
|
|
82
|
+
if (options.casing === "camelcase") transformedName = (0, _kubb_core_transformers.camelCase)(originalName);
|
|
83
|
+
else if (!(0, _kubb_core_transformers.isValidVarName)(originalName)) transformedName = (0, _kubb_core_transformers.camelCase)(originalName);
|
|
84
|
+
if (transformedName !== originalName) mapping[originalName] = transformedName;
|
|
85
|
+
});
|
|
86
|
+
return Object.keys(mapping).length > 0 ? mapping : void 0;
|
|
87
|
+
}
|
|
70
88
|
|
|
71
89
|
//#endregion
|
|
72
90
|
//#region src/utils/getSchemas.ts
|
|
@@ -92,10 +110,49 @@ function getSchemas({ oas, contentType, includes = [
|
|
|
92
110
|
}
|
|
93
111
|
|
|
94
112
|
//#endregion
|
|
113
|
+
//#region src/utils/paramsCasing.ts
|
|
114
|
+
/**
|
|
115
|
+
* Apply casing transformation to schema properties
|
|
116
|
+
* Only transforms property names, not nested schemas
|
|
117
|
+
*/
|
|
118
|
+
function applyParamsCasing(schema, casing) {
|
|
119
|
+
if (!casing || !schema.properties) return schema;
|
|
120
|
+
const transformedProperties = {};
|
|
121
|
+
const transformedRequired = [];
|
|
122
|
+
Object.entries(schema.properties).forEach(([originalName, propertySchema]) => {
|
|
123
|
+
let transformedName = originalName;
|
|
124
|
+
if (casing === "camelcase") transformedName = _kubb_core_transformers.default.camelCase(originalName);
|
|
125
|
+
else if (!(0, _kubb_core_transformers.isValidVarName)(originalName)) transformedName = _kubb_core_transformers.default.camelCase(originalName);
|
|
126
|
+
transformedProperties[transformedName] = propertySchema;
|
|
127
|
+
});
|
|
128
|
+
if (Array.isArray(schema.required)) schema.required.forEach((originalName) => {
|
|
129
|
+
let transformedName = originalName;
|
|
130
|
+
if (casing === "camelcase") transformedName = _kubb_core_transformers.default.camelCase(originalName);
|
|
131
|
+
else if (!(0, _kubb_core_transformers.isValidVarName)(originalName)) transformedName = _kubb_core_transformers.default.camelCase(originalName);
|
|
132
|
+
transformedRequired.push(transformedName);
|
|
133
|
+
});
|
|
134
|
+
return {
|
|
135
|
+
...schema,
|
|
136
|
+
properties: transformedProperties,
|
|
137
|
+
...transformedRequired.length > 0 && { required: transformedRequired }
|
|
138
|
+
};
|
|
139
|
+
}
|
|
140
|
+
/**
|
|
141
|
+
* Check if this schema is a parameter schema (pathParams, queryParams, or headerParams)
|
|
142
|
+
* Only these should be transformed, not response/data/body
|
|
143
|
+
*/
|
|
144
|
+
function isParameterSchema(schemaName) {
|
|
145
|
+
const lowerName = schemaName.toLowerCase();
|
|
146
|
+
return lowerName.includes("pathparams") || lowerName.includes("queryparams") || lowerName.includes("headerparams");
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
//#endregion
|
|
150
|
+
exports.applyParamsCasing = applyParamsCasing;
|
|
95
151
|
exports.getBanner = require_getFooter.getBanner;
|
|
96
152
|
exports.getComments = getComments;
|
|
97
153
|
exports.getFooter = require_getFooter.getFooter;
|
|
98
154
|
exports.getImports = getImports;
|
|
155
|
+
exports.getParamsMapping = getParamsMapping;
|
|
99
156
|
exports.getPathParams = getPathParams;
|
|
100
157
|
exports.getSchemaFactory = require_SchemaGenerator.getSchemaFactory;
|
|
101
158
|
exports.getSchemas = getSchemas;
|
|
@@ -105,4 +162,5 @@ Object.defineProperty(exports, 'isOptional', {
|
|
|
105
162
|
return _kubb_oas.isOptional;
|
|
106
163
|
}
|
|
107
164
|
});
|
|
165
|
+
exports.isParameterSchema = isParameterSchema;
|
|
108
166
|
//# sourceMappingURL=utils.cjs.map
|
package/dist/utils.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.cjs","names":["URLPath","SchemaGenerator","schemaKeywords"],"sources":["../src/utils/getComments.ts","../src/utils/getImports.ts","../src/utils/getParams.ts","../src/utils/getSchemas.ts"],"sourcesContent":["import { URLPath } from '@kubb/core/utils'\n\nimport type { Operation } from '@kubb/oas'\n\nexport function getComments(operation: Operation): string[] {\n return [\n operation.getDescription() && `@description ${operation.getDescription()}`,\n operation.getSummary() && `@summary ${operation.getSummary()}`,\n operation.path && `{@link ${new URLPath(operation.path).URL}}`,\n operation.isDeprecated() && '@deprecated',\n ]\n .filter(Boolean)\n .flatMap((text) => {\n // Split by newlines to preserve line breaks in JSDoc\n // Trim each line individually to remove leading/trailing whitespace\n return text.split(/\\r?\\n/).map((line) => line.trim())\n })\n .filter(Boolean)\n}\n","import type { KubbFile } from '@kubb/fabric-core/types'\nimport { SchemaGenerator } from '../SchemaGenerator.ts'\nimport type { Schema } from '../SchemaMapper'\nimport { schemaKeywords } from '../SchemaMapper'\n\n/**\n * Get imports from a schema tree by extracting all ref schemas that are importable\n */\nexport function getImports(tree: Array<Schema>): Array<KubbFile.Import> {\n const refs = SchemaGenerator.deepSearch(tree, schemaKeywords.ref)\n\n return refs\n ?.map((item) => {\n if (!item.args.path || !item.args.isImportable) {\n return undefined\n }\n\n return {\n name: [item.args.name],\n path: item.args.path,\n }\n })\n .filter(Boolean)\n}\n","import { camelCase, isValidVarName } from '@kubb/core/transformers'\nimport type { FunctionParamsAST } from '@kubb/core/utils'\nimport type { OasTypes } from '@kubb/oas'\nimport type { Params } from '@kubb/react-fabric/types'\nimport type { OperationSchema } from '../types.ts'\n/**\n *\n * @deprecated\n * TODO move to operationManager hook\n */\nexport function getASTParams(\n operationSchema: OperationSchema | undefined,\n {\n typed = false,\n override,\n }: {\n typed?: boolean\n override?: (data: FunctionParamsAST) => FunctionParamsAST\n } = {},\n): FunctionParamsAST[] {\n if (!operationSchema || !operationSchema.schema.properties || !operationSchema.name) {\n return []\n }\n\n const requiredFields = Array.isArray(operationSchema.schema.required) ? operationSchema.schema.required : []\n\n return Object.entries(operationSchema.schema.properties).map(([name]: [string, OasTypes.SchemaObject]) => {\n const data: FunctionParamsAST = {\n name,\n enabled: !!name,\n required: requiredFields.includes(name),\n type: typed ? `${operationSchema.name}[\"${name}\"]` : undefined,\n }\n\n return override ? override(data) : data\n })\n}\n\nexport function getPathParams(\n operationSchema: OperationSchema | undefined,\n options: {\n typed?: boolean\n casing?: 'camelcase'\n override?: (data: FunctionParamsAST) => FunctionParamsAST\n } = {},\n) {\n return getASTParams(operationSchema, options).reduce((acc, curr) => {\n if (curr.name && curr.enabled) {\n let name = isValidVarName(curr.name) ? curr.name : camelCase(curr.name)\n\n if (options.casing === 'camelcase') {\n name = camelCase(name)\n }\n\n acc[name] = {\n default: curr.default,\n type: curr.type,\n optional: !curr.required,\n }\n }\n\n return acc\n }, {} as Params)\n}\n","import type { contentType, Oas, OasTypes } from '@kubb/oas'\n\nexport type GetSchemasResult = {\n schemas: Record<string, OasTypes.SchemaObject>\n /**\n * Mapping from original component name to resolved name after collision handling\n * e.g., { 'Order': 'OrderSchema', 'variant': 'variant2' }\n */\n nameMapping: Map<string, string>\n}\n\ntype Mode = 'schemas' | 'responses' | 'requestBodies'\n\ntype GetSchemasProps = {\n oas: Oas\n contentType?: contentType\n includes?: Mode[]\n /**\n * Whether to resolve name collisions with suffixes.\n * If not provided, uses oas.options.collisionDetection\n * @default false (from oas.options or fallback)\n */\n collisionDetection?: boolean\n}\n\n/**\n * Collect schemas from OpenAPI components (schemas, responses, requestBodies)\n * and return them in dependency order along with name mapping for collision resolution.\n *\n * This function is a wrapper around the oas.getSchemas() method for backward compatibility.\n * New code should use oas.getSchemas() directly.\n *\n * @deprecated Use oas.getSchemas() instead\n */\nexport function getSchemas({ oas, contentType, includes = ['schemas', 'requestBodies', 'responses'], collisionDetection }: GetSchemasProps): GetSchemasResult {\n return oas.getSchemas({\n contentType,\n includes,\n collisionDetection,\n })\n}\n"],"mappings":";;;;;;;;;AAIA,SAAgB,YAAY,WAAgC;AAC1D,QAAO;EACL,UAAU,gBAAgB,IAAI,gBAAgB,UAAU,gBAAgB;EACxE,UAAU,YAAY,IAAI,YAAY,UAAU,YAAY;EAC5D,UAAU,QAAQ,UAAU,IAAIA,yBAAQ,UAAU,KAAK,CAAC,IAAI;EAC5D,UAAU,cAAc,IAAI;EAC7B,CACE,OAAO,QAAQ,CACf,SAAS,SAAS;AAGjB,SAAO,KAAK,MAAM,QAAQ,CAAC,KAAK,SAAS,KAAK,MAAM,CAAC;GACrD,CACD,OAAO,QAAQ;;;;;;;;ACTpB,SAAgB,WAAW,MAA6C;AAGtE,QAFaC,wCAAgB,WAAW,MAAMC,oCAAe,IAAI,EAG7D,KAAK,SAAS;AACd,MAAI,CAAC,KAAK,KAAK,QAAQ,CAAC,KAAK,KAAK,aAChC;AAGF,SAAO;GACL,MAAM,CAAC,KAAK,KAAK,KAAK;GACtB,MAAM,KAAK,KAAK;GACjB;GACD,CACD,OAAO,QAAQ;;;;;;;;;;ACZpB,SAAgB,aACd,iBACA,EACE,QAAQ,OACR,aAIE,EAAE,EACe;AACrB,KAAI,CAAC,mBAAmB,CAAC,gBAAgB,OAAO,cAAc,CAAC,gBAAgB,KAC7E,QAAO,EAAE;CAGX,MAAM,iBAAiB,MAAM,QAAQ,gBAAgB,OAAO,SAAS,GAAG,gBAAgB,OAAO,WAAW,EAAE;AAE5G,QAAO,OAAO,QAAQ,gBAAgB,OAAO,WAAW,CAAC,KAAK,CAAC,UAA2C;EACxG,MAAM,OAA0B;GAC9B;GACA,SAAS,CAAC,CAAC;GACX,UAAU,eAAe,SAAS,KAAK;GACvC,MAAM,QAAQ,GAAG,gBAAgB,KAAK,IAAI,KAAK,MAAM;GACtD;AAED,SAAO,WAAW,SAAS,KAAK,GAAG;GACnC;;AAGJ,SAAgB,cACd,iBACA,UAII,EAAE,EACN;AACA,QAAO,aAAa,iBAAiB,QAAQ,CAAC,QAAQ,KAAK,SAAS;AAClE,MAAI,KAAK,QAAQ,KAAK,SAAS;GAC7B,IAAI,mDAAsB,KAAK,KAAK,GAAG,KAAK,8CAAiB,KAAK,KAAK;AAEvE,OAAI,QAAQ,WAAW,YACrB,+CAAiB,KAAK;AAGxB,OAAI,QAAQ;IACV,SAAS,KAAK;IACd,MAAM,KAAK;IACX,UAAU,CAAC,KAAK;IACjB;;AAGH,SAAO;IACN,EAAE,CAAW;;;;;;;;;;;;;;AC5BlB,SAAgB,WAAW,EAAE,KAAK,aAAa,WAAW;CAAC;CAAW;CAAiB;CAAY,EAAE,sBAAyD;AAC5J,QAAO,IAAI,WAAW;EACpB;EACA;EACA;EACD,CAAC"}
|
|
1
|
+
{"version":3,"file":"utils.cjs","names":["URLPath","SchemaGenerator","schemaKeywords","transformers"],"sources":["../src/utils/getComments.ts","../src/utils/getImports.ts","../src/utils/getParams.ts","../src/utils/getSchemas.ts","../src/utils/paramsCasing.ts"],"sourcesContent":["import { URLPath } from '@kubb/core/utils'\n\nimport type { Operation } from '@kubb/oas'\n\nexport function getComments(operation: Operation): string[] {\n return [\n operation.getDescription() && `@description ${operation.getDescription()}`,\n operation.getSummary() && `@summary ${operation.getSummary()}`,\n operation.path && `{@link ${new URLPath(operation.path).URL}}`,\n operation.isDeprecated() && '@deprecated',\n ]\n .filter(Boolean)\n .flatMap((text) => {\n // Split by newlines to preserve line breaks in JSDoc\n // Trim each line individually to remove leading/trailing whitespace\n return text.split(/\\r?\\n/).map((line) => line.trim())\n })\n .filter(Boolean)\n}\n","import type { KubbFile } from '@kubb/fabric-core/types'\nimport { SchemaGenerator } from '../SchemaGenerator.ts'\nimport type { Schema } from '../SchemaMapper'\nimport { schemaKeywords } from '../SchemaMapper'\n\n/**\n * Get imports from a schema tree by extracting all ref schemas that are importable\n */\nexport function getImports(tree: Array<Schema>): Array<KubbFile.Import> {\n const refs = SchemaGenerator.deepSearch(tree, schemaKeywords.ref)\n\n return refs\n ?.map((item) => {\n if (!item.args.path || !item.args.isImportable) {\n return undefined\n }\n\n return {\n name: [item.args.name],\n path: item.args.path,\n }\n })\n .filter(Boolean)\n}\n","import { camelCase, isValidVarName } from '@kubb/core/transformers'\nimport type { FunctionParamsAST } from '@kubb/core/utils'\nimport type { OasTypes } from '@kubb/oas'\nimport type { Params } from '@kubb/react-fabric/types'\nimport type { OperationSchema } from '../types.ts'\n/**\n *\n * @deprecated\n * TODO move to operationManager hook\n */\nexport function getASTParams(\n operationSchema: OperationSchema | undefined,\n {\n typed = false,\n casing,\n override,\n }: {\n typed?: boolean\n casing?: 'camelcase'\n override?: (data: FunctionParamsAST) => FunctionParamsAST\n } = {},\n): FunctionParamsAST[] {\n if (!operationSchema || !operationSchema.schema.properties || !operationSchema.name) {\n return []\n }\n\n const requiredFields = Array.isArray(operationSchema.schema.required) ? operationSchema.schema.required : []\n\n return Object.entries(operationSchema.schema.properties).map(([name]: [string, OasTypes.SchemaObject]) => {\n // Use camelCase name for indexed access if casing is enabled\n const accessName = casing === 'camelcase' ? camelCase(name) : name\n\n const data: FunctionParamsAST = {\n name,\n enabled: !!name,\n required: requiredFields.includes(name),\n type: typed ? `${operationSchema.name}[\"${accessName}\"]` : undefined,\n }\n\n return override ? override(data) : data\n })\n}\n\nexport function getPathParams(\n operationSchema: OperationSchema | undefined,\n options: {\n typed?: boolean\n casing?: 'camelcase'\n override?: (data: FunctionParamsAST) => FunctionParamsAST\n } = {},\n) {\n return getASTParams(operationSchema, options).reduce((acc, curr) => {\n if (curr.name && curr.enabled) {\n let name = curr.name\n\n // Only transform to camelCase if explicitly requested\n if (options.casing === 'camelcase') {\n name = camelCase(name)\n } else if (!isValidVarName(name)) {\n // If not valid variable name and casing not set, still need to make it valid\n name = camelCase(name)\n }\n\n acc[name] = {\n default: curr.default,\n type: curr.type,\n optional: !curr.required,\n }\n }\n\n return acc\n }, {} as Params)\n}\n\n/**\n * Get a mapping of camelCase parameter names to their original names\n * Used for mapping function parameters to backend parameter names\n */\nexport function getParamsMapping(\n operationSchema: OperationSchema | undefined,\n options: {\n casing?: 'camelcase'\n } = {},\n): Record<string, string> | undefined {\n if (!operationSchema || !operationSchema.schema.properties) {\n return undefined\n }\n\n const mapping: Record<string, string> = {}\n\n Object.entries(operationSchema.schema.properties).forEach(([originalName]) => {\n let transformedName = originalName\n\n // Only transform to camelCase if explicitly requested\n if (options.casing === 'camelcase') {\n transformedName = camelCase(originalName)\n } else if (!isValidVarName(originalName)) {\n // If not valid variable name and casing not set, still need to make it valid\n transformedName = camelCase(originalName)\n }\n\n // Only add mapping if the names differ\n if (transformedName !== originalName) {\n mapping[originalName] = transformedName\n }\n })\n\n return Object.keys(mapping).length > 0 ? mapping : undefined\n}\n","import type { contentType, Oas, OasTypes } from '@kubb/oas'\n\nexport type GetSchemasResult = {\n schemas: Record<string, OasTypes.SchemaObject>\n /**\n * Mapping from original component name to resolved name after collision handling\n * e.g., { 'Order': 'OrderSchema', 'variant': 'variant2' }\n */\n nameMapping: Map<string, string>\n}\n\ntype Mode = 'schemas' | 'responses' | 'requestBodies'\n\ntype GetSchemasProps = {\n oas: Oas\n contentType?: contentType\n includes?: Mode[]\n /**\n * Whether to resolve name collisions with suffixes.\n * If not provided, uses oas.options.collisionDetection\n * @default false (from oas.options or fallback)\n */\n collisionDetection?: boolean\n}\n\n/**\n * Collect schemas from OpenAPI components (schemas, responses, requestBodies)\n * and return them in dependency order along with name mapping for collision resolution.\n *\n * This function is a wrapper around the oas.getSchemas() method for backward compatibility.\n * New code should use oas.getSchemas() directly.\n *\n * @deprecated Use oas.getSchemas() instead\n */\nexport function getSchemas({ oas, contentType, includes = ['schemas', 'requestBodies', 'responses'], collisionDetection }: GetSchemasProps): GetSchemasResult {\n return oas.getSchemas({\n contentType,\n includes,\n collisionDetection,\n })\n}\n","import transformers, { isValidVarName } from '@kubb/core/transformers'\nimport type { SchemaObject } from '@kubb/oas'\n\n/**\n * Apply casing transformation to schema properties\n * Only transforms property names, not nested schemas\n */\nexport function applyParamsCasing(schema: SchemaObject, casing: 'camelcase' | undefined): SchemaObject {\n if (!casing || !schema.properties) {\n return schema\n }\n\n const transformedProperties: Record<string, any> = {}\n const transformedRequired: string[] = []\n\n // Transform property names\n Object.entries(schema.properties).forEach(([originalName, propertySchema]) => {\n let transformedName = originalName\n\n if (casing === 'camelcase') {\n transformedName = transformers.camelCase(originalName)\n } else if (!isValidVarName(originalName)) {\n // If not valid variable name, make it valid\n transformedName = transformers.camelCase(originalName)\n }\n\n transformedProperties[transformedName] = propertySchema\n })\n\n // Transform required field names\n if (Array.isArray(schema.required)) {\n schema.required.forEach((originalName) => {\n let transformedName = originalName\n\n if (casing === 'camelcase') {\n transformedName = transformers.camelCase(originalName)\n } else if (!isValidVarName(originalName)) {\n transformedName = transformers.camelCase(originalName)\n }\n\n transformedRequired.push(transformedName)\n })\n }\n\n // Return a new schema with transformed properties and required fields\n return {\n ...schema,\n properties: transformedProperties,\n ...(transformedRequired.length > 0 && { required: transformedRequired }),\n } as SchemaObject\n}\n\n/**\n * Check if this schema is a parameter schema (pathParams, queryParams, or headerParams)\n * Only these should be transformed, not response/data/body\n */\nexport function isParameterSchema(schemaName: string): boolean {\n const lowerName = schemaName.toLowerCase()\n return lowerName.includes('pathparams') || lowerName.includes('queryparams') || lowerName.includes('headerparams')\n}\n"],"mappings":";;;;;;;;;;AAIA,SAAgB,YAAY,WAAgC;AAC1D,QAAO;EACL,UAAU,gBAAgB,IAAI,gBAAgB,UAAU,gBAAgB;EACxE,UAAU,YAAY,IAAI,YAAY,UAAU,YAAY;EAC5D,UAAU,QAAQ,UAAU,IAAIA,yBAAQ,UAAU,KAAK,CAAC,IAAI;EAC5D,UAAU,cAAc,IAAI;EAC7B,CACE,OAAO,QAAQ,CACf,SAAS,SAAS;AAGjB,SAAO,KAAK,MAAM,QAAQ,CAAC,KAAK,SAAS,KAAK,MAAM,CAAC;GACrD,CACD,OAAO,QAAQ;;;;;;;;ACTpB,SAAgB,WAAW,MAA6C;AAGtE,QAFaC,wCAAgB,WAAW,MAAMC,oCAAe,IAAI,EAG7D,KAAK,SAAS;AACd,MAAI,CAAC,KAAK,KAAK,QAAQ,CAAC,KAAK,KAAK,aAChC;AAGF,SAAO;GACL,MAAM,CAAC,KAAK,KAAK,KAAK;GACtB,MAAM,KAAK,KAAK;GACjB;GACD,CACD,OAAO,QAAQ;;;;;;;;;;ACZpB,SAAgB,aACd,iBACA,EACE,QAAQ,OACR,QACA,aAKE,EAAE,EACe;AACrB,KAAI,CAAC,mBAAmB,CAAC,gBAAgB,OAAO,cAAc,CAAC,gBAAgB,KAC7E,QAAO,EAAE;CAGX,MAAM,iBAAiB,MAAM,QAAQ,gBAAgB,OAAO,SAAS,GAAG,gBAAgB,OAAO,WAAW,EAAE;AAE5G,QAAO,OAAO,QAAQ,gBAAgB,OAAO,WAAW,CAAC,KAAK,CAAC,UAA2C;EAExG,MAAM,aAAa,WAAW,qDAAwB,KAAK,GAAG;EAE9D,MAAM,OAA0B;GAC9B;GACA,SAAS,CAAC,CAAC;GACX,UAAU,eAAe,SAAS,KAAK;GACvC,MAAM,QAAQ,GAAG,gBAAgB,KAAK,IAAI,WAAW,MAAM;GAC5D;AAED,SAAO,WAAW,SAAS,KAAK,GAAG;GACnC;;AAGJ,SAAgB,cACd,iBACA,UAII,EAAE,EACN;AACA,QAAO,aAAa,iBAAiB,QAAQ,CAAC,QAAQ,KAAK,SAAS;AAClE,MAAI,KAAK,QAAQ,KAAK,SAAS;GAC7B,IAAI,OAAO,KAAK;AAGhB,OAAI,QAAQ,WAAW,YACrB,+CAAiB,KAAK;YACb,6CAAgB,KAAK,CAE9B,+CAAiB,KAAK;AAGxB,OAAI,QAAQ;IACV,SAAS,KAAK;IACd,MAAM,KAAK;IACX,UAAU,CAAC,KAAK;IACjB;;AAGH,SAAO;IACN,EAAE,CAAW;;;;;;AAOlB,SAAgB,iBACd,iBACA,UAEI,EAAE,EAC8B;AACpC,KAAI,CAAC,mBAAmB,CAAC,gBAAgB,OAAO,WAC9C;CAGF,MAAM,UAAkC,EAAE;AAE1C,QAAO,QAAQ,gBAAgB,OAAO,WAAW,CAAC,SAAS,CAAC,kBAAkB;EAC5E,IAAI,kBAAkB;AAGtB,MAAI,QAAQ,WAAW,YACrB,0DAA4B,aAAa;WAChC,6CAAgB,aAAa,CAEtC,0DAA4B,aAAa;AAI3C,MAAI,oBAAoB,aACtB,SAAQ,gBAAgB;GAE1B;AAEF,QAAO,OAAO,KAAK,QAAQ,CAAC,SAAS,IAAI,UAAU;;;;;;;;;;;;;;ACzErD,SAAgB,WAAW,EAAE,KAAK,aAAa,WAAW;CAAC;CAAW;CAAiB;CAAY,EAAE,sBAAyD;AAC5J,QAAO,IAAI,WAAW;EACpB;EACA;EACA;EACD,CAAC;;;;;;;;;AChCJ,SAAgB,kBAAkB,QAAsB,QAA+C;AACrG,KAAI,CAAC,UAAU,CAAC,OAAO,WACrB,QAAO;CAGT,MAAM,wBAA6C,EAAE;CACrD,MAAM,sBAAgC,EAAE;AAGxC,QAAO,QAAQ,OAAO,WAAW,CAAC,SAAS,CAAC,cAAc,oBAAoB;EAC5E,IAAI,kBAAkB;AAEtB,MAAI,WAAW,YACb,mBAAkBC,gCAAa,UAAU,aAAa;WAC7C,6CAAgB,aAAa,CAEtC,mBAAkBA,gCAAa,UAAU,aAAa;AAGxD,wBAAsB,mBAAmB;GACzC;AAGF,KAAI,MAAM,QAAQ,OAAO,SAAS,CAChC,QAAO,SAAS,SAAS,iBAAiB;EACxC,IAAI,kBAAkB;AAEtB,MAAI,WAAW,YACb,mBAAkBA,gCAAa,UAAU,aAAa;WAC7C,6CAAgB,aAAa,CACtC,mBAAkBA,gCAAa,UAAU,aAAa;AAGxD,sBAAoB,KAAK,gBAAgB;GACzC;AAIJ,QAAO;EACL,GAAG;EACH,YAAY;EACZ,GAAI,oBAAoB,SAAS,KAAK,EAAE,UAAU,qBAAqB;EACxE;;;;;;AAOH,SAAgB,kBAAkB,YAA6B;CAC7D,MAAM,YAAY,WAAW,aAAa;AAC1C,QAAO,UAAU,SAAS,aAAa,IAAI,UAAU,SAAS,cAAc,IAAI,UAAU,SAAS,eAAe"}
|
package/dist/utils.d.cts
CHANGED
|
@@ -41,6 +41,13 @@ declare function getPathParams(operationSchema: OperationSchema | undefined, opt
|
|
|
41
41
|
casing?: 'camelcase';
|
|
42
42
|
override?: (data: FunctionParamsAST) => FunctionParamsAST;
|
|
43
43
|
}): Params;
|
|
44
|
+
/**
|
|
45
|
+
* Get a mapping of camelCase parameter names to their original names
|
|
46
|
+
* Used for mapping function parameters to backend parameter names
|
|
47
|
+
*/
|
|
48
|
+
declare function getParamsMapping(operationSchema: OperationSchema | undefined, options?: {
|
|
49
|
+
casing?: 'camelcase';
|
|
50
|
+
}): Record<string, string> | undefined;
|
|
44
51
|
//#endregion
|
|
45
52
|
//#region src/utils/getSchemaFactory.d.ts
|
|
46
53
|
/**
|
|
@@ -105,5 +112,17 @@ declare function getSchemas({
|
|
|
105
112
|
collisionDetection
|
|
106
113
|
}: GetSchemasProps): GetSchemasResult;
|
|
107
114
|
//#endregion
|
|
108
|
-
|
|
115
|
+
//#region src/utils/paramsCasing.d.ts
|
|
116
|
+
/**
|
|
117
|
+
* Apply casing transformation to schema properties
|
|
118
|
+
* Only transforms property names, not nested schemas
|
|
119
|
+
*/
|
|
120
|
+
declare function applyParamsCasing(schema: SchemaObject, casing: 'camelcase' | undefined): SchemaObject;
|
|
121
|
+
/**
|
|
122
|
+
* Check if this schema is a parameter schema (pathParams, queryParams, or headerParams)
|
|
123
|
+
* Only these should be transformed, not response/data/body
|
|
124
|
+
*/
|
|
125
|
+
declare function isParameterSchema(schemaName: string): boolean;
|
|
126
|
+
//#endregion
|
|
127
|
+
export { applyParamsCasing, getBanner, getComments, getFooter, getImports, getParamsMapping, getPathParams, getSchemaFactory, getSchemas, isOptional, isParameterSchema };
|
|
109
128
|
//# sourceMappingURL=utils.d.cts.map
|
package/dist/utils.d.ts
CHANGED
|
@@ -42,6 +42,13 @@ declare function getPathParams(operationSchema: OperationSchema | undefined, opt
|
|
|
42
42
|
casing?: 'camelcase';
|
|
43
43
|
override?: (data: FunctionParamsAST) => FunctionParamsAST;
|
|
44
44
|
}): Params;
|
|
45
|
+
/**
|
|
46
|
+
* Get a mapping of camelCase parameter names to their original names
|
|
47
|
+
* Used for mapping function parameters to backend parameter names
|
|
48
|
+
*/
|
|
49
|
+
declare function getParamsMapping(operationSchema: OperationSchema | undefined, options?: {
|
|
50
|
+
casing?: 'camelcase';
|
|
51
|
+
}): Record<string, string> | undefined;
|
|
45
52
|
//#endregion
|
|
46
53
|
//#region src/utils/getSchemaFactory.d.ts
|
|
47
54
|
/**
|
|
@@ -106,5 +113,17 @@ declare function getSchemas({
|
|
|
106
113
|
collisionDetection
|
|
107
114
|
}: GetSchemasProps): GetSchemasResult;
|
|
108
115
|
//#endregion
|
|
109
|
-
|
|
116
|
+
//#region src/utils/paramsCasing.d.ts
|
|
117
|
+
/**
|
|
118
|
+
* Apply casing transformation to schema properties
|
|
119
|
+
* Only transforms property names, not nested schemas
|
|
120
|
+
*/
|
|
121
|
+
declare function applyParamsCasing(schema: SchemaObject, casing: 'camelcase' | undefined): SchemaObject;
|
|
122
|
+
/**
|
|
123
|
+
* Check if this schema is a parameter schema (pathParams, queryParams, or headerParams)
|
|
124
|
+
* Only these should be transformed, not response/data/body
|
|
125
|
+
*/
|
|
126
|
+
declare function isParameterSchema(schemaName: string): boolean;
|
|
127
|
+
//#endregion
|
|
128
|
+
export { applyParamsCasing, getBanner, getComments, getFooter, getImports, getParamsMapping, getPathParams, getSchemaFactory, getSchemas, isOptional, isParameterSchema };
|
|
110
129
|
//# sourceMappingURL=utils.d.ts.map
|
package/dist/utils.js
CHANGED
|
@@ -2,7 +2,7 @@ import { t as __name } from "./chunk-iVr_oF3V.js";
|
|
|
2
2
|
import { a as getSchemaFactory, t as SchemaGenerator } from "./SchemaGenerator-B3d6gOW8.js";
|
|
3
3
|
import { n as schemaKeywords } from "./SchemaMapper-D-GETHNf.js";
|
|
4
4
|
import { n as getBanner, t as getFooter } from "./getFooter-flVUU6wg.js";
|
|
5
|
-
import { camelCase, isValidVarName } from "@kubb/core/transformers";
|
|
5
|
+
import transformers, { camelCase, isValidVarName } from "@kubb/core/transformers";
|
|
6
6
|
import { URLPath } from "@kubb/core/utils";
|
|
7
7
|
import { isOptional } from "@kubb/oas";
|
|
8
8
|
|
|
@@ -40,15 +40,16 @@ function getImports(tree) {
|
|
|
40
40
|
* @deprecated
|
|
41
41
|
* TODO move to operationManager hook
|
|
42
42
|
*/
|
|
43
|
-
function getASTParams(operationSchema, { typed = false, override } = {}) {
|
|
43
|
+
function getASTParams(operationSchema, { typed = false, casing, override } = {}) {
|
|
44
44
|
if (!operationSchema || !operationSchema.schema.properties || !operationSchema.name) return [];
|
|
45
45
|
const requiredFields = Array.isArray(operationSchema.schema.required) ? operationSchema.schema.required : [];
|
|
46
46
|
return Object.entries(operationSchema.schema.properties).map(([name]) => {
|
|
47
|
+
const accessName = casing === "camelcase" ? camelCase(name) : name;
|
|
47
48
|
const data = {
|
|
48
49
|
name,
|
|
49
50
|
enabled: !!name,
|
|
50
51
|
required: requiredFields.includes(name),
|
|
51
|
-
type: typed ? `${operationSchema.name}["${
|
|
52
|
+
type: typed ? `${operationSchema.name}["${accessName}"]` : void 0
|
|
52
53
|
};
|
|
53
54
|
return override ? override(data) : data;
|
|
54
55
|
});
|
|
@@ -56,8 +57,9 @@ function getASTParams(operationSchema, { typed = false, override } = {}) {
|
|
|
56
57
|
function getPathParams(operationSchema, options = {}) {
|
|
57
58
|
return getASTParams(operationSchema, options).reduce((acc, curr) => {
|
|
58
59
|
if (curr.name && curr.enabled) {
|
|
59
|
-
let name =
|
|
60
|
+
let name = curr.name;
|
|
60
61
|
if (options.casing === "camelcase") name = camelCase(name);
|
|
62
|
+
else if (!isValidVarName(name)) name = camelCase(name);
|
|
61
63
|
acc[name] = {
|
|
62
64
|
default: curr.default,
|
|
63
65
|
type: curr.type,
|
|
@@ -67,6 +69,21 @@ function getPathParams(operationSchema, options = {}) {
|
|
|
67
69
|
return acc;
|
|
68
70
|
}, {});
|
|
69
71
|
}
|
|
72
|
+
/**
|
|
73
|
+
* Get a mapping of camelCase parameter names to their original names
|
|
74
|
+
* Used for mapping function parameters to backend parameter names
|
|
75
|
+
*/
|
|
76
|
+
function getParamsMapping(operationSchema, options = {}) {
|
|
77
|
+
if (!operationSchema || !operationSchema.schema.properties) return;
|
|
78
|
+
const mapping = {};
|
|
79
|
+
Object.entries(operationSchema.schema.properties).forEach(([originalName]) => {
|
|
80
|
+
let transformedName = originalName;
|
|
81
|
+
if (options.casing === "camelcase") transformedName = camelCase(originalName);
|
|
82
|
+
else if (!isValidVarName(originalName)) transformedName = camelCase(originalName);
|
|
83
|
+
if (transformedName !== originalName) mapping[originalName] = transformedName;
|
|
84
|
+
});
|
|
85
|
+
return Object.keys(mapping).length > 0 ? mapping : void 0;
|
|
86
|
+
}
|
|
70
87
|
|
|
71
88
|
//#endregion
|
|
72
89
|
//#region src/utils/getSchemas.ts
|
|
@@ -92,5 +109,42 @@ function getSchemas({ oas, contentType, includes = [
|
|
|
92
109
|
}
|
|
93
110
|
|
|
94
111
|
//#endregion
|
|
95
|
-
|
|
112
|
+
//#region src/utils/paramsCasing.ts
|
|
113
|
+
/**
|
|
114
|
+
* Apply casing transformation to schema properties
|
|
115
|
+
* Only transforms property names, not nested schemas
|
|
116
|
+
*/
|
|
117
|
+
function applyParamsCasing(schema, casing) {
|
|
118
|
+
if (!casing || !schema.properties) return schema;
|
|
119
|
+
const transformedProperties = {};
|
|
120
|
+
const transformedRequired = [];
|
|
121
|
+
Object.entries(schema.properties).forEach(([originalName, propertySchema]) => {
|
|
122
|
+
let transformedName = originalName;
|
|
123
|
+
if (casing === "camelcase") transformedName = transformers.camelCase(originalName);
|
|
124
|
+
else if (!isValidVarName(originalName)) transformedName = transformers.camelCase(originalName);
|
|
125
|
+
transformedProperties[transformedName] = propertySchema;
|
|
126
|
+
});
|
|
127
|
+
if (Array.isArray(schema.required)) schema.required.forEach((originalName) => {
|
|
128
|
+
let transformedName = originalName;
|
|
129
|
+
if (casing === "camelcase") transformedName = transformers.camelCase(originalName);
|
|
130
|
+
else if (!isValidVarName(originalName)) transformedName = transformers.camelCase(originalName);
|
|
131
|
+
transformedRequired.push(transformedName);
|
|
132
|
+
});
|
|
133
|
+
return {
|
|
134
|
+
...schema,
|
|
135
|
+
properties: transformedProperties,
|
|
136
|
+
...transformedRequired.length > 0 && { required: transformedRequired }
|
|
137
|
+
};
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* Check if this schema is a parameter schema (pathParams, queryParams, or headerParams)
|
|
141
|
+
* Only these should be transformed, not response/data/body
|
|
142
|
+
*/
|
|
143
|
+
function isParameterSchema(schemaName) {
|
|
144
|
+
const lowerName = schemaName.toLowerCase();
|
|
145
|
+
return lowerName.includes("pathparams") || lowerName.includes("queryparams") || lowerName.includes("headerparams");
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
//#endregion
|
|
149
|
+
export { applyParamsCasing, getBanner, getComments, getFooter, getImports, getParamsMapping, getPathParams, getSchemaFactory, getSchemas, isOptional, isParameterSchema };
|
|
96
150
|
//# sourceMappingURL=utils.js.map
|
package/dist/utils.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","names":[],"sources":["../src/utils/getComments.ts","../src/utils/getImports.ts","../src/utils/getParams.ts","../src/utils/getSchemas.ts"],"sourcesContent":["import { URLPath } from '@kubb/core/utils'\n\nimport type { Operation } from '@kubb/oas'\n\nexport function getComments(operation: Operation): string[] {\n return [\n operation.getDescription() && `@description ${operation.getDescription()}`,\n operation.getSummary() && `@summary ${operation.getSummary()}`,\n operation.path && `{@link ${new URLPath(operation.path).URL}}`,\n operation.isDeprecated() && '@deprecated',\n ]\n .filter(Boolean)\n .flatMap((text) => {\n // Split by newlines to preserve line breaks in JSDoc\n // Trim each line individually to remove leading/trailing whitespace\n return text.split(/\\r?\\n/).map((line) => line.trim())\n })\n .filter(Boolean)\n}\n","import type { KubbFile } from '@kubb/fabric-core/types'\nimport { SchemaGenerator } from '../SchemaGenerator.ts'\nimport type { Schema } from '../SchemaMapper'\nimport { schemaKeywords } from '../SchemaMapper'\n\n/**\n * Get imports from a schema tree by extracting all ref schemas that are importable\n */\nexport function getImports(tree: Array<Schema>): Array<KubbFile.Import> {\n const refs = SchemaGenerator.deepSearch(tree, schemaKeywords.ref)\n\n return refs\n ?.map((item) => {\n if (!item.args.path || !item.args.isImportable) {\n return undefined\n }\n\n return {\n name: [item.args.name],\n path: item.args.path,\n }\n })\n .filter(Boolean)\n}\n","import { camelCase, isValidVarName } from '@kubb/core/transformers'\nimport type { FunctionParamsAST } from '@kubb/core/utils'\nimport type { OasTypes } from '@kubb/oas'\nimport type { Params } from '@kubb/react-fabric/types'\nimport type { OperationSchema } from '../types.ts'\n/**\n *\n * @deprecated\n * TODO move to operationManager hook\n */\nexport function getASTParams(\n operationSchema: OperationSchema | undefined,\n {\n typed = false,\n override,\n }: {\n typed?: boolean\n override?: (data: FunctionParamsAST) => FunctionParamsAST\n } = {},\n): FunctionParamsAST[] {\n if (!operationSchema || !operationSchema.schema.properties || !operationSchema.name) {\n return []\n }\n\n const requiredFields = Array.isArray(operationSchema.schema.required) ? operationSchema.schema.required : []\n\n return Object.entries(operationSchema.schema.properties).map(([name]: [string, OasTypes.SchemaObject]) => {\n const data: FunctionParamsAST = {\n name,\n enabled: !!name,\n required: requiredFields.includes(name),\n type: typed ? `${operationSchema.name}[\"${name}\"]` : undefined,\n }\n\n return override ? override(data) : data\n })\n}\n\nexport function getPathParams(\n operationSchema: OperationSchema | undefined,\n options: {\n typed?: boolean\n casing?: 'camelcase'\n override?: (data: FunctionParamsAST) => FunctionParamsAST\n } = {},\n) {\n return getASTParams(operationSchema, options).reduce((acc, curr) => {\n if (curr.name && curr.enabled) {\n let name = isValidVarName(curr.name) ? curr.name : camelCase(curr.name)\n\n if (options.casing === 'camelcase') {\n name = camelCase(name)\n }\n\n acc[name] = {\n default: curr.default,\n type: curr.type,\n optional: !curr.required,\n }\n }\n\n return acc\n }, {} as Params)\n}\n","import type { contentType, Oas, OasTypes } from '@kubb/oas'\n\nexport type GetSchemasResult = {\n schemas: Record<string, OasTypes.SchemaObject>\n /**\n * Mapping from original component name to resolved name after collision handling\n * e.g., { 'Order': 'OrderSchema', 'variant': 'variant2' }\n */\n nameMapping: Map<string, string>\n}\n\ntype Mode = 'schemas' | 'responses' | 'requestBodies'\n\ntype GetSchemasProps = {\n oas: Oas\n contentType?: contentType\n includes?: Mode[]\n /**\n * Whether to resolve name collisions with suffixes.\n * If not provided, uses oas.options.collisionDetection\n * @default false (from oas.options or fallback)\n */\n collisionDetection?: boolean\n}\n\n/**\n * Collect schemas from OpenAPI components (schemas, responses, requestBodies)\n * and return them in dependency order along with name mapping for collision resolution.\n *\n * This function is a wrapper around the oas.getSchemas() method for backward compatibility.\n * New code should use oas.getSchemas() directly.\n *\n * @deprecated Use oas.getSchemas() instead\n */\nexport function getSchemas({ oas, contentType, includes = ['schemas', 'requestBodies', 'responses'], collisionDetection }: GetSchemasProps): GetSchemasResult {\n return oas.getSchemas({\n contentType,\n includes,\n collisionDetection,\n })\n}\n"],"mappings":";;;;;;;;;AAIA,SAAgB,YAAY,WAAgC;AAC1D,QAAO;EACL,UAAU,gBAAgB,IAAI,gBAAgB,UAAU,gBAAgB;EACxE,UAAU,YAAY,IAAI,YAAY,UAAU,YAAY;EAC5D,UAAU,QAAQ,UAAU,IAAI,QAAQ,UAAU,KAAK,CAAC,IAAI;EAC5D,UAAU,cAAc,IAAI;EAC7B,CACE,OAAO,QAAQ,CACf,SAAS,SAAS;AAGjB,SAAO,KAAK,MAAM,QAAQ,CAAC,KAAK,SAAS,KAAK,MAAM,CAAC;GACrD,CACD,OAAO,QAAQ;;;;;;;;ACTpB,SAAgB,WAAW,MAA6C;AAGtE,QAFa,gBAAgB,WAAW,MAAM,eAAe,IAAI,EAG7D,KAAK,SAAS;AACd,MAAI,CAAC,KAAK,KAAK,QAAQ,CAAC,KAAK,KAAK,aAChC;AAGF,SAAO;GACL,MAAM,CAAC,KAAK,KAAK,KAAK;GACtB,MAAM,KAAK,KAAK;GACjB;GACD,CACD,OAAO,QAAQ;;;;;;;;;;ACZpB,SAAgB,aACd,iBACA,EACE,QAAQ,OACR,aAIE,EAAE,EACe;AACrB,KAAI,CAAC,mBAAmB,CAAC,gBAAgB,OAAO,cAAc,CAAC,gBAAgB,KAC7E,QAAO,EAAE;CAGX,MAAM,iBAAiB,MAAM,QAAQ,gBAAgB,OAAO,SAAS,GAAG,gBAAgB,OAAO,WAAW,EAAE;AAE5G,QAAO,OAAO,QAAQ,gBAAgB,OAAO,WAAW,CAAC,KAAK,CAAC,UAA2C;EACxG,MAAM,OAA0B;GAC9B;GACA,SAAS,CAAC,CAAC;GACX,UAAU,eAAe,SAAS,KAAK;GACvC,MAAM,QAAQ,GAAG,gBAAgB,KAAK,IAAI,KAAK,MAAM;GACtD;AAED,SAAO,WAAW,SAAS,KAAK,GAAG;GACnC;;AAGJ,SAAgB,cACd,iBACA,UAII,EAAE,EACN;AACA,QAAO,aAAa,iBAAiB,QAAQ,CAAC,QAAQ,KAAK,SAAS;AAClE,MAAI,KAAK,QAAQ,KAAK,SAAS;GAC7B,IAAI,OAAO,eAAe,KAAK,KAAK,GAAG,KAAK,OAAO,UAAU,KAAK,KAAK;AAEvE,OAAI,QAAQ,WAAW,YACrB,QAAO,UAAU,KAAK;AAGxB,OAAI,QAAQ;IACV,SAAS,KAAK;IACd,MAAM,KAAK;IACX,UAAU,CAAC,KAAK;IACjB;;AAGH,SAAO;IACN,EAAE,CAAW;;;;;;;;;;;;;;AC5BlB,SAAgB,WAAW,EAAE,KAAK,aAAa,WAAW;CAAC;CAAW;CAAiB;CAAY,EAAE,sBAAyD;AAC5J,QAAO,IAAI,WAAW;EACpB;EACA;EACA;EACD,CAAC"}
|
|
1
|
+
{"version":3,"file":"utils.js","names":[],"sources":["../src/utils/getComments.ts","../src/utils/getImports.ts","../src/utils/getParams.ts","../src/utils/getSchemas.ts","../src/utils/paramsCasing.ts"],"sourcesContent":["import { URLPath } from '@kubb/core/utils'\n\nimport type { Operation } from '@kubb/oas'\n\nexport function getComments(operation: Operation): string[] {\n return [\n operation.getDescription() && `@description ${operation.getDescription()}`,\n operation.getSummary() && `@summary ${operation.getSummary()}`,\n operation.path && `{@link ${new URLPath(operation.path).URL}}`,\n operation.isDeprecated() && '@deprecated',\n ]\n .filter(Boolean)\n .flatMap((text) => {\n // Split by newlines to preserve line breaks in JSDoc\n // Trim each line individually to remove leading/trailing whitespace\n return text.split(/\\r?\\n/).map((line) => line.trim())\n })\n .filter(Boolean)\n}\n","import type { KubbFile } from '@kubb/fabric-core/types'\nimport { SchemaGenerator } from '../SchemaGenerator.ts'\nimport type { Schema } from '../SchemaMapper'\nimport { schemaKeywords } from '../SchemaMapper'\n\n/**\n * Get imports from a schema tree by extracting all ref schemas that are importable\n */\nexport function getImports(tree: Array<Schema>): Array<KubbFile.Import> {\n const refs = SchemaGenerator.deepSearch(tree, schemaKeywords.ref)\n\n return refs\n ?.map((item) => {\n if (!item.args.path || !item.args.isImportable) {\n return undefined\n }\n\n return {\n name: [item.args.name],\n path: item.args.path,\n }\n })\n .filter(Boolean)\n}\n","import { camelCase, isValidVarName } from '@kubb/core/transformers'\nimport type { FunctionParamsAST } from '@kubb/core/utils'\nimport type { OasTypes } from '@kubb/oas'\nimport type { Params } from '@kubb/react-fabric/types'\nimport type { OperationSchema } from '../types.ts'\n/**\n *\n * @deprecated\n * TODO move to operationManager hook\n */\nexport function getASTParams(\n operationSchema: OperationSchema | undefined,\n {\n typed = false,\n casing,\n override,\n }: {\n typed?: boolean\n casing?: 'camelcase'\n override?: (data: FunctionParamsAST) => FunctionParamsAST\n } = {},\n): FunctionParamsAST[] {\n if (!operationSchema || !operationSchema.schema.properties || !operationSchema.name) {\n return []\n }\n\n const requiredFields = Array.isArray(operationSchema.schema.required) ? operationSchema.schema.required : []\n\n return Object.entries(operationSchema.schema.properties).map(([name]: [string, OasTypes.SchemaObject]) => {\n // Use camelCase name for indexed access if casing is enabled\n const accessName = casing === 'camelcase' ? camelCase(name) : name\n\n const data: FunctionParamsAST = {\n name,\n enabled: !!name,\n required: requiredFields.includes(name),\n type: typed ? `${operationSchema.name}[\"${accessName}\"]` : undefined,\n }\n\n return override ? override(data) : data\n })\n}\n\nexport function getPathParams(\n operationSchema: OperationSchema | undefined,\n options: {\n typed?: boolean\n casing?: 'camelcase'\n override?: (data: FunctionParamsAST) => FunctionParamsAST\n } = {},\n) {\n return getASTParams(operationSchema, options).reduce((acc, curr) => {\n if (curr.name && curr.enabled) {\n let name = curr.name\n\n // Only transform to camelCase if explicitly requested\n if (options.casing === 'camelcase') {\n name = camelCase(name)\n } else if (!isValidVarName(name)) {\n // If not valid variable name and casing not set, still need to make it valid\n name = camelCase(name)\n }\n\n acc[name] = {\n default: curr.default,\n type: curr.type,\n optional: !curr.required,\n }\n }\n\n return acc\n }, {} as Params)\n}\n\n/**\n * Get a mapping of camelCase parameter names to their original names\n * Used for mapping function parameters to backend parameter names\n */\nexport function getParamsMapping(\n operationSchema: OperationSchema | undefined,\n options: {\n casing?: 'camelcase'\n } = {},\n): Record<string, string> | undefined {\n if (!operationSchema || !operationSchema.schema.properties) {\n return undefined\n }\n\n const mapping: Record<string, string> = {}\n\n Object.entries(operationSchema.schema.properties).forEach(([originalName]) => {\n let transformedName = originalName\n\n // Only transform to camelCase if explicitly requested\n if (options.casing === 'camelcase') {\n transformedName = camelCase(originalName)\n } else if (!isValidVarName(originalName)) {\n // If not valid variable name and casing not set, still need to make it valid\n transformedName = camelCase(originalName)\n }\n\n // Only add mapping if the names differ\n if (transformedName !== originalName) {\n mapping[originalName] = transformedName\n }\n })\n\n return Object.keys(mapping).length > 0 ? mapping : undefined\n}\n","import type { contentType, Oas, OasTypes } from '@kubb/oas'\n\nexport type GetSchemasResult = {\n schemas: Record<string, OasTypes.SchemaObject>\n /**\n * Mapping from original component name to resolved name after collision handling\n * e.g., { 'Order': 'OrderSchema', 'variant': 'variant2' }\n */\n nameMapping: Map<string, string>\n}\n\ntype Mode = 'schemas' | 'responses' | 'requestBodies'\n\ntype GetSchemasProps = {\n oas: Oas\n contentType?: contentType\n includes?: Mode[]\n /**\n * Whether to resolve name collisions with suffixes.\n * If not provided, uses oas.options.collisionDetection\n * @default false (from oas.options or fallback)\n */\n collisionDetection?: boolean\n}\n\n/**\n * Collect schemas from OpenAPI components (schemas, responses, requestBodies)\n * and return them in dependency order along with name mapping for collision resolution.\n *\n * This function is a wrapper around the oas.getSchemas() method for backward compatibility.\n * New code should use oas.getSchemas() directly.\n *\n * @deprecated Use oas.getSchemas() instead\n */\nexport function getSchemas({ oas, contentType, includes = ['schemas', 'requestBodies', 'responses'], collisionDetection }: GetSchemasProps): GetSchemasResult {\n return oas.getSchemas({\n contentType,\n includes,\n collisionDetection,\n })\n}\n","import transformers, { isValidVarName } from '@kubb/core/transformers'\nimport type { SchemaObject } from '@kubb/oas'\n\n/**\n * Apply casing transformation to schema properties\n * Only transforms property names, not nested schemas\n */\nexport function applyParamsCasing(schema: SchemaObject, casing: 'camelcase' | undefined): SchemaObject {\n if (!casing || !schema.properties) {\n return schema\n }\n\n const transformedProperties: Record<string, any> = {}\n const transformedRequired: string[] = []\n\n // Transform property names\n Object.entries(schema.properties).forEach(([originalName, propertySchema]) => {\n let transformedName = originalName\n\n if (casing === 'camelcase') {\n transformedName = transformers.camelCase(originalName)\n } else if (!isValidVarName(originalName)) {\n // If not valid variable name, make it valid\n transformedName = transformers.camelCase(originalName)\n }\n\n transformedProperties[transformedName] = propertySchema\n })\n\n // Transform required field names\n if (Array.isArray(schema.required)) {\n schema.required.forEach((originalName) => {\n let transformedName = originalName\n\n if (casing === 'camelcase') {\n transformedName = transformers.camelCase(originalName)\n } else if (!isValidVarName(originalName)) {\n transformedName = transformers.camelCase(originalName)\n }\n\n transformedRequired.push(transformedName)\n })\n }\n\n // Return a new schema with transformed properties and required fields\n return {\n ...schema,\n properties: transformedProperties,\n ...(transformedRequired.length > 0 && { required: transformedRequired }),\n } as SchemaObject\n}\n\n/**\n * Check if this schema is a parameter schema (pathParams, queryParams, or headerParams)\n * Only these should be transformed, not response/data/body\n */\nexport function isParameterSchema(schemaName: string): boolean {\n const lowerName = schemaName.toLowerCase()\n return lowerName.includes('pathparams') || lowerName.includes('queryparams') || lowerName.includes('headerparams')\n}\n"],"mappings":";;;;;;;;;AAIA,SAAgB,YAAY,WAAgC;AAC1D,QAAO;EACL,UAAU,gBAAgB,IAAI,gBAAgB,UAAU,gBAAgB;EACxE,UAAU,YAAY,IAAI,YAAY,UAAU,YAAY;EAC5D,UAAU,QAAQ,UAAU,IAAI,QAAQ,UAAU,KAAK,CAAC,IAAI;EAC5D,UAAU,cAAc,IAAI;EAC7B,CACE,OAAO,QAAQ,CACf,SAAS,SAAS;AAGjB,SAAO,KAAK,MAAM,QAAQ,CAAC,KAAK,SAAS,KAAK,MAAM,CAAC;GACrD,CACD,OAAO,QAAQ;;;;;;;;ACTpB,SAAgB,WAAW,MAA6C;AAGtE,QAFa,gBAAgB,WAAW,MAAM,eAAe,IAAI,EAG7D,KAAK,SAAS;AACd,MAAI,CAAC,KAAK,KAAK,QAAQ,CAAC,KAAK,KAAK,aAChC;AAGF,SAAO;GACL,MAAM,CAAC,KAAK,KAAK,KAAK;GACtB,MAAM,KAAK,KAAK;GACjB;GACD,CACD,OAAO,QAAQ;;;;;;;;;;ACZpB,SAAgB,aACd,iBACA,EACE,QAAQ,OACR,QACA,aAKE,EAAE,EACe;AACrB,KAAI,CAAC,mBAAmB,CAAC,gBAAgB,OAAO,cAAc,CAAC,gBAAgB,KAC7E,QAAO,EAAE;CAGX,MAAM,iBAAiB,MAAM,QAAQ,gBAAgB,OAAO,SAAS,GAAG,gBAAgB,OAAO,WAAW,EAAE;AAE5G,QAAO,OAAO,QAAQ,gBAAgB,OAAO,WAAW,CAAC,KAAK,CAAC,UAA2C;EAExG,MAAM,aAAa,WAAW,cAAc,UAAU,KAAK,GAAG;EAE9D,MAAM,OAA0B;GAC9B;GACA,SAAS,CAAC,CAAC;GACX,UAAU,eAAe,SAAS,KAAK;GACvC,MAAM,QAAQ,GAAG,gBAAgB,KAAK,IAAI,WAAW,MAAM;GAC5D;AAED,SAAO,WAAW,SAAS,KAAK,GAAG;GACnC;;AAGJ,SAAgB,cACd,iBACA,UAII,EAAE,EACN;AACA,QAAO,aAAa,iBAAiB,QAAQ,CAAC,QAAQ,KAAK,SAAS;AAClE,MAAI,KAAK,QAAQ,KAAK,SAAS;GAC7B,IAAI,OAAO,KAAK;AAGhB,OAAI,QAAQ,WAAW,YACrB,QAAO,UAAU,KAAK;YACb,CAAC,eAAe,KAAK,CAE9B,QAAO,UAAU,KAAK;AAGxB,OAAI,QAAQ;IACV,SAAS,KAAK;IACd,MAAM,KAAK;IACX,UAAU,CAAC,KAAK;IACjB;;AAGH,SAAO;IACN,EAAE,CAAW;;;;;;AAOlB,SAAgB,iBACd,iBACA,UAEI,EAAE,EAC8B;AACpC,KAAI,CAAC,mBAAmB,CAAC,gBAAgB,OAAO,WAC9C;CAGF,MAAM,UAAkC,EAAE;AAE1C,QAAO,QAAQ,gBAAgB,OAAO,WAAW,CAAC,SAAS,CAAC,kBAAkB;EAC5E,IAAI,kBAAkB;AAGtB,MAAI,QAAQ,WAAW,YACrB,mBAAkB,UAAU,aAAa;WAChC,CAAC,eAAe,aAAa,CAEtC,mBAAkB,UAAU,aAAa;AAI3C,MAAI,oBAAoB,aACtB,SAAQ,gBAAgB;GAE1B;AAEF,QAAO,OAAO,KAAK,QAAQ,CAAC,SAAS,IAAI,UAAU;;;;;;;;;;;;;;ACzErD,SAAgB,WAAW,EAAE,KAAK,aAAa,WAAW;CAAC;CAAW;CAAiB;CAAY,EAAE,sBAAyD;AAC5J,QAAO,IAAI,WAAW;EACpB;EACA;EACA;EACD,CAAC;;;;;;;;;AChCJ,SAAgB,kBAAkB,QAAsB,QAA+C;AACrG,KAAI,CAAC,UAAU,CAAC,OAAO,WACrB,QAAO;CAGT,MAAM,wBAA6C,EAAE;CACrD,MAAM,sBAAgC,EAAE;AAGxC,QAAO,QAAQ,OAAO,WAAW,CAAC,SAAS,CAAC,cAAc,oBAAoB;EAC5E,IAAI,kBAAkB;AAEtB,MAAI,WAAW,YACb,mBAAkB,aAAa,UAAU,aAAa;WAC7C,CAAC,eAAe,aAAa,CAEtC,mBAAkB,aAAa,UAAU,aAAa;AAGxD,wBAAsB,mBAAmB;GACzC;AAGF,KAAI,MAAM,QAAQ,OAAO,SAAS,CAChC,QAAO,SAAS,SAAS,iBAAiB;EACxC,IAAI,kBAAkB;AAEtB,MAAI,WAAW,YACb,mBAAkB,aAAa,UAAU,aAAa;WAC7C,CAAC,eAAe,aAAa,CACtC,mBAAkB,aAAa,UAAU,aAAa;AAGxD,sBAAoB,KAAK,gBAAgB;GACzC;AAIJ,QAAO;EACL,GAAG;EACH,YAAY;EACZ,GAAI,oBAAoB,SAAS,KAAK,EAAE,UAAU,qBAAqB;EACxE;;;;;;AAOH,SAAgB,kBAAkB,YAA6B;CAC7D,MAAM,YAAY,WAAW,aAAa;AAC1C,QAAO,UAAU,SAAS,aAAa,IAAI,UAAU,SAAS,cAAc,IAAI,UAAU,SAAS,eAAe"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@kubb/plugin-oas",
|
|
3
|
-
"version": "4.
|
|
3
|
+
"version": "4.21.0",
|
|
4
4
|
"description": "OpenAPI Specification (OAS) plugin for Kubb, providing core functionality for parsing and processing OpenAPI/Swagger schemas for code generation.",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"openapi",
|
|
@@ -85,8 +85,8 @@
|
|
|
85
85
|
"@kubb/react-fabric": "0.12.10",
|
|
86
86
|
"p-limit": "^7.3.0",
|
|
87
87
|
"remeda": "^2.33.5",
|
|
88
|
-
"@kubb/core": "4.
|
|
89
|
-
"@kubb/oas": "4.
|
|
88
|
+
"@kubb/core": "4.21.0",
|
|
89
|
+
"@kubb/oas": "4.21.0"
|
|
90
90
|
},
|
|
91
91
|
"peerDependencies": {
|
|
92
92
|
"@kubb/react-fabric": "0.12.10"
|
package/src/utils/getParams.ts
CHANGED
|
@@ -12,9 +12,11 @@ export function getASTParams(
|
|
|
12
12
|
operationSchema: OperationSchema | undefined,
|
|
13
13
|
{
|
|
14
14
|
typed = false,
|
|
15
|
+
casing,
|
|
15
16
|
override,
|
|
16
17
|
}: {
|
|
17
18
|
typed?: boolean
|
|
19
|
+
casing?: 'camelcase'
|
|
18
20
|
override?: (data: FunctionParamsAST) => FunctionParamsAST
|
|
19
21
|
} = {},
|
|
20
22
|
): FunctionParamsAST[] {
|
|
@@ -25,11 +27,14 @@ export function getASTParams(
|
|
|
25
27
|
const requiredFields = Array.isArray(operationSchema.schema.required) ? operationSchema.schema.required : []
|
|
26
28
|
|
|
27
29
|
return Object.entries(operationSchema.schema.properties).map(([name]: [string, OasTypes.SchemaObject]) => {
|
|
30
|
+
// Use camelCase name for indexed access if casing is enabled
|
|
31
|
+
const accessName = casing === 'camelcase' ? camelCase(name) : name
|
|
32
|
+
|
|
28
33
|
const data: FunctionParamsAST = {
|
|
29
34
|
name,
|
|
30
35
|
enabled: !!name,
|
|
31
36
|
required: requiredFields.includes(name),
|
|
32
|
-
type: typed ? `${operationSchema.name}["${
|
|
37
|
+
type: typed ? `${operationSchema.name}["${accessName}"]` : undefined,
|
|
33
38
|
}
|
|
34
39
|
|
|
35
40
|
return override ? override(data) : data
|
|
@@ -46,10 +51,14 @@ export function getPathParams(
|
|
|
46
51
|
) {
|
|
47
52
|
return getASTParams(operationSchema, options).reduce((acc, curr) => {
|
|
48
53
|
if (curr.name && curr.enabled) {
|
|
49
|
-
let name =
|
|
54
|
+
let name = curr.name
|
|
50
55
|
|
|
56
|
+
// Only transform to camelCase if explicitly requested
|
|
51
57
|
if (options.casing === 'camelcase') {
|
|
52
58
|
name = camelCase(name)
|
|
59
|
+
} else if (!isValidVarName(name)) {
|
|
60
|
+
// If not valid variable name and casing not set, still need to make it valid
|
|
61
|
+
name = camelCase(name)
|
|
53
62
|
}
|
|
54
63
|
|
|
55
64
|
acc[name] = {
|
|
@@ -62,3 +71,39 @@ export function getPathParams(
|
|
|
62
71
|
return acc
|
|
63
72
|
}, {} as Params)
|
|
64
73
|
}
|
|
74
|
+
|
|
75
|
+
/**
|
|
76
|
+
* Get a mapping of camelCase parameter names to their original names
|
|
77
|
+
* Used for mapping function parameters to backend parameter names
|
|
78
|
+
*/
|
|
79
|
+
export function getParamsMapping(
|
|
80
|
+
operationSchema: OperationSchema | undefined,
|
|
81
|
+
options: {
|
|
82
|
+
casing?: 'camelcase'
|
|
83
|
+
} = {},
|
|
84
|
+
): Record<string, string> | undefined {
|
|
85
|
+
if (!operationSchema || !operationSchema.schema.properties) {
|
|
86
|
+
return undefined
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
const mapping: Record<string, string> = {}
|
|
90
|
+
|
|
91
|
+
Object.entries(operationSchema.schema.properties).forEach(([originalName]) => {
|
|
92
|
+
let transformedName = originalName
|
|
93
|
+
|
|
94
|
+
// Only transform to camelCase if explicitly requested
|
|
95
|
+
if (options.casing === 'camelcase') {
|
|
96
|
+
transformedName = camelCase(originalName)
|
|
97
|
+
} else if (!isValidVarName(originalName)) {
|
|
98
|
+
// If not valid variable name and casing not set, still need to make it valid
|
|
99
|
+
transformedName = camelCase(originalName)
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
// Only add mapping if the names differ
|
|
103
|
+
if (transformedName !== originalName) {
|
|
104
|
+
mapping[originalName] = transformedName
|
|
105
|
+
}
|
|
106
|
+
})
|
|
107
|
+
|
|
108
|
+
return Object.keys(mapping).length > 0 ? mapping : undefined
|
|
109
|
+
}
|
package/src/utils/index.ts
CHANGED
|
@@ -3,6 +3,13 @@ export { getBanner } from './getBanner.ts'
|
|
|
3
3
|
export { getComments } from './getComments.ts'
|
|
4
4
|
export { getFooter } from './getFooter.ts'
|
|
5
5
|
export { getImports } from './getImports.ts'
|
|
6
|
-
export {
|
|
6
|
+
export {
|
|
7
|
+
getParamsMapping,
|
|
8
|
+
getPathParams,
|
|
9
|
+
} from './getParams.ts'
|
|
7
10
|
export { getSchemaFactory } from './getSchemaFactory.ts'
|
|
8
11
|
export { getSchemas } from './getSchemas.ts'
|
|
12
|
+
export {
|
|
13
|
+
applyParamsCasing,
|
|
14
|
+
isParameterSchema,
|
|
15
|
+
} from './paramsCasing.ts'
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import transformers, { isValidVarName } from '@kubb/core/transformers'
|
|
2
|
+
import type { SchemaObject } from '@kubb/oas'
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Apply casing transformation to schema properties
|
|
6
|
+
* Only transforms property names, not nested schemas
|
|
7
|
+
*/
|
|
8
|
+
export function applyParamsCasing(schema: SchemaObject, casing: 'camelcase' | undefined): SchemaObject {
|
|
9
|
+
if (!casing || !schema.properties) {
|
|
10
|
+
return schema
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
const transformedProperties: Record<string, any> = {}
|
|
14
|
+
const transformedRequired: string[] = []
|
|
15
|
+
|
|
16
|
+
// Transform property names
|
|
17
|
+
Object.entries(schema.properties).forEach(([originalName, propertySchema]) => {
|
|
18
|
+
let transformedName = originalName
|
|
19
|
+
|
|
20
|
+
if (casing === 'camelcase') {
|
|
21
|
+
transformedName = transformers.camelCase(originalName)
|
|
22
|
+
} else if (!isValidVarName(originalName)) {
|
|
23
|
+
// If not valid variable name, make it valid
|
|
24
|
+
transformedName = transformers.camelCase(originalName)
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
transformedProperties[transformedName] = propertySchema
|
|
28
|
+
})
|
|
29
|
+
|
|
30
|
+
// Transform required field names
|
|
31
|
+
if (Array.isArray(schema.required)) {
|
|
32
|
+
schema.required.forEach((originalName) => {
|
|
33
|
+
let transformedName = originalName
|
|
34
|
+
|
|
35
|
+
if (casing === 'camelcase') {
|
|
36
|
+
transformedName = transformers.camelCase(originalName)
|
|
37
|
+
} else if (!isValidVarName(originalName)) {
|
|
38
|
+
transformedName = transformers.camelCase(originalName)
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
transformedRequired.push(transformedName)
|
|
42
|
+
})
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
// Return a new schema with transformed properties and required fields
|
|
46
|
+
return {
|
|
47
|
+
...schema,
|
|
48
|
+
properties: transformedProperties,
|
|
49
|
+
...(transformedRequired.length > 0 && { required: transformedRequired }),
|
|
50
|
+
} as SchemaObject
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
/**
|
|
54
|
+
* Check if this schema is a parameter schema (pathParams, queryParams, or headerParams)
|
|
55
|
+
* Only these should be transformed, not response/data/body
|
|
56
|
+
*/
|
|
57
|
+
export function isParameterSchema(schemaName: string): boolean {
|
|
58
|
+
const lowerName = schemaName.toLowerCase()
|
|
59
|
+
return lowerName.includes('pathparams') || lowerName.includes('queryparams') || lowerName.includes('headerparams')
|
|
60
|
+
}
|