yit-player
Ai friendly CLI music player
README
Yit (No Tabs. Just Tunes.) Player 🎵
The Fire-and-Forget Music Player for Developers.
Yit is a lightweight, headless, terminal-based audio player designed for flow states. It allows you to search, queue, and control music directly from your CLI without ever touching a browser or a heavy GUI.
It runs in the background (daemonized), meaning you can close your terminal, switch tabs, or keep coding while the music plays.
🚀 Features
- Daemon Architecture: The player runs as a detached background process. Your terminal is never blocked.
- Instant Search: Uses
yt-dlpto fetch metadata in milliseconds. - Smart Queue: Manage your playlist (
add,next,back,Loop) with simple commands. - Cross-Platform: Works natively on Windows, macOS, and Linux.
- Agent-Native: Built from the ground up to be controlled by AI Agents (Vibe Coding).
📦 Installation
pip install yit-player
Requirements
- None! Yit automatically manages the
mpvaudio engine internally. - Windows: Auto-downloads a portable
mpv.exeif missing. - Mac/Linux: Uses system MPV (install via
breworaptif needed).
Troubleshooting: "Command/Path not found"
If you run yit and get an error, your Python scripts folder is not in your system PATH.
Solution: Run it like this instead (works 100% of the time):
python -m yit search "slava funk" -p
⚡ Quick Start
1. Search & Play
# Search for a song
yit search "funk sigilo"
# Auto-play the first result immediately
yit search "funk infernal" -p
2. Control Playback
yit pause # (or 'p')
yit resume # (or 'r')
yit toggle # Toggle play/pause
yit stop # Kill the player
3. Queue Management
yit add 1 # Add result #1 from your last search to the queue (use 1 - 5 to choose from search results)
yit queue # Show the current queue
yit next # Skip track (or 'n')
yit back # Previous track (or 'b')
yit clear # Wipe the queue
4. Looping
yit loop # Loop the current track indefinitely
yit unloop # Return to normal playback
5. Status
yit status # Check if currently Playing/Paused and Looped
6. Favorites (❤️)
Save your best tracks for later.
# list all favorites
yit fav
# Add to favorites
yit fav add # Add the CURRENTLY playing song
yit fav add 1 # Add result #1 from your last search
# Play favorites
yit fav play # Play ALL favorites (starting from #1)
yit fav play 3 # Play favorite #3
# Remove
yit fav remove 2 # Remove favorite #2
🤖 For AI Agents & Vibe Coding
Yit is designed to be self-documenting for AI context. If you are building an AI agent or using an LLM in your IDE:
- Read context: Point your agent to AI_INSTRUCTIONS.md (included in the repo).
- Discovery: Run
yit commandsto get a JSON list of all capabilities. - State: Run
yit agentto get the full player state (Track, Time, Queue) in pure JSON.
Example Agent Output (yit agent):
{
"status": "playing",
"track": {
"title": "Never Gonna Give You Up",
"url": "https://..."
},
"position": 45.2,
"duration": 212.0,
"queue_length": 5
}
Installation for Claude Desktop & AI IDEs (MCP)
Yit includes a built-in Model Context Protocol (MCP) server (yit-mcp). You can easily connect Yit to any supported AI IDE or desktop agent.
Add the following JSON configuration block to your client's MCP config file (e.g., mcp_config.json):
{
"mcpServers": {
"yit-player": {
"command": "yit-mcp",
"args": [],
"env": {},
"disabled": false
}
}
}
🛠️ Architecture
- Client: Python CLI (
yit) handles argument parsing and user signals. - Daemon: A detached
mpvprocess handles audio decoding and network streaming. - Communication: IPC (Inter-Process Communication) via Named Pipes (Windows) or Unix Sockets (Linux/Mac).
- Persistence:
~/.yit/history.jsonstores your playback history and queue metadata.
⚠️ Disclaimer and Legal Notice
1. Educational Purpose Only
This software (Yit) is a proof-of-concept project designed strictly for educational and research purposes. Its primary goal is to demonstrate:
- Advanced Python subprocess management and Daemon architecture.
- Inter-Process Communication (IPC) using sockets and named pipes.
- Memory-efficient resource management in CLI environments.
2. Third-Party Content
This tool acts as a command-line interface (CLI) wrapper for open-source media engines (mpv) and network libraries (yt-dlp).
- No Content Hosting: This application does not host, store, distribute, or decrypt any copyrighted media content.
- Streaming Only: It is designed for transient streaming of publicly available content. It does not include features to permanently download or "rip" media to the disk.
3. Terms of Service Users are responsible for ensuring their use of this tool complies with the Terms of Service of any third-party platforms they interact with. The developer of this tool assumes no liability for misuse, account suspensions, or legal consequences arising from the use of this software.
4. No Monetization This project is free and open-source. It is not monetized in any way, nor does it generate revenue from the content it accesses.
License
This project is licensed under the GNU General Public License v3.0 (GPLv3). This ensures the software remains free and open-source. Commercial distribution of this software as a closed-source product is strictly prohibited.
Contact
For any questions, please contact vijayaraj.devworks@gmail.com.
<!-- mcp-name: VijayarajParamasivam/yit-player -->
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.