Metadata-Version: 2.4
Name: claude-meet-mcp
Version: 1.0.0
Summary: AI-powered meeting scheduler using Claude and Google Calendar. Stop playing email tennis.
Author-email: Shaunak Inamdar <inamdarshaunak01@gmail.com>
Maintainer-email: Shaunak Inamdar <inamdarshaunak01@gmail.com>
License-Expression: MIT
Project-URL: Homepage, https://github.com/ShaunakInamdar/claude-meet-mcp
Project-URL: Documentation, https://github.com/ShaunakInamdar/claude-meet-mcp#readme
Project-URL: Repository, https://github.com/ShaunakInamdar/claude-meet-mcp
Project-URL: Issues, https://github.com/ShaunakInamdar/claude-meet-mcp/issues
Project-URL: Changelog, https://github.com/ShaunakInamdar/claude-meet-mcp/releases
Keywords: calendar,scheduling,claude,anthropic,ai,google-calendar,mcp,model-context-protocol,meeting,productivity,automation
Classifier: Development Status :: 4 - Beta
Classifier: Environment :: Console
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: End Users/Desktop
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Topic :: Office/Business :: Scheduling
Classifier: Topic :: Communications :: Conferencing
Classifier: Topic :: Utilities
Requires-Python: >=3.10
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: anthropic>=0.40.0
Requires-Dist: google-api-python-client>=2.100.0
Requires-Dist: google-auth-httplib2>=0.1.1
Requires-Dist: google-auth-oauthlib>=1.1.0
Requires-Dist: click>=8.1.7
Requires-Dist: python-dateutil>=2.8.2
Requires-Dist: pytz>=2023.3
Requires-Dist: python-dotenv>=1.0.0
Requires-Dist: mcp>=1.0.0
Provides-Extra: dev
Requires-Dist: pytest>=7.0.0; extra == "dev"
Requires-Dist: pytest-cov>=4.0.0; extra == "dev"
Requires-Dist: ruff>=0.1.0; extra == "dev"
Requires-Dist: build; extra == "dev"
Requires-Dist: twine; extra == "dev"
Dynamic: license-file

# Claude Meet MCP

**Stop playing email tennis. Let AI schedule your meetings in seconds.**

