oas 28.1.0 → 28.3.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.
Files changed (59) hide show
  1. package/dist/analyzer/index.cjs +7 -7
  2. package/dist/analyzer/index.cjs.map +1 -1
  3. package/dist/analyzer/index.js +5 -5
  4. package/dist/analyzer/index.js.map +1 -1
  5. package/dist/{chunk-UW57LXCE.cjs → chunk-4DBNE7RJ.cjs} +1 -1
  6. package/dist/chunk-4DBNE7RJ.cjs.map +1 -0
  7. package/dist/{chunk-MW5BWU34.cjs → chunk-636SYI6H.cjs} +26 -26
  8. package/dist/chunk-636SYI6H.cjs.map +1 -0
  9. package/dist/{chunk-XS7VDTTT.cjs → chunk-6JSHPV2O.cjs} +1 -1
  10. package/dist/chunk-6JSHPV2O.cjs.map +1 -0
  11. package/dist/{chunk-N4TGMVNA.cjs → chunk-G5MSDVMW.cjs} +7 -7
  12. package/dist/chunk-G5MSDVMW.cjs.map +1 -0
  13. package/dist/{chunk-64CLCOBW.cjs → chunk-GDEE6EQV.cjs} +32 -31
  14. package/dist/chunk-GDEE6EQV.cjs.map +1 -0
  15. package/dist/{chunk-L2OVXZK3.js → chunk-NBQXNFZT.js} +1 -1
  16. package/dist/chunk-NBQXNFZT.js.map +1 -0
  17. package/dist/{chunk-F42EZPPE.js → chunk-NIBF7F33.js} +16 -15
  18. package/dist/chunk-NIBF7F33.js.map +1 -0
  19. package/dist/{chunk-45FGY5MW.js → chunk-RF2D4VVK.js} +7 -7
  20. package/dist/chunk-RF2D4VVK.js.map +1 -0
  21. package/dist/{chunk-TM3VSYIS.js → chunk-T34XCOTS.js} +6 -6
  22. package/dist/chunk-T34XCOTS.js.map +1 -0
  23. package/dist/{chunk-BBB7GA2U.js → chunk-W3LSKLU6.js} +1 -1
  24. package/dist/chunk-W3LSKLU6.js.map +1 -0
  25. package/dist/{extensions-D51otYaI.d.ts → extensions-DAFceEIL.d.ts} +15 -2
  26. package/dist/{extensions-ViDsWf_9.d.cts → extensions-DlGC1TJ1.d.cts} +15 -2
  27. package/dist/extensions.cjs +2 -2
  28. package/dist/extensions.d.cts +1 -1
  29. package/dist/extensions.d.ts +1 -1
  30. package/dist/extensions.js +1 -1
  31. package/dist/index.cjs +6 -6
  32. package/dist/index.d.cts +1 -1
  33. package/dist/index.d.ts +1 -1
  34. package/dist/index.js +5 -5
  35. package/dist/operation/index.cjs +5 -5
  36. package/dist/operation/index.d.cts +1 -1
  37. package/dist/operation/index.d.ts +1 -1
  38. package/dist/operation/index.js +4 -4
  39. package/dist/operation/lib/get-parameters-as-json-schema.cjs +3 -3
  40. package/dist/operation/lib/get-parameters-as-json-schema.d.cts +1 -1
  41. package/dist/operation/lib/get-parameters-as-json-schema.d.ts +1 -1
  42. package/dist/operation/lib/get-parameters-as-json-schema.js +2 -2
  43. package/dist/reducer/index.cjs.map +1 -1
  44. package/dist/reducer/index.js.map +1 -1
  45. package/dist/utils.cjs +4 -4
  46. package/dist/utils.d.cts +1 -1
  47. package/dist/utils.d.ts +1 -1
  48. package/dist/utils.js +3 -3
  49. package/package.json +5 -5
  50. package/dist/chunk-45FGY5MW.js.map +0 -1
  51. package/dist/chunk-64CLCOBW.cjs.map +0 -1
  52. package/dist/chunk-BBB7GA2U.js.map +0 -1
  53. package/dist/chunk-F42EZPPE.js.map +0 -1
  54. package/dist/chunk-L2OVXZK3.js.map +0 -1
  55. package/dist/chunk-MW5BWU34.cjs.map +0 -1
  56. package/dist/chunk-N4TGMVNA.cjs.map +0 -1
  57. package/dist/chunk-TM3VSYIS.js.map +0 -1
  58. package/dist/chunk-UW57LXCE.cjs.map +0 -1
  59. package/dist/chunk-XS7VDTTT.cjs.map +0 -1
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  findSchemaDefinition,
3
3
  supportedMethods
4
- } from "./chunk-BBB7GA2U.js";
4
+ } from "./chunk-W3LSKLU6.js";
5
5
  import {
6
6
  cloneObject,
7
7
  getParametersAsJSONSchema,
@@ -10,10 +10,10 @@ import {
10
10
  isPrimitive,
11
11
  matches_mimetype_default,
12
12
  toJSONSchema
13
- } from "./chunk-TM3VSYIS.js";
13
+ } from "./chunk-T34XCOTS.js";
14
14
  import {
15
15
  getExtension
16
- } from "./chunk-L2OVXZK3.js";
16
+ } from "./chunk-NBQXNFZT.js";
17
17
  import {
18
18
  isRef
19
19
  } from "./chunk-UCEHCARG.js";
@@ -134,7 +134,7 @@ function sampleFromSchema(schema, opts = {}) {
134
134
  }),
135
135
  opts
136
136
  );
137
- } catch (error) {
137
+ } catch {
138
138
  return void 0;
139
139
  }
