diff --git a/src/legacy/core_plugins/console/server/proxy_route.js b/src/legacy/core_plugins/console/server/proxy_route.js index a7062133dcd36..963f26bd3523c 100644 --- a/src/legacy/core_plugins/console/server/proxy_route.js +++ b/src/legacy/core_plugins/console/server/proxy_route.js @@ -54,7 +54,6 @@ function getProxyHeaders(req) { if (contentType) { headers['content-type'] = contentType; } - return headers; } @@ -107,30 +106,37 @@ export const createProxyRoute = ({ agent, headers, } = getConfigForReq(req, uri); + const makeRequest = async (payloadToSend) => { + const wreckOptions = { + payload: payloadToSend, + timeout, + rejectUnauthorized, + agent, + headers: { + ...headers, + ...getProxyHeaders(req) + }, + }; + + const esResponse = await Wreck.request(method, uri, wreckOptions); + + if (method.toUpperCase() !== 'HEAD') { + return h.response(esResponse) + .code(esResponse.statusCode) + .header('warning', esResponse.headers.warning); + } - const wreckOptions = { - payload, - timeout, - rejectUnauthorized, - agent, - headers: { - ...headers, - ...getProxyHeaders(req) - }, - }; - - const esResponse = await Wreck.request(method, uri, wreckOptions); - - if (method.toUpperCase() !== 'HEAD') { - return h.response(esResponse) + return h.response(`${esResponse.statusCode} - ${esResponse.statusMessage}`) .code(esResponse.statusCode) + .type('text/plain') .header('warning', esResponse.headers.warning); + }; + if (method.toUpperCase() === 'DELETE') { + const data = await Wreck.read(payload); + return await makeRequest(data); + } else { + return await makeRequest(payload); } - - return h.response(`${esResponse.statusCode} - ${esResponse.statusMessage}`) - .code(esResponse.statusCode) - .type('text/plain') - .header('warning', esResponse.headers.warning); } } });