@loaders.gl/polyfills 3.1.0-alpha.2 → 3.1.0-beta.1
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 +3992 -5
- package/dist/es5/bundle.js +7 -0
- package/dist/es5/bundle.js.map +1 -0
- package/dist/es5/index.js +120 -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 +1459 -0
- package/dist/es5/lib/encoding.js.map +1 -0
- package/dist/{libs/encoding-indexes.js → es5/libs/encoding-indexes-asian.js} +2 -40
- package/dist/es5/node/buffer/btoa.node.js +16 -0
- package/dist/es5/node/buffer/btoa.node.js.map +1 -0
- package/dist/es5/node/buffer/to-array-buffer.node.js +16 -0
- package/dist/es5/node/buffer/to-array-buffer.node.js.map +1 -0
- package/dist/es5/node/fetch/fetch.node.js +141 -0
- package/dist/es5/node/fetch/fetch.node.js.map +1 -0
- package/dist/es5/node/fetch/headers.node.js +136 -0
- package/dist/{node → es5/node}/fetch/headers.node.js.map +1 -1
- package/dist/es5/node/fetch/response.node.js +96 -0
- package/dist/es5/node/fetch/response.node.js.map +1 -0
- package/dist/es5/node/fetch/utils/decode-data-uri.node.js +66 -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 +107 -0
- package/dist/es5/node/fetch/utils/stream-utils.node.js.map +1 -0
- package/dist/es5/node/file/blob-stream-controller.js +65 -0
- package/dist/es5/node/file/blob-stream-controller.js.map +1 -0
- package/dist/es5/node/file/blob-stream.js +38 -0
- package/dist/es5/node/file/blob-stream.js.map +1 -0
- package/dist/es5/node/file/blob.js +150 -0
- package/dist/es5/node/file/blob.js.map +1 -0
- package/dist/es5/node/file/file-reader.js +82 -0
- package/dist/es5/node/file/file-reader.js.map +1 -0
- package/dist/es5/node/file/file.js +35 -0
- package/dist/es5/node/file/file.js.map +1 -0
- package/dist/es5/node/file/install-file-polyfills.js +33 -0
- package/dist/es5/node/file/install-file-polyfills.js.map +1 -0
- package/dist/es5/node/file/readable-stream.js +15 -0
- package/dist/es5/node/file/readable-stream.js.map +1 -0
- package/dist/es5/node/images/encode-image.node.js +34 -0
- package/dist/es5/node/images/encode-image.node.js.map +1 -0
- package/dist/es5/node/images/parse-image.node.js +34 -0
- package/dist/es5/node/images/parse-image.node.js.map +1 -0
- package/dist/es5/promise/all-settled.js +29 -0
- package/dist/es5/promise/all-settled.js.map +1 -0
- package/dist/es5/utils/assert.js +13 -0
- package/dist/es5/utils/assert.js.map +1 -0
- package/dist/es5/utils/globals.js +16 -0
- package/dist/es5/utils/globals.js.map +1 -0
- package/dist/esm/bundle.js +5 -0
- package/dist/esm/bundle.js.map +1 -0
- package/dist/esm/index.js +63 -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 +1450 -0
- package/dist/esm/lib/encoding.js.map +1 -0
- package/{src/libs/encoding-indexes.js → dist/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 +9 -0
- package/dist/esm/node/buffer/to-array-buffer.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 +125 -0
- package/dist/esm/node/fetch/headers.node.js.map +1 -0
- package/dist/esm/node/fetch/response.node.js +88 -0
- package/dist/esm/node/fetch/response.node.js.map +1 -0
- package/dist/esm/node/fetch/utils/decode-data-uri.node.js +57 -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 +89 -0
- package/dist/esm/node/fetch/utils/stream-utils.node.js.map +1 -0
- package/dist/esm/node/file/blob-stream-controller.js +56 -0
- package/dist/esm/node/file/blob-stream-controller.js.map +1 -0
- package/dist/esm/node/file/blob-stream.js +26 -0
- package/dist/esm/node/file/blob-stream.js.map +1 -0
- package/dist/esm/node/file/blob.js +140 -0
- package/dist/esm/node/file/blob.js.map +1 -0
- package/dist/esm/node/file/file-reader.js +84 -0
- package/dist/esm/node/file/file-reader.js.map +1 -0
- package/dist/esm/node/file/file.js +26 -0
- package/dist/esm/node/file/file.js.map +1 -0
- package/dist/esm/node/file/install-file-polyfills.js +22 -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 +20 -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 +6 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +84 -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.node.d.ts +7 -0
- package/dist/node/fetch/fetch.node.d.ts.map +1 -0
- package/dist/node/fetch/fetch.node.js +104 -102
- 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 +94 -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 +73 -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 +61 -55
- package/dist/node/fetch/utils/stream-utils.node.d.ts +4 -0
- package/dist/node/fetch/utils/stream-utils.node.d.ts.map +1 -0
- package/dist/node/fetch/utils/stream-utils.node.js +88 -79
- 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 +11 -0
- package/dist/node/images/parse-image.node.d.ts.map +1 -0
- package/dist/node/images/parse-image.node.js +28 -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 +8 -8
- package/src/bundle.ts +2 -3
- package/src/index.ts +2 -2
- package/src/lib/encoding-indexes.ts +34 -0
- package/{dist/libs/encoding.js → src/lib/encoding.ts} +78 -78
- package/src/libs/encoding-indexes-asian.js +13 -0
- package/src/node/fetch/fetch.node.ts +19 -2
- package/src/node/images/parse-image.node.ts +12 -2
- package/dist/bundle.js.map +0 -1
- package/dist/dist.min.js +0 -2
- package/dist/dist.min.js.map +0 -1
- package/dist/index.js.map +0 -1
- 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/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
- package/src/libs/encoding.js +0 -3084
|
@@ -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.node.d.ts","sourceRoot":"","sources":["../../../src/node/fetch/fetch.node.ts"],"names":[],"mappings":"AAUA;;;;GAIG;AACH,wBAA8B,SAAS,CAAC,GAAG,KAAA,EAAE,OAAO,KAAA,OAwCnD"}
|
|
@@ -1,115 +1,117 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
const
|
|
8
|
-
|
|
9
|
-
const
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
url
|
|
23
|
-
|
|
24
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const fs_1 = __importDefault(require("fs")); // `fs` will be empty object in browsers (see package.json "browser" field).
|
|
7
|
+
const response_node_1 = __importDefault(require("./response.node"));
|
|
8
|
+
const headers_node_1 = __importDefault(require("./headers.node"));
|
|
9
|
+
const decode_data_uri_node_1 = require("./utils/decode-data-uri.node");
|
|
10
|
+
const stream_utils_node_1 = require("./utils/stream-utils.node");
|
|
11
|
+
const isDataURL = (url) => url.startsWith('data:');
|
|
12
|
+
const isRequestURL = (url) => url.startsWith('http:') || url.startsWith('https:');
|
|
13
|
+
/**
|
|
14
|
+
* Emulation of Browser fetch for Node.js
|
|
15
|
+
* @param url
|
|
16
|
+
* @param options
|
|
17
|
+
*/
|
|
18
|
+
async function fetchNode(url, options) {
|
|
19
|
+
try {
|
|
20
|
+
// Handle data urls in node, to match `fetch``
|
|
21
|
+
// Note - this loses the MIME type, data URIs are handled directly in fetch
|
|
22
|
+
if (isDataURL(url)) {
|
|
23
|
+
const { arrayBuffer, mimeType } = (0, decode_data_uri_node_1.decodeDataUri)(url);
|
|
24
|
+
const response = new response_node_1.default(arrayBuffer, {
|
|
25
|
+
headers: { 'content-type': mimeType },
|
|
26
|
+
url
|
|
27
|
+
});
|
|
28
|
+
return response;
|
|
29
|
+
}
|
|
30
|
+
// Automatically decompress gzipped files with .gz extension
|
|
31
|
+
const syntheticResponseHeaders = {};
|
|
32
|
+
const originalUrl = url;
|
|
33
|
+
if (url.endsWith('.gz')) {
|
|
34
|
+
url = url.slice(0, -3);
|
|
35
|
+
syntheticResponseHeaders['content-encoding'] = 'gzip';
|
|
36
|
+
}
|
|
37
|
+
// Need to create the stream in advance since Response constructor needs to be sync
|
|
38
|
+
const body = await (0, stream_utils_node_1.createReadStream)(originalUrl, options);
|
|
39
|
+
const headers = getHeaders(url, body, syntheticResponseHeaders);
|
|
40
|
+
const { status, statusText } = getStatus(body);
|
|
41
|
+
const followRedirect = !options || options.followRedirect || options.followRedirect === undefined;
|
|
42
|
+
if (status >= 300 && status < 400 && headers.has('location') && followRedirect) {
|
|
43
|
+
const redirectUrl = generateRedirectUrl(url, headers.get('location'));
|
|
44
|
+
// Redirect
|
|
45
|
+
return await fetchNode(redirectUrl, options);
|
|
46
|
+
}
|
|
47
|
+
return new response_node_1.default(body, { headers, status, statusText, url });
|
|
25
48
|
}
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
if (url.endsWith('.gz')) {
|
|
31
|
-
url = url.slice(0, -3);
|
|
32
|
-
syntheticResponseHeaders['content-encoding'] = 'gzip';
|
|
49
|
+
catch (error) {
|
|
50
|
+
// TODO - what error code to use here?
|
|
51
|
+
return new response_node_1.default(null, { status: 400, statusText: String(error), url });
|
|
33
52
|
}
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
return await fetchNode(headers.get('location'), options);
|
|
53
|
+
}
|
|
54
|
+
exports.default = fetchNode;
|
|
55
|
+
/**
|
|
56
|
+
* Generate redirect url from location without origin and protocol.
|
|
57
|
+
* @param originalUrl
|
|
58
|
+
* @param redirectUrl
|
|
59
|
+
*/
|
|
60
|
+
function generateRedirectUrl(originalUrl, location) {
|
|
61
|
+
if (location.startsWith('http')) {
|
|
62
|
+
return location;
|
|
45
63
|
}
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
statusText,
|
|
51
|
-
url
|
|
52
|
-
});
|
|
53
|
-
} catch (error) {
|
|
54
|
-
return new Response(null, {
|
|
55
|
-
status: 400,
|
|
56
|
-
statusText: String(error),
|
|
57
|
-
url
|
|
58
|
-
});
|
|
59
|
-
}
|
|
64
|
+
// If url doesn't have origin and protocol just extend current url origin with location.
|
|
65
|
+
const url = new URL(originalUrl);
|
|
66
|
+
url.pathname = location;
|
|
67
|
+
return url.href;
|
|
60
68
|
}
|
|
61
|
-
|
|
69
|
+
// HELPER FUNCTIONS
|
|
70
|
+
// PRIVATE
|
|
62
71
|
function getStatus(httpResponse) {
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
};
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
return {
|
|
71
|
-
status: 200,
|
|
72
|
-
statusText: 'OK'
|
|
73
|
-
};
|
|
72
|
+
if (httpResponse.statusCode) {
|
|
73
|
+
return { status: httpResponse.statusCode, statusText: httpResponse.statusMessage || 'NA' };
|
|
74
|
+
}
|
|
75
|
+
return { status: 200, statusText: 'OK' };
|
|
74
76
|
}
|
|
75
|
-
|
|
76
77
|
function getHeaders(url, httpResponse, additionalHeaders = {}) {
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
headers[key.toLowerCase()] = String(header);
|
|
78
|
+
const headers = {};
|
|
79
|
+
if (httpResponse && httpResponse.headers) {
|
|
80
|
+
const httpHeaders = httpResponse.headers;
|
|
81
|
+
for (const key in httpHeaders) {
|
|
82
|
+
const header = httpHeaders[key];
|
|
83
|
+
headers[key.toLowerCase()] = String(header);
|
|
84
|
+
}
|
|
85
85
|
}
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
headers['content-length'] = contentLength;
|
|
86
|
+
// Fix up content length if we can for best progress experience
|
|
87
|
+
if (!headers['content-length']) {
|
|
88
|
+
const contentLength = getContentLength(url);
|
|
89
|
+
if (Number.isFinite(contentLength)) {
|
|
90
|
+
headers['content-length'] = contentLength;
|
|
91
|
+
}
|
|
93
92
|
}
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
Object.assign(headers, additionalHeaders);
|
|
97
|
-
return new Headers(headers);
|
|
93
|
+
Object.assign(headers, additionalHeaders);
|
|
94
|
+
return new headers_node_1.default(headers);
|
|
98
95
|
}
|
|
99
|
-
|
|
100
96
|
function getContentLength(url) {
|
|
101
|
-
|
|
97
|
+
if (isRequestURL(url)) {
|
|
98
|
+
// Needs to be read from actual headers
|
|
99
|
+
return null;
|
|
100
|
+
}
|
|
101
|
+
else if (isDataURL(url)) {
|
|
102
|
+
// TODO - remove media type etc
|
|
103
|
+
return url.length - 'data:'.length;
|
|
104
|
+
}
|
|
105
|
+
// File URL
|
|
106
|
+
// TODO - how to handle non-existing file, this presumably just throws
|
|
107
|
+
try {
|
|
108
|
+
// strip query params from URL
|
|
109
|
+
const noqueryUrl = url.split('?')[0];
|
|
110
|
+
const stats = fs_1.default.statSync(noqueryUrl);
|
|
111
|
+
return stats.size;
|
|
112
|
+
}
|
|
113
|
+
catch (error) {
|
|
114
|
+
// ignore for now
|
|
115
|
+
}
|
|
102
116
|
return null;
|
|
103
|
-
} else if (isDataURL(url)) {
|
|
104
|
-
return url.length - 'data:'.length;
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
try {
|
|
108
|
-
const noqueryUrl = url.split('?')[0];
|
|
109
|
-
const stats = fs.statSync(noqueryUrl);
|
|
110
|
-
return stats.size;
|
|
111
|
-
} catch (error) {}
|
|
112
|
-
|
|
113
|
-
return null;
|
|
114
117
|
}
|
|
115
|
-
//# 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 default 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,MAAM,CAAC,OAAO,OAAO,OAAO;IAC1B,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,105 @@
|
|
|
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
|
+
/**
|
|
4
|
+
* Polyfill for Browser Headers
|
|
5
|
+
* Based on https://github.com/github/fetch under MIT license
|
|
6
|
+
*/
|
|
7
|
+
class Headers {
|
|
8
|
+
constructor(headers) {
|
|
9
|
+
this.map = {};
|
|
10
|
+
if (headers instanceof Headers) {
|
|
11
|
+
headers.forEach((value, name) => this.append(name, value));
|
|
12
|
+
}
|
|
13
|
+
else if (Array.isArray(headers)) {
|
|
14
|
+
headers.forEach((header) => this.append(header[0], header[1]));
|
|
15
|
+
}
|
|
16
|
+
else if (headers) {
|
|
17
|
+
Object.getOwnPropertyNames(headers).forEach((name) => this.append(name, headers[name]));
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
append(name, value) {
|
|
21
|
+
name = normalizeName(name);
|
|
22
|
+
value = normalizeValue(value);
|
|
23
|
+
const oldValue = this.map[name];
|
|
24
|
+
this.map[name] = oldValue ? `${oldValue}, ${value}` : value;
|
|
25
|
+
}
|
|
26
|
+
delete(name) {
|
|
27
|
+
delete this.map[normalizeName(name)];
|
|
18
28
|
}
|
|
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);
|
|
29
|
+
get(name) {
|
|
30
|
+
name = normalizeName(name);
|
|
31
|
+
return this.has(name) ? this.map[name] : null;
|
|
32
|
+
}
|
|
33
|
+
has(name) {
|
|
34
|
+
return this.map.hasOwnProperty(normalizeName(name));
|
|
35
|
+
}
|
|
36
|
+
set(name, value) {
|
|
37
|
+
this.map[normalizeName(name)] = normalizeValue(value);
|
|
38
|
+
}
|
|
39
|
+
forEach(visitor, thisArg = null) {
|
|
40
|
+
for (const name in this.map) {
|
|
41
|
+
if (this.map.hasOwnProperty(name)) {
|
|
42
|
+
if (thisArg) {
|
|
43
|
+
visitor.call(thisArg, this.map[name], name, this);
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
visitor(this.map[name], name, this);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
52
49
|
}
|
|
53
|
-
}
|
|
54
50
|
}
|
|
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
|
-
|
|
51
|
+
keys() {
|
|
52
|
+
const items = [];
|
|
53
|
+
this.forEach(function (value, name) {
|
|
54
|
+
items.push(name);
|
|
55
|
+
});
|
|
56
|
+
return iteratorFor(items);
|
|
57
|
+
}
|
|
58
|
+
values() {
|
|
59
|
+
const items = [];
|
|
60
|
+
this.forEach(function (value) {
|
|
61
|
+
items.push(value);
|
|
62
|
+
});
|
|
63
|
+
return iteratorFor(items);
|
|
64
|
+
}
|
|
65
|
+
entries() {
|
|
66
|
+
const items = [];
|
|
67
|
+
this.forEach(function (value, name) {
|
|
68
|
+
items.push([name, value]);
|
|
69
|
+
});
|
|
70
|
+
return iteratorFor(items);
|
|
71
|
+
}
|
|
72
|
+
*[Symbol.iterator]() {
|
|
73
|
+
// @ts-ignore must have a '[Symbol.iterator]()' method that returns an iterator.
|
|
74
|
+
yield* this.entries();
|
|
75
|
+
}
|
|
85
76
|
}
|
|
86
|
-
|
|
77
|
+
exports.default = Headers;
|
|
87
78
|
function normalizeName(name) {
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
return name.toLowerCase();
|
|
79
|
+
if (typeof name !== 'string') {
|
|
80
|
+
name = String(name);
|
|
81
|
+
}
|
|
82
|
+
if (/[^a-z0-9\-#$%&'*+.^_`|~]/i.test(name) || name === '') {
|
|
83
|
+
throw new TypeError('Invalid character in header field name');
|
|
84
|
+
}
|
|
85
|
+
return name.toLowerCase();
|
|
97
86
|
}
|
|
98
|
-
|
|
99
87
|
function normalizeValue(value) {
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
return value;
|
|
88
|
+
if (typeof value !== 'string') {
|
|
89
|
+
value = String(value);
|
|
90
|
+
}
|
|
91
|
+
return value;
|
|
105
92
|
}
|
|
106
|
-
|
|
93
|
+
// Build a destructive iterator for the value list
|
|
107
94
|
function iteratorFor(items) {
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
};
|
|
118
|
-
|
|
119
|
-
iterator[Symbol.iterator] = function () {
|
|
95
|
+
const iterator = {
|
|
96
|
+
next() {
|
|
97
|
+
const value = items.shift();
|
|
98
|
+
return { done: value === undefined, value };
|
|
99
|
+
}
|
|
100
|
+
};
|
|
101
|
+
iterator[Symbol.iterator] = function () {
|
|
102
|
+
return iterator;
|
|
103
|
+
};
|
|
120
104
|
return iterator;
|
|
121
|
-
};
|
|
122
|
-
|
|
123
|
-
return iterator;
|
|
124
105
|
}
|
|
125
|
-
//# sourceMappingURL=headers.node.js.map
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import Headers from './headers.node';
|
|
2
|
+
export default class Response {
|
|
3
|
+
readonly ok: boolean;
|
|
4
|
+
readonly status: number;
|
|
5
|
+
readonly statusText: string;
|
|
6
|
+
readonly headers: Headers;
|
|
7
|
+
readonly url: string;
|
|
8
|
+
bodyUsed: boolean;
|
|
9
|
+
private readonly _body;
|
|
10
|
+
constructor(body: any, options: {
|
|
11
|
+
headers?: any;
|
|
12
|
+
status?: number;
|
|
13
|
+
statusText?: string;
|
|
14
|
+
url: string;
|
|
15
|
+
});
|
|
16
|
+
get body(): any;
|
|
17
|
+
arrayBuffer(): Promise<any>;
|
|
18
|
+
text(): Promise<string>;
|
|
19
|
+
json(): Promise<any>;
|
|
20
|
+
blob(): Promise<Blob>;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=response.node.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"response.node.d.ts","sourceRoot":"","sources":["../../../src/node/fetch/response.node.ts"],"names":[],"mappings":"AAEA,OAAO,OAAO,MAAM,gBAAgB,CAAC;AAoBrC,MAAM,CAAC,OAAO,OAAO,QAAQ;IAC3B,QAAQ,CAAC,EAAE,EAAE,OAAO,CAAC;IACrB,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1B,QAAQ,CAAC,GAAG,EAAE,MAAM,CAAC;IACrB,QAAQ,EAAE,OAAO,CAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC;gBAIrB,IAAI,KAAA,EACJ,OAAO,EAAE;QACP,OAAO,CAAC,MAAC;QACT,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,GAAG,EAAE,MAAM,CAAC;KACb;IAuBH,IAAI,IAAI,QAKP;IAIK,WAAW;IAQX,IAAI;IAMJ,IAAI;IAKJ,IAAI;CAMX"}
|