[![PyPI version](https://badge.fury.io/py/claude-meet-mcp.svg)](https://badge.fury.io/py/claude-meet-mcp)
[![Python 3.10+](https://img.shields.io/badge/python-3.10+-blue.svg)](https://www.python.org/downloads/)
[![License: MIT](https://img.shields.io/badge/License-MIT-green.svg)](https://opensource.org/licenses/MIT)
[![CI](https://github.com/ShaunakInamdar/claude-meet-mcp/actions/workflows/ci.yml/badge.svg)](https://github.com/ShaunakInamdar/claude-meet-mcp/actions)

---

### The Problem

> "Are you free Tuesday at 2pm?"
> "No, how about Wednesday?"
> "I have a conflict at 3..."
> "What about Thursday morning?"
> *[5 emails later, 30 minutes wasted]*

### The Solution

> **You:** "Schedule a meeting with john@example.com and alice@example.com next week"
> **Claude Meet:** *Checks all calendars, finds mutual availability, books the meeting*
> **Done in 10 seconds.**

**You save: 5+ hours per week on scheduling.**

---

[Quick Start](#quick-start-60-seconds) | [Demo](#see-it-in-action) | [Features](#features) | [Documentation](docs/)

---

## Why Claude Meet?

| Feature | Email Back-and-Forth | Calendly | **Claude Meet** |
|---------|---------------------|----------|-----------------|
| Checks everyone's calendar | Manual | One-way only | **Automatic** |
| Natural language | No | No | **Yes** |
| AI-powered time suggestions | No | No | **Yes** |
| Works from terminal | No | No | **Yes** |
| Integrates with Claude Desktop | No | No | **Yes** |
| Privacy-first (your data stays yours) | Yes | No | **Yes** |
| Cost | Free but slow | $10-15/mo | **Free** |

---

## See It In Action

### CLI Demo

```
$ claude-meet chat

Claude Calendar Scheduler
Timezone: Europe/Berlin
Type 'help' for commands, 'exit' to quit
============================================================

You: Schedule a 1-hour meeting with alice@company.com and bob@company.com tomorrow

Claude: I'll find a time that works for everyone. Checking calendars...

Found these available slots for tomorrow:
  1. 9:00 AM - 10:00 AM (Recommended - prime morning time)
  2. 2:00 PM - 3:00 PM (Good option)
  3. 4:00 PM - 5:00 PM

Which time works best? And what should I call this meeting?

You: Let's do 2pm, call it "Project Kickoff"

Claude: Done! I've created "Project Kickoff" for tomorrow 2:00 PM - 3:00 PM.
Calendar invites sent to alice@company.com and bob@company.com.
```

### Claude Desktop Integration

Use Claude Meet directly in Claude Desktop - just ask Claude to schedule meetings naturally:

```
You: Check when sarah@example.com is free next Tuesday

Claude: I checked Sarah's calendar for next Tuesday. She's available:
  - 9:00 AM - 11:30 AM
  - 2:00 PM - 5:00 PM

Would you like me to schedule a meeting?
```

<!-- TODO: Add GIF demos and video tutorial -->

---

## Quick Start (60 seconds)

### Step 1: Install

```bash
pip install claude-meet-mcp
```

### Step 2: Setup

```bash
claude-meet init
```

The wizard guides you through:
- Setting your Anthropic API key
- Connecting Google Calendar (with step-by-step instructions)
- Configuring your timezone

### Step 3: Start scheduling

```bash
claude-meet chat
```

**That's it.** No complex configuration. No YAML files. Just works.

<details>
<summary>Alternative: Install from source</summary>

```bash
git clone https://github.com/ShaunakInamdar/claude-meet-mcp.git
cd claude-meet-mcp
pip install -e .
```

</details>

---

## Features

### Talk Naturally
No commands to memorize. No special syntax. Just tell Claude what you need.

```
"Find a time for a 30-minute sync with the design team next week"
"Schedule a demo with client@company.com on Friday afternoon"
"When is everyone free for a team lunch?"
```

### Smart Conflict Detection
Never double-book again. Claude Meet checks everyone's calendar before suggesting times.

### Intelligent Time Suggestions
Times are ranked by preference:
- Avoids early mornings and late evenings
- Respects lunch hours
- Prefers prime collaboration times (9-11 AM)

### Google Meet Integration
Add video conferencing with one word:

```
"Schedule a video call with remote-team@company.com tomorrow"
```

### Works Everywhere
- **CLI**: For terminal lovers
- **Claude Desktop**: Native MCP integration
- **Claude.ai**: Use as an MCP tool

---

## Perfect For

### Engineering Managers
- Schedule 1-on-1s across your entire team in minutes
- Find time for all-hands when everyone's calendar is packed
- Coordinate cross-team meetings without the back-and-forth

### Remote Teams
- Handles multiple timezones automatically
- Finds overlapping work hours across continents
- Async-first: schedule now, meet later

### Founders & Sales
- Book demos with prospects instantly
- Coordinate investor meetings efficiently
- Stop losing deals to scheduling friction

---

## Claude Desktop Integration

Add Claude Meet to Claude Desktop for seamless scheduling:

```bash
claude-meet mcp-setup
```

This generates the config to add to your Claude Desktop settings. Once configured, Claude can schedule meetings directly from your conversations.

### Available Tools

| Tool | What It Does |
|------|--------------|
| `check_calendar_availability` | See when people are free or busy |
| `find_meeting_times` | Get AI-ranked suggestions for meeting times |
| `create_calendar_event` | Book meetings and send invites |

[Full MCP setup guide](docs/MCP_SETUP.md)

---

## Configuration

Customize Claude Meet to match your work style:

```bash
# Set your timezone
claude-meet config set TIMEZONE=America/New_York

# Change business hours
claude-meet config set BUSINESS_HOURS_START=8
claude-meet config set BUSINESS_HOURS_END=18

# View all settings
claude-meet config
```

| Setting | Default | Description |
|---------|---------|-------------|
| `TIMEZONE` | Auto-detected | Your local timezone |
| `BUSINESS_HOURS_START` | 9 | When your workday starts |
| `BUSINESS_HOURS_END` | 17 | When your workday ends |
| `DEFAULT_DURATION` | 60 | Default meeting length (minutes) |

---

## Commands

| Command | Description |
|---------|-------------|
| `claude-meet init` | Interactive setup wizard |
| `claude-meet chat` | Start scheduling conversations |
| `claude-meet check` | Verify your setup is working |
| `claude-meet config` | View/edit configuration |
| `claude-meet auth` | Re-authenticate with Google |
| `claude-meet mcp-setup` | Get Claude Desktop config |
| `claude-meet upcoming` | See your next meetings |

---

## Architecture

```
┌─────────────────┐     ┌──────────────────┐     ┌─────────────────┐
│   Claude CLI    │────▶│   Claude API     │────▶│ Calendar Client │
│   or Desktop    │     │  (Tool Calling)  │     │  (Google API)   │
└─────────────────┘     └──────────────────┘     └─────────────────┘
                                │
                                ▼
                        ┌──────────────────┐
                        │    Scheduler     │
                        │ (Time Ranking)   │
                        └──────────────────┘
```

**How it works:**
1. You describe what you need in natural language
2. Claude interprets your request and calls the right tools
3. Calendar Client checks Google Calendar for availability
4. Scheduler ranks times by preference
5. Claude presents options and books your choice

---

## Troubleshooting

Run the diagnostic command first:

```bash
claude-meet check
```

This shows what's configured and what needs attention.

### Common Issues

**"API key not found"**
```bash
claude-meet config set ANTHROPIC_API_KEY=sk-ant-...
```

**"Google credentials not found"**
```bash
claude-meet init  # Follow the Google Cloud setup steps
```

**"Authentication expired"**
```bash
claude-meet logout && claude-meet auth
```

[Full troubleshooting guide](docs/TROUBLESHOOTING.md)

---

## Contributing

We welcome contributions! See our [Contributing Guide](CONTRIBUTING.md) for details.

```bash
# Run tests
pytest tests/ -v

# Run linting
ruff check claude_meet/
```

---

## Privacy & Security

- **Your data stays yours**: We never see your calendar data
- **Local tokens**: Google OAuth tokens stored locally in `~/.claude-meet/`
- **No tracking**: Zero analytics or telemetry
- **Open source**: Audit the code yourself

---

## Support the Project

If Claude Meet saves you time:

- **Star this repo** to help others find it
- **Report bugs** to help us improve
- **Share** with colleagues who hate scheduling

---

## License

MIT License - Use it however you want.

---

<p align="center">
  <b>Stop scheduling manually. Let AI do it.</b>
  <br><br>
  <a href="#quick-start-60-seconds">Get Started</a> ·
  <a href="https://github.com/ShaunakInamdar/claude-meet-mcp/issues">Report Bug</a> ·
  <a href="https://github.com/ShaunakInamdar/claude-meet-mcp/issues">Request Feature</a>
</p>
