Google Calendar

搜索与获取

by Kashyab19

连接 Google 账号以浏览和管理日历与事件,支持创建、更新、删除单次、重复或全天事件,并可跨日历查找安排、保持日程同步。

什么是 Google Calendar

连接 Google 账号以浏览和管理日历与事件,支持创建、更新、删除单次、重复或全天事件,并可跨日历查找安排、保持日程同步。

README

Google Calendar MCP Server

A Model Context Protocol (MCP) server that provides Google Calendar integration through the Smithery framework. This server enables AI assistants to interact with Google Calendar data including calendars, events, and user authentication.

Features

  • OAuth 2.1 Authentication: Secure authentication using OAuth 2.1 with PKCE
  • Calendar Management: List, create, update, and delete calendars
  • Event Operations: Full CRUD operations for calendar events
  • Search Functionality: Search events across multiple calendars
  • All-day Event Support: Handle both timed and all-day events
  • Error Handling: Comprehensive error handling with user-friendly messages
  • Guest Access: Supports anonymous access for initial connections

Architecture

This project consists of two main components:

  1. MCP Server (src/): The main MCP server that implements the Model Context Protocol
  2. Auth Server (auth-server/): OAuth 2.1 authorization server for secure authentication

Prerequisites

  • Node.js 20.0.0 or higher
  • npm or yarn
  • Google Cloud Console project with Calendar API enabled
  • OAuth 2.0 credentials from Google Cloud Console

Installation

  1. Clone and navigate to the project

    bash
    cd gcal-mcp
    npm install
    
  2. Install auth-server dependencies

    bash
    cd auth-server
    npm install
    cd ..
    
  3. Configure environment variables

    bash
    # Copy example files
    cp auth-server/env.example auth-server/.env
    
    # Edit auth-server/.env with your settings
    

Configuration

Auth Server Configuration

Create auth-server/.env with the following variables:

env
# Auth Server Configuration
AUTH_SERVER_ISSUER=http://localhost:3080
MCP_RESOURCE_ID=https://smithery.ai

# Google OAuth Configuration
GOOGLE_CLIENT_ID=your_google_client_id
GOOGLE_CLIENT_SECRET=your_google_client_secret
GOOGLE_REDIRECT_URI=http://localhost:3080/oauth/google/callback

# JWT Configuration
JWT_SECRET=your_jwt_secret_key
JWT_ISSUER=http://localhost:3080
JWT_AUDIENCE=https://smithery.ai

# Database (optional - uses in-memory by default)
DATABASE_URL=sqlite://./auth.db

Google Cloud Console Setup

  1. Create a Google Cloud project
  2. Enable the Google Calendar API
  3. Configure OAuth consent screen
  4. Create OAuth 2.0 credentials
  5. Add authorized redirect URIs:
    • http://localhost:3080/oauth/google/callback
    • https://smithery.ai/playground/callback

Usage

Development Mode

  1. Start the auth server

    bash
    cd auth-server
    npm run dev
    
  2. Start the MCP server (in a new terminal)

    bash
    cd gcal-mcp
    npm run dev
    
  3. Connect via Smithery Playground

    • Open Smithery Playground
    • Connect to your MCP server
    • Complete OAuth authentication when prompted

Production Deployment

  1. Build the project

    bash
    npm run build
    
  2. Configure production environment

    • Update auth server URL in production
    • Use HTTPS for all URLs
    • Configure proper CORS settings

Available Tools

Calendar Tools

  • list_calendars: List all accessible calendars
  • get_calendar: Get details of a specific calendar
  • create_calendar: Create a new calendar
  • update_calendar: Update calendar properties
  • delete_calendar: Delete a calendar
  • search_calendars: Search calendars by name or description

Event Tools

  • list_events: List events from a calendar
  • get_event: Get details of a specific event
  • create_event: Create a new event
  • update_event: Update event properties
  • delete_event: Delete an event
  • search_events: Search events across calendars

Authentication Tools

  • check_auth_status: Check current authentication status

API Reference

Authentication Flow

  1. Initial Connection: MCP server allows anonymous initial connections
  2. OAuth Registration: Client registers with the auth server
  3. Authorization: User authorizes via Google OAuth
  4. Token Exchange: Authorization code exchanged for access token
  5. Token Verification: All subsequent requests verify the access token

Error Handling

The server provides comprehensive error handling with specific error types:

  • AuthenticationError: OAuth or token-related errors
  • ValidationError: Input validation failures
  • RateLimitError: Rate limiting violations
  • GoogleAPIError: Google Calendar API errors
  • NetworkError: Network connectivity issues

Development

Project Structure

