← Back to Skills Marketplace
asteinberger

Airfoil

by Andy Steinberger · GitHub ↗ · v1.0.1
darwin ⚠ suspicious
2169
Downloads
0
Stars
4
Active Installs
2
Versions
Install in OpenClaw
/install airfoil
Description
Control AirPlay speakers via Airfoil from the command line. Connect, disconnect, set volume, and manage multi-room audio with simple CLI commands.
README (SKILL.md)

🔊 Airfoil Skill

    ╔═══════════════════════════════════════════════════════════╗
    ║                                                           ║
    ║   🎵  A I R F O I L   S P E A K E R   C O N T R O L  🎵  ║
    ║                                                           ║
    ║        Stream audio to any AirPlay speaker                ║
    ║              from your Mac via CLI                        ║
    ║                                                           ║
    ╚═══════════════════════════════════════════════════════════╝

"Why hop to your Mac when you can croak at it?" 🐸


📖 What Does This Skill Do?

The Airfoil Skill gives you full control over your AirPlay speakers directly from the terminal – or through Clawd! Connect speakers, control volume, check status – all without touching the mouse.

Features:

  • 📡 List — Show all available speakers
  • 🔗 Connect — Connect to a speaker
  • 🔌 Disconnect — Disconnect from a speaker
  • 🔊 Volume — Control volume (0-100%)
  • 📊 Status — Show connected speakers with volume levels

⚙️ Requirements

What Details
OS macOS (uses AppleScript)
App Airfoil by Rogue Amoeba
Price $35 (free trial available)

Installation

  1. Install Airfoil:

    # Via Homebrew
    brew install --cask airfoil
    
    # Or download from rogueamoeba.com/airfoil/mac/
    
  2. Launch Airfoil and grant Accessibility permissions (System Settings → Privacy & Security → Accessibility)

  3. Skill is ready! 🚀


🛠️ Commands

list — Show All Speakers

./airfoil.sh list

Output:

Computer, Andy's M5 Macbook, Sonos Move, Living Room TV

connect \x3Cspeaker> — Connect to Speaker

./airfoil.sh connect "Sonos Move"

Output:

Connected: Sonos Move

💡 Speaker name must match exactly (case-sensitive!)


disconnect \x3Cspeaker> — Disconnect Speaker

./airfoil.sh disconnect "Sonos Move"

Output:

Disconnected: Sonos Move

volume \x3Cspeaker> \x3C0-100> — Set Volume

# Set to 40%
./airfoil.sh volume "Sonos Move" 40

# Set to maximum
./airfoil.sh volume "Living Room TV" 100

# Quiet mode for night time
./airfoil.sh volume "Sonos Move" 15

Output:

Volume Sonos Move: 40%

status — Show Connected Speakers

./airfoil.sh status

Output:

Sonos Move: 40%
Living Room TV: 65%

Or if nothing is connected:

No speakers connected

🎯 Example Workflows

🏠 "Music in the Living Room"

./airfoil.sh connect "Sonos Move"
./airfoil.sh volume "Sonos Move" 50
# → Now fire up Spotify/Apple Music and enjoy!

🎬 "Movie Night Setup"

./airfoil.sh connect "Living Room TV"
./airfoil.sh volume "Living Room TV" 70
./airfoil.sh disconnect "Sonos Move"  # If still connected

🌙 "All Off"

for speaker in "Sonos Move" "Living Room TV"; do
    ./airfoil.sh disconnect "$speaker" 2>/dev/null
done
echo "All speakers disconnected 🌙"

🔧 Troubleshooting

❌ "Speaker Not Found"

Problem: execution error: Airfoil got an error: Can't get speaker...

Solutions:

  1. Check exact spelling: ./airfoil.sh list
  2. Speaker name is case-sensitive ("sonos move" ≠ "Sonos Move")
  3. Speaker must be on the same network
  4. Speaker must be powered on and reachable

❌ "Airfoil Won't Start / No Permission"

Problem: AppleScript can't control Airfoil

Solutions:

  1. System Settings → Privacy & Security → Accessibility
  2. Add Terminal (or iTerm)
  3. Add Airfoil
  4. Restart macOS (sometimes necessary 🙄)

❌ "Volume Doesn't Work"

Problem: Volume command has no effect

Solutions:

  1. Speaker must be connected before volume can be set
  2. First connect, then volume
  3. Some speakers have hardware-side limits

❌ "Airfoil Not Installed"

Problem: execution error: Application isn't running

Solution:

# Start Airfoil
open -a Airfoil

# Or install it
brew install --cask airfoil

❌ "bc: command not found"

Problem: Volume calculation fails

Solution:

# Install bc (should be standard on macOS)
brew install bc

📋 Known Speakers

These speakers have been tested:

