@kubb/plugin-faker 4.21.1 → 4.22.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 (37) hide show
  1. package/dist/{components-CDKWc3Yj.js → components-CiUIlcV3.js} +4 -3
  2. package/dist/components-CiUIlcV3.js.map +1 -0
  3. package/dist/{components-CQqf9rBj.cjs → components-D44-YPpj.cjs} +4 -3
  4. package/dist/components-D44-YPpj.cjs.map +1 -0
  5. package/dist/components.cjs +1 -1
  6. package/dist/components.d.cts +2 -1
  7. package/dist/components.d.ts +2 -1
  8. package/dist/components.js +1 -1
  9. package/dist/{fakerGenerator-VqIrrE7d.js → fakerGenerator-BWH5M054.js} +4 -4
  10. package/dist/fakerGenerator-BWH5M054.js.map +1 -0
  11. package/dist/{fakerGenerator-BC_ilj8m.cjs → fakerGenerator-DipEvGPU.cjs} +4 -4
  12. package/dist/fakerGenerator-DipEvGPU.cjs.map +1 -0
  13. package/dist/generators.cjs +1 -1
  14. package/dist/generators.d.cts +457 -1
  15. package/dist/generators.d.ts +457 -1
  16. package/dist/generators.js +1 -1
  17. package/dist/index.cjs +2 -2
  18. package/dist/index.d.cts +1 -1
  19. package/dist/index.d.ts +1 -1
  20. package/dist/index.js +1 -1
  21. package/dist/types-DPGJaaLM.d.cts +124 -0
  22. package/dist/types-wnjXCmBP.d.ts +123 -0
  23. package/package.json +5 -5
  24. package/src/generators/__snapshots__/createPet.ts +2 -2
  25. package/src/generators/__snapshots__/createPetSeed.ts +2 -2
  26. package/src/generators/__snapshots__/createPetUnknownTypeAny.ts +2 -2
  27. package/src/generators/__snapshots__/getPets.ts +2 -2
  28. package/src/generators/__snapshots__/showPetById.ts +4 -4
  29. package/src/generators/__snapshots__/updatePet.ts +34 -0
  30. package/src/generators/fakerGenerator.tsx +3 -1
  31. package/src/parser.ts +6 -2
  32. package/dist/components-CDKWc3Yj.js.map +0 -1
  33. package/dist/components-CQqf9rBj.cjs.map +0 -1
  34. package/dist/fakerGenerator-BC_ilj8m.cjs.map +0 -1
  35. package/dist/fakerGenerator-VqIrrE7d.js.map +0 -1
  36. package/dist/types-CB26F0zP.d.cts +0 -664
  37. package/dist/types-D8QPkAha.d.ts +0 -663
@@ -1,6 +1,462 @@
1
1
  import { t as __name } from "./chunk-eQyhnF5A.js";
2
- import { n as PluginFaker, r as ReactGenerator } from "./types-D8QPkAha.js";
2
+ import { n as PluginFaker } from "./types-wnjXCmBP.js";
3
+ import { BaseGenerator, Config, FileMetaBase, Group, KubbEvents, Output, Plugin, PluginFactoryOptions, PluginManager, ResolveNameParams } from "@kubb/core";
4
+ import { Fabric } from "@kubb/react-fabric";
5
+ import { FabricReactNode } from "@kubb/react-fabric/types";
6
+ import { HttpMethod, Oas, Operation, SchemaObject, contentType } from "@kubb/oas";
7
+ import { AsyncEventEmitter } from "@kubb/core/utils";
8
+ import { KubbFile } from "@kubb/fabric-core/types";
3
9
 
