diff --git a/.babelrc b/.babelrc index c13c5f6..3f1eaff 100644 --- a/.babelrc +++ b/.babelrc @@ -1,3 +1,12 @@ { - "presets": ["es2015"] + "presets": [ + "@babel/preset-typescript", + [ + "@babel/preset-env", + { + "useBuiltIns": "entry", + "corejs": "3.22" + } + ] + ] } diff --git a/.eslintrc b/.eslintrc new file mode 100644 index 0000000..8efdd5f --- /dev/null +++ b/.eslintrc @@ -0,0 +1,6 @@ +{ + "extends": ["eslint:recommended", "plugin:@typescript-eslint/recommended"], + "parser": "@typescript-eslint/parser", + "plugins": ["@typescript-eslint"], + "root": true +} diff --git a/.gitignore b/.gitignore index 437734f..4c0fcfc 100644 --- a/.gitignore +++ b/.gitignore @@ -1,7 +1,7 @@ node_modules/ +.vscode/settings.json npm-debug.log .DS_Store -package-lock.json # VIM Swap Files [._]*.s[a-v][a-z] diff --git a/.prettierrc b/.prettierrc new file mode 100644 index 0000000..e83a206 --- /dev/null +++ b/.prettierrc @@ -0,0 +1,6 @@ +{ + "semi": false, + "singleQuote": true, + "trailingComma": "none", + "printWidth": 120 +} diff --git a/.vscode/launch.json b/.vscode/launch.json index f3aff3f..d984800 100644 --- a/.vscode/launch.json +++ b/.vscode/launch.json @@ -6,18 +6,11 @@ "type": "node", "request": "launch", "cwd": "${workspaceRoot}", - "program": "${workspaceRoot}/node_modules/mocha/bin/_mocha", + "program": "${workspaceRoot}/node_modules/ts-mocha/bin/ts-mocha", "stopOnEntry": false, - "args": [ - "./src/*-unit.js", - "--require", "babel-register", "testutils.js", - "--reporter", "spec", - "--no-timeouts" - ], - "runtimeArgs": [ - "--nolazy" - ], + "args": ["./src/${fileBasename}", "--require", "@babel/register", "--reporter", "spec", "--no-timeouts"], + "runtimeArgs": ["--nolazy"], "sourceMaps": true - } + } ] } diff --git a/@types/emailjs-base64.d.ts b/@types/emailjs-base64.d.ts new file mode 100644 index 0000000..a4b5191 --- /dev/null +++ b/@types/emailjs-base64.d.ts @@ -0,0 +1,5 @@ +declare module 'emailjs-base64' { + export function encode(input: string | Uint8Array): string + export function decode(input: string, option: string): Uint8Array + export const OUTPUT_TYPED_ARRAY: string +} diff --git a/dist/charset.d.ts b/dist/charset.d.ts new file mode 100644 index 0000000..29bb3e0 --- /dev/null +++ b/dist/charset.d.ts @@ -0,0 +1,24 @@ +/** + * Encodes an unicode string into an Uint8Array object as UTF-8 + * + * @param {String} str String to be encoded + * @return {Uint8Array} UTF-8 encoded typed array + */ +export declare const encode: (str: string) => Uint8Array; +export declare const arr2str: (arr: Uint8Array) => string; +/** + * Decodes a string from Uint8Array to an unicode string using specified encoding + * + * @param {Uint8Array} buf Binary data to be decoded + * @param {String} Binary data is decoded into string using this charset + * @return {String} Decoded string + */ +export declare function decode(buf: Uint8Array, fromCharset?: string): string; +/** + * Convert a string from specific encoding to UTF-8 Uint8Array + * + * @param {String|Uint8Array} data Data to be encoded + * @param {String} Source encoding for the string (optional for data of type String) + * @return {Uint8Array} UTF-8 encoded typed array + */ +export declare const convert: (data: string | Uint8Array, fromCharset: string) => Uint8Array; diff --git a/dist/charset.js b/dist/charset.js index e8c390b..4baf32d 100644 --- a/dist/charset.js +++ b/dist/charset.js @@ -1,31 +1,28 @@ -'use strict'; +"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); -exports.convert = exports.arr2str = exports.encode = undefined; +exports.convert = exports.arr2str = void 0; exports.decode = decode; - -var _textEncoding = require('text-encoding'); - +exports.encode = void 0; +var _textEncoding = require("text-encoding"); /** * Encodes an unicode string into an Uint8Array object as UTF-8 * * @param {String} str String to be encoded * @return {Uint8Array} UTF-8 encoded typed array */ -var encode = exports.encode = function encode(str) { +var encode = function encode(str) { return new _textEncoding.TextEncoder('UTF-8').encode(str); }; - -var arr2str = exports.arr2str = function arr2str(arr) { +exports.encode = encode; +var arr2str = function arr2str(arr) { var CHUNK_SZ = 0x8000; var strs = []; - for (var i = 0; i < arr.length; i += CHUNK_SZ) { - strs.push(String.fromCharCode.apply(null, arr.subarray(i, i + CHUNK_SZ))); + strs.push(String.fromCharCode.apply(null, Array.from(arr.subarray(i, i + CHUNK_SZ)))); } - return strs.join(''); }; @@ -36,40 +33,31 @@ var arr2str = exports.arr2str = function arr2str(arr) { * @param {String} Binary data is decoded into string using this charset * @return {String} Decoded string */ +exports.arr2str = arr2str; function decode(buf) { var fromCharset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'utf-8'; - - var charsets = [{ charset: normalizeCharset(fromCharset), fatal: false }, { charset: 'utf-8', fatal: true }, { charset: 'iso-8859-15', fatal: false }]; - - var _iteratorNormalCompletion = true; - var _didIteratorError = false; - var _iteratorError = undefined; - - try { - for (var _iterator = charsets[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) { - var _step$value = _step.value, - charset = _step$value.charset, - fatal = _step$value.fatal; - - try { - return new _textEncoding.TextDecoder(charset, { fatal: fatal }).decode(buf); - } catch (e) {} - } - } catch (err) { - _didIteratorError = true; - _iteratorError = err; - } finally { + var charsets = [{ + charset: normalizeCharset(fromCharset), + fatal: false + }, { + charset: 'utf-8', + fatal: true + }, { + charset: 'iso-8859-15', + fatal: false + }]; + for (var _i = 0, _charsets = charsets; _i < _charsets.length; _i++) { + var _charsets$_i = _charsets[_i], + charset = _charsets$_i.charset, + fatal = _charsets$_i.fatal; try { - if (!_iteratorNormalCompletion && _iterator.return) { - _iterator.return(); - } - } finally { - if (_didIteratorError) { - throw _iteratorError; - } + return new _textEncoding.TextDecoder(charset, { + fatal: fatal + }).decode(buf); + } catch (e) { + // ignore } } - return arr2str(buf); // all else fails, treat it as binary } @@ -80,27 +68,21 @@ function decode(buf) { * @param {String} Source encoding for the string (optional for data of type String) * @return {Uint8Array} UTF-8 encoded typed array */ -var convert = exports.convert = function convert(data, fromCharset) { +var convert = function convert(data, fromCharset) { return typeof data === 'string' ? encode(data) : encode(decode(data, fromCharset)); }; - +exports.convert = convert; function normalizeCharset() { var charset = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'utf-8'; - - var match = void 0; - + var match; if (match = charset.match(/^utf[-_]?(\d+)$/i)) { return 'UTF-' + match[1]; } - if (match = charset.match(/^win[-_]?(\d+)$/i)) { return 'WINDOWS-' + match[1]; } - if (match = charset.match(/^latin[-_]?(\d+)$/i)) { return 'ISO-8859-' + match[1]; } - return charset; -} -//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jaGFyc2V0LmpzIl0sIm5hbWVzIjpbImRlY29kZSIsImVuY29kZSIsIlRleHRFbmNvZGVyIiwic3RyIiwiYXJyMnN0ciIsIkNIVU5LX1NaIiwic3RycyIsImkiLCJhcnIiLCJsZW5ndGgiLCJwdXNoIiwiU3RyaW5nIiwiZnJvbUNoYXJDb2RlIiwiYXBwbHkiLCJzdWJhcnJheSIsImpvaW4iLCJidWYiLCJmcm9tQ2hhcnNldCIsImNoYXJzZXRzIiwiY2hhcnNldCIsIm5vcm1hbGl6ZUNoYXJzZXQiLCJmYXRhbCIsIlRleHREZWNvZGVyIiwiZSIsImNvbnZlcnQiLCJkYXRhIiwibWF0Y2giXSwibWFwcGluZ3MiOiI7Ozs7OztRQTRCZ0JBLE0sR0FBQUEsTTs7QUE1QmhCOztBQUVBOzs7Ozs7QUFNTyxJQUFNQywwQkFBUyxTQUFUQSxNQUFTO0FBQUEsU0FBTyxJQUFJQyx5QkFBSixDQUFnQixPQUFoQixFQUF5QkQsTUFBekIsQ0FBZ0NFLEdBQWhDLENBQVA7QUFBQSxDQUFmOztBQUVBLElBQU1DLDRCQUFVLFNBQVZBLE9BQVUsTUFBTztBQUM1QixNQUFNQyxXQUFXLE1BQWpCO0FBQ0EsTUFBTUMsT0FBTyxFQUFiOztBQUVBLE9BQUssSUFBSUMsSUFBSSxDQUFiLEVBQWdCQSxJQUFJQyxJQUFJQyxNQUF4QixFQUFnQ0YsS0FBS0YsUUFBckMsRUFBK0M7QUFDN0NDLFNBQUtJLElBQUwsQ0FBVUMsT0FBT0MsWUFBUCxDQUFvQkMsS0FBcEIsQ0FBMEIsSUFBMUIsRUFBZ0NMLElBQUlNLFFBQUosQ0FBYVAsQ0FBYixFQUFnQkEsSUFBSUYsUUFBcEIsQ0FBaEMsQ0FBVjtBQUNEOztBQUVELFNBQU9DLEtBQUtTLElBQUwsQ0FBVSxFQUFWLENBQVA7QUFDRCxDQVRNOztBQVdQOzs7Ozs7O0FBT08sU0FBU2YsTUFBVCxDQUFpQmdCLEdBQWpCLEVBQTZDO0FBQUEsTUFBdkJDLFdBQXVCLHVFQUFULE9BQVM7O0FBQ2xELE1BQU1DLFdBQVcsQ0FDZixFQUFFQyxTQUFTQyxpQkFBaUJILFdBQWpCLENBQVgsRUFBMENJLE9BQU8sS0FBakQsRUFEZSxFQUVmLEVBQUVGLFNBQVMsT0FBWCxFQUFvQkUsT0FBTyxJQUEzQixFQUZlLEVBR2YsRUFBRUYsU0FBUyxhQUFYLEVBQTBCRSxPQUFPLEtBQWpDLEVBSGUsQ0FBakI7O0FBRGtEO0FBQUE7QUFBQTs7QUFBQTtBQU9sRCx5QkFBaUNILFFBQWpDLDhIQUEyQztBQUFBO0FBQUEsVUFBOUJDLE9BQThCLGVBQTlCQSxPQUE4QjtBQUFBLFVBQXJCRSxLQUFxQixlQUFyQkEsS0FBcUI7O0FBQ3pDLFVBQUk7QUFBRSxlQUFPLElBQUlDLHlCQUFKLENBQWdCSCxPQUFoQixFQUF5QixFQUFFRSxZQUFGLEVBQXpCLEVBQW9DckIsTUFBcEMsQ0FBMkNnQixHQUEzQyxDQUFQO0FBQXdELE9BQTlELENBQStELE9BQU9PLENBQVAsRUFBVSxDQUFHO0FBQzdFO0FBVGlEO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7O0FBV2xELFNBQU9uQixRQUFRWSxHQUFSLENBQVAsQ0FYa0QsQ0FXOUI7QUFDckI7O0FBRUQ7Ozs7Ozs7QUFPTyxJQUFNUSw0QkFBVSxTQUFWQSxPQUFVLENBQUNDLElBQUQsRUFBT1IsV0FBUDtBQUFBLFNBQXVCLE9BQU9RLElBQVAsS0FBZ0IsUUFBaEIsR0FBMkJ4QixPQUFPd0IsSUFBUCxDQUEzQixHQUEwQ3hCLE9BQU9ELE9BQU95QixJQUFQLEVBQWFSLFdBQWIsQ0FBUCxDQUFqRTtBQUFBLENBQWhCOztBQUVQLFNBQVNHLGdCQUFULEdBQThDO0FBQUEsTUFBbkJELE9BQW1CLHVFQUFULE9BQVM7O0FBQzVDLE1BQUlPLGNBQUo7O0FBRUEsTUFBS0EsUUFBUVAsUUFBUU8sS0FBUixDQUFjLGtCQUFkLENBQWIsRUFBaUQ7QUFDL0MsV0FBTyxTQUFTQSxNQUFNLENBQU4sQ0FBaEI7QUFDRDs7QUFFRCxNQUFLQSxRQUFRUCxRQUFRTyxLQUFSLENBQWMsa0JBQWQsQ0FBYixFQUFpRDtBQUMvQyxXQUFPLGFBQWFBLE1BQU0sQ0FBTixDQUFwQjtBQUNEOztBQUVELE1BQUtBLFFBQVFQLFFBQVFPLEtBQVIsQ0FBYyxvQkFBZCxDQUFiLEVBQW1EO0FBQ2pELFdBQU8sY0FBY0EsTUFBTSxDQUFOLENBQXJCO0FBQ0Q7O0FBRUQsU0FBT1AsT0FBUDtBQUNEIiwiZmlsZSI6ImNoYXJzZXQuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUZXh0RGVjb2RlciwgVGV4dEVuY29kZXIgfSBmcm9tICd0ZXh0LWVuY29kaW5nJ1xuXG4vKipcbiAqIEVuY29kZXMgYW4gdW5pY29kZSBzdHJpbmcgaW50byBhbiBVaW50OEFycmF5IG9iamVjdCBhcyBVVEYtOFxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBzdHIgU3RyaW5nIHRvIGJlIGVuY29kZWRcbiAqIEByZXR1cm4ge1VpbnQ4QXJyYXl9IFVURi04IGVuY29kZWQgdHlwZWQgYXJyYXlcbiAqL1xuZXhwb3J0IGNvbnN0IGVuY29kZSA9IHN0ciA9PiBuZXcgVGV4dEVuY29kZXIoJ1VURi04JykuZW5jb2RlKHN0cilcblxuZXhwb3J0IGNvbnN0IGFycjJzdHIgPSBhcnIgPT4ge1xuICBjb25zdCBDSFVOS19TWiA9IDB4ODAwMFxuICBjb25zdCBzdHJzID0gW11cblxuICBmb3IgKGxldCBpID0gMDsgaSA8IGFyci5sZW5ndGg7IGkgKz0gQ0hVTktfU1opIHtcbiAgICBzdHJzLnB1c2goU3RyaW5nLmZyb21DaGFyQ29kZS5hcHBseShudWxsLCBhcnIuc3ViYXJyYXkoaSwgaSArIENIVU5LX1NaKSkpXG4gIH1cblxuICByZXR1cm4gc3Rycy5qb2luKCcnKVxufVxuXG4vKipcbiAqIERlY29kZXMgYSBzdHJpbmcgZnJvbSBVaW50OEFycmF5IHRvIGFuIHVuaWNvZGUgc3RyaW5nIHVzaW5nIHNwZWNpZmllZCBlbmNvZGluZ1xuICpcbiAqIEBwYXJhbSB7VWludDhBcnJheX0gYnVmIEJpbmFyeSBkYXRhIHRvIGJlIGRlY29kZWRcbiAqIEBwYXJhbSB7U3RyaW5nfSBCaW5hcnkgZGF0YSBpcyBkZWNvZGVkIGludG8gc3RyaW5nIHVzaW5nIHRoaXMgY2hhcnNldFxuICogQHJldHVybiB7U3RyaW5nfSBEZWNvZGVkIHN0cmluZ1xuICovXG5leHBvcnQgZnVuY3Rpb24gZGVjb2RlIChidWYsIGZyb21DaGFyc2V0ID0gJ3V0Zi04Jykge1xuICBjb25zdCBjaGFyc2V0cyA9IFtcbiAgICB7IGNoYXJzZXQ6IG5vcm1hbGl6ZUNoYXJzZXQoZnJvbUNoYXJzZXQpLCBmYXRhbDogZmFsc2UgfSxcbiAgICB7IGNoYXJzZXQ6ICd1dGYtOCcsIGZhdGFsOiB0cnVlIH0sXG4gICAgeyBjaGFyc2V0OiAnaXNvLTg4NTktMTUnLCBmYXRhbDogZmFsc2UgfVxuICBdXG5cbiAgZm9yIChjb25zdCB7IGNoYXJzZXQsIGZhdGFsIH0gb2YgY2hhcnNldHMpIHtcbiAgICB0cnkgeyByZXR1cm4gbmV3IFRleHREZWNvZGVyKGNoYXJzZXQsIHsgZmF0YWwgfSkuZGVjb2RlKGJ1ZikgfSBjYXRjaCAoZSkgeyB9XG4gIH1cblxuICByZXR1cm4gYXJyMnN0cihidWYpIC8vIGFsbCBlbHNlIGZhaWxzLCB0cmVhdCBpdCBhcyBiaW5hcnlcbn1cblxuLyoqXG4gKiBDb252ZXJ0IGEgc3RyaW5nIGZyb20gc3BlY2lmaWMgZW5jb2RpbmcgdG8gVVRGLTggVWludDhBcnJheVxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfFVpbnQ4QXJyYXl9IGRhdGEgRGF0YSB0byBiZSBlbmNvZGVkXG4gKiBAcGFyYW0ge1N0cmluZ30gU291cmNlIGVuY29kaW5nIGZvciB0aGUgc3RyaW5nIChvcHRpb25hbCBmb3IgZGF0YSBvZiB0eXBlIFN0cmluZylcbiAqIEByZXR1cm4ge1VpbnQ4QXJyYXl9IFVURi04IGVuY29kZWQgdHlwZWQgYXJyYXlcbiAqL1xuZXhwb3J0IGNvbnN0IGNvbnZlcnQgPSAoZGF0YSwgZnJvbUNoYXJzZXQpID0+IHR5cGVvZiBkYXRhID09PSAnc3RyaW5nJyA/IGVuY29kZShkYXRhKSA6IGVuY29kZShkZWNvZGUoZGF0YSwgZnJvbUNoYXJzZXQpKVxuXG5mdW5jdGlvbiBub3JtYWxpemVDaGFyc2V0IChjaGFyc2V0ID0gJ3V0Zi04Jykge1xuICBsZXQgbWF0Y2hcblxuICBpZiAoKG1hdGNoID0gY2hhcnNldC5tYXRjaCgvXnV0ZlstX10/KFxcZCspJC9pKSkpIHtcbiAgICByZXR1cm4gJ1VURi0nICsgbWF0Y2hbMV1cbiAgfVxuXG4gIGlmICgobWF0Y2ggPSBjaGFyc2V0Lm1hdGNoKC9ed2luWy1fXT8oXFxkKykkL2kpKSkge1xuICAgIHJldHVybiAnV0lORE9XUy0nICsgbWF0Y2hbMV1cbiAgfVxuXG4gIGlmICgobWF0Y2ggPSBjaGFyc2V0Lm1hdGNoKC9ebGF0aW5bLV9dPyhcXGQrKSQvaSkpKSB7XG4gICAgcmV0dXJuICdJU08tODg1OS0nICsgbWF0Y2hbMV1cbiAgfVxuXG4gIHJldHVybiBjaGFyc2V0XG59XG4iXX0= \ No newline at end of file +} \ No newline at end of file diff --git a/dist/mimecodec.d.ts b/dist/mimecodec.d.ts new file mode 100644 index 0000000..7941321 --- /dev/null +++ b/dist/mimecodec.d.ts @@ -0,0 +1,162 @@ +import { encode, decode, convert } from './charset'; +/** + * Encodes all non printable and non ascii bytes to =XX form, where XX is the + * byte value in hex. This function does not convert linebreaks etc. it + * only escapes character sequences + * + * @param {String|Uint8Array} data Either a string or an Uint8Array + * @param {String} [fromCharset='UTF-8'] Source encoding + * @return {String} Mime encoded string + */ +export declare function mimeEncode(data?: string | Uint8Array, fromCharset?: string): string; +/** + * Decodes mime encoded string to an unicode string + * + * @param {String} str Mime encoded string + * @param {String} [fromCharset='UTF-8'] Source encoding + * @return {String} Decoded unicode string + */ +export declare function mimeDecode(str?: string, fromCharset?: string): string; +/** + * Encodes a string or an typed array of given charset into unicode + * base64 string. Also adds line breaks + * + * @param {String|Uint8Array} data String or typed array to be base64 encoded + * @param {String} Initial charset, e.g. 'binary'. Defaults to 'UTF-8' + * @return {String} Base64 encoded string + */ +export declare function base64Encode(data: string | Uint8Array, fromCharset?: string): string; +/** + * Decodes a base64 string of any charset into an unicode string + * + * @param {String} str Base64 encoded string + * @param {String} [fromCharset='UTF-8'] Original charset of the base64 encoded string + * @return {String} Decoded unicode string + */ +export declare function base64Decode(str: string, fromCharset?: string): string; +/** + * Encodes a string or an Uint8Array into a quoted printable encoding + * This is almost the same as mimeEncode, except line breaks will be changed + * as well to ensure that the lines are never longer than allowed length + * + * @param {String|Uint8Array} data String or an Uint8Array to mime encode + * @param {String} [fromCharset='UTF-8'] Original charset of the string + * @return {String} Mime encoded string + */ +export declare function quotedPrintableEncode(data?: string | Uint8Array, fromCharset?: string): string; +/** + * Decodes a string from a quoted printable encoding. This is almost the + * same as mimeDecode, except line breaks will be changed as well + * + * @param {String} str Mime encoded string to decode + * @param {String} [fromCharset='UTF-8'] Original charset of the string + * @return {String} Mime decoded string + */ +export declare function quotedPrintableDecode(str?: string, fromCharset?: string): string; +/** + * Encodes a string or an Uint8Array to an UTF-8 MIME Word + * https://tools.ietf.org/html/rfc2047 + * + * @param {String|Uint8Array} data String to be encoded + * @param {String} mimeWordEncoding='Q' Encoding for the mime word, either Q or B + * @param {String} [fromCharset='UTF-8'] Source sharacter set + * @return {String} Single or several mime words joined together + */ +export declare function mimeWordEncode(data: string | Uint8Array, mimeWordEncoding?: string, fromCharset?: string): string; +/** + * Finds word sequences with non ascii text and converts these to mime words + * + * @param {String|Uint8Array} data String to be encoded + * @param {String} mimeWordEncoding='Q' Encoding for the mime word, either Q or B + * @param {String} [fromCharset='UTF-8'] Source sharacter set + * @return {String} String with possible mime words + */ +export declare function mimeWordsEncode(data?: string | Uint8Array, mimeWordEncoding?: string, fromCharset?: string): string; +/** + * Decode a complete mime word encoded string + * + * @param {String} str Mime word encoded string + * @return {String} Decoded unicode string + */ +export declare function mimeWordDecode(str?: string): string; +/** + * Decode a string that might include one or several mime words + * + * @param {String} str String including some mime words that will be encoded + * @return {String} Decoded unicode string + */ +export declare function mimeWordsDecode(str?: string): string; +/** + * Folds long lines, useful for folding header lines (afterSpace=false) and + * flowed text (afterSpace=true) + * + * @param {String} str String to be folded + * @param {Boolean} afterSpace If true, leave a space in th end of a line + * @return {String} String with folded lines + */ +export declare function foldLines(str?: string, afterSpace?: boolean): string; +/** + * Encodes and folds a header line for a MIME message header. + * Shorthand for mimeWordsEncode + foldLines + * + * @param {String} key Key name, will not be encoded + * @param {String|Uint8Array} value Value to be encoded + * @param {String} [fromCharset='UTF-8'] Character set of the value + * @return {String} encoded and folded header line + */ +export declare function headerLineEncode(key: string, value: string | Uint8Array, fromCharset?: string): string; +/** + * The result is not mime word decoded, you need to do your own decoding based + * on the rules for the specific header key + * + * @param {String} headerLine Single header line, might include linebreaks as well if folded + * @return {Object} And object of {key, value} + */ +export declare function headerLineDecode(headerLine?: string): { + key: string; + value: string; +}; +/** + * Parses a block of header lines. Does not decode mime words as every + * header might have its own rules (eg. formatted email addresses and such) + * + * @param {String} headers Headers string + * @return {Object} An object of headers, where header keys are object keys. NB! Several values with the same key make up an Array + */ +export declare function headerLinesDecode(headers: string): Record; +/** + * Parses a header value with key=value arguments into a structured + * object. + * + * parseHeaderValue('content-type: text/plain; CHARSET='UTF-8'') -> + * { + * 'value': 'text/plain', + * 'params': { + * 'charset': 'UTF-8' + * } + * } + * + * @param {String} str Header value + * @return {Object} Header value as a parsed structure + */ +export declare function parseHeaderValue(str: string): { + value: string | false; + params: Record; +}; +/** + * Encodes a string or an Uint8Array to an UTF-8 Parameter Value Continuation encoding (rfc2231) + * Useful for splitting long parameter values. + * + * For example + * title="unicode string" + * becomes + * title*0*="utf-8''unicode" + * title*1*="%20string" + * + * @param {String|Uint8Array} data String to be encoded + * @param {Number} [maxLength=50] Max length for generated chunks + * @param {String} [fromCharset='UTF-8'] Source sharacter set + * @return {Array} A list of encoded keys and headers + */ +export declare function continuationEncode(key: string | Uint8Array, data: string, maxLength: number, fromCharset?: string): Array>; +export { decode, encode, convert }; diff --git a/dist/mimecodec.js b/dist/mimecodec.js index 8fe47c7..36a10c6 100644 --- a/dist/mimecodec.js +++ b/dist/mimecodec.js @@ -1,35 +1,56 @@ -'use strict'; +"use strict"; +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } Object.defineProperty(exports, "__esModule", { value: true }); -exports.convert = exports.encode = exports.decode = undefined; - -var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; - -exports.mimeEncode = mimeEncode; -exports.mimeDecode = mimeDecode; -exports.base64Encode = base64Encode; exports.base64Decode = base64Decode; -exports.quotedPrintableEncode = quotedPrintableEncode; -exports.quotedPrintableDecode = quotedPrintableDecode; -exports.mimeWordEncode = mimeWordEncode; -exports.mimeWordsEncode = mimeWordsEncode; -exports.mimeWordDecode = mimeWordDecode; -exports.mimeWordsDecode = mimeWordsDecode; +exports.base64Encode = base64Encode; +exports.continuationEncode = continuationEncode; +Object.defineProperty(exports, "convert", { + enumerable: true, + get: function get() { + return _charset.convert; + } +}); +Object.defineProperty(exports, "decode", { + enumerable: true, + get: function get() { + return _charset.decode; + } +}); +Object.defineProperty(exports, "encode", { + enumerable: true, + get: function get() { + return _charset.encode; + } +}); exports.foldLines = foldLines; -exports.headerLineEncode = headerLineEncode; exports.headerLineDecode = headerLineDecode; +exports.headerLineEncode = headerLineEncode; exports.headerLinesDecode = headerLinesDecode; +exports.mimeDecode = mimeDecode; +exports.mimeEncode = mimeEncode; +exports.mimeWordDecode = mimeWordDecode; +exports.mimeWordEncode = mimeWordEncode; +exports.mimeWordsDecode = mimeWordsDecode; +exports.mimeWordsEncode = mimeWordsEncode; exports.parseHeaderValue = parseHeaderValue; -exports.continuationEncode = continuationEncode; - -var _emailjsBase = require('emailjs-base64'); - -var _charset = require('./charset'); - -var _ramda = require('ramda'); - +exports.quotedPrintableDecode = quotedPrintableDecode; +exports.quotedPrintableEncode = quotedPrintableEncode; +var _emailjsBase = require("emailjs-base64"); +var _charset = require("./charset"); +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; } +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) { _defineProperty(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; } +function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); } +function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } +function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } +function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } +function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } +function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i["return"] && (_r = _i["return"](), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } } +function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } // Lines can't be longer than 76 + = 78 bytes // http://tools.ietf.org/html/rfc2045#section-6.7 var MAX_LINE_LENGTH = 76; @@ -48,21 +69,25 @@ var MAX_B64_MIME_WORD_BYTE_LENGTH = 39; function mimeEncode() { var data = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; var fromCharset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'UTF-8'; - var buffer = (0, _charset.convert)(data, fromCharset); return buffer.reduce(function (aggregate, ord, index) { return _checkRanges(ord) && !((ord === 0x20 || ord === 0x09) && (index === buffer.length - 1 || buffer[index + 1] === 0x0a || buffer[index + 1] === 0x0d)) ? aggregate + String.fromCharCode(ord) // if the char is in allowed range, then keep as is, unless it is a ws in the end of a line : aggregate + '=' + (ord < 0x10 ? '0' : '') + ord.toString(16).toUpperCase(); }, ''); - function _checkRanges(nr) { - var ranges = [// https://tools.ietf.org/html/rfc2045#section-6.7 - [0x09], // - [0x0A], // - [0x0D], // - [0x20, 0x3C], // !"#$%&'()*+,-./0123456789:; - [0x3E, 0x7E] // >?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|} + var ranges = [ + // https://tools.ietf.org/html/rfc2045#section-6.7 + [0x09], + // + [0x0a], + // + [0x0d], + // + [0x20, 0x3c], + // !"#$%&'()*+,-./0123456789:; + [0x3e, 0x7e] // >?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|} ]; + return ranges.reduce(function (val, range) { return val || range.length === 1 && nr === range[0] || range.length === 2 && nr >= range[0] && nr <= range[1]; }, false); @@ -77,12 +102,11 @@ function mimeEncode() { * @return {String} Decoded unicode string */ function mimeDecode() { + var _str$match; var str = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; var fromCharset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'UTF-8'; - - var encodedBytesCount = (str.match(/=[\da-fA-F]{2}/g) || []).length; + var encodedBytesCount = ((_str$match = str.match(/=[\da-fA-F]{2}/g)) !== null && _str$match !== void 0 ? _str$match : []).length; var buffer = new Uint8Array(str.length - encodedBytesCount * 2); - for (var i = 0, len = str.length, bufferPos = 0; i < len; i++) { var hex = str.substr(i + 1, 2); var chr = str.charAt(i); @@ -93,7 +117,6 @@ function mimeDecode() { buffer[bufferPos++] = chr.charCodeAt(0); } } - return (0, _charset.decode)(buffer, fromCharset); } @@ -107,7 +130,6 @@ function mimeDecode() { */ function base64Encode(data) { var fromCharset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'UTF-8'; - var buf = typeof data !== 'string' && fromCharset === 'binary' ? data : (0, _charset.convert)(data, fromCharset); var b64 = (0, _emailjsBase.encode)(buf); return _addBase64SoftLinebreaks(b64); @@ -137,7 +159,6 @@ function base64Decode(str, fromCharset) { function quotedPrintableEncode() { var data = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; var fromCharset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'UTF-8'; - var mimeEncodedStr = mimeEncode(data, fromCharset).replace(/\r?\n|\r/g, '\r\n') // fix line breaks, ensure .replace(/[\t ]+$/gm, function (spaces) { return spaces.replace(/ /g, '=20').replace(/\t/g, '=09'); @@ -157,7 +178,6 @@ function quotedPrintableEncode() { function quotedPrintableDecode() { var str = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; var fromCharset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'UTF-8'; - var rawString = str.replace(/[\t ]+$/gm, '') // remove invalid whitespace from the end of lines .replace(/=(?:\r?\n|$)/g, ''); // remove soft line breaks @@ -176,13 +196,11 @@ function quotedPrintableDecode() { function mimeWordEncode(data) { var mimeWordEncoding = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'Q'; var fromCharset = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'UTF-8'; - var parts = []; var str = typeof data === 'string' ? data : (0, _charset.decode)(data, fromCharset); - if (mimeWordEncoding === 'Q') { var _str = typeof data === 'string' ? data : (0, _charset.decode)(data, fromCharset); - var encodedStr = (0, _ramda.pipe)(mimeEncode, qEncodeForbiddenHeaderChars)(_str); + var encodedStr = qEncodeForbiddenHeaderChars(mimeEncode(_str)); parts = encodedStr.length < MAX_MIME_WORD_LENGTH ? [encodedStr] : _splitMimeEncodedString(encodedStr, MAX_MIME_WORD_LENGTH); } else { // Fits as much as possible into every line without breaking utf-8 multibyte characters' octets up across lines @@ -201,7 +219,6 @@ function mimeWordEncode(data) { str.substring(j) && parts.push(str.substring(j)); parts = parts.map(_charset.encode).map(_emailjsBase.encode); } - var prefix = '=?UTF-8?' + mimeWordEncoding + '?'; var suffix = '?= '; return parts.map(function (p) { @@ -217,7 +234,7 @@ var qEncodeForbiddenHeaderChars = function qEncodeForbiddenHeaderChars(str) { var qEncode = function qEncode(chr) { return chr === ' ' ? '_' : '=' + (chr.charCodeAt(0) < 0x10 ? '0' : '') + chr.charCodeAt(0).toString(16).toUpperCase(); }; - return str.replace(/[^a-z0-9!*+\-/=]/ig, qEncode); + return str.replace(/[^a-z0-9!*+\-/=]/gi, qEncode); }; /** @@ -232,7 +249,6 @@ function mimeWordsEncode() { var data = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; var mimeWordEncoding = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'Q'; var fromCharset = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'UTF-8'; - var regex = /([^\s\u0080-\uFFFF]*[\u0080-\uFFFF]+[^\s\u0080-\uFFFF]*(?:\s+[^\s\u0080-\uFFFF]*[\u0080-\uFFFF]+[^\s\u0080-\uFFFF]*\s*)?)+(?=\s|$)/g; return (0, _charset.decode)((0, _charset.convert)(data, fromCharset)).replace(regex, function (match) { return match.length ? mimeWordEncode(match, mimeWordEncoding, fromCharset) : ''; @@ -247,7 +263,6 @@ function mimeWordsEncode() { */ function mimeWordDecode() { var str = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; - var match = str.match(/^=\?([\w_\-*]+)\?([QqBb])\?([^?]*)\?=$/i); if (!match) return str; @@ -257,7 +272,6 @@ function mimeWordDecode() { var fromCharset = match[1].split('*').shift(); var encoding = (match[2] || 'Q').toString().toUpperCase(); var rawString = (match[3] || '').replace(/_/g, ' '); - if (encoding === 'B') { return base64Decode(rawString, fromCharset); } else if (encoding === 'Q') { @@ -275,10 +289,9 @@ function mimeWordDecode() { */ function mimeWordsDecode() { var str = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; - str = str.toString().replace(/(=\?[^?]+\?[QqBb]\?[^?]+\?=)\s+(?==\?[^?]+\?[QqBb]\?[^?]*\?=)/g, '$1'); // join bytes of multi-byte UTF-8 - var prevEncoding = void 0; + var prevEncoding; str = str.replace(/(\?=)?=\?[uU][tT][fF]-8\?([QqBb])\?/g, function (match, endOfPrevWord, encoding) { var result = endOfPrevWord && encoding === prevEncoding ? '' : match; prevEncoding = encoding; @@ -287,7 +300,6 @@ function mimeWordsDecode() { str = str.replace(/=\?[\w_\-*]+\?[QqBb]\?[^?]*\?=/g, function (mimeWord) { return mimeWordDecode(mimeWord.replace(/\s+/g, '')); }); - return str; } @@ -301,14 +313,11 @@ function mimeWordsDecode() { */ function foldLines() { var str = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; - var afterSpace = arguments[1]; - + var afterSpace = arguments.length > 1 ? arguments[1] : undefined; var pos = 0; var len = str.length; var result = ''; - var line = void 0, - match = void 0; - + var line, match; while (pos < len) { line = str.substr(pos, MAX_LINE_LENGTH); if (line.length < MAX_LINE_LENGTH) { @@ -325,14 +334,12 @@ function foldLines() { } else if (match = str.substr(pos + line.length).match(/^[^\s]+(\s*)/)) { line = line + match[0].substr(0, match[0].length - (!afterSpace ? (match[1] || '').length : 0)); } - result += line; pos += line.length; if (pos < len) { result += '\r\n'; } } - return result; } @@ -358,14 +365,13 @@ function headerLineEncode(key, value, fromCharset) { * @return {Object} And object of {key, value} */ function headerLineDecode() { + var _match$, _match$2; var headerLine = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; - var line = headerLine.toString().replace(/(?:\r?\n|\r)[ \t]*/g, ' ').trim(); var match = line.match(/^\s*([^:]+):(.*)$/); - return { - key: (match && match[1] || '').trim(), - value: (match && match[2] || '').trim() + key: ((_match$ = match === null || match === void 0 ? void 0 : match[1]) !== null && _match$ !== void 0 ? _match$ : '').trim(), + value: ((_match$2 = match === null || match === void 0 ? void 0 : match[2]) !== null && _match$2 !== void 0 ? _match$2 : '').trim() }; } @@ -378,27 +384,31 @@ function headerLineDecode() { */ function headerLinesDecode(headers) { var lines = headers.split(/\r?\n|\r/); - var headersObj = {}; - + var headersObjArr = {}; for (var i = lines.length - 1; i >= 0; i--) { if (i && lines[i].match(/^\s/)) { lines[i - 1] += '\r\n' + lines[i]; lines.splice(i, 1); } } - for (var _i = 0, len = lines.length; _i < len; _i++) { var header = headerLineDecode(lines[_i]); var key = header.key.toLowerCase(); var value = header.value; - - if (!headersObj[key]) { - headersObj[key] = value; + if (!headersObjArr[key]) { + headersObjArr[key] = [value]; } else { - headersObj[key] = [].concat(headersObj[key], value); + headersObjArr[key].push(value); } } + // convert single value arrays to single values + var headersObj = Object.fromEntries(Object.entries(headersObjArr).map(function (_ref) { + var _ref2 = _slicedToArray(_ref, 2), + key = _ref2[0], + value = _ref2[1]; + return value.length === 1 ? [key, value[0]] : [key, value]; + })); return headersObj; } @@ -418,17 +428,14 @@ function headerLinesDecode(headers) { * @return {Object} Header value as a parsed structure */ function parseHeaderValue(str) { - var response = { - value: false, - params: {} - }; var key = false; var value = ''; var type = 'value'; var quote = false; var escaped = false; - var chr = void 0; - + var chr; + var responseValue = false; + var initialParams = {}; for (var i = 0, len = str.length; i < len; i++) { chr = str.charAt(i); if (type === 'key') { @@ -450,10 +457,10 @@ function parseHeaderValue(str) { } else if (!quote && chr === '"') { quote = chr; } else if (!quote && chr === ';') { - if (key === false) { - response.value = value.trim(); + if (!key) { + responseValue = value.trim(); } else { - response.params[key] = value.trim(); + initialParams[key] = value.trim(); } type = 'key'; value = ''; @@ -463,70 +470,70 @@ function parseHeaderValue(str) { escaped = false; } } - if (type === 'value') { - if (key === false) { - response.value = value.trim(); + if (!key) { + responseValue = value.trim(); } else { - response.params[key] = value.trim(); + initialParams[key] = value.trim(); } } else if (value.trim()) { - response.params[value.trim().toLowerCase()] = ''; + initialParams[value.trim().toLowerCase()] = ''; } // handle parameter value continuations // https://tools.ietf.org/html/rfc2231#section-3 + var processedParams = {}; + // preprocess values - Object.keys(response.params).forEach(function (key) { + Object.keys(initialParams).forEach(function (key) { var actualKey, nr, match, value; if (match = key.match(/(\*(\d+)|\*(\d+)\*|\*)$/)) { actualKey = key.substr(0, match.index); nr = Number(match[2] || match[3]) || 0; - - if (!response.params[actualKey] || _typeof(response.params[actualKey]) !== 'object') { - response.params[actualKey] = { + if (!processedParams[actualKey]) { + processedParams[actualKey] = { charset: false, values: [] }; } - - value = response.params[key]; - + value = initialParams[key]; if (nr === 0 && match[0].substr(-1) === '*' && (match = value.match(/^([^']*)'[^']*'(.*)$/))) { - response.params[actualKey].charset = match[1] || 'iso-8859-1'; + processedParams[actualKey].charset = match[1] || 'iso-8859-1'; value = match[2]; } - - response.params[actualKey].values[nr] = value; + processedParams[actualKey].values[nr] = value; // remove the old reference - delete response.params[key]; + delete initialParams[key]; } }); + var concatenatedParams = {}; // concatenate split rfc2231 strings and convert encoded strings to mime encoded words - Object.keys(response.params).forEach(function (key) { + Object.keys(processedParams).forEach(function (key) { var value; - if (response.params[key] && Array.isArray(response.params[key].values)) { - value = response.params[key].values.map(function (val) { + if (processedParams[key] && Array.isArray(processedParams[key].values)) { + value = processedParams[key].values.map(function (val) { return val || ''; }).join(''); - - if (response.params[key].charset) { + if (processedParams[key].charset) { // convert "%AB" to "=?charset?Q?=AB?=" - response.params[key] = '=?' + response.params[key].charset + '?Q?' + value.replace(/[=?_\s]/g, function (s) { + concatenatedParams[key] = '=?' + processedParams[key].charset + '?Q?' + value.replace(/[=?_\s]/g, function (s) { // fix invalidly encoded chars var c = s.charCodeAt(0).toString(16); return s === ' ' ? '_' : '%' + (c.length < 2 ? '0' : '') + c; }).replace(/%/g, '=') + '?='; // change from urlencoding to percent encoding } else { - response.params[key] = value; + concatenatedParams[key] = value; } } }); - - return response; + var responseParams = _objectSpread(_objectSpread({}, initialParams), concatenatedParams); + return { + value: responseValue, + params: responseParams + }; } /** @@ -548,7 +555,6 @@ function continuationEncode(key, data, maxLength, fromCharset) { var list = []; var encodedStr = typeof data === 'string' ? data : (0, _charset.decode)(data, fromCharset); var line; - maxLength = maxLength || 50; // process ascii only text @@ -560,14 +566,12 @@ function continuationEncode(key, data, maxLength, fromCharset) { value: /[\s";=]/.test(encodedStr) ? '"' + encodedStr + '"' : encodedStr }]; } - - encodedStr = encodedStr.replace(new RegExp('.{' + maxLength + '}', 'g'), function (str) { + encodedStr = encodedStr.replace(new RegExp('.{' + maxLength.toString() + '}', 'g'), function (str) { list.push({ line: str }); return ''; }); - if (encodedStr) { list.push({ line: encodedStr @@ -575,8 +579,10 @@ function continuationEncode(key, data, maxLength, fromCharset) { } } else { // process text with unicode or special chars - var uriEncoded = encodeURIComponent('utf-8\'\'' + encodedStr); + var uriEncoded = encodeURIComponent("utf-8''" + encodedStr); var i = 0; + + // eslint-disable-next-line no-constant-condition while (true) { var len = maxLength; // must not split hex encoded byte between lines @@ -596,13 +602,12 @@ function continuationEncode(key, data, maxLength, fromCharset) { i += line.length; } } - return list.map(function (item, i) { return { // encoded lines: {name}*{part}* // unencoded lines: {name}*{part} // if any line needs to be encoded then the first line (part==0) is always encoded - key: key + '*' + i + (item.encoded ? '*' : ''), + key: key.toString() + '*' + i.toString() + (item.encoded ? '*' : ''), value: /[\s";=]/.test(item.line) ? '"' + item.line + '"' : item.line }; }); @@ -617,19 +622,15 @@ function continuationEncode(key, data, maxLength, fromCharset) { */ function _splitMimeEncodedString(str) { var maxlen = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 12; - var minWordLength = 12; // require at least 12 symbols to fit possible 4 octet UTF-8 sequences var maxWordLength = Math.max(maxlen, minWordLength); var lines = []; - while (str.length) { var curLine = str.substr(0, maxWordLength); - var match = curLine.match(/=[0-9A-F]?$/i); // skip incomplete escaped char if (match) { curLine = curLine.substr(0, match.index); } - var done = false; while (!done) { var chr = void 0; @@ -638,26 +639,22 @@ function _splitMimeEncodedString(str) { if (_match) { chr = parseInt(_match[1], 16); // invalid sequence, move one char back anc recheck - if (chr < 0xC2 && chr > 0x7F) { + if (chr < 0xc2 && chr > 0x7f) { curLine = curLine.substr(0, curLine.length - 3); done = false; } } } - if (curLine.length) { lines.push(curLine); } str = str.substr(curLine.length); } - return lines; } - function _addBase64SoftLinebreaks() { var base64EncodedStr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; - - return base64EncodedStr.trim().replace(new RegExp('.{' + MAX_LINE_LENGTH + '}', 'g'), '$&\r\n').trim(); + return base64EncodedStr.trim().replace(new RegExp('.{' + MAX_LINE_LENGTH.toString() + '}', 'g'), '$&\r\n').trim(); } /** @@ -668,24 +665,21 @@ function _addBase64SoftLinebreaks() { */ function _addQPSoftLinebreaks() { var qpEncodedStr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; - var pos = 0; var len = qpEncodedStr.length; var lineMargin = Math.floor(MAX_LINE_LENGTH / 3); var result = ''; - var match = void 0, - line = void 0; + var match, line; // insert soft linebreaks where needed while (pos < len) { line = qpEncodedStr.substr(pos, MAX_LINE_LENGTH); - if (match = line.match(/\r\n/)) { + if ((match = line.match(/\r\n/)) && match.index !== undefined) { line = line.substr(0, match.index + match[0].length); result += line; pos += line.length; continue; } - if (line.substr(-1) === '\n') { // nothing to change here result += line; @@ -710,21 +704,18 @@ function _addQPSoftLinebreaks() { } // ensure that utf-8 sequences are not split - while (line.length > 3 && line.length < len - pos && !line.match(/^(?:=[\da-f]{2}){1,4}$/i) && (match = line.match(/=[\da-f]{2}$/ig))) { + while (line.length > 3 && line.length < len - pos && !line.match(/^(?:=[\da-f]{2}){1,4}$/i) && (match = line.match(/=[\da-f]{2}$/gi))) { var code = parseInt(match[0].substr(1, 2), 16); if (code < 128) { break; } - line = line.substr(0, line.length - 3); - - if (code >= 0xC0) { + if (code >= 0xc0) { break; } } } } - if (pos + line.length < len && line.substr(-1) !== '\n') { if (line.length === MAX_LINE_LENGTH && line.match(/=[\da-f]{2}$/i)) { line = line.substr(0, line.length - 3); @@ -736,14 +727,7 @@ function _addQPSoftLinebreaks() { } else { pos += line.length; } - result += line; } - return result; -} - -exports.decode = _charset.decode; -exports.encode = _charset.encode; -exports.convert = _charset.convert; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/mimecodec.js"],"names":["mimeEncode","mimeDecode","base64Encode","base64Decode","quotedPrintableEncode","quotedPrintableDecode","mimeWordEncode","mimeWordsEncode","mimeWordDecode","mimeWordsDecode","foldLines","headerLineEncode","headerLineDecode","headerLinesDecode","parseHeaderValue","continuationEncode","MAX_LINE_LENGTH","MAX_MIME_WORD_LENGTH","MAX_B64_MIME_WORD_BYTE_LENGTH","data","fromCharset","buffer","reduce","aggregate","ord","index","_checkRanges","length","String","fromCharCode","toString","toUpperCase","nr","ranges","val","range","str","encodedBytesCount","match","Uint8Array","i","len","bufferPos","hex","substr","chr","charAt","test","parseInt","charCodeAt","buf","b64","_addBase64SoftLinebreaks","OUTPUT_TYPED_ARRAY","mimeEncodedStr","replace","spaces","_addQPSoftLinebreaks","rawString","mimeWordEncoding","parts","encodedStr","qEncodeForbiddenHeaderChars","_splitMimeEncodedString","j","substring","push","map","encode","encodeBase64","prefix","suffix","p","join","trim","qEncode","regex","split","shift","encoding","prevEncoding","endOfPrevWord","result","mimeWord","afterSpace","pos","line","key","value","encodedValue","headerLine","headers","lines","headersObj","splice","header","toLowerCase","concat","response","params","type","quote","escaped","Object","keys","forEach","actualKey","Number","charset","values","Array","isArray","s","c","maxLength","list","RegExp","uriEncoded","encodeURIComponent","encoded","item","maxlen","minWordLength","maxWordLength","Math","max","curLine","done","base64EncodedStr","qpEncodedStr","lineMargin","floor","code","decode","convert"],"mappings":";;;;;;;;;QAmBgBA,U,GAAAA,U;QA0BAC,U,GAAAA,U;QA0BAC,Y,GAAAA,Y;QAaAC,Y,GAAAA,Y;QAcAC,qB,GAAAA,qB;QAgBAC,qB,GAAAA,qB;QAiBAC,c,GAAAA,c;QAgDAC,e,GAAAA,e;QAWAC,c,GAAAA,c;QA0BAC,e,GAAAA,e;QAsBAC,S,GAAAA,S;QA0CAC,gB,GAAAA,gB;QAYAC,gB,GAAAA,gB;QAiBAC,iB,GAAAA,iB;QAyCAC,gB,GAAAA,gB;QAiIAC,kB,GAAAA,kB;;AA/dhB;;AACA;;AACA;;AAEA;AACA;AACA,IAAMC,kBAAkB,EAAxB;AACA,IAAMC,uBAAuB,EAA7B;AACA,IAAMC,gCAAgC,EAAtC;;AAEA;;;;;;;;;AASO,SAASlB,UAAT,GAAuD;AAAA,MAAlCmB,IAAkC,uEAA3B,EAA2B;AAAA,MAAvBC,WAAuB,uEAAT,OAAS;;AAC5D,MAAMC,SAAS,sBAAQF,IAAR,EAAcC,WAAd,CAAf;AACA,SAAOC,OAAOC,MAAP,CAAc,UAACC,SAAD,EAAYC,GAAZ,EAAiBC,KAAjB;AAAA,WACnBC,aAAaF,GAAb,KAAqB,EAAE,CAACA,QAAQ,IAAR,IAAgBA,QAAQ,IAAzB,MAAmCC,UAAUJ,OAAOM,MAAP,GAAgB,CAA1B,IAA+BN,OAAOI,QAAQ,CAAf,MAAsB,IAArD,IAA6DJ,OAAOI,QAAQ,CAAf,MAAsB,IAAtH,CAAF,CAArB,GACIF,YAAYK,OAAOC,YAAP,CAAoBL,GAApB,CADhB,CACyC;AADzC,MAEID,YAAY,GAAZ,IAAmBC,MAAM,IAAN,GAAa,GAAb,GAAmB,EAAtC,IAA4CA,IAAIM,QAAJ,CAAa,EAAb,EAAiBC,WAAjB,EAH7B;AAAA,GAAd,EAG2E,EAH3E,CAAP;;AAKA,WAASL,YAAT,CAAuBM,EAAvB,EAA2B;AACzB,QAAMC,SAAS,CAAE;AACf,KAAC,IAAD,CADa,EACL;AACR,KAAC,IAAD,CAFa,EAEL;AACR,KAAC,IAAD,CAHa,EAGL;AACR,KAAC,IAAD,EAAO,IAAP,CAJa,EAIC;AACd,KAAC,IAAD,EAAO,IAAP,CALa,CAKA;AALA,KAAf;AAOA,WAAOA,OAAOX,MAAP,CAAc,UAACY,GAAD,EAAMC,KAAN;AAAA,aAAgBD,OAAQC,MAAMR,MAAN,KAAiB,CAAjB,IAAsBK,OAAOG,MAAM,CAAN,CAArC,IAAmDA,MAAMR,MAAN,KAAiB,CAAjB,IAAsBK,MAAMG,MAAM,CAAN,CAA5B,IAAwCH,MAAMG,MAAM,CAAN,CAAjH;AAAA,KAAd,EAA0I,KAA1I,CAAP;AACD;AACF;;AAED;;;;;;;AAOO,SAASlC,UAAT,GAAsD;AAAA,MAAjCmC,GAAiC,uEAA3B,EAA2B;AAAA,MAAvBhB,WAAuB,uEAAT,OAAS;;AAC3D,MAAMiB,oBAAoB,CAACD,IAAIE,KAAJ,CAAU,iBAAV,KAAgC,EAAjC,EAAqCX,MAA/D;AACA,MAAIN,SAAS,IAAIkB,UAAJ,CAAeH,IAAIT,MAAJ,GAAaU,oBAAoB,CAAhD,CAAb;;AAEA,OAAK,IAAIG,IAAI,CAAR,EAAWC,MAAML,IAAIT,MAArB,EAA6Be,YAAY,CAA9C,EAAiDF,IAAIC,GAArD,EAA0DD,GAA1D,EAA+D;AAC7D,QAAIG,MAAMP,IAAIQ,MAAJ,CAAWJ,IAAI,CAAf,EAAkB,CAAlB,CAAV;AACA,QAAMK,MAAMT,IAAIU,MAAJ,CAAWN,CAAX,CAAZ;AACA,QAAIK,QAAQ,GAAR,IAAeF,GAAf,IAAsB,gBAAgBI,IAAhB,CAAqBJ,GAArB,CAA1B,EAAqD;AACnDtB,aAAOqB,WAAP,IAAsBM,SAASL,GAAT,EAAc,EAAd,CAAtB;AACAH,WAAK,CAAL;AACD,KAHD,MAGO;AACLnB,aAAOqB,WAAP,IAAsBG,IAAII,UAAJ,CAAe,CAAf,CAAtB;AACD;AACF;;AAED,SAAO,qBAAO5B,MAAP,EAAeD,WAAf,CAAP;AACD;;AAED;;;;;;;;AAQO,SAASlB,YAAT,CAAuBiB,IAAvB,EAAoD;AAAA,MAAvBC,WAAuB,uEAAT,OAAS;;AACzD,MAAM8B,MAAO,OAAO/B,IAAP,KAAgB,QAAhB,IAA4BC,gBAAgB,QAA7C,GAAyDD,IAAzD,GAAgE,sBAAQA,IAAR,EAAcC,WAAd,CAA5E;AACA,MAAM+B,MAAM,yBAAaD,GAAb,CAAZ;AACA,SAAOE,yBAAyBD,GAAzB,CAAP;AACD;;AAED;;;;;;;AAOO,SAAShD,YAAT,CAAuBiC,GAAvB,EAA4BhB,WAA5B,EAAyC;AAC9C,MAAM8B,MAAM,yBAAad,GAAb,EAAkBiB,+BAAlB,CAAZ;AACA,SAAOjC,gBAAgB,QAAhB,GAA2B,sBAAQ8B,GAAR,CAA3B,GAA0C,qBAAOA,GAAP,EAAY9B,WAAZ,CAAjD;AACD;;AAED;;;;;;;;;AASO,SAAShB,qBAAT,GAAkE;AAAA,MAAlCe,IAAkC,uEAA3B,EAA2B;AAAA,MAAvBC,WAAuB,uEAAT,OAAS;;AACvE,MAAMkC,iBAAiBtD,WAAWmB,IAAX,EAAiBC,WAAjB,EACpBmC,OADoB,CACZ,WADY,EACC,MADD,EACS;AADT,GAEpBA,OAFoB,CAEZ,WAFY,EAEC;AAAA,WAAUC,OAAOD,OAAP,CAAe,IAAf,EAAqB,KAArB,EAA4BA,OAA5B,CAAoC,KAApC,EAA2C,KAA3C,CAAV;AAAA,GAFD,CAAvB,CADuE,CAGc;;AAErF,SAAOE,qBAAqBH,cAArB,CAAP,CALuE,CAK3B;AAC7C;;AAED;;;;;;;;AAQO,SAASjD,qBAAT,GAAiE;AAAA,MAAjC+B,GAAiC,uEAA3B,EAA2B;AAAA,MAAvBhB,WAAuB,uEAAT,OAAS;;AACtE,MAAMsC,YAAYtB,IACfmB,OADe,CACP,WADO,EACM,EADN,EACU;AADV,GAEfA,OAFe,CAEP,eAFO,EAEU,EAFV,CAAlB,CADsE,CAGtC;;AAEhC,SAAOtD,WAAWyD,SAAX,EAAsBtC,WAAtB,CAAP;AACD;;AAED;;;;;;;;;AASO,SAASd,cAAT,CAAyBa,IAAzB,EAA8E;AAAA,MAA/CwC,gBAA+C,uEAA5B,GAA4B;AAAA,MAAvBvC,WAAuB,uEAAT,OAAS;;AACnF,MAAIwC,QAAQ,EAAZ;AACA,MAAMxB,MAAO,OAAOjB,IAAP,KAAgB,QAAjB,GAA6BA,IAA7B,GAAoC,qBAAOA,IAAP,EAAaC,WAAb,CAAhD;;AAEA,MAAIuC,qBAAqB,GAAzB,EAA8B;AAC5B,QAAMvB,OAAO,OAAOjB,IAAP,KAAgB,QAAjB,GAA6BA,IAA7B,GAAoC,qBAAOA,IAAP,EAAaC,WAAb,CAAhD;AACA,QAAIyC,aAAa,iBAAK7D,UAAL,EAAiB8D,2BAAjB,EAA8C1B,IAA9C,CAAjB;AACAwB,YAAQC,WAAWlC,MAAX,GAAoBV,oBAApB,GAA2C,CAAC4C,UAAD,CAA3C,GAA0DE,wBAAwBF,UAAxB,EAAoC5C,oBAApC,CAAlE;AACD,GAJD,MAIO;AACL;AACA,QAAI+C,IAAI,CAAR;AACA,QAAIxB,IAAI,CAAR;AACA,WAAOA,IAAIJ,IAAIT,MAAf,EAAuB;AACrB,UAAI,qBAAOS,IAAI6B,SAAJ,CAAcD,CAAd,EAAiBxB,CAAjB,CAAP,EAA4Bb,MAA5B,GAAqCT,6BAAzC,EAAwE;AACtE;AACA0C,cAAMM,IAAN,CAAW9B,IAAI6B,SAAJ,CAAcD,CAAd,EAAiBxB,IAAI,CAArB,CAAX;AACAwB,YAAIxB,IAAI,CAAR;AACD,OAJD,MAIO;AACLA;AACD;AACF;AACD;AACAJ,QAAI6B,SAAJ,CAAcD,CAAd,KAAoBJ,MAAMM,IAAN,CAAW9B,IAAI6B,SAAJ,CAAcD,CAAd,CAAX,CAApB;AACAJ,YAAQA,MAAMO,GAAN,CAAUC,eAAV,EAAkBD,GAAlB,CAAsBE,mBAAtB,CAAR;AACD;;AAED,MAAMC,SAAS,aAAaX,gBAAb,GAAgC,GAA/C;AACA,MAAMY,SAAS,KAAf;AACA,SAAOX,MAAMO,GAAN,CAAU;AAAA,WAAKG,SAASE,CAAT,GAAaD,MAAlB;AAAA,GAAV,EAAoCE,IAApC,CAAyC,EAAzC,EAA6CC,IAA7C,EAAP;AACD;;AAED;;;;AAIA,IAAMZ,8BAA8B,SAA9BA,2BAA8B,CAAU1B,GAAV,EAAe;AACjD,MAAMuC,UAAU,SAAVA,OAAU;AAAA,WAAO9B,QAAQ,GAAR,GAAc,GAAd,GAAqB,OAAOA,IAAII,UAAJ,CAAe,CAAf,IAAoB,IAApB,GAA2B,GAA3B,GAAiC,EAAxC,IAA8CJ,IAAII,UAAJ,CAAe,CAAf,EAAkBnB,QAAlB,CAA2B,EAA3B,EAA+BC,WAA/B,EAA1E;AAAA,GAAhB;AACA,SAAOK,IAAImB,OAAJ,CAAY,oBAAZ,EAAkCoB,OAAlC,CAAP;AACD,CAHD;;AAKA;;;;;;;;AAQO,SAASpE,eAAT,GAAoF;AAAA,MAA1DY,IAA0D,uEAAnD,EAAmD;AAAA,MAA/CwC,gBAA+C,uEAA5B,GAA4B;AAAA,MAAvBvC,WAAuB,uEAAT,OAAS;;AACzF,MAAMwD,QAAQ,qIAAd;AACA,SAAO,qBAAO,sBAAQzD,IAAR,EAAcC,WAAd,CAAP,EAAmCmC,OAAnC,CAA2CqB,KAA3C,EAAkD;AAAA,WAAStC,MAAMX,MAAN,GAAerB,eAAegC,KAAf,EAAsBqB,gBAAtB,EAAwCvC,WAAxC,CAAf,GAAsE,EAA/E;AAAA,GAAlD,CAAP;AACD;;AAED;;;;;;AAMO,SAASZ,cAAT,GAAmC;AAAA,MAAV4B,GAAU,uEAAJ,EAAI;;AACxC,MAAME,QAAQF,IAAIE,KAAJ,CAAU,yCAAV,CAAd;AACA,MAAI,CAACA,KAAL,EAAY,OAAOF,GAAP;;AAEZ;AACA;AACA;AACA,MAAMhB,cAAckB,MAAM,CAAN,EAASuC,KAAT,CAAe,GAAf,EAAoBC,KAApB,EAApB;AACA,MAAMC,WAAW,CAACzC,MAAM,CAAN,KAAY,GAAb,EAAkBR,QAAlB,GAA6BC,WAA7B,EAAjB;AACA,MAAM2B,YAAY,CAACpB,MAAM,CAAN,KAAY,EAAb,EAAiBiB,OAAjB,CAAyB,IAAzB,EAA+B,GAA/B,CAAlB;;AAEA,MAAIwB,aAAa,GAAjB,EAAsB;AACpB,WAAO5E,aAAauD,SAAb,EAAwBtC,WAAxB,CAAP;AACD,GAFD,MAEO,IAAI2D,aAAa,GAAjB,EAAsB;AAC3B,WAAO9E,WAAWyD,SAAX,EAAsBtC,WAAtB,CAAP;AACD,GAFM,MAEA;AACL,WAAOgB,GAAP;AACD;AACF;;AAED;;;;;;AAMO,SAAS3B,eAAT,GAAoC;AAAA,MAAV2B,GAAU,uEAAJ,EAAI;;AACzCA,QAAMA,IAAIN,QAAJ,GAAeyB,OAAf,CAAuB,gEAAvB,EAAyF,IAAzF,CAAN;AACA;AACA,MAAIyB,qBAAJ;AACA5C,QAAMA,IAAImB,OAAJ,CAAY,sCAAZ,EAAoD,UAACjB,KAAD,EAAQ2C,aAAR,EAAuBF,QAAvB,EAAoC;AAC5F,QAAMG,SAAUD,iBAAiBF,aAAaC,YAA/B,GAA+C,EAA/C,GAAoD1C,KAAnE;AACA0C,mBAAeD,QAAf;AACA,WAAOG,MAAP;AACD,GAJK,CAAN;AAKA9C,QAAMA,IAAImB,OAAJ,CAAY,iCAAZ,EAA+C;AAAA,WAAY/C,eAAe2E,SAAS5B,OAAT,CAAiB,MAAjB,EAAyB,EAAzB,CAAf,CAAZ;AAAA,GAA/C,CAAN;;AAEA,SAAOnB,GAAP;AACD;;AAED;;;;;;;;AAQO,SAAS1B,SAAT,GAA0C;AAAA,MAAtB0B,GAAsB,uEAAhB,EAAgB;AAAA,MAAZgD,UAAY;;AAC/C,MAAIC,MAAM,CAAV;AACA,MAAM5C,MAAML,IAAIT,MAAhB;AACA,MAAIuD,SAAS,EAAb;AACA,MAAII,aAAJ;AAAA,MAAUhD,cAAV;;AAEA,SAAO+C,MAAM5C,GAAb,EAAkB;AAChB6C,WAAOlD,IAAIQ,MAAJ,CAAWyC,GAAX,EAAgBrE,eAAhB,CAAP;AACA,QAAIsE,KAAK3D,MAAL,GAAcX,eAAlB,EAAmC;AACjCkE,gBAAUI,IAAV;AACA;AACD;AACD,QAAKhD,QAAQgD,KAAKhD,KAAL,CAAW,qBAAX,CAAb,EAAiD;AAC/CgD,aAAOhD,MAAM,CAAN,CAAP;AACA4C,gBAAUI,IAAV;AACAD,aAAOC,KAAK3D,MAAZ;AACA;AACD,KALD,MAKO,IAAI,CAACW,QAAQgD,KAAKhD,KAAL,CAAW,cAAX,CAAT,KAAwCA,MAAM,CAAN,EAASX,MAAT,IAAmByD,aAAa,CAAC9C,MAAM,CAAN,KAAY,EAAb,EAAiBX,MAA9B,GAAuC,CAA1D,IAA+D2D,KAAK3D,MAAhH,EAAwH;AAC7H2D,aAAOA,KAAK1C,MAAL,CAAY,CAAZ,EAAe0C,KAAK3D,MAAL,IAAeW,MAAM,CAAN,EAASX,MAAT,IAAmByD,aAAa,CAAC9C,MAAM,CAAN,KAAY,EAAb,EAAiBX,MAA9B,GAAuC,CAA1D,CAAf,CAAf,CAAP;AACD,KAFM,MAEA,IAAKW,QAAQF,IAAIQ,MAAJ,CAAWyC,MAAMC,KAAK3D,MAAtB,EAA8BW,KAA9B,CAAoC,cAApC,CAAb,EAAmE;AACxEgD,aAAOA,OAAOhD,MAAM,CAAN,EAASM,MAAT,CAAgB,CAAhB,EAAmBN,MAAM,CAAN,EAASX,MAAT,IAAmB,CAACyD,UAAD,GAAc,CAAC9C,MAAM,CAAN,KAAY,EAAb,EAAiBX,MAA/B,GAAwC,CAA3D,CAAnB,CAAd;AACD;;AAEDuD,cAAUI,IAAV;AACAD,WAAOC,KAAK3D,MAAZ;AACA,QAAI0D,MAAM5C,GAAV,EAAe;AACbyC,gBAAU,MAAV;AACD;AACF;;AAED,SAAOA,MAAP;AACD;;AAED;;;;;;;;;AASO,SAASvE,gBAAT,CAA2B4E,GAA3B,EAAgCC,KAAhC,EAAuCpE,WAAvC,EAAoD;AACzD,MAAIqE,eAAelF,gBAAgBiF,KAAhB,EAAuB,GAAvB,EAA4BpE,WAA5B,CAAnB;AACA,SAAOV,UAAU6E,MAAM,IAAN,GAAaE,YAAvB,CAAP;AACD;;AAED;;;;;;;AAOO,SAAS7E,gBAAT,GAA4C;AAAA,MAAjB8E,UAAiB,uEAAJ,EAAI;;AACjD,MAAMJ,OAAOI,WAAW5D,QAAX,GAAsByB,OAAtB,CAA8B,qBAA9B,EAAqD,GAArD,EAA0DmB,IAA1D,EAAb;AACA,MAAMpC,QAAQgD,KAAKhD,KAAL,CAAW,mBAAX,CAAd;;AAEA,SAAO;AACLiD,SAAK,CAAEjD,SAASA,MAAM,CAAN,CAAV,IAAuB,EAAxB,EAA4BoC,IAA5B,EADA;AAELc,WAAO,CAAElD,SAASA,MAAM,CAAN,CAAV,IAAuB,EAAxB,EAA4BoC,IAA5B;AAFF,GAAP;AAID;;AAED;;;;;;;AAOO,SAAS7D,iBAAT,CAA4B8E,OAA5B,EAAqC;AAC1C,MAAMC,QAAQD,QAAQd,KAAR,CAAc,UAAd,CAAd;AACA,MAAMgB,aAAa,EAAnB;;AAEA,OAAK,IAAIrD,IAAIoD,MAAMjE,MAAN,GAAe,CAA5B,EAA+Ba,KAAK,CAApC,EAAuCA,GAAvC,EAA4C;AAC1C,QAAIA,KAAKoD,MAAMpD,CAAN,EAASF,KAAT,CAAe,KAAf,CAAT,EAAgC;AAC9BsD,YAAMpD,IAAI,CAAV,KAAgB,SAASoD,MAAMpD,CAAN,CAAzB;AACAoD,YAAME,MAAN,CAAatD,CAAb,EAAgB,CAAhB;AACD;AACF;;AAED,OAAK,IAAIA,KAAI,CAAR,EAAWC,MAAMmD,MAAMjE,MAA5B,EAAoCa,KAAIC,GAAxC,EAA6CD,IAA7C,EAAkD;AAChD,QAAMuD,SAASnF,iBAAiBgF,MAAMpD,EAAN,CAAjB,CAAf;AACA,QAAM+C,MAAMQ,OAAOR,GAAP,CAAWS,WAAX,EAAZ;AACA,QAAMR,QAAQO,OAAOP,KAArB;;AAEA,QAAI,CAACK,WAAWN,GAAX,CAAL,EAAsB;AACpBM,iBAAWN,GAAX,IAAkBC,KAAlB;AACD,KAFD,MAEO;AACLK,iBAAWN,GAAX,IAAkB,GAAGU,MAAH,CAAUJ,WAAWN,GAAX,CAAV,EAA2BC,KAA3B,CAAlB;AACD;AACF;;AAED,SAAOK,UAAP;AACD;;AAED;;;;;;;;;;;;;;;AAeO,SAAS/E,gBAAT,CAA2BsB,GAA3B,EAAgC;AACrC,MAAI8D,WAAW;AACbV,WAAO,KADM;AAEbW,YAAQ;AAFK,GAAf;AAIA,MAAIZ,MAAM,KAAV;AACA,MAAIC,QAAQ,EAAZ;AACA,MAAIY,OAAO,OAAX;AACA,MAAIC,QAAQ,KAAZ;AACA,MAAIC,UAAU,KAAd;AACA,MAAIzD,YAAJ;;AAEA,OAAK,IAAIL,IAAI,CAAR,EAAWC,MAAML,IAAIT,MAA1B,EAAkCa,IAAIC,GAAtC,EAA2CD,GAA3C,EAAgD;AAC9CK,UAAMT,IAAIU,MAAJ,CAAWN,CAAX,CAAN;AACA,QAAI4D,SAAS,KAAb,EAAoB;AAClB,UAAIvD,QAAQ,GAAZ,EAAiB;AACf0C,cAAMC,MAAMd,IAAN,GAAasB,WAAb,EAAN;AACAI,eAAO,OAAP;AACAZ,gBAAQ,EAAR;AACA;AACD;AACDA,eAAS3C,GAAT;AACD,KARD,MAQO;AACL,UAAIyD,OAAJ,EAAa;AACXd,iBAAS3C,GAAT;AACD,OAFD,MAEO,IAAIA,QAAQ,IAAZ,EAAkB;AACvByD,kBAAU,IAAV;AACA;AACD,OAHM,MAGA,IAAID,SAASxD,QAAQwD,KAArB,EAA4B;AACjCA,gBAAQ,KAAR;AACD,OAFM,MAEA,IAAI,CAACA,KAAD,IAAUxD,QAAQ,GAAtB,EAA2B;AAChCwD,gBAAQxD,GAAR;AACD,OAFM,MAEA,IAAI,CAACwD,KAAD,IAAUxD,QAAQ,GAAtB,EAA2B;AAChC,YAAI0C,QAAQ,KAAZ,EAAmB;AACjBW,mBAASV,KAAT,GAAiBA,MAAMd,IAAN,EAAjB;AACD,SAFD,MAEO;AACLwB,mBAASC,MAAT,CAAgBZ,GAAhB,IAAuBC,MAAMd,IAAN,EAAvB;AACD;AACD0B,eAAO,KAAP;AACAZ,gBAAQ,EAAR;AACD,OARM,MAQA;AACLA,iBAAS3C,GAAT;AACD;AACDyD,gBAAU,KAAV;AACD;AACF;;AAED,MAAIF,SAAS,OAAb,EAAsB;AACpB,QAAIb,QAAQ,KAAZ,EAAmB;AACjBW,eAASV,KAAT,GAAiBA,MAAMd,IAAN,EAAjB;AACD,KAFD,MAEO;AACLwB,eAASC,MAAT,CAAgBZ,GAAhB,IAAuBC,MAAMd,IAAN,EAAvB;AACD;AACF,GAND,MAMO,IAAIc,MAAMd,IAAN,EAAJ,EAAkB;AACvBwB,aAASC,MAAT,CAAgBX,MAAMd,IAAN,GAAasB,WAAb,EAAhB,IAA8C,EAA9C;AACD;;AAED;AACA;;AAEA;AACAO,SAAOC,IAAP,CAAYN,SAASC,MAArB,EAA6BM,OAA7B,CAAqC,UAAUlB,GAAV,EAAe;AAClD,QAAImB,SAAJ,EAAe1E,EAAf,EAAmBM,KAAnB,EAA0BkD,KAA1B;AACA,QAAKlD,QAAQiD,IAAIjD,KAAJ,CAAU,yBAAV,CAAb,EAAoD;AAClDoE,kBAAYnB,IAAI3C,MAAJ,CAAW,CAAX,EAAcN,MAAMb,KAApB,CAAZ;AACAO,WAAK2E,OAAOrE,MAAM,CAAN,KAAYA,MAAM,CAAN,CAAnB,KAAgC,CAArC;;AAEA,UAAI,CAAC4D,SAASC,MAAT,CAAgBO,SAAhB,CAAD,IAA+B,QAAOR,SAASC,MAAT,CAAgBO,SAAhB,CAAP,MAAsC,QAAzE,EAAmF;AACjFR,iBAASC,MAAT,CAAgBO,SAAhB,IAA6B;AAC3BE,mBAAS,KADkB;AAE3BC,kBAAQ;AAFmB,SAA7B;AAID;;AAEDrB,cAAQU,SAASC,MAAT,CAAgBZ,GAAhB,CAAR;;AAEA,UAAIvD,OAAO,CAAP,IAAYM,MAAM,CAAN,EAASM,MAAT,CAAgB,CAAC,CAAjB,MAAwB,GAApC,KAA4CN,QAAQkD,MAAMlD,KAAN,CAAY,sBAAZ,CAApD,CAAJ,EAA8F;AAC5F4D,iBAASC,MAAT,CAAgBO,SAAhB,EAA2BE,OAA3B,GAAqCtE,MAAM,CAAN,KAAY,YAAjD;AACAkD,gBAAQlD,MAAM,CAAN,CAAR;AACD;;AAED4D,eAASC,MAAT,CAAgBO,SAAhB,EAA2BG,MAA3B,CAAkC7E,EAAlC,IAAwCwD,KAAxC;;AAEA;AACA,aAAOU,SAASC,MAAT,CAAgBZ,GAAhB,CAAP;AACD;AACF,GAzBD;;AA2BA;AACAgB,SAAOC,IAAP,CAAYN,SAASC,MAArB,EAA6BM,OAA7B,CAAqC,UAAUlB,GAAV,EAAe;AAClD,QAAIC,KAAJ;AACA,QAAIU,SAASC,MAAT,CAAgBZ,GAAhB,KAAwBuB,MAAMC,OAAN,CAAcb,SAASC,MAAT,CAAgBZ,GAAhB,EAAqBsB,MAAnC,CAA5B,EAAwE;AACtErB,cAAQU,SAASC,MAAT,CAAgBZ,GAAhB,EAAqBsB,MAArB,CAA4B1C,GAA5B,CAAgC,UAAUjC,GAAV,EAAe;AACrD,eAAOA,OAAO,EAAd;AACD,OAFO,EAELuC,IAFK,CAEA,EAFA,CAAR;;AAIA,UAAIyB,SAASC,MAAT,CAAgBZ,GAAhB,EAAqBqB,OAAzB,EAAkC;AAChC;AACAV,iBAASC,MAAT,CAAgBZ,GAAhB,IAAuB,OAAOW,SAASC,MAAT,CAAgBZ,GAAhB,EAAqBqB,OAA5B,GAAsC,KAAtC,GAA8CpB,MAClEjC,OADkE,CAC1D,UAD0D,EAC9C,UAAUyD,CAAV,EAAa;AAChC;AACA,cAAIC,IAAID,EAAE/D,UAAF,CAAa,CAAb,EAAgBnB,QAAhB,CAAyB,EAAzB,CAAR;AACA,iBAAOkF,MAAM,GAAN,GAAY,GAAZ,GAAkB,OAAOC,EAAEtF,MAAF,GAAW,CAAX,GAAe,GAAf,GAAqB,EAA5B,IAAkCsF,CAA3D;AACD,SALkE,EAMlE1D,OANkE,CAM1D,IAN0D,EAMpD,GANoD,CAA9C,GAMC,IANxB,CAFgC,CAQH;AAC9B,OATD,MASO;AACL2C,iBAASC,MAAT,CAAgBZ,GAAhB,IAAuBC,KAAvB;AACD;AACF;AACF,GApBD;;AAsBA,SAAOU,QAAP;AACD;;AAED;;;;;;;;;;;;;;;AAeO,SAASnF,kBAAT,CAA6BwE,GAA7B,EAAkCpE,IAAlC,EAAwC+F,SAAxC,EAAmD9F,WAAnD,EAAgE;AACrE,MAAM+F,OAAO,EAAb;AACA,MAAItD,aAAa,OAAO1C,IAAP,KAAgB,QAAhB,GAA2BA,IAA3B,GAAkC,qBAAOA,IAAP,EAAaC,WAAb,CAAnD;AACA,MAAIkE,IAAJ;;AAEA4B,cAAYA,aAAa,EAAzB;;AAEA;AACA,MAAI,cAAcnE,IAAd,CAAmB5B,IAAnB,CAAJ,EAA8B;AAC5B;AACA,QAAI0C,WAAWlC,MAAX,IAAqBuF,SAAzB,EAAoC;AAClC,aAAO,CAAC;AACN3B,aAAKA,GADC;AAENC,eAAO,UAAUzC,IAAV,CAAec,UAAf,IAA6B,MAAMA,UAAN,GAAmB,GAAhD,GAAsDA;AAFvD,OAAD,CAAP;AAID;;AAEDA,iBAAaA,WAAWN,OAAX,CAAmB,IAAI6D,MAAJ,CAAW,OAAOF,SAAP,GAAmB,GAA9B,EAAmC,GAAnC,CAAnB,EAA4D,UAAU9E,GAAV,EAAe;AACtF+E,WAAKjD,IAAL,CAAU;AACRoB,cAAMlD;AADE,OAAV;AAGA,aAAO,EAAP;AACD,KALY,CAAb;;AAOA,QAAIyB,UAAJ,EAAgB;AACdsD,WAAKjD,IAAL,CAAU;AACRoB,cAAMzB;AADE,OAAV;AAGD;AACF,GArBD,MAqBO;AACL;AACA,QAAMwD,aAAaC,mBAAmB,cAAczD,UAAjC,CAAnB;AACA,QAAIrB,IAAI,CAAR;AACA,WAAO,IAAP,EAAa;AACX,UAAIC,MAAMyE,SAAV;AACA;AACA,UAAIG,WAAW7E,IAAI0E,SAAJ,GAAgB,CAA3B,MAAkC,GAAtC,EAA2C;AACzCzE,eAAO,CAAP;AACD,OAFD,MAEO,IAAI4E,WAAW7E,IAAI0E,SAAJ,GAAgB,CAA3B,MAAkC,GAAtC,EAA2C;AAChDzE,eAAO,CAAP;AACD;AACD6C,aAAO+B,WAAWzE,MAAX,CAAkBJ,CAAlB,EAAqBC,GAArB,CAAP;AACA,UAAI,CAAC6C,IAAL,EAAW;AACT;AACD;AACD6B,WAAKjD,IAAL,CAAU;AACRoB,cAAMA,IADE;AAERiC,iBAAS;AAFD,OAAV;AAIA/E,WAAK8C,KAAK3D,MAAV;AACD;AACF;;AAED,SAAOwF,KAAKhD,GAAL,CAAS,UAAUqD,IAAV,EAAgBhF,CAAhB,EAAmB;AACjC,WAAO;AACL;AACA;AACA;AACA+C,WAAKA,MAAM,GAAN,GAAY/C,CAAZ,IAAiBgF,KAAKD,OAAL,GAAe,GAAf,GAAqB,EAAtC,CAJA;AAKL/B,aAAO,UAAUzC,IAAV,CAAeyE,KAAKlC,IAApB,IAA4B,MAAMkC,KAAKlC,IAAX,GAAkB,GAA9C,GAAoDkC,KAAKlC;AAL3D,KAAP;AAOD,GARM,CAAP;AASD;;AAED;;;;;;;AAOA,SAASvB,uBAAT,CAAkC3B,GAAlC,EAAoD;AAAA,MAAbqF,MAAa,uEAAJ,EAAI;;AAClD,MAAMC,gBAAgB,EAAtB,CADkD,CACzB;AACzB,MAAMC,gBAAgBC,KAAKC,GAAL,CAASJ,MAAT,EAAiBC,aAAjB,CAAtB;AACA,MAAM9B,QAAQ,EAAd;;AAEA,SAAOxD,IAAIT,MAAX,EAAmB;AACjB,QAAImG,UAAU1F,IAAIQ,MAAJ,CAAW,CAAX,EAAc+E,aAAd,CAAd;;AAEA,QAAMrF,QAAQwF,QAAQxF,KAAR,CAAc,cAAd,CAAd,CAHiB,CAG2B;AAC5C,QAAIA,KAAJ,EAAW;AACTwF,gBAAUA,QAAQlF,MAAR,CAAe,CAAf,EAAkBN,MAAMb,KAAxB,CAAV;AACD;;AAED,QAAIsG,OAAO,KAAX;AACA,WAAO,CAACA,IAAR,EAAc;AACZ,UAAIlF,YAAJ;AACAkF,aAAO,IAAP;AACA,UAAMzF,SAAQF,IAAIQ,MAAJ,CAAWkF,QAAQnG,MAAnB,EAA2BW,KAA3B,CAAiC,kBAAjC,CAAd,CAHY,CAGuD;AACnE,UAAIA,MAAJ,EAAW;AACTO,cAAMG,SAASV,OAAM,CAAN,CAAT,EAAmB,EAAnB,CAAN;AACA;AACA,YAAIO,MAAM,IAAN,IAAcA,MAAM,IAAxB,EAA8B;AAC5BiF,oBAAUA,QAAQlF,MAAR,CAAe,CAAf,EAAkBkF,QAAQnG,MAAR,GAAiB,CAAnC,CAAV;AACAoG,iBAAO,KAAP;AACD;AACF;AACF;;AAED,QAAID,QAAQnG,MAAZ,EAAoB;AAClBiE,YAAM1B,IAAN,CAAW4D,OAAX;AACD;AACD1F,UAAMA,IAAIQ,MAAJ,CAAWkF,QAAQnG,MAAnB,CAAN;AACD;;AAED,SAAOiE,KAAP;AACD;;AAED,SAASxC,wBAAT,GAA0D;AAAA,MAAvB4E,gBAAuB,uEAAJ,EAAI;;AACxD,SAAOA,iBAAiBtD,IAAjB,GAAwBnB,OAAxB,CAAgC,IAAI6D,MAAJ,CAAW,OAAOpG,eAAP,GAAyB,GAApC,EAAyC,GAAzC,CAAhC,EAA+E,QAA/E,EAAyF0D,IAAzF,EAAP;AACD;;AAED;;;;;;AAMA,SAASjB,oBAAT,GAAkD;AAAA,MAAnBwE,YAAmB,uEAAJ,EAAI;;AAChD,MAAI5C,MAAM,CAAV;AACA,MAAM5C,MAAMwF,aAAatG,MAAzB;AACA,MAAMuG,aAAaN,KAAKO,KAAL,CAAWnH,kBAAkB,CAA7B,CAAnB;AACA,MAAIkE,SAAS,EAAb;AACA,MAAI5C,cAAJ;AAAA,MAAWgD,aAAX;;AAEA;AACA,SAAOD,MAAM5C,GAAb,EAAkB;AAChB6C,WAAO2C,aAAarF,MAAb,CAAoByC,GAApB,EAAyBrE,eAAzB,CAAP;AACA,QAAKsB,QAAQgD,KAAKhD,KAAL,CAAW,MAAX,CAAb,EAAkC;AAChCgD,aAAOA,KAAK1C,MAAL,CAAY,CAAZ,EAAeN,MAAMb,KAAN,GAAca,MAAM,CAAN,EAASX,MAAtC,CAAP;AACAuD,gBAAUI,IAAV;AACAD,aAAOC,KAAK3D,MAAZ;AACA;AACD;;AAED,QAAI2D,KAAK1C,MAAL,CAAY,CAAC,CAAb,MAAoB,IAAxB,EAA8B;AAC5B;AACAsC,gBAAUI,IAAV;AACAD,aAAOC,KAAK3D,MAAZ;AACA;AACD,KALD,MAKO,IAAKW,QAAQgD,KAAK1C,MAAL,CAAY,CAACsF,UAAb,EAAyB5F,KAAzB,CAA+B,QAA/B,CAAb,EAAwD;AAC7D;AACAgD,aAAOA,KAAK1C,MAAL,CAAY,CAAZ,EAAe0C,KAAK3D,MAAL,IAAeW,MAAM,CAAN,EAASX,MAAT,GAAkB,CAAjC,CAAf,CAAP;AACAuD,gBAAUI,IAAV;AACAD,aAAOC,KAAK3D,MAAZ;AACA;AACD,KANM,MAMA,IAAI2D,KAAK3D,MAAL,GAAcX,kBAAkBkH,UAAhC,KAA+C5F,QAAQgD,KAAK1C,MAAL,CAAY,CAACsF,UAAb,EAAyB5F,KAAzB,CAA+B,uBAA/B,CAAvD,CAAJ,EAAqH;AAC1H;AACAgD,aAAOA,KAAK1C,MAAL,CAAY,CAAZ,EAAe0C,KAAK3D,MAAL,IAAeW,MAAM,CAAN,EAASX,MAAT,GAAkB,CAAjC,CAAf,CAAP;AACD,KAHM,MAGA,IAAI2D,KAAK1C,MAAL,CAAY,CAAC,CAAb,MAAoB,IAAxB,EAA8B;AACnC0C,aAAOA,KAAK1C,MAAL,CAAY,CAAZ,EAAe0C,KAAK3D,MAAL,GAAc,CAA7B,CAAP;AACD,KAFM,MAEA;AACL,UAAI2D,KAAKhD,KAAL,CAAW,iBAAX,CAAJ,EAAmC;AACjC;AACA,YAAKA,QAAQgD,KAAKhD,KAAL,CAAW,iBAAX,CAAb,EAA6C;AAC3CgD,iBAAOA,KAAK1C,MAAL,CAAY,CAAZ,EAAe0C,KAAK3D,MAAL,GAAcW,MAAM,CAAN,EAASX,MAAtC,CAAP;AACD;;AAED;AACA,eAAO2D,KAAK3D,MAAL,GAAc,CAAd,IAAmB2D,KAAK3D,MAAL,GAAcc,MAAM4C,GAAvC,IAA8C,CAACC,KAAKhD,KAAL,CAAW,yBAAX,CAA/C,KAAyFA,QAAQgD,KAAKhD,KAAL,CAAW,gBAAX,CAAjG,CAAP,EAAuI;AACrI,cAAM8F,OAAOpF,SAASV,MAAM,CAAN,EAASM,MAAT,CAAgB,CAAhB,EAAmB,CAAnB,CAAT,EAAgC,EAAhC,CAAb;AACA,cAAIwF,OAAO,GAAX,EAAgB;AACd;AACD;;AAED9C,iBAAOA,KAAK1C,MAAL,CAAY,CAAZ,EAAe0C,KAAK3D,MAAL,GAAc,CAA7B,CAAP;;AAEA,cAAIyG,QAAQ,IAAZ,EAAkB;AAChB;AACD;AACF;AACF;AACF;;AAED,QAAI/C,MAAMC,KAAK3D,MAAX,GAAoBc,GAApB,IAA2B6C,KAAK1C,MAAL,CAAY,CAAC,CAAb,MAAoB,IAAnD,EAAyD;AACvD,UAAI0C,KAAK3D,MAAL,KAAgBX,eAAhB,IAAmCsE,KAAKhD,KAAL,CAAW,eAAX,CAAvC,EAAoE;AAClEgD,eAAOA,KAAK1C,MAAL,CAAY,CAAZ,EAAe0C,KAAK3D,MAAL,GAAc,CAA7B,CAAP;AACD,OAFD,MAEO,IAAI2D,KAAK3D,MAAL,KAAgBX,eAApB,EAAqC;AAC1CsE,eAAOA,KAAK1C,MAAL,CAAY,CAAZ,EAAe0C,KAAK3D,MAAL,GAAc,CAA7B,CAAP;AACD;AACD0D,aAAOC,KAAK3D,MAAZ;AACA2D,cAAQ,OAAR;AACD,KARD,MAQO;AACLD,aAAOC,KAAK3D,MAAZ;AACD;;AAEDuD,cAAUI,IAAV;AACD;;AAED,SAAOJ,MAAP;AACD;;QAEQmD,M,GAAAA,e;QAAQjE,M,GAAAA,e;QAAQkE,O,GAAAA,gB","file":"mimecodec.js","sourcesContent":["import { encode as encodeBase64, decode as decodeBase64, OUTPUT_TYPED_ARRAY } from 'emailjs-base64'\nimport { encode, decode, convert, arr2str } from './charset'\nimport { pipe } from 'ramda'\n\n// Lines can't be longer than 76 + <CR><LF> = 78 bytes\n// http://tools.ietf.org/html/rfc2045#section-6.7\nconst MAX_LINE_LENGTH = 76\nconst MAX_MIME_WORD_LENGTH = 52\nconst MAX_B64_MIME_WORD_BYTE_LENGTH = 39\n\n/**\n * Encodes all non printable and non ascii bytes to =XX form, where XX is the\n * byte value in hex. This function does not convert linebreaks etc. it\n * only escapes character sequences\n *\n * @param {String|Uint8Array} data Either a string or an Uint8Array\n * @param {String} [fromCharset='UTF-8'] Source encoding\n * @return {String} Mime encoded string\n */\nexport function mimeEncode (data = '', fromCharset = 'UTF-8') {\n  const buffer = convert(data, fromCharset)\n  return buffer.reduce((aggregate, ord, index) =>\n    _checkRanges(ord) && !((ord === 0x20 || ord === 0x09) && (index === buffer.length - 1 || buffer[index + 1] === 0x0a || buffer[index + 1] === 0x0d))\n      ? aggregate + String.fromCharCode(ord) // if the char is in allowed range, then keep as is, unless it is a ws in the end of a line\n      : aggregate + '=' + (ord < 0x10 ? '0' : '') + ord.toString(16).toUpperCase(), '')\n\n  function _checkRanges (nr) {\n    const ranges = [ // https://tools.ietf.org/html/rfc2045#section-6.7\n      [0x09], // <TAB>\n      [0x0A], // <LF>\n      [0x0D], // <CR>\n      [0x20, 0x3C], // <SP>!\"#$%&'()*+,-./0123456789:;\n      [0x3E, 0x7E] // >?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}\n    ]\n    return ranges.reduce((val, range) => val || (range.length === 1 && nr === range[0]) || (range.length === 2 && nr >= range[0] && nr <= range[1]), false)\n  }\n}\n\n/**\n * Decodes mime encoded string to an unicode string\n *\n * @param {String} str Mime encoded string\n * @param {String} [fromCharset='UTF-8'] Source encoding\n * @return {String} Decoded unicode string\n */\nexport function mimeDecode (str = '', fromCharset = 'UTF-8') {\n  const encodedBytesCount = (str.match(/=[\\da-fA-F]{2}/g) || []).length\n  let buffer = new Uint8Array(str.length - encodedBytesCount * 2)\n\n  for (var i = 0, len = str.length, bufferPos = 0; i < len; i++) {\n    let hex = str.substr(i + 1, 2)\n    const chr = str.charAt(i)\n    if (chr === '=' && hex && /[\\da-fA-F]{2}/.test(hex)) {\n      buffer[bufferPos++] = parseInt(hex, 16)\n      i += 2\n    } else {\n      buffer[bufferPos++] = chr.charCodeAt(0)\n    }\n  }\n\n  return decode(buffer, fromCharset)\n}\n\n/**\n * Encodes a string or an typed array of given charset into unicode\n * base64 string. Also adds line breaks\n *\n * @param {String|Uint8Array} data String or typed array to be base64 encoded\n * @param {String} Initial charset, e.g. 'binary'. Defaults to 'UTF-8'\n * @return {String} Base64 encoded string\n */\nexport function base64Encode (data, fromCharset = 'UTF-8') {\n  const buf = (typeof data !== 'string' && fromCharset === 'binary') ? data : convert(data, fromCharset)\n  const b64 = encodeBase64(buf)\n  return _addBase64SoftLinebreaks(b64)\n}\n\n/**\n * Decodes a base64 string of any charset into an unicode string\n *\n * @param {String} str Base64 encoded string\n * @param {String} [fromCharset='UTF-8'] Original charset of the base64 encoded string\n * @return {String} Decoded unicode string\n */\nexport function base64Decode (str, fromCharset) {\n  const buf = decodeBase64(str, OUTPUT_TYPED_ARRAY)\n  return fromCharset === 'binary' ? arr2str(buf) : decode(buf, fromCharset)\n}\n\n/**\n * Encodes a string or an Uint8Array into a quoted printable encoding\n * This is almost the same as mimeEncode, except line breaks will be changed\n * as well to ensure that the lines are never longer than allowed length\n *\n * @param {String|Uint8Array} data String or an Uint8Array to mime encode\n * @param {String} [fromCharset='UTF-8'] Original charset of the string\n * @return {String} Mime encoded string\n */\nexport function quotedPrintableEncode (data = '', fromCharset = 'UTF-8') {\n  const mimeEncodedStr = mimeEncode(data, fromCharset)\n    .replace(/\\r?\\n|\\r/g, '\\r\\n') // fix line breaks, ensure <CR><LF>\n    .replace(/[\\t ]+$/gm, spaces => spaces.replace(/ /g, '=20').replace(/\\t/g, '=09')) // replace spaces in the end of lines\n\n  return _addQPSoftLinebreaks(mimeEncodedStr) // add soft line breaks to ensure line lengths sjorter than 76 bytes\n}\n\n/**\n * Decodes a string from a quoted printable encoding. This is almost the\n * same as mimeDecode, except line breaks will be changed as well\n *\n * @param {String} str Mime encoded string to decode\n * @param {String} [fromCharset='UTF-8'] Original charset of the string\n * @return {String} Mime decoded string\n */\nexport function quotedPrintableDecode (str = '', fromCharset = 'UTF-8') {\n  const rawString = str\n    .replace(/[\\t ]+$/gm, '') // remove invalid whitespace from the end of lines\n    .replace(/=(?:\\r?\\n|$)/g, '') // remove soft line breaks\n\n  return mimeDecode(rawString, fromCharset)\n}\n\n/**\n * Encodes a string or an Uint8Array to an UTF-8 MIME Word\n *   https://tools.ietf.org/html/rfc2047\n *\n * @param {String|Uint8Array} data String to be encoded\n * @param {String} mimeWordEncoding='Q' Encoding for the mime word, either Q or B\n * @param {String} [fromCharset='UTF-8'] Source sharacter set\n * @return {String} Single or several mime words joined together\n */\nexport function mimeWordEncode (data, mimeWordEncoding = 'Q', fromCharset = 'UTF-8') {\n  let parts = []\n  const str = (typeof data === 'string') ? data : decode(data, fromCharset)\n\n  if (mimeWordEncoding === 'Q') {\n    const str = (typeof data === 'string') ? data : decode(data, fromCharset)\n    let encodedStr = pipe(mimeEncode, qEncodeForbiddenHeaderChars)(str)\n    parts = encodedStr.length < MAX_MIME_WORD_LENGTH ? [encodedStr] : _splitMimeEncodedString(encodedStr, MAX_MIME_WORD_LENGTH)\n  } else {\n    // Fits as much as possible into every line without breaking utf-8 multibyte characters' octets up across lines\n    let j = 0\n    let i = 0\n    while (i < str.length) {\n      if (encode(str.substring(j, i)).length > MAX_B64_MIME_WORD_BYTE_LENGTH) {\n        // we went one character too far, substring at the char before\n        parts.push(str.substring(j, i - 1))\n        j = i - 1\n      } else {\n        i++\n      }\n    }\n    // add the remainder of the string\n    str.substring(j) && parts.push(str.substring(j))\n    parts = parts.map(encode).map(encodeBase64)\n  }\n\n  const prefix = '=?UTF-8?' + mimeWordEncoding + '?'\n  const suffix = '?= '\n  return parts.map(p => prefix + p + suffix).join('').trim()\n}\n\n/**\n * Q-Encodes remaining forbidden header chars\n *   https://tools.ietf.org/html/rfc2047#section-5\n */\nconst qEncodeForbiddenHeaderChars = function (str) {\n  const qEncode = chr => chr === ' ' ? '_' : ('=' + (chr.charCodeAt(0) < 0x10 ? '0' : '') + chr.charCodeAt(0).toString(16).toUpperCase())\n  return str.replace(/[^a-z0-9!*+\\-/=]/ig, qEncode)\n}\n\n/**\n * Finds word sequences with non ascii text and converts these to mime words\n *\n * @param {String|Uint8Array} data String to be encoded\n * @param {String} mimeWordEncoding='Q' Encoding for the mime word, either Q or B\n * @param {String} [fromCharset='UTF-8'] Source sharacter set\n * @return {String} String with possible mime words\n */\nexport function mimeWordsEncode (data = '', mimeWordEncoding = 'Q', fromCharset = 'UTF-8') {\n  const regex = /([^\\s\\u0080-\\uFFFF]*[\\u0080-\\uFFFF]+[^\\s\\u0080-\\uFFFF]*(?:\\s+[^\\s\\u0080-\\uFFFF]*[\\u0080-\\uFFFF]+[^\\s\\u0080-\\uFFFF]*\\s*)?)+(?=\\s|$)/g\n  return decode(convert(data, fromCharset)).replace(regex, match => match.length ? mimeWordEncode(match, mimeWordEncoding, fromCharset) : '')\n}\n\n/**\n * Decode a complete mime word encoded string\n *\n * @param {String} str Mime word encoded string\n * @return {String} Decoded unicode string\n */\nexport function mimeWordDecode (str = '') {\n  const match = str.match(/^=\\?([\\w_\\-*]+)\\?([QqBb])\\?([^?]*)\\?=$/i)\n  if (!match) return str\n\n  // RFC2231 added language tag to the encoding\n  // see: https://tools.ietf.org/html/rfc2231#section-5\n  // this implementation silently ignores this tag\n  const fromCharset = match[1].split('*').shift()\n  const encoding = (match[2] || 'Q').toString().toUpperCase()\n  const rawString = (match[3] || '').replace(/_/g, ' ')\n\n  if (encoding === 'B') {\n    return base64Decode(rawString, fromCharset)\n  } else if (encoding === 'Q') {\n    return mimeDecode(rawString, fromCharset)\n  } else {\n    return str\n  }\n}\n\n/**\n * Decode a string that might include one or several mime words\n *\n * @param {String} str String including some mime words that will be encoded\n * @return {String} Decoded unicode string\n */\nexport function mimeWordsDecode (str = '') {\n  str = str.toString().replace(/(=\\?[^?]+\\?[QqBb]\\?[^?]+\\?=)\\s+(?==\\?[^?]+\\?[QqBb]\\?[^?]*\\?=)/g, '$1')\n  // join bytes of multi-byte UTF-8\n  let prevEncoding\n  str = str.replace(/(\\?=)?=\\?[uU][tT][fF]-8\\?([QqBb])\\?/g, (match, endOfPrevWord, encoding) => {\n    const result = (endOfPrevWord && encoding === prevEncoding) ? '' : match\n    prevEncoding = encoding\n    return result\n  })\n  str = str.replace(/=\\?[\\w_\\-*]+\\?[QqBb]\\?[^?]*\\?=/g, mimeWord => mimeWordDecode(mimeWord.replace(/\\s+/g, '')))\n\n  return str\n}\n\n/**\n * Folds long lines, useful for folding header lines (afterSpace=false) and\n * flowed text (afterSpace=true)\n *\n * @param {String} str String to be folded\n * @param {Boolean} afterSpace If true, leave a space in th end of a line\n * @return {String} String with folded lines\n */\nexport function foldLines (str = '', afterSpace) {\n  let pos = 0\n  const len = str.length\n  let result = ''\n  let line, match\n\n  while (pos < len) {\n    line = str.substr(pos, MAX_LINE_LENGTH)\n    if (line.length < MAX_LINE_LENGTH) {\n      result += line\n      break\n    }\n    if ((match = line.match(/^[^\\n\\r]*(\\r?\\n|\\r)/))) {\n      line = match[0]\n      result += line\n      pos += line.length\n      continue\n    } else if ((match = line.match(/(\\s+)[^\\s]*$/)) && match[0].length - (afterSpace ? (match[1] || '').length : 0) < line.length) {\n      line = line.substr(0, line.length - (match[0].length - (afterSpace ? (match[1] || '').length : 0)))\n    } else if ((match = str.substr(pos + line.length).match(/^[^\\s]+(\\s*)/))) {\n      line = line + match[0].substr(0, match[0].length - (!afterSpace ? (match[1] || '').length : 0))\n    }\n\n    result += line\n    pos += line.length\n    if (pos < len) {\n      result += '\\r\\n'\n    }\n  }\n\n  return result\n}\n\n/**\n * Encodes and folds a header line for a MIME message header.\n * Shorthand for mimeWordsEncode + foldLines\n *\n * @param {String} key Key name, will not be encoded\n * @param {String|Uint8Array} value Value to be encoded\n * @param {String} [fromCharset='UTF-8'] Character set of the value\n * @return {String} encoded and folded header line\n */\nexport function headerLineEncode (key, value, fromCharset) {\n  var encodedValue = mimeWordsEncode(value, 'Q', fromCharset)\n  return foldLines(key + ': ' + encodedValue)\n}\n\n/**\n * The result is not mime word decoded, you need to do your own decoding based\n * on the rules for the specific header key\n *\n * @param {String} headerLine Single header line, might include linebreaks as well if folded\n * @return {Object} And object of {key, value}\n */\nexport function headerLineDecode (headerLine = '') {\n  const line = headerLine.toString().replace(/(?:\\r?\\n|\\r)[ \\t]*/g, ' ').trim()\n  const match = line.match(/^\\s*([^:]+):(.*)$/)\n\n  return {\n    key: ((match && match[1]) || '').trim(),\n    value: ((match && match[2]) || '').trim()\n  }\n}\n\n/**\n * Parses a block of header lines. Does not decode mime words as every\n * header might have its own rules (eg. formatted email addresses and such)\n *\n * @param {String} headers Headers string\n * @return {Object} An object of headers, where header keys are object keys. NB! Several values with the same key make up an Array\n */\nexport function headerLinesDecode (headers) {\n  const lines = headers.split(/\\r?\\n|\\r/)\n  const headersObj = {}\n\n  for (let i = lines.length - 1; i >= 0; i--) {\n    if (i && lines[i].match(/^\\s/)) {\n      lines[i - 1] += '\\r\\n' + lines[i]\n      lines.splice(i, 1)\n    }\n  }\n\n  for (let i = 0, len = lines.length; i < len; i++) {\n    const header = headerLineDecode(lines[i])\n    const key = header.key.toLowerCase()\n    const value = header.value\n\n    if (!headersObj[key]) {\n      headersObj[key] = value\n    } else {\n      headersObj[key] = [].concat(headersObj[key], value)\n    }\n  }\n\n  return headersObj\n}\n\n/**\n * Parses a header value with key=value arguments into a structured\n * object.\n *\n *   parseHeaderValue('content-type: text/plain; CHARSET='UTF-8'') ->\n *   {\n *     'value': 'text/plain',\n *     'params': {\n *       'charset': 'UTF-8'\n *     }\n *   }\n *\n * @param {String} str Header value\n * @return {Object} Header value as a parsed structure\n */\nexport function parseHeaderValue (str) {\n  let response = {\n    value: false,\n    params: {}\n  }\n  let key = false\n  let value = ''\n  let type = 'value'\n  let quote = false\n  let escaped = false\n  let chr\n\n  for (let i = 0, len = str.length; i < len; i++) {\n    chr = str.charAt(i)\n    if (type === 'key') {\n      if (chr === '=') {\n        key = value.trim().toLowerCase()\n        type = 'value'\n        value = ''\n        continue\n      }\n      value += chr\n    } else {\n      if (escaped) {\n        value += chr\n      } else if (chr === '\\\\') {\n        escaped = true\n        continue\n      } else if (quote && chr === quote) {\n        quote = false\n      } else if (!quote && chr === '\"') {\n        quote = chr\n      } else if (!quote && chr === ';') {\n        if (key === false) {\n          response.value = value.trim()\n        } else {\n          response.params[key] = value.trim()\n        }\n        type = 'key'\n        value = ''\n      } else {\n        value += chr\n      }\n      escaped = false\n    }\n  }\n\n  if (type === 'value') {\n    if (key === false) {\n      response.value = value.trim()\n    } else {\n      response.params[key] = value.trim()\n    }\n  } else if (value.trim()) {\n    response.params[value.trim().toLowerCase()] = ''\n  }\n\n  // handle parameter value continuations\n  // https://tools.ietf.org/html/rfc2231#section-3\n\n  // preprocess values\n  Object.keys(response.params).forEach(function (key) {\n    var actualKey, nr, match, value\n    if ((match = key.match(/(\\*(\\d+)|\\*(\\d+)\\*|\\*)$/))) {\n      actualKey = key.substr(0, match.index)\n      nr = Number(match[2] || match[3]) || 0\n\n      if (!response.params[actualKey] || typeof response.params[actualKey] !== 'object') {\n        response.params[actualKey] = {\n          charset: false,\n          values: []\n        }\n      }\n\n      value = response.params[key]\n\n      if (nr === 0 && match[0].substr(-1) === '*' && (match = value.match(/^([^']*)'[^']*'(.*)$/))) {\n        response.params[actualKey].charset = match[1] || 'iso-8859-1'\n        value = match[2]\n      }\n\n      response.params[actualKey].values[nr] = value\n\n      // remove the old reference\n      delete response.params[key]\n    }\n  })\n\n  // concatenate split rfc2231 strings and convert encoded strings to mime encoded words\n  Object.keys(response.params).forEach(function (key) {\n    var value\n    if (response.params[key] && Array.isArray(response.params[key].values)) {\n      value = response.params[key].values.map(function (val) {\n        return val || ''\n      }).join('')\n\n      if (response.params[key].charset) {\n        // convert \"%AB\" to \"=?charset?Q?=AB?=\"\n        response.params[key] = '=?' + response.params[key].charset + '?Q?' + value\n          .replace(/[=?_\\s]/g, function (s) {\n            // fix invalidly encoded chars\n            var c = s.charCodeAt(0).toString(16)\n            return s === ' ' ? '_' : '%' + (c.length < 2 ? '0' : '') + c\n          })\n          .replace(/%/g, '=') + '?=' // change from urlencoding to percent encoding\n      } else {\n        response.params[key] = value\n      }\n    }\n  })\n\n  return response\n}\n\n/**\n * Encodes a string or an Uint8Array to an UTF-8 Parameter Value Continuation encoding (rfc2231)\n * Useful for splitting long parameter values.\n *\n * For example\n *      title=\"unicode string\"\n * becomes\n *     title*0*=\"utf-8''unicode\"\n *     title*1*=\"%20string\"\n *\n * @param {String|Uint8Array} data String to be encoded\n * @param {Number} [maxLength=50] Max length for generated chunks\n * @param {String} [fromCharset='UTF-8'] Source sharacter set\n * @return {Array} A list of encoded keys and headers\n */\nexport function continuationEncode (key, data, maxLength, fromCharset) {\n  const list = []\n  var encodedStr = typeof data === 'string' ? data : decode(data, fromCharset)\n  var line\n\n  maxLength = maxLength || 50\n\n  // process ascii only text\n  if (/^[\\w.\\- ]*$/.test(data)) {\n    // check if conversion is even needed\n    if (encodedStr.length <= maxLength) {\n      return [{\n        key: key,\n        value: /[\\s\";=]/.test(encodedStr) ? '\"' + encodedStr + '\"' : encodedStr\n      }]\n    }\n\n    encodedStr = encodedStr.replace(new RegExp('.{' + maxLength + '}', 'g'), function (str) {\n      list.push({\n        line: str\n      })\n      return ''\n    })\n\n    if (encodedStr) {\n      list.push({\n        line: encodedStr\n      })\n    }\n  } else {\n    // process text with unicode or special chars\n    const uriEncoded = encodeURIComponent('utf-8\\'\\'' + encodedStr)\n    let i = 0\n    while (true) {\n      let len = maxLength\n      // must not split hex encoded byte between lines\n      if (uriEncoded[i + maxLength - 1] === '%') {\n        len -= 1\n      } else if (uriEncoded[i + maxLength - 2] === '%') {\n        len -= 2\n      }\n      line = uriEncoded.substr(i, len)\n      if (!line) {\n        break\n      }\n      list.push({\n        line: line,\n        encoded: true\n      })\n      i += line.length\n    }\n  }\n\n  return list.map(function (item, i) {\n    return {\n      // encoded lines: {name}*{part}*\n      // unencoded lines: {name}*{part}\n      // if any line needs to be encoded then the first line (part==0) is always encoded\n      key: key + '*' + i + (item.encoded ? '*' : ''),\n      value: /[\\s\";=]/.test(item.line) ? '\"' + item.line + '\"' : item.line\n    }\n  })\n}\n\n/**\n * Splits a mime encoded string. Needed for dividing mime words into smaller chunks\n *\n * @param {String} str Mime encoded string to be split up\n * @param {Number} maxlen Maximum length of characters for one part (minimum 12)\n * @return {Array} Split string\n */\nfunction _splitMimeEncodedString (str, maxlen = 12) {\n  const minWordLength = 12 // require at least 12 symbols to fit possible 4 octet UTF-8 sequences\n  const maxWordLength = Math.max(maxlen, minWordLength)\n  const lines = []\n\n  while (str.length) {\n    let curLine = str.substr(0, maxWordLength)\n\n    const match = curLine.match(/=[0-9A-F]?$/i) // skip incomplete escaped char\n    if (match) {\n      curLine = curLine.substr(0, match.index)\n    }\n\n    let done = false\n    while (!done) {\n      let chr\n      done = true\n      const match = str.substr(curLine.length).match(/^=([0-9A-F]{2})/i) // check if not middle of a unicode char sequence\n      if (match) {\n        chr = parseInt(match[1], 16)\n        // invalid sequence, move one char back anc recheck\n        if (chr < 0xC2 && chr > 0x7F) {\n          curLine = curLine.substr(0, curLine.length - 3)\n          done = false\n        }\n      }\n    }\n\n    if (curLine.length) {\n      lines.push(curLine)\n    }\n    str = str.substr(curLine.length)\n  }\n\n  return lines\n}\n\nfunction _addBase64SoftLinebreaks (base64EncodedStr = '') {\n  return base64EncodedStr.trim().replace(new RegExp('.{' + MAX_LINE_LENGTH + '}', 'g'), '$&\\r\\n').trim()\n}\n\n/**\n * Adds soft line breaks(the ones that will be stripped out when decoding QP)\n *\n * @param {String} qpEncodedStr String in Quoted-Printable encoding\n * @return {String} String with forced line breaks\n */\nfunction _addQPSoftLinebreaks (qpEncodedStr = '') {\n  let pos = 0\n  const len = qpEncodedStr.length\n  const lineMargin = Math.floor(MAX_LINE_LENGTH / 3)\n  let result = ''\n  let match, line\n\n  // insert soft linebreaks where needed\n  while (pos < len) {\n    line = qpEncodedStr.substr(pos, MAX_LINE_LENGTH)\n    if ((match = line.match(/\\r\\n/))) {\n      line = line.substr(0, match.index + match[0].length)\n      result += line\n      pos += line.length\n      continue\n    }\n\n    if (line.substr(-1) === '\\n') {\n      // nothing to change here\n      result += line\n      pos += line.length\n      continue\n    } else if ((match = line.substr(-lineMargin).match(/\\n.*?$/))) {\n      // truncate to nearest line break\n      line = line.substr(0, line.length - (match[0].length - 1))\n      result += line\n      pos += line.length\n      continue\n    } else if (line.length > MAX_LINE_LENGTH - lineMargin && (match = line.substr(-lineMargin).match(/[ \\t.,!?][^ \\t.,!?]*$/))) {\n      // truncate to nearest space\n      line = line.substr(0, line.length - (match[0].length - 1))\n    } else if (line.substr(-1) === '\\r') {\n      line = line.substr(0, line.length - 1)\n    } else {\n      if (line.match(/=[\\da-f]{0,2}$/i)) {\n        // push incomplete encoding sequences to the next line\n        if ((match = line.match(/=[\\da-f]{0,1}$/i))) {\n          line = line.substr(0, line.length - match[0].length)\n        }\n\n        // ensure that utf-8 sequences are not split\n        while (line.length > 3 && line.length < len - pos && !line.match(/^(?:=[\\da-f]{2}){1,4}$/i) && (match = line.match(/=[\\da-f]{2}$/ig))) {\n          const code = parseInt(match[0].substr(1, 2), 16)\n          if (code < 128) {\n            break\n          }\n\n          line = line.substr(0, line.length - 3)\n\n          if (code >= 0xC0) {\n            break\n          }\n        }\n      }\n    }\n\n    if (pos + line.length < len && line.substr(-1) !== '\\n') {\n      if (line.length === MAX_LINE_LENGTH && line.match(/=[\\da-f]{2}$/i)) {\n        line = line.substr(0, line.length - 3)\n      } else if (line.length === MAX_LINE_LENGTH) {\n        line = line.substr(0, line.length - 1)\n      }\n      pos += line.length\n      line += '=\\r\\n'\n    } else {\n      pos += line.length\n    }\n\n    result += line\n  }\n\n  return result\n}\n\nexport { decode, encode, convert }\n"]} \ No newline at end of file +} \ No newline at end of file diff --git a/package-lock.json b/package-lock.json new file mode 100644 index 0000000..a16226f --- /dev/null +++ b/package-lock.json @@ -0,0 +1,4097 @@ +{ + "name": "emailjs-mime-codec", + "version": "2.0.9", + "lockfileVersion": 1, + "requires": true, + "dependencies": { + "@ampproject/remapping": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.0.tgz", + "integrity": "sha512-qRmjj8nj9qmLTQXXmaR1cck3UXSRMPrbsLJAasZpF+t3riI71BXed5ebIOYwQntykeZuhjsdweEc9BxH5Jc26w==", + "dev": true, + "requires": { + "@jridgewell/gen-mapping": "^0.1.0", + "@jridgewell/trace-mapping": "^0.3.9" + } + }, + "@babel/cli": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/cli/-/cli-7.20.7.tgz", + "integrity": "sha512-WylgcELHB66WwQqItxNILsMlaTd8/SO6SgTTjMp4uCI7P4QyH1r3nqgFmO3BfM4AtfniHgFMH3EpYFj/zynBkQ==", + "dev": true, + "requires": { + "@jridgewell/trace-mapping": "^0.3.8", + "@nicolo-ribaudo/chokidar-2": "2.1.8-no-fsevents.3", + "chokidar": "^3.4.0", + "commander": "^4.0.1", + "convert-source-map": "^1.1.0", + "fs-readdir-recursive": "^1.1.0", + "glob": "^7.2.0", + "make-dir": "^2.1.0", + "slash": "^2.0.0" + }, + "dependencies": { + "anymatch": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", + "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", + "dev": true, + "optional": true, + "requires": { + "normalize-path": "^3.0.0", + "picomatch": "^2.0.4" + } + }, + "binary-extensions": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", + "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", + "dev": true, + "optional": true + }, + "braces": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", + "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", + "dev": true, + "optional": true, + "requires": { + "fill-range": "^7.0.1" + } + }, + "chokidar": { + "version": "3.5.3", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", + "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", + "dev": true, + "optional": true, + "requires": { + "anymatch": "~3.1.2", + "braces": "~3.0.2", + "fsevents": "~2.3.2", + "glob-parent": "~5.1.2", + "is-binary-path": "~2.1.0", + "is-glob": "~4.0.1", + "normalize-path": "~3.0.0", + "readdirp": "~3.6.0" + } + }, + "commander": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-4.1.1.tgz", + "integrity": "sha512-NOKm8xhkzAjzFx8B2v5OAHT+u5pRQc2UCa2Vq9jYL/31o2wi9mxBA7LIFs3sV5VSC49z6pEhfbMULvShKj26WA==", + "dev": true + }, + "fill-range": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", + "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", + "dev": true, + "optional": true, + "requires": { + "to-regex-range": "^5.0.1" + } + }, + "fsevents": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", + "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", + "dev": true, + "optional": true + }, + "glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", + "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", + "dev": true, + "optional": true, + "requires": { + "is-glob": "^4.0.1" + } + }, + "is-binary-path": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", + "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", + "dev": true, + "optional": true, + "requires": { + "binary-extensions": "^2.0.0" + } + }, + "is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", + "dev": true, + "optional": true + }, + "is-glob": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", + "dev": true, + "optional": true, + "requires": { + "is-extglob": "^2.1.1" + } + }, + "is-number": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", + "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", + "dev": true, + "optional": true + }, + "normalize-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", + "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", + "dev": true, + "optional": true + }, + "readdirp": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", + "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", + "dev": true, + "optional": true, + "requires": { + "picomatch": "^2.2.1" + } + }, + "slash": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-2.0.0.tgz", + "integrity": "sha512-ZYKh3Wh2z1PpEXWr0MpSBZ0V6mZHAQfYevttO11c51CaWjGTaadiKZ+wVt1PbMlDV5qhMFslpZCemhwOK7C89A==", + "dev": true + }, + "to-regex-range": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", + "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", + "dev": true, + "optional": true, + "requires": { + "is-number": "^7.0.0" + } + } + } + }, + "@babel/code-frame": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.18.6.tgz", + "integrity": "sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q==", + "dev": true, + "requires": { + "@babel/highlight": "^7.18.6" + } + }, + "@babel/compat-data": { + "version": "7.20.10", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.20.10.tgz", + "integrity": "sha512-sEnuDPpOJR/fcafHMjpcpGN5M2jbUGUHwmuWKM/YdPzeEDJg8bgmbcWQFUfE32MQjti1koACvoPVsDe8Uq+idg==", + "dev": true + }, + "@babel/core": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.20.7.tgz", + "integrity": "sha512-t1ZjCluspe5DW24bn2Rr1CDb2v9rn/hROtg9a2tmd0+QYf4bsloYfLQzjG4qHPNMhWtKdGC33R5AxGR2Af2cBw==", + "dev": true, + "requires": { + "@ampproject/remapping": "^2.1.0", + "@babel/code-frame": "^7.18.6", + "@babel/generator": "^7.20.7", + "@babel/helper-compilation-targets": "^7.20.7", + "@babel/helper-module-transforms": "^7.20.7", + "@babel/helpers": "^7.20.7", + "@babel/parser": "^7.20.7", + "@babel/template": "^7.20.7", + "@babel/traverse": "^7.20.7", + "@babel/types": "^7.20.7", + "convert-source-map": "^1.7.0", + "debug": "^4.1.0", + "gensync": "^1.0.0-beta.2", + "json5": "^2.2.1", + "semver": "^6.3.0" + }, + "dependencies": { + "debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "requires": { + "ms": "2.1.2" + } + }, + "json5": { + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", + "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", + "dev": true + }, + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + } + } + }, + "@babel/generator": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.20.7.tgz", + "integrity": "sha512-7wqMOJq8doJMZmP4ApXTzLxSr7+oO2jroJURrVEp6XShrQUObV8Tq/D0NCcoYg2uHqUrjzO0zwBjoYzelxK+sw==", + "dev": true, + "requires": { + "@babel/types": "^7.20.7", + "@jridgewell/gen-mapping": "^0.3.2", + "jsesc": "^2.5.1" + }, + "dependencies": { + "@jridgewell/gen-mapping": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz", + "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==", + "dev": true, + "requires": { + "@jridgewell/set-array": "^1.0.1", + "@jridgewell/sourcemap-codec": "^1.4.10", + "@jridgewell/trace-mapping": "^0.3.9" + } + }, + "jsesc": { + "version": "2.5.2", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", + "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", + "dev": true + } + } + }, + "@babel/helper-annotate-as-pure": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.18.6.tgz", + "integrity": "sha512-duORpUiYrEpzKIop6iNbjnwKLAKnJ47csTyRACyEmWj0QdUrm5aqNJGHSSEQSUAvNW0ojX0dOmK9dZduvkfeXA==", + "dev": true, + "requires": { + "@babel/types": "^7.18.6" + } + }, + "@babel/helper-builder-binary-assignment-operator-visitor": { + "version": "7.18.9", + "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.18.9.tgz", + "integrity": "sha512-yFQ0YCHoIqarl8BCRwBL8ulYUaZpz3bNsA7oFepAzee+8/+ImtADXNOmO5vJvsPff3qi+hvpkY/NYBTrBQgdNw==", + "dev": true, + "requires": { + "@babel/helper-explode-assignable-expression": "^7.18.6", + "@babel/types": "^7.18.9" + } + }, + "@babel/helper-compilation-targets": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.20.7.tgz", + "integrity": "sha512-4tGORmfQcrc+bvrjb5y3dG9Mx1IOZjsHqQVUz7XCNHO+iTmqxWnVg3KRygjGmpRLJGdQSKuvFinbIb0CnZwHAQ==", + "dev": true, + "requires": { + "@babel/compat-data": "^7.20.5", + "@babel/helper-validator-option": "^7.18.6", + "browserslist": "^4.21.3", + "lru-cache": "^5.1.1", + "semver": "^6.3.0" + }, + "dependencies": { + "lru-cache": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", + "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", + "dev": true, + "requires": { + "yallist": "^3.0.2" + } + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + }, + "yallist": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", + "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", + "dev": true + } + } + }, + "@babel/helper-create-class-features-plugin": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.20.7.tgz", + "integrity": "sha512-LtoWbDXOaidEf50hmdDqn9g8VEzsorMexoWMQdQODbvmqYmaF23pBP5VNPAGIFHsFQCIeKokDiz3CH5Y2jlY6w==", + "dev": true, + "requires": { + "@babel/helper-annotate-as-pure": "^7.18.6", + "@babel/helper-environment-visitor": "^7.18.9", + "@babel/helper-function-name": "^7.19.0", + "@babel/helper-member-expression-to-functions": "^7.20.7", + "@babel/helper-optimise-call-expression": "^7.18.6", + "@babel/helper-replace-supers": "^7.20.7", + "@babel/helper-split-export-declaration": "^7.18.6" + } + }, + "@babel/helper-create-regexp-features-plugin": { + "version": "7.20.5", + "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.20.5.tgz", + "integrity": "sha512-m68B1lkg3XDGX5yCvGO0kPx3v9WIYLnzjKfPcQiwntEQa5ZeRkPmo2X/ISJc8qxWGfwUr+kvZAeEzAwLec2r2w==", + "dev": true, + "requires": { + "@babel/helper-annotate-as-pure": "^7.18.6", + "regexpu-core": "^5.2.1" + } + }, + "@babel/helper-define-polyfill-provider": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.3.3.tgz", + "integrity": "sha512-z5aQKU4IzbqCC1XH0nAqfsFLMVSo22SBKUc0BxGrLkolTdPTructy0ToNnlO2zA4j9Q/7pjMZf0DSY+DSTYzww==", + "dev": true, + "requires": { + "@babel/helper-compilation-targets": "^7.17.7", + "@babel/helper-plugin-utils": "^7.16.7", + "debug": "^4.1.1", + "lodash.debounce": "^4.0.8", + "resolve": "^1.14.2", + "semver": "^6.1.2" + }, + "dependencies": { + "debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "requires": { + "ms": "2.1.2" + } + }, + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + } + } + }, + "@babel/helper-environment-visitor": { + "version": "7.18.9", + "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.18.9.tgz", + "integrity": "sha512-3r/aACDJ3fhQ/EVgFy0hpj8oHyHpQc+LPtJoY9SzTThAsStm4Ptegq92vqKoE3vD706ZVFWITnMnxucw+S9Ipg==", + "dev": true + }, + "@babel/helper-explode-assignable-expression": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.18.6.tgz", + "integrity": "sha512-eyAYAsQmB80jNfg4baAtLeWAQHfHFiR483rzFK+BhETlGZaQC9bsfrugfXDCbRHLQbIA7U5NxhhOxN7p/dWIcg==", + "dev": true, + "requires": { + "@babel/types": "^7.18.6" + } + }, + "@babel/helper-function-name": { + "version": "7.19.0", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.19.0.tgz", + "integrity": "sha512-WAwHBINyrpqywkUH0nTnNgI5ina5TFn85HKS0pbPDfxFfhyR/aNQEn4hGi1P1JyT//I0t4OgXUlofzWILRvS5w==", + "dev": true, + "requires": { + "@babel/template": "^7.18.10", + "@babel/types": "^7.19.0" + } + }, + "@babel/helper-hoist-variables": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz", + "integrity": "sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q==", + "dev": true, + "requires": { + "@babel/types": "^7.18.6" + } + }, + "@babel/helper-member-expression-to-functions": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.20.7.tgz", + "integrity": "sha512-9J0CxJLq315fEdi4s7xK5TQaNYjZw+nDVpVqr1axNGKzdrdwYBD5b4uKv3n75aABG0rCCTK8Im8Ww7eYfMrZgw==", + "dev": true, + "requires": { + "@babel/types": "^7.20.7" + } + }, + "@babel/helper-module-imports": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.18.6.tgz", + "integrity": "sha512-0NFvs3VkuSYbFi1x2Vd6tKrywq+z/cLeYC/RJNFrIX/30Bf5aiGYbtvGXolEktzJH8o5E5KJ3tT+nkxuuZFVlA==", + "dev": true, + "requires": { + "@babel/types": "^7.18.6" + } + }, + "@babel/helper-module-transforms": { + "version": "7.20.11", + "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.20.11.tgz", + "integrity": "sha512-uRy78kN4psmji1s2QtbtcCSaj/LILFDp0f/ymhpQH5QY3nljUZCaNWz9X1dEj/8MBdBEFECs7yRhKn8i7NjZgg==", + "dev": true, + "requires": { + "@babel/helper-environment-visitor": "^7.18.9", + "@babel/helper-module-imports": "^7.18.6", + "@babel/helper-simple-access": "^7.20.2", + "@babel/helper-split-export-declaration": "^7.18.6", + "@babel/helper-validator-identifier": "^7.19.1", + "@babel/template": "^7.20.7", + "@babel/traverse": "^7.20.10", + "@babel/types": "^7.20.7" + } + }, + "@babel/helper-optimise-call-expression": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.18.6.tgz", + "integrity": "sha512-HP59oD9/fEHQkdcbgFCnbmgH5vIQTJbxh2yf+CdM89/glUNnuzr87Q8GIjGEnOktTROemO0Pe0iPAYbqZuOUiA==", + "dev": true, + "requires": { + "@babel/types": "^7.18.6" + } + }, + "@babel/helper-plugin-utils": { + "version": "7.20.2", + "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.20.2.tgz", + "integrity": "sha512-8RvlJG2mj4huQ4pZ+rU9lqKi9ZKiRmuvGuM2HlWmkmgOhbs6zEAw6IEiJ5cQqGbDzGZOhwuOQNtZMi/ENLjZoQ==", + "dev": true + }, + "@babel/helper-remap-async-to-generator": { + "version": "7.18.9", + "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.18.9.tgz", + "integrity": "sha512-dI7q50YKd8BAv3VEfgg7PS7yD3Rtbi2J1XMXaalXO0W0164hYLnh8zpjRS0mte9MfVp/tltvr/cfdXPvJr1opA==", + "dev": true, + "requires": { + "@babel/helper-annotate-as-pure": "^7.18.6", + "@babel/helper-environment-visitor": "^7.18.9", + "@babel/helper-wrap-function": "^7.18.9", + "@babel/types": "^7.18.9" + } + }, + "@babel/helper-replace-supers": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.20.7.tgz", + "integrity": "sha512-vujDMtB6LVfNW13jhlCrp48QNslK6JXi7lQG736HVbHz/mbf4Dc7tIRh1Xf5C0rF7BP8iiSxGMCmY6Ci1ven3A==", + "dev": true, + "requires": { + "@babel/helper-environment-visitor": "^7.18.9", + "@babel/helper-member-expression-to-functions": "^7.20.7", + "@babel/helper-optimise-call-expression": "^7.18.6", + "@babel/template": "^7.20.7", + "@babel/traverse": "^7.20.7", + "@babel/types": "^7.20.7" + } + }, + "@babel/helper-simple-access": { + "version": "7.20.2", + "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.20.2.tgz", + "integrity": "sha512-+0woI/WPq59IrqDYbVGfshjT5Dmk/nnbdpcF8SnMhhXObpTq2KNBdLFRFrkVdbDOyUmHBCxzm5FHV1rACIkIbA==", + "dev": true, + "requires": { + "@babel/types": "^7.20.2" + } + }, + "@babel/helper-skip-transparent-expression-wrappers": { + "version": "7.20.0", + "resolved": "https://registry.npmjs.org/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.20.0.tgz", + "integrity": "sha512-5y1JYeNKfvnT8sZcK9DVRtpTbGiomYIHviSP3OQWmDPU3DeH4a1ZlT/N2lyQ5P8egjcRaT/Y9aNqUxK0WsnIIg==", + "dev": true, + "requires": { + "@babel/types": "^7.20.0" + } + }, + "@babel/helper-split-export-declaration": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz", + "integrity": "sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA==", + "dev": true, + "requires": { + "@babel/types": "^7.18.6" + } + }, + "@babel/helper-string-parser": { + "version": "7.19.4", + "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.19.4.tgz", + "integrity": "sha512-nHtDoQcuqFmwYNYPz3Rah5ph2p8PFeFCsZk9A/48dPc/rGocJ5J3hAAZ7pb76VWX3fZKu+uEr/FhH5jLx7umrw==", + "dev": true + }, + "@babel/helper-validator-identifier": { + "version": "7.19.1", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz", + "integrity": "sha512-awrNfaMtnHUr653GgGEs++LlAvW6w+DcPrOliSMXWCKo597CwL5Acf/wWdNkf/tfEQE3mjkeD1YOVZOUV/od1w==", + "dev": true + }, + "@babel/helper-validator-option": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.18.6.tgz", + "integrity": "sha512-XO7gESt5ouv/LRJdrVjkShckw6STTaB7l9BrpBaAHDeF5YZT+01PCwmR0SJHnkW6i8OwW/EVWRShfi4j2x+KQw==", + "dev": true + }, + "@babel/helper-wrap-function": { + "version": "7.20.5", + "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.20.5.tgz", + "integrity": "sha512-bYMxIWK5mh+TgXGVqAtnu5Yn1un+v8DDZtqyzKRLUzrh70Eal2O3aZ7aPYiMADO4uKlkzOiRiZ6GX5q3qxvW9Q==", + "dev": true, + "requires": { + "@babel/helper-function-name": "^7.19.0", + "@babel/template": "^7.18.10", + "@babel/traverse": "^7.20.5", + "@babel/types": "^7.20.5" + } + }, + "@babel/helpers": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.20.7.tgz", + "integrity": "sha512-PBPjs5BppzsGaxHQCDKnZ6Gd9s6xl8bBCluz3vEInLGRJmnZan4F6BYCeqtyXqkk4W5IlPmjK4JlOuZkpJ3xZA==", + "dev": true, + "requires": { + "@babel/template": "^7.20.7", + "@babel/traverse": "^7.20.7", + "@babel/types": "^7.20.7" + } + }, + "@babel/highlight": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz", + "integrity": "sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==", + "dev": true, + "requires": { + "@babel/helper-validator-identifier": "^7.18.6", + "chalk": "^2.0.0", + "js-tokens": "^4.0.0" + }, + "dependencies": { + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "requires": { + "color-convert": "^1.9.0" + } + }, + "chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + } + }, + "color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", + "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "dev": true, + "requires": { + "color-name": "1.1.3" + } + }, + "color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", + "dev": true + }, + "has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", + "dev": true + }, + "js-tokens": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", + "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", + "dev": true + }, + "supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "requires": { + "has-flag": "^3.0.0" + } + } + } + }, + "@babel/parser": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.20.7.tgz", + "integrity": "sha512-T3Z9oHybU+0vZlY9CiDSJQTD5ZapcW18ZctFMi0MOAl/4BjFF4ul7NVSARLdbGO5vDqy9eQiGTV0LtKfvCYvcg==", + "dev": true + }, + "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.18.6.tgz", + "integrity": "sha512-Dgxsyg54Fx1d4Nge8UnvTrED63vrwOdPmyvPzlNN/boaliRP54pm3pGzZD1SJUwrBA+Cs/xdG8kXX6Mn/RfISQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.20.7.tgz", + "integrity": "sha512-sbr9+wNE5aXMBBFBICk01tt7sBf2Oc9ikRFEcem/ZORup9IMUdNhW7/wVLEbbtlWOsEubJet46mHAL2C8+2jKQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.20.2", + "@babel/helper-skip-transparent-expression-wrappers": "^7.20.0", + "@babel/plugin-proposal-optional-chaining": "^7.20.7" + } + }, + "@babel/plugin-proposal-async-generator-functions": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.20.7.tgz", + "integrity": "sha512-xMbiLsn/8RK7Wq7VeVytytS2L6qE69bXPB10YCmMdDZbKF4okCqY74pI/jJQ/8U0b/F6NrT2+14b8/P9/3AMGA==", + "dev": true, + "requires": { + "@babel/helper-environment-visitor": "^7.18.9", + "@babel/helper-plugin-utils": "^7.20.2", + "@babel/helper-remap-async-to-generator": "^7.18.9", + "@babel/plugin-syntax-async-generators": "^7.8.4" + } + }, + "@babel/plugin-proposal-class-properties": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.18.6.tgz", + "integrity": "sha512-cumfXOF0+nzZrrN8Rf0t7M+tF6sZc7vhQwYQck9q1/5w2OExlD+b4v4RpMJFaV1Z7WcDRgO6FqvxqxGlwo+RHQ==", + "dev": true, + "requires": { + "@babel/helper-create-class-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-proposal-class-static-block": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-static-block/-/plugin-proposal-class-static-block-7.20.7.tgz", + "integrity": "sha512-AveGOoi9DAjUYYuUAG//Ig69GlazLnoyzMw68VCDux+c1tsnnH/OkYcpz/5xzMkEFC6UxjR5Gw1c+iY2wOGVeQ==", + "dev": true, + "requires": { + "@babel/helper-create-class-features-plugin": "^7.20.7", + "@babel/helper-plugin-utils": "^7.20.2", + "@babel/plugin-syntax-class-static-block": "^7.14.5" + } + }, + "@babel/plugin-proposal-dynamic-import": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-dynamic-import/-/plugin-proposal-dynamic-import-7.18.6.tgz", + "integrity": "sha512-1auuwmK+Rz13SJj36R+jqFPMJWyKEDd7lLSdOj4oJK0UTgGueSAtkrCvz9ewmgyU/P941Rv2fQwZJN8s6QruXw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-dynamic-import": "^7.8.3" + } + }, + "@babel/plugin-proposal-export-namespace-from": { + "version": "7.18.9", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-export-namespace-from/-/plugin-proposal-export-namespace-from-7.18.9.tgz", + "integrity": "sha512-k1NtHyOMvlDDFeb9G5PhUXuGj8m/wiwojgQVEhJ/fsVsMCpLyOP4h0uGEjYJKrRI+EVPlb5Jk+Gt9P97lOGwtA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.9", + "@babel/plugin-syntax-export-namespace-from": "^7.8.3" + } + }, + "@babel/plugin-proposal-json-strings": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.18.6.tgz", + "integrity": "sha512-lr1peyn9kOdbYc0xr0OdHTZ5FMqS6Di+H0Fz2I/JwMzGmzJETNeOFq2pBySw6X/KFL5EWDjlJuMsUGRFb8fQgQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-json-strings": "^7.8.3" + } + }, + "@babel/plugin-proposal-logical-assignment-operators": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-logical-assignment-operators/-/plugin-proposal-logical-assignment-operators-7.20.7.tgz", + "integrity": "sha512-y7C7cZgpMIjWlKE5T7eJwp+tnRYM89HmRvWM5EQuB5BoHEONjmQ8lSNmBUwOyy/GFRsohJED51YBF79hE1djug==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.20.2", + "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4" + } + }, + "@babel/plugin-proposal-nullish-coalescing-operator": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.18.6.tgz", + "integrity": "sha512-wQxQzxYeJqHcfppzBDnm1yAY0jSRkUXR2z8RePZYrKwMKgMlE8+Z6LUno+bd6LvbGh8Gltvy74+9pIYkr+XkKA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3" + } + }, + "@babel/plugin-proposal-numeric-separator": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.18.6.tgz", + "integrity": "sha512-ozlZFogPqoLm8WBr5Z8UckIoE4YQ5KESVcNudyXOR8uqIkliTEgJ3RoketfG6pmzLdeZF0H/wjE9/cCEitBl7Q==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-numeric-separator": "^7.10.4" + } + }, + "@babel/plugin-proposal-object-rest-spread": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.20.7.tgz", + "integrity": "sha512-d2S98yCiLxDVmBmE8UjGcfPvNEUbA1U5q5WxaWFUGRzJSVAZqm5W6MbPct0jxnegUZ0niLeNX+IOzEs7wYg9Dg==", + "dev": true, + "requires": { + "@babel/compat-data": "^7.20.5", + "@babel/helper-compilation-targets": "^7.20.7", + "@babel/helper-plugin-utils": "^7.20.2", + "@babel/plugin-syntax-object-rest-spread": "^7.8.3", + "@babel/plugin-transform-parameters": "^7.20.7" + } + }, + "@babel/plugin-proposal-optional-catch-binding": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.18.6.tgz", + "integrity": "sha512-Q40HEhs9DJQyaZfUjjn6vE8Cv4GmMHCYuMGIWUnlxH6400VGxOuwWsPt4FxXxJkC/5eOzgn0z21M9gMT4MOhbw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/plugin-syntax-optional-catch-binding": "^7.8.3" + } + }, + "@babel/plugin-proposal-optional-chaining": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.20.7.tgz", + "integrity": "sha512-T+A7b1kfjtRM51ssoOfS1+wbyCVqorfyZhT99TvxxLMirPShD8CzKMRepMlCBGM5RpHMbn8s+5MMHnPstJH6mQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.20.2", + "@babel/helper-skip-transparent-expression-wrappers": "^7.20.0", + "@babel/plugin-syntax-optional-chaining": "^7.8.3" + } + }, + "@babel/plugin-proposal-private-methods": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-methods/-/plugin-proposal-private-methods-7.18.6.tgz", + "integrity": "sha512-nutsvktDItsNn4rpGItSNV2sz1XwS+nfU0Rg8aCx3W3NOKVzdMjJRu0O5OkgDp3ZGICSTbgRpxZoWsxoKRvbeA==", + "dev": true, + "requires": { + "@babel/helper-create-class-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-proposal-private-property-in-object": { + "version": "7.20.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-property-in-object/-/plugin-proposal-private-property-in-object-7.20.5.tgz", + "integrity": "sha512-Vq7b9dUA12ByzB4EjQTPo25sFhY+08pQDBSZRtUAkj7lb7jahaHR5igera16QZ+3my1nYR4dKsNdYj5IjPHilQ==", + "dev": true, + "requires": { + "@babel/helper-annotate-as-pure": "^7.18.6", + "@babel/helper-create-class-features-plugin": "^7.20.5", + "@babel/helper-plugin-utils": "^7.20.2", + "@babel/plugin-syntax-private-property-in-object": "^7.14.5" + } + }, + "@babel/plugin-proposal-unicode-property-regex": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.18.6.tgz", + "integrity": "sha512-2BShG/d5yoZyXZfVePH91urL5wTG6ASZU9M4o03lKK8u8UW1y08OMttBSOADTcJrnPMpvDXRG3G8fyLh4ovs8w==", + "dev": true, + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-syntax-async-generators": { + "version": "7.8.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz", + "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-class-properties": { + "version": "7.12.13", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz", + "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.12.13" + } + }, + "@babel/plugin-syntax-class-static-block": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz", + "integrity": "sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-syntax-dynamic-import": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.3.tgz", + "integrity": "sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-export-namespace-from": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-export-namespace-from/-/plugin-syntax-export-namespace-from-7.8.3.tgz", + "integrity": "sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-syntax-import-assertions": { + "version": "7.20.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.20.0.tgz", + "integrity": "sha512-IUh1vakzNoWalR8ch/areW7qFopR2AEw03JlG7BbrDqmQ4X3q9uuipQwSGrUn7oGiemKjtSLDhNtQHzMHr1JdQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.19.0" + } + }, + "@babel/plugin-syntax-json-strings": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz", + "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-logical-assignment-operators": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz", + "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.10.4" + } + }, + "@babel/plugin-syntax-nullish-coalescing-operator": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz", + "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-numeric-separator": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz", + "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.10.4" + } + }, + "@babel/plugin-syntax-object-rest-spread": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz", + "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-optional-catch-binding": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz", + "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-optional-chaining": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz", + "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-private-property-in-object": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz", + "integrity": "sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-syntax-top-level-await": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz", + "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.14.5" + } + }, + "@babel/plugin-syntax-typescript": { + "version": "7.20.0", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.20.0.tgz", + "integrity": "sha512-rd9TkG+u1CExzS4SM1BlMEhMXwFLKVjOAFFCDx9PbX5ycJWDoWMcwdJH9RhkPu1dOgn5TrxLot/Gx6lWFuAUNQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.19.0" + } + }, + "@babel/plugin-transform-arrow-functions": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.20.7.tgz", + "integrity": "sha512-3poA5E7dzDomxj9WXWwuD6A5F3kc7VXwIJO+E+J8qtDtS+pXPAhrgEyh+9GBwBgPq1Z+bB+/JD60lp5jsN7JPQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.20.2" + } + }, + "@babel/plugin-transform-async-to-generator": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.20.7.tgz", + "integrity": "sha512-Uo5gwHPT9vgnSXQxqGtpdufUiWp96gk7yiP4Mp5bm1QMkEmLXBO7PAGYbKoJ6DhAwiNkcHFBol/x5zZZkL/t0Q==", + "dev": true, + "requires": { + "@babel/helper-module-imports": "^7.18.6", + "@babel/helper-plugin-utils": "^7.20.2", + "@babel/helper-remap-async-to-generator": "^7.18.9" + } + }, + "@babel/plugin-transform-block-scoped-functions": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.18.6.tgz", + "integrity": "sha512-ExUcOqpPWnliRcPqves5HJcJOvHvIIWfuS4sroBUenPuMdmW+SMHDakmtS7qOo13sVppmUijqeTv7qqGsvURpQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-transform-block-scoping": { + "version": "7.20.11", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.20.11.tgz", + "integrity": "sha512-tA4N427a7fjf1P0/2I4ScsHGc5jcHPbb30xMbaTke2gxDuWpUfXDuX1FEymJwKk4tuGUvGcejAR6HdZVqmmPyw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.20.2" + } + }, + "@babel/plugin-transform-classes": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.20.7.tgz", + "integrity": "sha512-LWYbsiXTPKl+oBlXUGlwNlJZetXD5Am+CyBdqhPsDVjM9Jc8jwBJFrKhHf900Kfk2eZG1y9MAG3UNajol7A4VQ==", + "dev": true, + "requires": { + "@babel/helper-annotate-as-pure": "^7.18.6", + "@babel/helper-compilation-targets": "^7.20.7", + "@babel/helper-environment-visitor": "^7.18.9", + "@babel/helper-function-name": "^7.19.0", + "@babel/helper-optimise-call-expression": "^7.18.6", + "@babel/helper-plugin-utils": "^7.20.2", + "@babel/helper-replace-supers": "^7.20.7", + "@babel/helper-split-export-declaration": "^7.18.6", + "globals": "^11.1.0" + } + }, + "@babel/plugin-transform-computed-properties": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.20.7.tgz", + "integrity": "sha512-Lz7MvBK6DTjElHAmfu6bfANzKcxpyNPeYBGEafyA6E5HtRpjpZwU+u7Qrgz/2OR0z+5TvKYbPdphfSaAcZBrYQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.20.2", + "@babel/template": "^7.20.7" + } + }, + "@babel/plugin-transform-destructuring": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.20.7.tgz", + "integrity": "sha512-Xwg403sRrZb81IVB79ZPqNQME23yhugYVqgTxAhT99h485F4f+GMELFhhOsscDUB7HCswepKeCKLn/GZvUKoBA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.20.2" + } + }, + "@babel/plugin-transform-dotall-regex": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.18.6.tgz", + "integrity": "sha512-6S3jpun1eEbAxq7TdjLotAsl4WpQI9DxfkycRcKrjhQYzU87qpXdknpBg/e+TdcMehqGnLFi7tnFUBR02Vq6wg==", + "dev": true, + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-transform-duplicate-keys": { + "version": "7.18.9", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.18.9.tgz", + "integrity": "sha512-d2bmXCtZXYc59/0SanQKbiWINadaJXqtvIQIzd4+hNwkWBgyCd5F/2t1kXoUdvPMrxzPvhK6EMQRROxsue+mfw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.9" + } + }, + "@babel/plugin-transform-exponentiation-operator": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.18.6.tgz", + "integrity": "sha512-wzEtc0+2c88FVR34aQmiz56dxEkxr2g8DQb/KfaFa1JYXOFVsbhvAonFN6PwVWj++fKmku8NP80plJ5Et4wqHw==", + "dev": true, + "requires": { + "@babel/helper-builder-binary-assignment-operator-visitor": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-transform-for-of": { + "version": "7.18.8", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.18.8.tgz", + "integrity": "sha512-yEfTRnjuskWYo0k1mHUqrVWaZwrdq8AYbfrpqULOJOaucGSp4mNMVps+YtA8byoevxS/urwU75vyhQIxcCgiBQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-transform-function-name": { + "version": "7.18.9", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.18.9.tgz", + "integrity": "sha512-WvIBoRPaJQ5yVHzcnJFor7oS5Ls0PYixlTYE63lCj2RtdQEl15M68FXQlxnG6wdraJIXRdR7KI+hQ7q/9QjrCQ==", + "dev": true, + "requires": { + "@babel/helper-compilation-targets": "^7.18.9", + "@babel/helper-function-name": "^7.18.9", + "@babel/helper-plugin-utils": "^7.18.9" + } + }, + "@babel/plugin-transform-literals": { + "version": "7.18.9", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.18.9.tgz", + "integrity": "sha512-IFQDSRoTPnrAIrI5zoZv73IFeZu2dhu6irxQjY9rNjTT53VmKg9fenjvoiOWOkJ6mm4jKVPtdMzBY98Fp4Z4cg==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.9" + } + }, + "@babel/plugin-transform-member-expression-literals": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.18.6.tgz", + "integrity": "sha512-qSF1ihLGO3q+/g48k85tUjD033C29TNTVB2paCwZPVmOsjn9pClvYYrM2VeJpBY2bcNkuny0YUyTNRyRxJ54KA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-transform-modules-amd": { + "version": "7.20.11", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.20.11.tgz", + "integrity": "sha512-NuzCt5IIYOW0O30UvqktzHYR2ud5bOWbY0yaxWZ6G+aFzOMJvrs5YHNikrbdaT15+KNO31nPOy5Fim3ku6Zb5g==", + "dev": true, + "requires": { + "@babel/helper-module-transforms": "^7.20.11", + "@babel/helper-plugin-utils": "^7.20.2" + } + }, + "@babel/plugin-transform-modules-commonjs": { + "version": "7.20.11", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.20.11.tgz", + "integrity": "sha512-S8e1f7WQ7cimJQ51JkAaDrEtohVEitXjgCGAS2N8S31Y42E+kWwfSz83LYz57QdBm7q9diARVqanIaH2oVgQnw==", + "dev": true, + "requires": { + "@babel/helper-module-transforms": "^7.20.11", + "@babel/helper-plugin-utils": "^7.20.2", + "@babel/helper-simple-access": "^7.20.2" + } + }, + "@babel/plugin-transform-modules-systemjs": { + "version": "7.20.11", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.20.11.tgz", + "integrity": "sha512-vVu5g9BPQKSFEmvt2TA4Da5N+QVS66EX21d8uoOihC+OCpUoGvzVsXeqFdtAEfVa5BILAeFt+U7yVmLbQnAJmw==", + "dev": true, + "requires": { + "@babel/helper-hoist-variables": "^7.18.6", + "@babel/helper-module-transforms": "^7.20.11", + "@babel/helper-plugin-utils": "^7.20.2", + "@babel/helper-validator-identifier": "^7.19.1" + } + }, + "@babel/plugin-transform-modules-umd": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.18.6.tgz", + "integrity": "sha512-dcegErExVeXcRqNtkRU/z8WlBLnvD4MRnHgNs3MytRO1Mn1sHRyhbcpYbVMGclAqOjdW+9cfkdZno9dFdfKLfQ==", + "dev": true, + "requires": { + "@babel/helper-module-transforms": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-transform-named-capturing-groups-regex": { + "version": "7.20.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.20.5.tgz", + "integrity": "sha512-mOW4tTzi5iTLnw+78iEq3gr8Aoq4WNRGpmSlrogqaiCBoR1HFhpU4JkpQFOHfeYx3ReVIFWOQJS4aZBRvuZ6mA==", + "dev": true, + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.20.5", + "@babel/helper-plugin-utils": "^7.20.2" + } + }, + "@babel/plugin-transform-new-target": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.18.6.tgz", + "integrity": "sha512-DjwFA/9Iu3Z+vrAn+8pBUGcjhxKguSMlsFqeCKbhb9BAV756v0krzVK04CRDi/4aqmk8BsHb4a/gFcaA5joXRw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-transform-object-super": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.18.6.tgz", + "integrity": "sha512-uvGz6zk+pZoS1aTZrOvrbj6Pp/kK2mp45t2B+bTDre2UgsZZ8EZLSJtUg7m/no0zOJUWgFONpB7Zv9W2tSaFlA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-replace-supers": "^7.18.6" + } + }, + "@babel/plugin-transform-parameters": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.20.7.tgz", + "integrity": "sha512-WiWBIkeHKVOSYPO0pWkxGPfKeWrCJyD3NJ53+Lrp/QMSZbsVPovrVl2aWZ19D/LTVnaDv5Ap7GJ/B2CTOZdrfA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.20.2" + } + }, + "@babel/plugin-transform-property-literals": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.18.6.tgz", + "integrity": "sha512-cYcs6qlgafTud3PAzrrRNbQtfpQ8+y/+M5tKmksS9+M1ckbH6kzY8MrexEM9mcA6JDsukE19iIRvAyYl463sMg==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-transform-regenerator": { + "version": "7.20.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.20.5.tgz", + "integrity": "sha512-kW/oO7HPBtntbsahzQ0qSE3tFvkFwnbozz3NWFhLGqH75vLEg+sCGngLlhVkePlCs3Jv0dBBHDzCHxNiFAQKCQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.20.2", + "regenerator-transform": "^0.15.1" + } + }, + "@babel/plugin-transform-reserved-words": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.18.6.tgz", + "integrity": "sha512-oX/4MyMoypzHjFrT1CdivfKZ+XvIPMFXwwxHp/r0Ddy2Vuomt4HDFGmft1TAY2yiTKiNSsh3kjBAzcM8kSdsjA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-transform-shorthand-properties": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.18.6.tgz", + "integrity": "sha512-eCLXXJqv8okzg86ywZJbRn19YJHU4XUa55oz2wbHhaQVn/MM+XhukiT7SYqp/7o00dg52Rj51Ny+Ecw4oyoygw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-transform-spread": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.20.7.tgz", + "integrity": "sha512-ewBbHQ+1U/VnH1fxltbJqDeWBU1oNLG8Dj11uIv3xVf7nrQu0bPGe5Rf716r7K5Qz+SqtAOVswoVunoiBtGhxw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.20.2", + "@babel/helper-skip-transparent-expression-wrappers": "^7.20.0" + } + }, + "@babel/plugin-transform-sticky-regex": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.18.6.tgz", + "integrity": "sha512-kfiDrDQ+PBsQDO85yj1icueWMfGfJFKN1KCkndygtu/C9+XUfydLC8Iv5UYJqRwy4zk8EcplRxEOeLyjq1gm6Q==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/plugin-transform-template-literals": { + "version": "7.18.9", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.18.9.tgz", + "integrity": "sha512-S8cOWfT82gTezpYOiVaGHrCbhlHgKhQt8XH5ES46P2XWmX92yisoZywf5km75wv5sYcXDUCLMmMxOLCtthDgMA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.9" + } + }, + "@babel/plugin-transform-typeof-symbol": { + "version": "7.18.9", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.18.9.tgz", + "integrity": "sha512-SRfwTtF11G2aemAZWivL7PD+C9z52v9EvMqH9BuYbabyPuKUvSWks3oCg6041pT925L4zVFqaVBeECwsmlguEw==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.9" + } + }, + "@babel/plugin-transform-typescript": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.20.7.tgz", + "integrity": "sha512-m3wVKEvf6SoszD8pu4NZz3PvfKRCMgk6D6d0Qi9hNnlM5M6CFS92EgF4EiHVLKbU0r/r7ty1hg7NPZwE7WRbYw==", + "dev": true, + "requires": { + "@babel/helper-create-class-features-plugin": "^7.20.7", + "@babel/helper-plugin-utils": "^7.20.2", + "@babel/plugin-syntax-typescript": "^7.20.0" + } + }, + "@babel/plugin-transform-unicode-escapes": { + "version": "7.18.10", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.18.10.tgz", + "integrity": "sha512-kKAdAI+YzPgGY/ftStBFXTI1LZFju38rYThnfMykS+IXy8BVx+res7s2fxf1l8I35DV2T97ezo6+SGrXz6B3iQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.9" + } + }, + "@babel/plugin-transform-unicode-regex": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.18.6.tgz", + "integrity": "sha512-gE7A6Lt7YLnNOL3Pb9BNeZvi+d8l7tcRrG4+pwJjK9hD2xX4mEvjlQW60G9EEmfXVYRPv9VRQcyegIVHCql/AA==", + "dev": true, + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + } + }, + "@babel/preset-env": { + "version": "7.20.2", + "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.20.2.tgz", + "integrity": "sha512-1G0efQEWR1EHkKvKHqbG+IN/QdgwfByUpM5V5QroDzGV2t3S/WXNQd693cHiHTlCFMpr9B6FkPFXDA2lQcKoDg==", + "dev": true, + "requires": { + "@babel/compat-data": "^7.20.1", + "@babel/helper-compilation-targets": "^7.20.0", + "@babel/helper-plugin-utils": "^7.20.2", + "@babel/helper-validator-option": "^7.18.6", + "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": "^7.18.6", + "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": "^7.18.9", + "@babel/plugin-proposal-async-generator-functions": "^7.20.1", + "@babel/plugin-proposal-class-properties": "^7.18.6", + "@babel/plugin-proposal-class-static-block": "^7.18.6", + "@babel/plugin-proposal-dynamic-import": "^7.18.6", + "@babel/plugin-proposal-export-namespace-from": "^7.18.9", + "@babel/plugin-proposal-json-strings": "^7.18.6", + "@babel/plugin-proposal-logical-assignment-operators": "^7.18.9", + "@babel/plugin-proposal-nullish-coalescing-operator": "^7.18.6", + "@babel/plugin-proposal-numeric-separator": "^7.18.6", + "@babel/plugin-proposal-object-rest-spread": "^7.20.2", + "@babel/plugin-proposal-optional-catch-binding": "^7.18.6", + "@babel/plugin-proposal-optional-chaining": "^7.18.9", + "@babel/plugin-proposal-private-methods": "^7.18.6", + "@babel/plugin-proposal-private-property-in-object": "^7.18.6", + "@babel/plugin-proposal-unicode-property-regex": "^7.18.6", + "@babel/plugin-syntax-async-generators": "^7.8.4", + "@babel/plugin-syntax-class-properties": "^7.12.13", + "@babel/plugin-syntax-class-static-block": "^7.14.5", + "@babel/plugin-syntax-dynamic-import": "^7.8.3", + "@babel/plugin-syntax-export-namespace-from": "^7.8.3", + "@babel/plugin-syntax-import-assertions": "^7.20.0", + "@babel/plugin-syntax-json-strings": "^7.8.3", + "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", + "@babel/plugin-syntax-numeric-separator": "^7.10.4", + "@babel/plugin-syntax-object-rest-spread": "^7.8.3", + "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", + "@babel/plugin-syntax-optional-chaining": "^7.8.3", + "@babel/plugin-syntax-private-property-in-object": "^7.14.5", + "@babel/plugin-syntax-top-level-await": "^7.14.5", + "@babel/plugin-transform-arrow-functions": "^7.18.6", + "@babel/plugin-transform-async-to-generator": "^7.18.6", + "@babel/plugin-transform-block-scoped-functions": "^7.18.6", + "@babel/plugin-transform-block-scoping": "^7.20.2", + "@babel/plugin-transform-classes": "^7.20.2", + "@babel/plugin-transform-computed-properties": "^7.18.9", + "@babel/plugin-transform-destructuring": "^7.20.2", + "@babel/plugin-transform-dotall-regex": "^7.18.6", + "@babel/plugin-transform-duplicate-keys": "^7.18.9", + "@babel/plugin-transform-exponentiation-operator": "^7.18.6", + "@babel/plugin-transform-for-of": "^7.18.8", + "@babel/plugin-transform-function-name": "^7.18.9", + "@babel/plugin-transform-literals": "^7.18.9", + "@babel/plugin-transform-member-expression-literals": "^7.18.6", + "@babel/plugin-transform-modules-amd": "^7.19.6", + "@babel/plugin-transform-modules-commonjs": "^7.19.6", + "@babel/plugin-transform-modules-systemjs": "^7.19.6", + "@babel/plugin-transform-modules-umd": "^7.18.6", + "@babel/plugin-transform-named-capturing-groups-regex": "^7.19.1", + "@babel/plugin-transform-new-target": "^7.18.6", + "@babel/plugin-transform-object-super": "^7.18.6", + "@babel/plugin-transform-parameters": "^7.20.1", + "@babel/plugin-transform-property-literals": "^7.18.6", + "@babel/plugin-transform-regenerator": "^7.18.6", + "@babel/plugin-transform-reserved-words": "^7.18.6", + "@babel/plugin-transform-shorthand-properties": "^7.18.6", + "@babel/plugin-transform-spread": "^7.19.0", + "@babel/plugin-transform-sticky-regex": "^7.18.6", + "@babel/plugin-transform-template-literals": "^7.18.9", + "@babel/plugin-transform-typeof-symbol": "^7.18.9", + "@babel/plugin-transform-unicode-escapes": "^7.18.10", + "@babel/plugin-transform-unicode-regex": "^7.18.6", + "@babel/preset-modules": "^0.1.5", + "@babel/types": "^7.20.2", + "babel-plugin-polyfill-corejs2": "^0.3.3", + "babel-plugin-polyfill-corejs3": "^0.6.0", + "babel-plugin-polyfill-regenerator": "^0.4.1", + "core-js-compat": "^3.25.1", + "semver": "^6.3.0" + }, + "dependencies": { + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + } + } + }, + "@babel/preset-modules": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/@babel/preset-modules/-/preset-modules-0.1.5.tgz", + "integrity": "sha512-A57th6YRG7oR3cq/yt/Y84MvGgE0eJG2F1JLhKuyG+jFxEgrd/HAMJatiFtmOiZurz+0DkrvbheCLaV5f2JfjA==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/plugin-proposal-unicode-property-regex": "^7.4.4", + "@babel/plugin-transform-dotall-regex": "^7.4.4", + "@babel/types": "^7.4.4", + "esutils": "^2.0.2" + } + }, + "@babel/preset-typescript": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/preset-typescript/-/preset-typescript-7.18.6.tgz", + "integrity": "sha512-s9ik86kXBAnD760aybBucdpnLsAt0jK1xqJn2juOn9lkOvSHV60os5hxoVJsPzMQxvnUJFAlkont2DvvaYEBtQ==", + "dev": true, + "requires": { + "@babel/helper-plugin-utils": "^7.18.6", + "@babel/helper-validator-option": "^7.18.6", + "@babel/plugin-transform-typescript": "^7.18.6" + } + }, + "@babel/register": { + "version": "7.18.9", + "resolved": "https://registry.npmjs.org/@babel/register/-/register-7.18.9.tgz", + "integrity": "sha512-ZlbnXDcNYHMR25ITwwNKT88JiaukkdVj/nG7r3wnuXkOTHc60Uy05PwMCPre0hSkY68E6zK3xz+vUJSP2jWmcw==", + "dev": true, + "requires": { + "clone-deep": "^4.0.1", + "find-cache-dir": "^2.0.0", + "make-dir": "^2.1.0", + "pirates": "^4.0.5", + "source-map-support": "^0.5.16" + } + }, + "@babel/runtime": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.20.7.tgz", + "integrity": "sha512-UF0tvkUtxwAgZ5W/KrkHf0Rn0fdnLDU9ScxBrEVNUprE/MzirjK4MJUX1/BVDv00Sv8cljtukVK1aky++X1SjQ==", + "dev": true, + "requires": { + "regenerator-runtime": "^0.13.11" + } + }, + "@babel/template": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.20.7.tgz", + "integrity": "sha512-8SegXApWe6VoNw0r9JHpSteLKTpTiLZ4rMlGIm9JQ18KiCtyQiAMEazujAHrUS5flrcqYZa75ukev3P6QmUwUw==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.18.6", + "@babel/parser": "^7.20.7", + "@babel/types": "^7.20.7" + } + }, + "@babel/traverse": { + "version": "7.20.10", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.20.10.tgz", + "integrity": "sha512-oSf1juCgymrSez8NI4A2sr4+uB/mFd9MXplYGPEBnfAuWmmyeVcHa6xLPiaRBcXkcb/28bgxmQLTVwFKE1yfsg==", + "dev": true, + "requires": { + "@babel/code-frame": "^7.18.6", + "@babel/generator": "^7.20.7", + "@babel/helper-environment-visitor": "^7.18.9", + "@babel/helper-function-name": "^7.19.0", + "@babel/helper-hoist-variables": "^7.18.6", + "@babel/helper-split-export-declaration": "^7.18.6", + "@babel/parser": "^7.20.7", + "@babel/types": "^7.20.7", + "debug": "^4.1.0", + "globals": "^11.1.0" + }, + "dependencies": { + "debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "requires": { + "ms": "2.1.2" + } + }, + "globals": { + "version": "11.12.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", + "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", + "dev": true + }, + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + } + } + }, + "@babel/types": { + "version": "7.20.7", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.20.7.tgz", + "integrity": "sha512-69OnhBxSSgK0OzTJai4kyPDiKTIe3j+ctaHdIGVbRahTLAT7L3R9oeXHC2aVSuGYt3cVnoAMDmOCgJ2yaiLMvg==", + "dev": true, + "requires": { + "@babel/helper-string-parser": "^7.19.4", + "@babel/helper-validator-identifier": "^7.19.1", + "to-fast-properties": "^2.0.0" + }, + "dependencies": { + "to-fast-properties": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", + "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", + "dev": true + } + } + }, + "@eslint/eslintrc": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-1.4.1.tgz", + "integrity": "sha512-XXrH9Uarn0stsyldqDYq8r++mROmWRI1xKMXa640Bb//SY1+ECYX6VzT6Lcx5frD0V30XieqJ0oX9I2Xj5aoMA==", + "dev": true, + "requires": { + "ajv": "^6.12.4", + "debug": "^4.3.2", + "espree": "^9.4.0", + "globals": "^13.19.0", + "ignore": "^5.2.0", + "import-fresh": "^3.2.1", + "js-yaml": "^4.1.0", + "minimatch": "^3.1.2", + "strip-json-comments": "^3.1.1" + }, + "dependencies": { + "debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "requires": { + "ms": "2.1.2" + } + }, + "globals": { + "version": "13.19.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-13.19.0.tgz", + "integrity": "sha512-dkQ957uSRWHw7CFXLUtUHQI3g3aWApYhfNR2O6jn/907riyTYKVBmxYVROkBcY614FSSeSJh7Xm7SrUWCxvJMQ==", + "dev": true, + "requires": { + "type-fest": "^0.20.2" + } + }, + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + }, + "type-fest": { + "version": "0.20.2", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", + "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", + "dev": true + } + } + }, + "@humanwhocodes/config-array": { + "version": "0.11.8", + "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.8.tgz", + "integrity": "sha512-UybHIJzJnR5Qc/MsD9Kr+RpO2h+/P1GhOwdiLPXK5TWk5sgTdu88bTD9UP+CKbPPh5Rni1u0GjAdYQLemG8g+g==", + "dev": true, + "requires": { + "@humanwhocodes/object-schema": "^1.2.1", + "debug": "^4.1.1", + "minimatch": "^3.0.5" + }, + "dependencies": { + "debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "requires": { + "ms": "2.1.2" + } + }, + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + } + } + }, + "@humanwhocodes/module-importer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", + "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", + "dev": true + }, + "@humanwhocodes/object-schema": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", + "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", + "dev": true + }, + "@jridgewell/gen-mapping": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz", + "integrity": "sha512-sQXCasFk+U8lWYEe66WxRDOE9PjVz4vSM51fTu3Hw+ClTpUSQb718772vH3pyS5pShp6lvQM7SxgIDXXXmOX7w==", + "dev": true, + "requires": { + "@jridgewell/set-array": "^1.0.0", + "@jridgewell/sourcemap-codec": "^1.4.10" + } + }, + "@jridgewell/resolve-uri": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", + "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", + "dev": true + }, + "@jridgewell/set-array": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", + "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", + "dev": true + }, + "@jridgewell/sourcemap-codec": { + "version": "1.4.14", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", + "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==", + "dev": true + }, + "@jridgewell/trace-mapping": { + "version": "0.3.17", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.17.tgz", + "integrity": "sha512-MCNzAp77qzKca9+W/+I0+sEpaUnZoeasnghNeVc41VZCEKaCH73Vq3BZZ/SzWIgrqE4H4ceI+p+b6C0mHf9T4g==", + "dev": true, + "requires": { + "@jridgewell/resolve-uri": "3.1.0", + "@jridgewell/sourcemap-codec": "1.4.14" + } + }, + "@nicolo-ribaudo/chokidar-2": { + "version": "2.1.8-no-fsevents.3", + "resolved": "https://registry.npmjs.org/@nicolo-ribaudo/chokidar-2/-/chokidar-2-2.1.8-no-fsevents.3.tgz", + "integrity": "sha512-s88O1aVtXftvp5bCPB7WnmXc5IwOZZ7YPuwNPt+GtOOXpPvad1LfbmjYv+qII7zP6RU2QGnqve27dnLycEnyEQ==", + "dev": true, + "optional": true + }, + "@nodelib/fs.scandir": { + "version": "2.1.5", + "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", + "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", + "dev": true, + "requires": { + "@nodelib/fs.stat": "2.0.5", + "run-parallel": "^1.1.9" + } + }, + "@nodelib/fs.stat": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", + "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", + "dev": true + }, + "@nodelib/fs.walk": { + "version": "1.2.8", + "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", + "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", + "dev": true, + "requires": { + "@nodelib/fs.scandir": "2.1.5", + "fastq": "^1.6.0" + } + }, + "@types/chai": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/@types/chai/-/chai-4.3.4.tgz", + "integrity": "sha512-KnRanxnpfpjUTqTCXslZSEdLfXExwgNxYPdiO2WGUj8+HDjFi8R3k5RVKPeSCzLjCcshCAtVO2QBbVuAV4kTnw==", + "dev": true + }, + "@types/json-schema": { + "version": "7.0.11", + "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.11.tgz", + "integrity": "sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ==", + "dev": true + }, + "@types/json5": { + "version": "0.0.29", + "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz", + "integrity": "sha512-dRLjCWHYg4oaA77cxO64oO+7JwCwnIzkZPdrrC71jQmQtlhM556pwKo5bUzqvZndkVbeFLIIi+9TC40JNF5hNQ==", + "dev": true, + "optional": true + }, + "@types/mocha": { + "version": "10.0.1", + "resolved": "https://registry.npmjs.org/@types/mocha/-/mocha-10.0.1.tgz", + "integrity": "sha512-/fvYntiO1GeICvqbQ3doGDIP97vWmvFt83GKguJ6prmQM2iXZfFcq6YE8KteFyRtX2/h5Hf91BYvPodJKFYv5Q==", + "dev": true + }, + "@types/node": { + "version": "18.11.18", + "resolved": "https://registry.npmjs.org/@types/node/-/node-18.11.18.tgz", + "integrity": "sha512-DHQpWGjyQKSHj3ebjFI/wRKcqQcdR+MoFBygntYOZytCqNfkd2ZC4ARDJ2DQqhjH5p85Nnd3jhUJIXrszFX/JA==", + "dev": true + }, + "@types/semver": { + "version": "7.3.13", + "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.3.13.tgz", + "integrity": "sha512-21cFJr9z3g5dW8B0CVI9g2O9beqaThGQ6ZFBqHfwhzLDKUxaqTIy3vnfah/UPkfOiF2pLq+tGz+W8RyCskuslw==", + "dev": true + }, + "@types/text-encoding": { + "version": "0.0.36", + "resolved": "https://registry.npmjs.org/@types/text-encoding/-/text-encoding-0.0.36.tgz", + "integrity": "sha512-LfATA7bH+MtAPlOshYgQ1M3n2r0TSB6Ns5ESvKYlVugkKErQg5oFbR2qO7XrKtNsrtzedDvTeqQfyTjdPJH7jw==", + "dev": true + }, + "@typescript-eslint/eslint-plugin": { + "version": "5.48.1", + "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.48.1.tgz", + "integrity": "sha512-9nY5K1Rp2ppmpb9s9S2aBiF3xo5uExCehMDmYmmFqqyxgenbHJ3qbarcLt4ITgaD6r/2ypdlcFRdcuVPnks+fQ==", + "dev": true, + "requires": { + "@typescript-eslint/scope-manager": "5.48.1", + "@typescript-eslint/type-utils": "5.48.1", + "@typescript-eslint/utils": "5.48.1", + "debug": "^4.3.4", + "ignore": "^5.2.0", + "natural-compare-lite": "^1.4.0", + "regexpp": "^3.2.0", + "semver": "^7.3.7", + "tsutils": "^3.21.0" + }, + "dependencies": { + "debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "requires": { + "ms": "2.1.2" + } + }, + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + } + } + }, + "@typescript-eslint/parser": { + "version": "5.48.1", + "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-5.48.1.tgz", + "integrity": "sha512-4yg+FJR/V1M9Xoq56SF9Iygqm+r5LMXvheo6DQ7/yUWynQ4YfCRnsKuRgqH4EQ5Ya76rVwlEpw4Xu+TgWQUcdA==", + "dev": true, + "requires": { + "@typescript-eslint/scope-manager": "5.48.1", + "@typescript-eslint/types": "5.48.1", + "@typescript-eslint/typescript-estree": "5.48.1", + "debug": "^4.3.4" + }, + "dependencies": { + "debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "requires": { + "ms": "2.1.2" + } + }, + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + } + } + }, + "@typescript-eslint/scope-manager": { + "version": "5.48.1", + "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.48.1.tgz", + "integrity": "sha512-S035ueRrbxRMKvSTv9vJKIWgr86BD8s3RqoRZmsSh/s8HhIs90g6UlK8ZabUSjUZQkhVxt7nmZ63VJ9dcZhtDQ==", + "dev": true, + "requires": { + "@typescript-eslint/types": "5.48.1", + "@typescript-eslint/visitor-keys": "5.48.1" + } + }, + "@typescript-eslint/type-utils": { + "version": "5.48.1", + "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-5.48.1.tgz", + "integrity": "sha512-Hyr8HU8Alcuva1ppmqSYtM/Gp0q4JOp1F+/JH5D1IZm/bUBrV0edoewQZiEc1r6I8L4JL21broddxK8HAcZiqQ==", + "dev": true, + "requires": { + "@typescript-eslint/typescript-estree": "5.48.1", + "@typescript-eslint/utils": "5.48.1", + "debug": "^4.3.4", + "tsutils": "^3.21.0" + }, + "dependencies": { + "debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "requires": { + "ms": "2.1.2" + } + }, + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + } + } + }, + "@typescript-eslint/types": { + "version": "5.48.1", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.48.1.tgz", + "integrity": "sha512-xHyDLU6MSuEEdIlzrrAerCGS3T7AA/L8Hggd0RCYBi0w3JMvGYxlLlXHeg50JI9Tfg5MrtsfuNxbS/3zF1/ATg==", + "dev": true + }, + "@typescript-eslint/typescript-estree": { + "version": "5.48.1", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-5.48.1.tgz", + "integrity": "sha512-Hut+Osk5FYr+sgFh8J/FHjqX6HFcDzTlWLrFqGoK5kVUN3VBHF/QzZmAsIXCQ8T/W9nQNBTqalxi1P3LSqWnRA==", + "dev": true, + "requires": { + "@typescript-eslint/types": "5.48.1", + "@typescript-eslint/visitor-keys": "5.48.1", + "debug": "^4.3.4", + "globby": "^11.1.0", + "is-glob": "^4.0.3", + "semver": "^7.3.7", + "tsutils": "^3.21.0" + }, + "dependencies": { + "debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "requires": { + "ms": "2.1.2" + } + }, + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + } + } + }, + "@typescript-eslint/utils": { + "version": "5.48.1", + "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-5.48.1.tgz", + "integrity": "sha512-SmQuSrCGUOdmGMwivW14Z0Lj8dxG1mOFZ7soeJ0TQZEJcs3n5Ndgkg0A4bcMFzBELqLJ6GTHnEU+iIoaD6hFGA==", + "dev": true, + "requires": { + "@types/json-schema": "^7.0.9", + "@types/semver": "^7.3.12", + "@typescript-eslint/scope-manager": "5.48.1", + "@typescript-eslint/types": "5.48.1", + "@typescript-eslint/typescript-estree": "5.48.1", + "eslint-scope": "^5.1.1", + "eslint-utils": "^3.0.0", + "semver": "^7.3.7" + } + }, + "@typescript-eslint/visitor-keys": { + "version": "5.48.1", + "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.48.1.tgz", + "integrity": "sha512-Ns0XBwmfuX7ZknznfXozgnydyR8F6ev/KEGePP4i74uL3ArsKbEhJ7raeKr1JSa997DBDwol/4a0Y+At82c9dA==", + "dev": true, + "requires": { + "@typescript-eslint/types": "5.48.1", + "eslint-visitor-keys": "^3.3.0" + } + }, + "acorn": { + "version": "8.8.1", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.8.1.tgz", + "integrity": "sha512-7zFpHzhnqYKrkYdUjF1HI1bzd0VygEGX8lFk4k5zVMqHEoES+P+7TKI+EvLO9WVMJ8eekdO0aDEK044xTXwPPA==", + "dev": true + }, + "acorn-jsx": { + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", + "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", + "dev": true + }, + "ajv": { + "version": "6.12.6", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", + "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", + "dev": true, + "requires": { + "fast-deep-equal": "^3.1.1", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" + } + }, + "ansi-colors": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", + "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", + "dev": true + }, + "ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", + "dev": true + }, + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "argparse": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", + "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", + "dev": true + }, + "array-union": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", + "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", + "dev": true + }, + "arrify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", + "integrity": "sha512-3CYzex9M9FGQjCGMGyi6/31c8GJbgb0qGyrx5HWxPd0aCwh4cB2YjMb2Xf9UuoogrMrlO9cTqnB5rI5GHZTcUA==", + "dev": true + }, + "assertion-error": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", + "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", + "dev": true + }, + "babel-plugin-polyfill-corejs2": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.3.3.tgz", + "integrity": "sha512-8hOdmFYFSZhqg2C/JgLUQ+t52o5nirNwaWM2B9LWteozwIvM14VSwdsCAUET10qT+kmySAlseadmfeeSWFCy+Q==", + "dev": true, + "requires": { + "@babel/compat-data": "^7.17.7", + "@babel/helper-define-polyfill-provider": "^0.3.3", + "semver": "^6.1.1" + }, + "dependencies": { + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true + } + } + }, + "babel-plugin-polyfill-corejs3": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.6.0.tgz", + "integrity": "sha512-+eHqR6OPcBhJOGgsIar7xoAB1GcSwVUA3XjAd7HJNzOXT4wv6/H7KIdA/Nc60cvUlDbKApmqNvD1B1bzOt4nyA==", + "dev": true, + "requires": { + "@babel/helper-define-polyfill-provider": "^0.3.3", + "core-js-compat": "^3.25.1" + } + }, + "babel-plugin-polyfill-regenerator": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.4.1.tgz", + "integrity": "sha512-NtQGmyQDXjQqQ+IzRkBVwEOz9lQ4zxAQZgoAYEtU9dJjnl1Oc98qnN7jcp+bE7O7aYzVpavXE3/VKXNzUbh7aw==", + "dev": true, + "requires": { + "@babel/helper-define-polyfill-provider": "^0.3.3" + } + }, + "balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", + "dev": true + }, + "brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "braces": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", + "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", + "dev": true, + "requires": { + "fill-range": "^7.0.1" + } + }, + "browser-stdout": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", + "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", + "dev": true + }, + "browserslist": { + "version": "4.21.4", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.4.tgz", + "integrity": "sha512-CBHJJdDmgjl3daYjN5Cp5kbTf1mUhZoS+beLklHIvkOWscs83YAhLlF3Wsh/lciQYAcbBJgTOD44VtG31ZM4Hw==", + "dev": true, + "requires": { + "caniuse-lite": "^1.0.30001400", + "electron-to-chromium": "^1.4.251", + "node-releases": "^2.0.6", + "update-browserslist-db": "^1.0.9" + } + }, + "buffer-from": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", + "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", + "dev": true + }, + "callsites": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", + "dev": true + }, + "camelcase": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", + "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", + "dev": true + }, + "caniuse-lite": { + "version": "1.0.30001441", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001441.tgz", + "integrity": "sha512-OyxRR4Vof59I3yGWXws6i908EtGbMzVUi3ganaZQHmydk1iwDhRnvaPG2WaR0KcqrDFKrxVZHULT396LEPhXfg==", + "dev": true + }, + "chai": { + "version": "4.3.7", + "resolved": "https://registry.npmjs.org/chai/-/chai-4.3.7.tgz", + "integrity": "sha512-HLnAzZ2iupm25PlN0xFreAlBA5zaBSv3og0DdeGA4Ar6h6rJ3A0rolRUKJhSF2V10GZKDgWF/VmAEsNWjCRB+A==", + "dev": true, + "requires": { + "assertion-error": "^1.1.0", + "check-error": "^1.0.2", + "deep-eql": "^4.1.2", + "get-func-name": "^2.0.0", + "loupe": "^2.3.1", + "pathval": "^1.1.1", + "type-detect": "^4.0.5" + } + }, + "chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", + "dev": true, + "requires": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + } + }, + "check-error": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", + "integrity": "sha512-BrgHpW9NURQgzoNyjfq0Wu6VFO6D7IZEmJNdtgNqpzGG8RuNFHt2jQxWlAs4HMe119chBnv+34syEZtc6IhLtA==", + "dev": true + }, + "cliui": { + "version": "7.0.4", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", + "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", + "dev": true, + "requires": { + "string-width": "^4.2.0", + "strip-ansi": "^6.0.0", + "wrap-ansi": "^7.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", + "dev": true + }, + "strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "requires": { + "ansi-regex": "^5.0.1" + } + } + } + }, + "clone-deep": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/clone-deep/-/clone-deep-4.0.1.tgz", + "integrity": "sha512-neHB9xuzh/wk0dIHweyAXv2aPGZIVk3pLMe+/RNzINf17fe0OG96QroktYAUm7SM1PBnzTabaLboqqxDyMU+SQ==", + "dev": true, + "requires": { + "is-plain-object": "^2.0.4", + "kind-of": "^6.0.2", + "shallow-clone": "^3.0.0" + } + }, + "color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "requires": { + "color-name": "~1.1.4" + } + }, + "color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, + "commondir": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", + "integrity": "sha512-W9pAhw0ja1Edb5GVdIF1mjZw/ASI0AlShXM83UUGe2DVr5TdAPEA1OA8m/g8zWp9x6On7gqufY+FatDbC3MDQg==", + "dev": true + }, + "concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", + "dev": true + }, + "concat-stream": { + "version": "1.6.2", + "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", + "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", + "dev": true, + "requires": { + "buffer-from": "^1.0.0", + "inherits": "^2.0.3", + "readable-stream": "^2.2.2", + "typedarray": "^0.0.6" + } + }, + "convert-source-map": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", + "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==", + "dev": true + }, + "core-js-compat": { + "version": "3.27.1", + "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.27.1.tgz", + "integrity": "sha512-Dg91JFeCDA17FKnneN7oCMz4BkQ4TcffkgHP4OWwp9yx3pi7ubqMDXXSacfNak1PQqjc95skyt+YBLHQJnkJwA==", + "dev": true, + "requires": { + "browserslist": "^4.21.4" + } + }, + "core-util-is": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", + "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==", + "dev": true + }, + "cross-spawn": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz", + "integrity": "sha512-pTgQJ5KC0d2hcY8eyL1IzlBPYjTkyH72XRZPnLyKus2mBfNjQs3klqbJU2VILqZryAZUt9JOb3h/mWMy23/f5A==", + "dev": true, + "requires": { + "lru-cache": "^4.0.1", + "shebang-command": "^1.2.0", + "which": "^1.2.9" + } + }, + "decamelize": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-4.0.0.tgz", + "integrity": "sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ==", + "dev": true + }, + "deep-eql": { + "version": "4.1.3", + "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-4.1.3.tgz", + "integrity": "sha512-WaEtAOpRA1MQ0eohqZjpGD8zdI0Ovsm8mmFhaDN8dvDZzyoUMcYDnf5Y6iu7HTXxf8JDS23qWa4a+hKCDyOPzw==", + "dev": true, + "requires": { + "type-detect": "^4.0.0" + } + }, + "deep-is": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", + "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", + "dev": true + }, + "diff": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/diff/-/diff-5.0.0.tgz", + "integrity": "sha512-/VTCrvm5Z0JGty/BWHljh+BAiw3IK+2j87NGMu8Nwc/f48WoDAC395uomO9ZD117ZOBaHmkX1oyLvkVM/aIT3w==", + "dev": true + }, + "dir-glob": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", + "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", + "dev": true, + "requires": { + "path-type": "^4.0.0" + } + }, + "doctrine": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", + "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", + "dev": true, + "requires": { + "esutils": "^2.0.2" + } + }, + "electron-to-chromium": { + "version": "1.4.284", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.284.tgz", + "integrity": "sha512-M8WEXFuKXMYMVr45fo8mq0wUrrJHheiKZf6BArTKk9ZBYCKJEOU5H8cdWgDT+qCVZf7Na4lVUaZsA+h6uA9+PA==", + "dev": true + }, + "emailjs-base64": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/emailjs-base64/-/emailjs-base64-1.1.4.tgz", + "integrity": "sha512-4h0xp1jgVTnIQBHxSJWXWanNnmuc5o+k4aHEpcLXSToN8asjB5qbXAexs7+PEsUKcEyBteNYsSvXUndYT2CGGA==" + }, + "emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true + }, + "escalade": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", + "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", + "dev": true + }, + "escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", + "dev": true + }, + "eslint": { + "version": "8.31.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.31.0.tgz", + "integrity": "sha512-0tQQEVdmPZ1UtUKXjX7EMm9BlgJ08G90IhWh0PKDCb3ZLsgAOHI8fYSIzYVZej92zsgq+ft0FGsxhJ3xo2tbuA==", + "dev": true, + "requires": { + "@eslint/eslintrc": "^1.4.1", + "@humanwhocodes/config-array": "^0.11.8", + "@humanwhocodes/module-importer": "^1.0.1", + "@nodelib/fs.walk": "^1.2.8", + "ajv": "^6.10.0", + "chalk": "^4.0.0", + "cross-spawn": "^7.0.2", + "debug": "^4.3.2", + "doctrine": "^3.0.0", + "escape-string-regexp": "^4.0.0", + "eslint-scope": "^7.1.1", + "eslint-utils": "^3.0.0", + "eslint-visitor-keys": "^3.3.0", + "espree": "^9.4.0", + "esquery": "^1.4.0", + "esutils": "^2.0.2", + "fast-deep-equal": "^3.1.3", + "file-entry-cache": "^6.0.1", + "find-up": "^5.0.0", + "glob-parent": "^6.0.2", + "globals": "^13.19.0", + "grapheme-splitter": "^1.0.4", + "ignore": "^5.2.0", + "import-fresh": "^3.0.0", + "imurmurhash": "^0.1.4", + "is-glob": "^4.0.0", + "is-path-inside": "^3.0.3", + "js-sdsl": "^4.1.4", + "js-yaml": "^4.1.0", + "json-stable-stringify-without-jsonify": "^1.0.1", + "levn": "^0.4.1", + "lodash.merge": "^4.6.2", + "minimatch": "^3.1.2", + "natural-compare": "^1.4.0", + "optionator": "^0.9.1", + "regexpp": "^3.2.0", + "strip-ansi": "^6.0.1", + "strip-json-comments": "^3.1.0", + "text-table": "^0.2.0" + }, + "dependencies": { + "cross-spawn": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", + "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", + "dev": true, + "requires": { + "path-key": "^3.1.0", + "shebang-command": "^2.0.0", + "which": "^2.0.1" + } + }, + "debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "requires": { + "ms": "2.1.2" + } + }, + "escape-string-regexp": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", + "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", + "dev": true + }, + "eslint-scope": { + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.1.1.tgz", + "integrity": "sha512-QKQM/UXpIiHcLqJ5AOyIW7XZmzjkzQXYE54n1++wb0u9V/abW3l9uQnxX8Z5Xd18xyKIMTUAyQ0k1e8pz6LUrw==", + "dev": true, + "requires": { + "esrecurse": "^4.3.0", + "estraverse": "^5.2.0" + } + }, + "glob-parent": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", + "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", + "dev": true, + "requires": { + "is-glob": "^4.0.3" + } + }, + "globals": { + "version": "13.19.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-13.19.0.tgz", + "integrity": "sha512-dkQ957uSRWHw7CFXLUtUHQI3g3aWApYhfNR2O6jn/907riyTYKVBmxYVROkBcY614FSSeSJh7Xm7SrUWCxvJMQ==", + "dev": true, + "requires": { + "type-fest": "^0.20.2" + } + }, + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + }, + "shebang-command": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", + "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", + "dev": true, + "requires": { + "shebang-regex": "^3.0.0" + } + }, + "shebang-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", + "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", + "dev": true + }, + "type-fest": { + "version": "0.20.2", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", + "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", + "dev": true + }, + "which": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + } + } + }, + "eslint-scope": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", + "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", + "dev": true, + "requires": { + "esrecurse": "^4.3.0", + "estraverse": "^4.1.1" + }, + "dependencies": { + "estraverse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", + "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", + "dev": true + } + } + }, + "eslint-utils": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz", + "integrity": "sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==", + "dev": true, + "requires": { + "eslint-visitor-keys": "^2.0.0" + }, + "dependencies": { + "eslint-visitor-keys": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", + "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", + "dev": true + } + } + }, + "eslint-visitor-keys": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.3.0.tgz", + "integrity": "sha512-mQ+suqKJVyeuwGYHAdjMFqjCyfl8+Ldnxuyp3ldiMBFKkvytrXUZWaiPCEav8qDHKty44bD+qV1IP4T+w+xXRA==", + "dev": true + }, + "espree": { + "version": "9.4.1", + "resolved": "https://registry.npmjs.org/espree/-/espree-9.4.1.tgz", + "integrity": "sha512-XwctdmTO6SIvCzd9810yyNzIrOrqNYV9Koizx4C/mRhf9uq0o4yHoCEU/670pOxOL/MSraektvSAji79kX90Vg==", + "dev": true, + "requires": { + "acorn": "^8.8.0", + "acorn-jsx": "^5.3.2", + "eslint-visitor-keys": "^3.3.0" + } + }, + "esquery": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", + "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", + "dev": true, + "requires": { + "estraverse": "^5.1.0" + } + }, + "esrecurse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", + "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", + "dev": true, + "requires": { + "estraverse": "^5.2.0" + } + }, + "estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", + "dev": true + }, + "esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", + "dev": true + }, + "fast-deep-equal": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", + "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", + "dev": true + }, + "fast-glob": { + "version": "3.2.12", + "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.2.12.tgz", + "integrity": "sha512-DVj4CQIYYow0BlaelwK1pHl5n5cRSJfM60UA0zK891sVInoPri2Ekj7+e1CT3/3qxXenpI+nBBmQAcJPJgaj4w==", + "dev": true, + "requires": { + "@nodelib/fs.stat": "^2.0.2", + "@nodelib/fs.walk": "^1.2.3", + "glob-parent": "^5.1.2", + "merge2": "^1.3.0", + "micromatch": "^4.0.4" + } + }, + "fast-json-stable-stringify": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", + "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", + "dev": true + }, + "fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", + "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", + "dev": true + }, + "fastq": { + "version": "1.15.0", + "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.15.0.tgz", + "integrity": "sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==", + "dev": true, + "requires": { + "reusify": "^1.0.4" + } + }, + "file-entry-cache": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", + "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", + "dev": true, + "requires": { + "flat-cache": "^3.0.4" + } + }, + "fill-range": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", + "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", + "dev": true, + "requires": { + "to-regex-range": "^5.0.1" + } + }, + "find-cache-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-2.1.0.tgz", + "integrity": "sha512-Tq6PixE0w/VMFfCgbONnkiQIVol/JJL7nRMi20fqzA4NRs9AfeqMGeRdPi3wIhYkxjeBaWh2rxwapn5Tu3IqOQ==", + "dev": true, + "requires": { + "commondir": "^1.0.1", + "make-dir": "^2.0.0", + "pkg-dir": "^3.0.0" + } + }, + "find-up": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", + "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", + "dev": true, + "requires": { + "locate-path": "^6.0.0", + "path-exists": "^4.0.0" + } + }, + "flat": { + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/flat/-/flat-5.0.2.tgz", + "integrity": "sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==", + "dev": true + }, + "flat-cache": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", + "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", + "dev": true, + "requires": { + "flatted": "^3.1.0", + "rimraf": "^3.0.2" + } + }, + "flatted": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.7.tgz", + "integrity": "sha512-5nqDSxl8nn5BSNxyR3n4I6eDmbolI6WT+QqR547RwxQapgjQBmtktdP+HTBb/a/zLsbzERTONyUB5pefh5TtjQ==", + "dev": true + }, + "fs-readdir-recursive": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/fs-readdir-recursive/-/fs-readdir-recursive-1.1.0.tgz", + "integrity": "sha512-GNanXlVr2pf02+sPN40XN8HG+ePaNcvM0q5mZBd668Obwb0yD5GiUbZOFgwn8kGMY6I3mdyDJzieUy3PTYyTRA==", + "dev": true + }, + "fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", + "dev": true + }, + "function-bind": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", + "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", + "dev": true + }, + "gensync": { + "version": "1.0.0-beta.2", + "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", + "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", + "dev": true + }, + "get-caller-file": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", + "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", + "dev": true + }, + "get-func-name": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", + "integrity": "sha512-Hm0ixYtaSZ/V7C8FJrtZIuBBI+iSgL+1Aq82zSu8VQNB4S3Gk8e7Qs3VwBDJAhmRZcFqkl3tQu36g/Foh5I5ig==", + "dev": true + }, + "glob": { + "version": "7.2.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", + "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", + "dev": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.1.1", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", + "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", + "dev": true, + "requires": { + "is-glob": "^4.0.1" + } + }, + "globals": { + "version": "11.12.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", + "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", + "dev": true + }, + "globby": { + "version": "11.1.0", + "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", + "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", + "dev": true, + "requires": { + "array-union": "^2.1.0", + "dir-glob": "^3.0.1", + "fast-glob": "^3.2.9", + "ignore": "^5.2.0", + "merge2": "^1.4.1", + "slash": "^3.0.0" + } + }, + "grapheme-splitter": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/grapheme-splitter/-/grapheme-splitter-1.0.4.tgz", + "integrity": "sha512-bzh50DW9kTPM00T8y4o8vQg89Di9oLJVLW/KaOGIXJWP/iqCN6WKYkbNOF04vFLJhwcpYUh9ydh/+5vpOqV4YQ==", + "dev": true + }, + "has": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", + "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", + "dev": true, + "requires": { + "function-bind": "^1.1.1" + } + }, + "has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true + }, + "he": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", + "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", + "dev": true + }, + "ignore": { + "version": "5.2.4", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz", + "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==", + "dev": true + }, + "import-fresh": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", + "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", + "dev": true, + "requires": { + "parent-module": "^1.0.0", + "resolve-from": "^4.0.0" + } + }, + "imurmurhash": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", + "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", + "dev": true + }, + "inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", + "dev": true, + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", + "dev": true + }, + "is-core-module": { + "version": "2.11.0", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.11.0.tgz", + "integrity": "sha512-RRjxlvLDkD1YJwDbroBHMb+cukurkDWNyHx7D3oNB5x9rb5ogcksMC5wHCadcXoo67gVr/+3GFySh3134zi6rw==", + "dev": true, + "requires": { + "has": "^1.0.3" + } + }, + "is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", + "dev": true + }, + "is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", + "dev": true + }, + "is-glob": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", + "dev": true, + "requires": { + "is-extglob": "^2.1.1" + } + }, + "is-number": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", + "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", + "dev": true + }, + "is-path-inside": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", + "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", + "dev": true + }, + "is-plain-obj": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-2.1.0.tgz", + "integrity": "sha512-YWnfyRwxL/+SsrWYfOpUtz5b3YD+nyfkHvjbcanzk8zgyO4ASD67uVMRt8k5bM4lLMDnXfriRhOpemw+NfT1eA==", + "dev": true + }, + "is-plain-object": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", + "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", + "dev": true, + "requires": { + "isobject": "^3.0.1" + } + }, + "is-unicode-supported": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", + "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", + "dev": true + }, + "isarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==", + "dev": true + }, + "isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", + "dev": true + }, + "isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha512-WhB9zCku7EGTj/HQQRz5aUQEUeoQZH2bWcltRErOpymJ4boYE6wL9Tbr23krRPSZ+C5zqNSrSw+Cc7sZZ4b7vg==", + "dev": true + }, + "js-sdsl": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/js-sdsl/-/js-sdsl-4.2.0.tgz", + "integrity": "sha512-dyBIzQBDkCqCu+0upx25Y2jGdbTGxE9fshMsCdK0ViOongpV+n5tXRcZY9v7CaVQ79AGS9KA1KHtojxiM7aXSQ==", + "dev": true + }, + "js-yaml": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", + "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", + "dev": true, + "requires": { + "argparse": "^2.0.1" + } + }, + "jsesc": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz", + "integrity": "sha512-uZz5UnB7u4T9LvwmFqXii7pZSouaRPorGs5who1Ip7VO0wxanFvBL7GkM6dTHlgX+jhBApRetaWpnDabOeTcnA==", + "dev": true + }, + "json-schema-traverse": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", + "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", + "dev": true + }, + "json-stable-stringify-without-jsonify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", + "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", + "dev": true + }, + "kind-of": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", + "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==", + "dev": true + }, + "levn": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", + "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", + "dev": true, + "requires": { + "prelude-ls": "^1.2.1", + "type-check": "~0.4.0" + } + }, + "locate-path": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", + "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", + "dev": true, + "requires": { + "p-locate": "^5.0.0" + } + }, + "lodash.debounce": { + "version": "4.0.8", + "resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz", + "integrity": "sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow==", + "dev": true + }, + "lodash.merge": { + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", + "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", + "dev": true + }, + "log-symbols": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", + "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", + "dev": true, + "requires": { + "chalk": "^4.1.0", + "is-unicode-supported": "^0.1.0" + }, + "dependencies": { + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", + "dev": true, + "requires": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + } + }, + "supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "requires": { + "has-flag": "^4.0.0" + } + } + } + }, + "loupe": { + "version": "2.3.6", + "resolved": "https://registry.npmjs.org/loupe/-/loupe-2.3.6.tgz", + "integrity": "sha512-RaPMZKiMy8/JruncMU5Bt6na1eftNoo++R4Y+N2FrxkDVTrGvcyzFTsaGif4QTeKESheMGegbhw6iUAq+5A8zA==", + "dev": true, + "requires": { + "get-func-name": "^2.0.0" + } + }, + "lru-cache": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", + "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", + "dev": true, + "requires": { + "pseudomap": "^1.0.2", + "yallist": "^2.1.2" + } + }, + "make-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz", + "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==", + "dev": true, + "requires": { + "pify": "^4.0.1", + "semver": "^5.6.0" + }, + "dependencies": { + "semver": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", + "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", + "dev": true + } + } + }, + "make-error": { + "version": "1.3.6", + "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", + "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", + "dev": true + }, + "merge2": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", + "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", + "dev": true + }, + "micromatch": { + "version": "4.0.5", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", + "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", + "dev": true, + "requires": { + "braces": "^3.0.2", + "picomatch": "^2.3.1" + } + }, + "minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "requires": { + "brace-expansion": "^1.1.7" + } + }, + "minimist": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.7.tgz", + "integrity": "sha512-bzfL1YUZsP41gmu/qjrEk0Q6i2ix/cVeAhbCbqH9u3zYutS1cLg00qhrD0M2MVdCcx4Sc0UpP2eBWo9rotpq6g==", + "dev": true + }, + "mkdirp": { + "version": "0.5.6", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", + "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", + "dev": true, + "requires": { + "minimist": "^1.2.6" + } + }, + "mocha": { + "version": "10.2.0", + "resolved": "https://registry.npmjs.org/mocha/-/mocha-10.2.0.tgz", + "integrity": "sha512-IDY7fl/BecMwFHzoqF2sg/SHHANeBoMMXFlS9r0OXKDssYE1M5O43wUY/9BVPeIvfH2zmEbBfseqN9gBQZzXkg==", + "dev": true, + "requires": { + "ansi-colors": "4.1.1", + "browser-stdout": "1.3.1", + "chokidar": "3.5.3", + "debug": "4.3.4", + "diff": "5.0.0", + "escape-string-regexp": "4.0.0", + "find-up": "5.0.0", + "glob": "7.2.0", + "he": "1.2.0", + "js-yaml": "4.1.0", + "log-symbols": "4.1.0", + "minimatch": "5.0.1", + "ms": "2.1.3", + "nanoid": "3.3.3", + "serialize-javascript": "6.0.0", + "strip-json-comments": "3.1.1", + "supports-color": "8.1.1", + "workerpool": "6.2.1", + "yargs": "16.2.0", + "yargs-parser": "20.2.4", + "yargs-unparser": "2.0.0" + }, + "dependencies": { + "anymatch": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", + "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", + "dev": true, + "requires": { + "normalize-path": "^3.0.0", + "picomatch": "^2.0.4" + } + }, + "binary-extensions": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", + "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", + "dev": true + }, + "braces": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", + "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", + "dev": true, + "requires": { + "fill-range": "^7.0.1" + } + }, + "chokidar": { + "version": "3.5.3", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", + "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", + "dev": true, + "requires": { + "anymatch": "~3.1.2", + "braces": "~3.0.2", + "fsevents": "~2.3.2", + "glob-parent": "~5.1.2", + "is-binary-path": "~2.1.0", + "is-glob": "~4.0.1", + "normalize-path": "~3.0.0", + "readdirp": "~3.6.0" + } + }, + "debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "requires": { + "ms": "2.1.2" + }, + "dependencies": { + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + } + } + }, + "escape-string-regexp": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", + "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", + "dev": true + }, + "fill-range": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", + "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", + "dev": true, + "requires": { + "to-regex-range": "^5.0.1" + } + }, + "fsevents": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", + "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", + "dev": true, + "optional": true + }, + "glob": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz", + "integrity": "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q==", + "dev": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + }, + "dependencies": { + "minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "requires": { + "brace-expansion": "^1.1.7" + } + } + } + }, + "glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", + "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", + "dev": true, + "requires": { + "is-glob": "^4.0.1" + } + }, + "is-binary-path": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", + "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", + "dev": true, + "requires": { + "binary-extensions": "^2.0.0" + } + }, + "is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", + "dev": true + }, + "is-glob": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", + "dev": true, + "requires": { + "is-extglob": "^2.1.1" + } + }, + "is-number": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", + "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", + "dev": true + }, + "minimatch": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.0.1.tgz", + "integrity": "sha512-nLDxIFRyhDblz3qMuq+SoRZED4+miJ/G+tdDrjkkkRnjAsBexeGpgjLEQ0blJy7rHhR2b93rhQY4SvyWu9v03g==", + "dev": true, + "requires": { + "brace-expansion": "^2.0.1" + }, + "dependencies": { + "brace-expansion": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", + "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", + "dev": true, + "requires": { + "balanced-match": "^1.0.0" + } + } + } + }, + "ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true + }, + "normalize-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", + "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", + "dev": true + }, + "readdirp": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", + "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", + "dev": true, + "requires": { + "picomatch": "^2.2.1" + } + }, + "supports-color": { + "version": "8.1.1", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", + "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", + "dev": true, + "requires": { + "has-flag": "^4.0.0" + } + }, + "to-regex-range": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", + "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", + "dev": true, + "requires": { + "is-number": "^7.0.0" + } + } + } + }, + "nanoid": { + "version": "3.3.3", + "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.3.tgz", + "integrity": "sha512-p1sjXuopFs0xg+fPASzQ28agW1oHD7xDsd9Xkf3T15H3c/cifrFHVwrh74PdoklAPi+i7MdRsE47vm2r6JoB+w==", + "dev": true + }, + "natural-compare": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", + "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", + "dev": true + }, + "natural-compare-lite": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/natural-compare-lite/-/natural-compare-lite-1.4.0.tgz", + "integrity": "sha512-Tj+HTDSJJKaZnfiuw+iaF9skdPpTo2GtEly5JHnWV/hfv2Qj/9RKsGISQtLh2ox3l5EAGw487hnBee0sIJ6v2g==", + "dev": true + }, + "node-releases": { + "version": "2.0.8", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.8.tgz", + "integrity": "sha512-dFSmB8fFHEH/s81Xi+Y/15DQY6VHW81nXRj86EMSL3lmuTmK1e+aT4wrFCkTbm+gSwkw4KpX+rT/pMM2c1mF+A==", + "dev": true + }, + "once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", + "dev": true, + "requires": { + "wrappy": "1" + } + }, + "optionator": { + "version": "0.9.1", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", + "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", + "dev": true, + "requires": { + "deep-is": "^0.1.3", + "fast-levenshtein": "^2.0.6", + "levn": "^0.4.1", + "prelude-ls": "^1.2.1", + "type-check": "^0.4.0", + "word-wrap": "^1.2.3" + } + }, + "os-shim": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/os-shim/-/os-shim-0.1.3.tgz", + "integrity": "sha512-jd0cvB8qQ5uVt0lvCIexBaROw1KyKm5sbulg2fWOHjETisuCzWyt+eTZKEMs8v6HwzoGs8xik26jg7eCM6pS+A==", + "dev": true + }, + "p-limit": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", + "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", + "dev": true, + "requires": { + "yocto-queue": "^0.1.0" + } + }, + "p-locate": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", + "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", + "dev": true, + "requires": { + "p-limit": "^3.0.2" + } + }, + "p-try": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", + "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", + "dev": true + }, + "parent-module": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", + "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", + "dev": true, + "requires": { + "callsites": "^3.0.0" + } + }, + "path-exists": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", + "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", + "dev": true + }, + "path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", + "dev": true + }, + "path-key": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", + "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", + "dev": true + }, + "path-parse": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", + "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", + "dev": true + }, + "path-type": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", + "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", + "dev": true + }, + "pathval": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.1.tgz", + "integrity": "sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==", + "dev": true + }, + "picocolors": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", + "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", + "dev": true + }, + "picomatch": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", + "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", + "dev": true + }, + "pify": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz", + "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==", + "dev": true + }, + "pirates": { + "version": "4.0.5", + "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.5.tgz", + "integrity": "sha512-8V9+HQPupnaXMA23c5hvl69zXvTwTzyAYasnkb0Tts4XvO4CliqONMOnvlq26rkhLC3nWDFBJf73LU1e1VZLaQ==", + "dev": true + }, + "pkg-dir": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-3.0.0.tgz", + "integrity": "sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==", + "dev": true, + "requires": { + "find-up": "^3.0.0" + }, + "dependencies": { + "find-up": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", + "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", + "dev": true, + "requires": { + "locate-path": "^3.0.0" + } + }, + "locate-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", + "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", + "dev": true, + "requires": { + "p-locate": "^3.0.0", + "path-exists": "^3.0.0" + } + }, + "p-limit": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", + "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", + "dev": true, + "requires": { + "p-try": "^2.0.0" + } + }, + "p-locate": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", + "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", + "dev": true, + "requires": { + "p-limit": "^2.0.0" + } + }, + "path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha512-bpC7GYwiDYQ4wYLe+FA8lhRjhQCMcQGuSgGGqDkg/QerRWw9CmGRT0iSOVRSZJ29NMLZgIzqaljJ63oaL4NIJQ==", + "dev": true + } + } + }, + "pre-commit": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/pre-commit/-/pre-commit-1.2.2.tgz", + "integrity": "sha512-qokTiqxD6GjODy5ETAIgzsRgnBWWQHQH2ghy86PU7mIn/wuWeTwF3otyNQZxWBwVn8XNr8Tdzj/QfUXpH+gRZA==", + "dev": true, + "requires": { + "cross-spawn": "^5.0.1", + "spawn-sync": "^1.0.15", + "which": "1.2.x" + }, + "dependencies": { + "which": { + "version": "1.2.14", + "resolved": "https://registry.npmjs.org/which/-/which-1.2.14.tgz", + "integrity": "sha512-16uPglFkRPzgiUXYMi1Jf8Z5EzN1iB4V0ZtMXcHZnwsBtQhhHeCqoWw7tsUY42hJGNDWtUsVLTjakIa5BgAxCw==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + } + } + }, + "prelude-ls": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", + "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", + "dev": true + }, + "prettier": { + "version": "2.8.2", + "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.8.2.tgz", + "integrity": "sha512-BtRV9BcncDyI2tsuS19zzhzoxD8Dh8LiCx7j7tHzrkz8GFXAexeWFdi22mjE1d16dftH2qNaytVxqiRTGlMfpw==", + "dev": true + }, + "process-nextick-args": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", + "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", + "dev": true + }, + "pseudomap": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", + "integrity": "sha512-b/YwNhb8lk1Zz2+bXXpS/LK9OisiZZ1SNsSLxN1x2OXVEhW2Ckr/7mWE5vrC1ZTiJlD9g19jWszTmJsB+oEpFQ==", + "dev": true + }, + "punycode": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.2.0.tgz", + "integrity": "sha512-LN6QV1IJ9ZhxWTNdktaPClrNfp8xdSAYS0Zk2ddX7XsXZAxckMHPCBcHRo0cTcEIgYPRiGEkmji3Idkh2yFtYw==", + "dev": true + }, + "queue-microtask": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", + "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", + "dev": true + }, + "randombytes": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", + "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", + "dev": true, + "requires": { + "safe-buffer": "^5.1.0" + } + }, + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "dev": true, + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "regenerate": { + "version": "1.4.2", + "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.4.2.tgz", + "integrity": "sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A==", + "dev": true + }, + "regenerate-unicode-properties": { + "version": "10.1.0", + "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-10.1.0.tgz", + "integrity": "sha512-d1VudCLoIGitcU/hEg2QqvyGZQmdC0Lf8BqdOMXGFSvJP4bNV1+XqbPQeHHLD51Jh4QJJ225dlIFvY4Ly6MXmQ==", + "dev": true, + "requires": { + "regenerate": "^1.4.2" + } + }, + "regenerator-runtime": { + "version": "0.13.11", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz", + "integrity": "sha512-kY1AZVr2Ra+t+piVaJ4gxaFaReZVH40AKNo7UCX6W+dEwBo/2oZJzqfuN1qLq1oL45o56cPaTXELwrTh8Fpggg==", + "dev": true + }, + "regenerator-transform": { + "version": "0.15.1", + "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.15.1.tgz", + "integrity": "sha512-knzmNAcuyxV+gQCufkYcvOqX/qIIfHLv0u5x79kRxuGojfYVky1f15TzZEu2Avte8QGepvUNTnLskf8E6X6Vyg==", + "dev": true, + "requires": { + "@babel/runtime": "^7.8.4" + } + }, + "regexpp": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", + "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", + "dev": true + }, + "regexpu-core": { + "version": "5.2.2", + "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-5.2.2.tgz", + "integrity": "sha512-T0+1Zp2wjF/juXMrMxHxidqGYn8U4R+zleSJhX9tQ1PUsS8a9UtYfbsF9LdiVgNX3kiX8RNaKM42nfSgvFJjmw==", + "dev": true, + "requires": { + "regenerate": "^1.4.2", + "regenerate-unicode-properties": "^10.1.0", + "regjsgen": "^0.7.1", + "regjsparser": "^0.9.1", + "unicode-match-property-ecmascript": "^2.0.0", + "unicode-match-property-value-ecmascript": "^2.1.0" + } + }, + "regjsgen": { + "version": "0.7.1", + "resolved": "https://registry.npmjs.org/regjsgen/-/regjsgen-0.7.1.tgz", + "integrity": "sha512-RAt+8H2ZEzHeYWxZ3H2z6tF18zyyOnlcdaafLrm21Bguj7uZy6ULibiAFdXEtKQY4Sy7wDTwDiOazasMLc4KPA==", + "dev": true + }, + "regjsparser": { + "version": "0.9.1", + "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.9.1.tgz", + "integrity": "sha512-dQUtn90WanSNl+7mQKcXAgZxvUe7Z0SqXlgzv0za4LwiUhyzBC58yQO3liFoUgu8GiJVInAhJjkj1N0EtQ5nkQ==", + "dev": true, + "requires": { + "jsesc": "~0.5.0" + } + }, + "require-directory": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", + "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", + "dev": true + }, + "resolve": { + "version": "1.22.1", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz", + "integrity": "sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==", + "dev": true, + "requires": { + "is-core-module": "^2.9.0", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + } + }, + "resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", + "dev": true + }, + "reusify": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", + "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", + "dev": true + }, + "rimraf": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", + "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", + "dev": true, + "requires": { + "glob": "^7.1.3" + } + }, + "run-parallel": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", + "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", + "dev": true, + "requires": { + "queue-microtask": "^1.2.2" + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", + "dev": true + }, + "semver": { + "version": "7.3.8", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.8.tgz", + "integrity": "sha512-NB1ctGL5rlHrPJtFDVIVzTyQylMLu9N9VICA6HSFJo8MCGVTMW6gfpicwKmmK/dAjTOrqu5l63JJOpDSrAis3A==", + "dev": true, + "requires": { + "lru-cache": "^6.0.0" + }, + "dependencies": { + "lru-cache": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", + "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", + "dev": true, + "requires": { + "yallist": "^4.0.0" + } + }, + "yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true + } + } + }, + "serialize-javascript": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", + "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", + "dev": true, + "requires": { + "randombytes": "^2.1.0" + } + }, + "shallow-clone": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/shallow-clone/-/shallow-clone-3.0.1.tgz", + "integrity": "sha512-/6KqX+GVUdqPuPPd2LxDDxzX6CAbjJehAAOKlNpqqUpAqPM6HeL8f+o3a+JsyGjn2lv0WY8UsTgUJjU9Ok55NA==", + "dev": true, + "requires": { + "kind-of": "^6.0.2" + } + }, + "shebang-command": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", + "integrity": "sha512-EV3L1+UQWGor21OmnvojK36mhg+TyIKDh3iFBKBohr5xeXIhNBcx8oWdgkTEEQ+BEFFYdLRuqMfd5L84N1V5Vg==", + "dev": true, + "requires": { + "shebang-regex": "^1.0.0" + } + }, + "shebang-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", + "integrity": "sha512-wpoSFAxys6b2a2wHZ1XpDSgD7N9iVjg29Ph9uV/uaP9Ex/KXlkTZTeddxDPSYQpgvzKLGJke2UU0AzoGCjNIvQ==", + "dev": true + }, + "slash": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", + "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", + "dev": true + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true + }, + "source-map-support": { + "version": "0.5.21", + "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", + "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", + "dev": true, + "requires": { + "buffer-from": "^1.0.0", + "source-map": "^0.6.0" + } + }, + "spawn-sync": { + "version": "1.0.15", + "resolved": "https://registry.npmjs.org/spawn-sync/-/spawn-sync-1.0.15.tgz", + "integrity": "sha512-9DWBgrgYZzNghseho0JOuh+5fg9u6QWhAWa51QC7+U5rCheZ/j1DrEZnyE0RBBRqZ9uEXGPgSSM0nky6burpVw==", + "dev": true, + "requires": { + "concat-stream": "^1.4.7", + "os-shim": "^0.1.2" + } + }, + "string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "requires": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "dependencies": { + "ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", + "dev": true + }, + "strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "requires": { + "ansi-regex": "^5.0.1" + } + } + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "dev": true, + "requires": { + "safe-buffer": "~5.1.0" + } + }, + "strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "requires": { + "ansi-regex": "^5.0.1" + } + }, + "strip-bom": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", + "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==", + "dev": true, + "optional": true + }, + "strip-json-comments": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", + "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", + "dev": true + }, + "supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "requires": { + "has-flag": "^4.0.0" + } + }, + "supports-preserve-symlinks-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", + "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", + "dev": true + }, + "text-encoding": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/text-encoding/-/text-encoding-0.7.0.tgz", + "integrity": "sha512-oJQ3f1hrOnbRLOcwKz0Liq2IcrvDeZRHXhd9RgLrsT+DjWY/nty1Hi7v3dtkaEYbPYe0mUoOfzRrMwfXXwgPUA==" + }, + "text-table": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", + "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", + "dev": true + }, + "to-regex-range": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", + "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", + "dev": true, + "requires": { + "is-number": "^7.0.0" + } + }, + "ts-mocha": { + "version": "10.0.0", + "resolved": "https://registry.npmjs.org/ts-mocha/-/ts-mocha-10.0.0.tgz", + "integrity": "sha512-VRfgDO+iiuJFlNB18tzOfypJ21xn2xbuZyDvJvqpTbWgkAgD17ONGr8t+Tl8rcBtOBdjXp5e/Rk+d39f7XBHRw==", + "dev": true, + "requires": { + "ts-node": "7.0.1", + "tsconfig-paths": "^3.5.0" + } + }, + "ts-node": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-7.0.1.tgz", + "integrity": "sha512-BVwVbPJRspzNh2yfslyT1PSbl5uIk03EZlb493RKHN4qej/D06n1cEhjlOJG69oFsE7OT8XjpTUcYf6pKTLMhw==", + "dev": true, + "requires": { + "arrify": "^1.0.0", + "buffer-from": "^1.1.0", + "diff": "^3.1.0", + "make-error": "^1.1.1", + "minimist": "^1.2.0", + "mkdirp": "^0.5.1", + "source-map-support": "^0.5.6", + "yn": "^2.0.0" + }, + "dependencies": { + "diff": { + "version": "3.5.0", + "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz", + "integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA==", + "dev": true + } + } + }, + "tsconfig-paths": { + "version": "3.14.1", + "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.14.1.tgz", + "integrity": "sha512-fxDhWnFSLt3VuTwtvJt5fpwxBHg5AdKWMsgcPOOIilyjymcYVZoCQF8fvFRezCNfblEXmi+PcM1eYHeOAgXCOQ==", + "dev": true, + "optional": true, + "requires": { + "@types/json5": "^0.0.29", + "json5": "^1.0.1", + "minimist": "^1.2.6", + "strip-bom": "^3.0.0" + }, + "dependencies": { + "json5": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.2.tgz", + "integrity": "sha512-g1MWMLBiz8FKi1e4w0UyVL3w+iJceWAFBAaBnnGKOpNa5f8TLktkbre1+s6oICydWAm+HRUGTmI+//xv2hvXYA==", + "dev": true, + "optional": true, + "requires": { + "minimist": "^1.2.0" + } + } + } + }, + "tslib": { + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", + "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", + "dev": true + }, + "tsutils": { + "version": "3.21.0", + "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.21.0.tgz", + "integrity": "sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA==", + "dev": true, + "requires": { + "tslib": "^1.8.1" + } + }, + "type-check": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", + "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", + "dev": true, + "requires": { + "prelude-ls": "^1.2.1" + } + }, + "type-detect": { + "version": "4.0.8", + "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", + "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", + "dev": true + }, + "typedarray": { + "version": "0.0.6", + "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", + "integrity": "sha512-/aCDEGatGvZ2BIk+HmLf4ifCJFwvKFNb9/JeZPMulfgFracn9QFcAf5GO8B/mweUjSoblS5In0cWhqpfs/5PQA==", + "dev": true + }, + "typescript": { + "version": "4.9.4", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.9.4.tgz", + "integrity": "sha512-Uz+dTXYzxXXbsFpM86Wh3dKCxrQqUcVMxwU54orwlJjOpO3ao8L7j5lH+dWfTwgCwIuM9GQ2kvVotzYJMXTBZg==", + "dev": true + }, + "unicode-canonical-property-names-ecmascript": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz", + "integrity": "sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ==", + "dev": true + }, + "unicode-match-property-ecmascript": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-2.0.0.tgz", + "integrity": "sha512-5kaZCrbp5mmbz5ulBkDkbY0SsPOjKqVS35VpL9ulMPfSl0J0Xsm+9Evphv9CoIZFwre7aJoa94AY6seMKGVN5Q==", + "dev": true, + "requires": { + "unicode-canonical-property-names-ecmascript": "^2.0.0", + "unicode-property-aliases-ecmascript": "^2.0.0" + } + }, + "unicode-match-property-value-ecmascript": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.1.0.tgz", + "integrity": "sha512-qxkjQt6qjg/mYscYMC0XKRn3Rh0wFPlfxB0xkt9CfyTvpX1Ra0+rAmdX2QyAobptSEvuy4RtpPRui6XkV+8wjA==", + "dev": true + }, + "unicode-property-aliases-ecmascript": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.1.0.tgz", + "integrity": "sha512-6t3foTQI9qne+OZoVQB/8x8rk2k1eVy1gRXhV3oFQ5T6R1dqQ1xtin3XqSlx3+ATBkliTaR/hHyJBm+LVPNM8w==", + "dev": true + }, + "update-browserslist-db": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.10.tgz", + "integrity": "sha512-OztqDenkfFkbSG+tRxBeAnCVPckDBcvibKd35yDONx6OU8N7sqgwc7rCbkJ/WcYtVRZ4ba68d6byhC21GFh7sQ==", + "dev": true, + "requires": { + "escalade": "^3.1.1", + "picocolors": "^1.0.0" + } + }, + "uri-js": { + "version": "4.4.1", + "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", + "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", + "dev": true, + "requires": { + "punycode": "^2.1.0" + } + }, + "util-deprecate": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", + "dev": true + }, + "which": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", + "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", + "dev": true, + "requires": { + "isexe": "^2.0.0" + } + }, + "word-wrap": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", + "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", + "dev": true + }, + "workerpool": { + "version": "6.2.1", + "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.2.1.tgz", + "integrity": "sha512-ILEIE97kDZvF9Wb9f6h5aXK4swSlKGUcOEGiIYb2OOu/IrDU9iwj0fD//SsA6E5ibwJxpEvhullJY4Sl4GcpAw==", + "dev": true + }, + "wrap-ansi": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", + "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", + "dev": true, + "requires": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", + "dev": true + }, + "ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "requires": { + "color-convert": "^2.0.1" + } + }, + "strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dev": true, + "requires": { + "ansi-regex": "^5.0.1" + } + } + } + }, + "wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", + "dev": true + }, + "y18n": { + "version": "5.0.8", + "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", + "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", + "dev": true + }, + "yallist": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", + "integrity": "sha512-ncTzHV7NvsQZkYe1DW7cbDLm0YpzHmZF5r/iyP3ZnQtMiJ+pjzisCiMNI+Sj+xQF5pXhSHxSB3uDbsBTzY/c2A==", + "dev": true + }, + "yargs": { + "version": "16.2.0", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", + "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", + "dev": true, + "requires": { + "cliui": "^7.0.2", + "escalade": "^3.1.1", + "get-caller-file": "^2.0.5", + "require-directory": "^2.1.1", + "string-width": "^4.2.0", + "y18n": "^5.0.5", + "yargs-parser": "^20.2.2" + } + }, + "yargs-parser": { + "version": "20.2.4", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.4.tgz", + "integrity": "sha512-WOkpgNhPTlE73h4VFAFsOnomJVaovO8VqLDzy5saChRBFQFBoMYirowyW+Q9HB4HFF4Z7VZTiG3iSzJJA29yRA==", + "dev": true + }, + "yargs-unparser": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-2.0.0.tgz", + "integrity": "sha512-7pRTIA9Qc1caZ0bZ6RYRGbHJthJWuakf+WmHK0rVeLkNrrGhfoabBNdue6kdINI6r4if7ocq9aD/n7xwKOdzOA==", + "dev": true, + "requires": { + "camelcase": "^6.0.0", + "decamelize": "^4.0.0", + "flat": "^5.0.2", + "is-plain-obj": "^2.1.0" + } + }, + "yn": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/yn/-/yn-2.0.0.tgz", + "integrity": "sha512-uTv8J/wiWTgUTg+9vLTi//leUl5vDQS6uii/emeTb2ssY7vl6QWf2fFbIIGjnhjvbdKlU0ed7QPgY1htTC86jQ==", + "dev": true + }, + "yocto-queue": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", + "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", + "dev": true + } + } +} diff --git a/package.json b/package.json index 942cf39..328e8bd 100644 --- a/package.json +++ b/package.json @@ -2,7 +2,8 @@ "name": "emailjs-mime-codec", "description": "Encode and decode quoted printable and base64 strings", "version": "2.0.9", - "main": "dist/mimecodec", + "main": "dist/mimecodec.js", + "types": "dist/mimecodec.d.ts", "homepage": "https://github.com/emailjs/emailjs-mime-codec", "repository": { "type": "git", @@ -16,38 +17,36 @@ ], "author": "Andris Reinman ", "scripts": { - "build": "./scripts/build.sh", - "lint": "$(npm bin)/standard", + "build": "rm -rf ./dist/ && npm run build.types && npm run babel.compile", + "babel.compile": "npx babel src --extensions '.ts' --out-dir dist --ignore '**/*.unit.ts'", + "build.types": "tsc --project tsconfig.types.json", + "lint": "npx eslint ./src/", "preversion": "npm run build", "test": "npm run lint && npm run unit", - "unit": "$(npm bin)/mocha './src/*-unit.js' --reporter spec --require babel-register testutils.js" + "unit": "npx ts-mocha './src/*.unit.ts' --reporter spec --require @babel/register" }, "dependencies": { "emailjs-base64": "^1.1.4", - "ramda": "^0.26.1", "text-encoding": "^0.7.0" }, "devDependencies": { - "babel-cli": "^6.26.0", - "babel-preset-es2015": "^6.24.1", - "babel-register": "^6.26.0", - "chai": "^4.2.0", - "mocha": "^6.1.4", + "@babel/cli": "^7.20.7", + "@babel/core": "^7.20.7", + "@babel/preset-env": "^7.20.2", + "@babel/preset-typescript": "^7.18.6", + "@babel/register": "^7.18.9", + "@types/chai": "^4.3.4", + "@types/mocha": "^10.0.1", + "@types/node": "^18.11.18", + "@types/text-encoding": "^0.0.36", + "@typescript-eslint/eslint-plugin": "^5.48.1", + "@typescript-eslint/parser": "^5.48.1", + "chai": "^4.3.7", + "eslint": "^8.31.0", + "mocha": "^10.2.0", "pre-commit": "^1.2.2", - "standard": "^12.0.1" - }, - "standard": { - "globals": [ - "describe", - "it", - "before", - "beforeAll", - "afterAll", - "after", - "expect" - ], - "ignore": [ - "dist" - ] + "prettier": "^2.8.2", + "ts-mocha": "^10.0.0", + "typescript": "^4.9.4" } } diff --git a/scripts/build.sh b/scripts/build.sh deleted file mode 100755 index ae108ea..0000000 --- a/scripts/build.sh +++ /dev/null @@ -1,7 +0,0 @@ -#!/bin/bash - -rm -rf $PWD/dist -babel src --out-dir dist --ignore '**/*-unit.js' --source-maps inline -git reset -git add $PWD/dist -git commit -m 'Updating dist files' -n diff --git a/src/charset.js b/src/charset.ts similarity index 69% rename from src/charset.js rename to src/charset.ts index ad8d522..4715d58 100644 --- a/src/charset.js +++ b/src/charset.ts @@ -6,14 +6,14 @@ import { TextDecoder, TextEncoder } from 'text-encoding' * @param {String} str String to be encoded * @return {Uint8Array} UTF-8 encoded typed array */ -export const encode = str => new TextEncoder('UTF-8').encode(str) +export const encode = (str: string): Uint8Array => new TextEncoder('UTF-8').encode(str) -export const arr2str = arr => { +export const arr2str = (arr: Uint8Array): string => { const CHUNK_SZ = 0x8000 const strs = [] for (let i = 0; i < arr.length; i += CHUNK_SZ) { - strs.push(String.fromCharCode.apply(null, arr.subarray(i, i + CHUNK_SZ))) + strs.push(String.fromCharCode.apply(null, Array.from(arr.subarray(i, i + CHUNK_SZ)))) } return strs.join('') @@ -26,7 +26,7 @@ export const arr2str = arr => { * @param {String} Binary data is decoded into string using this charset * @return {String} Decoded string */ -export function decode (buf, fromCharset = 'utf-8') { +export function decode(buf: Uint8Array, fromCharset = 'utf-8'): string { const charsets = [ { charset: normalizeCharset(fromCharset), fatal: false }, { charset: 'utf-8', fatal: true }, @@ -34,7 +34,11 @@ export function decode (buf, fromCharset = 'utf-8') { ] for (const { charset, fatal } of charsets) { - try { return new TextDecoder(charset, { fatal }).decode(buf) } catch (e) { } + try { + return new TextDecoder(charset, { fatal }).decode(buf) + } catch (e) { + // ignore + } } return arr2str(buf) // all else fails, treat it as binary @@ -47,9 +51,10 @@ export function decode (buf, fromCharset = 'utf-8') { * @param {String} Source encoding for the string (optional for data of type String) * @return {Uint8Array} UTF-8 encoded typed array */ -export const convert = (data, fromCharset) => typeof data === 'string' ? encode(data) : encode(decode(data, fromCharset)) +export const convert = (data: string | Uint8Array, fromCharset: string): Uint8Array => + typeof data === 'string' ? encode(data) : encode(decode(data, fromCharset)) -function normalizeCharset (charset = 'utf-8') { +function normalizeCharset(charset = 'utf-8'): string { let match if ((match = charset.match(/^utf[-_]?(\d+)$/i))) { diff --git a/src/charset-unit.js b/src/charset.unit.ts similarity index 75% rename from src/charset-unit.js rename to src/charset.unit.ts index ca09db4..ac2b83f 100644 --- a/src/charset-unit.js +++ b/src/charset.unit.ts @@ -1,10 +1,11 @@ +import { expect } from 'chai' import { encode, decode, convert } from './charset' describe('#charset', function () { describe('#encode', function () { it('should encode UTF-8 to ArrayBuffer', function () { const str = '신' - const encoded = new Uint8Array([0xEC, 0x8B, 0xA0]) + const encoded = new Uint8Array([0xec, 0x8b, 0xa0]) expect(encode(str)).to.deep.equal(encoded) }) @@ -13,7 +14,7 @@ describe('#charset', function () { describe('#decode', function () { it('should decode utf-8 arraybuffer', function () { const str = '신' - const encoded = new Uint8Array([0xEC, 0x8B, 0xA0]) + const encoded = new Uint8Array([0xec, 0x8b, 0xa0]) expect(decode(encoded)).to.deep.equal(str) }) @@ -21,7 +22,7 @@ describe('#charset', function () { it('should decode non utf-8 arraybuffer', function () { const str = '신' const encoding = 'ks_c_5601-1987' - const encoded = new Uint8Array([0xBD, 0xC5]) + const encoded = new Uint8Array([0xbd, 0xc5]) expect(decode(encoded, encoding)).to.deep.equal(str) }) @@ -29,14 +30,14 @@ describe('#charset', function () { describe('Missing and unknown charsets', function () { it('should detect utf-8', function () { const str = '신' - const encoded = new Uint8Array([0xEC, 0x8B, 0xA0]) + const encoded = new Uint8Array([0xec, 0x8b, 0xa0]) const encoding = 'x-illegal' expect(decode(encoded, encoding)).to.deep.equal(str) }) it('should fall back to latin_15 conversion for illegal charset', function () { const str = 'a1Šÿ' - const encoded = new Uint8Array([0x61, 0x31, 0xA6, 0xff]) + const encoded = new Uint8Array([0x61, 0x31, 0xa6, 0xff]) const encoding = 'x-illegal' expect(decode(encoded, encoding)).to.deep.equal(str) }) @@ -45,9 +46,9 @@ describe('#charset', function () { describe('#convert', function () { it('should convert non utf-8 to arraybuffer', function () { - const converted = new Uint8Array([0xEC, 0x8B, 0xA0]) + const converted = new Uint8Array([0xec, 0x8b, 0xa0]) const encoding = 'ks_c_5601-1987' - const encoded = new Uint8Array([0xBD, 0xC5]) + const encoded = new Uint8Array([0xbd, 0xc5]) expect(convert(encoded, encoding)).to.deep.equal(converted) }) diff --git a/src/mimecodec.js b/src/mimecodec.ts similarity index 65% rename from src/mimecodec.js rename to src/mimecodec.ts index 1f29499..8b39d02 100644 --- a/src/mimecodec.js +++ b/src/mimecodec.ts @@ -1,6 +1,5 @@ import { encode as encodeBase64, decode as decodeBase64, OUTPUT_TYPED_ARRAY } from 'emailjs-base64' import { encode, decode, convert, arr2str } from './charset' -import { pipe } from 'ramda' // Lines can't be longer than 76 + = 78 bytes // http://tools.ietf.org/html/rfc2045#section-6.7 @@ -17,22 +16,34 @@ const MAX_B64_MIME_WORD_BYTE_LENGTH = 39 * @param {String} [fromCharset='UTF-8'] Source encoding * @return {String} Mime encoded string */ -export function mimeEncode (data = '', fromCharset = 'UTF-8') { +export function mimeEncode(data: string | Uint8Array = '', fromCharset = 'UTF-8'): string { const buffer = convert(data, fromCharset) - return buffer.reduce((aggregate, ord, index) => - _checkRanges(ord) && !((ord === 0x20 || ord === 0x09) && (index === buffer.length - 1 || buffer[index + 1] === 0x0a || buffer[index + 1] === 0x0d)) - ? aggregate + String.fromCharCode(ord) // if the char is in allowed range, then keep as is, unless it is a ws in the end of a line - : aggregate + '=' + (ord < 0x10 ? '0' : '') + ord.toString(16).toUpperCase(), '') - - function _checkRanges (nr) { - const ranges = [ // https://tools.ietf.org/html/rfc2045#section-6.7 + return buffer.reduce( + (aggregate, ord, index) => + _checkRanges(ord) && + !( + (ord === 0x20 || ord === 0x09) && + (index === buffer.length - 1 || buffer[index + 1] === 0x0a || buffer[index + 1] === 0x0d) + ) + ? aggregate + String.fromCharCode(ord) // if the char is in allowed range, then keep as is, unless it is a ws in the end of a line + : aggregate + '=' + (ord < 0x10 ? '0' : '') + ord.toString(16).toUpperCase(), + '' + ) + + function _checkRanges(nr: number): boolean { + const ranges = [ + // https://tools.ietf.org/html/rfc2045#section-6.7 [0x09], // - [0x0A], // - [0x0D], // - [0x20, 0x3C], // !"#$%&'()*+,-./0123456789:; - [0x3E, 0x7E] // >?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|} + [0x0a], // + [0x0d], // + [0x20, 0x3c], // !"#$%&'()*+,-./0123456789:; + [0x3e, 0x7e] // >?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|} ] - return ranges.reduce((val, range) => val || (range.length === 1 && nr === range[0]) || (range.length === 2 && nr >= range[0] && nr <= range[1]), false) + return ranges.reduce( + (val, range) => + val || (range.length === 1 && nr === range[0]) || (range.length === 2 && nr >= range[0] && nr <= range[1]), + false + ) } } @@ -43,12 +54,12 @@ export function mimeEncode (data = '', fromCharset = 'UTF-8') { * @param {String} [fromCharset='UTF-8'] Source encoding * @return {String} Decoded unicode string */ -export function mimeDecode (str = '', fromCharset = 'UTF-8') { - const encodedBytesCount = (str.match(/=[\da-fA-F]{2}/g) || []).length - let buffer = new Uint8Array(str.length - encodedBytesCount * 2) +export function mimeDecode(str = '', fromCharset = 'UTF-8'): string { + const encodedBytesCount = (str.match(/=[\da-fA-F]{2}/g) ?? []).length + const buffer = new Uint8Array(str.length - encodedBytesCount * 2) - for (var i = 0, len = str.length, bufferPos = 0; i < len; i++) { - let hex = str.substr(i + 1, 2) + for (let i = 0, len = str.length, bufferPos = 0; i < len; i++) { + const hex = str.substr(i + 1, 2) const chr = str.charAt(i) if (chr === '=' && hex && /[\da-fA-F]{2}/.test(hex)) { buffer[bufferPos++] = parseInt(hex, 16) @@ -69,8 +80,8 @@ export function mimeDecode (str = '', fromCharset = 'UTF-8') { * @param {String} Initial charset, e.g. 'binary'. Defaults to 'UTF-8' * @return {String} Base64 encoded string */ -export function base64Encode (data, fromCharset = 'UTF-8') { - const buf = (typeof data !== 'string' && fromCharset === 'binary') ? data : convert(data, fromCharset) +export function base64Encode(data: string | Uint8Array, fromCharset = 'UTF-8'): string { + const buf = typeof data !== 'string' && fromCharset === 'binary' ? data : convert(data, fromCharset) const b64 = encodeBase64(buf) return _addBase64SoftLinebreaks(b64) } @@ -82,7 +93,7 @@ export function base64Encode (data, fromCharset = 'UTF-8') { * @param {String} [fromCharset='UTF-8'] Original charset of the base64 encoded string * @return {String} Decoded unicode string */ -export function base64Decode (str, fromCharset) { +export function base64Decode(str: string, fromCharset?: string): string { const buf = decodeBase64(str, OUTPUT_TYPED_ARRAY) return fromCharset === 'binary' ? arr2str(buf) : decode(buf, fromCharset) } @@ -96,10 +107,10 @@ export function base64Decode (str, fromCharset) { * @param {String} [fromCharset='UTF-8'] Original charset of the string * @return {String} Mime encoded string */ -export function quotedPrintableEncode (data = '', fromCharset = 'UTF-8') { +export function quotedPrintableEncode(data: string | Uint8Array = '', fromCharset = 'UTF-8'): string { const mimeEncodedStr = mimeEncode(data, fromCharset) .replace(/\r?\n|\r/g, '\r\n') // fix line breaks, ensure - .replace(/[\t ]+$/gm, spaces => spaces.replace(/ /g, '=20').replace(/\t/g, '=09')) // replace spaces in the end of lines + .replace(/[\t ]+$/gm, (spaces) => spaces.replace(/ /g, '=20').replace(/\t/g, '=09')) // replace spaces in the end of lines return _addQPSoftLinebreaks(mimeEncodedStr) // add soft line breaks to ensure line lengths sjorter than 76 bytes } @@ -112,7 +123,7 @@ export function quotedPrintableEncode (data = '', fromCharset = 'UTF-8') { * @param {String} [fromCharset='UTF-8'] Original charset of the string * @return {String} Mime decoded string */ -export function quotedPrintableDecode (str = '', fromCharset = 'UTF-8') { +export function quotedPrintableDecode(str = '', fromCharset = 'UTF-8'): string { const rawString = str .replace(/[\t ]+$/gm, '') // remove invalid whitespace from the end of lines .replace(/=(?:\r?\n|$)/g, '') // remove soft line breaks @@ -129,14 +140,17 @@ export function quotedPrintableDecode (str = '', fromCharset = 'UTF-8') { * @param {String} [fromCharset='UTF-8'] Source sharacter set * @return {String} Single or several mime words joined together */ -export function mimeWordEncode (data, mimeWordEncoding = 'Q', fromCharset = 'UTF-8') { +export function mimeWordEncode(data: string | Uint8Array, mimeWordEncoding = 'Q', fromCharset = 'UTF-8'): string { let parts = [] - const str = (typeof data === 'string') ? data : decode(data, fromCharset) + const str = typeof data === 'string' ? data : decode(data, fromCharset) if (mimeWordEncoding === 'Q') { - const str = (typeof data === 'string') ? data : decode(data, fromCharset) - let encodedStr = pipe(mimeEncode, qEncodeForbiddenHeaderChars)(str) - parts = encodedStr.length < MAX_MIME_WORD_LENGTH ? [encodedStr] : _splitMimeEncodedString(encodedStr, MAX_MIME_WORD_LENGTH) + const str = typeof data === 'string' ? data : decode(data, fromCharset) + const encodedStr = qEncodeForbiddenHeaderChars(mimeEncode(str)) + parts = + encodedStr.length < MAX_MIME_WORD_LENGTH + ? [encodedStr] + : _splitMimeEncodedString(encodedStr, MAX_MIME_WORD_LENGTH) } else { // Fits as much as possible into every line without breaking utf-8 multibyte characters' octets up across lines let j = 0 @@ -157,16 +171,20 @@ export function mimeWordEncode (data, mimeWordEncoding = 'Q', fromCharset = 'UTF const prefix = '=?UTF-8?' + mimeWordEncoding + '?' const suffix = '?= ' - return parts.map(p => prefix + p + suffix).join('').trim() + return parts + .map((p) => prefix + p + suffix) + .join('') + .trim() } /** * Q-Encodes remaining forbidden header chars * https://tools.ietf.org/html/rfc2047#section-5 */ -const qEncodeForbiddenHeaderChars = function (str) { - const qEncode = chr => chr === ' ' ? '_' : ('=' + (chr.charCodeAt(0) < 0x10 ? '0' : '') + chr.charCodeAt(0).toString(16).toUpperCase()) - return str.replace(/[^a-z0-9!*+\-/=]/ig, qEncode) +const qEncodeForbiddenHeaderChars = function (str: string): string { + const qEncode = (chr: string): string => + chr === ' ' ? '_' : '=' + (chr.charCodeAt(0) < 0x10 ? '0' : '') + chr.charCodeAt(0).toString(16).toUpperCase() + return str.replace(/[^a-z0-9!*+\-/=]/gi, qEncode) } /** @@ -177,9 +195,12 @@ const qEncodeForbiddenHeaderChars = function (str) { * @param {String} [fromCharset='UTF-8'] Source sharacter set * @return {String} String with possible mime words */ -export function mimeWordsEncode (data = '', mimeWordEncoding = 'Q', fromCharset = 'UTF-8') { - const regex = /([^\s\u0080-\uFFFF]*[\u0080-\uFFFF]+[^\s\u0080-\uFFFF]*(?:\s+[^\s\u0080-\uFFFF]*[\u0080-\uFFFF]+[^\s\u0080-\uFFFF]*\s*)?)+(?=\s|$)/g - return decode(convert(data, fromCharset)).replace(regex, match => match.length ? mimeWordEncode(match, mimeWordEncoding, fromCharset) : '') +export function mimeWordsEncode(data: string | Uint8Array = '', mimeWordEncoding = 'Q', fromCharset = 'UTF-8'): string { + const regex = + /([^\s\u0080-\uFFFF]*[\u0080-\uFFFF]+[^\s\u0080-\uFFFF]*(?:\s+[^\s\u0080-\uFFFF]*[\u0080-\uFFFF]+[^\s\u0080-\uFFFF]*\s*)?)+(?=\s|$)/g + return decode(convert(data, fromCharset)).replace(regex, (match) => + match.length ? mimeWordEncode(match, mimeWordEncoding, fromCharset) : '' + ) } /** @@ -188,7 +209,7 @@ export function mimeWordsEncode (data = '', mimeWordEncoding = 'Q', fromCharset * @param {String} str Mime word encoded string * @return {String} Decoded unicode string */ -export function mimeWordDecode (str = '') { +export function mimeWordDecode(str = ''): string { const match = str.match(/^=\?([\w_\-*]+)\?([QqBb])\?([^?]*)\?=$/i) if (!match) return str @@ -214,16 +235,16 @@ export function mimeWordDecode (str = '') { * @param {String} str String including some mime words that will be encoded * @return {String} Decoded unicode string */ -export function mimeWordsDecode (str = '') { +export function mimeWordsDecode(str = ''): string { str = str.toString().replace(/(=\?[^?]+\?[QqBb]\?[^?]+\?=)\s+(?==\?[^?]+\?[QqBb]\?[^?]*\?=)/g, '$1') // join bytes of multi-byte UTF-8 - let prevEncoding + let prevEncoding: string str = str.replace(/(\?=)?=\?[uU][tT][fF]-8\?([QqBb])\?/g, (match, endOfPrevWord, encoding) => { - const result = (endOfPrevWord && encoding === prevEncoding) ? '' : match + const result = endOfPrevWord && encoding === prevEncoding ? '' : match prevEncoding = encoding return result }) - str = str.replace(/=\?[\w_\-*]+\?[QqBb]\?[^?]*\?=/g, mimeWord => mimeWordDecode(mimeWord.replace(/\s+/g, ''))) + str = str.replace(/=\?[\w_\-*]+\?[QqBb]\?[^?]*\?=/g, (mimeWord) => mimeWordDecode(mimeWord.replace(/\s+/g, ''))) return str } @@ -236,7 +257,7 @@ export function mimeWordsDecode (str = '') { * @param {Boolean} afterSpace If true, leave a space in th end of a line * @return {String} String with folded lines */ -export function foldLines (str = '', afterSpace) { +export function foldLines(str = '', afterSpace?: boolean): string { let pos = 0 const len = str.length let result = '' @@ -253,7 +274,10 @@ export function foldLines (str = '', afterSpace) { result += line pos += line.length continue - } else if ((match = line.match(/(\s+)[^\s]*$/)) && match[0].length - (afterSpace ? (match[1] || '').length : 0) < line.length) { + } else if ( + (match = line.match(/(\s+)[^\s]*$/)) && + match[0].length - (afterSpace ? (match[1] || '').length : 0) < line.length + ) { line = line.substr(0, line.length - (match[0].length - (afterSpace ? (match[1] || '').length : 0))) } else if ((match = str.substr(pos + line.length).match(/^[^\s]+(\s*)/))) { line = line + match[0].substr(0, match[0].length - (!afterSpace ? (match[1] || '').length : 0)) @@ -278,8 +302,8 @@ export function foldLines (str = '', afterSpace) { * @param {String} [fromCharset='UTF-8'] Character set of the value * @return {String} encoded and folded header line */ -export function headerLineEncode (key, value, fromCharset) { - var encodedValue = mimeWordsEncode(value, 'Q', fromCharset) +export function headerLineEncode(key: string, value: string | Uint8Array, fromCharset?: string): string { + const encodedValue = mimeWordsEncode(value, 'Q', fromCharset) return foldLines(key + ': ' + encodedValue) } @@ -290,13 +314,16 @@ export function headerLineEncode (key, value, fromCharset) { * @param {String} headerLine Single header line, might include linebreaks as well if folded * @return {Object} And object of {key, value} */ -export function headerLineDecode (headerLine = '') { - const line = headerLine.toString().replace(/(?:\r?\n|\r)[ \t]*/g, ' ').trim() +export function headerLineDecode(headerLine = ''): { key: string; value: string } { + const line = headerLine + .toString() + .replace(/(?:\r?\n|\r)[ \t]*/g, ' ') + .trim() const match = line.match(/^\s*([^:]+):(.*)$/) return { - key: ((match && match[1]) || '').trim(), - value: ((match && match[2]) || '').trim() + key: (match?.[1] ?? '').trim(), + value: (match?.[2] ?? '').trim() } } @@ -307,9 +334,9 @@ export function headerLineDecode (headerLine = '') { * @param {String} headers Headers string * @return {Object} An object of headers, where header keys are object keys. NB! Several values with the same key make up an Array */ -export function headerLinesDecode (headers) { +export function headerLinesDecode(headers: string): Record { const lines = headers.split(/\r?\n|\r/) - const headersObj = {} + const headersObjArr: Record = {} for (let i = lines.length - 1; i >= 0; i--) { if (i && lines[i].match(/^\s/)) { @@ -323,13 +350,18 @@ export function headerLinesDecode (headers) { const key = header.key.toLowerCase() const value = header.value - if (!headersObj[key]) { - headersObj[key] = value + if (!headersObjArr[key]) { + headersObjArr[key] = [value] } else { - headersObj[key] = [].concat(headersObj[key], value) + headersObjArr[key].push(value) } } + // convert single value arrays to single values + const headersObj = Object.fromEntries( + Object.entries(headersObjArr).map(([key, value]) => (value.length === 1 ? [key, value[0]] : [key, value])) + ) + return headersObj } @@ -348,17 +380,16 @@ export function headerLinesDecode (headers) { * @param {String} str Header value * @return {Object} Header value as a parsed structure */ -export function parseHeaderValue (str) { - let response = { - value: false, - params: {} - } - let key = false +export function parseHeaderValue(str: string): { value: string | false; params: Record } { + let key: string | false = false let value = '' let type = 'value' - let quote = false + let quote: string | false = false let escaped = false - let chr + let chr: string + + let responseValue: string | boolean = false + const initialParams: Record = {} for (let i = 0, len = str.length; i < len; i++) { chr = str.charAt(i) @@ -381,10 +412,10 @@ export function parseHeaderValue (str) { } else if (!quote && chr === '"') { quote = chr } else if (!quote && chr === ';') { - if (key === false) { - response.value = value.trim() + if (!key) { + responseValue = value.trim() } else { - response.params[key] = value.trim() + initialParams[key] = value.trim() } type = 'key' value = '' @@ -396,70 +427,93 @@ export function parseHeaderValue (str) { } if (type === 'value') { - if (key === false) { - response.value = value.trim() + if (!key) { + responseValue = value.trim() } else { - response.params[key] = value.trim() + initialParams[key] = value.trim() } } else if (value.trim()) { - response.params[value.trim().toLowerCase()] = '' + initialParams[value.trim().toLowerCase()] = '' } // handle parameter value continuations // https://tools.ietf.org/html/rfc2231#section-3 + const processedParams: Record< + string, + { + charset: string | false + values: string[] + } + > = {} + // preprocess values - Object.keys(response.params).forEach(function (key) { - var actualKey, nr, match, value + Object.keys(initialParams).forEach(function (key) { + let actualKey, nr, match, value + if ((match = key.match(/(\*(\d+)|\*(\d+)\*|\*)$/))) { actualKey = key.substr(0, match.index) nr = Number(match[2] || match[3]) || 0 - if (!response.params[actualKey] || typeof response.params[actualKey] !== 'object') { - response.params[actualKey] = { + if (!processedParams[actualKey]) { + processedParams[actualKey] = { charset: false, values: [] } } - value = response.params[key] + value = initialParams[key] if (nr === 0 && match[0].substr(-1) === '*' && (match = value.match(/^([^']*)'[^']*'(.*)$/))) { - response.params[actualKey].charset = match[1] || 'iso-8859-1' + processedParams[actualKey].charset = match[1] || 'iso-8859-1' value = match[2] } - response.params[actualKey].values[nr] = value + processedParams[actualKey].values[nr] = value // remove the old reference - delete response.params[key] + delete initialParams[key] } }) + const concatenatedParams: Record = {} + // concatenate split rfc2231 strings and convert encoded strings to mime encoded words - Object.keys(response.params).forEach(function (key) { - var value - if (response.params[key] && Array.isArray(response.params[key].values)) { - value = response.params[key].values.map(function (val) { - return val || '' - }).join('') - - if (response.params[key].charset) { + Object.keys(processedParams).forEach(function (key) { + let value + if (processedParams[key] && Array.isArray(processedParams[key].values)) { + value = processedParams[key].values + .map(function (val) { + return val || '' + }) + .join('') + + if (processedParams[key].charset) { // convert "%AB" to "=?charset?Q?=AB?=" - response.params[key] = '=?' + response.params[key].charset + '?Q?' + value - .replace(/[=?_\s]/g, function (s) { - // fix invalidly encoded chars - var c = s.charCodeAt(0).toString(16) - return s === ' ' ? '_' : '%' + (c.length < 2 ? '0' : '') + c - }) - .replace(/%/g, '=') + '?=' // change from urlencoding to percent encoding + concatenatedParams[key] = + '=?' + + processedParams[key].charset + + '?Q?' + + value + .replace(/[=?_\s]/g, function (s: string): string { + // fix invalidly encoded chars + const c = s.charCodeAt(0).toString(16) + return s === ' ' ? '_' : '%' + (c.length < 2 ? '0' : '') + c + }) + .replace(/%/g, '=') + + '?=' // change from urlencoding to percent encoding } else { - response.params[key] = value + concatenatedParams[key] = value } } }) - return response + const responseParams = { ...initialParams, ...concatenatedParams } + + return { + value: responseValue, + params: responseParams + } } /** @@ -477,10 +531,15 @@ export function parseHeaderValue (str) { * @param {String} [fromCharset='UTF-8'] Source sharacter set * @return {Array} A list of encoded keys and headers */ -export function continuationEncode (key, data, maxLength, fromCharset) { +export function continuationEncode( + key: string | Uint8Array, + data: string, + maxLength: number, + fromCharset?: string +): Array> { const list = [] - var encodedStr = typeof data === 'string' ? data : decode(data, fromCharset) - var line + let encodedStr = typeof data === 'string' ? data : decode(data, fromCharset) + let line maxLength = maxLength || 50 @@ -488,13 +547,15 @@ export function continuationEncode (key, data, maxLength, fromCharset) { if (/^[\w.\- ]*$/.test(data)) { // check if conversion is even needed if (encodedStr.length <= maxLength) { - return [{ - key: key, - value: /[\s";=]/.test(encodedStr) ? '"' + encodedStr + '"' : encodedStr - }] + return [ + { + key, + value: /[\s";=]/.test(encodedStr) ? '"' + encodedStr + '"' : encodedStr + } + ] } - encodedStr = encodedStr.replace(new RegExp('.{' + maxLength + '}', 'g'), function (str) { + encodedStr = encodedStr.replace(new RegExp('.{' + maxLength.toString() + '}', 'g'), function (str) { list.push({ line: str }) @@ -508,8 +569,10 @@ export function continuationEncode (key, data, maxLength, fromCharset) { } } else { // process text with unicode or special chars - const uriEncoded = encodeURIComponent('utf-8\'\'' + encodedStr) + const uriEncoded = encodeURIComponent("utf-8''" + encodedStr) let i = 0 + + // eslint-disable-next-line no-constant-condition while (true) { let len = maxLength // must not split hex encoded byte between lines @@ -523,7 +586,7 @@ export function continuationEncode (key, data, maxLength, fromCharset) { break } list.push({ - line: line, + line, encoded: true }) i += line.length @@ -535,7 +598,7 @@ export function continuationEncode (key, data, maxLength, fromCharset) { // encoded lines: {name}*{part}* // unencoded lines: {name}*{part} // if any line needs to be encoded then the first line (part==0) is always encoded - key: key + '*' + i + (item.encoded ? '*' : ''), + key: key.toString() + '*' + i.toString() + (item.encoded ? '*' : ''), value: /[\s";=]/.test(item.line) ? '"' + item.line + '"' : item.line } }) @@ -548,7 +611,7 @@ export function continuationEncode (key, data, maxLength, fromCharset) { * @param {Number} maxlen Maximum length of characters for one part (minimum 12) * @return {Array} Split string */ -function _splitMimeEncodedString (str, maxlen = 12) { +function _splitMimeEncodedString(str: string, maxlen = 12): string[] { const minWordLength = 12 // require at least 12 symbols to fit possible 4 octet UTF-8 sequences const maxWordLength = Math.max(maxlen, minWordLength) const lines = [] @@ -569,7 +632,7 @@ function _splitMimeEncodedString (str, maxlen = 12) { if (match) { chr = parseInt(match[1], 16) // invalid sequence, move one char back anc recheck - if (chr < 0xC2 && chr > 0x7F) { + if (chr < 0xc2 && chr > 0x7f) { curLine = curLine.substr(0, curLine.length - 3) done = false } @@ -585,8 +648,11 @@ function _splitMimeEncodedString (str, maxlen = 12) { return lines } -function _addBase64SoftLinebreaks (base64EncodedStr = '') { - return base64EncodedStr.trim().replace(new RegExp('.{' + MAX_LINE_LENGTH + '}', 'g'), '$&\r\n').trim() +function _addBase64SoftLinebreaks(base64EncodedStr = ''): string { + return base64EncodedStr + .trim() + .replace(new RegExp('.{' + MAX_LINE_LENGTH.toString() + '}', 'g'), '$&\r\n') + .trim() } /** @@ -595,7 +661,7 @@ function _addBase64SoftLinebreaks (base64EncodedStr = '') { * @param {String} qpEncodedStr String in Quoted-Printable encoding * @return {String} String with forced line breaks */ -function _addQPSoftLinebreaks (qpEncodedStr = '') { +function _addQPSoftLinebreaks(qpEncodedStr = ''): string { let pos = 0 const len = qpEncodedStr.length const lineMargin = Math.floor(MAX_LINE_LENGTH / 3) @@ -605,7 +671,7 @@ function _addQPSoftLinebreaks (qpEncodedStr = '') { // insert soft linebreaks where needed while (pos < len) { line = qpEncodedStr.substr(pos, MAX_LINE_LENGTH) - if ((match = line.match(/\r\n/))) { + if ((match = line.match(/\r\n/)) && match.index !== undefined) { line = line.substr(0, match.index + match[0].length) result += line pos += line.length @@ -623,7 +689,10 @@ function _addQPSoftLinebreaks (qpEncodedStr = '') { result += line pos += line.length continue - } else if (line.length > MAX_LINE_LENGTH - lineMargin && (match = line.substr(-lineMargin).match(/[ \t.,!?][^ \t.,!?]*$/))) { + } else if ( + line.length > MAX_LINE_LENGTH - lineMargin && + (match = line.substr(-lineMargin).match(/[ \t.,!?][^ \t.,!?]*$/)) + ) { // truncate to nearest space line = line.substr(0, line.length - (match[0].length - 1)) } else if (line.substr(-1) === '\r') { @@ -636,7 +705,12 @@ function _addQPSoftLinebreaks (qpEncodedStr = '') { } // ensure that utf-8 sequences are not split - while (line.length > 3 && line.length < len - pos && !line.match(/^(?:=[\da-f]{2}){1,4}$/i) && (match = line.match(/=[\da-f]{2}$/ig))) { + while ( + line.length > 3 && + line.length < len - pos && + !line.match(/^(?:=[\da-f]{2}){1,4}$/i) && + (match = line.match(/=[\da-f]{2}$/gi)) + ) { const code = parseInt(match[0].substr(1, 2), 16) if (code < 128) { break @@ -644,7 +718,7 @@ function _addQPSoftLinebreaks (qpEncodedStr = '') { line = line.substr(0, line.length - 3) - if (code >= 0xC0) { + if (code >= 0xc0) { break } } diff --git a/src/mimecodec-unit.js b/src/mimecodec.unit.ts similarity index 50% rename from src/mimecodec-unit.js rename to src/mimecodec.unit.ts index 40ab965..9baf0d8 100644 --- a/src/mimecodec-unit.js +++ b/src/mimecodec.unit.ts @@ -1,11 +1,15 @@ -/* eslint-disable one-var, no-tabs */ - +import { expect } from 'chai' import { - mimeEncode, mimeDecode, - base64Encode, base64Decode, - quotedPrintableEncode, quotedPrintableDecode, - mimeWordEncode, mimeWordDecode, - mimeWordsEncode, mimeWordsDecode, + mimeEncode, + mimeDecode, + base64Encode, + base64Decode, + quotedPrintableEncode, + quotedPrintableDecode, + mimeWordEncode, + mimeWordDecode, + mimeWordsEncode, + mimeWordsDecode, foldLines, continuationEncode, headerLineEncode, @@ -15,21 +19,21 @@ import { describe('#mimeEncode', function () { it('shoud encode UTF-8', function () { - var str = 'tere ÕÄÖÕ', + const str = 'tere ÕÄÖÕ', encodedStr = 'tere =C3=95=C3=84=C3=96=C3=95' expect(mimeEncode(str)).to.equal(encodedStr) }) it('shoud encode trailing whitespace', function () { - var str = 'tere ', + const str = 'tere ', encodedStr = 'tere =20' expect(mimeEncode(str)).to.equal(encodedStr) }) it('shoud encode non UTF-8', function () { - var buf = new Uint8Array([0xBD, 0xC5]), + const buf = new Uint8Array([0xbd, 0xc5]), encoding = 'ks_c_5601-1987', encodedStr = '=EC=8B=A0' @@ -39,14 +43,14 @@ describe('#mimeEncode', function () { describe('#mimeDecode', function () { it('should decode UTF-8', function () { - var str = 'tere ÕÄÖÕ', + const str = 'tere ÕÄÖÕ', encodedStr = 'tere =C3=95=C3=84=C3=96=C3=95' expect(mimeDecode(encodedStr)).to.equal(str) }) it('should decode non UTF-8', function () { - var str = '신', + const str = '신', encoding = 'ks_c_5601-1987', encodedStr = '=BD=C5' @@ -56,28 +60,28 @@ describe('#mimeDecode', function () { describe('#base64Encode', function () { it('should base64Encode a UTF-8 string', function () { - var str = 'tere ÕÄÖÕ', + const str = 'tere ÕÄÖÕ', encodedStr = 'dGVyZSDDlcOEw5bDlQ==' expect(base64Encode(str)).to.equal(encodedStr) }) it('should base64Encode an ASCII string', function () { - var str = 'bliblablubb', + const str = 'bliblablubb', encodedStr = 'YmxpYmxhYmx1YmI=' expect(base64Encode(str, 'binary')).to.equal(encodedStr) }) it('should base64Encode a UTF-8 typed array', function () { - var buf = new Uint8Array([116, 101, 114, 101, 32, 195, 149, 195, 132, 195, 150, 195, 149]), + const buf = new Uint8Array([116, 101, 114, 101, 32, 195, 149, 195, 132, 195, 150, 195, 149]), encodedStr = 'dGVyZSDDlcOEw5bDlQ==' expect(base64Encode(buf)).to.equal(encodedStr) }) it('should base64Encode non UTF-8 typed array', function () { - var buf = new Uint8Array([0xBD, 0xC5]), + const buf = new Uint8Array([0xbd, 0xc5]), encoding = 'ks_c_5601-1987', encodedStr = '7Iug' @@ -87,14 +91,14 @@ describe('#base64Encode', function () { describe('#base64Decode', function () { it('should decode UTF-8', function () { - var str = 'tere ÕÄÖÕ', + const str = 'tere ÕÄÖÕ', encodedStr = 'dGVyZSDDlcOEw5bDlQ==' expect(base64Decode(encodedStr)).to.equal(str) }) it('should decode non UTF-8', function () { - var str = '신', + const str = '신', encoding = 'ks_c_5601-1987', encodedStr = 'vcU=' @@ -102,7 +106,8 @@ describe('#base64Decode', function () { }) it('should decode binary b64', () => { - const text = 'MIIB3AYJKoZIhvcNAQcDoIIBzTCCAckCAQIxggFuMIIBagIBADAjMB4xHDAJBgNVBAYTAlJVMA8G\n' + + const text = + 'MIIB3AYJKoZIhvcNAQcDoIIBzTCCAckCAQIxggFuMIIBagIBADAjMB4xHDAJBgNVBAYTAlJVMA8G\n' + 'A1UEAx4IAFQAZQBzAHQCAQEwPAYJKoZIhvcNAQEHMC+gDzANBglghkgBZQMEAgMFAKEcMBoGCSqG\n' + 'SIb3DQEBCDANBglghkgBZQMEAgMFAASCAQBDyepahKyM+hceeF7J+pyiSVYLElKyFKff9flMs1VX\n' + 'ZaBQRcEYpIqw9agD4u+aHlIOJ6AtdCbxaV0M8q6gjM4E5lUFUOqG/QIycdG2asZ0lza/DL8SdxfA\n' + @@ -119,61 +124,72 @@ describe('#base64Decode', function () { describe('#quotedPrintableEncode', function () { it('should encode UTF-8 to quoted-printable', function () { - var str = 'tere ÕÄ \t\nÕÄ \t\nÖÕ', + const str = 'tere ÕÄ \t\nÕÄ \t\nÖÕ', encodedStr = 'tere =C3=95=C3=84 =09\r\n=C3=95=C3=84 =09\r\n=C3=96=C3=95' expect(quotedPrintableEncode(str)).to.equal(encodedStr) }) it('should add soft line breaks', function () { - var str = 'õäöüõäöüõäöüõäöüõäöüõäöüõäöõ', - encodedStr = '=C3=B5=C3=A4=C3=B6=C3=BC=C3=B5=C3=A4=C3=B6=C3=BC=C3=B5=C3=A4=C3=B6=C3=BC=\r\n' + - '=C3=B5=C3=A4=C3=B6=C3=BC=C3=B5=C3=A4=C3=B6=C3=BC=C3=B5=C3=A4=C3=B6=C3=BC=\r\n' + - '=C3=B5=C3=A4=C3=B6=C3=B5' + const str = 'õäöüõäöüõäöüõäöüõäöüõäöüõäöõ', + encodedStr = + '=C3=B5=C3=A4=C3=B6=C3=BC=C3=B5=C3=A4=C3=B6=C3=BC=C3=B5=C3=A4=C3=B6=C3=BC=\r\n' + + '=C3=B5=C3=A4=C3=B6=C3=BC=C3=B5=C3=A4=C3=B6=C3=BC=C3=B5=C3=A4=C3=B6=C3=BC=\r\n' + + '=C3=B5=C3=A4=C3=B6=C3=B5' expect(quotedPrintableEncode(str)).to.equal(encodedStr) }) it('should encode short string', function () { - expect('Tere =C3=95=C3=84=C3=96=C3=9C!').to.equal(quotedPrintableEncode(new Uint8Array([0x54, 0x65, 0x72, 0x65, 0x20, 0xD5, 0xC4, 0xD6, 0xDC, 0x21]), 'Latin_1')) + expect('Tere =C3=95=C3=84=C3=96=C3=9C!').to.equal( + quotedPrintableEncode(new Uint8Array([0x54, 0x65, 0x72, 0x65, 0x20, 0xd5, 0xc4, 0xd6, 0xdc, 0x21]), 'Latin_1') + ) expect('Tere =C3=95=C3=84=C3=96=C3=9C=C5=A0=C5=BD!').to.equal(quotedPrintableEncode('Tere ÕÄÖÜŠŽ!')) - expect('Tere =C5=A0=C5=BD!').to.equal(quotedPrintableEncode(new Uint8Array([0x54, 0x65, 0x72, 0x65, 0x20, 0xD0, 0xDE, 0x21]), 'Win-1257')) + expect('Tere =C5=A0=C5=BD!').to.equal( + quotedPrintableEncode(new Uint8Array([0x54, 0x65, 0x72, 0x65, 0x20, 0xd0, 0xde, 0x21]), 'Win-1257') + ) }) it('should not wrap between encoded chars', function () { - var wrapped = 'a==========================', + const wrapped = 'a==========================', wrappedEncoded = 'a=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=\r\n=3D=3D' expect(wrappedEncoded).to.equal(quotedPrintableEncode(wrapped)) }) it('should encode long string', function () { - var longLine = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789' + - 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789' + - 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789' + - 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789', - longLineEncoded = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLM=\r\n' + - 'NOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ=\r\n' + - 'abcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklm=\r\n' + - 'nopqrstuvwxyz0123456789' + const longLine = + 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789' + + 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789' + + 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789' + + 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789', + longLineEncoded = + 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLM=\r\n' + + 'NOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ=\r\n' + + 'abcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklm=\r\n' + + 'nopqrstuvwxyz0123456789' expect(longLineEncoded).to.equal(quotedPrintableEncode(longLine)) }) it('should quote at line edge', function () { - var str = 'Title: The future of e-commerce is storytelling
', - strEncoded = 'Title: Th=\r\ne future of e-commerce is storytelling
' + const str = + 'Title: The future of e-commerce is storytelling
', + strEncoded = + 'Title: Th=\r\ne future of e-commerce is storytelling
' expect(strEncoded).to.equal(quotedPrintableEncode(str)) }) it('should wrap long string with UTF-8 sequence on edge', function () { - var longLine = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789' + - 'ABCDEFGHIÄÄÄPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789' + - 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789' + - 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789', - longLineEncoded = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHI=\r\n' + - '=C3=84=C3=84=C3=84PQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJ=\r\n' + - 'KLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVW=\r\n' + - 'XYZabcdefghijklmnopqrstuvwxyz0123456789' + const longLine = + 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789' + + 'ABCDEFGHIÄÄÄPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789' + + 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789' + + 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789', + longLineEncoded = + 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHI=\r\n' + + '=C3=84=C3=84=C3=84PQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJ=\r\n' + + 'KLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVW=\r\n' + + 'XYZabcdefghijklmnopqrstuvwxyz0123456789' expect(longLineEncoded).to.equal(quotedPrintableEncode(longLine)) }) @@ -185,27 +201,29 @@ describe('#quotedPrintableEncode', function () { describe('#quotedPrintableDecode', function () { it('should decode quoted-printable to UTF-8', function () { - var str = 'tere ÕÄ \t\r\nÕÄ \t\r\nÖÕ', + const str = 'tere ÕÄ \t\r\nÕÄ \t\r\nÖÕ', encodedStr = 'tere =C3=95=C3=84=20=09\r\n=C3=95=\r\n=C3=84=\r\n=20=09\r\n=C3=96=C3=95=' expect(quotedPrintableDecode(encodedStr)).to.equal(str) }) it('should decode string', function () { - var longLine = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789' + - 'ABCDEFGHIÄÄÄPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789' + - 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789' + - 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789', - longLineEncoded = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHI=\r\n' + - '=C3=84=C3=84=C3=84PQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJ=\r\n' + - 'KLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVW=\r\n' + - 'XYZabcdefghijklmnopqrstuvwxyz0123456789' + const longLine = + 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789' + + 'ABCDEFGHIÄÄÄPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789' + + 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789' + + 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789', + longLineEncoded = + 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHI=\r\n' + + '=C3=84=C3=84=C3=84PQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJ=\r\n' + + 'KLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVW=\r\n' + + 'XYZabcdefghijklmnopqrstuvwxyz0123456789' expect(longLine).to.equal(quotedPrintableDecode(longLineEncoded)) }) it('should decode string with soft linebreaks', function () { - var input = 'Tere =\r\nvana kere=', + const input = 'Tere =\r\nvana kere=', output = 'Tere vana kere' expect(output).to.equal(quotedPrintableDecode(input)) @@ -222,15 +240,20 @@ describe('#mimeWordEncode', function () { }) it('should QP-encode mime word', function () { - expect('=?UTF-8?Q?J=C3=B5ge-va=C5=BD?=').to.equal(mimeWordEncode(new Uint8Array([0x4A, 0xF5, 0x67, 0x65, 0x2D, 0x76, 0x61, 0xDE]), 'Q', 'iso-8859-13')) + expect('=?UTF-8?Q?J=C3=B5ge-va=C5=BD?=').to.equal( + mimeWordEncode(new Uint8Array([0x4a, 0xf5, 0x67, 0x65, 0x2d, 0x76, 0x61, 0xde]), 'Q', 'iso-8859-13') + ) }) it('should Base64-encode mime word', () => { - expect(mimeWordEncode('Привет и до свидания', 'B')).to.equal('=?UTF-8?B?0J/RgNC40LLQtdGCINC4INC00L4g0YHQstC40LTQsNC90LjRjw==?=') + expect(mimeWordEncode('Привет и до свидания', 'B')).to.equal( + '=?UTF-8?B?0J/RgNC40LLQtdGCINC4INC00L4g0YHQstC40LTQsNC90LjRjw==?=' + ) }) it('should Base64-encode a long mime word', () => { - const payload = 'üöß‹€Привет и до свиданияПривет и до свиданияПривет и до свиданияПривет и до свиданияПривет и до свиданияПривет и до свиданияПривет и до свиданияПривет и до свидания' + const payload = + 'üöß‹€Привет и до свиданияПривет и до свиданияПривет и до свиданияПривет и до свиданияПривет и до свиданияПривет и до свиданияПривет и до свиданияПривет и до свидания' const expected = '=?UTF-8?B?w7zDtsOf4oC54oKs0J/RgNC40LLQtdGCINC4INC00L4g0YHQstC4?= ' + '=?UTF-8?B?0LTQsNC90LjRj9Cf0YDQuNCy0LXRgiDQuCDQtNC+INGB0LLQuNC0?= ' + @@ -246,8 +269,8 @@ describe('#mimeWordEncode', function () { describe('#mimeWordsEncode', function () { it('should encode Ascii range', function () { - var input1 = 'метель" вьюга', - input2 = 'метель\'вьюга', + const input1 = 'метель" вьюга', + input2 = "метель'вьюга", input3 = 'Verão você vai adorar!', output1 = '=?UTF-8?Q?=D0=BC=D0=B5=D1=82=D0=B5=D0=BB=D1=8C=22_=D0=B2=D1=8C?= =?UTF-8?Q?=D1=8E=D0=B3=D0=B0?=', output2 = '=?UTF-8?Q?=D0=BC=D0=B5=D1=82=D0=B5=D0=BB=D1=8C=27=D0=B2=D1=8C?= =?UTF-8?Q?=D1=8E=D0=B3=D0=B0?=', @@ -266,7 +289,11 @@ describe('#mimeWordsDecode', function () { }) it('should decode mime words', function () { - expect('Jõge-vaŽ zz Jõge-vaŽJõge-vaŽJõge-vaŽ').to.equal(mimeWordsDecode('=?ISO-8859-13?Q?J=F5ge-va=DE?= zz =?ISO-8859-13?Q?J=F5ge-va=DE?= =?ISO-8859-13?Q?J=F5ge-va=DE?= =?ISO-8859-13?Q?J=F5ge-va=DE?=')) + expect('Jõge-vaŽ zz Jõge-vaŽJõge-vaŽJõge-vaŽ').to.equal( + mimeWordsDecode( + '=?ISO-8859-13?Q?J=F5ge-va=DE?= zz =?ISO-8859-13?Q?J=F5ge-va=DE?= =?ISO-8859-13?Q?J=F5ge-va=DE?= =?ISO-8859-13?Q?J=F5ge-va=DE?=' + ) + ) expect('Sssś Lałalalala').to.equal(mimeWordsDecode('=?UTF-8?B?U3NzxZsgTGHFgmFsYQ==?= =?UTF-8?B?bGFsYQ==?=')) }) @@ -275,17 +302,17 @@ describe('#mimeWordsDecode', function () { }) it('should decode ascii range', function () { - var input1 = 'метель" вьюга', - input2 = 'метель\'вьюга', + const input1 = 'метель" вьюга', + input2 = "метель'вьюга", output1 = '=?UTF-8?Q?=D0=BC=D0=B5=D1=82=D0=B5=D0=BB=D1=8C=22_?= =?UTF-8?Q?=D0=B2=D1=8C=D1=8E=D0=B3=D0=B0?=', - output2 = '=?UTF-8?Q?=D0=BC=D0=B5=D1=82=D0=B5=D0=BB=D1=8C\'?= =?UTF-8?Q?=D0=B2=D1=8C=D1=8E=D0=B3=D0=B0?=' + output2 = "=?UTF-8?Q?=D0=BC=D0=B5=D1=82=D0=B5=D0=BB=D1=8C'?= =?UTF-8?Q?=D0=B2=D1=8C=D1=8E=D0=B3=D0=B0?=" expect(mimeWordsDecode(output1)).to.equal(input1) expect(mimeWordsDecode(output2)).to.equal(input2) }) it('should decode empty string', function () { - var encoded1 = '=?UTF-8?Q??=', + const encoded1 = '=?UTF-8?Q??=', encoded2 = '=?UTF-8?B??=' expect(mimeWordsDecode(encoded1)).to.equal('') @@ -293,29 +320,52 @@ describe('#mimeWordsDecode', function () { }) it('should join bytes of Base64 multi-byte UTF-8 characters before parsing', function () { - expect('GLG: Regulation of Taxi in China - 张一兵').to.equal(mimeWordsDecode('=?utf-8?B?R0xHOiBSZWd1bGF0aW9uIG9mIFRheGkgaW4gQ2hpbmEgLSDl?= =?utf-8?B?vKDkuIDlhbU=?=')) - expect('***SPAM*** Очки виртуальной реальности').to.equal(mimeWordsDecode('***SPAM*** =?utf-8?B?0J7Rh9C60Lgg0LLQuNGA0YLRg9Cw0LvRjNC90L7QuSDR?=\r\n =?utf-8?B?gNC10LDQu9GM0L3QvtGB0YLQuA==?=')) + expect('GLG: Regulation of Taxi in China - 张一兵').to.equal( + mimeWordsDecode('=?utf-8?B?R0xHOiBSZWd1bGF0aW9uIG9mIFRheGkgaW4gQ2hpbmEgLSDl?= =?utf-8?B?vKDkuIDlhbU=?=') + ) + expect('***SPAM*** Очки виртуальной реальности').to.equal( + mimeWordsDecode( + '***SPAM*** =?utf-8?B?0J7Rh9C60Lgg0LLQuNGA0YLRg9Cw0LvRjNC90L7QuSDR?=\r\n =?utf-8?B?gNC10LDQu9GM0L3QvtGB0YLQuA==?=' + ) + ) }) it('should join bytes of Quoted-Printable multi-byte UTF-8 characters before parsing', function () { - expect('гос (передай кому надо тоже').to.equal(mimeWordsDecode('=?utf-8?Q?=D0=B3=D0=BE=D1=81_?==?utf-8?Q?(=D0=BF=D0=B5=D1=80=D0=B5=D0=B4=D0=B0=D0=B9_=D0=BA=D0=BE=D0?= =?utf-8?Q?=BC=D1=83_=D0=BD=D0=B0=D0=B4=D0=BE_=D1=82=D0=BE=D0=B6=D0=B5?=')) + expect('гос (передай кому надо тоже').to.equal( + mimeWordsDecode( + '=?utf-8?Q?=D0=B3=D0=BE=D1=81_?==?utf-8?Q?(=D0=BF=D0=B5=D1=80=D0=B5=D0=B4=D0=B0=D0=B9_=D0=BA=D0=BE=D0?= =?utf-8?Q?=BC=D1=83_=D0=BD=D0=B0=D0=B4=D0=BE_=D1=82=D0=BE=D0=B6=D0=B5?=' + ) + ) }) it('should not join together encoded words with different encodings', function () { - expect(' ⏯ Trendy Netflix Redesigns + ✈️ Airport App Challenge').to.equal(mimeWordsDecode('=?utf-8?b?IOKPryBUcmVuZHkgTmV0ZmxpeCBSZWRlc2lnbnMgKyDinIjvuI8g?= =?utf-8?q?Airport_App_Challenge?=')) + expect(' ⏯ Trendy Netflix Redesigns + ✈️ Airport App Challenge').to.equal( + mimeWordsDecode( + '=?utf-8?b?IOKPryBUcmVuZHkgTmV0ZmxpeCBSZWRlc2lnbnMgKyDinIjvuI8g?= =?utf-8?q?Airport_App_Challenge?=' + ) + ) }) it('should decode Quoted-Printable with bad line split', function () { - expect('гос (передай кому надо тоже').to.equal(mimeWordsDecode('=?utf-8?Q?=D0=B3=D0=BE=D1=81_?==?utf-8?Q?(=D0=BF=D0=B5=D1=80=D0=B5= D0=B4=D0=B0=D0=B9_=D0=BA=D0=BE=D0?= =?utf-8?Q?=BC=D1=83_=D0=BD=D0=B0=D0=B4=D0=BE_=D1=82=D0=BE=D0=B6=D0=B5?=')) + expect('гос (передай кому надо тоже').to.equal( + mimeWordsDecode( + '=?utf-8?Q?=D0=B3=D0=BE=D1=81_?==?utf-8?Q?(=D0=BF=D0=B5=D1=80=D0=B5= D0=B4=D0=B0=D0=B9_=D0=BA=D0=BE=D0?= =?utf-8?Q?=BC=D1=83_=D0=BD=D0=B0=D0=B4=D0=BE_=D1=82=D0=BE=D0=B6=D0=B5?=' + ) + ) }) it('should correclty parse this ISO-2022-JP encoded string', function () { - expect('ATOK Passport お申し込み完了&ユーザー登録完了(定額利用サービス)').to.equal(mimeWordsDecode('=?ISO-2022-JP?B?QVRPSyBQYXNzcG9ydCAbJEIkKj89JDc5fiRfNDAbKEI=?= =?ISO-2022-JP?B?GyRCTjshdSVmITwlNiE8RVBPPzQwTjsbKEI=?= =?ISO-2022-JP?B?GyRCIUpEajNbTXhNUSU1ITwlUyU5IUsbKEI=?=')) + expect('ATOK Passport お申し込み完了&ユーザー登録完了(定額利用サービス)').to.equal( + mimeWordsDecode( + '=?ISO-2022-JP?B?QVRPSyBQYXNzcG9ydCAbJEIkKj89JDc5fiRfNDAbKEI=?= =?ISO-2022-JP?B?GyRCTjshdSVmITwlNiE8RVBPPzQwTjsbKEI=?= =?ISO-2022-JP?B?GyRCIUpEajNbTXhNUSU1ITwlUyU5IUsbKEI=?=' + ) + ) }) it('should split QP on maxLength', function () { - var inputStr = 'Jõgeva Jõgeva Jõgeva mugeva Jõgeva Jõgeva Jõgeva Jõgeva Jõgeva', - outputStr = '=?UTF-8?Q?J=C3=B5geva_J=C3=B5geva_J=C3=B5geva?= mugeva =?UTF-8?Q?J=C3=B5geva_J=C3=B5geva_J=C3=B5geva_J=C3=B5geva_J?= =?UTF-8?Q?=C3=B5geva?=', + const inputStr = 'Jõgeva Jõgeva Jõgeva mugeva Jõgeva Jõgeva Jõgeva Jõgeva Jõgeva', + outputStr = + '=?UTF-8?Q?J=C3=B5geva_J=C3=B5geva_J=C3=B5geva?= mugeva =?UTF-8?Q?J=C3=B5geva_J=C3=B5geva_J=C3=B5geva_J=C3=B5geva_J?= =?UTF-8?Q?=C3=B5geva?=', encoded = mimeWordsEncode(inputStr, 'Q') expect(outputStr).to.equal(encoded) @@ -329,84 +379,109 @@ describe('#mimeWordsDecode', function () { describe('#continuationEncode', function () { it('should return quoted', function () { - expect([{ - key: 'title', - value: '"this is just a title"' - }]).to.deep.equal(continuationEncode('title', 'this is just a title', 500)) + expect([ + { + key: 'title', + value: '"this is just a title"' + } + ]).to.deep.equal(continuationEncode('title', 'this is just a title', 500)) }) it('should encode and split ascii', function () { - expect([{ - key: 'title*0', - value: '"this "' - }, { - key: 'title*1', - value: '"is ju"' - }, { - key: 'title*2', - value: '"st a "' - }, { - key: 'title*3', - value: 'title' - }]).to.deep.equal(continuationEncode('title', 'this is just a title', 5)) + expect([ + { + key: 'title*0', + value: '"this "' + }, + { + key: 'title*1', + value: '"is ju"' + }, + { + key: 'title*2', + value: '"st a "' + }, + { + key: 'title*3', + value: 'title' + } + ]).to.deep.equal(continuationEncode('title', 'this is just a title', 5)) }) it('should encode and split unicode', function () { - expect([{ - key: 'title*0*', - value: 'utf-8\'\'this%20is%20j' - }, { - key: 'title*1*', - value: 'ust%20a%20title%20' - }, { - key: 'title*2*', - value: '%C3%B5%C3%A4%C3%B6' - }, { - key: 'title*3*', - value: '%C3%BC' - }]).to.deep.equal(continuationEncode('title', 'this is just a title õäöü', 20)) + expect([ + { + key: 'title*0*', + value: "utf-8''this%20is%20j" + }, + { + key: 'title*1*', + value: 'ust%20a%20title%20' + }, + { + key: 'title*2*', + value: '%C3%B5%C3%A4%C3%B6' + }, + { + key: 'title*3*', + value: '%C3%BC' + } + ]).to.deep.equal(continuationEncode('title', 'this is just a title õäöü', 20)) }) it('should encode and decode', function () { - var input = 'Lorěm ipsum doloř siť amet, háš peřpetua compřéhenšam at, ei nám modó soleát éxpétěndá! Boňorum vocibůs dignisšim pro ad, ea sensibus efficiendi intellegam ius. Ad nam aperiam delicata voluptaria, vix nobis luptatum ea, ců úsú graeco viďiššě ňusqúam. ' - var headerLine = 'content-disposition: attachment; ' + continuationEncode('filename', input, 50).map(function (item) { - return item.key + '="' + item.value + '"' - }).join('; ') - var parsedHeader = parseHeaderValue(headerLine) + const input = + 'Lorěm ipsum doloř siť amet, háš peřpetua compřéhenšam at, ei nám modó soleát éxpétěndá! Boňorum vocibůs dignisšim pro ad, ea sensibus efficiendi intellegam ius. Ad nam aperiam delicata voluptaria, vix nobis luptatum ea, ců úsú graeco viďiššě ňusqúam. ' + const headerLine = + 'content-disposition: attachment; ' + + continuationEncode('filename', input, 50) + .map(function (item) { + return item.key + '="' + item.value + '"' + }) + .join('; ') + const parsedHeader = parseHeaderValue(headerLine) expect(input).to.equal(mimeWordsDecode(parsedHeader.params.filename)) }) it('should not cause URIError when encoding multi-byte unicode chars', function () { - expect([{ - key: 'title*0*', - value: 'utf-8\'\'%F0%9F%98%8A' - }]).to.deep.equal(continuationEncode('title', '😊', 500)) + expect([ + { + key: 'title*0*', + value: "utf-8''%F0%9F%98%8A" + } + ]).to.deep.equal(continuationEncode('title', '😊', 500)) }) }) describe('#foldLines', function () { it('should Fold long header line', function () { - var inputStr = 'Subject: Testin command line kirja õkva kakva mõni tõnis kõllas põllas tõllas rõllas jušla kušla tušla musla', - outputStr = 'Subject: Testin command line kirja =?UTF-8?Q?=C3=B5kva?= kakva\r\n' + - ' =?UTF-8?Q?m=C3=B5ni_t=C3=B5nis_k=C3=B5llas_p=C3=B5llas_t=C3=B5?=\r\n' + - ' =?UTF-8?Q?llas_r=C3=B5llas_ju=C5=A1la_ku=C5=A1la_tu=C5=A1la?= musla', + const inputStr = + 'Subject: Testin command line kirja õkva kakva mõni tõnis kõllas põllas tõllas rõllas jušla kušla tušla musla', + outputStr = + 'Subject: Testin command line kirja =?UTF-8?Q?=C3=B5kva?= kakva\r\n' + + ' =?UTF-8?Q?m=C3=B5ni_t=C3=B5nis_k=C3=B5llas_p=C3=B5llas_t=C3=B5?=\r\n' + + ' =?UTF-8?Q?llas_r=C3=B5llas_ju=C5=A1la_ku=C5=A1la_tu=C5=A1la?= musla', encodedHeaderLine = mimeWordsEncode(inputStr, 'Q') expect(outputStr).to.equal(foldLines(encodedHeaderLine)) }) it('should Fold flowed text', function () { - var inputStr = 'Testin command line kirja õkva kakva mõni tõnis kõllas põllas tõllas rõllas jušla kušla tušla musla Testin command line kirja õkva kakva mõni tõnis kõllas põllas tõllas rõllas jušla kušla tušla musla', - outputStr = 'Testin command line kirja õkva kakva mõni tõnis kõllas põllas tõllas rõllas \r\n' + - 'jušla kušla tušla musla Testin command line kirja õkva kakva mõni tõnis \r\n' + - 'kõllas põllas tõllas rõllas jušla kušla tušla musla' + const inputStr = + 'Testin command line kirja õkva kakva mõni tõnis kõllas põllas tõllas rõllas jušla kušla tušla musla Testin command line kirja õkva kakva mõni tõnis kõllas põllas tõllas rõllas jušla kušla tušla musla', + outputStr = + 'Testin command line kirja õkva kakva mõni tõnis kõllas põllas tõllas rõllas \r\n' + + 'jušla kušla tušla musla Testin command line kirja õkva kakva mõni tõnis \r\n' + + 'kõllas põllas tõllas rõllas jušla kušla tušla musla' - expect(outputStr).to.equal(foldLines(inputStr, 76, true)) + expect(outputStr).to.equal(foldLines(inputStr, true)) }) it('should fold one long line', function () { - var inputStr = 'Subject: =?UTF-8?Q?=CB=86=C2=B8=C3=81=C3=8C=C3=93=C4=B1=C3=8F=CB=87=C3=81=C3=9B^=C2=B8\\=C3=81=C4=B1=CB=86=C3=8C=C3=81=C3=9B=C3=98^\\=CB=9C=C3=9B=CB=9D=E2=84=A2=CB=87=C4=B1=C3=93=C2=B8^\\=CB=9C=EF=AC=81^\\=C2=B7\\=CB=9C=C3=98^=C2=A3=CB=9C#=EF=AC=81^\\=C2=A3=EF=AC=81^\\=C2=A3=EF=AC=81^\\?=', - outputStr = 'Subject:\r\n =?UTF-8?Q?=CB=86=C2=B8=C3=81=C3=8C=C3=93=C4=B1=C3=8F=CB=87=C3=81=C3=9B^=C2=B8\\=C3=81=C4=B1=CB=86=C3=8C=C3=81=C3=9B=C3=98^\\=CB=9C=C3=9B=CB=9D=E2=84=A2=CB=87=C4=B1=C3=93=C2=B8^\\=CB=9C=EF=AC=81^\\=C2=B7\\=CB=9C=C3=98^=C2=A3=CB=9C#=EF=AC=81^\\=C2=A3=EF=AC=81^\\=C2=A3=EF=AC=81^\\?=' + const inputStr = + 'Subject: =?UTF-8?Q?=CB=86=C2=B8=C3=81=C3=8C=C3=93=C4=B1=C3=8F=CB=87=C3=81=C3=9B^=C2=B8\\=C3=81=C4=B1=CB=86=C3=8C=C3=81=C3=9B=C3=98^\\=CB=9C=C3=9B=CB=9D=E2=84=A2=CB=87=C4=B1=C3=93=C2=B8^\\=CB=9C=EF=AC=81^\\=C2=B7\\=CB=9C=C3=98^=C2=A3=CB=9C#=EF=AC=81^\\=C2=A3=EF=AC=81^\\=C2=A3=EF=AC=81^\\?=', + outputStr = + 'Subject:\r\n =?UTF-8?Q?=CB=86=C2=B8=C3=81=C3=8C=C3=93=C4=B1=C3=8F=CB=87=C3=81=C3=9B^=C2=B8\\=C3=81=C4=B1=CB=86=C3=8C=C3=81=C3=9B=C3=98^\\=CB=9C=C3=9B=CB=9D=E2=84=A2=CB=87=C4=B1=C3=93=C2=B8^\\=CB=9C=EF=AC=81^\\=C2=B7\\=CB=9C=C3=98^=C2=A3=CB=9C#=EF=AC=81^\\=C2=A3=EF=AC=81^\\=C2=A3=EF=AC=81^\\?=' expect(outputStr).to.equal(foldLines(inputStr)) }) @@ -414,9 +489,10 @@ describe('#foldLines', function () { describe('#headerLineEncode', function () { it('should encode and fold header line', function () { - var key = 'Subject', + const key = 'Subject', value = 'Testin command line kirja õkva kakva mõni tõnis kõllas põllas tõllas rõllas jušla kušla tušla musla', - outputStr = 'Subject: Testin command line kirja =?UTF-8?Q?=C3=B5kva?= kakva\r\n' + + outputStr = + 'Subject: Testin command line kirja =?UTF-8?Q?=C3=B5kva?= kakva\r\n' + ' =?UTF-8?Q?m=C3=B5ni_t=C3=B5nis_k=C3=B5llas_p=C3=B5llas_t=C3=B5?=\r\n' + ' =?UTF-8?Q?llas_r=C3=B5llas_ju=C5=A1la_ku=C5=A1la_tu=C5=A1la?= musla', encodedHeaderLine = headerLineEncode(key, value) @@ -427,17 +503,22 @@ describe('#headerLineEncode', function () { describe('#headerLinesDecode', function () { it('should decode headers', function () { - var headersObj = { - 'subject': 'Tere =?UTF-8?Q?J=C3=B5geva?=', - 'x-app': ['My =?UTF-8?Q?=C5=A1=C5=A1=C5=A1=C5=A1?= app line 1', 'My =?UTF-8?Q?=C5=A1=C5=A1=C5=A1=C5=A1?= app line 2'], - 'long-line': 'tere =?UTF-8?Q?=C3=B5klva?= karu =?UTF-8?Q?m=C3=B5kva_=C5=A1apaka=C5=A1?= tutikas suur maja, =?UTF-8?Q?k=C3=B5rge?= hoone, segane jutt' + const headersObj = { + subject: 'Tere =?UTF-8?Q?J=C3=B5geva?=', + 'x-app': [ + 'My =?UTF-8?Q?=C5=A1=C5=A1=C5=A1=C5=A1?= app line 1', + 'My =?UTF-8?Q?=C5=A1=C5=A1=C5=A1=C5=A1?= app line 2' + ], + 'long-line': + 'tere =?UTF-8?Q?=C3=B5klva?= karu =?UTF-8?Q?m=C3=B5kva_=C5=A1apaka=C5=A1?= tutikas suur maja, =?UTF-8?Q?k=C3=B5rge?= hoone, segane jutt' }, - headersStr = 'Subject: Tere =?UTF-8?Q?J=C3=B5geva?=\r\n' + - 'X-APP: My =?UTF-8?Q?=C5=A1=C5=A1=C5=A1=C5=A1?= app line 1\r\n' + - 'X-APP: My =?UTF-8?Q?=C5=A1=C5=A1=C5=A1=C5=A1?= app line 2\r\n' + - 'Long-Line: tere =?UTF-8?Q?=C3=B5klva?= karu\r\n' + - ' =?UTF-8?Q?m=C3=B5kva_=C5=A1apaka=C5=A1?= tutikas suur maja,\r\n' + - ' =?UTF-8?Q?k=C3=B5rge?= hoone, segane jutt' + headersStr = + 'Subject: Tere =?UTF-8?Q?J=C3=B5geva?=\r\n' + + 'X-APP: My =?UTF-8?Q?=C5=A1=C5=A1=C5=A1=C5=A1?= app line 1\r\n' + + 'X-APP: My =?UTF-8?Q?=C5=A1=C5=A1=C5=A1=C5=A1?= app line 2\r\n' + + 'Long-Line: tere =?UTF-8?Q?=C3=B5klva?= karu\r\n' + + ' =?UTF-8?Q?m=C3=B5kva_=C5=A1apaka=C5=A1?= tutikas suur maja,\r\n' + + ' =?UTF-8?Q?k=C3=B5rge?= hoone, segane jutt' expect(headersObj).to.deep.equal(headerLinesDecode(headersStr)) }) @@ -445,7 +526,7 @@ describe('#headerLinesDecode', function () { describe('#parseHeaderValue', function () { it('should handle default value only', function () { - var str = 'text/plain', + const str = 'text/plain', obj = { value: 'text/plain', params: {} @@ -455,12 +536,12 @@ describe('#parseHeaderValue', function () { }) it('should handle unquoted params', function () { - var str = 'text/plain; CHARSET= UTF-8; format=flowed;', + const str = 'text/plain; CHARSET= UTF-8; format=flowed;', obj = { value: 'text/plain', params: { - 'charset': 'UTF-8', - 'format': 'flowed' + charset: 'UTF-8', + format: 'flowed' } } @@ -468,12 +549,12 @@ describe('#parseHeaderValue', function () { }) it('should handle quoted params', function () { - var str = 'text/plain; filename= ";;;\\""; format=flowed;', + const str = 'text/plain; filename= ";;;\\""; format=flowed;', obj = { value: 'text/plain', params: { - 'filename': ';;;"', - 'format': 'flowed' + filename: ';;;"', + format: 'flowed' } } @@ -481,19 +562,20 @@ describe('#parseHeaderValue', function () { }) it('should handle multi line values', function () { - var str = 'text/plain; single_encoded*="UTF-8\'\'%C3%95%C3%84%C3%96%C3%9C";\n' + - ' multi_encoded*0*=UTF-8\'\'%C3%96%C3%9C;\n' + - ' multi_encoded*1*=%C3%95%C3%84;\n' + - ' no_charset*0=OA;\n' + - ' no_charset*1=OU;\n' + - ' invalid*=utf-8\'\' _?\'=%ab', + const str = + 'text/plain; single_encoded*="UTF-8\'\'%C3%95%C3%84%C3%96%C3%9C";\n' + + " multi_encoded*0*=UTF-8''%C3%96%C3%9C;\n" + + ' multi_encoded*1*=%C3%95%C3%84;\n' + + ' no_charset*0=OA;\n' + + ' no_charset*1=OU;\n' + + " invalid*=utf-8'' _?'=%ab", obj = { value: 'text/plain', params: { - 'single_encoded': '=?UTF-8?Q?=C3=95=C3=84=C3=96=C3=9C?=', - 'multi_encoded': '=?UTF-8?Q?=C3=96=C3=9C=C3=95=C3=84?=', - 'no_charset': 'OAOU', - 'invalid': '=?utf-8?Q?_=5f=3f\'=3d=ab?=' + single_encoded: '=?UTF-8?Q?=C3=95=C3=84=C3=96=C3=9C?=', + multi_encoded: '=?UTF-8?Q?=C3=96=C3=9C=C3=95=C3=84?=', + no_charset: 'OAOU', + invalid: "=?utf-8?Q?_=5f=3f'=3d=ab?=" } } diff --git a/testutils.js b/testutils.js deleted file mode 100644 index b31be4f..0000000 --- a/testutils.js +++ /dev/null @@ -1,3 +0,0 @@ -import { expect } from 'chai' - -global.expect = expect diff --git a/tsconfig.json b/tsconfig.json new file mode 100644 index 0000000..505cfd1 --- /dev/null +++ b/tsconfig.json @@ -0,0 +1,103 @@ +{ + "compilerOptions": { + /* Visit https://aka.ms/tsconfig to read more about this file */ + + /* Projects */ + // "incremental": true, /* Save .tsbuildinfo files to allow for incremental compilation of projects. */ + // "composite": true, /* Enable constraints that allow a TypeScript project to be used with project references. */ + // "tsBuildInfoFile": "./.tsbuildinfo", /* Specify the path to .tsbuildinfo incremental compilation file. */ + // "disableSourceOfProjectReferenceRedirect": true, /* Disable preferring source files instead of declaration files when referencing composite projects. */ + // "disableSolutionSearching": true, /* Opt a project out of multi-project reference checking when editing. */ + // "disableReferencedProjectLoad": true, /* Reduce the number of projects loaded automatically by TypeScript. */ + + /* Language and Environment */ + "target": "es2016" /* Set the JavaScript language version for emitted JavaScript and include compatible library declarations. */, + // "lib": [], /* Specify a set of bundled library declaration files that describe the target runtime environment. */ + // "jsx": "preserve", /* Specify what JSX code is generated. */ + // "experimentalDecorators": true, /* Enable experimental support for TC39 stage 2 draft decorators. */ + // "emitDecoratorMetadata": true, /* Emit design-type metadata for decorated declarations in source files. */ + // "jsxFactory": "", /* Specify the JSX factory function used when targeting React JSX emit, e.g. 'React.createElement' or 'h'. */ + // "jsxFragmentFactory": "", /* Specify the JSX Fragment reference used for fragments when targeting React JSX emit e.g. 'React.Fragment' or 'Fragment'. */ + // "jsxImportSource": "", /* Specify module specifier used to import the JSX factory functions when using 'jsx: react-jsx*'. */ + // "reactNamespace": "", /* Specify the object invoked for 'createElement'. This only applies when targeting 'react' JSX emit. */ + // "noLib": true, /* Disable including any library files, including the default lib.d.ts. */ + // "useDefineForClassFields": true, /* Emit ECMAScript-standard-compliant class fields. */ + // "moduleDetection": "auto", /* Control what method is used to detect module-format JS files. */ + + /* Modules */ + "module": "commonjs" /* Specify what module code is generated. */, + // "rootDir": "./", /* Specify the root folder within your source files. */ + // "moduleResolution": "node", /* Specify how TypeScript looks up a file from a given module specifier. */ + // "baseUrl": "./", /* Specify the base directory to resolve non-relative module names. */ + // "paths": {}, /* Specify a set of entries that re-map imports to additional lookup locations. */ + // "rootDirs": [], /* Allow multiple folders to be treated as one when resolving modules. */ + // "typeRoots": [], /* Specify multiple folders that act like './node_modules/@types'. */ + // "types": [], /* Specify type package names to be included without being referenced in a source file. */ + // "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */ + // "moduleSuffixes": [], /* List of file name suffixes to search when resolving a module. */ + // "resolveJsonModule": true, /* Enable importing .json files. */ + // "noResolve": true, /* Disallow 'import's, 'require's or ''s from expanding the number of files TypeScript should add to a project. */ + + /* JavaScript Support */ + // "allowJs": true, /* Allow JavaScript files to be a part of your program. Use the 'checkJS' option to get errors from these files. */ + // "checkJs": true, /* Enable error reporting in type-checked JavaScript files. */ + // "maxNodeModuleJsDepth": 1, /* Specify the maximum folder depth used for checking JavaScript files from 'node_modules'. Only applicable with 'allowJs'. */ + + /* Emit */ + "declaration": true /* Generate .d.ts files from TypeScript and JavaScript files in your project. */, + // "declarationMap": true, /* Create sourcemaps for d.ts files. */ + "emitDeclarationOnly": true /* Only output d.ts files and not JavaScript files. */, + // "sourceMap": true, /* Create source map files for emitted JavaScript files. */ + // "outFile": "./", /* Specify a file that bundles all outputs into one JavaScript file. If 'declaration' is true, also designates a file that bundles all .d.ts output. */ + // "outDir": "./", /* Specify an output folder for all emitted files. */ + // "removeComments": true, /* Disable emitting comments. */ + // "noEmit": true, /* Disable emitting files from a compilation. */ + // "importHelpers": true, /* Allow importing helper functions from tslib once per project, instead of including them per-file. */ + // "importsNotUsedAsValues": "remove", /* Specify emit/checking behavior for imports that are only used for types. */ + // "downlevelIteration": true, /* Emit more compliant, but verbose and less performant JavaScript for iteration. */ + // "sourceRoot": "", /* Specify the root path for debuggers to find the reference source code. */ + // "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */ + // "inlineSourceMap": true, /* Include sourcemap files inside the emitted JavaScript. */ + // "inlineSources": true, /* Include source code in the sourcemaps inside the emitted JavaScript. */ + // "emitBOM": true, /* Emit a UTF-8 Byte Order Mark (BOM) in the beginning of output files. */ + // "newLine": "crlf", /* Set the newline character for emitting files. */ + // "stripInternal": true, /* Disable emitting declarations that have '@internal' in their JSDoc comments. */ + // "noEmitHelpers": true, /* Disable generating custom helper functions like '__extends' in compiled output. */ + // "noEmitOnError": true, /* Disable emitting files if any type checking errors are reported. */ + // "preserveConstEnums": true, /* Disable erasing 'const enum' declarations in generated code. */ + // "declarationDir": "./", /* Specify the output directory for generated declaration files. */ + // "preserveValueImports": true, /* Preserve unused imported values in the JavaScript output that would otherwise be removed. */ + + /* Interop Constraints */ + "isolatedModules": true /* Ensure that each file can be safely transpiled without relying on other imports. */, + // "allowSyntheticDefaultImports": true, /* Allow 'import x from y' when a module doesn't have a default export. */ + "esModuleInterop": true /* Emit additional JavaScript to ease support for importing CommonJS modules. This enables 'allowSyntheticDefaultImports' for type compatibility. */, + // "preserveSymlinks": true, /* Disable resolving symlinks to their realpath. This correlates to the same flag in node. */ + "forceConsistentCasingInFileNames": true /* Ensure that casing is correct in imports. */, + + /* Type Checking */ + "strict": true /* Enable all strict type-checking options. */, + // "noImplicitAny": true, /* Enable error reporting for expressions and declarations with an implied 'any' type. */ + // "strictNullChecks": true, /* When type checking, take into account 'null' and 'undefined'. */ + // "strictFunctionTypes": true, /* When assigning functions, check to ensure parameters and the return values are subtype-compatible. */ + // "strictBindCallApply": true, /* Check that the arguments for 'bind', 'call', and 'apply' methods match the original function. */ + // "strictPropertyInitialization": true, /* Check for class properties that are declared but not set in the constructor. */ + // "noImplicitThis": true, /* Enable error reporting when 'this' is given the type 'any'. */ + // "useUnknownInCatchVariables": true, /* Default catch clause variables as 'unknown' instead of 'any'. */ + // "alwaysStrict": true, /* Ensure 'use strict' is always emitted. */ + // "noUnusedLocals": true, /* Enable error reporting when local variables aren't read. */ + // "noUnusedParameters": true, /* Raise an error when a function parameter isn't read. */ + // "exactOptionalPropertyTypes": true, /* Interpret optional property types as written, rather than adding 'undefined'. */ + // "noImplicitReturns": true, /* Enable error reporting for codepaths that do not explicitly return in a function. */ + // "noFallthroughCasesInSwitch": true, /* Enable error reporting for fallthrough cases in switch statements. */ + // "noUncheckedIndexedAccess": true, /* Add 'undefined' to a type when accessed using an index. */ + // "noImplicitOverride": true, /* Ensure overriding members in derived classes are marked with an override modifier. */ + // "noPropertyAccessFromIndexSignature": true, /* Enforces using indexed accessors for keys declared using an indexed type. */ + // "allowUnusedLabels": true, /* Disable error reporting for unused labels. */ + // "allowUnreachableCode": true, /* Disable error reporting for unreachable code. */ + + /* Completeness */ + // "skipDefaultLibCheck": true, /* Skip type checking .d.ts files that are included with TypeScript. */ + "skipLibCheck": true /* Skip type checking all .d.ts files. */ + } +} diff --git a/tsconfig.types.json b/tsconfig.types.json new file mode 100644 index 0000000..33b60b9 --- /dev/null +++ b/tsconfig.types.json @@ -0,0 +1,13 @@ +{ + "extends": "./tsconfig", + "compilerOptions": { + "outDir": "dist", + "declaration": true, + "declarationMap": false, + "isolatedModules": false, + "noEmit": false, + "allowJs": false, + "emitDeclarationOnly": true + }, + "exclude": ["**/*.unit.ts"] +}