@loaders.gl/polyfills 3.4.14 → 3.4.15

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.
Files changed (41) hide show
  1. package/dist/es5/bundle.js +1 -1
  2. package/dist/es5/bundle.js.map +1 -1
  3. package/dist/es5/index.js +11 -12
  4. package/dist/es5/index.js.map +1 -1
  5. package/dist/es5/lib/encoding.js +12 -13
  6. package/dist/es5/lib/encoding.js.map +1 -1
  7. package/dist/es5/node/buffer/to-array-buffer.node.js +1 -1
  8. package/dist/es5/node/buffer/to-array-buffer.node.js.map +1 -1
  9. package/dist/es5/node/fetch/fetch-file.node.js +34 -59
  10. package/dist/es5/node/fetch/fetch-file.node.js.map +1 -1
  11. package/dist/es5/node/fetch/fetch.node.js +75 -135
  12. package/dist/es5/node/fetch/fetch.node.js.map +1 -1
  13. package/dist/es5/node/fetch/headers.node.js +63 -104
  14. package/dist/es5/node/fetch/headers.node.js.map +1 -1
  15. package/dist/es5/node/fetch/response.node.js +40 -147
  16. package/dist/es5/node/fetch/response.node.js.map +1 -1
  17. package/dist/es5/node/fetch/utils/decode-data-uri.node.js +10 -16
  18. package/dist/es5/node/fetch/utils/decode-data-uri.node.js.map +1 -1
  19. package/dist/es5/node/fetch/utils/stream-utils.node.js +22 -62
  20. package/dist/es5/node/fetch/utils/stream-utils.node.js.map +1 -1
  21. package/dist/es5/node/file/blob-stream-controller.js +33 -71
  22. package/dist/es5/node/file/blob-stream-controller.js.map +1 -1
  23. package/dist/es5/node/file/blob-stream.js +12 -48
  24. package/dist/es5/node/file/blob-stream.js.map +1 -1
  25. package/dist/es5/node/file/blob.js +98 -182
  26. package/dist/es5/node/file/blob.js.map +1 -1
  27. package/dist/es5/node/file/file-reader.js +39 -124
  28. package/dist/es5/node/file/file-reader.js.map +1 -1
  29. package/dist/es5/node/file/file.js +14 -31
  30. package/dist/es5/node/file/file.js.map +1 -1
  31. package/dist/es5/node/file/readable-stream.js +1 -17
  32. package/dist/es5/node/file/readable-stream.js.map +1 -1
  33. package/dist/es5/node/images/encode-image.node.js +8 -10
  34. package/dist/es5/node/images/encode-image.node.js.map +1 -1
  35. package/dist/es5/node/images/parse-image.node.js +23 -49
  36. package/dist/es5/node/images/parse-image.node.js.map +1 -1
  37. package/dist/es5/promise/all-settled.js +7 -7
  38. package/dist/es5/promise/all-settled.js.map +1 -1
  39. package/dist/es5/utils/globals.js +3 -5
  40. package/dist/es5/utils/globals.js.map +1 -1
  41. package/package.json +2 -2
