2009-06-07 18:56:35 +02:00
|
|
|
|
|
|
|
#ifndef __DB_H__
|
|
|
|
#define __DB_H__
|
|
|
|
|
2009-06-07 20:49:13 +02:00
|
|
|
#include <time.h>
|
2009-06-11 23:17:17 +02:00
|
|
|
#include <stddef.h>
|
2009-06-07 18:56:35 +02:00
|
|
|
#include <stdint.h>
|
|
|
|
|
2017-06-19 21:52:01 +02:00
|
|
|
#include "outputs.h"
|
2009-06-07 18:56:35 +02:00
|
|
|
|
|
|
|
enum index_type {
|
|
|
|
I_NONE,
|
|
|
|
I_FIRST,
|
|
|
|
I_LAST,
|
|
|
|
I_SUB
|
|
|
|
};
|
|
|
|
|
2018-01-21 00:22:21 +01:00
|
|
|
// Keep in sync with sort_clause[]
|
2010-04-24 10:20:26 +02:00
|
|
|
enum sort_type {
|
|
|
|
S_NONE = 0,
|
|
|
|
S_NAME,
|
|
|
|
S_ALBUM,
|
2010-10-09 15:57:34 +02:00
|
|
|
S_ARTIST,
|
2014-03-11 23:20:29 +01:00
|
|
|
S_PLAYLIST,
|
2015-02-23 18:43:38 +01:00
|
|
|
S_YEAR,
|
2015-05-26 21:10:28 +02:00
|
|
|
S_GENRE,
|
|
|
|
S_COMPOSER,
|
|
|
|
S_DISC,
|
|
|
|
S_TRACK,
|
2015-05-30 05:31:54 +02:00
|
|
|
S_VPATH,
|
2016-12-04 08:18:33 +01:00
|
|
|
S_POS,
|
|
|
|
S_SHUFFLE_POS,
|
2010-04-24 10:20:26 +02:00
|
|
|
};
|
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
#define Q_F_BROWSE (1 << 15)
|
|
|
|
|
|
|
|
enum query_type {
|
2015-05-30 05:31:54 +02:00
|
|
|
Q_ITEMS = 1,
|
|
|
|
Q_PL = 2,
|
2017-01-04 23:20:59 +01:00
|
|
|
Q_FIND_PL = 3,
|
|
|
|
Q_PLITEMS = 4,
|
|
|
|
Q_GROUP_ALBUMS = 5,
|
|
|
|
Q_GROUP_ARTISTS = 6,
|
|
|
|
Q_GROUP_ITEMS = 7,
|
2018-01-21 00:22:21 +01:00
|
|
|
Q_GROUP_DIRS = 8,
|
|
|
|
Q_COUNT_ITEMS = 9,
|
|
|
|
|
|
|
|
// Keep in sync with browse_clause[]
|
2017-01-04 23:20:59 +01:00
|
|
|
Q_BROWSE_ARTISTS = Q_F_BROWSE | 1,
|
|
|
|
Q_BROWSE_ALBUMS = Q_F_BROWSE | 2,
|
|
|
|
Q_BROWSE_GENRES = Q_F_BROWSE | 3,
|
|
|
|
Q_BROWSE_COMPOSERS = Q_F_BROWSE | 4,
|
2018-01-21 00:22:21 +01:00
|
|
|
Q_BROWSE_YEARS = Q_F_BROWSE | 5,
|
|
|
|
Q_BROWSE_DISCS = Q_F_BROWSE | 6,
|
|
|
|
Q_BROWSE_TRACKS = Q_F_BROWSE | 7,
|
|
|
|
Q_BROWSE_VPATH = Q_F_BROWSE | 8,
|
|
|
|
Q_BROWSE_PATH = Q_F_BROWSE | 9,
|
2009-06-07 18:56:35 +02:00
|
|
|
};
|
|
|
|
|
2014-01-11 23:05:29 +01:00
|
|
|
#define ARTWORK_UNKNOWN 0
|
|
|
|
#define ARTWORK_NONE 1
|
|
|
|
#define ARTWORK_EMBEDDED 2
|
|
|
|
#define ARTWORK_OWN 3
|
|
|
|
#define ARTWORK_DIR 4
|
|
|
|
#define ARTWORK_PARENTDIR 5
|
2014-03-11 23:20:29 +01:00
|
|
|
#define ARTWORK_SPOTIFY 6
|
2015-03-14 21:42:53 +01:00
|
|
|
#define ARTWORK_HTTP 7
|
2014-01-11 23:05:29 +01:00
|
|
|
|
2017-11-19 21:14:41 +01:00
|
|
|
#define DB_ADMIN_SCHEMA_VERSION_MAJOR "schema_version_major"
|
|
|
|
#define DB_ADMIN_SCHEMA_VERSION_MINOR "schema_version_minor"
|
|
|
|
#define DB_ADMIN_SCHEMA_VERSION "schema_version"
|
|
|
|
#define DB_ADMIN_QUEUE_VERSION "queue_version"
|
|
|
|
#define DB_ADMIN_DB_UPDATE "db_update"
|
2019-01-30 08:36:34 +01:00
|
|
|
#define DB_ADMIN_DB_MODIFIED "db_modified"
|
2017-11-19 21:14:41 +01:00
|
|
|
#define DB_ADMIN_START_TIME "start_time"
|
|
|
|
#define DB_ADMIN_LASTFM_SESSION_KEY "lastfm_sk"
|
|
|
|
#define DB_ADMIN_SPOTIFY_REFRESH_TOKEN "spotify_refresh_token"
|
2017-11-19 07:46:28 +01:00
|
|
|
|
2017-12-15 16:55:40 +01:00
|
|
|
/* Max value for media_file_info->rating (valid range is from 0 to 100) */
|
2017-12-10 09:31:00 +01:00
|
|
|
#define DB_FILES_RATING_MAX 100
|
|
|
|
|
2018-04-12 20:43:05 +02:00
|
|
|
/* Magic id for media_file_info objects that are not stored in the files database table */
|
|
|
|
#define DB_MEDIA_FILE_NON_PERSISTENT_ID 9999999
|
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
struct query_params {
|
|
|
|
/* Query parameters, filled in by caller */
|
|
|
|
enum query_type type;
|
|
|
|
enum index_type idx_type;
|
2010-04-24 10:20:26 +02:00
|
|
|
enum sort_type sort;
|
2010-03-07 11:53:16 +01:00
|
|
|
int id;
|
2014-11-10 22:53:08 +01:00
|
|
|
int64_t persistentid;
|
2009-06-07 18:56:35 +02:00
|
|
|
int offset;
|
|
|
|
int limit;
|
|
|
|
|
2018-03-17 13:27:59 +01:00
|
|
|
char *having;
|
2018-04-15 08:03:42 +02:00
|
|
|
char *order;
|
2018-09-22 09:32:05 +02:00
|
|
|
char *group;
|
2018-03-17 13:27:59 +01:00
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
char *filter;
|
|
|
|
|
|
|
|
/* Query results, filled in by query_start */
|
|
|
|
int results;
|
|
|
|
|
|
|
|
/* Private query context, keep out */
|
2017-10-14 20:16:34 +02:00
|
|
|
void *stmt;
|
2015-03-16 23:33:42 +01:00
|
|
|
char buf1[32];
|
|
|
|
char buf2[32];
|
2009-06-07 18:56:35 +02:00
|
|
|
};
|
|
|
|
|
2010-01-30 17:01:27 +01:00
|
|
|
struct pairing_info {
|
|
|
|
char *remote_id;
|
|
|
|
char *name;
|
|
|
|
char *guid;
|
|
|
|
};
|
|
|
|
|
2018-02-24 11:28:42 +01:00
|
|
|
/* Keep in sync with media_kind_labels[] */
|
2015-04-23 11:34:44 +02:00
|
|
|
enum media_kind {
|
2015-04-24 17:25:01 +02:00
|
|
|
MEDIA_KIND_MUSIC = 1,
|
2015-04-23 11:34:44 +02:00
|
|
|
MEDIA_KIND_MOVIE = 2,
|
|
|
|
MEDIA_KIND_PODCAST = 4,
|
|
|
|
MEDIA_KIND_AUDIOBOOK = 8,
|
2015-04-23 23:38:36 +02:00
|
|
|
MEDIA_KIND_MUSICVIDEO = 32,
|
2015-04-23 11:34:44 +02:00
|
|
|
MEDIA_KIND_TVSHOW = 64,
|
|
|
|
};
|
|
|
|
|
2018-02-24 11:28:42 +01:00
|
|
|
const char *
|
|
|
|
db_media_kind_label(enum media_kind media_kind);
|
|
|
|
|
|
|
|
enum media_kind
|
|
|
|
db_media_kind_enum(const char *label);
|
|
|
|
|
|
|
|
/* Keep in sync with data_kind_label[] */
|
2015-04-23 11:34:44 +02:00
|
|
|
enum data_kind {
|
2015-04-24 22:57:08 +02:00
|
|
|
DATA_KIND_FILE = 0, /* normal file */
|
2015-08-04 22:33:32 +02:00
|
|
|
DATA_KIND_HTTP = 1, /* network stream (radio) */
|
2015-04-24 22:57:08 +02:00
|
|
|
DATA_KIND_SPOTIFY = 2, /* iTunes has no spotify data kind, but we use 2 */
|
|
|
|
DATA_KIND_PIPE = 3, /* iTunes has no pipe data kind, but we use 3 */
|
2015-04-23 11:34:44 +02:00
|
|
|
};
|
|
|
|
|
2018-02-24 11:28:42 +01:00
|
|
|
const char *
|
|
|
|
db_data_kind_label(enum data_kind data_kind);
|
|
|
|
|
2015-04-24 22:57:08 +02:00
|
|
|
/* Note that fields marked as integers in the metadata map in filescanner_ffmpeg must be uint32_t here */
|
2009-06-07 18:56:35 +02:00
|
|
|
struct media_file_info {
|
2018-12-30 00:27:47 +01:00
|
|
|
uint32_t id;
|
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
char *path;
|
2018-12-30 00:27:47 +01:00
|
|
|
char *virtual_path;
|
2009-06-07 18:56:35 +02:00
|
|
|
char *fname;
|
2018-12-30 00:27:47 +01:00
|
|
|
uint32_t directory_id; /* Id of directory */
|
2009-06-07 18:56:35 +02:00
|
|
|
char *title;
|
|
|
|
char *artist;
|
|
|
|
char *album;
|
2018-12-30 00:27:47 +01:00
|
|
|
char *album_artist;
|
2009-06-07 18:56:35 +02:00
|
|
|
char *genre;
|
|
|
|
char *comment;
|
|
|
|
char *type; /* daap.songformat */
|
|
|
|
char *composer;
|
|
|
|
char *orchestra;
|
|
|
|
char *conductor;
|
|
|
|
char *grouping;
|
|
|
|
char *url; /* daap.songdataurl (asul) */
|
|
|
|
|
|
|
|
uint32_t bitrate;
|
|
|
|
uint32_t samplerate;
|
|
|
|
uint32_t song_length;
|
2010-02-02 21:01:56 +01:00
|
|
|
int64_t file_size;
|
2009-06-07 18:56:35 +02:00
|
|
|
uint32_t year; /* TDRC */
|
2018-12-30 00:27:47 +01:00
|
|
|
uint32_t date_released;
|
2009-06-07 18:56:35 +02:00
|
|
|
|
|
|
|
uint32_t track; /* TRCK */
|
|
|
|
uint32_t total_tracks;
|
|
|
|
|
|
|
|
uint32_t disc; /* TPOS */
|
|
|
|
uint32_t total_discs;
|
|
|
|
|
2018-12-30 00:27:47 +01:00
|
|
|
uint32_t bpm; /* TBPM */
|
|
|
|
uint32_t compilation;
|
2019-01-30 23:34:00 +01:00
|
|
|
uint32_t artwork;
|
2018-12-30 00:27:47 +01:00
|
|
|
uint32_t rating;
|
2009-06-07 18:56:35 +02:00
|
|
|
|
|
|
|
uint32_t play_count;
|
2018-12-30 00:27:47 +01:00
|
|
|
uint32_t skip_count;
|
2013-12-17 20:58:55 +01:00
|
|
|
uint32_t seek;
|
2018-12-30 00:27:47 +01:00
|
|
|
|
|
|
|
uint32_t data_kind; /* dmap.datakind (asdk) */
|
|
|
|
uint32_t media_kind;
|
|
|
|
uint32_t item_kind; /* song or movie */
|
|
|
|
|
|
|
|
char *description; /* daap.songdescription */
|
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
uint32_t db_timestamp;
|
2018-12-30 00:27:47 +01:00
|
|
|
uint32_t time_added; /* FIXME: time_t */
|
|
|
|
uint32_t time_modified;
|
|
|
|
uint32_t time_played;
|
|
|
|
uint32_t time_skipped;
|
2009-06-07 18:56:35 +02:00
|
|
|
|
|
|
|
uint32_t disabled;
|
|
|
|
|
2018-12-30 00:27:47 +01:00
|
|
|
uint64_t sample_count; //TODO [unused] sample count is never set and therefor always 0
|
2009-06-07 18:56:35 +02:00
|
|
|
char *codectype; /* song.codectype, 4 chars max (32 bits) */
|
|
|
|
|
2018-12-30 00:27:47 +01:00
|
|
|
uint32_t idx;
|
2009-06-07 18:56:35 +02:00
|
|
|
|
2018-12-30 00:27:47 +01:00
|
|
|
uint32_t has_video; /* iTunes 6.0.2 */
|
|
|
|
uint32_t contentrating;/* iTunes 5+ */
|
2009-06-07 18:56:35 +02:00
|
|
|
|
|
|
|
uint32_t bits_per_sample;
|
|
|
|
|
2009-12-26 08:28:28 +01:00
|
|
|
char *tv_series_name;
|
|
|
|
char *tv_episode_num_str; /* com.apple.itunes.episode-num-str, used as a unique episode identifier */
|
|
|
|
char *tv_network_name;
|
2018-12-30 00:27:47 +01:00
|
|
|
uint32_t tv_episode_sort;
|
|
|
|
uint32_t tv_season_num;
|
2010-03-06 17:13:56 +01:00
|
|
|
|
2013-12-17 20:58:55 +01:00
|
|
|
int64_t songartistid;
|
2010-03-06 17:13:56 +01:00
|
|
|
int64_t songalbumid;
|
2010-09-21 13:16:38 +02:00
|
|
|
|
|
|
|
char *title_sort;
|
|
|
|
char *artist_sort;
|
|
|
|
char *album_sort;
|
|
|
|
char *album_artist_sort;
|
2018-12-30 00:27:47 +01:00
|
|
|
char *composer_sort;
|
2009-06-07 18:56:35 +02:00
|
|
|
};
|
|
|
|
|
2009-06-11 23:17:17 +02:00
|
|
|
#define mfi_offsetof(field) offsetof(struct media_file_info, field)
|
|
|
|
|
2016-11-12 12:35:22 +01:00
|
|
|
/* PL_SPECIAL value must be in sync with type value in Q_PL* in db_init.c */
|
2010-01-21 17:52:51 +01:00
|
|
|
enum pl_type {
|
2015-04-21 19:12:54 +02:00
|
|
|
PL_SPECIAL = 0,
|
2015-03-30 01:03:15 +02:00
|
|
|
PL_FOLDER = 1,
|
2015-04-21 19:12:54 +02:00
|
|
|
PL_SMART = 2,
|
|
|
|
PL_PLAIN = 3,
|
2015-03-30 01:03:15 +02:00
|
|
|
PL_MAX,
|
2010-01-21 17:52:51 +01:00
|
|
|
};
|
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
struct playlist_info {
|
|
|
|
uint32_t id; /* integer id (miid) */
|
|
|
|
char *title; /* playlist name as displayed in iTunes (minm) */
|
2010-01-21 17:52:51 +01:00
|
|
|
enum pl_type type; /* see PL_ types */
|
2009-06-07 18:56:35 +02:00
|
|
|
uint32_t items; /* number of items (mimc) */
|
2015-03-16 23:33:42 +01:00
|
|
|
uint32_t streams; /* number of internet streams */
|
2009-06-07 18:56:35 +02:00
|
|
|
char *query; /* where clause if type 1 (MSPS) */
|
|
|
|
uint32_t db_timestamp; /* time last updated */
|
2009-06-10 15:23:02 +02:00
|
|
|
uint32_t disabled;
|
2009-06-07 18:56:35 +02:00
|
|
|
char *path; /* path of underlying playlist */
|
|
|
|
uint32_t index; /* index of playlist for paths with multiple playlists */
|
2010-01-21 17:52:51 +01:00
|
|
|
uint32_t special_id; /* iTunes identifies certain 'special' playlists with special meaning */
|
2014-12-21 20:41:44 +01:00
|
|
|
char *virtual_path; /* virtual path of underlying playlist */
|
2015-03-14 23:35:19 +01:00
|
|
|
uint32_t parent_id; /* Id of parent playlist if the playlist is nested */
|
2015-12-27 07:16:50 +01:00
|
|
|
uint32_t directory_id; /* Id of directory */
|
2018-04-15 08:03:42 +02:00
|
|
|
char *query_order; /* order by clause if it is a smart playlist */
|
2018-04-15 08:39:43 +02:00
|
|
|
int32_t query_limit; /* limit if it is a smart playlist */
|
2009-06-07 18:56:35 +02:00
|
|
|
};
|
|
|
|
|
2009-06-11 23:17:17 +02:00
|
|
|
#define pli_offsetof(field) offsetof(struct playlist_info, field)
|
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
struct db_playlist_info {
|
|
|
|
char *id;
|
|
|
|
char *title;
|
|
|
|
char *type;
|
|
|
|
char *items;
|
2015-03-16 23:33:42 +01:00
|
|
|
char *streams;
|
2009-06-07 18:56:35 +02:00
|
|
|
char *query;
|
|
|
|
char *db_timestamp;
|
2009-06-10 15:23:02 +02:00
|
|
|
char *disabled;
|
2009-06-07 18:56:35 +02:00
|
|
|
char *path;
|
|
|
|
char *index;
|
2010-01-21 17:52:51 +01:00
|
|
|
char *special_id;
|
2015-02-23 20:49:53 +01:00
|
|
|
char *virtual_path;
|
2015-03-14 23:35:19 +01:00
|
|
|
char *parent_id;
|
2015-12-27 07:16:50 +01:00
|
|
|
char *directory_id;
|
2018-04-15 08:03:42 +02:00
|
|
|
char *query_order;
|
2018-04-13 16:29:06 +02:00
|
|
|
char *query_limit;
|
2009-06-07 18:56:35 +02:00
|
|
|
};
|
|
|
|
|
2009-06-11 23:17:17 +02:00
|
|
|
#define dbpli_offsetof(field) offsetof(struct db_playlist_info, field)
|
|
|
|
|
2010-01-10 12:26:48 +01:00
|
|
|
struct group_info {
|
2010-03-06 18:56:30 +01:00
|
|
|
uint32_t id; /* integer id (miid) */
|
2010-01-10 12:26:48 +01:00
|
|
|
uint64_t persistentid; /* ulonglong id (mper) */
|
2013-12-18 19:14:39 +01:00
|
|
|
char *itemname; /* album or album_artist (minm) */
|
|
|
|
char *itemname_sort; /* album_sort or album_artist_sort (~mshc) */
|
2010-01-10 12:26:48 +01:00
|
|
|
uint32_t itemcount; /* number of items (mimc) */
|
2013-12-15 21:47:49 +01:00
|
|
|
uint32_t groupalbumcount; /* number of albums (agac) */
|
2010-01-10 12:26:48 +01:00
|
|
|
char *songalbumartist; /* song album artist (asaa) */
|
2014-02-21 20:39:57 +01:00
|
|
|
uint64_t songartistid; /* song artist id (asri) */
|
2016-06-11 23:10:13 +02:00
|
|
|
uint32_t song_length;
|
2010-01-10 12:26:48 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
#define gri_offsetof(field) offsetof(struct group_info, field)
|
|
|
|
|
|
|
|
struct db_group_info {
|
2010-03-06 18:56:30 +01:00
|
|
|
char *id;
|
2010-01-10 12:26:48 +01:00
|
|
|
char *persistentid;
|
|
|
|
char *itemname;
|
2013-12-18 19:14:39 +01:00
|
|
|
char *itemname_sort;
|
2010-01-10 12:26:48 +01:00
|
|
|
char *itemcount;
|
2013-08-29 22:00:37 +02:00
|
|
|
char *groupalbumcount;
|
2010-01-10 12:26:48 +01:00
|
|
|
char *songalbumartist;
|
2014-02-21 20:39:57 +01:00
|
|
|
char *songartistid;
|
2016-06-11 23:10:13 +02:00
|
|
|
char *song_length;
|
2010-01-10 12:26:48 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
#define dbgri_offsetof(field) offsetof(struct db_group_info, field)
|
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
struct db_media_file_info {
|
|
|
|
char *id;
|
|
|
|
char *path;
|
2018-12-30 00:27:47 +01:00
|
|
|
char *virtual_path;
|
2009-06-07 18:56:35 +02:00
|
|
|
char *fname;
|
2018-12-30 00:27:47 +01:00
|
|
|
char *directory_id;
|
2009-06-07 18:56:35 +02:00
|
|
|
char *title;
|
|
|
|
char *artist;
|
|
|
|
char *album;
|
2018-12-30 00:27:47 +01:00
|
|
|
char *album_artist;
|
2009-06-07 18:56:35 +02:00
|
|
|
char *genre;
|
|
|
|
char *comment;
|
|
|
|
char *type;
|
|
|
|
char *composer;
|
|
|
|
char *orchestra;
|
|
|
|
char *conductor;
|
|
|
|
char *grouping;
|
|
|
|
char *url;
|
|
|
|
char *bitrate;
|
|
|
|
char *samplerate;
|
|
|
|
char *song_length;
|
|
|
|
char *file_size;
|
|
|
|
char *year;
|
2018-12-30 00:27:47 +01:00
|
|
|
char *date_released;
|
2009-06-07 18:56:35 +02:00
|
|
|
char *track;
|
|
|
|
char *total_tracks;
|
|
|
|
char *disc;
|
|
|
|
char *total_discs;
|
|
|
|
char *bpm;
|
|
|
|
char *compilation;
|
2014-01-11 23:05:29 +01:00
|
|
|
char *artwork;
|
2009-06-07 18:56:35 +02:00
|
|
|
char *rating;
|
|
|
|
char *play_count;
|
2018-12-30 00:27:47 +01:00
|
|
|
char *skip_count;
|
2013-12-17 20:58:55 +01:00
|
|
|
char *seek;
|
2009-06-07 18:56:35 +02:00
|
|
|
char *data_kind;
|
2018-12-30 00:27:47 +01:00
|
|
|
char *media_kind;
|
2009-06-07 18:56:35 +02:00
|
|
|
char *item_kind;
|
|
|
|
char *description;
|
2018-12-30 00:27:47 +01:00
|
|
|
char *db_timestamp;
|
2009-06-07 18:56:35 +02:00
|
|
|
char *time_added;
|
|
|
|
char *time_modified;
|
|
|
|
char *time_played;
|
2018-12-30 00:27:47 +01:00
|
|
|
char *time_skipped;
|
2009-06-07 18:56:35 +02:00
|
|
|
char *disabled;
|
|
|
|
char *sample_count;
|
|
|
|
char *codectype;
|
|
|
|
char *idx;
|
|
|
|
char *has_video;
|
|
|
|
char *contentrating;
|
|
|
|
char *bits_per_sample;
|
2009-12-26 08:28:28 +01:00
|
|
|
char *tv_episode_sort;
|
|
|
|
char *tv_season_num;
|
|
|
|
char *tv_series_name;
|
|
|
|
char *tv_episode_num_str;
|
|
|
|
char *tv_network_name;
|
2013-12-17 20:58:55 +01:00
|
|
|
char *songartistid;
|
2010-03-06 17:13:56 +01:00
|
|
|
char *songalbumid;
|
2010-09-21 13:16:38 +02:00
|
|
|
char *title_sort;
|
|
|
|
char *artist_sort;
|
|
|
|
char *album_sort;
|
|
|
|
char *album_artist_sort;
|
2018-12-30 00:27:47 +01:00
|
|
|
char *composer_sort;
|
2009-06-07 18:56:35 +02:00
|
|
|
};
|
|
|
|
|
2009-06-11 23:17:17 +02:00
|
|
|
#define dbmfi_offsetof(field) offsetof(struct db_media_file_info, field)
|
|
|
|
|
2017-12-16 23:09:29 +01:00
|
|
|
enum strip_type {
|
|
|
|
STRIP_NONE,
|
|
|
|
STRIP_PATH,
|
|
|
|
};
|
|
|
|
|
2009-06-10 18:11:11 +02:00
|
|
|
struct watch_info {
|
|
|
|
int wd;
|
|
|
|
char *path;
|
|
|
|
uint32_t cookie;
|
|
|
|
};
|
|
|
|
|
2009-06-11 23:17:17 +02:00
|
|
|
#define wi_offsetof(field) offsetof(struct watch_info, field)
|
|
|
|
|
2009-06-11 16:44:49 +02:00
|
|
|
struct watch_enum {
|
|
|
|
uint32_t cookie;
|
|
|
|
char *match;
|
|
|
|
|
|
|
|
/* Private enum context, keep out */
|
2017-10-14 20:16:34 +02:00
|
|
|
void *stmt;
|
2009-06-11 16:44:49 +02:00
|
|
|
};
|
|
|
|
|
2015-05-26 21:24:10 +02:00
|
|
|
struct filecount_info {
|
2015-04-06 09:19:48 +02:00
|
|
|
uint32_t count;
|
2017-03-04 17:23:52 +01:00
|
|
|
uint64_t length;
|
2018-04-22 08:40:23 +02:00
|
|
|
uint32_t artist_count;
|
|
|
|
uint32_t album_count;
|
2015-04-06 09:19:48 +02:00
|
|
|
};
|
2009-06-07 18:56:35 +02:00
|
|
|
|
2016-11-12 12:35:22 +01:00
|
|
|
/* Directory ids must be in sync with the ids in Q_DIR* in db_init.c */
|
2016-01-24 18:45:28 +01:00
|
|
|
enum directory_ids {
|
|
|
|
DIR_ROOT = 1,
|
|
|
|
DIR_FILE = 2,
|
|
|
|
DIR_HTTP = 3,
|
|
|
|
DIR_SPOTIFY = 4,
|
2016-11-12 12:35:22 +01:00
|
|
|
DIR_MAX
|
2016-01-24 18:45:28 +01:00
|
|
|
};
|
|
|
|
|
2015-12-27 07:16:50 +01:00
|
|
|
struct directory_info {
|
|
|
|
uint32_t id;
|
|
|
|
char *virtual_path;
|
2018-11-24 09:23:32 +01:00
|
|
|
char *path;
|
2015-12-27 07:16:50 +01:00
|
|
|
uint32_t db_timestamp;
|
|
|
|
uint32_t disabled;
|
|
|
|
uint32_t parent_id;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct directory_enum {
|
|
|
|
int parent_id;
|
|
|
|
|
|
|
|
/* Private enum context, keep out */
|
2017-10-14 20:16:34 +02:00
|
|
|
void *stmt;
|
2015-12-27 07:16:50 +01:00
|
|
|
};
|
|
|
|
|
2018-12-28 19:10:17 +01:00
|
|
|
struct db_queue_item {
|
2016-12-03 08:03:19 +01:00
|
|
|
/* A unique id for this queue item. If the same item appears multiple
|
2016-11-04 15:34:00 +01:00
|
|
|
times in the queue each corresponding queue item has its own id. */
|
2016-12-03 08:03:19 +01:00
|
|
|
uint32_t id;
|
2016-11-04 15:34:00 +01:00
|
|
|
|
|
|
|
/* Id of the file/item in the files database */
|
|
|
|
uint32_t file_id;
|
|
|
|
|
2018-12-28 19:10:17 +01:00
|
|
|
uint32_t pos;
|
|
|
|
uint32_t shuffle_pos;
|
2016-11-04 15:34:00 +01:00
|
|
|
|
|
|
|
/* Data type of the item */
|
|
|
|
enum data_kind data_kind;
|
|
|
|
/* Media type of the item */
|
|
|
|
enum media_kind media_kind;
|
|
|
|
|
2018-12-28 19:10:17 +01:00
|
|
|
/* Length of the item in ms */
|
|
|
|
uint32_t song_length;
|
2016-11-04 15:34:00 +01:00
|
|
|
|
|
|
|
char *path;
|
|
|
|
char *virtual_path;
|
|
|
|
|
|
|
|
char *title;
|
|
|
|
char *artist;
|
|
|
|
char *album_artist;
|
|
|
|
char *album;
|
|
|
|
char *genre;
|
|
|
|
|
|
|
|
int64_t songalbumid;
|
|
|
|
uint32_t time_modified;
|
|
|
|
|
|
|
|
char *artist_sort;
|
|
|
|
char *album_sort;
|
|
|
|
char *album_artist_sort;
|
|
|
|
|
|
|
|
uint32_t year;
|
|
|
|
uint32_t track;
|
|
|
|
uint32_t disc;
|
2017-01-22 23:10:15 +01:00
|
|
|
|
|
|
|
char *artwork_url;
|
2017-11-25 17:57:35 +01:00
|
|
|
|
|
|
|
uint32_t queue_version;
|
2018-12-28 19:10:17 +01:00
|
|
|
|
|
|
|
char *composer;
|
|
|
|
|
|
|
|
/* Not saved in queue table */
|
|
|
|
uint32_t seek;
|
2016-11-04 15:34:00 +01:00
|
|
|
};
|
|
|
|
|
2018-12-28 19:10:17 +01:00
|
|
|
#define qi_offsetof(field) offsetof(struct db_queue_item, field)
|
|
|
|
|
2018-03-09 19:03:43 +01:00
|
|
|
struct db_queue_add_info
|
|
|
|
{
|
|
|
|
int queue_version;
|
2018-10-13 08:30:41 +02:00
|
|
|
int start_pos;
|
2018-03-09 19:03:43 +01:00
|
|
|
int pos;
|
2018-10-13 08:30:41 +02:00
|
|
|
int shuffle_pos;
|
|
|
|
int count;
|
|
|
|
int new_item_id;
|
2018-03-09 19:03:43 +01:00
|
|
|
};
|
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
char *
|
2017-10-14 10:14:09 +02:00
|
|
|
db_escape_string(const char *str); // TODO Remove this, use db_mprintf instead
|
|
|
|
|
|
|
|
char *
|
|
|
|
db_mprintf(const char *fmt, ...);
|
|
|
|
|
|
|
|
int
|
|
|
|
db_snprintf(char *s, int n, const char *fmt, ...);
|
2009-06-07 18:56:35 +02:00
|
|
|
|
2010-01-30 17:01:27 +01:00
|
|
|
void
|
|
|
|
free_pi(struct pairing_info *pi, int content_only);
|
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
void
|
|
|
|
free_mfi(struct media_file_info *mfi, int content_only);
|
|
|
|
|
|
|
|
void
|
|
|
|
free_pli(struct playlist_info *pli, int content_only);
|
|
|
|
|
2015-12-27 07:16:50 +01:00
|
|
|
void
|
|
|
|
free_di(struct directory_info *di, int content_only);
|
|
|
|
|
2017-10-25 23:32:16 +02:00
|
|
|
void
|
|
|
|
free_query_params(struct query_params *qp, int content_only);
|
|
|
|
|
2016-11-04 15:34:00 +01:00
|
|
|
void
|
|
|
|
free_queue_item(struct db_queue_item *queue_item, int content_only);
|
|
|
|
|
2010-12-05 12:22:52 +01:00
|
|
|
/* Maintenance and DB hygiene */
|
|
|
|
void
|
|
|
|
db_hook_post_scan(void);
|
|
|
|
|
2009-06-07 20:49:13 +02:00
|
|
|
void
|
|
|
|
db_purge_cruft(time_t ref);
|
|
|
|
|
2013-11-29 22:48:53 +01:00
|
|
|
void
|
|
|
|
db_purge_all(void);
|
|
|
|
|
2014-05-11 23:13:09 +02:00
|
|
|
/* Transactions */
|
|
|
|
void
|
|
|
|
db_transaction_begin(void);
|
|
|
|
|
|
|
|
void
|
|
|
|
db_transaction_end(void);
|
|
|
|
|
2016-11-04 15:34:00 +01:00
|
|
|
void
|
|
|
|
db_transaction_rollback(void);
|
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
/* Queries */
|
|
|
|
int
|
|
|
|
db_query_start(struct query_params *qp);
|
|
|
|
|
|
|
|
void
|
|
|
|
db_query_end(struct query_params *qp);
|
|
|
|
|
|
|
|
int
|
|
|
|
db_query_fetch_file(struct query_params *qp, struct db_media_file_info *dbmfi);
|
|
|
|
|
|
|
|
int
|
2016-02-21 18:05:11 +01:00
|
|
|
db_query_fetch_pl(struct query_params *qp, struct db_playlist_info *dbpli, int with_itemcount);
|
2009-06-07 18:56:35 +02:00
|
|
|
|
2010-01-10 12:26:48 +01:00
|
|
|
int
|
|
|
|
db_query_fetch_group(struct query_params *qp, struct db_group_info *dbgri);
|
|
|
|
|
2015-04-06 09:19:48 +02:00
|
|
|
int
|
2015-05-26 21:24:10 +02:00
|
|
|
db_query_fetch_count(struct query_params *qp, struct filecount_info *fci);
|
2015-04-06 09:19:48 +02:00
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
int
|
|
|
|
db_query_fetch_string(struct query_params *qp, char **string);
|
|
|
|
|
2010-12-05 16:27:06 +01:00
|
|
|
int
|
|
|
|
db_query_fetch_string_sort(struct query_params *qp, char **string, char **sortstring);
|
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
/* Files */
|
|
|
|
int
|
2009-06-11 18:41:50 +02:00
|
|
|
db_files_get_count(void);
|
2009-06-07 18:56:35 +02:00
|
|
|
|
|
|
|
void
|
|
|
|
db_file_inc_playcount(int id);
|
|
|
|
|
2018-08-18 22:56:27 +02:00
|
|
|
void
|
|
|
|
db_file_inc_skipcount(int id);
|
|
|
|
|
2019-01-23 09:25:34 +01:00
|
|
|
void
|
|
|
|
db_file_reset_playskip_count(int id);
|
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
void
|
2011-06-12 11:06:37 +02:00
|
|
|
db_file_ping(int id);
|
2009-06-07 18:56:35 +02:00
|
|
|
|
2017-10-01 00:43:24 +02:00
|
|
|
int
|
|
|
|
db_file_ping_bypath(const char *path, time_t mtime_max);
|
|
|
|
|
2013-11-30 23:12:09 +01:00
|
|
|
void
|
2017-10-01 00:43:24 +02:00
|
|
|
db_file_ping_bymatch(const char *path, int isdir);
|
2013-11-30 23:12:09 +01:00
|
|
|
|
2010-03-07 11:06:15 +01:00
|
|
|
char *
|
|
|
|
db_file_path_byid(int id);
|
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
int
|
2017-10-01 00:43:24 +02:00
|
|
|
db_file_id_bypath(const char *path);
|
2009-06-11 20:44:22 +02:00
|
|
|
|
2009-11-22 16:30:45 +01:00
|
|
|
int
|
2017-10-01 00:43:24 +02:00
|
|
|
db_file_id_byfile(const char *filename);
|
2009-11-22 16:30:45 +01:00
|
|
|
|
2009-11-22 15:39:38 +01:00
|
|
|
int
|
2017-10-01 00:43:24 +02:00
|
|
|
db_file_id_byurl(const char *url);
|
2009-11-22 15:39:38 +01:00
|
|
|
|
2015-07-17 03:22:24 +02:00
|
|
|
int
|
2017-10-01 00:43:24 +02:00
|
|
|
db_file_id_by_virtualpath_match(const char *path);
|
2015-07-17 03:22:24 +02:00
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
struct media_file_info *
|
|
|
|
db_file_fetch_byid(int id);
|
|
|
|
|
2014-12-21 20:41:44 +01:00
|
|
|
struct media_file_info *
|
2017-05-01 13:28:46 +02:00
|
|
|
db_file_fetch_byvirtualpath(const char *path);
|
2014-12-21 20:41:44 +01:00
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
int
|
|
|
|
db_file_add(struct media_file_info *mfi);
|
|
|
|
|
|
|
|
int
|
|
|
|
db_file_update(struct media_file_info *mfi);
|
|
|
|
|
2015-08-04 22:33:32 +02:00
|
|
|
void
|
2017-01-15 23:22:06 +01:00
|
|
|
db_file_seek_update(int id, uint32_t seek);
|
2015-08-04 22:33:32 +02:00
|
|
|
|
2017-12-09 17:12:13 +01:00
|
|
|
int
|
|
|
|
db_file_rating_update_byid(uint32_t id, uint32_t rating);
|
|
|
|
|
|
|
|
int
|
|
|
|
db_file_rating_update_byvirtualpath(const char *virtual_path, uint32_t rating);
|
|
|
|
|
2009-06-10 21:36:43 +02:00
|
|
|
void
|
2017-10-01 00:43:24 +02:00
|
|
|
db_file_delete_bypath(const char *path);
|
2009-06-10 21:36:43 +02:00
|
|
|
|
2009-06-10 22:11:24 +02:00
|
|
|
void
|
2017-12-16 23:09:29 +01:00
|
|
|
db_file_disable_bypath(const char *path, enum strip_type strip, uint32_t cookie);
|
2009-06-10 22:11:24 +02:00
|
|
|
|
2009-06-11 14:42:55 +02:00
|
|
|
void
|
2017-12-16 23:09:29 +01:00
|
|
|
db_file_disable_bymatch(const char *path, enum strip_type strip, uint32_t cookie);
|
2009-06-11 14:42:55 +02:00
|
|
|
|
2009-06-10 22:11:24 +02:00
|
|
|
int
|
2017-12-16 23:09:29 +01:00
|
|
|
db_file_enable_bycookie(uint32_t cookie, const char *path, const char *filename);
|
2009-06-10 22:11:24 +02:00
|
|
|
|
2015-12-27 07:16:50 +01:00
|
|
|
int
|
2017-10-01 00:43:24 +02:00
|
|
|
db_file_update_directoryid(const char *path, int dir_id);
|
2015-12-27 07:16:50 +01:00
|
|
|
|
2017-08-12 16:47:44 +02:00
|
|
|
int
|
|
|
|
db_filecount_get(struct filecount_info *fci, struct query_params *qp);
|
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
/* Playlists */
|
|
|
|
int
|
2009-06-11 18:41:50 +02:00
|
|
|
db_pl_get_count(void);
|
2009-06-07 18:56:35 +02:00
|
|
|
|
|
|
|
void
|
|
|
|
db_pl_ping(int id);
|
|
|
|
|
2013-11-30 23:12:09 +01:00
|
|
|
void
|
2017-10-01 00:43:24 +02:00
|
|
|
db_pl_ping_bymatch(const char *path, int isdir);
|
2013-11-30 23:12:09 +01:00
|
|
|
|
2017-10-02 23:02:25 +02:00
|
|
|
void
|
|
|
|
db_pl_ping_items_bymatch(const char *path, int id);
|
|
|
|
|
2017-05-01 13:28:46 +02:00
|
|
|
int
|
|
|
|
db_pl_id_bypath(const char *path);
|
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
struct playlist_info *
|
2016-12-31 07:28:18 +01:00
|
|
|
db_pl_fetch_bypath(const char *path);
|
2009-06-07 18:56:35 +02:00
|
|
|
|
2014-12-21 20:41:44 +01:00
|
|
|
struct playlist_info *
|
2017-05-01 13:28:46 +02:00
|
|
|
db_pl_fetch_byvirtualpath(const char *virtual_path);
|
2014-12-21 20:41:44 +01:00
|
|
|
|
2009-11-22 12:34:37 +01:00
|
|
|
struct playlist_info *
|
2017-10-01 00:43:24 +02:00
|
|
|
db_pl_fetch_bytitlepath(const char *title, const char *path);
|
2009-11-22 12:34:37 +01:00
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
int
|
2015-03-14 22:34:03 +01:00
|
|
|
db_pl_add(struct playlist_info *pli, int *id);
|
2009-06-07 18:56:35 +02:00
|
|
|
|
|
|
|
int
|
2016-12-31 07:28:18 +01:00
|
|
|
db_pl_add_item_bypath(int plid, const char *path);
|
2009-06-07 18:56:35 +02:00
|
|
|
|
2009-11-22 12:17:28 +01:00
|
|
|
int
|
|
|
|
db_pl_add_item_byid(int plid, int fileid);
|
|
|
|
|
2009-06-11 19:04:21 +02:00
|
|
|
void
|
|
|
|
db_pl_clear_items(int id);
|
|
|
|
|
2014-03-11 23:20:29 +01:00
|
|
|
int
|
2015-03-14 22:34:03 +01:00
|
|
|
db_pl_update(struct playlist_info *pli);
|
2014-03-11 23:20:29 +01:00
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
void
|
|
|
|
db_pl_delete(int id);
|
|
|
|
|
2009-06-10 21:36:43 +02:00
|
|
|
void
|
2017-10-01 00:43:24 +02:00
|
|
|
db_pl_delete_bypath(const char *path);
|
2009-06-10 21:36:43 +02:00
|
|
|
|
2009-06-10 22:11:24 +02:00
|
|
|
void
|
2017-12-16 23:09:29 +01:00
|
|
|
db_pl_disable_bypath(const char *path, enum strip_type strip, uint32_t cookie);
|
2009-06-10 22:11:24 +02:00
|
|
|
|
2009-06-11 14:42:55 +02:00
|
|
|
void
|
2017-12-16 23:09:29 +01:00
|
|
|
db_pl_disable_bymatch(const char *path, enum strip_type strip, uint32_t cookie);
|
2009-06-11 14:42:55 +02:00
|
|
|
|
2009-06-10 22:11:24 +02:00
|
|
|
int
|
2017-10-01 00:43:24 +02:00
|
|
|
db_pl_enable_bycookie(uint32_t cookie, const char *path);
|
2009-06-10 22:11:24 +02:00
|
|
|
|
2010-03-06 18:56:30 +01:00
|
|
|
/* Groups */
|
2016-12-14 19:28:27 +01:00
|
|
|
int
|
|
|
|
db_groups_cleanup();
|
|
|
|
|
2014-11-10 22:53:08 +01:00
|
|
|
int
|
|
|
|
db_group_persistentid_byid(int id, int64_t *persistentid);
|
2010-03-07 12:53:23 +01:00
|
|
|
|
2015-12-27 07:16:50 +01:00
|
|
|
|
|
|
|
/* Directories */
|
|
|
|
int
|
2018-11-24 12:14:41 +01:00
|
|
|
db_directory_id_byvirtualpath(const char *virtual_path);
|
|
|
|
|
|
|
|
int
|
|
|
|
db_directory_id_bypath(const char *path);
|
2015-12-27 07:16:50 +01:00
|
|
|
|
|
|
|
int
|
|
|
|
db_directory_enum_start(struct directory_enum *de);
|
|
|
|
|
|
|
|
int
|
|
|
|
db_directory_enum_fetch(struct directory_enum *de, struct directory_info *di);
|
|
|
|
|
|
|
|
void
|
|
|
|
db_directory_enum_end(struct directory_enum *de);
|
|
|
|
|
2014-12-21 20:41:44 +01:00
|
|
|
int
|
2018-11-24 09:44:18 +01:00
|
|
|
db_directory_addorupdate(char *virtual_path, char *path, int disabled, int parent_id);
|
2015-12-27 07:16:50 +01:00
|
|
|
|
|
|
|
void
|
2017-01-01 16:51:21 +01:00
|
|
|
db_directory_ping_bymatch(char *virtual_path);
|
2015-12-27 07:16:50 +01:00
|
|
|
|
|
|
|
void
|
2017-12-16 23:09:29 +01:00
|
|
|
db_directory_disable_bymatch(char *path, enum strip_type strip, uint32_t cookie);
|
2014-12-21 20:41:44 +01:00
|
|
|
|
|
|
|
int
|
2015-12-27 07:16:50 +01:00
|
|
|
db_directory_enable_bycookie(uint32_t cookie, char *path);
|
2014-12-21 20:41:44 +01:00
|
|
|
|
2016-01-30 07:27:20 +01:00
|
|
|
int
|
|
|
|
db_directory_enable_bypath(char *path);
|
|
|
|
|
2010-01-30 17:01:27 +01:00
|
|
|
/* Remotes */
|
|
|
|
int
|
|
|
|
db_pairing_add(struct pairing_info *pi);
|
|
|
|
|
|
|
|
int
|
|
|
|
db_pairing_fetch_byguid(struct pairing_info *pi);
|
|
|
|
|
2014-03-11 23:20:29 +01:00
|
|
|
#ifdef HAVE_SPOTIFY_H
|
|
|
|
/* Spotify */
|
|
|
|
void
|
|
|
|
db_spotify_purge(void);
|
|
|
|
|
|
|
|
void
|
|
|
|
db_spotify_pl_delete(int id);
|
2016-01-16 17:02:03 +01:00
|
|
|
|
|
|
|
void
|
2016-11-13 20:28:29 +01:00
|
|
|
db_spotify_files_delete(void);
|
2014-03-11 23:20:29 +01:00
|
|
|
#endif
|
|
|
|
|
2014-08-15 22:54:47 +02:00
|
|
|
/* Admin */
|
|
|
|
int
|
2016-12-09 16:31:42 +01:00
|
|
|
db_admin_set(const char *key, const char *value);
|
2014-08-15 22:54:47 +02:00
|
|
|
|
2017-11-19 07:46:28 +01:00
|
|
|
int
|
|
|
|
db_admin_setint(const char *key, int value);
|
|
|
|
|
2017-11-12 09:27:26 +01:00
|
|
|
int
|
|
|
|
db_admin_setint64(const char *key, int64_t value);
|
|
|
|
|
2014-08-15 22:54:47 +02:00
|
|
|
char *
|
|
|
|
db_admin_get(const char *key);
|
|
|
|
|
2017-11-19 07:46:28 +01:00
|
|
|
int
|
|
|
|
db_admin_getint(const char *key);
|
|
|
|
|
2017-11-12 09:27:26 +01:00
|
|
|
int64_t
|
|
|
|
db_admin_getint64(const char *key);
|
|
|
|
|
2014-08-15 22:54:47 +02:00
|
|
|
int
|
|
|
|
db_admin_delete(const char *key);
|
|
|
|
|
2017-06-19 21:52:01 +02:00
|
|
|
/* Speakers/outputs */
|
2010-11-02 18:40:14 +01:00
|
|
|
int
|
2017-06-19 21:52:01 +02:00
|
|
|
db_speaker_save(struct output_device *device);
|
2010-11-02 18:40:14 +01:00
|
|
|
|
|
|
|
int
|
2017-06-19 21:52:01 +02:00
|
|
|
db_speaker_get(struct output_device *device, uint64_t id);
|
2017-06-18 01:29:40 +02:00
|
|
|
|
2010-11-02 18:40:14 +01:00
|
|
|
void
|
|
|
|
db_speaker_clear_all(void);
|
|
|
|
|
2016-11-04 15:34:00 +01:00
|
|
|
/* Queue */
|
2017-01-22 23:10:15 +01:00
|
|
|
int
|
|
|
|
db_queue_update_item(struct db_queue_item *queue_item);
|
2016-11-12 13:23:41 +01:00
|
|
|
|
2016-11-04 15:34:00 +01:00
|
|
|
int
|
|
|
|
db_queue_add_by_queryafteritemid(struct query_params *qp, uint32_t item_id);
|
|
|
|
|
|
|
|
int
|
2018-09-06 21:16:27 +02:00
|
|
|
db_queue_add_by_query(struct query_params *qp, char reshuffle, uint32_t item_id, int position, int *count, int *new_item_id);
|
2016-11-04 15:34:00 +01:00
|
|
|
|
|
|
|
int
|
2018-09-06 21:16:27 +02:00
|
|
|
db_queue_add_by_playlistid(int plid, char reshuffle, uint32_t item_id, int position, int *count, int *new_item_id);
|
2016-11-04 15:34:00 +01:00
|
|
|
|
|
|
|
int
|
2018-09-06 21:16:27 +02:00
|
|
|
db_queue_add_by_fileid(int id, char reshuffle, uint32_t item_id, int position, int *count, int *new_item_id);
|
2016-11-04 15:34:00 +01:00
|
|
|
|
2017-02-18 06:54:44 +01:00
|
|
|
int
|
2018-10-13 08:30:41 +02:00
|
|
|
db_queue_add_start(struct db_queue_add_info *queue_add_info, int pos);
|
2018-03-09 19:03:43 +01:00
|
|
|
|
2018-10-13 08:30:41 +02:00
|
|
|
int
|
2018-11-10 07:41:36 +01:00
|
|
|
db_queue_add_end(struct db_queue_add_info *queue_add_info, char reshuffle, uint32_t item_id, int ret);
|
2018-03-09 19:03:43 +01:00
|
|
|
|
|
|
|
int
|
|
|
|
db_queue_add_item(struct db_queue_add_info *queue_add_info, struct db_queue_item *item);
|
2017-02-18 06:54:44 +01:00
|
|
|
|
2016-11-04 15:34:00 +01:00
|
|
|
int
|
2017-04-16 23:54:07 +02:00
|
|
|
db_queue_enum_start(struct query_params *qp);
|
2016-11-04 15:34:00 +01:00
|
|
|
|
|
|
|
void
|
2017-04-16 23:54:07 +02:00
|
|
|
db_queue_enum_end(struct query_params *qp);
|
2016-11-04 15:34:00 +01:00
|
|
|
|
|
|
|
int
|
2017-04-16 23:54:07 +02:00
|
|
|
db_queue_enum_fetch(struct query_params *qp, struct db_queue_item *queue_item);
|
2016-11-04 15:34:00 +01:00
|
|
|
|
|
|
|
struct db_queue_item *
|
|
|
|
db_queue_fetch_byitemid(uint32_t item_id);
|
|
|
|
|
|
|
|
struct db_queue_item *
|
|
|
|
db_queue_fetch_byfileid(uint32_t file_id);
|
|
|
|
|
|
|
|
struct db_queue_item *
|
|
|
|
db_queue_fetch_bypos(uint32_t pos, char shuffle);
|
|
|
|
|
|
|
|
struct db_queue_item *
|
|
|
|
db_queue_fetch_byposrelativetoitem(int pos, uint32_t item_id, char shuffle);
|
|
|
|
|
|
|
|
struct db_queue_item *
|
|
|
|
db_queue_fetch_next(uint32_t item_id, char shuffle);
|
|
|
|
|
|
|
|
struct db_queue_item *
|
|
|
|
db_queue_fetch_prev(uint32_t item_id, char shuffle);
|
|
|
|
|
|
|
|
int
|
|
|
|
db_queue_cleanup();
|
|
|
|
|
|
|
|
int
|
2017-02-11 09:28:35 +01:00
|
|
|
db_queue_clear(uint32_t keep_item_id);
|
2016-11-04 15:34:00 +01:00
|
|
|
|
|
|
|
int
|
|
|
|
db_queue_delete_byitemid(uint32_t item_id);
|
|
|
|
|
|
|
|
int
|
|
|
|
db_queue_delete_bypos(uint32_t pos, int count);
|
|
|
|
|
|
|
|
int
|
|
|
|
db_queue_delete_byposrelativetoitem(uint32_t pos, uint32_t item_id, char shuffle);
|
|
|
|
|
|
|
|
int
|
2017-04-17 10:46:24 +02:00
|
|
|
db_queue_move_byitemid(uint32_t item_id, int pos_to, char shuffle);
|
2016-11-04 15:34:00 +01:00
|
|
|
|
|
|
|
int
|
|
|
|
db_queue_move_bypos(int pos_from, int pos_to);
|
|
|
|
|
|
|
|
int
|
|
|
|
db_queue_move_byposrelativetoitem(uint32_t from_pos, uint32_t to_offset, uint32_t item_id, char shuffle);
|
|
|
|
|
|
|
|
int
|
|
|
|
db_queue_reshuffle(uint32_t item_id);
|
|
|
|
|
2018-11-05 21:35:17 +01:00
|
|
|
int
|
|
|
|
db_queue_inc_version(void);
|
|
|
|
|
2016-11-04 15:34:00 +01:00
|
|
|
int
|
|
|
|
db_queue_get_count();
|
|
|
|
|
|
|
|
int
|
|
|
|
db_queue_get_pos(uint32_t item_id, char shuffle);
|
|
|
|
|
2009-06-10 18:11:11 +02:00
|
|
|
/* Inotify */
|
|
|
|
int
|
|
|
|
db_watch_clear(void);
|
|
|
|
|
|
|
|
int
|
|
|
|
db_watch_add(struct watch_info *wi);
|
|
|
|
|
|
|
|
int
|
2009-06-11 16:47:15 +02:00
|
|
|
db_watch_delete_bywd(uint32_t wd);
|
2009-06-10 18:11:11 +02:00
|
|
|
|
2009-06-11 16:12:17 +02:00
|
|
|
int
|
|
|
|
db_watch_delete_bypath(char *path);
|
|
|
|
|
|
|
|
int
|
|
|
|
db_watch_delete_bymatch(char *path);
|
|
|
|
|
|
|
|
int
|
|
|
|
db_watch_delete_bycookie(uint32_t cookie);
|
|
|
|
|
2009-06-10 18:11:11 +02:00
|
|
|
int
|
|
|
|
db_watch_get_bywd(struct watch_info *wi);
|
|
|
|
|
2014-06-09 23:42:02 +02:00
|
|
|
int
|
|
|
|
db_watch_get_bypath(struct watch_info *wi);
|
|
|
|
|
2009-06-11 15:24:10 +02:00
|
|
|
void
|
2017-12-16 23:09:29 +01:00
|
|
|
db_watch_mark_bypath(char *path, enum strip_type strip, uint32_t cookie);
|
2009-06-11 15:24:10 +02:00
|
|
|
|
|
|
|
void
|
2017-12-16 23:09:29 +01:00
|
|
|
db_watch_mark_bymatch(char *path, enum strip_type strip, uint32_t cookie);
|
2009-06-11 15:24:10 +02:00
|
|
|
|
2009-06-11 15:42:51 +02:00
|
|
|
void
|
|
|
|
db_watch_move_bycookie(uint32_t cookie, char *path);
|
|
|
|
|
|
|
|
int
|
|
|
|
db_watch_cookie_known(uint32_t cookie);
|
|
|
|
|
2009-06-11 16:44:49 +02:00
|
|
|
int
|
|
|
|
db_watch_enum_start(struct watch_enum *we);
|
|
|
|
|
|
|
|
void
|
|
|
|
db_watch_enum_end(struct watch_enum *we);
|
|
|
|
|
|
|
|
int
|
|
|
|
db_watch_enum_fetchwd(struct watch_enum *we, uint32_t *wd);
|
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
|
|
|
|
int
|
|
|
|
db_perthread_init(void);
|
|
|
|
|
|
|
|
void
|
|
|
|
db_perthread_deinit(void);
|
|
|
|
|
|
|
|
int
|
|
|
|
db_init(void);
|
|
|
|
|
2010-04-26 18:24:09 +02:00
|
|
|
void
|
|
|
|
db_deinit(void);
|
|
|
|
|
2009-06-07 18:56:35 +02:00
|
|
|
#endif /* !__DB_H__ */
|