@kubb/plugin-msw 5.0.0-alpha.9 → 5.0.0-beta.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +17 -10
- package/README.md +1 -3
- package/dist/components-CLQ77DVn.cjs +584 -0
- package/dist/components-CLQ77DVn.cjs.map +1 -0
- package/dist/components-vO0FIb2i.js +519 -0
- package/dist/components-vO0FIb2i.js.map +1 -0
- package/dist/components.cjs +1 -1
- package/dist/components.d.ts +17 -21
- package/dist/components.js +1 -1
- package/dist/generators-BPJCs1x1.js +176 -0
- package/dist/generators-BPJCs1x1.js.map +1 -0
- package/dist/generators-CrmMwWE4.cjs +186 -0
- package/dist/generators-CrmMwWE4.cjs.map +1 -0
- package/dist/generators.cjs +1 -1
- package/dist/generators.d.ts +4 -500
- package/dist/generators.js +1 -1
- package/dist/index.cjs +54 -65
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +4 -4
- package/dist/index.js +51 -65
- package/dist/index.js.map +1 -1
- package/dist/types-Dxu0KMQ4.d.ts +89 -0
- package/package.json +59 -57
- package/src/components/Handlers.tsx +3 -3
- package/src/components/Mock.tsx +36 -28
- package/src/components/MockWithFaker.tsx +36 -24
- package/src/components/Response.tsx +23 -17
- package/src/generators/handlersGenerator.tsx +18 -18
- package/src/generators/mswGenerator.tsx +49 -60
- package/src/index.ts +1 -1
- package/src/plugin.ts +48 -85
- package/src/resolvers/resolverMsw.ts +19 -0
- package/src/types.ts +45 -22
- package/src/utils.ts +109 -0
- package/dist/components-8XBwMbFa.cjs +0 -343
- package/dist/components-8XBwMbFa.cjs.map +0 -1
- package/dist/components-DgtTZkWX.js +0 -277
- package/dist/components-DgtTZkWX.js.map +0 -1
- package/dist/generators-CY1SNd5X.cjs +0 -171
- package/dist/generators-CY1SNd5X.cjs.map +0 -1
- package/dist/generators-CvyZTxOm.js +0 -161
- package/dist/generators-CvyZTxOm.js.map +0 -1
- package/dist/types-MdHRNpgi.d.ts +0 -68
|
@@ -1,34 +1,40 @@
|
|
|
1
|
-
import
|
|
2
|
-
import {
|
|
3
|
-
import
|
|
1
|
+
import { ast } from '@kubb/core'
|
|
2
|
+
import { functionPrinter } from '@kubb/plugin-ts'
|
|
3
|
+
import { File, Function } from '@kubb/renderer-jsx'
|
|
4
|
+
import type { KubbReactNode } from '@kubb/renderer-jsx/types'
|
|
5
|
+
import { getContentType, hasResponseSchema } from '../utils.ts'
|
|
4
6
|
|
|
5
7
|
type Props = {
|
|
6
8
|
typeName: string
|
|
7
|
-
operation: Operation
|
|
8
9
|
name: string
|
|
9
|
-
|
|
10
|
+
response: ast.ResponseNode
|
|
11
|
+
key?: string | number | null
|
|
10
12
|
}
|
|
11
13
|
|
|
12
|
-
|
|
13
|
-
const responseObject = operation.getResponseByStatusCode(statusCode) as OasTypes.ResponseObject
|
|
14
|
-
const contentType = Object.keys(responseObject.content || {})?.[0]
|
|
14
|
+
const declarationPrinter = functionPrinter({ mode: 'declaration' })
|
|
15
15
|
|
|
16
|
+
export function Response({ name, typeName, response }: Props): KubbReactNode {
|
|
17
|
+
const statusCode = Number(response.statusCode)
|
|
18
|
+
const contentType = getContentType(response)
|
|
16
19
|
const headers = [contentType ? `'Content-Type': '${contentType}'` : undefined].filter(Boolean)
|
|
17
20
|
|
|
18
|
-
const
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
21
|
+
const params = declarationPrinter.print(
|
|
22
|
+
ast.createFunctionParameters({
|
|
23
|
+
params: [
|
|
24
|
+
ast.createFunctionParameter({
|
|
25
|
+
name: 'data',
|
|
26
|
+
type: ast.createParamsType({ variant: 'reference', name: typeName }),
|
|
27
|
+
optional: !hasResponseSchema(response),
|
|
28
|
+
}),
|
|
29
|
+
],
|
|
30
|
+
}),
|
|
31
|
+
)
|
|
26
32
|
|
|
27
33
|
const responseName = `${name}Response${statusCode}`
|
|
28
34
|
|
|
29
35
|
return (
|
|
30
36
|
<File.Source name={responseName} isIndexable isExportable>
|
|
31
|
-
<Function name={responseName} export params={params
|
|
37
|
+
<Function name={responseName} export params={params ?? ''}>
|
|
32
38
|
{`
|
|
33
39
|
return new Response(JSON.stringify(data), {
|
|
34
40
|
status: ${statusCode},
|
|
@@ -1,37 +1,37 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import { useOas, useOperationManager } from '@kubb/plugin-oas/hooks'
|
|
4
|
-
import { getBanner, getFooter } from '@kubb/plugin-oas/utils'
|
|
5
|
-
import { File } from '@kubb/react-fabric'
|
|
1
|
+
import { defineGenerator } from '@kubb/core'
|
|
2
|
+
import { File, jsxRenderer } from '@kubb/renderer-jsx'
|
|
6
3
|
import { Handlers } from '../components/Handlers.tsx'
|
|
7
4
|
import type { PluginMsw } from '../types'
|
|
5
|
+
import { transformName } from '../utils.ts'
|
|
8
6
|
|
|
9
|
-
export const handlersGenerator =
|
|
7
|
+
export const handlersGenerator = defineGenerator<PluginMsw>({
|
|
10
8
|
name: 'plugin-msw',
|
|
11
|
-
|
|
12
|
-
|
|
9
|
+
renderer: jsxRenderer,
|
|
10
|
+
operations(nodes, ctx) {
|
|
11
|
+
const { resolver, config, root, adapter } = ctx
|
|
12
|
+
const { output, group, transformers } = ctx.options
|
|
13
13
|
|
|
14
|
-
const
|
|
15
|
-
const { getName, getFile } = useOperationManager(generator)
|
|
14
|
+
const file = resolver.resolveFile({ name: 'handlers', extname: '.ts' }, { root, output, group })
|
|
16
15
|
|
|
17
|
-
const
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
16
|
+
const imports = nodes.map((node) => {
|
|
17
|
+
const operationName = transformName(resolver.resolveName(node.operationId), 'function', transformers)
|
|
18
|
+
const operationFile = resolver.resolveFile(
|
|
19
|
+
{ name: resolver.resolveName(node.operationId), extname: '.ts', tag: node.tags[0] ?? 'default', path: node.path },
|
|
20
|
+
{ root, output, group },
|
|
21
|
+
)
|
|
22
22
|
|
|
23
23
|
return <File.Import key={operationFile.path} name={[operationName]} root={file.path} path={operationFile.path} />
|
|
24
24
|
})
|
|
25
25
|
|
|
26
|
-
const handlers =
|
|
26
|
+
const handlers = nodes.map((node) => `${transformName(resolver.resolveName(node.operationId), 'function', transformers)}()`)
|
|
27
27
|
|
|
28
28
|
return (
|
|
29
29
|
<File
|
|
30
30
|
baseName={file.baseName}
|
|
31
31
|
path={file.path}
|
|
32
32
|
meta={file.meta}
|
|
33
|
-
banner={
|
|
34
|
-
footer={
|
|
33
|
+
banner={resolver.resolveBanner(adapter.inputNode, { output, config })}
|
|
34
|
+
footer={resolver.resolveFooter(adapter.inputNode, { output, config })}
|
|
35
35
|
>
|
|
36
36
|
{imports}
|
|
37
37
|
<Handlers name={'handlers'} handlers={handlers} />
|
|
@@ -1,94 +1,83 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { defineGenerator } from '@kubb/core'
|
|
2
2
|
import { pluginFakerName } from '@kubb/plugin-faker'
|
|
3
|
-
import { createReactGenerator } from '@kubb/plugin-oas/generators'
|
|
4
|
-
import { useOas, useOperationManager } from '@kubb/plugin-oas/hooks'
|
|
5
|
-
import { getBanner, getFooter } from '@kubb/plugin-oas/utils'
|
|
6
3
|
import { pluginTsName } from '@kubb/plugin-ts'
|
|
7
|
-
import { File } from '@kubb/
|
|
4
|
+
import { File, jsxRenderer } from '@kubb/renderer-jsx'
|
|
8
5
|
import { Mock, MockWithFaker, Response } from '../components'
|
|
9
6
|
import type { PluginMsw } from '../types'
|
|
7
|
+
import { getResponseTypes, getSuccessResponses, resolveFakerMeta, transformName } from '../utils.ts'
|
|
10
8
|
|
|
11
|
-
export const mswGenerator =
|
|
9
|
+
export const mswGenerator = defineGenerator<PluginMsw>({
|
|
12
10
|
name: 'msw',
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
} =
|
|
17
|
-
const driver = usePluginDriver()
|
|
18
|
-
|
|
19
|
-
const oas = useOas()
|
|
20
|
-
const { getSchemas, getName, getFile } = useOperationManager(generator)
|
|
11
|
+
renderer: jsxRenderer,
|
|
12
|
+
operation(node, ctx) {
|
|
13
|
+
const { driver, resolver, config, root, adapter } = ctx
|
|
14
|
+
const { output, parser, baseURL, group, transformers } = ctx.options
|
|
21
15
|
|
|
16
|
+
const fileName = resolver.resolveName(node.operationId)
|
|
22
17
|
const mock = {
|
|
23
|
-
name:
|
|
24
|
-
file:
|
|
18
|
+
name: transformName(fileName, 'function', transformers),
|
|
19
|
+
file: resolver.resolveFile({ name: fileName, extname: '.ts', tag: node.tags[0] ?? 'default', path: node.path }, { root, output, group }),
|
|
25
20
|
}
|
|
26
21
|
|
|
27
|
-
const
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
22
|
+
const fakerPlugin = parser === 'faker' ? driver.getPlugin(pluginFakerName) : undefined
|
|
23
|
+
const faker =
|
|
24
|
+
parser === 'faker' && fakerPlugin
|
|
25
|
+
? resolveFakerMeta(node, {
|
|
26
|
+
root,
|
|
27
|
+
fakerResolver: driver.getResolver(pluginFakerName),
|
|
28
|
+
fakerOutput: fakerPlugin.options?.output ?? output,
|
|
29
|
+
fakerGroup: fakerPlugin.options?.group,
|
|
30
|
+
})
|
|
31
|
+
: undefined
|
|
32
|
+
|
|
33
|
+
const pluginTs = driver.getPlugin(pluginTsName)
|
|
34
|
+
if (!pluginTs) return null
|
|
35
|
+
const tsResolver = driver.getResolver(pluginTsName)
|
|
31
36
|
|
|
32
37
|
const type = {
|
|
33
|
-
file:
|
|
34
|
-
|
|
38
|
+
file: tsResolver.resolveFile(
|
|
39
|
+
{ name: node.operationId, extname: '.ts', tag: node.tags[0] ?? 'default', path: node.path },
|
|
40
|
+
{ root, output: pluginTs.options?.output ?? output, group: pluginTs.options?.group },
|
|
41
|
+
),
|
|
42
|
+
responseName: tsResolver.resolveResponseName(node),
|
|
35
43
|
}
|
|
36
44
|
|
|
37
|
-
const
|
|
38
|
-
|
|
39
|
-
const
|
|
40
|
-
|
|
41
|
-
for (const code of responseStatusCodes) {
|
|
42
|
-
if (code === 'default') {
|
|
43
|
-
types.push(['default', type.schemas.response.name])
|
|
44
|
-
continue
|
|
45
|
-
}
|
|
45
|
+
const types = getResponseTypes(node, tsResolver)
|
|
46
|
+
const successResponses = getSuccessResponses(node)
|
|
47
|
+
const hasSuccessSchema = successResponses.some((response) => !!response.schema)
|
|
46
48
|
|
|
47
|
-
|
|
48
|
-
types.push([Number(code), type.schemas.response.name])
|
|
49
|
-
continue
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
const codeType = type.schemas.errors?.find((err) => err.statusCode === Number(code))
|
|
53
|
-
if (codeType) types.push([Number(code), codeType.name])
|
|
54
|
-
}
|
|
49
|
+
const requestName = node.requestBody?.content?.[0]?.schema ? tsResolver.resolveDataName(node) : undefined
|
|
55
50
|
|
|
56
51
|
return (
|
|
57
52
|
<File
|
|
58
53
|
baseName={mock.file.baseName}
|
|
59
54
|
path={mock.file.path}
|
|
60
55
|
meta={mock.file.meta}
|
|
61
|
-
banner={
|
|
62
|
-
footer={
|
|
56
|
+
banner={resolver.resolveBanner(adapter.inputNode, { output, config })}
|
|
57
|
+
footer={resolver.resolveFooter(adapter.inputNode, { output, config })}
|
|
63
58
|
>
|
|
64
59
|
<File.Import name={['http']} path="msw" />
|
|
65
|
-
<File.Import name={['
|
|
60
|
+
<File.Import name={['HttpResponseResolver']} isTypeOnly path="msw" />
|
|
66
61
|
<File.Import
|
|
67
|
-
name={Array.from(new Set([type.
|
|
62
|
+
name={Array.from(new Set([type.responseName, ...types.map((t) => t[1]), ...(requestName ? [requestName] : [])]))}
|
|
68
63
|
path={type.file.path}
|
|
69
64
|
root={mock.file.path}
|
|
70
65
|
isTypeOnly
|
|
71
66
|
/>
|
|
72
|
-
{parser === 'faker' && faker
|
|
73
|
-
<File.Import name={[faker.schemas.response.name]} root={mock.file.path} path={faker.file.path} />
|
|
74
|
-
)}
|
|
67
|
+
{parser === 'faker' && faker && <File.Import name={[faker.name]} root={mock.file.path} path={faker.file.path} />}
|
|
75
68
|
|
|
76
69
|
{types
|
|
77
70
|
.filter(([code]) => code !== 'default')
|
|
78
|
-
.map(([code, typeName]) =>
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
/>
|
|
89
|
-
)}
|
|
90
|
-
{parser === 'data' && (
|
|
91
|
-
<Mock name={mock.name} typeName={type.schemas.response.name} fakerName={faker.schemas.response.name} operation={operation} baseURL={baseURL} />
|
|
71
|
+
.map(([code, typeName]) => {
|
|
72
|
+
const response = node.responses.find((item) => item.statusCode === String(code))
|
|
73
|
+
if (!response) return null
|
|
74
|
+
return <Response key={typeName} typeName={typeName} response={response} name={mock.name} />
|
|
75
|
+
})}
|
|
76
|
+
|
|
77
|
+
{parser === 'faker' && faker && hasSuccessSchema ? (
|
|
78
|
+
<MockWithFaker name={mock.name} typeName={type.responseName} requestTypeName={requestName} fakerName={faker.name} node={node} baseURL={baseURL} />
|
|
79
|
+
) : (
|
|
80
|
+
<Mock name={mock.name} typeName={type.responseName} requestTypeName={requestName} node={node} baseURL={baseURL} />
|
|
92
81
|
)}
|
|
93
82
|
</File>
|
|
94
83
|
)
|
package/src/index.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export { pluginMsw, pluginMswName } from './plugin.ts'
|
|
1
|
+
export { default, pluginMsw, pluginMswName } from './plugin.ts'
|
|
2
2
|
export type { PluginMsw } from './types.ts'
|
package/src/plugin.ts
CHANGED
|
@@ -1,15 +1,14 @@
|
|
|
1
|
-
import path from 'node:path'
|
|
2
1
|
import { camelCase } from '@internals/utils'
|
|
3
|
-
import {
|
|
2
|
+
import { definePlugin, type Group } from '@kubb/core'
|
|
4
3
|
import { pluginFakerName } from '@kubb/plugin-faker'
|
|
5
|
-
import { OperationGenerator, pluginOasName } from '@kubb/plugin-oas'
|
|
6
4
|
import { pluginTsName } from '@kubb/plugin-ts'
|
|
7
5
|
import { handlersGenerator, mswGenerator } from './generators'
|
|
6
|
+
import { resolverMsw } from './resolvers/resolverMsw.ts'
|
|
8
7
|
import type { PluginMsw } from './types.ts'
|
|
9
8
|
|
|
10
9
|
export const pluginMswName = 'plugin-msw' satisfies PluginMsw['name']
|
|
11
10
|
|
|
12
|
-
export const pluginMsw =
|
|
11
|
+
export const pluginMsw = definePlugin<PluginMsw>((options) => {
|
|
13
12
|
const {
|
|
14
13
|
output = { path: 'handlers', barrelType: 'named' },
|
|
15
14
|
group,
|
|
@@ -19,97 +18,61 @@ export const pluginMsw = createPlugin<PluginMsw>((options) => {
|
|
|
19
18
|
transformers = {},
|
|
20
19
|
handlers = false,
|
|
21
20
|
parser = 'data',
|
|
22
|
-
generators = [mswGenerator, handlers ? handlersGenerator : undefined].filter(Boolean),
|
|
23
|
-
contentType,
|
|
24
21
|
baseURL,
|
|
22
|
+
resolver: userResolver,
|
|
23
|
+
transformer: userTransformer,
|
|
24
|
+
generators: userGenerators = [],
|
|
25
25
|
} = options
|
|
26
26
|
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
parser,
|
|
32
|
-
group,
|
|
33
|
-
baseURL,
|
|
34
|
-
},
|
|
35
|
-
pre: [pluginOasName, pluginTsName, parser === 'faker' ? pluginFakerName : undefined].filter(Boolean),
|
|
36
|
-
resolvePath(baseName, pathMode, options) {
|
|
37
|
-
const root = path.resolve(this.config.root, this.config.output.path)
|
|
38
|
-
const mode = pathMode ?? getMode(path.resolve(root, output.path))
|
|
39
|
-
|
|
40
|
-
if (mode === 'single') {
|
|
41
|
-
/**
|
|
42
|
-
* when output is a file then we will always append to the same file(output file), see fileManager.addOrAppend
|
|
43
|
-
* Other plugins then need to call addOrAppend instead of just add from the fileManager class
|
|
44
|
-
*/
|
|
45
|
-
return path.resolve(root, output.path)
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
if (group && (options?.group?.path || options?.group?.tag)) {
|
|
49
|
-
const groupName: Group['name'] = group?.name
|
|
27
|
+
const groupConfig = group
|
|
28
|
+
? ({
|
|
29
|
+
...group,
|
|
30
|
+
name: group.name
|
|
50
31
|
? group.name
|
|
51
|
-
: (ctx) => {
|
|
52
|
-
if (group
|
|
32
|
+
: (ctx: { group: string }) => {
|
|
33
|
+
if (group.type === 'path') {
|
|
53
34
|
return `${ctx.group.split('/')[1]}`
|
|
54
35
|
}
|
|
55
36
|
return `${camelCase(ctx.group)}Controller`
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
root,
|
|
60
|
-
output.path,
|
|
61
|
-
groupName({
|
|
62
|
-
group: group.type === 'path' ? options.group.path! : options.group.tag!,
|
|
63
|
-
}),
|
|
64
|
-
baseName,
|
|
65
|
-
)
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
return path.resolve(root, output.path, baseName)
|
|
69
|
-
},
|
|
70
|
-
resolveName(name, type) {
|
|
71
|
-
const resolvedName = camelCase(name, {
|
|
72
|
-
suffix: type ? 'handler' : undefined,
|
|
73
|
-
isFile: type === 'file',
|
|
74
|
-
})
|
|
37
|
+
},
|
|
38
|
+
} satisfies Group)
|
|
39
|
+
: undefined
|
|
75
40
|
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
const root = path.resolve(this.config.root, this.config.output.path)
|
|
84
|
-
const mode = getMode(path.resolve(root, output.path))
|
|
85
|
-
const oas = await this.getOas()
|
|
86
|
-
|
|
87
|
-
const operationGenerator = new OperationGenerator(this.plugin.options, {
|
|
88
|
-
fabric: this.fabric,
|
|
89
|
-
oas,
|
|
90
|
-
driver: this.driver,
|
|
91
|
-
events: this.events,
|
|
92
|
-
plugin: this.plugin,
|
|
93
|
-
contentType,
|
|
94
|
-
exclude,
|
|
95
|
-
include,
|
|
96
|
-
override,
|
|
97
|
-
mode,
|
|
98
|
-
})
|
|
99
|
-
|
|
100
|
-
const files = await operationGenerator.build(...generators)
|
|
101
|
-
await this.upsertFile(...files)
|
|
41
|
+
return {
|
|
42
|
+
name: pluginMswName,
|
|
43
|
+
options,
|
|
44
|
+
dependencies: [pluginTsName, parser === 'faker' ? pluginFakerName : undefined].filter(Boolean),
|
|
45
|
+
hooks: {
|
|
46
|
+
'kubb:plugin:setup'(ctx) {
|
|
47
|
+
const resolver = userResolver ? { ...resolverMsw, ...userResolver } : resolverMsw
|
|
102
48
|
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
49
|
+
ctx.setOptions({
|
|
50
|
+
output,
|
|
51
|
+
parser,
|
|
52
|
+
baseURL,
|
|
53
|
+
group: groupConfig,
|
|
54
|
+
exclude,
|
|
55
|
+
include,
|
|
56
|
+
override,
|
|
57
|
+
handlers,
|
|
58
|
+
transformers,
|
|
59
|
+
resolver,
|
|
60
|
+
})
|
|
61
|
+
ctx.setResolver(resolver)
|
|
62
|
+
if (userTransformer) {
|
|
63
|
+
ctx.setTransformer(userTransformer)
|
|
64
|
+
}
|
|
111
65
|
|
|
112
|
-
|
|
66
|
+
ctx.addGenerator(mswGenerator)
|
|
67
|
+
if (handlers) {
|
|
68
|
+
ctx.addGenerator(handlersGenerator)
|
|
69
|
+
}
|
|
70
|
+
for (const gen of userGenerators) {
|
|
71
|
+
ctx.addGenerator(gen)
|
|
72
|
+
}
|
|
73
|
+
},
|
|
113
74
|
},
|
|
114
75
|
}
|
|
115
76
|
})
|
|
77
|
+
|
|
78
|
+
export default pluginMsw
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { camelCase } from '@internals/utils'
|
|
2
|
+
import { defineResolver } from '@kubb/core'
|
|
3
|
+
import type { PluginMsw } from '../types.ts'
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Naming convention resolver for MSW plugin.
|
|
7
|
+
*
|
|
8
|
+
* Provides default naming helpers using camelCase with a `handler` suffix.
|
|
9
|
+
*/
|
|
10
|
+
export const resolverMsw = defineResolver<PluginMsw>((_ctx) => ({
|
|
11
|
+
name: 'default',
|
|
12
|
+
pluginName: 'plugin-msw',
|
|
13
|
+
default(name, type) {
|
|
14
|
+
return camelCase(name, { isFile: type === 'file' })
|
|
15
|
+
},
|
|
16
|
+
resolveName(name) {
|
|
17
|
+
return camelCase(name, { suffix: 'handler' })
|
|
18
|
+
},
|
|
19
|
+
}))
|
package/src/types.ts
CHANGED
|
@@ -1,65 +1,88 @@
|
|
|
1
|
-
import type { Group, Output, PluginFactoryOptions, ResolveNameParams } from '@kubb/core'
|
|
1
|
+
import type { ast, Exclude, Generator, Group, Include, Output, Override, PluginFactoryOptions, ResolveNameParams, Resolver } from '@kubb/core'
|
|
2
2
|
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
3
|
+
/**
|
|
4
|
+
* Resolver for MSW that provides naming methods for handler functions.
|
|
5
|
+
*/
|
|
6
|
+
export type ResolverMsw = Resolver & {
|
|
7
|
+
/**
|
|
8
|
+
* Resolves the handler function name for an operation.
|
|
9
|
+
*/
|
|
10
|
+
resolveName(this: ResolverMsw, name: string): string
|
|
11
|
+
}
|
|
6
12
|
|
|
7
13
|
export type Options = {
|
|
8
14
|
/**
|
|
9
15
|
* Specify the export location for the files and define the behavior of the output
|
|
10
|
-
* @default { path: '
|
|
16
|
+
* @default { path: 'handlers', barrelType: 'named' }
|
|
11
17
|
*/
|
|
12
|
-
output?: Output
|
|
13
|
-
/**
|
|
14
|
-
* Define which contentType should be used.
|
|
15
|
-
* By default, the first JSON valid mediaType is used
|
|
16
|
-
*/
|
|
17
|
-
contentType?: contentType
|
|
18
|
+
output?: Output
|
|
18
19
|
baseURL?: string
|
|
19
20
|
/**
|
|
20
21
|
* Group the MSW mocks based on the provided name.
|
|
21
22
|
*/
|
|
22
23
|
group?: Group
|
|
23
24
|
/**
|
|
24
|
-
*
|
|
25
|
+
* Tags, operations, or paths to exclude from generation.
|
|
25
26
|
*/
|
|
26
27
|
exclude?: Array<Exclude>
|
|
27
28
|
/**
|
|
28
|
-
*
|
|
29
|
+
* Tags, operations, or paths to include in generation.
|
|
29
30
|
*/
|
|
30
31
|
include?: Array<Include>
|
|
31
32
|
/**
|
|
32
|
-
*
|
|
33
|
+
* Override options for specific tags, operations, or paths.
|
|
33
34
|
*/
|
|
34
35
|
override?: Array<Override<ResolvedOptions>>
|
|
35
36
|
transformers?: {
|
|
36
37
|
/**
|
|
37
|
-
*
|
|
38
|
+
* Override the default naming for handlers.
|
|
38
39
|
*/
|
|
39
40
|
name?: (name: ResolveNameParams['name'], type?: ResolveNameParams['type']) => string
|
|
40
41
|
}
|
|
42
|
+
/**
|
|
43
|
+
* Override naming conventions for function names and types.
|
|
44
|
+
*/
|
|
45
|
+
resolver?: Partial<ResolverMsw> & ThisType<ResolverMsw>
|
|
46
|
+
/**
|
|
47
|
+
* AST visitor to transform generated nodes.
|
|
48
|
+
*/
|
|
49
|
+
transformer?: ast.Visitor
|
|
41
50
|
/**
|
|
42
51
|
* Create `handlers.ts` file with all handlers grouped by methods.
|
|
43
52
|
* @default false
|
|
44
53
|
*/
|
|
45
54
|
handlers?: boolean
|
|
46
55
|
/**
|
|
47
|
-
* Which parser
|
|
48
|
-
*
|
|
49
|
-
* - 'faker' uses @kubb/plugin-faker to generate the data for the response.
|
|
56
|
+
* Which parser to use for generating response data.
|
|
57
|
+
*
|
|
50
58
|
* @default 'data'
|
|
51
59
|
*/
|
|
52
60
|
parser?: 'data' | 'faker'
|
|
53
61
|
/**
|
|
54
|
-
*
|
|
62
|
+
* Additional generators alongside the default generators.
|
|
55
63
|
*/
|
|
56
64
|
generators?: Array<Generator<PluginMsw>>
|
|
57
65
|
}
|
|
66
|
+
|
|
58
67
|
type ResolvedOptions = {
|
|
59
|
-
output: Output
|
|
60
|
-
group:
|
|
68
|
+
output: Output
|
|
69
|
+
group: Group | undefined
|
|
70
|
+
exclude: NonNullable<Options['exclude']>
|
|
71
|
+
include: Options['include']
|
|
72
|
+
override: NonNullable<Options['override']>
|
|
61
73
|
parser: NonNullable<Options['parser']>
|
|
62
74
|
baseURL: Options['baseURL'] | undefined
|
|
75
|
+
handlers: boolean
|
|
76
|
+
transformers: NonNullable<Options['transformers']>
|
|
77
|
+
resolver: ResolverMsw
|
|
63
78
|
}
|
|
64
79
|
|
|
65
|
-
export type PluginMsw = PluginFactoryOptions<'plugin-msw', Options, ResolvedOptions,
|
|
80
|
+
export type PluginMsw = PluginFactoryOptions<'plugin-msw', Options, ResolvedOptions, ResolverMsw>
|
|
81
|
+
|
|
82
|
+
declare global {
|
|
83
|
+
namespace Kubb {
|
|
84
|
+
interface PluginRegistry {
|
|
85
|
+
'plugin-msw': PluginMsw
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
}
|