175 lines
235 KiB
JavaScript
175 lines
235 KiB
JavaScript
"use strict";
|
|
/*
|
|
* ATTENTION: An "eval-source-map" devtool has been used.
|
|
* This devtool is neither made for production nor for readable output files.
|
|
* It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
|
|
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
|
|
* or disable the default devtool with "devtool: false".
|
|
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
|
|
*/
|
|
exports.id = "vendor-chunks/mailsplit";
|
|
exports.ids = ["vendor-chunks/mailsplit"];
|
|
exports.modules = {
|
|
|
|
/***/ "(action-browser)/./node_modules/mailsplit/index.js":
|
|
/*!*****************************************!*\
|
|
!*** ./node_modules/mailsplit/index.js ***!
|
|
\*****************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst MessageSplitter = __webpack_require__(/*! ./lib/message-splitter */ \"(action-browser)/./node_modules/mailsplit/lib/message-splitter.js\");\nconst MessageJoiner = __webpack_require__(/*! ./lib/message-joiner */ \"(action-browser)/./node_modules/mailsplit/lib/message-joiner.js\");\nconst NodeRewriter = __webpack_require__(/*! ./lib/node-rewriter */ \"(action-browser)/./node_modules/mailsplit/lib/node-rewriter.js\");\nconst NodeStreamer = __webpack_require__(/*! ./lib/node-streamer */ \"(action-browser)/./node_modules/mailsplit/lib/node-streamer.js\");\nconst Headers = __webpack_require__(/*! ./lib/headers */ \"(action-browser)/./node_modules/mailsplit/lib/headers.js\");\n\nmodule.exports = {\n Splitter: MessageSplitter,\n Joiner: MessageJoiner,\n Rewriter: NodeRewriter,\n Streamer: NodeStreamer,\n Headers\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9tYWlsc3BsaXQvaW5kZXguanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWIsd0JBQXdCLG1CQUFPLENBQUMsaUdBQXdCO0FBQ3hELHNCQUFzQixtQkFBTyxDQUFDLDZGQUFzQjtBQUNwRCxxQkFBcUIsbUJBQU8sQ0FBQywyRkFBcUI7QUFDbEQscUJBQXFCLG1CQUFPLENBQUMsMkZBQXFCO0FBQ2xELGdCQUFnQixtQkFBTyxDQUFDLCtFQUFlOztBQUV2QztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvbWFpbHNwbGl0L2luZGV4LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgTWVzc2FnZVNwbGl0dGVyID0gcmVxdWlyZSgnLi9saWIvbWVzc2FnZS1zcGxpdHRlcicpO1xuY29uc3QgTWVzc2FnZUpvaW5lciA9IHJlcXVpcmUoJy4vbGliL21lc3NhZ2Utam9pbmVyJyk7XG5jb25zdCBOb2RlUmV3cml0ZXIgPSByZXF1aXJlKCcuL2xpYi9ub2RlLXJld3JpdGVyJyk7XG5jb25zdCBOb2RlU3RyZWFtZXIgPSByZXF1aXJlKCcuL2xpYi9ub2RlLXN0cmVhbWVyJyk7XG5jb25zdCBIZWFkZXJzID0gcmVxdWlyZSgnLi9saWIvaGVhZGVycycpO1xuXG5tb2R1bGUuZXhwb3J0cyA9IHtcbiAgICBTcGxpdHRlcjogTWVzc2FnZVNwbGl0dGVyLFxuICAgIEpvaW5lcjogTWVzc2FnZUpvaW5lcixcbiAgICBSZXdyaXRlcjogTm9kZVJld3JpdGVyLFxuICAgIFN0cmVhbWVyOiBOb2RlU3RyZWFtZXIsXG4gICAgSGVhZGVyc1xufTtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/mailsplit/index.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/mailsplit/lib/flowed-decoder.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/mailsplit/lib/flowed-decoder.js ***!
|
|
\******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\n// Helper class to rewrite nodes with specific mime type\n\nconst Transform = (__webpack_require__(/*! stream */ \"stream\").Transform);\nconst libmime = __webpack_require__(/*! libmime */ \"(action-browser)/./node_modules/libmime/lib/libmime.js\");\n\n/**\n * Really bad \"stream\" transform to parse format=flowed content\n *\n * @constructor\n * @param {String} delSp True if delsp option was used\n */\nclass FlowedDecoder extends Transform {\n constructor(config) {\n super();\n this.config = config || {};\n\n this.chunks = [];\n this.chunklen = 0;\n\n this.libmime = new libmime.Libmime({ Iconv: config.Iconv });\n }\n\n _transform(chunk, encoding, callback) {\n if (!chunk || !chunk.length) {\n return callback();\n }\n\n if (!encoding !== 'buffer') {\n chunk = Buffer.from(chunk, encoding);\n }\n\n this.chunks.push(chunk);\n this.chunklen += chunk.length;\n\n callback();\n }\n\n _flush(callback) {\n if (this.chunklen) {\n let currentBody = Buffer.concat(this.chunks, this.chunklen);\n\n if (this.config.encoding === 'base64') {\n currentBody = Buffer.from(currentBody.toString('binary'), 'base64');\n }\n\n let content = this.libmime.decodeFlowed(currentBody.toString('binary'), this.config.delSp);\n this.push(Buffer.from(content, 'binary'));\n }\n return callback();\n }\n}\n\nmodule.exports = FlowedDecoder;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9tYWlsc3BsaXQvbGliL2Zsb3dlZC1kZWNvZGVyLmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViOztBQUVBLGtCQUFrQix1REFBMkI7QUFDN0MsZ0JBQWdCLG1CQUFPLENBQUMsdUVBQVM7O0FBRWpDO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsV0FBVyxRQUFRO0FBQ25CO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSw2Q0FBNkMscUJBQXFCO0FBQ2xFOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL21haWxzcGxpdC9saWIvZmxvd2VkLWRlY29kZXIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG4vLyBIZWxwZXIgY2xhc3MgdG8gcmV3cml0ZSBub2RlcyB3aXRoIHNwZWNpZmljIG1pbWUgdHlwZVxuXG5jb25zdCBUcmFuc2Zvcm0gPSByZXF1aXJlKCdzdHJlYW0nKS5UcmFuc2Zvcm07XG5jb25zdCBsaWJtaW1lID0gcmVxdWlyZSgnbGlibWltZScpO1xuXG4vKipcbiAqIFJlYWxseSBiYWQgXCJzdHJlYW1cIiB0cmFuc2Zvcm0gdG8gcGFyc2UgZm9ybWF0PWZsb3dlZCBjb250ZW50XG4gKlxuICogQGNvbnN0cnVjdG9yXG4gKiBAcGFyYW0ge1N0cmluZ30gZGVsU3AgVHJ1ZSBpZiBkZWxzcCBvcHRpb24gd2FzIHVzZWRcbiAqL1xuY2xhc3MgRmxvd2VkRGVjb2RlciBleHRlbmRzIFRyYW5zZm9ybSB7XG4gICAgY29uc3RydWN0b3IoY29uZmlnKSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgICAgIHRoaXMuY29uZmlnID0gY29uZmlnIHx8IHt9O1xuXG4gICAgICAgIHRoaXMuY2h1bmtzID0gW107XG4gICAgICAgIHRoaXMuY2h1bmtsZW4gPSAwO1xuXG4gICAgICAgIHRoaXMubGlibWltZSA9IG5ldyBsaWJtaW1lLkxpYm1pbWUoeyBJY29udjogY29uZmlnLkljb252IH0pO1xuICAgIH1cblxuICAgIF90cmFuc2Zvcm0oY2h1bmssIGVuY29kaW5nLCBjYWxsYmFjaykge1xuICAgICAgICBpZiAoIWNodW5rIHx8ICFjaHVuay5sZW5ndGgpIHtcbiAgICAgICAgICAgIHJldHVybiBjYWxsYmFjaygpO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKCFlbmNvZGluZyAhPT0gJ2J1ZmZlcicpIHtcbiAgICAgICAgICAgIGNodW5rID0gQnVmZmVyLmZyb20oY2h1bmssIGVuY29kaW5nKTtcbiAgICAgICAgfVxuXG4gICAgICAgIHRoaXMuY2h1bmtzLnB1c2goY2h1bmspO1xuICAgICAgICB0aGlzLmNodW5rbGVuICs9IGNodW5rLmxlbmd0aDtcblxuICAgICAgICBjYWxsYmFjaygpO1xuICAgIH1cblxuICAgIF9mbHVzaChjYWxsYmFjaykge1xuICAgICAgICBpZiAodGhpcy5jaHVua2xlbikge1xuICAgICAgICAgICAgbGV0IGN1cnJlbnRCb2R5ID0gQnVmZmVyLmNvbmNhdCh0aGlzLmNodW5rcywgdGhpcy5jaHVua2xlbik7XG5cbiAgICAgICAgICAgIGlmICh0aGlzLmNvbmZpZy5lbmNvZGluZyA9PT0gJ2Jhc2U2NCcpIHtcbiAgICAgICAgICAgICAgICBjdXJyZW50Qm9keSA9IEJ1ZmZlci5mcm9tKGN1cnJlbnRCb2R5LnRvU3RyaW5nKCdiaW5hcnknKSwgJ2Jhc2U2NCcpO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICBsZXQgY29udGVudCA9IHRoaXMubGlibWltZS5kZWNvZGVGbG93ZWQoY3VycmVudEJvZHkudG9TdHJpbmcoJ2JpbmFyeScpLCB0aGlzLmNvbmZpZy5kZWxTcCk7XG4gICAgICAgICAgICB0aGlzLnB1c2goQnVmZmVyLmZyb20oY29udGVudCwgJ2JpbmFyeScpKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gY2FsbGJhY2soKTtcbiAgICB9XG59XG5cbm1vZHVsZS5leHBvcnRzID0gRmxvd2VkRGVjb2RlcjtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/mailsplit/lib/flowed-decoder.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/mailsplit/lib/headers.js":
|
|
/*!***********************************************!*\
|
|
!*** ./node_modules/mailsplit/lib/headers.js ***!
|
|
\***********************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst libmime = __webpack_require__(/*! libmime */ \"(action-browser)/./node_modules/libmime/lib/libmime.js\");\n\n/**\n * Class Headers to parse and handle message headers. Headers instance allows to\n * check existing, delete or add new headers\n */\nclass Headers {\n constructor(headers, config) {\n config = config || {};\n\n if (Array.isArray(headers)) {\n // already using parsed headers\n this.changed = true;\n this.headers = false;\n this.parsed = true;\n this.lines = headers;\n } else {\n // using original string/buffer headers\n this.changed = false;\n this.headers = headers;\n this.parsed = false;\n this.lines = false;\n }\n this.mbox = false;\n this.http = false;\n\n this.libmime = new libmime.Libmime({ Iconv: config.Iconv });\n }\n\n hasHeader(key) {\n if (!this.parsed) {\n this._parseHeaders();\n }\n key = this._normalizeHeader(key);\n return typeof this.lines.find(line => line.key === key) === 'object';\n }\n\n get(key) {\n if (!this.parsed) {\n this._parseHeaders();\n }\n key = this._normalizeHeader(key);\n let lines = this.lines.filter(line => line.key === key).map(line => line.line);\n\n return lines;\n }\n\n getDecoded(key) {\n return this.get(key)\n .map(line => this.libmime.decodeHeader(line))\n .filter(line => line && line.value);\n }\n\n getFirst(key) {\n if (!this.parsed) {\n this._parseHeaders();\n }\n key = this._normalizeHeader(key);\n let header = this.lines.find(line => line.key === key);\n if (!header) {\n return '';\n }\n return ((this.libmime.decodeHeader(header.line) || {}).value || '').toString().trim();\n }\n\n getList() {\n if (!this.parsed) {\n this._parseHeaders();\n }\n return this.lines;\n }\n\n add(key, value, index) {\n if (typeof value === 'undefined') {\n return;\n }\n\n if (typeof value === 'number') {\n value = value.toString();\n }\n\n if (typeof value === 'string') {\n value = Buffer.from(value);\n }\n\n value = value.toString('binary');\n this.addFormatted(key, this.libmime.foldLines(key + ': ' + value.replace(/\\r?\\n/g, ''), 76, false), index);\n }\n\n addFormatted(key, line, index) {\n if (!this.parsed) {\n this._parseHeaders();\n }\n index = index || 0;\n this.changed = true;\n\n if (!line) {\n return;\n }\n\n if (typeof line !== 'string') {\n line = line.toString('binary');\n }\n\n let header = {\n key: this._normalizeHeader(key),\n line\n };\n\n if (index < 1) {\n this.lines.unshift(header);\n } else if (index >= this.lines.length) {\n this.lines.push(header);\n } else {\n this.lines.splice(index, 0, header);\n }\n }\n\n remove(key) {\n if (!this.parsed) {\n this._parseHeaders();\n }\n key = this._normalizeHeader(key);\n for (let i = this.lines.length - 1; i >= 0; i--) {\n if (this.lines[i].key === key) {\n this.changed = true;\n this.lines.splice(i, 1);\n }\n }\n }\n\n update(key, value, relativeIndex) {\n if (!this.parsed) {\n this._parseHeaders();\n }\n let keyName = key;\n let index = 0;\n key = this._normalizeHeader(key);\n let relativeIndexCount = 0;\n let relativeMatchFound = false;\n for (let i = this.lines.length - 1; i >= 0; i--) {\n if (this.lines[i].key === key) {\n if (relativeIndex && relativeIndex !== relativeIndexCount) {\n relativeIndexCount++;\n continue;\n }\n index = i;\n this.changed = true;\n this.lines.splice(i, 1);\n if (relativeIndex) {\n relativeMatchFound = true;\n break;\n }\n }\n }\n\n if (relativeIndex && !relativeMatchFound) {\n return;\n }\n\n this.add(keyName, value, index);\n }\n\n build(lineEnd) {\n if (!this.changed && !lineEnd) {\n return typeof this.headers === 'string' ? Buffer.from(this.headers, 'binary') : this.headers;\n }\n\n if (!this.parsed) {\n this._parseHeaders();\n }\n\n lineEnd = lineEnd || '\\r\\n';\n\n let headers = this.lines.map(line => line.line.replace(/\\r?\\n/g, lineEnd)).join(lineEnd) + `${lineEnd}${lineEnd}`;\n\n if (this.mbox) {\n headers = this.mbox + lineEnd + headers;\n }\n\n if (this.http) {\n headers = this.http + lineEnd + headers;\n }\n\n return Buffer.from(headers, 'binary');\n }\n\n _normalizeHeader(key) {\n return (key || '').toLowerCase().trim();\n }\n\n _parseHeaders() {\n if (!this.headers) {\n this.lines = [];\n this.parsed = true;\n return;\n }\n\n let lines = this.headers\n .toString('binary')\n .replace(/[\\r\\n]+$/, '')\n .split(/\\r?\\n/);\n\n for (let i = lines.length - 1; i >= 0; i--) {\n let chr = lines[i].charAt(0);\n if (i && (chr === ' ' || chr === '\\t')) {\n lines[i - 1] += '\\r\\n' + lines[i];\n lines.splice(i, 1);\n } else {\n let line = lines[i];\n if (!i && /^From /i.test(line)) {\n // mbox file\n this.mbox = line;\n lines.splice(i, 1);\n continue;\n } else if (!i && /^POST /i.test(line)) {\n // HTTP POST request\n this.http = line;\n lines.splice(i, 1);\n continue;\n }\n let key = this._normalizeHeader(line.substr(0, line.indexOf(':')));\n lines[i] = {\n key,\n line\n };\n }\n }\n\n this.lines = lines;\n this.parsed = true;\n }\n}\n\n// expose to the world\nmodule.exports = Headers;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/mailsplit/lib/headers.js","mappings":"AAAa;;AAEb,gBAAgB,mBAAO,CAAC,uEAAS;;AAEjC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,6CAA6C,qBAAqB;AAClE;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6DAA6D;AAC7D;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,UAAU;AACV;AACA,UAAU;AACV;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,4CAA4C,QAAQ;AACpD;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,QAAQ;AACpD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,sGAAsG,QAAQ,EAAE,QAAQ;;AAExH;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,uCAAuC,QAAQ;AAC/C;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/mailsplit/lib/headers.js"],"sourcesContent":["'use strict';\n\nconst libmime = require('libmime');\n\n/**\n * Class Headers to parse and handle message headers. Headers instance allows to\n * check existing, delete or add new headers\n */\nclass Headers {\n    constructor(headers, config) {\n        config = config || {};\n\n        if (Array.isArray(headers)) {\n            // already using parsed headers\n            this.changed = true;\n            this.headers = false;\n            this.parsed = true;\n            this.lines = headers;\n        } else {\n            // using original string/buffer headers\n            this.changed = false;\n            this.headers = headers;\n            this.parsed = false;\n            this.lines = false;\n        }\n        this.mbox = false;\n        this.http = false;\n\n        this.libmime = new libmime.Libmime({ Iconv: config.Iconv });\n    }\n\n    hasHeader(key) {\n        if (!this.parsed) {\n            this._parseHeaders();\n        }\n        key = this._normalizeHeader(key);\n        return typeof this.lines.find(line => line.key === key) === 'object';\n    }\n\n    get(key) {\n        if (!this.parsed) {\n            this._parseHeaders();\n        }\n        key = this._normalizeHeader(key);\n        let lines = this.lines.filter(line => line.key === key).map(line => line.line);\n\n        return lines;\n    }\n\n    getDecoded(key) {\n        return this.get(key)\n            .map(line => this.libmime.decodeHeader(line))\n            .filter(line => line && line.value);\n    }\n\n    getFirst(key) {\n        if (!this.parsed) {\n            this._parseHeaders();\n        }\n        key = this._normalizeHeader(key);\n        let header = this.lines.find(line => line.key === key);\n        if (!header) {\n            return '';\n        }\n        return ((this.libmime.decodeHeader(header.line) || {}).value || '').toString().trim();\n    }\n\n    getList() {\n        if (!this.parsed) {\n            this._parseHeaders();\n        }\n        return this.lines;\n    }\n\n    add(key, value, index) {\n        if (typeof value === 'undefined') {\n            return;\n        }\n\n        if (typeof value === 'number') {\n            value = value.toString();\n        }\n\n        if (typeof value === 'string') {\n            value = Buffer.from(value);\n        }\n\n        value = value.toString('binary');\n        this.addFormatted(key, this.libmime.foldLines(key + ': ' + value.replace(/\\r?\\n/g, ''), 76, false), index);\n    }\n\n    addFormatted(key, line, index) {\n        if (!this.parsed) {\n            this._parseHeaders();\n        }\n        index = index || 0;\n        this.changed = true;\n\n        if (!line) {\n            return;\n        }\n\n        if (typeof line !== 'string') {\n            line = line.toString('binary');\n        }\n\n        let header = {\n            key: this._normalizeHeader(key),\n            line\n        };\n\n        if (index < 1) {\n            this.lines.unshift(header);\n        } else if (index >= this.lines.length) {\n            this.lines.push(header);\n        } else {\n            this.lines.splice(index, 0, header);\n        }\n    }\n\n    remove(key) {\n        if (!this.parsed) {\n            this._parseHeaders();\n        }\n        key = this._normalizeHeader(key);\n        for (let i = this.lines.length - 1; i >= 0; i--) {\n            if (this.lines[i].key === key) {\n                this.changed = true;\n                this.lines.splice(i, 1);\n            }\n        }\n    }\n\n    update(key, value, relativeIndex) {\n        if (!this.parsed) {\n            this._parseHeaders();\n        }\n        let keyName = key;\n        let index = 0;\n        key = this._normalizeHeader(key);\n        let relativeIndexCount = 0;\n        let relativeMatchFound = false;\n        for (let i = this.lines.length - 1; i >= 0; i--) {\n            if (this.lines[i].key === key) {\n                if (relativeIndex && relativeIndex !== relativeIndexCount) {\n                    relativeIndexCount++;\n                    continue;\n                }\n                index = i;\n                this.changed = true;\n                this.lines.splice(i, 1);\n                if (relativeIndex) {\n                    relativeMatchFound = true;\n                    break;\n                }\n            }\n        }\n\n        if (relativeIndex && !relativeMatchFound) {\n            return;\n        }\n\n        this.add(keyName, value, index);\n    }\n\n    build(lineEnd) {\n        if (!this.changed && !lineEnd) {\n            return typeof this.headers === 'string' ? Buffer.from(this.headers, 'binary') : this.headers;\n        }\n\n        if (!this.parsed) {\n            this._parseHeaders();\n        }\n\n        lineEnd = lineEnd || '\\r\\n';\n\n        let headers = this.lines.map(line => line.line.replace(/\\r?\\n/g, lineEnd)).join(lineEnd) + `${lineEnd}${lineEnd}`;\n\n        if (this.mbox) {\n            headers = this.mbox + lineEnd + headers;\n        }\n\n        if (this.http) {\n            headers = this.http + lineEnd + headers;\n        }\n\n        return Buffer.from(headers, 'binary');\n    }\n\n    _normalizeHeader(key) {\n        return (key || '').toLowerCase().trim();\n    }\n\n    _parseHeaders() {\n        if (!this.headers) {\n            this.lines = [];\n            this.parsed = true;\n            return;\n        }\n\n        let lines = this.headers\n            .toString('binary')\n            .replace(/[\\r\\n]+$/, '')\n            .split(/\\r?\\n/);\n\n        for (let i = lines.length - 1; i >= 0; i--) {\n            let chr = lines[i].charAt(0);\n            if (i && (chr === ' ' || chr === '\\t')) {\n                lines[i - 1] += '\\r\\n' + lines[i];\n                lines.splice(i, 1);\n            } else {\n                let line = lines[i];\n                if (!i && /^From /i.test(line)) {\n                    // mbox file\n                    this.mbox = line;\n                    lines.splice(i, 1);\n                    continue;\n                } else if (!i && /^POST /i.test(line)) {\n                    // HTTP POST request\n                    this.http = line;\n                    lines.splice(i, 1);\n                    continue;\n                }\n                let key = this._normalizeHeader(line.substr(0, line.indexOf(':')));\n                lines[i] = {\n                    key,\n                    line\n                };\n            }\n        }\n\n        this.lines = lines;\n        this.parsed = true;\n    }\n}\n\n// expose to the world\nmodule.exports = Headers;\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/mailsplit/lib/headers.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/mailsplit/lib/message-joiner.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/mailsplit/lib/message-joiner.js ***!
|
|
\******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst Transform = (__webpack_require__(/*! stream */ \"stream\").Transform);\n\nclass MessageJoiner extends Transform {\n constructor() {\n let options = {\n readableObjectMode: false,\n writableObjectMode: true\n };\n super(options);\n }\n\n _transform(obj, encoding, callback) {\n if (Buffer.isBuffer(obj)) {\n this.push(obj);\n } else if (obj.type === 'node') {\n this.push(obj.getHeaders());\n } else if (obj.value) {\n this.push(obj.value);\n }\n return callback();\n }\n\n _flush(callback) {\n return callback();\n }\n}\n\nmodule.exports = MessageJoiner;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9tYWlsc3BsaXQvbGliL21lc3NhZ2Utam9pbmVyLmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViLGtCQUFrQix1REFBMkI7O0FBRTdDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsVUFBVTtBQUNWO0FBQ0EsVUFBVTtBQUNWO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9tYWlsc3BsaXQvbGliL21lc3NhZ2Utam9pbmVyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgVHJhbnNmb3JtID0gcmVxdWlyZSgnc3RyZWFtJykuVHJhbnNmb3JtO1xuXG5jbGFzcyBNZXNzYWdlSm9pbmVyIGV4dGVuZHMgVHJhbnNmb3JtIHtcbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgbGV0IG9wdGlvbnMgPSB7XG4gICAgICAgICAgICByZWFkYWJsZU9iamVjdE1vZGU6IGZhbHNlLFxuICAgICAgICAgICAgd3JpdGFibGVPYmplY3RNb2RlOiB0cnVlXG4gICAgICAgIH07XG4gICAgICAgIHN1cGVyKG9wdGlvbnMpO1xuICAgIH1cblxuICAgIF90cmFuc2Zvcm0ob2JqLCBlbmNvZGluZywgY2FsbGJhY2spIHtcbiAgICAgICAgaWYgKEJ1ZmZlci5pc0J1ZmZlcihvYmopKSB7XG4gICAgICAgICAgICB0aGlzLnB1c2gob2JqKTtcbiAgICAgICAgfSBlbHNlIGlmIChvYmoudHlwZSA9PT0gJ25vZGUnKSB7XG4gICAgICAgICAgICB0aGlzLnB1c2gob2JqLmdldEhlYWRlcnMoKSk7XG4gICAgICAgIH0gZWxzZSBpZiAob2JqLnZhbHVlKSB7XG4gICAgICAgICAgICB0aGlzLnB1c2gob2JqLnZhbHVlKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gY2FsbGJhY2soKTtcbiAgICB9XG5cbiAgICBfZmx1c2goY2FsbGJhY2spIHtcbiAgICAgICAgcmV0dXJuIGNhbGxiYWNrKCk7XG4gICAgfVxufVxuXG5tb2R1bGUuZXhwb3J0cyA9IE1lc3NhZ2VKb2luZXI7XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/mailsplit/lib/message-joiner.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/mailsplit/lib/message-splitter.js":
|
|
/*!********************************************************!*\
|
|
!*** ./node_modules/mailsplit/lib/message-splitter.js ***!
|
|
\********************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst Transform = (__webpack_require__(/*! stream */ \"stream\").Transform);\nconst MimeNode = __webpack_require__(/*! ./mime-node */ \"(action-browser)/./node_modules/mailsplit/lib/mime-node.js\");\n\nconst MAX_HEAD_SIZE = 1 * 1024 * 1024;\nconst MAX_CHILD_NODES = 1000;\n\nconst HEAD = 0x01;\nconst BODY = 0x02;\n\nclass MessageSplitter extends Transform {\n constructor(config) {\n let options = {\n readableObjectMode: true,\n writableObjectMode: false\n };\n super(options);\n\n this.config = config || {};\n this.maxHeadSize = this.config.maxHeadSize || MAX_HEAD_SIZE;\n this.maxChildNodes = this.config.maxChildNodes || MAX_CHILD_NODES;\n this.tree = [];\n this.nodeCounter = 0;\n this.newNode();\n this.tree.push(this.node);\n this.line = false;\n this.hasFailed = false;\n }\n\n _transform(chunk, encoding, callback) {\n // process line by line\n // find next line ending\n let pos = 0;\n let i = 0;\n let group = {\n type: 'none'\n };\n let groupstart = this.line ? -this.line.length : 0;\n let groupend = 0;\n\n let checkTrailingLinebreak = data => {\n if (data.type === 'body' && data.node.parentNode && data.value && data.value.length) {\n if (data.value[data.value.length - 1] === 0x0a) {\n groupstart--;\n groupend--;\n pos--;\n if (data.value.length > 1 && data.value[data.value.length - 2] === 0x0d) {\n groupstart--;\n groupend--;\n pos--;\n if (groupstart < 0 && !this.line) {\n // store only <CR> as <LF> should be on the positive side\n this.line = Buffer.allocUnsafe(1);\n this.line[0] = 0x0d;\n }\n data.value = data.value.slice(0, data.value.length - 2);\n } else {\n data.value = data.value.slice(0, data.value.length - 1);\n }\n } else if (data.value[data.value.length - 1] === 0x0d) {\n groupstart--;\n groupend--;\n pos--;\n data.value = data.value.slice(0, data.value.length - 1);\n }\n }\n };\n\n let iterateData = () => {\n for (let len = chunk.length; i < len; i++) {\n // find next <LF>\n if (chunk[i] === 0x0a) {\n // line end\n\n let start = Math.max(pos, 0);\n pos = ++i;\n\n return this.processLine(chunk.slice(start, i), false, (err, data, flush) => {\n if (err) {\n this.hasFailed = true;\n return setImmediate(() => callback(err));\n }\n\n if (!data) {\n return setImmediate(iterateData);\n }\n\n if (flush) {\n if (group && group.type !== 'none') {\n if (group.type === 'body' && groupend >= groupstart && group.node.parentNode) {\n // do not include the last line ending for body\n if (chunk[groupend - 1] === 0x0a) {\n groupend--;\n if (groupend >= groupstart && chunk[groupend - 1] === 0x0d) {\n groupend--;\n }\n }\n }\n if (groupstart !== groupend) {\n group.value = chunk.slice(groupstart, groupend);\n if (groupend < i) {\n data.value = chunk.slice(groupend, i);\n }\n }\n this.push(group);\n group = {\n type: 'none'\n };\n groupstart = groupend = i;\n }\n this.push(data);\n groupend = i;\n return setImmediate(iterateData);\n }\n\n if (data.type === group.type) {\n // shift slice end position forward\n groupend = i;\n } else {\n if (group.type === 'body' && groupend >= groupstart && group.node.parentNode) {\n // do not include the last line ending for body\n if (chunk[groupend - 1] === 0x0a) {\n groupend--;\n if (groupend >= groupstart && chunk[groupend - 1] === 0x0d) {\n groupend--;\n }\n }\n }\n\n if (group.type !== 'none' && group.type !== 'node') {\n // we have a previous data/body chunk to output\n if (groupstart !== groupend) {\n group.value = chunk.slice(groupstart, groupend);\n if (group.value && group.value.length) {\n this.push(group);\n group = {\n type: 'none'\n };\n }\n }\n }\n\n if (data.type === 'node') {\n this.push(data);\n groupstart = i;\n groupend = i;\n } else if (groupstart < 0) {\n groupstart = i;\n groupend = i;\n checkTrailingLinebreak(data);\n if (data.value && data.value.length) {\n this.push(data);\n }\n } else {\n // start new body/data chunk\n group = data;\n groupstart = groupend;\n groupend = i;\n }\n }\n return setImmediate(iterateData);\n });\n }\n }\n\n // skip last linebreak for body\n if (pos >= groupstart + 1 && group.type === 'body' && group.node.parentNode) {\n // do not include the last line ending for body\n if (chunk[pos - 1] === 0x0a) {\n pos--;\n if (pos >= groupstart && chunk[pos - 1] === 0x0d) {\n pos--;\n }\n }\n }\n\n if (group.type !== 'none' && group.type !== 'node' && pos > groupstart) {\n // we have a leftover data/body chunk to push out\n group.value = chunk.slice(groupstart, pos);\n\n if (group.value && group.value.length) {\n this.push(group);\n group = {\n type: 'none'\n };\n }\n }\n\n if (pos < chunk.length) {\n if (this.line) {\n this.line = Buffer.concat([this.line, chunk.slice(pos)]);\n } else {\n this.line = chunk.slice(pos);\n }\n }\n callback();\n };\n\n setImmediate(iterateData);\n }\n\n _flush(callback) {\n if (this.hasFailed) {\n return callback();\n }\n this.processLine(false, true, (err, data) => {\n if (err) {\n return setImmediate(() => callback(err));\n }\n if (data && (data.type === 'node' || (data.value && data.value.length))) {\n this.push(data);\n }\n callback();\n });\n }\n\n compareBoundary(line, startpos, boundary) {\n // --{boundary}\\r\\n or --{boundary}--\\r\\n\n if (line.length < boundary.length + 3 + startpos || line.length > boundary.length + 6 + startpos) {\n return false;\n }\n for (let i = 0; i < boundary.length; i++) {\n if (line[i + 2 + startpos] !== boundary[i]) {\n return false;\n }\n }\n\n let pos = 0;\n for (let i = boundary.length + 2 + startpos; i < line.length; i++) {\n let c = line[i];\n if (pos === 0 && (c === 0x0d || c === 0x0a)) {\n // 1: next node\n return 1;\n }\n if (pos === 0 && c !== 0x2d) {\n // expecting \"-\"\n return false;\n }\n if (pos === 1 && c !== 0x2d) {\n // expecting \"-\"\n return false;\n }\n if (pos === 2 && c !== 0x0d && c !== 0x0a) {\n // expecting line terminator, either <CR> or <LF>\n return false;\n }\n if (pos === 3 && c !== 0x0a) {\n // expecting line terminator <LF>\n return false;\n }\n pos++;\n }\n\n // 2: multipart end\n return 2;\n }\n\n checkBoundary(line) {\n let startpos = 0;\n if (line.length >= 1 && (line[0] === 0x0d || line[0] === 0x0a)) {\n startpos++;\n if (line.length >= 2 && (line[0] === 0x0d || line[1] === 0x0a)) {\n startpos++;\n }\n }\n if (line.length < 4 || line[startpos] !== 0x2d || line[startpos + 1] !== 0x2d) {\n // defnitely not a boundary\n return false;\n }\n\n let boundary;\n if (this.node._boundary && (boundary = this.compareBoundary(line, startpos, this.node._boundary))) {\n // 1: next child\n // 2: multipart end\n return boundary;\n }\n\n if (this.node._parentBoundary && (boundary = this.compareBoundary(line, startpos, this.node._parentBoundary))) {\n // 3: next sibling\n // 4: parent end\n return boundary + 2;\n }\n\n return false;\n }\n\n processLine(line, final, next) {\n let flush = false;\n\n if (this.line && line) {\n line = Buffer.concat([this.line, line]);\n this.line = false;\n } else if (this.line && !line) {\n line = this.line;\n this.line = false;\n }\n\n if (!line) {\n line = Buffer.alloc(0);\n }\n\n if (this.nodeCounter > this.maxChildNodes) {\n let err = new Error('Max allowed child nodes exceeded');\n err.code = 'EMAXLEN';\n return next(err);\n }\n\n // we check boundary outside the HEAD/BODY scope as it may appear anywhere\n let boundary = this.checkBoundary(line);\n if (boundary) {\n // reached boundary, switch context\n switch (boundary) {\n case 1:\n // next child\n this.newNode(this.node);\n flush = true;\n break;\n case 2:\n // reached end of children, keep current node\n break;\n case 3: {\n // next sibling\n let parentNode = this.node.parentNode;\n if (parentNode && parentNode.contentType === 'message/rfc822') {\n // special case where immediate parent is an inline message block\n // move up another step\n parentNode = parentNode.parentNode;\n }\n this.newNode(parentNode);\n flush = true;\n break;\n }\n case 4:\n // special case when boundary close a node with only header.\n if (this.node && this.node._headerlen && !this.node.headers) {\n this.node.parseHeaders();\n this.push(this.node);\n }\n // move up\n if (this.tree.length) {\n this.node = this.tree.pop();\n }\n this.state = BODY;\n break;\n }\n\n return next(\n null,\n {\n node: this.node,\n type: 'data',\n value: line\n },\n flush\n );\n }\n\n switch (this.state) {\n case HEAD: {\n this.node.addHeaderChunk(line);\n if (this.node._headerlen > this.maxHeadSize) {\n let err = new Error('Max header size for a MIME node exceeded');\n err.code = 'EMAXLEN';\n return next(err);\n }\n if (final || (line.length === 1 && line[0] === 0x0a) || (line.length === 2 && line[0] === 0x0d && line[1] === 0x0a)) {\n let currentNode = this.node;\n\n currentNode.parseHeaders();\n\n // if the content is attached message then just continue\n if (\n currentNode.contentType === 'message/rfc822' &&\n !this.config.ignoreEmbedded &&\n (!currentNode.encoding || ['7bit', '8bit', 'binary'].includes(currentNode.encoding)) &&\n (this.config.defaultInlineEmbedded ? currentNode.disposition !== 'attachment' : currentNode.disposition === 'inline')\n ) {\n currentNode.messageNode = true;\n this.newNode(currentNode);\n if (currentNode.parentNode) {\n this.node._parentBoundary = currentNode.parentNode._boundary;\n }\n } else {\n if (currentNode.contentType === 'message/rfc822') {\n currentNode.messageNode = false;\n }\n this.state = BODY;\n if (currentNode.multipart && currentNode._boundary) {\n this.tree.push(currentNode);\n }\n }\n\n return next(null, currentNode, flush);\n }\n\n return next();\n }\n case BODY: {\n return next(\n null,\n {\n node: this.node,\n type: this.node.multipart ? 'data' : 'body',\n value: line\n },\n flush\n );\n }\n }\n\n next(null, false);\n }\n\n newNode(parent) {\n this.node = new MimeNode(parent || false, this.config);\n this.state = HEAD;\n this.nodeCounter++;\n }\n}\n\nmodule.exports = MessageSplitter;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/mailsplit/lib/message-splitter.js","mappings":"AAAa;;AAEb,kBAAkB,uDAA2B;AAC7C,iBAAiB,mBAAO,CAAC,+EAAa;;AAEtC;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,yCAAyC,SAAS;AAClD;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,0BAA0B;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,8BAA8B;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA,cAAc,SAAS,WAAW,SAAS;AAC3C;AACA;AACA;AACA,wBAAwB,qBAAqB;AAC7C;AACA;AACA;AACA;;AAEA;AACA,qDAAqD,iBAAiB;AACtE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA","sources":["/home/alma/nextgen/Neah-mail/node_modules/mailsplit/lib/message-splitter.js"],"sourcesContent":["'use strict';\n\nconst Transform = require('stream').Transform;\nconst MimeNode = require('./mime-node');\n\nconst MAX_HEAD_SIZE = 1 * 1024 * 1024;\nconst MAX_CHILD_NODES = 1000;\n\nconst HEAD = 0x01;\nconst BODY = 0x02;\n\nclass MessageSplitter extends Transform {\n    constructor(config) {\n        let options = {\n            readableObjectMode: true,\n            writableObjectMode: false\n        };\n        super(options);\n\n        this.config = config || {};\n        this.maxHeadSize = this.config.maxHeadSize || MAX_HEAD_SIZE;\n        this.maxChildNodes = this.config.maxChildNodes || MAX_CHILD_NODES;\n        this.tree = [];\n        this.nodeCounter = 0;\n        this.newNode();\n        this.tree.push(this.node);\n        this.line = false;\n        this.hasFailed = false;\n    }\n\n    _transform(chunk, encoding, callback) {\n        // process line by line\n        // find next line ending\n        let pos = 0;\n        let i = 0;\n        let group = {\n            type: 'none'\n        };\n        let groupstart = this.line ? -this.line.length : 0;\n        let groupend = 0;\n\n        let checkTrailingLinebreak = data => {\n            if (data.type === 'body' && data.node.parentNode && data.value && data.value.length) {\n                if (data.value[data.value.length - 1] === 0x0a) {\n                    groupstart--;\n                    groupend--;\n                    pos--;\n                    if (data.value.length > 1 && data.value[data.value.length - 2] === 0x0d) {\n                        groupstart--;\n                        groupend--;\n                        pos--;\n                        if (groupstart < 0 && !this.line) {\n                            // store only <CR> as <LF> should be on the positive side\n                            this.line = Buffer.allocUnsafe(1);\n                            this.line[0] = 0x0d;\n                        }\n                        data.value = data.value.slice(0, data.value.length - 2);\n                    } else {\n                        data.value = data.value.slice(0, data.value.length - 1);\n                    }\n                } else if (data.value[data.value.length - 1] === 0x0d) {\n                    groupstart--;\n                    groupend--;\n                    pos--;\n                    data.value = data.value.slice(0, data.value.length - 1);\n                }\n            }\n        };\n\n        let iterateData = () => {\n            for (let len = chunk.length; i < len; i++) {\n                // find next <LF>\n                if (chunk[i] === 0x0a) {\n                    // line end\n\n                    let start = Math.max(pos, 0);\n                    pos = ++i;\n\n                    return this.processLine(chunk.slice(start, i), false, (err, data, flush) => {\n                        if (err) {\n                            this.hasFailed = true;\n                            return setImmediate(() => callback(err));\n                        }\n\n                        if (!data) {\n                            return setImmediate(iterateData);\n                        }\n\n                        if (flush) {\n                            if (group && group.type !== 'none') {\n                                if (group.type === 'body' && groupend >= groupstart && group.node.parentNode) {\n                                    // do not include the last line ending for body\n                                    if (chunk[groupend - 1] === 0x0a) {\n                                        groupend--;\n                                        if (groupend >= groupstart && chunk[groupend - 1] === 0x0d) {\n                                            groupend--;\n                                        }\n                                    }\n                                }\n                                if (groupstart !== groupend) {\n                                    group.value = chunk.slice(groupstart, groupend);\n                                    if (groupend < i) {\n                                        data.value = chunk.slice(groupend, i);\n                                    }\n                                }\n                                this.push(group);\n                                group = {\n                                    type: 'none'\n                                };\n                                groupstart = groupend = i;\n                            }\n                            this.push(data);\n                            groupend = i;\n                            return setImmediate(iterateData);\n                        }\n\n                        if (data.type === group.type) {\n                            // shift slice end position forward\n                            groupend = i;\n                        } else {\n                            if (group.type === 'body' && groupend >= groupstart && group.node.parentNode) {\n                                // do not include the last line ending for body\n                                if (chunk[groupend - 1] === 0x0a) {\n                                    groupend--;\n                                    if (groupend >= groupstart && chunk[groupend - 1] === 0x0d) {\n                                        groupend--;\n                                    }\n                                }\n                            }\n\n                            if (group.type !== 'none' && group.type !== 'node') {\n                                // we have a previous data/body chunk to output\n                                if (groupstart !== groupend) {\n                                    group.value = chunk.slice(groupstart, groupend);\n                                    if (group.value && group.value.length) {\n                                        this.push(group);\n                                        group = {\n                                            type: 'none'\n                                        };\n                                    }\n                                }\n                            }\n\n                            if (data.type === 'node') {\n                                this.push(data);\n                                groupstart = i;\n                                groupend = i;\n                            } else if (groupstart < 0) {\n                                groupstart = i;\n                                groupend = i;\n                                checkTrailingLinebreak(data);\n                                if (data.value && data.value.length) {\n                                    this.push(data);\n                                }\n                            } else {\n                                // start new body/data chunk\n                                group = data;\n                                groupstart = groupend;\n                                groupend = i;\n                            }\n                        }\n                        return setImmediate(iterateData);\n                    });\n                }\n            }\n\n            // skip last linebreak for body\n            if (pos >= groupstart + 1 && group.type === 'body' && group.node.parentNode) {\n                // do not include the last line ending for body\n                if (chunk[pos - 1] === 0x0a) {\n                    pos--;\n                    if (pos >= groupstart && chunk[pos - 1] === 0x0d) {\n                        pos--;\n                    }\n                }\n            }\n\n            if (group.type !== 'none' && group.type !== 'node' && pos > groupstart) {\n                // we have a leftover data/body chunk to push out\n                group.value = chunk.slice(groupstart, pos);\n\n                if (group.value && group.value.length) {\n                    this.push(group);\n                    group = {\n                        type: 'none'\n                    };\n                }\n            }\n\n            if (pos < chunk.length) {\n                if (this.line) {\n                    this.line = Buffer.concat([this.line, chunk.slice(pos)]);\n                } else {\n                    this.line = chunk.slice(pos);\n                }\n            }\n            callback();\n        };\n\n        setImmediate(iterateData);\n    }\n\n    _flush(callback) {\n        if (this.hasFailed) {\n            return callback();\n        }\n        this.processLine(false, true, (err, data) => {\n            if (err) {\n                return setImmediate(() => callback(err));\n            }\n            if (data && (data.type === 'node' || (data.value && data.value.length))) {\n                this.push(data);\n            }\n            callback();\n        });\n    }\n\n    compareBoundary(line, startpos, boundary) {\n        // --{boundary}\\r\\n or --{boundary}--\\r\\n\n        if (line.length < boundary.length + 3 + startpos || line.length > boundary.length + 6 + startpos) {\n            return false;\n        }\n        for (let i = 0; i < boundary.length; i++) {\n            if (line[i + 2 + startpos] !== boundary[i]) {\n                return false;\n            }\n        }\n\n        let pos = 0;\n        for (let i = boundary.length + 2 + startpos; i < line.length; i++) {\n            let c = line[i];\n            if (pos === 0 && (c === 0x0d || c === 0x0a)) {\n                // 1: next node\n                return 1;\n            }\n            if (pos === 0 && c !== 0x2d) {\n                // expecting \"-\"\n                return false;\n            }\n            if (pos === 1 && c !== 0x2d) {\n                // expecting \"-\"\n                return false;\n            }\n            if (pos === 2 && c !== 0x0d && c !== 0x0a) {\n                // expecting line terminator, either <CR> or <LF>\n                return false;\n            }\n            if (pos === 3 && c !== 0x0a) {\n                // expecting line terminator <LF>\n                return false;\n            }\n            pos++;\n        }\n\n        // 2: multipart end\n        return 2;\n    }\n\n    checkBoundary(line) {\n        let startpos = 0;\n        if (line.length >= 1 && (line[0] === 0x0d || line[0] === 0x0a)) {\n            startpos++;\n            if (line.length >= 2 && (line[0] === 0x0d || line[1] === 0x0a)) {\n                startpos++;\n            }\n        }\n        if (line.length < 4 || line[startpos] !== 0x2d || line[startpos + 1] !== 0x2d) {\n            // defnitely not a boundary\n            return false;\n        }\n\n        let boundary;\n        if (this.node._boundary && (boundary = this.compareBoundary(line, startpos, this.node._boundary))) {\n            // 1: next child\n            // 2: multipart end\n            return boundary;\n        }\n\n        if (this.node._parentBoundary && (boundary = this.compareBoundary(line, startpos, this.node._parentBoundary))) {\n            // 3: next sibling\n            // 4: parent end\n            return boundary + 2;\n        }\n\n        return false;\n    }\n\n    processLine(line, final, next) {\n        let flush = false;\n\n        if (this.line && line) {\n            line = Buffer.concat([this.line, line]);\n            this.line = false;\n        } else if (this.line && !line) {\n            line = this.line;\n            this.line = false;\n        }\n\n        if (!line) {\n            line = Buffer.alloc(0);\n        }\n\n        if (this.nodeCounter > this.maxChildNodes) {\n            let err = new Error('Max allowed child nodes exceeded');\n            err.code = 'EMAXLEN';\n            return next(err);\n        }\n\n        // we check boundary outside the HEAD/BODY scope as it may appear anywhere\n        let boundary = this.checkBoundary(line);\n        if (boundary) {\n            // reached boundary, switch context\n            switch (boundary) {\n                case 1:\n                    // next child\n                    this.newNode(this.node);\n                    flush = true;\n                    break;\n                case 2:\n                    // reached end of children, keep current node\n                    break;\n                case 3: {\n                    // next sibling\n                    let parentNode = this.node.parentNode;\n                    if (parentNode && parentNode.contentType === 'message/rfc822') {\n                        // special case where immediate parent is an inline message block\n                        // move up another step\n                        parentNode = parentNode.parentNode;\n                    }\n                    this.newNode(parentNode);\n                    flush = true;\n                    break;\n                }\n                case 4:\n                    // special case when boundary close a node with only header.\n                    if (this.node && this.node._headerlen && !this.node.headers) {\n                        this.node.parseHeaders();\n                        this.push(this.node);\n                    }\n                    // move up\n                    if (this.tree.length) {\n                        this.node = this.tree.pop();\n                    }\n                    this.state = BODY;\n                    break;\n            }\n\n            return next(\n                null,\n                {\n                    node: this.node,\n                    type: 'data',\n                    value: line\n                },\n                flush\n            );\n        }\n\n        switch (this.state) {\n            case HEAD: {\n                this.node.addHeaderChunk(line);\n                if (this.node._headerlen > this.maxHeadSize) {\n                    let err = new Error('Max header size for a MIME node exceeded');\n                    err.code = 'EMAXLEN';\n                    return next(err);\n                }\n                if (final || (line.length === 1 && line[0] === 0x0a) || (line.length === 2 && line[0] === 0x0d && line[1] === 0x0a)) {\n                    let currentNode = this.node;\n\n                    currentNode.parseHeaders();\n\n                    // if the content is attached message then just continue\n                    if (\n                        currentNode.contentType === 'message/rfc822' &&\n                        !this.config.ignoreEmbedded &&\n                        (!currentNode.encoding || ['7bit', '8bit', 'binary'].includes(currentNode.encoding)) &&\n                        (this.config.defaultInlineEmbedded ? currentNode.disposition !== 'attachment' : currentNode.disposition === 'inline')\n                    ) {\n                        currentNode.messageNode = true;\n                        this.newNode(currentNode);\n                        if (currentNode.parentNode) {\n                            this.node._parentBoundary = currentNode.parentNode._boundary;\n                        }\n                    } else {\n                        if (currentNode.contentType === 'message/rfc822') {\n                            currentNode.messageNode = false;\n                        }\n                        this.state = BODY;\n                        if (currentNode.multipart && currentNode._boundary) {\n                            this.tree.push(currentNode);\n                        }\n                    }\n\n                    return next(null, currentNode, flush);\n                }\n\n                return next();\n            }\n            case BODY: {\n                return next(\n                    null,\n                    {\n                        node: this.node,\n                        type: this.node.multipart ? 'data' : 'body',\n                        value: line\n                    },\n                    flush\n                );\n            }\n        }\n\n        next(null, false);\n    }\n\n    newNode(parent) {\n        this.node = new MimeNode(parent || false, this.config);\n        this.state = HEAD;\n        this.nodeCounter++;\n    }\n}\n\nmodule.exports = MessageSplitter;\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/mailsplit/lib/message-splitter.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/mailsplit/lib/mime-node.js":
|
|
/*!*************************************************!*\
|
|
!*** ./node_modules/mailsplit/lib/mime-node.js ***!
|
|
\*************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst Headers = __webpack_require__(/*! ./headers */ \"(action-browser)/./node_modules/mailsplit/lib/headers.js\");\nconst libmime = __webpack_require__(/*! libmime */ \"(action-browser)/./node_modules/libmime/lib/libmime.js\");\nconst libqp = __webpack_require__(/*! libqp */ \"(action-browser)/./node_modules/libqp/lib/libqp.js\");\nconst libbase64 = __webpack_require__(/*! libbase64 */ \"(action-browser)/./node_modules/libbase64/lib/libbase64.js\");\nconst PassThrough = (__webpack_require__(/*! stream */ \"stream\").PassThrough);\nconst pathlib = __webpack_require__(/*! path */ \"path\");\n\nclass MimeNode {\n constructor(parentNode, config) {\n this.type = 'node';\n this.root = !parentNode;\n this.parentNode = parentNode;\n\n this._parentBoundary = this.parentNode && this.parentNode._boundary;\n this._headersLines = [];\n this._headerlen = 0;\n\n this._parsedContentType = false;\n this._boundary = false;\n\n this.multipart = false;\n this.encoding = false;\n this.headers = false;\n this.contentType = false;\n this.flowed = false;\n this.delSp = false;\n\n this.config = config || {};\n this.libmime = new libmime.Libmime({ Iconv: this.config.Iconv });\n\n this.parentPartNumber = (parentNode && this.partNr) || [];\n this.partNr = false; // resolved later\n this.childPartNumbers = 0;\n }\n\n getPartNr(provided) {\n if (provided) {\n return []\n .concat(this.partNr || [])\n .filter(nr => !isNaN(nr))\n .concat(provided);\n }\n let childPartNr = ++this.childPartNumbers;\n return []\n .concat(this.partNr || [])\n .filter(nr => !isNaN(nr))\n .concat(childPartNr);\n }\n\n addHeaderChunk(line) {\n if (!line) {\n return;\n }\n this._headersLines.push(line);\n this._headerlen += line.length;\n }\n\n parseHeaders() {\n if (this.headers) {\n return;\n }\n this.headers = new Headers(Buffer.concat(this._headersLines, this._headerlen), this.config);\n\n this._parsedContentDisposition = this.libmime.parseHeaderValue(this.headers.getFirst('Content-Disposition'));\n\n // if content-type is missing default to plaintext\n let contentHeader;\n if (this.headers.get('Content-Type').length) {\n contentHeader = this.headers.getFirst('Content-Type');\n } else {\n if (this._parsedContentDisposition.params.filename) {\n let extension = pathlib.parse(this._parsedContentDisposition.params.filename).ext.replace(/^\\./, '');\n if (extension) {\n contentHeader = libmime.detectMimeType(extension);\n }\n }\n if (!contentHeader) {\n if (/^attachment$/i.test(this._parsedContentDisposition.value)) {\n contentHeader = 'application/octet-stream';\n } else {\n contentHeader = 'text/plain';\n }\n }\n }\n\n this._parsedContentType = this.libmime.parseHeaderValue(contentHeader);\n\n this.encoding = this.headers\n .getFirst('Content-Transfer-Encoding')\n .replace(/\\(.*\\)/g, '')\n .toLowerCase()\n .trim();\n this.contentType = (this._parsedContentType.value || '').toLowerCase().trim() || false;\n this.charset = this._parsedContentType.params.charset || false;\n this.disposition = (this._parsedContentDisposition.value || '').toLowerCase().trim() || false;\n\n // fix invalidly encoded disposition values\n if (this.disposition) {\n try {\n this.disposition = this.libmime.decodeWords(this.disposition);\n } catch (E) {\n // failed to parse disposition, keep as is (most probably an unknown charset is used)\n }\n }\n\n this.filename = this._parsedContentDisposition.params.filename || this._parsedContentType.params.name || false;\n\n if (this._parsedContentType.params.format && this._parsedContentType.params.format.toLowerCase().trim() === 'flowed') {\n this.flowed = true;\n if (this._parsedContentType.params.delsp && this._parsedContentType.params.delsp.toLowerCase().trim() === 'yes') {\n this.delSp = true;\n }\n }\n\n if (this.filename) {\n try {\n this.filename = this.libmime.decodeWords(this.filename);\n } catch (E) {\n // failed to parse filename, keep as is (most probably an unknown charset is used)\n }\n }\n\n this.multipart =\n (this.contentType &&\n this.contentType.substr(0, this.contentType.indexOf('/')) === 'multipart' &&\n this.contentType.substr(this.contentType.indexOf('/') + 1)) ||\n false;\n this._boundary = (this._parsedContentType.params.boundary && Buffer.from(this._parsedContentType.params.boundary)) || false;\n\n this.rfc822 = this.contentType === 'message/rfc822';\n\n if (!this.parentNode || this.parentNode.rfc822) {\n this.partNr = this.parentNode ? this.parentNode.getPartNr('TEXT') : ['TEXT'];\n } else {\n this.partNr = this.parentNode ? this.parentNode.getPartNr() : [];\n }\n }\n\n getHeaders() {\n if (!this.headers) {\n this.parseHeaders();\n }\n return this.headers.build();\n }\n\n setContentType(contentType) {\n if (!this.headers) {\n this.parseHeaders();\n }\n\n contentType = (contentType || '').toLowerCase().trim();\n if (contentType) {\n this._parsedContentType.value = contentType;\n }\n\n if (!this.flowed && this._parsedContentType.params.format) {\n delete this._parsedContentType.params.format;\n }\n\n if (!this.delSp && this._parsedContentType.params.delsp) {\n delete this._parsedContentType.params.delsp;\n }\n\n this.headers.update('Content-Type', this.libmime.buildHeaderValue(this._parsedContentType));\n }\n\n setCharset(charset) {\n if (!this.headers) {\n this.parseHeaders();\n }\n\n charset = (charset || '').toLowerCase().trim();\n\n if (charset === 'ascii') {\n charset = '';\n }\n\n if (!charset) {\n if (!this._parsedContentType.value) {\n // nothing to set or update\n return;\n }\n delete this._parsedContentType.params.charset;\n } else {\n this._parsedContentType.params.charset = charset;\n }\n\n if (!this._parsedContentType.value) {\n this._parsedContentType.value = 'text/plain';\n }\n\n this.headers.update('Content-Type', this.libmime.buildHeaderValue(this._parsedContentType));\n }\n\n setFilename(filename) {\n if (!this.headers) {\n this.parseHeaders();\n }\n\n this.filename = (filename || '').toLowerCase().trim();\n\n if (this._parsedContentType.params.name) {\n delete this._parsedContentType.params.name;\n this.headers.update('Content-Type', this.libmime.buildHeaderValue(this._parsedContentType));\n }\n\n if (!this.filename) {\n if (!this._parsedContentDisposition.value) {\n // nothing to set or update\n return;\n }\n delete this._parsedContentDisposition.params.filename;\n } else {\n this._parsedContentDisposition.params.filename = this.filename;\n }\n\n if (!this._parsedContentDisposition.value) {\n this._parsedContentDisposition.value = 'attachment';\n }\n\n this.headers.update('Content-Disposition', this.libmime.buildHeaderValue(this._parsedContentDisposition));\n }\n\n getDecoder() {\n if (!this.headers) {\n this.parseHeaders();\n }\n\n switch (this.encoding) {\n case 'base64':\n return new libbase64.Decoder();\n case 'quoted-printable':\n return new libqp.Decoder();\n default:\n return new PassThrough();\n }\n }\n\n getEncoder(encoding) {\n if (!this.headers) {\n this.parseHeaders();\n }\n\n encoding = (encoding || '').toString().toLowerCase().trim();\n\n if (encoding && encoding !== this.encoding) {\n this.headers.update('Content-Transfer-Encoding', encoding);\n } else {\n encoding = this.encoding;\n }\n\n switch (encoding) {\n case 'base64':\n return new libbase64.Encoder();\n case 'quoted-printable':\n return new libqp.Encoder();\n default:\n return new PassThrough();\n }\n }\n}\n\nmodule.exports = MimeNode;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/mailsplit/lib/mime-node.js","mappings":"AAAa;;AAEb,gBAAgB,mBAAO,CAAC,2EAAW;AACnC,gBAAgB,mBAAO,CAAC,uEAAS;AACjC,cAAc,mBAAO,CAAC,iEAAO;AAC7B,kBAAkB,mBAAO,CAAC,6EAAW;AACrC,oBAAoB,yDAA6B;AACjD,gBAAgB,mBAAO,CAAC,kBAAM;;AAE9B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,6CAA6C,0BAA0B;;AAEvE;AACA,6BAA6B;AAC7B;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,UAAU;AACV;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,UAAU;AACV;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA","sources":["/home/alma/nextgen/Neah-mail/node_modules/mailsplit/lib/mime-node.js"],"sourcesContent":["'use strict';\n\nconst Headers = require('./headers');\nconst libmime = require('libmime');\nconst libqp = require('libqp');\nconst libbase64 = require('libbase64');\nconst PassThrough = require('stream').PassThrough;\nconst pathlib = require('path');\n\nclass MimeNode {\n    constructor(parentNode, config) {\n        this.type = 'node';\n        this.root = !parentNode;\n        this.parentNode = parentNode;\n\n        this._parentBoundary = this.parentNode && this.parentNode._boundary;\n        this._headersLines = [];\n        this._headerlen = 0;\n\n        this._parsedContentType = false;\n        this._boundary = false;\n\n        this.multipart = false;\n        this.encoding = false;\n        this.headers = false;\n        this.contentType = false;\n        this.flowed = false;\n        this.delSp = false;\n\n        this.config = config || {};\n        this.libmime = new libmime.Libmime({ Iconv: this.config.Iconv });\n\n        this.parentPartNumber = (parentNode && this.partNr) || [];\n        this.partNr = false; // resolved later\n        this.childPartNumbers = 0;\n    }\n\n    getPartNr(provided) {\n        if (provided) {\n            return []\n                .concat(this.partNr || [])\n                .filter(nr => !isNaN(nr))\n                .concat(provided);\n        }\n        let childPartNr = ++this.childPartNumbers;\n        return []\n            .concat(this.partNr || [])\n            .filter(nr => !isNaN(nr))\n            .concat(childPartNr);\n    }\n\n    addHeaderChunk(line) {\n        if (!line) {\n            return;\n        }\n        this._headersLines.push(line);\n        this._headerlen += line.length;\n    }\n\n    parseHeaders() {\n        if (this.headers) {\n            return;\n        }\n        this.headers = new Headers(Buffer.concat(this._headersLines, this._headerlen), this.config);\n\n        this._parsedContentDisposition = this.libmime.parseHeaderValue(this.headers.getFirst('Content-Disposition'));\n\n        // if content-type is missing default to plaintext\n        let contentHeader;\n        if (this.headers.get('Content-Type').length) {\n            contentHeader = this.headers.getFirst('Content-Type');\n        } else {\n            if (this._parsedContentDisposition.params.filename) {\n                let extension = pathlib.parse(this._parsedContentDisposition.params.filename).ext.replace(/^\\./, '');\n                if (extension) {\n                    contentHeader = libmime.detectMimeType(extension);\n                }\n            }\n            if (!contentHeader) {\n                if (/^attachment$/i.test(this._parsedContentDisposition.value)) {\n                    contentHeader = 'application/octet-stream';\n                } else {\n                    contentHeader = 'text/plain';\n                }\n            }\n        }\n\n        this._parsedContentType = this.libmime.parseHeaderValue(contentHeader);\n\n        this.encoding = this.headers\n            .getFirst('Content-Transfer-Encoding')\n            .replace(/\\(.*\\)/g, '')\n            .toLowerCase()\n            .trim();\n        this.contentType = (this._parsedContentType.value || '').toLowerCase().trim() || false;\n        this.charset = this._parsedContentType.params.charset || false;\n        this.disposition = (this._parsedContentDisposition.value || '').toLowerCase().trim() || false;\n\n        // fix invalidly encoded disposition values\n        if (this.disposition) {\n            try {\n                this.disposition = this.libmime.decodeWords(this.disposition);\n            } catch (E) {\n                // failed to parse disposition, keep as is (most probably an unknown charset is used)\n            }\n        }\n\n        this.filename = this._parsedContentDisposition.params.filename || this._parsedContentType.params.name || false;\n\n        if (this._parsedContentType.params.format && this._parsedContentType.params.format.toLowerCase().trim() === 'flowed') {\n            this.flowed = true;\n            if (this._parsedContentType.params.delsp && this._parsedContentType.params.delsp.toLowerCase().trim() === 'yes') {\n                this.delSp = true;\n            }\n        }\n\n        if (this.filename) {\n            try {\n                this.filename = this.libmime.decodeWords(this.filename);\n            } catch (E) {\n                // failed to parse filename, keep as is (most probably an unknown charset is used)\n            }\n        }\n\n        this.multipart =\n            (this.contentType &&\n                this.contentType.substr(0, this.contentType.indexOf('/')) === 'multipart' &&\n                this.contentType.substr(this.contentType.indexOf('/') + 1)) ||\n            false;\n        this._boundary = (this._parsedContentType.params.boundary && Buffer.from(this._parsedContentType.params.boundary)) || false;\n\n        this.rfc822 = this.contentType === 'message/rfc822';\n\n        if (!this.parentNode || this.parentNode.rfc822) {\n            this.partNr = this.parentNode ? this.parentNode.getPartNr('TEXT') : ['TEXT'];\n        } else {\n            this.partNr = this.parentNode ? this.parentNode.getPartNr() : [];\n        }\n    }\n\n    getHeaders() {\n        if (!this.headers) {\n            this.parseHeaders();\n        }\n        return this.headers.build();\n    }\n\n    setContentType(contentType) {\n        if (!this.headers) {\n            this.parseHeaders();\n        }\n\n        contentType = (contentType || '').toLowerCase().trim();\n        if (contentType) {\n            this._parsedContentType.value = contentType;\n        }\n\n        if (!this.flowed && this._parsedContentType.params.format) {\n            delete this._parsedContentType.params.format;\n        }\n\n        if (!this.delSp && this._parsedContentType.params.delsp) {\n            delete this._parsedContentType.params.delsp;\n        }\n\n        this.headers.update('Content-Type', this.libmime.buildHeaderValue(this._parsedContentType));\n    }\n\n    setCharset(charset) {\n        if (!this.headers) {\n            this.parseHeaders();\n        }\n\n        charset = (charset || '').toLowerCase().trim();\n\n        if (charset === 'ascii') {\n            charset = '';\n        }\n\n        if (!charset) {\n            if (!this._parsedContentType.value) {\n                // nothing to set or update\n                return;\n            }\n            delete this._parsedContentType.params.charset;\n        } else {\n            this._parsedContentType.params.charset = charset;\n        }\n\n        if (!this._parsedContentType.value) {\n            this._parsedContentType.value = 'text/plain';\n        }\n\n        this.headers.update('Content-Type', this.libmime.buildHeaderValue(this._parsedContentType));\n    }\n\n    setFilename(filename) {\n        if (!this.headers) {\n            this.parseHeaders();\n        }\n\n        this.filename = (filename || '').toLowerCase().trim();\n\n        if (this._parsedContentType.params.name) {\n            delete this._parsedContentType.params.name;\n            this.headers.update('Content-Type', this.libmime.buildHeaderValue(this._parsedContentType));\n        }\n\n        if (!this.filename) {\n            if (!this._parsedContentDisposition.value) {\n                // nothing to set or update\n                return;\n            }\n            delete this._parsedContentDisposition.params.filename;\n        } else {\n            this._parsedContentDisposition.params.filename = this.filename;\n        }\n\n        if (!this._parsedContentDisposition.value) {\n            this._parsedContentDisposition.value = 'attachment';\n        }\n\n        this.headers.update('Content-Disposition', this.libmime.buildHeaderValue(this._parsedContentDisposition));\n    }\n\n    getDecoder() {\n        if (!this.headers) {\n            this.parseHeaders();\n        }\n\n        switch (this.encoding) {\n            case 'base64':\n                return new libbase64.Decoder();\n            case 'quoted-printable':\n                return new libqp.Decoder();\n            default:\n                return new PassThrough();\n        }\n    }\n\n    getEncoder(encoding) {\n        if (!this.headers) {\n            this.parseHeaders();\n        }\n\n        encoding = (encoding || '').toString().toLowerCase().trim();\n\n        if (encoding && encoding !== this.encoding) {\n            this.headers.update('Content-Transfer-Encoding', encoding);\n        } else {\n            encoding = this.encoding;\n        }\n\n        switch (encoding) {\n            case 'base64':\n                return new libbase64.Encoder();\n            case 'quoted-printable':\n                return new libqp.Encoder();\n            default:\n                return new PassThrough();\n        }\n    }\n}\n\nmodule.exports = MimeNode;\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/mailsplit/lib/mime-node.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/mailsplit/lib/node-rewriter.js":
|
|
/*!*****************************************************!*\
|
|
!*** ./node_modules/mailsplit/lib/node-rewriter.js ***!
|
|
\*****************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\n// Helper class to rewrite nodes with specific mime type\n\nconst Transform = (__webpack_require__(/*! stream */ \"stream\").Transform);\nconst FlowedDecoder = __webpack_require__(/*! ./flowed-decoder */ \"(action-browser)/./node_modules/mailsplit/lib/flowed-decoder.js\");\n\n/**\n * NodeRewriter Transform stream. Updates content for all nodes with specified mime type\n *\n * @constructor\n * @param {String} mimeType Define the Mime-Type to look for\n * @param {Function} rewriteAction Function to run with the node content\n */\nclass NodeRewriter extends Transform {\n constructor(filterFunc, rewriteAction) {\n let options = {\n readableObjectMode: true,\n writableObjectMode: true\n };\n super(options);\n\n this.filterFunc = filterFunc;\n this.rewriteAction = rewriteAction;\n\n this.decoder = false;\n this.encoder = false;\n this.continue = false;\n }\n\n _transform(data, encoding, callback) {\n this.processIncoming(data, callback);\n }\n\n _flush(callback) {\n if (this.decoder) {\n // emit an empty node just in case there is pending data to end\n return this.processIncoming(\n {\n type: 'none'\n },\n callback\n );\n }\n return callback();\n }\n\n processIncoming(data, callback) {\n if (this.decoder && data.type === 'body') {\n // data to parse\n if (!this.decoder.write(data.value)) {\n return this.decoder.once('drain', callback);\n } else {\n return callback();\n }\n } else if (this.decoder && data.type !== 'body') {\n // stop decoding.\n // we can not process the current data chunk as we need to wait until\n // the parsed data is completely processed, so we store a reference to the\n // continue callback\n this.continue = () => {\n this.continue = false;\n this.decoder = false;\n this.encoder = false;\n this.processIncoming(data, callback);\n };\n return this.decoder.end();\n } else if (data.type === 'node' && this.filterFunc(data)) {\n // found matching node, create new handler\n this.emit('node', this.createDecodePair(data));\n } else if (this.readable && data.type !== 'none') {\n // we don't care about this data, just pass it over to the joiner\n this.push(data);\n }\n callback();\n }\n\n createDecodePair(node) {\n this.decoder = node.getDecoder();\n\n if (['base64', 'quoted-printable'].includes(node.encoding)) {\n this.encoder = node.getEncoder();\n } else {\n this.encoder = node.getEncoder('quoted-printable');\n }\n\n let lastByte = false;\n\n let decoder = this.decoder;\n let encoder = this.encoder;\n let firstChunk = true;\n decoder.$reading = false;\n\n let readFromEncoder = () => {\n decoder.$reading = true;\n\n let data = encoder.read();\n if (data === null) {\n decoder.$reading = false;\n return;\n }\n\n if (firstChunk) {\n firstChunk = false;\n if (this.readable) {\n this.push(node);\n if (node.type === 'body') {\n lastByte = node.value && node.value.length && node.value[node.value.length - 1];\n }\n }\n }\n\n let writeMore = true;\n if (this.readable) {\n writeMore = this.push({\n node,\n type: 'body',\n value: data\n });\n lastByte = data && data.length && data[data.length - 1];\n }\n\n if (writeMore) {\n return setImmediate(readFromEncoder);\n } else {\n encoder.pause();\n // no idea how to catch drain? use timeout for now as poor man's substitute\n // this.once('drain', () => encoder.resume());\n setTimeout(() => {\n encoder.resume();\n setImmediate(readFromEncoder);\n }, 100);\n }\n };\n\n encoder.on('readable', () => {\n if (!decoder.$reading) {\n return readFromEncoder();\n }\n });\n\n encoder.on('end', () => {\n if (firstChunk) {\n firstChunk = false;\n if (this.readable) {\n this.push(node);\n if (node.type === 'body') {\n lastByte = node.value && node.value.length && node.value[node.value.length - 1];\n }\n }\n }\n\n if (lastByte !== 0x0a) {\n // make sure there is a terminating line break\n this.push({\n node,\n type: 'body',\n value: Buffer.from([0x0a])\n });\n }\n\n if (this.continue) {\n return this.continue();\n }\n });\n\n if (/^text\\//.test(node.contentType) && node.flowed) {\n // text/plain; format=flowed is a special case\n let flowDecoder = decoder;\n decoder = new FlowedDecoder({\n delSp: node.delSp,\n encoding: node.encoding\n });\n flowDecoder.on('error', err => {\n decoder.emit('error', err);\n });\n flowDecoder.pipe(decoder);\n\n // we don't know what kind of data we are going to get, does it comply with the\n // requirements of format=flowed, so we just cancel it\n node.flowed = false;\n node.delSp = false;\n node.setContentType();\n }\n\n return {\n node,\n decoder,\n encoder\n };\n }\n}\n\nmodule.exports = NodeRewriter;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/mailsplit/lib/node-rewriter.js","mappings":"AAAa;;AAEb;;AAEA,kBAAkB,uDAA2B;AAC7C,sBAAsB,mBAAO,CAAC,yFAAkB;;AAEhD;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,UAAU;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,UAAU;AACV;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;;AAEA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;;AAEA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;;AAEA;AACA;AACA;AACA,SAAS;;AAET;AACA,2BAA2B;AAC3B;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,aAAa;AACb;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA","sources":["/home/alma/nextgen/Neah-mail/node_modules/mailsplit/lib/node-rewriter.js"],"sourcesContent":["'use strict';\n\n// Helper class to rewrite nodes with specific mime type\n\nconst Transform = require('stream').Transform;\nconst FlowedDecoder = require('./flowed-decoder');\n\n/**\n * NodeRewriter Transform stream. Updates content for all nodes with specified mime type\n *\n * @constructor\n * @param {String} mimeType Define the Mime-Type to look for\n * @param {Function} rewriteAction Function to run with the node content\n */\nclass NodeRewriter extends Transform {\n    constructor(filterFunc, rewriteAction) {\n        let options = {\n            readableObjectMode: true,\n            writableObjectMode: true\n        };\n        super(options);\n\n        this.filterFunc = filterFunc;\n        this.rewriteAction = rewriteAction;\n\n        this.decoder = false;\n        this.encoder = false;\n        this.continue = false;\n    }\n\n    _transform(data, encoding, callback) {\n        this.processIncoming(data, callback);\n    }\n\n    _flush(callback) {\n        if (this.decoder) {\n            // emit an empty node just in case there is pending data to end\n            return this.processIncoming(\n                {\n                    type: 'none'\n                },\n                callback\n            );\n        }\n        return callback();\n    }\n\n    processIncoming(data, callback) {\n        if (this.decoder && data.type === 'body') {\n            // data to parse\n            if (!this.decoder.write(data.value)) {\n                return this.decoder.once('drain', callback);\n            } else {\n                return callback();\n            }\n        } else if (this.decoder && data.type !== 'body') {\n            // stop decoding.\n            // we can not process the current data chunk as we need to wait until\n            // the parsed data is completely processed, so we store a reference to the\n            // continue callback\n            this.continue = () => {\n                this.continue = false;\n                this.decoder = false;\n                this.encoder = false;\n                this.processIncoming(data, callback);\n            };\n            return this.decoder.end();\n        } else if (data.type === 'node' && this.filterFunc(data)) {\n            // found matching node, create new handler\n            this.emit('node', this.createDecodePair(data));\n        } else if (this.readable && data.type !== 'none') {\n            // we don't care about this data, just pass it over to the joiner\n            this.push(data);\n        }\n        callback();\n    }\n\n    createDecodePair(node) {\n        this.decoder = node.getDecoder();\n\n        if (['base64', 'quoted-printable'].includes(node.encoding)) {\n            this.encoder = node.getEncoder();\n        } else {\n            this.encoder = node.getEncoder('quoted-printable');\n        }\n\n        let lastByte = false;\n\n        let decoder = this.decoder;\n        let encoder = this.encoder;\n        let firstChunk = true;\n        decoder.$reading = false;\n\n        let readFromEncoder = () => {\n            decoder.$reading = true;\n\n            let data = encoder.read();\n            if (data === null) {\n                decoder.$reading = false;\n                return;\n            }\n\n            if (firstChunk) {\n                firstChunk = false;\n                if (this.readable) {\n                    this.push(node);\n                    if (node.type === 'body') {\n                        lastByte = node.value && node.value.length && node.value[node.value.length - 1];\n                    }\n                }\n            }\n\n            let writeMore = true;\n            if (this.readable) {\n                writeMore = this.push({\n                    node,\n                    type: 'body',\n                    value: data\n                });\n                lastByte = data && data.length && data[data.length - 1];\n            }\n\n            if (writeMore) {\n                return setImmediate(readFromEncoder);\n            } else {\n                encoder.pause();\n                // no idea how to catch drain? use timeout for now as poor man's substitute\n                // this.once('drain', () => encoder.resume());\n                setTimeout(() => {\n                    encoder.resume();\n                    setImmediate(readFromEncoder);\n                }, 100);\n            }\n        };\n\n        encoder.on('readable', () => {\n            if (!decoder.$reading) {\n                return readFromEncoder();\n            }\n        });\n\n        encoder.on('end', () => {\n            if (firstChunk) {\n                firstChunk = false;\n                if (this.readable) {\n                    this.push(node);\n                    if (node.type === 'body') {\n                        lastByte = node.value && node.value.length && node.value[node.value.length - 1];\n                    }\n                }\n            }\n\n            if (lastByte !== 0x0a) {\n                // make sure there is a terminating line break\n                this.push({\n                    node,\n                    type: 'body',\n                    value: Buffer.from([0x0a])\n                });\n            }\n\n            if (this.continue) {\n                return this.continue();\n            }\n        });\n\n        if (/^text\\//.test(node.contentType) && node.flowed) {\n            // text/plain; format=flowed is a special case\n            let flowDecoder = decoder;\n            decoder = new FlowedDecoder({\n                delSp: node.delSp,\n                encoding: node.encoding\n            });\n            flowDecoder.on('error', err => {\n                decoder.emit('error', err);\n            });\n            flowDecoder.pipe(decoder);\n\n            // we don't know what kind of data we are going to get, does it comply with the\n            // requirements of format=flowed, so we just cancel it\n            node.flowed = false;\n            node.delSp = false;\n            node.setContentType();\n        }\n\n        return {\n            node,\n            decoder,\n            encoder\n        };\n    }\n}\n\nmodule.exports = NodeRewriter;\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/mailsplit/lib/node-rewriter.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/mailsplit/lib/node-streamer.js":
|
|
/*!*****************************************************!*\
|
|
!*** ./node_modules/mailsplit/lib/node-streamer.js ***!
|
|
\*****************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\n// Helper class to rewrite nodes with specific mime type\n\nconst Transform = (__webpack_require__(/*! stream */ \"stream\").Transform);\nconst FlowedDecoder = __webpack_require__(/*! ./flowed-decoder */ \"(action-browser)/./node_modules/mailsplit/lib/flowed-decoder.js\");\n\n/**\n * NodeRewriter Transform stream. Updates content for all nodes with specified mime type\n *\n * @constructor\n * @param {String} mimeType Define the Mime-Type to look for\n * @param {Function} streamAction Function to run with the node content\n */\nclass NodeStreamer extends Transform {\n constructor(filterFunc, streamAction) {\n let options = {\n readableObjectMode: true,\n writableObjectMode: true\n };\n super(options);\n\n this.filterFunc = filterFunc;\n this.streamAction = streamAction;\n\n this.decoder = false;\n this.canContinue = false;\n this.continue = false;\n }\n\n _transform(data, encoding, callback) {\n this.processIncoming(data, callback);\n }\n\n _flush(callback) {\n if (this.decoder) {\n // emit an empty node just in case there is pending data to end\n return this.processIncoming(\n {\n type: 'none'\n },\n callback\n );\n }\n return callback();\n }\n\n processIncoming(data, callback) {\n if (this.decoder && data.type === 'body') {\n // data to parse\n this.push(data);\n if (!this.decoder.write(data.value)) {\n return this.decoder.once('drain', callback);\n } else {\n return callback();\n }\n } else if (this.decoder && data.type !== 'body') {\n // stop decoding.\n // we can not process the current data chunk as we need to wait until\n // the parsed data is completely processed, so we store a reference to the\n // continue callback\n\n let doContinue = () => {\n this.continue = false;\n this.decoder = false;\n this.canContinue = false;\n this.processIncoming(data, callback);\n };\n\n if (this.canContinue) {\n setImmediate(doContinue);\n } else {\n this.continue = () => doContinue();\n }\n\n return this.decoder.end();\n } else if (data.type === 'node' && this.filterFunc(data)) {\n this.push(data);\n // found matching node, create new handler\n this.emit('node', this.createDecoder(data));\n } else if (this.readable && data.type !== 'none') {\n // we don't care about this data, just pass it over to the joiner\n this.push(data);\n }\n callback();\n }\n\n createDecoder(node) {\n this.decoder = node.getDecoder();\n\n let decoder = this.decoder;\n decoder.$reading = false;\n\n if (/^text\\//.test(node.contentType) && node.flowed) {\n let flowDecoder = decoder;\n decoder = new FlowedDecoder({\n delSp: node.delSp\n });\n flowDecoder.on('error', err => {\n decoder.emit('error', err);\n });\n flowDecoder.pipe(decoder);\n }\n\n return {\n node,\n decoder,\n done: () => {\n if (typeof this.continue === 'function') {\n // called once input stream is processed\n this.continue();\n } else {\n // called before input stream is processed\n this.canContinue = true;\n }\n }\n };\n }\n}\n\nmodule.exports = NodeStreamer;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9tYWlsc3BsaXQvbGliL25vZGUtc3RyZWFtZXIuanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWI7O0FBRUEsa0JBQWtCLHVEQUEyQjtBQUM3QyxzQkFBc0IsbUJBQU8sQ0FBQyx5RkFBa0I7O0FBRWhEO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsV0FBVyxRQUFRO0FBQ25CLFdBQVcsVUFBVTtBQUNyQjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGlCQUFpQjtBQUNqQjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGNBQWM7QUFDZDtBQUNBO0FBQ0EsVUFBVTtBQUNWO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsY0FBYztBQUNkO0FBQ0E7O0FBRUE7QUFDQSxVQUFVO0FBQ1Y7QUFDQTtBQUNBO0FBQ0EsVUFBVTtBQUNWO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGtCQUFrQjtBQUNsQjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvbWFpbHNwbGl0L2xpYi9ub2RlLXN0cmVhbWVyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuLy8gSGVscGVyIGNsYXNzIHRvIHJld3JpdGUgbm9kZXMgd2l0aCBzcGVjaWZpYyBtaW1lIHR5cGVcblxuY29uc3QgVHJhbnNmb3JtID0gcmVxdWlyZSgnc3RyZWFtJykuVHJhbnNmb3JtO1xuY29uc3QgRmxvd2VkRGVjb2RlciA9IHJlcXVpcmUoJy4vZmxvd2VkLWRlY29kZXInKTtcblxuLyoqXG4gKiBOb2RlUmV3cml0ZXIgVHJhbnNmb3JtIHN0cmVhbS4gVXBkYXRlcyBjb250ZW50IGZvciBhbGwgbm9kZXMgd2l0aCBzcGVjaWZpZWQgbWltZSB0eXBlXG4gKlxuICogQGNvbnN0cnVjdG9yXG4gKiBAcGFyYW0ge1N0cmluZ30gbWltZVR5cGUgRGVmaW5lIHRoZSBNaW1lLVR5cGUgdG8gbG9vayBmb3JcbiAqIEBwYXJhbSB7RnVuY3Rpb259IHN0cmVhbUFjdGlvbiBGdW5jdGlvbiB0byBydW4gd2l0aCB0aGUgbm9kZSBjb250ZW50XG4gKi9cbmNsYXNzIE5vZGVTdHJlYW1lciBleHRlbmRzIFRyYW5zZm9ybSB7XG4gICAgY29uc3RydWN0b3IoZmlsdGVyRnVuYywgc3RyZWFtQWN0aW9uKSB7XG4gICAgICAgIGxldCBvcHRpb25zID0ge1xuICAgICAgICAgICAgcmVhZGFibGVPYmplY3RNb2RlOiB0cnVlLFxuICAgICAgICAgICAgd3JpdGFibGVPYmplY3RNb2RlOiB0cnVlXG4gICAgICAgIH07XG4gICAgICAgIHN1cGVyKG9wdGlvbnMpO1xuXG4gICAgICAgIHRoaXMuZmlsdGVyRnVuYyA9IGZpbHRlckZ1bmM7XG4gICAgICAgIHRoaXMuc3RyZWFtQWN0aW9uID0gc3RyZWFtQWN0aW9uO1xuXG4gICAgICAgIHRoaXMuZGVjb2RlciA9IGZhbHNlO1xuICAgICAgICB0aGlzLmNhbkNvbnRpbnVlID0gZmFsc2U7XG4gICAgICAgIHRoaXMuY29udGludWUgPSBmYWxzZTtcbiAgICB9XG5cbiAgICBfdHJhbnNmb3JtKGRhdGEsIGVuY29kaW5nLCBjYWxsYmFjaykge1xuICAgICAgICB0aGlzLnByb2Nlc3NJbmNvbWluZyhkYXRhLCBjYWxsYmFjayk7XG4gICAgfVxuXG4gICAgX2ZsdXNoKGNhbGxiYWNrKSB7XG4gICAgICAgIGlmICh0aGlzLmRlY29kZXIpIHtcbiAgICAgICAgICAgIC8vIGVtaXQgYW4gZW1wdHkgbm9kZSBqdXN0IGluIGNhc2UgdGhlcmUgaXMgcGVuZGluZyBkYXRhIHRvIGVuZFxuICAgICAgICAgICAgcmV0dXJuIHRoaXMucHJvY2Vzc0luY29taW5nKFxuICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgdHlwZTogJ25vbmUnXG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICBjYWxsYmFja1xuICAgICAgICAgICAgKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gY2FsbGJhY2soKTtcbiAgICB9XG5cbiAgICBwcm9jZXNzSW5jb21pbmcoZGF0YSwgY2FsbGJhY2spIHtcbiAgICAgICAgaWYgKHRoaXMuZGVjb2RlciAmJiBkYXRhLnR5cGUgPT09ICdib2R5Jykge1xuICAgICAgICAgICAgLy8gZGF0YSB0byBwYXJzZVxuICAgICAgICAgICAgdGhpcy5wdXNoKGRhdGEpO1xuICAgICAgICAgICAgaWYgKCF0aGlzLmRlY29kZXIud3JpdGUoZGF0YS52YWx1ZSkpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gdGhpcy5kZWNvZGVyLm9uY2UoJ2RyYWluJywgY2FsbGJhY2spO1xuICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gY2FsbGJhY2soKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSBlbHNlIGlmICh0aGlzLmRlY29kZXIgJiYgZGF0YS50eXBlICE9PSAnYm9keScpIHtcbiAgICAgICAgICAgIC8vIHN0b3AgZGVjb2RpbmcuXG4gICAgICAgICAgICAvLyB3ZSBjYW4gbm90IHByb2Nlc3MgdGhlIGN1cnJlbnQgZGF0YSBjaHVuayBhcyB3ZSBuZWVkIHRvIHdhaXQgdW50aWxcbiAgICAgICAgICAgIC8vIHRoZSBwYXJzZWQgZGF0YSBpcyBjb21wbGV0ZWx5IHByb2Nlc3NlZCwgc28gd2Ugc3RvcmUgYSByZWZlcmVuY2UgdG8gdGhlXG4gICAgICAgICAgICAvLyBjb250aW51ZSBjYWxsYmFja1xuXG4gICAgICAgICAgICBsZXQgZG9Db250aW51ZSA9ICgpID0+IHtcbiAgICAgICAgICAgICAgICB0aGlzLmNvbnRpbnVlID0gZmFsc2U7XG4gICAgICAgICAgICAgICAgdGhpcy5kZWNvZGVyID0gZmFsc2U7XG4gICAgICAgICAgICAgICAgdGhpcy5jYW5Db250aW51ZSA9IGZhbHNlO1xuICAgICAgICAgICAgICAgIHRoaXMucHJvY2Vzc0luY29taW5nKGRhdGEsIGNhbGxiYWNrKTtcbiAgICAgICAgICAgIH07XG5cbiAgICAgICAgICAgIGlmICh0aGlzLmNhbkNvbnRpbnVlKSB7XG4gICAgICAgICAgICAgICAgc2V0SW1tZWRpYXRlKGRvQ29udGludWUpO1xuICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICB0aGlzLmNvbnRpbnVlID0gKCkgPT4gZG9Db250aW51ZSgpO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICByZXR1cm4gdGhpcy5kZWNvZGVyLmVuZCgpO1xuICAgICAgICB9IGVsc2UgaWYgKGRhdGEudHlwZSA9PT0gJ25vZGUnICYmIHRoaXMuZmlsdGVyRnVuYyhkYXRhKSkge1xuICAgICAgICAgICAgdGhpcy5wdXNoKGRhdGEpO1xuICAgICAgICAgICAgLy8gZm91bmQgbWF0Y2hpbmcgbm9kZSwgY3JlYXRlIG5ldyBoYW5kbGVyXG4gICAgICAgICAgICB0aGlzLmVtaXQoJ25vZGUnLCB0aGlzLmNyZWF0ZURlY29kZXIoZGF0YSkpO1xuICAgICAgICB9IGVsc2UgaWYgKHRoaXMucmVhZGFibGUgJiYgZGF0YS50eXBlICE9PSAnbm9uZScpIHtcbiAgICAgICAgICAgIC8vIHdlIGRvbid0IGNhcmUgYWJvdXQgdGhpcyBkYXRhLCBqdXN0IHBhc3MgaXQgb3ZlciB0byB0aGUgam9pbmVyXG4gICAgICAgICAgICB0aGlzLnB1c2goZGF0YSk7XG4gICAgICAgIH1cbiAgICAgICAgY2FsbGJhY2soKTtcbiAgICB9XG5cbiAgICBjcmVhdGVEZWNvZGVyKG5vZGUpIHtcbiAgICAgICAgdGhpcy5kZWNvZGVyID0gbm9kZS5nZXREZWNvZGVyKCk7XG5cbiAgICAgICAgbGV0IGRlY29kZXIgPSB0aGlzLmRlY29kZXI7XG4gICAgICAgIGRlY29kZXIuJHJlYWRpbmcgPSBmYWxzZTtcblxuICAgICAgICBpZiAoL150ZXh0XFwvLy50ZXN0KG5vZGUuY29udGVudFR5cGUpICYmIG5vZGUuZmxvd2VkKSB7XG4gICAgICAgICAgICBsZXQgZmxvd0RlY29kZXIgPSBkZWNvZGVyO1xuICAgICAgICAgICAgZGVjb2RlciA9IG5ldyBGbG93ZWREZWNvZGVyKHtcbiAgICAgICAgICAgICAgICBkZWxTcDogbm9kZS5kZWxTcFxuICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICBmbG93RGVjb2Rlci5vbignZXJyb3InLCBlcnIgPT4ge1xuICAgICAgICAgICAgICAgIGRlY29kZXIuZW1pdCgnZXJyb3InLCBlcnIpO1xuICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICBmbG93RGVjb2Rlci5waXBlKGRlY29kZXIpO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIG5vZGUsXG4gICAgICAgICAgICBkZWNvZGVyLFxuICAgICAgICAgICAgZG9uZTogKCkgPT4ge1xuICAgICAgICAgICAgICAgIGlmICh0eXBlb2YgdGhpcy5jb250aW51ZSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgICAgICAgICAgICAgICAgICAvLyBjYWxsZWQgb25jZSBpbnB1dCBzdHJlYW0gaXMgcHJvY2Vzc2VkXG4gICAgICAgICAgICAgICAgICAgIHRoaXMuY29udGludWUoKTtcbiAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICAvLyBjYWxsZWQgYmVmb3JlIGlucHV0IHN0cmVhbSBpcyBwcm9jZXNzZWRcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5jYW5Db250aW51ZSA9IHRydWU7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICB9O1xuICAgIH1cbn1cblxubW9kdWxlLmV4cG9ydHMgPSBOb2RlU3RyZWFtZXI7XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/mailsplit/lib/node-streamer.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/mailsplit/index.js":
|
|
/*!*****************************************!*\
|
|
!*** ./node_modules/mailsplit/index.js ***!
|
|
\*****************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst MessageSplitter = __webpack_require__(/*! ./lib/message-splitter */ \"(rsc)/./node_modules/mailsplit/lib/message-splitter.js\");\nconst MessageJoiner = __webpack_require__(/*! ./lib/message-joiner */ \"(rsc)/./node_modules/mailsplit/lib/message-joiner.js\");\nconst NodeRewriter = __webpack_require__(/*! ./lib/node-rewriter */ \"(rsc)/./node_modules/mailsplit/lib/node-rewriter.js\");\nconst NodeStreamer = __webpack_require__(/*! ./lib/node-streamer */ \"(rsc)/./node_modules/mailsplit/lib/node-streamer.js\");\nconst Headers = __webpack_require__(/*! ./lib/headers */ \"(rsc)/./node_modules/mailsplit/lib/headers.js\");\n\nmodule.exports = {\n Splitter: MessageSplitter,\n Joiner: MessageJoiner,\n Rewriter: NodeRewriter,\n Streamer: NodeStreamer,\n Headers\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvbWFpbHNwbGl0L2luZGV4LmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViLHdCQUF3QixtQkFBTyxDQUFDLHNGQUF3QjtBQUN4RCxzQkFBc0IsbUJBQU8sQ0FBQyxrRkFBc0I7QUFDcEQscUJBQXFCLG1CQUFPLENBQUMsZ0ZBQXFCO0FBQ2xELHFCQUFxQixtQkFBTyxDQUFDLGdGQUFxQjtBQUNsRCxnQkFBZ0IsbUJBQU8sQ0FBQyxvRUFBZTs7QUFFdkM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL21haWxzcGxpdC9pbmRleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IE1lc3NhZ2VTcGxpdHRlciA9IHJlcXVpcmUoJy4vbGliL21lc3NhZ2Utc3BsaXR0ZXInKTtcbmNvbnN0IE1lc3NhZ2VKb2luZXIgPSByZXF1aXJlKCcuL2xpYi9tZXNzYWdlLWpvaW5lcicpO1xuY29uc3QgTm9kZVJld3JpdGVyID0gcmVxdWlyZSgnLi9saWIvbm9kZS1yZXdyaXRlcicpO1xuY29uc3QgTm9kZVN0cmVhbWVyID0gcmVxdWlyZSgnLi9saWIvbm9kZS1zdHJlYW1lcicpO1xuY29uc3QgSGVhZGVycyA9IHJlcXVpcmUoJy4vbGliL2hlYWRlcnMnKTtcblxubW9kdWxlLmV4cG9ydHMgPSB7XG4gICAgU3BsaXR0ZXI6IE1lc3NhZ2VTcGxpdHRlcixcbiAgICBKb2luZXI6IE1lc3NhZ2VKb2luZXIsXG4gICAgUmV3cml0ZXI6IE5vZGVSZXdyaXRlcixcbiAgICBTdHJlYW1lcjogTm9kZVN0cmVhbWVyLFxuICAgIEhlYWRlcnNcbn07XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/mailsplit/index.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/mailsplit/lib/flowed-decoder.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/mailsplit/lib/flowed-decoder.js ***!
|
|
\******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\n// Helper class to rewrite nodes with specific mime type\n\nconst Transform = (__webpack_require__(/*! stream */ \"stream\").Transform);\nconst libmime = __webpack_require__(/*! libmime */ \"(rsc)/./node_modules/libmime/lib/libmime.js\");\n\n/**\n * Really bad \"stream\" transform to parse format=flowed content\n *\n * @constructor\n * @param {String} delSp True if delsp option was used\n */\nclass FlowedDecoder extends Transform {\n constructor(config) {\n super();\n this.config = config || {};\n\n this.chunks = [];\n this.chunklen = 0;\n\n this.libmime = new libmime.Libmime({ Iconv: config.Iconv });\n }\n\n _transform(chunk, encoding, callback) {\n if (!chunk || !chunk.length) {\n return callback();\n }\n\n if (!encoding !== 'buffer') {\n chunk = Buffer.from(chunk, encoding);\n }\n\n this.chunks.push(chunk);\n this.chunklen += chunk.length;\n\n callback();\n }\n\n _flush(callback) {\n if (this.chunklen) {\n let currentBody = Buffer.concat(this.chunks, this.chunklen);\n\n if (this.config.encoding === 'base64') {\n currentBody = Buffer.from(currentBody.toString('binary'), 'base64');\n }\n\n let content = this.libmime.decodeFlowed(currentBody.toString('binary'), this.config.delSp);\n this.push(Buffer.from(content, 'binary'));\n }\n return callback();\n }\n}\n\nmodule.exports = FlowedDecoder;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvbWFpbHNwbGl0L2xpYi9mbG93ZWQtZGVjb2Rlci5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYjs7QUFFQSxrQkFBa0IsdURBQTJCO0FBQzdDLGdCQUFnQixtQkFBTyxDQUFDLDREQUFTOztBQUVqQztBQUNBO0FBQ0E7QUFDQTtBQUNBLFdBQVcsUUFBUTtBQUNuQjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsNkNBQTZDLHFCQUFxQjtBQUNsRTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9tYWlsc3BsaXQvbGliL2Zsb3dlZC1kZWNvZGVyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuLy8gSGVscGVyIGNsYXNzIHRvIHJld3JpdGUgbm9kZXMgd2l0aCBzcGVjaWZpYyBtaW1lIHR5cGVcblxuY29uc3QgVHJhbnNmb3JtID0gcmVxdWlyZSgnc3RyZWFtJykuVHJhbnNmb3JtO1xuY29uc3QgbGlibWltZSA9IHJlcXVpcmUoJ2xpYm1pbWUnKTtcblxuLyoqXG4gKiBSZWFsbHkgYmFkIFwic3RyZWFtXCIgdHJhbnNmb3JtIHRvIHBhcnNlIGZvcm1hdD1mbG93ZWQgY29udGVudFxuICpcbiAqIEBjb25zdHJ1Y3RvclxuICogQHBhcmFtIHtTdHJpbmd9IGRlbFNwIFRydWUgaWYgZGVsc3Agb3B0aW9uIHdhcyB1c2VkXG4gKi9cbmNsYXNzIEZsb3dlZERlY29kZXIgZXh0ZW5kcyBUcmFuc2Zvcm0ge1xuICAgIGNvbnN0cnVjdG9yKGNvbmZpZykge1xuICAgICAgICBzdXBlcigpO1xuICAgICAgICB0aGlzLmNvbmZpZyA9IGNvbmZpZyB8fCB7fTtcblxuICAgICAgICB0aGlzLmNodW5rcyA9IFtdO1xuICAgICAgICB0aGlzLmNodW5rbGVuID0gMDtcblxuICAgICAgICB0aGlzLmxpYm1pbWUgPSBuZXcgbGlibWltZS5MaWJtaW1lKHsgSWNvbnY6IGNvbmZpZy5JY29udiB9KTtcbiAgICB9XG5cbiAgICBfdHJhbnNmb3JtKGNodW5rLCBlbmNvZGluZywgY2FsbGJhY2spIHtcbiAgICAgICAgaWYgKCFjaHVuayB8fCAhY2h1bmsubGVuZ3RoKSB7XG4gICAgICAgICAgICByZXR1cm4gY2FsbGJhY2soKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmICghZW5jb2RpbmcgIT09ICdidWZmZXInKSB7XG4gICAgICAgICAgICBjaHVuayA9IEJ1ZmZlci5mcm9tKGNodW5rLCBlbmNvZGluZyk7XG4gICAgICAgIH1cblxuICAgICAgICB0aGlzLmNodW5rcy5wdXNoKGNodW5rKTtcbiAgICAgICAgdGhpcy5jaHVua2xlbiArPSBjaHVuay5sZW5ndGg7XG5cbiAgICAgICAgY2FsbGJhY2soKTtcbiAgICB9XG5cbiAgICBfZmx1c2goY2FsbGJhY2spIHtcbiAgICAgICAgaWYgKHRoaXMuY2h1bmtsZW4pIHtcbiAgICAgICAgICAgIGxldCBjdXJyZW50Qm9keSA9IEJ1ZmZlci5jb25jYXQodGhpcy5jaHVua3MsIHRoaXMuY2h1bmtsZW4pO1xuXG4gICAgICAgICAgICBpZiAodGhpcy5jb25maWcuZW5jb2RpbmcgPT09ICdiYXNlNjQnKSB7XG4gICAgICAgICAgICAgICAgY3VycmVudEJvZHkgPSBCdWZmZXIuZnJvbShjdXJyZW50Qm9keS50b1N0cmluZygnYmluYXJ5JyksICdiYXNlNjQnKTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgbGV0IGNvbnRlbnQgPSB0aGlzLmxpYm1pbWUuZGVjb2RlRmxvd2VkKGN1cnJlbnRCb2R5LnRvU3RyaW5nKCdiaW5hcnknKSwgdGhpcy5jb25maWcuZGVsU3ApO1xuICAgICAgICAgICAgdGhpcy5wdXNoKEJ1ZmZlci5mcm9tKGNvbnRlbnQsICdiaW5hcnknKSk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGNhbGxiYWNrKCk7XG4gICAgfVxufVxuXG5tb2R1bGUuZXhwb3J0cyA9IEZsb3dlZERlY29kZXI7XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/mailsplit/lib/flowed-decoder.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/mailsplit/lib/headers.js":
|
|
/*!***********************************************!*\
|
|
!*** ./node_modules/mailsplit/lib/headers.js ***!
|
|
\***********************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst libmime = __webpack_require__(/*! libmime */ \"(rsc)/./node_modules/libmime/lib/libmime.js\");\n\n/**\n * Class Headers to parse and handle message headers. Headers instance allows to\n * check existing, delete or add new headers\n */\nclass Headers {\n constructor(headers, config) {\n config = config || {};\n\n if (Array.isArray(headers)) {\n // already using parsed headers\n this.changed = true;\n this.headers = false;\n this.parsed = true;\n this.lines = headers;\n } else {\n // using original string/buffer headers\n this.changed = false;\n this.headers = headers;\n this.parsed = false;\n this.lines = false;\n }\n this.mbox = false;\n this.http = false;\n\n this.libmime = new libmime.Libmime({ Iconv: config.Iconv });\n }\n\n hasHeader(key) {\n if (!this.parsed) {\n this._parseHeaders();\n }\n key = this._normalizeHeader(key);\n return typeof this.lines.find(line => line.key === key) === 'object';\n }\n\n get(key) {\n if (!this.parsed) {\n this._parseHeaders();\n }\n key = this._normalizeHeader(key);\n let lines = this.lines.filter(line => line.key === key).map(line => line.line);\n\n return lines;\n }\n\n getDecoded(key) {\n return this.get(key)\n .map(line => this.libmime.decodeHeader(line))\n .filter(line => line && line.value);\n }\n\n getFirst(key) {\n if (!this.parsed) {\n this._parseHeaders();\n }\n key = this._normalizeHeader(key);\n let header = this.lines.find(line => line.key === key);\n if (!header) {\n return '';\n }\n return ((this.libmime.decodeHeader(header.line) || {}).value || '').toString().trim();\n }\n\n getList() {\n if (!this.parsed) {\n this._parseHeaders();\n }\n return this.lines;\n }\n\n add(key, value, index) {\n if (typeof value === 'undefined') {\n return;\n }\n\n if (typeof value === 'number') {\n value = value.toString();\n }\n\n if (typeof value === 'string') {\n value = Buffer.from(value);\n }\n\n value = value.toString('binary');\n this.addFormatted(key, this.libmime.foldLines(key + ': ' + value.replace(/\\r?\\n/g, ''), 76, false), index);\n }\n\n addFormatted(key, line, index) {\n if (!this.parsed) {\n this._parseHeaders();\n }\n index = index || 0;\n this.changed = true;\n\n if (!line) {\n return;\n }\n\n if (typeof line !== 'string') {\n line = line.toString('binary');\n }\n\n let header = {\n key: this._normalizeHeader(key),\n line\n };\n\n if (index < 1) {\n this.lines.unshift(header);\n } else if (index >= this.lines.length) {\n this.lines.push(header);\n } else {\n this.lines.splice(index, 0, header);\n }\n }\n\n remove(key) {\n if (!this.parsed) {\n this._parseHeaders();\n }\n key = this._normalizeHeader(key);\n for (let i = this.lines.length - 1; i >= 0; i--) {\n if (this.lines[i].key === key) {\n this.changed = true;\n this.lines.splice(i, 1);\n }\n }\n }\n\n update(key, value, relativeIndex) {\n if (!this.parsed) {\n this._parseHeaders();\n }\n let keyName = key;\n let index = 0;\n key = this._normalizeHeader(key);\n let relativeIndexCount = 0;\n let relativeMatchFound = false;\n for (let i = this.lines.length - 1; i >= 0; i--) {\n if (this.lines[i].key === key) {\n if (relativeIndex && relativeIndex !== relativeIndexCount) {\n relativeIndexCount++;\n continue;\n }\n index = i;\n this.changed = true;\n this.lines.splice(i, 1);\n if (relativeIndex) {\n relativeMatchFound = true;\n break;\n }\n }\n }\n\n if (relativeIndex && !relativeMatchFound) {\n return;\n }\n\n this.add(keyName, value, index);\n }\n\n build(lineEnd) {\n if (!this.changed && !lineEnd) {\n return typeof this.headers === 'string' ? Buffer.from(this.headers, 'binary') : this.headers;\n }\n\n if (!this.parsed) {\n this._parseHeaders();\n }\n\n lineEnd = lineEnd || '\\r\\n';\n\n let headers = this.lines.map(line => line.line.replace(/\\r?\\n/g, lineEnd)).join(lineEnd) + `${lineEnd}${lineEnd}`;\n\n if (this.mbox) {\n headers = this.mbox + lineEnd + headers;\n }\n\n if (this.http) {\n headers = this.http + lineEnd + headers;\n }\n\n return Buffer.from(headers, 'binary');\n }\n\n _normalizeHeader(key) {\n return (key || '').toLowerCase().trim();\n }\n\n _parseHeaders() {\n if (!this.headers) {\n this.lines = [];\n this.parsed = true;\n return;\n }\n\n let lines = this.headers\n .toString('binary')\n .replace(/[\\r\\n]+$/, '')\n .split(/\\r?\\n/);\n\n for (let i = lines.length - 1; i >= 0; i--) {\n let chr = lines[i].charAt(0);\n if (i && (chr === ' ' || chr === '\\t')) {\n lines[i - 1] += '\\r\\n' + lines[i];\n lines.splice(i, 1);\n } else {\n let line = lines[i];\n if (!i && /^From /i.test(line)) {\n // mbox file\n this.mbox = line;\n lines.splice(i, 1);\n continue;\n } else if (!i && /^POST /i.test(line)) {\n // HTTP POST request\n this.http = line;\n lines.splice(i, 1);\n continue;\n }\n let key = this._normalizeHeader(line.substr(0, line.indexOf(':')));\n lines[i] = {\n key,\n line\n };\n }\n }\n\n this.lines = lines;\n this.parsed = true;\n }\n}\n\n// expose to the world\nmodule.exports = Headers;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/mailsplit/lib/headers.js","mappings":"AAAa;;AAEb,gBAAgB,mBAAO,CAAC,4DAAS;;AAEjC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,6CAA6C,qBAAqB;AAClE;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6DAA6D;AAC7D;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,UAAU;AACV;AACA,UAAU;AACV;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,4CAA4C,QAAQ;AACpD;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,QAAQ;AACpD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,sGAAsG,QAAQ,EAAE,QAAQ;;AAExH;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,uCAAuC,QAAQ;AAC/C;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/mailsplit/lib/headers.js"],"sourcesContent":["'use strict';\n\nconst libmime = require('libmime');\n\n/**\n * Class Headers to parse and handle message headers. Headers instance allows to\n * check existing, delete or add new headers\n */\nclass Headers {\n    constructor(headers, config) {\n        config = config || {};\n\n        if (Array.isArray(headers)) {\n            // already using parsed headers\n            this.changed = true;\n            this.headers = false;\n            this.parsed = true;\n            this.lines = headers;\n        } else {\n            // using original string/buffer headers\n            this.changed = false;\n            this.headers = headers;\n            this.parsed = false;\n            this.lines = false;\n        }\n        this.mbox = false;\n        this.http = false;\n\n        this.libmime = new libmime.Libmime({ Iconv: config.Iconv });\n    }\n\n    hasHeader(key) {\n        if (!this.parsed) {\n            this._parseHeaders();\n        }\n        key = this._normalizeHeader(key);\n        return typeof this.lines.find(line => line.key === key) === 'object';\n    }\n\n    get(key) {\n        if (!this.parsed) {\n            this._parseHeaders();\n        }\n        key = this._normalizeHeader(key);\n        let lines = this.lines.filter(line => line.key === key).map(line => line.line);\n\n        return lines;\n    }\n\n    getDecoded(key) {\n        return this.get(key)\n            .map(line => this.libmime.decodeHeader(line))\n            .filter(line => line && line.value);\n    }\n\n    getFirst(key) {\n        if (!this.parsed) {\n            this._parseHeaders();\n        }\n        key = this._normalizeHeader(key);\n        let header = this.lines.find(line => line.key === key);\n        if (!header) {\n            return '';\n        }\n        return ((this.libmime.decodeHeader(header.line) || {}).value || '').toString().trim();\n    }\n\n    getList() {\n        if (!this.parsed) {\n            this._parseHeaders();\n        }\n        return this.lines;\n    }\n\n    add(key, value, index) {\n        if (typeof value === 'undefined') {\n            return;\n        }\n\n        if (typeof value === 'number') {\n            value = value.toString();\n        }\n\n        if (typeof value === 'string') {\n            value = Buffer.from(value);\n        }\n\n        value = value.toString('binary');\n        this.addFormatted(key, this.libmime.foldLines(key + ': ' + value.replace(/\\r?\\n/g, ''), 76, false), index);\n    }\n\n    addFormatted(key, line, index) {\n        if (!this.parsed) {\n            this._parseHeaders();\n        }\n        index = index || 0;\n        this.changed = true;\n\n        if (!line) {\n            return;\n        }\n\n        if (typeof line !== 'string') {\n            line = line.toString('binary');\n        }\n\n        let header = {\n            key: this._normalizeHeader(key),\n            line\n        };\n\n        if (index < 1) {\n            this.lines.unshift(header);\n        } else if (index >= this.lines.length) {\n            this.lines.push(header);\n        } else {\n            this.lines.splice(index, 0, header);\n        }\n    }\n\n    remove(key) {\n        if (!this.parsed) {\n            this._parseHeaders();\n        }\n        key = this._normalizeHeader(key);\n        for (let i = this.lines.length - 1; i >= 0; i--) {\n            if (this.lines[i].key === key) {\n                this.changed = true;\n                this.lines.splice(i, 1);\n            }\n        }\n    }\n\n    update(key, value, relativeIndex) {\n        if (!this.parsed) {\n            this._parseHeaders();\n        }\n        let keyName = key;\n        let index = 0;\n        key = this._normalizeHeader(key);\n        let relativeIndexCount = 0;\n        let relativeMatchFound = false;\n        for (let i = this.lines.length - 1; i >= 0; i--) {\n            if (this.lines[i].key === key) {\n                if (relativeIndex && relativeIndex !== relativeIndexCount) {\n                    relativeIndexCount++;\n                    continue;\n                }\n                index = i;\n                this.changed = true;\n                this.lines.splice(i, 1);\n                if (relativeIndex) {\n                    relativeMatchFound = true;\n                    break;\n                }\n            }\n        }\n\n        if (relativeIndex && !relativeMatchFound) {\n            return;\n        }\n\n        this.add(keyName, value, index);\n    }\n\n    build(lineEnd) {\n        if (!this.changed && !lineEnd) {\n            return typeof this.headers === 'string' ? Buffer.from(this.headers, 'binary') : this.headers;\n        }\n\n        if (!this.parsed) {\n            this._parseHeaders();\n        }\n\n        lineEnd = lineEnd || '\\r\\n';\n\n        let headers = this.lines.map(line => line.line.replace(/\\r?\\n/g, lineEnd)).join(lineEnd) + `${lineEnd}${lineEnd}`;\n\n        if (this.mbox) {\n            headers = this.mbox + lineEnd + headers;\n        }\n\n        if (this.http) {\n            headers = this.http + lineEnd + headers;\n        }\n\n        return Buffer.from(headers, 'binary');\n    }\n\n    _normalizeHeader(key) {\n        return (key || '').toLowerCase().trim();\n    }\n\n    _parseHeaders() {\n        if (!this.headers) {\n            this.lines = [];\n            this.parsed = true;\n            return;\n        }\n\n        let lines = this.headers\n            .toString('binary')\n            .replace(/[\\r\\n]+$/, '')\n            .split(/\\r?\\n/);\n\n        for (let i = lines.length - 1; i >= 0; i--) {\n            let chr = lines[i].charAt(0);\n            if (i && (chr === ' ' || chr === '\\t')) {\n                lines[i - 1] += '\\r\\n' + lines[i];\n                lines.splice(i, 1);\n            } else {\n                let line = lines[i];\n                if (!i && /^From /i.test(line)) {\n                    // mbox file\n                    this.mbox = line;\n                    lines.splice(i, 1);\n                    continue;\n                } else if (!i && /^POST /i.test(line)) {\n                    // HTTP POST request\n                    this.http = line;\n                    lines.splice(i, 1);\n                    continue;\n                }\n                let key = this._normalizeHeader(line.substr(0, line.indexOf(':')));\n                lines[i] = {\n                    key,\n                    line\n                };\n            }\n        }\n\n        this.lines = lines;\n        this.parsed = true;\n    }\n}\n\n// expose to the world\nmodule.exports = Headers;\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/mailsplit/lib/headers.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/mailsplit/lib/message-joiner.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/mailsplit/lib/message-joiner.js ***!
|
|
\******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst Transform = (__webpack_require__(/*! stream */ \"stream\").Transform);\n\nclass MessageJoiner extends Transform {\n constructor() {\n let options = {\n readableObjectMode: false,\n writableObjectMode: true\n };\n super(options);\n }\n\n _transform(obj, encoding, callback) {\n if (Buffer.isBuffer(obj)) {\n this.push(obj);\n } else if (obj.type === 'node') {\n this.push(obj.getHeaders());\n } else if (obj.value) {\n this.push(obj.value);\n }\n return callback();\n }\n\n _flush(callback) {\n return callback();\n }\n}\n\nmodule.exports = MessageJoiner;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvbWFpbHNwbGl0L2xpYi9tZXNzYWdlLWpvaW5lci5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYixrQkFBa0IsdURBQTJCOztBQUU3QztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLFVBQVU7QUFDVjtBQUNBLFVBQVU7QUFDVjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvbWFpbHNwbGl0L2xpYi9tZXNzYWdlLWpvaW5lci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IFRyYW5zZm9ybSA9IHJlcXVpcmUoJ3N0cmVhbScpLlRyYW5zZm9ybTtcblxuY2xhc3MgTWVzc2FnZUpvaW5lciBleHRlbmRzIFRyYW5zZm9ybSB7XG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIGxldCBvcHRpb25zID0ge1xuICAgICAgICAgICAgcmVhZGFibGVPYmplY3RNb2RlOiBmYWxzZSxcbiAgICAgICAgICAgIHdyaXRhYmxlT2JqZWN0TW9kZTogdHJ1ZVxuICAgICAgICB9O1xuICAgICAgICBzdXBlcihvcHRpb25zKTtcbiAgICB9XG5cbiAgICBfdHJhbnNmb3JtKG9iaiwgZW5jb2RpbmcsIGNhbGxiYWNrKSB7XG4gICAgICAgIGlmIChCdWZmZXIuaXNCdWZmZXIob2JqKSkge1xuICAgICAgICAgICAgdGhpcy5wdXNoKG9iaik7XG4gICAgICAgIH0gZWxzZSBpZiAob2JqLnR5cGUgPT09ICdub2RlJykge1xuICAgICAgICAgICAgdGhpcy5wdXNoKG9iai5nZXRIZWFkZXJzKCkpO1xuICAgICAgICB9IGVsc2UgaWYgKG9iai52YWx1ZSkge1xuICAgICAgICAgICAgdGhpcy5wdXNoKG9iai52YWx1ZSk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGNhbGxiYWNrKCk7XG4gICAgfVxuXG4gICAgX2ZsdXNoKGNhbGxiYWNrKSB7XG4gICAgICAgIHJldHVybiBjYWxsYmFjaygpO1xuICAgIH1cbn1cblxubW9kdWxlLmV4cG9ydHMgPSBNZXNzYWdlSm9pbmVyO1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/mailsplit/lib/message-joiner.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/mailsplit/lib/message-splitter.js":
|
|
/*!********************************************************!*\
|
|
!*** ./node_modules/mailsplit/lib/message-splitter.js ***!
|
|
\********************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst Transform = (__webpack_require__(/*! stream */ \"stream\").Transform);\nconst MimeNode = __webpack_require__(/*! ./mime-node */ \"(rsc)/./node_modules/mailsplit/lib/mime-node.js\");\n\nconst MAX_HEAD_SIZE = 1 * 1024 * 1024;\nconst MAX_CHILD_NODES = 1000;\n\nconst HEAD = 0x01;\nconst BODY = 0x02;\n\nclass MessageSplitter extends Transform {\n constructor(config) {\n let options = {\n readableObjectMode: true,\n writableObjectMode: false\n };\n super(options);\n\n this.config = config || {};\n this.maxHeadSize = this.config.maxHeadSize || MAX_HEAD_SIZE;\n this.maxChildNodes = this.config.maxChildNodes || MAX_CHILD_NODES;\n this.tree = [];\n this.nodeCounter = 0;\n this.newNode();\n this.tree.push(this.node);\n this.line = false;\n this.hasFailed = false;\n }\n\n _transform(chunk, encoding, callback) {\n // process line by line\n // find next line ending\n let pos = 0;\n let i = 0;\n let group = {\n type: 'none'\n };\n let groupstart = this.line ? -this.line.length : 0;\n let groupend = 0;\n\n let checkTrailingLinebreak = data => {\n if (data.type === 'body' && data.node.parentNode && data.value && data.value.length) {\n if (data.value[data.value.length - 1] === 0x0a) {\n groupstart--;\n groupend--;\n pos--;\n if (data.value.length > 1 && data.value[data.value.length - 2] === 0x0d) {\n groupstart--;\n groupend--;\n pos--;\n if (groupstart < 0 && !this.line) {\n // store only <CR> as <LF> should be on the positive side\n this.line = Buffer.allocUnsafe(1);\n this.line[0] = 0x0d;\n }\n data.value = data.value.slice(0, data.value.length - 2);\n } else {\n data.value = data.value.slice(0, data.value.length - 1);\n }\n } else if (data.value[data.value.length - 1] === 0x0d) {\n groupstart--;\n groupend--;\n pos--;\n data.value = data.value.slice(0, data.value.length - 1);\n }\n }\n };\n\n let iterateData = () => {\n for (let len = chunk.length; i < len; i++) {\n // find next <LF>\n if (chunk[i] === 0x0a) {\n // line end\n\n let start = Math.max(pos, 0);\n pos = ++i;\n\n return this.processLine(chunk.slice(start, i), false, (err, data, flush) => {\n if (err) {\n this.hasFailed = true;\n return setImmediate(() => callback(err));\n }\n\n if (!data) {\n return setImmediate(iterateData);\n }\n\n if (flush) {\n if (group && group.type !== 'none') {\n if (group.type === 'body' && groupend >= groupstart && group.node.parentNode) {\n // do not include the last line ending for body\n if (chunk[groupend - 1] === 0x0a) {\n groupend--;\n if (groupend >= groupstart && chunk[groupend - 1] === 0x0d) {\n groupend--;\n }\n }\n }\n if (groupstart !== groupend) {\n group.value = chunk.slice(groupstart, groupend);\n if (groupend < i) {\n data.value = chunk.slice(groupend, i);\n }\n }\n this.push(group);\n group = {\n type: 'none'\n };\n groupstart = groupend = i;\n }\n this.push(data);\n groupend = i;\n return setImmediate(iterateData);\n }\n\n if (data.type === group.type) {\n // shift slice end position forward\n groupend = i;\n } else {\n if (group.type === 'body' && groupend >= groupstart && group.node.parentNode) {\n // do not include the last line ending for body\n if (chunk[groupend - 1] === 0x0a) {\n groupend--;\n if (groupend >= groupstart && chunk[groupend - 1] === 0x0d) {\n groupend--;\n }\n }\n }\n\n if (group.type !== 'none' && group.type !== 'node') {\n // we have a previous data/body chunk to output\n if (groupstart !== groupend) {\n group.value = chunk.slice(groupstart, groupend);\n if (group.value && group.value.length) {\n this.push(group);\n group = {\n type: 'none'\n };\n }\n }\n }\n\n if (data.type === 'node') {\n this.push(data);\n groupstart = i;\n groupend = i;\n } else if (groupstart < 0) {\n groupstart = i;\n groupend = i;\n checkTrailingLinebreak(data);\n if (data.value && data.value.length) {\n this.push(data);\n }\n } else {\n // start new body/data chunk\n group = data;\n groupstart = groupend;\n groupend = i;\n }\n }\n return setImmediate(iterateData);\n });\n }\n }\n\n // skip last linebreak for body\n if (pos >= groupstart + 1 && group.type === 'body' && group.node.parentNode) {\n // do not include the last line ending for body\n if (chunk[pos - 1] === 0x0a) {\n pos--;\n if (pos >= groupstart && chunk[pos - 1] === 0x0d) {\n pos--;\n }\n }\n }\n\n if (group.type !== 'none' && group.type !== 'node' && pos > groupstart) {\n // we have a leftover data/body chunk to push out\n group.value = chunk.slice(groupstart, pos);\n\n if (group.value && group.value.length) {\n this.push(group);\n group = {\n type: 'none'\n };\n }\n }\n\n if (pos < chunk.length) {\n if (this.line) {\n this.line = Buffer.concat([this.line, chunk.slice(pos)]);\n } else {\n this.line = chunk.slice(pos);\n }\n }\n callback();\n };\n\n setImmediate(iterateData);\n }\n\n _flush(callback) {\n if (this.hasFailed) {\n return callback();\n }\n this.processLine(false, true, (err, data) => {\n if (err) {\n return setImmediate(() => callback(err));\n }\n if (data && (data.type === 'node' || (data.value && data.value.length))) {\n this.push(data);\n }\n callback();\n });\n }\n\n compareBoundary(line, startpos, boundary) {\n // --{boundary}\\r\\n or --{boundary}--\\r\\n\n if (line.length < boundary.length + 3 + startpos || line.length > boundary.length + 6 + startpos) {\n return false;\n }\n for (let i = 0; i < boundary.length; i++) {\n if (line[i + 2 + startpos] !== boundary[i]) {\n return false;\n }\n }\n\n let pos = 0;\n for (let i = boundary.length + 2 + startpos; i < line.length; i++) {\n let c = line[i];\n if (pos === 0 && (c === 0x0d || c === 0x0a)) {\n // 1: next node\n return 1;\n }\n if (pos === 0 && c !== 0x2d) {\n // expecting \"-\"\n return false;\n }\n if (pos === 1 && c !== 0x2d) {\n // expecting \"-\"\n return false;\n }\n if (pos === 2 && c !== 0x0d && c !== 0x0a) {\n // expecting line terminator, either <CR> or <LF>\n return false;\n }\n if (pos === 3 && c !== 0x0a) {\n // expecting line terminator <LF>\n return false;\n }\n pos++;\n }\n\n // 2: multipart end\n return 2;\n }\n\n checkBoundary(line) {\n let startpos = 0;\n if (line.length >= 1 && (line[0] === 0x0d || line[0] === 0x0a)) {\n startpos++;\n if (line.length >= 2 && (line[0] === 0x0d || line[1] === 0x0a)) {\n startpos++;\n }\n }\n if (line.length < 4 || line[startpos] !== 0x2d || line[startpos + 1] !== 0x2d) {\n // defnitely not a boundary\n return false;\n }\n\n let boundary;\n if (this.node._boundary && (boundary = this.compareBoundary(line, startpos, this.node._boundary))) {\n // 1: next child\n // 2: multipart end\n return boundary;\n }\n\n if (this.node._parentBoundary && (boundary = this.compareBoundary(line, startpos, this.node._parentBoundary))) {\n // 3: next sibling\n // 4: parent end\n return boundary + 2;\n }\n\n return false;\n }\n\n processLine(line, final, next) {\n let flush = false;\n\n if (this.line && line) {\n line = Buffer.concat([this.line, line]);\n this.line = false;\n } else if (this.line && !line) {\n line = this.line;\n this.line = false;\n }\n\n if (!line) {\n line = Buffer.alloc(0);\n }\n\n if (this.nodeCounter > this.maxChildNodes) {\n let err = new Error('Max allowed child nodes exceeded');\n err.code = 'EMAXLEN';\n return next(err);\n }\n\n // we check boundary outside the HEAD/BODY scope as it may appear anywhere\n let boundary = this.checkBoundary(line);\n if (boundary) {\n // reached boundary, switch context\n switch (boundary) {\n case 1:\n // next child\n this.newNode(this.node);\n flush = true;\n break;\n case 2:\n // reached end of children, keep current node\n break;\n case 3: {\n // next sibling\n let parentNode = this.node.parentNode;\n if (parentNode && parentNode.contentType === 'message/rfc822') {\n // special case where immediate parent is an inline message block\n // move up another step\n parentNode = parentNode.parentNode;\n }\n this.newNode(parentNode);\n flush = true;\n break;\n }\n case 4:\n // special case when boundary close a node with only header.\n if (this.node && this.node._headerlen && !this.node.headers) {\n this.node.parseHeaders();\n this.push(this.node);\n }\n // move up\n if (this.tree.length) {\n this.node = this.tree.pop();\n }\n this.state = BODY;\n break;\n }\n\n return next(\n null,\n {\n node: this.node,\n type: 'data',\n value: line\n },\n flush\n );\n }\n\n switch (this.state) {\n case HEAD: {\n this.node.addHeaderChunk(line);\n if (this.node._headerlen > this.maxHeadSize) {\n let err = new Error('Max header size for a MIME node exceeded');\n err.code = 'EMAXLEN';\n return next(err);\n }\n if (final || (line.length === 1 && line[0] === 0x0a) || (line.length === 2 && line[0] === 0x0d && line[1] === 0x0a)) {\n let currentNode = this.node;\n\n currentNode.parseHeaders();\n\n // if the content is attached message then just continue\n if (\n currentNode.contentType === 'message/rfc822' &&\n !this.config.ignoreEmbedded &&\n (!currentNode.encoding || ['7bit', '8bit', 'binary'].includes(currentNode.encoding)) &&\n (this.config.defaultInlineEmbedded ? currentNode.disposition !== 'attachment' : currentNode.disposition === 'inline')\n ) {\n currentNode.messageNode = true;\n this.newNode(currentNode);\n if (currentNode.parentNode) {\n this.node._parentBoundary = currentNode.parentNode._boundary;\n }\n } else {\n if (currentNode.contentType === 'message/rfc822') {\n currentNode.messageNode = false;\n }\n this.state = BODY;\n if (currentNode.multipart && currentNode._boundary) {\n this.tree.push(currentNode);\n }\n }\n\n return next(null, currentNode, flush);\n }\n\n return next();\n }\n case BODY: {\n return next(\n null,\n {\n node: this.node,\n type: this.node.multipart ? 'data' : 'body',\n value: line\n },\n flush\n );\n }\n }\n\n next(null, false);\n }\n\n newNode(parent) {\n this.node = new MimeNode(parent || false, this.config);\n this.state = HEAD;\n this.nodeCounter++;\n }\n}\n\nmodule.exports = MessageSplitter;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/mailsplit/lib/message-splitter.js","mappings":"AAAa;;AAEb,kBAAkB,uDAA2B;AAC7C,iBAAiB,mBAAO,CAAC,oEAAa;;AAEtC;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,yCAAyC,SAAS;AAClD;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,0BAA0B;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,8BAA8B;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA,cAAc,SAAS,WAAW,SAAS;AAC3C;AACA;AACA;AACA,wBAAwB,qBAAqB;AAC7C;AACA;AACA;AACA;;AAEA;AACA,qDAAqD,iBAAiB;AACtE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA","sources":["/home/alma/nextgen/Neah-mail/node_modules/mailsplit/lib/message-splitter.js"],"sourcesContent":["'use strict';\n\nconst Transform = require('stream').Transform;\nconst MimeNode = require('./mime-node');\n\nconst MAX_HEAD_SIZE = 1 * 1024 * 1024;\nconst MAX_CHILD_NODES = 1000;\n\nconst HEAD = 0x01;\nconst BODY = 0x02;\n\nclass MessageSplitter extends Transform {\n    constructor(config) {\n        let options = {\n            readableObjectMode: true,\n            writableObjectMode: false\n        };\n        super(options);\n\n        this.config = config || {};\n        this.maxHeadSize = this.config.maxHeadSize || MAX_HEAD_SIZE;\n        this.maxChildNodes = this.config.maxChildNodes || MAX_CHILD_NODES;\n        this.tree = [];\n        this.nodeCounter = 0;\n        this.newNode();\n        this.tree.push(this.node);\n        this.line = false;\n        this.hasFailed = false;\n    }\n\n    _transform(chunk, encoding, callback) {\n        // process line by line\n        // find next line ending\n        let pos = 0;\n        let i = 0;\n        let group = {\n            type: 'none'\n        };\n        let groupstart = this.line ? -this.line.length : 0;\n        let groupend = 0;\n\n        let checkTrailingLinebreak = data => {\n            if (data.type === 'body' && data.node.parentNode && data.value && data.value.length) {\n                if (data.value[data.value.length - 1] === 0x0a) {\n                    groupstart--;\n                    groupend--;\n                    pos--;\n                    if (data.value.length > 1 && data.value[data.value.length - 2] === 0x0d) {\n                        groupstart--;\n                        groupend--;\n                        pos--;\n                        if (groupstart < 0 && !this.line) {\n                            // store only <CR> as <LF> should be on the positive side\n                            this.line = Buffer.allocUnsafe(1);\n                            this.line[0] = 0x0d;\n                        }\n                        data.value = data.value.slice(0, data.value.length - 2);\n                    } else {\n                        data.value = data.value.slice(0, data.value.length - 1);\n                    }\n                } else if (data.value[data.value.length - 1] === 0x0d) {\n                    groupstart--;\n                    groupend--;\n                    pos--;\n                    data.value = data.value.slice(0, data.value.length - 1);\n                }\n            }\n        };\n\n        let iterateData = () => {\n            for (let len = chunk.length; i < len; i++) {\n                // find next <LF>\n                if (chunk[i] === 0x0a) {\n                    // line end\n\n                    let start = Math.max(pos, 0);\n                    pos = ++i;\n\n                    return this.processLine(chunk.slice(start, i), false, (err, data, flush) => {\n                        if (err) {\n                            this.hasFailed = true;\n                            return setImmediate(() => callback(err));\n                        }\n\n                        if (!data) {\n                            return setImmediate(iterateData);\n                        }\n\n                        if (flush) {\n                            if (group && group.type !== 'none') {\n                                if (group.type === 'body' && groupend >= groupstart && group.node.parentNode) {\n                                    // do not include the last line ending for body\n                                    if (chunk[groupend - 1] === 0x0a) {\n                                        groupend--;\n                                        if (groupend >= groupstart && chunk[groupend - 1] === 0x0d) {\n                                            groupend--;\n                                        }\n                                    }\n                                }\n                                if (groupstart !== groupend) {\n                                    group.value = chunk.slice(groupstart, groupend);\n                                    if (groupend < i) {\n                                        data.value = chunk.slice(groupend, i);\n                                    }\n                                }\n                                this.push(group);\n                                group = {\n                                    type: 'none'\n                                };\n                                groupstart = groupend = i;\n                            }\n                            this.push(data);\n                            groupend = i;\n                            return setImmediate(iterateData);\n                        }\n\n                        if (data.type === group.type) {\n                            // shift slice end position forward\n                            groupend = i;\n                        } else {\n                            if (group.type === 'body' && groupend >= groupstart && group.node.parentNode) {\n                                // do not include the last line ending for body\n                                if (chunk[groupend - 1] === 0x0a) {\n                                    groupend--;\n                                    if (groupend >= groupstart && chunk[groupend - 1] === 0x0d) {\n                                        groupend--;\n                                    }\n                                }\n                            }\n\n                            if (group.type !== 'none' && group.type !== 'node') {\n                                // we have a previous data/body chunk to output\n                                if (groupstart !== groupend) {\n                                    group.value = chunk.slice(groupstart, groupend);\n                                    if (group.value && group.value.length) {\n                                        this.push(group);\n                                        group = {\n                                            type: 'none'\n                                        };\n                                    }\n                                }\n                            }\n\n                            if (data.type === 'node') {\n                                this.push(data);\n                                groupstart = i;\n                                groupend = i;\n                            } else if (groupstart < 0) {\n                                groupstart = i;\n                                groupend = i;\n                                checkTrailingLinebreak(data);\n                                if (data.value && data.value.length) {\n                                    this.push(data);\n                                }\n                            } else {\n                                // start new body/data chunk\n                                group = data;\n                                groupstart = groupend;\n                                groupend = i;\n                            }\n                        }\n                        return setImmediate(iterateData);\n                    });\n                }\n            }\n\n            // skip last linebreak for body\n            if (pos >= groupstart + 1 && group.type === 'body' && group.node.parentNode) {\n                // do not include the last line ending for body\n                if (chunk[pos - 1] === 0x0a) {\n                    pos--;\n                    if (pos >= groupstart && chunk[pos - 1] === 0x0d) {\n                        pos--;\n                    }\n                }\n            }\n\n            if (group.type !== 'none' && group.type !== 'node' && pos > groupstart) {\n                // we have a leftover data/body chunk to push out\n                group.value = chunk.slice(groupstart, pos);\n\n                if (group.value && group.value.length) {\n                    this.push(group);\n                    group = {\n                        type: 'none'\n                    };\n                }\n            }\n\n            if (pos < chunk.length) {\n                if (this.line) {\n                    this.line = Buffer.concat([this.line, chunk.slice(pos)]);\n                } else {\n                    this.line = chunk.slice(pos);\n                }\n            }\n            callback();\n        };\n\n        setImmediate(iterateData);\n    }\n\n    _flush(callback) {\n        if (this.hasFailed) {\n            return callback();\n        }\n        this.processLine(false, true, (err, data) => {\n            if (err) {\n                return setImmediate(() => callback(err));\n            }\n            if (data && (data.type === 'node' || (data.value && data.value.length))) {\n                this.push(data);\n            }\n            callback();\n        });\n    }\n\n    compareBoundary(line, startpos, boundary) {\n        // --{boundary}\\r\\n or --{boundary}--\\r\\n\n        if (line.length < boundary.length + 3 + startpos || line.length > boundary.length + 6 + startpos) {\n            return false;\n        }\n        for (let i = 0; i < boundary.length; i++) {\n            if (line[i + 2 + startpos] !== boundary[i]) {\n                return false;\n            }\n        }\n\n        let pos = 0;\n        for (let i = boundary.length + 2 + startpos; i < line.length; i++) {\n            let c = line[i];\n            if (pos === 0 && (c === 0x0d || c === 0x0a)) {\n                // 1: next node\n                return 1;\n            }\n            if (pos === 0 && c !== 0x2d) {\n                // expecting \"-\"\n                return false;\n            }\n            if (pos === 1 && c !== 0x2d) {\n                // expecting \"-\"\n                return false;\n            }\n            if (pos === 2 && c !== 0x0d && c !== 0x0a) {\n                // expecting line terminator, either <CR> or <LF>\n                return false;\n            }\n            if (pos === 3 && c !== 0x0a) {\n                // expecting line terminator <LF>\n                return false;\n            }\n            pos++;\n        }\n\n        // 2: multipart end\n        return 2;\n    }\n\n    checkBoundary(line) {\n        let startpos = 0;\n        if (line.length >= 1 && (line[0] === 0x0d || line[0] === 0x0a)) {\n            startpos++;\n            if (line.length >= 2 && (line[0] === 0x0d || line[1] === 0x0a)) {\n                startpos++;\n            }\n        }\n        if (line.length < 4 || line[startpos] !== 0x2d || line[startpos + 1] !== 0x2d) {\n            // defnitely not a boundary\n            return false;\n        }\n\n        let boundary;\n        if (this.node._boundary && (boundary = this.compareBoundary(line, startpos, this.node._boundary))) {\n            // 1: next child\n            // 2: multipart end\n            return boundary;\n        }\n\n        if (this.node._parentBoundary && (boundary = this.compareBoundary(line, startpos, this.node._parentBoundary))) {\n            // 3: next sibling\n            // 4: parent end\n            return boundary + 2;\n        }\n\n        return false;\n    }\n\n    processLine(line, final, next) {\n        let flush = false;\n\n        if (this.line && line) {\n            line = Buffer.concat([this.line, line]);\n            this.line = false;\n        } else if (this.line && !line) {\n            line = this.line;\n            this.line = false;\n        }\n\n        if (!line) {\n            line = Buffer.alloc(0);\n        }\n\n        if (this.nodeCounter > this.maxChildNodes) {\n            let err = new Error('Max allowed child nodes exceeded');\n            err.code = 'EMAXLEN';\n            return next(err);\n        }\n\n        // we check boundary outside the HEAD/BODY scope as it may appear anywhere\n        let boundary = this.checkBoundary(line);\n        if (boundary) {\n            // reached boundary, switch context\n            switch (boundary) {\n                case 1:\n                    // next child\n                    this.newNode(this.node);\n                    flush = true;\n                    break;\n                case 2:\n                    // reached end of children, keep current node\n                    break;\n                case 3: {\n                    // next sibling\n                    let parentNode = this.node.parentNode;\n                    if (parentNode && parentNode.contentType === 'message/rfc822') {\n                        // special case where immediate parent is an inline message block\n                        // move up another step\n                        parentNode = parentNode.parentNode;\n                    }\n                    this.newNode(parentNode);\n                    flush = true;\n                    break;\n                }\n                case 4:\n                    // special case when boundary close a node with only header.\n                    if (this.node && this.node._headerlen && !this.node.headers) {\n                        this.node.parseHeaders();\n                        this.push(this.node);\n                    }\n                    // move up\n                    if (this.tree.length) {\n                        this.node = this.tree.pop();\n                    }\n                    this.state = BODY;\n                    break;\n            }\n\n            return next(\n                null,\n                {\n                    node: this.node,\n                    type: 'data',\n                    value: line\n                },\n                flush\n            );\n        }\n\n        switch (this.state) {\n            case HEAD: {\n                this.node.addHeaderChunk(line);\n                if (this.node._headerlen > this.maxHeadSize) {\n                    let err = new Error('Max header size for a MIME node exceeded');\n                    err.code = 'EMAXLEN';\n                    return next(err);\n                }\n                if (final || (line.length === 1 && line[0] === 0x0a) || (line.length === 2 && line[0] === 0x0d && line[1] === 0x0a)) {\n                    let currentNode = this.node;\n\n                    currentNode.parseHeaders();\n\n                    // if the content is attached message then just continue\n                    if (\n                        currentNode.contentType === 'message/rfc822' &&\n                        !this.config.ignoreEmbedded &&\n                        (!currentNode.encoding || ['7bit', '8bit', 'binary'].includes(currentNode.encoding)) &&\n                        (this.config.defaultInlineEmbedded ? currentNode.disposition !== 'attachment' : currentNode.disposition === 'inline')\n                    ) {\n                        currentNode.messageNode = true;\n                        this.newNode(currentNode);\n                        if (currentNode.parentNode) {\n                            this.node._parentBoundary = currentNode.parentNode._boundary;\n                        }\n                    } else {\n                        if (currentNode.contentType === 'message/rfc822') {\n                            currentNode.messageNode = false;\n                        }\n                        this.state = BODY;\n                        if (currentNode.multipart && currentNode._boundary) {\n                            this.tree.push(currentNode);\n                        }\n                    }\n\n                    return next(null, currentNode, flush);\n                }\n\n                return next();\n            }\n            case BODY: {\n                return next(\n                    null,\n                    {\n                        node: this.node,\n                        type: this.node.multipart ? 'data' : 'body',\n                        value: line\n                    },\n                    flush\n                );\n            }\n        }\n\n        next(null, false);\n    }\n\n    newNode(parent) {\n        this.node = new MimeNode(parent || false, this.config);\n        this.state = HEAD;\n        this.nodeCounter++;\n    }\n}\n\nmodule.exports = MessageSplitter;\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/mailsplit/lib/message-splitter.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/mailsplit/lib/mime-node.js":
|
|
/*!*************************************************!*\
|
|
!*** ./node_modules/mailsplit/lib/mime-node.js ***!
|
|
\*************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst Headers = __webpack_require__(/*! ./headers */ \"(rsc)/./node_modules/mailsplit/lib/headers.js\");\nconst libmime = __webpack_require__(/*! libmime */ \"(rsc)/./node_modules/libmime/lib/libmime.js\");\nconst libqp = __webpack_require__(/*! libqp */ \"(rsc)/./node_modules/libqp/lib/libqp.js\");\nconst libbase64 = __webpack_require__(/*! libbase64 */ \"(rsc)/./node_modules/libbase64/lib/libbase64.js\");\nconst PassThrough = (__webpack_require__(/*! stream */ \"stream\").PassThrough);\nconst pathlib = __webpack_require__(/*! path */ \"path\");\n\nclass MimeNode {\n constructor(parentNode, config) {\n this.type = 'node';\n this.root = !parentNode;\n this.parentNode = parentNode;\n\n this._parentBoundary = this.parentNode && this.parentNode._boundary;\n this._headersLines = [];\n this._headerlen = 0;\n\n this._parsedContentType = false;\n this._boundary = false;\n\n this.multipart = false;\n this.encoding = false;\n this.headers = false;\n this.contentType = false;\n this.flowed = false;\n this.delSp = false;\n\n this.config = config || {};\n this.libmime = new libmime.Libmime({ Iconv: this.config.Iconv });\n\n this.parentPartNumber = (parentNode && this.partNr) || [];\n this.partNr = false; // resolved later\n this.childPartNumbers = 0;\n }\n\n getPartNr(provided) {\n if (provided) {\n return []\n .concat(this.partNr || [])\n .filter(nr => !isNaN(nr))\n .concat(provided);\n }\n let childPartNr = ++this.childPartNumbers;\n return []\n .concat(this.partNr || [])\n .filter(nr => !isNaN(nr))\n .concat(childPartNr);\n }\n\n addHeaderChunk(line) {\n if (!line) {\n return;\n }\n this._headersLines.push(line);\n this._headerlen += line.length;\n }\n\n parseHeaders() {\n if (this.headers) {\n return;\n }\n this.headers = new Headers(Buffer.concat(this._headersLines, this._headerlen), this.config);\n\n this._parsedContentDisposition = this.libmime.parseHeaderValue(this.headers.getFirst('Content-Disposition'));\n\n // if content-type is missing default to plaintext\n let contentHeader;\n if (this.headers.get('Content-Type').length) {\n contentHeader = this.headers.getFirst('Content-Type');\n } else {\n if (this._parsedContentDisposition.params.filename) {\n let extension = pathlib.parse(this._parsedContentDisposition.params.filename).ext.replace(/^\\./, '');\n if (extension) {\n contentHeader = libmime.detectMimeType(extension);\n }\n }\n if (!contentHeader) {\n if (/^attachment$/i.test(this._parsedContentDisposition.value)) {\n contentHeader = 'application/octet-stream';\n } else {\n contentHeader = 'text/plain';\n }\n }\n }\n\n this._parsedContentType = this.libmime.parseHeaderValue(contentHeader);\n\n this.encoding = this.headers\n .getFirst('Content-Transfer-Encoding')\n .replace(/\\(.*\\)/g, '')\n .toLowerCase()\n .trim();\n this.contentType = (this._parsedContentType.value || '').toLowerCase().trim() || false;\n this.charset = this._parsedContentType.params.charset || false;\n this.disposition = (this._parsedContentDisposition.value || '').toLowerCase().trim() || false;\n\n // fix invalidly encoded disposition values\n if (this.disposition) {\n try {\n this.disposition = this.libmime.decodeWords(this.disposition);\n } catch (E) {\n // failed to parse disposition, keep as is (most probably an unknown charset is used)\n }\n }\n\n this.filename = this._parsedContentDisposition.params.filename || this._parsedContentType.params.name || false;\n\n if (this._parsedContentType.params.format && this._parsedContentType.params.format.toLowerCase().trim() === 'flowed') {\n this.flowed = true;\n if (this._parsedContentType.params.delsp && this._parsedContentType.params.delsp.toLowerCase().trim() === 'yes') {\n this.delSp = true;\n }\n }\n\n if (this.filename) {\n try {\n this.filename = this.libmime.decodeWords(this.filename);\n } catch (E) {\n // failed to parse filename, keep as is (most probably an unknown charset is used)\n }\n }\n\n this.multipart =\n (this.contentType &&\n this.contentType.substr(0, this.contentType.indexOf('/')) === 'multipart' &&\n this.contentType.substr(this.contentType.indexOf('/') + 1)) ||\n false;\n this._boundary = (this._parsedContentType.params.boundary && Buffer.from(this._parsedContentType.params.boundary)) || false;\n\n this.rfc822 = this.contentType === 'message/rfc822';\n\n if (!this.parentNode || this.parentNode.rfc822) {\n this.partNr = this.parentNode ? this.parentNode.getPartNr('TEXT') : ['TEXT'];\n } else {\n this.partNr = this.parentNode ? this.parentNode.getPartNr() : [];\n }\n }\n\n getHeaders() {\n if (!this.headers) {\n this.parseHeaders();\n }\n return this.headers.build();\n }\n\n setContentType(contentType) {\n if (!this.headers) {\n this.parseHeaders();\n }\n\n contentType = (contentType || '').toLowerCase().trim();\n if (contentType) {\n this._parsedContentType.value = contentType;\n }\n\n if (!this.flowed && this._parsedContentType.params.format) {\n delete this._parsedContentType.params.format;\n }\n\n if (!this.delSp && this._parsedContentType.params.delsp) {\n delete this._parsedContentType.params.delsp;\n }\n\n this.headers.update('Content-Type', this.libmime.buildHeaderValue(this._parsedContentType));\n }\n\n setCharset(charset) {\n if (!this.headers) {\n this.parseHeaders();\n }\n\n charset = (charset || '').toLowerCase().trim();\n\n if (charset === 'ascii') {\n charset = '';\n }\n\n if (!charset) {\n if (!this._parsedContentType.value) {\n // nothing to set or update\n return;\n }\n delete this._parsedContentType.params.charset;\n } else {\n this._parsedContentType.params.charset = charset;\n }\n\n if (!this._parsedContentType.value) {\n this._parsedContentType.value = 'text/plain';\n }\n\n this.headers.update('Content-Type', this.libmime.buildHeaderValue(this._parsedContentType));\n }\n\n setFilename(filename) {\n if (!this.headers) {\n this.parseHeaders();\n }\n\n this.filename = (filename || '').toLowerCase().trim();\n\n if (this._parsedContentType.params.name) {\n delete this._parsedContentType.params.name;\n this.headers.update('Content-Type', this.libmime.buildHeaderValue(this._parsedContentType));\n }\n\n if (!this.filename) {\n if (!this._parsedContentDisposition.value) {\n // nothing to set or update\n return;\n }\n delete this._parsedContentDisposition.params.filename;\n } else {\n this._parsedContentDisposition.params.filename = this.filename;\n }\n\n if (!this._parsedContentDisposition.value) {\n this._parsedContentDisposition.value = 'attachment';\n }\n\n this.headers.update('Content-Disposition', this.libmime.buildHeaderValue(this._parsedContentDisposition));\n }\n\n getDecoder() {\n if (!this.headers) {\n this.parseHeaders();\n }\n\n switch (this.encoding) {\n case 'base64':\n return new libbase64.Decoder();\n case 'quoted-printable':\n return new libqp.Decoder();\n default:\n return new PassThrough();\n }\n }\n\n getEncoder(encoding) {\n if (!this.headers) {\n this.parseHeaders();\n }\n\n encoding = (encoding || '').toString().toLowerCase().trim();\n\n if (encoding && encoding !== this.encoding) {\n this.headers.update('Content-Transfer-Encoding', encoding);\n } else {\n encoding = this.encoding;\n }\n\n switch (encoding) {\n case 'base64':\n return new libbase64.Encoder();\n case 'quoted-printable':\n return new libqp.Encoder();\n default:\n return new PassThrough();\n }\n }\n}\n\nmodule.exports = MimeNode;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/mailsplit/lib/mime-node.js","mappings":"AAAa;;AAEb,gBAAgB,mBAAO,CAAC,gEAAW;AACnC,gBAAgB,mBAAO,CAAC,4DAAS;AACjC,cAAc,mBAAO,CAAC,sDAAO;AAC7B,kBAAkB,mBAAO,CAAC,kEAAW;AACrC,oBAAoB,yDAA6B;AACjD,gBAAgB,mBAAO,CAAC,kBAAM;;AAE9B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,6CAA6C,0BAA0B;;AAEvE;AACA,6BAA6B;AAC7B;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,UAAU;AACV;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,UAAU;AACV;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA","sources":["/home/alma/nextgen/Neah-mail/node_modules/mailsplit/lib/mime-node.js"],"sourcesContent":["'use strict';\n\nconst Headers = require('./headers');\nconst libmime = require('libmime');\nconst libqp = require('libqp');\nconst libbase64 = require('libbase64');\nconst PassThrough = require('stream').PassThrough;\nconst pathlib = require('path');\n\nclass MimeNode {\n    constructor(parentNode, config) {\n        this.type = 'node';\n        this.root = !parentNode;\n        this.parentNode = parentNode;\n\n        this._parentBoundary = this.parentNode && this.parentNode._boundary;\n        this._headersLines = [];\n        this._headerlen = 0;\n\n        this._parsedContentType = false;\n        this._boundary = false;\n\n        this.multipart = false;\n        this.encoding = false;\n        this.headers = false;\n        this.contentType = false;\n        this.flowed = false;\n        this.delSp = false;\n\n        this.config = config || {};\n        this.libmime = new libmime.Libmime({ Iconv: this.config.Iconv });\n\n        this.parentPartNumber = (parentNode && this.partNr) || [];\n        this.partNr = false; // resolved later\n        this.childPartNumbers = 0;\n    }\n\n    getPartNr(provided) {\n        if (provided) {\n            return []\n                .concat(this.partNr || [])\n                .filter(nr => !isNaN(nr))\n                .concat(provided);\n        }\n        let childPartNr = ++this.childPartNumbers;\n        return []\n            .concat(this.partNr || [])\n            .filter(nr => !isNaN(nr))\n            .concat(childPartNr);\n    }\n\n    addHeaderChunk(line) {\n        if (!line) {\n            return;\n        }\n        this._headersLines.push(line);\n        this._headerlen += line.length;\n    }\n\n    parseHeaders() {\n        if (this.headers) {\n            return;\n        }\n        this.headers = new Headers(Buffer.concat(this._headersLines, this._headerlen), this.config);\n\n        this._parsedContentDisposition = this.libmime.parseHeaderValue(this.headers.getFirst('Content-Disposition'));\n\n        // if content-type is missing default to plaintext\n        let contentHeader;\n        if (this.headers.get('Content-Type').length) {\n            contentHeader = this.headers.getFirst('Content-Type');\n        } else {\n            if (this._parsedContentDisposition.params.filename) {\n                let extension = pathlib.parse(this._parsedContentDisposition.params.filename).ext.replace(/^\\./, '');\n                if (extension) {\n                    contentHeader = libmime.detectMimeType(extension);\n                }\n            }\n            if (!contentHeader) {\n                if (/^attachment$/i.test(this._parsedContentDisposition.value)) {\n                    contentHeader = 'application/octet-stream';\n                } else {\n                    contentHeader = 'text/plain';\n                }\n            }\n        }\n\n        this._parsedContentType = this.libmime.parseHeaderValue(contentHeader);\n\n        this.encoding = this.headers\n            .getFirst('Content-Transfer-Encoding')\n            .replace(/\\(.*\\)/g, '')\n            .toLowerCase()\n            .trim();\n        this.contentType = (this._parsedContentType.value || '').toLowerCase().trim() || false;\n        this.charset = this._parsedContentType.params.charset || false;\n        this.disposition = (this._parsedContentDisposition.value || '').toLowerCase().trim() || false;\n\n        // fix invalidly encoded disposition values\n        if (this.disposition) {\n            try {\n                this.disposition = this.libmime.decodeWords(this.disposition);\n            } catch (E) {\n                // failed to parse disposition, keep as is (most probably an unknown charset is used)\n            }\n        }\n\n        this.filename = this._parsedContentDisposition.params.filename || this._parsedContentType.params.name || false;\n\n        if (this._parsedContentType.params.format && this._parsedContentType.params.format.toLowerCase().trim() === 'flowed') {\n            this.flowed = true;\n            if (this._parsedContentType.params.delsp && this._parsedContentType.params.delsp.toLowerCase().trim() === 'yes') {\n                this.delSp = true;\n            }\n        }\n\n        if (this.filename) {\n            try {\n                this.filename = this.libmime.decodeWords(this.filename);\n            } catch (E) {\n                // failed to parse filename, keep as is (most probably an unknown charset is used)\n            }\n        }\n\n        this.multipart =\n            (this.contentType &&\n                this.contentType.substr(0, this.contentType.indexOf('/')) === 'multipart' &&\n                this.contentType.substr(this.contentType.indexOf('/') + 1)) ||\n            false;\n        this._boundary = (this._parsedContentType.params.boundary && Buffer.from(this._parsedContentType.params.boundary)) || false;\n\n        this.rfc822 = this.contentType === 'message/rfc822';\n\n        if (!this.parentNode || this.parentNode.rfc822) {\n            this.partNr = this.parentNode ? this.parentNode.getPartNr('TEXT') : ['TEXT'];\n        } else {\n            this.partNr = this.parentNode ? this.parentNode.getPartNr() : [];\n        }\n    }\n\n    getHeaders() {\n        if (!this.headers) {\n            this.parseHeaders();\n        }\n        return this.headers.build();\n    }\n\n    setContentType(contentType) {\n        if (!this.headers) {\n            this.parseHeaders();\n        }\n\n        contentType = (contentType || '').toLowerCase().trim();\n        if (contentType) {\n            this._parsedContentType.value = contentType;\n        }\n\n        if (!this.flowed && this._parsedContentType.params.format) {\n            delete this._parsedContentType.params.format;\n        }\n\n        if (!this.delSp && this._parsedContentType.params.delsp) {\n            delete this._parsedContentType.params.delsp;\n        }\n\n        this.headers.update('Content-Type', this.libmime.buildHeaderValue(this._parsedContentType));\n    }\n\n    setCharset(charset) {\n        if (!this.headers) {\n            this.parseHeaders();\n        }\n\n        charset = (charset || '').toLowerCase().trim();\n\n        if (charset === 'ascii') {\n            charset = '';\n        }\n\n        if (!charset) {\n            if (!this._parsedContentType.value) {\n                // nothing to set or update\n                return;\n            }\n            delete this._parsedContentType.params.charset;\n        } else {\n            this._parsedContentType.params.charset = charset;\n        }\n\n        if (!this._parsedContentType.value) {\n            this._parsedContentType.value = 'text/plain';\n        }\n\n        this.headers.update('Content-Type', this.libmime.buildHeaderValue(this._parsedContentType));\n    }\n\n    setFilename(filename) {\n        if (!this.headers) {\n            this.parseHeaders();\n        }\n\n        this.filename = (filename || '').toLowerCase().trim();\n\n        if (this._parsedContentType.params.name) {\n            delete this._parsedContentType.params.name;\n            this.headers.update('Content-Type', this.libmime.buildHeaderValue(this._parsedContentType));\n        }\n\n        if (!this.filename) {\n            if (!this._parsedContentDisposition.value) {\n                // nothing to set or update\n                return;\n            }\n            delete this._parsedContentDisposition.params.filename;\n        } else {\n            this._parsedContentDisposition.params.filename = this.filename;\n        }\n\n        if (!this._parsedContentDisposition.value) {\n            this._parsedContentDisposition.value = 'attachment';\n        }\n\n        this.headers.update('Content-Disposition', this.libmime.buildHeaderValue(this._parsedContentDisposition));\n    }\n\n    getDecoder() {\n        if (!this.headers) {\n            this.parseHeaders();\n        }\n\n        switch (this.encoding) {\n            case 'base64':\n                return new libbase64.Decoder();\n            case 'quoted-printable':\n                return new libqp.Decoder();\n            default:\n                return new PassThrough();\n        }\n    }\n\n    getEncoder(encoding) {\n        if (!this.headers) {\n            this.parseHeaders();\n        }\n\n        encoding = (encoding || '').toString().toLowerCase().trim();\n\n        if (encoding && encoding !== this.encoding) {\n            this.headers.update('Content-Transfer-Encoding', encoding);\n        } else {\n            encoding = this.encoding;\n        }\n\n        switch (encoding) {\n            case 'base64':\n                return new libbase64.Encoder();\n            case 'quoted-printable':\n                return new libqp.Encoder();\n            default:\n                return new PassThrough();\n        }\n    }\n}\n\nmodule.exports = MimeNode;\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/mailsplit/lib/mime-node.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/mailsplit/lib/node-rewriter.js":
|
|
/*!*****************************************************!*\
|
|
!*** ./node_modules/mailsplit/lib/node-rewriter.js ***!
|
|
\*****************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\n// Helper class to rewrite nodes with specific mime type\n\nconst Transform = (__webpack_require__(/*! stream */ \"stream\").Transform);\nconst FlowedDecoder = __webpack_require__(/*! ./flowed-decoder */ \"(rsc)/./node_modules/mailsplit/lib/flowed-decoder.js\");\n\n/**\n * NodeRewriter Transform stream. Updates content for all nodes with specified mime type\n *\n * @constructor\n * @param {String} mimeType Define the Mime-Type to look for\n * @param {Function} rewriteAction Function to run with the node content\n */\nclass NodeRewriter extends Transform {\n constructor(filterFunc, rewriteAction) {\n let options = {\n readableObjectMode: true,\n writableObjectMode: true\n };\n super(options);\n\n this.filterFunc = filterFunc;\n this.rewriteAction = rewriteAction;\n\n this.decoder = false;\n this.encoder = false;\n this.continue = false;\n }\n\n _transform(data, encoding, callback) {\n this.processIncoming(data, callback);\n }\n\n _flush(callback) {\n if (this.decoder) {\n // emit an empty node just in case there is pending data to end\n return this.processIncoming(\n {\n type: 'none'\n },\n callback\n );\n }\n return callback();\n }\n\n processIncoming(data, callback) {\n if (this.decoder && data.type === 'body') {\n // data to parse\n if (!this.decoder.write(data.value)) {\n return this.decoder.once('drain', callback);\n } else {\n return callback();\n }\n } else if (this.decoder && data.type !== 'body') {\n // stop decoding.\n // we can not process the current data chunk as we need to wait until\n // the parsed data is completely processed, so we store a reference to the\n // continue callback\n this.continue = () => {\n this.continue = false;\n this.decoder = false;\n this.encoder = false;\n this.processIncoming(data, callback);\n };\n return this.decoder.end();\n } else if (data.type === 'node' && this.filterFunc(data)) {\n // found matching node, create new handler\n this.emit('node', this.createDecodePair(data));\n } else if (this.readable && data.type !== 'none') {\n // we don't care about this data, just pass it over to the joiner\n this.push(data);\n }\n callback();\n }\n\n createDecodePair(node) {\n this.decoder = node.getDecoder();\n\n if (['base64', 'quoted-printable'].includes(node.encoding)) {\n this.encoder = node.getEncoder();\n } else {\n this.encoder = node.getEncoder('quoted-printable');\n }\n\n let lastByte = false;\n\n let decoder = this.decoder;\n let encoder = this.encoder;\n let firstChunk = true;\n decoder.$reading = false;\n\n let readFromEncoder = () => {\n decoder.$reading = true;\n\n let data = encoder.read();\n if (data === null) {\n decoder.$reading = false;\n return;\n }\n\n if (firstChunk) {\n firstChunk = false;\n if (this.readable) {\n this.push(node);\n if (node.type === 'body') {\n lastByte = node.value && node.value.length && node.value[node.value.length - 1];\n }\n }\n }\n\n let writeMore = true;\n if (this.readable) {\n writeMore = this.push({\n node,\n type: 'body',\n value: data\n });\n lastByte = data && data.length && data[data.length - 1];\n }\n\n if (writeMore) {\n return setImmediate(readFromEncoder);\n } else {\n encoder.pause();\n // no idea how to catch drain? use timeout for now as poor man's substitute\n // this.once('drain', () => encoder.resume());\n setTimeout(() => {\n encoder.resume();\n setImmediate(readFromEncoder);\n }, 100);\n }\n };\n\n encoder.on('readable', () => {\n if (!decoder.$reading) {\n return readFromEncoder();\n }\n });\n\n encoder.on('end', () => {\n if (firstChunk) {\n firstChunk = false;\n if (this.readable) {\n this.push(node);\n if (node.type === 'body') {\n lastByte = node.value && node.value.length && node.value[node.value.length - 1];\n }\n }\n }\n\n if (lastByte !== 0x0a) {\n // make sure there is a terminating line break\n this.push({\n node,\n type: 'body',\n value: Buffer.from([0x0a])\n });\n }\n\n if (this.continue) {\n return this.continue();\n }\n });\n\n if (/^text\\//.test(node.contentType) && node.flowed) {\n // text/plain; format=flowed is a special case\n let flowDecoder = decoder;\n decoder = new FlowedDecoder({\n delSp: node.delSp,\n encoding: node.encoding\n });\n flowDecoder.on('error', err => {\n decoder.emit('error', err);\n });\n flowDecoder.pipe(decoder);\n\n // we don't know what kind of data we are going to get, does it comply with the\n // requirements of format=flowed, so we just cancel it\n node.flowed = false;\n node.delSp = false;\n node.setContentType();\n }\n\n return {\n node,\n decoder,\n encoder\n };\n }\n}\n\nmodule.exports = NodeRewriter;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/mailsplit/lib/node-rewriter.js","mappings":"AAAa;;AAEb;;AAEA,kBAAkB,uDAA2B;AAC7C,sBAAsB,mBAAO,CAAC,8EAAkB;;AAEhD;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,UAAU;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,UAAU;AACV;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;;AAEA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;;AAEA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;;AAEA;AACA;AACA;AACA,SAAS;;AAET;AACA,2BAA2B;AAC3B;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,aAAa;AACb;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA","sources":["/home/alma/nextgen/Neah-mail/node_modules/mailsplit/lib/node-rewriter.js"],"sourcesContent":["'use strict';\n\n// Helper class to rewrite nodes with specific mime type\n\nconst Transform = require('stream').Transform;\nconst FlowedDecoder = require('./flowed-decoder');\n\n/**\n * NodeRewriter Transform stream. Updates content for all nodes with specified mime type\n *\n * @constructor\n * @param {String} mimeType Define the Mime-Type to look for\n * @param {Function} rewriteAction Function to run with the node content\n */\nclass NodeRewriter extends Transform {\n    constructor(filterFunc, rewriteAction) {\n        let options = {\n            readableObjectMode: true,\n            writableObjectMode: true\n        };\n        super(options);\n\n        this.filterFunc = filterFunc;\n        this.rewriteAction = rewriteAction;\n\n        this.decoder = false;\n        this.encoder = false;\n        this.continue = false;\n    }\n\n    _transform(data, encoding, callback) {\n        this.processIncoming(data, callback);\n    }\n\n    _flush(callback) {\n        if (this.decoder) {\n            // emit an empty node just in case there is pending data to end\n            return this.processIncoming(\n                {\n                    type: 'none'\n                },\n                callback\n            );\n        }\n        return callback();\n    }\n\n    processIncoming(data, callback) {\n        if (this.decoder && data.type === 'body') {\n            // data to parse\n            if (!this.decoder.write(data.value)) {\n                return this.decoder.once('drain', callback);\n            } else {\n                return callback();\n            }\n        } else if (this.decoder && data.type !== 'body') {\n            // stop decoding.\n            // we can not process the current data chunk as we need to wait until\n            // the parsed data is completely processed, so we store a reference to the\n            // continue callback\n            this.continue = () => {\n                this.continue = false;\n                this.decoder = false;\n                this.encoder = false;\n                this.processIncoming(data, callback);\n            };\n            return this.decoder.end();\n        } else if (data.type === 'node' && this.filterFunc(data)) {\n            // found matching node, create new handler\n            this.emit('node', this.createDecodePair(data));\n        } else if (this.readable && data.type !== 'none') {\n            // we don't care about this data, just pass it over to the joiner\n            this.push(data);\n        }\n        callback();\n    }\n\n    createDecodePair(node) {\n        this.decoder = node.getDecoder();\n\n        if (['base64', 'quoted-printable'].includes(node.encoding)) {\n            this.encoder = node.getEncoder();\n        } else {\n            this.encoder = node.getEncoder('quoted-printable');\n        }\n\n        let lastByte = false;\n\n        let decoder = this.decoder;\n        let encoder = this.encoder;\n        let firstChunk = true;\n        decoder.$reading = false;\n\n        let readFromEncoder = () => {\n            decoder.$reading = true;\n\n            let data = encoder.read();\n            if (data === null) {\n                decoder.$reading = false;\n                return;\n            }\n\n            if (firstChunk) {\n                firstChunk = false;\n                if (this.readable) {\n                    this.push(node);\n                    if (node.type === 'body') {\n                        lastByte = node.value && node.value.length && node.value[node.value.length - 1];\n                    }\n                }\n            }\n\n            let writeMore = true;\n            if (this.readable) {\n                writeMore = this.push({\n                    node,\n                    type: 'body',\n                    value: data\n                });\n                lastByte = data && data.length && data[data.length - 1];\n            }\n\n            if (writeMore) {\n                return setImmediate(readFromEncoder);\n            } else {\n                encoder.pause();\n                // no idea how to catch drain? use timeout for now as poor man's substitute\n                // this.once('drain', () => encoder.resume());\n                setTimeout(() => {\n                    encoder.resume();\n                    setImmediate(readFromEncoder);\n                }, 100);\n            }\n        };\n\n        encoder.on('readable', () => {\n            if (!decoder.$reading) {\n                return readFromEncoder();\n            }\n        });\n\n        encoder.on('end', () => {\n            if (firstChunk) {\n                firstChunk = false;\n                if (this.readable) {\n                    this.push(node);\n                    if (node.type === 'body') {\n                        lastByte = node.value && node.value.length && node.value[node.value.length - 1];\n                    }\n                }\n            }\n\n            if (lastByte !== 0x0a) {\n                // make sure there is a terminating line break\n                this.push({\n                    node,\n                    type: 'body',\n                    value: Buffer.from([0x0a])\n                });\n            }\n\n            if (this.continue) {\n                return this.continue();\n            }\n        });\n\n        if (/^text\\//.test(node.contentType) && node.flowed) {\n            // text/plain; format=flowed is a special case\n            let flowDecoder = decoder;\n            decoder = new FlowedDecoder({\n                delSp: node.delSp,\n                encoding: node.encoding\n            });\n            flowDecoder.on('error', err => {\n                decoder.emit('error', err);\n            });\n            flowDecoder.pipe(decoder);\n\n            // we don't know what kind of data we are going to get, does it comply with the\n            // requirements of format=flowed, so we just cancel it\n            node.flowed = false;\n            node.delSp = false;\n            node.setContentType();\n        }\n\n        return {\n            node,\n            decoder,\n            encoder\n        };\n    }\n}\n\nmodule.exports = NodeRewriter;\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/mailsplit/lib/node-rewriter.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/mailsplit/lib/node-streamer.js":
|
|
/*!*****************************************************!*\
|
|
!*** ./node_modules/mailsplit/lib/node-streamer.js ***!
|
|
\*****************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\n// Helper class to rewrite nodes with specific mime type\n\nconst Transform = (__webpack_require__(/*! stream */ \"stream\").Transform);\nconst FlowedDecoder = __webpack_require__(/*! ./flowed-decoder */ \"(rsc)/./node_modules/mailsplit/lib/flowed-decoder.js\");\n\n/**\n * NodeRewriter Transform stream. Updates content for all nodes with specified mime type\n *\n * @constructor\n * @param {String} mimeType Define the Mime-Type to look for\n * @param {Function} streamAction Function to run with the node content\n */\nclass NodeStreamer extends Transform {\n constructor(filterFunc, streamAction) {\n let options = {\n readableObjectMode: true,\n writableObjectMode: true\n };\n super(options);\n\n this.filterFunc = filterFunc;\n this.streamAction = streamAction;\n\n this.decoder = false;\n this.canContinue = false;\n this.continue = false;\n }\n\n _transform(data, encoding, callback) {\n this.processIncoming(data, callback);\n }\n\n _flush(callback) {\n if (this.decoder) {\n // emit an empty node just in case there is pending data to end\n return this.processIncoming(\n {\n type: 'none'\n },\n callback\n );\n }\n return callback();\n }\n\n processIncoming(data, callback) {\n if (this.decoder && data.type === 'body') {\n // data to parse\n this.push(data);\n if (!this.decoder.write(data.value)) {\n return this.decoder.once('drain', callback);\n } else {\n return callback();\n }\n } else if (this.decoder && data.type !== 'body') {\n // stop decoding.\n // we can not process the current data chunk as we need to wait until\n // the parsed data is completely processed, so we store a reference to the\n // continue callback\n\n let doContinue = () => {\n this.continue = false;\n this.decoder = false;\n this.canContinue = false;\n this.processIncoming(data, callback);\n };\n\n if (this.canContinue) {\n setImmediate(doContinue);\n } else {\n this.continue = () => doContinue();\n }\n\n return this.decoder.end();\n } else if (data.type === 'node' && this.filterFunc(data)) {\n this.push(data);\n // found matching node, create new handler\n this.emit('node', this.createDecoder(data));\n } else if (this.readable && data.type !== 'none') {\n // we don't care about this data, just pass it over to the joiner\n this.push(data);\n }\n callback();\n }\n\n createDecoder(node) {\n this.decoder = node.getDecoder();\n\n let decoder = this.decoder;\n decoder.$reading = false;\n\n if (/^text\\//.test(node.contentType) && node.flowed) {\n let flowDecoder = decoder;\n decoder = new FlowedDecoder({\n delSp: node.delSp\n });\n flowDecoder.on('error', err => {\n decoder.emit('error', err);\n });\n flowDecoder.pipe(decoder);\n }\n\n return {\n node,\n decoder,\n done: () => {\n if (typeof this.continue === 'function') {\n // called once input stream is processed\n this.continue();\n } else {\n // called before input stream is processed\n this.canContinue = true;\n }\n }\n };\n }\n}\n\nmodule.exports = NodeStreamer;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvbWFpbHNwbGl0L2xpYi9ub2RlLXN0cmVhbWVyLmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViOztBQUVBLGtCQUFrQix1REFBMkI7QUFDN0Msc0JBQXNCLG1CQUFPLENBQUMsOEVBQWtCOztBQUVoRDtBQUNBO0FBQ0E7QUFDQTtBQUNBLFdBQVcsUUFBUTtBQUNuQixXQUFXLFVBQVU7QUFDckI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxpQkFBaUI7QUFDakI7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxjQUFjO0FBQ2Q7QUFDQTtBQUNBLFVBQVU7QUFDVjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLGNBQWM7QUFDZDtBQUNBOztBQUVBO0FBQ0EsVUFBVTtBQUNWO0FBQ0E7QUFDQTtBQUNBLFVBQVU7QUFDVjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxrQkFBa0I7QUFDbEI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL21haWxzcGxpdC9saWIvbm9kZS1zdHJlYW1lci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbi8vIEhlbHBlciBjbGFzcyB0byByZXdyaXRlIG5vZGVzIHdpdGggc3BlY2lmaWMgbWltZSB0eXBlXG5cbmNvbnN0IFRyYW5zZm9ybSA9IHJlcXVpcmUoJ3N0cmVhbScpLlRyYW5zZm9ybTtcbmNvbnN0IEZsb3dlZERlY29kZXIgPSByZXF1aXJlKCcuL2Zsb3dlZC1kZWNvZGVyJyk7XG5cbi8qKlxuICogTm9kZVJld3JpdGVyIFRyYW5zZm9ybSBzdHJlYW0uIFVwZGF0ZXMgY29udGVudCBmb3IgYWxsIG5vZGVzIHdpdGggc3BlY2lmaWVkIG1pbWUgdHlwZVxuICpcbiAqIEBjb25zdHJ1Y3RvclxuICogQHBhcmFtIHtTdHJpbmd9IG1pbWVUeXBlIERlZmluZSB0aGUgTWltZS1UeXBlIHRvIGxvb2sgZm9yXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBzdHJlYW1BY3Rpb24gRnVuY3Rpb24gdG8gcnVuIHdpdGggdGhlIG5vZGUgY29udGVudFxuICovXG5jbGFzcyBOb2RlU3RyZWFtZXIgZXh0ZW5kcyBUcmFuc2Zvcm0ge1xuICAgIGNvbnN0cnVjdG9yKGZpbHRlckZ1bmMsIHN0cmVhbUFjdGlvbikge1xuICAgICAgICBsZXQgb3B0aW9ucyA9IHtcbiAgICAgICAgICAgIHJlYWRhYmxlT2JqZWN0TW9kZTogdHJ1ZSxcbiAgICAgICAgICAgIHdyaXRhYmxlT2JqZWN0TW9kZTogdHJ1ZVxuICAgICAgICB9O1xuICAgICAgICBzdXBlcihvcHRpb25zKTtcblxuICAgICAgICB0aGlzLmZpbHRlckZ1bmMgPSBmaWx0ZXJGdW5jO1xuICAgICAgICB0aGlzLnN0cmVhbUFjdGlvbiA9IHN0cmVhbUFjdGlvbjtcblxuICAgICAgICB0aGlzLmRlY29kZXIgPSBmYWxzZTtcbiAgICAgICAgdGhpcy5jYW5Db250aW51ZSA9IGZhbHNlO1xuICAgICAgICB0aGlzLmNvbnRpbnVlID0gZmFsc2U7XG4gICAgfVxuXG4gICAgX3RyYW5zZm9ybShkYXRhLCBlbmNvZGluZywgY2FsbGJhY2spIHtcbiAgICAgICAgdGhpcy5wcm9jZXNzSW5jb21pbmcoZGF0YSwgY2FsbGJhY2spO1xuICAgIH1cblxuICAgIF9mbHVzaChjYWxsYmFjaykge1xuICAgICAgICBpZiAodGhpcy5kZWNvZGVyKSB7XG4gICAgICAgICAgICAvLyBlbWl0IGFuIGVtcHR5IG5vZGUganVzdCBpbiBjYXNlIHRoZXJlIGlzIHBlbmRpbmcgZGF0YSB0byBlbmRcbiAgICAgICAgICAgIHJldHVybiB0aGlzLnByb2Nlc3NJbmNvbWluZyhcbiAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICAgIHR5cGU6ICdub25lJ1xuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgY2FsbGJhY2tcbiAgICAgICAgICAgICk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGNhbGxiYWNrKCk7XG4gICAgfVxuXG4gICAgcHJvY2Vzc0luY29taW5nKGRhdGEsIGNhbGxiYWNrKSB7XG4gICAgICAgIGlmICh0aGlzLmRlY29kZXIgJiYgZGF0YS50eXBlID09PSAnYm9keScpIHtcbiAgICAgICAgICAgIC8vIGRhdGEgdG8gcGFyc2VcbiAgICAgICAgICAgIHRoaXMucHVzaChkYXRhKTtcbiAgICAgICAgICAgIGlmICghdGhpcy5kZWNvZGVyLndyaXRlKGRhdGEudmFsdWUpKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHRoaXMuZGVjb2Rlci5vbmNlKCdkcmFpbicsIGNhbGxiYWNrKTtcbiAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIGNhbGxiYWNrKCk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH0gZWxzZSBpZiAodGhpcy5kZWNvZGVyICYmIGRhdGEudHlwZSAhPT0gJ2JvZHknKSB7XG4gICAgICAgICAgICAvLyBzdG9wIGRlY29kaW5nLlxuICAgICAgICAgICAgLy8gd2UgY2FuIG5vdCBwcm9jZXNzIHRoZSBjdXJyZW50IGRhdGEgY2h1bmsgYXMgd2UgbmVlZCB0byB3YWl0IHVudGlsXG4gICAgICAgICAgICAvLyB0aGUgcGFyc2VkIGRhdGEgaXMgY29tcGxldGVseSBwcm9jZXNzZWQsIHNvIHdlIHN0b3JlIGEgcmVmZXJlbmNlIHRvIHRoZVxuICAgICAgICAgICAgLy8gY29udGludWUgY2FsbGJhY2tcblxuICAgICAgICAgICAgbGV0IGRvQ29udGludWUgPSAoKSA9PiB7XG4gICAgICAgICAgICAgICAgdGhpcy5jb250aW51ZSA9IGZhbHNlO1xuICAgICAgICAgICAgICAgIHRoaXMuZGVjb2RlciA9IGZhbHNlO1xuICAgICAgICAgICAgICAgIHRoaXMuY2FuQ29udGludWUgPSBmYWxzZTtcbiAgICAgICAgICAgICAgICB0aGlzLnByb2Nlc3NJbmNvbWluZyhkYXRhLCBjYWxsYmFjayk7XG4gICAgICAgICAgICB9O1xuXG4gICAgICAgICAgICBpZiAodGhpcy5jYW5Db250aW51ZSkge1xuICAgICAgICAgICAgICAgIHNldEltbWVkaWF0ZShkb0NvbnRpbnVlKTtcbiAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgdGhpcy5jb250aW51ZSA9ICgpID0+IGRvQ29udGludWUoKTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgcmV0dXJuIHRoaXMuZGVjb2Rlci5lbmQoKTtcbiAgICAgICAgfSBlbHNlIGlmIChkYXRhLnR5cGUgPT09ICdub2RlJyAmJiB0aGlzLmZpbHRlckZ1bmMoZGF0YSkpIHtcbiAgICAgICAgICAgIHRoaXMucHVzaChkYXRhKTtcbiAgICAgICAgICAgIC8vIGZvdW5kIG1hdGNoaW5nIG5vZGUsIGNyZWF0ZSBuZXcgaGFuZGxlclxuICAgICAgICAgICAgdGhpcy5lbWl0KCdub2RlJywgdGhpcy5jcmVhdGVEZWNvZGVyKGRhdGEpKTtcbiAgICAgICAgfSBlbHNlIGlmICh0aGlzLnJlYWRhYmxlICYmIGRhdGEudHlwZSAhPT0gJ25vbmUnKSB7XG4gICAgICAgICAgICAvLyB3ZSBkb24ndCBjYXJlIGFib3V0IHRoaXMgZGF0YSwganVzdCBwYXNzIGl0IG92ZXIgdG8gdGhlIGpvaW5lclxuICAgICAgICAgICAgdGhpcy5wdXNoKGRhdGEpO1xuICAgICAgICB9XG4gICAgICAgIGNhbGxiYWNrKCk7XG4gICAgfVxuXG4gICAgY3JlYXRlRGVjb2Rlcihub2RlKSB7XG4gICAgICAgIHRoaXMuZGVjb2RlciA9IG5vZGUuZ2V0RGVjb2RlcigpO1xuXG4gICAgICAgIGxldCBkZWNvZGVyID0gdGhpcy5kZWNvZGVyO1xuICAgICAgICBkZWNvZGVyLiRyZWFkaW5nID0gZmFsc2U7XG5cbiAgICAgICAgaWYgKC9edGV4dFxcLy8udGVzdChub2RlLmNvbnRlbnRUeXBlKSAmJiBub2RlLmZsb3dlZCkge1xuICAgICAgICAgICAgbGV0IGZsb3dEZWNvZGVyID0gZGVjb2RlcjtcbiAgICAgICAgICAgIGRlY29kZXIgPSBuZXcgRmxvd2VkRGVjb2Rlcih7XG4gICAgICAgICAgICAgICAgZGVsU3A6IG5vZGUuZGVsU3BcbiAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgZmxvd0RlY29kZXIub24oJ2Vycm9yJywgZXJyID0+IHtcbiAgICAgICAgICAgICAgICBkZWNvZGVyLmVtaXQoJ2Vycm9yJywgZXJyKTtcbiAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgZmxvd0RlY29kZXIucGlwZShkZWNvZGVyKTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICBub2RlLFxuICAgICAgICAgICAgZGVjb2RlcixcbiAgICAgICAgICAgIGRvbmU6ICgpID0+IHtcbiAgICAgICAgICAgICAgICBpZiAodHlwZW9mIHRoaXMuY29udGludWUgPT09ICdmdW5jdGlvbicpIHtcbiAgICAgICAgICAgICAgICAgICAgLy8gY2FsbGVkIG9uY2UgaW5wdXQgc3RyZWFtIGlzIHByb2Nlc3NlZFxuICAgICAgICAgICAgICAgICAgICB0aGlzLmNvbnRpbnVlKCk7XG4gICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgLy8gY2FsbGVkIGJlZm9yZSBpbnB1dCBzdHJlYW0gaXMgcHJvY2Vzc2VkXG4gICAgICAgICAgICAgICAgICAgIHRoaXMuY2FuQ29udGludWUgPSB0cnVlO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgfTtcbiAgICB9XG59XG5cbm1vZHVsZS5leHBvcnRzID0gTm9kZVN0cmVhbWVyO1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/mailsplit/lib/node-streamer.js\n");
|
|
|
|
/***/ })
|
|
|
|
};
|
|
; |