fix: handle missing EOF when decompressing response

Closes: #1609
pull/1656/head
nsankbeil 2 years ago
parent 1439b6cc9c
commit 5640798fe4

@ -1,6 +1,6 @@
/* eslint-disable prefer-promise-reject-errors */ /* eslint-disable prefer-promise-reject-errors */
/* eslint-disable no-param-reassign */ /* eslint-disable no-param-reassign */
import { createUnzip } from "node:zlib"; import { createUnzip, constants as zlibConstants } from "node:zlib";
import { http, https } from "follow-redirects"; import { http, https } from "follow-redirects";
@ -34,7 +34,11 @@ function handleRequest(requestor, url, params) {
let responseContent = response; let responseContent = response;
if (contentEncoding === 'gzip' || contentEncoding === 'deflate') { if (contentEncoding === 'gzip' || contentEncoding === 'deflate') {
responseContent = createUnzip(); responseContent = createUnzip({
flush: zlibConstants.Z_SYNC_FLUSH,
finishFlush: zlibConstants.Z_SYNC_FLUSH
});
// zlib errors // zlib errors
responseContent.on("error", (e) => { responseContent.on("error", (e) => {
logger.error(e); logger.error(e);
@ -103,6 +107,6 @@ export async function httpProxy(url, params = {}) {
constructedUrl.pathname constructedUrl.pathname
); );
logger.error(err); logger.error(err);
return [500, "application/json", { error: {message: err?.message ?? "Unknown error", url, rawError: err} }, null]; return [500, "application/json", { error: { message: err?.message ?? "Unknown error", url, rawError: err } }, null];
} }
} }

Loading…
Cancel
Save