https://github.com/zeroasterisk/sonos-simple-cli
Control Sonos from CLI with pause|play and Alfred support
https://github.com/zeroasterisk/sonos-simple-cli
Last synced: 10 months ago
JSON representation
Control Sonos from CLI with pause|play and Alfred support
- Host: GitHub
- URL: https://github.com/zeroasterisk/sonos-simple-cli
- Owner: zeroasterisk
- Created: 2015-04-01T19:39:38.000Z (about 11 years ago)
- Default Branch: master
- Last Pushed: 2015-04-02T18:49:35.000Z (about 11 years ago)
- Last Synced: 2025-07-24T10:31:32.297Z (11 months ago)
- Language: JavaScript
- Size: 195 KB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Sonos Simple CLI
There are many better projects out there.
But this is one I am working on to play with Node CLI
and to use personally for the control of my own Sonos speakers.
## Features
- [x] acts only only the configured device via `roomName` config file `~/.sonos.json`
- [x] caches a found/configured device (faster startup)
- [x] supports pause/play toggle, and prev/next, vol +/-
- [x] built in support for Alfred Workflow (and thus a global hotkey shortcut)
- [x] configuration file `~/.sonos.json` to setup which `roomName` you want to use
- [ ] fix Alfred path so we don't need the `~/bin/` symlink
- [ ] TODO allow `roomName:*` all vs. configured `roomName`
- [ ] TODO allow `roomName:first` "get first" vs. configured `roomName`
- [ ] TODO autoconfigure: look for all, prompt selection, cache
## Thanks
A big thanks to the Sonos API implementation Lib I'm using:
https://github.com/bencevans/node-sonos
## Install
```
$ npm install sonos-simple-cli -g
```
If you want to use Alfred Workflow - it has path problems which I'm currently
solving with an explicit symlink *(something more elegant coming)*
```
cd ~
mkdir bin
cd bin
ln -s $(which sonos-simple-cli) sonos-simple-cli
```
### Development / Manual Install
if for some reason, you want to develop on this and play with it,
here's a guide which shuld get you setup and functional pretty easily.
```
cd ~
mkdir bin
git clone https://github.com/zeroasterisk/sonos-simple-cli.git sonos-simple-cli-repo
ln -s sonos-simple-cli-repo/sonos.js sonos-simple-cli
cd sonos-simple-cli-repo
npm install
```
## Configure
You must specify a `roomName` for this to work.
*The theory being that you could use control different `roomName` "groups" in
isolation. It's also useful to only pause/play the music playing where you are
vs. the whole network.*
All we need is the `roomName` as a string:
```
echo '{"roomName": "My Controller Room Here"}' > ~/.sonos.json
```
eg: `cat ~/.sonos.json` should look like `{"roomName":"Living Room"}`
## Manual Script Running
```
$ node ~/bin/sonos.js help
-----------------------------
----- Sonos Simple CLI ------
-----------------------------
sonos-simple-cli playpause
sonos-simple-cli play
sonos-simple-cli pause
sonos-simple-cli next
sonos-simple-cli prev
sonos-simple-cli volup
sonos-simple-cli voldown
sonos-simple-cli mute
sonos-simple-cli unmute
sonos-simple-cli mutetoggle
sonos-simple-cli clearCache
-----------------------------
$ ~/bin/sonos-simple-cli playpause
> SONOS set to PAUSED
Beastie Boys "I Don't Know"
@ 58/180 sec
```
## Configure for Alfred
Install [Alfred](http://www.alfredapp.com/) *if not already installed*.
To get the workflow, just double-click on `sonos-simple-cli.alfredworkflow` and
install it.
> You will recognise Alfred workflows by their .alfredworkflow file extension and their icon.
>
> To install a workflow, simply double-click the workflow file on your Mac. Alfred will show you a preview of the name and description of the workflow as well as the details for the developer, if available. Click the "Import" button to add the workflow to the sidebar on the left.
http://support.alfredapp.com/workflows:installing/
* CMD+F7 -> prev
* CMD+F8 -> play/pause
* CMD+F9 -> next
* CMD+F10 -> mutetoggle
* CMD+F11 -> volume down
* CMD+F12 -> volume up
### Manual Setup in Alfred
*here's how I created the Alfred Worflow*
Alfred > Workflows
Click `+` (bottom left) to add a new Workflow
Click `+` (top right) to add an `trigger > hotkey`
Then choose your hotkey and save.
Click `+` (top right) to add an `action -> run script`
select `/bin/bash` at the top, then enter the following
source ~/.profile
/usr/local/bin/node ~/bin/sonos.js pauseplay

then click save.
Finally, drag a line between them.

Bonus Points, output when done
Add an `output > notification` and setup as follows

then connect and you're all set