Booking System (Fixed)
Fixed booking system with Google Calendar integration, email confirmations, and MCP Server integration
Konstrex
README
Booking System (Fixed)
This repository contains the fixed version of the booking system for Andriana Delcheva, addressing several critical issues with the previous implementation. The system is designed to run on Cloudflare Workers and integrates with Google Calendar and MCP Servers.
🛠️ Fixed Issues
This implementation resolves the following issues that were present in the original system:
- Fixed Booking Completion - Users can now successfully select a date and complete bookings.
- Fixed Confirmation Emails - Email confirmations are now sent after successful bookings.
- Fixed Google Calendar Integration - Bookings now create events in Google Calendar.
- Implemented Availability Checking - The system checks for available slots before confirming bookings.
- Implemented MCP Server Integration - Backend processing uses MCP Servers for enhanced functionality.
🌟 Key Features
- Multi-step Booking Process - Intuitive step-by-step booking flow for better UX
- Real-time Availability Checking - Checks Google Calendar for conflicts
- Automated Email Confirmations - Sends details to the customer
- Google Calendar Integration - Creates calendar events with service details
- MCP Server Integration - Tracks booking events and provides enhanced processing
- Comprehensive Error Handling - Provides meaningful feedback to users
- Responsive Design - Works on mobile and desktop devices
🚀 Deployment
Prerequisites
- Cloudflare Workers account
- Google Cloud project with Calendar API enabled
- Google service account with access to the Calendar
- MCP Server for backend processing
Setup Instructions
- Clone the repository
git clone https://github.com/Konstrex/booking-system-fixed.git
cd booking-system-fixed
- Install dependencies
npm install
- Configure environment variables
The following environment variables need to be set either in the wrangler.toml file or using Cloudflare's secrets:
-
Google Calendar Integration
GOOGLE_CLIENT_EMAIL
- Already configured to "andrianadelcheva@totemic-point-453101-s4.iam.gserviceaccount.com"GOOGLE_PRIVATE_KEY
- Your service account private keyGOOGLE_CALENDAR_ID
- The ID of the calendar to use
-
Email Configuration
EMAIL_FROM
- Email address to send confirmations fromBUSINESS_NAME
- Name of the business (already set to "Andriana Delcheva")BUSINESS_EMAIL
- Business email for reply-to
-
MCP Server Integration
MCP_ENABLED
- Set to "true" to enable MCP integrationMCP_SERVER_URL
- URL of the MCP serverMCP_API_KEY
- API key for authenticating with the MCP server
- Set secrets using Wrangler
For sensitive information, use Wrangler's secret management:
wrangler secret put GOOGLE_PRIVATE_KEY
wrangler secret put GOOGLE_CALENDAR_ID
wrangler secret put MCP_SERVER_URL
wrangler secret put MCP_API_KEY
- Deploy to Cloudflare Workers
npm run deploy:prod
📝 Google Calendar Setup
To ensure the Google Calendar integration works properly:
-
Ensure the service account has appropriate permissions by adding it to your Google Calendar:
- Open Google Calendar
- Go to Calendar Settings
- Under "Share with specific people," add the service account email:
andrianadelcheva@totemic-point-453101-s4.iam.gserviceaccount.com
- Set permissions to "Make changes and manage sharing"
-
The JWT authentication is configured to use the correct token_uri:
https://oauth2.googleapis.com/token
📧 Email Configuration
The system uses MCP Servers for handling email notifications. After a successful booking, an email is sent containing:
- Subject: "Booking Confirmation"
- Appointment details (date, time, service)
- Google Calendar link
- Booking reference number
🤖 MCP Server Integration
MCP Servers are used for enhanced functionality:
-
Event Notifications - MCP is notified about key events:
- Availability checks
- Booking creations
- Email confirmations
- Calendar event creations
-
Error Handling - MCP receives detailed error information for monitoring and debugging.
-
Booking Processing - The system can offload the entire booking process to MCP if configured.
🧪 Testing
To test the system locally:
npm run dev:local
For end-to-end testing:
- Select a date and service
- Check available time slots
- Enter customer details
- Complete the booking
- Verify the appointment appears in Google Calendar
- Confirm the confirmation email is received
📚 Technical Implementation Details
Fixed Booking Flow
The booking flow has been completely reworked to ensure a single API request is made when booking. Key improvements:
- Multi-step form with validation at each step
- Single API call for the final booking request
- Clear error messages for failed bookings
- Loading indicators during API calls
Fixed Google Calendar Integration
The Google Calendar integration now:
- Uses proper JWT authentication with the service account
- Checks for existing events before booking
- Creates detailed calendar events with all booking information
- Properly formats dates and times
- Includes attendees and reminders
Enhanced Error Handling
Comprehensive error handling has been implemented:
- Validation errors with specific messages
- Network error handling with retry options
- Server error logging with MCP integration
- User-friendly error messages
📋 API Endpoints
Check Availability
POST /api/availability
Request body:
{
"date": "2025-03-15",
"duration": 60
}
Response:
{
"success": true,
"availableSlots": [
{ "startTime": "09:00", "endTime": "10:00" },
{ "startTime": "10:00", "endTime": "11:00" },
/* ... */
]
}
Book Appointment
POST /api/book
Request body:
{
"name": "John Doe",
"email": "john@example.com",
"phone": "+1234567890",
"date": "2025-03-15",
"time": "10:00",
"services": [
{
"name": "Massage",
"duration": 60,
"price": 80
}
],
"notes": "Optional notes",
"agreed": true
}
Response:
{
"success": true,
"message": "Booking created successfully",
"bookingId": "BK-JOHNDO-123456",
"eventId": "calendar_event_id"
}
🔄 Continuous Improvement
Future improvements could include:
- Adding a dashboard for managing bookings
- Implementing booking cancellation/rescheduling
- Adding payment integration
- Creating a customer account system
Recommended Servers
contentful-mcp
Update, create, delete content, content-models and assets in your Contentful Space

Supabase MCP Server
A Model Context Protocol (MCP) server that provides programmatic access to the Supabase Management API. This server allows AI models and other clients to manage Supabase projects and organizations through a standardized interface.

Azure MCP Server
Enables natural language interaction with Azure services through Claude Desktop, supporting resource management, subscription handling, and tenant selection with secure authentication.

SettleMint
Leverage SettleMint's Model Context Protocol server to seamlessly interact with enterprise blockchain infrastructure. Build, deploy, and manage smart contracts through AI-powered assistants, streamlining your blockchain development workflow for maximum efficiency.

Brev
Run, build, train, and deploy ML models on the cloud.

Story SDK MCP Server
This server provides MCP (Model Context Protocol) tools for interacting with Story's Python SDK. Features Get license terms Mint and register IP Asset with PIL Terms Mint license tokens Send $IP to a wallet Upload image to ipfs via Pinata [External] Upload ip and nft metadata via Pinata [External]

Tembo MCP Server
An MCP server that enables Claude to interact with Tembo Cloud platform API, allowing users to manage Tembo Cloud resources through natural language.

Workers MCP
A package that connects Claude Desktop and other MCP clients to Cloudflare Workers, enabling custom functionality to be accessed via natural language through the Model Context Protocol.

Appwrite MCP Server
A Model Context Protocol server that allows AI assistants to interact with Appwrite's API, providing tools to manage databases, users, functions, teams, and other resources within Appwrite projects.
MCP2Lambda
Enables AI models to interact with AWS Lambda functions via the MCP protocol, allowing access to private resources, real-time data, and custom computation in a secure environment.