@kubb/plugin-mcp 0.0.0-canary-20250414193247
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 +21 -0
- package/README.md +53 -0
- package/dist/chunk-5AJXTSAA.cjs +179 -0
- package/dist/chunk-5AJXTSAA.cjs.map +1 -0
- package/dist/chunk-RN55DM2O.cjs +97 -0
- package/dist/chunk-RN55DM2O.cjs.map +1 -0
- package/dist/chunk-VPK2OEBV.js +95 -0
- package/dist/chunk-VPK2OEBV.js.map +1 -0
- package/dist/chunk-WEY2R35B.js +176 -0
- package/dist/chunk-WEY2R35B.js.map +1 -0
- package/dist/components.cjs +12 -0
- package/dist/components.cjs.map +1 -0
- package/dist/components.d.cts +27 -0
- package/dist/components.d.ts +27 -0
- package/dist/components.js +3 -0
- package/dist/components.js.map +1 -0
- package/dist/generators.cjs +17 -0
- package/dist/generators.cjs.map +1 -0
- package/dist/generators.d.cts +11 -0
- package/dist/generators.d.ts +11 -0
- package/dist/generators.js +4 -0
- package/dist/generators.js.map +1 -0
- package/dist/index.cjs +108 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +10 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.js +101 -0
- package/dist/index.js.map +1 -0
- package/dist/types-B4DlUSkU.d.cts +54 -0
- package/dist/types-B4DlUSkU.d.ts +54 -0
- package/package.json +117 -0
- package/src/components/Server.tsx +141 -0
- package/src/components/index.ts +1 -0
- package/src/generators/__snapshots__/.mcp.json +9 -0
- package/src/generators/__snapshots__/createPet.ts +19 -0
- package/src/generators/__snapshots__/deletePet.ts +18 -0
- package/src/generators/__snapshots__/getPets.ts +19 -0
- package/src/generators/__snapshots__/server.ts +37 -0
- package/src/generators/__snapshots__/showPetById.ts +25 -0
- package/src/generators/index.ts +2 -0
- package/src/generators/mcpGenerator.tsx +89 -0
- package/src/generators/serverGenerator.tsx +93 -0
- package/src/index.ts +2 -0
- package/src/plugin.ts +120 -0
- package/src/types.ts +54 -0
package/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2024 Stijn Van Hulle
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/README.md
ADDED
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
<div align="center">
|
|
2
|
+
|
|
3
|
+
<!-- <img src="assets/logo.png" alt="logo" width="200" height="auto" /> -->
|
|
4
|
+
<h1>@kubb/plugin-cypress</h1>
|
|
5
|
+
|
|
6
|
+
<p>
|
|
7
|
+
Swagger integration to create MCP helpers.
|
|
8
|
+
</p>
|
|
9
|
+
<img src="https://raw.githubusercontent.com/kubb-labs/kubb/main/assets/banner.png" alt="logo" height="auto" />
|
|
10
|
+
|
|
11
|
+
[![npm version][npm-version-src]][npm-version-href]
|
|
12
|
+
[![npm downloads][npm-downloads-src]][npm-downloads-href]
|
|
13
|
+
[![Coverage][coverage-src]][coverage-href]
|
|
14
|
+
[![License][license-src]][license-href]
|
|
15
|
+
|
|
16
|
+
<h4>
|
|
17
|
+
<a href="https://codesandbox.io/s/github/kubb-labs/kubb/tree/main//examples/typescript" target="_blank">View Demo</a>
|
|
18
|
+
<span> · </span>
|
|
19
|
+
<a href="https://kubb.dev/" target="_blank">Documentation</a>
|
|
20
|
+
<span> · </span>
|
|
21
|
+
<a href="https://github.com/kubb-labs/kubb/issues/" target="_blank">Report Bug</a>
|
|
22
|
+
<span> · </span>
|
|
23
|
+
<a href="https://github.com/kubb-labs/kubb/issues/" target="_blank">Request Feature</a>
|
|
24
|
+
</h4>
|
|
25
|
+
</div>
|
|
26
|
+
|
|
27
|
+
## Supporting Kubb
|
|
28
|
+
|
|
29
|
+
Kubb uses an MIT-licensed open source project with its ongoing development made possible entirely by the support of Sponsors. If you would like to become a sponsor, please consider:
|
|
30
|
+
|
|
31
|
+
- [Become a Sponsor on GitHub](https://github.com/sponsors/stijnvanhulle)
|
|
32
|
+
|
|
33
|
+
<p align="center">
|
|
34
|
+
<a href="https://github.com/sponsors/stijnvanhulle">
|
|
35
|
+
<img src="https://raw.githubusercontent.com/stijnvanhulle/sponsors/main/sponsors.svg" alt="My sponsors" />
|
|
36
|
+
</a>
|
|
37
|
+
</p>
|
|
38
|
+
|
|
39
|
+
|
|
40
|
+
<!-- Badges -->
|
|
41
|
+
|
|
42
|
+
[npm-version-src]: https://img.shields.io/npm/v/@kubb/plugin-mcp?flat&colorA=18181B&colorB=f58517
|
|
43
|
+
[npm-version-href]: https://npmjs.com/package/@kubb/plugin-mcp
|
|
44
|
+
[npm-downloads-src]: https://img.shields.io/npm/dm/@kubb/plugin-mcp?flat&colorA=18181B&colorB=f58517
|
|
45
|
+
[npm-downloads-href]: https://npmjs.com/package/@kubb/plugin-mcp
|
|
46
|
+
[license-src]: https://img.shields.io/github/license/kubb-labs/kubb.svg?flat&colorA=18181B&colorB=f58517
|
|
47
|
+
[license-href]: https://github.com/kubb-labs/kubb/blob/main/LICENSE
|
|
48
|
+
[build-src]: https://img.shields.io/github/actions/workflow/status/kubb-labs/kubb/ci.yaml?style=flat&colorA=18181B&colorB=f58517
|
|
49
|
+
[build-href]: https://www.npmjs.com/package/@kubb/plugin-mcp
|
|
50
|
+
[minified-src]: https://img.shields.io/bundlephobia/min/@kubb/plugin-mcp?style=flat&colorA=18181B&colorB=f58517
|
|
51
|
+
[minified-href]: https://www.npmjs.com/package/@kubb/plugin-mcp
|
|
52
|
+
[coverage-src]: https://img.shields.io/codecov/c/github/kubb-labs/kubb?style=flat&colorA=18181B&colorB=f58517
|
|
53
|
+
[coverage-href]: https://www.npmjs.com/package/@kubb/plugin-mcp
|
|
@@ -0,0 +1,179 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var chunkRN55DM2O_cjs = require('./chunk-RN55DM2O.cjs');
|
|
4
|
+
var pluginOas = require('@kubb/plugin-oas');
|
|
5
|
+
var hooks = require('@kubb/plugin-oas/hooks');
|
|
6
|
+
var utils = require('@kubb/plugin-oas/utils');
|
|
7
|
+
var pluginTs = require('@kubb/plugin-ts');
|
|
8
|
+
var react = require('@kubb/react');
|
|
9
|
+
var components = require('@kubb/plugin-client/components');
|
|
10
|
+
var jsxRuntime = require('@kubb/react/jsx-runtime');
|
|
11
|
+
var pluginZod = require('@kubb/plugin-zod');
|
|
12
|
+
|
|
13
|
+
var mcpGenerator = pluginOas.createReactGenerator({
|
|
14
|
+
name: "mcp",
|
|
15
|
+
Operation({ operation }) {
|
|
16
|
+
const {
|
|
17
|
+
plugin: { options }
|
|
18
|
+
} = react.useApp();
|
|
19
|
+
const oas = hooks.useOas();
|
|
20
|
+
const { getSchemas, getName, getFile } = hooks.useOperationManager();
|
|
21
|
+
const mcp = {
|
|
22
|
+
name: getName(operation, { type: "function", suffix: "handler" }),
|
|
23
|
+
file: getFile(operation)
|
|
24
|
+
};
|
|
25
|
+
const type = {
|
|
26
|
+
file: getFile(operation, { pluginKey: [pluginTs.pluginTsName] }),
|
|
27
|
+
schemas: getSchemas(operation, { pluginKey: [pluginTs.pluginTsName], type: "type" })
|
|
28
|
+
};
|
|
29
|
+
return /* @__PURE__ */ jsxRuntime.jsxs(
|
|
30
|
+
react.File,
|
|
31
|
+
{
|
|
32
|
+
baseName: mcp.file.baseName,
|
|
33
|
+
path: mcp.file.path,
|
|
34
|
+
meta: mcp.file.meta,
|
|
35
|
+
banner: utils.getBanner({ oas, output: options.output }),
|
|
36
|
+
footer: utils.getFooter({ oas, output: options.output }),
|
|
37
|
+
children: [
|
|
38
|
+
/* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: ["CallToolResult"], path: "@modelcontextprotocol/sdk/types", isTypeOnly: true }),
|
|
39
|
+
/* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: "client", path: options.client.importPath }),
|
|
40
|
+
/* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: ["RequestConfig", "ResponseErrorConfig"], path: options.client.importPath, isTypeOnly: true }),
|
|
41
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
42
|
+
react.File.Import,
|
|
43
|
+
{
|
|
44
|
+
name: [
|
|
45
|
+
type.schemas.request?.name,
|
|
46
|
+
type.schemas.response.name,
|
|
47
|
+
type.schemas.pathParams?.name,
|
|
48
|
+
type.schemas.queryParams?.name,
|
|
49
|
+
type.schemas.headerParams?.name,
|
|
50
|
+
...type.schemas.statusCodes?.map((item) => item.name) || []
|
|
51
|
+
].filter(Boolean),
|
|
52
|
+
root: mcp.file.path,
|
|
53
|
+
path: type.file.path,
|
|
54
|
+
isTypeOnly: true
|
|
55
|
+
}
|
|
56
|
+
),
|
|
57
|
+
/* @__PURE__ */ jsxRuntime.jsxs(
|
|
58
|
+
components.Client,
|
|
59
|
+
{
|
|
60
|
+
name: mcp.name,
|
|
61
|
+
isConfigurable: false,
|
|
62
|
+
returnType: "Promise<CallToolResult>",
|
|
63
|
+
baseURL: options.client.baseURL,
|
|
64
|
+
operation,
|
|
65
|
+
typeSchemas: type.schemas,
|
|
66
|
+
zodSchemas: void 0,
|
|
67
|
+
dataReturnType: options.client.dataReturnType,
|
|
68
|
+
paramsType: "object",
|
|
69
|
+
paramsCasing: "camelcase",
|
|
70
|
+
pathParamsType: "object",
|
|
71
|
+
parser: "client",
|
|
72
|
+
children: [
|
|
73
|
+
options.client.dataReturnType === "data" && `return {
|
|
74
|
+
content: [
|
|
75
|
+
{
|
|
76
|
+
type: 'text',
|
|
77
|
+
text: JSON.stringify(res.data)
|
|
78
|
+
}
|
|
79
|
+
]
|
|
80
|
+
}`,
|
|
81
|
+
options.client.dataReturnType === "full" && `return {
|
|
82
|
+
content: [
|
|
83
|
+
{
|
|
84
|
+
type: 'text',
|
|
85
|
+
text: JSON.stringify(res)
|
|
86
|
+
}
|
|
87
|
+
]
|
|
88
|
+
}`
|
|
89
|
+
]
|
|
90
|
+
}
|
|
91
|
+
)
|
|
92
|
+
]
|
|
93
|
+
}
|
|
94
|
+
);
|
|
95
|
+
}
|
|
96
|
+
});
|
|
97
|
+
var serverGenerator = pluginOas.createReactGenerator({
|
|
98
|
+
name: "operations",
|
|
99
|
+
Operations({ operations, options }) {
|
|
100
|
+
const { pluginManager, plugin } = react.useApp();
|
|
101
|
+
const oas = hooks.useOas();
|
|
102
|
+
const { getFile, getName, getSchemas } = hooks.useOperationManager();
|
|
103
|
+
const name = "server";
|
|
104
|
+
const file = pluginManager.getFile({ name, extname: ".ts", pluginKey: plugin.key });
|
|
105
|
+
const jsonFile = pluginManager.getFile({ name: ".mcp", extname: ".json", pluginKey: plugin.key });
|
|
106
|
+
const operationsMapped = operations.map((operation) => {
|
|
107
|
+
return {
|
|
108
|
+
operationId: operation.getOperationId(),
|
|
109
|
+
description: operation.getDescription(),
|
|
110
|
+
mcp: {
|
|
111
|
+
name: getName(operation, {
|
|
112
|
+
type: "function",
|
|
113
|
+
suffix: "handler"
|
|
114
|
+
}),
|
|
115
|
+
file: getFile(operation)
|
|
116
|
+
},
|
|
117
|
+
zod: {
|
|
118
|
+
name: getName(operation, {
|
|
119
|
+
type: "function",
|
|
120
|
+
pluginKey: [pluginZod.pluginZodName]
|
|
121
|
+
}),
|
|
122
|
+
schemas: getSchemas(operation, { pluginKey: [pluginZod.pluginZodName], type: "function" }),
|
|
123
|
+
file: getFile(operation, { pluginKey: [pluginZod.pluginZodName] })
|
|
124
|
+
},
|
|
125
|
+
type: {
|
|
126
|
+
schemas: getSchemas(operation, { pluginKey: [pluginTs.pluginTsName], type: "type" })
|
|
127
|
+
}
|
|
128
|
+
};
|
|
129
|
+
});
|
|
130
|
+
const imports = operationsMapped.flatMap(({ mcp, zod }) => {
|
|
131
|
+
return [
|
|
132
|
+
/* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: [mcp.name], root: file.path, path: mcp.file.path }, mcp.name),
|
|
133
|
+
/* @__PURE__ */ jsxRuntime.jsx(
|
|
134
|
+
react.File.Import,
|
|
135
|
+
{
|
|
136
|
+
name: [zod.schemas.request?.name, zod.schemas.pathParams?.name, zod.schemas.queryParams?.name, zod.schemas.headerParams?.name].filter(Boolean),
|
|
137
|
+
root: file.path,
|
|
138
|
+
path: zod.file.path
|
|
139
|
+
},
|
|
140
|
+
zod.name
|
|
141
|
+
)
|
|
142
|
+
];
|
|
143
|
+
});
|
|
144
|
+
return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
|
|
145
|
+
/* @__PURE__ */ jsxRuntime.jsxs(
|
|
146
|
+
react.File,
|
|
147
|
+
{
|
|
148
|
+
baseName: file.baseName,
|
|
149
|
+
path: file.path,
|
|
150
|
+
meta: file.meta,
|
|
151
|
+
banner: utils.getBanner({ oas, output: options.output, config: pluginManager.config }),
|
|
152
|
+
footer: utils.getFooter({ oas, output: options.output }),
|
|
153
|
+
children: [
|
|
154
|
+
/* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: ["McpServer"], path: "@modelcontextprotocol/sdk/server/mcp" }),
|
|
155
|
+
/* @__PURE__ */ jsxRuntime.jsx(react.File.Import, { name: ["StdioServerTransport"], path: "@modelcontextprotocol/sdk/server/stdio" }),
|
|
156
|
+
imports,
|
|
157
|
+
/* @__PURE__ */ jsxRuntime.jsx(chunkRN55DM2O_cjs.Server, { name, serverName: oas.api.info?.title, serverVersion: oas.getVersion(), operations: operationsMapped })
|
|
158
|
+
]
|
|
159
|
+
}
|
|
160
|
+
),
|
|
161
|
+
/* @__PURE__ */ jsxRuntime.jsx(react.File, { baseName: jsonFile.baseName, path: jsonFile.path, meta: jsonFile.meta, children: /* @__PURE__ */ jsxRuntime.jsx(react.File.Source, { name, children: `
|
|
162
|
+
{
|
|
163
|
+
"mcpServers": {
|
|
164
|
+
"${oas.api.info?.title || "server"}": {
|
|
165
|
+
"type": "stdio",
|
|
166
|
+
"command": "npx",
|
|
167
|
+
"args": ["tsx", "${file.path}"]
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
` }) })
|
|
172
|
+
] });
|
|
173
|
+
}
|
|
174
|
+
});
|
|
175
|
+
|
|
176
|
+
exports.mcpGenerator = mcpGenerator;
|
|
177
|
+
exports.serverGenerator = serverGenerator;
|
|
178
|
+
//# sourceMappingURL=chunk-5AJXTSAA.cjs.map
|
|
179
|
+
//# sourceMappingURL=chunk-5AJXTSAA.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/generators/mcpGenerator.tsx","../src/generators/serverGenerator.tsx"],"names":["createReactGenerator","useApp","useOas","useOperationManager","pluginTsName","jsxs","File","getBanner","getFooter","jsx","Client","pluginZodName","Fragment","Server"],"mappings":"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","file":"chunk-5AJXTSAA.cjs","sourcesContent":["import { createReactGenerator } from '@kubb/plugin-oas'\nimport { useOas, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getBanner, getFooter } from '@kubb/plugin-oas/utils'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport { File, useApp } from '@kubb/react'\nimport type { PluginMcp } from '../types'\nimport { Client } from '@kubb/plugin-client/components'\n\nexport const mcpGenerator = createReactGenerator<PluginMcp>({\n name: 'mcp',\n Operation({ operation }) {\n const {\n plugin: { options },\n } = useApp<PluginMcp>()\n const oas = useOas()\n const { getSchemas, getName, getFile } = useOperationManager()\n\n const mcp = {\n name: getName(operation, { type: 'function', suffix: 'handler' }),\n file: getFile(operation),\n }\n\n const type = {\n file: getFile(operation, { pluginKey: [pluginTsName] }),\n schemas: getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' }),\n }\n\n return (\n <File\n baseName={mcp.file.baseName}\n path={mcp.file.path}\n meta={mcp.file.meta}\n banner={getBanner({ oas, output: options.output })}\n footer={getFooter({ oas, output: options.output })}\n >\n <File.Import name={['CallToolResult']} path={'@modelcontextprotocol/sdk/types'} isTypeOnly />\n <File.Import name={'client'} path={options.client.importPath} />\n <File.Import name={['RequestConfig', 'ResponseErrorConfig']} path={options.client.importPath} isTypeOnly />\n <File.Import\n name={[\n type.schemas.request?.name,\n type.schemas.response.name,\n type.schemas.pathParams?.name,\n type.schemas.queryParams?.name,\n type.schemas.headerParams?.name,\n ...(type.schemas.statusCodes?.map((item) => item.name) || []),\n ].filter(Boolean)}\n root={mcp.file.path}\n path={type.file.path}\n isTypeOnly\n />\n\n <Client\n name={mcp.name}\n isConfigurable={false}\n returnType={'Promise<CallToolResult>'}\n baseURL={options.client.baseURL}\n operation={operation}\n typeSchemas={type.schemas}\n zodSchemas={undefined}\n dataReturnType={options.client.dataReturnType}\n paramsType={'object'}\n paramsCasing={'camelcase'}\n pathParamsType={'object'}\n parser={'client'}\n >\n {options.client.dataReturnType === 'data' &&\n `return {\n content: [\n {\n type: 'text',\n text: JSON.stringify(res.data)\n }\n ]\n }`}\n {options.client.dataReturnType === 'full' &&\n `return {\n content: [\n {\n type: 'text',\n text: JSON.stringify(res)\n }\n ]\n }`}\n </Client>\n </File>\n )\n },\n})\n","import { createReactGenerator } from '@kubb/plugin-oas'\nimport { useOas, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getBanner, getFooter } from '@kubb/plugin-oas/utils'\nimport { File, useApp } from '@kubb/react'\nimport { Server } from '../components/Server'\nimport type { PluginMcp } from '../types'\nimport { pluginZodName } from '@kubb/plugin-zod'\nimport { pluginTsName } from '@kubb/plugin-ts'\n\nexport const serverGenerator = createReactGenerator<PluginMcp>({\n name: 'operations',\n Operations({ operations, options }) {\n const { pluginManager, plugin } = useApp<PluginMcp>()\n const oas = useOas()\n const { getFile, getName, getSchemas } = useOperationManager()\n\n const name = 'server'\n const file = pluginManager.getFile({ name, extname: '.ts', pluginKey: plugin.key })\n\n const jsonFile = pluginManager.getFile({ name: '.mcp', extname: '.json', pluginKey: plugin.key })\n\n const operationsMapped = operations.map((operation) => {\n return {\n operationId: operation.getOperationId(),\n description: operation.getDescription(),\n mcp: {\n name: getName(operation, {\n type: 'function',\n suffix: 'handler',\n }),\n file: getFile(operation),\n },\n zod: {\n name: getName(operation, {\n type: 'function',\n pluginKey: [pluginZodName],\n }),\n schemas: getSchemas(operation, { pluginKey: [pluginZodName], type: 'function' }),\n file: getFile(operation, { pluginKey: [pluginZodName] }),\n },\n type: {\n schemas: getSchemas(operation, { pluginKey: [pluginTsName], type: 'type' }),\n },\n }\n })\n\n const imports = operationsMapped.flatMap(({ mcp, zod }) => {\n return [\n <File.Import key={mcp.name} name={[mcp.name]} root={file.path} path={mcp.file.path} />,\n <File.Import\n key={zod.name}\n name={[zod.schemas.request?.name, zod.schemas.pathParams?.name, zod.schemas.queryParams?.name, zod.schemas.headerParams?.name].filter(Boolean)}\n root={file.path}\n path={zod.file.path}\n />,\n ]\n })\n\n return (\n <>\n <File\n baseName={file.baseName}\n path={file.path}\n meta={file.meta}\n banner={getBanner({ oas, output: options.output, config: pluginManager.config })}\n footer={getFooter({ oas, output: options.output })}\n >\n <File.Import name={['McpServer']} path={'@modelcontextprotocol/sdk/server/mcp'} />\n <File.Import name={['StdioServerTransport']} path={'@modelcontextprotocol/sdk/server/stdio'} />\n\n {imports}\n <Server name={name} serverName={oas.api.info?.title} serverVersion={oas.getVersion()} operations={operationsMapped} />\n </File>\n\n <File baseName={jsonFile.baseName} path={jsonFile.path} meta={jsonFile.meta}>\n <File.Source name={name}>\n {`\n {\n \"mcpServers\": {\n \"${oas.api.info?.title || 'server'}\": {\n \"type\": \"stdio\",\n \"command\": \"npx\",\n \"args\": [\"tsx\", \"${file.path}\"]\n }\n }\n }\n `}\n </File.Source>\n </File>\n </>\n )\n },\n})\n"]}
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var react = require('@kubb/react');
|
|
4
|
+
var utils = require('@kubb/plugin-oas/utils');
|
|
5
|
+
var oas = require('@kubb/oas');
|
|
6
|
+
var transformers = require('@kubb/core/transformers');
|
|
7
|
+
var jsxRuntime = require('@kubb/react/jsx-runtime');
|
|
8
|
+
|
|
9
|
+
// src/components/Server.tsx
|
|
10
|
+
function getParams({ schemas }) {
|
|
11
|
+
const pathParams = utils.getPathParams(schemas.pathParams, {
|
|
12
|
+
typed: false
|
|
13
|
+
});
|
|
14
|
+
return react.FunctionParams.factory({
|
|
15
|
+
data: {
|
|
16
|
+
mode: "object",
|
|
17
|
+
children: {
|
|
18
|
+
...Object.entries(pathParams).reduce((acc, [key, param]) => {
|
|
19
|
+
if (param && schemas.pathParams?.name) {
|
|
20
|
+
let suffix = ".shape";
|
|
21
|
+
if (oas.isNullable(schemas.pathParams.schema)) {
|
|
22
|
+
if (oas.isReference(schemas.pathParams)) {
|
|
23
|
+
suffix = ".unwrap().schema.unwrap().shape";
|
|
24
|
+
} else {
|
|
25
|
+
suffix = ".unwrap().shape";
|
|
26
|
+
}
|
|
27
|
+
} else {
|
|
28
|
+
if (oas.isReference(schemas.pathParams)) {
|
|
29
|
+
suffix = ".schema.shape";
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
param.value = `${schemas.pathParams?.name}${suffix}['${key}']`;
|
|
33
|
+
}
|
|
34
|
+
return {
|
|
35
|
+
...acc,
|
|
36
|
+
[transformers.camelCase(key)]: param
|
|
37
|
+
};
|
|
38
|
+
}, {}),
|
|
39
|
+
data: schemas.request?.name ? {
|
|
40
|
+
value: schemas.request?.name,
|
|
41
|
+
optional: utils.isOptional(schemas.request?.schema)
|
|
42
|
+
} : void 0,
|
|
43
|
+
params: schemas.queryParams?.name ? {
|
|
44
|
+
value: schemas.queryParams?.name,
|
|
45
|
+
optional: utils.isOptional(schemas.queryParams?.schema)
|
|
46
|
+
} : void 0,
|
|
47
|
+
headers: schemas.headerParams?.name ? {
|
|
48
|
+
value: schemas.headerParams?.name,
|
|
49
|
+
optional: utils.isOptional(schemas.headerParams?.schema)
|
|
50
|
+
} : void 0
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
function Server({ name, serverName, serverVersion, operations }) {
|
|
56
|
+
return /* @__PURE__ */ jsxRuntime.jsx(jsxRuntime.Fragment, { children: /* @__PURE__ */ jsxRuntime.jsxs(react.File.Source, { name, isExportable: true, isIndexable: true, children: [
|
|
57
|
+
/* @__PURE__ */ jsxRuntime.jsx(react.Const, { name: "server", export: true, children: `
|
|
58
|
+
new McpServer({
|
|
59
|
+
name: '${serverName}',
|
|
60
|
+
version: '${serverVersion}',
|
|
61
|
+
})
|
|
62
|
+
` }),
|
|
63
|
+
operations.map(({ operationId, mcp, zod, description = "" }) => {
|
|
64
|
+
const paramsClient = getParams({ schemas: zod.schemas });
|
|
65
|
+
if (zod.schemas.request?.name || zod.schemas.headerParams?.name || zod.schemas.queryParams?.name || zod.schemas.pathParams?.name) {
|
|
66
|
+
return `
|
|
67
|
+
server.tool('${operationId}', '${description}', ${paramsClient.toObjectValue()}, async (${paramsClient.toObject()}) => {
|
|
68
|
+
return ${mcp.name}(${paramsClient.toObject()})
|
|
69
|
+
})
|
|
70
|
+
`;
|
|
71
|
+
}
|
|
72
|
+
return `
|
|
73
|
+
server.tool('${operationId}', '${description}', async () => {
|
|
74
|
+
return ${mcp.name}(${paramsClient.toObject()})
|
|
75
|
+
})
|
|
76
|
+
`;
|
|
77
|
+
}).filter(Boolean),
|
|
78
|
+
`
|
|
79
|
+
async function startServer() {
|
|
80
|
+
try {
|
|
81
|
+
const transport = new StdioServerTransport()
|
|
82
|
+
await server.connect(transport)
|
|
83
|
+
console.error('Server started and listening on stdio')
|
|
84
|
+
} catch (error) {
|
|
85
|
+
console.error('Failed to start server:', error)
|
|
86
|
+
process.exit(1)
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
startServer()
|
|
91
|
+
`
|
|
92
|
+
] }) });
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
exports.Server = Server;
|
|
96
|
+
//# sourceMappingURL=chunk-RN55DM2O.cjs.map
|
|
97
|
+
//# sourceMappingURL=chunk-RN55DM2O.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/Server.tsx"],"names":["getPathParams","FunctionParams","isNullable","isReference","camelCase","isOptional","jsx","Fragment","File","Const"],"mappings":"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","file":"chunk-RN55DM2O.cjs","sourcesContent":["import type * as KubbFile from '@kubb/fs/types'\n\nimport { Const, File, FunctionParams } from '@kubb/react'\nimport type { OperationSchemas } from '@kubb/plugin-oas'\nimport { getPathParams, isOptional } from '@kubb/plugin-oas/utils'\nimport { isNullable, isReference } from '@kubb/oas'\nimport { camelCase } from '@kubb/core/transformers'\n\ntype Props = {\n name: string\n serverName: string\n serverVersion: string\n operations: Array<{\n operationId: string\n description?: string\n mcp: {\n name: string\n file: KubbFile.File\n }\n zod: {\n name: string\n file: KubbFile.File\n schemas: OperationSchemas\n }\n type: {\n schemas: OperationSchemas\n }\n }>\n}\n\ntype GetParamsProps = {\n schemas: OperationSchemas\n}\n\nfunction getParams({ schemas }: GetParamsProps) {\n const pathParams = getPathParams(schemas.pathParams, {\n typed: false,\n })\n\n return FunctionParams.factory({\n data: {\n mode: 'object',\n children: {\n ...Object.entries(pathParams).reduce((acc, [key, param]) => {\n if (param && schemas.pathParams?.name) {\n let suffix = '.shape'\n\n if (isNullable(schemas.pathParams.schema)) {\n if (isReference(schemas.pathParams)) {\n suffix = '.unwrap().schema.unwrap().shape'\n } else {\n suffix = '.unwrap().shape'\n }\n } else {\n if (isReference(schemas.pathParams)) {\n suffix = '.schema.shape'\n }\n }\n\n param.value = `${schemas.pathParams?.name}${suffix}['${key}']`\n }\n\n return {\n ...acc,\n [camelCase(key)]: param,\n }\n }, {}),\n data: schemas.request?.name\n ? {\n value: schemas.request?.name,\n optional: isOptional(schemas.request?.schema),\n }\n : undefined,\n params: schemas.queryParams?.name\n ? {\n value: schemas.queryParams?.name,\n optional: isOptional(schemas.queryParams?.schema),\n }\n : undefined,\n headers: schemas.headerParams?.name\n ? {\n value: schemas.headerParams?.name,\n optional: isOptional(schemas.headerParams?.schema),\n }\n : undefined,\n },\n },\n })\n}\n\nexport function Server({ name, serverName, serverVersion, operations }: Props) {\n return (\n <>\n <File.Source name={name} isExportable isIndexable>\n <Const name={'server'} export>\n {`\n new McpServer({\n name: '${serverName}',\n version: '${serverVersion}',\n})\n `}\n </Const>\n\n {operations\n .map(({ operationId, mcp, zod, description = '' }) => {\n const paramsClient = getParams({ schemas: zod.schemas })\n\n if (zod.schemas.request?.name || zod.schemas.headerParams?.name || zod.schemas.queryParams?.name || zod.schemas.pathParams?.name) {\n return `\nserver.tool('${operationId}', '${description}', ${paramsClient.toObjectValue()}, async (${paramsClient.toObject()}) => {\n return ${mcp.name}(${paramsClient.toObject()})\n})\n `\n }\n\n return `\nserver.tool('${operationId}', '${description}', async () => {\n return ${mcp.name}(${paramsClient.toObject()})\n})\n `\n })\n .filter(Boolean)}\n\n {`\nasync function startServer() {\n try {\n const transport = new StdioServerTransport()\n await server.connect(transport)\n console.error('Server started and listening on stdio')\n } catch (error) {\n console.error('Failed to start server:', error)\n process.exit(1)\n }\n}\n\nstartServer()\n`}\n </File.Source>\n </>\n )\n}\n"]}
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
import { File, Const, FunctionParams } from '@kubb/react';
|
|
2
|
+
import { getPathParams, isOptional } from '@kubb/plugin-oas/utils';
|
|
3
|
+
import { isNullable, isReference } from '@kubb/oas';
|
|
4
|
+
import { camelCase } from '@kubb/core/transformers';
|
|
5
|
+
import { jsx, Fragment, jsxs } from '@kubb/react/jsx-runtime';
|
|
6
|
+
|
|
7
|
+
// src/components/Server.tsx
|
|
8
|
+
function getParams({ schemas }) {
|
|
9
|
+
const pathParams = getPathParams(schemas.pathParams, {
|
|
10
|
+
typed: false
|
|
11
|
+
});
|
|
12
|
+
return FunctionParams.factory({
|
|
13
|
+
data: {
|
|
14
|
+
mode: "object",
|
|
15
|
+
children: {
|
|
16
|
+
...Object.entries(pathParams).reduce((acc, [key, param]) => {
|
|
17
|
+
if (param && schemas.pathParams?.name) {
|
|
18
|
+
let suffix = ".shape";
|
|
19
|
+
if (isNullable(schemas.pathParams.schema)) {
|
|
20
|
+
if (isReference(schemas.pathParams)) {
|
|
21
|
+
suffix = ".unwrap().schema.unwrap().shape";
|
|
22
|
+
} else {
|
|
23
|
+
suffix = ".unwrap().shape";
|
|
24
|
+
}
|
|
25
|
+
} else {
|
|
26
|
+
if (isReference(schemas.pathParams)) {
|
|
27
|
+
suffix = ".schema.shape";
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
param.value = `${schemas.pathParams?.name}${suffix}['${key}']`;
|
|
31
|
+
}
|
|
32
|
+
return {
|
|
33
|
+
...acc,
|
|
34
|
+
[camelCase(key)]: param
|
|
35
|
+
};
|
|
36
|
+
}, {}),
|
|
37
|
+
data: schemas.request?.name ? {
|
|
38
|
+
value: schemas.request?.name,
|
|
39
|
+
optional: isOptional(schemas.request?.schema)
|
|
40
|
+
} : void 0,
|
|
41
|
+
params: schemas.queryParams?.name ? {
|
|
42
|
+
value: schemas.queryParams?.name,
|
|
43
|
+
optional: isOptional(schemas.queryParams?.schema)
|
|
44
|
+
} : void 0,
|
|
45
|
+
headers: schemas.headerParams?.name ? {
|
|
46
|
+
value: schemas.headerParams?.name,
|
|
47
|
+
optional: isOptional(schemas.headerParams?.schema)
|
|
48
|
+
} : void 0
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
function Server({ name, serverName, serverVersion, operations }) {
|
|
54
|
+
return /* @__PURE__ */ jsx(Fragment, { children: /* @__PURE__ */ jsxs(File.Source, { name, isExportable: true, isIndexable: true, children: [
|
|
55
|
+
/* @__PURE__ */ jsx(Const, { name: "server", export: true, children: `
|
|
56
|
+
new McpServer({
|
|
57
|
+
name: '${serverName}',
|
|
58
|
+
version: '${serverVersion}',
|
|
59
|
+
})
|
|
60
|
+
` }),
|
|
61
|
+
operations.map(({ operationId, mcp, zod, description = "" }) => {
|
|
62
|
+
const paramsClient = getParams({ schemas: zod.schemas });
|
|
63
|
+
if (zod.schemas.request?.name || zod.schemas.headerParams?.name || zod.schemas.queryParams?.name || zod.schemas.pathParams?.name) {
|
|
64
|
+
return `
|
|
65
|
+
server.tool('${operationId}', '${description}', ${paramsClient.toObjectValue()}, async (${paramsClient.toObject()}) => {
|
|
66
|
+
return ${mcp.name}(${paramsClient.toObject()})
|
|
67
|
+
})
|
|
68
|
+
`;
|
|
69
|
+
}
|
|
70
|
+
return `
|
|
71
|
+
server.tool('${operationId}', '${description}', async () => {
|
|
72
|
+
return ${mcp.name}(${paramsClient.toObject()})
|
|
73
|
+
})
|
|
74
|
+
`;
|
|
75
|
+
}).filter(Boolean),
|
|
76
|
+
`
|
|
77
|
+
async function startServer() {
|
|
78
|
+
try {
|
|
79
|
+
const transport = new StdioServerTransport()
|
|
80
|
+
await server.connect(transport)
|
|
81
|
+
console.error('Server started and listening on stdio')
|
|
82
|
+
} catch (error) {
|
|
83
|
+
console.error('Failed to start server:', error)
|
|
84
|
+
process.exit(1)
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
startServer()
|
|
89
|
+
`
|
|
90
|
+
] }) });
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
export { Server };
|
|
94
|
+
//# sourceMappingURL=chunk-VPK2OEBV.js.map
|
|
95
|
+
//# sourceMappingURL=chunk-VPK2OEBV.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/Server.tsx"],"names":[],"mappings":"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","file":"chunk-VPK2OEBV.js","sourcesContent":["import type * as KubbFile from '@kubb/fs/types'\n\nimport { Const, File, FunctionParams } from '@kubb/react'\nimport type { OperationSchemas } from '@kubb/plugin-oas'\nimport { getPathParams, isOptional } from '@kubb/plugin-oas/utils'\nimport { isNullable, isReference } from '@kubb/oas'\nimport { camelCase } from '@kubb/core/transformers'\n\ntype Props = {\n name: string\n serverName: string\n serverVersion: string\n operations: Array<{\n operationId: string\n description?: string\n mcp: {\n name: string\n file: KubbFile.File\n }\n zod: {\n name: string\n file: KubbFile.File\n schemas: OperationSchemas\n }\n type: {\n schemas: OperationSchemas\n }\n }>\n}\n\ntype GetParamsProps = {\n schemas: OperationSchemas\n}\n\nfunction getParams({ schemas }: GetParamsProps) {\n const pathParams = getPathParams(schemas.pathParams, {\n typed: false,\n })\n\n return FunctionParams.factory({\n data: {\n mode: 'object',\n children: {\n ...Object.entries(pathParams).reduce((acc, [key, param]) => {\n if (param && schemas.pathParams?.name) {\n let suffix = '.shape'\n\n if (isNullable(schemas.pathParams.schema)) {\n if (isReference(schemas.pathParams)) {\n suffix = '.unwrap().schema.unwrap().shape'\n } else {\n suffix = '.unwrap().shape'\n }\n } else {\n if (isReference(schemas.pathParams)) {\n suffix = '.schema.shape'\n }\n }\n\n param.value = `${schemas.pathParams?.name}${suffix}['${key}']`\n }\n\n return {\n ...acc,\n [camelCase(key)]: param,\n }\n }, {}),\n data: schemas.request?.name\n ? {\n value: schemas.request?.name,\n optional: isOptional(schemas.request?.schema),\n }\n : undefined,\n params: schemas.queryParams?.name\n ? {\n value: schemas.queryParams?.name,\n optional: isOptional(schemas.queryParams?.schema),\n }\n : undefined,\n headers: schemas.headerParams?.name\n ? {\n value: schemas.headerParams?.name,\n optional: isOptional(schemas.headerParams?.schema),\n }\n : undefined,\n },\n },\n })\n}\n\nexport function Server({ name, serverName, serverVersion, operations }: Props) {\n return (\n <>\n <File.Source name={name} isExportable isIndexable>\n <Const name={'server'} export>\n {`\n new McpServer({\n name: '${serverName}',\n version: '${serverVersion}',\n})\n `}\n </Const>\n\n {operations\n .map(({ operationId, mcp, zod, description = '' }) => {\n const paramsClient = getParams({ schemas: zod.schemas })\n\n if (zod.schemas.request?.name || zod.schemas.headerParams?.name || zod.schemas.queryParams?.name || zod.schemas.pathParams?.name) {\n return `\nserver.tool('${operationId}', '${description}', ${paramsClient.toObjectValue()}, async (${paramsClient.toObject()}) => {\n return ${mcp.name}(${paramsClient.toObject()})\n})\n `\n }\n\n return `\nserver.tool('${operationId}', '${description}', async () => {\n return ${mcp.name}(${paramsClient.toObject()})\n})\n `\n })\n .filter(Boolean)}\n\n {`\nasync function startServer() {\n try {\n const transport = new StdioServerTransport()\n await server.connect(transport)\n console.error('Server started and listening on stdio')\n } catch (error) {\n console.error('Failed to start server:', error)\n process.exit(1)\n }\n}\n\nstartServer()\n`}\n </File.Source>\n </>\n )\n}\n"]}
|