Skip to main content
Glama

Omotenashi QR MCP Server

おもてなし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

remote-capable server

The server can be hosted and run remotely because it primarily relies on remote services or has no dependency on the local environment.

Enables text-to-speech generation through the Omotenashi QR API, supporting multiple languages (Japanese, English, Chinese, Korean) with customizable voice speakers and speed settings.

  1. 概要
    1. アーキテクチャ
  2. 機能
    1. 必要な環境
      1. セットアップ
        1. 1. 依存関係のインストール
        2. 2. 環境変数の設定
        3. 3. サーバーの起動
      2. 使用方法
        1. ヘルスチェック
        2. MCP初期化
        3. ツールリストの取得
        4. 音声生成ツールの実行
      3. ツール仕様
        1. generate_audio
      4. Nginx リバースプロキシ設定
        1. PM2による常駐化(推奨)
          1. トラブルシューティング
            1. サーバーが起動しない
            2. API呼び出しでエラーが発生する
          2. 開発
            1. ローカル開発
            2. ログレベル
          3. セキュリティ
            1. ライセンス
              1. 作者

                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