2021-04-09 19:37:54 +02:00
# OwnTone API Endpoint Reference
2018-02-08 21:19:55 +01:00
Available API endpoints:
* [Player ](#player ): control playback, volume, shuffle/repeat modes
* [Outputs / Speakers ](#outputs--speakers ): list available outputs and enable/disable outputs
2018-03-02 12:37:32 +01:00
* [Queue ](#queue ): list, add or modify the current queue
2018-11-19 20:33:27 +01:00
* [Library ](#library ): list playlists, artists, albums and tracks from your library or trigger library rescan
2018-04-14 08:09:25 +02:00
* [Search ](#search ): search for playlists, artists, albums and tracks
2018-02-08 21:19:55 +01:00
* [Server info ](#server-info ): get server information
2019-08-31 08:43:53 +02:00
* [Settings ](#settings ): list and change settings for the player web interface
2018-02-08 21:19:55 +01:00
* [Push notifications ](#push-notifications ): receive push notifications
2018-03-02 12:37:32 +01:00
JSON-Object model:
* [Queue item ](#queue-item-object )
* [Playlist ](#playlist-object )
* [Artist ](#artist-object )
* [Album ](#album-object )
* [Track ](#track-object )
2018-02-08 21:19:55 +01:00
## Player
| Method | Endpoint | Description |
| --------- | ------------------------------------------------ | ------------------------------------ |
| GET | [/api/player ](#get-player-status ) | Get player status |
2019-01-22 09:24:14 +01:00
| PUT | [/api/player/play, /api/player/pause, /api/player/stop, /api/player/toggle ](#control-playback ) | Start, pause or stop playback |
2019-01-27 20:04:38 +11:00
| PUT | [/api/player/next, /api/player/previous ](#skip-tracks ) | Skip forward or backward |
2018-02-08 21:19:55 +01:00
| PUT | [/api/player/shuffle ](#set-shuffle-mode ) | Set shuffle mode |
| PUT | [/api/player/consume ](#set-consume-mode ) | Set consume mode |
| PUT | [/api/player/repeat ](#set-repeat-mode ) | Set repeat mode |
| PUT | [/api/player/volume ](#set-volume ) | Set master volume or volume for a specific output |
2018-04-14 08:09:25 +02:00
| PUT | [/api/player/seek ](#seek ) | Seek to a position in the currently playing track |
2018-02-08 21:19:55 +01:00
### Get player status
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-02-08 21:19:55 +01:00
GET /api/player
```
**Response**
| Key | Type | Value |
| ----------------- | -------- | ----------------------------------------- |
| state | string | `play` , `pause` or `stop` |
| repeat | string | `off` , `all` or `single` |
| consume | boolean | `true` if consume mode is enabled |
| shuffle | boolean | `true` if shuffle mode is enabled |
| volume | integer | Master volume in percent (0 - 100) |
| item_id | integer | The current playing queue item `id` |
| item_length_ms | integer | Total length in milliseconds of the current queue item |
| item_progress_ms | integer | Progress into the current queue item in milliseconds |
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-02-08 21:19:55 +01:00
curl -X GET "http://localhost:3689/api/player"
```
2018-10-25 19:20:49 +02:00
```json
2018-02-08 21:19:55 +01:00
{
"state": "pause",
"repeat": "off",
"consume": false,
"shuffle": false,
"volume": 50,
"item_id": 269,
"item_length_ms": 278093,
"item_progress_ms": 3674
}
```
### Control playback
Start or resume, pause, stop playback.
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-02-08 21:19:55 +01:00
PUT /api/player/play
```
2018-10-25 19:20:49 +02:00
```http
2018-02-08 21:19:55 +01:00
PUT /api/player/pause
```
2018-10-25 19:20:49 +02:00
```http
2018-02-08 21:19:55 +01:00
PUT /api/player/stop
```
2019-01-22 09:24:14 +01:00
```http
PUT /api/player/toggle
```
2018-02-08 21:19:55 +01:00
**Response**
On success returns the HTTP `204 No Content` success status response code.
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-02-08 21:19:55 +01:00
curl -X PUT "http://localhost:3689/api/player/play"
```
2018-10-25 19:20:49 +02:00
```shell
2018-02-08 21:19:55 +01:00
curl -X PUT "http://localhost:3689/api/player/pause"
```
2018-10-25 19:20:49 +02:00
```shell
2018-02-08 21:19:55 +01:00
curl -X PUT "http://localhost:3689/api/player/stop"
```
2019-01-22 09:24:14 +01:00
```shell
curl -X PUT "http://localhost:3689/api/player/toggle"
```
2018-02-08 21:19:55 +01:00
### Skip tracks
Skip forward or backward
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-02-08 21:19:55 +01:00
PUT /api/player/next
```
2018-10-25 19:20:49 +02:00
```http
2019-01-27 20:04:38 +11:00
PUT /api/player/previous
2018-02-08 21:19:55 +01:00
```
**Response**
On success returns the HTTP `204 No Content` success status response code.
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-02-08 21:19:55 +01:00
curl -X PUT "http://localhost:3689/api/player/next"
```
2018-10-25 19:20:49 +02:00
```shell
2019-01-27 20:04:38 +11:00
curl -X PUT "http://localhost:3689/api/player/previous"
2018-02-08 21:19:55 +01:00
```
### Set shuffle mode
Enable or disable shuffle mode
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-02-08 21:19:55 +01:00
PUT /api/player/shuffle
```
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| state | The new shuffle state, should be either `true` or `false` |
**Response**
On success returns the HTTP `204 No Content` success status response code.
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-02-08 21:19:55 +01:00
curl -X PUT "http://localhost:3689/api/player/shuffle?state=true"
```
### Set consume mode
Enable or disable consume mode
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-02-08 21:19:55 +01:00
PUT /api/player/consume
```
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| state | The new consume state, should be either `true` or `false` |
**Response**
On success returns the HTTP `204 No Content` success status response code.
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-02-08 21:19:55 +01:00
curl -X PUT "http://localhost:3689/api/player/consume?state=true"
```
### Set repeat mode
Change repeat mode
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-02-08 21:19:55 +01:00
PUT /api/player/repeat
```
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| state | The new repeat mode, should be either `off` , `all` or `single` |
**Response**
On success returns the HTTP `204 No Content` success status response code.
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-02-08 21:19:55 +01:00
curl -X PUT "http://localhost:3689/api/player/repeat?state=all"
```
### Set volume
Change master volume or volume of a specific output.
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-02-08 21:19:55 +01:00
PUT /api/player/volume
```
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| volume | The new volume (0 - 100) |
2019-01-22 09:24:14 +01:00
| step | The increase or decrease volume by the given amount (-100 - 100) |
2018-02-08 21:19:55 +01:00
| output_id | *(Optional)* If an output id is given, only the volume of this output will be changed. If parameter is omited, the master volume will be changed. |
2019-01-22 09:24:14 +01:00
Either `volume` or `step` must be present as query parameter
2018-02-08 21:19:55 +01:00
**Response**
On success returns the HTTP `204 No Content` success status response code.
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-02-08 21:19:55 +01:00
curl -X PUT "http://localhost:3689/api/player/volume?volume=50"
```
2019-01-22 09:24:14 +01:00
```shell
curl -X PUT "http://localhost:3689/api/player/volume?step=-5"
```
2018-10-25 19:20:49 +02:00
```shell
2018-02-08 21:19:55 +01:00
curl -X PUT "http://localhost:3689/api/player/volume?volume=50& output_id=0"
```
2018-04-14 08:09:25 +02:00
### Seek
Seek to a position in the currently playing track.
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-04-14 08:09:25 +02:00
PUT /api/player/seek
```
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| position_ms | The new position in milliseconds to seek to |
2019-09-22 10:05:51 +02:00
| seek_ms | A relative amount of milliseconds to seek to |
2018-04-14 08:09:25 +02:00
**Response**
On success returns the HTTP `204 No Content` success status response code.
**Example**
2019-09-22 10:05:51 +02:00
Seek to position:
2018-10-25 19:20:49 +02:00
```shell
2018-04-14 08:09:25 +02:00
curl -X PUT "http://localhost:3689/api/player/seek?position_ms=2000"
```
2019-09-22 10:05:51 +02:00
Relative seeking (skip 30 seconds backwards):
```shell
curl -X PUT "http://localhost:3689/api/player/seek?seek_ms=-30000"
```
2018-04-14 08:09:25 +02:00
2018-02-08 21:19:55 +01:00
## Outputs / Speakers
| Method | Endpoint | Description |
| --------- | ------------------------------------------------ | ------------------------------------ |
| GET | [/api/outputs ](#get-a-list-of-available-outputs ) | Get a list of available outputs |
| PUT | [/api/outputs/set ](#set-enabled-outputs ) | Set enabled outputs |
| GET | [/api/outputs/{id} ](#get-an-output ) | Get an output |
2020-05-26 22:46:49 +02:00
| PUT | [/api/outputs/{id} ](#change-an-output ) | Change an output setting |
2019-09-26 08:03:28 +02:00
| PUT | [/api/outputs/{id}/toggle ](#toggle-an-output ) | Enable or disable an output, depending on the current state |
2018-02-08 21:19:55 +01:00
### Get a list of available outputs
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-02-08 21:19:55 +01:00
GET /api/outputs
```
**Response**
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| outputs | array | Array of `output` objects |
**`output` object**
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| id | string | Output id |
| name | string | Output name |
| type | string | Type of the output: `AirPlay` , `Chromecast` , `ALSA` , `Pulseaudio` , `fifo` |
| selected | boolean | `true` if output is enabled |
| has_password | boolean | `true` if output is password protected |
| requires_auth | boolean | `true` if output requires authentication |
| needs_auth_key | boolean | `true` if output requires an authorization key (device verification) |
| volume | integer | Volume in percent (0 - 100) |
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-02-08 21:19:55 +01:00
curl -X GET "http://localhost:3689/api/outputs"
```
2018-10-25 19:20:49 +02:00
```json
2018-02-08 21:19:55 +01:00
{
"outputs": [
{
"id": "123456789012345",
"name": "kitchen",
"type": "AirPlay",
"selected": true,
"has_password": false,
"requires_auth": false,
"needs_auth_key": false,
"volume": 0
},
{
"id": "0",
"name": "Computer",
"type": "ALSA",
"selected": true,
"has_password": false,
"requires_auth": false,
"needs_auth_key": false,
"volume": 19
},
{
"id": "100",
"name": "daapd-fifo",
"type": "fifo",
"selected": false,
"has_password": false,
"requires_auth": false,
"needs_auth_key": false,
"volume": 0
}
]
}
```
### Set enabled outputs
2021-04-09 19:37:54 +02:00
Set the enabled outputs by passing an array of output ids. The server enables all outputs
2018-02-08 21:19:55 +01:00
with the given ids and disables the remaining outputs.
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-02-08 21:19:55 +01:00
PUT /api/outputs/set
```
**Body parameters**
| Parameter | Type | Value |
| --------------- | -------- | -------------------- |
| outputs | array | Array of output ids |
**Response**
On success returns the HTTP `204 No Content` success status response code.
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-02-08 21:19:55 +01:00
curl -X PUT "http://localhost:3689/api/outputs/set" --data "{\"outputs\":[\"198018693182577\",\"0\"]}"
```
### Get an output
Get an output
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-02-08 21:19:55 +01:00
GET /api/outputs/{id}
```
**Path parameters**
| Parameter | Value |
| --------------- | -------------------- |
| id | Output id |
**Response**
On success returns the HTTP `200 OK` success status response code. With the response body holding the ** `output` object**.
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-02-08 21:19:55 +01:00
curl -X GET "http://localhost:3689/api/outputs/0"
```
2018-10-25 19:20:49 +02:00
```json
2018-02-08 21:19:55 +01:00
{
"id": "0",
"name": "Computer",
"type": "ALSA",
"selected": true,
"has_password": false,
"requires_auth": false,
"needs_auth_key": false,
"volume": 3
}
```
### Change an output
Enable or disable an output and change its volume.
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-02-08 21:19:55 +01:00
PUT /api/outputs/{id}
```
**Path parameters**
| Parameter | Value |
| --------------- | -------------------- |
| id | Output id |
**Body parameters**
| Parameter | Type | Value |
| --------------- | --------- | -------------------- |
| selected | boolean | *(Optional)* `true` to enable and `false` to disable the output |
| volume | integer | *(Optional)* Volume in percent (0 - 100) |
2020-05-26 22:46:49 +02:00
| pin | string | *(Optional)* PIN for device verification |
2018-02-08 21:19:55 +01:00
**Response**
On success returns the HTTP `204 No Content` success status response code.
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-02-08 21:19:55 +01:00
curl -X PUT "http://localhost:3689/api/outputs/0" --data "{\"selected\":true, \"volume\": 50}"
```
2019-09-26 08:03:28 +02:00
### Toggle an output
Enable or disable an output, depending on its current state
**Endpoint**
```http
PUT /api/outputs/{id}/toggle
```
**Path parameters**
| Parameter | Value |
| --------------- | -------------------- |
| id | Output id |
**Response**
On success returns the HTTP `204 No Content` success status response code.
**Example**
```shell
curl -X PUT "http://localhost:3689/api/outputs/0/toggle"
```
2018-03-02 12:37:32 +01:00
## Queue
| Method | Endpoint | Description |
| --------- | ----------------------------------------------------------- | ------------------------------------ |
| GET | [/api/queue ](#list-queue-items ) | Get a list of queue items |
| PUT | [/api/queue/clear ](#clearing-the-queue ) | Remove all items from the queue |
| POST | [/api/queue/items/add ](#adding-items-to-the-queue ) | Add items to the queue |
2021-03-12 21:06:06 +01:00
| PUT | [/api/queue/items/{id}\|now_playing ](#updating-a-queue-item )| Updating a queue item in the queue |
2021-01-21 22:46:19 +01:00
| DELETE | [/api/queue/items/{id} ](#removing-a-queue-item ) | Remove a queue item from the queue |
2018-03-02 12:37:32 +01:00
### List queue items
Lists the items in the current queue
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-03-02 12:37:32 +01:00
GET /api/queue
```
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
2021-04-01 23:23:18 +02:00
| id | *(Optional)* If a queue item id is given, only the item with the id will be returend. Use id=now_playing to get the currently playing item. |
2018-03-02 12:37:32 +01:00
| start | *(Optional)* If a `start` and an `end` position is given, only the items from `start` (included) to `end` (excluded) will be returned. If only a `start` position is given, only the item at this position will be returned. |
| end | *(Optional)* See `start` parameter |
**Response**
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| version | integer | Version number of the current queue |
| count | integer | Number of items in the current queue |
| items | array | Array of [`queue item` ](#queue-item-object ) objects |
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-03-02 12:37:32 +01:00
curl -X GET "http://localhost:3689/api/queue"
```
2018-10-25 19:20:49 +02:00
```json
2018-03-02 12:37:32 +01:00
{
"version": 833,
"count": 20,
"items": [
{
"id": 12122,
"position": 0,
"track_id": 10749,
"title": "Angels",
"artist": "The xx",
"artist_sort": "xx, The",
"album": "Coexist",
"album_sort": "Coexist",
"albumartist": "The xx",
"albumartist_sort": "xx, The",
"genre": "Indie Rock",
"year": 2012,
"track_number": 1,
"disc_number": 1,
"length_ms": 171735,
"media_kind": "music",
"data_kind": "file",
2018-04-14 08:09:25 +02:00
"path": "/music/srv/The xx/Coexist/01 Angels.mp3",
2018-03-02 12:37:32 +01:00
"uri": "library:track:10749"
},
...
]
}
```
### Clearing the queue
Remove all items form the current queue
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-03-02 12:37:32 +01:00
PUT /api/queue/clear
```
**Response**
On success returns the HTTP `204 No Content` success status response code.
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-03-02 12:37:32 +01:00
curl -X PUT "http://localhost:3689/api/queue/clear"
```
### Adding items to the queue
Add tracks, playlists artists or albums to the current queue
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-03-02 12:37:32 +01:00
POST /api/queue/items/add
```
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
2019-01-02 09:51:11 +01:00
| uris | Comma seperated list of resource identifiers (`track` , `playlist` , `artist` or `album` object `uri` ) |
| expression | A smart playlist query expression identifying the tracks that will be added to the queue. |
| position | *(Optional)* If a position is given, new items are inserted starting from this position into the queue. |
| playback | *(Optional)* If the `playback` parameter is set to `start` , playback will be started after adding the new items. |
2019-02-22 13:27:31 +01:00
| playback_from_position | *(Optional)* If the `playback` parameter is set to `start` , playback will be started with the queue item at the position given in `playback_from_position` . |
2019-01-02 09:51:11 +01:00
| clear | *(Optional)* If the `clear` parameter is set to `true` , the queue will be cleared before adding the new items. |
| shuffle | *(Optional)* If the `shuffle` parameter is set to `true` , the shuffle mode is activated. If it is set to something else, the shuffle mode is deactivated. To leave the shuffle mode untouched the parameter should be ommited. |
2020-07-04 11:55:55 +01:00
| limit | *(Optional)* Maximum number of tracks to add |
2018-03-02 12:37:32 +01:00
2018-12-29 10:03:26 +01:00
Either the `uris` or the `expression` parameter must be set. If both are set the `uris` parameter takes presedence and the `expression` parameter will be ignored.
2018-03-02 12:37:32 +01:00
**Response**
2018-12-17 19:03:34 +01:00
On success returns the HTTP `200 OK` success status response code.
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| count | integer | number of tracks added to the queue |
2018-03-02 12:37:32 +01:00
**Example**
2018-12-29 10:03:26 +01:00
Add new items by uri:
2018-10-25 19:20:49 +02:00
```shell
2018-03-02 12:37:32 +01:00
curl -X POST "http://localhost:3689/api/queue/items/add?uris=library:playlist:68,library:artist:2932599850102967727"
```
2018-12-17 19:03:34 +01:00
```json
{
"count": 42
}
```
2018-12-29 10:03:26 +01:00
Add new items by query language:
```shell
curl -X POST "http://localhost:3689/api/queue/items/add?expression=media_kind+is+music"
```
```json
{
"count": 42
}
```
2020-07-04 11:55:55 +01:00
Clear current queue, add 10 new random tracks of `genre` _Pop_ and start playback
```
curl -X POST "http://localhost:3689/api/queue/items/add?limit=10& clear=true& playback=start& expression=genre+is+%22Pop%22+order+by+random+desc"
```
```json
{
"count": 10
}
```
2018-03-02 12:37:32 +01:00
2021-01-20 22:39:34 +01:00
### Updating a queue item
2018-03-02 12:37:32 +01:00
2021-01-20 22:39:34 +01:00
Update or move a queue item in the current queue
2018-03-02 12:37:32 +01:00
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-03-02 12:37:32 +01:00
PUT /api/queue/items/{id}
```
2021-01-21 22:46:19 +01:00
or
```http
PUT /api/queue/items/now_playing
```
2018-03-02 12:37:32 +01:00
**Path parameters**
| Parameter | Value |
| --------------- | -------------------- |
| id | Queue item id |
2021-01-21 22:46:19 +01:00
(or use now_playing to update the currenly playing track)
2018-03-02 12:37:32 +01:00
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| new_position | The new position for the queue item in the current queue. |
2021-01-20 22:39:34 +01:00
| title | New track title |
| album | New album title |
| artist | New artist |
| album_artist | New album artist |
| composer | New composer |
| genre | New genre |
| artwork_url | New URL to track artwork |
2018-03-02 12:37:32 +01:00
**Response**
On success returns the HTTP `204 No Content` success status response code.
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-03-02 12:37:32 +01:00
curl -X PUT "http://localhost:3689/api/queue/items/3?new_position=0"
```
2021-01-20 22:39:34 +01:00
```shell
curl -X PUT "http://localhost:3689/api/queue/items/3?title=Awesome%20title& artwork_url=http%3A%2F%2Fgyfgafguf.dk%2Fimages%2Fpige3.jpg"
```
2018-03-02 12:37:32 +01:00
2021-01-21 22:46:19 +01:00
```shell
curl -X PUT "http://localhost:3689/api/queue/items/now_playing?title=Awesome%20title& artwork_url=http%3A%2F%2Fgyfgafguf.dk%2Fimages%2Fpige3.jpg"
```
2018-03-02 12:37:32 +01:00
### Removing a queue item
Remove a queue item from the current queue
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-03-02 12:37:32 +01:00
DELETE /api/queue/items/{id}
```
**Path parameters**
| Parameter | Value |
| --------------- | -------------------- |
| id | Queue item id |
**Response**
On success returns the HTTP `204 No Content` success status response code.
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-03-02 12:37:32 +01:00
curl -X PUT "http://localhost:3689/api/queue/items/2"
```
## Library
| Method | Endpoint | Description |
| --------- | ----------------------------------------------------------- | ------------------------------------ |
2018-11-19 20:33:27 +01:00
| GET | [/api/library ](#library-information ) | Get library information |
2018-03-02 12:37:32 +01:00
| GET | [/api/library/playlists ](#list-playlists ) | Get a list of playlists |
2018-04-14 08:09:25 +02:00
| GET | [/api/library/playlists/{id} ](#get-a-playlist ) | Get a playlist |
2020-04-17 20:10:58 +02:00
| PUT | [/api/library/playlists/{id} ](#update-a-playlist ) | Update a playlist attribute |
2020-03-21 22:20:59 +01:00
| DELETE | [/api/library/playlists/{id} ](#delete-a-playlist ) | Delete a playlist |
2018-03-02 12:37:32 +01:00
| GET | [/api/library/playlists/{id}/tracks ](#list-playlist-tracks ) | Get list of tracks for a playlist |
2020-03-12 17:58:44 +00:00
| PUT | [/api/library/playlists/{id}/tracks ](#update-playlist-tracks ) | Update play count of tracks for a playlist |
2020-02-23 11:40:44 +01:00
| GET | [/api/library/playlists/{id}/playlists ](#list-playlists-in-a-playlist-folder ) | Get list of playlists for a playlist folder |
2018-03-02 12:37:32 +01:00
| GET | [/api/library/artists ](#list-artists ) | Get a list of artists |
2018-04-14 08:09:25 +02:00
| GET | [/api/library/artists/{id} ](#get-an-artist ) | Get an artist |
2018-03-02 12:37:32 +01:00
| GET | [/api/library/artists/{id}/albums ](#list-artist-albums ) | Get list of albums for an artist |
| GET | [/api/library/albums ](#list-albums ) | Get a list of albums |
2018-04-14 08:09:25 +02:00
| GET | [/api/library/albums/{id} ](#get-an-album ) | Get an album |
2018-03-02 12:37:32 +01:00
| GET | [/api/library/albums/{id}/tracks ](#list-album-tracks ) | Get list of tracks for an album |
2019-01-23 09:42:00 +01:00
| GET | [/api/library/tracks/{id} ](#get-a-track ) | Get a track |
2020-04-18 12:56:07 +02:00
| GET | [/api/library/tracks/{id}/playlists ](#list-playlists-for-a-track ) | Get list of playlists for a track |
2021-09-17 22:58:21 +02:00
| PUT | [/api/library/tracks/{id} ](#update-track-properties ) | Update track properties |
2018-09-02 08:05:18 +01:00
| GET | [/api/library/genres ](#list-genres ) | Get list of genres |
2018-04-22 09:01:43 +02:00
| GET | [/api/library/count ](#get-count-of-tracks-artists-and-albums ) | Get count of tracks, artists and albums |
2019-01-23 09:42:00 +01:00
| GET | [/api/library/files ](#list-local-directories ) | Get list of directories in the local library |
2020-03-21 22:20:59 +01:00
| POST | [/api/library/add ](#add-an-item-to-the-library ) | Add an item to the library |
2019-06-18 10:15:22 +01:00
| PUT | [/api/update ](#trigger-rescan ) | Trigger a library rescan |
2020-07-31 09:17:37 +01:00
| PUT | [/api/rescan ](#trigger-metadata-rescan ) | Trigger a library metadata rescan |
2020-07-31 09:16:31 +01:00
| PUT | [/api/library/backup ](#backup-db ) | Request library backup db |
2018-03-02 12:37:32 +01:00
2018-11-19 20:33:27 +01:00
### Library information
List some library stats
**Endpoint**
```http
GET /api/library
```
**Response**
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| songs | integer | Array of [`playlist` ](#playlist-object ) objects |
| db_playtime | integer | Total playtime of all songs in the library |
| artists | integer | Number of album artists in the library |
| albums | integer | Number of albums in the library |
| started_at | string | Server startup time (timestamp in `ISO 8601` format) |
| updated_at | string | Last library update (timestamp in `ISO 8601` format) |
| updating | boolean | `true` if library rescan is in progress |
**Example**
```shell
curl -X GET "http://localhost:3689/api/library"
```
```json
{
"songs": 217,
"db_playtime": 66811,
"artists": 9,
"albums": 19,
"started_at": "2018-11-19T19:06:08Z",
"updated_at": "2018-11-19T19:06:16Z",
"updating": false
}
```
2018-03-02 12:37:32 +01:00
### List playlists
2020-02-23 11:40:44 +01:00
Lists all playlists in your library (does not return playlist folders)
2018-03-02 12:37:32 +01:00
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-03-02 12:37:32 +01:00
GET /api/library/playlists
```
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| offset | *(Optional)* Offset of the first playlist to return |
| limit | *(Optional)* Maximum number of playlists to return |
**Response**
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| items | array | Array of [`playlist` ](#playlist-object ) objects |
| total | integer | Total number of playlists in the library |
| offset | integer | Requested offset of the first playlist |
| limit | integer | Requested maximum number of playlists |
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-03-02 12:37:32 +01:00
curl -X GET "http://localhost:3689/api/library/playlists"
```
2018-10-25 19:20:49 +02:00
```json
2018-03-02 12:37:32 +01:00
{
"items": [
{
"id": 1,
"name": "radio",
"path": "/music/srv/radio.m3u",
"smart_playlist": false,
"uri": "library:playlist:1"
},
...
],
"total": 20,
"offset": 0,
"limit": -1
}
```
2018-04-14 08:09:25 +02:00
### Get a playlist
Get a specific playlists in your library
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-04-14 08:09:25 +02:00
GET /api/library/playlists/{id}
```
**Path parameters**
| Parameter | Value |
| --------------- | -------------------- |
| id | Playlist id |
**Response**
On success returns the HTTP `200 OK` success status response code. With the response body holding the ** [`playlist` ](#playlist-object ) object**.
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-04-14 08:09:25 +02:00
curl -X GET "http://localhost:3689/api/library/playlists/1"
```
2018-10-25 19:20:49 +02:00
```json
2018-04-14 08:09:25 +02:00
{
"id": 1,
"name": "radio",
"path": "/music/srv/radio.m3u",
"smart_playlist": false,
"uri": "library:playlist:1"
}
```
2020-04-17 20:10:58 +02:00
### Update a playlist
Update attributes of a specific playlists in your library
**Endpoint**
```http
PUT /api/library/playlists/{id}
```
**Path parameters**
| Parameter | Value |
| --------------- | -------------------- |
| id | Playlist id |
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| query_limit | For RSS feeds, this sets how many podcasts to retrieve |
**Example**
```shell
curl -X PUT "http://localhost:3689/api/library/playlists/25?query_limit=20"
```
### Delete a playlist
Delete a playlist, e.g. a RSS feed
**Endpoint**
```http
DELETE /api/library/playlists/{id}
```
**Path parameters**
| Parameter | Value |
| --------------- | -------------------- |
| id | Playlist id |
**Example**
```shell
curl -X DELETE "http://localhost:3689/api/library/playlists/25"
```
2018-03-02 12:37:32 +01:00
### List playlist tracks
Lists the tracks in a playlists
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-03-02 12:37:32 +01:00
GET /api/library/playlists/{id}/tracks
```
**Path parameters**
| Parameter | Value |
| --------------- | -------------------- |
| id | Playlist id |
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| offset | *(Optional)* Offset of the first track to return |
| limit | *(Optional)* Maximum number of tracks to return |
**Response**
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| items | array | Array of [`track` ](#track-object ) objects |
| total | integer | Total number of tracks in the playlist |
| offset | integer | Requested offset of the first track |
| limit | integer | Requested maximum number of tracks |
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-03-02 12:37:32 +01:00
curl -X GET "http://localhost:3689/api/library/playlists/1/tracks"
```
2018-10-25 19:20:49 +02:00
```json
2018-03-02 12:37:32 +01:00
{
"items": [
{
"id": 10766,
"title": "Solange wir tanzen",
"artist": "Heinrich",
"artist_sort": "Heinrich",
"album": "Solange wir tanzen",
"album_sort": "Solange wir tanzen",
"albumartist": "Heinrich",
"albumartist_sort": "Heinrich",
"genre": "Electronica",
"year": 2014,
"track_number": 1,
"disc_number": 1,
"length_ms": 223085,
"play_count": 2,
2018-08-18 22:56:27 +02:00
"skip_count": 1,
"time_played": "2018-02-23T10:31:20Z",
2018-03-02 12:37:32 +01:00
"media_kind": "music",
"data_kind": "file",
"path": "/music/srv/Heinrich/Solange wir tanzen/01 Solange wir tanzen.mp3",
"uri": "library:track:10766"
},
...
],
"total": 20,
"offset": 0,
"limit": -1
}
```
2020-03-12 17:58:44 +00:00
### Update playlist tracks
Updates the play count for tracks in a playlists
**Endpoint**
```http
PUT /api/library/playlists/{id}/tracks
```
**Path parameters**
| Parameter | Value |
| --------------- | -------------------- |
| id | Playlist id |
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| play_count | Either `increment` , `played` or `reset` . `increment` will increment `play_count` and update `time_played` , `played` will be like `increment` but only where `play_count` is 0, `reset` will set `play_count` and `skip_count` to zero and delete `time_played` and `time_skipped` |
**Example**
```shell
curl -X PUT "http://localhost:3689/api/library/playlists/1/tracks?play_count=played"
```
2018-03-02 12:37:32 +01:00
2020-02-23 11:40:44 +01:00
### List playlists in a playlist folder
Lists the playlists in a playlist folder
**Note**: The root playlist folder has `id` 0.
**Endpoint**
```http
GET /api/library/playlists/{id}/playlists
```
**Path parameters**
| Parameter | Value |
| --------------- | -------------------- |
| id | Playlist id |
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| offset | *(Optional)* Offset of the first playlist to return |
| limit | *(Optional)* Maximum number of playlist to return |
**Response**
| Key | Type | Value |
| --------------- | -------- | ------------------------------------------------ |
| items | array | Array of [`playlist` ](#playlist-object ) objects |
| total | integer | Total number of playlists in the playlist folder |
| offset | integer | Requested offset of the first playlist |
| limit | integer | Requested maximum number of playlist |
**Example**
```shell
curl -X GET "http://localhost:3689/api/library/playlists/0/tracks"
```
```json
{
"items": [
{
"id": 11,
"name": "Spotify",
"path": "spotify:playlistfolder",
"parent_id": "0",
"smart_playlist": false,
"folder": true,
"uri": "library:playlist:11"
},
{
"id": 8,
"name": "bytefm",
"path": "/srv/music/Playlists/bytefm.m3u",
"parent_id": "0",
"smart_playlist": false,
"folder": false,
"uri": "library:playlist:8"
}
],
"total": 2,
"offset": 0,
"limit": -1
}
```
2018-03-02 12:37:32 +01:00
### List artists
Lists the artists in your library
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-03-02 12:37:32 +01:00
GET /api/library/artists
```
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| offset | *(Optional)* Offset of the first artist to return |
| limit | *(Optional)* Maximum number of artists to return |
**Response**
| Key | Type | Value |
| --------------- | -------- | ------------------------------------------- |
| items | array | Array of [`artist` ](#artist-object ) objects |
| total | integer | Total number of artists in the library |
| offset | integer | Requested offset of the first artist |
| limit | integer | Requested maximum number of artists |
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-03-02 12:37:32 +01:00
curl -X GET "http://localhost:3689/api/library/artists"
```
2018-10-25 19:20:49 +02:00
```json
2018-03-02 12:37:32 +01:00
{
"items": [
{
"id": "3815427709949443149",
"name": "ABAY",
"name_sort": "ABAY",
"album_count": 1,
"track_count": 10,
"length_ms": 2951554,
"uri": "library:artist:3815427709949443149"
},
...
],
"total": 20,
"offset": 0,
"limit": -1
}
```
2018-04-14 08:09:25 +02:00
### Get an artist
Get a specific artist in your library
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-04-14 08:09:25 +02:00
GET /api/library/artists/{id}
```
**Path parameters**
| Parameter | Value |
| --------------- | -------------------- |
| id | Artist id |
**Response**
On success returns the HTTP `200 OK` success status response code. With the response body holding the ** [`artist` ](#artist-object ) object**.
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-04-14 08:09:25 +02:00
curl -X GET "http://localhost:3689/api/library/artists/3815427709949443149"
```
2018-10-25 19:20:49 +02:00
```json
2018-04-14 08:09:25 +02:00
{
"id": "3815427709949443149",
"name": "ABAY",
"name_sort": "ABAY",
"album_count": 1,
"track_count": 10,
"length_ms": 2951554,
"uri": "library:artist:3815427709949443149"
}
```
2018-03-02 12:37:32 +01:00
### List artist albums
Lists the albums of an artist
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-03-02 12:37:32 +01:00
GET /api/library/artists/{id}/albums
```
**Path parameters**
| Parameter | Value |
| --------------- | -------------------- |
| id | Artist id |
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| offset | *(Optional)* Offset of the first album to return |
| limit | *(Optional)* Maximum number of albums to return |
**Response**
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| items | array | Array of [`album` ](#album-object ) objects |
| total | integer | Total number of albums of this artist |
| offset | integer | Requested offset of the first album |
| limit | integer | Requested maximum number of albums |
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-03-02 12:37:32 +01:00
curl -X GET "http://localhost:3689/api/library/artists/32561671101664759/albums"
```
2018-10-25 19:20:49 +02:00
```json
2018-03-02 12:37:32 +01:00
{
"items": [
{
"id": "8009851123233197743",
"name": "Add Violence",
"name_sort": "Add Violence",
"artist": "Nine Inch Nails",
"artist_id": "32561671101664759",
"track_count": 5,
"length_ms": 1634961,
"uri": "library:album:8009851123233197743"
},
...
],
"total": 20,
"offset": 0,
"limit": -1
}
```
### List albums
Lists the albums in your library
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-03-02 12:37:32 +01:00
GET /api/library/albums
```
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| offset | *(Optional)* Offset of the first album to return |
| limit | *(Optional)* Maximum number of albums to return |
**Response**
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| items | array | Array of [`album` ](#album-object ) objects |
| total | integer | Total number of albums in the library |
| offset | integer | Requested offset of the first albums |
| limit | integer | Requested maximum number of albums |
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-03-02 12:37:32 +01:00
curl -X GET "http://localhost:3689/api/library/albums"
```
2018-10-25 19:20:49 +02:00
```json
2018-03-02 12:37:32 +01:00
{
"items": [
{
"id": "8009851123233197743",
"name": "Add Violence",
"name_sort": "Add Violence",
"artist": "Nine Inch Nails",
"artist_id": "32561671101664759",
"track_count": 5,
"length_ms": 1634961,
"uri": "library:album:8009851123233197743"
},
...
],
"total": 20,
"offset": 0,
"limit": -1
}
```
2018-04-14 08:09:25 +02:00
### Get an album
Get a specific album in your library
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-04-14 08:09:25 +02:00
GET /api/library/albums/{id}
```
**Path parameters**
| Parameter | Value |
| --------------- | -------------------- |
| id | Album id |
**Response**
On success returns the HTTP `200 OK` success status response code. With the response body holding the ** [`album` ](#album-object ) object**.
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-04-14 08:09:25 +02:00
curl -X GET "http://localhost:3689/api/library/albums/8009851123233197743"
```
2018-10-25 19:20:49 +02:00
```json
2018-04-14 08:09:25 +02:00
{
"id": "8009851123233197743",
"name": "Add Violence",
"name_sort": "Add Violence",
"artist": "Nine Inch Nails",
"artist_id": "32561671101664759",
"track_count": 5,
"length_ms": 1634961,
"uri": "library:album:8009851123233197743"
}
```
2018-03-02 12:37:32 +01:00
### List album tracks
Lists the tracks in an album
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-03-02 12:37:32 +01:00
GET /api/library/albums/{id}/tracks
```
**Path parameters**
| Parameter | Value |
| --------------- | -------------------- |
| id | Album id |
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| offset | *(Optional)* Offset of the first track to return |
| limit | *(Optional)* Maximum number of tracks to return |
**Response**
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| items | array | Array of [`track` ](#track-object ) objects |
| total | integer | Total number of tracks |
| offset | integer | Requested offset of the first track |
| limit | integer | Requested maximum number of tracks |
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-03-02 12:37:32 +01:00
curl -X GET "http://localhost:3689/api/library/albums/1/tracks"
```
2018-10-25 19:20:49 +02:00
```json
2018-03-02 12:37:32 +01:00
{
"items": [
{
"id": 10766,
"title": "Solange wir tanzen",
"artist": "Heinrich",
"artist_sort": "Heinrich",
"album": "Solange wir tanzen",
"album_sort": "Solange wir tanzen",
"albumartist": "Heinrich",
"albumartist_sort": "Heinrich",
"genre": "Electronica",
"year": 2014,
"track_number": 1,
"disc_number": 1,
"length_ms": 223085,
"play_count": 2,
"last_time_played": "2018-02-23T10:31:20Z",
"media_kind": "music",
"data_kind": "file",
"path": "/music/srv/Heinrich/Solange wir tanzen/01 Solange wir tanzen.mp3",
"uri": "library:track:10766"
},
...
],
"total": 20,
"offset": 0,
"limit": -1
}
```
2019-01-23 09:42:00 +01:00
### Get a track
Get a specific track in your library
**Endpoint**
```http
GET /api/library/tracks/{id}
```
**Path parameters**
| Parameter | Value |
| --------------- | -------------------- |
| id | Track id |
**Response**
On success returns the HTTP `200 OK` success status response code. With the response body holding the ** [`track` ](#track-object ) object**.
**Example**
```shell
curl -X GET "http://localhost:3689/api/library/track/1"
```
```json
{
"id": 1,
"title": "Pardon Me",
"title_sort": "Pardon Me",
"artist": "Incubus",
"artist_sort": "Incubus",
"album": "Make Yourself",
"album_sort": "Make Yourself",
"album_id": "6683985628074308431",
"album_artist": "Incubus",
"album_artist_sort": "Incubus",
"album_artist_id": "4833612337650426236",
"composer": "Alex Katunich/Brandon Boyd/Chris Kilmore/Jose Antonio Pasillas II/Mike Einziger",
"genre": "Alternative Rock",
"year": 2001,
"track_number": 12,
"disc_number": 1,
"length_ms": 223170,
"rating": 0,
2021-09-16 10:51:54 +01:00
"usermark": 0,
2019-01-23 09:42:00 +01:00
"play_count": 0,
"skip_count": 0,
"time_added": "2019-01-20T11:58:29Z",
"date_released": "2001-05-27",
"seek_ms": 0,
"media_kind": "music",
"data_kind": "file",
"path": "/music/srv/Incubus/Make Yourself/12 Pardon Me.mp3",
"uri": "library:track:1",
"artwork_url": "/artwork/item/1"
}
```
2020-04-18 12:56:07 +02:00
### List playlists for a track
Get the list of playlists that contain a track (does not return smart playlists)
**Endpoint**
```http
GET /api/library/tracks/{id}/playlists
```
**Path parameters**
| Parameter | Value |
| --------------- | -------------------- |
| id | Track id |
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| offset | *(Optional)* Offset of the first playlist to return |
| limit | *(Optional)* Maximum number of playlist to return |
**Response**
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| items | array | Array of [`playlist` ](#playlist-object ) objects |
| total | integer | Total number of playlists |
| offset | integer | Requested offset of the first playlist |
| limit | integer | Requested maximum number of playlists |
**Example**
```shell
curl -X GET "http://localhost:3689/api/library/tracks/27/playlists"
```
```json
{
"items": [
{
"id": 1,
"name": "playlist",
"path": "/music/srv/playlist.m3u",
"smart_playlist": false,
"uri": "library:playlist:1"
},
...
],
"total": 2,
"offset": 0,
"limit": -1
}
```
2019-01-23 09:42:00 +01:00
### Update track properties
2021-09-16 10:51:54 +01:00
Change properties of a specific track (supported properties are "rating", "play_count" and "usermark")
2019-01-23 09:42:00 +01:00
**Endpoint**
```http
PUT /api/library/tracks/{id}
```
**Path parameters**
| Parameter | Value |
| --------------- | -------------------- |
| id | Track id |
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| rating | The new rating (0 - 100) |
| play_count | Either `increment` or `reset` . `increment` will increment `play_count` and update `time_played` , `reset` will set `play_count` and `skip_count` to zero and delete `time_played` and `time_skipped` |
2021-09-16 10:51:54 +01:00
| usermark | The new usermark (>= 0) |
2019-01-23 09:42:00 +01:00
**Response**
On success returns the HTTP `204 No Content` success status response code.
**Example**
```shell
curl -X PUT "http://localhost:3689/api/library/tracks/1?rating=100"
```
```shell
curl -X PUT "http://localhost:3689/api/library/tracks/1?play_count=increment"
```
2018-11-24 12:43:28 +01:00
### List genres
2018-09-02 08:05:18 +01:00
Get list of genres
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-09-02 08:05:18 +01:00
GET /api/library/genres
```
**Response**
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| items | array | Array of [`genre` ](#genre-object ) objects |
| total | integer | Total number of genres in the library |
| offset | integer | Requested offset of the first genre |
| limit | integer | Requested maximum number of genres |
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-09-02 08:05:18 +01:00
curl -X GET "http://localhost:3689/api/library/genres"
```
2018-10-25 19:20:49 +02:00
```json
2018-09-02 08:05:18 +01:00
{
"items": [
{
"name": "Classical"
},
{
"name": "Drum & Bass"
},
{
"name": "Pop"
},
{
"name": "Rock/Pop"
},
{
"name": "'90s Alternative"
}
],
"total": 5,
"offset": 0,
"limit": -1
}
```
### List albums for genre
Lists the albums in a genre
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-09-02 08:05:18 +01:00
GET api/search?type=albums& expression=genre+is+\"{genre name}\""
```
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| genre | genre name (uri encoded and html esc seq for chars: '/& ) |
| offset | *(Optional)* Offset of the first album to return |
| limit | *(Optional)* Maximum number of albums to return |
**Response**
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| items | array | Array of [`album` ](#album-object ) objects |
| total | integer | Total number of albums in the library |
| offset | integer | Requested offset of the first albums |
| limit | integer | Requested maximum number of albums |
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-09-02 08:05:18 +01:00
curl -X GET "http://localhost:3689/api/search?type=albums& expression=genre+is+\"Pop\""
curl -X GET "http://localhost:3689/api/search?type=albums& expression=genre+is+\"Rock%2FPop\"" # Rock/Pop
curl -X GET "http://localhost:3689/api/search?type=albums& expression=genre+is+\"Drum%20%26%20Bass\"" # Drum & Bass
curl -X GET "http://localhost:3689/api/search?type=albums& expression=genre+is+\"%2790s%20Alternative\"" # '90 Alternative
```
2018-10-25 19:20:49 +02:00
```json
2018-09-02 08:05:18 +01:00
{
"albums": {
"items": [
{
"id": "320189328729146437",
"name": "Best Ever",
"name_sort": "Best Ever",
"artist": "ABC",
"artist_id": "8760559201889050080",
"track_count": 1,
"length_ms": 3631,
"uri": "library:album:320189328729146437"
},
{
"id": "7964595866631625723",
"name": "Greatest Hits",
"name_sort": "Greatest Hits",
"artist": "Marvin Gaye",
"artist_id": "5261930703203735930",
"track_count": 2,
"length_ms": 7262,
"uri": "library:album:7964595866631625723"
},
{
"id": "3844610748145176456",
"name": "The Very Best of Etta",
"name_sort": "Very Best of Etta",
"artist": "Etta James",
"artist_id": "2627182178555864595",
"track_count": 1,
"length_ms": 177926,
"uri": "library:album:3844610748145176456"
}
],
"total": 3,
"offset": 0,
"limit": -1
}
}
```
2018-04-22 09:01:43 +02:00
### Get count of tracks, artists and albums
Get information about the number of tracks, artists and albums and the total playtime
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-04-22 09:01:43 +02:00
GET /api/library/count
```
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| expression | *(Optional)* The smart playlist query expression, if this parameter is omitted returns the information for the whole library |
**Response**
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| tracks | integer | Number of tracks matching the expression |
| artists | integer | Number of artists matching the expression |
| albums | integer | Number of albums matching the expression |
| db_playtime | integer | Total playtime in milliseconds of all tracks matching the expression |
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-04-22 09:01:43 +02:00
curl -X GET "http://localhost:3689/api/library/count?expression=data_kind+is+file"
```
2018-10-25 19:20:49 +02:00
```json
2018-04-22 09:01:43 +02:00
{
"tracks": 6811,
"artists": 355,
"albums": 646,
"db_playtime": 1590767
}
```
2018-11-19 20:33:27 +01:00
2018-11-24 12:43:28 +01:00
### List local directories
List the local directories and the directory contents (tracks and playlists)
**Endpoint**
```http
GET /api/library/files
```
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| directory | *(Optional)* A path to a directory in your local library. |
**Response**
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| directories | array | Array of [`directory` ](#directory-object ) objects containing the sub directories |
| tracks | object | [`paging` ](#paging-object ) object containing [`track` ](#track-object ) objects that matches the `directory` |
| playlists | object | [`paging` ](#paging-object ) object containing [`playlist` ](#playlist-object ) objects that matches the `directory` |
**Example**
```shell
curl -X GET "http://localhost:3689/api/library/files?directory=/music/srv"
```
```json
{
"directories": [
{
"path": "/music/srv/Audiobooks"
},
{
"path": "/music/srv/Music"
},
{
"path": "/music/srv/Playlists"
},
{
"path": "/music/srv/Podcasts"
}
],
"tracks": {
"items": [
{
"id": 1,
"title": "input.pipe",
"artist": "Unknown artist",
"artist_sort": "Unknown artist",
"album": "Unknown album",
"album_sort": "Unknown album",
"album_id": "4201163758598356043",
"album_artist": "Unknown artist",
"album_artist_sort": "Unknown artist",
"album_artist_id": "4187901437947843388",
"genre": "Unknown genre",
"year": 0,
"track_number": 0,
"disc_number": 0,
"length_ms": 0,
"play_count": 0,
"skip_count": 0,
"time_added": "2018-11-24T08:41:35Z",
"seek_ms": 0,
"media_kind": "music",
"data_kind": "pipe",
"path": "/music/srv/input.pipe",
"uri": "library:track:1",
"artwork_url": "/artwork/item/1"
}
],
"total": 1,
"offset": 0,
"limit": -1
},
"playlists": {
"items": [
{
"id": 8,
"name": "radio",
"path": "/music/srv/radio.m3u",
"smart_playlist": true,
"uri": "library:playlist:8"
}
],
"total": 1,
"offset": 0,
"limit": -1
}
}
```
2018-11-19 20:33:27 +01:00
### Trigger rescan
Trigger a library rescan
**Endpoint**
```http
2019-06-18 10:15:22 +01:00
PUT /api/update
2018-11-19 20:33:27 +01:00
```
**Response**
On success returns the HTTP `204 No Content` success status response code.
**Example**
```shell
2019-06-18 10:15:22 +01:00
curl -X PUT "http://localhost:3689/api/update"
2018-11-19 20:33:27 +01:00
```
```json
{
"songs": 217,
"db_playtime": 66811,
"artists": 9,
"albums": 19,
"started_at": "2018-11-19T19:06:08Z",
"updated_at": "2018-11-19T19:06:16Z",
"updating": false
}
```
2018-04-22 09:01:43 +02:00
2019-07-09 12:46:17 +01:00
### Trigger metadata rescan
2019-06-08 19:44:51 +01:00
Trigger a library metadata rescan even if files have not been updated. Maintenence method.
**Endpoint**
```http
2019-06-18 09:36:57 +01:00
PUT /api/rescan
2019-06-08 19:44:51 +01:00
```
**Response**
On success returns the HTTP `204 No Content` success status response code.
**Example**
```shell
2019-06-18 09:36:57 +01:00
curl -X PUT "http://localhost:3689/api/rescan"
2019-06-08 19:44:51 +01:00
```
2018-04-22 09:01:43 +02:00
2020-07-31 09:16:31 +01:00
### Backup DB
Request a library backup - configuration must be enabled and point to a valid writable path. Maintenance method.
**Endpoint**
```http
PUT /api/library/backup
```
**Response**
On success returns the HTTP `200 OK` success status response code.
If backups are not enabled returns HTTP `503 Service Unavailable` response code.
Otherwise a HTTP `500 Internal Server Error` response is returned.
**Example**
```shell
curl -X PUT "http://localhost:3689/api/library/backup"
```
2018-03-02 12:37:32 +01:00
2018-04-14 08:09:25 +02:00
## Search
| Method | Endpoint | Description |
| --------- | ----------------------------------------------------------- | ------------------------------------ |
2018-09-02 08:05:18 +01:00
| GET | [/api/search ](#search-by-search-term ) | Search for playlists, artists, albums, tracks,genres by a simple search term |
2018-04-14 08:09:25 +02:00
| GET | [/api/search ](#search-by-query-language ) | Search by complex query expression |
### Search by search term
2018-09-02 08:05:18 +01:00
Search for playlists, artists, albums, tracks, genres that include the given query in their title (case insensitive matching).
2018-04-14 08:09:25 +02:00
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-04-14 08:09:25 +02:00
GET /api/search
```
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| query | The search keyword |
2018-09-02 08:05:18 +01:00
| type | Comma separated list of the result types (`playlist` , `artist` , `album` , `track` , `genre` ) |
2018-04-22 09:01:43 +02:00
| media_kind | *(Optional)* Filter results by media kind (`music` , `movie` , `podcast` , `audiobook` , `musicvideo` , `tvshow` ). Filter only applies to artist, album and track result types. |
2018-04-14 08:09:25 +02:00
| offset | *(Optional)* Offset of the first item to return for each type |
| limit | *(Optional)* Maximum number of items to return for each type |
**Response**
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| tracks | object | [`paging` ](#paging-object ) object containing [`track` ](#track-object ) objects that matches the `query` |
| artists | object | [`paging` ](#paging-object ) object containing [`artist` ](#artist-object ) objects that matches the `query` |
| albums | object | [`paging` ](#paging-object ) object containing [`album` ](#album-object ) objects that matches the `query` |
| playlists | object | [`paging` ](#paging-object ) object containing [`playlist` ](#playlist-object ) objects that matches the `query` |
**Example**
Search for all tracks, artists, albums and playlists that contain "the" in their title and return the first two results for each type:
2018-10-25 19:20:49 +02:00
```shell
2018-04-14 08:09:25 +02:00
curl -X GET "http://localhost:3689/api/search?type=tracks,artists,albums,playlists& query=the& offset=0& limit=2"
```
2018-10-25 19:20:49 +02:00
```json
2018-04-14 08:09:25 +02:00
{
"tracks": {
"items": [
{
"id": 35,
"title": "Another Love",
"artist": "Tom Odell",
"artist_sort": "Tom Odell",
"album": "Es is was es is",
"album_sort": "Es is was es is",
"album_id": "6494853621007413058",
"album_artist": "Various artists",
"album_artist_sort": "Various artists",
"album_artist_id": "8395563705718003786",
"genre": "Singer/Songwriter",
"year": 2013,
"track_number": 7,
"disc_number": 1,
"length_ms": 251030,
"play_count": 0,
"media_kind": "music",
"data_kind": "file",
"path": "/music/srv/Compilations/Es is was es is/07 Another Love.m4a",
"uri": "library:track:35"
},
{
"id": 215,
"title": "Away From the Sun",
"artist": "3 Doors Down",
"artist_sort": "3 Doors Down",
"album": "Away From the Sun",
"album_sort": "Away From the Sun",
"album_id": "8264078270267374619",
"album_artist": "3 Doors Down",
"album_artist_sort": "3 Doors Down",
"album_artist_id": "5030128490104968038",
"genre": "Rock",
"year": 2002,
"track_number": 2,
"disc_number": 1,
"length_ms": 233278,
"play_count": 0,
"media_kind": "music",
"data_kind": "file",
"path": "/music/srv/Away From the Sun/02 Away From the Sun.mp3",
"uri": "library:track:215"
}
],
"total": 14,
"offset": 0,
"limit": 2
},
"artists": {
"items": [
{
"id": "8737690491750445895",
"name": "The xx",
"name_sort": "xx, The",
"album_count": 2,
"track_count": 25,
"length_ms": 5229196,
"uri": "library:artist:8737690491750445895"
}
],
"total": 1,
"offset": 0,
"limit": 2
},
"albums": {
"items": [
{
"id": "8264078270267374619",
"name": "Away From the Sun",
"name_sort": "Away From the Sun",
"artist": "3 Doors Down",
"artist_id": "5030128490104968038",
"track_count": 12,
"length_ms": 2818174,
"uri": "library:album:8264078270267374619"
},
{
"id": "6835720495312674468",
"name": "The Better Life",
"name_sort": "Better Life",
"artist": "3 Doors Down",
"artist_id": "5030128490104968038",
"track_count": 11,
"length_ms": 2393332,
"uri": "library:album:6835720495312674468"
}
],
"total": 3,
"offset": 0,
"limit": 2
},
"playlists": {
"items": [],
"total": 0,
"offset": 0,
"limit": 2
}
}
```
### Search by query language
2021-03-29 16:14:22 +02:00
Search for artists, albums, tracks by a smart playlist query expression (see [README_SMARTPL.md ](https://github.com/owntone/owntone-server/blob/master/README_SMARTPL.md ) for the expression syntax).
2018-04-14 08:09:25 +02:00
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-04-14 08:09:25 +02:00
GET /api/search
```
**Query parameters**
| Parameter | Value |
| --------------- | ----------------------------------------------------------- |
| expression | The smart playlist query expression |
| type | Comma separated list of the result types (`artist` , `album` , `track` |
| offset | *(Optional)* Offset of the first item to return for each type |
| limit | *(Optional)* Maximum number of items to return for each type |
**Response**
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| tracks | object | [`paging` ](#paging-object ) object containing [`track` ](#track-object ) objects that matches the `query` |
| artists | object | [`paging` ](#paging-object ) object containing [`artist` ](#artist-object ) objects that matches the `query` |
| albums | object | [`paging` ](#paging-object ) object containing [`album` ](#album-object ) objects that matches the `query` |
**Example**
Search for music tracks ordered descending by the time added to the library and limit result to 2 items:
2018-10-25 19:20:49 +02:00
```shell
2018-04-14 08:09:25 +02:00
curl -X GET "http://localhost:3689/api/search?type=tracks& expression=media_kind+is+music+order+by+time_added+desc& offset=0& limit=2"
```
2018-03-02 12:37:32 +01:00
2018-02-08 21:19:55 +01:00
## Server info
| Method | Endpoint | Description |
| --------- | ------------------------------------------------ | ------------------------------------ |
| GET | [/api/config ](#config ) | Get configuration information |
### Config
**Endpoint**
2018-10-25 19:20:49 +02:00
```http
2018-02-08 21:19:55 +01:00
GET /api/config
```
**Response**
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
2021-04-09 19:37:54 +02:00
| version | string | Server version |
2018-02-08 21:19:55 +01:00
| websocket_port | integer | Port number for the [websocket ](#push-notifications ) (or `0` if websocket is disabled) |
2021-04-09 19:37:54 +02:00
| buildoptions | array | Array of strings indicating which features are supported by the server |
2018-02-08 21:19:55 +01:00
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-02-08 21:19:55 +01:00
curl -X GET "http://localhost:3689/api/config"
```
2018-10-25 19:20:49 +02:00
```json
2018-02-08 21:19:55 +01:00
{
"websocket_port": 3688,
"version": "25.0",
"buildoptions": [
"ffmpeg",
"iTunes XML",
"Spotify",
"LastFM",
"MPD",
"Device verification",
"Websockets",
"ALSA"
]
}
```
2019-08-31 08:43:53 +02:00
## Settings
| Method | Endpoint | Description |
| --------- | ------------------------------------------------ | ------------------------------------ |
| GET | [/api/settings ](#list-categories ) | Get all available categories |
| GET | [/api/settings/{category-name} ](#get-a-category ) | Get all available options for a category |
2020-05-16 00:04:37 +02:00
| GET | [/api/settings/{category-name}/{option-name} ](#get-an-option ) | Get a single setting option |
| PUT | [/api/settings/{category-name}/{option-name} ](#change-an-option-value ) | Change the value of a setting option |
| DELETE | [/api/settings/{category-name}/{option-name} ](#delete-an-option ) | Reset a setting option to its default |
2019-08-31 08:43:53 +02:00
### List categories
List all settings categories with their options
**Endpoint**
```http
GET /api/settings
```
**Response**
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| categories | array | Array of settings [category ](#category-object ) objects |
**Example**
```shell
curl -X GET "http://localhost:3689/api/settings"
```
```json
{
"categories": [
{
"name": "webinterface",
"options": [
{
"name": "show_composer_now_playing",
"type": 1,
"value": true
},
{
"name": "show_composer_for_genre",
"type": 2,
"value": "classical"
}
]
}
]
}
```
### Get a category
Get a settings category with their options
**Endpoint**
```http
GET /api/settings/{category-name}
```
**Response**
Returns a settings [category ](#category-object ) object
**Example**
```shell
curl -X GET "http://localhost:3689/api/settings/webinterface"
```
```json
{
"name": "webinterface",
"options": [
{
"name": "show_composer_now_playing",
"type": 1,
"value": true
},
{
"name": "show_composer_for_genre",
"type": 2,
"value": "classical"
}
]
}
```
2020-05-16 00:04:37 +02:00
### Get an option
2019-08-31 08:43:53 +02:00
Get a single settings option
**Endpoint**
```http
GET /api/settings/{category-name}/{option-name}
```
**Response**
Returns a settings [option ](#option-object ) object
**Example**
```shell
curl -X GET "http://localhost:3689/api/settings/webinterface/show_composer_now_playing"
```
```json
{
"name": "show_composer_now_playing",
"type": 1,
"value": true
}
```
2020-05-16 00:04:37 +02:00
### Change an option value
2019-08-31 08:43:53 +02:00
Get a single settings option
**Endpoint**
```http
PUT /api/settings/{category-name}/{option-name}
```
**Request**
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| name | string | Option name |
| value | (integer / boolean / string) | New option value |
**Response**
On success returns the HTTP `204 No Content` success status response code.
**Example**
```shell
curl -X PUT "http://localhost:3689/api/settings/webinterface/show_composer_now_playing" --data "{\"name\":\"show_composer_now_playing\",\"value\":true}"
```
2020-05-16 00:04:37 +02:00
### Delete an option
Delete a single settings option (thus resetting it to default)
**Endpoint**
```http
DELETE /api/settings/{category-name}/{option-name}
```
**Response**
On success returns the HTTP `204 No Content` success status response code.
**Example**
```shell
curl -X DELETE "http://localhost:3689/api/settings/webinterface/show_composer_now_playing"
```
2018-02-08 21:19:55 +01:00
## Push notifications
2021-04-09 19:37:54 +02:00
If the server was built with websocket support it exposes a websocket at `localhost:3688` to inform clients of changes (e. g. player state or library updates).
The port depends on the server configuration and can be read using the [`/api/config` ](#config ) endpoint.
2018-02-08 21:19:55 +01:00
2021-04-09 19:37:54 +02:00
After connecting to the websocket, the client should send a message containing the event types it is interested in. After that the server
2018-02-08 21:19:55 +01:00
will send a message each time one of the events occurred.
**Message**
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| notify | array | Array of event types |
**Event types**
| Type | Description |
| --------------- | ----------------------------------------- |
| update | Library update started or finished |
2018-12-30 09:06:53 +01:00
| database | Library database changed (new/modified/deleted tracks) |
2018-02-08 21:19:55 +01:00
| outputs | An output was enabled or disabled |
| player | Player state changes |
| options | Playback option changes (shuffle, repeat, consume mode) |
| volume | Volume changes |
| queue | Queue changes |
**Example**
2018-10-25 19:20:49 +02:00
```shell
2018-02-08 21:19:55 +01:00
curl --include \
--no-buffer \
--header "Connection: Upgrade" \
--header "Upgrade: websocket" \
--header "Host: localhost:3688" \
--header "Origin: http://localhost:3688" \
--header "Sec-WebSocket-Key: SGVsbG8sIHdvcmxkIQ==" \
--header "Sec-WebSocket-Version: 13" \
--header "Sec-WebSocket-Protocol: notify" \
http://localhost:3688/ \
--data "{ \"notify\": [ \"player\" ] }"
```
2018-10-25 19:20:49 +02:00
```json
2018-02-08 21:19:55 +01:00
{
"notify": [
"player"
]
}
```
2018-03-02 12:37:32 +01:00
## Object model
### `queue item` object
| Key | Type | Value |
| ------------------ | -------- | ----------------------------------------- |
| id | string | Item id |
| position | integer | Position in the queue (starting with zero) |
| track_id | string | Track id |
| title | string | Title |
| artist | string | Track artist name |
| artist_sort | string | Track artist sort name |
| album | string | Album name |
| album_sort | string | Album sort name |
2019-02-14 08:24:36 +01:00
| album_id | string | Album id |
2018-03-02 12:37:32 +01:00
| album_artist | string | Album artist name |
| album_artist_sort | string | Album artist sort name |
2019-02-14 08:24:36 +01:00
| album_artist_id | string | Album artist id |
2018-11-23 14:52:30 +00:00
| composer | string | Composer (optional) |
2018-03-02 12:37:32 +01:00
| genre | string | Genre |
| year | integer | Release year |
| track_number | integer | Track number |
| disc_number | integer | Disc number |
| length_ms | integer | Track length in milliseconds |
| media_kind | string | Media type of this track: `music` , `movie` , `podcast` , `audiobook` , `musicvideo` , `tvshow` |
| data_kind | string | Data type of this track: `file` , `url` , `spotify` , `pipe` |
| path | string | Path |
| uri | string | Resource identifier |
2018-11-30 07:19:12 +01:00
| artwork_url | string | *(optional)* [Artwork url ](#artwork-urls ) |
2019-06-04 22:02:15 +01:00
| type | string | file (codec) type (ie mp3/flac/...) |
| bitrate | string | file bitrate (ie 192/128/...) |
| samplerate | string | file sample rate (ie 44100/48000/...) |
| channel | string | file channel (ie mono/stereo/xx ch)) |
2018-03-02 12:37:32 +01:00
### `playlist` object
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| id | string | Playlist id |
| name | string | Playlist name |
| path | string | Path |
2020-02-23 11:40:44 +01:00
| parent_id | integer | Playlist id of the parent (folder) playlist |
| type | string | Type of this playlist: `special` , `folder` , `smart` , `plain` |
| smart_playlist | boolean | `true` if playlist is a smart playlist |
| folder | boolean | `true` if it is a playlist folder |
2018-03-02 12:37:32 +01:00
| uri | string | Resource identifier |
### `artist` object
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| id | string | Artist id |
| name | string | Artist name |
| name_sort | string | Artist sort name |
| album_count | integer | Number of albums |
| track_count | integer | Number of tracks |
| length_ms | integer | Total length of tracks in milliseconds |
| uri | string | Resource identifier |
2018-11-30 07:19:12 +01:00
| artwork_url | string | *(optional)* [Artwork url ](#artwork-urls ) |
2018-03-02 12:37:32 +01:00
### `album` object
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| id | string | Album id |
| name | string | Album name |
| name_sort | string | Album sort name |
| artist_id | string | Album artist id |
| artist | string | Album artist name |
| track_count | integer | Number of tracks |
| length_ms | integer | Total length of tracks in milliseconds |
| uri | string | Resource identifier |
2018-11-30 07:19:12 +01:00
| artwork_url | string | *(optional)* [Artwork url ](#artwork-urls ) |
2018-03-02 12:37:32 +01:00
### `track` object
| Key | Type | Value |
| ------------------ | -------- | ----------------------------------------- |
| id | string | Track id |
| title | string | Title |
2018-12-15 09:02:02 +01:00
| title_sort | string | Sort title |
2018-03-02 12:37:32 +01:00
| artist | string | Track artist name |
| artist_sort | string | Track artist sort name |
| album | string | Album name |
| album_sort | string | Album sort name |
2018-04-14 08:09:25 +02:00
| album_id | string | Album id |
2018-03-02 12:37:32 +01:00
| album_artist | string | Album artist name |
| album_artist_sort | string | Album artist sort name |
2018-04-14 08:09:25 +02:00
| album_artist_id | string | Album artist id |
2018-11-23 14:52:30 +00:00
| composer | string | Track composer |
2018-03-02 12:37:32 +01:00
| genre | string | Genre |
2021-07-04 12:04:41 +02:00
| comment | string | Comment |
2018-03-02 12:37:32 +01:00
| year | integer | Release year |
| track_number | integer | Track number |
| disc_number | integer | Disc number |
| length_ms | integer | Track length in milliseconds |
2018-12-15 09:02:02 +01:00
| rating | integer | Track rating (ranges from 0 to 100) |
2018-03-02 12:37:32 +01:00
| play_count | integer | How many times the track was played |
2018-12-15 09:02:02 +01:00
| skip_count | integer | How many times the track was skipped |
2018-04-22 09:01:43 +02:00
| time_played | string | Timestamp in `ISO 8601` format |
2018-12-15 09:02:02 +01:00
| time_skipped | string | Timestamp in `ISO 8601` format |
2018-04-22 09:01:43 +02:00
| time_added | string | Timestamp in `ISO 8601` format |
| date_released | string | Date in the format `yyyy-mm-dd` |
| seek_ms | integer | Resume point in milliseconds (available only for podcasts and audiobooks) |
2018-03-02 12:37:32 +01:00
| media_kind | string | Media type of this track: `music` , `movie` , `podcast` , `audiobook` , `musicvideo` , `tvshow` |
2019-02-22 13:25:44 +01:00
| data_kind | string | Data type of this track: `file` , `url` , `spotify` , `pipe` |
2018-03-02 12:37:32 +01:00
| path | string | Path |
| uri | string | Resource identifier |
2018-11-30 07:19:12 +01:00
| artwork_url | string | *(optional)* [Artwork url ](#artwork-urls ) |
2021-09-16 10:51:54 +01:00
| usermark | integer | User review marking of track (ranges from 0) |
2018-04-14 08:09:25 +02:00
### `paging` object
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| items | array | Array of result objects |
| total | integer | Total number of items |
| offset | integer | Requested offset of the first item |
| limit | integer | Requested maximum number of items |
2018-09-02 08:05:18 +01:00
### `genre` object
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| name | string | Name of genre |
2018-11-30 07:19:12 +01:00
2018-11-24 12:43:28 +01:00
### `directory` object
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| path | string | Directory path |
2018-11-30 07:19:12 +01:00
2019-08-31 08:43:53 +02:00
### `category` object
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| name | string | Category name |
| options | array | Array of option in this category |
### `option` object
| Key | Type | Value |
| --------------- | -------- | ----------------------------------------- |
| name | string | Option name |
| type | integer | The type of the value for this option (`0` : integer, `1` : boolean, `2` : string) |
| value | (integer / boolean / string) | Current value for this option |
2018-11-30 07:19:12 +01:00
### Artwork urls
Artwork urls in `queue item` , `artist` , `album` and `track` objects can be either relative urls or absolute urls to the artwork image.
2021-04-09 19:37:54 +02:00
Absolute artwork urls are pointing to external artwork images (e. g. for radio streams that provide artwork metadata), while relative artwork urls are served from the server.
2018-11-30 07:19:12 +01:00
2021-04-09 19:37:54 +02:00
It is possible to add the query parameters `maxwidth` and/or `maxheight` to relative artwork urls, in order to get a smaller image (the server only scales down never up).
2018-11-30 07:19:12 +01:00
2018-11-24 12:43:28 +01:00
Note that even if a relative artwork url attribute is present, it is not guaranteed to exist.