Houki e-Gov MCP Server

Houki e-Gov MCP Server

Enables LLMs to search and retrieve Japanese laws from the e-Gov API v2, including keyword search, article fetching, table of contents, and revision history.

Category
访问服务器

README

Houki e-Gov MCP Server

CI npm version License: MIT Node

日本の法令(憲法・法律・政令・省令・規則)を e-Gov 法令API v2 経由で取得する MCP サーバ。

LLM が条文をキーワード・略称・分野で検索したり、特定の条項を Markdown / JSON で取得したり、改正履歴を引いたりできるようにする。

提供ツール

Tool 用途
search_law 法令タイトルでキーワード検索(略称→正式名解決済み)
get_law 条/項/号レベルで本文取得(Markdown / JSON / TOC)
get_toc 目次のみ取得(トークン節約)
get_law_revisions 改正履歴を取得(公布日・施行日・状態)
search_fulltext 全文検索(Phase 2 まで search_law にフォールバック)
resolve_abbreviation 略称→正式名解決の診断
explain_law_type 法令種別(憲法・法律・政令・省令・通達 等)の解説

略称辞書(165エントリ・6分野)は @shuji-bonji/houki-abbreviations を内部で利用しています。

インストール

Claude Desktop で使う

// claude_desktop_config.json
{
  "mcpServers": {
    "houki-egov": {
      "command": "npx",
      "args": ["-y", "@shuji-bonji/houki-egov-mcp"]
    }
  }
}

ローカル開発

git clone git@github.com:shuji-bonji/houki-egov-mcp.git
cd houki-egov-mcp
npm install
npm run build
npm test
// 開発中の動作確認 (.mcp.json)
{
  "mcpServers": {
    "houki-egov-local": {
      "command": "node",
      "args": ["/absolute/path/to/houki-egov-mcp/dist/index.js"]
    }
  }
}

使用例

# LLM への問いかけ → MCP ツール呼び出し

「消費税法30条1項を見せて」
  → get_law(law_name="消法", article="30", paragraph=1)

「労働基準法の目次を取得」
  → get_toc(law_name="労基法")

「個人情報保護法の改正履歴を最新5件」
  → get_law_revisions(law_name="個情法", latest=5)

「電帳法って正式名称なに?」
  → resolve_abbreviation(abbr="電帳法")
  → 電子計算機を使用して作成する国税関係帳簿書類の保存方法等の特例に関する法律

「政令と省令の違いは?」
  → explain_law_type(name="政令")

状態

