From 9197f0f64bd2c80d3795afca5be416dccd73a9c4 Mon Sep 17 00:00:00 2001 From: chme Date: Sun, 24 Jan 2016 18:59:05 +0100 Subject: [PATCH] [spotify] fixup - added error handling --- src/spotify.c | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) diff --git a/src/spotify.c b/src/spotify.c index 81cd3372..1334e1f4 100644 --- a/src/spotify.c +++ b/src/spotify.c @@ -622,7 +622,13 @@ spotify_track_save(int plid, sp_track *track, const char *pltitle, int time_adde return -1; } - snprintf(virtual_path, sizeof(virtual_path), "/spotify:/%s", mfi.artist); + ret = snprintf(virtual_path, sizeof(virtual_path), "/spotify:/%s", mfi.artist); + if ((ret < 0) || (ret >= sizeof(virtual_path))) + { + DPRINTF(E_LOG, L_SPOTIFY, "Virtual path exceeds PATH_MAX (/spotify:/%s)\n", mfi.artist); + free_mfi(&mfi, 1); + return -1; + } dir_id = db_directory_addorupdate(virtual_path, 0, DIR_SPOTIFY); if (dir_id <= 0) { @@ -630,7 +636,13 @@ spotify_track_save(int plid, sp_track *track, const char *pltitle, int time_adde free_mfi(&mfi, 1); return -1; } - snprintf(virtual_path, sizeof(virtual_path), "/spotify:/%s/%s", mfi.artist, mfi.album); + ret = snprintf(virtual_path, sizeof(virtual_path), "/spotify:/%s/%s", mfi.artist, mfi.album); + if ((ret < 0) || (ret >= sizeof(virtual_path))) + { + DPRINTF(E_LOG, L_SPOTIFY, "Virtual path exceeds PATH_MAX (/spotify:/%s/%s)\n", mfi.artist, mfi.album); + free_mfi(&mfi, 1); + return -1; + } dir_id = db_directory_addorupdate(virtual_path, 0, dir_id); if (dir_id <= 0) {