=== NEW SERVERS ADDED (7) === - servers/closebot — 119 tools, 14 modules, 4,656 lines TS (Stage 7) - servers/google-console — Google Search Console MCP (Stage 7) - servers/meta-ads — Meta/Facebook Ads MCP (Stage 8) - servers/twilio — Twilio communications MCP (Stage 8) - servers/competitor-research — Competitive intel MCP (Stage 6) - servers/n8n-apps — n8n workflow MCP apps (Stage 6) - servers/reonomy — Commercial real estate MCP (Stage 1) === FACTORY INFRASTRUCTURE ADDED === - infra/factory-tools — mcp-jest, mcp-validator, mcp-add, MCP Inspector - 60 test configs, 702 auto-generated test cases - All 30 servers score 100/100 protocol compliance - infra/command-center — Pipeline state, operator playbook, dashboard config - infra/factory-reviews — Automated eval reports === DOCS ADDED === - docs/MCP-FACTORY.md — Factory overview - docs/reports/ — 5 pipeline evaluation reports - docs/research/ — Browser MCP research === RULES ESTABLISHED === - CONTRIBUTING.md — All MCP work MUST go in this repo - README.md — Full inventory of 37 servers + infra docs - .gitignore — Updated for Python venvs TOTAL: 37 MCP servers + full factory pipeline in one repo. This is now the single source of truth for all MCP work.
71 lines
1.7 KiB
TypeScript
71 lines
1.7 KiB
TypeScript
import { Client } from "@modelcontextprotocol/sdk/client/index.js";
|
|
import { McpResponse } from "./types.js";
|
|
|
|
// JSON value type matching the client utils
|
|
type JsonValue =
|
|
| string
|
|
| number
|
|
| boolean
|
|
| null
|
|
| undefined
|
|
| JsonValue[]
|
|
| { [key: string]: JsonValue };
|
|
|
|
// List available prompts
|
|
export async function listPrompts(
|
|
client: Client,
|
|
metadata?: Record<string, string>,
|
|
): Promise<McpResponse> {
|
|
try {
|
|
const params =
|
|
metadata && Object.keys(metadata).length > 0 ? { _meta: metadata } : {};
|
|
const response = await client.listPrompts(params);
|
|
return response;
|
|
} catch (error) {
|
|
throw new Error(
|
|
`Failed to list prompts: ${error instanceof Error ? error.message : String(error)}`,
|
|
);
|
|
}
|
|
}
|
|
|
|
// Get a prompt
|
|
export async function getPrompt(
|
|
client: Client,
|
|
name: string,
|
|
args?: Record<string, JsonValue>,
|
|
metadata?: Record<string, string>,
|
|
): Promise<McpResponse> {
|
|
try {
|
|
// Convert all arguments to strings for prompt arguments
|
|
const stringArgs: Record<string, string> = {};
|
|
if (args) {
|
|
for (const [key, value] of Object.entries(args)) {
|
|
if (typeof value === "string") {
|
|
stringArgs[key] = value;
|
|
} else if (value === null || value === undefined) {
|
|
stringArgs[key] = String(value);
|
|
} else {
|
|
stringArgs[key] = JSON.stringify(value);
|
|
}
|
|
}
|
|
}
|
|
|
|
const params: any = {
|
|
name,
|
|
arguments: stringArgs,
|
|
};
|
|
|
|
if (metadata && Object.keys(metadata).length > 0) {
|
|
params._meta = metadata;
|
|
}
|
|
|
|
const response = await client.getPrompt(params);
|
|
|
|
return response;
|
|
} catch (error) {
|
|
throw new Error(
|
|
`Failed to get prompt: ${error instanceof Error ? error.message : String(error)}`,
|
|
);
|
|
}
|
|
}
|