Omotenashi QR MCP Server
Enables text-to-speech generation through the Omotenashi QR API, supporting multiple languages (Japanese, English, Chinese, Korean) with customizable voice speakers and speed settings.
README
おもてなし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
トラブルシューティング
サーバーが起動しない
- 環境変数が正しく設定されているか確認してください
- ポート8001が使用可能か確認してください:
lsof -i :8001 - Node.jsのバージョンを確認してください:
node --version(18以上必要)
API呼び出しでエラーが発生する
OMOTENASHI_SESSION_TOKENが有効か確認してくださいBASE_API_URLが正しいか確認してください- サーバーログを確認してください:ログには詳細なエラー情報が出力されます
開発
ローカル開発
# サーバーを起動(開発モード)
npm start
# 別のターミナルでテスト
curl http://localhost:8001/health
ログレベル
サーバーは以下のログレベルでメッセージを出力します:
info: 通常の操作情報debug: デバッグ情報(API呼び出し詳細など)error: エラー情報
セキュリティ
- API KEY認証: すべてのMCPリクエスト(初期化を除く)には
X-API-Keyヘッダーが必要 - セッション管理: 各クライアントに固有のセッションIDが割り当てられます
- 環境変数: 機密情報は
.envファイルで管理(Gitにコミットしない)
ライセンス
ISC
作者
おもてなしQR開発チーム
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.