10
+ //#region ../plugin-oas/src/types.d.ts
11
+ type GetOasOptions = {
12
+ validate?: boolean;
13
+ };
14
+ type Context$2 = {
15
+ getOas(options?: GetOasOptions): Promise<Oas>;
16
+ getBaseURL(): Promise<string | undefined>;
17
+ };
18
+ declare global {
19
+ namespace Kubb {
20
+ interface PluginContext extends Context$2 {}
21
+ }
22
+ }
23
+ /**
24
+ * `propertyName` is the ref name + resolved with the nameResolver
25
+ * @example import { Pet } from './Pet'
26
+ *
27
+ * `originalName` is the original name used(in PascalCase), only used to remove duplicates
28
+ *
29
+ * `pluginKey` can be used to override the current plugin being used, handy when you want to import a type/schema out of another plugin
30
+ * @example import a type(plugin-ts) for a mock file(swagger-faker)
31
+ */
32
+ type Ref = {
33
+ propertyName: string;
34
+ originalName: string;
35
+ path: KubbFile.Path;
36
+ pluginKey?: Plugin['key'];
37
+ };
38
+ type Refs = Record<string, Ref>;
39
+ type OperationSchema = {
40
+ /**
41
+ * Converted name, contains already `PathParams`, `QueryParams`, ...
42
+ */
43
+ name: string;
44
+ schema: SchemaObject;
45
+ operation?: Operation;
46
+ /**
47
+ * OperationName in PascalCase, only being used in OperationGenerator
48
+ */
49
+ operationName: string;
50
+ description?: string;
51
+ statusCode?: number;
52
+ keys?: string[];
53
+ keysToOmit?: string[];
54
+ withData?: boolean;
55
+ };
56
+ type OperationSchemas = {
57
+ pathParams?: OperationSchema & {
58
+ keysToOmit?: never;
59
+ };
60
+ queryParams?: OperationSchema & {
61
+ keysToOmit?: never;
62
+ };
63
+ headerParams?: OperationSchema & {
64
+ keysToOmit?: never;
65
+ };
66
+ request?: OperationSchema;
67
+ response: OperationSchema;
68
+ responses: Array<OperationSchema>;
69
+ statusCodes?: Array<OperationSchema>;
70
+ errors?: Array<OperationSchema>;
71
+ };
72
+ type ByTag = {
73
+ type: 'tag';
74
+ pattern: string | RegExp;
75
+ };
76
+ type ByOperationId = {
77
+ type: 'operationId';
78
+ pattern: string | RegExp;
79
+ };
80
+ type ByPath = {
81
+ type: 'path';
82
+ pattern: string | RegExp;
83
+ };
84
+ type ByMethod = {
85
+ type: 'method';
86
+ pattern: HttpMethod | RegExp;
87
+ };
88
+ type BySchemaName = {
89
+ type: 'schemaName';
90
+ pattern: string | RegExp;
91
+ };
92
+ type ByContentType = {
93
+ type: 'contentType';
94
+ pattern: string | RegExp;
95
+ };
96
+ type Exclude = ByTag | ByOperationId | ByPath | ByMethod | ByContentType;
97
+ type Include = ByTag | ByOperationId | ByPath | ByMethod | ByContentType;
98
+ type Override<TOptions> = (ByTag | ByOperationId | ByPath | ByMethod | BySchemaName | ByContentType) & {
99
+ options: Partial<TOptions>;
100
+ };
101
+ //#endregion
102
+ //#region ../plugin-oas/src/OperationGenerator.d.ts
103
+ type Context$1<TOptions, TPluginOptions extends PluginFactoryOptions> = {
104
+ fabric: Fabric;
105
+ oas: Oas;
106
+ exclude: Array<Exclude> | undefined;
107
+ include: Array<Include> | undefined;
108
+ override: Array<Override<TOptions>> | undefined;
109
+ contentType: contentType | undefined;
110
+ pluginManager: PluginManager;
111
+ events?: AsyncEventEmitter<KubbEvents>;
112
+ /**
113
+ * Current plugin
114
+ */
115
+ plugin: Plugin<TPluginOptions>;
116
+ mode: KubbFile.Mode;
117
+ UNSTABLE_NAMING?: true;
118
+ };
119
+ declare class OperationGenerator<TPluginOptions extends PluginFactoryOptions = PluginFactoryOptions, TFileMeta extends FileMetaBase = FileMetaBase> extends BaseGenerator<TPluginOptions['resolvedOptions'], Context$1<TPluginOptions['resolvedOptions'], TPluginOptions>> {
120
+ #private;
121
+ getOptions(operation: Operation, method: HttpMethod): Partial<TPluginOptions['resolvedOptions']>;
122
+ getSchemas(operation: Operation, {
123
+ resolveName
124
+ }?: {
125
+ resolveName?: (name: string) => string;
126
+ }): OperationSchemas;
127
+ getOperations(): Promise<Array<{
128
+ path: string;
129
+ method: HttpMethod;
130
+ operation: Operation;
131
+ }>>;
132
+ build(...generators: Array<Generator<TPluginOptions>>): Promise<Array<KubbFile.File<TFileMeta>>>;
133
+ }
134
+ //#endregion
135
+ //#region ../plugin-oas/src/SchemaMapper.d.ts
136
+ type SchemaKeywordMapper = {
137
+ object: {
138
+ keyword: 'object';
139
+ args: {
140
+ properties: {
141
+ [x: string]: Schema[];
142
+ };
143
+ additionalProperties: Schema[];
144
+ patternProperties?: Record<string, Schema[]>;
145
+ strict?: boolean;
146
+ };
147
+ };
148
+ url: {
149
+ keyword: 'url';
150
+ };
151
+ readOnly: {
152
+ keyword: 'readOnly';
153
+ };
154
+ writeOnly: {
155
+ keyword: 'writeOnly';
156
+ };
157
+ uuid: {
158
+ keyword: 'uuid';
159
+ };
160
+ email: {
161
+ keyword: 'email';
162
+ };
163
+ firstName: {
164
+ keyword: 'firstName';
165
+ };
166
+ lastName: {
167
+ keyword: 'lastName';
168
+ };
169
+ phone: {
170
+ keyword: 'phone';
171
+ };
172
+ password: {
173
+ keyword: 'password';
174
+ };
175
+ date: {
176
+ keyword: 'date';
177
+ args: {
178
+ type?: 'date' | 'string';
179
+ };
180
+ };
181
+ time: {
182
+ keyword: 'time';
183
+ args: {
184
+ type?: 'date' | 'string';
185
+ };
186
+ };
187
+ datetime: {
188
+ keyword: 'datetime';
189
+ args: {
190
+ offset?: boolean;
191
+ local?: boolean;
192
+ };
193
+ };
194
+ tuple: {
195
+ keyword: 'tuple';
196
+ args: {
197
+ items: Schema[];
198
+ min?: number;
199
+ max?: number;
200
+ rest?: Schema;
201
+ };
202
+ };
203
+ array: {
204
+ keyword: 'array';
205
+ args: {
206
+ items: Schema[];
207
+ min?: number;
208
+ max?: number;
209
+ unique?: boolean;
210
+ };
211
+ };
212
+ enum: {
213
+ keyword: 'enum';
214
+ args: {
215
+ name: string;
216
+ typeName: string;
217
+ asConst: boolean;
218
+ items: Array<{
219
+ name: string | number;
220
+ format: 'string' | 'number' | 'boolean';
221
+ value?: string | number | boolean;
222
+ }>;
223
+ };
224
+ };
225
+ and: {
226
+ keyword: 'and';
227
+ args: Schema[];
228
+ };
229
+ const: {
230
+ keyword: 'const';
231
+ args: {
232
+ name: string | number;
233
+ format: 'string' | 'number' | 'boolean';
234
+ value?: string | number | boolean;
235
+ };
236
+ };
237
+ union: {
238
+ keyword: 'union';
239
+ args: Schema[];
240
+ };
241
+ ref: {
242
+ keyword: 'ref';
243
+ args: {
244
+ name: string;
245
+ $ref: string;
246
+ /**
247
+ * Full qualified path.
248
+ */
249
+ path: KubbFile.Path;
250
+ /**
251
+ * When true `File.Import` is used.
252
+ * When false a reference is used inside the current file.
253
+ */
254
+ isImportable: boolean;
255
+ };
256
+ };
257
+ matches: {
258
+ keyword: 'matches';
259
+ args?: string;
260
+ };
261
+ boolean: {
262
+ keyword: 'boolean';
263
+ };
264
+ default: {
265
+ keyword: 'default';
266
+ args: string | number | boolean;
267
+ };
268
+ string: {
269
+ keyword: 'string';
270
+ };
271
+ integer: {
272
+ keyword: 'integer';
273
+ };
274
+ number: {
275
+ keyword: 'number';
276
+ };
277
+ max: {
278
+ keyword: 'max';
279
+ args: number;
280
+ };
281
+ min: {
282
+ keyword: 'min';
283
+ args: number;
284
+ };
285
+ exclusiveMaximum: {
286
+ keyword: 'exclusiveMaximum';
287
+ args: number;
288
+ };
289
+ exclusiveMinimum: {
290
+ keyword: 'exclusiveMinimum';
291
+ args: number;
292
+ };
293
+ describe: {
294
+ keyword: 'describe';
295
+ args: string;
296
+ };
297
+ example: {
298
+ keyword: 'example';
299
+ args: string;
300
+ };
301
+ deprecated: {
302
+ keyword: 'deprecated';
303
+ };
304
+ optional: {
305
+ keyword: 'optional';
306
+ };
307
+ undefined: {
308
+ keyword: 'undefined';
309
+ };
310
+ nullish: {
311
+ keyword: 'nullish';
312
+ };
313
+ nullable: {
314
+ keyword: 'nullable';
315
+ };
316
+ null: {
317
+ keyword: 'null';
318
+ };
319
+ any: {
320
+ keyword: 'any';
321
+ };
322
+ unknown: {
323
+ keyword: 'unknown';
324
+ };
325
+ void: {
326
+ keyword: 'void';
327
+ };
328
+ blob: {
329
+ keyword: 'blob';
330
+ };
331
+ schema: {
332
+ keyword: 'schema';
333
+ args: {
334
+ type: 'string' | 'number' | 'integer' | 'boolean' | 'array' | 'object';
335
+ format?: string;
336
+ };
337
+ };
338
+ name: {
339
+ keyword: 'name';
340
+ args: string;
341
+ };
342
+ catchall: {
343
+ keyword: 'catchall';
344
+ };
345
+ interface: {
346
+ keyword: 'interface';
347
+ };
348
+ };
349
+ type Schema = {
350
+ keyword: string;
351
+ } | SchemaKeywordMapper[keyof SchemaKeywordMapper];
352
+ //#endregion
353
+ //#region ../plugin-oas/src/SchemaGenerator.d.ts
354
+ type Context<TOptions, TPluginOptions extends PluginFactoryOptions> = {
355
+ fabric: Fabric;
356
+ oas: Oas;
357
+ pluginManager: PluginManager;
358
+ events?: AsyncEventEmitter<KubbEvents>;
359
+ /**
360
+ * Current plugin
361
+ */
362
+ plugin: Plugin<TPluginOptions>;
363
+ mode: KubbFile.Mode;
364
+ include?: Array<'schemas' | 'responses' | 'requestBodies'>;
365
+ override: Array<Override<TOptions>> | undefined;
366
+ contentType?: contentType;
367
+ output?: string;
368
+ };
369
+ type SchemaGeneratorOptions = {
370
+ dateType: false | 'string' | 'stringOffset' | 'stringLocal' | 'date';
371
+ unknownType: 'any' | 'unknown' | 'void';
372
+ emptySchemaType: 'any' | 'unknown' | 'void';
373
+ enumType?: 'enum' | 'asConst' | 'asPascalConst' | 'constEnum' | 'literal' | 'inlineLiteral';
374
+ enumSuffix?: string;
375
+ /**
376
+ * @deprecated Will be removed in v5. Use `collisionDetection: true` instead to prevent enum name collisions.
377
+ * When `collisionDetection` is enabled, the rootName-based approach eliminates the need for numeric suffixes.
378
+ * @internal
379
+ */
380
+ usedEnumNames?: Record<string, number>;
381
+ mapper?: Record<string, string>;
382
+ typed?: boolean;
383
+ transformers: {
384
+ /**
385
+ * Customize the names based on the type that is provided by the plugin.
386
+ */
387
+ name?: (name: ResolveNameParams['name'], type?: ResolveNameParams['type']) => string;
388
+ /**
389
+ * Receive schema and name(propertyName) and return FakerMeta array
390
+ * TODO TODO add docs
391
+ * @beta
392
+ */
393
+ schema?: (schemaProps: SchemaProps$1, defaultSchemas: Schema[]) => Array<Schema> | undefined;
394
+ };
395
+ };
396
+ type SchemaProps$1 = {
397
+ schema: SchemaObject | null;
398
+ name: string | null;
399
+ parentName: string | null;
400
+ rootName?: string | null;
401
+ };
402
+ declare class SchemaGenerator<TOptions extends SchemaGeneratorOptions = SchemaGeneratorOptions, TPluginOptions extends PluginFactoryOptions = PluginFactoryOptions, TFileMeta extends FileMetaBase = FileMetaBase> extends BaseGenerator<TOptions, Context<TOptions, TPluginOptions>> {
403
+ #private;
404
+ refs: Refs;
405
+ /**
406
+ * Creates a type node from a given schema.
407
+ * Delegates to getBaseTypeFromSchema internally and
408
+ * optionally adds a union with null.
409
+ */
410
+ parse(props: SchemaProps$1): Schema[];
411
+ static deepSearch<T extends keyof SchemaKeywordMapper>(tree: Schema[] | undefined, keyword: T): Array<SchemaKeywordMapper[T]>;
412
+ static find<T extends keyof SchemaKeywordMapper>(tree: Schema[] | undefined, keyword: T): SchemaKeywordMapper[T] | undefined;
413
+ static combineObjects(tree: Schema[] | undefined): Schema[];
414
+ build(...generators: Array<Generator<TPluginOptions>>): Promise<Array<KubbFile.File<TFileMeta>>>;
415
+ }
416
+ //#endregion
417
+ //#region ../plugin-oas/src/generators/createGenerator.d.ts
418
+ type CoreGenerator<TOptions extends PluginFactoryOptions> = {
419
+ name: string;
420
+ type: 'core';
421
+ operations: (props: OperationsProps<TOptions>) => Promise<KubbFile.File[]>;
422
+ operation: (props: OperationProps<TOptions>) => Promise<KubbFile.File[]>;
423
+ schema: (props: SchemaProps<TOptions>) => Promise<KubbFile.File[]>;
424
+ };
425
+ //#endregion
426
+ //#region ../plugin-oas/src/generators/types.d.ts
427
+ type OperationsProps<TOptions extends PluginFactoryOptions> = {
428
+ config: Config;
429
+ generator: Omit<OperationGenerator<TOptions>, 'build'>;
430
+ plugin: Plugin<TOptions>;
431
+ operations: Array<Operation>;
432
+ };
433
+ type OperationProps<TOptions extends PluginFactoryOptions> = {
434
+ config: Config;
435
+ generator: Omit<OperationGenerator<TOptions>, 'build'>;
436
+ plugin: Plugin<TOptions>;
437
+ operation: Operation;
438
+ };
439
+ type SchemaProps<TOptions extends PluginFactoryOptions> = {
440
+ config: Config;
441
+ generator: Omit<SchemaGenerator<SchemaGeneratorOptions, TOptions>, 'build'>;
442
+ plugin: Plugin<TOptions>;
443
+ schema: {
444
+ name: string;
445
+ tree: Array<Schema>;
446
+ value: SchemaObject;
447
+ };
448
+ };
449
+ type Generator<TOptions extends PluginFactoryOptions> = CoreGenerator<TOptions> | ReactGenerator<TOptions>;
450
+ //#endregion
451
+ //#region ../plugin-oas/src/generators/createReactGenerator.d.ts
452
+ type ReactGenerator<TOptions extends PluginFactoryOptions> = {
453
+ name: string;
454
+ type: 'react';
455
+ Operations: (props: OperationsProps<TOptions>) => FabricReactNode;
456
+ Operation: (props: OperationProps<TOptions>) => FabricReactNode;
457
+ Schema: (props: SchemaProps<TOptions>) => FabricReactNode;
458
+ };
459
+ //#endregion
4
460
  //#region src/generators/fakerGenerator.d.ts
