Guides
Breadcrumbs

Agentic

MCP discover endpoint

POST

{{baseUrl}}/orchestrator/api/agents/mcp/discover/

discovers available MCP tools


Example Request
{
  "url": "https://mcp.context7.com/mcp",
  "headers": {
    "Authorization": "Bearer {{mcpToken}}"
  }
}
Example Response
{
    "tools": [
        {
            "name": "resolve-library-id",
            "title": "Resolve Context7 Library ID",
            "description": "Resolves a package/product name to a Context7-compatible library ID and returns matching libraries.\n\nYou MUST call this function before 'Query Documentation' tool to obtain a valid Context7-compatible library ID UNLESS the user explicitly provides a library ID in the format '/org/project' or '/org/project/version' in their query.\n\nEach result includes:\n- Library ID: Context7-compatible identifier (format: /org/project)\n- Name: Library or package name\n- Description: Short summary\n- Code Snippets: Number of available code examples\n- Source Reputation: Authority indicator (High, Medium, Low, or Unknown)\n- Benchmark Score: Quality indicator (100 is the highest score)\n- Versions: List of versions if available. Use one of those versions if the user provides a version in their query. The format of the version is /org/project/version.\n\nFor best results, select libraries based on name match, source reputation, snippet coverage, benchmark score, and relevance to your use case.\n\nSelection Process:\n1. Analyze the query to understand what library/package the user is looking for\n2. Return the most relevant match based on:\n- Name similarity to the query (exact matches prioritized)\n- Description relevance to the query's intent\n- Documentation coverage (prioritize libraries with higher Code Snippet counts)\n- Source reputation (consider libraries with High or Medium reputation more authoritative)\n- Benchmark Score: Quality indicator (100 is the highest score)\n\nResponse Format:\n- Return the selected library ID in a clearly marked section\n- Provide a brief explanation for why this library was chosen\n- If multiple good matches exist, acknowledge this but proceed with the most relevant one\n- If no good matches exist, clearly state this and suggest query refinements\n\nFor ambiguous queries, request clarification before proceeding with a best-guess match.\n\nIMPORTANT: Do not call this tool more than 3 times per question. If you cannot find what you need after 3 calls, use the best result you have.",
            "inputSchema": {
                "$schema": "http://json-schema.org/draft-07/schema#",
                "type": "object",
                "properties": {
                    "query": {
                        "type": "string",
                        "description": "The question or task you need help with. This is used to rank library results by relevance to what the user is trying to accomplish. The query is sent to the Context7 API for processing. Do not include any sensitive or confidential information such as API keys, passwords, credentials, personal data, or proprietary code in your query."
                    },
                    "libraryName": {
                        "type": "string",
                        "description": "Library name to search for and retrieve a Context7-compatible library ID."
                    }
                },
                "required": [
                    "query",
                    "libraryName"
                ]
            },
            "outputSchema": null,
            "icons": null,
            "annotations": {
                "title": null,
                "readOnlyHint": true,
                "destructiveHint": null,
                "idempotentHint": null,
                "openWorldHint": null
            },
            "meta": null,
            "execution": {
                "taskSupport": "forbidden"
            }
        },
        {
            "name": "query-docs",
            "title": "Query Documentation",
            "description": "Retrieves and queries up-to-date documentation and code examples from Context7 for any programming library or framework.\n\nYou must call 'Resolve Context7 Library ID' tool first to obtain the exact Context7-compatible library ID required to use this tool, UNLESS the user explicitly provides a library ID in the format '/org/project' or '/org/project/version' in their query.\n\nIMPORTANT: Do not call this tool more than 3 times per question. If you cannot find what you need after 3 calls, use the best information you have.",
            "inputSchema": {
                "$schema": "http://json-schema.org/draft-07/schema#",
                "type": "object",
                "properties": {
                    "libraryId": {
                        "type": "string",
                        "description": "Exact Context7-compatible library ID (e.g., '/mongodb/docs', '/vercel/next.js', '/supabase/supabase', '/vercel/next.js/v14.3.0-canary.87') retrieved from 'resolve-library-id' or directly from user query in the format '/org/project' or '/org/project/version'."
                    },
                    "query": {
                        "type": "string",
                        "description": "The question or task you need help with. Be specific and include relevant details. Good: 'How to set up authentication with JWT in Express.js' or 'React useEffect cleanup function examples'. Bad: 'auth' or 'hooks'. The query is sent to the Context7 API for processing. Do not include any sensitive or confidential information such as API keys, passwords, credentials, personal data, or proprietary code in your query."
                    }
                },
                "required": [
                    "libraryId",
                    "query"
                ]
            },
            "outputSchema": null,
            "icons": null,
            "annotations": {
                "title": null,
                "readOnlyHint": true,
                "destructiveHint": null,
                "idempotentHint": null,
                "openWorldHint": null
            },
            "meta": null,
            "execution": {
                "taskSupport": "forbidden"
            }
        }
    ]
}