Metadata-Version: 2.4
Name: radiomcp
Version: 1.1.0
Summary: Internet radio MCP server + TUI player - 55,000+ stations, Airtune API, mpv playback
Project-URL: Homepage, https://github.com/meshpop/radiomcp
Project-URL: Repository, https://github.com/meshpop/radiomcp
Project-URL: Issues, https://github.com/meshpop/radiomcp/issues
Author-email: meshpop <mpop@mpop.dev>
License: MIT
License-File: LICENSE
Keywords: ai,claude,internet-radio,mcp,music,radio,streaming
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: End Users/Desktop
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: MacOS
Classifier: Operating System :: POSIX :: Linux
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 :: Internet
Classifier: Topic :: Multimedia :: Sound/Audio
Requires-Python: >=3.9
Requires-Dist: mcp[cli]>=1.0.0
Provides-Extra: dev
Requires-Dist: black; extra == 'dev'
Requires-Dist: pytest; extra == 'dev'
Requires-Dist: ruff; extra == 'dev'
Description-Content-Type: text/markdown

# Airtune

Search and play 41,000+ verified internet radio stations from 200+ countries.

Powered by [Airtune API](https://api.airtune.ai) | [korean](README.ko.md)

## Components

| Component | Description |
|-----------|-------------|
| **radiomcp** | MCP Server + HTTP API + CLI - integrates with Claude Desktop, Codex, GPT |
| **radio** | TUI App - interactive terminal player |

## radiomcp (MCP Server)

### Installation

```bash
pipx install radiomcp
```

> **Note:** Use `pipx` (recommended) to ensure the `radio` command is automatically added to your PATH.
> If you prefer `pip`, you may need to add the scripts directory to your PATH manually.
> Install pipx: `brew install pipx` (macOS) or `pip install pipx` (Linux/Windows)

### Player Installation (Optional)

Install one of the following for better playback quality. Falls back to browser if none installed.

| Player | macOS | Linux | Windows |
|--------|-------|-------|---------|
| **mpv** (recommended) | `brew install mpv` | `apt install mpv` | `winget install mpv` |
| **VLC** | `brew install vlc` | `apt install vlc` | [vlc.io](https://vlc.io) |
| **ffplay** | `brew install ffmpeg` | `apt install ffmpeg` | [ffmpeg.org](https://ffmpeg.org) |

**Auto-detection priority:** mpv > vlc > ffplay > browser

### Claude Desktop Configuration

`claude_desktop_config.json`:
```json
{
  "mcpServers": {
    "radio": {
      "command": "python3",
      "args": ["-m", "radiomcp"]
    }
  }
}
```

### CLI Mode

```bash
radiomcp search jazz
radiomcp search "korean news"
radiomcp play <url> "Station Name"
radiomcp stop
radiomcp now
radiomcp recommend focus
radiomcp update              # Update station DB from Airtune API
radiomcp serve --port 8100   # Start HTTP API server
```

### Usage with Claude

Ask Claude in natural language:
- "Play some jazz radio"
- "Find Korean news stations"
- "What's playing now?"
- "Stop the radio"

### Player Backends

| Backend | Description |
|---------|-------------|
| **mpv** | Best quality, auto-reconnect, ICY metadata |
| **vlc** | Widely installed, stable |
| **ffplay** | Included with ffmpeg, lightweight |
| **browser** | No installation needed, auto fallback |

See [radiomcp/README.md](radiomcp/README.md) for details.

---

## radio (TUI)

Interactive terminal player for internet radio. Installed with `pip install radiomcp`.

### Installation

```bash
# Required
brew install mpv

# Optional (for song recognition)
brew install ffmpeg
pip install openai-whisper
```

### Run

```bash
radio
```

### Usage

#### Search

```
> jazz              # keyword search
> korea news        # combined search
> relaxing music    # mood search
> japan classical   # multilingual
```

| Key | Function |
|-----|----------|
| `g` | Genre selection |
| `c` | Country selection |
| `p` | Popular stations |
| `h` | High quality (256k+) |
| `/` | Search mode |
| `!` | Toggle search mode (DB only/DB+API) |

#### Search Modes

| Mode | Speed | Description |
|------|-------|-------------|
| DB only | 0.1s | Local SQLite (default, instant) |
| DB+API | 1s+ | Includes RadioGraph API |

Toggle with `!` key

#### AI Recommendations

| Key | Function |
|-----|----------|
| `a` | Personalized recommendations |
| `t` | View taste analysis |
| `w` | Time-based mood recommendations |

#### Song Info

| Key | Function |
|-----|----------|
| `n` | Current song |
| `i` | Song recognition (Shazam-like) |
| `il` | Recognized songs list |

#### Song History (Auto)

Songs are automatically saved when track changes.

| Key | Function |
|-----|----------|
| `sl` | View song history |
| `st` | Toggle song history on/off |
| `sc` | Clear song history |

#### Favorites

| Key | Function |
|-----|----------|
| `f` | View favorites |
| `+` | Add to favorites |
| `-` | Remove from favorites |
| `<` | Previous favorite |
| `>` | Next favorite |
| `l` | Playlists |
| `pl name type` | Create playlist |

Playlist types: `favorites`, `history`, `mood`, `ai`, `tag:jazz`, `country:KR`

#### Playback

| Key | Function |
|-----|----------|
| `number` | Play station |
| `r` | Resume last station |
| `s` | Stop |
| `q` | Quit |

Auto-fetches latest URL on play (handles token expiration)

#### Volume Control

| Key | Function |
|-----|----------|
| `v` | Show volume |
| `v+` | Volume up |
| `v-` | Volume down |
| `v50` | Set volume to 50% |

#### DJ Mode

```bash
RADIOCLI_DJ=1 radio
```

| Key | Function |
|-----|----------|
| `d` | Toggle DJ mode |

Supports 10 languages: English, Korean, Japanese, French, German, Spanish, Chinese, Portuguese, Russian, Italian

### DB Management

```bash
radio --db-stats         # DB statistics
radio --cleanup          # Clean dead stations
radiomcp update          # Sync latest stations from RadioGraph API
```

## Multilingual Search

Supports 50+ languages including:

| Language | Example | Converts to |
|----------|---------|-------------|
| English | jazz, classical, news | jazz, classical, news |
| Korean | jazz, classical, news | jazz, classical, news |
| Japanese | ジャズ, クラシック | jazz, classical |
| Chinese | 爵士乐, 古典音乐 | jazz, classical |
| Russian | джаз, классика | jazz, classical |
| Arabic | موسيقى, أخبار | music, news |
| Hindi | संगीत, समाचार | music, news |

## Quality Filters

Include in search:

| Keyword | Filter |
|---------|--------|
| HQ, high quality | 192k+ |
| HD | 256k+ |
| LQ, low quality | 96k or less |

Example: `jazz HQ`

## Environment Variables

| Variable | Description | Default |
|----------|-------------|---------|
| `RADIOCLI_LLM` | LLM provider | `none` |
| `RADIOCLI_DJ` | DJ mode | `0` |
| `RADIOCLI_LANG` | UI language | auto |
| `RADIOCLI_VOICE` | TTS voice | `en-US-JennyNeural` |
| `OLLAMA_MODEL` | Ollama model | `llama3.2` |
| `OLLAMA_URL` | Ollama server | `http://localhost:11434` |
| `ANTHROPIC_API_KEY` | Claude API key | - |
| `OPENAI_API_KEY` | OpenAI API key | - |

## TTS Voices

| Voice | Language |
|-------|----------|
| `en-US-JennyNeural` | English (Female) |
| `ko-KR-SunHiNeural` | Korean (Female) |
| `ja-JP-NanamiNeural` | Japanese (Female) |
| `fr-FR-DeniseNeural` | French (Female) |
| `de-DE-KatjaNeural` | German (Female) |
| `zh-CN-XiaoxiaoNeural` | Chinese (Female) |

## Data Storage

```
~/.radiocli/
├── favorites.json        # Favorites
├── history.json          # Listening history (stations)
├── songs.json            # Song history (auto)
├── recognized_songs.json # Recognized songs
├── playlists.json        # Playlists
└── mpv.sock              # mpv socket

```

Station DB (`radio_stations.db`, 24k+ stations) is bundled with the package and stored in `~/.radiocli/` after first run. Use `radiomcp update` to sync latest stations.

## Dependencies

- Python 3.9+
- mpv (required for CLI)
- ffmpeg (for song recording)
- openai-whisper (for DJ speech recognition, optional)
- edge-tts (for DJ mode)
- ollama (for LLM, optional)

## Architecture

See [docs/ARCHITECTURE.md](docs/ARCHITECTURE.md) for system architecture.

**Data Pipeline:**
- Daily URL validation & new station sync
- Korean broadcaster URL resolvers (KBS, MBC, YTN)
- Stations sourced from Radio Browser + Icecast directories

## License

- **Code**: MIT - See [LICENSE](LICENSE)
- **Station Database**: ODbL 1.0 - See [DATA_LICENSE.md](DATA_LICENSE.md)
- **Attribution**: See [ATTRIBUTION.md](ATTRIBUTION.md)
