@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 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}["${name}"]` : void 0
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 = (0, _kubb_core_transformers.isValidVarName)(curr.name) ? curr.name : (0, _kubb_core_transformers.camelCase)(curr.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
@@ -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":"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"}
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
- export { getBanner, getComments, getFooter, getImports, getPathParams, getSchemaFactory, getSchemas, isOptional };
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
- export { getBanner, getComments, getFooter, getImports, getPathParams, getSchemaFactory, getSchemas, isOptional };
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}["${name}"]` : void 0
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 = isValidVarName(curr.name) ? curr.name : camelCase(curr.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
- export { getBanner, getComments, getFooter, getImports, getPathParams, getSchemaFactory, getSchemas, isOptional };
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":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kubb/plugin-oas",
3
- "version": "4.20.5",
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.20.5",
89
- "@kubb/oas": "4.20.5"
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"
@@ -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}["${name}"]` : undefined,
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 = isValidVarName(curr.name) ? curr.name : camelCase(curr.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
+ }
@@ -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 { getPathParams } from './getParams.ts'
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
+ }