@kubb/plugin-mcp 5.0.0-alpha.9 → 5.0.0-beta.4
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 -4
- package/dist/index.cjs +957 -92
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +207 -4
- package/dist/index.js +923 -90
- package/dist/index.js.map +1 -1
- package/extension.yaml +470 -0
- package/package.json +42 -64
- package/src/components/McpHandler.tsx +173 -0
- package/src/components/Server.tsx +89 -109
- package/src/generators/mcpGenerator.tsx +65 -84
- package/src/generators/serverGenerator.tsx +95 -58
- package/src/index.ts +11 -2
- package/src/plugin.ts +87 -135
- package/src/resolvers/resolverMcp.ts +25 -0
- package/src/types.ts +46 -28
- package/src/utils.ts +113 -0
- package/dist/Server-DV9zFrUP.cjs +0 -221
- package/dist/Server-DV9zFrUP.cjs.map +0 -1
- package/dist/Server-KWLMg0Lm.js +0 -173
- package/dist/Server-KWLMg0Lm.js.map +0 -1
- package/dist/components.cjs +0 -3
- package/dist/components.d.ts +0 -41
- package/dist/components.js +0 -2
- package/dist/generators-CWAFnA94.cjs +0 -285
- package/dist/generators-CWAFnA94.cjs.map +0 -1
- package/dist/generators-TtEOkDB1.js +0 -274
- package/dist/generators-TtEOkDB1.js.map +0 -1
- package/dist/generators.cjs +0 -4
- package/dist/generators.d.ts +0 -508
- package/dist/generators.js +0 -2
- package/dist/types-DXZDZ3vf.d.ts +0 -64
- package/src/components/index.ts +0 -1
- package/src/generators/index.ts +0 -2
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Server-KWLMg0Lm.js","names":[],"sources":["../../../internals/utils/src/casing.ts","../../../internals/utils/src/reserved.ts","../src/components/Server.tsx"],"sourcesContent":["type Options = {\n /** When `true`, dot-separated segments are split on `.` and joined with `/` after casing. */\n isFile?: boolean\n /** Text prepended before casing is applied. */\n prefix?: string\n /** Text appended before casing is applied. */\n suffix?: string\n}\n\n/**\n * Shared implementation for camelCase and PascalCase conversion.\n * Splits on common word boundaries (spaces, hyphens, underscores, dots, slashes, colons)\n * and capitalizes each word according to `pascal`.\n *\n * When `pascal` is `true` the first word is also capitalized (PascalCase), otherwise only subsequent words are.\n */\nfunction toCamelOrPascal(text: string, pascal: boolean): string {\n const normalized = text\n .trim()\n .replace(/([a-z\\d])([A-Z])/g, '$1 $2')\n .replace(/([A-Z]+)([A-Z][a-z])/g, '$1 $2')\n .replace(/(\\d)([a-z])/g, '$1 $2')\n\n const words = normalized.split(/[\\s\\-_./\\\\:]+/).filter(Boolean)\n\n return words\n .map((word, i) => {\n const allUpper = word.length > 1 && word === word.toUpperCase()\n if (allUpper) return word\n if (i === 0 && !pascal) return word.charAt(0).toLowerCase() + word.slice(1)\n return word.charAt(0).toUpperCase() + word.slice(1)\n })\n .join('')\n .replace(/[^a-zA-Z0-9]/g, '')\n}\n\n/**\n * Splits `text` on `.` and applies `transformPart` to each segment.\n * The last segment receives `isLast = true`, all earlier segments receive `false`.\n * Segments are joined with `/` to form a file path.\n */\nfunction applyToFileParts(text: string, transformPart: (part: string, isLast: boolean) => string): string {\n const parts = text.split('.')\n return parts.map((part, i) => transformPart(part, i === parts.length - 1)).join('/')\n}\n\n/**\n * Converts `text` to camelCase.\n * When `isFile` is `true`, dot-separated segments are each cased independently and joined with `/`.\n *\n * @example\n * camelCase('hello-world') // 'helloWorld'\n * camelCase('pet.petId', { isFile: true }) // 'pet/petId'\n */\nexport function camelCase(text: string, { isFile, prefix = '', suffix = '' }: Options = {}): string {\n if (isFile) {\n return applyToFileParts(text, (part, isLast) => camelCase(part, isLast ? { prefix, suffix } : {}))\n }\n\n return toCamelOrPascal(`${prefix} ${text} ${suffix}`, false)\n}\n\n/**\n * Converts `text` to PascalCase.\n * When `isFile` is `true`, the last dot-separated segment is PascalCased and earlier segments are camelCased.\n *\n * @example\n * pascalCase('hello-world') // 'HelloWorld'\n * pascalCase('pet.petId', { isFile: true }) // 'pet/PetId'\n */\nexport function pascalCase(text: string, { isFile, prefix = '', suffix = '' }: Options = {}): string {\n if (isFile) {\n return applyToFileParts(text, (part, isLast) => (isLast ? pascalCase(part, { prefix, suffix }) : camelCase(part)))\n }\n\n return toCamelOrPascal(`${prefix} ${text} ${suffix}`, true)\n}\n\n/**\n * Converts `text` to snake_case.\n *\n * @example\n * snakeCase('helloWorld') // 'hello_world'\n * snakeCase('Hello-World') // 'hello_world'\n */\nexport function snakeCase(text: string, { prefix = '', suffix = '' }: Omit<Options, 'isFile'> = {}): string {\n const processed = `${prefix} ${text} ${suffix}`.trim()\n return processed\n .replace(/([a-z])([A-Z])/g, '$1_$2')\n .replace(/[\\s\\-.]+/g, '_')\n .replace(/[^a-zA-Z0-9_]/g, '')\n .toLowerCase()\n .split('_')\n .filter(Boolean)\n .join('_')\n}\n\n/**\n * Converts `text` to SCREAMING_SNAKE_CASE.\n *\n * @example\n * screamingSnakeCase('helloWorld') // 'HELLO_WORLD'\n */\nexport function screamingSnakeCase(text: string, { prefix = '', suffix = '' }: Omit<Options, 'isFile'> = {}): string {\n return snakeCase(text, { prefix, suffix }).toUpperCase()\n}\n","/**\n * JavaScript and Java reserved words.\n * @link https://github.com/jonschlinkert/reserved/blob/master/index.js\n */\nconst reservedWords = new Set([\n 'abstract',\n 'arguments',\n 'boolean',\n 'break',\n 'byte',\n 'case',\n 'catch',\n 'char',\n 'class',\n 'const',\n 'continue',\n 'debugger',\n 'default',\n 'delete',\n 'do',\n 'double',\n 'else',\n 'enum',\n 'eval',\n 'export',\n 'extends',\n 'false',\n 'final',\n 'finally',\n 'float',\n 'for',\n 'function',\n 'goto',\n 'if',\n 'implements',\n 'import',\n 'in',\n 'instanceof',\n 'int',\n 'interface',\n 'let',\n 'long',\n 'native',\n 'new',\n 'null',\n 'package',\n 'private',\n 'protected',\n 'public',\n 'return',\n 'short',\n 'static',\n 'super',\n 'switch',\n 'synchronized',\n 'this',\n 'throw',\n 'throws',\n 'transient',\n 'true',\n 'try',\n 'typeof',\n 'var',\n 'void',\n 'volatile',\n 'while',\n 'with',\n 'yield',\n 'Array',\n 'Date',\n 'hasOwnProperty',\n 'Infinity',\n 'isFinite',\n 'isNaN',\n 'isPrototypeOf',\n 'length',\n 'Math',\n 'name',\n 'NaN',\n 'Number',\n 'Object',\n 'prototype',\n 'String',\n 'toString',\n 'undefined',\n 'valueOf',\n] as const)\n\n/**\n * Prefixes a word with `_` when it is a reserved JavaScript/Java identifier\n * or starts with a digit.\n */\nexport function transformReservedWord(word: string): string {\n const firstChar = word.charCodeAt(0)\n if (word && (reservedWords.has(word as 'valueOf') || (firstChar >= 48 && firstChar <= 57))) {\n return `_${word}`\n }\n return word\n}\n\n/**\n * Returns `true` when `name` is a syntactically valid JavaScript variable name.\n */\nexport function isValidVarName(name: string): boolean {\n try {\n new Function(`var ${name}`)\n } catch {\n return false\n }\n return true\n}\n","import { camelCase, isValidVarName } from '@internals/utils'\nimport type { KubbFile } from '@kubb/fabric-core/types'\nimport type { SchemaObject } from '@kubb/oas'\nimport type { OperationSchemas } from '@kubb/plugin-oas'\nimport { isOptional } from '@kubb/plugin-oas/utils'\nimport { Const, File, FunctionParams } from '@kubb/react-fabric'\nimport type { FabricReactNode } from '@kubb/react-fabric/types'\n\ntype Props = {\n name: string\n serverName: string\n serverVersion: string\n paramsCasing?: 'camelcase'\n operations: Array<{\n tool: {\n name: string\n title?: string\n description: string\n }\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 paramsCasing?: 'camelcase'\n}\n\nfunction zodExprFromOasSchema(schema: SchemaObject): string {\n const types = Array.isArray(schema.type) ? schema.type : [schema.type]\n const baseType = types.find((t) => t && t !== 'null')\n const isNullableType = types.includes('null')\n\n let expr: string\n switch (baseType) {\n case 'integer':\n expr = 'z.coerce.number()'\n break\n case 'number':\n expr = 'z.number()'\n break\n case 'boolean':\n expr = 'z.boolean()'\n break\n case 'array':\n expr = 'z.array(z.unknown())'\n break\n default:\n expr = 'z.string()'\n }\n\n if (isNullableType) {\n expr = `${expr}.nullable()`\n }\n\n return expr\n}\n\nfunction getParams({ schemas, paramsCasing }: GetParamsProps) {\n const pathParamProperties = schemas.pathParams?.schema?.properties ?? {}\n const requiredFields = Array.isArray(schemas.pathParams?.schema?.required) ? schemas.pathParams.schema.required : []\n\n const pathParamEntries = Object.entries(pathParamProperties).reduce<Record<string, { value: string; optional: boolean }>>(\n (acc, [originalKey, propSchema]) => {\n const key = paramsCasing === 'camelcase' || !isValidVarName(originalKey) ? camelCase(originalKey) : originalKey\n acc[key] = {\n value: zodExprFromOasSchema(propSchema as SchemaObject),\n optional: !requiredFields.includes(originalKey),\n }\n return acc\n },\n {},\n )\n\n return FunctionParams.factory({\n data: {\n mode: 'object',\n children: {\n ...pathParamEntries,\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, paramsCasing, operations }: Props): FabricReactNode {\n return (\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(({ tool, mcp, zod }) => {\n const paramsClient = getParams({ schemas: zod.schemas, paramsCasing })\n const outputSchema = zod.schemas.response?.name\n\n const config = [\n tool.title ? `title: ${JSON.stringify(tool.title)}` : null,\n `description: ${JSON.stringify(tool.description)}`,\n outputSchema ? `outputSchema: { data: ${outputSchema} }` : null,\n ]\n .filter(Boolean)\n .join(',\\n ')\n\n if (zod.schemas.request?.name || zod.schemas.headerParams?.name || zod.schemas.queryParams?.name || zod.schemas.pathParams?.name) {\n return `\nserver.registerTool(${JSON.stringify(tool.name)}, {\n ${config},\n inputSchema: ${paramsClient.toObjectValue()},\n}, async (${paramsClient.toObject()}) => {\n return ${mcp.name}(${paramsClient.toObject()})\n})\n `\n }\n\n return `\nserver.registerTool(${JSON.stringify(tool.name)}, {\n ${config},\n}, async () => {\n return ${mcp.name}(${paramsClient.toObject()})\n})\n `\n })\n .filter(Boolean)}\n\n {`\nexport async function startServer() {\n try {\n const transport = new StdioServerTransport()\n await server.connect(transport)\n\n } catch (error) {\n console.error('Failed to start server:', error)\n process.exit(1)\n }\n}\n`}\n </File.Source>\n )\n}\n"],"mappings":"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"}
|
package/dist/components.cjs
DELETED
package/dist/components.d.ts
DELETED
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import { t as __name } from "./chunk--u3MIqq1.js";
|
|
2
|
-
import { OperationSchemas } from "@kubb/plugin-oas";
|
|
3
|
-
import { KubbFile } from "@kubb/fabric-core/types";
|
|
4
|
-
import { FabricReactNode } from "@kubb/react-fabric/types";
|
|
5
|
-
|
|
6
|
-
//#region src/components/Server.d.ts
|
|
7
|
-
type Props = {
|
|
8
|
-
name: string;
|
|
9
|
-
serverName: string;
|
|
10
|
-
serverVersion: string;
|
|
11
|
-
paramsCasing?: 'camelcase';
|
|
12
|
-
operations: Array<{
|
|
13
|
-
tool: {
|
|
14
|
-
name: string;
|
|
15
|
-
title?: string;
|
|
16
|
-
description: string;
|
|
17
|
-
};
|
|
18
|
-
mcp: {
|
|
19
|
-
name: string;
|
|
20
|
-
file: KubbFile.File;
|
|
21
|
-
};
|
|
22
|
-
zod: {
|
|
23
|
-
name: string;
|
|
24
|
-
file: KubbFile.File;
|
|
25
|
-
schemas: OperationSchemas;
|
|
26
|
-
};
|
|
27
|
-
type: {
|
|
28
|
-
schemas: OperationSchemas;
|
|
29
|
-
};
|
|
30
|
-
}>;
|
|
31
|
-
};
|
|
32
|
-
declare function Server({
|
|
33
|
-
name,
|
|
34
|
-
serverName,
|
|
35
|
-
serverVersion,
|
|
36
|
-
paramsCasing,
|
|
37
|
-
operations
|
|
38
|
-
}: Props): FabricReactNode;
|
|
39
|
-
//#endregion
|
|
40
|
-
export { Server };
|
|
41
|
-
//# sourceMappingURL=components.d.ts.map
|
package/dist/components.js
DELETED
|
@@ -1,285 +0,0 @@
|
|
|
1
|
-
const require_Server = require("./Server-DV9zFrUP.cjs");
|
|
2
|
-
let node_path = require("node:path");
|
|
3
|
-
node_path = require_Server.__toESM(node_path);
|
|
4
|
-
let _kubb_plugin_ts = require("@kubb/plugin-ts");
|
|
5
|
-
let _kubb_plugin_zod = require("@kubb/plugin-zod");
|
|
6
|
-
let _kubb_plugin_client_components = require("@kubb/plugin-client/components");
|
|
7
|
-
let _kubb_plugin_oas_generators = require("@kubb/plugin-oas/generators");
|
|
8
|
-
let _kubb_plugin_oas_hooks = require("@kubb/plugin-oas/hooks");
|
|
9
|
-
let _kubb_plugin_oas_utils = require("@kubb/plugin-oas/utils");
|
|
10
|
-
let _kubb_react_fabric = require("@kubb/react-fabric");
|
|
11
|
-
let _kubb_react_fabric_jsx_runtime = require("@kubb/react-fabric/jsx-runtime");
|
|
12
|
-
let _kubb_core_hooks = require("@kubb/core/hooks");
|
|
13
|
-
//#region src/generators/mcpGenerator.tsx
|
|
14
|
-
const mcpGenerator = (0, _kubb_plugin_oas_generators.createReactGenerator)({
|
|
15
|
-
name: "mcp",
|
|
16
|
-
Operation({ config, operation, generator, plugin }) {
|
|
17
|
-
const { options } = plugin;
|
|
18
|
-
const oas = (0, _kubb_plugin_oas_hooks.useOas)();
|
|
19
|
-
const { getSchemas, getName, getFile } = (0, _kubb_plugin_oas_hooks.useOperationManager)(generator);
|
|
20
|
-
const mcp = {
|
|
21
|
-
name: getName(operation, {
|
|
22
|
-
type: "function",
|
|
23
|
-
suffix: "handler"
|
|
24
|
-
}),
|
|
25
|
-
file: getFile(operation)
|
|
26
|
-
};
|
|
27
|
-
const type = {
|
|
28
|
-
file: getFile(operation, { pluginName: _kubb_plugin_ts.pluginTsName }),
|
|
29
|
-
schemas: getSchemas(operation, {
|
|
30
|
-
pluginName: _kubb_plugin_ts.pluginTsName,
|
|
31
|
-
type: "type"
|
|
32
|
-
})
|
|
33
|
-
};
|
|
34
|
-
return /* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsxs)(_kubb_react_fabric.File, {
|
|
35
|
-
baseName: mcp.file.baseName,
|
|
36
|
-
path: mcp.file.path,
|
|
37
|
-
meta: mcp.file.meta,
|
|
38
|
-
banner: (0, _kubb_plugin_oas_utils.getBanner)({
|
|
39
|
-
oas,
|
|
40
|
-
output: options.output
|
|
41
|
-
}),
|
|
42
|
-
footer: (0, _kubb_plugin_oas_utils.getFooter)({
|
|
43
|
-
oas,
|
|
44
|
-
output: options.output
|
|
45
|
-
}),
|
|
46
|
-
children: [
|
|
47
|
-
options.client.importPath ? /* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsxs)(_kubb_react_fabric_jsx_runtime.Fragment, { children: [
|
|
48
|
-
/* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsx)(_kubb_react_fabric.File.Import, {
|
|
49
|
-
name: "fetch",
|
|
50
|
-
path: options.client.importPath
|
|
51
|
-
}),
|
|
52
|
-
/* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsx)(_kubb_react_fabric.File.Import, {
|
|
53
|
-
name: [
|
|
54
|
-
"Client",
|
|
55
|
-
"RequestConfig",
|
|
56
|
-
"ResponseErrorConfig"
|
|
57
|
-
],
|
|
58
|
-
path: options.client.importPath,
|
|
59
|
-
isTypeOnly: true
|
|
60
|
-
}),
|
|
61
|
-
options.client.dataReturnType === "full" && /* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsx)(_kubb_react_fabric.File.Import, {
|
|
62
|
-
name: ["ResponseConfig"],
|
|
63
|
-
path: options.client.importPath,
|
|
64
|
-
isTypeOnly: true
|
|
65
|
-
})
|
|
66
|
-
] }) : /* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsxs)(_kubb_react_fabric_jsx_runtime.Fragment, { children: [
|
|
67
|
-
/* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsx)(_kubb_react_fabric.File.Import, {
|
|
68
|
-
name: ["fetch"],
|
|
69
|
-
root: mcp.file.path,
|
|
70
|
-
path: node_path.default.resolve(config.root, config.output.path, ".kubb/fetch.ts")
|
|
71
|
-
}),
|
|
72
|
-
/* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsx)(_kubb_react_fabric.File.Import, {
|
|
73
|
-
name: [
|
|
74
|
-
"Client",
|
|
75
|
-
"RequestConfig",
|
|
76
|
-
"ResponseErrorConfig"
|
|
77
|
-
],
|
|
78
|
-
root: mcp.file.path,
|
|
79
|
-
path: node_path.default.resolve(config.root, config.output.path, ".kubb/fetch.ts"),
|
|
80
|
-
isTypeOnly: true
|
|
81
|
-
}),
|
|
82
|
-
options.client.dataReturnType === "full" && /* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsx)(_kubb_react_fabric.File.Import, {
|
|
83
|
-
name: ["ResponseConfig"],
|
|
84
|
-
root: mcp.file.path,
|
|
85
|
-
path: node_path.default.resolve(config.root, config.output.path, ".kubb/fetch.ts"),
|
|
86
|
-
isTypeOnly: true
|
|
87
|
-
})
|
|
88
|
-
] }),
|
|
89
|
-
/* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsx)(_kubb_react_fabric.File.Import, {
|
|
90
|
-
name: ["buildFormData"],
|
|
91
|
-
root: mcp.file.path,
|
|
92
|
-
path: node_path.default.resolve(config.root, config.output.path, ".kubb/config.ts")
|
|
93
|
-
}),
|
|
94
|
-
/* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsx)(_kubb_react_fabric.File.Import, {
|
|
95
|
-
name: ["CallToolResult"],
|
|
96
|
-
path: "@modelcontextprotocol/sdk/types",
|
|
97
|
-
isTypeOnly: true
|
|
98
|
-
}),
|
|
99
|
-
/* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsx)(_kubb_react_fabric.File.Import, {
|
|
100
|
-
name: [
|
|
101
|
-
type.schemas.request?.name,
|
|
102
|
-
type.schemas.response.name,
|
|
103
|
-
type.schemas.pathParams?.name,
|
|
104
|
-
type.schemas.queryParams?.name,
|
|
105
|
-
type.schemas.headerParams?.name,
|
|
106
|
-
...type.schemas.statusCodes?.map((item) => item.name) || []
|
|
107
|
-
].filter(Boolean),
|
|
108
|
-
root: mcp.file.path,
|
|
109
|
-
path: type.file.path,
|
|
110
|
-
isTypeOnly: true
|
|
111
|
-
}),
|
|
112
|
-
/* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsxs)(_kubb_plugin_client_components.Client, {
|
|
113
|
-
name: mcp.name,
|
|
114
|
-
isConfigurable: false,
|
|
115
|
-
returnType: "Promise<CallToolResult>",
|
|
116
|
-
baseURL: options.client.baseURL,
|
|
117
|
-
operation,
|
|
118
|
-
typeSchemas: type.schemas,
|
|
119
|
-
zodSchemas: void 0,
|
|
120
|
-
dataReturnType: options.client.dataReturnType || "data",
|
|
121
|
-
paramsType: "object",
|
|
122
|
-
paramsCasing: options.client?.paramsCasing || options.paramsCasing,
|
|
123
|
-
pathParamsType: "object",
|
|
124
|
-
parser: "client",
|
|
125
|
-
children: [options.client.dataReturnType === "data" && `return {
|
|
126
|
-
content: [
|
|
127
|
-
{
|
|
128
|
-
type: 'text',
|
|
129
|
-
text: JSON.stringify(res.data)
|
|
130
|
-
}
|
|
131
|
-
],
|
|
132
|
-
structuredContent: { data: res.data }
|
|
133
|
-
}`, options.client.dataReturnType === "full" && `return {
|
|
134
|
-
content: [
|
|
135
|
-
{
|
|
136
|
-
type: 'text',
|
|
137
|
-
text: JSON.stringify(res)
|
|
138
|
-
}
|
|
139
|
-
],
|
|
140
|
-
structuredContent: { data: res.data }
|
|
141
|
-
}`]
|
|
142
|
-
})
|
|
143
|
-
]
|
|
144
|
-
});
|
|
145
|
-
}
|
|
146
|
-
});
|
|
147
|
-
//#endregion
|
|
148
|
-
//#region src/generators/serverGenerator.tsx
|
|
149
|
-
const serverGenerator = (0, _kubb_plugin_oas_generators.createReactGenerator)({
|
|
150
|
-
name: "operations",
|
|
151
|
-
Operations({ operations, generator, plugin }) {
|
|
152
|
-
const driver = (0, _kubb_core_hooks.usePluginDriver)();
|
|
153
|
-
const { options } = plugin;
|
|
154
|
-
const oas = (0, _kubb_plugin_oas_hooks.useOas)();
|
|
155
|
-
const { getFile, getName, getSchemas } = (0, _kubb_plugin_oas_hooks.useOperationManager)(generator);
|
|
156
|
-
const name = "server";
|
|
157
|
-
const file = driver.getFile({
|
|
158
|
-
name,
|
|
159
|
-
extname: ".ts",
|
|
160
|
-
pluginName: plugin.name
|
|
161
|
-
});
|
|
162
|
-
const jsonFile = driver.getFile({
|
|
163
|
-
name: ".mcp",
|
|
164
|
-
extname: ".json",
|
|
165
|
-
pluginName: plugin.name
|
|
166
|
-
});
|
|
167
|
-
const operationsMapped = operations.map((operation) => {
|
|
168
|
-
return {
|
|
169
|
-
tool: {
|
|
170
|
-
name: operation.getOperationId() || operation.getSummary() || `${operation.method.toUpperCase()} ${operation.path}`,
|
|
171
|
-
title: operation.getSummary() || void 0,
|
|
172
|
-
description: operation.getDescription() || `Make a ${operation.method.toUpperCase()} request to ${operation.path}`
|
|
173
|
-
},
|
|
174
|
-
mcp: {
|
|
175
|
-
name: getName(operation, {
|
|
176
|
-
type: "function",
|
|
177
|
-
suffix: "handler"
|
|
178
|
-
}),
|
|
179
|
-
file: getFile(operation)
|
|
180
|
-
},
|
|
181
|
-
zod: {
|
|
182
|
-
name: getName(operation, {
|
|
183
|
-
type: "function",
|
|
184
|
-
pluginName: _kubb_plugin_zod.pluginZodName
|
|
185
|
-
}),
|
|
186
|
-
schemas: getSchemas(operation, {
|
|
187
|
-
pluginName: _kubb_plugin_zod.pluginZodName,
|
|
188
|
-
type: "function"
|
|
189
|
-
}),
|
|
190
|
-
file: getFile(operation, { pluginName: _kubb_plugin_zod.pluginZodName })
|
|
191
|
-
},
|
|
192
|
-
type: { schemas: getSchemas(operation, {
|
|
193
|
-
pluginName: _kubb_plugin_ts.pluginTsName,
|
|
194
|
-
type: "type"
|
|
195
|
-
}) }
|
|
196
|
-
};
|
|
197
|
-
});
|
|
198
|
-
const imports = operationsMapped.flatMap(({ mcp, zod }) => {
|
|
199
|
-
return [/* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsx)(_kubb_react_fabric.File.Import, {
|
|
200
|
-
name: [mcp.name],
|
|
201
|
-
root: file.path,
|
|
202
|
-
path: mcp.file.path
|
|
203
|
-
}, mcp.name), /* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsx)(_kubb_react_fabric.File.Import, {
|
|
204
|
-
name: [
|
|
205
|
-
zod.schemas.request?.name,
|
|
206
|
-
zod.schemas.pathParams?.name,
|
|
207
|
-
zod.schemas.queryParams?.name,
|
|
208
|
-
zod.schemas.headerParams?.name,
|
|
209
|
-
zod.schemas.response?.name
|
|
210
|
-
].filter(Boolean),
|
|
211
|
-
root: file.path,
|
|
212
|
-
path: zod.file.path
|
|
213
|
-
}, zod.name)];
|
|
214
|
-
});
|
|
215
|
-
return /* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsxs)(_kubb_react_fabric_jsx_runtime.Fragment, { children: [/* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsxs)(_kubb_react_fabric.File, {
|
|
216
|
-
baseName: file.baseName,
|
|
217
|
-
path: file.path,
|
|
218
|
-
meta: file.meta,
|
|
219
|
-
banner: (0, _kubb_plugin_oas_utils.getBanner)({
|
|
220
|
-
oas,
|
|
221
|
-
output: options.output,
|
|
222
|
-
config: driver.config
|
|
223
|
-
}),
|
|
224
|
-
footer: (0, _kubb_plugin_oas_utils.getFooter)({
|
|
225
|
-
oas,
|
|
226
|
-
output: options.output
|
|
227
|
-
}),
|
|
228
|
-
children: [
|
|
229
|
-
/* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsx)(_kubb_react_fabric.File.Import, {
|
|
230
|
-
name: ["McpServer"],
|
|
231
|
-
path: "@modelcontextprotocol/sdk/server/mcp"
|
|
232
|
-
}),
|
|
233
|
-
/* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsx)(_kubb_react_fabric.File.Import, {
|
|
234
|
-
name: ["z"],
|
|
235
|
-
path: "zod"
|
|
236
|
-
}),
|
|
237
|
-
/* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsx)(_kubb_react_fabric.File.Import, {
|
|
238
|
-
name: ["StdioServerTransport"],
|
|
239
|
-
path: "@modelcontextprotocol/sdk/server/stdio"
|
|
240
|
-
}),
|
|
241
|
-
imports,
|
|
242
|
-
/* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsx)(require_Server.Server, {
|
|
243
|
-
name,
|
|
244
|
-
serverName: oas.api.info?.title,
|
|
245
|
-
serverVersion: oas.getVersion(),
|
|
246
|
-
paramsCasing: options.paramsCasing,
|
|
247
|
-
operations: operationsMapped
|
|
248
|
-
})
|
|
249
|
-
]
|
|
250
|
-
}), /* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsx)(_kubb_react_fabric.File, {
|
|
251
|
-
baseName: jsonFile.baseName,
|
|
252
|
-
path: jsonFile.path,
|
|
253
|
-
meta: jsonFile.meta,
|
|
254
|
-
children: /* @__PURE__ */ (0, _kubb_react_fabric_jsx_runtime.jsx)(_kubb_react_fabric.File.Source, {
|
|
255
|
-
name,
|
|
256
|
-
children: `
|
|
257
|
-
{
|
|
258
|
-
"mcpServers": {
|
|
259
|
-
"${oas.api.info?.title || "server"}": {
|
|
260
|
-
"type": "stdio",
|
|
261
|
-
"command": "npx",
|
|
262
|
-
"args": ["tsx", "${file.path}"]
|
|
263
|
-
}
|
|
264
|
-
}
|
|
265
|
-
}
|
|
266
|
-
`
|
|
267
|
-
})
|
|
268
|
-
})] });
|
|
269
|
-
}
|
|
270
|
-
});
|
|
271
|
-
//#endregion
|
|
272
|
-
Object.defineProperty(exports, "mcpGenerator", {
|
|
273
|
-
enumerable: true,
|
|
274
|
-
get: function() {
|
|
275
|
-
return mcpGenerator;
|
|
276
|
-
}
|
|
277
|
-
});
|
|
278
|
-
Object.defineProperty(exports, "serverGenerator", {
|
|
279
|
-
enumerable: true,
|
|
280
|
-
get: function() {
|
|
281
|
-
return serverGenerator;
|
|
282
|
-
}
|
|
283
|
-
});
|
|
284
|
-
|
|
285
|
-
//# sourceMappingURL=generators-CWAFnA94.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"generators-CWAFnA94.cjs","names":["pluginTsName","File","path","Client","pluginZodName","pluginTsName","File","Server"],"sources":["../src/generators/mcpGenerator.tsx","../src/generators/serverGenerator.tsx"],"sourcesContent":["import path from 'node:path'\nimport { Client } from '@kubb/plugin-client/components'\nimport { createReactGenerator } from '@kubb/plugin-oas/generators'\nimport { useOas, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getBanner, getFooter } from '@kubb/plugin-oas/utils'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport { File } from '@kubb/react-fabric'\nimport type { PluginMcp } from '../types'\n\nexport const mcpGenerator = createReactGenerator<PluginMcp>({\n name: 'mcp',\n Operation({ config, operation, generator, plugin }) {\n const { options } = plugin\n const oas = useOas()\n\n const { getSchemas, getName, getFile } = useOperationManager(generator)\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, { pluginName: pluginTsName }),\n schemas: getSchemas(operation, { pluginName: 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 {options.client.importPath ? (\n <>\n <File.Import name={'fetch'} path={options.client.importPath} />\n <File.Import name={['Client', 'RequestConfig', 'ResponseErrorConfig']} path={options.client.importPath} isTypeOnly />\n {options.client.dataReturnType === 'full' && <File.Import name={['ResponseConfig']} path={options.client.importPath} isTypeOnly />}\n </>\n ) : (\n <>\n <File.Import name={['fetch']} root={mcp.file.path} path={path.resolve(config.root, config.output.path, '.kubb/fetch.ts')} />\n <File.Import\n name={['Client', 'RequestConfig', 'ResponseErrorConfig']}\n root={mcp.file.path}\n path={path.resolve(config.root, config.output.path, '.kubb/fetch.ts')}\n isTypeOnly\n />\n {options.client.dataReturnType === 'full' && (\n <File.Import name={['ResponseConfig']} root={mcp.file.path} path={path.resolve(config.root, config.output.path, '.kubb/fetch.ts')} isTypeOnly />\n )}\n </>\n )}\n <File.Import name={['buildFormData']} root={mcp.file.path} path={path.resolve(config.root, config.output.path, '.kubb/config.ts')} />\n <File.Import name={['CallToolResult']} path={'@modelcontextprotocol/sdk/types'} 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 || 'data'}\n paramsType={'object'}\n paramsCasing={options.client?.paramsCasing || options.paramsCasing}\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 structuredContent: { data: res.data }\n }`}\n {options.client.dataReturnType === 'full' &&\n `return {\n content: [\n {\n type: 'text',\n text: JSON.stringify(res)\n }\n ],\n structuredContent: { data: res.data }\n }`}\n </Client>\n </File>\n )\n },\n})\n","import { usePluginDriver } from '@kubb/core/hooks'\nimport { createReactGenerator } from '@kubb/plugin-oas/generators'\nimport { useOas, useOperationManager } from '@kubb/plugin-oas/hooks'\nimport { getBanner, getFooter } from '@kubb/plugin-oas/utils'\nimport { pluginTsName } from '@kubb/plugin-ts'\nimport { pluginZodName } from '@kubb/plugin-zod'\nimport { File } from '@kubb/react-fabric'\nimport { Server } from '../components/Server'\nimport type { PluginMcp } from '../types'\n\nexport const serverGenerator = createReactGenerator<PluginMcp>({\n name: 'operations',\n Operations({ operations, generator, plugin }) {\n const driver = usePluginDriver()\n const { options } = plugin\n\n const oas = useOas()\n const { getFile, getName, getSchemas } = useOperationManager(generator)\n\n const name = 'server'\n const file = driver.getFile({ name, extname: '.ts', pluginName: plugin.name })\n\n const jsonFile = driver.getFile({ name: '.mcp', extname: '.json', pluginName: plugin.name })\n\n const operationsMapped = operations.map((operation) => {\n return {\n tool: {\n name: operation.getOperationId() || operation.getSummary() || `${operation.method.toUpperCase()} ${operation.path}`,\n title: operation.getSummary() || undefined,\n description: operation.getDescription() || `Make a ${operation.method.toUpperCase()} request to ${operation.path}`,\n },\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 pluginName: pluginZodName,\n }),\n schemas: getSchemas(operation, { pluginName: pluginZodName, type: 'function' }),\n file: getFile(operation, { pluginName: pluginZodName }),\n },\n type: {\n schemas: getSchemas(operation, { pluginName: 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={[\n zod.schemas.request?.name,\n zod.schemas.pathParams?.name,\n zod.schemas.queryParams?.name,\n zod.schemas.headerParams?.name,\n zod.schemas.response?.name,\n ].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: driver.config })}\n footer={getFooter({ oas, output: options.output })}\n >\n <File.Import name={['McpServer']} path={'@modelcontextprotocol/sdk/server/mcp'} />\n <File.Import name={['z']} path={'zod'} />\n <File.Import name={['StdioServerTransport']} path={'@modelcontextprotocol/sdk/server/stdio'} />\n\n {imports}\n <Server\n name={name}\n serverName={oas.api.info?.title}\n serverVersion={oas.getVersion()}\n paramsCasing={options.paramsCasing}\n operations={operationsMapped}\n />\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"],"mappings":"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"}
|
|
@@ -1,274 +0,0 @@
|
|
|
1
|
-
import "./chunk--u3MIqq1.js";
|
|
2
|
-
import { t as Server } from "./Server-KWLMg0Lm.js";
|
|
3
|
-
import path from "node:path";
|
|
4
|
-
import { pluginTsName } from "@kubb/plugin-ts";
|
|
5
|
-
import { pluginZodName } from "@kubb/plugin-zod";
|
|
6
|
-
import { Client } from "@kubb/plugin-client/components";
|
|
7
|
-
import { createReactGenerator } from "@kubb/plugin-oas/generators";
|
|
8
|
-
import { useOas, useOperationManager } from "@kubb/plugin-oas/hooks";
|
|
9
|
-
import { getBanner, getFooter } from "@kubb/plugin-oas/utils";
|
|
10
|
-
import { File } from "@kubb/react-fabric";
|
|
11
|
-
import { Fragment, jsx, jsxs } from "@kubb/react-fabric/jsx-runtime";
|
|
12
|
-
import { usePluginDriver } from "@kubb/core/hooks";
|
|
13
|
-
//#region src/generators/mcpGenerator.tsx
|
|
14
|
-
const mcpGenerator = createReactGenerator({
|
|
15
|
-
name: "mcp",
|
|
16
|
-
Operation({ config, operation, generator, plugin }) {
|
|
17
|
-
const { options } = plugin;
|
|
18
|
-
const oas = useOas();
|
|
19
|
-
const { getSchemas, getName, getFile } = useOperationManager(generator);
|
|
20
|
-
const mcp = {
|
|
21
|
-
name: getName(operation, {
|
|
22
|
-
type: "function",
|
|
23
|
-
suffix: "handler"
|
|
24
|
-
}),
|
|
25
|
-
file: getFile(operation)
|
|
26
|
-
};
|
|
27
|
-
const type = {
|
|
28
|
-
file: getFile(operation, { pluginName: pluginTsName }),
|
|
29
|
-
schemas: getSchemas(operation, {
|
|
30
|
-
pluginName: pluginTsName,
|
|
31
|
-
type: "type"
|
|
32
|
-
})
|
|
33
|
-
};
|
|
34
|
-
return /* @__PURE__ */ jsxs(File, {
|
|
35
|
-
baseName: mcp.file.baseName,
|
|
36
|
-
path: mcp.file.path,
|
|
37
|
-
meta: mcp.file.meta,
|
|
38
|
-
banner: getBanner({
|
|
39
|
-
oas,
|
|
40
|
-
output: options.output
|
|
41
|
-
}),
|
|
42
|
-
footer: getFooter({
|
|
43
|
-
oas,
|
|
44
|
-
output: options.output
|
|
45
|
-
}),
|
|
46
|
-
children: [
|
|
47
|
-
options.client.importPath ? /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
48
|
-
/* @__PURE__ */ jsx(File.Import, {
|
|
49
|
-
name: "fetch",
|
|
50
|
-
path: options.client.importPath
|
|
51
|
-
}),
|
|
52
|
-
/* @__PURE__ */ jsx(File.Import, {
|
|
53
|
-
name: [
|
|
54
|
-
"Client",
|
|
55
|
-
"RequestConfig",
|
|
56
|
-
"ResponseErrorConfig"
|
|
57
|
-
],
|
|
58
|
-
path: options.client.importPath,
|
|
59
|
-
isTypeOnly: true
|
|
60
|
-
}),
|
|
61
|
-
options.client.dataReturnType === "full" && /* @__PURE__ */ jsx(File.Import, {
|
|
62
|
-
name: ["ResponseConfig"],
|
|
63
|
-
path: options.client.importPath,
|
|
64
|
-
isTypeOnly: true
|
|
65
|
-
})
|
|
66
|
-
] }) : /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
67
|
-
/* @__PURE__ */ jsx(File.Import, {
|
|
68
|
-
name: ["fetch"],
|
|
69
|
-
root: mcp.file.path,
|
|
70
|
-
path: path.resolve(config.root, config.output.path, ".kubb/fetch.ts")
|
|
71
|
-
}),
|
|
72
|
-
/* @__PURE__ */ jsx(File.Import, {
|
|
73
|
-
name: [
|
|
74
|
-
"Client",
|
|
75
|
-
"RequestConfig",
|
|
76
|
-
"ResponseErrorConfig"
|
|
77
|
-
],
|
|
78
|
-
root: mcp.file.path,
|
|
79
|
-
path: path.resolve(config.root, config.output.path, ".kubb/fetch.ts"),
|
|
80
|
-
isTypeOnly: true
|
|
81
|
-
}),
|
|
82
|
-
options.client.dataReturnType === "full" && /* @__PURE__ */ jsx(File.Import, {
|
|
83
|
-
name: ["ResponseConfig"],
|
|
84
|
-
root: mcp.file.path,
|
|
85
|
-
path: path.resolve(config.root, config.output.path, ".kubb/fetch.ts"),
|
|
86
|
-
isTypeOnly: true
|
|
87
|
-
})
|
|
88
|
-
] }),
|
|
89
|
-
/* @__PURE__ */ jsx(File.Import, {
|
|
90
|
-
name: ["buildFormData"],
|
|
91
|
-
root: mcp.file.path,
|
|
92
|
-
path: path.resolve(config.root, config.output.path, ".kubb/config.ts")
|
|
93
|
-
}),
|
|
94
|
-
/* @__PURE__ */ jsx(File.Import, {
|
|
95
|
-
name: ["CallToolResult"],
|
|
96
|
-
path: "@modelcontextprotocol/sdk/types",
|
|
97
|
-
isTypeOnly: true
|
|
98
|
-
}),
|
|
99
|
-
/* @__PURE__ */ jsx(File.Import, {
|
|
100
|
-
name: [
|
|
101
|
-
type.schemas.request?.name,
|
|
102
|
-
type.schemas.response.name,
|
|
103
|
-
type.schemas.pathParams?.name,
|
|
104
|
-
type.schemas.queryParams?.name,
|
|
105
|
-
type.schemas.headerParams?.name,
|
|
106
|
-
...type.schemas.statusCodes?.map((item) => item.name) || []
|
|
107
|
-
].filter(Boolean),
|
|
108
|
-
root: mcp.file.path,
|
|
109
|
-
path: type.file.path,
|
|
110
|
-
isTypeOnly: true
|
|
111
|
-
}),
|
|
112
|
-
/* @__PURE__ */ jsxs(Client, {
|
|
113
|
-
name: mcp.name,
|
|
114
|
-
isConfigurable: false,
|
|
115
|
-
returnType: "Promise<CallToolResult>",
|
|
116
|
-
baseURL: options.client.baseURL,
|
|
117
|
-
operation,
|
|
118
|
-
typeSchemas: type.schemas,
|
|
119
|
-
zodSchemas: void 0,
|
|
120
|
-
dataReturnType: options.client.dataReturnType || "data",
|
|
121
|
-
paramsType: "object",
|
|
122
|
-
paramsCasing: options.client?.paramsCasing || options.paramsCasing,
|
|
123
|
-
pathParamsType: "object",
|
|
124
|
-
parser: "client",
|
|
125
|
-
children: [options.client.dataReturnType === "data" && `return {
|
|
126
|
-
content: [
|
|
127
|
-
{
|
|
128
|
-
type: 'text',
|
|
129
|
-
text: JSON.stringify(res.data)
|
|
130
|
-
}
|
|
131
|
-
],
|
|
132
|
-
structuredContent: { data: res.data }
|
|
133
|
-
}`, options.client.dataReturnType === "full" && `return {
|
|
134
|
-
content: [
|
|
135
|
-
{
|
|
136
|
-
type: 'text',
|
|
137
|
-
text: JSON.stringify(res)
|
|
138
|
-
}
|
|
139
|
-
],
|
|
140
|
-
structuredContent: { data: res.data }
|
|
141
|
-
}`]
|
|
142
|
-
})
|
|
143
|
-
]
|
|
144
|
-
});
|
|
145
|
-
}
|
|
146
|
-
});
|
|
147
|
-
//#endregion
|
|
148
|
-
//#region src/generators/serverGenerator.tsx
|
|
149
|
-
const serverGenerator = createReactGenerator({
|
|
150
|
-
name: "operations",
|
|
151
|
-
Operations({ operations, generator, plugin }) {
|
|
152
|
-
const driver = usePluginDriver();
|
|
153
|
-
const { options } = plugin;
|
|
154
|
-
const oas = useOas();
|
|
155
|
-
const { getFile, getName, getSchemas } = useOperationManager(generator);
|
|
156
|
-
const name = "server";
|
|
157
|
-
const file = driver.getFile({
|
|
158
|
-
name,
|
|
159
|
-
extname: ".ts",
|
|
160
|
-
pluginName: plugin.name
|
|
161
|
-
});
|
|
162
|
-
const jsonFile = driver.getFile({
|
|
163
|
-
name: ".mcp",
|
|
164
|
-
extname: ".json",
|
|
165
|
-
pluginName: plugin.name
|
|
166
|
-
});
|
|
167
|
-
const operationsMapped = operations.map((operation) => {
|
|
168
|
-
return {
|
|
169
|
-
tool: {
|
|
170
|
-
name: operation.getOperationId() || operation.getSummary() || `${operation.method.toUpperCase()} ${operation.path}`,
|
|
171
|
-
title: operation.getSummary() || void 0,
|
|
172
|
-
description: operation.getDescription() || `Make a ${operation.method.toUpperCase()} request to ${operation.path}`
|
|
173
|
-
},
|
|
174
|
-
mcp: {
|
|
175
|
-
name: getName(operation, {
|
|
176
|
-
type: "function",
|
|
177
|
-
suffix: "handler"
|
|
178
|
-
}),
|
|
179
|
-
file: getFile(operation)
|
|
180
|
-
},
|
|
181
|
-
zod: {
|
|
182
|
-
name: getName(operation, {
|
|
183
|
-
type: "function",
|
|
184
|
-
pluginName: pluginZodName
|
|
185
|
-
}),
|
|
186
|
-
schemas: getSchemas(operation, {
|
|
187
|
-
pluginName: pluginZodName,
|
|
188
|
-
type: "function"
|
|
189
|
-
}),
|
|
190
|
-
file: getFile(operation, { pluginName: pluginZodName })
|
|
191
|
-
},
|
|
192
|
-
type: { schemas: getSchemas(operation, {
|
|
193
|
-
pluginName: pluginTsName,
|
|
194
|
-
type: "type"
|
|
195
|
-
}) }
|
|
196
|
-
};
|
|
197
|
-
});
|
|
198
|
-
const imports = operationsMapped.flatMap(({ mcp, zod }) => {
|
|
199
|
-
return [/* @__PURE__ */ jsx(File.Import, {
|
|
200
|
-
name: [mcp.name],
|
|
201
|
-
root: file.path,
|
|
202
|
-
path: mcp.file.path
|
|
203
|
-
}, mcp.name), /* @__PURE__ */ jsx(File.Import, {
|
|
204
|
-
name: [
|
|
205
|
-
zod.schemas.request?.name,
|
|
206
|
-
zod.schemas.pathParams?.name,
|
|
207
|
-
zod.schemas.queryParams?.name,
|
|
208
|
-
zod.schemas.headerParams?.name,
|
|
209
|
-
zod.schemas.response?.name
|
|
210
|
-
].filter(Boolean),
|
|
211
|
-
root: file.path,
|
|
212
|
-
path: zod.file.path
|
|
213
|
-
}, zod.name)];
|
|
214
|
-
});
|
|
215
|
-
return /* @__PURE__ */ jsxs(Fragment, { children: [/* @__PURE__ */ jsxs(File, {
|
|
216
|
-
baseName: file.baseName,
|
|
217
|
-
path: file.path,
|
|
218
|
-
meta: file.meta,
|
|
219
|
-
banner: getBanner({
|
|
220
|
-
oas,
|
|
221
|
-
output: options.output,
|
|
222
|
-
config: driver.config
|
|
223
|
-
}),
|
|
224
|
-
footer: getFooter({
|
|
225
|
-
oas,
|
|
226
|
-
output: options.output
|
|
227
|
-
}),
|
|
228
|
-
children: [
|
|
229
|
-
/* @__PURE__ */ jsx(File.Import, {
|
|
230
|
-
name: ["McpServer"],
|
|
231
|
-
path: "@modelcontextprotocol/sdk/server/mcp"
|
|
232
|
-
}),
|
|
233
|
-
/* @__PURE__ */ jsx(File.Import, {
|
|
234
|
-
name: ["z"],
|
|
235
|
-
path: "zod"
|
|
236
|
-
}),
|
|
237
|
-
/* @__PURE__ */ jsx(File.Import, {
|
|
238
|
-
name: ["StdioServerTransport"],
|
|
239
|
-
path: "@modelcontextprotocol/sdk/server/stdio"
|
|
240
|
-
}),
|
|
241
|
-
imports,
|
|
242
|
-
/* @__PURE__ */ jsx(Server, {
|
|
243
|
-
name,
|
|
244
|
-
serverName: oas.api.info?.title,
|
|
245
|
-
serverVersion: oas.getVersion(),
|
|
246
|
-
paramsCasing: options.paramsCasing,
|
|
247
|
-
operations: operationsMapped
|
|
248
|
-
})
|
|
249
|
-
]
|
|
250
|
-
}), /* @__PURE__ */ jsx(File, {
|
|
251
|
-
baseName: jsonFile.baseName,
|
|
252
|
-
path: jsonFile.path,
|
|
253
|
-
meta: jsonFile.meta,
|
|
254
|
-
children: /* @__PURE__ */ jsx(File.Source, {
|
|
255
|
-
name,
|
|
256
|
-
children: `
|
|
257
|
-
{
|
|
258
|
-
"mcpServers": {
|
|
259
|
-
"${oas.api.info?.title || "server"}": {
|
|
260
|
-
"type": "stdio",
|
|
261
|
-
"command": "npx",
|
|
262
|
-
"args": ["tsx", "${file.path}"]
|
|
263
|
-
}
|
|
264
|
-
}
|
|
265
|
-
}
|
|
266
|
-
`
|
|
267
|
-
})
|
|
268
|
-
})] });
|
|
269
|
-
}
|
|
270
|
-
});
|
|
271
|
-
//#endregion
|
|
272
|
-
export { mcpGenerator as n, serverGenerator as t };
|
|
273
|
-
|
|
274
|
-
//# sourceMappingURL=generators-TtEOkDB1.js.map
|