5
461
  declare const fakerGenerator: ReactGenerator<PluginFaker>;
6
462
  //#endregion
@@ -1,3 +1,3 @@
1
- import { t as fakerGenerator } from "./fakerGenerator-VqIrrE7d.js";
1
+ import { t as fakerGenerator } from "./fakerGenerator-BWH5M054.js";
2
2
 
3
3
  export { fakerGenerator };
package/dist/index.cjs CHANGED
@@ -1,5 +1,5 @@
1
- const require_components = require('./components-CQqf9rBj.cjs');
2
- const require_fakerGenerator = require('./fakerGenerator-BC_ilj8m.cjs');
1
+ const require_components = require('./components-D44-YPpj.cjs');
2
+ const require_fakerGenerator = require('./fakerGenerator-DipEvGPU.cjs');
3
3
  let node_path = require("node:path");
4
4
  node_path = require_components.__toESM(node_path);
5
5
  let _kubb_core = require("@kubb/core");
package/dist/index.d.cts CHANGED
@@ -1,4 +1,4 @@
1
- import { a as __name, n as PluginFaker, t as Options } from "./types-CB26F0zP.cjs";
1
+ import { n as PluginFaker, r as __name, t as Options } from "./types-DPGJaaLM.cjs";
2
2
  import * as _kubb_core0 from "@kubb/core";
