Metadata-Version: 2.4
Name: mlit-mcp
Version: 0.1.0
Summary: MCP Server for MLIT (Ministry of Land, Infrastructure, Transport and Tourism) Real Estate Information
Author-email: Takurot <takuro.t@gmail.com>
License: MIT
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3.11
Classifier: Topic :: Scientific/Engineering :: GIS
Requires-Python: >=3.11
Requires-Dist: cachetools>=5.3.3
Requires-Dist: fastapi>=0.115.0
Requires-Dist: fastmcp>=2.0.0
Requires-Dist: httpx-sse>=0.4.0
Requires-Dist: httpx>=0.27.2
Requires-Dist: matplotlib>=3.7.0
Requires-Dist: mcp>=1.0.0
Requires-Dist: numpy>=1.24.0
Requires-Dist: pandas>=2.0.0
Requires-Dist: pydantic-settings>=2.6.0
Requires-Dist: python-dotenv>=1.0.0
Requires-Dist: requests>=2.31.0
Requires-Dist: seaborn>=0.13.0
Requires-Dist: tenacity>=9.0.0
Requires-Dist: tqdm>=4.66.0
Requires-Dist: trio>=0.26.0
Requires-Dist: urllib3>=2.0.0
Requires-Dist: uvicorn>=0.30.0
Provides-Extra: dev
Requires-Dist: black>=23.12.0; extra == 'dev'
Requires-Dist: flake8>=6.1.0; extra == 'dev'
Requires-Dist: mypy>=1.6.0; extra == 'dev'
Requires-Dist: pytest-asyncio>=0.23.0; extra == 'dev'
Requires-Dist: pytest-httpx>=0.20.0; extra == 'dev'
Requires-Dist: pytest>=7.4.0; extra == 'dev'
Description-Content-Type: text/markdown

# MLIT Real Estate MCP Server

日本の国土交通省「不動産情報ライブラリ」API を利用し、不動産取引価格・地価公示・都市計画などの情報を LLM (Large Language Model) エージェントに提供する MCP (Model Context Protocol) サーバーです。

## 特徴

- **MCP 対応**: Cursor, Claude Desktop などの MCP クライアントから直接利用可能。
- **キャッシュ機能**: API レスポンスをキャッシュし、API 制限や待機時間を緩和 (InMemory & File-based)。
- **GeoJSON/MVT 対応**: 大規模な地理データは MCP の `resource://` として効率的に受け渡し。
- **堅牢性**: API エラー時の自動リトライ、レート制限への対応。
- **統計情報**: キャッシュヒット率やエラー数をモニター可能。

## 必要なもの

- Python 3.11 以上
- **国土交通省 API キー**
  - [不動産情報ライブラリ API 利用申請](https://www.reinfolib.mlit.go.jp/ex-api/external/XIT001) から取得してください。

## インストール

1. リポジトリをクローン:
   ```bash
   git clone https://github.com/takurot/real-estate-mcp.git
   cd real-estate-mcp
   ```

### PyPI からインストールする場合 (推奨)

```bash
pip install mlit-mcp
```

### ソースコードからインストールする場合


2. 依存パッケージのインストール:
   ```bash
   python -m venv .venv
   source .venv/bin/activate  # Windows: .venv\Scripts\activate
   pip install -r requirements.txt
   ```

3. 環境変数の設定:
   `.env` ファイルを作成し、API キーを設定します。
   ```bash
   MLIT_API_KEY=your_api_key_here
   ```

## 使い方 (MCP サーバーとして実行)

### 1. MCP サーバーの設定方法

以下の手順で MCP クライアントから本サーバーを利用できます。

1) 仮想環境の Python パスを確認します。
```bash
pwd  # リポジトリ直下の絶対パスを確認
echo "$(pwd)/.venv/bin/python"  # macOS/Linux の例
# Windows の例: .venv\\Scripts\\python.exe
```

2) API キーを環境変数で渡す設定にします（`.env` も読み込まれます）。

3) MCP クライアントの設定ファイルに以下を追加します（Claude / Cursor の例）。

MCP クライアントの設定ファイル (例: `claude_desktop_config.json` や Cursor の MCP 設定) に以下を追加します。

```json
{
  "mcpServers": {
    "mlit": {
      "command": "/absolute/path/to/real-estate-mcp/.venv/bin/python",
      "args": ["-m", "mlit_mcp"],
      "cwd": "/absolute/path/to/real-estate-mcp",
      "env": {
        "MLIT_API_KEY": "your_api_key_here"
      }
    }
  }
}
```

補足:
- Claude Desktop の設定ファイルパス（macOS 例）: `~/Library/Application Support/Claude/claude_desktop_config.json`
- Cursor はアプリ内の MCP 設定から `mcpServers` を追加してください（設定 UI/ドキュメントに準拠）。

### 2. コマンドラインでの動作確認

サーバーは標準入出力 (stdio) を使用します。まず依存関係を全てインストールしてください:

```bash
pip install -r requirements.txt
```

Cursor / Claude の設定に記載した `command` と `cwd` で、同じ内容を手動で確認する場合は、リポジトリ直下で次を実行します。

```bash
./.venv/bin/python -m mlit_mcp
```

何も表示されず待機状態になりますが正常です（MCP クライアントからの接続を待っています）。

### 3. HTTP サーバーでのローカル確認（任意）

FastAPI ベースの HTTP アダプターで簡易確認ができます。

```bash
uvicorn mlit_mcp.server:app --reload
```
ブラウザで `http://127.0.0.1:8000/docs` を開くと OpenAPI ドキュメントが表示されます。

## 利用可能なツール一覧

| ツール名 | 説明 | 引数例 |
| --- | --- | --- |
| `mlit.list_municipalities` | 指定した都道府県の市区町村コード一覧を取得 | `{"prefectureCode": "13"}` |
| `mlit.fetch_transactions` | 不動産取引価格情報の検索・取得 (期間・場所指定) | `{"year_from": 2020, "year_to": 2020, "pref_code": "13", "city_code": "13101"}` |
| `mlit.fetch_transaction_points` | 取引情報のポイントデータを GeoJSON リソースとして取得 | `{"year_from": 2020, ...}` |
| `mlit.fetch_land_price_points` | 地価公示・地価調査ポイントの取得 | `{"zoom": 12, "x": 3639, "y": 1612, "year": 2023}` |
| `mlit.fetch_urban_planning_zones` | 都市計画区域・用途地域などの取得 | `{"zoom": 12, "x": ..., "y": ...}` |
| `mlit.fetch_school_districts` | 学区データの取得 (Vector Tile -> Base64 MVT) | `{"zoom": 12, "x": ..., "y": ...}` |
| `mlit.get_server_stats` | サーバーの統計情報 (リクエスト数, キャッシュヒット率など) を取得 | `{}` |

> **Note**: ポイント系データツール (`fetch_*_points`) はレスポンスが大きいため、MCP の `resource` URI を返却します。クライアントは `read_resource` で別途データを取得できます。

## 開発・テスト

### テスト実行
```bash
# 全テスト
pytest

# カバレッジ
pytest --cov=mlit_mcp
```

### コード品質チェック
```bash
# フォーマット
black .
# Lint
flake8 mlit_mcp tests
# 型チェック
mypy mlit_mcp
```

### ディレクトリ構成
- `mlit_mcp/`: サーバー本体コード
  - `tools/`: 各 MCP ツールの実装
- `tests/`: テストコード
  - `e2e/`: エンドツーエンドテスト

## ライセンス
MIT License

## メンテナ向けメモ
開発規約・構成・テスト方針の詳細は `AGENTS.md` を参照してください。
