skills$openclaw/airfoil
asteinberger3.4kā˜…

by asteinberger

airfoil – OpenClaw Skill

airfoil is an OpenClaw Skills integration for security workflows. Control AirPlay speakers via Airfoil from the command line. Connect, disconnect, set volume, and manage multi-room audio with simple CLI commands.

3.4k stars2.1k forksSecurity L1
Updated Feb 7, 2026Created Feb 7, 2026security

Skill Snapshot

nameairfoil
descriptionControl AirPlay speakers via Airfoil from the command line. Connect, disconnect, set volume, and manage multi-room audio with simple CLI commands. OpenClaw Skills integration.
ownerasteinberger
repositoryasteinberger/airfoil
languageMarkdown
licenseMIT
topics
securityL1
installopenclaw add @asteinberger/airfoil
last updatedFeb 7, 2026

Maintainer

asteinberger

asteinberger

Maintains airfoil in the OpenClaw Skills directory.

View GitHub profile
File Explorer
3 files
.
_meta.json
272 B
airfoil.sh
2.5 KB
SKILL.md
6.2 KB
SKILL.md

name: airfoil description: Control AirPlay speakers via Airfoil from the command line. Connect, disconnect, set volume, and manage multi-room audio with simple CLI commands. metadata: {"clawdbot":{"emoji":"šŸ”Š","os":["darwin"],"requires":{"bins":["osascript"]}}}

šŸ”Š 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

WhatDetails
OSmacOS (uses AppleScript)
AppAirfoil 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 <speaker> — Connect to Speaker

./airfoil.sh connect "Sonos Move"

Output:

Connected: Sonos Move

šŸ’” Speaker name must match exactly (case-sensitive!)


disconnect <speaker> — Disconnect Speaker

./airfoil.sh disconnect "Sonos Move"

Output:

Disconnected: Sonos Move

volume <speaker> <0-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:

SpeakerTypeNotes
ComputerLocalAlways available
Andy's M5 MacbookMacWhen on the network
Sonos MoveSonosBluetooth or WiFi
Living Room TVApple TVVia 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

VersionDateChanges
1.0.02025-01-25Initial release
1.1.02025-06-10Documentation polished 🐸
1.2.02025-06-26Translated to English, ClawdHub-ready!

🐸 Credits

  @..@
 (----)
( >__< )   "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


<div align="center">

Made with šŸ’š for the Clawdbot Community

Ribbit! 🐸

</div>
README.md

No README available.

Permissions & Security

Security level L1: Low-risk skills with minimal permissions. Review inputs and outputs before running in production.

Requirements

| What | Details | |------|---------| | **OS** | macOS (uses AppleScript) | | **App** | [Airfoil](https://rogueamoeba.com/airfoil/mac/) by Rogue Amoeba | | **Price** | $35 (free trial available) | ### Installation 1. **Install Airfoil:** ```bash # 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!** šŸš€ ---

FAQ

How do I install airfoil?

Run openclaw add @asteinberger/airfoil in your terminal. This installs airfoil into your OpenClaw Skills catalog.

Does this skill run locally or in the cloud?

OpenClaw Skills execute locally by default. Review the SKILL.md and permissions before running any skill.

Where can I verify the source code?

The source repository is available at https://github.com/openclaw/skills/tree/main/skills/asteinberger/airfoil. Review commits and README documentation before installing.