# openfda-mcp-server MCP server

Query FDA data on drugs, food, devices, and recalls via openFDA. STDIO or Streamable HTTP.

## Links
- Registry page: https://www.getdrio.com/mcp/io-github-cyanheads-openfda-mcp-server
- Repository: https://github.com/cyanheads/openfda-mcp-server

## Install
- Command: `npx -y @cyanheads/openfda-mcp-server`
- Endpoint: https://openfda.caseyjhand.com/mcp
- Auth: Auth required by registry metadata

## Setup notes
- Package: Npm @cyanheads/openfda-mcp-server v0.1.20
- Environment variable: OPENFDA_API_KEY
- Environment variable: MCP_LOG_LEVEL (default info)
- Package: Npm @cyanheads/openfda-mcp-server v0.1.20
- Environment variable: OPENFDA_API_KEY
- Environment variable: MCP_TRANSPORT_TYPE (required; default http)
- Environment variable: MCP_HTTP_HOST (default 127.0.0.1)
- Environment variable: MCP_HTTP_PORT (default 3010)
- Environment variable: MCP_HTTP_ENDPOINT_PATH (default /mcp)
- Environment variable: MCP_AUTH_MODE (default none)
- Environment variable: MCP_LOG_LEVEL (default info)
- The upstream registry signals required auth or secrets.
- Remote endpoint: https://openfda.caseyjhand.com/mcp

## Tools
- openfda_search_adverse_events (Openfda Search Adverse Events) - Search adverse event reports across drugs, food, and devices. Use to investigate safety signals, find reports for a specific product, or explore reactions by demographics. Endpoint: https://openfda.caseyjhand.com/mcp
- openfda_search_animal_events (Openfda Search Animal Events) - Search adverse event reports for veterinary drugs and devices submitted to the FDA Center for Veterinary Medicine. Records include animal species, breed, age, weight, drug name and route, adverse reactions (using VeDDRA terminology), and outcome. Use to investigate safety signals for veterinary products, find reports by animal species or drug, or explore reaction patterns. Endpoint: https://openfda.caseyjhand.com/mcp
- openfda_search_drug_shortages (Openfda Search Drug Shortages) - Search FDA drug shortage records. Returns per-product shortage status, availability, therapeutic category, dosage form, manufacturer, and dates. Use to check whether a drug is currently in shortage, find all oncology drugs with supply issues, or retrieve the openfda block (brand_name, product_ndc, rxcui) to chain into openfda_get_drug_label or openfda_lookup_ndc. Endpoint: https://openfda.caseyjhand.com/mcp
- openfda_search_recalls (Openfda Search Recalls) - Search enforcement reports and recall actions across drugs, food, and devices. Endpoint: https://openfda.caseyjhand.com/mcp
- openfda_search_tobacco_reports (Openfda Search Tobacco Reports) - Search problem reports submitted to the FDA for tobacco products, including e-cigarettes, vaping products, cigarettes, and smokeless tobacco. Reports capture product type, reported health problems (e.g. seizure, chest pain), product problems (e.g. exploding battery), whether a non-user was affected, and submission date. Use to investigate safety signals, find reports by product type, or analyze health effects. Endpoint: https://openfda.caseyjhand.com/mcp
- openfda_count_values (Openfda Count Values) - Aggregate and tally unique values for any field across any openFDA endpoint. Returns ranked term-count pairs sorted by count descending. Pair with openfda_search_adverse_events, openfda_search_drug_approvals, openfda_search_device_clearances, openfda_search_recalls, openfda_get_drug_label, or openfda_lookup_ndc when sample records help interpret the aggregates. Endpoint: https://openfda.caseyjhand.com/mcp
- openfda_describe_fields (Openfda Describe Fields) - Return the searchable field paths for an openFDA endpoint, grouped by category with type and description. Use before constructing a search query to find the correct dotted field path — field names differ per endpoint and are not discoverable from the tool schema alone. Endpoint: https://openfda.caseyjhand.com/mcp
- openfda_get_drug_label (Openfda Get Drug Label) - Look up FDA drug labeling (package inserts / SPL documents). Check indications, warnings, dosage, contraindications, active ingredients, or any structured label section. Endpoint: https://openfda.caseyjhand.com/mcp
- openfda_search_drug_approvals (Openfda Search Drug Approvals) - Search the Drugs@FDA database for drug application approvals (NDAs and ANDAs). Returns application details, sponsor info, and full submission history. Pair with openfda_get_drug_label to read the approved label, or openfda_count_values to aggregate by sponsor_name, product_type, or route. Endpoint: https://openfda.caseyjhand.com/mcp
- openfda_search_device_clearances (Openfda Search Device Clearances) - Search FDA device premarket notifications — 510(k) clearances and PMA approvals. Endpoint: https://openfda.caseyjhand.com/mcp
- openfda_lookup_ndc (Openfda Lookup Ndc) - Look up drugs in the NDC (National Drug Code) Directory. Identify drug products by NDC code, find active ingredients, packaging details, or manufacturer info. Pair with openfda_get_drug_label using the returned brand_name or set_id to read the package insert. Endpoint: https://openfda.caseyjhand.com/mcp
- openfda_drug_profile (Openfda Drug Profile) - Resolve one drug name to its FDA identity, then fan out in parallel across the bounded per-drug openFDA endpoints and merge into one profile: identity, label highlights, adverse-event summary, recall history, Drugs@FDA approval, and shortage status. Replaces chaining openfda_get_drug_label, openfda_search_adverse_events, openfda_search_recalls, openfda_search_drug_approvals, and openfda_search_drug_shortages — and reconciles the identifier drift between endpoints that makes that chaining error-prone. Each section is best-effort: a miss returns null rather than failing the call. For deep dives into any one area, use the dedicated tool. Endpoint: https://openfda.caseyjhand.com/mcp
- openfda_dataframe_describe (Openfda Dataframe Describe) - List the tables and column schemas on a DataCanvas staged by an openFDA search tool. Call before openfda_dataframe_query to discover the exact table name, column names, and DuckDB types needed for valid SQL. row_count is the full staged result set, not the inline preview count. Columns typed JSON hold nested openFDA objects/arrays — query them with DuckDB json functions. Endpoint: https://openfda.caseyjhand.com/mcp
- openfda_dataframe_query (Openfda Dataframe Query) - Run a read-only SQL SELECT against a DataCanvas table staged by an openFDA search tool (canvas_id + canvas_table in its response when spilled=true). Enables GROUP BY, COUNT/SUM/AVG, time-series, and joins across the full result set without re-paging the API. Call openfda_dataframe_describe first to get the exact table and column names. Scalar fields are stored as text (CAST for numeric math); nested objects/arrays are JSON columns — read them with DuckDB json functions, e.g. json_extract_string(openfda, '$.brand_name[0]'). Only SELECT is allowed — DDL, DML, COPY, and file-reading functions are blocked. Endpoint: https://openfda.caseyjhand.com/mcp

## Resources
Not captured

## Prompts
Not captured

## Metadata
- Owner: io.github.cyanheads
- Version: 0.1.20
- Runtime: Npm
- Transports: STDIO, HTTP
- License: Not captured
- Language: Not captured
- Stars: Not captured
- Updated: Jun 5, 2026
- Source: https://registry.modelcontextprotocol.io