3
3
 
4
4
  //#region src/plugin.d.ts
package/dist/index.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  import { t as __name } from "./chunk-eQyhnF5A.js";
2
- import { n as PluginFaker, t as Options } from "./types-D8QPkAha.js";
2
+ import { n as PluginFaker, t as Options } from "./types-wnjXCmBP.js";
3
3
  import * as _kubb_core0 from "@kubb/core";
4
4
 
5
5
  //#region src/plugin.d.ts
package/dist/index.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import { t as __name } from "./chunk-eQyhnF5A.js";
2
- import { t as fakerGenerator } from "./fakerGenerator-VqIrrE7d.js";
2
+ import { t as fakerGenerator } from "./fakerGenerator-BWH5M054.js";
3
3
  import path from "node:path";
4
4
  import { definePlugin, getBarrelFiles, getMode } from "@kubb/core";
5
5
  import { camelCase } from "@kubb/core/transformers";
@@ -0,0 +1,124 @@
1
+ import { Exclude, Include, Override, ResolvePathOptions, Schema } from "@kubb/plugin-oas";
2
+ import { Group, Output, PluginFactoryOptions, ResolveNameParams } from "@kubb/core";
3
+ import { Oas, SchemaObject, contentType } from "@kubb/oas";
4
+ import { Generator } from "@kubb/plugin-oas/generators";
5
+
6
+ //#region rolldown:runtime
7
+ //#endregion
8
+ //#region src/types.d.ts
9
+ type Options = {
10
+ /**
11
+ * Specify the export location for the files and define the behavior of the output
12
+ * @default { path: 'handlers', barrelType: 'named' }
13
+ */
14
+ output?: Output<Oas>;
15
+ /**
16
+ * Define which contentType should be used.
17
+ * By default, the first JSON valid mediaType is used
18
+ */
19
+ contentType?: contentType;
20
+ /**
21
+ * Group the Faker mocks based on the provided name.
22
+ */
23
+ group?: Group;
24
+ /**
25
+ * Array containing exclude parameters to exclude/skip tags/operations/methods/paths.
26
+ */
27
+ exclude?: Array<Exclude>;
28
+ /**
29
+ * Array containing include parameters to include tags/operations/methods/paths.
30
+ */
31
+ include?: Array<Include>;
32
+ /**
33
+ * Array containing override parameters to override `options` based on tags/operations/methods/paths.
34
+ */
35
+ override?: Array<Override<ResolvedOptions>>;
36
+ /**
37
+ * Choose to use date or datetime as JavaScript Date instead of string.
38
+ * - 'string' represents dates as string values.
39
+ * - 'date' represents dates as JavaScript Date objects.
40
+ * @default 'string'
41
+ */
42
+ dateType?: 'string' | 'date';
43
+ /**
44
+ * Which parser should be used when dateType is set to string.
45
+ * - 'faker' uses faker's built-in date formatting methods.
46
+ * - 'dayjs' uses dayjs for date formatting with custom patterns.
47
+ * - 'moment' uses moment for date formatting with custom patterns.
48
+ * @default 'faker'
49
+ */
50
+ dateParser?: 'faker' | 'dayjs' | 'moment' | (string & {});
51
+ /**
52
+ * Which type to use when the Swagger/OpenAPI file is not providing more information.
53
+ * - 'any' allows any value.
54
+ * - 'unknown' requires type narrowing before use.
55
+ * - 'void' represents no value.
56
+ * @default 'any'
57
+ */
58
+ unknownType?: 'any' | 'unknown' | 'void';
59
+ /**
60
+ * Which type to use for empty schema values.
61
+ * - 'any' allows any value.
62
+ * - 'unknown' requires type narrowing before use.
63
+ * - 'void' represents no value.
64
+ * @default `unknownType`
65
+ */
66
+ emptySchemaType?: 'any' | 'unknown' | 'void';
67
+ /**
68
+ * Choose which generator to use when using Regexp.
69
+ * - 'faker' uses faker.helpers.fromRegExp for generating values from regex patterns.
70
+ * - 'randexp' uses RandExp library for generating values from regex patterns.
71
+ * @default 'faker'
72
+ */
73
+ regexGenerator?: 'faker' | 'randexp';
74
+ mapper?: Record<string, string>;
75
+ /**
76
+ * The use of Seed is intended to allow for consistent values in a test.
77
+ */
78
+ seed?: number | number[];
79
+ /**
80
+ * Transform parameter names to a specific casing format.
81
+ * When set to 'camelcase', parameter names in path, query, and header params will be transformed to camelCase.
82
+ * This should match the paramsCasing setting used in @kubb/plugin-ts.
83
+ * @default undefined
84
+ */
85
+ paramsCasing?: 'camelcase';
86
+ transformers?: {
87
+ /**
88
+ * Customize the names based on the type that is provided by the plugin.
89
+ */
90
+ name?: (name: ResolveNameParams['name'], type?: ResolveNameParams['type']) => string;
91
+ /**
92
+ * Receive schema and baseName(propertyName) and return FakerMeta array
93
+ * TODO TODO add docs
94
+ * @beta
95
+ */
96
+ schema?: (props: {
97
+ schema: SchemaObject | null;
98
+ name: string | null;
99
+ parentName: string | null;
100
+ }, defaultSchemas: Schema[]) => Schema[] | undefined;
101
+ };
102
+ /**
103
+ * Define some generators next to the faker generators
104
+ */
105
+ generators?: Array<Generator<PluginFaker>>;
106
+ };
107
+ type ResolvedOptions = {
108
+ output: Output<Oas>;
109
+ group: Options['group'];
110
+ override: NonNullable<Options['override']>;
111
+ dateType: NonNullable<Options['dateType']>;
112
+ dateParser: NonNullable<Options['dateParser']>;
113
+ unknownType: NonNullable<Options['unknownType']>;
114
+ emptySchemaType: NonNullable<Options['emptySchemaType']>;
115
+ transformers: NonNullable<Options['transformers']>;
116
+ seed: NonNullable<Options['seed']> | undefined;
117
+ mapper: NonNullable<Options['mapper']>;
118
+ regexGenerator: NonNullable<Options['regexGenerator']>;
119
+ paramsCasing: Options['paramsCasing'];
120
+ };
121
+ type PluginFaker = PluginFactoryOptions<'plugin-faker', Options, ResolvedOptions, never, ResolvePathOptions>;
122
+ //#endregion
123
+ export { PluginFaker as n, __name as r, Options as t };
124
+ //# sourceMappingURL=types-DPGJaaLM.d.cts.map