mirror of
https://github.com/owntone/owntone-server.git
synced 2025-01-15 00:35:03 -05:00
[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:
parent
23979d223c
commit
631996f133
17
src/mpd.c
17
src/mpd.c
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user