Skip to main content
Glama

MCP Database Server

by JuanYin1
MIT License
3,221
1
  • Apple
  • Linux
resourceHandlers.ts2.27 kB
import { dbAll, getListTablesQuery, getDescribeTableQuery, getDatabaseMetadata } from '../db/index.js'; /** * Handle listing resources request * @returns List of available resources */ export async function handleListResources() { try { const dbInfo = getDatabaseMetadata(); const dbType = dbInfo.type; let resourceBaseUrl: URL; // Create appropriate URL based on database type if (dbType === 'sqlite' && dbInfo.path) { resourceBaseUrl = new URL(`sqlite:///${dbInfo.path}`); } else if (dbType === 'sqlserver' && dbInfo.server && dbInfo.database) { resourceBaseUrl = new URL(`sqlserver://${dbInfo.server}/${dbInfo.database}`); } else { resourceBaseUrl = new URL(`db:///database`); } const SCHEMA_PATH = "schema"; // Use adapter-specific query to list tables const query = getListTablesQuery(); const result = await dbAll(query); return { resources: result.map((row: any) => ({ uri: new URL(`${row.name}/${SCHEMA_PATH}`, resourceBaseUrl).href, mimeType: "application/json", name: `"${row.name}" database schema`, })), }; } catch (error: any) { throw new Error(`Error listing resources: ${error.message}`); } } /** * Handle reading a specific resource * @param uri URI of the resource to read * @returns Resource contents */ export async function handleReadResource(uri: string) { try { const resourceUrl = new URL(uri); const SCHEMA_PATH = "schema"; const pathComponents = resourceUrl.pathname.split("/"); const schema = pathComponents.pop(); const tableName = pathComponents.pop(); if (schema !== SCHEMA_PATH) { throw new Error("Invalid resource URI"); } // Use adapter-specific query to describe the table const query = getDescribeTableQuery(tableName!); const result = await dbAll(query); return { contents: [ { uri, mimeType: "application/json", text: JSON.stringify(result.map((column: any) => ({ column_name: column.name, data_type: column.type })), null, 2), }, ], }; } catch (error: any) { throw new Error(`Error reading resource: ${error.message}`); } }

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/JuanYin1/mcp-database-server-with-database'

If you have feedback or need assistance with the MCP directory API, please join our Discord server