layout | title |
---|---|
default |
CLI - Database commands |
rescan <|playlists|onlinelibrary|external|full singlefolder|?>
The rescan
command causes the server to rescan the entire music library, reloading the music file information.
- If
playlists
is indicated (rescan playlists
), only the playlist directory is rescanned. - If
onlinelibrary
is indicated (rescan onlinelibrary
), only the import from online music services is run. - If
external
is requested, the rescan will be performed using the external scanner process instead of the in-process scanner. - If
full file://some/path
is defined, then only this path will be scanned. Issued with a?
,rescan ?
returns if the server is currently scanning.
Scanning occurs when the server starts and following rescan
and wipecache
commands.
Examples:
Request: "rescan<LF>"
Response: "rescan<LF>"
Request: "rescan ?<LF>"
Response: "rescan 1<LF>"
rescanprogress
The rescanprogress
query returns details on the scanning progress. This query does not take any parameters.
Returned tagged parameters:
Tag | Description |
---|---|
rescan |
Returned with value 1 if the server is still scanning the database, otherwise returned with value 0 and the fields below are not returned. |
totaltime |
Total elapsed time since the start of the scan, format hh:mm:ss . |
importer |
A completion percentage for each importer. Importers include:-directory (Music folder), playlist (Playlist folder), iTunes (iTunes), musicip (MusicIP), as well as more technical ones such as mergeva (Various Artists merging) and dboptimize (Database optimization).The type, quantity and order of importers is determined dynamically as rescan progresses. |
info |
Additional information about the current scanning step, like eg. the currently scanned file name. |
steps |
Scanning steps in the order they've been executed. |
lastscanfailed |
Information about a possible failure in case a scan has not finished in an attended manner. |
Example:
Request: "rescanprogress<LF>"
Response: "rescanprogress rescan:1 totaltime:00:00:07 directory:100 playlist:100 itunes:15 <LF>"
Request: "rescanprogress<LF>"
Response: "rescanprogress rescan:1 totaltime:00:01:04 directory:100 playlist:100 itunes:100 itunes_playlists:100 mergeva:100 cleanup1:100 cleanup2:100 dboptimize:47 <LF>"
abortscan
The abortscan
command causes the server to cancel a running scan. Please note that after stopping a scan this way you'll have to fully rescan your music collection to get consistent data.
Examples:
Request: "abortscan<LF>"
Response: "abortscan<LF>"
wipecache
The wipecache
command allows the caller to have the server rescan its music library, reloading the music file information. This differs from the rescan
command in that it first clears the tag database. During a rescan triggered by wipecache
, rescan ?
returns true.
Examples:
Request: "wipecache<LF>"
Response: "wipecache<LF>"
libraries
The libraries
query returns a list of known library views with their ID to the caller.
Examples:
Request: "libraries<LF>"
Response: "libraries id:8c7ee510 name:FLAC%20files%20only<LF>"
<playerid> libraries getid
The libraries getid
query returns the ID and the name of library set to be used by the given player. Returns id:0 and no name if no library is active.
Examples:
Request: "04:20:00:12:23:45 libraries getid<LF>"
Request: "04:20:00:12:23:45 libraries getid id:8c7ee510 name:FLAC%20files%20only<LF>"
info total genres ?
The info total genres ?
query returns the number of unique genres in the server music database.
Examples:
Request: "info total genres ?<LF>"
Response: "info total genres 18<LF>"
info total artists ?
The info total artists ?
query returns the number of unique artists in the server music database. The Composer, band and orchestra in artists
preference (Server Settings, Behavior) determines which contributors are considered artists.
Examples:
Request: "info total artists ?<LF>"
Response: "info total artists 18<LF>"
info total albums ?
The info total albums ?
query returns the number of unique albums in the server music database.
Examples:
Request: "info total albums ?<LF>"
Response: "info total albums 18<LF>"
info total songs ?
The info total songs ?
query returns the number of unique songs in the server music database.
Examples:
Request: "info total songs ?<LF>"
Response: "info total songs 18<LF>"
info total duration ?
The info total duration ?
query returns the number of seconds playtime in the server music database.
Examples:
Request: "info total duration ?<LF>"
Response: "info total duration 66109<LF>"
genres <start> <itemsPerResponse> <taggedParameters>
The genres
query returns all genres known by the server.
Note that the server supports multiple genres per track, depending on the Multiple items in tags
preference (Server Settings, Behavior).
Accepted tagged parameters:
Tag | Description |
---|---|
search |
Search string. The search is case insensitive and obeys the Search Within Words server parameter. |
artist_id |
Limit results to those genres proposed by the artist identified by artist_id . |
album_id |
Limit results to those genres available on the album identified by album_id . |
track_id |
Limit results to the genres of the track identified by track_id . If present, other filters are ignored. |
genre_id |
Limit results to the genre identified by genre_id . The genre_id may be a list of comma separated IDs. If present, other filters are ignored. |
library_id |
Virtual library ID, to restrict the results to a virtual library view. |
year |
Limit results to the genres of the tracks of the given year . |
tags |
Determines which tags are returned. Each returned tag is identified by a letter (see below). The default value is empty. |
Returned tagged parameters:
Block | Tag | Description |
---|---|---|
First block: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
rescan |
Returned with value 1 if the server is still scanning the database. The results may therefore be incomplete. Not returned if no scan is in progress. | |
count |
Number of results returned by the query. If no filter parameter is present, this is the same value as returned by info total genres ? . |
|
CC count |
- Only return the number of results, but not the results themselves. | |
Z indexList |
An array of arrays indicating how many items start with each key letter. | |
For each genre: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
id |
Genre ID. Item delimiter. | |
genre |
Genre name. | |
s |
textkey |
The genre's textkey
is the first letter of the sorting key.
Example:
Request: "genres 0 5<LF>"
Response: "genres 0 5 rescan:1 count:6 id:3 genre:Acid%20Jazz id:4 genre:Alternative%20&%20Punk id:5 genre:French id:6 genre:No%20Genre id:7 genre:Pop <LF>"
Request: "genres 0 5 search:unk<LF>"
Response: "genres 0 5 search:unk count:1 id:4 genre:Alternative%20&%20Punk<LF>"
artists <start> <itemsPerResponse> <taggedParameters>
The artists
query returns all artists known by the server. The results of this query depend in part on the Compilations
preference (Server Settings, Behavior). The Various Artists
pseudo-artist appears if the server groups compilations.
Accepted tagged parameters:
Tag | Description |
---|---|
search |
Search substring. The search is case insensitive and obeys the Search Within Words server parameter. |
genre_id |
Genre ID, to restrict the results to those artists with songs of that genre. The genre_id may be a list of comma separated IDs. |
album_id |
Album ID, to restrict the results to those artists with songs of that album. |
track_id |
Track ID, to restrict the results to the artist of track_id . If specified, all other filters are ignored. |
artist_id |
Artist ID, to restrict the results to a single artist. If specified, all other filters are ignored. |
role_id |
Contributor role ID, to restrict the results to the artist of role_id . This parameter must be a comma separated list of role IDs, or a comma separated list of role tokens (eg. ALBUMARTIST, ARTIST) |
library_id |
Virtual library ID, to restrict the results to a virtual library view. |
include_online_only_artists |
Include external artists from music services, even if they don't have any track or album in the current collection. This allows callers to browse those artists on the external service. Please note that this parmeter would be ignored if some kind of filtering argument was given which didn't apply to artists without related tracks (eg. genre_id, album_id etc.). |
tags |
Determines which tags are returned. Each returned tag is identified by a letter (see below). The default value is empty. |
Returned tagged parameters:
Block | Tag | Description |
---|---|---|
First block: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
rescan |
Returned with value 1 if the server is still scanning the database. The results may therefore be incomplete. Not returned if no scan is in progress. | |
count |
Number of results returned by the query. If no search string is present, this is the same value as returned by info total artists ? |
|
CC count |
Only return the number of results, but not the results themselves. | |
Z indexList |
An array of arrays indicating how many items start with each key letter. | |
For each artist: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
id |
Artist ID. Item delimiter. | |
artist |
Artist name. | |
s textkey |
The artist's textkey is the first letter of the sorting key. CLARIFICATION-NEEDED |
|
E extid |
The contributor's external ID, if it is eg. from an online music service. CLARIFICATION-NEEDED |
Example:
Request: "artists 0 5<LF>"
Response: "artists 0 5 count:7 id:2 artist:Anastacia id:3 artist:Calogero id:4 artist:Evanescence id:5 artist:Leftfield%20%26%20Lydon id:18 artist:Llorca <LF>"
Request: "artists 0 5 genre_id:7<LF>"
Response: "artists 0 5 genre_id:7 count:2 id:2 artist:Anastacia id:19 artist:Sarah%20Connor <LF>"
roles <start> <itemsPerResponse> <taggedParameters>
The roles
query returns all roles known by the server for a given track, or releases.
Accepted tagged parameters:
Tag | Description |
---|---|
track_id |
Track ID, to restrict the results to the album of track_id . If specified, all other filters are ignored. |
artist_id |
Artist ID, to restrict the results to those albums by artist_id . |
album_id |
Album ID, to restrict the results to a single album. Or a comma sparated list of album IDs, to restrict the results to a specific list of albums. If specified, all other filters are ignored. |
year |
Year, to restrict the results to those albums of that year. |
work_id |
Limit results to an individual work . |
library_id |
Virtual library ID, to restrict the results to a virtual library view. |
tags |
Determines which tags are returned. Each returned tag is identified by a letter. The only valid values currently are t (textual representation of the contributor type), and CC (only return count of results, but no other data). |
Returned tagged parameters:
Block | Tag | Description |
---|---|---|
First block: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
rescan |
Returned with value 1 if the server is still scanning the database. The results may therefore be incomplete. Not returned if no scan is in progress. | |
For each role: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
role_id |
The role ID. | |
role_name |
The contributor role name (only if requested with tag:t ) |
Example:
Request: "roles 0 1 tags:t<LF>"
Response: "roles 0 1 rescan:1 count:6 role_id:1 role_name:ARTIST <LF>"
albums <start> <itemsPerResponse> <taggedParameters>
The albums
query returns all albums known by the server. The results of this query depend in part on the Group discs
preference (Server Settings, Behavior).
Accepted tagged parameters:
Tag | Description |
---|---|
search |
Search substring. The search is case insensitive and obeys the Search Within Words server parameter. |
genre_id |
Genre ID, to restrict the results to those albums with songs of that genre. The genre_id may be a list of comma separated IDs. |
artist_id |
Artist ID, to restrict the results to those albums by artist_id . |
track_id |
Track ID, to restrict the results to the album of track_id . If specified, all other filters are ignored. |
album_id |
Album ID, to restrict the results to a single album. Or a comma sparated list of album IDs, to restrict the results to a specific list of albums. If specified, all other filters are ignored. |
role_id |
Contributor role ID, to restrict the results to those albums by artist of role role_id . This parameter must be a comma separated list of role IDs, or a comma separated list of role tokens (eg. ALBUMARTIST, ARTIST) |
library_id |
Virtual library ID, to restrict the results to a virtual library view. |
year |
Year, to restrict the results to those albums of that year. |
compilation |
Compilation, to restrict the results to those albums that are (1) or aren't (0) compilations. |
sort |
Sort order of the returned list of albums. One of: album , (the default), new (sort by the date the item was added to the library, in descending order), changed (sort by change date in descending order), artflow which sorts by artist, year, album for use with artwork-centric interfaces, artistalbum , yearalbum , yearartistalbum , random . |
tags |
Determines which tags are returned. Each returned tag is identified by a letter (see below). The default value is l . |
Returned tagged parameters:
Block | Tag | Description |
---|---|---|
First block: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
rescan |
Returned with value 1 if the server is still scanning the database. The results may therefore be incomplete. Not returned if no scan is in progress. | |
count |
Number of results returned by the query. If no filter is present, this is the same value as returned by info total albums ? |
|
CC count |
Only return the number of results, but not the results themselves. CLARIFICATION-NEEDED | |
Z indexList |
An array of arrays indicating how many items start with each key letter (or year for a year-dominated sort order). CLARIFICATION-NEEDED | |
For each album: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
id |
Album ID. Item delimiter. | |
l album |
Album name, including the server's added (N of M) if the server is set to group multi disc albums together. See tag title for the unmodified value. CLARIFICATION-NEEDED |
|
y year |
Album year. This is determined by the server based on the album tracks. | |
j artwork_track_id |
Identifier of one of the album tracks, used by the server to display the album's artwork. | |
t title |
Raw album title as found in the album tracks ID3 tags, as opposed to album . Note that title and album are identical if the server is set to group discs together. |
|
i disc |
Disc number of this album. Only if the server is not set to group multi-disc albums together. | |
q disccount |
Number of discs for this album. Only if known. | |
w compilation |
1 if this album is a compilation. | |
W release_type |
The release type of an album, eg. album , ep , etc. |
|
a artist |
The album artist (depends on server configuration). | |
aa artists |
A comma separated list of album artists (depends on server configuration). | |
S artist_id |
The album artist id (depends on server configuration). | |
SS artist_ids |
A comma separated list of album artist ids (depends on server configuration). | |
s textkey |
The album's textkey is the first letter of the sorting key. |
|
E extid |
The album's external ID, if it is eg. from an online music service. | |
R role_ids |
A comma separated list of role ids for the album. | |
X album_replay_gain |
The album's replay-gain. | |
2 group_count |
Returns a count of distinct works/groupings/performances on the album, to assist UI formatting of the album results. |
Examples:
Request: "albums 0 4<LF>"
Response: "albums 0 4 count:14 id:1 album:Amadeus%20(Disc%201%20of%202) id:4 album:Anastacia id:5 album:Bounce%20[Single] id:6 album:Fallen<LF>"
Request: "albums 0 5 genre_id:7<LF>"
Response: "albums 0 5 genre_id:7 count:2 id:4 album:Anastacia id:5 album:Bounce%20[Single]<LF>"
Request: "albums 0 5 artist_id:19<LF>"
Response: "albums 0 5 artist_id:19 count:1 id:5 album:Bounce%20[Single]<LF>"
works <start> <itemsPerResponse> <taggedParameters>
The works
query returns all works known by the server.
A Work is a (usually classical) piece of music made up of one or more movements, acts, scenes etc, each of which is usually a separate track.
A Work is defined by its name and its composer.
An Album can contain many Works, and an instance of a Work can exist on many Albums. There is therefore a many-to-many relationship between Works and Albums. This many-to-many relationship is resolved in the Tracks table which contains the album id and the work id.
Accepted tagged parameters:
Tag | Description |
---|---|
search |
Search string. The search is case insensitive and obeys the Search Within Words server parameter. |
artist_id |
Limit results to those works on which the artist identified by artist_id performs. |
genre_id |
Limit results to the genre(s) identified by genre_id . The genre_id may be a list of comma separated IDs. |
library_id |
Virtual library ID, to restrict the results to a virtual library view. |
work_id |
Limit results to an individual work . |
role_id |
Limit results to the role(s) identified by role_id . The role_id may be a list of comma separated IDs. |
Returned parameters:
Block | Tag | Description |
---|---|---|
First block: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
count | count |
Number of results returned by the query. |
For each work: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
single_composer |
only returned if the results contain works from a single composer who is also the searched-for contributor | |
composer |
the name of the composer of the work | |
work |
the name of the work | |
composer_id |
the id of the composer of the work | |
artwork_track_id |
the id of the artwork for the first album found containing the work | |
artwork_track_ids |
a list of all artwork ids of albums containing the work | |
album_id |
a list of the ids of all albums containing the work | |
textkey |
if single_composer (see above), the first letter of the work name, otherwise, the first letter of the composer name |
|
favorites_url |
the URL for favoriting the work | |
favorites_title |
the text to be used for the favorite |
years <start> <itemsPerResponse> <taggedParameters>
The years
query returns all years known by the server.
Accepted tagged parameters:
Tag | Description |
---|---|
year |
Return only the specified year. |
hasAlbums:1 |
Return only years which are valid for albums. |
Returned tagged parameters:
Block | Tag | Description |
---|---|---|
First block: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
rescan |
Returned with value 1 if the server is still scanning the database. The results may therefore be incomplete. Not returned if no scan is in progress. | |
For each year: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
year |
Year. Item delimiter. |
Example:
Request: "years 0 5<LF>"
Response: "years 0 5 rescan:1 count:6 year:1985 year:1987 year:1988 year:2002 year:2003 year:2004 <LF>"
musicfolder <start> <itemsPerResponse> <taggedParameters>
The musicfolder
query returns the content of a given music folder, starting from the top level directory configured in the server.
mediafolder
is an alias to musicfolder
.
Accepted tagged parameters:
Tag | Description |
---|---|
folder_id |
Browses the folder identified by folder_id . |
return_top |
If set to 1, and folder_id is provided, will return the data about the listed folder instead of the child folders. |
url |
Browses the folder identified by url . If the content of url did not happen to be in the server database, it is added to it.url has precedence over folder_id if both are provided. |
type |
One of audio , or list . Select the media type you want to browse in the given folder. |
tags |
Determines which tags are returned. Each returned tag is identified by a letter (see below). The default value is empty. |
recursive |
If set to 1, the query will return information about the requested folder and its sub-folders, and all files in there. |
Returned tagged parameters:
Block | Tag | Description |
---|---|---|
First block: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
rescan |
Returned with value 1 if the server is still scanning the database. The results may therefore be incomplete. Not returned if no scan is in progress. | |
count |
Number of results returned by the query. | |
For each item in the folder: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
id |
Track, playlist or folder ID. Item delimiter. | |
type |
One of track , folder , playlist , or unknown . |
|
c coverid |
coverid to use when constructing an artwork URL, such as /music/$coverid/cover.jpg | |
d duration |
Song duration in seconds. | |
s textkey |
The item's textkey is the first letter of the sorting key. |
|
u url |
The item's full URL. |
Example:
Request: "musicfolder 0 10<LF>"
Response: "musicfolder 0 10 count:26 id:1 title:03%20Barbie%20Girl.mp3 type:audio id:2 title:12%20-%20If%20I%20Had%20You.mp3 type:audio id:313 title:A-Ha type:dir id:50 title:Test.m3u type:playlist<LF>"
Request: "musicfolder 0 10 folder_id:313<LF>"
Response: "musicfolder 0 10 folder_id:313 count:2 id:335 title:Lifelines type:dir id:336 title:Minor%20Earth%20Major%20Sky type:dir<LF>"
mediafolder
is an alias of musicfolder
playlists <start> <itemsPerResponse> <taggedParameters>
The playlists
query returns all playlists known by the server.
Accepted tagged parameters:
Tag | Description |
---|---|
search |
Search substring. The search is case insensitive and obeys the Search Within Words server parameter. |
tags |
Determines which tags are returned. Each returned tag is identified by a letter (see below). The default value is empty. |
Returned tagged parameters:
Block | Tag | Description |
---|---|---|
First block: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
rescan |
Returned with value 1 if the server is still scanning the database. The results may therefore be incomplete. Not returned if no scan is in progress. | |
count |
Number of results returned by the query. | |
For each playlist: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
id |
Playlist ID. Item delimiter. | |
playlist |
Playlist name | |
s textkey |
The playlist's textkey is the first letter of the sorting key. |
|
u url |
The playlist's url. | |
E extid |
The playlist's external ID, if it is eg. from an online music service. | |
x remote |
If 1, this is a remote playlist. |
Example:
Request: "playlists 0 2<LF>"
Response: "playlists 0 2 count:5 id:37 name:Funky%20Beats id:57 name:SUPER<LF>"
Request: "playlists 0 2 search:SUPER tags:u<LF>"
Response: "playlists 0 2 search:SUPER tags:u count:1 id:57 name:SUPER url:playlist:///Volume/path/file.m3u<LF>"
playlists tracks <start> <itemsPerResponse> <taggedParameters>
The playlists tracks
query returns the tracks of a given playlist.
Accepted tagged parameters:
Tag | Description |
---|---|
playlist_id |
Playlist ID as returned by the playlists query. This is a mandatory parameter. |
tags |
Determines which tags are returned. Each returned tag is identified by a letter (see command songinfo for a list of possible fields and their identifying letter). The default tags value for this command is gald . |
Returned tagged parameters:
Block | Tag | Description |
---|---|---|
First block: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
rescan |
Returned with value 1 if the server is still scanning the database. The results may therefore be incomplete. Not returned if no scan is in progress. | |
count |
Number of tracks in the playlist. | |
For each track: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
playlist index |
Index (first item is 0) of the track in the playlist. The first returned instance of this field is equal to start. Item seperator. | |
Tags |
Same tags as defined in command songinfo . |
playlists rename <taggedParameters>
This command renames a saved playlist.
Accepted tagged parameters:
Tag | Description |
---|---|
playlist_id |
The id of the playlist to rename. |
newname |
The new name of the playlist (without .m3u). |
dry_run |
Used to check if the new name is already used by another playlist. The command performs the name check but does not overwrite the existing playlist. If a name conflict occurs, the command will return a overwritten_playlist_id parameter. |
Returned tagged parameters:
Tag | Description |
---|---|
overwritten_playlist_id |
This returns the playlist id of the playlist overwritten (if dry_run is 0 or not present) by renaming the playlist. Only present if a playlist is overwritten. |
Examples:
Request: "playlists rename playlist_id:22 newname:Hello<LF>"
Response: "playlists rename playlist_id:22 newname:Hello<LF>"
playlists new <taggedParameters>
This command creates an empty saved playlist, to be further manipulated by other commands.
Accepted tagged parameters:
Tag | Description |
---|---|
name |
The name of the playlist (without .m3u). |
Returned tagged parameters:
Tag | Description |
---|---|
playlist_id |
This returns the playlist id of the created playlist. |
overwritten_playlist_id |
This returns the playlist id of an existing playlist with the same name. The new playlist is not created. |
Examples:
Request: "playlists new name:Hello<LF>"
Response: "playlists new name:Hello playlist_id:345<LF>"
playlists delete <taggedParameters>
This command deletes a saved playlist.
Accepted tagged parameters:
Tag | Description |
---|---|
playlist_id |
The id of the playlist to delete. |
Examples:
Request: "playlists delete playlist_id:22<LF>"
Response: "playlists delete playlist_id:22<LF>"
playlists edit <taggedParameters>
This command manipulates the track content of a saved playlist.
Accepted tagged parameters:
Tag | Description |
---|---|
playlist_id |
The id of the playlist to manipulate. |
cmd |
One of up , down , move , delete or add , in order to move up, down, delete or add a track. |
index |
For cmd:up , cmd:down , cmd:move and cmd:delete the index of the track to edit. |
toindex |
For cmd:move the new index of the track to be moved. |
title |
For cmd:add , the title of the track to add. |
url |
For cmd:add , the url of the track to add. |
Examples:
Request: "playlists edit cmd:up playlist_id:22 index:3<LF>"
Response: "playlists edit cmd:up playlist_id:22 index:3<LF>"
Request: "playlists edit cmd:add playlist_id:22 title:Song url:file://...<LF>"
Response: "playlists edit cmd:add playlist_id:22 title:Song url:file://...<LF>"
songinfo <start> <itemsPerResponse> <taggedParameters>
The songinfo
command returns all the information on a song known by the server. Please note that the and parameters apply to the individual data fields below and not, as they do in other extended CLI queries, to the number of songs (or artists, genres, etc.) returned; the songinfo
only ever returns information about a single song.
Accepted tagged parameters:
Tag | Description |
---|---|
url |
Song path as returned by other CLI commands. This is a mandatory parameter, except if track_id is provided. |
track_id |
Track ID as returned by other CLI commands. This is a mandatory parameter, except if url is provided. |
tags |
Determines which tags are returned. Each returned tag is identified by a letter (see below). The default value is all info except the url (u ) and the multi-valued tags for genre(s) (G & P ) and artists (A & S ) |
Returned tagged parameters:
Tag | Description | |
---|---|---|
rescan |
Returned with value 1 if the server is still scanning the database. The results may therefore be incomplete. Not returned if no scan is in progress. | |
count |
Number of results returned by the query, that is, total number of elements to return for this song. | |
id |
Track ID. | |
title |
Song title | |
a artist |
Artist name. | |
A <role> |
For every artist role (one of artist , composer , conductor , band , albumartist or trackartist ), a comma and space (', ') separated list of names. |
|
AA <role> |
This is like A , but without the space after the comma. This should simplify parsing/splitting when required. |
|
B buttons |
A hash with button definitions. Only available for certain plugins such as Pandora. | |
c coverid |
coverid to use when constructing an artwork URL, such as /music/$coverid/cover.jpg | |
C compilation |
1 if the album this track belongs to is a compilation | |
K artwork_url |
A full URL to remote artwork. Only available for certain online music services. | |
W release_type |
The release type of the track's album, eg. album , ep , etc. |
|
d duration |
Song duration in seconds. | |
e album_id |
Album ID. Only if known. | |
f filesize |
Song file length in bytes. Only if known. | |
g genre |
Genre name. Only if known. | |
G genres |
Genre names, separated by commas (only useful if the server is set to handle multiple items in tags). | |
i disc |
Disc number. Only if known. | |
I samplesize |
Song sample size (in bits) | |
j coverart |
1 if coverart is available for this song. Not listed otherwise. | |
J artwork_track_id |
Identifier of the album track used by the server to display the album's artwork. Not listed if artwork is not available for this album. | |
k comment |
Song comments, if any. | |
K artwork_url |
A full URL to remote artwork. Only available for certain online music services. | |
l album |
Album name. Only if known. | |
L info_link |
A custom link to use for trackinfo. Only available for certain online music services. | |
m bpm |
Beats per minute. Only if known. | |
M musicmagic_mixable |
1 if track is mixable, otherwise 0. | |
n modificationTime |
Date and time song file was last changed on disk. | |
N remote_title |
Title of the internet radio station. | |
o type |
Content type. Only if known. | |
Q lossless |
1 if track is lossless, otherwise 0. | |
p genre_id |
Genre ID. Only if known. | |
P genre_ids |
Genre IDs, separated by commas (only useful if the server is set to handle multiple items in tags). | |
D addedTime |
Date and time song file was first added to the database. | |
U lastUpdated |
Date and time song file was last updated in the database. | |
q disccount |
Number of discs. Only if known. | |
r bitrate |
Song bitrate. Only if known. | |
R rating |
Song rating, if known and greater than 0. | |
O playcount |
Song play count. | |
s artist_id |
Artist ID. | |
S <role>_ids |
For each role as defined above, the list of ids (comma separated). | |
t tracknum |
Track number. Only if known. | |
T samplerate |
Song sample rate (in KHz) | |
u url |
Song file url. | |
v tagversion |
Version of tag information in song file. Only if known. | |
w lyrics |
Lyrics. Only if known. | |
x remote |
If 1, this is a remote track. | |
E extid |
Some tracks have an external identifier (eg. from an online music service). | |
X album_replay_gain |
Replay gain of the album (in dB), if any | |
y year |
Song year. Only if known. | |
Y replay_gain |
Replay gain (in dB), if any | |
V live_edge |
The Live edge of a remote stream. -1 is not live, 0 is live at the edge, >0 is number of seconds from the live edge. |
Example:
Request: "songinfo 0 100 track_id:2<LF>"
Response: "songinfo 0 100 track_id:2 count:26 id:2 title:If%20I%20Had%20You artist:Diana%20Krall duration:297.117 album_id:2 filesize:5952369 genre:Vocal comment:Pianist%2Fvocalist%20Diana%20Krall%20pays%20tribute%20to%20the%20Nat%20King%20Cole%20Trio.... album:All%20for%20You modificationTime:Thursday%2C%20March%201%2C%202007%2C%209:21:58%20PM type:mp3 genre_id:2 bitrate:160kbps%20VBR artist_id:3 tracknum:12 tagversion:ID3v2.3.0 year:1995 samplerate:44100 url:file:%2F%2F%2FUsers%2Ffred%2FPrograms%2FLyrion Music Server%2FMusic%2F12%2520-%2520If%2520I%2520Had%2520You.mp3 <LF>"
titles|songs|tracks <start> <itemsPerResponse> <taggedParameters>
The titles
command returns all titles known by the server.
songs
and tracks
are aliases for titles
Accepted tagged parameters:
Tag | Description | |
---|---|---|
genre_id |
Genre ID, to restrict the results to the titles of that genre. | |
artist_id |
Artist ID, to restrict the results to the titles of that artist. | |
album_id |
Album ID, to restrict the results to the titles of that album. | |
track_id |
Track ID, to restrict the results to a single track. | |
role_id |
Contributor role ID, to restrict the results to the artist of role role_id . This parameter must be a comma separated list of role IDs, or a comma separated list of role tokens (eg. ALBUMARTIST, ARTIST) |
|
release_type |
The release type of the track's album, eg. album , ep , etc. |
|
library_id |
Virtual library ID, to restrict the results to a virtual library view. | |
year |
Year, to restrict the results to the titles of that year. | |
search |
Search substring. The search is case insensitive and obeys the Search Within Words server parameter. |
|
tags |
Determines which tags are returned. Each returned tag is identified by a letter (see command songinfo for a list of possible fields and their identifying letter). The default tags value for this command is gald . |
|
CC |
Only return the number of results, but not the results themselves. | |
sort |
Sorting, one of:-title (the default), tracknum (in which case the track field (t ) is added automatically to the response) or albumtrack (in which case the track and album-title fields (l and t ) are added automatically to the response). Sorting by tracks is possible only if tracks are defined and for a single album. |
Returned tagged parameters:
Block | Tag | Description |
---|---|---|
First block: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
rescan |
Returned with value 1 if the server is still scanning the database. The results may therefore be incomplete. Not returned if no scan is in progress. | |
count |
Number of results returned by the query. If no search string or album/artist/genre filter is present, this is the same value as returned by info total songs ? . |
|
For each title: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
Tags |
Same tags as defined in command songinfo . |
Example:
Request: "titles 0 2<LF>"
Response: "titles 0 2 count:100 id:55 title:Ancestral%20Aid genre:Soundtrack artist:Various%20Artists album:The%20Hunt%20For%20Red%20October duration:136.93387755102 disc:1 track:5 year:1990 url:file://Disk | he%20Hunt%20For%20Red%20October/Ancestral%20Aid.mp3 id:1 title:Any%20How genre:Acid%20Jazz artist:Llorca album:New%20Comer duration:340.297142857143 track:5 year:2001 url:...<LF>"
Request: "titles 0 12 album:Anastacia tags:p<LF>"
Response: "titles 0 12 album:Anastacia tags:p count:12 id:4 title:Heavy%20On%20My%20Heart url:... id:1 title:I%20Do url:... id:2 title:Left%20Outside%20Alone url:...<LF>"
tags <url|track_id>
Return the tracks found in the file referenced by the url
or track_id
.
Please note that returned data depends on the file format, tagging software used, etc.
Accepted tagged parameters:
Tag | Description |
---|---|
url |
The file:// or tmp:// URL to the audio file. |
track_id |
The track's ID |
Example:
Request: "tags track_id:454<LF>"
Response: tags track_id%3A454 ALBUM%3A0 ARTIST%3ALow%20Roar COMMENT%3A%40JW DATE%3A2014 GENRE%3AAlternative REPLAYGAIN_ALBUM_GAIN%3A-9.18%20dB REPLAYGAIN_ALBUM_PEAK%3A1.00000000 REPLAYGAIN_REFERENCE_LOUDNESS%3A89.0%20dB REPLAYGAIN_TRACK_GAIN%3A-3.16%20dB REPLAYGAIN_TRACK_PEAK%3A0.96447754 TITLE%3AIn%20the%20Morning TRACKNUMBER%3A8 VENDOR%3Areference%20libFLAC%201.2.1%2020070917
search <start> <itemsPerResponse> <taggedParameters>
The search
command returns artists, albums and tracks matching a search string.
Please note that start
and itemsPerResponse
are calculated per category. If you eg. have genres and tracks with the search term in them, you'll get itemsPerResponse
number of each of them. The total number of items returned therefore can be a multiple of itemsPerResponse
.
Accepted tagged parameters:
Tag | Description |
---|---|
term |
Search string |
Returned tagged parameters:
Block | Tag | Description |
---|---|---|
First block: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
rescan |
Returned with value 1 if the server is still scanning the database. The results may therefore be incomplete. Not returned if no scan is in progress. | |
count |
Total number of results returned by the query. This is the sum of artists_count , albums_count and tracks_count . |
|
artists_count |
Total number of artists found. | |
albums_count |
Total number of albums found. | |
genres_count |
Total number of genres found. | |
tracks_count |
Total number of tracks found. | |
For each artist: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
artist_id |
Artist ID. | |
artist |
Artist name. | |
For each album: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
album_id |
Album ID. | |
albu |
Album title | |
For each genre: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
genre_id |
Genre ID. | |
genre |
Genre title. | |
For each track: {: colspan=3} | ⁠ {: style="padding:0"} | ⁠ {: style="padding:0"} |
track_id |
Track ID. | |
track |
Track title. |
Example:
Request: "search 0 20 term:al<LF>"
Response: "search 0 20 term:al count:9 artists_count:2 albums_count:1 tracks_count:6 artist_id:2 artist:Alanis%20Morissette artist_id:37 artist:Alphaville album_id:10 album:All%20Time%20Greatest%20Hits%20%5BBarry%20White%5D%20MMM track_id:11 track:All%20I%20Really%20Want track_id:68 track:The%20Sun%20Always%20Shines%20On%20TV track_id:185 track:All%20Around%20The%20World track_id:189 track:Give%20Me%20All%20Your%20Love%20%5BSingle%20Cut%5D track_id:245 track:Better%20All%20The%20Time
pragma <pragma string>
The pragma
command executes the given pragma string against the SQLite database engine. If using MySQL, this command has no effect. For a list of available pragmas, see sqlite.org. Warning: Do not use this function unless you know what you are doing!
Example:
pragma locking_mode = NORMAL