From c45a85d1430a9da4958d5fd29750249b270f34a5 Mon Sep 17 00:00:00 2001 From: ejurgensen Date: Sun, 27 Aug 2017 00:02:39 +0200 Subject: [PATCH] [dacp] Fix issue where Hyperfine Remote provides speaker ids as decimal Also align a bit on how we handle hex/dec parameters --- src/httpd_dacp.c | 26 ++++++++++++++++++++++---- src/misc.c | 4 ---- 2 files changed, 22 insertions(+), 8 deletions(-) diff --git a/src/httpd_dacp.c b/src/httpd_dacp.c index 5b973276..037171da 100644 --- a/src/httpd_dacp.c +++ b/src/httpd_dacp.c @@ -716,7 +716,12 @@ dacp_propset_userrating(const char *value, struct evkeyvalq *query) } param++; - ret = safe_hextou32(param, &itemid); + + if (strncmp(param, "0x", 2) == 0) + ret = safe_hextou32(param, &itemid); + else + ret = safe_atou32(param, &itemid); + if (ret < 0) { DPRINTF(E_LOG, L_DACP, "Couldn't convert item-spec/song-spec to an integer in dacp.userrating (%s)\n", param); @@ -1224,7 +1229,11 @@ dacp_reply_playspec(struct evhttp_request *req, struct evbuffer *evbuf, char **u } param++; - ret = safe_hextou32(param, &plid); + if (strncmp(param, "0x", 2) == 0) + ret = safe_hextou32(param, &plid); + else + ret = safe_atou32(param, &plid); + if (ret < 0) { DPRINTF(E_LOG, L_DACP, "Couldn't convert container-spec to an integer in playspec (%s)\n", param); @@ -1253,7 +1262,11 @@ dacp_reply_playspec(struct evhttp_request *req, struct evbuffer *evbuf, char **u } param++; - ret = safe_hextou32(param, &id); + if (strncmp(param, "0x", 2) == 0) + ret = safe_hextou32(param, &id); + else + ret = safe_atou32(param, &id); + if (ret < 0) { DPRINTF(E_LOG, L_DACP, "Couldn't convert container-item-spec/item-spec to an integer in playspec (%s)\n", param); @@ -2490,7 +2503,12 @@ dacp_reply_setspeakers(struct evhttp_request *req, struct evbuffer *evbuf, char { param++; - ret = safe_hextou64(param, &ids[i]); + // Some like Remote will give us hex, others will give us decimal (e.g. Hyperfine) + if (strncmp(param, "0x", 2) == 0) + ret = safe_hextou64(param, &ids[i]); + else + ret = safe_atou64(param, &ids[i]); + if (ret < 0) { DPRINTF(E_LOG, L_DACP, "Invalid speaker id in request: %s\n", param); diff --git a/src/misc.c b/src/misc.c index 56fde219..25f0d1b8 100644 --- a/src/misc.c +++ b/src/misc.c @@ -130,10 +130,6 @@ safe_hextou32(const char *str, uint32_t *val) *val = 0; - /* A hex shall begin with 0x */ - if (strncmp(str, "0x", 2) != 0) - return safe_atou32(str, val); - errno = 0; intval = strtoul(str, &end, 16);