140
140
  } else if (hasPolymorphism) {
@@ -731,14 +731,14 @@ var Operation = class {
731
731
  let keys;
732
732
  try {
733
733
  keys = Object.keys(requirement);
734
- } catch (e) {
734
+ } catch {
735
735
  return false;
736
736
  }
737
737
  const keysWithTypes = keys.map((key) => {
738
738
  let security;
739
739
  try {
740
740
  security = this.api.components.securitySchemes[key];
741
- } catch (e) {
741
+ } catch {
742
742
  return false;
743
743
  }
744
744
  if (!security) return false;
@@ -1274,4 +1274,4 @@ export {
1274
1274
  * @license Apache-2.0
1275
1275
  * @see {@link https://github.com/swagger-api/swagger-ui/blob/master/src/core/plugins/samples/fn.js}
1276
1276
  */
1277
- //# sourceMappingURL=chunk-45FGY5MW.js.map
1277
+ //# sourceMappingURL=chunk-RF2D4VVK.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/operation/lib/dedupe-common-parameters.ts","../src/samples/index.ts","../src/samples/utils.ts","../src/operation/lib/get-mediatype-examples.ts","../src/operation/lib/get-response-examples.ts","../src/operation/lib/get-callback-examples.ts","../src/operation/lib/get-example-groups.ts","../src/operation/lib/get-requestbody-examples.ts","../src/operation/lib/get-response-as-json-schema.ts","../src/operation/lib/operationId.ts","../src/operation/index.ts"],"sourcesContent":["import type { ParameterObject } from '../../types.js';\n\nimport { isRef } from '../../types.js';\n\n/**\n * With an array of common parameters filter down them to what isn't already present in a list of\n * non-common parameters.\n *\n * @param parameters Array of parameters defined at the operation level.\n * @param commonParameters Array of **common** parameters defined at the path item level.\n */\nexport function dedupeCommonParameters(\n parameters: ParameterObject[],\n commonParameters: ParameterObject[],\n): ParameterObject[] {\n return commonParameters.filter((param: ParameterObject) => {\n return !parameters.find((param2: ParameterObject) => {\n if (param.name && param2.name) {\n return param.name === param2.name && param.in === param2.in;\n } else if (isRef(param) && isRef(param2)) {\n return param.$ref === param2.$ref;\n }\n\n return false;\n });\n });\n}\n","/**\n * This file has been extracted and modified from Swagger UI.\n *\n * @license Apache-2.0\n * @see {@link https://github.com/swagger-api/swagger-ui/blob/master/src/core/plugins/samples/fn.js}\n */\nimport type { SchemaObject } from '../types.js';\n\nimport mergeJSONSchemaAllOf from 'json-schema-merge-allof';\nimport memoize from 'memoizee';\n\nimport { deeplyStripKey, isFunc, normalizeArray, objectify, usesPolymorphism } from './utils.js';\n\nconst sampleDefaults = (genericSample: boolean | number | string) => {\n return (schema: SchemaObject): typeof genericSample =>\n typeof schema.default === typeof genericSample ? schema.default : genericSample;\n};\n\nconst primitives: Record<string, (arg: SchemaObject) => boolean | number | string> = {\n string: sampleDefaults('string'),\n string_email: sampleDefaults('user@example.com'),\n 'string_date-time': sampleDefaults(new Date().toISOString()),\n string_date: sampleDefaults(new Date().toISOString().substring(0, 10)),\n 'string_YYYY-MM-DD': sampleDefaults(new Date().toISOString().substring(0, 10)),\n string_uuid: sampleDefaults('3fa85f64-5717-4562-b3fc-2c963f66afa6'),\n string_hostname: sampleDefaults('example.com'),\n string_ipv4: sampleDefaults('198.51.100.42'),\n string_ipv6: sampleDefaults('2001:0db8:5b96:0000:0000:426f:8e17:642a'),\n number: sampleDefaults(0),\n number_float: sampleDefaults(0.0),\n integer: sampleDefaults(0),\n boolean: sampleDefaults(true),\n};\n\nconst primitive = (schema: SchemaObject) => {\n const objectifiedSchema = objectify(schema);\n const { format } = objectifiedSchema;\n let { type } = objectifiedSchema;\n\n if (type === 'null') {\n return null;\n } else if (Array.isArray(type)) {\n if (type.length === 1) {\n type = type[0];\n } else {\n // If one of our types is `null` then we should generate a sample for the non-null value.\n if (type.includes('null')) {\n type = type.filter(t => t !== 'null');\n }\n\n type = type.shift();\n }\n }\n\n // @todo add support for if `type` is an array\n const fn = primitives[`${type}_${format}`] || primitives[type as string];\n if (isFunc(fn)) {\n return fn(objectifiedSchema);\n }\n\n return `Unknown Type: ${objectifiedSchema.type}`;\n};\n\n/**\n * Generate a piece of sample data from a JSON Schema object. If `example` declarations are present\n * they will be utilized, but generally this will generate fake data for the information present in\n * the schema.\n *\n * @param schema JSON Schema to generate a sample for.\n */\nfunction sampleFromSchema(\n schema: SchemaObject,\n opts: {\n /**\n * If you wish to include data that's flagged as `readOnly`.\n */\n includeReadOnly?: boolean;\n\n /**\n * If you wish to include data that's flatted as `writeOnly`.\n */\n includeWriteOnly?: boolean;\n } = {},\n): Record<string, unknown> | unknown[] | boolean | number | string | null | undefined {\n const objectifySchema = objectify(schema);\n let { type } = objectifySchema;\n\n const hasPolymorphism = usesPolymorphism(objectifySchema);\n if (hasPolymorphism === 'allOf') {\n try {\n return sampleFromSchema(\n mergeJSONSchemaAllOf(objectifySchema, {\n resolvers: {\n // Ignore any unrecognized OAS-specific keywords that might be present on the schema\n // (like `xml`).\n defaultResolver: mergeJSONSchemaAllOf.options.resolvers.title,\n },\n }),\n opts,\n );\n } catch {\n return undefined;\n }\n } else if (hasPolymorphism) {\n const samples = (objectifySchema[hasPolymorphism] as SchemaObject[]).map(s => {\n return sampleFromSchema(s, opts);\n });\n\n if (samples.length === 1) {\n return samples[0];\n } else if (samples.some(s => s === null)) {\n // If one of our samples is null then we should try to surface the first non-null one.\n return samples.find(s => s !== null);\n }\n\n // If we still don't have a sample then we should just return whatever the first sample we've\n // got is. The sample might not be a _full_ example but it should be enough to act as a sample.\n return samples[0];\n }\n\n const { example, additionalProperties, properties, items } = objectifySchema;\n const { includeReadOnly, includeWriteOnly } = opts;\n\n if (example !== undefined) {\n return deeplyStripKey(example, '$$ref', (val: string) => {\n // do a couple of quick sanity tests to ensure the value\n // looks like a $$ref that swagger-client generates.\n return typeof val === 'string' && val.indexOf('#') > -1;\n });\n }\n\n if (!type) {\n if (properties || additionalProperties) {\n type = 'object';\n } else if (items) {\n type = 'array';\n } else {\n return undefined;\n }\n }\n\n if (type === 'object' || (Array.isArray(type) && type.includes('object'))) {\n const props = objectify(properties);\n const obj: Record<string, any> = {};\n for (const name in props) {\n if (props?.[name].deprecated) {\n continue;\n }\n\n if (props?.[name].readOnly && !includeReadOnly) {\n continue;\n }\n\n if (props?.[name].writeOnly && !includeWriteOnly) {\n continue;\n }\n\n if (props[name].examples?.length) {\n obj[name] = props[name].examples[0];\n continue;\n }\n\n obj[name] = sampleFromSchema(props[name], opts);\n }\n\n if (additionalProperties === true) {\n obj.additionalProp = {};\n } else if (additionalProperties) {\n const additionalProps = objectify(additionalProperties);\n const additionalPropVal = sampleFromSchema(additionalProps, opts);\n\n obj.additionalProp = additionalPropVal;\n }\n\n return obj;\n }\n\n if (type === 'array' || (Array.isArray(type) && type.includes('array'))) {\n // `items` should always be present on arrays, but if it isn't we should at least do our best\n // to support its absence.\n if (typeof items === 'undefined') {\n return [];\n }\n\n if (Array.isArray(items.anyOf)) {\n return items.anyOf.map((i: SchemaObject) => sampleFromSchema(i, opts));\n }\n\n if (Array.isArray(items.oneOf)) {\n return items.oneOf.map((i: SchemaObject) => sampleFromSchema(i, opts));\n }\n\n return [sampleFromSchema(items, opts)];\n }\n\n if (schema.enum) {\n if (schema.default) {\n return schema.default;\n }\n\n return normalizeArray(schema.enum as string[])[0];\n }\n\n if (type === 'file') {\n return undefined;\n }\n\n return primitive(schema);\n}\n\nconst memo: typeof sampleFromSchema = memoize(sampleFromSchema);\n\n// biome-ignore lint/style/noDefaultExport: This is safe for now.\nexport default memo;\n","/**\n * Portions of this file have been extracted and modified from Swagger UI.\n *\n * @license Apache-2.0\n * @see {@link https://github.com/swagger-api/swagger-ui/blob/master/src/core/utils.js}\n */\nimport type { SchemaObject } from '../types.js';\n\nimport { isObject } from '../lib/helpers.js';\n\nexport function usesPolymorphism(schema: SchemaObject): 'allOf' | 'anyOf' | 'oneOf' | false {\n if (schema.oneOf) {\n return 'oneOf';\n } else if (schema.anyOf) {\n return 'anyOf';\n } else if (schema.allOf) {\n return 'allOf';\n }\n\n return false;\n}\n\nexport function objectify(thing: Record<string, unknown> | unknown): Record<string, any> {\n if (!isObject(thing)) {\n return {};\n }\n\n return thing;\n}\n\nexport function normalizeArray(arr: (number | string)[] | number | string): (number | string)[] {\n if (Array.isArray(arr)) {\n return arr;\n }\n\n return [arr];\n}\n\n// biome-ignore lint/complexity/noBannedTypes: This is part of a type guard.\nexport function isFunc(thing: unknown): thing is Function {\n return typeof thing === 'function';\n}\n\n// Deeply strips a specific key from an object.\n//\n// `predicate` can be used to discriminate the stripping further,\n// by preserving the key's place in the object based on its value.\n// @todo make this have a better type than `any`\nexport function deeplyStripKey(\n input: unknown,\n keyToStrip: string,\n predicate = (obj: unknown, key?: string): boolean => true,\n): SchemaObject | any {\n if (typeof input !== 'object' || Array.isArray(input) || input === null || !keyToStrip) {\n return input;\n }\n\n const obj = { ...input } as Record<string, SchemaObject>;\n\n Object.keys(obj).forEach(k => {\n if (k === keyToStrip && predicate(obj[k], k)) {\n delete obj[k];\n return;\n }\n\n obj[k] = deeplyStripKey(obj[k], keyToStrip, predicate);\n });\n\n return obj;\n}\n","import type { MediaTypeObject } from '../../types.js';\n\nimport matchesMimeType from '../../lib/matches-mimetype.js';\nimport sampleFromSchema from '../../samples/index.js';\n\nexport interface MediaTypeExample {\n description?: string;\n summary?: string;\n title?: string;\n value: unknown;\n}\n\n/**\n * Extracts a collection of examples from an OpenAPI Media Type Object. The example will either\n * come from the `example` property, the first item in an `examples` array, or if none of those are\n * present it will generate an example based off its schema.\n *\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.3.md#media-type-object}\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.0.md#media-type-object}\n * @param mediaType The media type that we're looking for examples for.\n * @param mediaTypeObject The media type object that we're looking for examples for.\n */\nexport function getMediaTypeExamples(\n mediaType: string,\n mediaTypeObject: MediaTypeObject,\n opts: {\n /**\n * If you wish to include data that's flagged as `readOnly`.\n */\n includeReadOnly?: boolean;\n\n /**\n * If you wish to include data that's flatted as `writeOnly`.\n */\n includeWriteOnly?: boolean;\n } = {},\n): MediaTypeExample[] {\n if (mediaTypeObject.example) {\n return [\n {\n value: mediaTypeObject.example,\n },\n ];\n } else if (mediaTypeObject.examples) {\n const { examples } = mediaTypeObject;\n const multipleExamples = Object.keys(examples)\n .map(key => {\n let summary = key;\n let description: string;\n\n let example = examples[key];\n if (example !== null && typeof example === 'object') {\n if ('summary' in example) {\n summary = example.summary;\n }\n\n if ('description' in example) {\n description = example.description;\n }\n\n if ('value' in example) {\n // If we have a $ref here then it's a circular reference and we should ignore it.\n if (example.value !== null && typeof example.value === 'object' && '$ref' in example.value) {\n return false;\n }\n\n example = example.value;\n }\n }\n\n const ret: MediaTypeExample = { summary, title: key, value: example };\n if (description) {\n ret.description = description;\n }\n\n return ret;\n })\n .filter(Boolean) as MediaTypeExample[];\n\n // If we were able to grab examples from the `examples` property return them (`examples` can\n // sometimes be an empty object), otherwise we should try to generate some instead.\n if (multipleExamples.length) {\n return multipleExamples;\n }\n }\n\n if (mediaTypeObject.schema) {\n // We do not fully support XML so we shouldn't generate XML samples for XML schemas.\n if (!matchesMimeType.xml(mediaType)) {\n return [\n {\n value: sampleFromSchema(JSON.parse(JSON.stringify(mediaTypeObject.schema)), opts),\n },\n ];\n }\n }\n\n return [];\n}\n","import type { OperationObject } from '../../types.js';\nimport type { MediaTypeExample } from './get-mediatype-examples.js';\n\nimport { isRef } from '../../types.js';\nimport { getMediaTypeExamples } from './get-mediatype-examples.js';\n\nexport type ResponseExamples = {\n mediaTypes: Record<string, MediaTypeExample[]>;\n onlyHeaders?: boolean;\n status: string;\n}[];\n\n/**\n * Retrieve a collection of response examples keyed, by their media type.\n *\n * @param operation Operation to retrieve response examples for.\n */\nexport function getResponseExamples(operation: OperationObject) {\n return Object.keys(operation.responses || {})\n .map(status => {\n const response = operation.responses[status];\n let onlyHeaders = false;\n\n // If we have a $ref here that means that this was a circular ref so we should ignore it.\n if (isRef(response)) {\n return false;\n }\n\n const mediaTypes: Record<string, MediaTypeExample[]> = {};\n (response.content ? Object.keys(response.content) : []).forEach(mediaType => {\n if (!mediaType) return;\n\n const mediaTypeObject = response.content[mediaType];\n const examples = getMediaTypeExamples(mediaType, mediaTypeObject, {\n includeReadOnly: true,\n includeWriteOnly: false,\n });\n\n if (examples) {\n mediaTypes[mediaType] = examples;\n }\n });\n\n // If the response has no content, but has headers, hardcode an empty example so the headers\n // modal will still display\n if (response.headers && Object.keys(response.headers).length && !Object.keys(mediaTypes).length) {\n mediaTypes['*/*'] = [];\n onlyHeaders = true;\n }\n\n if (!Object.keys(mediaTypes).length) {\n return false;\n }\n\n return {\n status,\n mediaTypes,\n ...(onlyHeaders ? { onlyHeaders } : {}),\n };\n })\n .filter(Boolean) as ResponseExamples;\n}\n","import type { CallbackObject, OperationObject } from '../../types.js';\nimport type { ResponseExamples } from './get-response-examples.js';\n\nimport { getResponseExamples } from './get-response-examples.js';\n\nexport type CallbackExamples = {\n example: ResponseExamples;\n expression: string;\n identifier: string;\n method: string;\n}[];\n\n/**\n * With an OpenAPI Operation Object return back a collection of examples for any callbacks that may\n * be present.\n *\n * @param operation Operation to retrieve callback examples from.\n */\nexport function getCallbackExamples(operation: OperationObject): CallbackExamples {\n const ret: CallbackExamples = [];\n\n // spreads the contents of the map for each callback so there's not nested arrays returned\n return ret.concat(\n ...Object.keys(operation.callbacks || {}).map(identifier => {\n const callback = operation.callbacks[identifier] as CallbackObject;\n\n // spreads the contents again so there's not nested arrays returned\n return []\n .concat(\n ...Object.keys(callback).map(expression => {\n return Object.keys(callback[expression]).map(method => {\n const pathItem = callback[expression] as Record<string, OperationObject>;\n const example = getResponseExamples(pathItem[method]);\n if (example.length === 0) return false;\n\n return {\n identifier,\n expression,\n method,\n example,\n };\n });\n }),\n )\n .filter(Boolean);\n }),\n );\n}\n","import type { OpenAPIV3 } from 'openapi-types';\nimport type { DataForHAR } from '../../types.js';\nimport type { Operation } from '../index.js';\nimport type { MediaTypeExample } from './get-mediatype-examples.js';\n\nimport { type Extensions, getExtension } from '../../extensions.js';\n\nexport type ExampleGroups = Record<\n string,\n {\n /**\n * Array of custom code samples that contain `correspondingExample` key.\n * Mutually exclusive of `request`. Note that if this object is present,\n * there may or may not be corresponding responses in the `response` object.\n */\n customCodeSamples?: (Extensions['code-samples'][number] & {\n /**\n * The index in the originally defined `code-samples` array\n */\n originalIndex: number;\n })[];\n\n /**\n * Title of example group. This is derived from the `summary` field of one of\n * the operation's example objects. The precedence is as follows (from highest to lowest):\n * 1. The first custom code sample's `name` field.\n * 2. The first request parameter (e.g., cookie/header/path/query) example object that\n * contains a `summary` field\n * 3. The request body example object's `summary` field\n * 4. The response example object's `summary` field\n *\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.3.md#example-object}\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.0.md#example-object}\n */\n name: string;\n\n /**\n * Object containing the example request data for the current example key.\n * Mutually exclusive of `customCodeSamples`. If `customCodeSamples` is present,\n * any request example definitions are ignored.\n */\n request?: DataForHAR;\n\n /**\n * Object containing the example response data for the current example key.\n */\n response?: {\n /**\n * The content type of the current example\n *\n * @example \"application/json\"\n * @example \"text/plain\"\n */\n mediaType: string;\n\n /**\n * The entire response example object. The example value itself is contained\n * within `value`.\n *\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.3.md#example-object}\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.0.md#example-object}\n */\n mediaTypeExample: MediaTypeExample;\n\n /**\n * The HTTP status code for the current response example\n *\n * @example \"2xx\"\n * @example \"400\"\n */\n status: string;\n };\n }\n>;\n\n/**\n * Internal key to represent custom code samples that do not have a corresponding response example.\n */\nconst noCorrespondingResponseKey = 'NoCorrespondingResponseForCustomCodeSample';\n\n/**\n * Takes a groups object and an operation and adds any matching response examples\n * to existing groups object\n */\nfunction addMatchingResponseExamples(groups: ExampleGroups, operation: Operation) {\n operation.getResponseExamples().forEach(example => {\n Object.entries(example.mediaTypes || {}).forEach(([mediaType, mediaTypeExamples]) => {\n mediaTypeExamples.forEach(mediaTypeExample => {\n // only add a response example if the `title` field exists\n // and it matches one of the existing example keys\n if (mediaTypeExample.title && Object.keys(groups).includes(mediaTypeExample.title)) {\n groups[mediaTypeExample.title].response = {\n mediaType,\n mediaTypeExample,\n status: example.status,\n };\n\n // if the current group doesn't already have a name set,\n // use the response example object's summary field\n if (!groups[mediaTypeExample.title].name) {\n groups[mediaTypeExample.title].name = mediaTypeExample.summary;\n }\n }\n });\n });\n });\n}\n\n/**\n * Returns a name for the given custom code sample. If there isn't already one defined,\n * we construct a fallback value based on where the sample is in the array.\n */\nfunction getDefaultName(sample: Extensions['code-samples'][number], count: Record<string, number>): string {\n return sample.name && sample.name.length > 0\n ? sample.name\n : `Default${count[sample.language] > 1 ? ` #${count[sample.language]}` : ''}`;\n}\n\n/**\n * Returns an object with groups of all example definitions (body/header/query/path/response/etc.).\n * The examples are grouped by their key when defined via the `examples` map.\n *\n * Any custom code samples defined via the `x-readme.code-samples` extension are returned,\n * regardless of if they have a matching response example.\n *\n * For standard OAS request parameter (e.g., body/header/query/path/etc.) examples,\n * they are only present in the return object if they have a corresponding response example\n * (i.e., a response example with the same key in the `examples` map).\n */\nexport function getExampleGroups(operation: Operation): ExampleGroups {\n const namelessCodeSampleCounts: Record<string, number> = {};\n const groups: ExampleGroups = {};\n\n // add custom code samples\n const codeSamples = getExtension('code-samples', operation.api, operation) as Extensions['code-samples'];\n codeSamples?.forEach((sample, i) => {\n if (namelessCodeSampleCounts[sample.language]) {\n namelessCodeSampleCounts[sample.language] += 1;\n } else {\n namelessCodeSampleCounts[sample.language] = 1;\n }\n const name = getDefaultName(sample, namelessCodeSampleCounts);\n\n // sample contains `correspondingExample` key\n if (groups[sample.correspondingExample]?.customCodeSamples?.length) {\n groups[sample.correspondingExample].customCodeSamples.push({ ...sample, name, originalIndex: i });\n } else if (sample.correspondingExample) {\n groups[sample.correspondingExample] = {\n name,\n customCodeSamples: [{ ...sample, name, originalIndex: i }],\n };\n }\n\n // sample does not contain a corresponding response example\n else if (groups[noCorrespondingResponseKey]?.customCodeSamples?.length) {\n groups[noCorrespondingResponseKey].customCodeSamples.push({ ...sample, name, originalIndex: i });\n } else {\n groups[noCorrespondingResponseKey] = {\n name,\n customCodeSamples: [{ ...sample, name, originalIndex: i }],\n };\n }\n });\n\n // if we added any custom code samples, add the corresponding response examples and return\n if (Object.keys(groups).length) {\n addMatchingResponseExamples(groups, operation);\n return groups;\n }\n\n // add request param examples\n operation.getParameters().forEach(param => {\n Object.entries(param.examples || {}).forEach(([exampleKey, paramExample]: [string, OpenAPIV3.ExampleObject]) => {\n groups[exampleKey] = {\n ...groups[exampleKey],\n name: groups[exampleKey]?.name || paramExample.summary,\n request: {\n ...groups[exampleKey]?.request,\n [param.in]: {\n ...groups[exampleKey]?.request?.[param.in],\n [param.name]: paramExample.value,\n },\n },\n };\n });\n });\n\n // add request body examples\n operation.getRequestBodyExamples().forEach(requestExample => {\n requestExample.examples.forEach((mediaTypeExample: MediaTypeExample) => {\n if (mediaTypeExample.title) {\n const mediaType = requestExample.mediaType === 'application/x-www-form-urlencoded' ? 'formData' : 'body';\n groups[mediaTypeExample.title] = {\n ...groups[mediaTypeExample.title],\n name: groups[mediaTypeExample.title]?.name || mediaTypeExample.summary,\n request: {\n ...groups[mediaTypeExample.title]?.request,\n [mediaType]: mediaTypeExample.value,\n },\n };\n }\n });\n });\n\n // if we added any request examples, add the corresponding response examples\n if (Object.keys(groups).length) {\n addMatchingResponseExamples(groups, operation);\n }\n\n // prune any objects that don't have both a request and a response\n Object.entries(groups).forEach(([groupId, group]) => {\n if (group.request && !group.response) {\n delete groups[groupId];\n }\n });\n\n return groups;\n}\n","import type { OperationObject, RequestBodyObject } from '../../types.js';\nimport type { MediaTypeExample } from './get-mediatype-examples.js';\n\nimport { getMediaTypeExamples } from './get-mediatype-examples.js';\n\nexport type RequestBodyExamples = {\n examples: MediaTypeExample[];\n mediaType: string;\n}[];\n\n/**\n * Retrieve a collection of request body examples, keyed by their media type.\n *\n * @param operation Operation to retrieve requestBody examples for.\n */\nexport function getRequestBodyExamples(operation: OperationObject): RequestBodyExamples {\n // `requestBody` will never have `$ref` pointers here so we need to work around the type that we\n // have from `OperationObject`.\n const requestBody = operation.requestBody as RequestBodyObject;\n if (!requestBody || !requestBody.content) {\n return [];\n }\n\n return Object.keys(requestBody.content || {})\n .map(mediaType => {\n const mediaTypeObject = requestBody.content[mediaType];\n const examples = getMediaTypeExamples(mediaType, mediaTypeObject, {\n includeReadOnly: false,\n includeWriteOnly: true,\n });\n\n if (!examples.length) {\n return false;\n }\n\n return {\n mediaType,\n examples,\n };\n })\n .filter(x => x !== false);\n}\n","import type {\n ComponentsObject,\n HeaderObject,\n MediaTypeObject,\n OASDocument,\n ResponseObject,\n SchemaObject,\n} from '../../types.js';\nimport type { Operation } from '../index.js';\n\nimport { cloneObject } from '../../lib/clone-object.js';\nimport { isPrimitive } from '../../lib/helpers.js';\nimport matches from '../../lib/matches-mimetype.js';\nimport { getSchemaVersionString, toJSONSchema } from '../../lib/openapi-to-json-schema.js';\n\ninterface ResponseSchemaObject {\n description?: string;\n label: string;\n schema: SchemaObject;\n type: string[] | string;\n}\n\nconst isJSON = matches.json;\n\n/**\n * Turn a header map from OpenAPI 3.0 (and some earlier versions too) into a schema.\n *\n * Note: This does not support OpenAPI 3.1's header format.\n *\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.3.md#header-object}\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.3.md#header-object}\n * @param response Response object to build a JSON Schema object for its headers for.\n */\nfunction buildHeadersSchema(\n response: ResponseObject,\n opts?: {\n /**\n * With a transformer you can transform any data within a given schema, like say if you want to\n * rewrite a potentially unsafe `title` that might be eventually used as a JS variable name,\n * just make sure to return your transformed schema.\n */\n transformer?: (schema: SchemaObject) => SchemaObject;\n },\n) {\n const headers = response.headers;\n\n const headersSchema: SchemaObject = {\n type: 'object',\n properties: {},\n };\n\n Object.keys(headers).forEach(key => {\n if (headers[key] && (headers[key] as HeaderObject).schema) {\n const header: HeaderObject = headers[key] as HeaderObject;\n\n // TODO: Response headers are essentially parameters in OAS\n // This means they can have content instead of schema.\n // We should probably support that in the future\n headersSchema.properties[key] = toJSONSchema(header.schema, {\n addEnumsToDescriptions: true,\n transformer: opts.transformer,\n });\n\n if (header.description) {\n (headersSchema.properties[key] as HeaderObject).description = header.description;\n }\n }\n });\n\n const headersWrapper: {\n description?: string;\n label: string;\n schema: SchemaObject;\n type: string;\n } = {\n schema: headersSchema,\n type: 'object',\n label: 'Headers',\n };\n\n if (response.description && headersWrapper.schema) {\n headersWrapper.description = response.description;\n }\n\n return headersWrapper;\n}\n\n/**\n * Extract all the response schemas, matching the format of `get-parameters-as-json-schema`.\n *\n * Note: This expects a dereferenced schema.\n *\n * @param operation Operation to construct a response JSON Schema for.\n * @param api The OpenAPI definition that this operation originates.\n * @param statusCode The response status code to generate a schema for.\n */\nexport function getResponseAsJSONSchema(\n operation: Operation,\n api: OASDocument,\n statusCode: number | string,\n opts?: {\n includeDiscriminatorMappingRefs?: boolean;\n /**\n * With a transformer you can transform any data within a given schema, like say if you want\n * to rewrite a potentially unsafe `title` that might be eventually used as a JS variable\n * name, just make sure to return your transformed schema.\n */\n transformer?: (schema: SchemaObject) => SchemaObject;\n },\n): ResponseSchemaObject[] | null {\n const response = operation.getResponseByStatusCode(statusCode);\n const jsonSchema: ResponseSchemaObject[] = [];\n\n if (!response) {\n return null;\n }\n\n let hasCircularRefs = false;\n let hasDiscriminatorMappingRefs = false;\n\n function refLogger(ref: string, type: 'discriminator' | 'ref') {\n if (type === 'ref') {\n hasCircularRefs = true;\n } else {\n hasDiscriminatorMappingRefs = true;\n }\n }\n\n /**\n * @param content An array of `MediaTypeObject`'s to retrieve a preferred schema out of. We\n * prefer JSON media types.\n */\n function getPreferredSchema(content: Record<string, MediaTypeObject>) {\n if (!content) {\n return null;\n }\n\n const contentTypes = Object.keys(content);\n if (!contentTypes.length) {\n return null;\n }\n\n for (let i = 0; i < contentTypes.length; i++) {\n if (isJSON(contentTypes[i])) {\n return toJSONSchema(cloneObject(content[contentTypes[i]].schema), {\n addEnumsToDescriptions: true,\n refLogger,\n transformer: opts.transformer,\n });\n }\n }\n\n // We always want to prefer the JSON-compatible content types over everything else but if we\n // haven't found one we should default to the first available.\n const contentType = contentTypes.shift();\n return toJSONSchema(cloneObject(content[contentType].schema), {\n addEnumsToDescriptions: true,\n refLogger,\n transformer: opts.transformer,\n });\n }\n\n const foundSchema = getPreferredSchema((response as ResponseObject).content);\n if (foundSchema) {\n const schema = cloneObject(foundSchema);\n const schemaWrapper: {\n description?: string;\n label: string;\n schema: SchemaObject;\n type: string[] | string;\n } = {\n // If there's no `type` then the root schema is a circular `$ref` that we likely won't be\n // able to render so instead of generating a JSON Schema with an `undefined` type we should\n // default to `string` so there's at least *something* the end-user can interact with.\n type: foundSchema.type || 'string',\n schema: isPrimitive(schema)\n ? schema\n : {\n ...schema,\n $schema: getSchemaVersionString(schema, api),\n },\n label: 'Response body',\n };\n\n if ((response as ResponseObject).description && schemaWrapper.schema) {\n schemaWrapper.description = (response as ResponseObject).description;\n }\n\n /**\n * Since this library assumes that the schema has already been dereferenced, adding every\n * component here that **isn't** circular adds a ton of bloat so it'd be cool if `components`\n * was just the remaining `$ref` pointers that are still being referenced.\n *\n * @todo\n */\n if (api.components && schemaWrapper.schema) {\n // We should only include components if we've got circular refs or we have discriminator\n // mapping refs (we want to include them).\n if (hasCircularRefs || (hasDiscriminatorMappingRefs && opts.includeDiscriminatorMappingRefs)) {\n ((schemaWrapper.schema as SchemaObject).components as ComponentsObject) = api.components as ComponentsObject;\n }\n }\n\n jsonSchema.push(schemaWrapper);\n }\n\n // 3.0.3 and earlier headers. TODO: New format for 3.1.0\n if ((response as ResponseObject).headers) {\n jsonSchema.push(buildHeadersSchema(response as ResponseObject, opts));\n }\n\n return jsonSchema.length ? jsonSchema : null;\n}\n","import type { OperationObject } from '../../types.ts';\n\nexport interface OperationIDGeneratorOptions {\n /**\n * Generate a JS method-friendly operation ID when one isn't present.\n *\n * For backwards compatiblity reasons this option will be indefinitely supported however we\n * recommend using `friendlyCase` instead as it's a heavily improved version of this option.\n *\n * @see {friendlyCase}\n * @deprecated\n */\n camelCase?: boolean;\n\n /**\n * Generate a human-friendly, but still camelCase, operation ID when one isn't present. The\n * difference between this and `camelCase` is that this also ensure that consecutive words are\n * not present in the resulting ID. For example, for the endpoint `/candidate/{candidate}` will\n * return `getCandidateCandidate` for `camelCase` however `friendlyCase` will return\n * `getCandidate`.\n *\n * The reason this friendliness is just not a part of the `camelCase` option is because we have\n * a number of consumers of the old operation ID style and making that change there would a\n * breaking change that we don't have any easy way to resolve.\n */\n friendlyCase?: boolean;\n}\n\n/**\n * Determine if an operation has an `operationId` present in its schema. Note that if one is\n * present in the schema but is an empty string then this will return false.\n *\n */\nexport function hasOperationId(operation: OperationObject): boolean {\n return Boolean('operationId' in operation && operation.operationId.length);\n}\n\n/**\n * Get an `operationId` for an operation. If one is not present (it's not required by the spec!)\n * a hash of the path and method will be returned instead.\n *\n */\nexport function getOperationId(\n path: string,\n method: string,\n operation: OperationObject,\n opts: OperationIDGeneratorOptions = {},\n): string {\n function sanitize(id: string) {\n // We aren't sanitizing underscores here by default in order to preserve operation IDs that\n // were already generated with this method in the past.\n return id\n .replace(opts?.camelCase || opts?.friendlyCase ? /[^a-zA-Z0-9_]/g : /[^a-zA-Z0-9]/g, '-') // Remove weird characters\n .replace(/--+/g, '-') // Remove double --'s\n .replace(/^-|-$/g, ''); // Don't start or end with -\n }\n\n const operationIdExists = hasOperationId(operation);\n let operationId: string;\n if (operationIdExists) {\n operationId = operation.operationId;\n } else {\n operationId = sanitize(path).toLowerCase();\n }\n\n const currMethod = method.toLowerCase();\n if (opts?.camelCase || opts?.friendlyCase) {\n if (opts?.friendlyCase) {\n // In order to generate friendlier operation IDs we should swap out underscores with spaces\n // so the end result will be _slightly_ more camelCase.\n operationId = operationId.replaceAll('_', ' ');\n\n if (!operationIdExists) {\n // In another effort to generate friendly operation IDs we should prevent words from\n // appearing in consecutive order (eg. `/candidate/{candidate}` should generate\n // `getCandidate` not `getCandidateCandidate`). However we only want to do this if we're\n // generating the operation ID as if they intentionally added a consecutive word into the\n // operation ID then we should respect that.\n operationId = operationId\n .replace(/[^a-zA-Z0-9_]+(.)/g, (_, chr) => ` ${chr}`)\n .split(' ')\n .filter((word, i, arr) => word !== arr[i - 1])\n .join(' ');\n }\n }\n\n operationId = operationId.replace(/[^a-zA-Z0-9_]+(.)/g, (_, chr) => chr.toUpperCase());\n if (operationIdExists) {\n operationId = sanitize(operationId);\n }\n\n // Never start with a number.\n operationId = operationId.replace(/^[0-9]/g, match => `_${match}`);\n\n // Ensure that the first character of an `operationId` is always lowercase.\n operationId = operationId.charAt(0).toLowerCase() + operationId.slice(1);\n\n // If the generated `operationId` already starts with the method (eg. `getPets`) we don't want\n // to double it up into `getGetPets`.\n if (operationId.startsWith(currMethod)) {\n return operationId;\n }\n\n // If this operation already has an `operationId` and we just cleaned it up then we shouldn't\n // prefix it with an HTTP method.\n if (operationIdExists) {\n return operationId;\n }\n\n // Because we're merging the `operationId` into an HTTP method we need to reset the first\n // character of it back to lowercase so we end up with `getBuster`, not `getbuster`.\n operationId = operationId.charAt(0).toUpperCase() + operationId.slice(1);\n return `${currMethod}${operationId}`;\n } else if (operationIdExists) {\n return operationId;\n }\n\n return `${currMethod}_${operationId}`;\n}\n","import type { OpenAPIV3, OpenAPIV3_1 } from 'openapi-types';\nimport type { Extensions } from '../extensions.js';\nimport type {\n CallbackObject,\n HttpMethods,\n KeyedSecuritySchemeObject,\n MediaTypeObject,\n OAS31Document,\n OASDocument,\n OperationObject,\n ParameterObject,\n PathItemObject,\n RequestBodyObject,\n ResponseObject,\n SchemaObject,\n SecurityRequirementObject,\n SecurityType,\n TagObject,\n} from '../types.js';\nimport type { CallbackExamples } from './lib/get-callback-examples.js';\nimport type { getParametersAsJSONSchemaOptions, SchemaWrapper } from './lib/get-parameters-as-json-schema.js';\nimport type { RequestBodyExamples } from './lib/get-requestbody-examples.js';\nimport type { ResponseExamples } from './lib/get-response-examples.js';\nimport type { OperationIDGeneratorOptions } from './lib/operationId.js';\n\nimport findSchemaDefinition from '../lib/find-schema-definition.js';\nimport matchesMimeType from '../lib/matches-mimetype.js';\nimport { isRef } from '../types.js';\nimport { supportedMethods } from '../utils.js';\nimport { dedupeCommonParameters } from './lib/dedupe-common-parameters.js';\nimport { getCallbackExamples } from './lib/get-callback-examples.js';\nimport { type ExampleGroups, getExampleGroups } from './lib/get-example-groups.js';\nimport { getParametersAsJSONSchema } from './lib/get-parameters-as-json-schema.js';\nimport { getRequestBodyExamples } from './lib/get-requestbody-examples.js';\nimport { getResponseAsJSONSchema } from './lib/get-response-as-json-schema.js';\nimport { getResponseExamples } from './lib/get-response-examples.js';\nimport { getOperationId, hasOperationId } from './lib/operationId.js';\n\nexport class Operation {\n /**\n * Schema of the operation from the API Definition.\n */\n schema: OperationObject;\n\n /**\n * OpenAPI API Definition that this operation originated from.\n */\n api: OASDocument;\n\n /**\n * Path that this operation is targeted towards.\n */\n path: string;\n\n /**\n * HTTP Method that this operation is targeted towards.\n */\n method: HttpMethods;\n\n /**\n * The primary Content Type that this operation accepts.\n */\n contentType: string;\n\n /**\n * An object with groups of all example definitions (body/header/query/path/response/etc.)\n */\n exampleGroups: ExampleGroups;\n\n /**\n * Request body examples for this operation.\n */\n requestBodyExamples: RequestBodyExamples;\n\n /**\n * Response examples for this operation.\n */\n responseExamples: ResponseExamples;\n\n /**\n * Callback examples for this operation (if it has callbacks).\n */\n callbackExamples: CallbackExamples;\n\n /**\n * Flattened out arrays of both request and response headers that are utilized on this operation.\n */\n headers: {\n request: string[];\n response: string[];\n };\n\n constructor(api: OASDocument, path: string, method: HttpMethods, operation: OperationObject) {\n this.schema = operation;\n this.api = api;\n this.path = path;\n this.method = method;\n\n this.contentType = undefined;\n this.requestBodyExamples = undefined;\n this.responseExamples = undefined;\n this.callbackExamples = undefined;\n this.exampleGroups = undefined;\n this.headers = {\n request: [],\n response: [],\n };\n }\n\n getSummary(): string {\n if (this.schema?.summary && typeof this.schema.summary === 'string') {\n return this.schema.summary;\n } else if (this.api.paths[this.path].summary && typeof this.api.paths[this.path].summary === 'string') {\n return this.api.paths[this.path].summary;\n }\n\n return undefined;\n }\n\n getDescription(): string {\n if (this.schema?.description && typeof this.schema.description === 'string') {\n return this.schema.description;\n } else if (this.api.paths[this.path].description && typeof this.api.paths[this.path].description === 'string') {\n return this.api.paths[this.path].description;\n }\n\n return undefined;\n }\n\n getContentType(): string {\n if (this.contentType) {\n return this.contentType;\n }\n\n let types: string[] = [];\n if (this.schema.requestBody) {\n if ('$ref' in this.schema.requestBody) {\n this.schema.requestBody = findSchemaDefinition(this.schema.requestBody.$ref, this.api);\n }\n\n if ('content' in this.schema.requestBody) {\n types = Object.keys(this.schema.requestBody.content);\n }\n }\n\n this.contentType = 'application/json';\n if (types?.length) {\n this.contentType = types[0];\n }\n\n // Favor JSON if it exists\n types.forEach(t => {\n if (matchesMimeType.json(t)) {\n this.contentType = t;\n }\n });\n\n return this.contentType;\n }\n\n isFormUrlEncoded(): boolean {\n return matchesMimeType.formUrlEncoded(this.getContentType());\n }\n\n isMultipart(): boolean {\n return matchesMimeType.multipart(this.getContentType());\n }\n\n isJson(): boolean {\n return matchesMimeType.json(this.getContentType());\n }\n\n isXml(): boolean {\n return matchesMimeType.xml(this.getContentType());\n }\n\n /**\n * Checks if the current operation is a webhook or not.\n *\n */\n isWebhook(): boolean {\n return this instanceof Webhook;\n }\n\n /**\n * Returns an array of all security requirements associated wtih this operation. If none are\n * defined at the operation level, the securities for the entire API definition are returned\n * (with an empty array as a final fallback).\n *\n */\n getSecurity(): SecurityRequirementObject[] {\n if (!this.api?.components?.securitySchemes || !Object.keys(this.api.components.securitySchemes).length) {\n return [];\n }\n\n return this.schema.security || this.api.security || [];\n }\n\n /**\n * Retrieve a collection of grouped security schemes. The inner array determines AND-grouped\n * security schemes, the outer array determines OR-groups.\n *\n * @see {@link https://swagger.io/docs/specification/authentication/#multiple}\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.3.md#security-requirement-object}\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.0.md#security-requirement-object}\n * @param filterInvalid Optional flag that, when set to `true`, filters out invalid/nonexistent\n * security schemes, rather than returning `false`.\n */\n getSecurityWithTypes(\n filterInvalid = false,\n ): ((false | { security: KeyedSecuritySchemeObject; type: SecurityType })[] | false)[] {\n const securityRequirements = this.getSecurity();\n\n return securityRequirements.map(requirement => {\n let keys: string[];\n try {\n keys = Object.keys(requirement);\n } catch {\n return false;\n }\n\n const keysWithTypes = keys.map(key => {\n let security: KeyedSecuritySchemeObject;\n try {\n // Remove the reference type, because we know this will be dereferenced\n security = this.api.components.securitySchemes[key] as KeyedSecuritySchemeObject;\n } catch {\n return false;\n }\n\n if (!security) return false;\n\n let type: SecurityType = null;\n\n if (security.type === 'http') {\n if (security.scheme === 'basic') type = 'Basic';\n else if (security.scheme === 'bearer') type = 'Bearer';\n else type = security.type;\n } else if (security.type === 'oauth2') {\n type = 'OAuth2';\n } else if (security.type === 'apiKey') {\n if (security.in === 'query') type = 'Query';\n else if (security.in === 'header') type = 'Header';\n else if (security.in === 'cookie') type = 'Cookie';\n else type = security.type;\n } else {\n return false;\n }\n\n return {\n type,\n security: {\n ...security,\n _key: key,\n _requirements: requirement[key],\n },\n };\n });\n\n if (filterInvalid) return keysWithTypes.filter(key => key !== false);\n\n return keysWithTypes;\n });\n }\n\n /**\n * Retrieve an object where the keys are unique scheme types, and the values are arrays\n * containing each security scheme of that type.\n *\n */\n prepareSecurity(): Record<SecurityType, KeyedSecuritySchemeObject[]> {\n const securitiesWithTypes = this.getSecurityWithTypes();\n\n return securitiesWithTypes.reduce(\n (prev, securities) => {\n if (!securities) return prev;\n\n securities.forEach(security => {\n // Remove non-existent schemes\n if (!security) return;\n if (!prev[security.type]) prev[security.type] = [];\n\n // Only add schemes we haven't seen yet.\n const exists = prev[security.type].some(sec => sec._key === security.security._key);\n if (!exists) {\n // Since an operation can require the same security scheme several times (each with different scope requirements),\n // including the `_requirements` in this object would be misleading since we dedupe the security schemes.\n if (security.security?._requirements) delete security.security._requirements;\n prev[security.type].push(security.security);\n }\n });\n\n return prev;\n },\n {} as Record<SecurityType, KeyedSecuritySchemeObject[]>,\n );\n }\n\n getHeaders(): Operation['headers'] {\n const security = this.prepareSecurity();\n if (security.Header) {\n this.headers.request = (security.Header as OpenAPIV3_1.ApiKeySecurityScheme[]).map(h => {\n return h.name;\n });\n }\n\n if (security.Bearer || security.Basic || security.OAuth2) {\n this.headers.request.push('Authorization');\n }\n\n if (security.Cookie) {\n this.headers.request.push('Cookie');\n }\n\n if (this.schema.parameters) {\n this.headers.request = this.headers.request.concat(\n // Remove the reference object because we will have already dereferenced.\n (this.schema.parameters as OpenAPIV3_1.ParameterObject[] | OpenAPIV3.ParameterObject[])\n .map(p => {\n if (p.in && p.in === 'header') return p.name;\n return undefined;\n })\n .filter(p => p),\n );\n }\n\n if (this.schema.responses) {\n this.headers.response = Object.keys(this.schema.responses)\n // Remove the reference object because we will have already dereferenced.\n .filter(r => (this.schema.responses[r] as ResponseObject).headers)\n .map(r =>\n // Remove the reference object because we will have already dereferenced.\n Object.keys((this.schema.responses[r] as ResponseObject).headers),\n )\n .reduce((a, b) => a.concat(b), []);\n }\n\n // If the operation doesn't already specify a `content-type` request header, we check if the\n // path operation request body contains content, which implies that we should also include the\n // `content-type` header.\n if (!this.headers.request.includes('Content-Type') && this.schema.requestBody) {\n if (\n (this.schema.requestBody as RequestBodyObject).content &&\n Object.keys((this.schema.requestBody as RequestBodyObject).content)\n ) {\n this.headers.request.push('Content-Type');\n }\n }\n\n // This is a similar approach, but in this case if we check the response content and prioritize\n // the `accept` request header and `content-type` request header.\n if (this.schema.responses) {\n if (\n Object.keys(this.schema.responses).some(\n response => !!(this.schema.responses[response] as ResponseObject).content,\n )\n ) {\n if (!this.headers.request.includes('Accept')) this.headers.request.push('Accept');\n if (!this.headers.response.includes('Content-Type')) this.headers.response.push('Content-Type');\n }\n }\n\n return this.headers;\n }\n\n /**\n * Determine if the operation has an `operationId` present in its schema. Note that if one is\n * present in the schema but is an empty string then this will return false.\n *\n */\n hasOperationId(): boolean {\n return hasOperationId(this.schema);\n }\n\n /**\n * Determine if an operation has an `operationId` present in its schema. Note that if one is\n * present in the schema but is an empty string then this will return false.\n *\n */\n static hasOperationId(schema: OperationObject): boolean {\n return hasOperationId(schema);\n }\n\n /**\n * Get an `operationId` for this operation. If one is not present (it's not required by the spec!)\n * a hash of the path and method will be returned instead.\n *\n */\n getOperationId(opts: OperationIDGeneratorOptions = {}): string {\n return getOperationId(this.path, this.method, this.schema, opts);\n }\n\n /**\n * Get an `operationId` for an operation. If one is not present (it's not required by the spec!)\n * a hash of the path and method will be returned instead.\n *\n */\n static getOperationId(\n path: string,\n method: string,\n schema: OperationObject,\n opts: OperationIDGeneratorOptions = {},\n ): string {\n return getOperationId(path, method, schema, opts);\n }\n\n /**\n * Return an array of all tags, and their metadata, that exist on this operation.\n *\n */\n getTags(): TagObject[] {\n if (!('tags' in this.schema)) {\n return [];\n }\n\n const oasTagMap: Map<string, TagObject> = new Map();\n if ('tags' in this.api) {\n this.api.tags.forEach((tag: TagObject) => {\n oasTagMap.set(tag.name, tag);\n });\n }\n\n const oasTags = Object.fromEntries(oasTagMap);\n\n const tags: TagObject[] = [];\n if (Array.isArray(this.schema.tags)) {\n this.schema.tags.forEach(tag => {\n if (tag in oasTags) {\n tags.push(oasTags[tag]);\n } else {\n tags.push({\n name: tag,\n });\n }\n });\n }\n\n return tags;\n }\n\n /**\n * Return is the operation is flagged as `deprecated` or not.\n *\n */\n isDeprecated(): boolean {\n return 'deprecated' in this.schema ? this.schema.deprecated : false;\n }\n\n /**\n * Determine if the operation has any (non-request body) parameters.\n *\n */\n hasParameters(): boolean {\n return !!this.getParameters().length;\n }\n\n /**\n * Return the parameters (non-request body) on the operation.\n *\n */\n getParameters(): ParameterObject[] {\n let parameters = (this.schema?.parameters || []) as ParameterObject[];\n const commonParams = (this.api?.paths?.[this.path]?.parameters || []) as ParameterObject[];\n if (commonParams.length) {\n parameters = parameters.concat(dedupeCommonParameters(parameters, commonParams) || []);\n }\n\n return parameters;\n }\n\n /**\n * Determine if this operation has any required parameters.\n *\n */\n hasRequiredParameters(): boolean {\n return this.getParameters().some(param => 'required' in param && param.required);\n }\n\n /**\n * Convert the operation into an array of JSON Schema schemas for each available type of\n * parameter available on the operation.\n *\n */\n getParametersAsJSONSchema(opts: getParametersAsJSONSchemaOptions = {}): SchemaWrapper[] {\n return getParametersAsJSONSchema(this, this.api, {\n includeDiscriminatorMappingRefs: true,\n transformer: (s: SchemaObject) => s,\n ...opts,\n });\n }\n\n /**\n * Get a single response for this status code, formatted as JSON schema.\n *\n * @param statusCode Status code to pull a JSON Schema response for.\n */\n getResponseAsJSONSchema(\n statusCode: number | string,\n opts: {\n /**\n * If you wish to include discriminator mapping `$ref` components alongside your\n * `discriminator` in schemas. Defaults to `true`.\n */\n includeDiscriminatorMappingRefs?: boolean;\n\n /**\n * With a transformer you can transform any data within a given schema, like say if you want\n * to rewrite a potentially unsafe `title` that might be eventually used as a JS variable\n * name, just make sure to return your transformed schema.\n */\n transformer?: (schema: SchemaObject) => SchemaObject;\n } = {},\n ): SchemaObject {\n return getResponseAsJSONSchema(this, this.api, statusCode, {\n includeDiscriminatorMappingRefs: true,\n transformer: (s: SchemaObject) => s,\n ...opts,\n });\n }\n\n /**\n * Get an array of all valid response status codes for this operation.\n *\n */\n getResponseStatusCodes(): string[] {\n return this.schema.responses ? Object.keys(this.schema.responses) : [];\n }\n\n /**\n * Determine if the operation has any request bodies.\n *\n */\n hasRequestBody(): boolean {\n return !!this.schema.requestBody;\n }\n\n /**\n * Retrieve the list of all available media types that the operations request body can accept.\n *\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.3.md#media-type-object}\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.0.md#media-type-object}\n */\n getRequestBodyMediaTypes(): string[] {\n if (!this.hasRequestBody()) {\n return [];\n }\n\n const requestBody = this.schema.requestBody;\n if (isRef(requestBody)) {\n // If the request body is still a `$ref` pointer we should return false because this library\n // assumes that you've run dereferencing beforehand.\n return [];\n }\n\n return Object.keys(requestBody.content);\n }\n\n /**\n * Determine if this operation has a required request body.\n *\n */\n hasRequiredRequestBody(): boolean {\n if (!this.hasRequestBody()) {\n return false;\n }\n\n const requestBody = this.schema.requestBody;\n if (isRef(requestBody)) {\n return false;\n }\n\n if (requestBody.required) {\n return true;\n }\n\n // The OpenAPI spec isn't clear on the differentiation between schema `required` and\n // `requestBody.required` because you can have required top-level schema properties but a\n // non-required requestBody that negates each other.\n //\n // To kind of work ourselves around this and present a better QOL for this accessor, if at this\n // final point where we don't have a required request body, but the underlying Media Type Object\n // schema says that it has required properties then we should ultimately recognize that this\n // request body is required -- even as the request body description says otherwise.\n return !!this.getParametersAsJSONSchema()\n .filter(js => ['body', 'formData'].includes(js.type))\n .find(js => js.schema && Array.isArray(js.schema.required) && js.schema.required.length);\n }\n\n /**\n * Retrieve a specific request body content schema off this operation.\n *\n * If no media type is supplied this will return either the first available JSON-like request\n * body, or the first available if there are no JSON-like media types present. When this return\n * comes back it's in the form of an array with the first key being the selected media type,\n * followed by the media type object in question.\n *\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.3.md#media-type-object}\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.0.md#media-type-object}\n * @param mediaType Specific request body media type to retrieve if present.\n */\n getRequestBody(mediaType?: string): MediaTypeObject | false | [string, MediaTypeObject, ...string[]] {\n if (!this.hasRequestBody()) {\n return false;\n }\n\n const requestBody = this.schema.requestBody;\n if (isRef(requestBody)) {\n // If the request body is still a `$ref` pointer we should return false because this library\n // assumes that you've run dereferencing beforehand.\n return false;\n }\n\n if (mediaType) {\n if (!(mediaType in requestBody.content)) {\n return false;\n }\n\n return requestBody.content[mediaType];\n }\n\n // Since no media type was supplied we need to find either the first JSON-like media type that\n // we've got, or the first available of anything else if no JSON-like media types are present.\n let availableMediaType: string;\n const mediaTypes = this.getRequestBodyMediaTypes();\n mediaTypes.forEach((mt: string) => {\n if (!availableMediaType && matchesMimeType.json(mt)) {\n availableMediaType = mt;\n }\n });\n\n if (!availableMediaType) {\n mediaTypes.forEach((mt: string) => {\n if (!availableMediaType) {\n availableMediaType = mt;\n }\n });\n }\n\n if (availableMediaType) {\n return [\n availableMediaType,\n requestBody.content[availableMediaType],\n ...(requestBody.description ? [requestBody.description] : []),\n ];\n }\n\n return false;\n }\n\n /**\n * Retrieve an array of request body examples that this operation has.\n *\n */\n getRequestBodyExamples(): RequestBodyExamples {\n const isRequestExampleValueDefined = typeof this.requestBodyExamples?.[0]?.examples?.[0].value !== 'undefined';\n\n if (this.requestBodyExamples && isRequestExampleValueDefined) {\n return this.requestBodyExamples;\n }\n\n this.requestBodyExamples = getRequestBodyExamples(this.schema);\n return this.requestBodyExamples;\n }\n\n /**\n * Return a specific response out of the operation by a given HTTP status code.\n *\n * @param statusCode Status code to pull a response object for.\n */\n getResponseByStatusCode(statusCode: number | string): ResponseObject | boolean {\n if (!this.schema.responses) {\n return false;\n }\n\n if (typeof this.schema.responses[statusCode] === 'undefined') {\n return false;\n }\n\n const response = this.schema.responses[statusCode];\n\n if (isRef(response)) {\n return false;\n }\n\n // Remove the reference from the type, because it will already be dereferenced.\n return response;\n }\n\n /**\n * Retrieve an array of response examples that this operation has.\n *\n */\n getResponseExamples(): ResponseExamples {\n if (this.responseExamples) {\n return this.responseExamples;\n }\n\n // @todo Remove this `as` once we convert getResponseExamples\n this.responseExamples = getResponseExamples(this.schema) as ResponseExamples;\n return this.responseExamples;\n }\n\n /**\n * Determine if the operation has callbacks.\n *\n */\n hasCallbacks(): boolean {\n return !!this.schema.callbacks;\n }\n\n /**\n * Retrieve a specific callback.\n *\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.3.md#callback-object}\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.0.md#callback-object}\n * @param identifier Callback identifier to look for.\n * @param expression Callback expression to look for.\n * @param method HTTP Method on the callback to look for.\n */\n getCallback(identifier: string, expression: string, method: HttpMethods): Callback | false {\n if (!this.schema.callbacks) return false;\n\n // The usage of `as` in the below is to remove the possibility of a ref type, since we've\n // dereferenced.\n const callback = this.schema.callbacks[identifier]\n ? (((this.schema.callbacks as Record<string, CallbackObject>)[identifier] as CallbackObject)[\n expression\n ] as PathItemObject)\n : false;\n\n if (!callback || !callback[method]) return false;\n return new Callback(this.api, expression, method, callback[method], identifier, callback);\n }\n\n /**\n * Retrieve an array of operations created from each callback.\n *\n */\n getCallbacks(): (Callback | false)[] | false {\n const callbackOperations: (Callback | false)[] = [];\n if (!this.hasCallbacks()) return false;\n\n Object.keys(this.schema.callbacks).forEach(callback => {\n Object.keys(this.schema.callbacks[callback]).forEach(expression => {\n const cb = this.schema.callbacks[callback];\n\n if (!isRef(cb)) {\n const exp = cb[expression];\n\n if (!isRef(exp)) {\n Object.keys(exp).forEach((method: HttpMethods) => {\n if (!supportedMethods.includes(method)) return;\n\n callbackOperations.push(this.getCallback(callback, expression, method));\n });\n }\n }\n });\n });\n\n return callbackOperations;\n }\n\n /**\n * Retrieve an array of callback examples that this operation has.\n *\n */\n getCallbackExamples(): CallbackExamples {\n if (this.callbackExamples) {\n return this.callbackExamples;\n }\n\n this.callbackExamples = getCallbackExamples(this.schema);\n return this.callbackExamples;\n }\n\n /**\n * Determine if a given a custom specification extension exists within the operation.\n *\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.3.md#specification-extensions}\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.0.md#specification-extensions}\n * @param extension Specification extension to lookup.\n */\n hasExtension(extension: string): boolean {\n return Boolean(this.schema && extension in this.schema);\n }\n\n /**\n * Retrieve a custom specification extension off of the operation.\n *\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.3.md#specification-extensions}\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.0.md#specification-extensions}\n * @param extension Specification extension to lookup.\n *\n * @deprecated Use `oas.getExtension(extension, operation)` instead.\n */\n getExtension(extension: string | keyof Extensions): any {\n return this.schema?.[extension];\n }\n\n /**\n * Returns an object with groups of all example definitions (body/header/query/path/response/etc.).\n * The examples are grouped by their key when defined via the `examples` map.\n *\n * Any custom code samples defined via the `x-readme.code-samples` extension are returned,\n * regardless of if they have a matching response example.\n *\n * For standard OAS request parameter (e.g., body/header/query/path/etc.) examples,\n * they are only present in the return object if they have a corresponding response example\n * (i.e., a response example with the same key in the `examples` map).\n */\n getExampleGroups(): ExampleGroups {\n if (this.exampleGroups) return this.exampleGroups;\n\n const groups = getExampleGroups(this);\n\n this.exampleGroups = groups;\n\n return groups;\n }\n}\n\nexport class Callback extends Operation {\n /**\n * The identifier that this callback is set to.\n */\n identifier: string;\n\n /**\n * The parent path item object that this Callback exists within.\n */\n parentSchema: PathItemObject;\n\n constructor(\n oas: OASDocument,\n path: string,\n method: HttpMethods,\n operation: OperationObject,\n identifier: string,\n parentPathItem: PathItemObject,\n ) {\n super(oas, path, method, operation);\n\n this.identifier = identifier;\n this.parentSchema = parentPathItem;\n }\n\n /**\n * Return the primary identifier for this callback.\n *\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.3.md#callback-object}\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.0.md#callback-object}\n */\n getIdentifier(): string {\n return this.identifier;\n }\n\n getSummary(): string {\n if (this.schema?.summary && typeof this.schema.summary === 'string') {\n return this.schema.summary;\n } else if (this.parentSchema.summary && typeof this.parentSchema.summary === 'string') {\n return this.parentSchema.summary;\n }\n\n return undefined;\n }\n\n getDescription(): string {\n if (this.schema?.description && typeof this.schema.description === 'string') {\n return this.schema.description;\n } else if (this.parentSchema.description && typeof this.parentSchema.description === 'string') {\n return this.parentSchema.description;\n }\n\n return undefined;\n }\n\n getParameters(): ParameterObject[] {\n let parameters = (this.schema?.parameters || []) as ParameterObject[];\n const commonParams = (this.parentSchema.parameters || []) as ParameterObject[];\n if (commonParams.length) {\n parameters = parameters.concat(dedupeCommonParameters(parameters, commonParams) || []);\n }\n\n return parameters;\n }\n}\n\nexport class Webhook extends Operation {\n /**\n * OpenAPI API Definition that this webhook originated from.\n */\n declare api: OAS31Document;\n\n getSummary(): string {\n if (this.schema?.summary && typeof this.schema.summary === 'string') {\n return this.schema.summary;\n } else if (this.api.webhooks[this.path].summary && typeof this.api.webhooks[this.path].summary === 'string') {\n return this.api.webhooks[this.path].summary;\n }\n\n return undefined;\n }\n\n getDescription(): string {\n if (this.schema?.description && typeof this.schema.description === 'string') {\n return this.schema.description;\n } else if (\n this.api.webhooks[this.path].description &&\n typeof this.api.webhooks[this.path].description === 'string'\n ) {\n return this.api.webhooks[this.path].description;\n }\n\n return undefined;\n }\n}\n"],"mappings":"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","names":[]}
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  PARAMETER_ORDERING,
3
3
  getExtension
4
- } from "./chunk-L2OVXZK3.js";
4
+ } from "./chunk-NBQXNFZT.js";
5
5
  import {
6
6
  isOAS31,
7
7
  isRef,
@@ -131,7 +131,7 @@ function searchForValueByPropAndPointer(property, pointer, schemas = []) {
131
131
  }
132
132
  try {
133
133
  foundValue = jsonpointer.get(schema, pointers[i]);
134
- } catch (err) {
134
+ } catch {
135
135
  }
136
136
  if (foundValue !== void 0) {
137
137
  break;
@@ -206,7 +206,7 @@ function toJSONSchema(data, opts = {}) {
206
206
  defaultResolver: mergeJSONSchemaAllOf.options.resolvers.title
207
207
  }
208
208
  });
209
- } catch (e) {
209
+ } catch {
210
210
  const { ...schemaWithoutAllOf } = schema;
211
211
  schema = schemaWithoutAllOf;
212
212
  delete schema.allOf;
@@ -507,7 +507,7 @@ function toJSONSchema(data, opts = {}) {
507
507
  if (userJwtDefault) {
508
508
  schema.default = userJwtDefault;
509
509
  }
510
- } catch (err) {
510
+ } catch {
511
511
  }
512
512
  }
513
513
  if ("default" in schema && typeof schema.default !== "undefined") {
@@ -526,7 +526,7 @@ function toJSONSchema(data, opts = {}) {
526
526
  if (isSchema(schema, isPolymorphicAllOfChild) && "enum" in schema && Array.isArray(schema.enum)) {
527
527
  schema.enum = Array.from(new Set(schema.enum));
528
528
  if (addEnumsToDescriptions) {
529
- const enums = schema.enum.filter(Boolean).map((str) => `\`${str}\``).join(" ");
529
+ const enums = schema.enum.filter((v) => v !== void 0 && (typeof v !== "string" || v.trim() !== "")).map((str) => `\`${str}\``).join(" ");
530
530
  if (enums.length) {
531
531
  if ("description" in schema) {
532
532
  schema.description += `
@@ -832,4 +832,4 @@ export {
832
832
  types,
833
833
  getParametersAsJSONSchema
834
834
  };
835
- //# sourceMappingURL=chunk-TM3VSYIS.js.map
835
+ //# sourceMappingURL=chunk-T34XCOTS.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/lib/clone-object.ts","../src/lib/helpers.ts","../src/lib/matches-mimetype.ts","../src/lib/openapi-to-json-schema.ts","../src/operation/lib/get-parameters-as-json-schema.ts"],"sourcesContent":["export function cloneObject<T>(obj: T): T {\n if (typeof obj === 'undefined') {\n return undefined;\n }\n\n return JSON.parse(JSON.stringify(obj));\n}\n","import type { SchemaObject } from '../types.js';\n\nexport function hasSchemaType(schema: SchemaObject, discriminator: 'array' | 'object'): boolean {\n if (Array.isArray(schema.type)) {\n return schema.type.includes(discriminator);\n }\n\n return schema.type === discriminator;\n}\n\nexport function isObject(val: unknown): val is Record<string, unknown> {\n return typeof val === 'object' && val !== null && !Array.isArray(val);\n}\n\nexport function isPrimitive(val: unknown): val is boolean | number | string {\n return typeof val === 'string' || typeof val === 'number' || typeof val === 'boolean';\n}\n","function matchesMediaType(types: string[], mediaType: string): boolean {\n return types.some(type => {\n return mediaType.indexOf(type) > -1;\n });\n}\n\n// biome-ignore lint/style/noDefaultExport: This is safe for now.\nexport default {\n formUrlEncoded: (mimeType: string): boolean => {\n return matchesMediaType(['application/x-www-form-urlencoded'], mimeType);\n },\n\n json: (contentType: string): boolean => {\n return matchesMediaType(\n ['application/json', 'application/x-json', 'text/json', 'text/x-json', '+json'],\n contentType,\n );\n },\n\n multipart: (contentType: string): boolean => {\n return matchesMediaType(\n ['multipart/mixed', 'multipart/related', 'multipart/form-data', 'multipart/alternative'],\n contentType,\n );\n },\n\n wildcard: (contentType: string): boolean => {\n return contentType === '*/*';\n },\n\n xml: (contentType: string): boolean => {\n return matchesMediaType(\n [\n 'application/xml',\n 'application/xml-external-parsed-entity',\n 'application/xml-dtd',\n 'text/xml',\n 'text/xml-external-parsed-entity',\n '+xml',\n ],\n contentType,\n );\n },\n};\n","import type { JSONSchema7TypeName } from 'json-schema';\nimport type { OpenAPIV3_1 } from 'openapi-types';\nimport type { JSONSchema, OASDocument, RequestBodyObject, SchemaObject } from '../types.js';\n\nimport mergeJSONSchemaAllOf from 'json-schema-merge-allof';\nimport jsonpointer from 'jsonpointer';\nimport removeUndefinedObjects from 'remove-undefined-objects';\n\nimport { isOAS31, isRef, isSchema } from '../types.js';\nimport { hasSchemaType, isObject, isPrimitive } from './helpers.js';\n\n/**\n * This list has been pulled from `openapi-schema-to-json-schema` but been slightly modified to fit\n * within the constraints in which ReadMe uses the output from this library in schema form\n * rendering as while properties like `readOnly` aren't represented within JSON Schema, we support\n * it within that library's handling of OpenAPI-friendly JSON Schema.\n *\n * @see {@link https://github.com/openapi-contrib/openapi-schema-to-json-schema/blob/main/src/consts.ts}\n */\nconst UNSUPPORTED_SCHEMA_PROPS = [\n 'example', // OpenAPI supports `example` but we're mapping it to `examples` in this library.\n 'externalDocs',\n 'xml',\n] as const;\n\nexport interface toJSONSchemaOptions {\n /**\n * Whether or not to extend descriptions with a list of any present enums.\n */\n addEnumsToDescriptions?: boolean;\n\n /**\n * Current location within the schema -- this is a JSON pointer.\n */\n currentLocation?: string;\n\n /**\n * Object containing a global set of defaults that we should apply to schemas that match it.\n */\n globalDefaults?: Record<string, unknown>;\n\n /**\n * If you wish to hide properties that are marked as being `readOnly`.\n */\n hideReadOnlyProperties?: boolean;\n\n /**\n * If you wish to hide properties that are marked as being `writeOnly`.\n */\n hideWriteOnlyProperties?: boolean;\n\n /**\n * Is this schema the child of a polymorphic `allOf` schema?\n */\n isPolymorphicAllOfChild?: boolean;\n\n /**\n * Array of parent `default` schemas to utilize when attempting to path together schema defaults.\n */\n prevDefaultSchemas?: SchemaObject[];\n\n /**\n * Array of parent `example` schemas to utilize when attempting to path together schema examples.\n */\n prevExampleSchemas?: SchemaObject[];\n\n /**\n * A function that's called anytime a (circular) `$ref` is found.\n */\n refLogger?: (ref: string, type: 'discriminator' | 'ref') => void;\n\n /**\n * With a transformer you can transform any data within a given schema, like say if you want\n * to rewrite a potentially unsafe `title` that might be eventually used as a JS variable\n * name, just make sure to return your transformed schema.\n */\n transformer?: (schema: SchemaObject) => SchemaObject;\n}\n\n/**\n * Encode a string to be used as a JSON pointer.\n *\n * @see {@link https://tools.ietf.org/html/rfc6901}\n * @param str String to encode into string that can be used as a JSON pointer.\n */\nfunction encodePointer(str: string) {\n return str.replace('~', '~0').replace('/', '~1');\n}\n\nexport function getSchemaVersionString(schema: SchemaObject, api: OASDocument): string {\n // If we're not on version 3.1.0, we always fall back to the default schema version for pre-3.1.0.\n if (!isOAS31(api)) {\n // This should remain as an HTTP url, not HTTPS.\n return 'http://json-schema.org/draft-04/schema#';\n }\n\n /**\n * If the schema indicates the version, prefer that.\n *\n * We use `as` here because the schema *should* be an OAS 3.1 schema due to the `isOAS31` check\n * above.\n */\n if ((schema as OpenAPIV3_1.SchemaObject).$schema) {\n return (schema as OpenAPIV3_1.SchemaObject).$schema;\n }\n\n // If the user defined a global schema version on their OAS document, prefer that.\n if (api.jsonSchemaDialect) {\n return api.jsonSchemaDialect;\n }\n\n return 'https://json-schema.org/draft/2020-12/schema#';\n}\n\nfunction isPolymorphicSchema(schema: SchemaObject): boolean {\n return 'allOf' in schema || 'anyOf' in schema || 'oneOf' in schema;\n}\n\nfunction isRequestBodySchema(schema: unknown): schema is RequestBodyObject {\n return 'content' in (schema as RequestBodyObject);\n}\n\n/**\n * Given a JSON pointer, a type of property to look for, and an array of schemas do a reverse\n * search through them until we find the JSON pointer, or part of it, within the array.\n *\n * This function will allow you to take a pointer like `/tags/name` and return back `buster` from\n * the following array:\n *\n * ```\n * [\n * {\n * example: {id: 20}\n * },\n * {\n * examples: {\n * distinctName: {\n * tags: {name: 'buster'}\n * }\n * }\n * }\n * ]\n * ```\n *\n * As with most things however, this is not without its quirks! If a deeply nested property shares\n * the same name as an example that's further up the stack (like `tags.id` and an example for `id`),\n * there's a chance that it'll be misidentified as having an example and receive the wrong value.\n *\n * That said, any example is usually better than no example though, so while it's quirky behavior\n * it shouldn't raise immediate cause for alarm.\n *\n * @see {@link https://tools.ietf.org/html/rfc6901}\n * @param property Specific type of schema property to look for a value for.\n * @param pointer JSON pointer to search for an example for.\n * @param schemas Array of previous schemas we've found relating to this pointer.\n */\nfunction searchForValueByPropAndPointer(\n property: 'default' | 'example',\n pointer: string,\n schemas: toJSONSchemaOptions['prevDefaultSchemas'] | toJSONSchemaOptions['prevExampleSchemas'] = [],\n) {\n if (!schemas.length || !pointer.length) {\n return undefined;\n }\n\n const locSplit = pointer.split('/').filter(Boolean).reverse();\n const pointers = [];\n\n let point = '';\n for (let i = 0; i < locSplit.length; i += 1) {\n point = `/${locSplit[i]}${point}`;\n pointers.push(point);\n }\n\n let foundValue: any;\n const rev = [...schemas].reverse();\n\n for (let i = 0; i < pointers.length; i += 1) {\n for (let ii = 0; ii < rev.length; ii += 1) {\n let schema = rev[ii];\n\n if (property === 'example') {\n if ('example' in schema) {\n schema = schema.example;\n } else {\n if (!Array.isArray(schema.examples) || !schema.examples.length) {\n continue;\n }\n\n // Prevent us from crashing if `examples` is a completely empty object.\n schema = [...schema.examples].shift();\n }\n } else {\n schema = schema.default;\n }\n\n try {\n foundValue = jsonpointer.get(schema, pointers[i]);\n } catch {\n // If the schema we're looking at is `{obj: null}` and our pointer is `/obj/propertyName`\n // `jsonpointer` will throw an error. If that happens, we should silently catch and toss it\n // and return no example.\n }\n\n if (foundValue !== undefined) {\n break;\n }\n }\n\n if (foundValue !== undefined) {\n break;\n }\n }\n\n return foundValue;\n}\n\n/**\n * Given an OpenAPI-flavored JSON Schema, make an effort to modify it so it's shaped more towards\n * stock JSON Schema.\n *\n * Why do this?\n *\n * 1. OpenAPI 3.0.x supports its own flavor of JSON Schema that isn't fully compatible with most\n * JSON Schema tooling (like `@readme/oas-form` or `@rjsf/core`).\n * 2. While validating an OpenAPI definition will prevent corrupted or improper schemas from\n * occuring, we have a lot of legacy schemas in ReadMe that were ingested before we had proper\n * validation in place, and as a result have some API definitions that will not pass validation\n * right now. In addition to reshaping OAS-JSON Schema into JSON Schema this library will also\n * fix these improper schemas: things like `type: object` having `items` instead of `properties`,\n * or `type: array` missing `items`.\n * 3. To ease the burden of polymorphic handling on our form rendering engine we make an attempt\n * to merge `allOf` schemas here.\n * 4. Additionally due to OpenAPI 3.0.x not supporting JSON Schema, in order to support the\n * `example` keyword that OAS supports, we need to do some work in here to remap it into\n * `examples`. However, since all we care about in respect to examples for usage within\n * `@readme/oas-form`, we're only retaining primitives. This *slightly* deviates from JSON\n * Schema in that JSON Schema allows for any schema to be an example, but since\n * `@readme/oas-form` can only actually **render** primitives, that's what we're retaining.\n * 5. Though OpenAPI 3.1 does support full JSON Schema, this library should be able to handle it\n * without any problems.\n *\n * And why use this over `@openapi-contrib/openapi-schema-to-json-schema`? Fortunately and\n * unfortunately we've got a lot of API definitions in our database that aren't currently valid so\n * we need to have a lot of bespoke handling for odd quirks, typos, and missing declarations that\n * might be present.\n *\n * @todo add support for `schema: false` and `not` cases.\n * @see {@link https://json-schema.org/draft/2019-09/json-schema-validation.html}\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.3.md#schema-object}\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.0.md#schema-object}\n * @param data OpenAPI Schema Object to convert to pure JSON Schema.\n */\nexport function toJSONSchema(data: SchemaObject | boolean, opts: toJSONSchemaOptions = {}): SchemaObject {\n let schema = data === true ? {} : { ...data };\n const schemaAdditionalProperties = isSchema(schema) ? schema.additionalProperties : null;\n\n const {\n addEnumsToDescriptions,\n currentLocation,\n globalDefaults,\n hideReadOnlyProperties,\n hideWriteOnlyProperties,\n isPolymorphicAllOfChild,\n prevDefaultSchemas,\n prevExampleSchemas,\n refLogger,\n transformer,\n } = {\n addEnumsToDescriptions: false,\n currentLocation: '',\n globalDefaults: {},\n hideReadOnlyProperties: false,\n hideWriteOnlyProperties: false,\n isPolymorphicAllOfChild: false,\n prevDefaultSchemas: [] as toJSONSchemaOptions['prevDefaultSchemas'],\n prevExampleSchemas: [] as toJSONSchemaOptions['prevExampleSchemas'],\n refLogger: () => true,\n transformer: (s: SchemaObject) => s,\n ...opts,\n };\n\n // If this schema contains a `$ref`, it's circular and we shouldn't try to resolve it. Just\n // return and move along.\n if (isRef(schema)) {\n refLogger(schema.$ref, 'ref');\n\n return transformer({\n $ref: schema.$ref,\n });\n }\n\n // If we don't have a set type, but are dealing with an `anyOf`, `oneOf`, or `allOf`\n // representation let's run through them and make sure they're good.\n if (isSchema(schema, isPolymorphicAllOfChild)) {\n // If this is an `allOf` schema we should make an attempt to merge so as to ease the burden on\n // the tooling that ingests these schemas.\n if ('allOf' in schema && Array.isArray(schema.allOf)) {\n try {\n schema = mergeJSONSchemaAllOf(schema as JSONSchema, {\n ignoreAdditionalProperties: true,\n resolvers: {\n // `merge-json-schema-allof` by default takes the first `description` when you're\n // merging an `allOf` but because generally when you're merging two schemas together\n // with an `allOf` you want data in the subsequent schemas to be applied to the first\n // and `description` should be a part of that.\n description: (obj: string[]) => {\n return obj.slice(-1)[0];\n },\n\n // `merge-json-schema-allof` doesn't support merging enum arrays but since that's a\n // safe and simple operation as enums always contain primitives we can handle it\n // ourselves with a custom resolver.\n enum: (obj: unknown[]) => {\n let arr: unknown[] = [];\n obj.forEach(e => {\n arr = arr.concat(e);\n });\n\n return arr;\n },\n\n // for any unknown keywords (e.g., `example`, `format`, `x-readme-ref-name`),\n // we fallback to using the title resolver (which uses the first value found).\n // https://github.com/mokkabonna/json-schema-merge-allof/blob/ea2e48ee34415022de5a50c236eb4793a943ad11/src/index.js#L292\n // https://github.com/mokkabonna/json-schema-merge-allof/blob/ea2e48ee34415022de5a50c236eb4793a943ad11/README.md?plain=1#L147\n defaultResolver: mergeJSONSchemaAllOf.options.resolvers.title,\n } as unknown,\n }) as SchemaObject;\n } catch {\n // If we can't merge the `allOf` for whatever reason (like if one item is a `string` and\n // the other is a `object`) then we should completely remove it from the schema and continue\n // with whatever we've got. Why? If we don't, any tooling that's ingesting this will need\n // to account for the incompatible `allOf` and it may be subject to more breakages than\n // just not having it present would be.\n const { ...schemaWithoutAllOf } = schema;\n schema = schemaWithoutAllOf as SchemaObject;\n delete schema.allOf;\n }\n\n // If after merging the `allOf` this schema still contains a `$ref` then it's circular and\n // we shouldn't do anything else.\n if (isRef(schema)) {\n refLogger(schema.$ref, 'ref');\n\n return transformer({\n $ref: schema.$ref,\n });\n }\n }\n\n ['anyOf', 'oneOf'].forEach((polyType: 'anyOf' | 'oneOf') => {\n if (polyType in schema && Array.isArray(schema[polyType])) {\n schema[polyType].forEach((item, idx) => {\n const polyOptions: toJSONSchemaOptions = {\n addEnumsToDescriptions,\n currentLocation: `${currentLocation}/${idx}`,\n globalDefaults,\n hideReadOnlyProperties,\n hideWriteOnlyProperties,\n isPolymorphicAllOfChild: false,\n prevDefaultSchemas,\n prevExampleSchemas,\n refLogger,\n transformer,\n };\n\n // When `properties` or `items` are present alongside a polymorphic schema instead of\n // letting whatever JSON Schema interpreter is handling these constructed schemas we can\n // guide its hand a bit by manually transforming it into an inferred `allOf` of the\n // `properties` + the polymorph schema.\n //\n // This `allOf` schema will be merged together when fed through `toJSONSchema`.\n if ('properties' in schema) {\n schema[polyType][idx] = toJSONSchema(\n { required: schema.required, allOf: [item, { properties: schema.properties }] } as SchemaObject,\n polyOptions,\n );\n } else if ('items' in schema) {\n schema[polyType][idx] = toJSONSchema(\n { allOf: [item, { items: schema.items }] } as SchemaObject,\n polyOptions,\n );\n } else {\n schema[polyType][idx] = toJSONSchema(item as SchemaObject, polyOptions);\n }\n\n // Ensure that we don't have any invalid `required` booleans lying around.\n if (\n isObject(schema[polyType][idx]) &&\n 'required' in (schema[polyType][idx] as SchemaObject) &&\n typeof (schema[polyType][idx] as SchemaObject).required === 'boolean'\n ) {\n delete (schema[polyType][idx] as SchemaObject).required;\n }\n });\n }\n });\n\n if ('discriminator' in schema) {\n if ('mapping' in schema.discriminator && typeof schema.discriminator.mapping === 'object') {\n // Discriminator mappings aren't written as traditional `$ref` pointers so in order to log\n // them to the supplied `refLogger`.\n const mapping = schema.discriminator.mapping;\n Object.keys(mapping).forEach(k => {\n refLogger(mapping[k], 'discriminator');\n });\n }\n }\n }\n\n // If this schema is malformed for some reason, let's do our best to repair it.\n if (!('type' in schema) && !isPolymorphicSchema(schema) && !isRequestBodySchema(schema)) {\n if ('properties' in schema) {\n schema.type = 'object';\n } else if ('items' in schema) {\n schema.type = 'array';\n } else {\n // If there's still no `type` on the schema we should leave it alone because we don't have a\n // great way to know if it's part of a nested schema that should, and couldn't be merged,\n // into another, or it's just purely malformed.\n //\n // Whatever tooling that ingests the generated schema should handle it however it needs to.\n }\n }\n\n if ('type' in schema) {\n // `nullable` isn't a thing in JSON Schema but it was in OpenAPI 3.0 so we should retain and\n // translate it into something that's compatible with JSON Schema.\n if ('nullable' in schema) {\n if (schema.nullable) {\n if (Array.isArray(schema.type)) {\n schema.type.push('null');\n } else if (schema.type !== null && schema.type !== 'null') {\n schema.type = [schema.type, 'null'];\n }\n }\n\n delete schema.nullable;\n }\n\n if (schema.type === null) {\n // `type: null` is possible in JSON Schema but we're translating it to a string version\n // so we don't need to worry about asserting nullish types in our implementations of this\n // generated schema.\n schema.type = 'null';\n } else if (Array.isArray(schema.type)) {\n if (schema.type.includes(null)) {\n schema.type[schema.type.indexOf(null)] = 'null';\n }\n\n schema.type = Array.from(new Set(schema.type));\n\n // We don't need `type: [<type>]` when we can just as easily make it `type: <type>`.\n if (schema.type.length === 1) {\n schema.type = schema.type.shift();\n } else if (schema.type.includes('array') || schema.type.includes('boolean') || schema.type.includes('object')) {\n // If we have a `null` type but there's only two types present then we can remove `null`\n // as an option and flag the whole schema as `nullable`.\n const isNullable = schema.type.includes('null');\n\n if (schema.type.length === 2 && isNullable) {\n // If this is `array | null` or `object | null` then we don't need to do anything.\n } else {\n // If this mixed type has non-primitives then we for convenience of our implementation\n // we're moving them into a `oneOf`.\n const nonPrimitives: any[] = [];\n\n // Because arrays, booleans, and objects are not compatible with any other schem type\n // other than null we're moving them into an isolated `oneOf`, and as such want to take\n // with it its specific properties that may be present on our current schema.\n Object.entries({\n // https://json-schema.org/understanding-json-schema/reference/array.html\n array: [\n 'additionalItems',\n 'contains',\n 'items',\n 'maxContains',\n 'maxItems',\n 'minContains',\n 'minItems',\n 'prefixItems',\n 'uniqueItems',\n ],\n\n // https://json-schema.org/understanding-json-schema/reference/boolean.html\n boolean: [\n // Booleans don't have any boolean-specific properties.\n ],\n\n // https://json-schema.org/understanding-json-schema/reference/object.html\n object: [\n 'additionalProperties',\n 'maxProperties',\n 'minProperties',\n 'nullable',\n 'patternProperties',\n 'properties',\n 'propertyNames',\n 'required',\n ],\n }).forEach(([typeKey, keywords]) => {\n if (!schema.type.includes(typeKey as JSONSchema7TypeName)) {\n return;\n }\n\n const reducedSchema: any = removeUndefinedObjects({\n type: isNullable ? [typeKey, 'null'] : typeKey,\n\n allowEmptyValue: (schema as any).allowEmptyValue ?? undefined,\n deprecated: schema.deprecated ?? undefined,\n description: schema.description ?? undefined,\n readOnly: schema.readOnly ?? undefined,\n title: schema.title ?? undefined,\n writeOnly: schema.writeOnly ?? undefined,\n });\n\n keywords.forEach((t: keyof SchemaObject) => {\n if (t in schema) {\n reducedSchema[t] = schema[t];\n delete schema[t];\n }\n });\n\n nonPrimitives.push(reducedSchema);\n });\n\n schema.type = schema.type.filter(t => t !== 'array' && t !== 'boolean' && t !== 'object');\n if (schema.type.length === 1) {\n schema.type = schema.type.shift();\n }\n\n // Because we may have encountered a fully mixed non-primitive type like `array | object`\n // we only want to retain the existing schema object if we still have types remaining\n // in it.\n if (schema.type.length > 1) {\n schema = { oneOf: [schema, ...nonPrimitives] };\n } else {\n schema = { oneOf: nonPrimitives };\n }\n }\n }\n }\n }\n\n if (isSchema(schema, isPolymorphicAllOfChild)) {\n if ('default' in schema && isObject(schema.default)) {\n prevDefaultSchemas.push({ default: schema.default });\n }\n\n // JSON Schema doesn't support OpenAPI-style examples so we need to reshape them a bit.\n if ('example' in schema) {\n // Only bother adding primitive examples.\n if (isPrimitive(schema.example)) {\n schema.examples = [schema.example];\n } else if (Array.isArray(schema.example)) {\n schema.examples = schema.example.filter(example => isPrimitive(example));\n if (!schema.examples.length) {\n delete schema.examples;\n }\n } else {\n prevExampleSchemas.push({ example: schema.example });\n }\n\n delete schema.example;\n } else if ('examples' in schema) {\n let reshapedExamples = false;\n if (typeof schema.examples === 'object' && !Array.isArray(schema.examples)) {\n const examples: unknown[] = [];\n Object.keys(schema.examples).forEach(name => {\n const example = schema.examples[name as unknown as number];\n if ('$ref' in example) {\n // no-op because any `$ref` example here after dereferencing is circular so we should\n // ignore it\n refLogger(example.$ref, 'ref');\n } else if ('value' in example) {\n if (isPrimitive(example.value)) {\n examples.push(example.value);\n reshapedExamples = true;\n } else if (Array.isArray(example.value) && isPrimitive(example.value[0])) {\n examples.push(example.value[0]);\n reshapedExamples = true;\n } else {\n // If this example is neither a primitive or an array we should dump it into the\n // `prevExampleSchemas` array because we might be able to extract an example from it\n // further downstream.\n prevExampleSchemas.push({\n example: example.value,\n });\n }\n }\n });\n\n if (examples.length) {\n reshapedExamples = true;\n schema.examples = examples;\n }\n } else if (Array.isArray(schema.examples) && isPrimitive(schema.examples[0])) {\n // We haven't reshaped `examples` here, but since it's in a state that's preferrable to us\n // let's keep it around.\n reshapedExamples = true;\n }\n\n if (!reshapedExamples) {\n delete schema.examples;\n }\n }\n\n // If we didn't have any immediately defined examples, let's search backwards and see if we can\n // find one. But as we're only looking for primitive example, only try to search for one if\n // we're dealing with a primitive schema.\n if (!hasSchemaType(schema, 'array') && !hasSchemaType(schema, 'object') && !schema.examples) {\n const foundExample = searchForValueByPropAndPointer('example', currentLocation, prevExampleSchemas);\n if (foundExample) {\n // We can only really deal with primitives, so only promote those as the found example if\n // it is.\n if (isPrimitive(foundExample) || (Array.isArray(foundExample) && isPrimitive(foundExample[0]))) {\n schema.examples = [foundExample];\n }\n }\n }\n\n if (hasSchemaType(schema, 'array')) {\n if ('items' in schema) {\n if (!Array.isArray(schema.items) && Object.keys(schema.items).length === 1 && isRef(schema.items)) {\n // `items` contains a `$ref`, so since it's circular we should do a no-op here and log\n // and ignore it.\n refLogger(schema.items.$ref, 'ref');\n } else if (schema.items !== true) {\n // Run through the arrays contents and clean them up.\n schema.items = toJSONSchema(schema.items as SchemaObject, {\n addEnumsToDescriptions,\n currentLocation: `${currentLocation}/0`,\n globalDefaults,\n hideReadOnlyProperties,\n hideWriteOnlyProperties,\n prevExampleSchemas,\n refLogger,\n transformer,\n });\n\n // If we have a non-array `required` entry in our `items` schema then it's invalid and we\n // should remove it. We only support non-array boolean `required` properties inside object\n // properties.\n if (isObject(schema.items) && 'required' in schema.items && !Array.isArray(schema.items.required)) {\n delete schema.items.required;\n }\n }\n } else if ('properties' in schema || 'additionalProperties' in schema) {\n // This is a fix to handle cases where someone may have typod `items` as `properties` on an\n // array. Since throwing a complete failure isn't ideal, we can see that they meant for the\n // type to be `object`, so we can do our best to shape the data into what they were\n // intending it to be.\n schema.type = 'object';\n } else {\n // This is a fix to handle cases where we have a malformed array with no `items` property\n // present.\n (schema as any).items = {};\n }\n } else if (hasSchemaType(schema, 'object')) {\n if ('properties' in schema) {\n Object.keys(schema.properties).forEach(prop => {\n if (\n Array.isArray(schema.properties[prop]) ||\n (typeof schema.properties[prop] === 'object' && schema.properties[prop] !== null)\n ) {\n const newPropSchema = toJSONSchema(schema.properties[prop] as SchemaObject, {\n addEnumsToDescriptions,\n currentLocation: `${currentLocation}/${encodePointer(prop)}`,\n globalDefaults,\n hideReadOnlyProperties,\n hideWriteOnlyProperties,\n prevDefaultSchemas,\n prevExampleSchemas,\n refLogger,\n transformer,\n });\n\n // If this property is read or write only then we should fully hide it from its parent schema.\n let propShouldBeUpdated = true;\n if ((hideReadOnlyProperties || hideWriteOnlyProperties) && !Object.keys(newPropSchema).length) {\n // We should only delete this schema if it wasn't already empty though. We do this\n // because we (un)fortunately have handling in our API Explorer form system for\n // schemas that are devoid of any `type` declaration.\n if (Object.keys(schema.properties[prop]).length > 0) {\n delete schema.properties[prop];\n propShouldBeUpdated = false;\n }\n }\n\n if (propShouldBeUpdated) {\n schema.properties[prop] = newPropSchema;\n\n /**\n * JSON Schema does not have any support for `required: <boolean>` but because some\n * of our users do this, and it does not throw OpenAPI validation errors thanks to\n * some extremely loose typings around `schema` in the official JSON Schema\n * definitions that the OAI offers, we're opting to support these users and upgrade\n * their invalid `required` definitions into ones that our tooling can interpret.\n *\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/schemas/v3.1/schema.json#L1114-L1121}\n */\n if (\n isObject(newPropSchema) &&\n 'required' in newPropSchema &&\n typeof newPropSchema.required === 'boolean' &&\n newPropSchema.required === true\n ) {\n if ('required' in schema && Array.isArray(schema.required)) {\n schema.required.push(prop);\n } else {\n schema.required = [prop];\n }\n\n delete (schema.properties[prop] as SchemaObject).required;\n }\n }\n }\n });\n\n // If we want to hide all readOnly or writeOnly properites and it happens to be that this\n // object was comprised of only those then we shouldn't render this object.\n if (hideReadOnlyProperties || hideWriteOnlyProperties) {\n if (!Object.keys(schema.properties).length) {\n return transformer({});\n }\n }\n }\n\n if (typeof schemaAdditionalProperties === 'object' && schemaAdditionalProperties !== null) {\n // If this `additionalProperties` is completely empty and devoid of any sort of schema,\n // treat it as such. Otherwise let's recurse into it and see if we can sort it out.\n if (\n !('type' in schemaAdditionalProperties) &&\n !('$ref' in schemaAdditionalProperties) &&\n // We know it will be a schema object because it's dereferenced\n !isPolymorphicSchema(schemaAdditionalProperties as SchemaObject)\n ) {\n schema.additionalProperties = true;\n } else {\n // We know it will be a schema object because it's dereferenced\n schema.additionalProperties = toJSONSchema(schemaAdditionalProperties as SchemaObject, {\n addEnumsToDescriptions,\n currentLocation,\n globalDefaults,\n hideReadOnlyProperties,\n hideWriteOnlyProperties,\n prevDefaultSchemas,\n prevExampleSchemas,\n refLogger,\n transformer,\n });\n }\n }\n\n // Since neither `properties` and `additionalProperties` are actually required to be present\n // on an object, since we construct this schema work to build up a form we still need\n // *something* for the user to enter in for this object so we'll add back in\n // `additionalProperties` for that.\n if (!isPolymorphicSchema(schema) && !('properties' in schema) && !('additionalProperties' in schema)) {\n schema.additionalProperties = true;\n }\n }\n }\n\n /**\n * Users can pass in parameter defaults via JWT User Data. We're checking to see if the defaults\n * being passed in exist on endpoints via jsonpointer\n *\n * @see {@link https://docs.readme.com/docs/passing-data-to-jwt}\n */\n if (\n isSchema(schema, isPolymorphicAllOfChild) &&\n globalDefaults &&\n Object.keys(globalDefaults).length > 0 &&\n currentLocation\n ) {\n try {\n const userJwtDefault = jsonpointer.get(globalDefaults, currentLocation);\n if (userJwtDefault) {\n schema.default = userJwtDefault;\n }\n } catch {\n // If jsonpointer returns an error, we won't show any defaults for that path.\n }\n }\n\n // Only add a default value if we actually have one.\n if ('default' in schema && typeof schema.default !== 'undefined') {\n if (hasSchemaType(schema, 'object')) {\n // Defaults for `object` and types have been dereferenced into their children schemas already\n // above so we don't need to preserve this default anymore.\n delete schema.default;\n } else if (\n ('allowEmptyValue' in schema && schema.allowEmptyValue && schema.default === '') ||\n schema.default !== ''\n ) {\n // If we have `allowEmptyValue` present, and the default is actually an empty string, let it\n // through as it's allowed.\n } else {\n // If the default is empty and we don't want to allowEmptyValue, we need to remove the\n // default.\n delete schema.default;\n }\n } else if (prevDefaultSchemas.length) {\n const foundDefault = searchForValueByPropAndPointer('default', currentLocation, prevDefaultSchemas);\n\n // We shouldn't ever set an object default out of the parent lineage tree defaults because\n // the contents of that object will be set on the schema that they're a part of. Setting\n // that object as well would result us in duplicating the defaults for that schema in two\n // places.\n if (\n isPrimitive(foundDefault) ||\n foundDefault === null ||\n (Array.isArray(foundDefault) && hasSchemaType(schema, 'array'))\n ) {\n schema.default = foundDefault;\n }\n }\n\n if (isSchema(schema, isPolymorphicAllOfChild) && 'enum' in schema && Array.isArray(schema.enum)) {\n // Enums should not have duplicated items as those will break AJV validation.\n // If we ever target ES6 for typescript we can drop this array.from.\n // https://stackoverflow.com/questions/33464504/using-spread-syntax-and-new-set-with-typescript/56870548\n schema.enum = Array.from(new Set(schema.enum));\n\n // If we want to add enums to descriptions (like in the case of response JSON Schema)\n // generation we need to convert them into a list of Markdown tilda'd strings. We're also\n // filtering away empty and falsy strings here because adding empty `` blocks to the description\n // will serve nobody any good.\n if (addEnumsToDescriptions) {\n const enums = schema.enum\n .filter(v => v !== undefined && (typeof v !== 'string' || v.trim() !== ''))\n .map(str => `\\`${str}\\``)\n .join(' ');\n\n if (enums.length) {\n if ('description' in schema) {\n schema.description += `\\n\\n${enums}`;\n } else {\n schema.description = enums;\n }\n }\n }\n }\n\n // Clean up any remaining `items` or `properties` schema fragments lying around if there's also\n // polymorphism present.\n if ('anyOf' in schema || 'oneOf' in schema) {\n if ('properties' in schema) {\n delete schema.properties;\n }\n\n if ('items' in schema) {\n delete schema.items;\n }\n }\n\n // Remove unsupported JSON Schema props.\n for (let i = 0; i < UNSUPPORTED_SCHEMA_PROPS.length; i += 1) {\n // Using the as here because the purpose is to delete keys we don't expect, so of course the\n // typing won't work\n delete (schema as Record<string, unknown>)[UNSUPPORTED_SCHEMA_PROPS[i]];\n }\n\n // If we want to hide any `readOnly` or `writeOnly` schemas, and this one is that, then we\n // shouldn't return anything.\n if (hideReadOnlyProperties && 'readOnly' in schema && schema.readOnly === true) {\n return {};\n } else if (hideWriteOnlyProperties && 'writeOnly' in schema && schema.writeOnly === true) {\n return {};\n }\n\n return transformer(schema);\n}\n","import type { OpenAPIV3_1 } from 'openapi-types';\nimport type { toJSONSchemaOptions } from '../../lib/openapi-to-json-schema.js';\nimport type { ComponentsObject, ExampleObject, OASDocument, ParameterObject, SchemaObject } from '../../types.js';\nimport type { Operation } from '../index.js';\n\nimport { getExtension, PARAMETER_ORDERING } from '../../extensions.js';\nimport { cloneObject } from '../../lib/clone-object.js';\nimport { isPrimitive } from '../../lib/helpers.js';\nimport matchesMimetype from '../../lib/matches-mimetype.js';\nimport { getSchemaVersionString, toJSONSchema } from '../../lib/openapi-to-json-schema.js';\n\nexport interface SchemaWrapper {\n $schema?: string;\n deprecatedProps?: SchemaWrapper;\n description?: string;\n label?: string;\n schema: SchemaObject;\n type: string;\n}\n\n/**\n * The order of this object determines how they will be sorted in the compiled JSON Schema\n * representation.\n *\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.3.md#parameter-object}\n * @see {@link https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.0.md#parameter-object}\n */\nexport const types: Record<keyof OASDocument, string> = {\n path: 'Path Params',\n query: 'Query Params',\n body: 'Body Params',\n cookie: 'Cookie Params',\n formData: 'Form Data',\n header: 'Headers',\n metadata: 'Metadata', // This a special type reserved for https://npm.im/api\n};\n\nexport interface getParametersAsJSONSchemaOptions {\n /**\n * Contains an object of user defined schema defaults.\n */\n globalDefaults?: Record<string, unknown>;\n\n /**\n * If you wish to hide properties that are marked as being `readOnly`.\n */\n hideReadOnlyProperties?: boolean;\n\n /**\n * If you wish to hide properties that are marked as being `writeOnly`.\n */\n hideWriteOnlyProperties?: boolean;\n\n /**\n * If you wish to include discriminator mapping `$ref` components alongside your\n * `discriminator` in schemas. Defaults to `true`.\n */\n includeDiscriminatorMappingRefs?: boolean;\n\n /**\n * If you want the output to be two objects: body (contains `body` and `formData` JSON\n * Schema) and metadata (contains `path`, `query`, `cookie`, and `header`).\n */\n mergeIntoBodyAndMetadata?: boolean;\n\n /**\n * If you wish to **not** split out deprecated properties into a separate `deprecatedProps`\n * object.\n */\n retainDeprecatedProperties?: boolean;\n\n /**\n * With a transformer you can transform any data within a given schema, like say if you want\n * to rewrite a potentially unsafe `title` that might be eventually used as a JS variable\n * name, just make sure to return your transformed schema.\n */\n transformer?: (schema: SchemaObject) => SchemaObject;\n}\n\nexport function getParametersAsJSONSchema(\n operation: Operation,\n api: OASDocument,\n opts?: getParametersAsJSONSchemaOptions,\n): SchemaWrapper[] {\n let hasCircularRefs = false;\n let hasDiscriminatorMappingRefs = false;\n\n function refLogger(ref: string, type: 'discriminator' | 'ref') {\n if (type === 'ref') {\n hasCircularRefs = true;\n } else {\n hasDiscriminatorMappingRefs = true;\n }\n }\n\n function getDeprecated(schema: SchemaObject, type: string) {\n // If we wish to retain deprecated properties then we shouldn't split them out into the\n // `deprecatedProps` object.\n if (opts.retainDeprecatedProperties) {\n return null;\n }\n\n // If there's no properties, bail\n if (!schema || !schema.properties) return null;\n\n // Clone the original schema so this doesn't interfere with it\n const deprecatedBody = cloneObject(schema);\n\n // Booleans are not valid for required in draft 4, 7 or 2020. Not sure why the typing thinks\n // they are.\n const requiredParams = (schema.required || []) as string[];\n\n // Find all top-level deprecated properties from the schema - required and readOnly params are\n // excluded.\n const allDeprecatedProps: Record<string, SchemaObject> = {};\n\n Object.keys(deprecatedBody.properties).forEach(key => {\n const deprecatedProp = deprecatedBody.properties[key] as SchemaObject;\n if (deprecatedProp.deprecated && !requiredParams.includes(key) && !deprecatedProp.readOnly) {\n allDeprecatedProps[key] = deprecatedProp;\n }\n });\n\n // We know this is the right type. todo: don't use as\n (deprecatedBody.properties as Record<string, SchemaObject>) = allDeprecatedProps;\n const deprecatedSchema = toJSONSchema(deprecatedBody, {\n globalDefaults: opts.globalDefaults,\n hideReadOnlyProperties: opts.hideReadOnlyProperties,\n hideWriteOnlyProperties: opts.hideWriteOnlyProperties,\n prevExampleSchemas: [],\n refLogger,\n transformer: opts.transformer,\n });\n\n // Check if the schema wasn't created or there's no deprecated properties\n if (Object.keys(deprecatedSchema).length === 0 || Object.keys(deprecatedSchema.properties).length === 0) {\n return null;\n }\n\n // Remove deprecated properties from the original schema\n // Not using the clone here becuase we WANT this to affect the original\n Object.keys(schema.properties).forEach(key => {\n // We know this will always be a SchemaObject\n if ((schema.properties[key] as SchemaObject).deprecated && !requiredParams.includes(key)) {\n delete schema.properties[key];\n }\n });\n\n return {\n type,\n schema: isPrimitive(deprecatedSchema)\n ? deprecatedSchema\n : {\n ...deprecatedSchema,\n $schema: getSchemaVersionString(deprecatedSchema, api),\n },\n };\n }\n\n /**\n *\n */\n function transformRequestBody(): SchemaWrapper {\n const requestBody = operation.getRequestBody();\n if (!requestBody || !Array.isArray(requestBody)) return null;\n\n const [mediaType, mediaTypeObject, description] = requestBody;\n const type = mediaType === 'application/x-www-form-urlencoded' ? 'formData' : 'body';\n\n // If this schema is completely empty, don't bother processing it.\n if (!mediaTypeObject.schema || !Object.keys(mediaTypeObject.schema).length) {\n return null;\n }\n\n const prevExampleSchemas: toJSONSchemaOptions['prevExampleSchemas'] = [];\n if ('example' in mediaTypeObject) {\n prevExampleSchemas.push({ example: mediaTypeObject.example });\n } else if ('examples' in mediaTypeObject) {\n prevExampleSchemas.push({\n examples: Object.values(mediaTypeObject.examples)\n .map((example: ExampleObject) => example.value)\n .filter(val => val !== undefined),\n });\n }\n\n // We're cloning the request schema because we've had issues with request schemas that were\n // dereferenced being processed multiple times because their component is also processed.\n const requestSchema = cloneObject(mediaTypeObject.schema);\n\n const cleanedSchema = toJSONSchema(requestSchema, {\n globalDefaults: opts.globalDefaults,\n hideReadOnlyProperties: opts.hideReadOnlyProperties,\n hideWriteOnlyProperties: opts.hideWriteOnlyProperties,\n prevExampleSchemas,\n refLogger,\n transformer: opts.transformer,\n });\n\n // If this schema is **still** empty, don't bother returning it.\n if (!Object.keys(cleanedSchema).length) {\n return null;\n }\n\n return {\n type,\n label: types[type],\n schema: isPrimitive(cleanedSchema)\n ? cleanedSchema\n : {\n ...cleanedSchema,\n $schema: getSchemaVersionString(cleanedSchema, api),\n },\n deprecatedProps: getDeprecated(cleanedSchema, type),\n ...(description ? { description } : {}),\n };\n }\n\n function transformComponents(): ComponentsObject {\n if (!('components' in api)) {\n return false;\n }\n\n const components: Partial<ComponentsObject> = {\n ...Object.keys(api.components)\n .map(componentType => ({ [componentType]: {} }))\n .reduce((prev, next) => Object.assign(prev, next), {}),\n };\n\n Object.keys(api.components).forEach((componentType: keyof ComponentsObject) => {\n if (typeof api.components[componentType] === 'object' && !Array.isArray(api.components[componentType])) {\n Object.keys(api.components[componentType]).forEach(schemaName => {\n const componentSchema = cloneObject(api.components[componentType][schemaName]);\n components[componentType][schemaName] = toJSONSchema(componentSchema as SchemaObject, {\n globalDefaults: opts.globalDefaults,\n hideReadOnlyProperties: opts.hideReadOnlyProperties,\n hideWriteOnlyProperties: opts.hideWriteOnlyProperties,\n refLogger,\n transformer: opts.transformer,\n });\n });\n }\n });\n\n // If none of our above component type placeholders got used let's clean them up.\n Object.keys(components).forEach((componentType: keyof ComponentsObject) => {\n if (!Object.keys(components[componentType]).length) {\n delete components[componentType];\n }\n });\n\n return components;\n }\n\n function transformParameters(): SchemaWrapper[] {\n const operationParams = operation.getParameters();\n\n const transformed = Object.keys(types)\n .map(type => {\n const required: string[] = [];\n\n // This `as` actually *could* be a ref, but we don't want refs to pass through here, so\n // `.in` will never match `type`\n const parameters = operationParams.filter(param => (param as ParameterObject).in === type);\n if (parameters.length === 0) {\n return null;\n }\n\n const properties = parameters.reduce((prev: Record<string, SchemaObject>, current: ParameterObject) => {\n let schema: SchemaObject = {};\n if ('schema' in current) {\n const currentSchema: SchemaObject = current.schema ? cloneObject(current.schema) : {};\n\n if (current.example) {\n // `example` can be present outside of the `schema` block so if it's there we should\n // pull it in so it can be handled and returned if it's valid.\n currentSchema.example = current.example;\n } else if (current.examples) {\n // `examples` isn't actually supported here in OAS 3.0, but we might as well support\n // it because `examples` is JSON Schema and that's fully supported in OAS 3.1.\n currentSchema.examples = current.examples as unknown as unknown[];\n }\n\n if (current.deprecated) currentSchema.deprecated = current.deprecated;\n\n const interimSchema = toJSONSchema(currentSchema, {\n currentLocation: `/${current.name}`,\n globalDefaults: opts.globalDefaults,\n hideReadOnlyProperties: opts.hideReadOnlyProperties,\n hideWriteOnlyProperties: opts.hideWriteOnlyProperties,\n refLogger,\n transformer: opts.transformer,\n });\n\n schema = isPrimitive(interimSchema)\n ? interimSchema\n : {\n ...interimSchema,\n\n // Note: this applies a `$schema` version to each field in the larger schema\n // object. It's not really **correct** but it's what we have to do because\n // there's a chance that the end user has indicated the schemas are different.\n $schema: getSchemaVersionString(currentSchema, api),\n };\n } else if ('content' in current && typeof current.content === 'object') {\n const contentKeys = Object.keys(current.content);\n if (contentKeys.length) {\n let contentType: string;\n if (contentKeys.length === 1) {\n contentType = contentKeys[0];\n } else {\n // We should always try to prioritize `application/json` over any other possible\n // content that might be present on this schema.\n const jsonLikeContentTypes = contentKeys.filter(k => matchesMimetype.json(k));\n if (jsonLikeContentTypes.length) {\n contentType = jsonLikeContentTypes[0];\n } else {\n contentType = contentKeys[0];\n }\n }\n\n if (typeof current.content[contentType] === 'object' && 'schema' in current.content[contentType]) {\n const currentSchema: SchemaObject = current.content[contentType].schema\n ? cloneObject(current.content[contentType].schema)\n : {};\n\n if (current.example) {\n // `example` can be present outside of the `schema` block so if it's there we\n // should pull it in so it can be handled and returned if it's valid.\n currentSchema.example = current.example;\n } else if (current.examples) {\n // `examples` isn't actually supported here in OAS 3.0, but we might as well\n // support it because `examples` is JSON Schema and that's fully supported in OAS\n // 3.1.\n currentSchema.examples = current.examples as unknown as unknown[];\n }\n\n if (current.deprecated) currentSchema.deprecated = current.deprecated;\n\n const interimSchema = toJSONSchema(currentSchema, {\n currentLocation: `/${current.name}`,\n globalDefaults: opts.globalDefaults,\n hideReadOnlyProperties: opts.hideReadOnlyProperties,\n hideWriteOnlyProperties: opts.hideWriteOnlyProperties,\n refLogger,\n transformer: opts.transformer,\n });\n\n schema = isPrimitive(interimSchema)\n ? interimSchema\n : {\n ...interimSchema,\n\n // Note: this applies a `$schema` version to each field in the larger schema\n // object. It's not really **correct** but it's what we have to do because\n // there's a chance that the end user has indicated the schemas are different.\n $schema: getSchemaVersionString(currentSchema, api),\n };\n }\n }\n }\n\n // Parameter descriptions don't exist in `current.schema` so `constructSchema` will never\n // have access to it.\n if (current.description) {\n if (!isPrimitive(schema)) {\n schema.description = current.description;\n }\n }\n\n prev[current.name] = schema;\n\n if (current.required) {\n required.push(current.name);\n }\n\n return prev;\n }, {});\n\n // This typing is technically WRONG :( but it's the best we can do for now.\n const schema: OpenAPIV3_1.SchemaObject = {\n type: 'object',\n properties: properties as Record<string, OpenAPIV3_1.SchemaObject>,\n required,\n };\n\n return {\n type,\n label: types[type],\n schema,\n deprecatedProps: getDeprecated(schema, type),\n };\n })\n .filter(Boolean);\n\n if (!opts.mergeIntoBodyAndMetadata) {\n return transformed;\n } else if (!transformed.length) {\n return [];\n }\n\n // If we want to merge parameters into a single metadata entry then we need to pull all\n // available schemas and `deprecatedProps` (if we don't want to retain them via the\n // `retainDeprecatedProps` option) under one roof.\n const deprecatedProps = transformed.map(r => r.deprecatedProps?.schema || null).filter(Boolean);\n return [\n {\n type: 'metadata',\n label: types.metadata,\n schema: {\n allOf: transformed.map(r => r.schema),\n } as SchemaObject,\n deprecatedProps: deprecatedProps.length\n ? {\n type: 'metadata',\n schema: {\n allOf: deprecatedProps,\n } as SchemaObject,\n }\n : null,\n },\n ];\n }\n\n // If this operation neither has any parameters or a request body then we should return null\n // because there won't be any JSON Schema.\n if (!operation.hasParameters() && !operation.hasRequestBody()) {\n return null;\n }\n\n // `metadata` is `api` SDK specific, is not a part of the `PARAMETER_ORDERING` extension, and\n // should always be sorted last. We also define `formData` as `form` in the extension because\n // we don't want folks to have to deal with casing issues so we need to rewrite it to `formData`.\n const typeKeys = (getExtension(PARAMETER_ORDERING, api, operation) as string[]).map(k => k.toLowerCase());\n typeKeys[typeKeys.indexOf('form')] = 'formData';\n typeKeys.push('metadata');\n\n const jsonSchema = [transformRequestBody()].concat(...transformParameters()).filter(Boolean);\n\n // We should only include `components`, or even bother transforming components into JSON Schema,\n // if we either have circular refs or if we have discriminator mapping refs somewhere and want to\n // include them.\n const shouldIncludeComponents =\n hasCircularRefs || (hasDiscriminatorMappingRefs && opts.includeDiscriminatorMappingRefs);\n\n const components = shouldIncludeComponents ? transformComponents() : false;\n\n return jsonSchema\n .map(group => {\n /**\n * Since this library assumes that the schema has already been dereferenced, adding every\n * component here that **isn't** circular adds a ton of bloat so it'd be cool if `components`\n * was just the remaining `$ref` pointers that are still being referenced.\n *\n * @todo\n */\n if (components && shouldIncludeComponents) {\n // Fixing typing and confused version mismatches\n (group.schema.components as ComponentsObject) = components;\n }\n\n // Delete deprecatedProps if it's null on the schema.\n if (!group.deprecatedProps) delete group.deprecatedProps;\n\n return group;\n })\n .sort((a, b) => {\n return typeKeys.indexOf(a.type) - typeKeys.indexOf(b.type);\n });\n}\n"],"mappings":"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","names":["types","components","schema"]}
@@ -24,4 +24,4 @@ export {
24
24
  findSchemaDefinition,
25
25
  supportedMethods
26
26
  };
27
- //# sourceMappingURL=chunk-BBB7GA2U.js.map
27
+ //# sourceMappingURL=chunk-W3LSKLU6.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/lib/find-schema-definition.ts","../src/utils.ts"],"sourcesContent":["import jsonpointer from 'jsonpointer';\n\n/**\n * Lookup a reference pointer within an OpenAPI definition and return the schema that it resolves\n * to.\n *\n * @param $ref Reference to look up a schema for.\n * @param definition OpenAPI definition to look for the `$ref` pointer in.\n */\n// biome-ignore lint/style/noDefaultExport: This is safe for now.\nexport default function findSchemaDefinition($ref: string, definition = {}): any {\n let currRef = $ref.trim();\n if (currRef === '') {\n // If this ref is empty, don't bother trying to look for it.\n return false;\n }\n\n if (currRef.startsWith('#')) {\n // Decode URI fragment representation.\n currRef = decodeURIComponent(currRef.substring(1));\n } else {\n throw new Error(`Could not find a definition for ${$ref}.`);\n }\n\n const current = jsonpointer.get(definition, currRef);\n if (current === undefined) {\n throw new Error(`Could not find a definition for ${$ref}.`);\n }\n\n return current;\n}\n","import findSchemaDefinition from './lib/find-schema-definition.js';\nimport matchesMimeType from './lib/matches-mimetype.js';\nimport { types as jsonSchemaTypes } from './operation/lib/get-parameters-as-json-schema.js';\n\nconst supportedMethods = ['get', 'put', 'post', 'delete', 'options', 'head', 'patch', 'trace'] as const;\n\nexport { findSchemaDefinition, jsonSchemaTypes, matchesMimeType, supportedMethods };\n"],"mappings":";AAAA,OAAO,iBAAiB;AAUT,SAAR,qBAAsC,MAAc,aAAa,CAAC,GAAQ;AAC/E,MAAI,UAAU,KAAK,KAAK;AACxB,MAAI,YAAY,IAAI;AAElB,WAAO;AAAA,EACT;AAEA,MAAI,QAAQ,WAAW,GAAG,GAAG;AAE3B,cAAU,mBAAmB,QAAQ,UAAU,CAAC,CAAC;AAAA,EACnD,OAAO;AACL,UAAM,IAAI,MAAM,mCAAmC,IAAI,GAAG;AAAA,EAC5D;AAEA,QAAM,UAAU,YAAY,IAAI,YAAY,OAAO;AACnD,MAAI,YAAY,QAAW;AACzB,UAAM,IAAI,MAAM,mCAAmC,IAAI,GAAG;AAAA,EAC5D;AAEA,SAAO;AACT;;;AC1BA,IAAM,mBAAmB,CAAC,OAAO,OAAO,QAAQ,UAAU,WAAW,QAAQ,SAAS,OAAO;","names":[]}
@@ -551,13 +551,14 @@ declare const METRICS_ENABLED = "metrics-enabled";
551
551
  * Configuration options for OAuth flows in the API Explorer.
552
552
  *
553
553
  * @defaultValue {}
554
- * @see {@link https://docs.readme.com/main/docs/openapi-extensions#oauth-options}
554
+ * @see {@link https://docs.readme.com/main/docs/openapi-extensions#oauth-configuration-options}
555
555
  * @example
556
556
  * {
557
557
  * "x-readme": {
558
558
  * "oauth-options": {
559
559
  * "scopeSeparator": ",",
560
- * "useInsecureClientAuthentication": true
560
+ * "useInsecureClientAuthentication": true,
561
+ * "usePkce": false
561
562
  * }
562
563
  * }
563
564
  * }
@@ -703,6 +704,18 @@ interface Extensions {
703
704
  * @default false
704
705
  */
705
706
  useInsecureClientAuthentication?: boolean;
707
+ /**
708
+ * When enabled, uses PKCE (Proof Key for Code Exchange) for the authorization code flow.
709
+ * The client secret is replaced with an auto-generated code verifier and code challenge.
710
+ * When disabled, uses the standard OAuth 2.0 authorization code flow with client credentials.
711
+ *
712
+ * @see {@link https://datatracker.ietf.org/doc/html/rfc7636#section-4.1}
713
+ * @see {@link https://datatracker.ietf.org/doc/html/rfc7636#section-4.2}
714
+ *
715
+ * @example true
716
+ * @default false
717
+ */
718
+ usePkce?: boolean;
706
719
  };
707
720
  [PARAMETER_ORDERING]: ('body' | 'cookie' | 'form' | 'header' | 'path' | 'query')[];
708
721
  [PROXY_ENABLED]: boolean;
@@ -551,13 +551,14 @@ declare const METRICS_ENABLED = "metrics-enabled";
551
551
  * Configuration options for OAuth flows in the API Explorer.
552
552
  *
553
553
  * @defaultValue {}
554
- * @see {@link https://docs.readme.com/main/docs/openapi-extensions#oauth-options}
554
+ * @see {@link https://docs.readme.com/main/docs/openapi-extensions#oauth-configuration-options}
555
555
  * @example
556
556
  * {
557
557
  * "x-readme": {
558
558
  * "oauth-options": {
559
559
  * "scopeSeparator": ",",
560
- * "useInsecureClientAuthentication": true
560
+ * "useInsecureClientAuthentication": true,
561
+ * "usePkce": false
561
562
  * }
562
563
  * }
563
564
  * }
@@ -703,6 +704,18 @@ interface Extensions {
703
704
  * @default false
704
705
  */
705
706
  useInsecureClientAuthentication?: boolean;
707
+ /**
708
+ * When enabled, uses PKCE (Proof Key for Code Exchange) for the authorization code flow.
709
+ * The client secret is replaced with an auto-generated code verifier and code challenge.
710
+ * When disabled, uses the standard OAuth 2.0 authorization code flow with client credentials.
711
+ *
712
+ * @see {@link https://datatracker.ietf.org/doc/html/rfc7636#section-4.1}
713
+ * @see {@link https://datatracker.ietf.org/doc/html/rfc7636#section-4.2}
714
+ *
715
+ * @example true
716
+ * @default false
717
+ */
718
+ usePkce?: boolean;
706
719
  };
707
720
  [PARAMETER_ORDERING]: ('body' | 'cookie' | 'form' | 'header' | 'path' | 'query')[];
708
721
  [PROXY_ENABLED]: boolean;