D&D Knowledge Navigator

D&D Knowledge Navigator

使用资源、工具和提示实现的 DnD 5e API 的 MCP 服务器实现。

procload

研究与数据
访问服务器

README

D&D 知识导航器

一个基于 Python 的服务器,实现了模型上下文协议 (MCP),用于将 Claude 和其他 AI 助手连接到《龙与地下城》5e 游戏信息。

什么是 MCP?

模型上下文协议 (MCP) 是 Anthropic 开发的一个框架,它使像 Claude 这样的 AI 助手能够与外部工具和服务进行通信。该服务器利用 Anthropic 的 Python 实现 FastMCP 协议,在 AI 助手和 D&D 5e API 之间创建一个结构化的桥梁。

有关 MCP 的详细说明以及本项目如何实现它,请查看我们的博客文章

功能

  • FastMCP 集成:为 AI 助手提供工具和资源来查询 D&D 游戏数据
  • D&D 5e API 集成:完全访问法术、怪物、装备、职业、种族等
  • 高效缓存:API 响应的持久本地存储,以提高性能
  • 结构化数据访问:定义良好的资源和工具,用于一致的 AI 交互
  • 来源归属:全面跟踪和显示信息来源
  • 可视化格式:Markdown 模板,用于精美地呈现 D&D 内容
  • 查询增强:通过同义词处理和模糊匹配智能处理 D&D 查询

设置

前提条件

  • Python 3.10 或更高版本
  • uv 包管理器(推荐)
  • Claude Desktop 客户端(用于与 Claude 一起使用)

安装

  1. 克隆此存储库:

    git clone https://github.com/yourusername/dnd-knowledge-navigator.git
    cd dnd-knowledge-navigator
    
  2. 安装依赖项:

    uv pip install -r requirements.txt
    

    或者

    pip install .
    
  3. 配置 Claude Desktop(如果与 Claude 一起使用):

    • 在 Claude Desktop 配置目录中创建一个 claude_desktop_config.json 文件
    • 添加以下配置(根据需要调整路径):
      {
        "mcpServers": {
          "dnd": {
            "command": "/path/to/uv",
            "args": [
              "--directory",
              "/path/to/dnd-knowledge-navigator",
              "run",
              "dnd_mcp_server.py"
            ]
          }
        }
      }
      
  4. 运行服务器:

    uv run python dnd_mcp_server.py
    

MCP 工具用法

连接到 AI 助手后,可以使用以下工具:

  • search_all_categories:在所有 D&D 资源中搜索特定术语
  • verify_with_api:根据官方 API 数据验证 D&D 语句
  • check_api_health:检查 D&D 5e API 的健康状况和状态

来源归属系统

该服务器包含一个全面的来源归属系统,该系统:

  • 跟踪返回给用户的所有信息的来源
  • 提供每条信息的置信度
  • 包括 API 端点和相关性分数
  • 格式化归属信息以进行清晰呈现

模板系统

该服务器包含一个模板系统,用于格式化 D&D 内容:

  • 怪物属性块,具有组织的属性和能力
  • 法术描述,具有格式化的组件和效果
  • 装备详情,具有组织的属性
  • 可配置的格式选项(表格、表情符号、紧凑模式)

要禁用模板,请在 src/templates/config.py 中设置 TEMPLATES_ENABLED = False

查询增强系统

该服务器包含一个查询增强系统,可以改善搜索结果:

  • D&D 术语的同义词处理(例如,“AC”→“护甲等级”)
  • 游戏特定符号的特殊术语识别(例如,“2d6+3”、“STR save”)
  • 常见拼写错误的模糊匹配(例如,“firball”→“fireball”)
  • 类别优先级排序,以将搜索重点放在相关内容上

要禁用查询增强,请在 enhance_query 函数中将参数设置为 False

文档

全面的文档可在 docs/ 目录中找到:

缓存资源

服务器在 cache/ 目录中维护一个本地缓存,以最大限度地减少 API 调用并缩短响应时间。此目录通过 .gitignore 从 git 中排除。

配置

编辑 prompts.py 以修改或添加新的提示模板,或编辑 resources.py 以调整资源端点。

贡献

