mirror of
https://github.com/mozilla/pdf.js.git
synced 2025-04-19 22:58:07 +02:00
Merge pull request #18682 from Snuffleupagus/responseHeaders
Use response-`Headers` in the different `IPDFStream` implementations
This commit is contained in:
commit
c159cb1335
5 changed files with 158 additions and 206 deletions
|
@ -127,11 +127,11 @@ class PDFFetchStreamReader {
|
|||
this._reader = response.body.getReader();
|
||||
this._headersCapability.resolve();
|
||||
|
||||
const getResponseHeader = name => response.headers.get(name);
|
||||
const responseHeaders = response.headers;
|
||||
|
||||
const { allowRangeRequests, suggestedLength } =
|
||||
validateRangeRequestCapabilities({
|
||||
getResponseHeader,
|
||||
responseHeaders,
|
||||
isHttp: stream.isHttp,
|
||||
rangeChunkSize: this._rangeChunkSize,
|
||||
disableRange: this._disableRange,
|
||||
|
@ -141,7 +141,7 @@ class PDFFetchStreamReader {
|
|||
// Setting right content length.
|
||||
this._contentLength = suggestedLength || this._contentLength;
|
||||
|
||||
this._filename = extractFilenameFromHeader(getResponseHeader);
|
||||
this._filename = extractFilenameFromHeader(responseHeaders);
|
||||
|
||||
// We need to stop reading when range is supported and streaming is
|
||||
// disabled.
|
||||
|
|
|
@ -249,7 +249,7 @@ class PDFNetworkStreamFullRequestReader {
|
|||
};
|
||||
this._url = source.url;
|
||||
this._fullRequestId = manager.requestFull(args);
|
||||
this._headersReceivedCapability = Promise.withResolvers();
|
||||
this._headersCapability = Promise.withResolvers();
|
||||
this._disableRange = source.disableRange || false;
|
||||
this._contentLength = source.length; // Optional
|
||||
this._rangeChunkSize = source.rangeChunkSize;
|
||||
|
@ -273,11 +273,20 @@ class PDFNetworkStreamFullRequestReader {
|
|||
const fullRequestXhrId = this._fullRequestId;
|
||||
const fullRequestXhr = this._manager.getRequestXhr(fullRequestXhrId);
|
||||
|
||||
const getResponseHeader = name => fullRequestXhr.getResponseHeader(name);
|
||||
const responseHeaders = new Headers(
|
||||
fullRequestXhr
|
||||
.getAllResponseHeaders()
|
||||
.trim()
|
||||
.split(/[\r\n]+/)
|
||||
.map(x => {
|
||||
const [key, ...val] = x.split(": ");
|
||||
return [key, val.join(": ")];
|
||||
})
|
||||
);
|
||||
|
||||
const { allowRangeRequests, suggestedLength } =
|
||||
validateRangeRequestCapabilities({
|
||||
getResponseHeader,
|
||||
responseHeaders,
|
||||
isHttp: this._manager.isHttp,
|
||||
rangeChunkSize: this._rangeChunkSize,
|
||||
disableRange: this._disableRange,
|
||||
|
@ -289,7 +298,7 @@ class PDFNetworkStreamFullRequestReader {
|
|||
// Setting right content length.
|
||||
this._contentLength = suggestedLength || this._contentLength;
|
||||
|
||||
this._filename = extractFilenameFromHeader(getResponseHeader);
|
||||
this._filename = extractFilenameFromHeader(responseHeaders);
|
||||
|
||||
if (this._isRangeSupported) {
|
||||
// NOTE: by cancelling the full request, and then issuing range
|
||||
|
@ -299,7 +308,7 @@ class PDFNetworkStreamFullRequestReader {
|
|||
this._manager.abortRequest(fullRequestXhrId);
|
||||
}
|
||||
|
||||
this._headersReceivedCapability.resolve();
|
||||
this._headersCapability.resolve();
|
||||
}
|
||||
|
||||
_onDone(data) {
|
||||
|
@ -323,7 +332,7 @@ class PDFNetworkStreamFullRequestReader {
|
|||
|
||||
_onError(status) {
|
||||
this._storedError = createResponseStatusError(status, this._url);
|
||||
this._headersReceivedCapability.reject(this._storedError);
|
||||
this._headersCapability.reject(this._storedError);
|
||||
for (const requestCapability of this._requests) {
|
||||
requestCapability.reject(this._storedError);
|
||||
}
|
||||
|
@ -355,7 +364,7 @@ class PDFNetworkStreamFullRequestReader {
|
|||
}
|
||||
|
||||
get headersReady() {
|
||||
return this._headersReceivedCapability.promise;
|
||||
return this._headersCapability.promise;
|
||||
}
|
||||
|
||||
async read() {
|
||||
|
@ -376,7 +385,7 @@ class PDFNetworkStreamFullRequestReader {
|
|||
|
||||
cancel(reason) {
|
||||
this._done = true;
|
||||
this._headersReceivedCapability.reject(reason);
|
||||
this._headersCapability.reject(reason);
|
||||
for (const requestCapability of this._requests) {
|
||||
requestCapability.resolve({ value: undefined, done: true });
|
||||
}
|
||||
|
|
|
@ -37,7 +37,7 @@ function createHeaders(isHttp, httpHeaders) {
|
|||
}
|
||||
|
||||
function validateRangeRequestCapabilities({
|
||||
getResponseHeader,
|
||||
responseHeaders,
|
||||
isHttp,
|
||||
rangeChunkSize,
|
||||
disableRange,
|
||||
|
@ -53,7 +53,7 @@ function validateRangeRequestCapabilities({
|
|||
suggestedLength: undefined,
|
||||
};
|
||||
|
||||
const length = parseInt(getResponseHeader("Content-Length"), 10);
|
||||
const length = parseInt(responseHeaders.get("Content-Length"), 10);
|
||||
if (!Number.isInteger(length)) {
|
||||
return returnValues;
|
||||
}
|
||||
|
@ -69,11 +69,11 @@ function validateRangeRequestCapabilities({
|
|||
if (disableRange || !isHttp) {
|
||||
return returnValues;
|
||||
}
|
||||
if (getResponseHeader("Accept-Ranges") !== "bytes") {
|
||||
if (responseHeaders.get("Accept-Ranges") !== "bytes") {
|
||||
return returnValues;
|
||||
}
|
||||
|
||||
const contentEncoding = getResponseHeader("Content-Encoding") || "identity";
|
||||
const contentEncoding = responseHeaders.get("Content-Encoding") || "identity";
|
||||
if (contentEncoding !== "identity") {
|
||||
return returnValues;
|
||||
}
|
||||
|
@ -82,8 +82,8 @@ function validateRangeRequestCapabilities({
|
|||
return returnValues;
|
||||
}
|
||||
|
||||
function extractFilenameFromHeader(getResponseHeader) {
|
||||
const contentDisposition = getResponseHeader("Content-Disposition");
|
||||
function extractFilenameFromHeader(responseHeaders) {
|
||||
const contentDisposition = responseHeaders.get("Content-Disposition");
|
||||
if (contentDisposition) {
|
||||
let filename = getFilenameFromContentDispositionHeader(contentDisposition);
|
||||
if (filename.includes("%")) {
|
||||
|
|
|
@ -305,14 +305,11 @@ class PDFNodeStreamFullReader extends BaseFullReader {
|
|||
this._headersCapability.resolve();
|
||||
this._setReadableStream(response);
|
||||
|
||||
// Make sure that headers name are in lower case, as mentioned
|
||||
// here: https://nodejs.org/api/http.html#http_message_headers.
|
||||
const getResponseHeader = name =>
|
||||
this._readableStream.headers[name.toLowerCase()];
|
||||
const responseHeaders = new Headers(this._readableStream.headers);
|
||||
|
||||
const { allowRangeRequests, suggestedLength } =
|
||||
validateRangeRequestCapabilities({
|
||||
getResponseHeader,
|
||||
responseHeaders,
|
||||
isHttp: stream.isHttp,
|
||||
rangeChunkSize: this._rangeChunkSize,
|
||||
disableRange: this._disableRange,
|
||||
|
@ -322,7 +319,7 @@ class PDFNodeStreamFullReader extends BaseFullReader {
|
|||
// Setting right content length.
|
||||
this._contentLength = suggestedLength || this._contentLength;
|
||||
|
||||
this._filename = extractFilenameFromHeader(getResponseHeader);
|
||||
this._filename = extractFilenameFromHeader(responseHeaders);
|
||||
};
|
||||
|
||||
this._request = createRequest(this._url, headers, handleResponse);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue