git clone https://github.com/openclaw/skills
T=$(mktemp -d) && git clone --depth=1 https://github.com/openclaw/skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/akivasolutions/plex-ctl" ~/.claude/skills/openclaw-skills-plex-ctl && rm -rf "$T"
T=$(mktemp -d) && git clone --depth=1 https://github.com/openclaw/skills "$T" && mkdir -p ~/.openclaw/skills && cp -r "$T/skills/akivasolutions/plex-ctl" ~/.openclaw/skills/openclaw-skills-plex-ctl && rm -rf "$T"
skills/akivasolutions/plex-ctl/SKILL.mdplexctl — Plex Media Server Control
Standalone CLI for controlling Plex Media Server and clients via the Plex API
When to Use
Trigger phrases:
- "play [title] on Plex"
- "search Plex for [query]"
- "what's playing on Plex"
- "pause/resume Plex"
- "show me what's on deck"
- "what's new on Plex"
- "list Plex clients"
- "tell me about [movie/show]"
Use this skill when:
- User wants to play specific content on Plex
- User wants to search their Plex library
- User wants to control playback (pause, resume, stop, next, prev)
- User wants to see what's currently playing
- User wants to browse recently added content
- User wants to see continue watching (on-deck)
- User wants detailed info about a title
Don't use this skill when:
- User wants Apple TV-specific navigation (use ClawTV instead)
- User wants vision-based automation (use ClawTV instead)
- User wants to manage Plex server settings (use Plex web UI)
Commands
Setup
plexctl setup
Interactive first-time setup:
- Plex server URL (e.g., http://192.168.86.86:32400)
- Plex token
- Default client selection
Playback
# Play a movie (fuzzy search) plexctl play "Fight Club" plexctl play "inception" # Play specific TV episode plexctl play "The Office" -s 3 -e 10 plexctl play "Westworld" --season 2 --episode 6 # Play on specific client (overrides default) plexctl play "Matrix" -c "Living Room TV"
Playback Control
plexctl pause # Pause current playback plexctl resume # Resume playback plexctl stop # Stop playback plexctl next # Skip to next track/episode plexctl prev # Go to previous track/episode
Search & Discovery
# Search across all libraries plexctl search "matrix" plexctl search "breaking bad" # Recently added content plexctl recent # Last 10 items plexctl recent -n 20 # Last 20 items # Continue watching (on-deck) plexctl on-deck # What's currently playing plexctl now-playing # Detailed info about a title plexctl info "Inception" plexctl info "The Office"
Library Management
# List all libraries plexctl libraries # List available clients plexctl clients
Setup Instructions
1. Install Dependencies
pip install plexapi
2. Run Setup
plexctl setup
You'll need:
- Plex server URL: Usually
http://[local-ip]:32400 - Plex token: Get from Settings → Account → Authorized Devices
- Or from browser URL when logged into Plex Web
- Look for
parameterX-Plex-Token
- Default client: The tool will discover available clients
3. Verify
plexctl clients # Should list your devices plexctl libraries # Should list your libraries plexctl search "test" # Should return results
Required Credentials
Config stored in
~/.plexctl/config.json:
{ "plex_url": "http://192.168.86.86:32400", "plex_token": "your-plex-token-here", "default_client": "Apple TV" }
Getting Your Plex Token
Method 1: Settings Page
- Log into Plex Web (app.plex.tv)
- Settings → Account → Authorized Devices
- Look for your token in the page source or URL
Method 2: Browser URL
- Open any Plex Web page while logged in
- Check the URL for
X-Plex-Token=... - Copy the token value
Method 3: XML Direct Method
- Navigate to:
http://[your-plex-ip]:32400/?X-Plex-Token= - View page source
- Look for
attributeauthToken
Privacy & Data
- Local only: Connects directly to your Plex Media Server on your local network
- No cloud APIs: All communication is local (unless using Plex cloud discovery as fallback)
- No external services: No data sent to third parties
- No telemetry: No usage tracking or analytics
- Config storage: Only stores Plex URL, token, and default client locally
Note: Plex cloud discovery (MyPlex) is only used as a fallback when local GDM discovery fails. All media playback is direct to your local server.
Common Use Cases
1. Quick Movie Playback
plexctl play "Fight Club"
Searches library, finds best match, starts playing on default client.
2. Binge Watching TV Shows
plexctl play "Breaking Bad" -s 1 -e 1 # ... watch episode ... plexctl next # Next episode plexctl next # Next episode
3. Continue Watching
plexctl on-deck # See what's in progress plexctl play "Show Name" # Resume from where you left off
4. Browse New Content
plexctl recent # See what's new plexctl info "Movie Title" # Get details plexctl play "Movie Title" # Watch it
5. Multi-Client Control
plexctl clients # List all clients plexctl play "Movie" -c "Bedroom TV" # Play on specific client plexctl pause -c "Living Room TV" # Pause specific client
6. Library Search
plexctl search "christopher nolan" # Find all Nolan films plexctl search "breaking" # Fuzzy search plexctl info "Inception" # Get details before watching
Fuzzy Matching
The
play and info commands use fuzzy search:
- "fight club" → "Fight Club (1999)"
- "inception" → "Inception"
- "office" → "The Office (U.S.)"
Exact matches are prioritized over partial matches.
Error Handling
Client not found:
Error: Client 'Apple TV' not found Available clients: Local: • Living Room TV (Plex for Apple TV) • Bedroom (Plex Web)
No results:
No results found for: xyz123
Connection failed:
Error connecting to Plex server: [Errno 61] Connection refused URL: http://192.168.86.86:32400 Check your plex_url and plex_token in config
Integration with OpenClaw
When a user asks to play something on Plex:
- Parse the request — extract title, season, episode
- Choose command:
- Movie:
plexctl play "Title" - TV show specific episode:
plexctl play "Show" -s N -e N - Search first:
thenplexctl search "query"plexctl play "Title"
- Movie:
- Execute and report — run command, share output with user
Example agent flow:
User: "Play Fight Club on Plex" Agent: [exec] plexctl play "Fight Club" Output: Found: Fight Club (1999) (movie) ✓ Playing on Apple TV Agent: "Now playing Fight Club on your Apple TV"
Troubleshooting
Can't connect to Plex:
- Verify server is running
- Check URL (should be http://IP:32400, not https)
- Verify token is correct
- Check firewall settings
Client not found:
- Make sure Plex app is open on the client device
- Run
to see available clientsplexctl clients - Try cloud discovery (automatic fallback)
- Restart Plex app on client device
Playback fails:
- Verify client can play the content type
- Check client is still active (
)plexctl clients - Try playing manually in Plex app first
- Check Plex server logs
Search returns no results:
- Verify content exists in your library
- Try broader search terms
- Check library is scanned and up-to-date
- Run
to verify library accessplexctl libraries
Performance
- Local GDM discovery: ~100ms
- Cloud fallback discovery: ~500-1000ms
- Search: ~200-500ms depending on library size
- Playback start: ~500ms
- Control commands: ~100ms
All operations are direct Plex API calls — no vision, no screenshots, no AI inference needed.
Differences from ClawTV
| Feature | plexctl | ClawTV |
|---|---|---|
| Plex control | ✅ Direct API | ✅ API + Vision |
| Apple TV remote | ❌ | ✅ |
| Vision-based navigation | ❌ | ✅ |
| Any streaming app | ❌ | ✅ |
| Speed | ⚡ Instant | 🐢 Slower (screenshots) |
| Dependencies | plexapi only | pyatv, Anthropic API, QuickTime |
| Use case | Plex-only control | Universal TV automation |
When to use plexctl: Fast, direct Plex control
When to use ClawTV: Complex navigation, non-Plex apps, vision-based automation