[jsonapi] Coverity fixups

This commit is contained in:
ejurgensen 2022-01-20 00:16:30 +01:00
parent 53ee9a3c39
commit 070866b41a

View File

@ -1829,7 +1829,7 @@ jsonapi_reply_outputs_set(struct httpd_request *hreq)
{ {
nspk = json_object_array_length(outputs); nspk = json_object_array_length(outputs);
ids = calloc((nspk + 1), sizeof(uint64_t)); CHECK_NULL(L_WEB, ids = calloc((nspk + 1), sizeof(uint64_t)));
ids[0] = nspk; ids[0] = nspk;
ret = 0; ret = 0;
@ -2502,8 +2502,8 @@ jsonapi_reply_queue_tracks_add(struct httpd_request *hreq)
const char *param_uris; const char *param_uris;
const char *param_expression; const char *param_expression;
const char *param; const char *param;
int pos = -1; int pos;
int limit = -1; int limit;
bool shuffle; bool shuffle;
int total_count = 0; int total_count = 0;
json_object *reply; json_object *reply;
@ -2522,6 +2522,8 @@ jsonapi_reply_queue_tracks_add(struct httpd_request *hreq)
DPRINTF(E_DBG, L_WEB, "Add tracks starting at position '%d\n", pos); DPRINTF(E_DBG, L_WEB, "Add tracks starting at position '%d\n", pos);
} }
else
pos = -1;
param_uris = evhttp_find_header(hreq->query, "uris"); param_uris = evhttp_find_header(hreq->query, "uris");
param_expression = evhttp_find_header(hreq->query, "expression"); param_expression = evhttp_find_header(hreq->query, "expression");
@ -2557,9 +2559,10 @@ jsonapi_reply_queue_tracks_add(struct httpd_request *hreq)
{ {
// This overrides the value specified in query // This overrides the value specified in query
param = evhttp_find_header(hreq->query, "limit"); param = evhttp_find_header(hreq->query, "limit");
if (param) if (param && safe_atoi32(param, &limit) == 0)
safe_atoi32(param, &limit);
ret = queue_tracks_add_byexpression(param_expression, pos, limit, &total_count); ret = queue_tracks_add_byexpression(param_expression, pos, limit, &total_count);
else
ret = queue_tracks_add_byexpression(param_expression, pos, -1, &total_count);
} }
if (ret == 0) if (ret == 0)
@ -2579,9 +2582,12 @@ jsonapi_reply_queue_tracks_add(struct httpd_request *hreq)
if (param && strcmp(param, "start") == 0) if (param && strcmp(param, "start") == 0)
{ {
if ((param = evhttp_find_header(hreq->query, "playback_from_position"))) if ((param = evhttp_find_header(hreq->query, "playback_from_position")))
play_item_at_position(param); ret = (play_item_at_position(param) == HTTP_NOCONTENT) ? 0 : -1;
else else
player_playback_start(); ret = player_playback_start();
if (ret < 0)
return HTTP_INTERNAL;
} }
return HTTP_OK; return HTTP_OK;
@ -2610,10 +2616,11 @@ update_pos(uint32_t item_id, const char *new, char shuffle)
} }
static inline void static inline void
update_str(char **str, const char *new) update_str(bool *is_changed, char **str, const char *new)
{ {
free(*str); free(*str);
*str = strdup(new); *str = strdup(new);
*is_changed = true;
} }
static int static int
@ -2629,11 +2636,19 @@ jsonapi_reply_queue_tracks_update(struct httpd_request *hreq)
player_get_status(&status); player_get_status(&status);
if (strcmp(hreq->uri_parsed->path_parts[3], "now_playing") != 0) if (strcmp(hreq->uri_parsed->path_parts[3], "now_playing") != 0)
safe_atou32(hreq->uri_parsed->path_parts[3], &item_id); {
ret = safe_atou32(hreq->uri_parsed->path_parts[3], &item_id);
if (ret < 0)
{
DPRINTF(E_LOG, L_WEB, "No valid item id given: '%s'\n", hreq->uri_parsed->path);
return HTTP_BADREQUEST;
}
}
else else
item_id = status.item_id; item_id = status.item_id;
if (!item_id || !(queue_item = db_queue_fetch_byitemid(item_id))) queue_item = db_queue_fetch_byitemid(item_id);
if (!queue_item)
{ {
DPRINTF(E_LOG, L_WEB, "No valid item id given, or now_playing given but not playing: '%s'\n", hreq->uri_parsed->path); DPRINTF(E_LOG, L_WEB, "No valid item id given, or now_playing given but not playing: '%s'\n", hreq->uri_parsed->path);
return HTTP_BADREQUEST; return HTTP_BADREQUEST;
@ -2643,20 +2658,20 @@ jsonapi_reply_queue_tracks_update(struct httpd_request *hreq)
is_changed = false; is_changed = false;
if ((param = evhttp_find_header(hreq->query, "new_position"))) if ((param = evhttp_find_header(hreq->query, "new_position")))
ret = update_pos(item_id, param, status.shuffle); ret = update_pos(item_id, param, status.shuffle);
if ((param = evhttp_find_header(hreq->query, "title")) && (is_changed = true)) if ((param = evhttp_find_header(hreq->query, "title")))
update_str(&queue_item->title, param); update_str(&is_changed, &queue_item->title, param);
if ((param = evhttp_find_header(hreq->query, "album")) && (is_changed = true)) if ((param = evhttp_find_header(hreq->query, "album")))
update_str(&queue_item->album, param); update_str(&is_changed, &queue_item->album, param);
if ((param = evhttp_find_header(hreq->query, "artist")) && (is_changed = true)) if ((param = evhttp_find_header(hreq->query, "artist")))
update_str(&queue_item->artist, param); update_str(&is_changed, &queue_item->artist, param);
if ((param = evhttp_find_header(hreq->query, "album_artist")) && (is_changed = true)) if ((param = evhttp_find_header(hreq->query, "album_artist")))
update_str(&queue_item->album_artist, param); update_str(&is_changed, &queue_item->album_artist, param);
if ((param = evhttp_find_header(hreq->query, "composer")) && (is_changed = true)) if ((param = evhttp_find_header(hreq->query, "composer")))
update_str(&queue_item->composer, param); update_str(&is_changed, &queue_item->composer, param);
if ((param = evhttp_find_header(hreq->query, "genre")) && (is_changed = true)) if ((param = evhttp_find_header(hreq->query, "genre")))
update_str(&queue_item->genre, param); update_str(&is_changed, &queue_item->genre, param);
if ((param = evhttp_find_header(hreq->query, "artwork_url")) && (is_changed = true)) if ((param = evhttp_find_header(hreq->query, "artwork_url")))
update_str(&queue_item->artwork_url, param); update_str(&is_changed, &queue_item->artwork_url, param);
if (ret != HTTP_OK) if (ret != HTTP_OK)
return ret; return ret;