Google Calendar MCP Server
Enables interaction with Google Calendar through the Google Calendar API. Supports listing calendars, creating/deleting events, and retrieving calendar events with OAuth2 authentication.
README
Google Calendar MCP Server
Google Calendar APIを使用したMCP(Model Context Protocol)サーバーです。FastMCPフレームワークを使用してGoogleカレンダーの操作機能を提供します。
機能
- カレンダー一覧取得: 利用可能なGoogleカレンダーの一覧を取得
- イベント取得: 指定したカレンダーからイベントを取得
- イベント作成: 新しいカレンダーイベントを作成
- イベント削除: カレンダーイベントを削除
要件
- Python 3.12以上
- Google Cloud Platformプロジェクト
- Google Calendar API有効化
- OAuth2認証情報
インストール
- リポジトリをクローン
git clone <repository-url>
cd google-calendar-mcp
- 依存関係をインストール
pip install -e .
またはuvを使用する場合:
uv sync
設定
1. Google Cloud Platform設定
- Google Cloud Consoleでプロジェクトを作成
- Google Calendar APIを有効化
- OAuth2認証情報を作成
- 必要な環境変数を設定
2. 環境変数設定
以下の環境変数を設定してください:
export GOOGLE_CLIENT_ID="your_client_id"
export GOOGLE_CLIENT_SECRET="your_client_secret"
export GOOGLE_PROJECT_ID="your_project_id"
export GOOGLE_REFRESH_TOKEN="your_refresh_token"
または.envファイルに設定:
GOOGLE_CLIENT_ID=your_client_id
GOOGLE_CLIENT_SECRET=your_client_secret
GOOGLE_PROJECT_ID=your_project_id
GOOGLE_REFRESH_TOKEN=your_refresh_token
3. OAuth2認証情報の取得
- Google Cloud ConsoleでOAuth2認証情報を作成
- 認証フローを実行してリフレッシュトークンを取得
- 取得した値を環境変数に設定
使用方法
MCPサーバーとして実行
python main.py
直接実行
python -m src.google_calendar_mcp
API仕様
list_calendars()
利用可能なGoogleカレンダーの一覧を取得します。
引数: なし
戻り値:
success(bool): 処理が成功したかどうかcalendars(List[Dict]): カレンダー情報のリストcount(int): カレンダー数error(str): エラーメッセージ(失敗時)
get_events()
指定したカレンダーからイベントを取得します。
引数:
calendar_id(str): カレンダーID(デフォルト: 'primary')time_min(str): 開始時刻(ISO形式、デフォルト: 現在時刻)time_max(str): 終了時刻(ISO形式、デフォルト: 7日後)max_results(int): 最大取得件数(デフォルト: 10)
戻り値:
success(bool): 処理が成功したかどうかevents(List[Dict]): イベント情報のリストcount(int): イベント数error(str): エラーメッセージ(失敗時)
create_event()
新しいカレンダーイベントを作成します。
引数:
summary(str): イベントタイトル(必須)start_time(str): 開始時刻(ISO形式、必須)end_time(str): 終了時刻(ISO形式、必須)description(str): イベントの説明(デフォルト: '')location(str): 場所(デフォルト: '')calendar_id(str): カレンダーID(デフォルト: 'primary')attendees(List[str]): 参加者メールアドレスのリスト(デフォルト: None)
戻り値:
success(bool): 処理が成功したかどうかevent_id(str): 作成されたイベントのIDevent_link(str): イベントのGoogleカレンダーリンクmessage(str): 成功メッセージerror(str): エラーメッセージ(失敗時)
delete_event()
カレンダーイベントを削除します。
引数:
event_id(str): 削除するイベントのID(必須)calendar_id(str): カレンダーID(デフォルト: 'primary')
戻り値:
success(bool): 処理が成功したかどうかmessage(str): 成功メッセージerror(str): エラーメッセージ(失敗時)
テスト
モックモードでのテスト実行
python run_tests.py --mode mock
実際のAPIを使用したテスト実行
python run_tests.py --mode real_api
カバレッジレポート付きテスト実行
python run_tests.py --mode mock --coverage
特定のテスト実行
python run_tests.py --mode mock --test test_calendar_tools.py::TestListCalendars
プロジェクト構造
google-calendar-mcp/
├── src/
│ ├── __init__.py
│ ├── google_calendar_mcp.py # MCPサーバーのメインエントリーポイント
│ ├── auth/
│ │ ├── __init__.py
│ │ └── google_auth.py # Google認証処理
│ └── tools/
│ ├── __init__.py
│ └── calendar_tools.py # カレンダー操作機能
├── tests/
│ ├── __init__.py
│ └── test_calendar_tools.py # テストコード
├── main.py # アプリケーションエントリーポイント
├── run_tests.py # テスト実行スクリプト
├── pyproject.toml # プロジェクト設定
├── pytest.ini # pytest設定
└── README.md # このファイル
依存関係
fastmcp: MCPサーバーフレームワークgoogle-api-python-client: Google APIクライアントgoogle-auth-httplib2: Google認証ライブラリgoogle-auth-oauthlib: OAuth2認証ライブラリpython-dotenv: 環境変数管理pytest: テストフレームワークpytest-mock: モックテストライブラリ
ライセンス
このプロジェクトのライセンスについては、LICENSEファイルを参照してください。
貢献
プルリクエストやイシューの報告を歓迎します。
トラブルシューティング
認証エラー
- 環境変数が正しく設定されているか確認
- OAuth2認証情報が有効か確認
- Google Calendar APIが有効化されているか確認
権限エラー
- 必要なスコープが設定されているか確認
- カレンダーへのアクセス権限があるか確認
テストエラー
- 環境変数
USE_REAL_APIの設定を確認 - 必要な依存関係がインストールされているか確認
推荐服务器
Baidu Map
百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Magic Component Platform (MCP)
一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。
Audiense Insights MCP Server
通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。
VeyraX
一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。
graphlit-mcp-server
模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。
Kagi MCP Server
一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。
e2b-mcp-server
使用 MCP 通过 e2b 运行代码。
Neon MCP Server
用于与 Neon 管理 API 和数据库交互的 MCP 服务器
Exa MCP Server
模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。