code
gcal-mcp/
├── src/
│   ├── index.ts              # Main MCP server
│   ├── oauth-provider.ts     # OAuth provider implementation
│   ├── auth-utils.ts         # Authentication utilities
│   ├── constants.ts          # Server constants
│   ├── errors.ts             # Error handling
│   └── tools/
│       ├── auth.ts           # Authentication tools
│       ├── calendars.ts      # Calendar management tools
│       └── events.ts         # Event management tools
├── auth-server/
│   ├── src/
│   │   ├── index.ts          # Auth server main
│   │   ├── google-auth.ts    # Google OAuth integration
│   │   ├── storage.ts        # Token storage
│   │   └── crypto.ts         # Cryptographic utilities
│   └── tests/                # E2E tests
└── package.json

Scripts

  • npm run dev: Start development server
  • npm run build: Build for production
  • npm run check: Lint and format code
  • npm run test: Run tests

Testing

Run the comprehensive E2E tests:

bash
cd auth-server
npm run test:e2e

Troubleshooting

Common Issues

  1. Infinite Loop During Registration

    • Cause: Smithery SDK's requireBearerAuth middleware blocks MCP initialize
    • Solution: OAuth is currently disabled. Contact Smithery developers for SDK fix
  2. Authentication Failures

    • Verify Google OAuth credentials
    • Check redirect URI configuration
    • Ensure Calendar API is enabled
  3. Network Connectivity

    • Verify auth server is running on port 3080
    • Check firewall settings
    • Ensure proper URL configuration

Debug Mode

Enable debug logging:

bash
LOG_LEVEL=debug npm run dev

Configuration Check

Use the configuration checker:

bash
./check-config.sh

Security Considerations

  • Token Storage: Access tokens are stored securely with automatic refresh
  • PKCE: Uses Proof Key for Code Exchange for enhanced security
  • HTTPS: Always use HTTPS in production
  • Scope Limitation: Minimal required scopes for Google Calendar access
  • Token Expiration: Automatic token refresh and cleanup

Contributing

  1. Fork the repository
  2. Create a feature branch
  3. Make your changes
  4. Add tests if applicable
  5. Run linting and formatting
  6. Submit a pull request

Code Style

  • Use TypeScript strict mode
  • Follow the existing code structure
  • Add comprehensive error handling
  • Include JSDoc comments for public APIs
  • Run npm run check before committing

Support

Related Projects

常见问题

Google Calendar 是什么?

连接 Google 账号以浏览和管理日历与事件,支持创建、更新、删除单次、重复或全天事件,并可跨日历查找安排、保持日程同步。

相关 Skills

Morning Brief

by amadeus9169

This skill pulls the latest headlines from a reliable international RSS feed and presents a concise list of news titles. It is ideal for a quick, up-to-date snapshot of global events at the start of your day.

搜索与获取
未扫描3.9k

SEO Audit Skill

by amdf01-debug

热门

搜索与获取
未扫描3.9k

agent-browser

by chulla-ceja

热门

Browser automation CLI for AI agents. Use when the user needs to interact with websites, including navigating pages, filling forms, clicking buttons, taking screenshots, extracting data, testing web apps, or automating any browser task. Triggers include requests to "open a website", "fill out a form", "click a button", "take a screenshot", "scrape data from a page", "test this web app", "login to a site", "automate browser actions", or any task requiring programmatic web interaction.

搜索与获取
未扫描3.9k

相关 MCP Server

by Anthropic

热门

Puppeteer 是让 Claude 自动操作浏览器进行网页抓取和测试的 MCP 服务器。

这个服务器解决了手动编写 Puppeteer 脚本的繁琐问题,适合需要自动化网页交互的开发者,比如抓取动态内容或做端到端测试。不过,作为参考实现,它可能缺少生产级的安全防护,建议在可控环境中使用。

搜索与获取
83.1k

网页抓取

编辑精选

by Anthropic

热门

Fetch 是 MCP 官方参考服务器,让 AI 能抓取网页并转为 Markdown 格式。

这个服务器解决了 AI 直接处理网页内容时格式混乱的问题,适合需要让 Claude 分析在线文档或新闻的开发者。不过作为参考实现,它缺乏生产级的安全配置,你得自己处理反爬虫和隐私风险。

搜索与获取
83.1k

Brave 搜索

编辑精选

by Anthropic

热门

Brave Search 是让 Claude 直接调用 Brave 搜索 API 获取实时网络信息的 MCP 服务器。

如果你想让 AI 助手帮你搜索最新资讯或技术文档,这个工具能绕过传统搜索的限制,直接返回结构化数据。特别适合需要实时信息的开发者,比如查 API 更新或竞品动态。不过它依赖 Brave 的 API 配额,高频使用可能受限。

搜索与获取
83.1k

评论