@loaders.gl/polyfills 4.0.0-alpha.4 → 4.0.0-alpha.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/bundle.d.ts +2 -0
- package/dist/bundle.d.ts.map +1 -0
- package/dist/bundle.js +2 -2
- package/dist/dist.min.js +4207 -0
- package/dist/es5/bundle.js +6 -0
- package/dist/es5/bundle.js.map +1 -0
- package/dist/es5/index.js +103 -0
- package/dist/es5/index.js.map +1 -0
- package/dist/es5/lib/encoding-indexes.js +37 -0
- package/dist/es5/lib/encoding-indexes.js.map +1 -0
- package/dist/es5/lib/encoding.js +1214 -0
- package/dist/es5/lib/encoding.js.map +1 -0
- package/{src/libs/encoding-indexes.js → dist/es5/libs/encoding-indexes-asian.js} +2 -40
- package/dist/es5/node/buffer/btoa.node.js +14 -0
- package/dist/es5/node/buffer/btoa.node.js.map +1 -0
- package/dist/es5/node/buffer/to-array-buffer.node.js +14 -0
- package/dist/es5/node/buffer/to-array-buffer.node.js.map +1 -0
- package/dist/es5/node/fetch/fetch-file.node.js +83 -0
- package/dist/es5/node/fetch/fetch-file.node.js.map +1 -0
- package/dist/es5/node/fetch/fetch.node.js +194 -0
- package/dist/es5/node/fetch/fetch.node.js.map +1 -0
- package/dist/es5/node/fetch/headers.node.js +151 -0
- package/dist/es5/node/fetch/headers.node.js.map +1 -0
- package/dist/es5/node/fetch/response.node.js +182 -0
- package/dist/es5/node/fetch/response.node.js.map +1 -0
- package/dist/es5/node/fetch/utils/decode-data-uri.node.js +58 -0
- package/dist/es5/node/fetch/utils/decode-data-uri.node.js.map +1 -0
- package/dist/es5/node/fetch/utils/stream-utils.node.js +92 -0
- package/dist/es5/node/fetch/utils/stream-utils.node.js.map +1 -0
- package/dist/es5/node/file/blob-stream-controller.js +90 -0
- package/dist/es5/node/file/blob-stream-controller.js.map +1 -0
- package/dist/es5/node/file/blob-stream.js +64 -0
- package/dist/es5/node/file/blob-stream.js.map +1 -0
- package/dist/es5/node/file/blob.js +212 -0
- package/dist/es5/node/file/blob.js.map +1 -0
- package/dist/es5/node/file/file-reader.js +153 -0
- package/dist/es5/node/file/file-reader.js.map +1 -0
- package/dist/es5/node/file/file.js +44 -0
- package/dist/es5/node/file/file.js.map +1 -0
- package/dist/es5/node/file/install-file-polyfills.js +25 -0
- package/dist/es5/node/file/install-file-polyfills.js.map +1 -0
- package/dist/es5/node/file/readable-stream.js +27 -0
- package/dist/es5/node/file/readable-stream.js.map +1 -0
- package/dist/es5/node/images/encode-image.node.js +30 -0
- package/dist/es5/node/images/encode-image.node.js.map +1 -0
- package/dist/es5/node/images/parse-image.node.js +64 -0
- package/dist/es5/node/images/parse-image.node.js.map +1 -0
- package/dist/es5/promise/all-settled.js +28 -0
- package/dist/es5/promise/all-settled.js.map +1 -0
- package/dist/es5/utils/assert.js +12 -0
- package/dist/es5/utils/assert.js.map +1 -0
- package/dist/es5/utils/globals.js +18 -0
- package/dist/es5/utils/globals.js.map +1 -0
- package/dist/esm/bundle.js +4 -0
- package/dist/esm/bundle.js.map +1 -0
- package/dist/esm/index.js +54 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/lib/encoding-indexes.js +30 -0
- package/dist/esm/lib/encoding-indexes.js.map +1 -0
- package/dist/esm/lib/encoding.js +1206 -0
- package/dist/esm/lib/encoding.js.map +1 -0
- package/dist/{libs/encoding-indexes.js → esm/libs/encoding-indexes-asian.js} +2 -40
- package/dist/esm/node/buffer/btoa.node.js +7 -0
- package/dist/esm/node/buffer/btoa.node.js.map +1 -0
- package/dist/esm/node/buffer/to-array-buffer.node.js +8 -0
- package/dist/esm/node/buffer/to-array-buffer.node.js.map +1 -0
- package/dist/esm/node/fetch/fetch-file.node.js +50 -0
- package/dist/esm/node/fetch/fetch-file.node.js.map +1 -0
- package/dist/esm/node/fetch/fetch.node.js +126 -0
- package/dist/esm/node/fetch/fetch.node.js.map +1 -0
- package/dist/esm/node/fetch/headers.node.js +102 -0
- package/dist/esm/node/fetch/headers.node.js.map +1 -0
- package/dist/esm/node/fetch/response.node.js +67 -0
- package/dist/esm/node/fetch/response.node.js.map +1 -0
- package/dist/esm/node/fetch/utils/decode-data-uri.node.js +45 -0
- package/dist/esm/node/fetch/utils/decode-data-uri.node.js.map +1 -0
- package/dist/esm/node/fetch/utils/stream-utils.node.js +43 -0
- package/dist/esm/node/fetch/utils/stream-utils.node.js.map +1 -0
- package/dist/esm/node/file/blob-stream-controller.js +44 -0
- package/dist/esm/node/file/blob-stream-controller.js.map +1 -0
- package/dist/esm/node/file/blob-stream.js +20 -0
- package/dist/esm/node/file/blob-stream.js.map +1 -0
- package/dist/esm/node/file/blob.js +120 -0
- package/dist/esm/node/file/blob.js.map +1 -0
- package/dist/esm/node/file/file-reader.js +60 -0
- package/dist/esm/node/file/file-reader.js.map +1 -0
- package/dist/esm/node/file/file.js +19 -0
- package/dist/esm/node/file/file.js.map +1 -0
- package/dist/esm/node/file/install-file-polyfills.js +19 -0
- package/dist/esm/node/file/install-file-polyfills.js.map +1 -0
- package/dist/esm/node/file/readable-stream.js +4 -0
- package/dist/esm/node/file/readable-stream.js.map +1 -0
- package/dist/esm/node/images/encode-image.node.js +20 -0
- package/dist/esm/node/images/encode-image.node.js.map +1 -0
- package/dist/esm/node/images/parse-image.node.js +29 -0
- package/dist/esm/node/images/parse-image.node.js.map +1 -0
- package/dist/esm/promise/all-settled.js +19 -0
- package/dist/esm/promise/all-settled.js.map +1 -0
- package/dist/esm/utils/assert.js +6 -0
- package/dist/esm/utils/assert.js.map +1 -0
- package/dist/esm/utils/globals.js +9 -0
- package/dist/esm/utils/globals.js.map +1 -0
- package/dist/index.d.ts +8 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +90 -49
- package/dist/lib/encoding-indexes.d.ts +31 -0
- package/dist/lib/encoding-indexes.d.ts.map +1 -0
- package/dist/lib/encoding-indexes.js +35 -0
- package/dist/lib/encoding.d.ts +15 -0
- package/dist/lib/encoding.d.ts.map +1 -0
- package/dist/lib/encoding.js +2779 -0
- package/dist/libs/encoding-indexes-asian.d.ts +10 -0
- package/dist/libs/encoding-indexes-asian.d.ts.map +1 -0
- package/dist/libs/encoding-indexes-asian.js +14 -0
- package/dist/node/buffer/btoa.node.d.ts +3 -0
- package/dist/node/buffer/btoa.node.d.ts.map +1 -0
- package/dist/node/buffer/btoa.node.js +12 -5
- package/dist/node/buffer/to-array-buffer.node.d.ts +2 -0
- package/dist/node/buffer/to-array-buffer.node.d.ts.map +1 -0
- package/dist/node/buffer/to-array-buffer.node.js +11 -8
- package/dist/node/fetch/fetch-file.node.d.ts +4 -0
- package/dist/node/fetch/fetch-file.node.d.ts.map +1 -0
- package/dist/node/fetch/fetch-file.node.js +51 -0
- package/dist/node/fetch/fetch.node.d.ts +12 -0
- package/dist/node/fetch/fetch.node.d.ts.map +1 -0
- package/dist/node/fetch/fetch.node.js +128 -111
- package/dist/node/fetch/headers.node.d.ts +34 -0
- package/dist/node/fetch/headers.node.d.ts.map +1 -0
- package/dist/node/fetch/headers.node.js +95 -114
- package/dist/node/fetch/response.node.d.ts +22 -0
- package/dist/node/fetch/response.node.d.ts.map +1 -0
- package/dist/node/fetch/response.node.js +72 -84
- package/dist/node/fetch/utils/decode-data-uri.node.d.ts +16 -0
- package/dist/node/fetch/utils/decode-data-uri.node.d.ts.map +1 -0
- package/dist/node/fetch/utils/decode-data-uri.node.js +63 -55
- package/dist/node/fetch/utils/stream-utils.node.d.ts +17 -0
- package/dist/node/fetch/utils/stream-utils.node.d.ts.map +1 -0
- package/dist/node/fetch/utils/stream-utils.node.js +69 -85
- package/dist/node/file/blob-stream-controller.d.ts +29 -0
- package/dist/node/file/blob-stream-controller.d.ts.map +1 -0
- package/dist/node/file/blob-stream-controller.js +59 -52
- package/dist/node/file/blob-stream.d.ts +25 -0
- package/dist/node/file/blob-stream.d.ts.map +1 -0
- package/dist/node/file/blob-stream.js +36 -25
- package/dist/node/file/blob.d.ts +58 -0
- package/dist/node/file/blob.d.ts.map +1 -0
- package/dist/node/file/blob.js +151 -131
- package/dist/node/file/file-reader.d.ts +24 -0
- package/dist/node/file/file-reader.d.ts.map +1 -0
- package/dist/node/file/file-reader.js +28 -77
- package/dist/node/file/file.d.ts +25 -0
- package/dist/node/file/file.d.ts.map +1 -0
- package/dist/node/file/file.js +36 -25
- package/dist/node/file/install-file-polyfills.d.ts +2 -0
- package/dist/node/file/install-file-polyfills.d.ts.map +1 -0
- package/dist/node/file/install-file-polyfills.js +26 -21
- package/dist/node/file/readable-stream.d.ts +4 -0
- package/dist/node/file/readable-stream.d.ts.map +1 -0
- package/dist/node/file/readable-stream.js +10 -3
- package/dist/node/images/encode-image.node.d.ts +20 -0
- package/dist/node/images/encode-image.node.d.ts.map +1 -0
- package/dist/node/images/encode-image.node.js +38 -17
- package/dist/node/images/parse-image.node.d.ts +13 -0
- package/dist/node/images/parse-image.node.d.ts.map +1 -0
- package/dist/node/images/parse-image.node.js +40 -19
- package/dist/promise/all-settled.d.ts +10 -0
- package/dist/promise/all-settled.d.ts.map +1 -0
- package/dist/promise/all-settled.js +22 -17
- package/dist/utils/assert.d.ts +2 -0
- package/dist/utils/assert.d.ts.map +1 -0
- package/dist/utils/assert.js +8 -5
- package/dist/utils/globals.d.ts +4 -0
- package/dist/utils/globals.d.ts.map +1 -0
- package/dist/utils/globals.js +34 -7
- package/package.json +9 -8
- package/src/index.ts +9 -6
- package/src/lib/encoding-indexes.ts +34 -0
- package/src/{libs/encoding.js → lib/encoding.ts} +78 -78
- package/src/libs/encoding-indexes-asian.js +13 -0
- package/src/node/fetch/fetch-file.node.ts +51 -0
- package/src/node/fetch/fetch.node.ts +64 -30
- package/src/node/fetch/headers.node.ts +1 -1
- package/src/node/fetch/response.node.ts +4 -2
- package/src/node/fetch/utils/decode-data-uri.node.ts +7 -6
- package/src/node/fetch/utils/stream-utils.node.ts +39 -64
- package/src/node/images/parse-image.node.ts +35 -20
- package/dist/bundle.js.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/libs/encoding.js +0 -3084
- package/dist/node/buffer/btoa.node.js.map +0 -1
- package/dist/node/buffer/to-array-buffer.node.js.map +0 -1
- package/dist/node/fetch/fetch.node.js.map +0 -1
- package/dist/node/fetch/headers.node.js.map +0 -1
- package/dist/node/fetch/response.node.js.map +0 -1
- package/dist/node/fetch/utils/decode-data-uri.node.js.map +0 -1
- package/dist/node/fetch/utils/stream-utils.node.js.map +0 -1
- package/dist/node/file/blob-stream-controller.js.map +0 -1
- package/dist/node/file/blob-stream.js.map +0 -1
- package/dist/node/file/blob.js.map +0 -1
- package/dist/node/file/file-reader.js.map +0 -1
- package/dist/node/file/file.js.map +0 -1
- package/dist/node/file/install-file-polyfills.js.map +0 -1
- package/dist/node/file/readable-stream.js.map +0 -1
- package/dist/node/images/encode-image.node.js.map +0 -1
- package/dist/node/images/parse-image.node.js.map +0 -1
- package/dist/promise/all-settled.js.map +0 -1
- package/dist/utils/assert.js.map +0 -1
- package/dist/utils/globals.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"btoa.node.d.ts","sourceRoot":"","sources":["../../../src/node/buffer/btoa.node.ts"],"names":[],"mappings":"AAIA,wBAAgB,IAAI,CAAC,MAAM,KAAA,UAE1B;AAED,wBAAgB,IAAI,CAAC,MAAM,KAAA,UAE1B"}
|
|
@@ -1,7 +1,14 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
// btoa, atob polyfills for Node.js
|
|
3
|
+
// Note: The atob and btoa functions (not just the polyfills!) are not unicode safe
|
|
4
|
+
// But still useful for unit testing
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.btoa = exports.atob = void 0;
|
|
7
|
+
function atob(string) {
|
|
8
|
+
return Buffer.from(string).toString('base64');
|
|
3
9
|
}
|
|
4
|
-
|
|
5
|
-
|
|
10
|
+
exports.atob = atob;
|
|
11
|
+
function btoa(base64) {
|
|
12
|
+
return Buffer.from(base64, 'base64').toString('ascii');
|
|
6
13
|
}
|
|
7
|
-
|
|
14
|
+
exports.btoa = btoa;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"to-array-buffer.node.d.ts","sourceRoot":"","sources":["../../../src/node/buffer/to-array-buffer.node.ts"],"names":[],"mappings":"AAAA,wBAAgB,mBAAmB,CAAC,MAAM,KAAA,OAOzC"}
|
|
@@ -1,9 +1,12 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.bufferToArrayBuffer = void 0;
|
|
4
|
+
function bufferToArrayBuffer(buffer) {
|
|
5
|
+
// TODO - per docs we should just be able to call buffer.buffer, but there are issues
|
|
6
|
+
if (Buffer.isBuffer(buffer)) {
|
|
7
|
+
const typedArray = new Uint8Array(buffer);
|
|
8
|
+
return typedArray.buffer;
|
|
9
|
+
}
|
|
10
|
+
return buffer;
|
|
8
11
|
}
|
|
9
|
-
|
|
12
|
+
exports.bufferToArrayBuffer = bufferToArrayBuffer;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fetch-file.node.d.ts","sourceRoot":"","sources":["../../../src/node/fetch/fetch-file.node.ts"],"names":[],"mappings":"AAGA,OAAO,EAAC,QAAQ,EAAC,MAAM,iBAAiB,CAAC;AAGzC,wBAAgB,YAAY,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAEjD;AAED,wBAAsB,aAAa,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,KAAA,GAAG,OAAO,CAAC,QAAQ,CAAC,CAsB3E"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// loaders.gl, MIT license
|
|
3
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
4
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
5
|
+
};
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.fetchFileNode = exports.isRequestURL = void 0;
|
|
8
|
+
const fs_1 = __importDefault(require("fs")); // `fs` will be empty object in browsers (see package.json "browser" field).
|
|
9
|
+
const response_node_1 = require("./response.node");
|
|
10
|
+
const headers_node_1 = require("./headers.node");
|
|
11
|
+
function isRequestURL(url) {
|
|
12
|
+
return url.startsWith('http:') || url.startsWith('https:');
|
|
13
|
+
}
|
|
14
|
+
exports.isRequestURL = isRequestURL;
|
|
15
|
+
async function fetchFileNode(url, options) {
|
|
16
|
+
const noqueryUrl = url.split('?')[0];
|
|
17
|
+
try {
|
|
18
|
+
// Now open the stream
|
|
19
|
+
const body = await new Promise((resolve, reject) => {
|
|
20
|
+
// @ts-ignore
|
|
21
|
+
const stream = fs_1.default.createReadStream(noqueryUrl, { encoding: null });
|
|
22
|
+
stream.once('readable', () => resolve(stream));
|
|
23
|
+
stream.on('error', (error) => reject(error));
|
|
24
|
+
});
|
|
25
|
+
const status = 200;
|
|
26
|
+
const statusText = 'OK';
|
|
27
|
+
const headers = getHeadersForFile(noqueryUrl);
|
|
28
|
+
return new response_node_1.Response(body, { headers, status, statusText, url });
|
|
29
|
+
}
|
|
30
|
+
catch (error) {
|
|
31
|
+
const status = 400;
|
|
32
|
+
const statusText = error.message;
|
|
33
|
+
const headers = {};
|
|
34
|
+
return new response_node_1.Response(error.message, { headers, status, statusText, url });
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
exports.fetchFileNode = fetchFileNode;
|
|
38
|
+
function getHeadersForFile(noqueryUrl) {
|
|
39
|
+
const headers = {};
|
|
40
|
+
// Fix up content length if we can for best progress experience
|
|
41
|
+
if (!headers['content-length']) {
|
|
42
|
+
const stats = fs_1.default.statSync(noqueryUrl);
|
|
43
|
+
headers['content-length'] = stats.size;
|
|
44
|
+
}
|
|
45
|
+
// Automatically decompress gzipped files with .gz extension
|
|
46
|
+
if (noqueryUrl.endsWith('.gz')) {
|
|
47
|
+
noqueryUrl = noqueryUrl.slice(0, -3);
|
|
48
|
+
headers['content-encoding'] = 'gzip';
|
|
49
|
+
}
|
|
50
|
+
return new headers_node_1.Headers(headers);
|
|
51
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import http from 'http';
|
|
3
|
+
import { Response } from './response.node';
|
|
4
|
+
/**
|
|
5
|
+
* Emulation of Browser fetch for Node.js
|
|
6
|
+
* @param url
|
|
7
|
+
* @param options
|
|
8
|
+
*/
|
|
9
|
+
export declare function fetchNode(url: string, options: any): Promise<Response>;
|
|
10
|
+
/** Returns a promise that resolves to a readable stream */
|
|
11
|
+
export declare function createHTTPRequestReadStream(url: string, options: any): Promise<http.IncomingMessage>;
|
|
12
|
+
//# sourceMappingURL=fetch.node.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fetch.node.d.ts","sourceRoot":"","sources":["../../../src/node/fetch/fetch.node.ts"],"names":[],"mappings":";AAEA,OAAO,IAAI,MAAM,MAAM,CAAC;AAExB,OAAO,EAAC,QAAQ,EAAC,MAAM,iBAAiB,CAAC;AASzC;;;;GAIG;AAEH,wBAAsB,SAAS,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,KAAA,GAAG,OAAO,CAAC,QAAQ,CAAC,CA6CvE;AAED,2DAA2D;AAC3D,wBAAsB,2BAA2B,CAC/C,GAAG,EAAE,MAAM,EACX,OAAO,KAAA,GACN,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC,CAW/B"}
|
|
@@ -1,126 +1,143 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
const
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
// loaders.gl, MIT license
|
|
3
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
4
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
5
|
+
};
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.createHTTPRequestReadStream = exports.fetchNode = void 0;
|
|
8
|
+
const http_1 = __importDefault(require("http"));
|
|
9
|
+
const https_1 = __importDefault(require("https"));
|
|
10
|
+
const response_node_1 = require("./response.node");
|
|
11
|
+
const headers_node_1 = require("./headers.node");
|
|
12
|
+
const decode_data_uri_node_1 = require("./utils/decode-data-uri.node");
|
|
13
|
+
const fetch_file_node_1 = require("./fetch-file.node");
|
|
14
|
+
const isDataURL = (url) => url.startsWith('data:');
|
|
15
|
+
const isRequestURL = (url) => url.startsWith('http:') || url.startsWith('https:');
|
|
16
|
+
/**
|
|
17
|
+
* Emulation of Browser fetch for Node.js
|
|
18
|
+
* @param url
|
|
19
|
+
* @param options
|
|
20
|
+
*/
|
|
21
|
+
// eslint-disable-next-line complexity
|
|
22
|
+
async function fetchNode(url, options) {
|
|
23
|
+
try {
|
|
24
|
+
// Handle file streams in node
|
|
25
|
+
if (!isRequestURL(url) && !isDataURL(url)) {
|
|
26
|
+
return await (0, fetch_file_node_1.fetchFileNode)(url, options);
|
|
27
|
+
}
|
|
28
|
+
// Handle data urls in node, to match `fetch``
|
|
29
|
+
// Note - this loses the MIME type, data URIs are handled directly in fetch
|
|
30
|
+
if (isDataURL(url)) {
|
|
31
|
+
const { arrayBuffer, mimeType } = (0, decode_data_uri_node_1.decodeDataUri)(url);
|
|
32
|
+
const response = new response_node_1.Response(arrayBuffer, {
|
|
33
|
+
headers: { 'content-type': mimeType },
|
|
34
|
+
url
|
|
35
|
+
});
|
|
36
|
+
return response;
|
|
37
|
+
}
|
|
38
|
+
// Automatically decompress gzipped files with .gz extension
|
|
39
|
+
const syntheticResponseHeaders = {};
|
|
40
|
+
const originalUrl = url;
|
|
41
|
+
if (url.endsWith('.gz')) {
|
|
42
|
+
url = url.slice(0, -3);
|
|
43
|
+
syntheticResponseHeaders['content-encoding'] = 'gzip';
|
|
44
|
+
}
|
|
45
|
+
// Need to create the stream in advance since Response constructor needs to be sync
|
|
46
|
+
const body = await createHTTPRequestReadStream(originalUrl, options);
|
|
47
|
+
const headers = getHeaders(url, body, syntheticResponseHeaders);
|
|
48
|
+
const { status, statusText } = getStatus(body);
|
|
49
|
+
const followRedirect = !options || options.followRedirect || options.followRedirect === undefined;
|
|
50
|
+
if (status >= 300 && status < 400 && headers.has('location') && followRedirect) {
|
|
51
|
+
const redirectUrl = generateRedirectUrl(url, headers.get('location'));
|
|
52
|
+
// Redirect
|
|
53
|
+
return await fetchNode(redirectUrl, options);
|
|
54
|
+
}
|
|
55
|
+
return new response_node_1.Response(body, { headers, status, statusText, url });
|
|
25
56
|
}
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
if (url.endsWith('.gz')) {
|
|
31
|
-
url = url.slice(0, -3);
|
|
32
|
-
syntheticResponseHeaders['content-encoding'] = 'gzip';
|
|
57
|
+
catch (error) {
|
|
58
|
+
// TODO - what error code to use here?
|
|
59
|
+
return new response_node_1.Response(null, { status: 400, statusText: String(error), url });
|
|
33
60
|
}
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
return new Response(body, {
|
|
49
|
-
headers,
|
|
50
|
-
status,
|
|
51
|
-
statusText,
|
|
52
|
-
url
|
|
53
|
-
});
|
|
54
|
-
} catch (error) {
|
|
55
|
-
return new Response(null, {
|
|
56
|
-
status: 400,
|
|
57
|
-
statusText: String(error),
|
|
58
|
-
url
|
|
61
|
+
}
|
|
62
|
+
exports.fetchNode = fetchNode;
|
|
63
|
+
/** Returns a promise that resolves to a readable stream */
|
|
64
|
+
async function createHTTPRequestReadStream(url, options) {
|
|
65
|
+
// HANDLE HTTP/HTTPS REQUESTS IN NODE
|
|
66
|
+
// TODO: THIS IS BAD SINCE WE RETURN A PROMISE INSTEAD OF A STREAM
|
|
67
|
+
return await new Promise((resolve, reject) => {
|
|
68
|
+
const requestOptions = getRequestOptions(url, options);
|
|
69
|
+
const req = url.startsWith('https:')
|
|
70
|
+
? https_1.default.request(requestOptions, (res) => resolve(res))
|
|
71
|
+
: http_1.default.request(requestOptions, (res) => resolve(res));
|
|
72
|
+
req.on('error', (error) => reject(error));
|
|
73
|
+
req.end();
|
|
59
74
|
});
|
|
60
|
-
}
|
|
61
75
|
}
|
|
62
|
-
|
|
76
|
+
exports.createHTTPRequestReadStream = createHTTPRequestReadStream;
|
|
77
|
+
/**
|
|
78
|
+
* Generate redirect url from location without origin and protocol.
|
|
79
|
+
* @param originalUrl
|
|
80
|
+
* @param redirectUrl
|
|
81
|
+
*/
|
|
63
82
|
function generateRedirectUrl(originalUrl, location) {
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
83
|
+
if (location.startsWith('http')) {
|
|
84
|
+
return location;
|
|
85
|
+
}
|
|
86
|
+
// If url doesn't have origin and protocol just extend current url origin with location.
|
|
87
|
+
const url = new URL(originalUrl);
|
|
88
|
+
url.pathname = location;
|
|
89
|
+
return url.href;
|
|
71
90
|
}
|
|
72
|
-
|
|
73
|
-
function
|
|
74
|
-
|
|
91
|
+
// HELPER FUNCTIONS
|
|
92
|
+
function getRequestOptions(url, options) {
|
|
93
|
+
// Ensure header keys are lower case so that we can merge without duplicates
|
|
94
|
+
const originalHeaders = options?.headers || {};
|
|
95
|
+
const headers = {};
|
|
96
|
+
for (const key of Object.keys(originalHeaders)) {
|
|
97
|
+
headers[key.toLowerCase()] = originalHeaders[key];
|
|
98
|
+
}
|
|
99
|
+
// Add default accept-encoding to headers
|
|
100
|
+
headers['accept-encoding'] = headers['accept-encoding'] || 'gzip,br,deflate';
|
|
101
|
+
const urlObject = new URL(url);
|
|
75
102
|
return {
|
|
76
|
-
|
|
77
|
-
|
|
103
|
+
hostname: urlObject.hostname,
|
|
104
|
+
path: urlObject.pathname,
|
|
105
|
+
method: 'GET',
|
|
106
|
+
// Add options and user provided 'options.fetch' overrides if available
|
|
107
|
+
...options,
|
|
108
|
+
...options?.fetch,
|
|
109
|
+
// Override with updated headers with accepted encodings:
|
|
110
|
+
headers,
|
|
111
|
+
port: urlObject.port
|
|
78
112
|
};
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
return {
|
|
82
|
-
status: 200,
|
|
83
|
-
statusText: 'OK'
|
|
84
|
-
};
|
|
85
113
|
}
|
|
86
|
-
|
|
114
|
+
function getStatus(httpResponse) {
|
|
115
|
+
if (httpResponse.statusCode) {
|
|
116
|
+
return { status: httpResponse.statusCode, statusText: httpResponse.statusMessage || 'NA' };
|
|
117
|
+
}
|
|
118
|
+
return { status: 200, statusText: 'OK' };
|
|
119
|
+
}
|
|
87
120
|
function getHeaders(url, httpResponse, additionalHeaders = {}) {
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
headers[key.toLowerCase()] = String(header);
|
|
121
|
+
const headers = {};
|
|
122
|
+
if (httpResponse && httpResponse.headers) {
|
|
123
|
+
const httpHeaders = httpResponse.headers;
|
|
124
|
+
for (const key in httpHeaders) {
|
|
125
|
+
const header = httpHeaders[key];
|
|
126
|
+
headers[key.toLowerCase()] = String(header);
|
|
127
|
+
}
|
|
96
128
|
}
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
headers['content-length'] = contentLength;
|
|
129
|
+
// Fix up content length if we can for best progress experience
|
|
130
|
+
if (!headers['content-length']) {
|
|
131
|
+
const contentLength = getContentLength(url);
|
|
132
|
+
if (Number.isFinite(contentLength)) {
|
|
133
|
+
headers['content-length'] = contentLength;
|
|
134
|
+
}
|
|
104
135
|
}
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
Object.assign(headers, additionalHeaders);
|
|
108
|
-
return new Headers(headers);
|
|
136
|
+
Object.assign(headers, additionalHeaders);
|
|
137
|
+
return new headers_node_1.Headers(headers);
|
|
109
138
|
}
|
|
110
|
-
|
|
139
|
+
/** Needs to be read from actual headers */
|
|
111
140
|
function getContentLength(url) {
|
|
112
|
-
|
|
113
|
-
return null;
|
|
114
|
-
} else if (isDataURL(url)) {
|
|
115
|
-
return url.length - 'data:'.length;
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
try {
|
|
119
|
-
const noqueryUrl = url.split('?')[0];
|
|
120
|
-
const stats = fs.statSync(noqueryUrl);
|
|
121
|
-
return stats.size;
|
|
122
|
-
} catch (error) {}
|
|
123
|
-
|
|
124
|
-
return null;
|
|
141
|
+
// TODO - remove media type etc
|
|
142
|
+
return isDataURL(url) ? url.length - 'data:'.length : null;
|
|
125
143
|
}
|
|
126
|
-
//# sourceMappingURL=fetch.node.js.map
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Polyfill for Browser Headers
|
|
3
|
+
* Based on https://github.com/github/fetch under MIT license
|
|
4
|
+
*/
|
|
5
|
+
export declare class Headers {
|
|
6
|
+
map: {};
|
|
7
|
+
constructor(headers: any);
|
|
8
|
+
append(name: any, value: any): void;
|
|
9
|
+
delete(name: any): void;
|
|
10
|
+
get(name: any): any;
|
|
11
|
+
has(name: any): boolean;
|
|
12
|
+
set(name: any, value: any): void;
|
|
13
|
+
forEach(visitor: any, thisArg?: null): void;
|
|
14
|
+
keys(): {
|
|
15
|
+
next(): {
|
|
16
|
+
done: boolean;
|
|
17
|
+
value: any;
|
|
18
|
+
};
|
|
19
|
+
};
|
|
20
|
+
values(): {
|
|
21
|
+
next(): {
|
|
22
|
+
done: boolean;
|
|
23
|
+
value: any;
|
|
24
|
+
};
|
|
25
|
+
};
|
|
26
|
+
entries(): {
|
|
27
|
+
next(): {
|
|
28
|
+
done: boolean;
|
|
29
|
+
value: any;
|
|
30
|
+
};
|
|
31
|
+
};
|
|
32
|
+
[Symbol.iterator](): Generator<any, void, unknown>;
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=headers.node.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"headers.node.d.ts","sourceRoot":"","sources":["../../../src/node/fetch/headers.node.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,qBAAa,OAAO;IAClB,GAAG,EAAE,EAAE,CAAC;gBAEI,OAAO,KAAA;IAYnB,MAAM,CAAC,IAAI,KAAA,EAAE,KAAK,KAAA;IAOlB,MAAM,CAAC,IAAI,KAAA;IAIX,GAAG,CAAC,IAAI,KAAA;IAKR,GAAG,CAAC,IAAI,KAAA;IAIR,GAAG,CAAC,IAAI,KAAA,EAAE,KAAK,KAAA;IAIf,OAAO,CAAC,OAAO,KAAA,EAAE,OAAO,OAAO;IAY/B,IAAI;;;;;;IAQJ,MAAM;;;;;;IAQN,OAAO;;;;;;IAQN,CAAC,MAAM,CAAC,QAAQ,CAAC;CAInB"}
|
|
@@ -1,125 +1,106 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Headers = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* Polyfill for Browser Headers
|
|
6
|
+
* Based on https://github.com/github/fetch under MIT license
|
|
7
|
+
*/
|
|
8
|
+
class Headers {
|
|
9
|
+
constructor(headers) {
|
|
10
|
+
this.map = {};
|
|
11
|
+
if (headers instanceof Headers) {
|
|
12
|
+
headers.forEach((value, name) => this.append(name, value));
|
|
13
|
+
}
|
|
14
|
+
else if (Array.isArray(headers)) {
|
|
15
|
+
headers.forEach((header) => this.append(header[0], header[1]));
|
|
16
|
+
}
|
|
17
|
+
else if (headers) {
|
|
18
|
+
Object.getOwnPropertyNames(headers).forEach((name) => this.append(name, headers[name]));
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
append(name, value) {
|
|
22
|
+
name = normalizeName(name);
|
|
23
|
+
value = normalizeValue(value);
|
|
24
|
+
const oldValue = this.map[name];
|
|
25
|
+
this.map[name] = oldValue ? `${oldValue}, ${value}` : value;
|
|
26
|
+
}
|
|
27
|
+
delete(name) {
|
|
28
|
+
delete this.map[normalizeName(name)];
|
|
18
29
|
}
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
set(name, value) {
|
|
42
|
-
this.map[normalizeName(name)] = normalizeValue(value);
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
forEach(visitor, thisArg = null) {
|
|
46
|
-
for (const name in this.map) {
|
|
47
|
-
if (this.map.hasOwnProperty(name)) {
|
|
48
|
-
if (thisArg) {
|
|
49
|
-
visitor.call(thisArg, this.map[name], name, this);
|
|
50
|
-
} else {
|
|
51
|
-
visitor(this.map[name], name, this);
|
|
30
|
+
get(name) {
|
|
31
|
+
name = normalizeName(name);
|
|
32
|
+
return this.has(name) ? this.map[name] : null;
|
|
33
|
+
}
|
|
34
|
+
has(name) {
|
|
35
|
+
return this.map.hasOwnProperty(normalizeName(name));
|
|
36
|
+
}
|
|
37
|
+
set(name, value) {
|
|
38
|
+
this.map[normalizeName(name)] = normalizeValue(value);
|
|
39
|
+
}
|
|
40
|
+
forEach(visitor, thisArg = null) {
|
|
41
|
+
for (const name in this.map) {
|
|
42
|
+
if (this.map.hasOwnProperty(name)) {
|
|
43
|
+
if (thisArg) {
|
|
44
|
+
visitor.call(thisArg, this.map[name], name, this);
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
visitor(this.map[name], name, this);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
52
50
|
}
|
|
53
|
-
}
|
|
54
51
|
}
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
*[_Symbol$iterator]() {
|
|
82
|
-
yield* this.entries();
|
|
83
|
-
}
|
|
84
|
-
|
|
52
|
+
keys() {
|
|
53
|
+
const items = [];
|
|
54
|
+
this.forEach(function (value, name) {
|
|
55
|
+
items.push(name);
|
|
56
|
+
});
|
|
57
|
+
return iteratorFor(items);
|
|
58
|
+
}
|
|
59
|
+
values() {
|
|
60
|
+
const items = [];
|
|
61
|
+
this.forEach(function (value) {
|
|
62
|
+
items.push(value);
|
|
63
|
+
});
|
|
64
|
+
return iteratorFor(items);
|
|
65
|
+
}
|
|
66
|
+
entries() {
|
|
67
|
+
const items = [];
|
|
68
|
+
this.forEach(function (value, name) {
|
|
69
|
+
items.push([name, value]);
|
|
70
|
+
});
|
|
71
|
+
return iteratorFor(items);
|
|
72
|
+
}
|
|
73
|
+
*[Symbol.iterator]() {
|
|
74
|
+
// @ts-ignore must have a '[Symbol.iterator]()' method that returns an iterator.
|
|
75
|
+
yield* this.entries();
|
|
76
|
+
}
|
|
85
77
|
}
|
|
86
|
-
|
|
78
|
+
exports.Headers = Headers;
|
|
87
79
|
function normalizeName(name) {
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
return name.toLowerCase();
|
|
80
|
+
if (typeof name !== 'string') {
|
|
81
|
+
name = String(name);
|
|
82
|
+
}
|
|
83
|
+
if (/[^a-z0-9\-#$%&'*+.^_`|~]/i.test(name) || name === '') {
|
|
84
|
+
throw new TypeError('Invalid character in header field name');
|
|
85
|
+
}
|
|
86
|
+
return name.toLowerCase();
|
|
97
87
|
}
|
|
98
|
-
|
|
99
88
|
function normalizeValue(value) {
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
return value;
|
|
89
|
+
if (typeof value !== 'string') {
|
|
90
|
+
value = String(value);
|
|
91
|
+
}
|
|
92
|
+
return value;
|
|
105
93
|
}
|
|
106
|
-
|
|
94
|
+
// Build a destructive iterator for the value list
|
|
107
95
|
function iteratorFor(items) {
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
};
|
|
118
|
-
|
|
119
|
-
iterator[Symbol.iterator] = function () {
|
|
96
|
+
const iterator = {
|
|
97
|
+
next() {
|
|
98
|
+
const value = items.shift();
|
|
99
|
+
return { done: value === undefined, value };
|
|
100
|
+
}
|
|
101
|
+
};
|
|
102
|
+
iterator[Symbol.iterator] = function () {
|
|
103
|
+
return iterator;
|
|
104
|
+
};
|
|
120
105
|
return iterator;
|
|
121
|
-
};
|
|
122
|
-
|
|
123
|
-
return iterator;
|
|
124
106
|
}
|
|
125
|
-
//# sourceMappingURL=headers.node.js.map
|