Speaker Type Notes
Computer Local Always available
Andy's M5 Macbook Mac When on the network
Sonos Move Sonos Bluetooth or WiFi
Living Room TV Apple TV Via AirPlay

💡 Use ./airfoil.sh list to discover your own speakers!


🔗 Integration with Clawd

This skill works perfectly with Clawd! Examples:

"Hey Clawd, connect the Sonos Move"
→ ./airfoil.sh connect "Sonos Move"

"Turn the music down"
→ ./airfoil.sh volume "Sonos Move" 30

"Which speakers are on?"
→ ./airfoil.sh status

📜 Changelog

Version Date Changes
1.0.0 2025-01-25 Initial release
1.1.0 2025-06-10 Documentation polished 🐸
1.2.0 2025-06-26 Translated to English, ClawdHub-ready!

🐸 Credits

  @..@
 (----)
( >__\x3C )   "This skill was crafted with love
 ^^  ^^     by a frog and his human!"

Author: Andy Steinberger (with help from his Clawdbot Owen the Frog 🐸)
Powered by: Airfoil by Rogue Amoeba
Part of: Clawdbot Skills Collection


\x3Cdiv align="center">

Made with 💚 for the Clawdbot Community

Ribbit! 🐸

\x3C/div>

Usage Guidance
This skill appears to do exactly what it says: it runs local AppleScript (osascript) to control the Airfoil app. Before installing or running: 1) Ensure you trust the source and have legitimately installed Airfoil (the app is commercial). 2) Review the included airfoil.sh (it's short and readable). 3) Be aware that granting Terminal/iTerm Automation or Accessibility permissions allows scripts to control apps on your Mac — only grant those permissions if you trust the skill. 4) No network exfiltration or secret access is requested by the skill, but always confirm you installed Airfoil from the official site or Homebrew cask.
Capability Analysis
Type: OpenClaw Skill Name: airfoil Version: 1.0.1 The skill uses `osascript` to control the Airfoil application, which is its stated purpose. However, the `airfoil.sh` script directly interpolates user-provided speaker names (`$SPEAKER`) into AppleScript commands (e.g., in `connect`, `disconnect`, `volume` functions). This creates a potential AppleScript injection vulnerability if the input from the agent is not properly sanitized, allowing an attacker to execute arbitrary AppleScript commands on the macOS system. While the intent appears to be benign application control, this direct interpolation without sanitization represents a significant security risk.
Capability Assessment
Purpose & Capability
Name/description match the behavior. The script uses osascript to talk to the Airfoil app (connect, disconnect, set volume, list/status) — exactly what the skill advertises. OS restriction (darwin) and required binary (osascript) are appropriate.
Instruction Scope
SKILL.md and the script only interact with the Airfoil app via AppleScript and local command-line utilities. The instructions correctly ask the user to install Airfoil and grant accessibility/automation permissions. Note: granting Terminal/iTerm Automation/Accessibility is sensitive because it allows controlling other apps — the SKILL.md documents this and the script itself contains only direct Airfoil AppleScript calls.
Install Mechanism
No install spec in the skill bundle (instruction-only with a small shell script). The SKILL.md recommends installing Airfoil via Homebrew or rogueamoeba.com, which are reasonable and expected for this purpose. Nothing is downloaded or executed from an untrusted URL by the skill itself.
Credentials
The skill requests no environment variables, no credentials, and no config paths. The requested permissions (Accessibility/Automation) are proportional to using AppleScript to control Airfoil.
Persistence & Privilege
always is false and the skill does not request elevated platform privileges or attempt to modify other skills or system configuration. It runs only when invoked and performs local AppleScript operations.
How to Use
  1. Make sure OpenClaw is installed (local or Docker)
  2. Run the install command in chat: /install airfoil
  3. After installation, invoke the skill by name or use /airfoil
  4. Provide required inputs per the skill's parameter spec and get structured output
Version History
v1.0.1
Added YAML frontmatter with description for ClawdHub
v1.0.0
Initial release - AirPlay speaker control via Airfoil
Metadata
Slug airfoil
Version 1.0.1
License
All-time Installs 4
Active Installs 4
Total Versions 2
Frequently Asked Questions

What is Airfoil?

Control AirPlay speakers via Airfoil from the command line. Connect, disconnect, set volume, and manage multi-room audio with simple CLI commands. It is an AI Agent Skill for Claude Code / OpenClaw, with 2169 downloads so far.

How do I install Airfoil?

Run "/install airfoil" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.

Is Airfoil free?

Yes, Airfoil is completely free (open-source). You can download, install and use it at no cost.

Which platforms does Airfoil support?

Airfoil is cross-platform and runs anywhere OpenClaw / Claude Code is available (darwin).

Who created Airfoil?

It is built and maintained by Andy Steinberger (@asteinberger); the current version is v1.0.1.

💬 Comments