Meetbot
Meet.bot is AI-native scheduling for people and agents. Check real calendar availability and book meetings on Google and Microsoft calendars through scheduling pages — and pay per meeting booked, not per user or seat. Actions: Book Meeting, Find Slots, Get Scheduling Page Info.
README
Meet.bot MCP (Model Context Protocol)
A Model Context Protocol (MCP) server for the Meet.bot Booking Page API, enabling AI assistants to interact with scheduling and booking functionality.
What is this?
This MCP server connects AI assistants (like Claude, ChatGPT, and others that support MCP) to your Meet.bot account, allowing them to schedule meetings on your behalf. Instead of manually copying booking links or checking your calendar, you can simply ask your AI assistant to "schedule a 30-minute meeting with John next week" and it will handle the booking through your MeetBot scheduling pages.
How it works:
- Connect your MeetBot API token to the MCP server
- Configure your AI assistant to use this MCP server
- Ask your AI assistant to schedule meetings - it can check your availability, find time slots, and book meetings directly through your MeetBot account
This is particularly useful for busy professionals who want to automate meeting scheduling and let their AI assistant manage their calendar intelligently.
If you don't have an account, you can get one for free at https://meet.bot
Features
- Complete API Coverage: Implements all endpoints from the Meet.bot Booking Page API v1
- Type Safety: Full TypeScript support with comprehensive type definitions
- Runtime Validation: Zod schemas for input validation and data integrity
- Authentication Support: Bearer token authentication
- Error Handling: Robust error handling with detailed error messages
- Health Checks: Built-in health monitoring using the /v1/pages endpoint
- MCP Protocol Compliance: Full Model Context Protocol server implementation
- Dual Mode Support: Run locally (stdio) or remotely (HTTP/SSE)
- Production Deployed: Live at https://mcp.meet.bot
- Production Ready: Thoroughly tested and validated for production use
Installation
npm install @meetbot/mcp
Quick Start
1. Install and Configure
# Install the package
npm install @meetbot/mcp
# Or install globally for CLI usage
npm install -g @meetbot/mcp
2. Authentication
Authentication is not a tool—it is connection-based:
- HTTP/SSE (remote, e.g. https://mcp.meet.bot): Send
Authorization: Bearer <your_api_token>in the request headers when connecting. The server uses this token for all API calls in that session. - Stdio (local): Set the
MEETBOT_AUTH_TOKENenvironment variable when starting the server (e.g.MEETBOT_AUTH_TOKEN=your_token npx @meetbot/mcp).
There is no configure_meetbot or similar tool; the AI uses the tools below and auth is handled by the connection.
3. Use the Available Tools
The MCP server provides the following tools:
Get Scheduling Pages
await get_scheduling_pages();
// Returns all scheduling pages for the authenticated user
Get Page Information
await get_page_info({
page: "https://meet.bot/user/30min"
});
// Returns detailed information about a specific scheduling page
Get Available Slots
await get_available_slots({
page: "https://meet.bot/user/30min",
count: 10,
start: "2025-01-01",
end: "2025-01-31",
timezone: "America/New_York",
booking_link: true
});
// Returns available booking slots with optional filters
Book a Meeting
await book_meeting({
page: "https://meet.bot/user/30min",
guest_email: "guest@example.com",
guest_name: "Jane Doe",
notes: "Meeting to discuss project requirements",
start: "2025-01-15T14:00:00Z"
});
// Books a new meeting slot
Health Check
await health_check();
// Verifies API connectivity using the /v1/pages endpoint
Webhooks
Get notified the moment a meeting is booked, rescheduled, or cancelled. Meet.bot POSTs a JWT-signed (HS256) JSON payload — the same contract as the partner webhook — to your URL for each event (booking_received, booking_rescheduled, booking_cancelled).
// List your webhooks
await list_webhooks();
// Create (omit id) or update (pass id) a webhook
await set_webhook({
webhook_url: "https://your-app.example.com/meetbot-hook",
description: "CRM sync",
coverage: "all", // or "selected" with pages: [<page id>, ...]
scope: "self" // team admins can use "team" to also receive teammates' bookings
});
// Returns the webhook including the shared secret used to verify the signature.
// Delete a webhook
await delete_webhook({ id: 123 });
Deployment Options
The MCP server can be run in two modes:
1. Local Mode (Stdio Transport)
For local integration with AI assistants like Claude Desktop. Uses stdio transport for communication.
# Run locally
npx @meetbot/mcp
# Or with environment variable
MEETBOT_AUTH_TOKEN="your_token" npx @meetbot/mcp
2. HTTP Mode (SSE Transport)
For remote deployment with HTTP/SSE transport. This allows the MCP server to be accessed over the network.
Running the HTTP Server
# Build and start the HTTP server
npm run build
npm run start:http
# Or with custom port
PORT=8080 npm run start:http
# Or run directly with npx
npx meetbot-mcp-http
Server Endpoints
- SSE Endpoint:
GET /sse- Establishes an SSE connection for MCP communication - Messages Endpoint:
POST /messages?sessionId=<id>- Receives client messages - Health Check:
GET /health- Server health status
Authentication
All requests require a Bearer token in the Authorization header:
Authorization: Bearer <your-meetbot-api-token>
The same token is used to authenticate with the Meet.bot API.
Testing the HTTP Server
Local Testing:
# Health check (should fail without auth)
curl http://localhost:3000/health
# Health check with authentication
curl -H "Authorization: Bearer YOUR_TOKEN" http://localhost:3000/health
# Connect to SSE endpoint
curl -N -H "Authorization: Bearer YOUR_TOKEN" http://localhost:3000/sse
# Or use the test script
./test-http-server.sh YOUR_TOKEN
Production Testing:
# Test the live deployment
curl -H "Authorization: Bearer YOUR_TOKEN" \
https://mcp.meet.bot/health
# Expected response:
# {"status":"ok","service":"meetbot-mcp"}
Deployment
The HTTP server can be deployed to various platforms:
- Railway:
railway up✅ Live at https://mcp.meet.bot - Fly.io:
fly launch && fly deploy - Google Cloud Run: Container-based deployment
- AWS App Runner: Container-based deployment
- Any VPS: Run with Node.js directly
Example: Connecting to Production
# Your MCP client should connect to:
# https://mcp.meet.bot/sse
# With Authorization header:
# Authorization: Bearer <your-meetbot-api-token>
Example Dockerfile:
FROM node:18-alpine
WORKDIR /app
COPY package*.json ./
RUN npm ci --only=production
COPY dist ./dist
EXPOSE 3000
CMD ["node", "dist/cli-http.js"]
MCP Integration
Using with AI Assistants
This MCP server can be integrated with AI assistants like Claude, ChatGPT, and others that support the Model Context Protocol.
Configuration Example
{
"mcpServers": {
"meetbot": {
"command": "npx",
"args": ["@meetbot/mcp"],
"env": {
"MEETBOT_AUTH_TOKEN": "your_bearer_token_here"
}
}
}
}
Available MCP Tools
The server exposes 8 tools for AI assistants:
get_scheduling_pages- List all scheduling pagesget_page_info- Get page detailsget_available_slots- Find available time slotsbook_meeting- Book a meetinghealth_check- Verify API connectivity using /v1/pages endpointlist_webhooks- List your outbound booking webhooksset_webhook- Create or update a webhook (booking_received / booking_rescheduled / booking_cancelled)delete_webhook- Delete a webhook
Authentication is provided by the connection (Bearer token in HTTP header for remote, or MEETBOT_AUTH_TOKEN for local stdio)—there is no separate configure tool.
Testing and Validation
The package has been thoroughly tested and validated:
✅ MCP Protocol Compliance: Full JSON-RPC 2.0 support ✅ Tool Discovery: All 5 tools properly exposed ✅ Error Handling: Graceful error responses ✅ Type Safety: Complete TypeScript support ✅ Schema Validation: Input validation with Zod ✅ Production Ready: Tested with real MCP clients
Package Statistics
- Package Size: 12.8 kB (58.0 kB unpacked)
- Test Coverage: 21 passing tests
- Dependencies: 3 production dependencies
- TypeScript: 100% type coverage
- Build Status: ✅ Passing
- npm Registry: Published and available
Usage Examples
As a Library
import { MeetbotClient, MeetbotMCPServer } from '@meetbot/mcp';
// Use as a direct API client
const client = new MeetbotClient({
authToken: 'your_token'
});
// Use as an MCP server
const server = new MeetbotMCPServer();
await server.run();
As an MCP Server
# Run the MCP server
npx @meetbot/mcp
# Or install globally
npm install -g @meetbot/mcp
meetbot-mcp
API Reference
MeetbotClient
The core API client for direct integration:
import { MeetbotClient } from '@meetbot/mcp';
const client = new MeetbotClient({
authToken: 'your_token'
});
// Get all scheduling pages
const pages = await client.getPages();
// Get page information
const pageInfo = await client.getPageInfo({
page: 'https://meet.bot/user/30min'
});
// Get available slots
const slots = await client.getSlots({
page: 'https://meet.bot/user/30min',
count: 20
});
// Book a meeting
const booking = await client.bookSlot({
page: 'https://meet.bot/user/30min',
guest_email: 'guest@example.com',
guest_name: 'Jane Doe',
start: '2025-01-15T14:00:00Z'
});
Data Types
All API responses are fully typed:
interface BookSlot {
success: boolean;
page: string;
guest_email: string;
guest_name: string;
notes?: string;
start: string;
ical_uid: string;
}
interface PageInfo {
title: string;
duration: number;
url: string;
owner_name: string;
max_days_into_the_future: number;
}
interface Slots {
count: number;
duration: number;
slots: SlotDetails[];
}
Configuration
Environment Variables
You can configure the MCP server using environment variables:
export MEETBOT_AUTH_TOKEN="your_bearer_token"
# Then run the server
meetbot-mcp
Authentication
Auth is connection-based, not a tool:
- HTTP/SSE: Send
Authorization: Bearer <token>in request headers when connecting to the MCP server. - Stdio: Set
MEETBOT_AUTH_TOKENwhen running the server (e.g.MEETBOT_AUTH_TOKEN=your_token meetbot-mcp).
Development
Running Tests
npm test
npm run test:watch
Linting
npm run lint
npm run lint:fix
CLI Usage
The package includes a command-line interface for running the MCP server:
# Install globally
npm install -g @meetbot/mcp
# Run the MCP server
meetbot-mcp
# Or run directly with npx (no installation required)
npx @meetbot/mcp
Environment Variables
You can configure the server using environment variables:
export MEETBOT_AUTH_TOKEN="your_bearer_token"
# Then run the server
meetbot-mcp
Error Handling
The MCP server provides detailed error messages for common issues:
- Configuration Errors: Missing or invalid configuration parameters
- Authentication Errors: Invalid tokens
- API Errors: Detailed error messages from the Meet.bot API
- Validation Errors: Input validation failures with specific field errors
Contributing
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests for new functionality
- Submit a pull request
License
MIT License - see LICENSE file for details.
Support
- Documentation: https://docs.meet.bot
- Issues: GitHub Issues
- Discussions: GitHub Discussions
Changelog
1.2.10
- Fix (stdio startup crash): the stdio server (
npx @meetbot/mcp) declared a tools handler without advertising thetoolscapability, so the MCP SDK threw "Server does not support tools" and the process exited on launch. Now declarescapabilities.tools; the server boots and answersinitialize+tools/list(no token needed for introspection).
1.2.9
- Server card: Added
/.well-known/mcp/server-card.jsonfor discovery and manual metadata (tools, prompts, authentication) - Smithery quality: Tool annotations (
audience,priority), richer parameter descriptions, and prompts capability for quality scoring - Prompts (skills): Six MCP prompts for Smithery and clients:
schedule_meeting,check_availability,book_for_guest,share_booking_link,list_my_pages,suggest_timeswith fullprompts/listandprompts/getsupport
1.2.7
- Example Config Update: Removed obsolete
MEETBOT_BASE_URLfrom example configuration (base URL is hardcoded to https://meet.bot)
1.2.6
- Documentation Updates: Updated production URL from Railway to https://mcp.meet.bot
- Enhanced README: Added "What is this?" section explaining the MCP's purpose and how to use it for scheduling meetings through MeetBot accounts
- User Onboarding: Added link to sign up for a free Meet.bot account
1.2.5
- Jest Configuration: Updated Jest configuration for ES module support
- Build Improvements: Excluded test files from TypeScript compilation
- Publishing: Refined publishing checklist and documentation
1.1.1
- ES Module Fix: Fixed ES module compatibility for Railway and other Node.js deployments
- Import Extensions: Added proper
.jsextensions to all relative imports - Live Deployment: Successfully deployed to https://mcp.meet.bot
- Production Validated: Confirmed working in production environment
1.1.0
- HTTP/SSE Transport: Added HTTP server with SSE transport for remote deployment
- Bearer Token Authentication: Implemented authentication for HTTP endpoints
- Multi-mode Support: Can run as local stdio server or remote HTTP server
- Deployment Ready: Added Dockerfile and deployment configurations for Railway, Fly.io, etc.
- Health Check Endpoint: Added
/healthendpoint for monitoring - Session Management: Proper session handling with transport cleanup
- Production Ready: Complete HTTP implementation with authentication and error handling
1.0.4
- Fixed Health Check: Now uses the real
/v1/pagesendpoint instead of a fake health endpoint - Updated Documentation: Clarified health check implementation details
- Improved Reliability: Health check now properly validates API connectivity
1.0.3
- Simplified Configuration: Removed baseUrl requirement - now hardcoded to https://meet.bot
- Updated Documentation: Simplified configuration examples
- Improved UX: Users only need to provide authToken
1.0.2
- Fixed Authentication: Removed unsupported sessionId parameter
- Corrected API URL: Updated from api.meet.bot to meet.bot
- Updated Documentation: Accurate authentication examples
1.0.1
- Enhanced Documentation: Comprehensive README with usage examples
- MCP Integration Guide: Added AI assistant configuration examples
- Testing Results: Added validation and testing information
1.0.0
- Initial release - Production-ready MCP server for Meet.bot API
- Complete API coverage - All Meet.bot Booking Page API v1 endpoints
- TypeScript support - Full type safety with comprehensive definitions
- Runtime validation - Zod schemas for input validation and data integrity
- MCP server implementation - Full Model Context Protocol compliance
- CLI tool - Command-line interface for running the MCP server
- Error handling - Robust error handling with detailed messages
- Authentication - Support for bearer token authentication
- Health checks - Built-in API connectivity monitoring using /v1/pages endpoint
- Testing - Comprehensive test suite with 21 passing tests
- Documentation - Complete API documentation and usage examples
- Functional Testing - Verified with real MCP client requests
- npm Publishing - Successfully published to npm registry
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.