欢迎贡献!请随时提交 Pull Request。

  1. Fork 存储库
  2. 创建您的功能分支 (git checkout -b feature/amazing-feature)
  3. 提交您的更改 (git commit -m 'Add some amazing feature')
  4. 推送到分支 (git push origin feature/amazing-feature)
  5. 打开一个 Pull Request

许可证

本项目根据 MIT 许可证获得许可 - 有关详细信息,请参阅 LICENSE 文件。

致谢

包结构

D&D 知识导航器组织为一个 Python 包,其结构如下:

dnd-knowledge-navigator/
├── dnd_mcp_server.py      # 主服务器入口点
├── run_tests.py           # 运行所有测试的脚本
├── setup.py               # 包安装配置
├── src/                   # 源代码目录
│   ├── __init__.py        # 包初始化
│   ├── attribution/       # 来源归属系统
│   ├── core/              # 核心功能
│   ├── query_enhancement/ # 查询增强系统
│   └── templates/         # 响应格式模板
├── tests/                 # 测试目录
│   ├── __init__.py        # 测试包初始化
│   └── test_*.py          # 测试文件
└── docs/                  # 文档

有关包结构的更详细说明,请参阅包结构文档

安装

要安装该软件包以进行开发:

# 克隆存储库
git clone https://github.com/yourusername/dnd-knowledge-navigator.git
cd dnd-knowledge-navigator

# 创建并激活虚拟环境
python -m venv .venv
source .venv/bin/activate  # 在 Windows 上:.venv\Scripts\activate

# 以开发模式安装软件包
pip install -e .

运行服务器

要启动 D&D 知识导航器服务器:

python dnd_mcp_server.py

运行测试

要运行所有测试:

./run_tests.py

推荐服务器

Crypto Price & Market Analysis MCP Server

Crypto Price & Market Analysis MCP Server

一个模型上下文协议 (MCP) 服务器,它使用 CoinCap API 提供全面的加密货币分析。该服务器通过一个易于使用的界面提供实时价格数据、市场分析和历史趋势。 (Alternative, slightly more formal and technical translation): 一个模型上下文协议 (MCP) 服务器,利用 CoinCap API 提供全面的加密货币分析服务。该服务器通过用户友好的界面,提供实时价格数据、市场分析以及历史趋势数据。

精选
TypeScript
MCP PubMed Search

MCP PubMed Search

用于搜索 PubMed 的服务器(PubMed 是一个免费的在线数据库,用户可以在其中搜索生物医学和生命科学文献)。 我是在 MCP 发布当天创建的,但当时正在度假。 我看到有人在您的数据库中发布了类似的服务器,但还是决定发布我的服务器。

精选
Python
mixpanel

mixpanel

连接到您的 Mixpanel 数据。 从 Mixpanel 分析查询事件、留存和漏斗数据。

精选
TypeScript
Sequential Thinking MCP Server

Sequential Thinking MCP Server

这个服务器通过将复杂问题分解为顺序步骤来促进结构化的问题解决,支持修订,并通过完整的 MCP 集成来实现多条解决方案路径。

精选
Python
Nefino MCP Server

Nefino MCP Server

为大型语言模型提供访问德国可再生能源项目新闻和信息的能力,允许按地点、主题(太阳能、风能、氢能)和日期范围进行筛选。

官方
Python
Vectorize

Vectorize

将 MCP 服务器向量化以实现高级检索、私有深度研究、Anything-to-Markdown 文件提取和文本分块。

官方
JavaScript
Mathematica Documentation MCP server

Mathematica Documentation MCP server

一个服务器,通过 FastMCP 提供对 Mathematica 文档的访问,使用户能够从 Wolfram Mathematica 检索函数文档和列出软件包符号。

本地
Python
kb-mcp-server

kb-mcp-server

一个 MCP 服务器,旨在实现便携性、本地化、简易性和便利性,以支持对 txtai “all in one” 嵌入数据库进行基于语义/图的检索。任何 tar.gz 格式的 txtai 嵌入数据库都可以被加载。

本地
Python
Research MCP Server

Research MCP Server

这个服务器用作 MCP 服务器,与 Notion 交互以检索和创建调查数据,并与 Claude Desktop Client 集成以进行和审查调查。

本地
Python
Cryo MCP Server

Cryo MCP Server

一个API服务器,实现了模型补全协议(MCP),用于Cryo区块链数据提取,允许用户通过任何兼容MCP的客户端查询以太坊区块链数据。

本地
Python