UNPKG

unstructured-client

Version:

<h3 align="center"> <img src="https://raw.githubusercontent.com/Unstructured-IO/unstructured/main/img/unstructured_logo.png" height="200" > </h3>

98 lines 3.35 kB
/* * Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT. */ import { SSEServerTransport } from "@modelcontextprotocol/sdk/server/sse.js"; import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js"; import express from "express"; import { createConsoleLogger, } from "../../console-logger.js"; import { createMCPServer } from "../../server.js"; export async function main(flags) { flags.env?.forEach(([key, value]) => { process.env[key] = value; }); switch (flags.transport) { case "stdio": await startStdio(flags); break; case "sse": await startSSE(flags); break; default: throw new Error(`Invalid transport: ${flags.transport}`); } } async function startStdio(flags) { const logger = createConsoleLogger(flags["log-level"]); const transport = new StdioServerTransport(); const server = createMCPServer({ logger, allowedTools: flags.tool, scopes: flags.scope, security: { apiKeyAuth: flags["api-key-auth"] ?? "" }, serverURL: flags["server-url"], server: flags.server, }); await server.connect(transport); const abort = async () => { await server.close(); process.exit(0); }; process.on("SIGTERM", abort); process.on("SIGINT", abort); } async function startSSE(flags) { const logger = createConsoleLogger(flags["log-level"]); const app = express(); const mcpServer = createMCPServer({ logger, allowedTools: flags.tool, scopes: flags.scope, security: { apiKeyAuth: flags["api-key-auth"] ?? "" }, serverURL: flags["server-url"], server: flags.server, }); let transport; const controller = new AbortController(); app.get("/sse", async (_req, res) => { transport = new SSEServerTransport("/message", res); await mcpServer.connect(transport); mcpServer.server.onclose = async () => { res.end(); }; }); app.post("/message", async (req, res) => { if (!transport) { throw new Error("Server transport not initialized"); } await transport.handlePostMessage(req, res); }); const httpServer = app.listen(flags.port, "0.0.0.0", () => { const ha = httpServer.address(); const host = typeof ha === "string" ? ha : `${ha?.address}:${ha?.port}`; logger.info("MCP HTTP server started", { host }); }); let closing = false; controller.signal.addEventListener("abort", async () => { if (closing) { logger.info("Received second signal. Forcing shutdown."); process.exit(1); } closing = true; logger.info("Shutting down MCP server"); await mcpServer.close(); logger.info("Shutting down HTTP server"); const timer = setTimeout(() => { logger.info("Forcing shutdown"); process.exit(1); }, 5000); httpServer.close(() => { clearTimeout(timer); logger.info("Graceful shutdown complete"); process.exit(0); }); }); const abort = () => controller.abort(); process.on("SIGTERM", abort); process.on("SIGINT", abort); } //# sourceMappingURL=impl.js.map