@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.
Files changed (45) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +53 -0
  3. package/dist/chunk-5AJXTSAA.cjs +179 -0
  4. package/dist/chunk-5AJXTSAA.cjs.map +1 -0
  5. package/dist/chunk-RN55DM2O.cjs +97 -0
  6. package/dist/chunk-RN55DM2O.cjs.map +1 -0
  7. package/dist/chunk-VPK2OEBV.js +95 -0
  8. package/dist/chunk-VPK2OEBV.js.map +1 -0
  9. package/dist/chunk-WEY2R35B.js +176 -0
  10. package/dist/chunk-WEY2R35B.js.map +1 -0
  11. package/dist/components.cjs +12 -0
  12. package/dist/components.cjs.map +1 -0
  13. package/dist/components.d.cts +27 -0
  14. package/dist/components.d.ts +27 -0
  15. package/dist/components.js +3 -0
  16. package/dist/components.js.map +1 -0
  17. package/dist/generators.cjs +17 -0
  18. package/dist/generators.cjs.map +1 -0
  19. package/dist/generators.d.cts +11 -0
  20. package/dist/generators.d.ts +11 -0
  21. package/dist/generators.js +4 -0
  22. package/dist/generators.js.map +1 -0
  23. package/dist/index.cjs +108 -0
  24. package/dist/index.cjs.map +1 -0
  25. package/dist/index.d.cts +10 -0
  26. package/dist/index.d.ts +10 -0
  27. package/dist/index.js +101 -0
  28. package/dist/index.js.map +1 -0
  29. package/dist/types-B4DlUSkU.d.cts +54 -0
  30. package/dist/types-B4DlUSkU.d.ts +54 -0
  31. package/package.json +117 -0
  32. package/src/components/Server.tsx +141 -0
  33. package/src/components/index.ts +1 -0
  34. package/src/generators/__snapshots__/.mcp.json +9 -0
  35. package/src/generators/__snapshots__/createPet.ts +19 -0
  36. package/src/generators/__snapshots__/deletePet.ts +18 -0
  37. package/src/generators/__snapshots__/getPets.ts +19 -0
  38. package/src/generators/__snapshots__/server.ts +37 -0
  39. package/src/generators/__snapshots__/showPetById.ts +25 -0
  40. package/src/generators/index.ts +2 -0
  41. package/src/generators/mcpGenerator.tsx +89 -0
  42. package/src/generators/serverGenerator.tsx +93 -0
  43. package/src/index.ts +2 -0
  44. package/src/plugin.ts +120 -0
  45. 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"]}