mirror of
https://github.com/owntone/owntone-server.git
synced 2025-01-24 21:23:17 -05:00
[spotify/jsonapi] Map date_released for Spotify tracks; fix date
released being off by one day in the JSON API
This commit is contained in:
parent
7040382688
commit
451e0bf10b
@ -113,7 +113,7 @@ safe_json_add_int_from_string(json_object *obj, const char *key, const char *val
|
||||
}
|
||||
|
||||
static inline void
|
||||
safe_json_add_time_from_string(json_object *obj, const char *key, const char *value, bool with_time)
|
||||
safe_json_add_time_from_string(json_object *obj, const char *key, const char *value)
|
||||
{
|
||||
uint32_t tmp;
|
||||
time_t timestamp;
|
||||
@ -139,9 +139,38 @@ safe_json_add_time_from_string(json_object *obj, const char *key, const char *va
|
||||
return;
|
||||
}
|
||||
|
||||
if (with_time)
|
||||
strftime(result, sizeof(result), "%FT%TZ", &tm);
|
||||
else
|
||||
|
||||
json_object_object_add(obj, key, json_object_new_string(result));
|
||||
}
|
||||
|
||||
static inline void
|
||||
safe_json_add_date_from_string(json_object *obj, const char *key, const char *value)
|
||||
{
|
||||
uint32_t tmp;
|
||||
time_t timestamp;
|
||||
struct tm tm;
|
||||
char result[32];
|
||||
|
||||
if (!value)
|
||||
return;
|
||||
|
||||
if (safe_atou32(value, &tmp) != 0)
|
||||
{
|
||||
DPRINTF(E_LOG, L_WEB, "Error converting timestamp to uint32_t: %s\n", value);
|
||||
return;
|
||||
}
|
||||
|
||||
if (!tmp)
|
||||
return;
|
||||
|
||||
timestamp = tmp;
|
||||
if (localtime_r(×tamp, &tm) == NULL)
|
||||
{
|
||||
DPRINTF(E_LOG, L_WEB, "Error converting timestamp to localtime: %s\n", value);
|
||||
return;
|
||||
}
|
||||
|
||||
strftime(result, sizeof(result), "%F", &tm);
|
||||
|
||||
json_object_object_add(obj, key, json_object_new_string(result));
|
||||
@ -165,8 +194,8 @@ artist_to_json(struct db_group_info *dbgri)
|
||||
safe_json_add_int_from_string(item, "track_count", dbgri->itemcount);
|
||||
safe_json_add_int_from_string(item, "length_ms", dbgri->song_length);
|
||||
|
||||
safe_json_add_time_from_string(item, "time_played", dbgri->time_played, true);
|
||||
safe_json_add_time_from_string(item, "time_added", dbgri->time_added, true);
|
||||
safe_json_add_time_from_string(item, "time_played", dbgri->time_played);
|
||||
safe_json_add_time_from_string(item, "time_added", dbgri->time_added);
|
||||
|
||||
ret = safe_atoi32(dbgri->seek, &intval);
|
||||
if (ret == 0)
|
||||
@ -210,8 +239,8 @@ album_to_json(struct db_group_info *dbgri)
|
||||
safe_json_add_int_from_string(item, "track_count", dbgri->itemcount);
|
||||
safe_json_add_int_from_string(item, "length_ms", dbgri->song_length);
|
||||
|
||||
safe_json_add_time_from_string(item, "time_played", dbgri->time_played, true);
|
||||
safe_json_add_time_from_string(item, "time_added", dbgri->time_added, true);
|
||||
safe_json_add_time_from_string(item, "time_played", dbgri->time_played);
|
||||
safe_json_add_time_from_string(item, "time_added", dbgri->time_added);
|
||||
|
||||
ret = safe_atoi32(dbgri->seek, &intval);
|
||||
if (ret == 0)
|
||||
@ -225,7 +254,7 @@ album_to_json(struct db_group_info *dbgri)
|
||||
if (ret == 0)
|
||||
safe_json_add_string(item, "data_kind", db_data_kind_label(intval));
|
||||
|
||||
safe_json_add_time_from_string(item, "date_released", dbgri->date_released, false);
|
||||
safe_json_add_date_from_string(item, "date_released", dbgri->date_released);
|
||||
safe_json_add_int_from_string(item, "year", dbgri->year);
|
||||
|
||||
ret = snprintf(uri, sizeof(uri), "%s:%s:%s", "library", "album", dbgri->persistentid);
|
||||
@ -271,10 +300,10 @@ track_to_json(struct db_media_file_info *dbmfi)
|
||||
safe_json_add_int_from_string(item, "rating", dbmfi->rating);
|
||||
safe_json_add_int_from_string(item, "play_count", dbmfi->play_count);
|
||||
safe_json_add_int_from_string(item, "skip_count", dbmfi->skip_count);
|
||||
safe_json_add_time_from_string(item, "time_played", dbmfi->time_played, true);
|
||||
safe_json_add_time_from_string(item, "time_skipped", dbmfi->time_skipped, true);
|
||||
safe_json_add_time_from_string(item, "time_added", dbmfi->time_added, true);
|
||||
safe_json_add_time_from_string(item, "date_released", dbmfi->date_released, false);
|
||||
safe_json_add_time_from_string(item, "time_played", dbmfi->time_played);
|
||||
safe_json_add_time_from_string(item, "time_skipped", dbmfi->time_skipped);
|
||||
safe_json_add_time_from_string(item, "time_added", dbmfi->time_added);
|
||||
safe_json_add_date_from_string(item, "date_released", dbmfi->date_released);
|
||||
safe_json_add_int_from_string(item, "seek_ms", dbmfi->seek);
|
||||
|
||||
safe_json_add_string(item, "type", dbmfi->type);
|
||||
@ -1113,14 +1142,14 @@ jsonapi_reply_library(struct httpd_request *hreq)
|
||||
ret = db_admin_get(&s, DB_ADMIN_START_TIME);
|
||||
if (ret == 0)
|
||||
{
|
||||
safe_json_add_time_from_string(jreply, "started_at", s, true);
|
||||
safe_json_add_time_from_string(jreply, "started_at", s);
|
||||
free(s);
|
||||
}
|
||||
|
||||
ret = db_admin_get(&s, DB_ADMIN_DB_UPDATE);
|
||||
if (ret == 0)
|
||||
{
|
||||
safe_json_add_time_from_string(jreply, "updated_at", s, true);
|
||||
safe_json_add_time_from_string(jreply, "updated_at", s);
|
||||
free(s);
|
||||
}
|
||||
|
||||
|
@ -52,6 +52,7 @@ struct spotify_album
|
||||
const char *name;
|
||||
const char *release_date;
|
||||
const char *release_date_precision;
|
||||
time_t release_date_time;
|
||||
int release_year;
|
||||
const char *uri;
|
||||
const char *artwork_url;
|
||||
@ -728,6 +729,8 @@ parse_metadata_album(json_object *jsonalbum, struct spotify_album *album, int ma
|
||||
|
||||
album->release_date = jparse_str_from_obj(jsonalbum, "release_date");
|
||||
album->release_date_precision = jparse_str_from_obj(jsonalbum, "release_date_precision");
|
||||
if (strcmp(album->release_date_precision, "day") == 0)
|
||||
album->release_date_time = jparse_time_from_obj(jsonalbum, "release_date");
|
||||
album->release_year = get_year_from_date(album->release_date);
|
||||
|
||||
if (max_w > 0)
|
||||
@ -1389,6 +1392,7 @@ map_track_to_mfi(struct media_file_info *mfi, const struct spotify_track *track,
|
||||
mfi->album = safe_strdup(album->name);
|
||||
mfi->genre = safe_strdup(album->genre);
|
||||
mfi->compilation = album->is_compilation;
|
||||
mfi->date_released = album->release_date_time;
|
||||
mfi->year = album->release_year;
|
||||
}
|
||||
else
|
||||
|
Loading…
x
Reference in New Issue
Block a user