@kubb/core 5.0.0-alpha.7 → 5.0.0-alpha.9

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.
@@ -1,23 +0,0 @@
1
- import type { UnknownUserPlugin, UserConfig } from '../types.ts'
2
-
3
- type PluginsArray = Array<Omit<UnknownUserPlugin, 'inject'>>
4
-
5
- function isJSONPlugins(plugins: UserConfig['plugins']): boolean {
6
- return Array.isArray(plugins) && plugins.some((plugin) => Array.isArray(plugin) && typeof (plugin as unknown[])[0] === 'string')
7
- }
8
-
9
- function isObjectPlugins(plugins: UserConfig['plugins']): boolean {
10
- return plugins instanceof Object && !Array.isArray(plugins)
11
- }
12
-
13
- export function getPlugins(plugins: UserConfig['plugins']): Promise<PluginsArray | undefined> {
14
- if (isObjectPlugins(plugins)) {
15
- throw new Error('Object plugins are not supported anymore, best to use http://kubb.dev/getting-started/configure#json')
16
- }
17
-
18
- if (isJSONPlugins(plugins)) {
19
- throw new Error('JSON plugins are not supported anymore, best to use http://kubb.dev/getting-started/configure#json')
20
- }
21
-
22
- return Promise.resolve(plugins)
23
- }
@@ -1,93 +0,0 @@
1
- import { isOperationNode, isSchemaNode } from '@kubb/ast'
2
- import type { Node, OperationNode, SchemaNode } from '@kubb/ast/types'
3
-
4
- type FilterItem = {
5
- type: string
6
- pattern: string | RegExp
7
- }
8
-
9
- type OverrideItem<TOptions> = FilterItem & {
10
- options: Omit<Partial<TOptions>, 'override'>
11
- }
12
-
13
- type ResolveOptionsContext<TOptions> = {
14
- options: TOptions
15
- exclude?: Array<FilterItem>
16
- include?: Array<FilterItem>
17
- override?: Array<OverrideItem<TOptions>>
18
- }
19
-
20
- function matchesOperationPattern(node: OperationNode, type: string, pattern: string | RegExp): boolean {
21
- switch (type) {
22
- case 'tag':
23
- return node.tags.some((tag) => !!tag.match(pattern))
24
- case 'operationId':
25
- return !!node.operationId.match(pattern)
26
- case 'path':
27
- return !!node.path.match(pattern)
28
- case 'method':
29
- return !!(node.method.toLowerCase() as string).match(pattern)
30
- default:
31
- return false
32
- }
33
- }
34
-
35
- function matchesSchemaPattern(node: SchemaNode, type: string, pattern: string | RegExp): boolean | null {
36
- switch (type) {
37
- case 'schemaName':
38
- return node.name ? !!node.name.match(pattern) : false
39
- default:
40
- return null
41
- }
42
- }
43
-
44
- /**
45
- * Resolves the effective plugin options for a given AST node by applying
46
- * `exclude`, `include`, and `override` rules from the plugin configuration.
47
- *
48
- * Returns `null` when the node is excluded or not matched by `include`.
49
- * Returns the merged options (base options merged with any matching `override`) otherwise.
50
- *
51
- * Supported filter types for `OperationNode`: `tag`, `operationId`, `path`, `method`.
52
- * Supported filter types for `SchemaNode`: `schemaName`.
53
- *
54
- * @example
55
- * const resolved = resolveOptions(operationNode, { options, exclude, include, override })
56
- * if (!resolved) return // excluded
57
- */
58
- export function resolveOptions<TOptions>(node: Node, { options, exclude = [], include, override = [] }: ResolveOptionsContext<TOptions>): TOptions | null {
59
- if (isOperationNode(node)) {
60
- const isExcluded = exclude.some(({ type, pattern }) => matchesOperationPattern(node, type, pattern))
61
- if (isExcluded) {
62
- return null
63
- }
64
-
65
- if (include && !include.some(({ type, pattern }) => matchesOperationPattern(node, type, pattern))) {
66
- return null
67
- }
68
-
69
- const overrideOptions = override.find(({ type, pattern }) => matchesOperationPattern(node, type, pattern))?.options
70
-
71
- return { ...options, ...overrideOptions }
72
- }
73
-
74
- if (isSchemaNode(node)) {
75
- if (exclude.some(({ type, pattern }) => matchesSchemaPattern(node, type, pattern) === true)) {
76
- return null
77
- }
78
-
79
- if (include) {
80
- const results = include.map(({ type, pattern }) => matchesSchemaPattern(node, type, pattern))
81
- const applicable = results.filter((r) => r !== null)
82
- if (applicable.length > 0 && !applicable.includes(true)) {
83
- return null
84
- }
85
- }
86
-
87
- const overrideOptions = override.find(({ type, pattern }) => matchesSchemaPattern(node, type, pattern) === true)?.options
88
-
89
- return { ...options, ...overrideOptions }
90
- }
91
-
92
- return options
93
- }