
calendar mcp
一个用于 Google 日历集成的 Model Context Protocol (MCP) 服务器,支持自动身份验证和自然语言交互。
Repository Info
About This Server
一个用于 Google 日历集成的 Model Context Protocol (MCP) 服务器,支持自动身份验证和自然语言交互。
Model Context Protocol (MCP) - This server can be integrated with AI applications to provide additional context and capabilities, enabling enhanced AI interactions and functionality.
Documentation
Calendar AutoAuth MCP Server
A Model Context Protocol (MCP) server for Google Calendar integration in Cluade Desktop with auto authentication support. This server enables AI assistants to manage Google Calendar events through natural language interactions.
Features
- Create calendar events with title, time, description, and location
- Retrieve event details by event ID
- Update existing events (title, time, description, location)
- Delete events
- List events within a specified time range
- Full integration with Google Calendar API
- Simple OAuth2 authentication flow with auto browser launch
- Support for both Desktop and Web application credentials
- Global credential storage for convenience
Installation & Authentication
Installing via Smithery
To install Calendar AutoAuth Server for Claude Desktop automatically via Smithery:
npx -y @smithery/cli install @raghavared/calendar-mcp --client claude
-
Create a Google Cloud Project and obtain credentials:
a. Create a Google Cloud Project:
- Go to Google Cloud Console
- Create a new project or select an existing one
- Enable the Google Calendar API for your project
b. Create OAuth 2.0 Credentials:
- Go to "APIs & Services" > "Credentials"
- Click "Create Credentials" > "OAuth client ID"
- Choose either "Desktop app" or "Web application" as application type
- Give it a name and click "Create"
- For Web application, add
http://localhost:3000/v2/auth/google/callbackto the authorized redirect URIs - Download the JSON file of your client's OAuth keys
- Rename the key file to
token.json
-
Run Authentication:
You can authenticate in two ways:
a. Global Authentication (Recommended):
# First time: Place token.json in your home directory's .calendar-mcp folder mkdir -p ~/.calendar-mcp mv token.json ~/.calendar-mcp/ # Run authentication from anywhere npx @raghavared/calendar-mcp authb. Local Authentication:
# Place token.json in your current directory # The file will be automatically copied to global config npx @raghavared/calendar-mcp authThe authentication process will:
-
Look for
token.jsonin the current directory or~/.calendar-mcp/ -
If found in current directory, copy it to
~/.calendar-mcp/ -
Open your default browser for Google authentication
-
Save credentials as
~/.calendar-mcp/credentials.json
Note:
- After successful authentication, credentials are stored globally in
~/.calendar-mcp/and can be used from any directory - Both Desktop app and Web application credentials are supported
- For Web application credentials, make sure to add
http://localhost:3000/v2/auth/google/callbackto your authorized redirect URIs
-
-
Configure in Claude Desktop:
{
"mcpServers": {
"calendar": {
"command": "npx",
"args": [
"@raghavared/calendar-mcp"
]
}
}
}
Docker Support
If you prefer using Docker:
- Authentication:
docker run -i --rm \
--mount type=bind,source=/path/to/token.json,target=/token.json \
-v mcp-calendar:/path \
-e CALENDAR_OAUTH_PATH=/token.json \
-e "CALENDAR_CREDENTIALS_PATH=/path/credentials.json" \
-p 3000:3000 \
mcp/calendar auth
- Usage:
{
"mcpServers": {
"calendar": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"-v",
"mcp-calendar:/path",
"-e",
"CALENDAR_CREDENTIALS_PATH=/path/credentials.json",
"mcp/calendar"
]
}
}
}
Usage Examples
The server provides several tools that can be used through the Claude Desktop:
Create Event
{
"summary": "Team Meeting",
"start": {
"dateTime": "2024-01-20T10:00:00Z"
},
"end": {
"dateTime": "2024-01-20T11:00:00Z"
},
"description": "Weekly team sync",
"location": "Conference Room A"
}
List Events
{
"timeMin": "2024-01-01T00:00:00Z",
"timeMax": "2024-12-31T23:59:59Z",
"maxResults": 10,
"orderBy": "startTime"
}
Update Event
{
"eventId": "event123",
"summary": "Updated Meeting Title",
"start": {
"dateTime": "2024-01-20T11:00:00Z"
},
"end": {
"dateTime": "2024-01-20T12:00:00Z"
}
}
Delete Event
{
"eventId": "event123"
}
Security Notes
- OAuth credentials are stored securely in your local environment (
~/.calendar-mcp/) - The server uses offline access to maintain persistent authentication
- Never share or commit your credentials to version control
- Regularly review and revoke unused access in your Google Account settings
- Credentials are stored globally but are only accessible by the current user
Troubleshooting
-
OAuth Keys Not Found
- Make sure
token.jsonis in either your current directory or~/.calendar-mcp/ - Check file permissions
- Make sure
-
Invalid Credentials Format
- Ensure your OAuth keys file contains either
weborinstalledcredentials - For web applications, verify the redirect URI is correctly configured
- Ensure your OAuth keys file contains either
-
Port Already in Use
- If port 3000 is already in use, please free it up before running authentication
- You can find and stop the process using that port
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
License
This project is licensed under the ISC License.
Author
Raghava Reddy
Support
If you encounter any issues or have questions, please file an issue on the GitHub repository.
Quick Start
Clone the repository
git clone https://github.com/raghavared/calendar-mcpInstall dependencies
cd calendar-mcp
npm installFollow the documentation
Check the repository's README.md file for specific installation and usage instructions.
Repository Details
Recommended MCP Servers
Discord MCP
Enable AI assistants to seamlessly interact with Discord servers, channels, and messages.
Knit MCP
Connect AI agents to 200+ SaaS applications and automate workflows.
Apify MCP Server
Deploy and interact with Apify actors for web scraping and data extraction.
BrowserStack MCP
BrowserStack MCP Server for automated testing across multiple browsers.
Zapier MCP
A Zapier server that provides automation capabilities for various apps.