[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:
chme 2020-09-01 20:37:10 +02:00
parent 7040382688
commit 451e0bf10b
2 changed files with 49 additions and 16 deletions

View File

@ -113,7 +113,7 @@ safe_json_add_int_from_string(json_object *obj, const char *key, const char *val
} }
static inline void 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; uint32_t tmp;
time_t timestamp; time_t timestamp;
@ -139,10 +139,39 @@ safe_json_add_time_from_string(json_object *obj, const char *key, const char *va
return; return;
} }
if (with_time) strftime(result, sizeof(result), "%FT%TZ", &tm);
strftime(result, sizeof(result), "%FT%TZ", &tm);
else json_object_object_add(obj, key, json_object_new_string(result));
strftime(result, sizeof(result), "%F", &tm); }
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(&timestamp, &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)); 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, "track_count", dbgri->itemcount);
safe_json_add_int_from_string(item, "length_ms", dbgri->song_length); 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_played", dbgri->time_played);
safe_json_add_time_from_string(item, "time_added", dbgri->time_added, true); safe_json_add_time_from_string(item, "time_added", dbgri->time_added);
ret = safe_atoi32(dbgri->seek, &intval); ret = safe_atoi32(dbgri->seek, &intval);
if (ret == 0) 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, "track_count", dbgri->itemcount);
safe_json_add_int_from_string(item, "length_ms", dbgri->song_length); 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_played", dbgri->time_played);
safe_json_add_time_from_string(item, "time_added", dbgri->time_added, true); safe_json_add_time_from_string(item, "time_added", dbgri->time_added);
ret = safe_atoi32(dbgri->seek, &intval); ret = safe_atoi32(dbgri->seek, &intval);
if (ret == 0) if (ret == 0)
@ -225,7 +254,7 @@ album_to_json(struct db_group_info *dbgri)
if (ret == 0) if (ret == 0)
safe_json_add_string(item, "data_kind", db_data_kind_label(intval)); 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); safe_json_add_int_from_string(item, "year", dbgri->year);
ret = snprintf(uri, sizeof(uri), "%s:%s:%s", "library", "album", dbgri->persistentid); 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, "rating", dbmfi->rating);
safe_json_add_int_from_string(item, "play_count", dbmfi->play_count); 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_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_played", dbmfi->time_played);
safe_json_add_time_from_string(item, "time_skipped", dbmfi->time_skipped, true); safe_json_add_time_from_string(item, "time_skipped", dbmfi->time_skipped);
safe_json_add_time_from_string(item, "time_added", dbmfi->time_added, true); safe_json_add_time_from_string(item, "time_added", dbmfi->time_added);
safe_json_add_time_from_string(item, "date_released", dbmfi->date_released, false); 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_int_from_string(item, "seek_ms", dbmfi->seek);
safe_json_add_string(item, "type", dbmfi->type); 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); ret = db_admin_get(&s, DB_ADMIN_START_TIME);
if (ret == 0) 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); free(s);
} }
ret = db_admin_get(&s, DB_ADMIN_DB_UPDATE); ret = db_admin_get(&s, DB_ADMIN_DB_UPDATE);
if (ret == 0) 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); free(s);
} }

View File

@ -52,6 +52,7 @@ struct spotify_album
const char *name; const char *name;
const char *release_date; const char *release_date;
const char *release_date_precision; const char *release_date_precision;
time_t release_date_time;
int release_year; int release_year;
const char *uri; const char *uri;
const char *artwork_url; 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 = jparse_str_from_obj(jsonalbum, "release_date");
album->release_date_precision = jparse_str_from_obj(jsonalbum, "release_date_precision"); 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); album->release_year = get_year_from_date(album->release_date);
if (max_w > 0) 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->album = safe_strdup(album->name);
mfi->genre = safe_strdup(album->genre); mfi->genre = safe_strdup(album->genre);
mfi->compilation = album->is_compilation; mfi->compilation = album->is_compilation;
mfi->date_released = album->release_date_time;
mfi->year = album->release_year; mfi->year = album->release_year;
} }
else else