@@ -6,7 +6,7 @@ Object.defineProperty(exports, "__esModule", {
6
6
  exports.bufferToArrayBuffer = bufferToArrayBuffer;
7
7
  function bufferToArrayBuffer(buffer) {
8
8
  if (Buffer.isBuffer(buffer)) {
9
- var typedArray = new Uint8Array(buffer);
9
+ const typedArray = new Uint8Array(buffer);
10
10
  return typedArray.buffer;
11
11
  }
12
12
  return buffer;
@@ -1 +1 @@
1
- {"version":3,"file":"to-array-buffer.node.js","names":["bufferToArrayBuffer","buffer","Buffer","isBuffer","typedArray","Uint8Array"],"sources":["../../../../src/node/buffer/to-array-buffer.node.ts"],"sourcesContent":["export function bufferToArrayBuffer(buffer) {\n // TODO - per docs we should just be able to call buffer.buffer, but there are issues\n if (Buffer.isBuffer(buffer)) {\n const typedArray = new Uint8Array(buffer);\n return typedArray.buffer;\n }\n return buffer;\n}\n"],"mappings":";;;;;;AAAO,SAASA,mBAAmBA,CAACC,MAAM,EAAE;EAE1C,IAAIC,MAAM,CAACC,QAAQ,CAACF,MAAM,CAAC,EAAE;IAC3B,IAAMG,UAAU,GAAG,IAAIC,UAAU,CAACJ,MAAM,CAAC;IACzC,OAAOG,UAAU,CAACH,MAAM;EAC1B;EACA,OAAOA,MAAM;AACf"}
1
+ {"version":3,"file":"to-array-buffer.node.js","names":["bufferToArrayBuffer","buffer","Buffer","isBuffer","typedArray","Uint8Array"],"sources":["../../../../src/node/buffer/to-array-buffer.node.ts"],"sourcesContent":["export function bufferToArrayBuffer(buffer) {\n // TODO - per docs we should just be able to call buffer.buffer, but there are issues\n if (Buffer.isBuffer(buffer)) {\n const typedArray = new Uint8Array(buffer);\n return typedArray.buffer;\n }\n return buffer;\n}\n"],"mappings":";;;;;;AAAO,SAASA,mBAAmBA,CAACC,MAAM,EAAE;EAE1C,IAAIC,MAAM,CAACC,QAAQ,CAACF,MAAM,CAAC,EAAE;IAC3B,MAAMG,UAAU,GAAG,IAAIC,UAAU,CAACJ,MAAM,CAAC;IACzC,OAAOG,UAAU,CAACH,MAAM;EAC1B;EACA,OAAOA,MAAM;AACf"}
@@ -6,78 +6,53 @@ Object.defineProperty(exports, "__esModule", {
6
6
  });
7
7
  exports.fetchFileNode = fetchFileNode;
8
8
  exports.isRequestURL = isRequestURL;
9
- var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
10
- var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
11
9
  var _fs = _interopRequireDefault(require("fs"));
12
10
  var _response = require("./response.node");
13
- var _headers2 = require("./headers.node");
11
+ var _headers = require("./headers.node");
14
12
  function isRequestURL(url) {
15
13
  return url.startsWith('http:') || url.startsWith('https:');
16
14
  }
17
- function fetchFileNode(_x, _x2) {
18
- return _fetchFileNode.apply(this, arguments);
19
- }
20
- function _fetchFileNode() {
21
- _fetchFileNode = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(url, options) {
22
- var noqueryUrl, body, status, statusText, headers, _status, _statusText, _headers;
23
- return _regenerator.default.wrap(function _callee$(_context) {
24
- while (1) switch (_context.prev = _context.next) {
25
- case 0:
26
- noqueryUrl = url.split('?')[0];
27
- _context.prev = 1;
28
- _context.next = 4;
29
- return new Promise(function (resolve, reject) {
30
- var stream = _fs.default.createReadStream(noqueryUrl, {
31
- encoding: null
32
- });
33
- stream.once('readable', function () {
34
- return resolve(stream);
35
- });
36
- stream.on('error', function (error) {
37
- return reject(error);
38
- });
39
- });
40
- case 4:
41
- body = _context.sent;
42
- status = 200;
43
- statusText = 'OK';
44
- headers = getHeadersForFile(noqueryUrl);
45
- return _context.abrupt("return", new _response.Response(body, {
46
- headers: headers,
47
- status: status,
48
- statusText: statusText,
49
- url: url
50
- }));
51
- case 11:
52
- _context.prev = 11;
53
- _context.t0 = _context["catch"](1);
54
- _status = 400;
55
- _statusText = _context.t0.message;
56
- _headers = {};
57
- return _context.abrupt("return", new _response.Response(_context.t0.message, {
58
- headers: _headers,
59
- status: _status,
60
- statusText: _statusText,
61
- url: url
62
- }));
63
- case 17:
64
- case "end":
65
- return _context.stop();
66
- }
67
- }, _callee, null, [[1, 11]]);
68
- }));
69
- return _fetchFileNode.apply(this, arguments);
15
+ async function fetchFileNode(url, options) {
16
+ const noqueryUrl = url.split('?')[0];
17
+ try {
18
+ const body = await new Promise((resolve, reject) => {
19
+ const stream = _fs.default.createReadStream(noqueryUrl, {
20
+ encoding: null
21
+ });
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.Response(body, {
29
+ headers,
30
+ status,
31
+ statusText,
32
+ url
33
+ });
34
+ } catch (error) {
35
+ const status = 400;
36
+ const statusText = error.message;
37
+ const headers = {};
38
+ return new _response.Response(error.message, {
39
+ headers,
40
+ status,
41
+ statusText,
42
+ url
43
+ });
44
+ }
70
45
  }
71
46
  function getHeadersForFile(noqueryUrl) {
72
- var headers = {};
47
+ const headers = {};
73
48
  if (!headers['content-length']) {
74
- var stats = _fs.default.statSync(noqueryUrl);
49
+ const stats = _fs.default.statSync(noqueryUrl);
75
50
  headers['content-length'] = stats.size;
76
51
  }
77
52
  if (noqueryUrl.endsWith('.gz')) {
78
53
  noqueryUrl = noqueryUrl.slice(0, -3);
79
54
  headers['content-encoding'] = 'gzip';
80
55
  }
81
- return new _headers2.Headers(headers);
56
+ return new _headers.Headers(headers);
82
57
  }
83
58
  //# sourceMappingURL=fetch-file.node.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"fetch-file.node.js","names":["_fs","_interopRequireDefault","require","_response","_headers2","isRequestURL","url","startsWith","fetchFileNode","_x","_x2","_fetchFileNode","apply","arguments","_asyncToGenerator2","default","_regenerator","mark","_callee","options","noqueryUrl","body","status","statusText","headers","_status","_statusText","_headers","wrap","_callee$","_context","prev","next","split","Promise","resolve","reject","stream","fs","createReadStream","encoding","once","on","error","sent","getHeadersForFile","abrupt","Response","t0","message","stop","stats","statSync","size","endsWith","slice","Headers"],"sources":["../../../../src/node/fetch/fetch-file.node.ts"],"sourcesContent":["// loaders.gl, MIT license\n\nimport fs from 'fs'; // `fs` will be empty object in browsers (see package.json \"browser\" field).\nimport {Response} from './response.node';\nimport {Headers} from './headers.node';\n\nexport function isRequestURL(url: string): boolean {\n return url.startsWith('http:') || url.startsWith('https:');\n}\n\nexport async function fetchFileNode(url: string, options): Promise<Response> {\n const noqueryUrl = url.split('?')[0];\n\n try {\n // Now open the stream\n const body = await new Promise((resolve, reject) => {\n // @ts-ignore\n const stream = fs.createReadStream(noqueryUrl, {encoding: null});\n stream.once('readable', () => resolve(stream));\n stream.on('error', (error) => reject(error));\n });\n\n const status = 200;\n const statusText = 'OK';\n const headers = getHeadersForFile(noqueryUrl);\n return new Response(body, {headers, status, statusText, url});\n } catch (error) {\n const status = 400;\n const statusText = (error as Error).message;\n const headers = {};\n return new Response((error as Error).message, {headers, status, statusText, url});\n }\n}\n\nfunction getHeadersForFile(noqueryUrl: string): Headers {\n const headers = {};\n\n // Fix up content length if we can for best progress experience\n if (!headers['content-length']) {\n const stats = fs.statSync(noqueryUrl);\n headers['content-length'] = stats.size;\n }\n\n // Automatically decompress gzipped files with .gz extension\n if (noqueryUrl.endsWith('.gz')) {\n noqueryUrl = noqueryUrl.slice(0, -3);\n headers['content-encoding'] = 'gzip';\n }\n\n return new Headers(headers);\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"fetch-file.node.js","names":["_fs","_interopRequireDefault","require","_response","_headers","isRequestURL","url","startsWith","fetchFileNode","options","noqueryUrl","split","body","Promise","resolve","reject","stream","fs","createReadStream","encoding","once","on","error","status","statusText","headers","getHeadersForFile","Response","message","stats","statSync","size","endsWith","slice","Headers"],"sources":["../../../../src/node/fetch/fetch-file.node.ts"],"sourcesContent":["// loaders.gl, MIT license\n\nimport fs from 'fs'; // `fs` will be empty object in browsers (see package.json \"browser\" field).\nimport {Response} from './response.node';\nimport {Headers} from './headers.node';\n\nexport function isRequestURL(url: string): boolean {\n return url.startsWith('http:') || url.startsWith('https:');\n}\n\nexport async function fetchFileNode(url: string, options): Promise<Response> {\n const noqueryUrl = url.split('?')[0];\n\n try {\n // Now open the stream\n const body = await new Promise((resolve, reject) => {\n // @ts-ignore\n const stream = fs.createReadStream(noqueryUrl, {encoding: null});\n stream.once('readable', () => resolve(stream));\n stream.on('error', (error) => reject(error));\n });\n\n const status = 200;\n const statusText = 'OK';\n const headers = getHeadersForFile(noqueryUrl);\n return new Response(body, {headers, status, statusText, url});\n } catch (error) {\n const status = 400;\n const statusText = (error as Error).message;\n const headers = {};\n return new Response((error as Error).message, {headers, status, statusText, url});\n }\n}\n\nfunction getHeadersForFile(noqueryUrl: string): Headers {\n const headers = {};\n\n // Fix up content length if we can for best progress experience\n if (!headers['content-length']) {\n const stats = fs.statSync(noqueryUrl);\n headers['content-length'] = stats.size;\n }\n\n // Automatically decompress gzipped files with .gz extension\n if (noqueryUrl.endsWith('.gz')) {\n noqueryUrl = noqueryUrl.slice(0, -3);\n headers['content-encoding'] = 'gzip';\n }\n\n return new Headers(headers);\n}\n"],"mappings":";;;;;;;;AAEA,IAAAA,GAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,SAAA,GAAAD,OAAA;AACA,IAAAE,QAAA,GAAAF,OAAA;AAEO,SAASG,YAAYA,CAACC,GAAW,EAAW;EACjD,OAAOA,GAAG,CAACC,UAAU,CAAC,OAAO,CAAC,IAAID,GAAG,CAACC,UAAU,CAAC,QAAQ,CAAC;AAC5D;AAEO,eAAeC,aAAaA,CAACF,GAAW,EAAEG,OAAO,EAAqB;EAC3E,MAAMC,UAAU,GAAGJ,GAAG,CAACK,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;EAEpC,IAAI;IAEF,MAAMC,IAAI,GAAG,MAAM,IAAIC,OAAO,CAAC,CAACC,OAAO,EAAEC,MAAM,KAAK;MAElD,MAAMC,MAAM,GAAGC,WAAE,CAACC,gBAAgB,CAACR,UAAU,EAAE;QAACS,QAAQ,EAAE;MAAI,CAAC,CAAC;MAChEH,MAAM,CAACI,IAAI,CAAC,UAAU,EAAE,MAAMN,OAAO,CAACE,MAAM,CAAC,CAAC;MAC9CA,MAAM,CAACK,EAAE,CAAC,OAAO,EAAGC,KAAK,IAAKP,MAAM,CAACO,KAAK,CAAC,CAAC;IAC9C,CAAC,CAAC;IAEF,MAAMC,MAAM,GAAG,GAAG;IAClB,MAAMC,UAAU,GAAG,IAAI;IACvB,MAAMC,OAAO,GAAGC,iBAAiB,CAAChB,UAAU,CAAC;IAC7C,OAAO,IAAIiB,kBAAQ,CAACf,IAAI,EAAE;MAACa,OAAO;MAAEF,MAAM;MAAEC,UAAU;MAAElB;IAAG,CAAC,CAAC;EAC/D,CAAC,CAAC,OAAOgB,KAAK,EAAE;IACd,MAAMC,MAAM,GAAG,GAAG;IAClB,MAAMC,UAAU,GAAIF,KAAK,CAAWM,OAAO;IAC3C,MAAMH,OAAO,GAAG,CAAC,CAAC;IAClB,OAAO,IAAIE,kBAAQ,CAAEL,KAAK,CAAWM,OAAO,EAAE;MAACH,OAAO;MAAEF,MAAM;MAAEC,UAAU;MAAElB;IAAG,CAAC,CAAC;EACnF;AACF;AAEA,SAASoB,iBAAiBA,CAAChB,UAAkB,EAAW;EACtD,MAAMe,OAAO,GAAG,CAAC,CAAC;EAGlB,IAAI,CAACA,OAAO,CAAC,gBAAgB,CAAC,EAAE;IAC9B,MAAMI,KAAK,GAAGZ,WAAE,CAACa,QAAQ,CAACpB,UAAU,CAAC;IACrCe,OAAO,CAAC,gBAAgB,CAAC,GAAGI,KAAK,CAACE,IAAI;EACxC;EAGA,IAAIrB,UAAU,CAACsB,QAAQ,CAAC,KAAK,CAAC,EAAE;IAC9BtB,UAAU,GAAGA,UAAU,CAACuB,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACpCR,OAAO,CAAC,kBAAkB,CAAC,GAAG,MAAM;EACtC;EAEA,OAAO,IAAIS,gBAAO,CAACT,OAAO,CAAC;AAC7B"}
@@ -6,156 +6,96 @@ Object.defineProperty(exports, "__esModule", {
6
6
  });
7
7
  exports.createHTTPRequestReadStream = createHTTPRequestReadStream;
8
8
  exports.fetchNode = fetchNode;
9
- var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
10
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
- var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
12
9
  var _http = _interopRequireDefault(require("http"));
13
10
  var _https = _interopRequireDefault(require("https"));
14
11
  var _response = require("./response.node");
15
12
  var _headers = require("./headers.node");
16
- var _decodeDataUri2 = require("./utils/decode-data-uri.node");
13
+ var _decodeDataUri = require("./utils/decode-data-uri.node");
17
14
  var _fetchFile = require("./fetch-file.node");
18
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
19
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
20
- var isDataURL = function isDataURL(url) {
21
- return url.startsWith('data:');
22
- };
23
- var isRequestURL = function isRequestURL(url) {
24
- return url.startsWith('http:') || url.startsWith('https:');
25
- };
26
- function fetchNode(_x, _x2) {
27
- return _fetchNode.apply(this, arguments);
28
- }
29
- function _fetchNode() {
30
- _fetchNode = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee(url, options) {
31
- var _decodeDataUri, arrayBuffer, mimeType, response, syntheticResponseHeaders, originalUrl, body, headers, _getStatus, status, statusText, followRedirect, redirectUrl;
32
- return _regenerator.default.wrap(function _callee$(_context) {
33
- while (1) switch (_context.prev = _context.next) {
34
- case 0:
35
- _context.prev = 0;
36
- if (!(!isRequestURL(url) && !isDataURL(url))) {
37
- _context.next = 5;
38
- break;
39
- }
40
- _context.next = 4;
41
- return (0, _fetchFile.fetchFileNode)(url, options);
42
- case 4:
43
- return _context.abrupt("return", _context.sent);
44
- case 5:
45
- if (!isDataURL(url)) {
46
- _context.next = 9;
47
- break;
48
- }
49
- _decodeDataUri = (0, _decodeDataUri2.decodeDataUri)(url), arrayBuffer = _decodeDataUri.arrayBuffer, mimeType = _decodeDataUri.mimeType;
50
- response = new _response.Response(arrayBuffer, {
51
- headers: {
52
- 'content-type': mimeType
53
- },
54
- url: url
55
- });
56
- return _context.abrupt("return", response);
57
- case 9:
58
- syntheticResponseHeaders = {};
59
- originalUrl = url;
60
- if (url.endsWith('.gz')) {
61
- url = url.slice(0, -3);
62
- syntheticResponseHeaders['content-encoding'] = 'gzip';
63
- }
64
- _context.next = 14;
65
- return createHTTPRequestReadStream(originalUrl, options);
66
- case 14:
67
- body = _context.sent;
68
- headers = getHeaders(url, body, syntheticResponseHeaders);
69
- _getStatus = getStatus(body), status = _getStatus.status, statusText = _getStatus.statusText;
70
- followRedirect = !options || options.followRedirect || options.followRedirect === undefined;
71
- if (!(status >= 300 && status < 400 && headers.has('location') && followRedirect)) {
72
- _context.next = 23;
73
- break;
74
- }
75
- redirectUrl = generateRedirectUrl(url, headers.get('location'));
76
- _context.next = 22;
77
- return fetchNode(redirectUrl, options);
78
- case 22:
79
- return _context.abrupt("return", _context.sent);
80
- case 23:
81
- return _context.abrupt("return", new _response.Response(body, {
82
- headers: headers,
83
- status: status,
84
- statusText: statusText,
85
- url: url
86
- }));
87
- case 26:
88
- _context.prev = 26;
89
- _context.t0 = _context["catch"](0);
90
- return _context.abrupt("return", new _response.Response(null, {
91
- status: 400,
92
- statusText: String(_context.t0),
93
- url: url
94
- }));
95
- case 29:
96
- case "end":
97
- return _context.stop();
98
- }
99
- }, _callee, null, [[0, 26]]);
100
- }));
101
- return _fetchNode.apply(this, arguments);
102
- }
103
- function createHTTPRequestReadStream(_x3, _x4) {
104
- return _createHTTPRequestReadStream.apply(this, arguments);
15
+ const isDataURL = url => url.startsWith('data:');
16
+ const isRequestURL = url => url.startsWith('http:') || url.startsWith('https:');
17
+ async function fetchNode(url, options) {
18
+ try {
19
+ if (!isRequestURL(url) && !isDataURL(url)) {
20
+ return await (0, _fetchFile.fetchFileNode)(url, options);
21
+ }
22
+ if (isDataURL(url)) {
23
+ const {
24
+ arrayBuffer,
25
+ mimeType
26
+ } = (0, _decodeDataUri.decodeDataUri)(url);
27
+ const response = new _response.Response(arrayBuffer, {
28
+ headers: {
29
+ 'content-type': mimeType
30
+ },
31
+ url
32
+ });
33
+ return response;
34
+ }
35
+ const syntheticResponseHeaders = {};
36
+ const originalUrl = url;
37
+ if (url.endsWith('.gz')) {
38
+ url = url.slice(0, -3);
39
+ syntheticResponseHeaders['content-encoding'] = 'gzip';
40
+ }
41
+ const body = await createHTTPRequestReadStream(originalUrl, options);
42
+ const headers = getHeaders(url, body, syntheticResponseHeaders);
43
+ const {
44
+ status,
45
+ statusText
46
+ } = getStatus(body);
47
+ const followRedirect = !options || options.followRedirect || options.followRedirect === undefined;
48
+ if (status >= 300 && status < 400 && headers.has('location') && followRedirect) {
49
+ const redirectUrl = generateRedirectUrl(url, headers.get('location'));
50
+ return await fetchNode(redirectUrl, options);
51
+ }
52
+ return new _response.Response(body, {
53
+ headers,
54
+ status,
55
+ statusText,
56
+ url
57
+ });
58
+ } catch (error) {
59
+ return new _response.Response(null, {
60
+ status: 400,
61
+ statusText: String(error),
62
+ url
63
+ });
64
+ }
105
65
  }
106
- function _createHTTPRequestReadStream() {
107
- _createHTTPRequestReadStream = (0, _asyncToGenerator2.default)(_regenerator.default.mark(function _callee2(url, options) {
108
- return _regenerator.default.wrap(function _callee2$(_context2) {
109
- while (1) switch (_context2.prev = _context2.next) {
110
- case 0:
111
- _context2.next = 2;
112
- return new Promise(function (resolve, reject) {
113
- var requestOptions = getRequestOptions(url, options);
114
- var req = url.startsWith('https:') ? _https.default.request(requestOptions, function (res) {
115
- return resolve(res);
116
- }) : _http.default.request(requestOptions, function (res) {
117
- return resolve(res);
118
- });
119
- req.on('error', function (error) {
120
- return reject(error);
121
- });
122
- req.end();
123
- });
124
- case 2:
125
- return _context2.abrupt("return", _context2.sent);
126
- case 3:
127
- case "end":
128
- return _context2.stop();
129
- }
130
- }, _callee2);
131
- }));
132
- return _createHTTPRequestReadStream.apply(this, arguments);
66
+ async function createHTTPRequestReadStream(url, options) {
67
+ return await new Promise((resolve, reject) => {
68
+ const requestOptions = getRequestOptions(url, options);
69
+ const req = url.startsWith('https:') ? _https.default.request(requestOptions, res => resolve(res)) : _http.default.request(requestOptions, res => resolve(res));
70
+ req.on('error', error => reject(error));
71
+ req.end();
72
+ });
133
73
  }
134
74
  function generateRedirectUrl(originalUrl, location) {
135
75
  if (location.startsWith('http')) {
136
76
  return location;
137
77
  }
138
- var url = new URL(originalUrl);
78
+ const url = new URL(originalUrl);
139
79
  url.pathname = location;
140
80
  return url.href;
141
81
  }
142
82
  function getRequestOptions(url, options) {
143
- var originalHeaders = (options === null || options === void 0 ? void 0 : options.headers) || {};
144
- var headers = {};
145
- for (var _i = 0, _Object$keys = Object.keys(originalHeaders); _i < _Object$keys.length; _i++) {
146
- var key = _Object$keys[_i];
83
+ const originalHeaders = (options === null || options === void 0 ? void 0 : options.headers) || {};
84
+ const headers = {};
85
+ for (const key of Object.keys(originalHeaders)) {
147
86
  headers[key.toLowerCase()] = originalHeaders[key];
148
87
  }
149
88
  headers['accept-encoding'] = headers['accept-encoding'] || 'gzip,br,deflate';
150
- var urlObject = new URL(url);
151
- return _objectSpread(_objectSpread(_objectSpread({
89
+ const urlObject = new URL(url);
90
+ return {
152
91
  hostname: urlObject.hostname,
153
92
  path: urlObject.pathname,
154
- method: 'GET'
155
- }, options), options === null || options === void 0 ? void 0 : options.fetch), {}, {
156
- headers: headers,
93
+ method: 'GET',
94
+ ...options,
95
+ ...(options === null || options === void 0 ? void 0 : options.fetch),
96
+ headers,
157
97
  port: urlObject.port
158
- });
98
+ };
159
99
  }
160
100
  function getStatus(httpResponse) {
161
101
  if (httpResponse.statusCode) {
@@ -170,17 +110,17 @@ function getStatus(httpResponse) {
170
110
  };
171
111
  }
172
112
  function getHeaders(url, httpResponse) {
173
- var additionalHeaders = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
174
- var headers = {};
113
+ let additionalHeaders = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
114
+ const headers = {};
175
115
  if (httpResponse && httpResponse.headers) {
176
- var httpHeaders = httpResponse.headers;
177
- for (var key in httpHeaders) {
178
- var header = httpHeaders[key];
116
+ const httpHeaders = httpResponse.headers;
117
+ for (const key in httpHeaders) {
118
+ const header = httpHeaders[key];
179
119
  headers[key.toLowerCase()] = String(header);
180
120
  }
181
121
  }
182
122
  if (!headers['content-length']) {
183
- var contentLength = getContentLength(url);
123
+ const contentLength = getContentLength(url);
184
124
  if (Number.isFinite(contentLength)) {
185
125
  headers['content-length'] = contentLength;
186
126
  }
@@ -1 +1 @@
1
- {"version":3,"file":"fetch.node.js","names":["_http","_interopRequireDefault","require","_https","_response","_headers","_decodeDataUri2","_fetchFile","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","isDataURL","url","startsWith","isRequestURL","fetchNode","_x","_x2","_fetchNode","_asyncToGenerator2","_regenerator","mark","_callee","options","_decodeDataUri","arrayBuffer","mimeType","response","syntheticResponseHeaders","originalUrl","body","headers","_getStatus","status","statusText","followRedirect","redirectUrl","wrap","_callee$","_context","prev","next","fetchFileNode","abrupt","sent","decodeDataUri","Response","endsWith","slice","createHTTPRequestReadStream","getHeaders","getStatus","undefined","has","generateRedirectUrl","get","t0","String","stop","_x3","_x4","_createHTTPRequestReadStream","_callee2","_callee2$","_context2","Promise","resolve","reject","requestOptions","getRequestOptions","req","https","request","res","http","on","error","end","location","URL","pathname","href","originalHeaders","_i","_Object$keys","toLowerCase","urlObject","hostname","path","method","fetch","port","httpResponse","statusCode","statusMessage","additionalHeaders","httpHeaders","header","contentLength","getContentLength","Number","isFinite","assign","Headers"],"sources":["../../../../src/node/fetch/fetch.node.ts"],"sourcesContent":["// loaders.gl, MIT license\n\nimport http from 'http';\nimport https from 'https';\nimport {Response} from './response.node';\nimport {Headers} from './headers.node';\nimport {decodeDataUri} from './utils/decode-data-uri.node';\n\nimport {fetchFileNode} from './fetch-file.node';\n\nconst isDataURL = (url: string): boolean => url.startsWith('data:');\nconst isRequestURL = (url: string): boolean => url.startsWith('http:') || url.startsWith('https:');\n\n/**\n * Emulation of Browser fetch for Node.js\n * @param url\n * @param options\n */\n// eslint-disable-next-line complexity\nexport async function fetchNode(url: string, options): Promise<Response> {\n try {\n // Handle file streams in node\n if (!isRequestURL(url) && !isDataURL(url)) {\n return await fetchFileNode(url, options);\n }\n\n // Handle data urls in node, to match `fetch``\n // Note - this loses the MIME type, data URIs are handled directly in fetch\n if (isDataURL(url)) {\n const {arrayBuffer, mimeType} = decodeDataUri(url);\n const response = new Response(arrayBuffer, {\n headers: {'content-type': mimeType},\n url\n });\n return response;\n }\n\n // Automatically decompress gzipped files with .gz extension\n const syntheticResponseHeaders = {};\n const originalUrl = url;\n if (url.endsWith('.gz')) {\n url = url.slice(0, -3);\n syntheticResponseHeaders['content-encoding'] = 'gzip';\n }\n\n // Need to create the stream in advance since Response constructor needs to be sync\n const body = await createHTTPRequestReadStream(originalUrl, options);\n const headers = getHeaders(url, body, syntheticResponseHeaders);\n const {status, statusText} = getStatus(body);\n\n const followRedirect =\n !options || options.followRedirect || options.followRedirect === undefined;\n\n if (status >= 300 && status < 400 && headers.has('location') && followRedirect) {\n const redirectUrl = generateRedirectUrl(url, headers.get('location'));\n\n // Redirect\n return await fetchNode(redirectUrl, options);\n }\n return new Response(body, {headers, status, statusText, url});\n } catch (error) {\n // TODO - what error code to use here?\n return new Response(null, {status: 400, statusText: String(error), url});\n }\n}\n\n/** Returns a promise that resolves to a readable stream */\nexport async function createHTTPRequestReadStream(\n url: string,\n options\n): Promise<http.IncomingMessage> {\n // HANDLE HTTP/HTTPS REQUESTS IN NODE\n // TODO: THIS IS BAD SINCE WE RETURN A PROMISE INSTEAD OF A STREAM\n return await new Promise((resolve, reject) => {\n const requestOptions = getRequestOptions(url, options);\n const req = url.startsWith('https:')\n ? https.request(requestOptions, (res) => resolve(res))\n : http.request(requestOptions, (res) => resolve(res));\n req.on('error', (error) => reject(error));\n req.end();\n });\n}\n\n/**\n * Generate redirect url from location without origin and protocol.\n * @param originalUrl\n * @param redirectUrl\n */\nfunction generateRedirectUrl(originalUrl: string, location: string): string {\n if (location.startsWith('http')) {\n return location;\n }\n // If url doesn't have origin and protocol just extend current url origin with location.\n const url = new URL(originalUrl);\n url.pathname = location;\n\n return url.href;\n}\n\n// HELPER FUNCTIONS\n\nfunction getRequestOptions(url: string, options?: {fetch?: typeof fetch; headers?}) {\n // Ensure header keys are lower case so that we can merge without duplicates\n const originalHeaders = options?.headers || {};\n const headers = {};\n for (const key of Object.keys(originalHeaders)) {\n headers[key.toLowerCase()] = originalHeaders[key];\n }\n\n // Add default accept-encoding to headers\n headers['accept-encoding'] = headers['accept-encoding'] || 'gzip,br,deflate';\n\n const urlObject = new URL(url);\n return {\n hostname: urlObject.hostname,\n path: urlObject.pathname,\n method: 'GET',\n // Add options and user provided 'options.fetch' overrides if available\n ...options,\n ...options?.fetch,\n // Override with updated headers with accepted encodings:\n headers,\n port: urlObject.port\n };\n}\n\nfunction getStatus(httpResponse: http.IncomingMessage): {status: number; statusText: string} {\n if (httpResponse.statusCode) {\n return {status: httpResponse.statusCode, statusText: httpResponse.statusMessage || 'NA'};\n }\n return {status: 200, statusText: 'OK'};\n}\n\nfunction getHeaders(url, httpResponse, additionalHeaders = {}) {\n const headers = {};\n\n if (httpResponse && httpResponse.headers) {\n const httpHeaders = httpResponse.headers;\n for (const key in httpHeaders) {\n const header = httpHeaders[key];\n headers[key.toLowerCase()] = String(header);\n }\n }\n\n // Fix up content length if we can for best progress experience\n if (!headers['content-length']) {\n const contentLength = getContentLength(url);\n if (Number.isFinite(contentLength)) {\n headers['content-length'] = contentLength;\n }\n }\n\n Object.assign(headers, additionalHeaders);\n\n return new Headers(headers);\n}\n\n/** Needs to be read from actual headers */\nfunction getContentLength(url: string): number | null {\n // TODO - remove media type etc\n return isDataURL(url) ? url.length - 'data:'.length : null;\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"fetch.node.js","names":["_http","_interopRequireDefault","require","_https","_response","_headers","_decodeDataUri","_fetchFile","isDataURL","url","startsWith","isRequestURL","fetchNode","options","fetchFileNode","arrayBuffer","mimeType","decodeDataUri","response","Response","headers","syntheticResponseHeaders","originalUrl","endsWith","slice","body","createHTTPRequestReadStream","getHeaders","status","statusText","getStatus","followRedirect","undefined","has","redirectUrl","generateRedirectUrl","get","error","String","Promise","resolve","reject","requestOptions","getRequestOptions","req","https","request","res","http","on","end","location","URL","pathname","href","originalHeaders","key","Object","keys","toLowerCase","urlObject","hostname","path","method","fetch","port","httpResponse","statusCode","statusMessage","additionalHeaders","arguments","length","httpHeaders","header","contentLength","getContentLength","Number","isFinite","assign","Headers"],"sources":["../../../../src/node/fetch/fetch.node.ts"],"sourcesContent":["// loaders.gl, MIT license\n\nimport http from 'http';\nimport https from 'https';\nimport {Response} from './response.node';\nimport {Headers} from './headers.node';\nimport {decodeDataUri} from './utils/decode-data-uri.node';\n\nimport {fetchFileNode} from './fetch-file.node';\n\nconst isDataURL = (url: string): boolean => url.startsWith('data:');\nconst isRequestURL = (url: string): boolean => url.startsWith('http:') || url.startsWith('https:');\n\n/**\n * Emulation of Browser fetch for Node.js\n * @param url\n * @param options\n */\n// eslint-disable-next-line complexity\nexport async function fetchNode(url: string, options): Promise<Response> {\n try {\n // Handle file streams in node\n if (!isRequestURL(url) && !isDataURL(url)) {\n return await fetchFileNode(url, options);\n }\n\n // Handle data urls in node, to match `fetch``\n // Note - this loses the MIME type, data URIs are handled directly in fetch\n if (isDataURL(url)) {\n const {arrayBuffer, mimeType} = decodeDataUri(url);\n const response = new Response(arrayBuffer, {\n headers: {'content-type': mimeType},\n url\n });\n return response;\n }\n\n // Automatically decompress gzipped files with .gz extension\n const syntheticResponseHeaders = {};\n const originalUrl = url;\n if (url.endsWith('.gz')) {\n url = url.slice(0, -3);\n syntheticResponseHeaders['content-encoding'] = 'gzip';\n }\n\n // Need to create the stream in advance since Response constructor needs to be sync\n const body = await createHTTPRequestReadStream(originalUrl, options);\n const headers = getHeaders(url, body, syntheticResponseHeaders);\n const {status, statusText} = getStatus(body);\n\n const followRedirect =\n !options || options.followRedirect || options.followRedirect === undefined;\n\n if (status >= 300 && status < 400 && headers.has('location') && followRedirect) {\n const redirectUrl = generateRedirectUrl(url, headers.get('location'));\n\n // Redirect\n return await fetchNode(redirectUrl, options);\n }\n return new Response(body, {headers, status, statusText, url});\n } catch (error) {\n // TODO - what error code to use here?\n return new Response(null, {status: 400, statusText: String(error), url});\n }\n}\n\n/** Returns a promise that resolves to a readable stream */\nexport async function createHTTPRequestReadStream(\n url: string,\n options\n): Promise<http.IncomingMessage> {\n // HANDLE HTTP/HTTPS REQUESTS IN NODE\n // TODO: THIS IS BAD SINCE WE RETURN A PROMISE INSTEAD OF A STREAM\n return await new Promise((resolve, reject) => {\n const requestOptions = getRequestOptions(url, options);\n const req = url.startsWith('https:')\n ? https.request(requestOptions, (res) => resolve(res))\n : http.request(requestOptions, (res) => resolve(res));\n req.on('error', (error) => reject(error));\n req.end();\n });\n}\n\n/**\n * Generate redirect url from location without origin and protocol.\n * @param originalUrl\n * @param redirectUrl\n */\nfunction generateRedirectUrl(originalUrl: string, location: string): string {\n if (location.startsWith('http')) {\n return location;\n }\n // If url doesn't have origin and protocol just extend current url origin with location.\n const url = new URL(originalUrl);\n url.pathname = location;\n\n return url.href;\n}\n\n// HELPER FUNCTIONS\n\nfunction getRequestOptions(url: string, options?: {fetch?: typeof fetch; headers?}) {\n // Ensure header keys are lower case so that we can merge without duplicates\n const originalHeaders = options?.headers || {};\n const headers = {};\n for (const key of Object.keys(originalHeaders)) {\n headers[key.toLowerCase()] = originalHeaders[key];\n }\n\n // Add default accept-encoding to headers\n headers['accept-encoding'] = headers['accept-encoding'] || 'gzip,br,deflate';\n\n const urlObject = new URL(url);\n return {\n hostname: urlObject.hostname,\n path: urlObject.pathname,\n method: 'GET',\n // Add options and user provided 'options.fetch' overrides if available\n ...options,\n ...options?.fetch,\n // Override with updated headers with accepted encodings:\n headers,\n port: urlObject.port\n };\n}\n\nfunction getStatus(httpResponse: http.IncomingMessage): {status: number; statusText: string} {\n if (httpResponse.statusCode) {\n return {status: httpResponse.statusCode, statusText: httpResponse.statusMessage || 'NA'};\n }\n return {status: 200, statusText: 'OK'};\n}\n\nfunction getHeaders(url, httpResponse, additionalHeaders = {}) {\n const headers = {};\n\n if (httpResponse && httpResponse.headers) {\n const httpHeaders = httpResponse.headers;\n for (const key in httpHeaders) {\n const header = httpHeaders[key];\n headers[key.toLowerCase()] = String(header);\n }\n }\n\n // Fix up content length if we can for best progress experience\n if (!headers['content-length']) {\n const contentLength = getContentLength(url);\n if (Number.isFinite(contentLength)) {\n headers['content-length'] = contentLength;\n }\n }\n\n Object.assign(headers, additionalHeaders);\n\n return new Headers(headers);\n}\n\n/** Needs to be read from actual headers */\nfunction getContentLength(url: string): number | null {\n // TODO - remove media type etc\n return isDataURL(url) ? url.length - 'data:'.length : null;\n}\n"],"mappings":"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"}