← 返回 Skills 市场
asteinberger

Airfoil

作者 Andy Steinberger · GitHub ↗ · v1.0.1
darwin ⚠ suspicious
2169
总下载
0
收藏
4
当前安装
2
版本数
在 OpenClaw 中安装
/install airfoil
功能描述
Control AirPlay speakers via Airfoil from the command line. Connect, disconnect, set volume, and manage multi-room audio with simple CLI commands.
使用说明 (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>

安全使用建议
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.
功能分析
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.
能力评估
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.
如何使用
  1. 确保已安装 OpenClaw(本地或 Docker 部署)
  2. 在对话框中输入安装命令:/install airfoil
  3. 安装完成后,直接呼叫该 Skill 的名称或使用 /airfoil 触发
  4. 根据 Skill 的参数说明提供必要输入,即可获得结构化输出
版本历史
v1.0.1
Added YAML frontmatter with description for ClawdHub
v1.0.0
Initial release - AirPlay speaker control via Airfoil
元数据
Slug airfoil
版本 1.0.1
许可证
累计安装 4
当前安装数 4
历史版本数 2
常见问题

Airfoil 是什么?

Control AirPlay speakers via Airfoil from the command line. Connect, disconnect, set volume, and manage multi-room audio with simple CLI commands. 它是一个面向 Claude Code / OpenClaw 的 AI Agent Skill 插件,目前累计下载 2169 次。

如何安装 Airfoil?

在 OpenClaw 或 Claude Code 对话框中运行命令「/install airfoil」即可一键安装,无需额外配置。

Airfoil 是免费的吗?

是的,Airfoil 完全免费(开源免费),可自由下载、安装和使用。

Airfoil 支持哪些平台?

Airfoil 跨平台运行,可在任意部署了 OpenClaw / Claude Code 的环境中使用(darwin)。

谁开发了 Airfoil?

由 Andy Steinberger(@asteinberger)开发并维护,当前版本 v1.0.1。

💬 留言讨论