v0.2.0 (2026-04-27)

  • [x] e-Gov 法令API v2 クライアント(searchLaws / getLawData / getLawRevisions
  • [x] 法令ツリー走査(条/項/号、目次抽出)+ LRU cache
  • [x] 7ツール本実装
  • [x] 略称辞書を @shuji-bonji/houki-abbreviations ^0.1.0 に分離
  • [x] 法令階層ナレッジ(憲法・法律・政令・省令・規則・条例・告示・訓令・通達・通知 の10種別)
  • [x] Trusted Publisher (OIDC) で publish
  • [x] テストスイート(50 tests

計画中

  • [ ] Phase 2: search_fulltext 本実装(bulkDL + SQLite FTS5)
  • [ ] 漢数字対応(「第三十条」を 30 に変換)
  • [ ] 大規模法令の応答サイズ対策(民法・会社法)
  • [ ] エラーメッセージの LLM 可読化向上

houki-hub MCP family

houki-egov-mcp は 単体で利用可能ですが、houki-hub MCP family の一員でもあります。同じ family 内の他 MCP(計画中)と組み合わせると、通達・判例等まで横断的に扱えます。

パッケージ 役割 状態
@shuji-bonji/houki-abbreviations 略称辞書(共有ライブラリ) ✅ v0.1.0
@shuji-bonji/houki-egov-mcp e-Gov 法令API クライアント(このリポジトリ) ✅ v0.2.0
@shuji-bonji/houki-nta-mcp 国税庁通達・Q&A・タックスアンサー 計画中
@shuji-bonji/houki-mhlw-mcp 厚労省通達・通知 計画中
@shuji-bonji/houki-court-mcp 判例(裁判所サイト) 構想中
@shuji-bonji/houki-saiketsu-mcp 国税不服審判所裁決 構想中
@shuji-bonji/houki-hub meta-package(一括 install) 計画中

family 全体の設計思想・想定利用シーン・業法との関係は docs/DESIGN.md を参照。

エラー応答 (houki-hub family contract)

v0.3.0 より、本 MCP のエラー応答は houki-hub family 共通契約に完全準拠します。code 文字列は family 全体で統一された語彙を使用するため、複数の MCP を併用しても LLM・Skill 層は一貫したロジックで解釈できます。

houki-egov-mcp の src/errors.ts は family 全体の リファレンス実装として位置付けられています。他 MCP は同じ code 語彙を共有しつつ、共通パッケージへの依存は持たずに独立実装します。

{
  "error": "法令『消費税法』第3000条は存在しません",
  "code": "ARTICLE_NOT_FOUND",
  "hint": "条番号を get_toc で確認してください",
  "next_actions": [
    { "action": "get_toc", "reason": "目次で正しい条番号を特定", "example": { "law_name": "消費税法" } }
  ],
  "retryable": false
}

本 MCP で使用するコード

code 用途 retryable
INVALID_ARGUMENT キーワード未指定など引数バリデーション失敗 false
INVALID_ARTICLE_NUM 条番号フォーマットが不正 (例: 未対応の漢数字) false
OUT_OF_SCOPE 通達名で get_law を呼んだ等、別 MCP の管轄リソースが要求された false
LAW_NOT_FOUND 略称解決・検索のいずれでも法令が見つからない false
ARTICLE_NOT_FOUND 指定された条/項/号が見つからない false
SOURCE_API_ERROR e-Gov API がエラー応答 (4xx/5xx) 状況による
SOURCE_TIMEOUT e-Gov API がタイムアウト true
SOURCE_RATE_LIMITED e-Gov API がレート制限 (HTTP 429) true
SOURCE_UNAVAILABLE DNS 失敗 / ECONNREFUSED 等で e-Gov に到達不能 true
INTERNAL_ERROR 内部エラー (バグ・予期せぬ例外) false
UNKNOWN_TOOL 存在しない tool 名が呼ばれた false

Migration (v0.2.x → v0.3.0)

  • v0.2.x までは EGOV_API_ERROR / EGOV_TIMEOUT / EGOV_RATE_LIMITED を返していました。v0.3.0 からは family 共通の SOURCE_API_ERROR / SOURCE_TIMEOUT / SOURCE_RATE_LIMITED に切替。
  • EGOV_*LawErrorCode の型としては残置していますが、本 MCP からはもう発行しません。次のメジャー (v1.0.0) で削除予定。
  • 構造化エラーの形 ({ error, code, hint?, next_actions?, retryable?, detail? }) は不変。クライアント側で code 文字列の比較をしている場合は SOURCE_* を受け付けるよう更新してください。
  • OUT_OF_SCOPE を新たに受け取る可能性があります。例えば「消基通」(消費税法基本通達 / 国税庁の通達) を get_lawlaw_name に渡すと、next_actions[0].example.mcp = "houki-nta" を含む OUT_OF_SCOPE が返されるので、Skill 層は houki-nta-mcp に切り替えてください。

ドキュメント

業法との関係

本MCPは 一次情報の取得・提示のみ を担います。分析は LLM、判断は利用者(または有資格者)の責任です。業としての法律事務・税務業務への利用は想定外です — 詳細は DISCLAIMER.md 参照。

デジタル庁公式 MCP との関係

デジタル庁は 2025年12月〜2026年3月の「法令×デジタル」ハッカソンで法令API / MCP のプロトタイプを試行提供した。将来一般公開された場合は、本 MCP のコアを公式 MCP に委譲し、houki-hub family 全体は 公式が手を出さないレイヤ(通達・裁決・判例の横断インデックス、業法対応 Skill 等) に注力する方針。

ライセンス

MIT — 個人利用・学習用途のフォーク・改変・再配布を自由に許可します。

ただし、業としての使用(弁護士法72条・税理士法52条・社労士法27条が定める独占業務) については想定外であり、作者は一切の責任を負いません。DISCLAIMER.md を必ずご確認ください。

推荐服务器

Baidu Map

Baidu Map

百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。

官方
精选
JavaScript
Playwright MCP Server

Playwright MCP Server

一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。

官方
精选
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。

官方
精选
本地
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。

官方
精选
本地
TypeScript
VeyraX

VeyraX

一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。

官方
精选
本地
graphlit-mcp-server

graphlit-mcp-server

模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。

官方
精选
TypeScript
Kagi MCP Server

Kagi MCP Server

一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。

官方
精选
Python
e2b-mcp-server

e2b-mcp-server

使用 MCP 通过 e2b 运行代码。

官方
精选
Neon MCP Server

Neon MCP Server

用于与 Neon 管理 API 和数据库交互的 MCP 服务器

官方
精选
Exa MCP Server

Exa MCP Server

模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。

官方
精选