Servidor MCP de Google Calendar
AVISO DE ACTUALIZACIÓN DE VERSIÓN
La versión 1.0.5 añade compatibilidad con eventos recurrentes mediante el parámetrorecurrenceen las herramientascreateEventyupdateEvent. Esto permite crear y modificar eventos recurrentes directamente sin tener que configurarlos manualmente tras su creación.
Descripción general del proyecto
El servidor MCP de Google Calendar es una implementación de servidor MCP (Protocolo de Contexto de Modelo) que permite la integración entre Google Calendar y Claude Desktop. Este proyecto permite a Claude interactuar con el Google Calendar del usuario, ofreciendo la posibilidad de mostrar, crear, actualizar y eliminar eventos del calendario mediante interacción con lenguaje natural.
Características principales
Integración de Google Calendar : proporciona un puente entre Claude Desktop y la API de Google Calendar
Implementación de MCP : sigue la especificación del Protocolo de contexto de modelo para la integración de herramientas de asistente de IA
Autenticación OAuth2 : gestiona el flujo de autenticación de la API de Google de forma segura
Gestión de eventos : admite operaciones integrales de eventos de calendario (obtener, crear, actualizar, eliminar)
Compatibilidad de color : capacidad de establecer y actualizar colores de eventos mediante el parámetro colorId
Transporte STDIO : utiliza entrada/salida estándar para la comunicación con Claude Desktop
Arquitectura técnica
Este proyecto utiliza:
TypeScript : para el desarrollo de código con seguridad de tipos
SDK de MCP : utiliza
@modelcontextprotocol/sdkpara la integración con Claude DesktopAPI de Google : utiliza
googleapispara acceder a la API de Google CalendarZod : Implementa la validación del esquema para datos de solicitud/respuesta
Configuración basada en el entorno : utiliza dotenv para la gestión de la configuración
Helmet.js : Para encabezados de seguridad
AES-256-GCM : para cifrado de tokens
Jest : para pruebas unitarias y cobertura
Acciones de GitHub : para CI/CD
Componentes principales
Servidor MCP : implementación del servidor central que maneja la comunicación con Claude Desktop
Herramientas de Google Calendar : Operaciones de calendario (recuperación, creación, actualización, eliminación)
Controlador de autenticación : gestión del flujo OAuth2 con la API de Google
Validación de esquemas : garantizar la integridad de los datos en todas las operaciones
Token Manager : gestión segura de tokens de autenticación
Herramientas disponibles
Este servidor MCP proporciona las siguientes herramientas para interactuar con Google Calendar:
1. obtenerEventos
Recupera eventos del calendario con varias opciones de filtrado.
Parámetros:
calendarId(opcional): ID del calendario (usa el calendario principal si se omite)timeMin(opcional): Hora de inicio para la recuperación del evento (formato ISO 8601, p. ej., "2025-03-01T00:00:00Z")timeMax(opcional): Hora de finalización para la recuperación del evento (formato ISO 8601)maxResults(opcional): Número máximo de eventos a recuperar (predeterminado: 10)orderBy(opcional): orden de clasificación ("startTime" o "updated")
2. crearEvento
Crea un nuevo evento de calendario.
Parámetros:
calendarId(opcional): ID del calendario (usa el calendario principal si se omite)event: objeto de detalles del evento que contiene:summary(obligatorio): Título del eventodescription(opcional): Descripción del eventolocation(opcional): Ubicación del eventostart: objeto de tiempo de inicio con:dateTime(opcional): formato ISO 8601 (p. ej., "2025-03-15T09:00:00+09:00")date(opcional): formato AAAA-MM-DD para eventos de todo el díatimeZone(opcional): zona horaria (p. ej., "Asia/Tokio")
end: objeto de hora de finalización (mismo formato que inicio)attendees(opcional): Matriz de asistentes con correo electrónico y nombre para mostrar opcionalcolorId(opcional): ID de color del evento (1-11)recurrence(opcional): Matriz de reglas de recurrencia en formato RFC5545 (por ejemplo, ["RRULE:FREQ=WEEKLY;BYDAY=MO,WE,FR"])
3. actualizaciónEvento
Actualiza un evento de calendario existente. La función obtiene primero los datos del evento existente y los fusiona con los datos de actualización, conservando los campos no incluidos en la solicitud de actualización.
Parámetros:
calendarId(opcional): ID del calendario (usa el calendario principal si se omite)eventId(obligatorio): ID del evento a actualizarevent: objeto de detalles del evento que contiene los campos a actualizar (la misma estructura que createEvent, todos los campos son opcionales)Sólo se actualizarán los campos que se proporcionen explícitamente
Los campos no incluidos en la solicitud de actualización conservarán sus valores existentes
Esto permite realizar actualizaciones parciales sin perder datos.
El parámetro
recurrencese puede actualizar para modificar patrones de eventos recurrentes
4. eliminarEvento
Elimina un evento del calendario.
Parámetros:
calendarId(opcional): ID del calendario (usa el calendario principal si se omite)eventId(obligatorio): ID del evento a eliminar
5. autenticar
Se vuelve a autenticar con Google Calendar. Esto es útil si quieres cambiar entre diferentes cuentas de Google sin tener que reiniciar Claude.
Parámetros:
Ninguno
Directrices de desarrollo
Al añadir nuevas funciones, modificar código o corregir errores, incremente semánticamente la versión con cada cambio mediante el comando npm version . Además, asegúrese de que su código sea claro y cumpla con todas las reglas de codificación necesarias, como la programación orientada a objetos. El script de versión ejecutará automáticamente npm install cuando se actualice la versión, pero aun así debe compilar, ejecutar lint y probar su código antes de enviarlo.
Estructura del código
src/ : Directorio del código fuente
auth/ : Manejo de autenticación
config/ : Ajustes de configuración
mcp/ : Implementación del servidor MCP
herramientas/ : Implementaciones de herramientas de Google Calendar
utils/ : Funciones de utilidad y ayudantes
Mejores prácticas
Escritura correcta según las mejores prácticas de TypeScript
Mantener un manejo integral de errores
Garantizar un flujo de autenticación adecuado
Mantenga las dependencias actualizadas
Redactar documentación clara para todas las funciones.
Implementar las mejores prácticas de seguridad
Siga los estándares de autenticación OAuth 2.1
Utilice la validación del esquema para todos los datos de entrada/salida
Pruebas
Implementar pruebas unitarias para la funcionalidad principal
Pruebe exhaustivamente el flujo de autenticación
Verificar la manipulación del calendario con la API de Google
Ejecutar pruebas con informes de cobertura
Asegúrese de que se incluyan pruebas de seguridad
Despliegue
Este paquete se publica en npm como @takumi0706/google-calendar-mcp :
Prerrequisitos
Cree un proyecto de Google Cloud y habilite la API de Google Calendar
Configurar las credenciales de OAuth2 en Google Cloud Console
Configurar variables de entorno:
Configuración del escritorio de Claude
Añade el servidor a tu claude_desktop_config.json . Si estás trabajando en un entorno donde no se puede acceder a localhost, añade la variable de entorno USE_MANUAL_AUTH con el valor "true".
Consideraciones de seguridad
Los tokens OAuth se almacenan únicamente en la memoria (no se almacenan en un almacenamiento basado en archivos)
Las credenciales confidenciales deben proporcionarse como variables de entorno
Cifrado de tokens mediante AES-256-GCM para almacenamiento seguro
Implementación de PKCE con generación explícita de code_verifier y code_challenge
Validación de parámetros de estado para la protección CSRF
Encabezados de seguridad aplicados mediante Helmet.js
Limitación de velocidad para la protección de puntos finales de API
Validación de entrada con el esquema Zod
Para obtener más detalles, consulte SECURITY.md .
Mantenimiento
Actualizaciones periódicas para mantener la compatibilidad con la API de Google Calendar
Las actualizaciones de versiones están documentadas en README.md
Solución de problemas
Si encuentra algún problema:
Asegúrese de que sus credenciales de Google OAuth estén configuradas correctamente
Asegúrese de tener permisos suficientes para acceder a la API de Google Calendar
Verifique que la configuración de Claude Desktop sea correcta
Errores comunes
Errores de análisis de JSON : Si ve errores como
Unexpected non-whitespace character after JSON at position 4 (line 1 column 5), suele deberse a mensajes JSON-RPC mal formados. Este problema se ha solucionado en la versión 0.6.7 y posteriores. Si persiste, actualice a la última versión.Errores de autenticación : Verifique sus credenciales de Google OAuth
Parámetro de estado no válido : Si al volver a autenticarse ve
Authentication failed: Invalid state parameter, actualice a la versión 1.0.3 o posterior, que corrige la gestión del ciclo de vida del servidor OAuth. En versiones anteriores, es posible que deba cerrar el puerto 4153 y reiniciar la aplicación.Errores de conexión : asegúrese de que solo se esté ejecutando una instancia del servidor
Problemas de desconexión : asegúrese de que su servidor esté manejando correctamente los mensajes MCP sin sockets TCP personalizados
No se puede acceder a localhost : Si ejecuta la aplicación en un entorno donde no se puede acceder a localhost (como un servidor remoto o un contenedor), habilite la autenticación manual configurando
USE_MANUAL_AUTH=true. Esto le permitirá ingresar manualmente el código de autorización que muestra Google después de autorizar la aplicación.
Historial de versiones
Cambios de la versión 1.0.6
Se solucionó el problema de que el alcance no es necesario en este servidor MCP del calendario de Google.
Cambios de la versión 1.0.5
Se agregó soporte para eventos recurrentes a través del parámetro
recurrenceen las herramientascreateEventyupdateEventPermite la creación y modificación de eventos recurrentes directamente sin configuración manual
Cambios de la versión 1.0.4
Versión de mantenimiento con actualización del número de versión
Sin cambios funcionales desde la versión 1.0.3
Garantiza la compatibilidad con las últimas dependencias.
Cambios de la versión 1.0.3
Se agregó una nueva herramienta
authenticatepara permitir la reautenticación sin reiniciar ClaudeSe hizo posible cambiar entre diferentes cuentas de Google durante una sesión
Funcionalidad de autenticación expuesta a través de la interfaz MCP
Experiencia de usuario mejorada al eliminar la necesidad de reiniciar para cambiar de cuenta
Se agregó la opción de autenticación manual para entornos donde no se puede acceder al host local
Se implementó la interfaz readline para ingresar códigos de autorización manualmente
Se agregó la variable de entorno USE_MANUAL_AUTH para habilitar la autenticación manual
Dependencia de zod actualizada a la última versión (3.24.2)
Validación de esquema mejorada con las últimas funciones de zod
Mayor estabilidad y seguridad del código
Se corrigió el error "Parámetro de estado no válido" durante la reautenticación.
Servidor OAuth modificado para iniciarse a pedido y apagarse después de la autenticación
Gestión mejorada del ciclo de vida del servidor para evitar conflictos de puertos
Manejo mejorado de errores para el flujo de autenticación
Cambios de la versión 1.0.2
Se corrigió la función
updateEventpara preservar los datos de eventos existentes al realizar actualizaciones parcialesSe agregó la función
getEventpara obtener datos de eventos existentes antes de actualizarSe modificó
updateEventpara fusionar los datos de actualización con los datos existentes para evitar la pérdida de datos.Se actualizó la validación del esquema para que todos los campos sean opcionales en las solicitudes de actualización
Documentación mejorada para la función
updateEvent
Cambios de la versión 1.0.1
Se solucionó el problema de compatibilidad con Node.js v20.9.0+ y el paquete 'open' (v10+)
Se reemplazó la importación estática con la importación dinámica para el paquete "abierto" exclusivo de ESM
Manejo de errores mejorado al abrir el navegador durante la autenticación OAuth
Comentarios de código mejorados para un mejor mantenimiento
Cambios de la versión 1.0.0
Lanzamiento de la versión principal que marca la preparación para la producción
Refactorización integral del código para una mejor mantenibilidad
Internacionalización de todos los mensajes y comentarios (traducidos del japonés al inglés)
Mayor consistencia y legibilidad del código
Mensajes de error mejorados para una mejor experiencia del usuario
Documentación actualizada para reflejar el estado actual del proyecto.
Estilo de codificación estandarizado en todo el código base
Cambios de la versión 0.8.0
Flujo de autenticación OAuth mejorado para gestionar problemas de token de actualización
Se agregó
prompt: 'consent'para obligar a Google a mostrar la pantalla de consentimiento y proporcionar un nuevo token de actualización.Flujo de autenticación modificado para funcionar solo con un token de acceso si no hay un token de actualización disponible
Lógica de actualización de token mejorada para manejar casos en los que no hay un token de actualización o si el token de actualización no es válido
Almacenamiento de tokens actualizado para guardar tokens de acceso actualizados para una mejor gestión de tokens
Se solucionó un posible bucle infinito en la lógica de actualización del token.
Desarrollo
Para contribuir a este proyecto:
Pruebas
Para ejecutar las pruebas:
Licencia
Instituto Tecnológico de Massachusetts (MIT)
This server cannot be installed
hybrid server
The server is able to function both locally and remotely, depending on the configuration or use case.
Un servidor de protocolo de contexto de modelo que integra Google Calendar con Claude Desktop, lo que permite a los usuarios administrar eventos del calendario (ver, crear, actualizar, eliminar) a través del lenguaje natural.
Related MCP Servers
- Asecurity-licenseAqualityModel Context Protocol server for Gmail integration. This allows Claude Desktop (or any MCP client) to interact with your Gmail account through Google Apps Script.Last updated -2612MIT License
- -security-license-qualityEnables comprehensive calendar management with capabilities to create, list, update, and delete events through a Model Context Protocol server integrated with Google Calendar.Last updated -143MIT License
- -security-license-qualityAllows interaction with Google Calendar through Claude Desktop using the Model Context Protocol, enabling calendar event management and schedule analysis.Last updated -2
- -security-license-qualityModel Context Protocol server that provides seamless access to Google Calendar API with asynchronous operation support, enabling efficient calendar management through a standardized interface.Last updated -1