Skip to main content
Glama

おもてなしQR MCP Server

ChatGPTなどのMCP対応クライアントから、おもてなしQRの音声生成APIを呼び出すための最小構成MCPサーバーです。

概要

このMCPサーバーは、Model Context Protocol (MCP) に準拠したAPIゲートウェイとして機能し、MCPクライアントからのリクエストを既存のおもてなしQR音声生成APIにプロキシします。

アーキテクチャ

ChatGPT(MCPクライアント)
        │ (MCP API KEY 認証)
        ▼
mcp.omotenashiqr.com(Node MCPサーバー)
        │ (内部固定 session_token)
        ▼
omotenashiqr.com/api/v2/video/generate-audio(既存API)

機能

  • MCP準拠: Model Context Protocol 2024-11-05 に準拠

  • API KEY認証: MCPクライアントからのリクエストをAPI KEYで認証

  • 音声生成ツール: generate_audio ツールを提供

  • セッション管理: StreamableHTTP transportを使用したセッション管理

  • ロギング: 詳細なログ出力で動作を追跡

必要な環境

  • Node.js 18以上

  • npm または yarn

セットアップ

1. 依存関係のインストール

npm install

2. 環境変数の設定

.env ファイルを作成し、以下の環境変数を設定します:

# MCP Server API Key (MCPクライアントからのリクエスト認証用)
MCP_API_KEY=your-mcp-api-key-here

# おもてなしQR 管理者セッショントークン(既存APIへのリクエスト用)
OMOTENASHI_SESSION_TOKEN=your-admin-session-token-here

# 既存APIのベースURL
BASE_API_URL=https://omotenashiqr.com

# MCPサーバーのポート番号(デフォルト: 8001)
MCP_PORT=8001

3. サーバーの起動

npm start

サーバーが起動すると、以下のエンドポイントが利用可能になります:

  • POST /mcp - MCPリクエストエンドポイント

  • GET /mcp - SSEストリームエンドポイント

  • DELETE /mcp - セッション終了エンドポイント

  • GET /health - ヘルスチェックエンドポイント

使用方法

ヘルスチェック

curl http://localhost:8001/health

MCP初期化

curl -X POST http://localhost:8001/mcp \
  -H "Content-Type: application/json" \
  -H "Accept: application/json, text/event-stream" \
  -d '{
    "jsonrpc": "2.0",
    "method": "initialize",
    "params": {
      "protocolVersion": "2024-11-05",
      "capabilities": {},
      "clientInfo": {
        "name": "test-client",
        "version": "1.0.0"
      }
    },
    "id": 1
  }'

レスポンスヘッダーから Mcp-Session-Id を取得してください。

ツールリストの取得

curl -X POST http://localhost:8001/mcp \
  -H "Content-Type: application/json" \
  -H "Accept: application/json, text/event-stream" \
  -H "Mcp-Session-Id: YOUR_SESSION_ID" \
  -H "X-API-Key: YOUR_API_KEY" \
  -d '{
    "jsonrpc": "2.0",
    "method": "tools/list",
    "params": {},
    "id": 2
  }'

音声生成ツールの実行

curl -X POST http://localhost:8001/mcp \
  -H "Content-Type: application/json" \
  -H "Accept: application/json, text/event-stream" \
  -H "Mcp-Session-Id: YOUR_SESSION_ID" \
  -H "X-API-Key: YOUR_API_KEY" \
  -d '{
    "jsonrpc": "2.0",
    "method": "tools/call",
    "params": {
      "name": "generate_audio",
      "arguments": {
        "content": "こんにちは、世界",
        "language": "ja",
        "voice_speaker": "Orus",
        "voice_speed": 1.0
      }
    },
    "id": 3
  }'

ツール仕様

generate_audio

テキストから音声を生成します。

パラメータ:

パラメータ

必須

デフォルト

説明

content

string

-

音声化するテキスト内容

language

enum

ja

言語 (ja, en, zh, ko)

voice_speaker

string

Orus

音声スピーカー名

voice_speed

number

1.0

音声速度 (0.5-2.0)

レスポンス例:

{
  "content": [
    {
      "type": "text",
      "text": "{\"success\": true, \"project_id\": \"...\", \"status\": \"...\", ...}"
    }
  ]
}

Nginx リバースプロキシ設定

本番環境では、Nginxをリバースプロキシとして使用することを推奨します。

設定例(/etc/nginx/sites-available/mcp.omotenashiqr.com):

server {
    listen 80;
    server_name mcp.omotenashiqr.com;

    location / {
        proxy_pass http://localhost:8001;
        proxy_http_version 1.1;

        # WebSocket/SSE対応
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";

        # ヘッダー転送
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;

        # タイムアウト設定
        proxy_read_timeout 300;
        proxy_connect_timeout 300;
        proxy_send_timeout 300;
    }
}

SSL設定(Let's Encrypt):

sudo certbot --nginx -d mcp.omotenashiqr.com

PM2による常駐化(推奨)

本番環境では、PM2を使用してサーバーを常駐させることを推奨します:

# PM2のインストール
npm install -g pm2

# サーバーの起動
pm2 start server.mjs --name mcp-omotenashi

# 自動起動設定
pm2 startup
pm2 save

# ログの確認
pm2 logs mcp-omotenashi

トラブルシューティング

サーバーが起動しない

  1. 環境変数が正しく設定されているか確認してください

  2. ポート8001が使用可能か確認してください:lsof -i :8001

  3. Node.jsのバージョンを確認してください:node --version (18以上必要)

API呼び出しでエラーが発生する

  1. OMOTENASHI_SESSION_TOKEN が有効か確認してください

  2. BASE_API_URL が正しいか確認してください

  3. サーバーログを確認してください:ログには詳細なエラー情報が出力されます

開発

ローカル開発

# サーバーを起動(開発モード)
npm start

# 別のターミナルでテスト
curl http://localhost:8001/health

ログレベル

サーバーは以下のログレベルでメッセージを出力します:

  • info: 通常の操作情報

  • debug: デバッグ情報(API呼び出し詳細など)

  • error: エラー情報

セキュリティ

  • API KEY認証: すべてのMCPリクエスト(初期化を除く)にはX-API-Keyヘッダーが必要

  • セッション管理: 各クライアントに固有のセッションIDが割り当てられます

  • 環境変数: 機密情報は.envファイルで管理(Gitにコミットしない)

ライセンス

ISC

作者

おもてなしQR開発チーム

-
security - not tested
F
license - not found
-
quality - not tested

Resources

Looking for Admin?

Admins can modify the Dockerfile, update the server description, and track usage metrics. If you are the server author, to access the admin panel.

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/rakuai-support/mcp-omotenashi'

If you have feedback or need assistance with the MCP directory API, please join our Discord server