-
Notifications
You must be signed in to change notification settings - Fork 33
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #67 from edgar-vincent/add-favorites-cli
- Loading branch information
Showing
3 changed files
with
260 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,184 @@ | ||
--- | ||
layout: default | ||
title: CLI - Favorites commands and queries | ||
--- | ||
|
||
<link rel="stylesheet" href="../cli-doc.css"> | ||
|
||
# Favorites commands and queries | ||
|
||
*** | ||
## favorites items | ||
`favorites items <start> <itemsPerResponse> <taggedParameters>` | ||
|
||
The `favorites items` query returns all server favorites. | ||
|
||
**Accepted tagged parameters:** | ||
|
||
| Tag | Description| | ||
|---|---| | ||
| `item_id` |The id of a favorite to be returned. The id represents the hierarchical structure of the file using a dotted syntax similar to the one used in SNMP, like eg. 2.0.9.3 | | ||
| `search` |When a list of items is to be returned, it can be filtered by its name or title.| | ||
| `want_url` |If set to 1, urls are returned by the query, otherwise they aren't.| | ||
| `feedMode` |If set to 1, the entire nested hierarchy of favorites is returned. In this case, the type will be opml and the nested sub-items will be in each level's items array.| | ||
|
||
**Returned tagged parameters:** | ||
|
||
| Block | Tag | Description | | ||
|---|---|---| | ||
| First block: {: colspan=3} |⁠ {: style="padding:0"}|⁠ {: style="padding:0"}| | ||
|| `count` | The number of items available at the selected level. | | ||
| For each element: {: colspan=3} |⁠ {: style="padding:0"}|⁠ {: style="padding:0"}| | ||
|| `id` | An item's hierarchical id. Item delimiter. | | ||
|| `name` | An item's (favorite or folder) name. | | ||
|| `hasitems` | Whether or not an item has sub-items. May indicate the number of sub-items. | | ||
|| `url` | URL of the station or track (only returned if parameter `want_url` is set to 1). Although, the station can be played using the [playlist play](./playlist.md#playlist-play) command, an equivalent command that operates on the id is provided below. | | ||
|
||
*** | ||
## favorites exists | ||
`favorites exists <id | url>` | ||
|
||
The `favorites exists` command is used to check whether a given track | ||
ID or URL exists in favorites. | ||
|
||
**Returned tagged parameters:** | ||
|
||
| Tag | Description | | ||
|----------|-------------------------------------------------------------| | ||
| `exists` | Returned with value 1 if the ID or URL exists in favorites. | | ||
| `index` | If exists is 1, the index of the ID or URL in favorites. | | ||
|
||
Example: | ||
``` | ||
Request: "favorites exists file:///... <LF>" | ||
Response: "favorites exists file:///... exists:1 index:5<LF>" | ||
``` | ||
|
||
*** | ||
## favorites add | ||
`favorites add <taggedParameters>` | ||
|
||
The `favorites add` command adds a favorite. | ||
|
||
**Accepted tagged parameters:** | ||
|
||
| Tag | Description | | ||
|-----------|------------------------------------------| | ||
| `item_id` | The id of a favorite to be inserted. The id represents the hierarchical structure of the file using a dotted syntax similar to the one used in SNMP, like eg. 2.0.9.3.<br>Room is made to accommodate the new favorite. If no item_id is provided, the favorite is added at position 0. | | ||
| `title` | Favorite title (mandatory) | | ||
| `url` | Favorite url (mandatory) | | ||
| `icon` | Optional URL to an icon to be used with this favorite. | | ||
|
||
**Returned tagged parameters:** | ||
|
||
| Tag | Description | | ||
|---------|--------------------------------------------------------------| | ||
| `count` | Returned with value 1 if adding the favorite was successful. | | ||
|
||
Example: | ||
``` | ||
Request: "favorites add url:file:///... title:BestSong<LF>" | ||
Response: "favorites add url:file:///... title:BestSong | ||
count:1<LF>" | ||
``` | ||
|
||
*** | ||
## favorites addlevel | ||
`favorites addlevel <taggedParameters>` | ||
The `favorites addlevel` command adds a favorite level (a folder). | ||
|
||
**Accepted tagged parameters:** | ||
|
||
| Tag | Description | | ||
|---------|-------------------------------------| | ||
| item_id | The id of a level to be inserted. The id represents the hierarchical structure of the level using a dotted syntax similar to the one used in SNMP, like eg. 2.0.9.3.<br>Room is made to accommodate the new level. If no item_id is provided, the level is added at position 0. | | ||
| title | Level title (mandatory) | | ||
|
||
**Returned tagged parameters:** | ||
|
||
| Tag | Description | | ||
|-------|-----------------------------------------------------------| | ||
| count | Returned with value 1 if adding the level was successful. | | ||
Example: | ||
``` | ||
Request: "favorites addlevel title:Favourites<LF>" | ||
Response: "favorites addlevel title:Favourites count:1<LF>" | ||
``` | ||
|
||
*** | ||
## favorites delete | ||
`favorites delete <taggedParameters>` | ||
|
||
The `favorites delete` command deletes a favorite or a level. | ||
|
||
**Accepted tagged parameters:** | ||
|
||
| Tag | Description | | ||
|---------|-------------------------------------| | ||
| item_id | The id of a favorite or level to be deleted. The id represents the hierarchical structure of the file using a dotted syntax similar to the one used in SNMP, like eg. 2.0.9.3.<br>This parameter is mandatory. | | ||
|
||
Example: | ||
``` | ||
Request: "favorites delete item_id:1.2.3.4.5<LF>" | ||
Response: "favorites delete item_id:1.2.3.4.5<LF>" | ||
``` | ||
|
||
*** | ||
## favorites rename | ||
`favorites rename <taggedParameters>` | ||
|
||
The `favorites rename` command renames a favorite or a level. | ||
|
||
**Accepted tagged parameters:** | ||
|
||
| Tag | Description | | ||
|---------|-------------------------------------| | ||
| item_id | The id of a favorite or level to be renamed. The id represents the hierarchical structure of the file using a dotted syntax similar to the one used in SNMP, like eg. 2.0.9.3.<br>This parameter is mandatory. | | ||
| title | The new title to rename this item to. This parameter is mandatory. | | ||
|
||
Example: | ||
``` | ||
Request: "favorites rename item_id:1.2.3.4.5 title:NewTitle<LF>" | ||
Response: "favorites rename item_id:1.2.3.4.5 title:NewTitle<LF>" | ||
``` | ||
|
||
*** | ||
## favorites move | ||
`favorites move <taggedParameters>` | ||
|
||
The `favorites move` command moves a favorite or a level. | ||
|
||
**Accepted tagged parameters:** | ||
|
||
| Tag | Description | | ||
|---------|-------------------------------------| | ||
| from_id | The id of a favorite or level to be moved. The id represents the hierarchical structure of the file using a dotted syntax similar to the one used in SNMP, like eg. 2.0.9.3.<br>This parameter is mandatory. | | ||
| to_id | The id to move the favorite or level to. The id represents the hierarchical structure of the file using a dotted syntax similar to the one used in SNMP, like eg. 2.0.9.3.<br>This parameter is mandatory. | | ||
|
||
Example: | ||
``` | ||
Request: "favorites move from_id:1.2.3.4.5 to_id:5.4.3.2.1<LF>" | ||
Response: "favorites move from_id:1.2.3.4.5 to_id:5.4.3.2.1<LF>" | ||
``` | ||
|
||
*** | ||
## favorites playlist | ||
`<playerid> favorites playlist <play|load|insert|add> <taggedParameters>` | ||
|
||
This command adds or plays a favorite. | ||
If item_id defines an item that can't be played, but contains playable | ||
subitems, then these will be played instead. This allows to eg. play all | ||
tracks of a genre. | ||
|
||
**Accepted tagged parameters:** | ||
|
||
| Tag | Description | | ||
|---------|-------------------------------------------------------------------------------------| | ||
| item_id | The id of an item to be played. The id represents the hierarchical structure of the file using a dotted syntax similar to the one used in SNMP, like eg. 2.0.9.3 | | ||
|
||
Example: | ||
``` | ||
Request: "6e:ef:54:e9:02:b0 favorites playlist play item_id:1.1<LF>" | ||
Response: "6e:ef:54:e9:02:b0 favorites playlist play item_id:1.1<LF>" | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,74 @@ | ||
--- | ||
layout: default | ||
title: CLI - RandomPlay commands and queries | ||
--- | ||
|
||
<link rel="stylesheet" href="../cli-doc.css"> | ||
|
||
# Randomplay commands and queries | ||
*** | ||
## randomplay | ||
`<playerid> randomplay <tracks|albums|contributors|year|disable>` | ||
|
||
The `randomplay` command starts a random mix of the given type. The | ||
`disable` type would disable continuation of the currently playing | ||
mix. It would cause the current playlist to play to the end and no new | ||
tracks be added. | ||
|
||
Example: | ||
``` | ||
Request: "04:20:00:12:23:45 randomplay albums<LF>" | ||
Response: "04:20:00:12:23:45 randomplay albums<LF>" | ||
``` | ||
|
||
## randomplaygenrelist | ||
`<playerid> randomplaygenrelist` | ||
|
||
This returns a formatted list of genres which is for use on the Jive | ||
platform. | ||
|
||
Example: | ||
``` | ||
Request: "04:20:00:12:23:45 randomplaygenrelist<LF>" | ||
Response: "04:20:00:12:23:45 randomplaygenrelist count%3A103 | ||
offset%3A0 actions%3AHASH(0xb804350) checkbox%3A1 text%3A80s | ||
actions%3AHASH(0xb8042a8) checkbox%3A1 text%3AAcid%20Jazz | ||
actions%3AHASH(0xb80438c) checkbox%3A1 text%3AAcoustic | ||
actions%3AHASH(0xb804494) checkbox%3A0 text%3AAdvertisement | ||
actions%3AHASH(0xb8cdcc0) checkbox%3A1 text%3AAfropop | ||
actions%3AHASH(0xb8cdf9c) checkbox%3A1 <LF>" | ||
``` | ||
|
||
## randomplaychoosegenre | ||
`<playerid> randomplaychoosegenre <0|1>` | ||
|
||
Turn a particular genre on/off in random mix. | ||
|
||
Example: | ||
``` | ||
Request: "04:20:00:12:23:45 randomplaychoosegenre Afropop 1<LF>" | ||
Response: "04:20:00:12:23:45 randomplaychoosegenre Afropop 1<LF>" | ||
``` | ||
|
||
## randomplaygenreselectall | ||
`<playerid> randomplaygenreselectall <0|1>` | ||
|
||
Turn all genres on/off in random mix. | ||
|
||
Example: | ||
``` | ||
Request: "04:20:00:12:23:45 randomplaygenreselectall 1<LF>" | ||
Response: "04:20:00:12:23:45 randomplaychoosegenre 1<LF>" | ||
``` | ||
|
||
## randomplayisactive | ||
`<playerid> randomplayisactive` | ||
|
||
Get to know whether RandomPlay is active for a given player, and what | ||
kind of mix it's playing. | ||
|
||
Example: | ||
``` | ||
Request: "04:20:00:12:23:45 randomplaygisactive" | ||
Response: "04:20:00:12:23:45 randomplayisactive album" | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters