[mpd] Decouple mpd and httpd

mpd is based on evhttp, so if httpd should use another backend they need to be
decoupled. No need to use httpd_send_reply/error, since CORS headers are not
relevant to MPD artwork serving.
This commit is contained in:
ejurgensen 2022-12-19 23:09:22 +01:00
parent 23979d223c
commit 631996f133

View File

@ -47,7 +47,6 @@
#include "commands.h" #include "commands.h"
#include "conffile.h" #include "conffile.h"
#include "db.h" #include "db.h"
#include "httpd.h"
#include "library.h" #include "library.h"
#include "listener.h" #include "listener.h"
#include "logger.h" #include "logger.h"
@ -4651,7 +4650,7 @@ artwork_cb(struct evhttp_request *req, void *arg)
if (evhttp_request_get_command(req) != EVHTTP_REQ_GET) if (evhttp_request_get_command(req) != EVHTTP_REQ_GET)
{ {
DPRINTF(E_LOG, L_MPD, "Unsupported request type for artwork\n"); DPRINTF(E_LOG, L_MPD, "Unsupported request type for artwork\n");
httpd_send_error(req, HTTP_BADMETHOD, "Method not allowed"); evhttp_send_error(req, HTTP_BADMETHOD, "Method not allowed");
return; return;
} }
@ -4662,7 +4661,7 @@ artwork_cb(struct evhttp_request *req, void *arg)
if (!decoded) if (!decoded)
{ {
DPRINTF(E_LOG, L_MPD, "Bad artwork request with uri '%s'\n", uri); DPRINTF(E_LOG, L_MPD, "Bad artwork request with uri '%s'\n", uri);
httpd_send_error(req, HTTP_BADREQUEST, 0); evhttp_send_error(req, HTTP_BADREQUEST, 0);
return; return;
} }
@ -4670,7 +4669,7 @@ artwork_cb(struct evhttp_request *req, void *arg)
if (!path) if (!path)
{ {
DPRINTF(E_LOG, L_MPD, "Invalid path from artwork request with uri '%s'\n", uri); DPRINTF(E_LOG, L_MPD, "Invalid path from artwork request with uri '%s'\n", uri);
httpd_send_error(req, HTTP_BADREQUEST, 0); evhttp_send_error(req, HTTP_BADREQUEST, 0);
evhttp_uri_free(decoded); evhttp_uri_free(decoded);
return; return;
} }
@ -4679,7 +4678,7 @@ artwork_cb(struct evhttp_request *req, void *arg)
if (!decoded_path) if (!decoded_path)
{ {
DPRINTF(E_LOG, L_MPD, "Error decoding path from artwork request with uri '%s'\n", uri); DPRINTF(E_LOG, L_MPD, "Error decoding path from artwork request with uri '%s'\n", uri);
httpd_send_error(req, HTTP_BADREQUEST, 0); evhttp_send_error(req, HTTP_BADREQUEST, 0);
evhttp_uri_free(decoded); evhttp_uri_free(decoded);
return; return;
} }
@ -4694,7 +4693,7 @@ artwork_cb(struct evhttp_request *req, void *arg)
if (!itemid) if (!itemid)
{ {
DPRINTF(E_WARN, L_MPD, "No item found for path '%s' from request uri '%s'\n", decoded_path, uri); DPRINTF(E_WARN, L_MPD, "No item found for path '%s' from request uri '%s'\n", decoded_path, uri);
httpd_send_error(req, HTTP_NOTFOUND, "Document was not found"); evhttp_send_error(req, HTTP_NOTFOUND, "Document was not found");
evhttp_uri_free(decoded); evhttp_uri_free(decoded);
free(decoded_path); free(decoded_path);
return; return;
@ -4704,7 +4703,7 @@ artwork_cb(struct evhttp_request *req, void *arg)
if (!evbuffer) if (!evbuffer)
{ {
DPRINTF(E_LOG, L_MPD, "Could not allocate an evbuffer for artwork request\n"); DPRINTF(E_LOG, L_MPD, "Could not allocate an evbuffer for artwork request\n");
httpd_send_error(req, HTTP_INTERNAL, "Document was not found"); evhttp_send_error(req, HTTP_INTERNAL, "Document was not found");
evhttp_uri_free(decoded); evhttp_uri_free(decoded);
free(decoded_path); free(decoded_path);
return; return;
@ -4713,7 +4712,7 @@ artwork_cb(struct evhttp_request *req, void *arg)
format = artwork_get_item(evbuffer, itemid, ART_DEFAULT_WIDTH, ART_DEFAULT_HEIGHT, 0); format = artwork_get_item(evbuffer, itemid, ART_DEFAULT_WIDTH, ART_DEFAULT_HEIGHT, 0);
if (format < 0) if (format < 0)
{ {
httpd_send_error(req, HTTP_NOTFOUND, "Document was not found"); evhttp_send_error(req, HTTP_NOTFOUND, "Document was not found");
} }
else else
{ {
@ -4728,7 +4727,7 @@ artwork_cb(struct evhttp_request *req, void *arg)
break; break;
} }
httpd_send_reply(req, HTTP_OK, "OK", evbuffer, HTTPD_SEND_NO_GZIP); evhttp_send_reply(req, HTTP_OK, "OK", evbuffer);
} }
evbuffer_free(evbuffer); evbuffer_free(evbuffer);