LND MCP Server

LND MCP Server

一个使用自然语言查询闪电网络 (LND) 节点数据的模型上下文协议 (MCP)。 (Alternatively, a more literal translation could be used, but the above is more natural in Chinese.) Literal translation: 用于使用自然语言查询闪电网络 (LND) 节点数据的模型上下文协议 (MCP)。

pblittle

研究与数据
访问服务器

README

Lightning Network MCP 服务器

Lightning Network MCP 服务器允许大型语言模型 (LLM) 代理(例如在 Goose 中运行的代理)使用自然语言查询闪电网络节点数据。 它实现了 模型上下文协议 (MCP) 规范版本 2025-03-26,并且完全兼容 MCP Inspector 1.7.0。

该服务器使用 gRPC 或闪电网络节点连接 (LNC) 连接到您的节点,并返回可读的摘要和机器可读的 JSON 输出。 它被设计为模块化、可测试和可扩展的,以支持其他节点类型,例如 Core Lightning 和 Eclair。

有关架构详细信息,请参阅 ARCHITECTURE.md

功能

该系统解释自然语言提示,确定用户意图,评估领域逻辑,并查询您的闪电网络节点。 响应以纯语言和结构化的 JSON 形式返回。 它目前支持基本的通道查询,并且正在积极发展以覆盖更广泛的节点状态、发票和路由数据。

示例查询

用自然语言提问:

Show me my channels

获取人类可读的响应:

Your node has 5 channels with a total capacity of 0.05000000 BTC (5,000,000 sats).
4 channels are active and 1 is inactive.

Your channels:
1. ACINQ: 0.02000000 BTC (2,000,000 sats) (active)
2. Bitrefill: 0.01000000 BTC (1,000,000 sats) (active)
3. LightningTipBot: 0.00800000 BTC (800,000 sats) (active)
4. Wallet of Satoshi: 0.00700000 BTC (700,000 sats) (active)
5. LN+: 0.00500000 BTC (500,000 sats) (inactive)

以及用于应用程序的结构化 JSON 数据:

{
  "channels": [
    {
      "remote_alias": "ACINQ",
      "capacity": 2000000,
      "local_balance": 800000,
      "active": true
    },
    ...
  ],
  "summary": {
    "total_capacity": 5000000,
    "active_channels": 4,
    "inactive_channels": 1,
    "largest_channel_alias": "ACINQ",
    "average_local_balance": 750000
  }
}

JSON 输出提供了相同数据的结构化版本,并针对 LLM 代理、UI 层或下游应用程序的使用进行了优化。

支持的功能

目前,该系统支持基本的通道查询:

  • “Show me my channels”

更强大的查询正在以下领域开发中:

  • 通道 “What is the health of my channels?” “Do I have any inactive channels?”

  • 发票 “How many invoices have I received this week?” “What was my last payment?”

  • 节点 “What node am I connected to the most?” “What node did I last forward a payment to?”

  • 路由 “How much have I routed in the last 24 hours?” “Which channels are doing most of the routing?”

快速开始

这提供了使用真实节点的零配置开发体验。

使用真实节点运行(通过 gRPC 或 LNC 的 LND)

cp .env.example .env
# 使用您的 LND 凭据配置 .env
npm run mcp:prod

通过 Tor 连接到 LND 节点

要连接到作为 Tor 隐藏服务运行的 LND 节点:

  1. 确保 Tor 已安装并在您的系统上运行:

    # macOS (使用 Homebrew)
    brew install tor
    brew services start tor
    
    # Ubuntu/Debian
    sudo apt install tor
    sudo systemctl start tor
    
  2. 使用 Tor SOCKS 代理设置配置您的 .env 文件:

    CONNECTION_TYPE=lnd-direct
    LND_HOST=your-node-address.onion
    LND_PORT=10009
    LND_TLS_CERT_PATH=/path/to/tls.pem  # 使用 PEM 格式以获得更好的兼容性
    LND_MACAROON_PATH=/path/to/admin.macaroon
    SOCKS_PROXY_HOST=localhost
    SOCKS_PROXY_PORT=9050
    
  3. 确保您的 TLS 证书为 PEM 格式(以 -----BEGIN CERTIFICATE----- 开头)。 如果您有原始证书,可以使用 extract-credentials.js 脚本将其转换为 PEM 格式。

使用凭据提取工具

如果您有 lndconnect URL(通常在移动应用程序中使用),您可以使用以下命令提取凭据:

# 从 lndconnect URL 提取凭据
node scripts/extract-credentials.js "lndconnect://your-node.onion:10009?cert=BASE64CERT&macaroon=BASE64MACAROON"

# 或者在您的 .env 文件中设置 LNDCONNECT_URL 并运行
node scripts/extract-credentials.js

此脚本将:

  • 提取主机、端口、证书和 macaroon
  • 将证书转换为 PEM 格式(连接所需的格式)
  • 将文件保存到 test/fixtures 目录
  • 打印要添加到您的 .env 文件的配置

使用 MCP Inspector 测试

要使用官方 MCP inspector 测试服务器:

npm install -g @modelcontextprotocol/inspector
npm run build
LOG_LEVEL=warn npx @modelcontextprotocol/inspector node scripts/inspect.js

兼容性

  • MCP 规范版本 2025-03-26
  • MCP Inspector 版本 1.7.0
  • MCP 代理兼容性(例如,Goose)
  • gRPC 支持直接节点访问
  • LNC 支持安全远程访问
  • JSON 和自然语言输出格式

贡献

有关设置、样式和测试指南,请参阅 CONTRIBUTING.md

许可证

Apache License 2.0。 请参阅 LICENSE

推荐服务器

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