Skip to main content

MCP server exposing Dify knowledge base retrieval to Cursor and other MCP clients

Project description

dify-mcp

Expose Dify knowledge base retrieval capabilities via MCP (Model Context Protocol), for use in Cursor and other MCP-compatible clients.

Connect to a self-hosted or remote Dify instance over HTTP, with optional dataset allowlisting for access control.

Features

  • Knowledge base discovery — list and inspect allowed datasets
  • Semantic retrieval — search chunks via Dify POST /datasets/{dataset_id}/retrieve
  • Document browsing — list documents and segments within a dataset
  • Dataset allowlist — restrict access to specific dataset_id values
  • stdio transport — no manual server startup; the MCP client launches the process

Requirements

  • Python 3.11+
  • A running Dify instance with Knowledge Base API enabled
  • Network access from the machine running the MCP server to your Dify API endpoint
  • A Dify Knowledge Base API Key (Dify → Knowledge → Service API → API Key)

Quick Start

1. Clone and install

git clone https://github.com/salted-butter-joshua/dify-mcp.git
cd dify-mcp

python3.11 -m venv .venv

# Windows
.venv\Scripts\python.exe -m pip install -e .

# macOS / Linux
.venv/bin/python -m pip install -e .

Verify import:

# Windows
.venv\Scripts\python.exe -c "import dify_mcp; print('OK')"

# macOS / Linux
.venv/bin/python -c "import dify_mcp; print('OK')"

2. Configure environment

Copy the example env file and edit it:

cp .env.example .env
DIFY_API_BASE=http://your-dify-host/v1
DIFY_API_KEY=dataset-your-api-key
DIFY_ALLOWED_DATASETS=dataset-uuid-1,dataset-uuid-2
DIFY_TIMEOUT=30
DIFY_VERIFY_SSL=false
Variable Description
DIFY_API_BASE Dify Knowledge API base URL, e.g. http://192.168.1.100/v1
DIFY_API_KEY Knowledge Base API key
DIFY_ALLOWED_DATASETS Comma-separated dataset UUIDs to expose (required)
DIFY_TIMEOUT HTTP timeout in seconds (default: 30)
DIFY_VERIFY_SSL Verify TLS certificates (default: false for self-signed certs)

Run the health check:

# Windows
.venv\Scripts\python.exe scripts/health_check.py

# macOS / Linux
.venv/bin/python scripts/health_check.py

3. Add to Cursor

You do not need to start the MCP server manually. Cursor launches it automatically via stdio.

  1. Open Cursor Settings → MCPEdit config
  2. Add the following to mcpServers in your MCP config file:
    • Windows: %USERPROFILE%\.cursor\mcp.json
    • macOS / Linux: ~/.cursor/mcp.json
  3. Replace paths and env values with your own
  4. Restart Cursor

See mcp.json.example for a full example.

Windows example:

{
  "mcpServers": {
    "dify-knowledge": {
      "command": "/absolute/path/to/dify-mcp/.venv/Scripts/python.exe",
      "args": ["-m", "dify_mcp.server"],
      "cwd": "/absolute/path/to/dify-mcp",
      "env": {
        "DIFY_API_BASE": "http://your-dify-host/v1",
        "DIFY_API_KEY": "dataset-your-api-key",
        "DIFY_ALLOWED_DATASETS": "dataset-uuid-1,dataset-uuid-2",
        "DIFY_TIMEOUT": "30",
        "DIFY_VERIFY_SSL": "false"
      }
    }
  }
}

macOS / Linux example:

{
  "mcpServers": {
    "dify-knowledge": {
      "command": "/absolute/path/to/dify-mcp/.venv/bin/python",
      "args": ["-m", "dify_mcp.server"],
      "cwd": "/absolute/path/to/dify-mcp",
      "env": {
        "DIFY_API_BASE": "http://your-dify-host/v1",
        "DIFY_API_KEY": "dataset-your-api-key",
        "DIFY_ALLOWED_DATASETS": "dataset-uuid-1,dataset-uuid-2"
      }
    }
  }
}

4. Verify in Cursor

  1. Cursor Settings → MCP → confirm dify-knowledge shows as enabled
  2. In chat, try:
    • List available Dify knowledge bases
    • Search the knowledge base for "your query"

MCP Tools

Tool Description
list_datasets List knowledge bases within the allowlist
get_dataset Get metadata for one dataset
search_knowledge Retrieve relevant chunks (primary retrieval tool)
list_documents List documents in a dataset
list_document_segments List text segments for a document

Architecture

Cursor (MCP client)
    │ stdio
    ▼
dify-mcp (local process)
    │ HTTPS / HTTP
    ▼
Dify Knowledge API (/v1/datasets/...)

The MCP server runs locally on your machine and calls the Dify API over the network. Dify does not need to reach your machine.

Troubleshooting

Issue Cause Fix
No matching distribution found for mcp Python < 3.11 Use Python 3.11+ in .venv
MCP shows error (red) Wrong Python path, invalid key, or network issue Check mcp.json paths and env vars
401 Unauthorized Invalid API key Regenerate key in Dify Service API panel
Dataset not in allowed list UUID not in DIFY_ALLOWED_DATASETS Add the dataset UUID to the allowlist
Health check missing env vars .env not found Ensure .env exists in the project root
Connection timeout Dify unreachable Check network / VPN / firewall

Project Structure

dify-mcp/
├── src/dify_mcp/
│   ├── server.py        # MCP entry point
│   ├── config.py        # Settings and allowlist
│   ├── dify_client.py   # Dify Knowledge API client
│   └── formatters.py    # Response formatting
├── scripts/
│   └── health_check.py  # Connectivity test
├── mcp.json.example     # Cursor MCP config template
├── .env.example         # Environment variable template
└── Dify-API.md          # Local API path reference

API Reference

Security Notes

  • Never commit .env or API keys to version control
  • A single Knowledge Base API key can access all visible datasets under the account — use DIFY_ALLOWED_DATASETS to limit exposure
  • Prefer running MCP locally; keep API keys in mcp.json env or .env on your machine only

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

dify_mcp-0.1.0.tar.gz (16.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

dify_mcp-0.1.0-py3-none-any.whl (9.8 kB view details)

Uploaded Python 3

File details

Details for the file dify_mcp-0.1.0.tar.gz.

File metadata

  • Download URL: dify_mcp-0.1.0.tar.gz
  • Upload date:
  • Size: 16.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for dify_mcp-0.1.0.tar.gz
Algorithm Hash digest
SHA256 783d1cd814c9f5fb79724e813d043bf351945490d31bb6016b3c62e947ba8cb5
MD5 1a77e1e4530b22c978363e0aa14642e7
BLAKE2b-256 b21abb94f7680c6183eec392b86f0e6ef47f11dfb4de0afe1a5227472931e055

See more details on using hashes here.

Provenance

The following attestation bundles were made for dify_mcp-0.1.0.tar.gz:

Publisher: publish.yml on salted-butter-joshua/dify-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file dify_mcp-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: dify_mcp-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 9.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for dify_mcp-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 4f22b4368bd267f46a981ae2cacc6f8e5af416440bd593d18734459cb7e654a0
MD5 bebcce870c6209b6ce20c566b89b08cf
BLAKE2b-256 17d3d16e0f4bb1b7b9af72a60628d565fc0ec0c476cbebb53a2fdb471487c517

See more details on using hashes here.

Provenance

The following attestation bundles were made for dify_mcp-0.1.0-py3-none-any.whl:

Publisher: publish.yml on salted-butter-joshua/dify-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page