
SF Cleaning Service
Enables booking cleaning services in San Francisco by collecting customer details and automatically sending booking requests via email to service partners.
README
IRL - SF Cleaning Service
IRL - A Model Context Protocol (MCP) server for booking cleaning services in San Francisco. Can be deployed locally or to Vercel for remote access.
Setup
1. Install Dependencies
npm install
2. Set Up Resend API
-
Create Resend Account: Go to https://resend.com and sign up
-
Get API Key:
- Navigate to your Resend Dashboard
- Go to "API Keys" section
- Create a new API key or copy your existing one
- It will look like:
re_BcASVtoX_Bj4QhZei4xSjyyLr21vhMbVd
-
Verify Domain (Required for custom email):
- To send from gwen@irl-concierge.com
- Go to "Domains" in Resend Dashboard
- Add domain: irl-concierge.com
- Follow DNS verification steps (add TXT, MX records)
- Once verified, you can send from gwen@irl-concierge.com
3. Configure Email Credentials
Edit .env
file with your Resend credentials:
RESEND_API_KEY=re_xxxxxxxxxxxxxxxxxx
FROM_EMAIL=gwen@irl-concierge.com
PARTNER_EMAILS=partner1@example.com,partner2@example.com
Note: You must verify the domain irl-concierge.com
in Resend before you can send from gwen@irl-concierge.com
. Until verified, use onboarding@resend.dev
for testing.
4. Configure Claude Desktop
Add to your Claude Desktop configuration file:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"sf-cleaning": {
"command": "node",
"args": ["/absolute/path/to/mcp-sf-cleaning/index.js"]
}
}
}
Replace /absolute/path/to/mcp-sf-cleaning/index.js
with the actual path to your index.js file.
5. Restart Claude Desktop
After configuration, restart Claude Desktop to load the MCP server.
Vercel Deployment (For Remote Access)
1. Install Vercel CLI
npm install -g vercel
2. Set Environment Variables
cd /Users/rana/Downloads/IRL/mcp-sf-cleaning
# Set up Vercel environment variables
vercel env add RESEND_API_KEY
# Enter: re_BcASVtoX_Bj4QhZei4xSjyyLr21vhMbVd
vercel env add FROM_EMAIL
# Enter: gwen@irl-concierge.com
vercel env add PARTNER_EMAILS
# Enter: ranadaytoday@outlook.com
3. Deploy to Vercel
vercel --prod
Follow the prompts:
- Set up and deploy? Y
- Which scope? (select your account)
- Link to existing project? N
- Project name? irl
- Directory? ./
- Want to modify settings? N
4. Get Your MCP Server URL
After deployment, you'll get a URL like:
https://mcp-sf-cleaning.vercel.app
5. Add to Claude Desktop as Custom Connector
- Open Claude Desktop
- Go to Settings → Connectors
- Click "Add custom connector"
- Enter:
- Name: SF Cleaning Service
- Remote MCP server URL:
https://mcp-sf-cleaning.vercel.app/api/mcp
- Save and restart Claude
Testing the Remote Server
You can test the API directly:
# List tools
curl -X POST https://mcp-sf-cleaning.vercel.app/api/mcp \
-H "Content-Type: application/json" \
-d '{"method":"tools/list"}'
# Request cleaning (SF address)
curl -X POST https://mcp-sf-cleaning.vercel.app/api/mcp \
-H "Content-Type: application/json" \
-d '{
"method": "tools/call",
"params": {
"name": "request_cleaning",
"arguments": {
"name": "John Doe",
"phone": "415-555-1234",
"address": "123 Market St, SF 94105"
}
}
}'
Test Conversation Examples
Example 1: San Francisco Address (Accepted)
You: Can you book a cleaning service for me?
Claude: I'll help you book a cleaning service. I'll need your name, phone number, and address.
You: Name is John Doe, phone is 415-555-0123, address is 123 Market St, San Francisco, CA 94105
Claude: [Uses request_cleaning tool]
Result: ✅ Sent! John Doe, they'll call 415-555-0123 within 1 hour.
Example 2: Non-SF Address (Rejected)
You: Book cleaning for Sarah Smith, 510-555-9876, 456 Broadway, Oakland, CA 94607
Claude: [Uses request_cleaning tool]
Result: Sorry, we only serve San Francisco currently. We're expanding - stay tuned!
Example 3: SF Zip Code Detection
You: I need cleaning at 789 Pine Street, 94108. Name: Alice Wong, Phone: 415-555-3456
Claude: [Uses request_cleaning tool]
Result: ✅ Sent! Alice Wong, they'll call 415-555-3456 within 1 hour.
Usage
The server provides one tool:
request_cleaning
: Books cleaning service for SF addresses only
Parameters:
name
: Customer namephone
: Contact phone numberaddress
: Service address (must be in San Francisco)
Responses:
- SF Address: "✅ Sent! [name], they'll call [phone] within 1 hour."
- Non-SF Address: "Sorry, we only serve San Francisco currently. We're expanding - stay tuned!"
How It Works
- Checks if address contains "sf", "san francisco", or SF zip codes (940xx, 941xx)
- If in SF: Sends email via Resend API to partners and confirms booking
- If not in SF: Returns polite rejection message
Why Resend?
- Simple API: Clean, modern email API designed for developers
- No SMTP hassles: No need for app passwords or complex SMTP settings
- Better deliverability: Built-in SPF, DKIM, and DMARC support
- Free tier: 3,000 emails/month free, perfect for small projectsTest auto-deployment
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.