1115 lines
2.0 MiB
1115 lines
2.0 MiB
"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/imapflow";
|
|
exports.ids = ["vendor-chunks/imapflow"];
|
|
exports.modules = {
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/charsets.js":
|
|
/*!***********************************************!*\
|
|
!*** ./node_modules/imapflow/lib/charsets.js ***!
|
|
\***********************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\nconst CHARACTER_SETS = [\n 'US-ASCII',\n 'ISO-8859-1',\n 'ISO-8859-2',\n 'ISO-8859-3',\n 'ISO-8859-4',\n 'ISO-8859-5',\n 'ISO-8859-6',\n 'ISO-8859-7',\n 'ISO-8859-8',\n 'ISO-8859-9',\n 'ISO-8859-10',\n 'ISO_6937-2-add',\n 'JIS_X0201',\n 'JIS_Encoding',\n 'Shift_JIS',\n 'EUC-JP',\n 'Extended_UNIX_Code_Fixed_Width_for_Japanese',\n 'BS_4730',\n 'SEN_850200_C',\n 'IT',\n 'ES',\n 'DIN_66003',\n 'NS_4551-1',\n 'NF_Z_62-010',\n 'ISO-10646-UTF-1',\n 'ISO_646.basic:1983',\n 'INVARIANT',\n 'ISO_646.irv:1983',\n 'NATS-SEFI',\n 'NATS-SEFI-ADD',\n 'NATS-DANO',\n 'NATS-DANO-ADD',\n 'SEN_850200_B',\n 'KS_C_5601-1987',\n 'ISO-2022-KR',\n 'EUC-KR',\n 'ISO-2022-JP',\n 'ISO-2022-JP-2',\n 'JIS_C6220-1969-jp',\n 'JIS_C6220-1969-ro',\n 'PT',\n 'greek7-old',\n 'latin-greek',\n 'NF_Z_62-010_(1973)',\n 'Latin-greek-1',\n 'ISO_5427',\n 'JIS_C6226-1978',\n 'BS_viewdata',\n 'INIS',\n 'INIS-8',\n 'INIS-cyrillic',\n 'ISO_5427:1981',\n 'ISO_5428:1980',\n 'GB_1988-80',\n 'GB_2312-80',\n 'NS_4551-2',\n 'videotex-suppl',\n 'PT2',\n 'ES2',\n 'MSZ_7795.3',\n 'JIS_C6226-1983',\n 'greek7',\n 'ASMO_449',\n 'iso-ir-90',\n 'JIS_C6229-1984-a',\n 'JIS_C6229-1984-b',\n 'JIS_C6229-1984-b-add',\n 'JIS_C6229-1984-hand',\n 'JIS_C6229-1984-hand-add',\n 'JIS_C6229-1984-kana',\n 'ISO_2033-1983',\n 'ANSI_X3.110-1983',\n 'T.61-7bit',\n 'T.61-8bit',\n 'ECMA-cyrillic',\n 'CSA_Z243.4-1985-1',\n 'CSA_Z243.4-1985-2',\n 'CSA_Z243.4-1985-gr',\n 'ISO-8859-6-E',\n 'ISO-8859-6-I',\n 'T.101-G2',\n 'ISO-8859-8-E',\n 'ISO-8859-8-I',\n 'CSN_369103',\n 'JUS_I.B1.002',\n 'IEC_P27-1',\n 'JUS_I.B1.003-serb',\n 'JUS_I.B1.003-mac',\n 'greek-ccitt',\n 'NC_NC00-10:81',\n 'ISO_6937-2-25',\n 'GOST_19768-74',\n 'ISO_8859-supp',\n 'ISO_10367-box',\n 'latin-lap',\n 'JIS_X0212-1990',\n 'DS_2089',\n 'us-dk',\n 'dk-us',\n 'KSC5636',\n 'UNICODE-1-1-UTF-7',\n 'ISO-2022-CN',\n 'ISO-2022-CN-EXT',\n 'UTF-8',\n 'ISO-8859-13',\n 'ISO-8859-14',\n 'ISO-8859-15',\n 'ISO-8859-16',\n 'GBK',\n 'GB18030',\n 'OSD_EBCDIC_DF04_15',\n 'OSD_EBCDIC_DF03_IRV',\n 'OSD_EBCDIC_DF04_1',\n 'ISO-11548-1',\n 'KZ-1048',\n 'ISO-10646-UCS-2',\n 'ISO-10646-UCS-4',\n 'ISO-10646-UCS-Basic',\n 'ISO-10646-Unicode-Latin1',\n 'ISO-10646-J-1',\n 'ISO-Unicode-IBM-1261',\n 'ISO-Unicode-IBM-1268',\n 'ISO-Unicode-IBM-1276',\n 'ISO-Unicode-IBM-1264',\n 'ISO-Unicode-IBM-1265',\n 'UNICODE-1-1',\n 'SCSU',\n 'UTF-7',\n 'UTF-16BE',\n 'UTF-16LE',\n 'UTF-16',\n 'CESU-8',\n 'UTF-32',\n 'UTF-32BE',\n 'UTF-32LE',\n 'BOCU-1',\n 'ISO-8859-1-Windows-3.0-Latin-1',\n 'ISO-8859-1-Windows-3.1-Latin-1',\n 'ISO-8859-2-Windows-Latin-2',\n 'ISO-8859-9-Windows-Latin-5',\n 'hp-roman8',\n 'Adobe-Standard-Encoding',\n 'Ventura-US',\n 'Ventura-International',\n 'DEC-MCS',\n 'IBM850',\n 'PC8-Danish-Norwegian',\n 'IBM862',\n 'PC8-Turkish',\n 'IBM-Symbols',\n 'IBM-Thai',\n 'HP-Legal',\n 'HP-Pi-font',\n 'HP-Math8',\n 'Adobe-Symbol-Encoding',\n 'HP-DeskTop',\n 'Ventura-Math',\n 'Microsoft-Publishing',\n 'Windows-31J',\n 'GB2312',\n 'Big5',\n 'macintosh',\n 'IBM037',\n 'IBM038',\n 'IBM273',\n 'IBM274',\n 'IBM275',\n 'IBM277',\n 'IBM278',\n 'IBM280',\n 'IBM281',\n 'IBM284',\n 'IBM285',\n 'IBM290',\n 'IBM297',\n 'IBM420',\n 'IBM423',\n 'IBM424',\n 'IBM437',\n 'IBM500',\n 'IBM851',\n 'IBM852',\n 'IBM855',\n 'IBM857',\n 'IBM860',\n 'IBM861',\n 'IBM863',\n 'IBM864',\n 'IBM865',\n 'IBM868',\n 'IBM869',\n 'IBM870',\n 'IBM871',\n 'IBM880',\n 'IBM891',\n 'IBM903',\n 'IBM904',\n 'IBM905',\n 'IBM918',\n 'IBM1026',\n 'EBCDIC-AT-DE',\n 'EBCDIC-AT-DE-A',\n 'EBCDIC-CA-FR',\n 'EBCDIC-DK-NO',\n 'EBCDIC-DK-NO-A',\n 'EBCDIC-FI-SE',\n 'EBCDIC-FI-SE-A',\n 'EBCDIC-FR',\n 'EBCDIC-IT',\n 'EBCDIC-PT',\n 'EBCDIC-ES',\n 'EBCDIC-ES-A',\n 'EBCDIC-ES-S',\n 'EBCDIC-UK',\n 'EBCDIC-US',\n 'UNKNOWN-8BIT',\n 'MNEMONIC',\n 'MNEM',\n 'VISCII',\n 'VIQR',\n 'KOI8-R',\n 'HZ-GB-2312',\n 'IBM866',\n 'IBM775',\n 'KOI8-U',\n 'IBM00858',\n 'IBM00924',\n 'IBM01140',\n 'IBM01141',\n 'IBM01142',\n 'IBM01143',\n 'IBM01144',\n 'IBM01145',\n 'IBM01146',\n 'IBM01147',\n 'IBM01148',\n 'IBM01149',\n 'Big5-HKSCS',\n 'IBM1047',\n 'PTCP154',\n 'Amiga-1251',\n 'KOI7-switched',\n 'BRF',\n 'TSCII',\n 'CP51932',\n 'windows-874',\n 'windows-1250',\n 'windows-1251',\n 'windows-1252',\n 'windows-1253',\n 'windows-1254',\n 'windows-1255',\n 'windows-1256',\n 'windows-1257',\n 'windows-1258',\n 'TIS-620',\n 'CP50220'\n];\n\nconst CHARSET_MAP = new Map();\n\nCHARACTER_SETS.forEach(entry => {\n let key = entry.replace(/[_-\\s]/g, '').toLowerCase();\n let modifiedKey = key\n .replace(/^windows/, 'win')\n .replace(/^usascii/, 'ascii')\n .replace(/^iso8859/, 'latin');\n CHARSET_MAP.set(key, entry);\n if (!CHARSET_MAP.has(modifiedKey)) {\n CHARSET_MAP.set(modifiedKey, entry);\n }\n});\n\nmodule.exports.resolveCharset = charset => {\n let key = charset.replace(/[_-\\s]/g, '').toLowerCase();\n if (CHARSET_MAP.has(key)) {\n return CHARSET_MAP.get(key);\n }\n return null;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/imapflow/lib/charsets.js","mappings":"AAAa;;AAEb;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;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;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;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;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;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;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;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED,6BAA6B;AAC7B;AACA;AACA;AACA;AACA;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/charsets.js"],"sourcesContent":["'use strict';\n\nconst CHARACTER_SETS = [\n    'US-ASCII',\n    'ISO-8859-1',\n    'ISO-8859-2',\n    'ISO-8859-3',\n    'ISO-8859-4',\n    'ISO-8859-5',\n    'ISO-8859-6',\n    'ISO-8859-7',\n    'ISO-8859-8',\n    'ISO-8859-9',\n    'ISO-8859-10',\n    'ISO_6937-2-add',\n    'JIS_X0201',\n    'JIS_Encoding',\n    'Shift_JIS',\n    'EUC-JP',\n    'Extended_UNIX_Code_Fixed_Width_for_Japanese',\n    'BS_4730',\n    'SEN_850200_C',\n    'IT',\n    'ES',\n    'DIN_66003',\n    'NS_4551-1',\n    'NF_Z_62-010',\n    'ISO-10646-UTF-1',\n    'ISO_646.basic:1983',\n    'INVARIANT',\n    'ISO_646.irv:1983',\n    'NATS-SEFI',\n    'NATS-SEFI-ADD',\n    'NATS-DANO',\n    'NATS-DANO-ADD',\n    'SEN_850200_B',\n    'KS_C_5601-1987',\n    'ISO-2022-KR',\n    'EUC-KR',\n    'ISO-2022-JP',\n    'ISO-2022-JP-2',\n    'JIS_C6220-1969-jp',\n    'JIS_C6220-1969-ro',\n    'PT',\n    'greek7-old',\n    'latin-greek',\n    'NF_Z_62-010_(1973)',\n    'Latin-greek-1',\n    'ISO_5427',\n    'JIS_C6226-1978',\n    'BS_viewdata',\n    'INIS',\n    'INIS-8',\n    'INIS-cyrillic',\n    'ISO_5427:1981',\n    'ISO_5428:1980',\n    'GB_1988-80',\n    'GB_2312-80',\n    'NS_4551-2',\n    'videotex-suppl',\n    'PT2',\n    'ES2',\n    'MSZ_7795.3',\n    'JIS_C6226-1983',\n    'greek7',\n    'ASMO_449',\n    'iso-ir-90',\n    'JIS_C6229-1984-a',\n    'JIS_C6229-1984-b',\n    'JIS_C6229-1984-b-add',\n    'JIS_C6229-1984-hand',\n    'JIS_C6229-1984-hand-add',\n    'JIS_C6229-1984-kana',\n    'ISO_2033-1983',\n    'ANSI_X3.110-1983',\n    'T.61-7bit',\n    'T.61-8bit',\n    'ECMA-cyrillic',\n    'CSA_Z243.4-1985-1',\n    'CSA_Z243.4-1985-2',\n    'CSA_Z243.4-1985-gr',\n    'ISO-8859-6-E',\n    'ISO-8859-6-I',\n    'T.101-G2',\n    'ISO-8859-8-E',\n    'ISO-8859-8-I',\n    'CSN_369103',\n    'JUS_I.B1.002',\n    'IEC_P27-1',\n    'JUS_I.B1.003-serb',\n    'JUS_I.B1.003-mac',\n    'greek-ccitt',\n    'NC_NC00-10:81',\n    'ISO_6937-2-25',\n    'GOST_19768-74',\n    'ISO_8859-supp',\n    'ISO_10367-box',\n    'latin-lap',\n    'JIS_X0212-1990',\n    'DS_2089',\n    'us-dk',\n    'dk-us',\n    'KSC5636',\n    'UNICODE-1-1-UTF-7',\n    'ISO-2022-CN',\n    'ISO-2022-CN-EXT',\n    'UTF-8',\n    'ISO-8859-13',\n    'ISO-8859-14',\n    'ISO-8859-15',\n    'ISO-8859-16',\n    'GBK',\n    'GB18030',\n    'OSD_EBCDIC_DF04_15',\n    'OSD_EBCDIC_DF03_IRV',\n    'OSD_EBCDIC_DF04_1',\n    'ISO-11548-1',\n    'KZ-1048',\n    'ISO-10646-UCS-2',\n    'ISO-10646-UCS-4',\n    'ISO-10646-UCS-Basic',\n    'ISO-10646-Unicode-Latin1',\n    'ISO-10646-J-1',\n    'ISO-Unicode-IBM-1261',\n    'ISO-Unicode-IBM-1268',\n    'ISO-Unicode-IBM-1276',\n    'ISO-Unicode-IBM-1264',\n    'ISO-Unicode-IBM-1265',\n    'UNICODE-1-1',\n    'SCSU',\n    'UTF-7',\n    'UTF-16BE',\n    'UTF-16LE',\n    'UTF-16',\n    'CESU-8',\n    'UTF-32',\n    'UTF-32BE',\n    'UTF-32LE',\n    'BOCU-1',\n    'ISO-8859-1-Windows-3.0-Latin-1',\n    'ISO-8859-1-Windows-3.1-Latin-1',\n    'ISO-8859-2-Windows-Latin-2',\n    'ISO-8859-9-Windows-Latin-5',\n    'hp-roman8',\n    'Adobe-Standard-Encoding',\n    'Ventura-US',\n    'Ventura-International',\n    'DEC-MCS',\n    'IBM850',\n    'PC8-Danish-Norwegian',\n    'IBM862',\n    'PC8-Turkish',\n    'IBM-Symbols',\n    'IBM-Thai',\n    'HP-Legal',\n    'HP-Pi-font',\n    'HP-Math8',\n    'Adobe-Symbol-Encoding',\n    'HP-DeskTop',\n    'Ventura-Math',\n    'Microsoft-Publishing',\n    'Windows-31J',\n    'GB2312',\n    'Big5',\n    'macintosh',\n    'IBM037',\n    'IBM038',\n    'IBM273',\n    'IBM274',\n    'IBM275',\n    'IBM277',\n    'IBM278',\n    'IBM280',\n    'IBM281',\n    'IBM284',\n    'IBM285',\n    'IBM290',\n    'IBM297',\n    'IBM420',\n    'IBM423',\n    'IBM424',\n    'IBM437',\n    'IBM500',\n    'IBM851',\n    'IBM852',\n    'IBM855',\n    'IBM857',\n    'IBM860',\n    'IBM861',\n    'IBM863',\n    'IBM864',\n    'IBM865',\n    'IBM868',\n    'IBM869',\n    'IBM870',\n    'IBM871',\n    'IBM880',\n    'IBM891',\n    'IBM903',\n    'IBM904',\n    'IBM905',\n    'IBM918',\n    'IBM1026',\n    'EBCDIC-AT-DE',\n    'EBCDIC-AT-DE-A',\n    'EBCDIC-CA-FR',\n    'EBCDIC-DK-NO',\n    'EBCDIC-DK-NO-A',\n    'EBCDIC-FI-SE',\n    'EBCDIC-FI-SE-A',\n    'EBCDIC-FR',\n    'EBCDIC-IT',\n    'EBCDIC-PT',\n    'EBCDIC-ES',\n    'EBCDIC-ES-A',\n    'EBCDIC-ES-S',\n    'EBCDIC-UK',\n    'EBCDIC-US',\n    'UNKNOWN-8BIT',\n    'MNEMONIC',\n    'MNEM',\n    'VISCII',\n    'VIQR',\n    'KOI8-R',\n    'HZ-GB-2312',\n    'IBM866',\n    'IBM775',\n    'KOI8-U',\n    'IBM00858',\n    'IBM00924',\n    'IBM01140',\n    'IBM01141',\n    'IBM01142',\n    'IBM01143',\n    'IBM01144',\n    'IBM01145',\n    'IBM01146',\n    'IBM01147',\n    'IBM01148',\n    'IBM01149',\n    'Big5-HKSCS',\n    'IBM1047',\n    'PTCP154',\n    'Amiga-1251',\n    'KOI7-switched',\n    'BRF',\n    'TSCII',\n    'CP51932',\n    'windows-874',\n    'windows-1250',\n    'windows-1251',\n    'windows-1252',\n    'windows-1253',\n    'windows-1254',\n    'windows-1255',\n    'windows-1256',\n    'windows-1257',\n    'windows-1258',\n    'TIS-620',\n    'CP50220'\n];\n\nconst CHARSET_MAP = new Map();\n\nCHARACTER_SETS.forEach(entry => {\n    let key = entry.replace(/[_-\\s]/g, '').toLowerCase();\n    let modifiedKey = key\n        .replace(/^windows/, 'win')\n        .replace(/^usascii/, 'ascii')\n        .replace(/^iso8859/, 'latin');\n    CHARSET_MAP.set(key, entry);\n    if (!CHARSET_MAP.has(modifiedKey)) {\n        CHARSET_MAP.set(modifiedKey, entry);\n    }\n});\n\nmodule.exports.resolveCharset = charset => {\n    let key = charset.replace(/[_-\\s]/g, '').toLowerCase();\n    if (CHARSET_MAP.has(key)) {\n        return CHARSET_MAP.get(key);\n    }\n    return null;\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/charsets.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/append.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/append.js ***!
|
|
\******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { getStatusCode, formatFlag, canUseFlag, formatDateTime, normalizePath, encodePath, comparePaths, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(action-browser)/./node_modules/imapflow/lib/tools.js\");\n\n// Appends a message to a mailbox\nmodule.exports = async (connection, destination, content, flags, idate) => {\n if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state) || !destination) {\n // nothing to do here\n return;\n }\n\n if (connection.capabilities.has('APPENDLIMIT')) {\n let appendLimit = connection.capabilities.get('APPENDLIMIT');\n if (typeof appendLimit === 'number' && appendLimit < content.length) {\n let err = new Error('Message content too big for APPENDLIMIT=' + appendLimit);\n err.serverResponseCode = 'APPENDLIMIT';\n throw err;\n }\n }\n\n destination = normalizePath(connection, destination);\n\n let expectExists = comparePaths(connection, connection.mailbox.path, destination);\n\n flags = (Array.isArray(flags) ? flags : [].concat(flags || []))\n .map(flag => flag && formatFlag(flag.toString()))\n .filter(flag => flag && canUseFlag(connection.mailbox, flag));\n\n let attributes = [{ type: 'ATOM', value: encodePath(connection, destination) }];\n\n idate = idate ? formatDateTime(idate) : false;\n\n if (flags.length || idate) {\n attributes.push(flags.map(flag => ({ type: 'ATOM', value: flag })));\n }\n\n if (idate) {\n attributes.push({ type: 'STRING', value: idate }); // force quotes as required by date-time\n }\n\n let isLiteral8 = false;\n if (connection.capabilities.has('BINARY') && !connection.disableBinary) {\n if (typeof content === 'string') {\n content = Buffer.from(content);\n }\n // Value is literal8 if it contains NULL bytes. The server must support the BINARY extension\n // and if it does not then send the value as a regular literal and hope for the best\n isLiteral8 = content.indexOf(Buffer.from([0])) >= 0;\n }\n\n attributes.push({ type: 'LITERAL', value: content, isLiteral8 });\n\n let map = { destination };\n if (connection.mailbox && connection.mailbox.path) {\n map.path = connection.mailbox.path;\n }\n\n let response;\n try {\n response = await connection.exec('APPEND', attributes, {\n untagged: expectExists\n ? {\n EXISTS: async untagged => {\n map.seq = Number(untagged.command);\n\n if (expectExists) {\n let prevCount = connection.mailbox.exists;\n if (map.seq !== prevCount) {\n connection.mailbox.exists = map.seq;\n connection.emit('exists', {\n path: connection.mailbox.path,\n count: map.seq,\n prevCount\n });\n }\n }\n }\n }\n : false\n });\n\n let section = response.response.attributes && response.response.attributes[0] && response.response.attributes[0].section;\n if (section && section.length) {\n let responseCode = section[0] && typeof section[0].value === 'string' ? section[0].value : '';\n switch (responseCode.toUpperCase()) {\n case 'APPENDUID':\n {\n let uidValidity = section[1] && typeof section[1].value === 'string' && !isNaN(section[1].value) ? BigInt(section[1].value) : false;\n let uid = section[2] && typeof section[2].value === 'string' && !isNaN(section[2].value) ? Number(section[2].value) : false;\n if (uidValidity) {\n map.uidValidity = uidValidity;\n }\n if (uid) {\n map.uid = uid;\n }\n }\n break;\n }\n }\n\n response.next();\n\n if (expectExists && !map.seq) {\n // try to use NOOP to get the new sequence number\n try {\n response = await connection.exec('NOOP', false, {\n untagged: {\n EXISTS: async untagged => {\n map.seq = Number(untagged.command);\n\n if (expectExists) {\n let prevCount = connection.mailbox.exists;\n if (map.seq !== prevCount) {\n connection.mailbox.exists = map.seq;\n connection.emit('exists', {\n path: connection.mailbox.path,\n count: map.seq,\n prevCount\n });\n }\n }\n }\n },\n comment: 'Sequence not found from APPEND output'\n });\n response.next();\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n }\n }\n\n if (map.seq && !map.uid) {\n let list = await connection.search({ seq: map.seq }, { uid: true });\n if (list && list.length) {\n map.uid = list[0];\n }\n }\n\n return map;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n throw err;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/imapflow/lib/commands/append.js","mappings":"AAAa;;AAEb,QAAQ,+GAA+G,EAAE,mBAAO,CAAC,0EAAa;;AAE9I;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;;AAEA,wBAAwB,0DAA0D;;AAElF;;AAEA;AACA,6CAA6C,2BAA2B;AACxE;;AAEA;AACA,0BAA0B,8BAA8B,GAAG;AAC3D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,sBAAsB,6CAA6C;;AAEnE,gBAAgB;AAChB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC;AACnC;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC;AACrC;AACA;AACA;AACA,qBAAqB;AACrB;AACA,iBAAiB;AACjB;AACA,cAAc;AACd,sCAAsC,yBAAyB;AAC/D;AACA;;AAEA;AACA,iDAAiD,cAAc,IAAI,WAAW;AAC9E;AACA;AACA;AACA;;AAEA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;;AAEA,8BAA8B,yBAAyB;AACvD;AACA;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/commands/append.js"],"sourcesContent":["'use strict';\n\nconst { getStatusCode, formatFlag, canUseFlag, formatDateTime, normalizePath, encodePath, comparePaths, getErrorText } = require('../tools.js');\n\n// Appends a message to a mailbox\nmodule.exports = async (connection, destination, content, flags, idate) => {\n    if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state) || !destination) {\n        // nothing to do here\n        return;\n    }\n\n    if (connection.capabilities.has('APPENDLIMIT')) {\n        let appendLimit = connection.capabilities.get('APPENDLIMIT');\n        if (typeof appendLimit === 'number' && appendLimit < content.length) {\n            let err = new Error('Message content too big for APPENDLIMIT=' + appendLimit);\n            err.serverResponseCode = 'APPENDLIMIT';\n            throw err;\n        }\n    }\n\n    destination = normalizePath(connection, destination);\n\n    let expectExists = comparePaths(connection, connection.mailbox.path, destination);\n\n    flags = (Array.isArray(flags) ? flags : [].concat(flags || []))\n        .map(flag => flag && formatFlag(flag.toString()))\n        .filter(flag => flag && canUseFlag(connection.mailbox, flag));\n\n    let attributes = [{ type: 'ATOM', value: encodePath(connection, destination) }];\n\n    idate = idate ? formatDateTime(idate) : false;\n\n    if (flags.length || idate) {\n        attributes.push(flags.map(flag => ({ type: 'ATOM', value: flag })));\n    }\n\n    if (idate) {\n        attributes.push({ type: 'STRING', value: idate }); // force quotes as required by date-time\n    }\n\n    let isLiteral8 = false;\n    if (connection.capabilities.has('BINARY') && !connection.disableBinary) {\n        if (typeof content === 'string') {\n            content = Buffer.from(content);\n        }\n        // Value is literal8 if it contains NULL bytes. The server must support the BINARY extension\n        // and if it does not then send the value as a regular literal and hope for the best\n        isLiteral8 = content.indexOf(Buffer.from([0])) >= 0;\n    }\n\n    attributes.push({ type: 'LITERAL', value: content, isLiteral8 });\n\n    let map = { destination };\n    if (connection.mailbox && connection.mailbox.path) {\n        map.path = connection.mailbox.path;\n    }\n\n    let response;\n    try {\n        response = await connection.exec('APPEND', attributes, {\n            untagged: expectExists\n                ? {\n                      EXISTS: async untagged => {\n                          map.seq = Number(untagged.command);\n\n                          if (expectExists) {\n                              let prevCount = connection.mailbox.exists;\n                              if (map.seq !== prevCount) {\n                                  connection.mailbox.exists = map.seq;\n                                  connection.emit('exists', {\n                                      path: connection.mailbox.path,\n                                      count: map.seq,\n                                      prevCount\n                                  });\n                              }\n                          }\n                      }\n                  }\n                : false\n        });\n\n        let section = response.response.attributes && response.response.attributes[0] && response.response.attributes[0].section;\n        if (section && section.length) {\n            let responseCode = section[0] && typeof section[0].value === 'string' ? section[0].value : '';\n            switch (responseCode.toUpperCase()) {\n                case 'APPENDUID':\n                    {\n                        let uidValidity = section[1] && typeof section[1].value === 'string' && !isNaN(section[1].value) ? BigInt(section[1].value) : false;\n                        let uid = section[2] && typeof section[2].value === 'string' && !isNaN(section[2].value) ? Number(section[2].value) : false;\n                        if (uidValidity) {\n                            map.uidValidity = uidValidity;\n                        }\n                        if (uid) {\n                            map.uid = uid;\n                        }\n                    }\n                    break;\n            }\n        }\n\n        response.next();\n\n        if (expectExists && !map.seq) {\n            // try to use NOOP to get the new sequence number\n            try {\n                response = await connection.exec('NOOP', false, {\n                    untagged: {\n                        EXISTS: async untagged => {\n                            map.seq = Number(untagged.command);\n\n                            if (expectExists) {\n                                let prevCount = connection.mailbox.exists;\n                                if (map.seq !== prevCount) {\n                                    connection.mailbox.exists = map.seq;\n                                    connection.emit('exists', {\n                                        path: connection.mailbox.path,\n                                        count: map.seq,\n                                        prevCount\n                                    });\n                                }\n                            }\n                        }\n                    },\n                    comment: 'Sequence not found from APPEND output'\n                });\n                response.next();\n            } catch (err) {\n                connection.log.warn({ err, cid: connection.id });\n            }\n        }\n\n        if (map.seq && !map.uid) {\n            let list = await connection.search({ seq: map.seq }, { uid: true });\n            if (list && list.length) {\n                map.uid = list[0];\n            }\n        }\n\n        return map;\n    } catch (err) {\n        let errorCode = getStatusCode(err.response);\n        if (errorCode) {\n            err.serverResponseCode = errorCode;\n        }\n        err.response = await getErrorText(err.response);\n\n        connection.log.warn({ err, cid: connection.id });\n        throw err;\n    }\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/append.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/authenticate.js":
|
|
/*!************************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/authenticate.js ***!
|
|
\************************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { getStatusCode, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(action-browser)/./node_modules/imapflow/lib/tools.js\");\n\nasync function authOauth(connection, username, accessToken) {\n let oauthbearer;\n let command;\n let breaker;\n\n if (connection.capabilities.has('AUTH=OAUTHBEARER')) {\n oauthbearer = [`n,a=${username},`, `host=${connection.servername}`, `port=993`, `auth=Bearer ${accessToken}`, '', ''].join('\\x01');\n command = 'OAUTHBEARER';\n breaker = 'AQ==';\n } else if (connection.capabilities.has('AUTH=XOAUTH') || connection.capabilities.has('AUTH=XOAUTH2')) {\n oauthbearer = [`user=${username}`, `auth=Bearer ${accessToken}`, '', ''].join('\\x01');\n command = 'XOAUTH2';\n breaker = '';\n }\n\n let errorResponse = false;\n try {\n let response = await connection.exec(\n 'AUTHENTICATE',\n [\n { type: 'ATOM', value: command },\n { type: 'ATOM', value: Buffer.from(oauthbearer).toString('base64'), sensitive: true }\n ],\n {\n onPlusTag: async resp => {\n if (resp.attributes && resp.attributes[0] && resp.attributes[0].type === 'TEXT') {\n try {\n errorResponse = JSON.parse(Buffer.from(resp.attributes[0].value, 'base64').toString());\n } catch (err) {\n connection.log.debug({ errorResponse: resp.attributes[0].value, err });\n }\n }\n\n connection.log.debug({ src: 'c', msg: breaker, comment: `Error response for ${command}` });\n connection.write(breaker);\n }\n }\n );\n response.next();\n\n connection.authCapabilities.set(`AUTH=${command}`, true);\n\n return username;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.authenticationFailed = true;\n err.response = await getErrorText(err.response);\n if (errorResponse) {\n err.oauthError = errorResponse;\n }\n throw err;\n }\n}\n\nasync function authLogin(connection, username, password) {\n let errorResponse = false;\n try {\n let response = await connection.exec('AUTHENTICATE', [{ type: 'ATOM', value: 'LOGIN' }], {\n onPlusTag: async resp => {\n if (resp.attributes && resp.attributes[0] && resp.attributes[0].type === 'TEXT') {\n let question = Buffer.from(resp.attributes[0].value, 'base64').toString();\n switch (\n question.toLowerCase().replace(/[:\\x00]*$/, '') // eslint-disable-line no-control-regex\n ) {\n case 'username':\n case 'user name': {\n let encodedUsername = Buffer.from(username).toString('base64');\n connection.log.debug({ src: 'c', msg: encodedUsername, comment: `Encoded username for AUTH=LOGIN` });\n connection.write(encodedUsername);\n break;\n }\n\n case 'password':\n connection.log.debug({ src: 'c', msg: '(* value hidden *)', comment: `Encoded password for AUTH=LOGIN` });\n connection.write(Buffer.from(password).toString('base64'));\n break;\n\n default: {\n let error = new Error(`Unknown LOGIN question \"${question}\"`);\n throw error;\n }\n }\n }\n }\n });\n\n response.next();\n\n connection.authCapabilities.set(`AUTH=LOGIN`, true);\n\n return username;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.authenticationFailed = true;\n err.response = await getErrorText(err.response);\n if (errorResponse) {\n err.oauthError = errorResponse;\n }\n throw err;\n }\n}\n\nasync function authPlain(connection, username, password) {\n let errorResponse = false;\n try {\n let response = await connection.exec('AUTHENTICATE', [{ type: 'ATOM', value: 'PLAIN' }], {\n onPlusTag: async () => {\n let encodedResponse = Buffer.from(['', username, password].join('\\x00')).toString('base64');\n let loggedResponse = Buffer.from(['', username, '(* value hidden *)'].join('\\x00')).toString('base64');\n connection.log.debug({ src: 'c', msg: loggedResponse, comment: `Encoded response for AUTH=PLAIN` });\n connection.write(encodedResponse);\n }\n });\n\n response.next();\n\n connection.authCapabilities.set(`AUTH=PLAIN`, true);\n\n return username;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.authenticationFailed = true;\n err.response = await getErrorText(err.response);\n if (errorResponse) {\n err.oauthError = errorResponse;\n }\n throw err;\n }\n}\n\n// Authenticates user using LOGIN\nmodule.exports = async (connection, username, { accessToken, password, loginMethod }) => {\n if (connection.state !== connection.states.NOT_AUTHENTICATED) {\n // nothing to do here\n return;\n }\n\n if (accessToken) {\n // AUTH=OAUTHBEARER and AUTH=XOAUTH in the context of OAuth2 or very similar so we can handle these together\n if (connection.capabilities.has('AUTH=OAUTHBEARER') || connection.capabilities.has('AUTH=XOAUTH') || connection.capabilities.has('AUTH=XOAUTH2')) {\n return await authOauth(connection, username, accessToken);\n }\n }\n\n if (password) {\n if ((!loginMethod && connection.capabilities.has('AUTH=PLAIN')) || loginMethod === 'AUTH=PLAIN') {\n return await authPlain(connection, username, password);\n }\n\n if ((!loginMethod && connection.capabilities.has('AUTH=LOGIN')) || loginMethod === 'AUTH=LOGIN') {\n return await authLogin(connection, username, password);\n }\n }\n\n throw new Error('Unsupported authentication mechanism');\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/imapflow/lib/commands/authenticate.js","mappings":"AAAa;;AAEb,QAAQ,8BAA8B,EAAE,mBAAO,CAAC,0EAAa;;AAE7D;AACA;AACA;AACA;;AAEA;AACA,8BAA8B,SAAS,YAAY,sBAAsB,8BAA8B,YAAY;AACnH;AACA;AACA,MAAM;AACN,+BAA+B,SAAS,kBAAkB,YAAY;AACtE;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,kBAAkB,8BAA8B;AAChD,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B;AAC1B,mDAAmD,8CAA8C;AACjG;AACA;;AAEA,2CAA2C,uDAAuD,QAAQ,GAAG;AAC7G;AACA;AACA;AACA;AACA;;AAEA,gDAAgD,QAAQ;;AAExD;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,gEAAgE,8BAA8B;AAC9F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mDAAmD,4EAA4E;AAC/H;AACA;AACA;;AAEA;AACA,mDAAmD,iFAAiF;AACpI;AACA;;AAEA;AACA,6EAA6E,SAAS;AACtF;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;;AAEA;;AAEA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,gEAAgE,8BAA8B;AAC9F;AACA;AACA;AACA,uCAAuC,2EAA2E;AAClH;AACA;AACA,SAAS;;AAET;;AAEA;;AAEA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,gDAAgD,oCAAoC;AACpF;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/commands/authenticate.js"],"sourcesContent":["'use strict';\n\nconst { getStatusCode, getErrorText } = require('../tools.js');\n\nasync function authOauth(connection, username, accessToken) {\n    let oauthbearer;\n    let command;\n    let breaker;\n\n    if (connection.capabilities.has('AUTH=OAUTHBEARER')) {\n        oauthbearer = [`n,a=${username},`, `host=${connection.servername}`, `port=993`, `auth=Bearer ${accessToken}`, '', ''].join('\\x01');\n        command = 'OAUTHBEARER';\n        breaker = 'AQ==';\n    } else if (connection.capabilities.has('AUTH=XOAUTH') || connection.capabilities.has('AUTH=XOAUTH2')) {\n        oauthbearer = [`user=${username}`, `auth=Bearer ${accessToken}`, '', ''].join('\\x01');\n        command = 'XOAUTH2';\n        breaker = '';\n    }\n\n    let errorResponse = false;\n    try {\n        let response = await connection.exec(\n            'AUTHENTICATE',\n            [\n                { type: 'ATOM', value: command },\n                { type: 'ATOM', value: Buffer.from(oauthbearer).toString('base64'), sensitive: true }\n            ],\n            {\n                onPlusTag: async resp => {\n                    if (resp.attributes && resp.attributes[0] && resp.attributes[0].type === 'TEXT') {\n                        try {\n                            errorResponse = JSON.parse(Buffer.from(resp.attributes[0].value, 'base64').toString());\n                        } catch (err) {\n                            connection.log.debug({ errorResponse: resp.attributes[0].value, err });\n                        }\n                    }\n\n                    connection.log.debug({ src: 'c', msg: breaker, comment: `Error response for ${command}` });\n                    connection.write(breaker);\n                }\n            }\n        );\n        response.next();\n\n        connection.authCapabilities.set(`AUTH=${command}`, true);\n\n        return username;\n    } catch (err) {\n        let errorCode = getStatusCode(err.response);\n        if (errorCode) {\n            err.serverResponseCode = errorCode;\n        }\n        err.authenticationFailed = true;\n        err.response = await getErrorText(err.response);\n        if (errorResponse) {\n            err.oauthError = errorResponse;\n        }\n        throw err;\n    }\n}\n\nasync function authLogin(connection, username, password) {\n    let errorResponse = false;\n    try {\n        let response = await connection.exec('AUTHENTICATE', [{ type: 'ATOM', value: 'LOGIN' }], {\n            onPlusTag: async resp => {\n                if (resp.attributes && resp.attributes[0] && resp.attributes[0].type === 'TEXT') {\n                    let question = Buffer.from(resp.attributes[0].value, 'base64').toString();\n                    switch (\n                        question.toLowerCase().replace(/[:\\x00]*$/, '') // eslint-disable-line no-control-regex\n                    ) {\n                        case 'username':\n                        case 'user name': {\n                            let encodedUsername = Buffer.from(username).toString('base64');\n                            connection.log.debug({ src: 'c', msg: encodedUsername, comment: `Encoded username for AUTH=LOGIN` });\n                            connection.write(encodedUsername);\n                            break;\n                        }\n\n                        case 'password':\n                            connection.log.debug({ src: 'c', msg: '(* value hidden *)', comment: `Encoded password for AUTH=LOGIN` });\n                            connection.write(Buffer.from(password).toString('base64'));\n                            break;\n\n                        default: {\n                            let error = new Error(`Unknown LOGIN question \"${question}\"`);\n                            throw error;\n                        }\n                    }\n                }\n            }\n        });\n\n        response.next();\n\n        connection.authCapabilities.set(`AUTH=LOGIN`, true);\n\n        return username;\n    } catch (err) {\n        let errorCode = getStatusCode(err.response);\n        if (errorCode) {\n            err.serverResponseCode = errorCode;\n        }\n        err.authenticationFailed = true;\n        err.response = await getErrorText(err.response);\n        if (errorResponse) {\n            err.oauthError = errorResponse;\n        }\n        throw err;\n    }\n}\n\nasync function authPlain(connection, username, password) {\n    let errorResponse = false;\n    try {\n        let response = await connection.exec('AUTHENTICATE', [{ type: 'ATOM', value: 'PLAIN' }], {\n            onPlusTag: async () => {\n                let encodedResponse = Buffer.from(['', username, password].join('\\x00')).toString('base64');\n                let loggedResponse = Buffer.from(['', username, '(* value hidden *)'].join('\\x00')).toString('base64');\n                connection.log.debug({ src: 'c', msg: loggedResponse, comment: `Encoded response for AUTH=PLAIN` });\n                connection.write(encodedResponse);\n            }\n        });\n\n        response.next();\n\n        connection.authCapabilities.set(`AUTH=PLAIN`, true);\n\n        return username;\n    } catch (err) {\n        let errorCode = getStatusCode(err.response);\n        if (errorCode) {\n            err.serverResponseCode = errorCode;\n        }\n        err.authenticationFailed = true;\n        err.response = await getErrorText(err.response);\n        if (errorResponse) {\n            err.oauthError = errorResponse;\n        }\n        throw err;\n    }\n}\n\n// Authenticates user using LOGIN\nmodule.exports = async (connection, username, { accessToken, password, loginMethod }) => {\n    if (connection.state !== connection.states.NOT_AUTHENTICATED) {\n        // nothing to do here\n        return;\n    }\n\n    if (accessToken) {\n        // AUTH=OAUTHBEARER and AUTH=XOAUTH in the context of OAuth2 or very similar so we can handle these together\n        if (connection.capabilities.has('AUTH=OAUTHBEARER') || connection.capabilities.has('AUTH=XOAUTH') || connection.capabilities.has('AUTH=XOAUTH2')) {\n            return await authOauth(connection, username, accessToken);\n        }\n    }\n\n    if (password) {\n        if ((!loginMethod && connection.capabilities.has('AUTH=PLAIN')) || loginMethod === 'AUTH=PLAIN') {\n            return await authPlain(connection, username, password);\n        }\n\n        if ((!loginMethod && connection.capabilities.has('AUTH=LOGIN')) || loginMethod === 'AUTH=LOGIN') {\n            return await authLogin(connection, username, password);\n        }\n    }\n\n    throw new Error('Unsupported authentication mechanism');\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/authenticate.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/capability.js":
|
|
/*!**********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/capability.js ***!
|
|
\**********************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\n// Refresh capabilities from server\nmodule.exports = async connection => {\n if (connection.capabilities.size && !connection.expectCapabilityUpdate) {\n return connection.capabilities;\n }\n\n let response;\n try {\n // untagged capability response is processed by global handler\n response = await connection.exec('CAPABILITY');\n\n response.next();\n return connection.capabilities;\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvY2FwYWJpbGl0eS5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxNQUFNO0FBQ04sOEJBQThCLHlCQUF5QjtBQUN2RDtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L2xpYi9jb21tYW5kcy9jYXBhYmlsaXR5LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuLy8gUmVmcmVzaCBjYXBhYmlsaXRpZXMgZnJvbSBzZXJ2ZXJcbm1vZHVsZS5leHBvcnRzID0gYXN5bmMgY29ubmVjdGlvbiA9PiB7XG4gICAgaWYgKGNvbm5lY3Rpb24uY2FwYWJpbGl0aWVzLnNpemUgJiYgIWNvbm5lY3Rpb24uZXhwZWN0Q2FwYWJpbGl0eVVwZGF0ZSkge1xuICAgICAgICByZXR1cm4gY29ubmVjdGlvbi5jYXBhYmlsaXRpZXM7XG4gICAgfVxuXG4gICAgbGV0IHJlc3BvbnNlO1xuICAgIHRyeSB7XG4gICAgICAgIC8vIHVudGFnZ2VkIGNhcGFiaWxpdHkgcmVzcG9uc2UgaXMgcHJvY2Vzc2VkIGJ5IGdsb2JhbCBoYW5kbGVyXG4gICAgICAgIHJlc3BvbnNlID0gYXdhaXQgY29ubmVjdGlvbi5leGVjKCdDQVBBQklMSVRZJyk7XG5cbiAgICAgICAgcmVzcG9uc2UubmV4dCgpO1xuICAgICAgICByZXR1cm4gY29ubmVjdGlvbi5jYXBhYmlsaXRpZXM7XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICAgIGNvbm5lY3Rpb24ubG9nLndhcm4oeyBlcnIsIGNpZDogY29ubmVjdGlvbi5pZCB9KTtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbn07XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/capability.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/close.js":
|
|
/*!*****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/close.js ***!
|
|
\*****************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\n// Closes a mailbox\nmodule.exports = async connection => {\n if (connection.state !== connection.states.SELECTED) {\n // nothing to do here\n return;\n }\n\n let response;\n try {\n response = await connection.exec('CLOSE');\n response.next();\n\n let currentMailbox = connection.mailbox;\n connection.mailbox = false;\n connection.currentSelectCommand = false;\n connection.state = connection.states.AUTHENTICATED;\n\n if (currentMailbox) {\n connection.emit('mailboxClose', currentMailbox);\n }\n return true;\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvY2xvc2UuanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOLDhCQUE4Qix5QkFBeUI7QUFDdkQ7QUFDQTtBQUNBIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvY2xvc2UuanMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG4vLyBDbG9zZXMgYSBtYWlsYm94XG5tb2R1bGUuZXhwb3J0cyA9IGFzeW5jIGNvbm5lY3Rpb24gPT4ge1xuICAgIGlmIChjb25uZWN0aW9uLnN0YXRlICE9PSBjb25uZWN0aW9uLnN0YXRlcy5TRUxFQ1RFRCkge1xuICAgICAgICAvLyBub3RoaW5nIHRvIGRvIGhlcmVcbiAgICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGxldCByZXNwb25zZTtcbiAgICB0cnkge1xuICAgICAgICByZXNwb25zZSA9IGF3YWl0IGNvbm5lY3Rpb24uZXhlYygnQ0xPU0UnKTtcbiAgICAgICAgcmVzcG9uc2UubmV4dCgpO1xuXG4gICAgICAgIGxldCBjdXJyZW50TWFpbGJveCA9IGNvbm5lY3Rpb24ubWFpbGJveDtcbiAgICAgICAgY29ubmVjdGlvbi5tYWlsYm94ID0gZmFsc2U7XG4gICAgICAgIGNvbm5lY3Rpb24uY3VycmVudFNlbGVjdENvbW1hbmQgPSBmYWxzZTtcbiAgICAgICAgY29ubmVjdGlvbi5zdGF0ZSA9IGNvbm5lY3Rpb24uc3RhdGVzLkFVVEhFTlRJQ0FURUQ7XG5cbiAgICAgICAgaWYgKGN1cnJlbnRNYWlsYm94KSB7XG4gICAgICAgICAgICBjb25uZWN0aW9uLmVtaXQoJ21haWxib3hDbG9zZScsIGN1cnJlbnRNYWlsYm94KTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgY29ubmVjdGlvbi5sb2cud2Fybih7IGVyciwgY2lkOiBjb25uZWN0aW9uLmlkIH0pO1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxufTtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/close.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/compress.js":
|
|
/*!********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/compress.js ***!
|
|
\********************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\n// Requests compression from server\nmodule.exports = async connection => {\n if (!connection.capabilities.has('COMPRESS=DEFLATE') || connection._inflate) {\n // nothing to do here\n return false;\n }\n\n let response;\n try {\n response = await connection.exec('COMPRESS', [{ type: 'ATOM', value: 'DEFLATE' }]);\n response.next();\n return true;\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvY29tcHJlc3MuanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSx3REFBd0QsZ0NBQWdDO0FBQ3hGO0FBQ0E7QUFDQSxNQUFNO0FBQ04sOEJBQThCLHlCQUF5QjtBQUN2RDtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L2xpYi9jb21tYW5kcy9jb21wcmVzcy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbi8vIFJlcXVlc3RzIGNvbXByZXNzaW9uIGZyb20gc2VydmVyXG5tb2R1bGUuZXhwb3J0cyA9IGFzeW5jIGNvbm5lY3Rpb24gPT4ge1xuICAgIGlmICghY29ubmVjdGlvbi5jYXBhYmlsaXRpZXMuaGFzKCdDT01QUkVTUz1ERUZMQVRFJykgfHwgY29ubmVjdGlvbi5faW5mbGF0ZSkge1xuICAgICAgICAvLyBub3RoaW5nIHRvIGRvIGhlcmVcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cblxuICAgIGxldCByZXNwb25zZTtcbiAgICB0cnkge1xuICAgICAgICByZXNwb25zZSA9IGF3YWl0IGNvbm5lY3Rpb24uZXhlYygnQ09NUFJFU1MnLCBbeyB0eXBlOiAnQVRPTScsIHZhbHVlOiAnREVGTEFURScgfV0pO1xuICAgICAgICByZXNwb25zZS5uZXh0KCk7XG4gICAgICAgIHJldHVybiB0cnVlO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICBjb25uZWN0aW9uLmxvZy53YXJuKHsgZXJyLCBjaWQ6IGNvbm5lY3Rpb24uaWQgfSk7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG59O1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/compress.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/copy.js":
|
|
/*!****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/copy.js ***!
|
|
\****************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { getStatusCode, normalizePath, encodePath, expandRange, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(action-browser)/./node_modules/imapflow/lib/tools.js\");\n\n// Copies messages from current mailbox to some other mailbox\nmodule.exports = async (connection, range, destination, options) => {\n if (connection.state !== connection.states.SELECTED || !range || !destination) {\n // nothing to do here\n return;\n }\n\n options = options || {};\n destination = normalizePath(connection, destination);\n\n let attributes = [\n { type: 'SEQUENCE', value: range },\n { type: 'ATOM', value: encodePath(connection, destination) }\n ];\n\n let response;\n try {\n response = await connection.exec(options.uid ? 'UID COPY' : 'COPY', attributes);\n response.next();\n\n let map = { path: connection.mailbox.path, destination };\n let section = response.response.attributes && response.response.attributes[0] && response.response.attributes[0].section;\n let responseCode = section && section.length && section[0] && typeof section[0].value === 'string' ? section[0].value : '';\n switch (responseCode) {\n case 'COPYUID':\n {\n let uidValidity = section[1] && typeof section[1].value === 'string' && !isNaN(section[1].value) ? BigInt(section[1].value) : false;\n if (uidValidity) {\n map.uidValidity = uidValidity;\n }\n\n let sourceUids = section[2] && typeof section[2].value === 'string' ? expandRange(section[2].value) : false;\n let destinationUids = section[3] && typeof section[3].value === 'string' ? expandRange(section[3].value) : false;\n if (sourceUids && destinationUids && sourceUids.length === destinationUids.length) {\n map.uidMap = new Map(sourceUids.map((uid, i) => [uid, destinationUids[i]]));\n }\n }\n break;\n }\n\n return map;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvY29weS5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYixRQUFRLHNFQUFzRSxFQUFFLG1CQUFPLENBQUMsMEVBQWE7O0FBRXJHO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0EsVUFBVSxnQ0FBZ0M7QUFDMUMsVUFBVTtBQUNWOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLG9CQUFvQjtBQUNwQjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDhCQUE4Qix5QkFBeUI7QUFDdkQ7QUFDQTtBQUNBIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvY29weS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IHsgZ2V0U3RhdHVzQ29kZSwgbm9ybWFsaXplUGF0aCwgZW5jb2RlUGF0aCwgZXhwYW5kUmFuZ2UsIGdldEVycm9yVGV4dCB9ID0gcmVxdWlyZSgnLi4vdG9vbHMuanMnKTtcblxuLy8gQ29waWVzIG1lc3NhZ2VzIGZyb20gY3VycmVudCBtYWlsYm94IHRvIHNvbWUgb3RoZXIgbWFpbGJveFxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyAoY29ubmVjdGlvbiwgcmFuZ2UsIGRlc3RpbmF0aW9uLCBvcHRpb25zKSA9PiB7XG4gICAgaWYgKGNvbm5lY3Rpb24uc3RhdGUgIT09IGNvbm5lY3Rpb24uc3RhdGVzLlNFTEVDVEVEIHx8ICFyYW5nZSB8fCAhZGVzdGluYXRpb24pIHtcbiAgICAgICAgLy8gbm90aGluZyB0byBkbyBoZXJlXG4gICAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBvcHRpb25zID0gb3B0aW9ucyB8fCB7fTtcbiAgICBkZXN0aW5hdGlvbiA9IG5vcm1hbGl6ZVBhdGgoY29ubmVjdGlvbiwgZGVzdGluYXRpb24pO1xuXG4gICAgbGV0IGF0dHJpYnV0ZXMgPSBbXG4gICAgICAgIHsgdHlwZTogJ1NFUVVFTkNFJywgdmFsdWU6IHJhbmdlIH0sXG4gICAgICAgIHsgdHlwZTogJ0FUT00nLCB2YWx1ZTogZW5jb2RlUGF0aChjb25uZWN0aW9uLCBkZXN0aW5hdGlvbikgfVxuICAgIF07XG5cbiAgICBsZXQgcmVzcG9uc2U7XG4gICAgdHJ5IHtcbiAgICAgICAgcmVzcG9uc2UgPSBhd2FpdCBjb25uZWN0aW9uLmV4ZWMob3B0aW9ucy51aWQgPyAnVUlEIENPUFknIDogJ0NPUFknLCBhdHRyaWJ1dGVzKTtcbiAgICAgICAgcmVzcG9uc2UubmV4dCgpO1xuXG4gICAgICAgIGxldCBtYXAgPSB7IHBhdGg6IGNvbm5lY3Rpb24ubWFpbGJveC5wYXRoLCBkZXN0aW5hdGlvbiB9O1xuICAgICAgICBsZXQgc2VjdGlvbiA9IHJlc3BvbnNlLnJlc3BvbnNlLmF0dHJpYnV0ZXMgJiYgcmVzcG9uc2UucmVzcG9uc2UuYXR0cmlidXRlc1swXSAmJiByZXNwb25zZS5yZXNwb25zZS5hdHRyaWJ1dGVzWzBdLnNlY3Rpb247XG4gICAgICAgIGxldCByZXNwb25zZUNvZGUgPSBzZWN0aW9uICYmIHNlY3Rpb24ubGVuZ3RoICYmIHNlY3Rpb25bMF0gJiYgdHlwZW9mIHNlY3Rpb25bMF0udmFsdWUgPT09ICdzdHJpbmcnID8gc2VjdGlvblswXS52YWx1ZSA6ICcnO1xuICAgICAgICBzd2l0Y2ggKHJlc3BvbnNlQ29kZSkge1xuICAgICAgICAgICAgY2FzZSAnQ09QWVVJRCc6XG4gICAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgICAgICBsZXQgdWlkVmFsaWRpdHkgPSBzZWN0aW9uWzFdICYmIHR5cGVvZiBzZWN0aW9uWzFdLnZhbHVlID09PSAnc3RyaW5nJyAmJiAhaXNOYU4oc2VjdGlvblsxXS52YWx1ZSkgPyBCaWdJbnQoc2VjdGlvblsxXS52YWx1ZSkgOiBmYWxzZTtcbiAgICAgICAgICAgICAgICAgICAgaWYgKHVpZFZhbGlkaXR5KSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBtYXAudWlkVmFsaWRpdHkgPSB1aWRWYWxpZGl0eTtcbiAgICAgICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgICAgIGxldCBzb3VyY2VVaWRzID0gc2VjdGlvblsyXSAmJiB0eXBlb2Ygc2VjdGlvblsyXS52YWx1ZSA9PT0gJ3N0cmluZycgPyBleHBhbmRSYW5nZShzZWN0aW9uWzJdLnZhbHVlKSA6IGZhbHNlO1xuICAgICAgICAgICAgICAgICAgICBsZXQgZGVzdGluYXRpb25VaWRzID0gc2VjdGlvblszXSAmJiB0eXBlb2Ygc2VjdGlvblszXS52YWx1ZSA9PT0gJ3N0cmluZycgPyBleHBhbmRSYW5nZShzZWN0aW9uWzNdLnZhbHVlKSA6IGZhbHNlO1xuICAgICAgICAgICAgICAgICAgICBpZiAoc291cmNlVWlkcyAmJiBkZXN0aW5hdGlvblVpZHMgJiYgc291cmNlVWlkcy5sZW5ndGggPT09IGRlc3RpbmF0aW9uVWlkcy5sZW5ndGgpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIG1hcC51aWRNYXAgPSBuZXcgTWFwKHNvdXJjZVVpZHMubWFwKCh1aWQsIGkpID0+IFt1aWQsIGRlc3RpbmF0aW9uVWlkc1tpXV0pKTtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICBicmVhaztcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBtYXA7XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICAgIGxldCBlcnJvckNvZGUgPSBnZXRTdGF0dXNDb2RlKGVyci5yZXNwb25zZSk7XG4gICAgICAgIGlmIChlcnJvckNvZGUpIHtcbiAgICAgICAgICAgIGVyci5zZXJ2ZXJSZXNwb25zZUNvZGUgPSBlcnJvckNvZGU7XG4gICAgICAgIH1cbiAgICAgICAgZXJyLnJlc3BvbnNlID0gYXdhaXQgZ2V0RXJyb3JUZXh0KGVyci5yZXNwb25zZSk7XG5cbiAgICAgICAgY29ubmVjdGlvbi5sb2cud2Fybih7IGVyciwgY2lkOiBjb25uZWN0aW9uLmlkIH0pO1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxufTtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/copy.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/create.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/create.js ***!
|
|
\******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { encodePath, normalizePath, getStatusCode, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(action-browser)/./node_modules/imapflow/lib/tools.js\");\n\n// Creates a new mailbox\nmodule.exports = async (connection, path) => {\n if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state)) {\n // nothing to do here\n return;\n }\n\n path = normalizePath(connection, path);\n\n let response;\n try {\n let map = {\n path\n };\n response = await connection.exec('CREATE', [{ type: 'ATOM', value: encodePath(connection, path) }]);\n\n let section =\n response.response.attributes &&\n response.response.attributes[0] &&\n response.response.attributes[0].section &&\n response.response.attributes[0].section.length\n ? response.response.attributes[0].section\n : false;\n\n if (section) {\n let key;\n section.forEach((attribute, i) => {\n if (i % 2 === 0) {\n key = attribute && typeof attribute.value === 'string' ? attribute.value : false;\n return;\n }\n\n if (!key) {\n return;\n }\n\n let value;\n switch (key.toLowerCase()) {\n case 'mailboxid':\n key = 'mailboxId';\n value = Array.isArray(attribute) && attribute[0] && typeof attribute[0].value === 'string' ? attribute[0].value : false;\n break;\n }\n\n if (key && value) {\n map[key] = value;\n }\n });\n }\n\n map.created = true;\n response.next();\n\n //make sure we are subscribed to the new folder as well\n await connection.run('SUBSCRIBE', path);\n\n return map;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n switch (errorCode) {\n case 'ALREADYEXISTS':\n // no need to do anything, mailbox already exists\n return {\n path,\n created: false\n };\n }\n\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n\n connection.log.warn({ err, cid: connection.id });\n throw err;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvY3JlYXRlLmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViLFFBQVEseURBQXlELEVBQUUsbUJBQU8sQ0FBQywwRUFBYTs7QUFFeEY7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxzREFBc0QsbURBQW1EOztBQUV6RztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBLDhCQUE4Qix5QkFBeUI7QUFDdkQ7QUFDQTtBQUNBIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvY3JlYXRlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgeyBlbmNvZGVQYXRoLCBub3JtYWxpemVQYXRoLCBnZXRTdGF0dXNDb2RlLCBnZXRFcnJvclRleHQgfSA9IHJlcXVpcmUoJy4uL3Rvb2xzLmpzJyk7XG5cbi8vIENyZWF0ZXMgYSBuZXcgbWFpbGJveFxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyAoY29ubmVjdGlvbiwgcGF0aCkgPT4ge1xuICAgIGlmICghW2Nvbm5lY3Rpb24uc3RhdGVzLkFVVEhFTlRJQ0FURUQsIGNvbm5lY3Rpb24uc3RhdGVzLlNFTEVDVEVEXS5pbmNsdWRlcyhjb25uZWN0aW9uLnN0YXRlKSkge1xuICAgICAgICAvLyBub3RoaW5nIHRvIGRvIGhlcmVcbiAgICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIHBhdGggPSBub3JtYWxpemVQYXRoKGNvbm5lY3Rpb24sIHBhdGgpO1xuXG4gICAgbGV0IHJlc3BvbnNlO1xuICAgIHRyeSB7XG4gICAgICAgIGxldCBtYXAgPSB7XG4gICAgICAgICAgICBwYXRoXG4gICAgICAgIH07XG4gICAgICAgIHJlc3BvbnNlID0gYXdhaXQgY29ubmVjdGlvbi5leGVjKCdDUkVBVEUnLCBbeyB0eXBlOiAnQVRPTScsIHZhbHVlOiBlbmNvZGVQYXRoKGNvbm5lY3Rpb24sIHBhdGgpIH1dKTtcblxuICAgICAgICBsZXQgc2VjdGlvbiA9XG4gICAgICAgICAgICByZXNwb25zZS5yZXNwb25zZS5hdHRyaWJ1dGVzICYmXG4gICAgICAgICAgICByZXNwb25zZS5yZXNwb25zZS5hdHRyaWJ1dGVzWzBdICYmXG4gICAgICAgICAgICByZXNwb25zZS5yZXNwb25zZS5hdHRyaWJ1dGVzWzBdLnNlY3Rpb24gJiZcbiAgICAgICAgICAgIHJlc3BvbnNlLnJlc3BvbnNlLmF0dHJpYnV0ZXNbMF0uc2VjdGlvbi5sZW5ndGhcbiAgICAgICAgICAgICAgICA/IHJlc3BvbnNlLnJlc3BvbnNlLmF0dHJpYnV0ZXNbMF0uc2VjdGlvblxuICAgICAgICAgICAgICAgIDogZmFsc2U7XG5cbiAgICAgICAgaWYgKHNlY3Rpb24pIHtcbiAgICAgICAgICAgIGxldCBrZXk7XG4gICAgICAgICAgICBzZWN0aW9uLmZvckVhY2goKGF0dHJpYnV0ZSwgaSkgPT4ge1xuICAgICAgICAgICAgICAgIGlmIChpICUgMiA9PT0gMCkge1xuICAgICAgICAgICAgICAgICAgICBrZXkgPSBhdHRyaWJ1dGUgJiYgdHlwZW9mIGF0dHJpYnV0ZS52YWx1ZSA9PT0gJ3N0cmluZycgPyBhdHRyaWJ1dGUudmFsdWUgOiBmYWxzZTtcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgIGlmICgha2V5KSB7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICBsZXQgdmFsdWU7XG4gICAgICAgICAgICAgICAgc3dpdGNoIChrZXkudG9Mb3dlckNhc2UoKSkge1xuICAgICAgICAgICAgICAgICAgICBjYXNlICdtYWlsYm94aWQnOlxuICAgICAgICAgICAgICAgICAgICAgICAga2V5ID0gJ21haWxib3hJZCc7XG4gICAgICAgICAgICAgICAgICAgICAgICB2YWx1ZSA9IEFycmF5LmlzQXJyYXkoYXR0cmlidXRlKSAmJiBhdHRyaWJ1dGVbMF0gJiYgdHlwZW9mIGF0dHJpYnV0ZVswXS52YWx1ZSA9PT0gJ3N0cmluZycgPyBhdHRyaWJ1dGVbMF0udmFsdWUgOiBmYWxzZTtcbiAgICAgICAgICAgICAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgIGlmIChrZXkgJiYgdmFsdWUpIHtcbiAgICAgICAgICAgICAgICAgICAgbWFwW2tleV0gPSB2YWx1ZTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfVxuXG4gICAgICAgIG1hcC5jcmVhdGVkID0gdHJ1ZTtcbiAgICAgICAgcmVzcG9uc2UubmV4dCgpO1xuXG4gICAgICAgIC8vbWFrZSBzdXJlIHdlIGFyZSBzdWJzY3JpYmVkIHRvIHRoZSBuZXcgZm9sZGVyIGFzIHdlbGxcbiAgICAgICAgYXdhaXQgY29ubmVjdGlvbi5ydW4oJ1NVQlNDUklCRScsIHBhdGgpO1xuXG4gICAgICAgIHJldHVybiBtYXA7XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICAgIGxldCBlcnJvckNvZGUgPSBnZXRTdGF0dXNDb2RlKGVyci5yZXNwb25zZSk7XG4gICAgICAgIGlmIChlcnJvckNvZGUpIHtcbiAgICAgICAgICAgIGVyci5zZXJ2ZXJSZXNwb25zZUNvZGUgPSBlcnJvckNvZGU7XG4gICAgICAgIH1cbiAgICAgICAgZXJyLnJlc3BvbnNlID0gYXdhaXQgZ2V0RXJyb3JUZXh0KGVyci5yZXNwb25zZSk7XG5cbiAgICAgICAgc3dpdGNoIChlcnJvckNvZGUpIHtcbiAgICAgICAgICAgIGNhc2UgJ0FMUkVBRFlFWElTVFMnOlxuICAgICAgICAgICAgICAgIC8vIG5vIG5lZWQgdG8gZG8gYW55dGhpbmcsIG1haWxib3ggYWxyZWFkeSBleGlzdHNcbiAgICAgICAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgICAgICAgICBwYXRoLFxuICAgICAgICAgICAgICAgICAgICBjcmVhdGVkOiBmYWxzZVxuICAgICAgICAgICAgICAgIH07XG4gICAgICAgIH1cblxuICAgICAgICBpZiAoZXJyb3JDb2RlKSB7XG4gICAgICAgICAgICBlcnIuc2VydmVyUmVzcG9uc2VDb2RlID0gZXJyb3JDb2RlO1xuICAgICAgICB9XG5cbiAgICAgICAgY29ubmVjdGlvbi5sb2cud2Fybih7IGVyciwgY2lkOiBjb25uZWN0aW9uLmlkIH0pO1xuICAgICAgICB0aHJvdyBlcnI7XG4gICAgfVxufTtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/create.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/delete.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/delete.js ***!
|
|
\******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { encodePath, normalizePath, getStatusCode, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(action-browser)/./node_modules/imapflow/lib/tools.js\");\n\n// Deletes an existing mailbox\nmodule.exports = async (connection, path) => {\n if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state)) {\n // nothing to do here\n return;\n }\n\n path = normalizePath(connection, path);\n\n if (connection.states.SELECTED && connection.mailbox.path === path) {\n await connection.run('CLOSE');\n }\n\n let response;\n try {\n let map = {\n path\n };\n response = await connection.exec('DELETE', [{ type: 'ATOM', value: encodePath(connection, path) }]);\n response.next();\n return map;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n throw err;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvZGVsZXRlLmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViLFFBQVEseURBQXlELEVBQUUsbUJBQU8sQ0FBQywwRUFBYTs7QUFFeEY7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esc0RBQXNELG1EQUFtRDtBQUN6RztBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsOEJBQThCLHlCQUF5QjtBQUN2RDtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L2xpYi9jb21tYW5kcy9kZWxldGUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCB7IGVuY29kZVBhdGgsIG5vcm1hbGl6ZVBhdGgsIGdldFN0YXR1c0NvZGUsIGdldEVycm9yVGV4dCB9ID0gcmVxdWlyZSgnLi4vdG9vbHMuanMnKTtcblxuLy8gRGVsZXRlcyBhbiBleGlzdGluZyBtYWlsYm94XG5tb2R1bGUuZXhwb3J0cyA9IGFzeW5jIChjb25uZWN0aW9uLCBwYXRoKSA9PiB7XG4gICAgaWYgKCFbY29ubmVjdGlvbi5zdGF0ZXMuQVVUSEVOVElDQVRFRCwgY29ubmVjdGlvbi5zdGF0ZXMuU0VMRUNURURdLmluY2x1ZGVzKGNvbm5lY3Rpb24uc3RhdGUpKSB7XG4gICAgICAgIC8vIG5vdGhpbmcgdG8gZG8gaGVyZVxuICAgICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgcGF0aCA9IG5vcm1hbGl6ZVBhdGgoY29ubmVjdGlvbiwgcGF0aCk7XG5cbiAgICBpZiAoY29ubmVjdGlvbi5zdGF0ZXMuU0VMRUNURUQgJiYgY29ubmVjdGlvbi5tYWlsYm94LnBhdGggPT09IHBhdGgpIHtcbiAgICAgICAgYXdhaXQgY29ubmVjdGlvbi5ydW4oJ0NMT1NFJyk7XG4gICAgfVxuXG4gICAgbGV0IHJlc3BvbnNlO1xuICAgIHRyeSB7XG4gICAgICAgIGxldCBtYXAgPSB7XG4gICAgICAgICAgICBwYXRoXG4gICAgICAgIH07XG4gICAgICAgIHJlc3BvbnNlID0gYXdhaXQgY29ubmVjdGlvbi5leGVjKCdERUxFVEUnLCBbeyB0eXBlOiAnQVRPTScsIHZhbHVlOiBlbmNvZGVQYXRoKGNvbm5lY3Rpb24sIHBhdGgpIH1dKTtcbiAgICAgICAgcmVzcG9uc2UubmV4dCgpO1xuICAgICAgICByZXR1cm4gbWFwO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICBsZXQgZXJyb3JDb2RlID0gZ2V0U3RhdHVzQ29kZShlcnIucmVzcG9uc2UpO1xuICAgICAgICBpZiAoZXJyb3JDb2RlKSB7XG4gICAgICAgICAgICBlcnIuc2VydmVyUmVzcG9uc2VDb2RlID0gZXJyb3JDb2RlO1xuICAgICAgICB9XG4gICAgICAgIGVyci5yZXNwb25zZSA9IGF3YWl0IGdldEVycm9yVGV4dChlcnIucmVzcG9uc2UpO1xuXG4gICAgICAgIGNvbm5lY3Rpb24ubG9nLndhcm4oeyBlcnIsIGNpZDogY29ubmVjdGlvbi5pZCB9KTtcbiAgICAgICAgdGhyb3cgZXJyO1xuICAgIH1cbn07XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/delete.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/enable.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/enable.js ***!
|
|
\******************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\n// Enables extensions\nmodule.exports = async (connection, extensionList) => {\n if (!connection.capabilities.has('ENABLE') || connection.state !== connection.states.AUTHENTICATED) {\n // nothing to do here\n return;\n }\n\n extensionList = extensionList.filter(extension => connection.capabilities.has(extension.toUpperCase()));\n if (!extensionList.length) {\n return;\n }\n\n let response;\n try {\n let enabled = new Set();\n response = await connection.exec(\n 'ENABLE',\n extensionList.map(extension => ({ type: 'ATOM', value: extension.toUpperCase() })),\n {\n untagged: {\n ENABLED: async untagged => {\n if (!untagged.attributes || !untagged.attributes.length) {\n return;\n }\n untagged.attributes.forEach(attr => {\n if (attr.value && typeof attr.value === 'string') {\n enabled.add(attr.value.toUpperCase().trim());\n }\n });\n }\n }\n }\n );\n connection.enabled = enabled;\n response.next();\n return enabled;\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvZW5hYmxlLmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsOENBQThDLDhDQUE4QztBQUM1RjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHlCQUF5QjtBQUN6QjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTiw4QkFBOEIseUJBQXlCO0FBQ3ZEO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL2VuYWJsZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbi8vIEVuYWJsZXMgZXh0ZW5zaW9uc1xubW9kdWxlLmV4cG9ydHMgPSBhc3luYyAoY29ubmVjdGlvbiwgZXh0ZW5zaW9uTGlzdCkgPT4ge1xuICAgIGlmICghY29ubmVjdGlvbi5jYXBhYmlsaXRpZXMuaGFzKCdFTkFCTEUnKSB8fCBjb25uZWN0aW9uLnN0YXRlICE9PSBjb25uZWN0aW9uLnN0YXRlcy5BVVRIRU5USUNBVEVEKSB7XG4gICAgICAgIC8vIG5vdGhpbmcgdG8gZG8gaGVyZVxuICAgICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgZXh0ZW5zaW9uTGlzdCA9IGV4dGVuc2lvbkxpc3QuZmlsdGVyKGV4dGVuc2lvbiA9PiBjb25uZWN0aW9uLmNhcGFiaWxpdGllcy5oYXMoZXh0ZW5zaW9uLnRvVXBwZXJDYXNlKCkpKTtcbiAgICBpZiAoIWV4dGVuc2lvbkxpc3QubGVuZ3RoKSB7XG4gICAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBsZXQgcmVzcG9uc2U7XG4gICAgdHJ5IHtcbiAgICAgICAgbGV0IGVuYWJsZWQgPSBuZXcgU2V0KCk7XG4gICAgICAgIHJlc3BvbnNlID0gYXdhaXQgY29ubmVjdGlvbi5leGVjKFxuICAgICAgICAgICAgJ0VOQUJMRScsXG4gICAgICAgICAgICBleHRlbnNpb25MaXN0Lm1hcChleHRlbnNpb24gPT4gKHsgdHlwZTogJ0FUT00nLCB2YWx1ZTogZXh0ZW5zaW9uLnRvVXBwZXJDYXNlKCkgfSkpLFxuICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIHVudGFnZ2VkOiB7XG4gICAgICAgICAgICAgICAgICAgIEVOQUJMRUQ6IGFzeW5jIHVudGFnZ2VkID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmICghdW50YWdnZWQuYXR0cmlidXRlcyB8fCAhdW50YWdnZWQuYXR0cmlidXRlcy5sZW5ndGgpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICB1bnRhZ2dlZC5hdHRyaWJ1dGVzLmZvckVhY2goYXR0ciA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgaWYgKGF0dHIudmFsdWUgJiYgdHlwZW9mIGF0dHIudmFsdWUgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVuYWJsZWQuYWRkKGF0dHIudmFsdWUudG9VcHBlckNhc2UoKS50cmltKCkpO1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICApO1xuICAgICAgICBjb25uZWN0aW9uLmVuYWJsZWQgPSBlbmFibGVkO1xuICAgICAgICByZXNwb25zZS5uZXh0KCk7XG4gICAgICAgIHJldHVybiBlbmFibGVkO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICBjb25uZWN0aW9uLmxvZy53YXJuKHsgZXJyLCBjaWQ6IGNvbm5lY3Rpb24uaWQgfSk7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG59O1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/enable.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/expunge.js":
|
|
/*!*******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/expunge.js ***!
|
|
\*******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { getStatusCode, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(action-browser)/./node_modules/imapflow/lib/tools.js\");\n\n// Deletes specified messages\nmodule.exports = async (connection, range, options) => {\n if (connection.state !== connection.states.SELECTED || !range) {\n // nothing to do here\n return;\n }\n\n options = options || {};\n\n await connection.messageFlagsAdd(range, ['\\\\Deleted'], options);\n\n let byUid = options.uid && connection.capabilities.has('UIDPLUS');\n let command = byUid ? 'UID EXPUNGE' : 'EXPUNGE';\n let attributes = byUid ? [{ type: 'SEQUENCE', value: range }] : false;\n\n let response;\n try {\n response = await connection.exec(command, attributes);\n\n // A OK [HIGHESTMODSEQ 9122] Expunge completed (0.010 + 0.000 + 0.012 secs).\n let section = response.response.attributes && response.response.attributes[0] && response.response.attributes[0].section;\n let responseCode = section && section.length && section[0] && typeof section[0].value === 'string' ? section[0].value : '';\n if (responseCode.toUpperCase() === 'HIGHESTMODSEQ') {\n let highestModseq = section[1] && typeof section[1].value === 'string' && !isNaN(section[1].value) ? BigInt(section[1].value) : false;\n if (highestModseq && (!connection.mailbox.highestModseq || highestModseq > connection.mailbox.highestModseq)) {\n connection.mailbox.highestModseq = highestModseq;\n }\n }\n\n response.next();\n return true;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvZXhwdW5nZS5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYixRQUFRLDhCQUE4QixFQUFFLG1CQUFPLENBQUMsMEVBQWE7O0FBRTdEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0EsZ0NBQWdDLGdDQUFnQzs7QUFFaEU7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsOEJBQThCLHlCQUF5QjtBQUN2RDtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L2xpYi9jb21tYW5kcy9leHB1bmdlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgeyBnZXRTdGF0dXNDb2RlLCBnZXRFcnJvclRleHQgfSA9IHJlcXVpcmUoJy4uL3Rvb2xzLmpzJyk7XG5cbi8vIERlbGV0ZXMgc3BlY2lmaWVkIG1lc3NhZ2VzXG5tb2R1bGUuZXhwb3J0cyA9IGFzeW5jIChjb25uZWN0aW9uLCByYW5nZSwgb3B0aW9ucykgPT4ge1xuICAgIGlmIChjb25uZWN0aW9uLnN0YXRlICE9PSBjb25uZWN0aW9uLnN0YXRlcy5TRUxFQ1RFRCB8fCAhcmFuZ2UpIHtcbiAgICAgICAgLy8gbm90aGluZyB0byBkbyBoZXJlXG4gICAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBvcHRpb25zID0gb3B0aW9ucyB8fCB7fTtcblxuICAgIGF3YWl0IGNvbm5lY3Rpb24ubWVzc2FnZUZsYWdzQWRkKHJhbmdlLCBbJ1xcXFxEZWxldGVkJ10sIG9wdGlvbnMpO1xuXG4gICAgbGV0IGJ5VWlkID0gb3B0aW9ucy51aWQgJiYgY29ubmVjdGlvbi5jYXBhYmlsaXRpZXMuaGFzKCdVSURQTFVTJyk7XG4gICAgbGV0IGNvbW1hbmQgPSBieVVpZCA/ICdVSUQgRVhQVU5HRScgOiAnRVhQVU5HRSc7XG4gICAgbGV0IGF0dHJpYnV0ZXMgPSBieVVpZCA/IFt7IHR5cGU6ICdTRVFVRU5DRScsIHZhbHVlOiByYW5nZSB9XSA6IGZhbHNlO1xuXG4gICAgbGV0IHJlc3BvbnNlO1xuICAgIHRyeSB7XG4gICAgICAgIHJlc3BvbnNlID0gYXdhaXQgY29ubmVjdGlvbi5leGVjKGNvbW1hbmQsIGF0dHJpYnV0ZXMpO1xuXG4gICAgICAgIC8vIEEgT0sgW0hJR0hFU1RNT0RTRVEgOTEyMl0gRXhwdW5nZSBjb21wbGV0ZWQgKDAuMDEwICsgMC4wMDAgKyAwLjAxMiBzZWNzKS5cbiAgICAgICAgbGV0IHNlY3Rpb24gPSByZXNwb25zZS5yZXNwb25zZS5hdHRyaWJ1dGVzICYmIHJlc3BvbnNlLnJlc3BvbnNlLmF0dHJpYnV0ZXNbMF0gJiYgcmVzcG9uc2UucmVzcG9uc2UuYXR0cmlidXRlc1swXS5zZWN0aW9uO1xuICAgICAgICBsZXQgcmVzcG9uc2VDb2RlID0gc2VjdGlvbiAmJiBzZWN0aW9uLmxlbmd0aCAmJiBzZWN0aW9uWzBdICYmIHR5cGVvZiBzZWN0aW9uWzBdLnZhbHVlID09PSAnc3RyaW5nJyA/IHNlY3Rpb25bMF0udmFsdWUgOiAnJztcbiAgICAgICAgaWYgKHJlc3BvbnNlQ29kZS50b1VwcGVyQ2FzZSgpID09PSAnSElHSEVTVE1PRFNFUScpIHtcbiAgICAgICAgICAgIGxldCBoaWdoZXN0TW9kc2VxID0gc2VjdGlvblsxXSAmJiB0eXBlb2Ygc2VjdGlvblsxXS52YWx1ZSA9PT0gJ3N0cmluZycgJiYgIWlzTmFOKHNlY3Rpb25bMV0udmFsdWUpID8gQmlnSW50KHNlY3Rpb25bMV0udmFsdWUpIDogZmFsc2U7XG4gICAgICAgICAgICBpZiAoaGlnaGVzdE1vZHNlcSAmJiAoIWNvbm5lY3Rpb24ubWFpbGJveC5oaWdoZXN0TW9kc2VxIHx8IGhpZ2hlc3RNb2RzZXEgPiBjb25uZWN0aW9uLm1haWxib3guaGlnaGVzdE1vZHNlcSkpIHtcbiAgICAgICAgICAgICAgICBjb25uZWN0aW9uLm1haWxib3guaGlnaGVzdE1vZHNlcSA9IGhpZ2hlc3RNb2RzZXE7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICByZXNwb25zZS5uZXh0KCk7XG4gICAgICAgIHJldHVybiB0cnVlO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICBsZXQgZXJyb3JDb2RlID0gZ2V0U3RhdHVzQ29kZShlcnIucmVzcG9uc2UpO1xuICAgICAgICBpZiAoZXJyb3JDb2RlKSB7XG4gICAgICAgICAgICBlcnIuc2VydmVyUmVzcG9uc2VDb2RlID0gZXJyb3JDb2RlO1xuICAgICAgICB9XG4gICAgICAgIGVyci5yZXNwb25zZSA9IGF3YWl0IGdldEVycm9yVGV4dChlcnIucmVzcG9uc2UpO1xuXG4gICAgICAgIGNvbm5lY3Rpb24ubG9nLndhcm4oeyBlcnIsIGNpZDogY29ubmVjdGlvbi5pZCB9KTtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbn07XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/expunge.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/fetch.js":
|
|
/*!*****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/fetch.js ***!
|
|
\*****************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { formatMessageResponse } = __webpack_require__(/*! ../tools */ \"(action-browser)/./node_modules/imapflow/lib/tools.js\");\n\n// Fetches emails from server\nmodule.exports = async (connection, range, query, options) => {\n if (connection.state !== connection.states.SELECTED || !range) {\n // nothing to do here\n return;\n }\n\n options = options || {};\n\n let mailbox = connection.mailbox;\n\n const commandKey = connection.capabilities.has('BINARY') && options.binary && !connection.disableBinary ? 'BINARY' : 'BODY';\n\n let retryCount = 0;\n while (retryCount < 4) {\n let messages = {\n count: 0,\n list: []\n };\n\n let response;\n try {\n let attributes = [{ type: 'SEQUENCE', value: (range || '*').toString() }];\n\n let queryStructure = [];\n\n let setBodyPeek = (attributes, partial) => {\n let bodyPeek = {\n type: 'ATOM',\n value: `${commandKey}.PEEK`,\n section: [],\n partial\n };\n\n if (Array.isArray(attributes)) {\n attributes.forEach(attribute => {\n bodyPeek.section.push(attribute);\n });\n } else if (attributes) {\n bodyPeek.section.push(attributes);\n }\n\n queryStructure.push(bodyPeek);\n };\n\n ['all', 'fast', 'full', 'uid', 'flags', 'bodyStructure', 'envelope', 'internalDate'].forEach(key => {\n if (query[key]) {\n queryStructure.push({ type: 'ATOM', value: key.toUpperCase() });\n }\n });\n\n if (query.size) {\n queryStructure.push({ type: 'ATOM', value: 'RFC822.SIZE' });\n }\n\n if (query.source) {\n let partial;\n if (typeof query.source === 'object' && (query.source.start || query.source.maxLength)) {\n partial = [Number(query.source.start) || 0];\n if (query.source.maxLength && !isNaN(query.source.maxLength)) {\n partial.push(Number(query.source.maxLength));\n }\n }\n queryStructure.push({ type: 'ATOM', value: `${commandKey}.PEEK`, section: [], partial });\n }\n\n // if possible, always request for unique email id\n if (connection.capabilities.has('OBJECTID')) {\n queryStructure.push({ type: 'ATOM', value: 'EMAILID' });\n } else if (connection.capabilities.has('X-GM-EXT-1')) {\n queryStructure.push({ type: 'ATOM', value: 'X-GM-MSGID' });\n }\n\n if (query.threadId) {\n if (connection.capabilities.has('OBJECTID')) {\n queryStructure.push({ type: 'ATOM', value: 'THREADID' });\n } else if (connection.capabilities.has('X-GM-EXT-1')) {\n queryStructure.push({ type: 'ATOM', value: 'X-GM-THRID' });\n }\n }\n\n if (query.labels) {\n if (connection.capabilities.has('X-GM-EXT-1')) {\n queryStructure.push({ type: 'ATOM', value: 'X-GM-LABELS' });\n }\n }\n\n // always ask for modseq if possible\n if (connection.enabled.has('CONDSTORE') && !mailbox.noModseq) {\n queryStructure.push({ type: 'ATOM', value: 'MODSEQ' });\n }\n\n // always make sure to include UID in the request as well even though server might auto-add it itself\n if (!query.uid) {\n queryStructure.push({ type: 'ATOM', value: 'UID' });\n }\n\n if (query.headers) {\n if (Array.isArray(query.headers)) {\n setBodyPeek([{ type: 'ATOM', value: 'HEADER.FIELDS' }, query.headers.map(header => ({ type: 'ATOM', value: header }))]);\n } else {\n setBodyPeek({ type: 'ATOM', value: 'HEADER' });\n }\n }\n\n if (query.bodyParts && query.bodyParts.length) {\n query.bodyParts.forEach(part => {\n if (!part) {\n return;\n }\n let key;\n let partial;\n if (typeof part === 'object') {\n if (!part.key || typeof part.key !== 'string') {\n return;\n }\n key = part.key.toUpperCase();\n if (part.start || part.maxLength) {\n partial = [Number(part.start) || 0];\n if (part.maxLength && !isNaN(part.maxLength)) {\n partial.push(Number(part.maxLength));\n }\n }\n } else if (typeof part === 'string') {\n key = part.toUpperCase();\n } else {\n return;\n }\n\n setBodyPeek({ type: 'ATOM', value: key }, partial);\n });\n }\n\n if (queryStructure.length === 1) {\n queryStructure = queryStructure.pop();\n }\n\n attributes.push(queryStructure);\n\n if (options.changedSince && connection.enabled.has('CONDSTORE') && !mailbox.noModseq) {\n let changedSinceArgs = [\n {\n type: 'ATOM',\n value: 'CHANGEDSINCE'\n },\n {\n type: 'ATOM',\n value: options.changedSince.toString()\n }\n ];\n\n if (options.uid && connection.enabled.has('QRESYNC')) {\n changedSinceArgs.push({\n type: 'ATOM',\n value: 'VANISHED'\n });\n }\n\n attributes.push(changedSinceArgs);\n }\n\n response = await connection.exec(options.uid ? 'UID FETCH' : 'FETCH', attributes, {\n untagged: {\n FETCH: async untagged => {\n messages.count++;\n let formatted = await formatMessageResponse(untagged, mailbox);\n if (typeof options.onUntaggedFetch === 'function') {\n await new Promise((resolve, reject) => {\n options.onUntaggedFetch(formatted, err => {\n if (err) {\n reject(err);\n } else {\n resolve();\n }\n });\n });\n } else {\n messages.list.push(formatted);\n }\n }\n }\n });\n\n response.next();\n return messages;\n } catch (err) {\n if (err.code === 'ETHROTTLE') {\n // retrying\n connection.log.warn({\n msg: 'Retrying throttled request',\n cid: connection.id,\n code: err.code,\n response: err.responseText,\n throttleReset: err.throttleReset,\n retryCount\n });\n retryCount++;\n continue;\n }\n\n connection.log.warn({ err, cid: connection.id });\n throw err;\n }\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/imapflow/lib/commands/fetch.js","mappings":"AAAa;;AAEb,QAAQ,wBAAwB,EAAE,mBAAO,CAAC,uEAAU;;AAEpD;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,gCAAgC,oDAAoD;;AAEpF;;AAEA;AACA;AACA;AACA,8BAA8B,WAAW;AACzC;AACA;AACA;;AAEA;AACA;AACA;AACA,qBAAqB;AACrB,kBAAkB;AAClB;AACA;;AAEA;AACA;;AAEA;AACA;AACA,0CAA0C,wCAAwC;AAClF;AACA,aAAa;;AAEb;AACA,sCAAsC,oCAAoC;AAC1E;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sCAAsC,wBAAwB,WAAW,8BAA8B;AACvG;;AAEA;AACA;AACA,sCAAsC,gCAAgC;AACtE,cAAc;AACd,sCAAsC,mCAAmC;AACzE;;AAEA;AACA;AACA,0CAA0C,iCAAiC;AAC3E,kBAAkB;AAClB,0CAA0C,mCAAmC;AAC7E;AACA;;AAEA;AACA;AACA,0CAA0C,oCAAoC;AAC9E;AACA;;AAEA;AACA;AACA,sCAAsC,+BAA+B;AACrE;;AAEA;AACA;AACA,sCAAsC,4BAA4B;AAClE;;AAEA;AACA;AACA,mCAAmC,sCAAsC,iCAAiC,6BAA6B;AACvI,kBAAkB;AAClB,kCAAkC,+BAA+B;AACjE;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA,sBAAsB;AACtB;AACA;;AAEA,kCAAkC,0BAA0B;AAC5D,iBAAiB;AACjB;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sCAAsC;AACtC;AACA;AACA,iCAAiC;AACjC,6BAA6B;AAC7B,0BAA0B;AAC1B;AACA;AACA;AACA;AACA,aAAa;;AAEb;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;;AAEA,kCAAkC,yBAAyB;AAC3D;AACA;AACA;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/commands/fetch.js"],"sourcesContent":["'use strict';\n\nconst { formatMessageResponse } = require('../tools');\n\n// Fetches emails from server\nmodule.exports = async (connection, range, query, options) => {\n    if (connection.state !== connection.states.SELECTED || !range) {\n        // nothing to do here\n        return;\n    }\n\n    options = options || {};\n\n    let mailbox = connection.mailbox;\n\n    const commandKey = connection.capabilities.has('BINARY') && options.binary && !connection.disableBinary ? 'BINARY' : 'BODY';\n\n    let retryCount = 0;\n    while (retryCount < 4) {\n        let messages = {\n            count: 0,\n            list: []\n        };\n\n        let response;\n        try {\n            let attributes = [{ type: 'SEQUENCE', value: (range || '*').toString() }];\n\n            let queryStructure = [];\n\n            let setBodyPeek = (attributes, partial) => {\n                let bodyPeek = {\n                    type: 'ATOM',\n                    value: `${commandKey}.PEEK`,\n                    section: [],\n                    partial\n                };\n\n                if (Array.isArray(attributes)) {\n                    attributes.forEach(attribute => {\n                        bodyPeek.section.push(attribute);\n                    });\n                } else if (attributes) {\n                    bodyPeek.section.push(attributes);\n                }\n\n                queryStructure.push(bodyPeek);\n            };\n\n            ['all', 'fast', 'full', 'uid', 'flags', 'bodyStructure', 'envelope', 'internalDate'].forEach(key => {\n                if (query[key]) {\n                    queryStructure.push({ type: 'ATOM', value: key.toUpperCase() });\n                }\n            });\n\n            if (query.size) {\n                queryStructure.push({ type: 'ATOM', value: 'RFC822.SIZE' });\n            }\n\n            if (query.source) {\n                let partial;\n                if (typeof query.source === 'object' && (query.source.start || query.source.maxLength)) {\n                    partial = [Number(query.source.start) || 0];\n                    if (query.source.maxLength && !isNaN(query.source.maxLength)) {\n                        partial.push(Number(query.source.maxLength));\n                    }\n                }\n                queryStructure.push({ type: 'ATOM', value: `${commandKey}.PEEK`, section: [], partial });\n            }\n\n            // if possible, always request for unique email id\n            if (connection.capabilities.has('OBJECTID')) {\n                queryStructure.push({ type: 'ATOM', value: 'EMAILID' });\n            } else if (connection.capabilities.has('X-GM-EXT-1')) {\n                queryStructure.push({ type: 'ATOM', value: 'X-GM-MSGID' });\n            }\n\n            if (query.threadId) {\n                if (connection.capabilities.has('OBJECTID')) {\n                    queryStructure.push({ type: 'ATOM', value: 'THREADID' });\n                } else if (connection.capabilities.has('X-GM-EXT-1')) {\n                    queryStructure.push({ type: 'ATOM', value: 'X-GM-THRID' });\n                }\n            }\n\n            if (query.labels) {\n                if (connection.capabilities.has('X-GM-EXT-1')) {\n                    queryStructure.push({ type: 'ATOM', value: 'X-GM-LABELS' });\n                }\n            }\n\n            // always ask for modseq if possible\n            if (connection.enabled.has('CONDSTORE') && !mailbox.noModseq) {\n                queryStructure.push({ type: 'ATOM', value: 'MODSEQ' });\n            }\n\n            // always make sure to include UID in the request as well even though server might auto-add it itself\n            if (!query.uid) {\n                queryStructure.push({ type: 'ATOM', value: 'UID' });\n            }\n\n            if (query.headers) {\n                if (Array.isArray(query.headers)) {\n                    setBodyPeek([{ type: 'ATOM', value: 'HEADER.FIELDS' }, query.headers.map(header => ({ type: 'ATOM', value: header }))]);\n                } else {\n                    setBodyPeek({ type: 'ATOM', value: 'HEADER' });\n                }\n            }\n\n            if (query.bodyParts && query.bodyParts.length) {\n                query.bodyParts.forEach(part => {\n                    if (!part) {\n                        return;\n                    }\n                    let key;\n                    let partial;\n                    if (typeof part === 'object') {\n                        if (!part.key || typeof part.key !== 'string') {\n                            return;\n                        }\n                        key = part.key.toUpperCase();\n                        if (part.start || part.maxLength) {\n                            partial = [Number(part.start) || 0];\n                            if (part.maxLength && !isNaN(part.maxLength)) {\n                                partial.push(Number(part.maxLength));\n                            }\n                        }\n                    } else if (typeof part === 'string') {\n                        key = part.toUpperCase();\n                    } else {\n                        return;\n                    }\n\n                    setBodyPeek({ type: 'ATOM', value: key }, partial);\n                });\n            }\n\n            if (queryStructure.length === 1) {\n                queryStructure = queryStructure.pop();\n            }\n\n            attributes.push(queryStructure);\n\n            if (options.changedSince && connection.enabled.has('CONDSTORE') && !mailbox.noModseq) {\n                let changedSinceArgs = [\n                    {\n                        type: 'ATOM',\n                        value: 'CHANGEDSINCE'\n                    },\n                    {\n                        type: 'ATOM',\n                        value: options.changedSince.toString()\n                    }\n                ];\n\n                if (options.uid && connection.enabled.has('QRESYNC')) {\n                    changedSinceArgs.push({\n                        type: 'ATOM',\n                        value: 'VANISHED'\n                    });\n                }\n\n                attributes.push(changedSinceArgs);\n            }\n\n            response = await connection.exec(options.uid ? 'UID FETCH' : 'FETCH', attributes, {\n                untagged: {\n                    FETCH: async untagged => {\n                        messages.count++;\n                        let formatted = await formatMessageResponse(untagged, mailbox);\n                        if (typeof options.onUntaggedFetch === 'function') {\n                            await new Promise((resolve, reject) => {\n                                options.onUntaggedFetch(formatted, err => {\n                                    if (err) {\n                                        reject(err);\n                                    } else {\n                                        resolve();\n                                    }\n                                });\n                            });\n                        } else {\n                            messages.list.push(formatted);\n                        }\n                    }\n                }\n            });\n\n            response.next();\n            return messages;\n        } catch (err) {\n            if (err.code === 'ETHROTTLE') {\n                // retrying\n                connection.log.warn({\n                    msg: 'Retrying throttled request',\n                    cid: connection.id,\n                    code: err.code,\n                    response: err.responseText,\n                    throttleReset: err.throttleReset,\n                    retryCount\n                });\n                retryCount++;\n                continue;\n            }\n\n            connection.log.warn({ err, cid: connection.id });\n            throw err;\n        }\n    }\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/fetch.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/id.js":
|
|
/*!**************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/id.js ***!
|
|
\**************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { formatDateTime } = __webpack_require__(/*! ../tools.js */ \"(action-browser)/./node_modules/imapflow/lib/tools.js\");\n\n// Sends ID info to server and updates server info data based on response\nmodule.exports = async (connection, clientInfo) => {\n if (!connection.capabilities.has('ID')) {\n // nothing to do here\n return;\n }\n\n let response;\n try {\n let map = {};\n\n // convert object into an array of value tuples\n let formattedClientInfo = !clientInfo\n ? null\n : Object.keys(clientInfo)\n .map(key => [key, formatValue(key, clientInfo[key])])\n .filter(entry => entry[1])\n .flatMap(entry => entry);\n\n if (formattedClientInfo && !formattedClientInfo.length) {\n // value array has no elements\n formattedClientInfo = null;\n }\n\n response = await connection.exec('ID', [formattedClientInfo], {\n untagged: {\n ID: async untagged => {\n let params = untagged.attributes && untagged.attributes[0];\n let key;\n (Array.isArray(params) ? params : [].concat(params || [])).forEach((val, i) => {\n if (i % 2 === 0) {\n key = val.value;\n } else if (typeof key === 'string' && typeof val.value === 'string') {\n map[key.toLowerCase().trim()] = val.value;\n }\n });\n }\n }\n });\n connection.serverInfo = map;\n response.next();\n return map;\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n\nfunction formatValue(key, value) {\n switch (key.toLowerCase()) {\n case 'date':\n // Date has to be in imap date-time format\n return formatDateTime(value);\n default:\n // Other values are strings without newlines\n return (value || '').toString().replace(/\\s+/g, ' ');\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvaWQuanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWIsUUFBUSxpQkFBaUIsRUFBRSxtQkFBTyxDQUFDLDBFQUFhOztBQUVoRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSwwQkFBMEI7QUFDMUI7QUFDQTtBQUNBLHFCQUFxQjtBQUNyQjtBQUNBO0FBQ0EsU0FBUztBQUNUO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTiw4QkFBOEIseUJBQXlCO0FBQ3ZEO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL2lkLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgeyBmb3JtYXREYXRlVGltZSB9ID0gcmVxdWlyZSgnLi4vdG9vbHMuanMnKTtcblxuLy8gU2VuZHMgSUQgaW5mbyB0byBzZXJ2ZXIgYW5kIHVwZGF0ZXMgc2VydmVyIGluZm8gZGF0YSBiYXNlZCBvbiByZXNwb25zZVxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyAoY29ubmVjdGlvbiwgY2xpZW50SW5mbykgPT4ge1xuICAgIGlmICghY29ubmVjdGlvbi5jYXBhYmlsaXRpZXMuaGFzKCdJRCcpKSB7XG4gICAgICAgIC8vIG5vdGhpbmcgdG8gZG8gaGVyZVxuICAgICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgbGV0IHJlc3BvbnNlO1xuICAgIHRyeSB7XG4gICAgICAgIGxldCBtYXAgPSB7fTtcblxuICAgICAgICAvLyBjb252ZXJ0IG9iamVjdCBpbnRvIGFuIGFycmF5IG9mIHZhbHVlIHR1cGxlc1xuICAgICAgICBsZXQgZm9ybWF0dGVkQ2xpZW50SW5mbyA9ICFjbGllbnRJbmZvXG4gICAgICAgICAgICA/IG51bGxcbiAgICAgICAgICAgIDogT2JqZWN0LmtleXMoY2xpZW50SW5mbylcbiAgICAgICAgICAgICAgICAgIC5tYXAoa2V5ID0+IFtrZXksIGZvcm1hdFZhbHVlKGtleSwgY2xpZW50SW5mb1trZXldKV0pXG4gICAgICAgICAgICAgICAgICAuZmlsdGVyKGVudHJ5ID0+IGVudHJ5WzFdKVxuICAgICAgICAgICAgICAgICAgLmZsYXRNYXAoZW50cnkgPT4gZW50cnkpO1xuXG4gICAgICAgIGlmIChmb3JtYXR0ZWRDbGllbnRJbmZvICYmICFmb3JtYXR0ZWRDbGllbnRJbmZvLmxlbmd0aCkge1xuICAgICAgICAgICAgLy8gdmFsdWUgYXJyYXkgaGFzIG5vIGVsZW1lbnRzXG4gICAgICAgICAgICBmb3JtYXR0ZWRDbGllbnRJbmZvID0gbnVsbDtcbiAgICAgICAgfVxuXG4gICAgICAgIHJlc3BvbnNlID0gYXdhaXQgY29ubmVjdGlvbi5leGVjKCdJRCcsIFtmb3JtYXR0ZWRDbGllbnRJbmZvXSwge1xuICAgICAgICAgICAgdW50YWdnZWQ6IHtcbiAgICAgICAgICAgICAgICBJRDogYXN5bmMgdW50YWdnZWQgPT4ge1xuICAgICAgICAgICAgICAgICAgICBsZXQgcGFyYW1zID0gdW50YWdnZWQuYXR0cmlidXRlcyAmJiB1bnRhZ2dlZC5hdHRyaWJ1dGVzWzBdO1xuICAgICAgICAgICAgICAgICAgICBsZXQga2V5O1xuICAgICAgICAgICAgICAgICAgICAoQXJyYXkuaXNBcnJheShwYXJhbXMpID8gcGFyYW1zIDogW10uY29uY2F0KHBhcmFtcyB8fCBbXSkpLmZvckVhY2goKHZhbCwgaSkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgaWYgKGkgJSAyID09PSAwKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAga2V5ID0gdmFsLnZhbHVlO1xuICAgICAgICAgICAgICAgICAgICAgICAgfSBlbHNlIGlmICh0eXBlb2Yga2V5ID09PSAnc3RyaW5nJyAmJiB0eXBlb2YgdmFsLnZhbHVlID09PSAnc3RyaW5nJykge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG1hcFtrZXkudG9Mb3dlckNhc2UoKS50cmltKCldID0gdmFsLnZhbHVlO1xuICAgICAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgICAgICBjb25uZWN0aW9uLnNlcnZlckluZm8gPSBtYXA7XG4gICAgICAgIHJlc3BvbnNlLm5leHQoKTtcbiAgICAgICAgcmV0dXJuIG1hcDtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgY29ubmVjdGlvbi5sb2cud2Fybih7IGVyciwgY2lkOiBjb25uZWN0aW9uLmlkIH0pO1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxufTtcblxuZnVuY3Rpb24gZm9ybWF0VmFsdWUoa2V5LCB2YWx1ZSkge1xuICAgIHN3aXRjaCAoa2V5LnRvTG93ZXJDYXNlKCkpIHtcbiAgICAgICAgY2FzZSAnZGF0ZSc6XG4gICAgICAgICAgICAvLyBEYXRlIGhhcyB0byBiZSBpbiBpbWFwIGRhdGUtdGltZSBmb3JtYXRcbiAgICAgICAgICAgIHJldHVybiBmb3JtYXREYXRlVGltZSh2YWx1ZSk7XG4gICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgICAvLyBPdGhlciB2YWx1ZXMgYXJlIHN0cmluZ3Mgd2l0aG91dCBuZXdsaW5lc1xuICAgICAgICAgICAgcmV0dXJuICh2YWx1ZSB8fCAnJykudG9TdHJpbmcoKS5yZXBsYWNlKC9cXHMrL2csICcgJyk7XG4gICAgfVxufVxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/id.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/idle.js":
|
|
/*!****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/idle.js ***!
|
|
\****************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\nconst NOOP_INTERVAL = 2 * 60 * 1000;\n\nasync function runIdle(connection) {\n let response;\n\n let preCheckWaitQueue = [];\n try {\n connection.idling = true;\n\n //let idleSent = false;\n let doneRequested = false;\n let doneSent = false;\n let canEnd = false;\n\n let preCheck = async () => {\n doneRequested = true;\n if (canEnd && !doneSent) {\n connection.log.debug({\n src: 'c',\n msg: `DONE`,\n comment: `breaking IDLE`,\n lockId: connection.currentLock?.lockId,\n path: connection.mailbox && connection.mailbox.path\n });\n connection.write('DONE');\n doneSent = true;\n\n connection.idling = false;\n connection.preCheck = false; // unset itself\n\n while (preCheckWaitQueue.length) {\n let { resolve } = preCheckWaitQueue.shift();\n resolve();\n }\n }\n };\n\n let connectionPreCheck = () => {\n let handler = new Promise((resolve, reject) => {\n preCheckWaitQueue.push({ resolve, reject });\n });\n\n connection.log.trace({\n msg: 'Requesting IDLE break',\n lockId: connection.currentLock?.lockId,\n path: connection.mailbox && connection.mailbox.path,\n queued: preCheckWaitQueue.length,\n doneRequested,\n canEnd,\n doneSent\n });\n\n preCheck().catch(err => connection.log.warn({ err, cid: connection.id }));\n\n return handler;\n };\n\n connection.preCheck = connectionPreCheck;\n\n response = await connection.exec('IDLE', false, {\n onPlusTag: async () => {\n connection.log.debug({ msg: `Initiated IDLE, waiting for server input`, lockId: connection.currentLock?.lockId, doneRequested });\n canEnd = true;\n if (doneRequested) {\n try {\n await preCheck();\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n }\n }\n },\n onSend: () => {\n //idleSent = true;\n }\n });\n\n // unset before response.next() if preCheck function is not already cleared (usually is)\n if (typeof connection.preCheck === 'function' && connection.preCheck === connectionPreCheck) {\n connection.log.trace({\n msg: 'Clearing pre-check function',\n lockId: connection.currentLock?.lockId,\n path: connection.mailbox && connection.mailbox.path,\n queued: preCheckWaitQueue.length,\n doneRequested,\n canEnd,\n doneSent\n });\n connection.preCheck = false;\n while (preCheckWaitQueue.length) {\n let { resolve } = preCheckWaitQueue.shift();\n resolve();\n }\n }\n\n response.next();\n return;\n } catch (err) {\n connection.preCheck = false;\n connection.idling = false;\n\n connection.log.warn({ err, cid: connection.id });\n while (preCheckWaitQueue.length) {\n let { reject } = preCheckWaitQueue.shift();\n reject(err);\n }\n return false;\n }\n}\n\n// Listens for changes in mailbox\nmodule.exports = async (connection, maxIdleTime) => {\n if (connection.state !== connection.states.SELECTED) {\n // nothing to do here\n return;\n }\n\n if (connection.capabilities.has('IDLE')) {\n let idleTimer;\n let stillIdling = false;\n let runIdleLoop = async () => {\n if (maxIdleTime) {\n idleTimer = setTimeout(() => {\n if (connection.idling) {\n if (typeof connection.preCheck === 'function') {\n stillIdling = true;\n // request IDLE break if IDLE has been running for allowed time\n connection.log.trace({ msg: 'Max allowed IDLE time reached', cid: connection.id });\n connection.preCheck().catch(err => connection.log.warn({ err, cid: connection.id }));\n }\n }\n }, maxIdleTime);\n }\n let resp = await runIdle(connection);\n clearTimeout(idleTimer);\n if (stillIdling) {\n stillIdling = false;\n return runIdleLoop();\n }\n return resp;\n };\n return runIdleLoop();\n }\n\n let idleTimer;\n return new Promise(resolve => {\n if (!connection.currentSelectCommand) {\n return resolve();\n }\n\n // no IDLE support, fallback to NOOP'ing\n connection.preCheck = async () => {\n connection.preCheck = false; // unset itself\n clearTimeout(idleTimer);\n connection.log.debug({ src: 'c', msg: `breaking NOOP loop` });\n connection.idling = false;\n resolve();\n };\n\n let selectCommand = connection.currentSelectCommand;\n\n let idleCheck = async () => {\n let response;\n switch (connection.missingIdleCommand) {\n case 'SELECT':\n // FIXME: somehow a loop occurs after some time of idling with SELECT\n connection.log.debug({ src: 'c', msg: `Running SELECT to detect changes in folder` });\n response = await connection.exec(selectCommand.command, selectCommand.arguments);\n break;\n\n case 'STATUS':\n {\n let statusArgs = [selectCommand.arguments[0], []]; // path\n for (let key of ['MESSAGES', 'UIDNEXT', 'UIDVALIDITY', 'UNSEEN']) {\n statusArgs[1].push({ type: 'ATOM', value: key.toUpperCase() });\n }\n connection.log.debug({ src: 'c', msg: `Running STATUS to detect changes in folder` });\n response = await connection.exec('STATUS', statusArgs);\n }\n break;\n\n case 'NOOP':\n default:\n response = await connection.exec('NOOP', false, { comment: 'IDLE not supported' });\n break;\n }\n response.next();\n };\n\n let noopInterval = maxIdleTime ? Math.min(NOOP_INTERVAL, maxIdleTime) : NOOP_INTERVAL;\n\n let runLoop = () => {\n idleCheck()\n .then(() => {\n clearTimeout(idleTimer);\n idleTimer = setTimeout(runLoop, noopInterval);\n })\n .catch(err => {\n clearTimeout(idleTimer);\n connection.preCheck = false;\n connection.log.warn({ err, cid: connection.id });\n resolve();\n });\n };\n\n connection.log.debug({ src: 'c', msg: `initiated NOOP loop` });\n connection.idling = true;\n runLoop();\n });\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/imapflow/lib/commands/idle.js","mappings":"AAAa;;AAEb;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;;AAEA;AACA,6CAA6C;;AAE7C;AACA,0BAA0B,UAAU;AACpC;AACA;AACA;AACA;;AAEA;AACA;AACA,yCAAyC,iBAAiB;AAC1D,aAAa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;;AAEb,0DAA0D,yBAAyB;;AAEnF;AACA;;AAEA;;AAEA;AACA;AACA,uCAAuC,wGAAwG;AAC/I;AACA;AACA;AACA;AACA,sBAAsB;AACtB,8CAA8C,yBAAyB;AACvE;AACA;AACA,aAAa;AACb;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,sBAAsB,UAAU;AAChC;AACA;AACA;;AAEA;AACA;AACA,MAAM;AACN;AACA;;AAEA,8BAA8B,yBAAyB;AACvD;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mDAAmD,0DAA0D;AAC7G,qFAAqF,yBAAyB;AAC9G;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,yCAAyC;AACzC;AACA,mCAAmC,qCAAqC;AACxE;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,2CAA2C,6DAA6D;AACxG;AACA;;AAEA;AACA;AACA,2EAA2E;AAC3E;AACA,iDAAiD,wCAAwC;AACzF;AACA,+CAA+C,6DAA6D;AAC5G;AACA;AACA;;AAEA;AACA;AACA,sEAAsE,+BAA+B;AACrG;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA,0CAA0C,yBAAyB;AACnE;AACA,iBAAiB;AACjB;;AAEA,+BAA+B,sCAAsC;AACrE;AACA;AACA,KAAK;AACL","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/commands/idle.js"],"sourcesContent":["'use strict';\n\nconst NOOP_INTERVAL = 2 * 60 * 1000;\n\nasync function runIdle(connection) {\n    let response;\n\n    let preCheckWaitQueue = [];\n    try {\n        connection.idling = true;\n\n        //let idleSent = false;\n        let doneRequested = false;\n        let doneSent = false;\n        let canEnd = false;\n\n        let preCheck = async () => {\n            doneRequested = true;\n            if (canEnd && !doneSent) {\n                connection.log.debug({\n                    src: 'c',\n                    msg: `DONE`,\n                    comment: `breaking IDLE`,\n                    lockId: connection.currentLock?.lockId,\n                    path: connection.mailbox && connection.mailbox.path\n                });\n                connection.write('DONE');\n                doneSent = true;\n\n                connection.idling = false;\n                connection.preCheck = false; // unset itself\n\n                while (preCheckWaitQueue.length) {\n                    let { resolve } = preCheckWaitQueue.shift();\n                    resolve();\n                }\n            }\n        };\n\n        let connectionPreCheck = () => {\n            let handler = new Promise((resolve, reject) => {\n                preCheckWaitQueue.push({ resolve, reject });\n            });\n\n            connection.log.trace({\n                msg: 'Requesting IDLE break',\n                lockId: connection.currentLock?.lockId,\n                path: connection.mailbox && connection.mailbox.path,\n                queued: preCheckWaitQueue.length,\n                doneRequested,\n                canEnd,\n                doneSent\n            });\n\n            preCheck().catch(err => connection.log.warn({ err, cid: connection.id }));\n\n            return handler;\n        };\n\n        connection.preCheck = connectionPreCheck;\n\n        response = await connection.exec('IDLE', false, {\n            onPlusTag: async () => {\n                connection.log.debug({ msg: `Initiated IDLE, waiting for server input`, lockId: connection.currentLock?.lockId, doneRequested });\n                canEnd = true;\n                if (doneRequested) {\n                    try {\n                        await preCheck();\n                    } catch (err) {\n                        connection.log.warn({ err, cid: connection.id });\n                    }\n                }\n            },\n            onSend: () => {\n                //idleSent = true;\n            }\n        });\n\n        // unset before response.next() if preCheck function is not already cleared (usually is)\n        if (typeof connection.preCheck === 'function' && connection.preCheck === connectionPreCheck) {\n            connection.log.trace({\n                msg: 'Clearing pre-check function',\n                lockId: connection.currentLock?.lockId,\n                path: connection.mailbox && connection.mailbox.path,\n                queued: preCheckWaitQueue.length,\n                doneRequested,\n                canEnd,\n                doneSent\n            });\n            connection.preCheck = false;\n            while (preCheckWaitQueue.length) {\n                let { resolve } = preCheckWaitQueue.shift();\n                resolve();\n            }\n        }\n\n        response.next();\n        return;\n    } catch (err) {\n        connection.preCheck = false;\n        connection.idling = false;\n\n        connection.log.warn({ err, cid: connection.id });\n        while (preCheckWaitQueue.length) {\n            let { reject } = preCheckWaitQueue.shift();\n            reject(err);\n        }\n        return false;\n    }\n}\n\n// Listens for changes in mailbox\nmodule.exports = async (connection, maxIdleTime) => {\n    if (connection.state !== connection.states.SELECTED) {\n        // nothing to do here\n        return;\n    }\n\n    if (connection.capabilities.has('IDLE')) {\n        let idleTimer;\n        let stillIdling = false;\n        let runIdleLoop = async () => {\n            if (maxIdleTime) {\n                idleTimer = setTimeout(() => {\n                    if (connection.idling) {\n                        if (typeof connection.preCheck === 'function') {\n                            stillIdling = true;\n                            // request IDLE break if IDLE has been running for allowed time\n                            connection.log.trace({ msg: 'Max allowed IDLE time reached', cid: connection.id });\n                            connection.preCheck().catch(err => connection.log.warn({ err, cid: connection.id }));\n                        }\n                    }\n                }, maxIdleTime);\n            }\n            let resp = await runIdle(connection);\n            clearTimeout(idleTimer);\n            if (stillIdling) {\n                stillIdling = false;\n                return runIdleLoop();\n            }\n            return resp;\n        };\n        return runIdleLoop();\n    }\n\n    let idleTimer;\n    return new Promise(resolve => {\n        if (!connection.currentSelectCommand) {\n            return resolve();\n        }\n\n        // no IDLE support, fallback to NOOP'ing\n        connection.preCheck = async () => {\n            connection.preCheck = false; // unset itself\n            clearTimeout(idleTimer);\n            connection.log.debug({ src: 'c', msg: `breaking NOOP loop` });\n            connection.idling = false;\n            resolve();\n        };\n\n        let selectCommand = connection.currentSelectCommand;\n\n        let idleCheck = async () => {\n            let response;\n            switch (connection.missingIdleCommand) {\n                case 'SELECT':\n                    // FIXME: somehow a loop occurs after some time of idling with SELECT\n                    connection.log.debug({ src: 'c', msg: `Running SELECT to detect changes in folder` });\n                    response = await connection.exec(selectCommand.command, selectCommand.arguments);\n                    break;\n\n                case 'STATUS':\n                    {\n                        let statusArgs = [selectCommand.arguments[0], []]; // path\n                        for (let key of ['MESSAGES', 'UIDNEXT', 'UIDVALIDITY', 'UNSEEN']) {\n                            statusArgs[1].push({ type: 'ATOM', value: key.toUpperCase() });\n                        }\n                        connection.log.debug({ src: 'c', msg: `Running STATUS to detect changes in folder` });\n                        response = await connection.exec('STATUS', statusArgs);\n                    }\n                    break;\n\n                case 'NOOP':\n                default:\n                    response = await connection.exec('NOOP', false, { comment: 'IDLE not supported' });\n                    break;\n            }\n            response.next();\n        };\n\n        let noopInterval = maxIdleTime ? Math.min(NOOP_INTERVAL, maxIdleTime) : NOOP_INTERVAL;\n\n        let runLoop = () => {\n            idleCheck()\n                .then(() => {\n                    clearTimeout(idleTimer);\n                    idleTimer = setTimeout(runLoop, noopInterval);\n                })\n                .catch(err => {\n                    clearTimeout(idleTimer);\n                    connection.preCheck = false;\n                    connection.log.warn({ err, cid: connection.id });\n                    resolve();\n                });\n        };\n\n        connection.log.debug({ src: 'c', msg: `initiated NOOP loop` });\n        connection.idling = true;\n        runLoop();\n    });\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/idle.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/list.js":
|
|
/*!****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/list.js ***!
|
|
\****************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { decodePath, encodePath, normalizePath } = __webpack_require__(/*! ../tools.js */ \"(action-browser)/./node_modules/imapflow/lib/tools.js\");\nconst { specialUse } = __webpack_require__(/*! ../special-use */ \"(action-browser)/./node_modules/imapflow/lib/special-use.js\");\n\n// Lists mailboxes from server\nmodule.exports = async (connection, reference, mailbox, options) => {\n options = options || {};\n\n const FLAG_SORT_ORDER = ['\\\\Inbox', '\\\\Flagged', '\\\\Sent', '\\\\Drafts', '\\\\All', '\\\\Archive', '\\\\Junk', '\\\\Trash'];\n const SOURCE_SORT_ORDER = ['user', 'extension', 'name'];\n\n let listCommand = connection.capabilities.has('XLIST') && !connection.capabilities.has('SPECIAL-USE') ? 'XLIST' : 'LIST';\n\n let response;\n try {\n let entries = [];\n\n let statusMap = new Map();\n let returnArgs = [];\n let statusQueryAttributes = [];\n\n if (options.statusQuery) {\n Object.keys(options.statusQuery || {}).forEach(key => {\n if (!options.statusQuery[key]) {\n return;\n }\n\n switch (key.toUpperCase()) {\n case 'MESSAGES':\n case 'RECENT':\n case 'UIDNEXT':\n case 'UIDVALIDITY':\n case 'UNSEEN':\n statusQueryAttributes.push({ type: 'ATOM', value: key.toUpperCase() });\n break;\n\n case 'HIGHESTMODSEQ':\n if (connection.capabilities.has('CONDSTORE')) {\n statusQueryAttributes.push({ type: 'ATOM', value: key.toUpperCase() });\n }\n break;\n }\n });\n }\n\n if (listCommand === 'LIST' && connection.capabilities.has('LIST-STATUS') && statusQueryAttributes.length) {\n returnArgs.push({ type: 'ATOM', value: 'STATUS' }, statusQueryAttributes);\n if (connection.capabilities.has('SPECIAL-USE')) {\n returnArgs.push({ type: 'ATOM', value: 'SPECIAL-USE' });\n }\n }\n\n let specialUseMatches = {};\n let addSpecialUseMatch = (entry, type, source) => {\n if (!specialUseMatches[type]) {\n specialUseMatches[type] = [];\n }\n specialUseMatches[type].push({ entry, source });\n };\n\n let specialUseHints = {};\n if (options.specialUseHints && typeof options.specialUseHints === 'object') {\n for (let type of Object.keys(options.specialUseHints)) {\n if (\n ['sent', 'junk', 'trash', 'drafts', 'archive'].includes(type) &&\n options.specialUseHints[type] &&\n typeof options.specialUseHints[type] === 'string'\n ) {\n specialUseHints[normalizePath(connection, options.specialUseHints[type])] = `\\\\${type.replace(/^./, c => c.toUpperCase())}`;\n }\n }\n }\n\n let runList = async (reference, mailbox) => {\n const cmdArgs = [encodePath(connection, reference), encodePath(connection, mailbox)];\n\n if (returnArgs.length) {\n cmdArgs.push({ type: 'ATOM', value: 'RETURN' }, returnArgs);\n }\n\n response = await connection.exec(listCommand, cmdArgs, {\n untagged: {\n [listCommand]: async untagged => {\n if (!untagged.attributes || !untagged.attributes.length) {\n return;\n }\n\n let entry = {\n path: normalizePath(connection, decodePath(connection, (untagged.attributes[2] && untagged.attributes[2].value) || '')),\n pathAsListed: (untagged.attributes[2] && untagged.attributes[2].value) || '',\n flags: new Set(untagged.attributes[0].map(entry => entry.value)),\n delimiter: untagged.attributes[1] && untagged.attributes[1].value,\n listed: true\n };\n\n if (specialUseHints[entry.path]) {\n addSpecialUseMatch(entry, specialUseHints[entry.path], 'user');\n }\n\n if (listCommand === 'XLIST' && entry.flags.has('\\\\Inbox')) {\n // XLIST specific flag, ignore\n entry.flags.delete('\\\\Inbox');\n if (entry.path !== 'INBOX') {\n // XLIST may use localised inbox name\n addSpecialUseMatch(entry, '\\\\Inbox', 'extension');\n }\n }\n\n if (entry.path.toUpperCase() === 'INBOX') {\n addSpecialUseMatch(entry, '\\\\Inbox', 'name');\n }\n\n if (entry.delimiter && entry.path.charAt(0) === entry.delimiter) {\n entry.path = entry.path.slice(1);\n }\n\n entry.parentPath = entry.delimiter && entry.path ? entry.path.substr(0, entry.path.lastIndexOf(entry.delimiter)) : '';\n entry.parent = entry.delimiter ? entry.path.split(entry.delimiter) : [entry.path];\n entry.name = entry.parent.pop();\n\n let { flag: specialUseFlag, source: flagSource } = specialUse(\n connection.capabilities.has('XLIST') || connection.capabilities.has('SPECIAL-USE'),\n entry\n );\n\n if (specialUseFlag) {\n addSpecialUseMatch(entry, specialUseFlag, flagSource);\n }\n\n entries.push(entry);\n },\n\n STATUS: async untagged => {\n let statusPath = normalizePath(connection, decodePath(connection, (untagged.attributes[0] && untagged.attributes[0].value) || ''));\n let statusList = untagged.attributes && Array.isArray(untagged.attributes[1]) ? untagged.attributes[1] : false;\n if (!statusList || !statusPath) {\n return;\n }\n\n let key;\n\n let map = { path: statusPath };\n\n statusList.forEach((entry, i) => {\n if (i % 2 === 0) {\n key = entry && typeof entry.value === 'string' ? entry.value : false;\n return;\n }\n if (!key || !entry || typeof entry.value !== 'string') {\n return;\n }\n let value = false;\n switch (key.toUpperCase()) {\n case 'MESSAGES':\n key = 'messages';\n value = !isNaN(entry.value) ? Number(entry.value) : false;\n break;\n\n case 'RECENT':\n key = 'recent';\n value = !isNaN(entry.value) ? Number(entry.value) : false;\n break;\n\n case 'UIDNEXT':\n key = 'uidNext';\n value = !isNaN(entry.value) ? Number(entry.value) : false;\n break;\n\n case 'UIDVALIDITY':\n key = 'uidValidity';\n value = !isNaN(entry.value) ? BigInt(entry.value) : false;\n break;\n\n case 'UNSEEN':\n key = 'unseen';\n value = !isNaN(entry.value) ? Number(entry.value) : false;\n break;\n\n case 'HIGHESTMODSEQ':\n key = 'highestModseq';\n value = !isNaN(entry.value) ? BigInt(entry.value) : false;\n break;\n }\n if (value === false) {\n return;\n }\n\n map[key] = value;\n });\n\n statusMap.set(statusPath, map);\n }\n }\n });\n response.next();\n };\n\n let normalizedReference = normalizePath(connection, reference || '');\n await runList(normalizedReference, normalizePath(connection, mailbox || '', true));\n\n if (options.listOnly) {\n return entries;\n }\n\n if (normalizedReference && !specialUseMatches['\\\\Inbox']) {\n // INBOX was most probably not included in the listing if namespace was used\n await runList('', 'INBOX');\n }\n\n if (options.statusQuery) {\n for (let entry of entries) {\n if (!entry.flags.has('\\\\Noselect') && !entry.flags.has('\\\\NonExistent')) {\n if (statusMap.has(entry.path)) {\n entry.status = statusMap.get(entry.path);\n } else if (!statusMap.size) {\n // run STATUS command\n try {\n entry.status = await connection.run('STATUS', entry.path, options.statusQuery);\n } catch (err) {\n entry.status = { error: err };\n }\n }\n }\n }\n }\n\n response = await connection.exec(\n 'LSUB',\n [encodePath(connection, normalizePath(connection, reference || '')), encodePath(connection, normalizePath(connection, mailbox || '', true))],\n {\n untagged: {\n LSUB: async untagged => {\n if (!untagged.attributes || !untagged.attributes.length) {\n return;\n }\n\n let entry = {\n path: normalizePath(connection, decodePath(connection, (untagged.attributes[2] && untagged.attributes[2].value) || '')),\n pathAsListed: (untagged.attributes[2] && untagged.attributes[2].value) || '',\n flags: new Set(untagged.attributes[0].map(entry => entry.value)),\n delimiter: untagged.attributes[1] && untagged.attributes[1].value,\n subscribed: true\n };\n\n if (entry.path.toUpperCase() === 'INBOX') {\n addSpecialUseMatch(entry, '\\\\Inbox', 'name');\n }\n\n if (entry.delimiter && entry.path.charAt(0) === entry.delimiter) {\n entry.path = entry.path.slice(1);\n }\n\n entry.parentPath = entry.delimiter && entry.path ? entry.path.substr(0, entry.path.lastIndexOf(entry.delimiter)) : '';\n entry.parent = entry.delimiter ? entry.path.split(entry.delimiter) : [entry.path];\n entry.name = entry.parent.pop();\n\n let existing = entries.find(existing => existing.path === entry.path);\n if (existing) {\n existing.subscribed = true;\n entry.flags.forEach(flag => existing.flags.add(flag));\n } else {\n // ignore non-listed folders\n /*\n let specialUseFlag = specialUse(connection.capabilities.has('XLIST') || connection.capabilities.has('SPECIAL-USE'), entry);\n if (specialUseFlag && !flagsSeen.has(specialUseFlag)) {\n entry.specialUse = specialUseFlag;\n }\n entries.push(entry);\n */\n }\n }\n }\n }\n );\n response.next();\n\n for (let type of Object.keys(specialUseMatches)) {\n let sortedEntries = specialUseMatches[type].sort((a, b) => {\n let aSource = SOURCE_SORT_ORDER.indexOf(a.source);\n let bSource = SOURCE_SORT_ORDER.indexOf(b.source);\n if (aSource === bSource) {\n return a.entry.path.localeCompare(b.entry.path);\n }\n return aSource - bSource;\n });\n\n if (!sortedEntries[0].entry.specialUse) {\n sortedEntries[0].entry.specialUse = type;\n sortedEntries[0].entry.specialUseSource = sortedEntries[0].source;\n }\n }\n\n let inboxEntry = entries.find(entry => entry.specialUse === '\\\\Inbox');\n if (inboxEntry && !inboxEntry.subscribed) {\n // override server settings and make INBOX always as subscribed\n inboxEntry.subscribed = true;\n }\n\n return entries.sort((a, b) => {\n if (a.specialUse && !b.specialUse) {\n return -1;\n }\n if (!a.specialUse && b.specialUse) {\n return 1;\n }\n if (a.specialUse && b.specialUse) {\n return FLAG_SORT_ORDER.indexOf(a.specialUse) - FLAG_SORT_ORDER.indexOf(b.specialUse);\n }\n\n let aList = [].concat(a.parent).concat(a.name);\n let bList = [].concat(b.parent).concat(b.name);\n\n for (let i = 0; i < aList.length; i++) {\n let aPart = aList[i];\n let bPart = bList[i];\n if (aPart !== bPart) {\n return aPart.localeCompare(bPart || '');\n }\n }\n\n return a.path.localeCompare(b.path);\n });\n } catch (err) {\n connection.log.warn({ msg: 'Failed to list folders', err, cid: connection.id });\n throw err;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/imapflow/lib/commands/list.js","mappings":"AAAa;;AAEb,QAAQ,wCAAwC,EAAE,mBAAO,CAAC,0EAAa;AACvE,QAAQ,aAAa,EAAE,mBAAO,CAAC,mFAAgB;;AAE/C;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,iDAAiD;AACjD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,qDAAqD,wCAAwC;AAC7F;;AAEA;AACA;AACA,yDAAyD,wCAAwC;AACjG;AACA;AACA;AACA,aAAa;AACb;;AAEA;AACA,8BAA8B,+BAA+B;AAC7D;AACA,kCAAkC,oCAAoC;AACtE;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,2CAA2C,eAAe;AAC1D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qGAAqG,yCAAyC;AAC9I;AACA;AACA;;AAEA;AACA;;AAEA;AACA,+BAA+B,+BAA+B;AAC9D;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,8BAA8B,2CAA2C;AACzE;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,qBAAqB;;AAErB;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,oCAAoC;;AAEpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,yBAAyB;;AAEzB;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;AACA,0BAA0B;AAC1B,6CAA6C;AAC7C;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,0BAA0B;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;;AAEb;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,4BAA4B,kBAAkB;AAC9C;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,SAAS;AACT,MAAM;AACN,8BAA8B,wDAAwD;AACtF;AACA;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/commands/list.js"],"sourcesContent":["'use strict';\n\nconst { decodePath, encodePath, normalizePath } = require('../tools.js');\nconst { specialUse } = require('../special-use');\n\n// Lists mailboxes from server\nmodule.exports = async (connection, reference, mailbox, options) => {\n    options = options || {};\n\n    const FLAG_SORT_ORDER = ['\\\\Inbox', '\\\\Flagged', '\\\\Sent', '\\\\Drafts', '\\\\All', '\\\\Archive', '\\\\Junk', '\\\\Trash'];\n    const SOURCE_SORT_ORDER = ['user', 'extension', 'name'];\n\n    let listCommand = connection.capabilities.has('XLIST') && !connection.capabilities.has('SPECIAL-USE') ? 'XLIST' : 'LIST';\n\n    let response;\n    try {\n        let entries = [];\n\n        let statusMap = new Map();\n        let returnArgs = [];\n        let statusQueryAttributes = [];\n\n        if (options.statusQuery) {\n            Object.keys(options.statusQuery || {}).forEach(key => {\n                if (!options.statusQuery[key]) {\n                    return;\n                }\n\n                switch (key.toUpperCase()) {\n                    case 'MESSAGES':\n                    case 'RECENT':\n                    case 'UIDNEXT':\n                    case 'UIDVALIDITY':\n                    case 'UNSEEN':\n                        statusQueryAttributes.push({ type: 'ATOM', value: key.toUpperCase() });\n                        break;\n\n                    case 'HIGHESTMODSEQ':\n                        if (connection.capabilities.has('CONDSTORE')) {\n                            statusQueryAttributes.push({ type: 'ATOM', value: key.toUpperCase() });\n                        }\n                        break;\n                }\n            });\n        }\n\n        if (listCommand === 'LIST' && connection.capabilities.has('LIST-STATUS') && statusQueryAttributes.length) {\n            returnArgs.push({ type: 'ATOM', value: 'STATUS' }, statusQueryAttributes);\n            if (connection.capabilities.has('SPECIAL-USE')) {\n                returnArgs.push({ type: 'ATOM', value: 'SPECIAL-USE' });\n            }\n        }\n\n        let specialUseMatches = {};\n        let addSpecialUseMatch = (entry, type, source) => {\n            if (!specialUseMatches[type]) {\n                specialUseMatches[type] = [];\n            }\n            specialUseMatches[type].push({ entry, source });\n        };\n\n        let specialUseHints = {};\n        if (options.specialUseHints && typeof options.specialUseHints === 'object') {\n            for (let type of Object.keys(options.specialUseHints)) {\n                if (\n                    ['sent', 'junk', 'trash', 'drafts', 'archive'].includes(type) &&\n                    options.specialUseHints[type] &&\n                    typeof options.specialUseHints[type] === 'string'\n                ) {\n                    specialUseHints[normalizePath(connection, options.specialUseHints[type])] = `\\\\${type.replace(/^./, c => c.toUpperCase())}`;\n                }\n            }\n        }\n\n        let runList = async (reference, mailbox) => {\n            const cmdArgs = [encodePath(connection, reference), encodePath(connection, mailbox)];\n\n            if (returnArgs.length) {\n                cmdArgs.push({ type: 'ATOM', value: 'RETURN' }, returnArgs);\n            }\n\n            response = await connection.exec(listCommand, cmdArgs, {\n                untagged: {\n                    [listCommand]: async untagged => {\n                        if (!untagged.attributes || !untagged.attributes.length) {\n                            return;\n                        }\n\n                        let entry = {\n                            path: normalizePath(connection, decodePath(connection, (untagged.attributes[2] && untagged.attributes[2].value) || '')),\n                            pathAsListed: (untagged.attributes[2] && untagged.attributes[2].value) || '',\n                            flags: new Set(untagged.attributes[0].map(entry => entry.value)),\n                            delimiter: untagged.attributes[1] && untagged.attributes[1].value,\n                            listed: true\n                        };\n\n                        if (specialUseHints[entry.path]) {\n                            addSpecialUseMatch(entry, specialUseHints[entry.path], 'user');\n                        }\n\n                        if (listCommand === 'XLIST' && entry.flags.has('\\\\Inbox')) {\n                            // XLIST specific flag, ignore\n                            entry.flags.delete('\\\\Inbox');\n                            if (entry.path !== 'INBOX') {\n                                // XLIST may use localised inbox name\n                                addSpecialUseMatch(entry, '\\\\Inbox', 'extension');\n                            }\n                        }\n\n                        if (entry.path.toUpperCase() === 'INBOX') {\n                            addSpecialUseMatch(entry, '\\\\Inbox', 'name');\n                        }\n\n                        if (entry.delimiter && entry.path.charAt(0) === entry.delimiter) {\n                            entry.path = entry.path.slice(1);\n                        }\n\n                        entry.parentPath = entry.delimiter && entry.path ? entry.path.substr(0, entry.path.lastIndexOf(entry.delimiter)) : '';\n                        entry.parent = entry.delimiter ? entry.path.split(entry.delimiter) : [entry.path];\n                        entry.name = entry.parent.pop();\n\n                        let { flag: specialUseFlag, source: flagSource } = specialUse(\n                            connection.capabilities.has('XLIST') || connection.capabilities.has('SPECIAL-USE'),\n                            entry\n                        );\n\n                        if (specialUseFlag) {\n                            addSpecialUseMatch(entry, specialUseFlag, flagSource);\n                        }\n\n                        entries.push(entry);\n                    },\n\n                    STATUS: async untagged => {\n                        let statusPath = normalizePath(connection, decodePath(connection, (untagged.attributes[0] && untagged.attributes[0].value) || ''));\n                        let statusList = untagged.attributes && Array.isArray(untagged.attributes[1]) ? untagged.attributes[1] : false;\n                        if (!statusList || !statusPath) {\n                            return;\n                        }\n\n                        let key;\n\n                        let map = { path: statusPath };\n\n                        statusList.forEach((entry, i) => {\n                            if (i % 2 === 0) {\n                                key = entry && typeof entry.value === 'string' ? entry.value : false;\n                                return;\n                            }\n                            if (!key || !entry || typeof entry.value !== 'string') {\n                                return;\n                            }\n                            let value = false;\n                            switch (key.toUpperCase()) {\n                                case 'MESSAGES':\n                                    key = 'messages';\n                                    value = !isNaN(entry.value) ? Number(entry.value) : false;\n                                    break;\n\n                                case 'RECENT':\n                                    key = 'recent';\n                                    value = !isNaN(entry.value) ? Number(entry.value) : false;\n                                    break;\n\n                                case 'UIDNEXT':\n                                    key = 'uidNext';\n                                    value = !isNaN(entry.value) ? Number(entry.value) : false;\n                                    break;\n\n                                case 'UIDVALIDITY':\n                                    key = 'uidValidity';\n                                    value = !isNaN(entry.value) ? BigInt(entry.value) : false;\n                                    break;\n\n                                case 'UNSEEN':\n                                    key = 'unseen';\n                                    value = !isNaN(entry.value) ? Number(entry.value) : false;\n                                    break;\n\n                                case 'HIGHESTMODSEQ':\n                                    key = 'highestModseq';\n                                    value = !isNaN(entry.value) ? BigInt(entry.value) : false;\n                                    break;\n                            }\n                            if (value === false) {\n                                return;\n                            }\n\n                            map[key] = value;\n                        });\n\n                        statusMap.set(statusPath, map);\n                    }\n                }\n            });\n            response.next();\n        };\n\n        let normalizedReference = normalizePath(connection, reference || '');\n        await runList(normalizedReference, normalizePath(connection, mailbox || '', true));\n\n        if (options.listOnly) {\n            return entries;\n        }\n\n        if (normalizedReference && !specialUseMatches['\\\\Inbox']) {\n            // INBOX was most probably not included in the listing if namespace was used\n            await runList('', 'INBOX');\n        }\n\n        if (options.statusQuery) {\n            for (let entry of entries) {\n                if (!entry.flags.has('\\\\Noselect') && !entry.flags.has('\\\\NonExistent')) {\n                    if (statusMap.has(entry.path)) {\n                        entry.status = statusMap.get(entry.path);\n                    } else if (!statusMap.size) {\n                        // run STATUS command\n                        try {\n                            entry.status = await connection.run('STATUS', entry.path, options.statusQuery);\n                        } catch (err) {\n                            entry.status = { error: err };\n                        }\n                    }\n                }\n            }\n        }\n\n        response = await connection.exec(\n            'LSUB',\n            [encodePath(connection, normalizePath(connection, reference || '')), encodePath(connection, normalizePath(connection, mailbox || '', true))],\n            {\n                untagged: {\n                    LSUB: async untagged => {\n                        if (!untagged.attributes || !untagged.attributes.length) {\n                            return;\n                        }\n\n                        let entry = {\n                            path: normalizePath(connection, decodePath(connection, (untagged.attributes[2] && untagged.attributes[2].value) || '')),\n                            pathAsListed: (untagged.attributes[2] && untagged.attributes[2].value) || '',\n                            flags: new Set(untagged.attributes[0].map(entry => entry.value)),\n                            delimiter: untagged.attributes[1] && untagged.attributes[1].value,\n                            subscribed: true\n                        };\n\n                        if (entry.path.toUpperCase() === 'INBOX') {\n                            addSpecialUseMatch(entry, '\\\\Inbox', 'name');\n                        }\n\n                        if (entry.delimiter && entry.path.charAt(0) === entry.delimiter) {\n                            entry.path = entry.path.slice(1);\n                        }\n\n                        entry.parentPath = entry.delimiter && entry.path ? entry.path.substr(0, entry.path.lastIndexOf(entry.delimiter)) : '';\n                        entry.parent = entry.delimiter ? entry.path.split(entry.delimiter) : [entry.path];\n                        entry.name = entry.parent.pop();\n\n                        let existing = entries.find(existing => existing.path === entry.path);\n                        if (existing) {\n                            existing.subscribed = true;\n                            entry.flags.forEach(flag => existing.flags.add(flag));\n                        } else {\n                            // ignore non-listed folders\n                            /*\n                            let specialUseFlag = specialUse(connection.capabilities.has('XLIST') || connection.capabilities.has('SPECIAL-USE'), entry);\n                            if (specialUseFlag && !flagsSeen.has(specialUseFlag)) {\n                                entry.specialUse = specialUseFlag;\n                            }\n                            entries.push(entry);\n                            */\n                        }\n                    }\n                }\n            }\n        );\n        response.next();\n\n        for (let type of Object.keys(specialUseMatches)) {\n            let sortedEntries = specialUseMatches[type].sort((a, b) => {\n                let aSource = SOURCE_SORT_ORDER.indexOf(a.source);\n                let bSource = SOURCE_SORT_ORDER.indexOf(b.source);\n                if (aSource === bSource) {\n                    return a.entry.path.localeCompare(b.entry.path);\n                }\n                return aSource - bSource;\n            });\n\n            if (!sortedEntries[0].entry.specialUse) {\n                sortedEntries[0].entry.specialUse = type;\n                sortedEntries[0].entry.specialUseSource = sortedEntries[0].source;\n            }\n        }\n\n        let inboxEntry = entries.find(entry => entry.specialUse === '\\\\Inbox');\n        if (inboxEntry && !inboxEntry.subscribed) {\n            // override server settings and make INBOX always as subscribed\n            inboxEntry.subscribed = true;\n        }\n\n        return entries.sort((a, b) => {\n            if (a.specialUse && !b.specialUse) {\n                return -1;\n            }\n            if (!a.specialUse && b.specialUse) {\n                return 1;\n            }\n            if (a.specialUse && b.specialUse) {\n                return FLAG_SORT_ORDER.indexOf(a.specialUse) - FLAG_SORT_ORDER.indexOf(b.specialUse);\n            }\n\n            let aList = [].concat(a.parent).concat(a.name);\n            let bList = [].concat(b.parent).concat(b.name);\n\n            for (let i = 0; i < aList.length; i++) {\n                let aPart = aList[i];\n                let bPart = bList[i];\n                if (aPart !== bPart) {\n                    return aPart.localeCompare(bPart || '');\n                }\n            }\n\n            return a.path.localeCompare(b.path);\n        });\n    } catch (err) {\n        connection.log.warn({ msg: 'Failed to list folders', err, cid: connection.id });\n        throw err;\n    }\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/list.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/login.js":
|
|
/*!*****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/login.js ***!
|
|
\*****************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { getStatusCode, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(action-browser)/./node_modules/imapflow/lib/tools.js\");\n\n// Authenticates user using LOGIN\nmodule.exports = async (connection, username, password) => {\n if (connection.state !== connection.states.NOT_AUTHENTICATED) {\n // nothing to do here\n return;\n }\n\n try {\n let response = await connection.exec('LOGIN', [\n { type: 'STRING', value: username },\n { type: 'STRING', value: password, sensitive: true }\n ]);\n response.next();\n\n connection.authCapabilities.set('LOGIN', true);\n\n return username;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.authenticationFailed = true;\n err.response = await getErrorText(err.response);\n throw err;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvbG9naW4uanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWIsUUFBUSw4QkFBOEIsRUFBRSxtQkFBTyxDQUFDLDBFQUFhOztBQUU3RDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLGNBQWMsaUNBQWlDO0FBQy9DLGNBQWM7QUFDZDtBQUNBOztBQUVBOztBQUVBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL2xvZ2luLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgeyBnZXRTdGF0dXNDb2RlLCBnZXRFcnJvclRleHQgfSA9IHJlcXVpcmUoJy4uL3Rvb2xzLmpzJyk7XG5cbi8vIEF1dGhlbnRpY2F0ZXMgdXNlciB1c2luZyBMT0dJTlxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyAoY29ubmVjdGlvbiwgdXNlcm5hbWUsIHBhc3N3b3JkKSA9PiB7XG4gICAgaWYgKGNvbm5lY3Rpb24uc3RhdGUgIT09IGNvbm5lY3Rpb24uc3RhdGVzLk5PVF9BVVRIRU5USUNBVEVEKSB7XG4gICAgICAgIC8vIG5vdGhpbmcgdG8gZG8gaGVyZVxuICAgICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgdHJ5IHtcbiAgICAgICAgbGV0IHJlc3BvbnNlID0gYXdhaXQgY29ubmVjdGlvbi5leGVjKCdMT0dJTicsIFtcbiAgICAgICAgICAgIHsgdHlwZTogJ1NUUklORycsIHZhbHVlOiB1c2VybmFtZSB9LFxuICAgICAgICAgICAgeyB0eXBlOiAnU1RSSU5HJywgdmFsdWU6IHBhc3N3b3JkLCBzZW5zaXRpdmU6IHRydWUgfVxuICAgICAgICBdKTtcbiAgICAgICAgcmVzcG9uc2UubmV4dCgpO1xuXG4gICAgICAgIGNvbm5lY3Rpb24uYXV0aENhcGFiaWxpdGllcy5zZXQoJ0xPR0lOJywgdHJ1ZSk7XG5cbiAgICAgICAgcmV0dXJuIHVzZXJuYW1lO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICBsZXQgZXJyb3JDb2RlID0gZ2V0U3RhdHVzQ29kZShlcnIucmVzcG9uc2UpO1xuICAgICAgICBpZiAoZXJyb3JDb2RlKSB7XG4gICAgICAgICAgICBlcnIuc2VydmVyUmVzcG9uc2VDb2RlID0gZXJyb3JDb2RlO1xuICAgICAgICB9XG4gICAgICAgIGVyci5hdXRoZW50aWNhdGlvbkZhaWxlZCA9IHRydWU7XG4gICAgICAgIGVyci5yZXNwb25zZSA9IGF3YWl0IGdldEVycm9yVGV4dChlcnIucmVzcG9uc2UpO1xuICAgICAgICB0aHJvdyBlcnI7XG4gICAgfVxufTtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/login.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/logout.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/logout.js ***!
|
|
\******************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\n// Logs out user and closes connection\nmodule.exports = async connection => {\n if (connection.state === connection.states.LOGOUT) {\n // nothing to do here\n return false;\n }\n\n if (connection.state === connection.states.NOT_AUTHENTICATED) {\n connection.state = connection.states.LOGOUT;\n connection.close();\n return false;\n }\n\n let response;\n try {\n response = await connection.exec('LOGOUT');\n return true;\n } catch (err) {\n if (err.code === 'NoConnection') {\n return true;\n }\n connection.log.warn({ err, cid: connection.id });\n return false;\n } finally {\n // close even if command failed\n connection.state = connection.states.LOGOUT;\n if (response && typeof response.next === 'function') {\n response.next();\n }\n connection.close();\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvbG9nb3V0LmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBLDhCQUE4Qix5QkFBeUI7QUFDdkQ7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL2xvZ291dC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbi8vIExvZ3Mgb3V0IHVzZXIgYW5kIGNsb3NlcyBjb25uZWN0aW9uXG5tb2R1bGUuZXhwb3J0cyA9IGFzeW5jIGNvbm5lY3Rpb24gPT4ge1xuICAgIGlmIChjb25uZWN0aW9uLnN0YXRlID09PSBjb25uZWN0aW9uLnN0YXRlcy5MT0dPVVQpIHtcbiAgICAgICAgLy8gbm90aGluZyB0byBkbyBoZXJlXG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG5cbiAgICBpZiAoY29ubmVjdGlvbi5zdGF0ZSA9PT0gY29ubmVjdGlvbi5zdGF0ZXMuTk9UX0FVVEhFTlRJQ0FURUQpIHtcbiAgICAgICAgY29ubmVjdGlvbi5zdGF0ZSA9IGNvbm5lY3Rpb24uc3RhdGVzLkxPR09VVDtcbiAgICAgICAgY29ubmVjdGlvbi5jbG9zZSgpO1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuXG4gICAgbGV0IHJlc3BvbnNlO1xuICAgIHRyeSB7XG4gICAgICAgIHJlc3BvbnNlID0gYXdhaXQgY29ubmVjdGlvbi5leGVjKCdMT0dPVVQnKTtcbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICAgIGlmIChlcnIuY29kZSA9PT0gJ05vQ29ubmVjdGlvbicpIHtcbiAgICAgICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgICB9XG4gICAgICAgIGNvbm5lY3Rpb24ubG9nLndhcm4oeyBlcnIsIGNpZDogY29ubmVjdGlvbi5pZCB9KTtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH0gZmluYWxseSB7XG4gICAgICAgIC8vIGNsb3NlIGV2ZW4gaWYgY29tbWFuZCBmYWlsZWRcbiAgICAgICAgY29ubmVjdGlvbi5zdGF0ZSA9IGNvbm5lY3Rpb24uc3RhdGVzLkxPR09VVDtcbiAgICAgICAgaWYgKHJlc3BvbnNlICYmIHR5cGVvZiByZXNwb25zZS5uZXh0ID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgICAgICByZXNwb25zZS5uZXh0KCk7XG4gICAgICAgIH1cbiAgICAgICAgY29ubmVjdGlvbi5jbG9zZSgpO1xuICAgIH1cbn07XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/logout.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/move.js":
|
|
/*!****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/move.js ***!
|
|
\****************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { getStatusCode, normalizePath, encodePath, expandRange, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(action-browser)/./node_modules/imapflow/lib/tools.js\");\n\n// Moves messages from current mailbox to some other mailbox\nmodule.exports = async (connection, range, destination, options) => {\n if (connection.state !== connection.states.SELECTED || !range || !destination) {\n // nothing to do here\n return;\n }\n\n options = options || {};\n destination = normalizePath(connection, destination);\n\n let attributes = [\n { type: 'SEQUENCE', value: range },\n { type: 'ATOM', value: encodePath(connection, destination) }\n ];\n\n let map = { path: connection.mailbox.path, destination };\n\n if (!connection.capabilities.has('MOVE')) {\n let result = await connection.messageCopy(range, destination, options);\n await connection.messageDelete(range, Object.assign({ silent: true }, options));\n return result;\n }\n\n let checkMoveInfo = response => {\n let section = response.attributes && response.attributes[0] && response.attributes[0].section;\n let responseCode = section && section.length && section[0] && typeof section[0].value === 'string' ? section[0].value : '';\n switch (responseCode) {\n case 'COPYUID':\n {\n let uidValidity = section[1] && typeof section[1].value === 'string' && !isNaN(section[1].value) ? BigInt(section[1].value) : false;\n if (uidValidity) {\n map.uidValidity = uidValidity;\n }\n\n let sourceUids = section[2] && typeof section[2].value === 'string' ? expandRange(section[2].value) : false;\n let destinationUids = section[3] && typeof section[3].value === 'string' ? expandRange(section[3].value) : false;\n if (sourceUids && destinationUids && sourceUids.length === destinationUids.length) {\n map.uidMap = new Map(sourceUids.map((uid, i) => [uid, destinationUids[i]]));\n }\n }\n break;\n }\n };\n\n let response;\n try {\n response = await connection.exec(options.uid ? 'UID MOVE' : 'MOVE', attributes, {\n untagged: {\n OK: async untagged => {\n checkMoveInfo(untagged);\n }\n }\n });\n response.next();\n\n checkMoveInfo(response.response);\n return map;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvbW92ZS5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYixRQUFRLHNFQUFzRSxFQUFFLG1CQUFPLENBQUMsMEVBQWE7O0FBRXJHO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0EsVUFBVSxnQ0FBZ0M7QUFDMUMsVUFBVTtBQUNWOztBQUVBLGdCQUFnQjs7QUFFaEI7QUFDQTtBQUNBLDhEQUE4RCxjQUFjO0FBQzVFO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7O0FBRUE7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDhCQUE4Qix5QkFBeUI7QUFDdkQ7QUFDQTtBQUNBIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvbW92ZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IHsgZ2V0U3RhdHVzQ29kZSwgbm9ybWFsaXplUGF0aCwgZW5jb2RlUGF0aCwgZXhwYW5kUmFuZ2UsIGdldEVycm9yVGV4dCB9ID0gcmVxdWlyZSgnLi4vdG9vbHMuanMnKTtcblxuLy8gTW92ZXMgbWVzc2FnZXMgZnJvbSBjdXJyZW50IG1haWxib3ggdG8gc29tZSBvdGhlciBtYWlsYm94XG5tb2R1bGUuZXhwb3J0cyA9IGFzeW5jIChjb25uZWN0aW9uLCByYW5nZSwgZGVzdGluYXRpb24sIG9wdGlvbnMpID0+IHtcbiAgICBpZiAoY29ubmVjdGlvbi5zdGF0ZSAhPT0gY29ubmVjdGlvbi5zdGF0ZXMuU0VMRUNURUQgfHwgIXJhbmdlIHx8ICFkZXN0aW5hdGlvbikge1xuICAgICAgICAvLyBub3RoaW5nIHRvIGRvIGhlcmVcbiAgICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIG9wdGlvbnMgPSBvcHRpb25zIHx8IHt9O1xuICAgIGRlc3RpbmF0aW9uID0gbm9ybWFsaXplUGF0aChjb25uZWN0aW9uLCBkZXN0aW5hdGlvbik7XG5cbiAgICBsZXQgYXR0cmlidXRlcyA9IFtcbiAgICAgICAgeyB0eXBlOiAnU0VRVUVOQ0UnLCB2YWx1ZTogcmFuZ2UgfSxcbiAgICAgICAgeyB0eXBlOiAnQVRPTScsIHZhbHVlOiBlbmNvZGVQYXRoKGNvbm5lY3Rpb24sIGRlc3RpbmF0aW9uKSB9XG4gICAgXTtcblxuICAgIGxldCBtYXAgPSB7IHBhdGg6IGNvbm5lY3Rpb24ubWFpbGJveC5wYXRoLCBkZXN0aW5hdGlvbiB9O1xuXG4gICAgaWYgKCFjb25uZWN0aW9uLmNhcGFiaWxpdGllcy5oYXMoJ01PVkUnKSkge1xuICAgICAgICBsZXQgcmVzdWx0ID0gYXdhaXQgY29ubmVjdGlvbi5tZXNzYWdlQ29weShyYW5nZSwgZGVzdGluYXRpb24sIG9wdGlvbnMpO1xuICAgICAgICBhd2FpdCBjb25uZWN0aW9uLm1lc3NhZ2VEZWxldGUocmFuZ2UsIE9iamVjdC5hc3NpZ24oeyBzaWxlbnQ6IHRydWUgfSwgb3B0aW9ucykpO1xuICAgICAgICByZXR1cm4gcmVzdWx0O1xuICAgIH1cblxuICAgIGxldCBjaGVja01vdmVJbmZvID0gcmVzcG9uc2UgPT4ge1xuICAgICAgICBsZXQgc2VjdGlvbiA9IHJlc3BvbnNlLmF0dHJpYnV0ZXMgJiYgcmVzcG9uc2UuYXR0cmlidXRlc1swXSAmJiByZXNwb25zZS5hdHRyaWJ1dGVzWzBdLnNlY3Rpb247XG4gICAgICAgIGxldCByZXNwb25zZUNvZGUgPSBzZWN0aW9uICYmIHNlY3Rpb24ubGVuZ3RoICYmIHNlY3Rpb25bMF0gJiYgdHlwZW9mIHNlY3Rpb25bMF0udmFsdWUgPT09ICdzdHJpbmcnID8gc2VjdGlvblswXS52YWx1ZSA6ICcnO1xuICAgICAgICBzd2l0Y2ggKHJlc3BvbnNlQ29kZSkge1xuICAgICAgICAgICAgY2FzZSAnQ09QWVVJRCc6XG4gICAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgICAgICBsZXQgdWlkVmFsaWRpdHkgPSBzZWN0aW9uWzFdICYmIHR5cGVvZiBzZWN0aW9uWzFdLnZhbHVlID09PSAnc3RyaW5nJyAmJiAhaXNOYU4oc2VjdGlvblsxXS52YWx1ZSkgPyBCaWdJbnQoc2VjdGlvblsxXS52YWx1ZSkgOiBmYWxzZTtcbiAgICAgICAgICAgICAgICAgICAgaWYgKHVpZFZhbGlkaXR5KSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBtYXAudWlkVmFsaWRpdHkgPSB1aWRWYWxpZGl0eTtcbiAgICAgICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgICAgIGxldCBzb3VyY2VVaWRzID0gc2VjdGlvblsyXSAmJiB0eXBlb2Ygc2VjdGlvblsyXS52YWx1ZSA9PT0gJ3N0cmluZycgPyBleHBhbmRSYW5nZShzZWN0aW9uWzJdLnZhbHVlKSA6IGZhbHNlO1xuICAgICAgICAgICAgICAgICAgICBsZXQgZGVzdGluYXRpb25VaWRzID0gc2VjdGlvblszXSAmJiB0eXBlb2Ygc2VjdGlvblszXS52YWx1ZSA9PT0gJ3N0cmluZycgPyBleHBhbmRSYW5nZShzZWN0aW9uWzNdLnZhbHVlKSA6IGZhbHNlO1xuICAgICAgICAgICAgICAgICAgICBpZiAoc291cmNlVWlkcyAmJiBkZXN0aW5hdGlvblVpZHMgJiYgc291cmNlVWlkcy5sZW5ndGggPT09IGRlc3RpbmF0aW9uVWlkcy5sZW5ndGgpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIG1hcC51aWRNYXAgPSBuZXcgTWFwKHNvdXJjZVVpZHMubWFwKCh1aWQsIGkpID0+IFt1aWQsIGRlc3RpbmF0aW9uVWlkc1tpXV0pKTtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICBicmVhaztcbiAgICAgICAgfVxuICAgIH07XG5cbiAgICBsZXQgcmVzcG9uc2U7XG4gICAgdHJ5IHtcbiAgICAgICAgcmVzcG9uc2UgPSBhd2FpdCBjb25uZWN0aW9uLmV4ZWMob3B0aW9ucy51aWQgPyAnVUlEIE1PVkUnIDogJ01PVkUnLCBhdHRyaWJ1dGVzLCB7XG4gICAgICAgICAgICB1bnRhZ2dlZDoge1xuICAgICAgICAgICAgICAgIE9LOiBhc3luYyB1bnRhZ2dlZCA9PiB7XG4gICAgICAgICAgICAgICAgICAgIGNoZWNrTW92ZUluZm8odW50YWdnZWQpO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgICAgIHJlc3BvbnNlLm5leHQoKTtcblxuICAgICAgICBjaGVja01vdmVJbmZvKHJlc3BvbnNlLnJlc3BvbnNlKTtcbiAgICAgICAgcmV0dXJuIG1hcDtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgbGV0IGVycm9yQ29kZSA9IGdldFN0YXR1c0NvZGUoZXJyLnJlc3BvbnNlKTtcbiAgICAgICAgaWYgKGVycm9yQ29kZSkge1xuICAgICAgICAgICAgZXJyLnNlcnZlclJlc3BvbnNlQ29kZSA9IGVycm9yQ29kZTtcbiAgICAgICAgfVxuICAgICAgICBlcnIucmVzcG9uc2UgPSBhd2FpdCBnZXRFcnJvclRleHQoZXJyLnJlc3BvbnNlKTtcblxuICAgICAgICBjb25uZWN0aW9uLmxvZy53YXJuKHsgZXJyLCBjaWQ6IGNvbm5lY3Rpb24uaWQgfSk7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG59O1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/move.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/namespace.js":
|
|
/*!*********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/namespace.js ***!
|
|
\*********************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\n// Requests NAMESPACE info from server\nmodule.exports = async connection => {\n if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state)) {\n // nothing to do here\n return;\n }\n\n if (!connection.capabilities.has('NAMESPACE')) {\n // try to derive from listing\n let { prefix, delimiter } = await getListPrefix(connection);\n if (delimiter && prefix && prefix.charAt(prefix.length - 1) !== delimiter) {\n prefix += delimiter;\n }\n let map = {\n personal: [{ prefix: prefix || '', delimiter }],\n other: false,\n shared: false\n };\n connection.namespaces = map;\n connection.namespace = connection.namespaces.personal[0];\n return connection.namespace;\n }\n\n let response;\n try {\n let map = {};\n response = await connection.exec('NAMESPACE', false, {\n untagged: {\n NAMESPACE: async untagged => {\n if (!untagged.attributes || !untagged.attributes.length) {\n return;\n }\n map.personal = getNamsepaceInfo(untagged.attributes[0]);\n map.other = getNamsepaceInfo(untagged.attributes[1]);\n map.shared = getNamsepaceInfo(untagged.attributes[2]);\n }\n }\n });\n connection.namespaces = map;\n\n // make sure that we have the first personal namespace always set\n if (!connection.namespaces.personal[0]) {\n connection.namespaces.personal[0] = { prefix: '', delimiter: '.' };\n }\n connection.namespaces.personal[0].prefix = connection.namespaces.personal[0].prefix || '';\n response.next();\n\n connection.namespace = connection.namespaces.personal[0];\n\n return connection.namespace;\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n return {\n error: true,\n status: err.responseStatus,\n text: err.responseText\n };\n }\n};\n\nasync function getListPrefix(connection) {\n let response;\n try {\n let map = {};\n response = await connection.exec('LIST', ['', ''], {\n untagged: {\n LIST: async untagged => {\n if (!untagged.attributes || !untagged.attributes.length) {\n return;\n }\n\n map.flags = new Set(untagged.attributes[0].map(entry => entry.value));\n map.delimiter = untagged.attributes[1] && untagged.attributes[1].value;\n map.prefix = (untagged.attributes[2] && untagged.attributes[2].value) || '';\n if (map.delimiter && map.prefix.charAt(0) === map.delimiter) {\n map.prefix = map.prefix.slice(1);\n }\n }\n }\n });\n response.next();\n return map;\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n return {};\n }\n}\n\nfunction getNamsepaceInfo(attribute) {\n if (!attribute || !attribute.length) {\n return false;\n }\n\n return attribute\n .filter(entry => entry.length >= 2 && typeof entry[0].value === 'string' && typeof entry[1].value === 'string')\n .map(entry => {\n let prefix = entry[0].value;\n let delimiter = entry[1].value;\n\n if (delimiter && prefix && prefix.charAt(prefix.length - 1) !== delimiter) {\n prefix += delimiter;\n }\n return { prefix, delimiter };\n });\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvbmFtZXNwYWNlLmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsY0FBYyxvQkFBb0I7QUFDbEM7QUFDQTtBQUNBO0FBQ0E7QUFDQSx5QkFBeUIsaUNBQWlDO0FBQzFEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7O0FBRUE7QUFDQTtBQUNBLGtEQUFrRDtBQUNsRDtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQSxNQUFNO0FBQ04sOEJBQThCLHlCQUF5QjtBQUN2RDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNUO0FBQ0E7QUFDQSxNQUFNO0FBQ04sOEJBQThCLHlCQUF5QjtBQUN2RDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxxQkFBcUI7QUFDckIsU0FBUztBQUNUIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvbmFtZXNwYWNlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuLy8gUmVxdWVzdHMgTkFNRVNQQUNFIGluZm8gZnJvbSBzZXJ2ZXJcbm1vZHVsZS5leHBvcnRzID0gYXN5bmMgY29ubmVjdGlvbiA9PiB7XG4gICAgaWYgKCFbY29ubmVjdGlvbi5zdGF0ZXMuQVVUSEVOVElDQVRFRCwgY29ubmVjdGlvbi5zdGF0ZXMuU0VMRUNURURdLmluY2x1ZGVzKGNvbm5lY3Rpb24uc3RhdGUpKSB7XG4gICAgICAgIC8vIG5vdGhpbmcgdG8gZG8gaGVyZVxuICAgICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgaWYgKCFjb25uZWN0aW9uLmNhcGFiaWxpdGllcy5oYXMoJ05BTUVTUEFDRScpKSB7XG4gICAgICAgIC8vIHRyeSB0byBkZXJpdmUgZnJvbSBsaXN0aW5nXG4gICAgICAgIGxldCB7IHByZWZpeCwgZGVsaW1pdGVyIH0gPSBhd2FpdCBnZXRMaXN0UHJlZml4KGNvbm5lY3Rpb24pO1xuICAgICAgICBpZiAoZGVsaW1pdGVyICYmIHByZWZpeCAmJiBwcmVmaXguY2hhckF0KHByZWZpeC5sZW5ndGggLSAxKSAhPT0gZGVsaW1pdGVyKSB7XG4gICAgICAgICAgICBwcmVmaXggKz0gZGVsaW1pdGVyO1xuICAgICAgICB9XG4gICAgICAgIGxldCBtYXAgPSB7XG4gICAgICAgICAgICBwZXJzb25hbDogW3sgcHJlZml4OiBwcmVmaXggfHwgJycsIGRlbGltaXRlciB9XSxcbiAgICAgICAgICAgIG90aGVyOiBmYWxzZSxcbiAgICAgICAgICAgIHNoYXJlZDogZmFsc2VcbiAgICAgICAgfTtcbiAgICAgICAgY29ubmVjdGlvbi5uYW1lc3BhY2VzID0gbWFwO1xuICAgICAgICBjb25uZWN0aW9uLm5hbWVzcGFjZSA9IGNvbm5lY3Rpb24ubmFtZXNwYWNlcy5wZXJzb25hbFswXTtcbiAgICAgICAgcmV0dXJuIGNvbm5lY3Rpb24ubmFtZXNwYWNlO1xuICAgIH1cblxuICAgIGxldCByZXNwb25zZTtcbiAgICB0cnkge1xuICAgICAgICBsZXQgbWFwID0ge307XG4gICAgICAgIHJlc3BvbnNlID0gYXdhaXQgY29ubmVjdGlvbi5leGVjKCdOQU1FU1BBQ0UnLCBmYWxzZSwge1xuICAgICAgICAgICAgdW50YWdnZWQ6IHtcbiAgICAgICAgICAgICAgICBOQU1FU1BBQ0U6IGFzeW5jIHVudGFnZ2VkID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKCF1bnRhZ2dlZC5hdHRyaWJ1dGVzIHx8ICF1bnRhZ2dlZC5hdHRyaWJ1dGVzLmxlbmd0aCkge1xuICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIG1hcC5wZXJzb25hbCA9IGdldE5hbXNlcGFjZUluZm8odW50YWdnZWQuYXR0cmlidXRlc1swXSk7XG4gICAgICAgICAgICAgICAgICAgIG1hcC5vdGhlciA9IGdldE5hbXNlcGFjZUluZm8odW50YWdnZWQuYXR0cmlidXRlc1sxXSk7XG4gICAgICAgICAgICAgICAgICAgIG1hcC5zaGFyZWQgPSBnZXROYW1zZXBhY2VJbmZvKHVudGFnZ2VkLmF0dHJpYnV0ZXNbMl0pO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgICAgIGNvbm5lY3Rpb24ubmFtZXNwYWNlcyA9IG1hcDtcblxuICAgICAgICAvLyBtYWtlIHN1cmUgdGhhdCB3ZSBoYXZlIHRoZSBmaXJzdCBwZXJzb25hbCBuYW1lc3BhY2UgYWx3YXlzIHNldFxuICAgICAgICBpZiAoIWNvbm5lY3Rpb24ubmFtZXNwYWNlcy5wZXJzb25hbFswXSkge1xuICAgICAgICAgICAgY29ubmVjdGlvbi5uYW1lc3BhY2VzLnBlcnNvbmFsWzBdID0geyBwcmVmaXg6ICcnLCBkZWxpbWl0ZXI6ICcuJyB9O1xuICAgICAgICB9XG4gICAgICAgIGNvbm5lY3Rpb24ubmFtZXNwYWNlcy5wZXJzb25hbFswXS5wcmVmaXggPSBjb25uZWN0aW9uLm5hbWVzcGFjZXMucGVyc29uYWxbMF0ucHJlZml4IHx8ICcnO1xuICAgICAgICByZXNwb25zZS5uZXh0KCk7XG5cbiAgICAgICAgY29ubmVjdGlvbi5uYW1lc3BhY2UgPSBjb25uZWN0aW9uLm5hbWVzcGFjZXMucGVyc29uYWxbMF07XG5cbiAgICAgICAgcmV0dXJuIGNvbm5lY3Rpb24ubmFtZXNwYWNlO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICBjb25uZWN0aW9uLmxvZy53YXJuKHsgZXJyLCBjaWQ6IGNvbm5lY3Rpb24uaWQgfSk7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICBlcnJvcjogdHJ1ZSxcbiAgICAgICAgICAgIHN0YXR1czogZXJyLnJlc3BvbnNlU3RhdHVzLFxuICAgICAgICAgICAgdGV4dDogZXJyLnJlc3BvbnNlVGV4dFxuICAgICAgICB9O1xuICAgIH1cbn07XG5cbmFzeW5jIGZ1bmN0aW9uIGdldExpc3RQcmVmaXgoY29ubmVjdGlvbikge1xuICAgIGxldCByZXNwb25zZTtcbiAgICB0cnkge1xuICAgICAgICBsZXQgbWFwID0ge307XG4gICAgICAgIHJlc3BvbnNlID0gYXdhaXQgY29ubmVjdGlvbi5leGVjKCdMSVNUJywgWycnLCAnJ10sIHtcbiAgICAgICAgICAgIHVudGFnZ2VkOiB7XG4gICAgICAgICAgICAgICAgTElTVDogYXN5bmMgdW50YWdnZWQgPT4ge1xuICAgICAgICAgICAgICAgICAgICBpZiAoIXVudGFnZ2VkLmF0dHJpYnV0ZXMgfHwgIXVudGFnZ2VkLmF0dHJpYnV0ZXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgICBtYXAuZmxhZ3MgPSBuZXcgU2V0KHVudGFnZ2VkLmF0dHJpYnV0ZXNbMF0ubWFwKGVudHJ5ID0+IGVudHJ5LnZhbHVlKSk7XG4gICAgICAgICAgICAgICAgICAgIG1hcC5kZWxpbWl0ZXIgPSB1bnRhZ2dlZC5hdHRyaWJ1dGVzWzFdICYmIHVudGFnZ2VkLmF0dHJpYnV0ZXNbMV0udmFsdWU7XG4gICAgICAgICAgICAgICAgICAgIG1hcC5wcmVmaXggPSAodW50YWdnZWQuYXR0cmlidXRlc1syXSAmJiB1bnRhZ2dlZC5hdHRyaWJ1dGVzWzJdLnZhbHVlKSB8fCAnJztcbiAgICAgICAgICAgICAgICAgICAgaWYgKG1hcC5kZWxpbWl0ZXIgJiYgbWFwLnByZWZpeC5jaGFyQXQoMCkgPT09IG1hcC5kZWxpbWl0ZXIpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIG1hcC5wcmVmaXggPSBtYXAucHJlZml4LnNsaWNlKDEpO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICAgICAgcmVzcG9uc2UubmV4dCgpO1xuICAgICAgICByZXR1cm4gbWFwO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICBjb25uZWN0aW9uLmxvZy53YXJuKHsgZXJyLCBjaWQ6IGNvbm5lY3Rpb24uaWQgfSk7XG4gICAgICAgIHJldHVybiB7fTtcbiAgICB9XG59XG5cbmZ1bmN0aW9uIGdldE5hbXNlcGFjZUluZm8oYXR0cmlidXRlKSB7XG4gICAgaWYgKCFhdHRyaWJ1dGUgfHwgIWF0dHJpYnV0ZS5sZW5ndGgpIHtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cblxuICAgIHJldHVybiBhdHRyaWJ1dGVcbiAgICAgICAgLmZpbHRlcihlbnRyeSA9PiBlbnRyeS5sZW5ndGggPj0gMiAmJiB0eXBlb2YgZW50cnlbMF0udmFsdWUgPT09ICdzdHJpbmcnICYmIHR5cGVvZiBlbnRyeVsxXS52YWx1ZSA9PT0gJ3N0cmluZycpXG4gICAgICAgIC5tYXAoZW50cnkgPT4ge1xuICAgICAgICAgICAgbGV0IHByZWZpeCA9IGVudHJ5WzBdLnZhbHVlO1xuICAgICAgICAgICAgbGV0IGRlbGltaXRlciA9IGVudHJ5WzFdLnZhbHVlO1xuXG4gICAgICAgICAgICBpZiAoZGVsaW1pdGVyICYmIHByZWZpeCAmJiBwcmVmaXguY2hhckF0KHByZWZpeC5sZW5ndGggLSAxKSAhPT0gZGVsaW1pdGVyKSB7XG4gICAgICAgICAgICAgICAgcHJlZml4ICs9IGRlbGltaXRlcjtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHJldHVybiB7IHByZWZpeCwgZGVsaW1pdGVyIH07XG4gICAgICAgIH0pO1xufVxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/namespace.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/noop.js":
|
|
/*!****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/noop.js ***!
|
|
\****************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\n// Sends a NO-OP command\nmodule.exports = async connection => {\n try {\n let response = await connection.exec('NOOP', false, { comment: 'Requested by command' });\n response.next();\n return true;\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvbm9vcC5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYjtBQUNBO0FBQ0E7QUFDQSw4REFBOEQsaUNBQWlDO0FBQy9GO0FBQ0E7QUFDQSxNQUFNO0FBQ04sOEJBQThCLHlCQUF5QjtBQUN2RDtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L2xpYi9jb21tYW5kcy9ub29wLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuLy8gU2VuZHMgYSBOTy1PUCBjb21tYW5kXG5tb2R1bGUuZXhwb3J0cyA9IGFzeW5jIGNvbm5lY3Rpb24gPT4ge1xuICAgIHRyeSB7XG4gICAgICAgIGxldCByZXNwb25zZSA9IGF3YWl0IGNvbm5lY3Rpb24uZXhlYygnTk9PUCcsIGZhbHNlLCB7IGNvbW1lbnQ6ICdSZXF1ZXN0ZWQgYnkgY29tbWFuZCcgfSk7XG4gICAgICAgIHJlc3BvbnNlLm5leHQoKTtcbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICAgIGNvbm5lY3Rpb24ubG9nLndhcm4oeyBlcnIsIGNpZDogY29ubmVjdGlvbi5pZCB9KTtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbn07XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/noop.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/quota.js":
|
|
/*!*****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/quota.js ***!
|
|
\*****************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { encodePath, getStatusCode, normalizePath, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(action-browser)/./node_modules/imapflow/lib/tools.js\");\n\n// Requests quota information for a mailbox\nmodule.exports = async (connection, path) => {\n if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state) || !path) {\n // nothing to do here\n return;\n }\n\n if (!connection.capabilities.has('QUOTA')) {\n return false;\n }\n\n path = normalizePath(connection, path);\n\n let map = { path };\n\n let processQuotaResponse = untagged => {\n let attributes = untagged.attributes && untagged.attributes[1];\n if (!attributes || !attributes.length) {\n return false;\n }\n\n let key = false;\n attributes.forEach((attribute, i) => {\n if (i % 3 === 0) {\n key = attribute && typeof attribute.value === 'string' ? attribute.value.toLowerCase() : false;\n return;\n }\n if (!key) {\n return;\n }\n\n let value = attribute && typeof attribute.value === 'string' && !isNaN(attribute.value) ? Number(attribute.value) : false;\n if (value === false) {\n return;\n }\n\n if (i % 3 === 1) {\n // usage\n if (!map[key]) {\n map[key] = {};\n }\n map[key].usage = value * (key === 'storage' ? 1024 : 1);\n }\n\n if (i % 3 === 2) {\n // limit\n if (!map[key]) {\n map[key] = {};\n }\n map[key].limit = value * (key === 'storage' ? 1024 : 1);\n\n if (map[key].limit) {\n map[key].status = Math.round(((map[key].usage || 0) / map[key].limit) * 100) + '%';\n }\n }\n });\n };\n\n let quotaFound = false;\n let response;\n try {\n response = await connection.exec('GETQUOTAROOT', [{ type: 'ATOM', value: encodePath(connection, path) }], {\n untagged: {\n QUOTAROOT: async untagged => {\n let quotaRoot =\n untagged.attributes && untagged.attributes[1] && typeof untagged.attributes[1].value === 'string'\n ? untagged.attributes[1].value\n : false;\n if (quotaRoot) {\n map.quotaRoot = quotaRoot;\n }\n },\n QUOTA: async untagged => {\n quotaFound = true;\n processQuotaResponse(untagged);\n }\n }\n });\n\n response.next();\n\n if (map.quotaRoot && !quotaFound) {\n response = await connection.exec('GETQUOTA', [{ type: 'ATOM', value: map.quotaRoot }], {\n untagged: {\n QUOTA: async untagged => {\n processQuotaResponse(untagged);\n }\n }\n });\n }\n\n return map;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvcXVvdGEuanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWIsUUFBUSx5REFBeUQsRUFBRSxtQkFBTyxDQUFDLDBFQUFhOztBQUV4RjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBOztBQUVBLGdCQUFnQjs7QUFFaEI7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNUOztBQUVBO0FBQ0E7QUFDQTtBQUNBLDREQUE0RCxtREFBbUQ7QUFDL0c7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsaUJBQWlCO0FBQ2pCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTOztBQUVUOztBQUVBO0FBQ0EsNERBQTRELG9DQUFvQztBQUNoRztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiOztBQUVBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsOEJBQThCLHlCQUF5QjtBQUN2RDtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L2xpYi9jb21tYW5kcy9xdW90YS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IHsgZW5jb2RlUGF0aCwgZ2V0U3RhdHVzQ29kZSwgbm9ybWFsaXplUGF0aCwgZ2V0RXJyb3JUZXh0IH0gPSByZXF1aXJlKCcuLi90b29scy5qcycpO1xuXG4vLyBSZXF1ZXN0cyBxdW90YSBpbmZvcm1hdGlvbiBmb3IgYSBtYWlsYm94XG5tb2R1bGUuZXhwb3J0cyA9IGFzeW5jIChjb25uZWN0aW9uLCBwYXRoKSA9PiB7XG4gICAgaWYgKCFbY29ubmVjdGlvbi5zdGF0ZXMuQVVUSEVOVElDQVRFRCwgY29ubmVjdGlvbi5zdGF0ZXMuU0VMRUNURURdLmluY2x1ZGVzKGNvbm5lY3Rpb24uc3RhdGUpIHx8ICFwYXRoKSB7XG4gICAgICAgIC8vIG5vdGhpbmcgdG8gZG8gaGVyZVxuICAgICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgaWYgKCFjb25uZWN0aW9uLmNhcGFiaWxpdGllcy5oYXMoJ1FVT1RBJykpIHtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cblxuICAgIHBhdGggPSBub3JtYWxpemVQYXRoKGNvbm5lY3Rpb24sIHBhdGgpO1xuXG4gICAgbGV0IG1hcCA9IHsgcGF0aCB9O1xuXG4gICAgbGV0IHByb2Nlc3NRdW90YVJlc3BvbnNlID0gdW50YWdnZWQgPT4ge1xuICAgICAgICBsZXQgYXR0cmlidXRlcyA9IHVudGFnZ2VkLmF0dHJpYnV0ZXMgJiYgdW50YWdnZWQuYXR0cmlidXRlc1sxXTtcbiAgICAgICAgaWYgKCFhdHRyaWJ1dGVzIHx8ICFhdHRyaWJ1dGVzLmxlbmd0aCkge1xuICAgICAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgICB9XG5cbiAgICAgICAgbGV0IGtleSA9IGZhbHNlO1xuICAgICAgICBhdHRyaWJ1dGVzLmZvckVhY2goKGF0dHJpYnV0ZSwgaSkgPT4ge1xuICAgICAgICAgICAgaWYgKGkgJSAzID09PSAwKSB7XG4gICAgICAgICAgICAgICAga2V5ID0gYXR0cmlidXRlICYmIHR5cGVvZiBhdHRyaWJ1dGUudmFsdWUgPT09ICdzdHJpbmcnID8gYXR0cmlidXRlLnZhbHVlLnRvTG93ZXJDYXNlKCkgOiBmYWxzZTtcbiAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBpZiAoIWtleSkge1xuICAgICAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgbGV0IHZhbHVlID0gYXR0cmlidXRlICYmIHR5cGVvZiBhdHRyaWJ1dGUudmFsdWUgPT09ICdzdHJpbmcnICYmICFpc05hTihhdHRyaWJ1dGUudmFsdWUpID8gTnVtYmVyKGF0dHJpYnV0ZS52YWx1ZSkgOiBmYWxzZTtcbiAgICAgICAgICAgIGlmICh2YWx1ZSA9PT0gZmFsc2UpIHtcbiAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIGlmIChpICUgMyA9PT0gMSkge1xuICAgICAgICAgICAgICAgIC8vIHVzYWdlXG4gICAgICAgICAgICAgICAgaWYgKCFtYXBba2V5XSkge1xuICAgICAgICAgICAgICAgICAgICBtYXBba2V5XSA9IHt9O1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICBtYXBba2V5XS51c2FnZSA9IHZhbHVlICogKGtleSA9PT0gJ3N0b3JhZ2UnID8gMTAyNCA6IDEpO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICBpZiAoaSAlIDMgPT09IDIpIHtcbiAgICAgICAgICAgICAgICAvLyBsaW1pdFxuICAgICAgICAgICAgICAgIGlmICghbWFwW2tleV0pIHtcbiAgICAgICAgICAgICAgICAgICAgbWFwW2tleV0gPSB7fTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgbWFwW2tleV0ubGltaXQgPSB2YWx1ZSAqIChrZXkgPT09ICdzdG9yYWdlJyA/IDEwMjQgOiAxKTtcblxuICAgICAgICAgICAgICAgIGlmIChtYXBba2V5XS5saW1pdCkge1xuICAgICAgICAgICAgICAgICAgICBtYXBba2V5XS5zdGF0dXMgPSBNYXRoLnJvdW5kKCgobWFwW2tleV0udXNhZ2UgfHwgMCkgLyBtYXBba2V5XS5saW1pdCkgKiAxMDApICsgJyUnO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgfTtcblxuICAgIGxldCBxdW90YUZvdW5kID0gZmFsc2U7XG4gICAgbGV0IHJlc3BvbnNlO1xuICAgIHRyeSB7XG4gICAgICAgIHJlc3BvbnNlID0gYXdhaXQgY29ubmVjdGlvbi5leGVjKCdHRVRRVU9UQVJPT1QnLCBbeyB0eXBlOiAnQVRPTScsIHZhbHVlOiBlbmNvZGVQYXRoKGNvbm5lY3Rpb24sIHBhdGgpIH1dLCB7XG4gICAgICAgICAgICB1bnRhZ2dlZDoge1xuICAgICAgICAgICAgICAgIFFVT1RBUk9PVDogYXN5bmMgdW50YWdnZWQgPT4ge1xuICAgICAgICAgICAgICAgICAgICBsZXQgcXVvdGFSb290ID1cbiAgICAgICAgICAgICAgICAgICAgICAgIHVudGFnZ2VkLmF0dHJpYnV0ZXMgJiYgdW50YWdnZWQuYXR0cmlidXRlc1sxXSAmJiB0eXBlb2YgdW50YWdnZWQuYXR0cmlidXRlc1sxXS52YWx1ZSA9PT0gJ3N0cmluZydcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA/IHVudGFnZ2VkLmF0dHJpYnV0ZXNbMV0udmFsdWVcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA6IGZhbHNlO1xuICAgICAgICAgICAgICAgICAgICBpZiAocXVvdGFSb290KSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBtYXAucXVvdGFSb290ID0gcXVvdGFSb290O1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICBRVU9UQTogYXN5bmMgdW50YWdnZWQgPT4ge1xuICAgICAgICAgICAgICAgICAgICBxdW90YUZvdW5kID0gdHJ1ZTtcbiAgICAgICAgICAgICAgICAgICAgcHJvY2Vzc1F1b3RhUmVzcG9uc2UodW50YWdnZWQpO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG5cbiAgICAgICAgcmVzcG9uc2UubmV4dCgpO1xuXG4gICAgICAgIGlmIChtYXAucXVvdGFSb290ICYmICFxdW90YUZvdW5kKSB7XG4gICAgICAgICAgICByZXNwb25zZSA9IGF3YWl0IGNvbm5lY3Rpb24uZXhlYygnR0VUUVVPVEEnLCBbeyB0eXBlOiAnQVRPTScsIHZhbHVlOiBtYXAucXVvdGFSb290IH1dLCB7XG4gICAgICAgICAgICAgICAgdW50YWdnZWQ6IHtcbiAgICAgICAgICAgICAgICAgICAgUVVPVEE6IGFzeW5jIHVudGFnZ2VkID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHByb2Nlc3NRdW90YVJlc3BvbnNlKHVudGFnZ2VkKTtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH0pO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIG1hcDtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgbGV0IGVycm9yQ29kZSA9IGdldFN0YXR1c0NvZGUoZXJyLnJlc3BvbnNlKTtcbiAgICAgICAgaWYgKGVycm9yQ29kZSkge1xuICAgICAgICAgICAgZXJyLnNlcnZlclJlc3BvbnNlQ29kZSA9IGVycm9yQ29kZTtcbiAgICAgICAgfVxuICAgICAgICBlcnIucmVzcG9uc2UgPSBhd2FpdCBnZXRFcnJvclRleHQoZXJyLnJlc3BvbnNlKTtcblxuICAgICAgICBjb25uZWN0aW9uLmxvZy53YXJuKHsgZXJyLCBjaWQ6IGNvbm5lY3Rpb24uaWQgfSk7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG59O1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/quota.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/rename.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/rename.js ***!
|
|
\******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { encodePath, normalizePath, getStatusCode, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(action-browser)/./node_modules/imapflow/lib/tools.js\");\n\n// Renames existing mailbox\nmodule.exports = async (connection, path, newPath) => {\n if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state)) {\n // nothing to do here\n return;\n }\n\n path = normalizePath(connection, path);\n newPath = normalizePath(connection, newPath);\n\n if (connection.states.SELECTED && connection.mailbox.path === path) {\n await connection.run('CLOSE');\n }\n\n let response;\n try {\n let map = {\n path,\n newPath\n };\n response = await connection.exec('RENAME', [\n { type: 'ATOM', value: encodePath(connection, path) },\n { type: 'ATOM', value: encodePath(connection, newPath) }\n ]);\n response.next();\n return map;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n throw err;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvcmVuYW1lLmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViLFFBQVEseURBQXlELEVBQUUsbUJBQU8sQ0FBQywwRUFBYTs7QUFFeEY7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsY0FBYyxtREFBbUQ7QUFDakUsY0FBYztBQUNkO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDhCQUE4Qix5QkFBeUI7QUFDdkQ7QUFDQTtBQUNBIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvcmVuYW1lLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgeyBlbmNvZGVQYXRoLCBub3JtYWxpemVQYXRoLCBnZXRTdGF0dXNDb2RlLCBnZXRFcnJvclRleHQgfSA9IHJlcXVpcmUoJy4uL3Rvb2xzLmpzJyk7XG5cbi8vIFJlbmFtZXMgZXhpc3RpbmcgbWFpbGJveFxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyAoY29ubmVjdGlvbiwgcGF0aCwgbmV3UGF0aCkgPT4ge1xuICAgIGlmICghW2Nvbm5lY3Rpb24uc3RhdGVzLkFVVEhFTlRJQ0FURUQsIGNvbm5lY3Rpb24uc3RhdGVzLlNFTEVDVEVEXS5pbmNsdWRlcyhjb25uZWN0aW9uLnN0YXRlKSkge1xuICAgICAgICAvLyBub3RoaW5nIHRvIGRvIGhlcmVcbiAgICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIHBhdGggPSBub3JtYWxpemVQYXRoKGNvbm5lY3Rpb24sIHBhdGgpO1xuICAgIG5ld1BhdGggPSBub3JtYWxpemVQYXRoKGNvbm5lY3Rpb24sIG5ld1BhdGgpO1xuXG4gICAgaWYgKGNvbm5lY3Rpb24uc3RhdGVzLlNFTEVDVEVEICYmIGNvbm5lY3Rpb24ubWFpbGJveC5wYXRoID09PSBwYXRoKSB7XG4gICAgICAgIGF3YWl0IGNvbm5lY3Rpb24ucnVuKCdDTE9TRScpO1xuICAgIH1cblxuICAgIGxldCByZXNwb25zZTtcbiAgICB0cnkge1xuICAgICAgICBsZXQgbWFwID0ge1xuICAgICAgICAgICAgcGF0aCxcbiAgICAgICAgICAgIG5ld1BhdGhcbiAgICAgICAgfTtcbiAgICAgICAgcmVzcG9uc2UgPSBhd2FpdCBjb25uZWN0aW9uLmV4ZWMoJ1JFTkFNRScsIFtcbiAgICAgICAgICAgIHsgdHlwZTogJ0FUT00nLCB2YWx1ZTogZW5jb2RlUGF0aChjb25uZWN0aW9uLCBwYXRoKSB9LFxuICAgICAgICAgICAgeyB0eXBlOiAnQVRPTScsIHZhbHVlOiBlbmNvZGVQYXRoKGNvbm5lY3Rpb24sIG5ld1BhdGgpIH1cbiAgICAgICAgXSk7XG4gICAgICAgIHJlc3BvbnNlLm5leHQoKTtcbiAgICAgICAgcmV0dXJuIG1hcDtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgbGV0IGVycm9yQ29kZSA9IGdldFN0YXR1c0NvZGUoZXJyLnJlc3BvbnNlKTtcbiAgICAgICAgaWYgKGVycm9yQ29kZSkge1xuICAgICAgICAgICAgZXJyLnNlcnZlclJlc3BvbnNlQ29kZSA9IGVycm9yQ29kZTtcbiAgICAgICAgfVxuICAgICAgICBlcnIucmVzcG9uc2UgPSBhd2FpdCBnZXRFcnJvclRleHQoZXJyLnJlc3BvbnNlKTtcblxuICAgICAgICBjb25uZWN0aW9uLmxvZy53YXJuKHsgZXJyLCBjaWQ6IGNvbm5lY3Rpb24uaWQgfSk7XG4gICAgICAgIHRocm93IGVycjtcbiAgICB9XG59O1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/rename.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/search.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/search.js ***!
|
|
\******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { getStatusCode, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(action-browser)/./node_modules/imapflow/lib/tools.js\");\nconst { searchCompiler } = __webpack_require__(/*! ../search-compiler.js */ \"(action-browser)/./node_modules/imapflow/lib/search-compiler.js\");\n\n// Updates flags for a message\nmodule.exports = async (connection, query, options) => {\n if (connection.state !== connection.states.SELECTED) {\n // nothing to do here\n return false;\n }\n\n options = options || {};\n\n let attributes;\n\n if (!query || query === true || (typeof query === 'object' && (!Object.keys(query).length || (Object.keys(query).length === 1 && query.all)))) {\n // search for all messages\n attributes = [{ type: 'ATOM', value: 'ALL' }];\n } else if (query && typeof query === 'object') {\n // normal query\n attributes = searchCompiler(connection, query);\n } else {\n return false;\n }\n\n let results = new Set();\n let response;\n try {\n response = await connection.exec(options.uid ? 'UID SEARCH' : 'SEARCH', attributes, {\n untagged: {\n SEARCH: async untagged => {\n if (untagged && untagged.attributes && untagged.attributes.length) {\n untagged.attributes.forEach(attribute => {\n if (attribute && attribute.value && typeof attribute.value === 'string' && !isNaN(attribute.value)) {\n results.add(Number(attribute.value));\n }\n });\n }\n }\n }\n });\n response.next();\n return Array.from(results).sort((a, b) => a - b);\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvc2VhcmNoLmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViLFFBQVEsOEJBQThCLEVBQUUsbUJBQU8sQ0FBQywwRUFBYTtBQUM3RCxRQUFRLGlCQUFpQixFQUFFLG1CQUFPLENBQUMsOEZBQXVCOztBQUUxRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTtBQUNBLHdCQUF3Qiw0QkFBNEI7QUFDcEQsTUFBTTtBQUNOO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EseUJBQXlCO0FBQ3pCO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsOEJBQThCLHlCQUF5QjtBQUN2RDtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L2xpYi9jb21tYW5kcy9zZWFyY2guanMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCB7IGdldFN0YXR1c0NvZGUsIGdldEVycm9yVGV4dCB9ID0gcmVxdWlyZSgnLi4vdG9vbHMuanMnKTtcbmNvbnN0IHsgc2VhcmNoQ29tcGlsZXIgfSA9IHJlcXVpcmUoJy4uL3NlYXJjaC1jb21waWxlci5qcycpO1xuXG4vLyBVcGRhdGVzIGZsYWdzIGZvciBhIG1lc3NhZ2Vcbm1vZHVsZS5leHBvcnRzID0gYXN5bmMgKGNvbm5lY3Rpb24sIHF1ZXJ5LCBvcHRpb25zKSA9PiB7XG4gICAgaWYgKGNvbm5lY3Rpb24uc3RhdGUgIT09IGNvbm5lY3Rpb24uc3RhdGVzLlNFTEVDVEVEKSB7XG4gICAgICAgIC8vIG5vdGhpbmcgdG8gZG8gaGVyZVxuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuXG4gICAgb3B0aW9ucyA9IG9wdGlvbnMgfHwge307XG5cbiAgICBsZXQgYXR0cmlidXRlcztcblxuICAgIGlmICghcXVlcnkgfHwgcXVlcnkgPT09IHRydWUgfHwgKHR5cGVvZiBxdWVyeSA9PT0gJ29iamVjdCcgJiYgKCFPYmplY3Qua2V5cyhxdWVyeSkubGVuZ3RoIHx8IChPYmplY3Qua2V5cyhxdWVyeSkubGVuZ3RoID09PSAxICYmIHF1ZXJ5LmFsbCkpKSkge1xuICAgICAgICAvLyBzZWFyY2ggZm9yIGFsbCBtZXNzYWdlc1xuICAgICAgICBhdHRyaWJ1dGVzID0gW3sgdHlwZTogJ0FUT00nLCB2YWx1ZTogJ0FMTCcgfV07XG4gICAgfSBlbHNlIGlmIChxdWVyeSAmJiB0eXBlb2YgcXVlcnkgPT09ICdvYmplY3QnKSB7XG4gICAgICAgIC8vIG5vcm1hbCBxdWVyeVxuICAgICAgICBhdHRyaWJ1dGVzID0gc2VhcmNoQ29tcGlsZXIoY29ubmVjdGlvbiwgcXVlcnkpO1xuICAgIH0gZWxzZSB7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG5cbiAgICBsZXQgcmVzdWx0cyA9IG5ldyBTZXQoKTtcbiAgICBsZXQgcmVzcG9uc2U7XG4gICAgdHJ5IHtcbiAgICAgICAgcmVzcG9uc2UgPSBhd2FpdCBjb25uZWN0aW9uLmV4ZWMob3B0aW9ucy51aWQgPyAnVUlEIFNFQVJDSCcgOiAnU0VBUkNIJywgYXR0cmlidXRlcywge1xuICAgICAgICAgICAgdW50YWdnZWQ6IHtcbiAgICAgICAgICAgICAgICBTRUFSQ0g6IGFzeW5jIHVudGFnZ2VkID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKHVudGFnZ2VkICYmIHVudGFnZ2VkLmF0dHJpYnV0ZXMgJiYgdW50YWdnZWQuYXR0cmlidXRlcy5sZW5ndGgpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHVudGFnZ2VkLmF0dHJpYnV0ZXMuZm9yRWFjaChhdHRyaWJ1dGUgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmIChhdHRyaWJ1dGUgJiYgYXR0cmlidXRlLnZhbHVlICYmIHR5cGVvZiBhdHRyaWJ1dGUudmFsdWUgPT09ICdzdHJpbmcnICYmICFpc05hTihhdHRyaWJ1dGUudmFsdWUpKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHJlc3VsdHMuYWRkKE51bWJlcihhdHRyaWJ1dGUudmFsdWUpKTtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgICAgIHJlc3BvbnNlLm5leHQoKTtcbiAgICAgICAgcmV0dXJuIEFycmF5LmZyb20ocmVzdWx0cykuc29ydCgoYSwgYikgPT4gYSAtIGIpO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICBsZXQgZXJyb3JDb2RlID0gZ2V0U3RhdHVzQ29kZShlcnIucmVzcG9uc2UpO1xuICAgICAgICBpZiAoZXJyb3JDb2RlKSB7XG4gICAgICAgICAgICBlcnIuc2VydmVyUmVzcG9uc2VDb2RlID0gZXJyb3JDb2RlO1xuICAgICAgICB9XG4gICAgICAgIGVyci5yZXNwb25zZSA9IGF3YWl0IGdldEVycm9yVGV4dChlcnIucmVzcG9uc2UpO1xuXG4gICAgICAgIGNvbm5lY3Rpb24ubG9nLndhcm4oeyBlcnIsIGNpZDogY29ubmVjdGlvbi5pZCB9KTtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbn07XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/search.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/select.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/select.js ***!
|
|
\******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { encodePath, normalizePath, getStatusCode, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(action-browser)/./node_modules/imapflow/lib/tools.js\");\n\n// Selects a mailbox\nmodule.exports = async (connection, path, options) => {\n if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state)) {\n // nothing to do here\n return;\n }\n options = options || {};\n\n path = normalizePath(connection, path);\n\n if (!connection.folders.has(path)) {\n let folders = await connection.run('LIST', '', path);\n if (!folders) {\n throw new Error('Failed to fetch folders');\n }\n folders.forEach(folder => {\n connection.folders.set(folder.path, folder);\n });\n }\n\n let folderListData = connection.folders.has(path) ? connection.folders.get(path) : false;\n\n let response;\n try {\n let map = { path };\n if (folderListData) {\n ['delimiter', 'specialUse', 'subscribed', 'listed'].forEach(key => {\n if (folderListData[key]) {\n map[key] = folderListData[key];\n }\n });\n }\n\n let extraArgs = [];\n if (connection.enabled.has('QRESYNC') && options.changedSince && options.uidValidity) {\n extraArgs.push([\n { type: 'ATOM', value: 'QRESYNC' },\n [\n { type: 'ATOM', value: options.uidValidity?.toString() },\n { type: 'ATOM', value: options.changedSince.toString() }\n ]\n ]);\n map.qresync = true;\n }\n\n let encodedPath = encodePath(connection, path);\n\n let selectCommand = {\n command: !options.readOnly ? 'SELECT' : 'EXAMINE',\n arguments: [{ type: encodedPath.indexOf('&') >= 0 ? 'STRING' : 'ATOM', value: encodedPath }].concat(extraArgs || [])\n };\n\n response = await connection.exec(selectCommand.command, selectCommand.arguments, {\n untagged: {\n OK: async untagged => {\n if (!untagged.attributes || !untagged.attributes.length) {\n return;\n }\n let section = !untagged.attributes[0].value && untagged.attributes[0].section;\n if (section && section.length > 1 && section[0].type === 'ATOM' && typeof section[0].value === 'string') {\n let key = section[0].value.toLowerCase();\n let value;\n\n if (typeof section[1].value === 'string') {\n value = section[1].value;\n } else if (Array.isArray(section[1])) {\n value = section[1].map(entry => (typeof entry.value === 'string' ? entry.value : false)).filter(entry => entry);\n }\n\n switch (key) {\n case 'highestmodseq':\n key = 'highestModseq';\n if (/^[0-9]+$/.test(value)) {\n value = BigInt(value);\n }\n break;\n\n case 'mailboxid':\n key = 'mailboxId';\n if (Array.isArray(value) && value.length) {\n value = value[0];\n }\n break;\n\n case 'permanentflags':\n key = 'permanentFlags';\n value = new Set(value);\n break;\n\n case 'uidnext':\n key = 'uidNext';\n value = Number(value);\n break;\n\n case 'uidvalidity':\n key = 'uidValidity';\n if (/^[0-9]+$/.test(value)) {\n value = BigInt(value);\n }\n break;\n }\n\n map[key] = value;\n }\n\n if (section && section.length === 1 && section[0].type === 'ATOM' && typeof section[0].value === 'string') {\n let key = section[0].value.toLowerCase();\n switch (key) {\n case 'nomodseq':\n key = 'noModseq';\n map[key] = true;\n break;\n }\n }\n },\n FLAGS: async untagged => {\n if (!untagged.attributes || (!untagged.attributes.length && Array.isArray(untagged.attributes[0]))) {\n return;\n }\n let flags = untagged.attributes[0].map(flag => (typeof flag.value === 'string' ? flag.value : false)).filter(flag => flag);\n map.flags = new Set(flags);\n },\n EXISTS: async untagged => {\n let num = Number(untagged.command);\n if (isNaN(num)) {\n return false;\n }\n\n map.exists = num;\n },\n VANISHED: async untagged => {\n await connection.untaggedVanished(\n untagged,\n // mailbox is not yet open, so use a dummy mailbox object\n { path, uidNext: false, uidValidity: false }\n );\n },\n // we should only get an untagged FETCH for a SELECT/EXAMINE if QRESYNC was asked for\n FETCH: async untagged => {\n await connection.untaggedFetch(\n untagged,\n // mailbox is not yet open, so use a dummy mailbox object\n { path, uidNext: false, uidValidity: false }\n );\n }\n }\n });\n\n let section = !response.response.attributes[0].value && response.response.attributes[0].section;\n if (section && section.length && section[0].type === 'ATOM' && typeof section[0].value === 'string') {\n switch (section[0].value.toUpperCase()) {\n case 'READ-ONLY':\n map.readOnly = true;\n break;\n case 'READ-WRITE':\n default:\n map.readOnly = false;\n break;\n }\n }\n\n if (\n map.qresync &&\n // UIDVALIDITY must be the same\n (options.uidValidity !== map.uidValidity ||\n // HIGHESTMODSEQ response must be present\n !map.highestModseq ||\n // NOMODSEQ is not allowed\n map.noModseq)\n ) {\n // QRESYNC does not apply here, so unset it\n map.qresync = false;\n }\n\n let currentMailbox = connection.mailbox;\n connection.mailbox = false;\n\n if (currentMailbox && currentMailbox.path !== path) {\n connection.emit('mailboxClose', currentMailbox);\n }\n\n connection.mailbox = map;\n connection.currentSelectCommand = selectCommand;\n connection.state = connection.states.SELECTED;\n\n if (!currentMailbox || currentMailbox.path !== path) {\n connection.emit('mailboxOpen', connection.mailbox);\n }\n\n response.next();\n return map;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n if (connection.state === connection.states.SELECTED) {\n // reset selected state\n\n let currentMailbox = connection.mailbox;\n\n connection.mailbox = false;\n connection.currentSelectCommand = false;\n connection.state = connection.states.AUTHENTICATED;\n\n if (currentMailbox) {\n connection.emit('mailboxClose', currentMailbox);\n }\n }\n\n connection.log.warn({ err, cid: connection.id });\n throw err;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/imapflow/lib/commands/select.js","mappings":"AAAa;;AAEb,QAAQ,yDAAyD,EAAE,mBAAO,CAAC,0EAAa;;AAExF;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;;AAEA;AACA;AACA,oBAAoB;AACpB;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;;AAEA;AACA;AACA;AACA,kBAAkB,gCAAgC;AAClD;AACA,sBAAsB,sDAAsD;AAC5E,sBAAsB;AACtB;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,0BAA0B,6EAA6E;AACvG;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,0BAA0B;AAC1B;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA,0BAA0B;AAC1B;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA,0BAA0B;AAC1B;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,8BAA8B,yBAAyB;AACvD;AACA;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/commands/select.js"],"sourcesContent":["'use strict';\n\nconst { encodePath, normalizePath, getStatusCode, getErrorText } = require('../tools.js');\n\n// Selects a mailbox\nmodule.exports = async (connection, path, options) => {\n    if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state)) {\n        // nothing to do here\n        return;\n    }\n    options = options || {};\n\n    path = normalizePath(connection, path);\n\n    if (!connection.folders.has(path)) {\n        let folders = await connection.run('LIST', '', path);\n        if (!folders) {\n            throw new Error('Failed to fetch folders');\n        }\n        folders.forEach(folder => {\n            connection.folders.set(folder.path, folder);\n        });\n    }\n\n    let folderListData = connection.folders.has(path) ? connection.folders.get(path) : false;\n\n    let response;\n    try {\n        let map = { path };\n        if (folderListData) {\n            ['delimiter', 'specialUse', 'subscribed', 'listed'].forEach(key => {\n                if (folderListData[key]) {\n                    map[key] = folderListData[key];\n                }\n            });\n        }\n\n        let extraArgs = [];\n        if (connection.enabled.has('QRESYNC') && options.changedSince && options.uidValidity) {\n            extraArgs.push([\n                { type: 'ATOM', value: 'QRESYNC' },\n                [\n                    { type: 'ATOM', value: options.uidValidity?.toString() },\n                    { type: 'ATOM', value: options.changedSince.toString() }\n                ]\n            ]);\n            map.qresync = true;\n        }\n\n        let encodedPath = encodePath(connection, path);\n\n        let selectCommand = {\n            command: !options.readOnly ? 'SELECT' : 'EXAMINE',\n            arguments: [{ type: encodedPath.indexOf('&') >= 0 ? 'STRING' : 'ATOM', value: encodedPath }].concat(extraArgs || [])\n        };\n\n        response = await connection.exec(selectCommand.command, selectCommand.arguments, {\n            untagged: {\n                OK: async untagged => {\n                    if (!untagged.attributes || !untagged.attributes.length) {\n                        return;\n                    }\n                    let section = !untagged.attributes[0].value && untagged.attributes[0].section;\n                    if (section && section.length > 1 && section[0].type === 'ATOM' && typeof section[0].value === 'string') {\n                        let key = section[0].value.toLowerCase();\n                        let value;\n\n                        if (typeof section[1].value === 'string') {\n                            value = section[1].value;\n                        } else if (Array.isArray(section[1])) {\n                            value = section[1].map(entry => (typeof entry.value === 'string' ? entry.value : false)).filter(entry => entry);\n                        }\n\n                        switch (key) {\n                            case 'highestmodseq':\n                                key = 'highestModseq';\n                                if (/^[0-9]+$/.test(value)) {\n                                    value = BigInt(value);\n                                }\n                                break;\n\n                            case 'mailboxid':\n                                key = 'mailboxId';\n                                if (Array.isArray(value) && value.length) {\n                                    value = value[0];\n                                }\n                                break;\n\n                            case 'permanentflags':\n                                key = 'permanentFlags';\n                                value = new Set(value);\n                                break;\n\n                            case 'uidnext':\n                                key = 'uidNext';\n                                value = Number(value);\n                                break;\n\n                            case 'uidvalidity':\n                                key = 'uidValidity';\n                                if (/^[0-9]+$/.test(value)) {\n                                    value = BigInt(value);\n                                }\n                                break;\n                        }\n\n                        map[key] = value;\n                    }\n\n                    if (section && section.length === 1 && section[0].type === 'ATOM' && typeof section[0].value === 'string') {\n                        let key = section[0].value.toLowerCase();\n                        switch (key) {\n                            case 'nomodseq':\n                                key = 'noModseq';\n                                map[key] = true;\n                                break;\n                        }\n                    }\n                },\n                FLAGS: async untagged => {\n                    if (!untagged.attributes || (!untagged.attributes.length && Array.isArray(untagged.attributes[0]))) {\n                        return;\n                    }\n                    let flags = untagged.attributes[0].map(flag => (typeof flag.value === 'string' ? flag.value : false)).filter(flag => flag);\n                    map.flags = new Set(flags);\n                },\n                EXISTS: async untagged => {\n                    let num = Number(untagged.command);\n                    if (isNaN(num)) {\n                        return false;\n                    }\n\n                    map.exists = num;\n                },\n                VANISHED: async untagged => {\n                    await connection.untaggedVanished(\n                        untagged,\n                        // mailbox is not yet open, so use a dummy mailbox object\n                        { path, uidNext: false, uidValidity: false }\n                    );\n                },\n                // we should only get an untagged FETCH for a SELECT/EXAMINE if QRESYNC was asked for\n                FETCH: async untagged => {\n                    await connection.untaggedFetch(\n                        untagged,\n                        // mailbox is not yet open, so use a dummy mailbox object\n                        { path, uidNext: false, uidValidity: false }\n                    );\n                }\n            }\n        });\n\n        let section = !response.response.attributes[0].value && response.response.attributes[0].section;\n        if (section && section.length && section[0].type === 'ATOM' && typeof section[0].value === 'string') {\n            switch (section[0].value.toUpperCase()) {\n                case 'READ-ONLY':\n                    map.readOnly = true;\n                    break;\n                case 'READ-WRITE':\n                default:\n                    map.readOnly = false;\n                    break;\n            }\n        }\n\n        if (\n            map.qresync &&\n            // UIDVALIDITY must be the same\n            (options.uidValidity !== map.uidValidity ||\n                // HIGHESTMODSEQ response must be present\n                !map.highestModseq ||\n                // NOMODSEQ is not allowed\n                map.noModseq)\n        ) {\n            // QRESYNC does not apply here, so unset it\n            map.qresync = false;\n        }\n\n        let currentMailbox = connection.mailbox;\n        connection.mailbox = false;\n\n        if (currentMailbox && currentMailbox.path !== path) {\n            connection.emit('mailboxClose', currentMailbox);\n        }\n\n        connection.mailbox = map;\n        connection.currentSelectCommand = selectCommand;\n        connection.state = connection.states.SELECTED;\n\n        if (!currentMailbox || currentMailbox.path !== path) {\n            connection.emit('mailboxOpen', connection.mailbox);\n        }\n\n        response.next();\n        return map;\n    } catch (err) {\n        let errorCode = getStatusCode(err.response);\n        if (errorCode) {\n            err.serverResponseCode = errorCode;\n        }\n        err.response = await getErrorText(err.response);\n\n        if (connection.state === connection.states.SELECTED) {\n            // reset selected state\n\n            let currentMailbox = connection.mailbox;\n\n            connection.mailbox = false;\n            connection.currentSelectCommand = false;\n            connection.state = connection.states.AUTHENTICATED;\n\n            if (currentMailbox) {\n                connection.emit('mailboxClose', currentMailbox);\n            }\n        }\n\n        connection.log.warn({ err, cid: connection.id });\n        throw err;\n    }\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/select.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/starttls.js":
|
|
/*!********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/starttls.js ***!
|
|
\********************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\n// Requests STARTTLS info from server\nmodule.exports = async connection => {\n if (!connection.capabilities.has('STARTTLS') || connection.secureConnection) {\n // nothing to do here\n return false;\n }\n\n let response;\n try {\n response = await connection.exec('STARTTLS');\n response.next();\n return true;\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvc3RhcnR0bHMuanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ04sOEJBQThCLHlCQUF5QjtBQUN2RDtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L2xpYi9jb21tYW5kcy9zdGFydHRscy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbi8vIFJlcXVlc3RzIFNUQVJUVExTIGluZm8gZnJvbSBzZXJ2ZXJcbm1vZHVsZS5leHBvcnRzID0gYXN5bmMgY29ubmVjdGlvbiA9PiB7XG4gICAgaWYgKCFjb25uZWN0aW9uLmNhcGFiaWxpdGllcy5oYXMoJ1NUQVJUVExTJykgfHwgY29ubmVjdGlvbi5zZWN1cmVDb25uZWN0aW9uKSB7XG4gICAgICAgIC8vIG5vdGhpbmcgdG8gZG8gaGVyZVxuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuXG4gICAgbGV0IHJlc3BvbnNlO1xuICAgIHRyeSB7XG4gICAgICAgIHJlc3BvbnNlID0gYXdhaXQgY29ubmVjdGlvbi5leGVjKCdTVEFSVFRMUycpO1xuICAgICAgICByZXNwb25zZS5uZXh0KCk7XG4gICAgICAgIHJldHVybiB0cnVlO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICBjb25uZWN0aW9uLmxvZy53YXJuKHsgZXJyLCBjaWQ6IGNvbm5lY3Rpb24uaWQgfSk7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG59O1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/starttls.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/status.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/status.js ***!
|
|
\******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { encodePath, normalizePath } = __webpack_require__(/*! ../tools.js */ \"(action-browser)/./node_modules/imapflow/lib/tools.js\");\n\n// Requests info about a mailbox\nmodule.exports = async (connection, path, query) => {\n if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state) || !path) {\n // nothing to do here\n return false;\n }\n\n path = normalizePath(connection, path);\n let encodedPath = encodePath(connection, path);\n\n let attributes = [{ type: encodedPath.indexOf('&') >= 0 ? 'STRING' : 'ATOM', value: encodedPath }];\n\n let queryAttributes = [];\n Object.keys(query || {}).forEach(key => {\n if (!query[key]) {\n return;\n }\n\n switch (key.toUpperCase()) {\n case 'MESSAGES':\n case 'RECENT':\n case 'UIDNEXT':\n case 'UIDVALIDITY':\n case 'UNSEEN':\n queryAttributes.push({ type: 'ATOM', value: key.toUpperCase() });\n break;\n\n case 'HIGHESTMODSEQ':\n if (connection.capabilities.has('CONDSTORE')) {\n queryAttributes.push({ type: 'ATOM', value: key.toUpperCase() });\n }\n break;\n }\n });\n\n if (!queryAttributes.length) {\n return false;\n }\n\n attributes.push(queryAttributes);\n\n let response;\n try {\n let map = { path };\n response = await connection.exec('STATUS', attributes, {\n untagged: {\n STATUS: async untagged => {\n // If STATUS is for current mailbox then update mailbox values\n let updateCurrent = connection.state === connection.states.SELECTED && path === connection.mailbox.path;\n\n let list = untagged.attributes && Array.isArray(untagged.attributes[1]) ? untagged.attributes[1] : false;\n if (!list) {\n return;\n }\n let key;\n list.forEach((entry, i) => {\n if (i % 2 === 0) {\n key = entry && typeof entry.value === 'string' ? entry.value : false;\n return;\n }\n if (!key || !entry || typeof entry.value !== 'string') {\n return;\n }\n let value = false;\n switch (key.toUpperCase()) {\n case 'MESSAGES':\n key = 'messages';\n value = !isNaN(entry.value) ? Number(entry.value) : false;\n if (updateCurrent) {\n let prevCount = connection.mailbox.exists;\n if (prevCount !== value) {\n // somehow message count in current folder has changed?\n connection.mailbox.exists = value;\n connection.emit('exists', {\n path,\n count: value,\n prevCount\n });\n }\n }\n break;\n\n case 'RECENT':\n key = 'recent';\n value = !isNaN(entry.value) ? Number(entry.value) : false;\n break;\n\n case 'UIDNEXT':\n key = 'uidNext';\n value = !isNaN(entry.value) ? Number(entry.value) : false;\n if (updateCurrent) {\n connection.mailbox.uidNext = value;\n }\n break;\n\n case 'UIDVALIDITY':\n key = 'uidValidity';\n value = !isNaN(entry.value) ? BigInt(entry.value) : false;\n break;\n\n case 'UNSEEN':\n key = 'unseen';\n value = !isNaN(entry.value) ? Number(entry.value) : false;\n break;\n\n case 'HIGHESTMODSEQ':\n key = 'highestModseq';\n value = !isNaN(entry.value) ? BigInt(entry.value) : false;\n if (updateCurrent) {\n connection.mailbox.highestModseq = value;\n }\n break;\n }\n if (value === false) {\n return;\n }\n\n map[key] = value;\n });\n }\n }\n });\n response.next();\n return map;\n } catch (err) {\n if (err.responseStatus === 'NO') {\n let folders = await connection.run('LIST', '', path, { listOnly: true });\n if (folders && !folders.length) {\n let error = new Error(`Mailbox doesn't exist: ${path}`);\n error.code = 'NotFound';\n error.response = err;\n throw error;\n }\n }\n\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/imapflow/lib/commands/status.js","mappings":"AAAa;;AAEb,QAAQ,4BAA4B,EAAE,mBAAO,CAAC,0EAAa;;AAE3D;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,wBAAwB,6EAA6E;;AAErG;AACA,2BAA2B;AAC3B;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,uCAAuC,wCAAwC;AAC/E;;AAEA;AACA;AACA,2CAA2C,wCAAwC;AACnF;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;;AAEA;;AAEA;AACA;AACA,oBAAoB;AACpB;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,yCAAyC;AACzC;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,qBAAqB;AACrB;AACA;AACA,SAAS;AACT;AACA;AACA,MAAM;AACN;AACA,mEAAmE,gBAAgB;AACnF;AACA,gEAAgE,KAAK;AACrE;AACA;AACA;AACA;AACA;;AAEA,8BAA8B,yBAAyB;AACvD;AACA;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/commands/status.js"],"sourcesContent":["'use strict';\n\nconst { encodePath, normalizePath } = require('../tools.js');\n\n// Requests info about a mailbox\nmodule.exports = async (connection, path, query) => {\n    if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state) || !path) {\n        // nothing to do here\n        return false;\n    }\n\n    path = normalizePath(connection, path);\n    let encodedPath = encodePath(connection, path);\n\n    let attributes = [{ type: encodedPath.indexOf('&') >= 0 ? 'STRING' : 'ATOM', value: encodedPath }];\n\n    let queryAttributes = [];\n    Object.keys(query || {}).forEach(key => {\n        if (!query[key]) {\n            return;\n        }\n\n        switch (key.toUpperCase()) {\n            case 'MESSAGES':\n            case 'RECENT':\n            case 'UIDNEXT':\n            case 'UIDVALIDITY':\n            case 'UNSEEN':\n                queryAttributes.push({ type: 'ATOM', value: key.toUpperCase() });\n                break;\n\n            case 'HIGHESTMODSEQ':\n                if (connection.capabilities.has('CONDSTORE')) {\n                    queryAttributes.push({ type: 'ATOM', value: key.toUpperCase() });\n                }\n                break;\n        }\n    });\n\n    if (!queryAttributes.length) {\n        return false;\n    }\n\n    attributes.push(queryAttributes);\n\n    let response;\n    try {\n        let map = { path };\n        response = await connection.exec('STATUS', attributes, {\n            untagged: {\n                STATUS: async untagged => {\n                    // If STATUS is for current mailbox then update mailbox values\n                    let updateCurrent = connection.state === connection.states.SELECTED && path === connection.mailbox.path;\n\n                    let list = untagged.attributes && Array.isArray(untagged.attributes[1]) ? untagged.attributes[1] : false;\n                    if (!list) {\n                        return;\n                    }\n                    let key;\n                    list.forEach((entry, i) => {\n                        if (i % 2 === 0) {\n                            key = entry && typeof entry.value === 'string' ? entry.value : false;\n                            return;\n                        }\n                        if (!key || !entry || typeof entry.value !== 'string') {\n                            return;\n                        }\n                        let value = false;\n                        switch (key.toUpperCase()) {\n                            case 'MESSAGES':\n                                key = 'messages';\n                                value = !isNaN(entry.value) ? Number(entry.value) : false;\n                                if (updateCurrent) {\n                                    let prevCount = connection.mailbox.exists;\n                                    if (prevCount !== value) {\n                                        // somehow message count in current folder has changed?\n                                        connection.mailbox.exists = value;\n                                        connection.emit('exists', {\n                                            path,\n                                            count: value,\n                                            prevCount\n                                        });\n                                    }\n                                }\n                                break;\n\n                            case 'RECENT':\n                                key = 'recent';\n                                value = !isNaN(entry.value) ? Number(entry.value) : false;\n                                break;\n\n                            case 'UIDNEXT':\n                                key = 'uidNext';\n                                value = !isNaN(entry.value) ? Number(entry.value) : false;\n                                if (updateCurrent) {\n                                    connection.mailbox.uidNext = value;\n                                }\n                                break;\n\n                            case 'UIDVALIDITY':\n                                key = 'uidValidity';\n                                value = !isNaN(entry.value) ? BigInt(entry.value) : false;\n                                break;\n\n                            case 'UNSEEN':\n                                key = 'unseen';\n                                value = !isNaN(entry.value) ? Number(entry.value) : false;\n                                break;\n\n                            case 'HIGHESTMODSEQ':\n                                key = 'highestModseq';\n                                value = !isNaN(entry.value) ? BigInt(entry.value) : false;\n                                if (updateCurrent) {\n                                    connection.mailbox.highestModseq = value;\n                                }\n                                break;\n                        }\n                        if (value === false) {\n                            return;\n                        }\n\n                        map[key] = value;\n                    });\n                }\n            }\n        });\n        response.next();\n        return map;\n    } catch (err) {\n        if (err.responseStatus === 'NO') {\n            let folders = await connection.run('LIST', '', path, { listOnly: true });\n            if (folders && !folders.length) {\n                let error = new Error(`Mailbox doesn't exist: ${path}`);\n                error.code = 'NotFound';\n                error.response = err;\n                throw error;\n            }\n        }\n\n        connection.log.warn({ err, cid: connection.id });\n        return false;\n    }\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/status.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/store.js":
|
|
/*!*****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/store.js ***!
|
|
\*****************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { getStatusCode, formatFlag, canUseFlag, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(action-browser)/./node_modules/imapflow/lib/tools.js\");\n\n// Updates flags for a message\nmodule.exports = async (connection, range, flags, options) => {\n if (connection.state !== connection.states.SELECTED || !range || (options.useLabels && !connection.capabilities.has('X-GM-EXT-1'))) {\n // nothing to do here\n return false;\n }\n\n options = options || {};\n let operation;\n\n operation = 'FLAGS';\n\n if (options.useLabels) {\n operation = 'X-GM-LABELS';\n } else if (options.silent) {\n operation = `${operation}.SILENT`;\n }\n\n switch ((options.operation || '').toLowerCase()) {\n case 'set':\n // do nothing, keep operation value as is\n break;\n case 'remove':\n operation = `-${operation}`;\n break;\n case 'add':\n default:\n operation = `+${operation}`;\n break;\n }\n\n flags = (Array.isArray(flags) ? flags : [].concat(flags || []))\n .map(flag => {\n flag = formatFlag(flag);\n\n if (!canUseFlag(connection.mailbox, flag) && operation !== 'remove') {\n // it does not seem that we can set this flag\n return false;\n }\n\n return flag;\n })\n .filter(flag => flag);\n\n if (!flags.length && options.operation !== 'set') {\n // nothing to do here\n return false;\n }\n\n let attributes = [{ type: 'SEQUENCE', value: range }, { type: 'ATOM', value: operation }, flags.map(flag => ({ type: 'ATOM', value: flag }))];\n\n if (options.unchangedSince && connection.enabled.has('CONDSTORE') && !connection.mailbox.noModseq) {\n attributes.push([\n {\n type: 'ATOM',\n value: 'UNCHANGEDSINCE'\n },\n {\n type: 'ATOM',\n value: options.unchangedSince.toString()\n }\n ]);\n }\n\n let response;\n try {\n response = await connection.exec(options.uid ? 'UID STORE' : 'STORE', attributes);\n response.next();\n return true;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvc3RvcmUuanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWIsUUFBUSxzREFBc0QsRUFBRSxtQkFBTyxDQUFDLDBFQUFhOztBQUVyRjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0EsTUFBTTtBQUNOLHVCQUF1QixVQUFVO0FBQ2pDOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSw0QkFBNEIsVUFBVTtBQUN0QztBQUNBO0FBQ0E7QUFDQSw0QkFBNEIsVUFBVTtBQUN0QztBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLFNBQVM7QUFDVDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSx3QkFBd0IsZ0NBQWdDLElBQUksZ0NBQWdDLHVCQUF1QiwyQkFBMkI7O0FBRTlJO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSw4QkFBOEIseUJBQXlCO0FBQ3ZEO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL3N0b3JlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgeyBnZXRTdGF0dXNDb2RlLCBmb3JtYXRGbGFnLCBjYW5Vc2VGbGFnLCBnZXRFcnJvclRleHQgfSA9IHJlcXVpcmUoJy4uL3Rvb2xzLmpzJyk7XG5cbi8vIFVwZGF0ZXMgZmxhZ3MgZm9yIGEgbWVzc2FnZVxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyAoY29ubmVjdGlvbiwgcmFuZ2UsIGZsYWdzLCBvcHRpb25zKSA9PiB7XG4gICAgaWYgKGNvbm5lY3Rpb24uc3RhdGUgIT09IGNvbm5lY3Rpb24uc3RhdGVzLlNFTEVDVEVEIHx8ICFyYW5nZSB8fCAob3B0aW9ucy51c2VMYWJlbHMgJiYgIWNvbm5lY3Rpb24uY2FwYWJpbGl0aWVzLmhhcygnWC1HTS1FWFQtMScpKSkge1xuICAgICAgICAvLyBub3RoaW5nIHRvIGRvIGhlcmVcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cblxuICAgIG9wdGlvbnMgPSBvcHRpb25zIHx8IHt9O1xuICAgIGxldCBvcGVyYXRpb247XG5cbiAgICBvcGVyYXRpb24gPSAnRkxBR1MnO1xuXG4gICAgaWYgKG9wdGlvbnMudXNlTGFiZWxzKSB7XG4gICAgICAgIG9wZXJhdGlvbiA9ICdYLUdNLUxBQkVMUyc7XG4gICAgfSBlbHNlIGlmIChvcHRpb25zLnNpbGVudCkge1xuICAgICAgICBvcGVyYXRpb24gPSBgJHtvcGVyYXRpb259LlNJTEVOVGA7XG4gICAgfVxuXG4gICAgc3dpdGNoICgob3B0aW9ucy5vcGVyYXRpb24gfHwgJycpLnRvTG93ZXJDYXNlKCkpIHtcbiAgICAgICAgY2FzZSAnc2V0JzpcbiAgICAgICAgICAgIC8vIGRvIG5vdGhpbmcsIGtlZXAgb3BlcmF0aW9uIHZhbHVlIGFzIGlzXG4gICAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSAncmVtb3ZlJzpcbiAgICAgICAgICAgIG9wZXJhdGlvbiA9IGAtJHtvcGVyYXRpb259YDtcbiAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICBjYXNlICdhZGQnOlxuICAgICAgICBkZWZhdWx0OlxuICAgICAgICAgICAgb3BlcmF0aW9uID0gYCske29wZXJhdGlvbn1gO1xuICAgICAgICAgICAgYnJlYWs7XG4gICAgfVxuXG4gICAgZmxhZ3MgPSAoQXJyYXkuaXNBcnJheShmbGFncykgPyBmbGFncyA6IFtdLmNvbmNhdChmbGFncyB8fCBbXSkpXG4gICAgICAgIC5tYXAoZmxhZyA9PiB7XG4gICAgICAgICAgICBmbGFnID0gZm9ybWF0RmxhZyhmbGFnKTtcblxuICAgICAgICAgICAgaWYgKCFjYW5Vc2VGbGFnKGNvbm5lY3Rpb24ubWFpbGJveCwgZmxhZykgJiYgb3BlcmF0aW9uICE9PSAncmVtb3ZlJykge1xuICAgICAgICAgICAgICAgIC8vIGl0IGRvZXMgbm90IHNlZW0gdGhhdCB3ZSBjYW4gc2V0IHRoaXMgZmxhZ1xuICAgICAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgcmV0dXJuIGZsYWc7XG4gICAgICAgIH0pXG4gICAgICAgIC5maWx0ZXIoZmxhZyA9PiBmbGFnKTtcblxuICAgIGlmICghZmxhZ3MubGVuZ3RoICYmIG9wdGlvbnMub3BlcmF0aW9uICE9PSAnc2V0Jykge1xuICAgICAgICAvLyBub3RoaW5nIHRvIGRvIGhlcmVcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cblxuICAgIGxldCBhdHRyaWJ1dGVzID0gW3sgdHlwZTogJ1NFUVVFTkNFJywgdmFsdWU6IHJhbmdlIH0sIHsgdHlwZTogJ0FUT00nLCB2YWx1ZTogb3BlcmF0aW9uIH0sIGZsYWdzLm1hcChmbGFnID0+ICh7IHR5cGU6ICdBVE9NJywgdmFsdWU6IGZsYWcgfSkpXTtcblxuICAgIGlmIChvcHRpb25zLnVuY2hhbmdlZFNpbmNlICYmIGNvbm5lY3Rpb24uZW5hYmxlZC5oYXMoJ0NPTkRTVE9SRScpICYmICFjb25uZWN0aW9uLm1haWxib3gubm9Nb2RzZXEpIHtcbiAgICAgICAgYXR0cmlidXRlcy5wdXNoKFtcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICB0eXBlOiAnQVRPTScsXG4gICAgICAgICAgICAgICAgdmFsdWU6ICdVTkNIQU5HRURTSU5DRSdcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgdHlwZTogJ0FUT00nLFxuICAgICAgICAgICAgICAgIHZhbHVlOiBvcHRpb25zLnVuY2hhbmdlZFNpbmNlLnRvU3RyaW5nKClcbiAgICAgICAgICAgIH1cbiAgICAgICAgXSk7XG4gICAgfVxuXG4gICAgbGV0IHJlc3BvbnNlO1xuICAgIHRyeSB7XG4gICAgICAgIHJlc3BvbnNlID0gYXdhaXQgY29ubmVjdGlvbi5leGVjKG9wdGlvbnMudWlkID8gJ1VJRCBTVE9SRScgOiAnU1RPUkUnLCBhdHRyaWJ1dGVzKTtcbiAgICAgICAgcmVzcG9uc2UubmV4dCgpO1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgbGV0IGVycm9yQ29kZSA9IGdldFN0YXR1c0NvZGUoZXJyLnJlc3BvbnNlKTtcbiAgICAgICAgaWYgKGVycm9yQ29kZSkge1xuICAgICAgICAgICAgZXJyLnNlcnZlclJlc3BvbnNlQ29kZSA9IGVycm9yQ29kZTtcbiAgICAgICAgfVxuICAgICAgICBlcnIucmVzcG9uc2UgPSBhd2FpdCBnZXRFcnJvclRleHQoZXJyLnJlc3BvbnNlKTtcblxuICAgICAgICBjb25uZWN0aW9uLmxvZy53YXJuKHsgZXJyLCBjaWQ6IGNvbm5lY3Rpb24uaWQgfSk7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG59O1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/store.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/subscribe.js":
|
|
/*!*********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/subscribe.js ***!
|
|
\*********************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { encodePath, normalizePath, getStatusCode, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(action-browser)/./node_modules/imapflow/lib/tools.js\");\n\n// Subscribes to a mailbox\nmodule.exports = async (connection, path) => {\n if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state)) {\n // nothing to do here\n return;\n }\n\n path = normalizePath(connection, path);\n\n let response;\n try {\n response = await connection.exec('SUBSCRIBE', [{ type: 'ATOM', value: encodePath(connection, path) }]);\n response.next();\n return true;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvc3Vic2NyaWJlLmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViLFFBQVEseURBQXlELEVBQUUsbUJBQU8sQ0FBQywwRUFBYTs7QUFFeEY7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQSx5REFBeUQsbURBQW1EO0FBQzVHO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSw4QkFBOEIseUJBQXlCO0FBQ3ZEO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL3N1YnNjcmliZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IHsgZW5jb2RlUGF0aCwgbm9ybWFsaXplUGF0aCwgZ2V0U3RhdHVzQ29kZSwgZ2V0RXJyb3JUZXh0IH0gPSByZXF1aXJlKCcuLi90b29scy5qcycpO1xuXG4vLyBTdWJzY3JpYmVzIHRvIGEgbWFpbGJveFxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyAoY29ubmVjdGlvbiwgcGF0aCkgPT4ge1xuICAgIGlmICghW2Nvbm5lY3Rpb24uc3RhdGVzLkFVVEhFTlRJQ0FURUQsIGNvbm5lY3Rpb24uc3RhdGVzLlNFTEVDVEVEXS5pbmNsdWRlcyhjb25uZWN0aW9uLnN0YXRlKSkge1xuICAgICAgICAvLyBub3RoaW5nIHRvIGRvIGhlcmVcbiAgICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIHBhdGggPSBub3JtYWxpemVQYXRoKGNvbm5lY3Rpb24sIHBhdGgpO1xuXG4gICAgbGV0IHJlc3BvbnNlO1xuICAgIHRyeSB7XG4gICAgICAgIHJlc3BvbnNlID0gYXdhaXQgY29ubmVjdGlvbi5leGVjKCdTVUJTQ1JJQkUnLCBbeyB0eXBlOiAnQVRPTScsIHZhbHVlOiBlbmNvZGVQYXRoKGNvbm5lY3Rpb24sIHBhdGgpIH1dKTtcbiAgICAgICAgcmVzcG9uc2UubmV4dCgpO1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgbGV0IGVycm9yQ29kZSA9IGdldFN0YXR1c0NvZGUoZXJyLnJlc3BvbnNlKTtcbiAgICAgICAgaWYgKGVycm9yQ29kZSkge1xuICAgICAgICAgICAgZXJyLnNlcnZlclJlc3BvbnNlQ29kZSA9IGVycm9yQ29kZTtcbiAgICAgICAgfVxuICAgICAgICBlcnIucmVzcG9uc2UgPSBhd2FpdCBnZXRFcnJvclRleHQoZXJyLnJlc3BvbnNlKTtcblxuICAgICAgICBjb25uZWN0aW9uLmxvZy53YXJuKHsgZXJyLCBjaWQ6IGNvbm5lY3Rpb24uaWQgfSk7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG59O1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/subscribe.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/commands/unsubscribe.js":
|
|
/*!***********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/unsubscribe.js ***!
|
|
\***********************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { encodePath, normalizePath, getStatusCode, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(action-browser)/./node_modules/imapflow/lib/tools.js\");\n\n// Unsubscribes from a mailbox\nmodule.exports = async (connection, path) => {\n if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state)) {\n // nothing to do here\n return;\n }\n\n path = normalizePath(connection, path);\n\n let response;\n try {\n response = await connection.exec('UNSUBSCRIBE', [{ type: 'ATOM', value: encodePath(connection, path) }]);\n response.next();\n return true;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvdW5zdWJzY3JpYmUuanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWIsUUFBUSx5REFBeUQsRUFBRSxtQkFBTyxDQUFDLDBFQUFhOztBQUV4RjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBLDJEQUEyRCxtREFBbUQ7QUFDOUc7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQSw4QkFBOEIseUJBQXlCO0FBQ3ZEO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL3Vuc3Vic2NyaWJlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgeyBlbmNvZGVQYXRoLCBub3JtYWxpemVQYXRoLCBnZXRTdGF0dXNDb2RlLCBnZXRFcnJvclRleHQgfSA9IHJlcXVpcmUoJy4uL3Rvb2xzLmpzJyk7XG5cbi8vIFVuc3Vic2NyaWJlcyBmcm9tIGEgbWFpbGJveFxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyAoY29ubmVjdGlvbiwgcGF0aCkgPT4ge1xuICAgIGlmICghW2Nvbm5lY3Rpb24uc3RhdGVzLkFVVEhFTlRJQ0FURUQsIGNvbm5lY3Rpb24uc3RhdGVzLlNFTEVDVEVEXS5pbmNsdWRlcyhjb25uZWN0aW9uLnN0YXRlKSkge1xuICAgICAgICAvLyBub3RoaW5nIHRvIGRvIGhlcmVcbiAgICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIHBhdGggPSBub3JtYWxpemVQYXRoKGNvbm5lY3Rpb24sIHBhdGgpO1xuXG4gICAgbGV0IHJlc3BvbnNlO1xuICAgIHRyeSB7XG4gICAgICAgIHJlc3BvbnNlID0gYXdhaXQgY29ubmVjdGlvbi5leGVjKCdVTlNVQlNDUklCRScsIFt7IHR5cGU6ICdBVE9NJywgdmFsdWU6IGVuY29kZVBhdGgoY29ubmVjdGlvbiwgcGF0aCkgfV0pO1xuICAgICAgICByZXNwb25zZS5uZXh0KCk7XG4gICAgICAgIHJldHVybiB0cnVlO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICBsZXQgZXJyb3JDb2RlID0gZ2V0U3RhdHVzQ29kZShlcnIucmVzcG9uc2UpO1xuICAgICAgICBpZiAoZXJyb3JDb2RlKSB7XG4gICAgICAgICAgICBlcnIuc2VydmVyUmVzcG9uc2VDb2RlID0gZXJyb3JDb2RlO1xuICAgICAgICB9XG5cbiAgICAgICAgZXJyLnJlc3BvbnNlID0gYXdhaXQgZ2V0RXJyb3JUZXh0KGVyci5yZXNwb25zZSk7XG5cbiAgICAgICAgY29ubmVjdGlvbi5sb2cud2Fybih7IGVyciwgY2lkOiBjb25uZWN0aW9uLmlkIH0pO1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxufTtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/commands/unsubscribe.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/handler/imap-compiler.js":
|
|
/*!************************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/handler/imap-compiler.js ***!
|
|
\************************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("/* eslint no-console: 0, new-cap: 0 */\n\n\n\nconst imapFormalSyntax = __webpack_require__(/*! ./imap-formal-syntax */ \"(action-browser)/./node_modules/imapflow/lib/handler/imap-formal-syntax.js\");\n\nconst formatRespEntry = (entry, returnEmpty) => {\n if (typeof entry === 'string') {\n return Buffer.from(entry);\n }\n\n if (typeof entry === 'number') {\n return Buffer.from(entry.toString());\n }\n\n if (Buffer.isBuffer(entry)) {\n return entry;\n }\n\n if (returnEmpty) {\n return null;\n }\n\n return Buffer.alloc(0);\n};\n\n/**\n * Compiles an input object into\n */\nmodule.exports = async (response, options) => {\n let { asArray, isLogging, literalPlus, literalMinus } = options || {};\n const respParts = [];\n\n let resp = [].concat(formatRespEntry(response.tag, true) || []).concat(response.command ? formatRespEntry(' ' + response.command) : []);\n let val;\n let lastType;\n\n let walk = async (node, options) => {\n options = options || {};\n\n let lastRespEntry = resp.length && resp[resp.length - 1];\n let lastRespByte = (lastRespEntry && lastRespEntry.length && lastRespEntry[lastRespEntry.length - 1]) || '';\n if (typeof lastRespByte === 'number') {\n lastRespByte = String.fromCharCode(lastRespByte);\n }\n\n if (lastType === 'LITERAL' || (!['(', '<', '['].includes(lastRespByte) && resp.length)) {\n if (options.subArray) {\n // ignore separator\n } else {\n resp.push(formatRespEntry(' '));\n }\n }\n\n if (node && node.buffer && !Buffer.isBuffer(node)) {\n // mongodb binary\n node = node.buffer;\n }\n\n if (Array.isArray(node)) {\n lastType = 'LIST';\n resp.push(formatRespEntry('('));\n\n // check if we need to skip separator WS between two arrays\n let subArray = node.length > 1 && Array.isArray(node[0]);\n\n for (let child of node) {\n if (subArray && !Array.isArray(child)) {\n subArray = false;\n }\n await walk(child, { subArray });\n }\n\n resp.push(formatRespEntry(')'));\n return;\n }\n\n if (!node && typeof node !== 'string' && typeof node !== 'number' && !Buffer.isBuffer(node)) {\n resp.push(formatRespEntry('NIL'));\n return;\n }\n\n if (typeof node === 'string' || Buffer.isBuffer(node)) {\n if (isLogging && node.length > 100) {\n resp.push(formatRespEntry('\"(* ' + node.length + 'B string *)\"'));\n } else {\n resp.push(formatRespEntry(JSON.stringify(node.toString())));\n }\n return;\n }\n\n if (typeof node === 'number') {\n resp.push(formatRespEntry(Math.round(node) || 0)); // Only integers allowed\n return;\n }\n\n lastType = node.type;\n\n if (isLogging && node.sensitive) {\n resp.push(formatRespEntry('\"(* value hidden *)\"'));\n return;\n }\n\n switch (node.type.toUpperCase()) {\n case 'LITERAL':\n if (isLogging) {\n resp.push(formatRespEntry('\"(* ' + node.value.length + 'B literal *)\"'));\n } else {\n let literalLength = !node.value ? 0 : Math.max(node.value.length, 0);\n\n let canAppend = !asArray || literalPlus || (literalMinus && literalLength <= 4096);\n let usePlus = canAppend && (literalMinus || literalPlus);\n\n resp.push(formatRespEntry(`${node.isLiteral8 ? '~' : ''}{${literalLength}${usePlus ? '+' : ''}}\\r\\n`));\n\n if (canAppend) {\n if (node.value && node.value.length) {\n resp.push(formatRespEntry(node.value));\n }\n } else {\n respParts.push(resp);\n resp = [].concat(formatRespEntry(node.value, true) || []);\n }\n }\n break;\n\n case 'STRING':\n if (isLogging && node.value.length > 100) {\n resp.push(formatRespEntry('\"(* ' + node.value.length + 'B string *)\"'));\n } else {\n resp.push(formatRespEntry(JSON.stringify((node.value || '').toString())));\n }\n break;\n\n case 'TEXT':\n case 'SEQUENCE':\n if (node.value) {\n resp.push(formatRespEntry(node.value));\n }\n break;\n\n case 'NUMBER':\n resp.push(formatRespEntry(node.value || 0));\n break;\n\n case 'ATOM':\n case 'SECTION':\n val = (node.value || '').toString();\n\n if (!node.section || val) {\n if (node.value === '' || imapFormalSyntax.verify(val.charAt(0) === '\\\\' ? val.substr(1) : val, imapFormalSyntax['ATOM-CHAR']()) >= 0) {\n val = JSON.stringify(val);\n }\n\n resp.push(formatRespEntry(val));\n }\n\n if (node.section) {\n resp.push(formatRespEntry('['));\n\n for (let child of node.section) {\n await walk(child);\n }\n\n resp.push(formatRespEntry(']'));\n }\n if (node.partial) {\n resp.push(formatRespEntry(`<${node.partial.join('.')}>`));\n }\n break;\n }\n };\n\n if (response.attributes) {\n let attributes = Array.isArray(response.attributes) ? response.attributes : [].concat(response.attributes);\n for (let child of attributes) {\n await walk(child);\n }\n }\n\n if (resp.length) {\n respParts.push(resp);\n }\n\n for (let i = 0; i < respParts.length; i++) {\n respParts[i] = Buffer.concat(respParts[i]);\n }\n\n return asArray ? respParts : respParts.flatMap(entry => entry);\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/imapflow/lib/handler/imap-compiler.js","mappings":"AAAA;;AAEa;;AAEb,yBAAyB,mBAAO,CAAC,wGAAsB;;AAEvD;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,UAAU,gDAAgD;AAC1D;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,oCAAoC,UAAU;AAC9C;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;;AAEA;AACA,+DAA+D;AAC/D;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;;AAEA;AACA;;AAEA,iDAAiD,4BAA4B,EAAE,cAAc,EAAE,oBAAoB;;AAEnH;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,kDAAkD,uBAAuB;AACzE;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,oBAAoB,sBAAsB;AAC1C;AACA;;AAEA;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/handler/imap-compiler.js"],"sourcesContent":["/* eslint no-console: 0, new-cap: 0 */\n\n'use strict';\n\nconst imapFormalSyntax = require('./imap-formal-syntax');\n\nconst formatRespEntry = (entry, returnEmpty) => {\n    if (typeof entry === 'string') {\n        return Buffer.from(entry);\n    }\n\n    if (typeof entry === 'number') {\n        return Buffer.from(entry.toString());\n    }\n\n    if (Buffer.isBuffer(entry)) {\n        return entry;\n    }\n\n    if (returnEmpty) {\n        return null;\n    }\n\n    return Buffer.alloc(0);\n};\n\n/**\n * Compiles an input object into\n */\nmodule.exports = async (response, options) => {\n    let { asArray, isLogging, literalPlus, literalMinus } = options || {};\n    const respParts = [];\n\n    let resp = [].concat(formatRespEntry(response.tag, true) || []).concat(response.command ? formatRespEntry(' ' + response.command) : []);\n    let val;\n    let lastType;\n\n    let walk = async (node, options) => {\n        options = options || {};\n\n        let lastRespEntry = resp.length && resp[resp.length - 1];\n        let lastRespByte = (lastRespEntry && lastRespEntry.length && lastRespEntry[lastRespEntry.length - 1]) || '';\n        if (typeof lastRespByte === 'number') {\n            lastRespByte = String.fromCharCode(lastRespByte);\n        }\n\n        if (lastType === 'LITERAL' || (!['(', '<', '['].includes(lastRespByte) && resp.length)) {\n            if (options.subArray) {\n                // ignore separator\n            } else {\n                resp.push(formatRespEntry(' '));\n            }\n        }\n\n        if (node && node.buffer && !Buffer.isBuffer(node)) {\n            // mongodb binary\n            node = node.buffer;\n        }\n\n        if (Array.isArray(node)) {\n            lastType = 'LIST';\n            resp.push(formatRespEntry('('));\n\n            // check if we need to skip separator WS between two arrays\n            let subArray = node.length > 1 && Array.isArray(node[0]);\n\n            for (let child of node) {\n                if (subArray && !Array.isArray(child)) {\n                    subArray = false;\n                }\n                await walk(child, { subArray });\n            }\n\n            resp.push(formatRespEntry(')'));\n            return;\n        }\n\n        if (!node && typeof node !== 'string' && typeof node !== 'number' && !Buffer.isBuffer(node)) {\n            resp.push(formatRespEntry('NIL'));\n            return;\n        }\n\n        if (typeof node === 'string' || Buffer.isBuffer(node)) {\n            if (isLogging && node.length > 100) {\n                resp.push(formatRespEntry('\"(* ' + node.length + 'B string *)\"'));\n            } else {\n                resp.push(formatRespEntry(JSON.stringify(node.toString())));\n            }\n            return;\n        }\n\n        if (typeof node === 'number') {\n            resp.push(formatRespEntry(Math.round(node) || 0)); // Only integers allowed\n            return;\n        }\n\n        lastType = node.type;\n\n        if (isLogging && node.sensitive) {\n            resp.push(formatRespEntry('\"(* value hidden *)\"'));\n            return;\n        }\n\n        switch (node.type.toUpperCase()) {\n            case 'LITERAL':\n                if (isLogging) {\n                    resp.push(formatRespEntry('\"(* ' + node.value.length + 'B literal *)\"'));\n                } else {\n                    let literalLength = !node.value ? 0 : Math.max(node.value.length, 0);\n\n                    let canAppend = !asArray || literalPlus || (literalMinus && literalLength <= 4096);\n                    let usePlus = canAppend && (literalMinus || literalPlus);\n\n                    resp.push(formatRespEntry(`${node.isLiteral8 ? '~' : ''}{${literalLength}${usePlus ? '+' : ''}}\\r\\n`));\n\n                    if (canAppend) {\n                        if (node.value && node.value.length) {\n                            resp.push(formatRespEntry(node.value));\n                        }\n                    } else {\n                        respParts.push(resp);\n                        resp = [].concat(formatRespEntry(node.value, true) || []);\n                    }\n                }\n                break;\n\n            case 'STRING':\n                if (isLogging && node.value.length > 100) {\n                    resp.push(formatRespEntry('\"(* ' + node.value.length + 'B string *)\"'));\n                } else {\n                    resp.push(formatRespEntry(JSON.stringify((node.value || '').toString())));\n                }\n                break;\n\n            case 'TEXT':\n            case 'SEQUENCE':\n                if (node.value) {\n                    resp.push(formatRespEntry(node.value));\n                }\n                break;\n\n            case 'NUMBER':\n                resp.push(formatRespEntry(node.value || 0));\n                break;\n\n            case 'ATOM':\n            case 'SECTION':\n                val = (node.value || '').toString();\n\n                if (!node.section || val) {\n                    if (node.value === '' || imapFormalSyntax.verify(val.charAt(0) === '\\\\' ? val.substr(1) : val, imapFormalSyntax['ATOM-CHAR']()) >= 0) {\n                        val = JSON.stringify(val);\n                    }\n\n                    resp.push(formatRespEntry(val));\n                }\n\n                if (node.section) {\n                    resp.push(formatRespEntry('['));\n\n                    for (let child of node.section) {\n                        await walk(child);\n                    }\n\n                    resp.push(formatRespEntry(']'));\n                }\n                if (node.partial) {\n                    resp.push(formatRespEntry(`<${node.partial.join('.')}>`));\n                }\n                break;\n        }\n    };\n\n    if (response.attributes) {\n        let attributes = Array.isArray(response.attributes) ? response.attributes : [].concat(response.attributes);\n        for (let child of attributes) {\n            await walk(child);\n        }\n    }\n\n    if (resp.length) {\n        respParts.push(resp);\n    }\n\n    for (let i = 0; i < respParts.length; i++) {\n        respParts[i] = Buffer.concat(respParts[i]);\n    }\n\n    return asArray ? respParts : respParts.flatMap(entry => entry);\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/handler/imap-compiler.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/handler/imap-formal-syntax.js":
|
|
/*!*****************************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/handler/imap-formal-syntax.js ***!
|
|
\*****************************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("/* eslint object-shorthand:0, new-cap: 0, no-useless-concat: 0 */\n\n\n\n// IMAP Formal Syntax\n// http://tools.ietf.org/html/rfc3501#section-9\n\nfunction expandRange(start, end) {\n let chars = [];\n for (let i = start; i <= end; i++) {\n chars.push(i);\n }\n return String.fromCharCode(...chars);\n}\n\nfunction excludeChars(source, exclude) {\n let sourceArr = Array.prototype.slice.call(source);\n for (let i = sourceArr.length - 1; i >= 0; i--) {\n if (exclude.indexOf(sourceArr[i]) >= 0) {\n sourceArr.splice(i, 1);\n }\n }\n return sourceArr.join('');\n}\n\nmodule.exports = {\n CHAR() {\n let value = expandRange(0x01, 0x7f);\n this.CHAR = function () {\n return value;\n };\n return value;\n },\n\n CHAR8() {\n let value = expandRange(0x01, 0xff);\n this.CHAR8 = function () {\n return value;\n };\n return value;\n },\n\n SP() {\n return ' ';\n },\n\n CTL() {\n let value = expandRange(0x00, 0x1f) + '\\x7F';\n this.CTL = function () {\n return value;\n };\n return value;\n },\n\n DQUOTE() {\n return '\"';\n },\n\n ALPHA() {\n let value = expandRange(0x41, 0x5a) + expandRange(0x61, 0x7a);\n this.ALPHA = function () {\n return value;\n };\n return value;\n },\n\n DIGIT() {\n let value = expandRange(0x30, 0x39);\n this.DIGIT = function () {\n return value;\n };\n return value;\n },\n\n 'ATOM-CHAR'() {\n let value = excludeChars(this.CHAR(), this['atom-specials']());\n this['ATOM-CHAR'] = function () {\n return value;\n };\n return value;\n },\n\n 'ASTRING-CHAR'() {\n let value = this['ATOM-CHAR']() + this['resp-specials']();\n this['ASTRING-CHAR'] = function () {\n return value;\n };\n return value;\n },\n\n 'TEXT-CHAR'() {\n let value = excludeChars(this.CHAR(), '\\r\\n');\n this['TEXT-CHAR'] = function () {\n return value;\n };\n return value;\n },\n\n 'atom-specials'() {\n let value = '(' + ')' + '{' + this.SP() + this.CTL() + this['list-wildcards']() + this['quoted-specials']() + this['resp-specials']();\n this['atom-specials'] = function () {\n return value;\n };\n return value;\n },\n\n 'list-wildcards'() {\n return '%' + '*';\n },\n\n 'quoted-specials'() {\n let value = this.DQUOTE() + '\\\\';\n this['quoted-specials'] = function () {\n return value;\n };\n return value;\n },\n\n 'resp-specials'() {\n return ']';\n },\n\n tag() {\n let value = excludeChars(this['ASTRING-CHAR'](), '+');\n this.tag = function () {\n return value;\n };\n return value;\n },\n\n command() {\n let value = this.ALPHA() + this.DIGIT() + '-';\n this.command = function () {\n return value;\n };\n return value;\n },\n\n verify(str, allowedChars) {\n for (let i = 0, len = str.length; i < len; i++) {\n if (allowedChars.indexOf(str.charAt(i)) < 0) {\n return i;\n }\n }\n return -1;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvaGFuZGxlci9pbWFwLWZvcm1hbC1zeW50YXguanMiLCJtYXBwaW5ncyI6IkFBQUE7O0FBRWE7O0FBRWI7QUFDQTs7QUFFQTtBQUNBO0FBQ0Esd0JBQXdCLFVBQVU7QUFDbEM7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLHVDQUF1QyxRQUFRO0FBQy9DO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7O0FBRUw7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLOztBQUVMO0FBQ0E7QUFDQSxLQUFLOztBQUVMO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7O0FBRUw7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLOztBQUVMO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7O0FBRUw7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBLGtDQUFrQztBQUNsQztBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7O0FBRUw7QUFDQTtBQUNBLEtBQUs7O0FBRUw7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLOztBQUVMO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7O0FBRUw7QUFDQSwwQ0FBMEMsU0FBUztBQUNuRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2hhbmRsZXIvaW1hcC1mb3JtYWwtc3ludGF4LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludCBvYmplY3Qtc2hvcnRoYW5kOjAsIG5ldy1jYXA6IDAsIG5vLXVzZWxlc3MtY29uY2F0OiAwICovXG5cbid1c2Ugc3RyaWN0JztcblxuLy8gSU1BUCBGb3JtYWwgU3ludGF4XG4vLyBodHRwOi8vdG9vbHMuaWV0Zi5vcmcvaHRtbC9yZmMzNTAxI3NlY3Rpb24tOVxuXG5mdW5jdGlvbiBleHBhbmRSYW5nZShzdGFydCwgZW5kKSB7XG4gICAgbGV0IGNoYXJzID0gW107XG4gICAgZm9yIChsZXQgaSA9IHN0YXJ0OyBpIDw9IGVuZDsgaSsrKSB7XG4gICAgICAgIGNoYXJzLnB1c2goaSk7XG4gICAgfVxuICAgIHJldHVybiBTdHJpbmcuZnJvbUNoYXJDb2RlKC4uLmNoYXJzKTtcbn1cblxuZnVuY3Rpb24gZXhjbHVkZUNoYXJzKHNvdXJjZSwgZXhjbHVkZSkge1xuICAgIGxldCBzb3VyY2VBcnIgPSBBcnJheS5wcm90b3R5cGUuc2xpY2UuY2FsbChzb3VyY2UpO1xuICAgIGZvciAobGV0IGkgPSBzb3VyY2VBcnIubGVuZ3RoIC0gMTsgaSA+PSAwOyBpLS0pIHtcbiAgICAgICAgaWYgKGV4Y2x1ZGUuaW5kZXhPZihzb3VyY2VBcnJbaV0pID49IDApIHtcbiAgICAgICAgICAgIHNvdXJjZUFyci5zcGxpY2UoaSwgMSk7XG4gICAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIHNvdXJjZUFyci5qb2luKCcnKTtcbn1cblxubW9kdWxlLmV4cG9ydHMgPSB7XG4gICAgQ0hBUigpIHtcbiAgICAgICAgbGV0IHZhbHVlID0gZXhwYW5kUmFuZ2UoMHgwMSwgMHg3Zik7XG4gICAgICAgIHRoaXMuQ0hBUiA9IGZ1bmN0aW9uICgpIHtcbiAgICAgICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICAgICAgfTtcbiAgICAgICAgcmV0dXJuIHZhbHVlO1xuICAgIH0sXG5cbiAgICBDSEFSOCgpIHtcbiAgICAgICAgbGV0IHZhbHVlID0gZXhwYW5kUmFuZ2UoMHgwMSwgMHhmZik7XG4gICAgICAgIHRoaXMuQ0hBUjggPSBmdW5jdGlvbiAoKSB7XG4gICAgICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgICAgIH07XG4gICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICB9LFxuXG4gICAgU1AoKSB7XG4gICAgICAgIHJldHVybiAnICc7XG4gICAgfSxcblxuICAgIENUTCgpIHtcbiAgICAgICAgbGV0IHZhbHVlID0gZXhwYW5kUmFuZ2UoMHgwMCwgMHgxZikgKyAnXFx4N0YnO1xuICAgICAgICB0aGlzLkNUTCA9IGZ1bmN0aW9uICgpIHtcbiAgICAgICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICAgICAgfTtcbiAgICAgICAgcmV0dXJuIHZhbHVlO1xuICAgIH0sXG5cbiAgICBEUVVPVEUoKSB7XG4gICAgICAgIHJldHVybiAnXCInO1xuICAgIH0sXG5cbiAgICBBTFBIQSgpIHtcbiAgICAgICAgbGV0IHZhbHVlID0gZXhwYW5kUmFuZ2UoMHg0MSwgMHg1YSkgKyBleHBhbmRSYW5nZSgweDYxLCAweDdhKTtcbiAgICAgICAgdGhpcy5BTFBIQSA9IGZ1bmN0aW9uICgpIHtcbiAgICAgICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICAgICAgfTtcbiAgICAgICAgcmV0dXJuIHZhbHVlO1xuICAgIH0sXG5cbiAgICBESUdJVCgpIHtcbiAgICAgICAgbGV0IHZhbHVlID0gZXhwYW5kUmFuZ2UoMHgzMCwgMHgzOSk7XG4gICAgICAgIHRoaXMuRElHSVQgPSBmdW5jdGlvbiAoKSB7XG4gICAgICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgICAgIH07XG4gICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICB9LFxuXG4gICAgJ0FUT00tQ0hBUicoKSB7XG4gICAgICAgIGxldCB2YWx1ZSA9IGV4Y2x1ZGVDaGFycyh0aGlzLkNIQVIoKSwgdGhpc1snYXRvbS1zcGVjaWFscyddKCkpO1xuICAgICAgICB0aGlzWydBVE9NLUNIQVInXSA9IGZ1bmN0aW9uICgpIHtcbiAgICAgICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICAgICAgfTtcbiAgICAgICAgcmV0dXJuIHZhbHVlO1xuICAgIH0sXG5cbiAgICAnQVNUUklORy1DSEFSJygpIHtcbiAgICAgICAgbGV0IHZhbHVlID0gdGhpc1snQVRPTS1DSEFSJ10oKSArIHRoaXNbJ3Jlc3Atc3BlY2lhbHMnXSgpO1xuICAgICAgICB0aGlzWydBU1RSSU5HLUNIQVInXSA9IGZ1bmN0aW9uICgpIHtcbiAgICAgICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICAgICAgfTtcbiAgICAgICAgcmV0dXJuIHZhbHVlO1xuICAgIH0sXG5cbiAgICAnVEVYVC1DSEFSJygpIHtcbiAgICAgICAgbGV0IHZhbHVlID0gZXhjbHVkZUNoYXJzKHRoaXMuQ0hBUigpLCAnXFxyXFxuJyk7XG4gICAgICAgIHRoaXNbJ1RFWFQtQ0hBUiddID0gZnVuY3Rpb24gKCkge1xuICAgICAgICAgICAgcmV0dXJuIHZhbHVlO1xuICAgICAgICB9O1xuICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgfSxcblxuICAgICdhdG9tLXNwZWNpYWxzJygpIHtcbiAgICAgICAgbGV0IHZhbHVlID0gJygnICsgJyknICsgJ3snICsgdGhpcy5TUCgpICsgdGhpcy5DVEwoKSArIHRoaXNbJ2xpc3Qtd2lsZGNhcmRzJ10oKSArIHRoaXNbJ3F1b3RlZC1zcGVjaWFscyddKCkgKyB0aGlzWydyZXNwLXNwZWNpYWxzJ10oKTtcbiAgICAgICAgdGhpc1snYXRvbS1zcGVjaWFscyddID0gZnVuY3Rpb24gKCkge1xuICAgICAgICAgICAgcmV0dXJuIHZhbHVlO1xuICAgICAgICB9O1xuICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgfSxcblxuICAgICdsaXN0LXdpbGRjYXJkcycoKSB7XG4gICAgICAgIHJldHVybiAnJScgKyAnKic7XG4gICAgfSxcblxuICAgICdxdW90ZWQtc3BlY2lhbHMnKCkge1xuICAgICAgICBsZXQgdmFsdWUgPSB0aGlzLkRRVU9URSgpICsgJ1xcXFwnO1xuICAgICAgICB0aGlzWydxdW90ZWQtc3BlY2lhbHMnXSA9IGZ1bmN0aW9uICgpIHtcbiAgICAgICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICAgICAgfTtcbiAgICAgICAgcmV0dXJuIHZhbHVlO1xuICAgIH0sXG5cbiAgICAncmVzcC1zcGVjaWFscycoKSB7XG4gICAgICAgIHJldHVybiAnXSc7XG4gICAgfSxcblxuICAgIHRhZygpIHtcbiAgICAgICAgbGV0IHZhbHVlID0gZXhjbHVkZUNoYXJzKHRoaXNbJ0FTVFJJTkctQ0hBUiddKCksICcrJyk7XG4gICAgICAgIHRoaXMudGFnID0gZnVuY3Rpb24gKCkge1xuICAgICAgICAgICAgcmV0dXJuIHZhbHVlO1xuICAgICAgICB9O1xuICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgfSxcblxuICAgIGNvbW1hbmQoKSB7XG4gICAgICAgIGxldCB2YWx1ZSA9IHRoaXMuQUxQSEEoKSArIHRoaXMuRElHSVQoKSArICctJztcbiAgICAgICAgdGhpcy5jb21tYW5kID0gZnVuY3Rpb24gKCkge1xuICAgICAgICAgICAgcmV0dXJuIHZhbHVlO1xuICAgICAgICB9O1xuICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgfSxcblxuICAgIHZlcmlmeShzdHIsIGFsbG93ZWRDaGFycykge1xuICAgICAgICBmb3IgKGxldCBpID0gMCwgbGVuID0gc3RyLmxlbmd0aDsgaSA8IGxlbjsgaSsrKSB7XG4gICAgICAgICAgICBpZiAoYWxsb3dlZENoYXJzLmluZGV4T2Yoc3RyLmNoYXJBdChpKSkgPCAwKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIGk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIC0xO1xuICAgIH1cbn07XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/handler/imap-formal-syntax.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/handler/imap-handler.js":
|
|
/*!***********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/handler/imap-handler.js ***!
|
|
\***********************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst parser = __webpack_require__(/*! ./imap-parser */ \"(action-browser)/./node_modules/imapflow/lib/handler/imap-parser.js\");\nconst compiler = __webpack_require__(/*! ./imap-compiler */ \"(action-browser)/./node_modules/imapflow/lib/handler/imap-compiler.js\");\n\nmodule.exports = {\n parser,\n compiler\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvaGFuZGxlci9pbWFwLWhhbmRsZXIuanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWIsZUFBZSxtQkFBTyxDQUFDLDBGQUFlO0FBQ3RDLGlCQUFpQixtQkFBTyxDQUFDLDhGQUFpQjs7QUFFMUM7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L2xpYi9oYW5kbGVyL2ltYXAtaGFuZGxlci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IHBhcnNlciA9IHJlcXVpcmUoJy4vaW1hcC1wYXJzZXInKTtcbmNvbnN0IGNvbXBpbGVyID0gcmVxdWlyZSgnLi9pbWFwLWNvbXBpbGVyJyk7XG5cbm1vZHVsZS5leHBvcnRzID0ge1xuICAgIHBhcnNlcixcbiAgICBjb21waWxlclxufTtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/handler/imap-handler.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/handler/imap-parser.js":
|
|
/*!**********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/handler/imap-parser.js ***!
|
|
\**********************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst imapFormalSyntax = __webpack_require__(/*! ./imap-formal-syntax */ \"(action-browser)/./node_modules/imapflow/lib/handler/imap-formal-syntax.js\");\nconst { ParserInstance } = __webpack_require__(/*! ./parser-instance */ \"(action-browser)/./node_modules/imapflow/lib/handler/parser-instance.js\");\n\nmodule.exports = async (command, options) => {\n options = options || {};\n\n let nullBytesRemoved = 0;\n\n // special case with a buggy IMAP server where responses are padded with zero bytes\n if (command[0] === 0) {\n // find the first non null byte and trim\n for (let i = 0; i < command.length; i++) {\n if (command[i] !== 0) {\n // trim to here\n command = command.slice(i);\n nullBytesRemoved = i;\n break;\n }\n }\n }\n\n const parser = new ParserInstance(command, options);\n const response = {};\n\n try {\n response.tag = await parser.getTag();\n\n await parser.getSpace();\n\n response.command = await parser.getCommand();\n\n if (nullBytesRemoved) {\n response.nullBytesRemoved = nullBytesRemoved;\n }\n\n if (['UID', 'AUTHENTICATE'].indexOf((response.command || '').toUpperCase()) >= 0) {\n await parser.getSpace();\n response.command += ' ' + (await parser.getElement(imapFormalSyntax.command()));\n }\n\n if (parser.remainder.trim().length) {\n await parser.getSpace();\n response.attributes = await parser.getAttributes();\n }\n\n if (parser.humanReadable) {\n response.attributes = (response.attributes || []).concat({\n type: 'TEXT',\n value: parser.humanReadable\n });\n }\n } catch (err) {\n if (err.code === 'ParserErrorExchange' && err.parserContext && err.parserContext.value) {\n return err.parserContext.value;\n }\n throw err;\n }\n\n return response;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvaGFuZGxlci9pbWFwLXBhcnNlci5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYix5QkFBeUIsbUJBQU8sQ0FBQyx3R0FBc0I7QUFDdkQsUUFBUSxpQkFBaUIsRUFBRSxtQkFBTyxDQUFDLGtHQUFtQjs7QUFFdEQ7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSx3QkFBd0Isb0JBQW9CO0FBQzVDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L2xpYi9oYW5kbGVyL2ltYXAtcGFyc2VyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgaW1hcEZvcm1hbFN5bnRheCA9IHJlcXVpcmUoJy4vaW1hcC1mb3JtYWwtc3ludGF4Jyk7XG5jb25zdCB7IFBhcnNlckluc3RhbmNlIH0gPSByZXF1aXJlKCcuL3BhcnNlci1pbnN0YW5jZScpO1xuXG5tb2R1bGUuZXhwb3J0cyA9IGFzeW5jIChjb21tYW5kLCBvcHRpb25zKSA9PiB7XG4gICAgb3B0aW9ucyA9IG9wdGlvbnMgfHwge307XG5cbiAgICBsZXQgbnVsbEJ5dGVzUmVtb3ZlZCA9IDA7XG5cbiAgICAvLyBzcGVjaWFsIGNhc2Ugd2l0aCBhIGJ1Z2d5IElNQVAgc2VydmVyIHdoZXJlIHJlc3BvbnNlcyBhcmUgcGFkZGVkIHdpdGggemVybyBieXRlc1xuICAgIGlmIChjb21tYW5kWzBdID09PSAwKSB7XG4gICAgICAgIC8vIGZpbmQgdGhlIGZpcnN0IG5vbiBudWxsIGJ5dGUgYW5kIHRyaW1cbiAgICAgICAgZm9yIChsZXQgaSA9IDA7IGkgPCBjb21tYW5kLmxlbmd0aDsgaSsrKSB7XG4gICAgICAgICAgICBpZiAoY29tbWFuZFtpXSAhPT0gMCkge1xuICAgICAgICAgICAgICAgIC8vIHRyaW0gdG8gaGVyZVxuICAgICAgICAgICAgICAgIGNvbW1hbmQgPSBjb21tYW5kLnNsaWNlKGkpO1xuICAgICAgICAgICAgICAgIG51bGxCeXRlc1JlbW92ZWQgPSBpO1xuICAgICAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgfVxuXG4gICAgY29uc3QgcGFyc2VyID0gbmV3IFBhcnNlckluc3RhbmNlKGNvbW1hbmQsIG9wdGlvbnMpO1xuICAgIGNvbnN0IHJlc3BvbnNlID0ge307XG5cbiAgICB0cnkge1xuICAgICAgICByZXNwb25zZS50YWcgPSBhd2FpdCBwYXJzZXIuZ2V0VGFnKCk7XG5cbiAgICAgICAgYXdhaXQgcGFyc2VyLmdldFNwYWNlKCk7XG5cbiAgICAgICAgcmVzcG9uc2UuY29tbWFuZCA9IGF3YWl0IHBhcnNlci5nZXRDb21tYW5kKCk7XG5cbiAgICAgICAgaWYgKG51bGxCeXRlc1JlbW92ZWQpIHtcbiAgICAgICAgICAgIHJlc3BvbnNlLm51bGxCeXRlc1JlbW92ZWQgPSBudWxsQnl0ZXNSZW1vdmVkO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKFsnVUlEJywgJ0FVVEhFTlRJQ0FURSddLmluZGV4T2YoKHJlc3BvbnNlLmNvbW1hbmQgfHwgJycpLnRvVXBwZXJDYXNlKCkpID49IDApIHtcbiAgICAgICAgICAgIGF3YWl0IHBhcnNlci5nZXRTcGFjZSgpO1xuICAgICAgICAgICAgcmVzcG9uc2UuY29tbWFuZCArPSAnICcgKyAoYXdhaXQgcGFyc2VyLmdldEVsZW1lbnQoaW1hcEZvcm1hbFN5bnRheC5jb21tYW5kKCkpKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChwYXJzZXIucmVtYWluZGVyLnRyaW0oKS5sZW5ndGgpIHtcbiAgICAgICAgICAgIGF3YWl0IHBhcnNlci5nZXRTcGFjZSgpO1xuICAgICAgICAgICAgcmVzcG9uc2UuYXR0cmlidXRlcyA9IGF3YWl0IHBhcnNlci5nZXRBdHRyaWJ1dGVzKCk7XG4gICAgICAgIH1cblxuICAgICAgICBpZiAocGFyc2VyLmh1bWFuUmVhZGFibGUpIHtcbiAgICAgICAgICAgIHJlc3BvbnNlLmF0dHJpYnV0ZXMgPSAocmVzcG9uc2UuYXR0cmlidXRlcyB8fCBbXSkuY29uY2F0KHtcbiAgICAgICAgICAgICAgICB0eXBlOiAnVEVYVCcsXG4gICAgICAgICAgICAgICAgdmFsdWU6IHBhcnNlci5odW1hblJlYWRhYmxlXG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICBpZiAoZXJyLmNvZGUgPT09ICdQYXJzZXJFcnJvckV4Y2hhbmdlJyAmJiBlcnIucGFyc2VyQ29udGV4dCAmJiBlcnIucGFyc2VyQ29udGV4dC52YWx1ZSkge1xuICAgICAgICAgICAgcmV0dXJuIGVyci5wYXJzZXJDb250ZXh0LnZhbHVlO1xuICAgICAgICB9XG4gICAgICAgIHRocm93IGVycjtcbiAgICB9XG5cbiAgICByZXR1cm4gcmVzcG9uc2U7XG59O1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/handler/imap-parser.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/handler/imap-stream.js":
|
|
/*!**********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/handler/imap-stream.js ***!
|
|
\**********************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst Transform = (__webpack_require__(/*! stream */ \"stream\").Transform);\nconst logger = __webpack_require__(/*! ../logger */ \"(action-browser)/./node_modules/imapflow/lib/logger.js\");\n\nconst LINE = 0x01;\nconst LITERAL = 0x02;\n\nconst LF = 0x0a;\nconst CR = 0x0d;\nconst NUM_0 = 0x30;\nconst NUM_9 = 0x39;\nconst CURLY_OPEN = 0x7b;\nconst CURLY_CLOSE = 0x7d;\n\nclass ImapStream extends Transform {\n constructor(options) {\n super({\n //writableHighWaterMark: 3,\n readableObjectMode: true,\n writableObjectMode: false\n });\n\n this.options = options || {};\n this.cid = this.options.cid;\n\n this.log =\n this.options.logger && typeof this.options.logger === 'object'\n ? this.options.logger\n : logger.child({\n component: 'imap-connection',\n cid: this.cid\n });\n\n this.readBytesCounter = 0;\n\n this.state = LINE;\n this.literalWaiting = 0;\n this.inputBuffer = []; // lines\n this.lineBuffer = []; // current line\n this.literalBuffer = [];\n this.literals = [];\n\n this.compress = false;\n this.secureConnection = this.options.secureConnection;\n\n this.processingInput = false;\n this.inputQueue = []; // unprocessed input chunks\n }\n\n checkLiteralMarker(line) {\n if (!line || !line.length) {\n return false;\n }\n\n let pos = line.length - 1;\n\n if (line[pos] === LF) {\n pos--;\n } else {\n return false;\n }\n if (pos >= 0 && line[pos] === CR) {\n pos--;\n }\n if (pos < 0) {\n return false;\n }\n\n if (!pos || line[pos] !== CURLY_CLOSE) {\n return false;\n }\n pos--;\n\n let numBytes = [];\n for (; pos > 0; pos--) {\n let c = line[pos];\n if (c >= NUM_0 && c <= NUM_9) {\n numBytes.unshift(c);\n continue;\n }\n if (c === CURLY_OPEN && numBytes.length) {\n this.state = LITERAL;\n this.literalWaiting = Number(Buffer.from(numBytes).toString());\n return true;\n }\n return false;\n }\n return false;\n }\n\n async processInputChunk(chunk, startPos) {\n startPos = startPos || 0;\n if (startPos >= chunk.length) {\n return;\n }\n\n switch (this.state) {\n case LINE: {\n let lineStart = startPos;\n for (let i = startPos, len = chunk.length; i < len; i++) {\n if (chunk[i] === LF) {\n // line end found\n this.lineBuffer.push(chunk.slice(lineStart, i + 1));\n lineStart = i + 1;\n\n let line = Buffer.concat(this.lineBuffer);\n\n this.inputBuffer.push(line);\n this.lineBuffer = [];\n\n // try to detect if this is a literal start\n if (this.checkLiteralMarker(line)) {\n // switch into line mode and start over\n return await this.processInputChunk(chunk, lineStart);\n }\n\n // reached end of command input, emit it\n let payload = this.inputBuffer.length === 1 ? this.inputBuffer[0] : Buffer.concat(this.inputBuffer);\n let literals = this.literals;\n this.inputBuffer = [];\n this.literals = [];\n\n if (payload.length) {\n // remove final line terminator\n let skipBytes = 0;\n if (payload.length >= 1 && payload[payload.length - 1] === LF) {\n skipBytes++;\n if (payload.length >= 2 && payload[payload.length - 2] === CR) {\n skipBytes++;\n }\n }\n\n if (skipBytes) {\n payload = payload.slice(0, payload.length - skipBytes);\n }\n\n if (payload.length) {\n await new Promise(resolve => {\n this.push({ payload, literals, next: resolve });\n });\n }\n }\n }\n }\n if (lineStart < chunk.length) {\n this.lineBuffer.push(chunk.slice(lineStart));\n }\n break;\n }\n\n case LITERAL: {\n // exactly until end of chunk\n if (chunk.length === startPos + this.literalWaiting) {\n if (!startPos) {\n this.literalBuffer.push(chunk);\n } else {\n this.literalBuffer.push(chunk.slice(startPos));\n }\n\n this.literalWaiting -= chunk.length;\n this.literals.push(Buffer.concat(this.literalBuffer));\n this.literalBuffer = [];\n this.state = LINE;\n\n return;\n } else if (chunk.length > startPos + this.literalWaiting) {\n let partial = chunk.slice(startPos, startPos + this.literalWaiting);\n this.literalBuffer.push(partial);\n startPos += partial.length;\n this.literalWaiting -= partial.length;\n this.literals.push(Buffer.concat(this.literalBuffer));\n this.literalBuffer = [];\n this.state = LINE;\n\n return await this.processInputChunk(chunk, startPos);\n } else {\n let partial = chunk.slice(startPos);\n this.literalBuffer.push(partial);\n startPos += partial.length;\n this.literalWaiting -= partial.length;\n return;\n }\n }\n }\n }\n\n async processInput() {\n let data;\n while ((data = this.inputQueue.shift())) {\n await this.processInputChunk(data.chunk);\n // mark chunk as processed\n data.next();\n }\n }\n\n _transform(chunk, encoding, next) {\n if (typeof chunk === 'string') {\n chunk = Buffer.from(chunk, encoding);\n }\n\n if (!chunk || !chunk.length) {\n return next();\n }\n\n this.readBytesCounter += chunk.length;\n\n if (this.options.logRaw) {\n this.log.trace({\n src: 's',\n msg: 'read from socket',\n data: chunk.toString('base64'),\n compress: !!this.compress,\n secure: !!this.secureConnection,\n cid: this.cid\n });\n }\n\n if (chunk && chunk.length) {\n this.inputQueue.push({ chunk, next });\n }\n\n if (!this.processingInput) {\n this.processingInput = true;\n this.processInput()\n .catch(err => this.emit('error', err))\n .finally(() => (this.processingInput = false));\n }\n }\n\n _flush(next) {\n next();\n }\n}\n\nmodule.exports.ImapStream = ImapStream;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/imapflow/lib/handler/imap-stream.js","mappings":"AAAa;;AAEb,kBAAkB,uDAA2B;AAC7C,eAAe,mBAAO,CAAC,yEAAW;;AAElC;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB;;AAEnB;;AAEA;AACA;AACA,+BAA+B;AAC/B,8BAA8B;AAC9B;AACA;;AAEA;AACA;;AAEA;AACA,8BAA8B;AAC9B;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,eAAe,SAAS;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,2DAA2D,SAAS;AACpE;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,gDAAgD,kCAAkC;AAClF,iCAAiC;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;;AAEA;AACA,mCAAmC,aAAa;AAChD;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,yBAAyB","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/handler/imap-stream.js"],"sourcesContent":["'use strict';\n\nconst Transform = require('stream').Transform;\nconst logger = require('../logger');\n\nconst LINE = 0x01;\nconst LITERAL = 0x02;\n\nconst LF = 0x0a;\nconst CR = 0x0d;\nconst NUM_0 = 0x30;\nconst NUM_9 = 0x39;\nconst CURLY_OPEN = 0x7b;\nconst CURLY_CLOSE = 0x7d;\n\nclass ImapStream extends Transform {\n    constructor(options) {\n        super({\n            //writableHighWaterMark: 3,\n            readableObjectMode: true,\n            writableObjectMode: false\n        });\n\n        this.options = options || {};\n        this.cid = this.options.cid;\n\n        this.log =\n            this.options.logger && typeof this.options.logger === 'object'\n                ? this.options.logger\n                : logger.child({\n                      component: 'imap-connection',\n                      cid: this.cid\n                  });\n\n        this.readBytesCounter = 0;\n\n        this.state = LINE;\n        this.literalWaiting = 0;\n        this.inputBuffer = []; // lines\n        this.lineBuffer = []; // current line\n        this.literalBuffer = [];\n        this.literals = [];\n\n        this.compress = false;\n        this.secureConnection = this.options.secureConnection;\n\n        this.processingInput = false;\n        this.inputQueue = []; // unprocessed input chunks\n    }\n\n    checkLiteralMarker(line) {\n        if (!line || !line.length) {\n            return false;\n        }\n\n        let pos = line.length - 1;\n\n        if (line[pos] === LF) {\n            pos--;\n        } else {\n            return false;\n        }\n        if (pos >= 0 && line[pos] === CR) {\n            pos--;\n        }\n        if (pos < 0) {\n            return false;\n        }\n\n        if (!pos || line[pos] !== CURLY_CLOSE) {\n            return false;\n        }\n        pos--;\n\n        let numBytes = [];\n        for (; pos > 0; pos--) {\n            let c = line[pos];\n            if (c >= NUM_0 && c <= NUM_9) {\n                numBytes.unshift(c);\n                continue;\n            }\n            if (c === CURLY_OPEN && numBytes.length) {\n                this.state = LITERAL;\n                this.literalWaiting = Number(Buffer.from(numBytes).toString());\n                return true;\n            }\n            return false;\n        }\n        return false;\n    }\n\n    async processInputChunk(chunk, startPos) {\n        startPos = startPos || 0;\n        if (startPos >= chunk.length) {\n            return;\n        }\n\n        switch (this.state) {\n            case LINE: {\n                let lineStart = startPos;\n                for (let i = startPos, len = chunk.length; i < len; i++) {\n                    if (chunk[i] === LF) {\n                        // line end found\n                        this.lineBuffer.push(chunk.slice(lineStart, i + 1));\n                        lineStart = i + 1;\n\n                        let line = Buffer.concat(this.lineBuffer);\n\n                        this.inputBuffer.push(line);\n                        this.lineBuffer = [];\n\n                        // try to detect if this is a literal start\n                        if (this.checkLiteralMarker(line)) {\n                            // switch into line mode and start over\n                            return await this.processInputChunk(chunk, lineStart);\n                        }\n\n                        // reached end of command input, emit it\n                        let payload = this.inputBuffer.length === 1 ? this.inputBuffer[0] : Buffer.concat(this.inputBuffer);\n                        let literals = this.literals;\n                        this.inputBuffer = [];\n                        this.literals = [];\n\n                        if (payload.length) {\n                            // remove final line terminator\n                            let skipBytes = 0;\n                            if (payload.length >= 1 && payload[payload.length - 1] === LF) {\n                                skipBytes++;\n                                if (payload.length >= 2 && payload[payload.length - 2] === CR) {\n                                    skipBytes++;\n                                }\n                            }\n\n                            if (skipBytes) {\n                                payload = payload.slice(0, payload.length - skipBytes);\n                            }\n\n                            if (payload.length) {\n                                await new Promise(resolve => {\n                                    this.push({ payload, literals, next: resolve });\n                                });\n                            }\n                        }\n                    }\n                }\n                if (lineStart < chunk.length) {\n                    this.lineBuffer.push(chunk.slice(lineStart));\n                }\n                break;\n            }\n\n            case LITERAL: {\n                // exactly until end of chunk\n                if (chunk.length === startPos + this.literalWaiting) {\n                    if (!startPos) {\n                        this.literalBuffer.push(chunk);\n                    } else {\n                        this.literalBuffer.push(chunk.slice(startPos));\n                    }\n\n                    this.literalWaiting -= chunk.length;\n                    this.literals.push(Buffer.concat(this.literalBuffer));\n                    this.literalBuffer = [];\n                    this.state = LINE;\n\n                    return;\n                } else if (chunk.length > startPos + this.literalWaiting) {\n                    let partial = chunk.slice(startPos, startPos + this.literalWaiting);\n                    this.literalBuffer.push(partial);\n                    startPos += partial.length;\n                    this.literalWaiting -= partial.length;\n                    this.literals.push(Buffer.concat(this.literalBuffer));\n                    this.literalBuffer = [];\n                    this.state = LINE;\n\n                    return await this.processInputChunk(chunk, startPos);\n                } else {\n                    let partial = chunk.slice(startPos);\n                    this.literalBuffer.push(partial);\n                    startPos += partial.length;\n                    this.literalWaiting -= partial.length;\n                    return;\n                }\n            }\n        }\n    }\n\n    async processInput() {\n        let data;\n        while ((data = this.inputQueue.shift())) {\n            await this.processInputChunk(data.chunk);\n            // mark chunk as processed\n            data.next();\n        }\n    }\n\n    _transform(chunk, encoding, next) {\n        if (typeof chunk === 'string') {\n            chunk = Buffer.from(chunk, encoding);\n        }\n\n        if (!chunk || !chunk.length) {\n            return next();\n        }\n\n        this.readBytesCounter += chunk.length;\n\n        if (this.options.logRaw) {\n            this.log.trace({\n                src: 's',\n                msg: 'read from socket',\n                data: chunk.toString('base64'),\n                compress: !!this.compress,\n                secure: !!this.secureConnection,\n                cid: this.cid\n            });\n        }\n\n        if (chunk && chunk.length) {\n            this.inputQueue.push({ chunk, next });\n        }\n\n        if (!this.processingInput) {\n            this.processingInput = true;\n            this.processInput()\n                .catch(err => this.emit('error', err))\n                .finally(() => (this.processingInput = false));\n        }\n    }\n\n    _flush(next) {\n        next();\n    }\n}\n\nmodule.exports.ImapStream = ImapStream;\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/handler/imap-stream.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/handler/parser-instance.js":
|
|
/*!**************************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/handler/parser-instance.js ***!
|
|
\**************************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("/* eslint new-cap: 0 */\n\n\n\nconst imapFormalSyntax = __webpack_require__(/*! ./imap-formal-syntax */ \"(action-browser)/./node_modules/imapflow/lib/handler/imap-formal-syntax.js\");\n\nconst { TokenParser } = __webpack_require__(/*! ./token-parser */ \"(action-browser)/./node_modules/imapflow/lib/handler/token-parser.js\");\n\nclass ParserInstance {\n constructor(input, options) {\n this.input = (input || '').toString();\n this.options = options || {};\n this.remainder = this.input;\n this.pos = 0;\n }\n\n async getTag() {\n if (!this.tag) {\n this.tag = await this.getElement(imapFormalSyntax.tag() + '*+', true);\n }\n return this.tag;\n }\n\n async getCommand() {\n if (this.tag === '+') {\n // special case\n this.humanReadable = this.remainder.trim();\n this.remainder = '';\n\n return '';\n }\n\n if (!this.command) {\n this.command = await this.getElement(imapFormalSyntax.command());\n }\n\n switch ((this.command || '').toString().toUpperCase()) {\n case 'OK':\n case 'NO':\n case 'BAD':\n case 'PREAUTH':\n case 'BYE':\n {\n let match = this.remainder.match(/^\\s+\\[/);\n if (match) {\n let nesting = 1;\n for (let i = match[0].length; i <= this.remainder.length; i++) {\n let c = this.remainder[i];\n\n if (c === '[') {\n nesting++;\n } else if (c === ']') {\n nesting--;\n }\n if (!nesting) {\n this.humanReadable = this.remainder.substring(i + 1).trim();\n this.remainder = this.remainder.substring(0, i + 1);\n break;\n }\n }\n } else {\n this.humanReadable = this.remainder.trim();\n this.remainder = '';\n }\n }\n break;\n }\n\n return this.command;\n }\n\n async getElement(syntax) {\n let match, element, errPos;\n\n if (this.remainder.match(/^\\s/)) {\n let error = new Error(`Unexpected whitespace at position ${this.pos} [E1]`);\n error.code = 'ParserError1';\n error.parserContext = { input: this.input, pos: this.pos };\n throw error;\n }\n\n if ((match = this.remainder.match(/^\\s*[^\\s]+(?=\\s|$)/))) {\n element = match[0];\n if ((errPos = imapFormalSyntax.verify(element, syntax)) >= 0) {\n if (this.tag === 'Server' && element === 'Unavailable.') {\n // Exchange error\n let error = new Error(`Server returned an error: ${this.input}`);\n error.code = 'ParserErrorExchange';\n error.parserContext = {\n input: this.input,\n element,\n pos: this.pos,\n value: {\n tag: '*',\n command: 'BAD',\n attributes: [{ type: 'TEXT', value: this.input }]\n }\n };\n throw error;\n }\n\n let error = new Error(`Unexpected char at position ${this.pos + errPos} [E2: ${JSON.stringify(element.charAt(errPos))}]`);\n error.code = 'ParserError2';\n error.parserContext = { input: this.input, element, pos: this.pos };\n throw error;\n }\n } else {\n let error = new Error(`Unexpected end of input at position ${this.pos} [E3]`);\n error.code = 'ParserError3';\n error.parserContext = { input: this.input, pos: this.pos };\n throw error;\n }\n\n this.pos += match[0].length;\n this.remainder = this.remainder.substr(match[0].length);\n\n return element;\n }\n\n async getSpace() {\n if (!this.remainder.length) {\n if (this.tag === '+' && this.pos === 1) {\n // special case, empty + response\n return;\n }\n\n let error = new Error(`Unexpected end of input at position ${this.pos} [E4]`);\n error.code = 'ParserError4';\n error.parserContext = { input: this.input, pos: this.pos };\n throw error;\n }\n\n if (imapFormalSyntax.verify(this.remainder.charAt(0), imapFormalSyntax.SP()) >= 0) {\n let error = new Error(`Unexpected char at position ${this.pos} [E5: ${JSON.stringify(this.remainder.charAt(0))}]`);\n error.code = 'ParserError5';\n error.parserContext = { input: this.input, element: this.remainder, pos: this.pos };\n throw error;\n }\n\n this.pos++;\n this.remainder = this.remainder.substr(1);\n }\n\n async getAttributes() {\n if (!this.remainder.length) {\n let error = new Error(`Unexpected end of input at position ${this.pos} [E6]`);\n error.code = 'ParserError6';\n error.parserContext = { input: this.input, pos: this.pos };\n throw error;\n }\n\n if (this.remainder.match(/^\\s/)) {\n let error = new Error(`Unexpected whitespace at position ${this.pos} [E7]`);\n error.code = 'ParserError7';\n error.parserContext = { input: this.input, element: this.remainder, pos: this.pos };\n throw error;\n }\n\n const tokenParser = new TokenParser(this, this.pos, this.remainder, this.options);\n\n return await tokenParser.getAttributes();\n }\n}\n\nmodule.exports.ParserInstance = ParserInstance;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/imapflow/lib/handler/parser-instance.js","mappings":"AAAA;;AAEa;;AAEb,yBAAyB,mBAAO,CAAC,wGAAsB;;AAEvD,QAAQ,cAAc,EAAE,mBAAO,CAAC,4FAAgB;;AAEhD;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sDAAsD,4BAA4B;AAClF;;AAEA;AACA;AACA,8BAA8B;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA,uEAAuE,UAAU;AACjF;AACA,oCAAoC;AACpC;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,uEAAuE,WAAW;AAClF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C,iCAAiC;AAC5E;AACA;AACA;AACA;;AAEA,qEAAqE,mBAAmB,OAAO,uCAAuC;AACtI;AACA,wCAAwC;AACxC;AACA;AACA,UAAU;AACV,yEAAyE,UAAU;AACnF;AACA,oCAAoC;AACpC;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA,yEAAyE,UAAU;AACnF;AACA,oCAAoC;AACpC;AACA;;AAEA;AACA,iEAAiE,UAAU,OAAO,yCAAyC;AAC3H;AACA,oCAAoC;AACpC;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,yEAAyE,UAAU;AACnF;AACA,oCAAoC;AACpC;AACA;;AAEA;AACA,uEAAuE,UAAU;AACjF;AACA,oCAAoC;AACpC;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA,6BAA6B","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/handler/parser-instance.js"],"sourcesContent":["/* eslint new-cap: 0 */\n\n'use strict';\n\nconst imapFormalSyntax = require('./imap-formal-syntax');\n\nconst { TokenParser } = require('./token-parser');\n\nclass ParserInstance {\n    constructor(input, options) {\n        this.input = (input || '').toString();\n        this.options = options || {};\n        this.remainder = this.input;\n        this.pos = 0;\n    }\n\n    async getTag() {\n        if (!this.tag) {\n            this.tag = await this.getElement(imapFormalSyntax.tag() + '*+', true);\n        }\n        return this.tag;\n    }\n\n    async getCommand() {\n        if (this.tag === '+') {\n            // special case\n            this.humanReadable = this.remainder.trim();\n            this.remainder = '';\n\n            return '';\n        }\n\n        if (!this.command) {\n            this.command = await this.getElement(imapFormalSyntax.command());\n        }\n\n        switch ((this.command || '').toString().toUpperCase()) {\n            case 'OK':\n            case 'NO':\n            case 'BAD':\n            case 'PREAUTH':\n            case 'BYE':\n                {\n                    let match = this.remainder.match(/^\\s+\\[/);\n                    if (match) {\n                        let nesting = 1;\n                        for (let i = match[0].length; i <= this.remainder.length; i++) {\n                            let c = this.remainder[i];\n\n                            if (c === '[') {\n                                nesting++;\n                            } else if (c === ']') {\n                                nesting--;\n                            }\n                            if (!nesting) {\n                                this.humanReadable = this.remainder.substring(i + 1).trim();\n                                this.remainder = this.remainder.substring(0, i + 1);\n                                break;\n                            }\n                        }\n                    } else {\n                        this.humanReadable = this.remainder.trim();\n                        this.remainder = '';\n                    }\n                }\n                break;\n        }\n\n        return this.command;\n    }\n\n    async getElement(syntax) {\n        let match, element, errPos;\n\n        if (this.remainder.match(/^\\s/)) {\n            let error = new Error(`Unexpected whitespace at position ${this.pos} [E1]`);\n            error.code = 'ParserError1';\n            error.parserContext = { input: this.input, pos: this.pos };\n            throw error;\n        }\n\n        if ((match = this.remainder.match(/^\\s*[^\\s]+(?=\\s|$)/))) {\n            element = match[0];\n            if ((errPos = imapFormalSyntax.verify(element, syntax)) >= 0) {\n                if (this.tag === 'Server' && element === 'Unavailable.') {\n                    // Exchange error\n                    let error = new Error(`Server returned an error: ${this.input}`);\n                    error.code = 'ParserErrorExchange';\n                    error.parserContext = {\n                        input: this.input,\n                        element,\n                        pos: this.pos,\n                        value: {\n                            tag: '*',\n                            command: 'BAD',\n                            attributes: [{ type: 'TEXT', value: this.input }]\n                        }\n                    };\n                    throw error;\n                }\n\n                let error = new Error(`Unexpected char at position ${this.pos + errPos} [E2: ${JSON.stringify(element.charAt(errPos))}]`);\n                error.code = 'ParserError2';\n                error.parserContext = { input: this.input, element, pos: this.pos };\n                throw error;\n            }\n        } else {\n            let error = new Error(`Unexpected end of input at position ${this.pos} [E3]`);\n            error.code = 'ParserError3';\n            error.parserContext = { input: this.input, pos: this.pos };\n            throw error;\n        }\n\n        this.pos += match[0].length;\n        this.remainder = this.remainder.substr(match[0].length);\n\n        return element;\n    }\n\n    async getSpace() {\n        if (!this.remainder.length) {\n            if (this.tag === '+' && this.pos === 1) {\n                // special case, empty + response\n                return;\n            }\n\n            let error = new Error(`Unexpected end of input at position ${this.pos} [E4]`);\n            error.code = 'ParserError4';\n            error.parserContext = { input: this.input, pos: this.pos };\n            throw error;\n        }\n\n        if (imapFormalSyntax.verify(this.remainder.charAt(0), imapFormalSyntax.SP()) >= 0) {\n            let error = new Error(`Unexpected char at position ${this.pos} [E5: ${JSON.stringify(this.remainder.charAt(0))}]`);\n            error.code = 'ParserError5';\n            error.parserContext = { input: this.input, element: this.remainder, pos: this.pos };\n            throw error;\n        }\n\n        this.pos++;\n        this.remainder = this.remainder.substr(1);\n    }\n\n    async getAttributes() {\n        if (!this.remainder.length) {\n            let error = new Error(`Unexpected end of input at position ${this.pos} [E6]`);\n            error.code = 'ParserError6';\n            error.parserContext = { input: this.input, pos: this.pos };\n            throw error;\n        }\n\n        if (this.remainder.match(/^\\s/)) {\n            let error = new Error(`Unexpected whitespace at position ${this.pos} [E7]`);\n            error.code = 'ParserError7';\n            error.parserContext = { input: this.input, element: this.remainder, pos: this.pos };\n            throw error;\n        }\n\n        const tokenParser = new TokenParser(this, this.pos, this.remainder, this.options);\n\n        return await tokenParser.getAttributes();\n    }\n}\n\nmodule.exports.ParserInstance = ParserInstance;\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/handler/parser-instance.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/handler/token-parser.js":
|
|
/*!***********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/handler/token-parser.js ***!
|
|
\***********************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("/* eslint new-cap: 0 */\n\n\n\nconst imapFormalSyntax = __webpack_require__(/*! ./imap-formal-syntax */ \"(action-browser)/./node_modules/imapflow/lib/handler/imap-formal-syntax.js\");\n\nconst STATE_ATOM = 0x001;\nconst STATE_LITERAL = 0x002;\nconst STATE_NORMAL = 0x003;\nconst STATE_PARTIAL = 0x004;\nconst STATE_SEQUENCE = 0x005;\nconst STATE_STRING = 0x006;\nconst STATE_TEXT = 0x007;\n\nconst RE_DIGITS = /^\\d+$/;\nconst RE_SINGLE_DIGIT = /^\\d$/;\n\nclass TokenParser {\n constructor(parent, startPos, str, options) {\n this.str = (str || '').toString();\n this.options = options || {};\n this.parent = parent;\n\n this.tree = this.currentNode = this.createNode();\n this.pos = startPos || 0;\n\n this.currentNode.type = 'TREE';\n\n this.state = STATE_NORMAL;\n }\n\n async getAttributes() {\n await this.processString();\n\n const attributes = [];\n let branch = attributes;\n\n let walk = async node => {\n let curBranch = branch;\n let elm;\n let partial;\n\n if (!node.isClosed && node.type === 'SEQUENCE' && node.value === '*') {\n node.isClosed = true;\n node.type = 'ATOM';\n }\n\n // If the node was never closed, throw it\n if (!node.isClosed) {\n let error = new Error(`Unexpected end of input at position ${this.pos + this.str.length - 1} [E9]`);\n error.code = 'ParserError9';\n error.parserContext = { input: this.str, pos: this.pos + this.str.length - 1 };\n throw error;\n }\n\n let type = (node.type || '').toString().toUpperCase();\n\n switch (type) {\n case 'LITERAL':\n case 'STRING':\n case 'SEQUENCE':\n elm = {\n type: node.type.toUpperCase(),\n value: node.value\n };\n branch.push(elm);\n break;\n\n case 'ATOM':\n if (node.value.toUpperCase() === 'NIL') {\n branch.push(null);\n break;\n }\n elm = {\n type: node.type.toUpperCase(),\n value: node.value\n };\n branch.push(elm);\n break;\n\n case 'SECTION':\n branch = branch[branch.length - 1].section = [];\n break;\n\n case 'LIST':\n elm = [];\n branch.push(elm);\n branch = elm;\n break;\n\n case 'PARTIAL':\n partial = node.value.split('.').map(Number);\n branch[branch.length - 1].partial = partial;\n break;\n }\n\n for (let childNode of node.childNodes) {\n await walk(childNode);\n }\n\n branch = curBranch;\n };\n\n await walk(this.tree);\n\n return attributes;\n }\n\n createNode(parentNode, startPos) {\n let node = {\n childNodes: [],\n type: false,\n value: '',\n isClosed: true\n };\n\n if (parentNode) {\n node.parentNode = parentNode;\n }\n\n if (typeof startPos === 'number') {\n node.startPos = startPos;\n }\n\n if (parentNode) {\n parentNode.childNodes.push(node);\n }\n\n return node;\n }\n\n async processString() {\n let chr, i, len;\n\n const checkSP = () => {\n // jump to the next non whitespace pos\n while (this.str.charAt(i + 1) === ' ') {\n i++;\n }\n };\n\n for (i = 0, len = this.str.length; i < len; i++) {\n chr = this.str.charAt(i);\n\n switch (this.state) {\n case STATE_NORMAL:\n switch (chr) {\n // DQUOTE starts a new string\n case '\"':\n this.currentNode = this.createNode(this.currentNode, this.pos + i);\n this.currentNode.type = 'string';\n this.state = STATE_STRING;\n this.currentNode.isClosed = false;\n break;\n\n // ( starts a new list\n case '(':\n this.currentNode = this.createNode(this.currentNode, this.pos + i);\n this.currentNode.type = 'LIST';\n this.currentNode.isClosed = false;\n break;\n\n // ) closes a list\n case ')':\n if (this.currentNode.type !== 'LIST') {\n let error = new Error(`Unexpected list terminator ) at position ${this.pos + i} [E10]`);\n error.code = 'ParserError10';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n this.currentNode.isClosed = true;\n this.currentNode.endPos = this.pos + i;\n this.currentNode = this.currentNode.parentNode;\n\n checkSP();\n break;\n\n // ] closes section group\n case ']':\n if (this.currentNode.type !== 'SECTION') {\n let error = new Error(`Unexpected section terminator ] at position ${this.pos + i} [E11]`);\n error.code = 'ParserError11';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n this.currentNode.isClosed = true;\n this.currentNode.endPos = this.pos + i;\n this.currentNode = this.currentNode.parentNode;\n\n checkSP();\n break;\n\n // < starts a new partial\n case '<':\n if (this.str.charAt(i - 1) !== ']') {\n this.currentNode = this.createNode(this.currentNode, this.pos + i);\n this.currentNode.type = 'ATOM';\n this.currentNode.value = chr;\n this.state = STATE_ATOM;\n } else {\n this.currentNode = this.createNode(this.currentNode, this.pos + i);\n this.currentNode.type = 'PARTIAL';\n this.state = STATE_PARTIAL;\n this.currentNode.isClosed = false;\n }\n break;\n\n // binary literal8\n case '~': {\n let nextChr = this.str.charAt(i + 1);\n if (nextChr !== '{') {\n if (imapFormalSyntax['ATOM-CHAR']().indexOf(nextChr) >= 0) {\n // treat as ATOM\n this.currentNode = this.createNode(this.currentNode, this.pos + i);\n this.currentNode.type = 'ATOM';\n this.currentNode.value = chr;\n this.state = STATE_ATOM;\n break;\n }\n\n let error = new Error(`Unexpected literal8 marker at position ${this.pos + i} [E12]`);\n error.code = 'ParserError12';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n this.expectedLiteralType = 'literal8';\n break;\n }\n\n // { starts a new literal\n case '{':\n this.currentNode = this.createNode(this.currentNode, this.pos + i);\n this.currentNode.type = 'LITERAL';\n this.currentNode.literalType = this.expectedLiteralType || 'literal';\n this.expectedLiteralType = false;\n this.state = STATE_LITERAL;\n this.currentNode.isClosed = false;\n break;\n\n // * starts a new sequence\n case '*':\n this.currentNode = this.createNode(this.currentNode, this.pos + i);\n this.currentNode.type = 'SEQUENCE';\n this.currentNode.value = chr;\n this.currentNode.isClosed = false;\n this.state = STATE_SEQUENCE;\n break;\n\n // normally a space should never occur\n case ' ':\n // just ignore\n break;\n\n // [ starts section\n case '[':\n // If it is the *first* element after response command, then process as a response argument list\n if (['OK', 'NO', 'BAD', 'BYE', 'PREAUTH'].includes(this.parent.command.toUpperCase()) && this.currentNode === this.tree) {\n this.currentNode.endPos = this.pos + i;\n\n this.currentNode = this.createNode(this.currentNode, this.pos + i);\n this.currentNode.type = 'ATOM';\n\n this.currentNode = this.createNode(this.currentNode, this.pos + i);\n this.currentNode.type = 'SECTION';\n this.currentNode.isClosed = false;\n this.state = STATE_NORMAL;\n\n // RFC2221 defines a response code REFERRAL whose payload is an\n // RFC2192/RFC5092 imapurl that we will try to parse as an ATOM but\n // fail quite badly at parsing. Since the imapurl is such a unique\n // (and crazy) term, we just specialize that case here.\n if (this.str.substr(i + 1, 9).toUpperCase() === 'REFERRAL ') {\n // create the REFERRAL atom\n this.currentNode = this.createNode(this.currentNode, this.pos + i + 1);\n this.currentNode.type = 'ATOM';\n this.currentNode.endPos = this.pos + i + 8;\n this.currentNode.value = 'REFERRAL';\n this.currentNode = this.currentNode.parentNode;\n\n // eat all the way through the ] to be the IMAPURL token.\n this.currentNode = this.createNode(this.currentNode, this.pos + i + 10);\n // just call this an ATOM, even though IMAPURL might be more correct\n this.currentNode.type = 'ATOM';\n // jump i to the ']'\n i = this.str.indexOf(']', i + 10);\n this.currentNode.endPos = this.pos + i - 1;\n this.currentNode.value = this.str.substring(this.currentNode.startPos - this.pos, this.currentNode.endPos - this.pos + 1);\n this.currentNode = this.currentNode.parentNode;\n\n // close out the SECTION\n this.currentNode.isClosed = true;\n this.currentNode = this.currentNode.parentNode;\n\n checkSP();\n }\n\n break;\n }\n\n /* falls through */\n default:\n // Any ATOM supported char starts a new Atom sequence, otherwise throw an error\n // Allow \\ as the first char for atom to support system flags\n // Allow % to support LIST '' %\n // Allow 8bit characters (presumably unicode)\n if (imapFormalSyntax['ATOM-CHAR']().indexOf(chr) < 0 && chr !== '\\\\' && chr !== '%' && chr.charCodeAt(0) < 0x80) {\n let error = new Error(`Unexpected char at position ${this.pos + i} [E13: ${JSON.stringify(chr)}]`);\n error.code = 'ParserError13';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n this.currentNode = this.createNode(this.currentNode, this.pos + i);\n this.currentNode.type = 'ATOM';\n this.currentNode.value = chr;\n this.state = STATE_ATOM;\n break;\n }\n break;\n\n case STATE_ATOM:\n // space finishes an atom\n if (chr === ' ') {\n this.currentNode.endPos = this.pos + i - 1;\n this.currentNode = this.currentNode.parentNode;\n this.state = STATE_NORMAL;\n break;\n }\n\n //\n if (\n this.currentNode.parentNode &&\n ((chr === ')' && this.currentNode.parentNode.type === 'LIST') || (chr === ']' && this.currentNode.parentNode.type === 'SECTION'))\n ) {\n this.currentNode.endPos = this.pos + i - 1;\n this.currentNode = this.currentNode.parentNode;\n\n this.currentNode.isClosed = true;\n this.currentNode.endPos = this.pos + i;\n this.currentNode = this.currentNode.parentNode;\n this.state = STATE_NORMAL;\n checkSP();\n\n break;\n }\n\n if ((chr === ',' || chr === ':') && RE_DIGITS.test(this.currentNode.value)) {\n this.currentNode.type = 'SEQUENCE';\n this.currentNode.isClosed = true;\n this.state = STATE_SEQUENCE;\n }\n\n // [ starts a section group for this element\n if (chr === '[') {\n // allowed only for selected elements\n if (['BODY', 'BODY.PEEK', 'BINARY', 'BINARY.PEEK'].indexOf(this.currentNode.value.toUpperCase()) < 0) {\n if (/[./]/.test(this.currentNode.value)) {\n // could be a path\n this.currentNode.value += chr;\n break;\n } else {\n let error = new Error(`Unexpected section start char [ at position ${this.pos + i} [E14]`);\n error.code = 'ParserError14';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n }\n this.currentNode.endPos = this.pos + i;\n this.currentNode = this.createNode(this.currentNode.parentNode, this.pos + i);\n this.currentNode.type = 'SECTION';\n this.currentNode.isClosed = false;\n this.state = STATE_NORMAL;\n break;\n }\n\n if (chr === '<') {\n let error = new Error(`Unexpected start of partial at position ${this.pos + i} [E15]`);\n error.code = 'ParserError15';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n // if the char is not ATOM compatible, throw. Allow \\* as an exception\n if (\n imapFormalSyntax['ATOM-CHAR']().indexOf(chr) < 0 &&\n chr.charCodeAt(0) < 0x80 && // allow 8bit (presumably unicode) bytes\n chr !== ']' &&\n !(chr === '*' && this.currentNode.value === '\\\\') &&\n (!this.parent || !this.parent.command || !['NO', 'BAD', 'OK'].includes(this.parent.command))\n ) {\n let error = new Error(`Unexpected char at position ${this.pos + i} [E16: ${JSON.stringify(chr)}]`);\n error.code = 'ParserError16';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n } else if (this.currentNode.value === '\\\\*') {\n let error = new Error(`Unexpected char at position ${this.pos + i} [E17: ${JSON.stringify(chr)}]`);\n error.code = 'ParserError17';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n this.currentNode.value += chr;\n break;\n\n case STATE_STRING:\n // DQUOTE ends the string sequence\n if (chr === '\"') {\n this.currentNode.endPos = this.pos + i;\n this.currentNode.isClosed = true;\n this.currentNode = this.currentNode.parentNode;\n this.state = STATE_NORMAL;\n\n checkSP();\n break;\n }\n\n // \\ Escapes the following char\n if (chr === '\\\\') {\n i++;\n if (i >= len) {\n let error = new Error(`Unexpected end of input at position ${this.pos + i} [E18]`);\n error.code = 'ParserError18';\n error.parserContext = { input: this.str, pos: this.pos + i };\n throw error;\n }\n chr = this.str.charAt(i);\n }\n\n this.currentNode.value += chr;\n break;\n\n case STATE_PARTIAL:\n if (chr === '>') {\n if (this.currentNode.value.at(-1) === '.') {\n let error = new Error(`Unexpected end of partial at position ${this.pos + i} [E19]`);\n error.code = 'ParserError19';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n this.currentNode.endPos = this.pos + i;\n this.currentNode.isClosed = true;\n this.currentNode = this.currentNode.parentNode;\n this.state = STATE_NORMAL;\n checkSP();\n break;\n }\n\n if (chr === '.' && (!this.currentNode.value.length || this.currentNode.value.match(/\\./))) {\n let error = new Error(`Unexpected partial separator . at position ${this.pos + i} [E20]`);\n error.code = 'ParserError20';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n if (imapFormalSyntax.DIGIT().indexOf(chr) < 0 && chr !== '.') {\n let error = new Error(`Unexpected char at position ${this.pos + i} [E21: ${JSON.stringify(chr)}]`);\n error.code = 'ParserError21';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n if (this.currentNode.value.match(/^0$|\\.0$/) && chr !== '.') {\n let error = new Error(`Invalid partial at position ${this.pos + i} [E22: ${JSON.stringify(chr)}]`);\n error.code = 'ParserError22';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n this.currentNode.value += chr;\n break;\n\n case STATE_LITERAL:\n if (this.currentNode.started) {\n // only relevant if literals are not already parsed out from input\n\n // Disabled NULL byte check\n // See https://github.com/emailjs/emailjs-imap-handler/commit/f11b2822bedabe492236e8263afc630134a3c41c\n /*\n if (chr === '\\u0000') {\n throw new Error('Unexpected \\\\x00 at position ' + (this.pos + i));\n }\n */\n\n this.currentNode.chBuffer[this.currentNode.chPos++] = chr.charCodeAt(0);\n\n if (this.currentNode.chPos >= this.currentNode.literalLength) {\n this.currentNode.endPos = this.pos + i;\n this.currentNode.isClosed = true;\n this.currentNode.value = this.currentNode.chBuffer.toString('binary');\n this.currentNode.chBuffer = Buffer.alloc(0);\n this.currentNode = this.currentNode.parentNode;\n this.state = STATE_NORMAL;\n checkSP();\n }\n break;\n }\n\n if (chr === '+' && this.options.literalPlus) {\n this.currentNode.literalPlus = true;\n break;\n }\n\n if (chr === '}') {\n if (!('literalLength' in this.currentNode)) {\n let error = new Error(`Unexpected literal prefix end char } at position ${this.pos + i} [E23]`);\n error.code = 'ParserError23';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n if (this.str.charAt(i + 1) === '\\n') {\n i++;\n } else if (this.str.charAt(i + 1) === '\\r' && this.str.charAt(i + 2) === '\\n') {\n i += 2;\n } else {\n let error = new Error(`Unexpected char at position ${this.pos + i} [E24: ${JSON.stringify(chr)}]`);\n error.code = 'ParserError24';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n this.currentNode.literalLength = Number(this.currentNode.literalLength);\n\n if (!this.currentNode.literalLength) {\n // special case where literal content length is 0\n // close the node right away, do not wait for additional input\n this.currentNode.endPos = this.pos + i;\n this.currentNode.isClosed = true;\n this.currentNode = this.currentNode.parentNode;\n this.state = STATE_NORMAL;\n checkSP();\n } else if (this.options.literals) {\n // use the next precached literal values\n this.currentNode.value = this.options.literals.shift();\n\n // only APPEND arguments are kept as Buffers\n /*\n if ((this.parent.command || '').toString().toUpperCase() !== 'APPEND') {\n this.currentNode.value = this.currentNode.value.toString('binary');\n }\n */\n\n this.currentNode.endPos = this.pos + i + this.currentNode.value.length;\n\n this.currentNode.started = false;\n this.currentNode.isClosed = true;\n this.currentNode = this.currentNode.parentNode;\n this.state = STATE_NORMAL;\n checkSP();\n } else {\n this.currentNode.started = true;\n // Allocate expected size buffer. Max size check is already performed\n // Maybe should use allocUnsafe instead?\n this.currentNode.chBuffer = Buffer.alloc(this.currentNode.literalLength);\n this.currentNode.chPos = 0;\n }\n break;\n }\n if (imapFormalSyntax.DIGIT().indexOf(chr) < 0) {\n let error = new Error(`Unexpected char at position ${this.pos + i} [E25: ${JSON.stringify(chr)}]`);\n error.code = 'ParserError25';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n if (this.currentNode.literalLength === '0') {\n let error = new Error(`Invalid literal at position ${this.pos + i} [E26]`);\n error.code = 'ParserError26';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n this.currentNode.literalLength = (this.currentNode.literalLength || '') + chr;\n break;\n\n case STATE_SEQUENCE:\n // space finishes the sequence set\n if (chr === ' ') {\n if (!RE_SINGLE_DIGIT.test(this.currentNode.value.at(-1)) && this.currentNode.value.at(-1) !== '*') {\n let error = new Error(`Unexpected whitespace at position ${this.pos + i} [E27]`);\n error.code = 'ParserError27';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n if (this.currentNode.value !== '*' && this.currentNode.value.at(-1) === '*' && this.currentNode.value.at(-2) !== ':') {\n let error = new Error(`Unexpected whitespace at position ${this.pos + i} [E28]`);\n error.code = 'ParserError28';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n this.currentNode.isClosed = true;\n this.currentNode.endPos = this.pos + i - 1;\n this.currentNode = this.currentNode.parentNode;\n this.state = STATE_NORMAL;\n break;\n } else if (this.currentNode.parentNode && chr === ']' && this.currentNode.parentNode.type === 'SECTION') {\n this.currentNode.endPos = this.pos + i - 1;\n this.currentNode = this.currentNode.parentNode;\n\n this.currentNode.isClosed = true;\n this.currentNode.endPos = this.pos + i;\n this.currentNode = this.currentNode.parentNode;\n this.state = STATE_NORMAL;\n\n checkSP();\n break;\n }\n\n if (chr === ':') {\n if (!RE_SINGLE_DIGIT.test(this.currentNode.value.at(-1)) && this.currentNode.value.at(-1) !== '*') {\n let error = new Error(`Unexpected range separator : at position ${this.pos + i} [E29]`);\n error.code = 'ParserError29';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n } else if (chr === '*') {\n if ([',', ':'].indexOf(this.currentNode.value.at(-1)) < 0) {\n let error = new Error(`Unexpected range wildcard at position ${this.pos + i} [E30]`);\n error.code = 'ParserError30';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n } else if (chr === ',') {\n if (!RE_SINGLE_DIGIT.test(this.currentNode.value.at(-1)) && this.currentNode.value.at(-1) !== '*') {\n let error = new Error(`Unexpected sequence separator , at position ${this.pos + i} [E31]`);\n error.code = 'ParserError31';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n if (this.currentNode.value.at(-1) === '*' && this.currentNode.value.at(-2) !== ':') {\n let error = new Error(`Unexpected sequence separator , at position ${this.pos + i} [E32]`);\n error.code = 'ParserError32';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n } else if (!RE_SINGLE_DIGIT.test(chr)) {\n let error = new Error(`Unexpected char at position ${this.pos + i} [E33: ${JSON.stringify(chr)}]`);\n error.code = 'ParserError33';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n if (RE_SINGLE_DIGIT.test(chr) && this.currentNode.value.at(-1) === '*') {\n let error = new Error(`Unexpected number at position ${this.pos + i} [E34: ${JSON.stringify(chr)}]`);\n error.code = 'ParserError34';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n this.currentNode.value += chr;\n break;\n\n case STATE_TEXT:\n this.currentNode.value += chr;\n break;\n }\n }\n }\n}\n\nmodule.exports.TokenParser = TokenParser;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/imapflow/lib/handler/token-parser.js","mappings":"AAAA;;AAEa;;AAEb,yBAAyB,mBAAO,CAAC,wGAAsB;;AAEvD;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,6EAA6E,gCAAgC;AAC7G;AACA,wCAAwC;AACxC;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA,2CAA2C,SAAS;AACpD;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,kGAAkG,cAAc;AAChH;AACA,wDAAwD;AACxD;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,qGAAqG,cAAc;AACnH;AACA,wDAAwD;AACxD;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B;AAC9B;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,8CAA8C;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,gGAAgG,cAAc;AAC9G;AACA,wDAAwD;AACxD;AACA;AACA;AACA;AACA;;AAEA,6BAA6B;AAC7B,+BAA+B;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qFAAqF,cAAc,QAAQ,oBAAoB;AAC/H;AACA,wDAAwD;AACxD;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B;AAC9B,qGAAqG,cAAc;AACnH;AACA,wDAAwD;AACxD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,yFAAyF,cAAc;AACvG;AACA,gDAAgD;AAChD;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6EAA6E,cAAc,QAAQ,oBAAoB;AACvH;AACA,gDAAgD;AAChD;AACA,sBAAsB;AACtB,6EAA6E,cAAc,QAAQ,oBAAoB;AACvH;AACA,gDAAgD;AAChD;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,yFAAyF,cAAc;AACvG;AACA,oDAAoD;AACpD;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,2FAA2F,cAAc;AACzG;AACA,oDAAoD;AACpD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,4FAA4F,cAAc;AAC1G;AACA,gDAAgD;AAChD;AACA;;AAEA;AACA,6EAA6E,cAAc,QAAQ,oBAAoB;AACvH;AACA,gDAAgD;AAChD;AACA;;AAEA;AACA,6EAA6E,cAAc,QAAQ,oBAAoB;AACvH;AACA,gDAAgD;AAChD;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,kCAAkC;AAClC;AACA,wFAAwF,cAAc,cAAc;AACpH;AACA,oDAAoD;AACpD;AACA;AACA;AACA;AACA,0BAA0B;AAC1B;AACA,0BAA0B;AAC1B,iFAAiF,cAAc,QAAQ,oBAAoB;AAC3H;AACA,oDAAoD;AACpD;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B;AAC1B;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,0BAA0B;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6EAA6E,cAAc,QAAQ,oBAAoB;AACvH;AACA,gDAAgD;AAChD;AACA;AACA;AACA,6EAA6E,cAAc;AAC3F;AACA,gDAAgD;AAChD;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,uFAAuF,cAAc;AACrG;AACA,oDAAoD;AACpD;AACA;;AAEA;AACA,uFAAuF,cAAc;AACrG;AACA,oDAAoD;AACpD;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,8FAA8F,cAAc;AAC5G;AACA,oDAAoD;AACpD;AACA;AACA,sBAAsB;AACtB;AACA,2FAA2F,cAAc;AACzG;AACA,oDAAoD;AACpD;AACA;AACA,sBAAsB;AACtB;AACA,iGAAiG,cAAc;AAC/G;AACA,oDAAoD;AACpD;AACA;AACA;AACA,iGAAiG,cAAc;AAC/G;AACA,oDAAoD;AACpD;AACA;AACA,sBAAsB;AACtB,6EAA6E,cAAc,QAAQ,oBAAoB;AACvH;AACA,gDAAgD;AAChD;AACA;;AAEA;AACA,+EAA+E,cAAc,QAAQ,oBAAoB;AACzH;AACA,gDAAgD;AAChD;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,0BAA0B","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/handler/token-parser.js"],"sourcesContent":["/* eslint new-cap: 0 */\n\n'use strict';\n\nconst imapFormalSyntax = require('./imap-formal-syntax');\n\nconst STATE_ATOM = 0x001;\nconst STATE_LITERAL = 0x002;\nconst STATE_NORMAL = 0x003;\nconst STATE_PARTIAL = 0x004;\nconst STATE_SEQUENCE = 0x005;\nconst STATE_STRING = 0x006;\nconst STATE_TEXT = 0x007;\n\nconst RE_DIGITS = /^\\d+$/;\nconst RE_SINGLE_DIGIT = /^\\d$/;\n\nclass TokenParser {\n    constructor(parent, startPos, str, options) {\n        this.str = (str || '').toString();\n        this.options = options || {};\n        this.parent = parent;\n\n        this.tree = this.currentNode = this.createNode();\n        this.pos = startPos || 0;\n\n        this.currentNode.type = 'TREE';\n\n        this.state = STATE_NORMAL;\n    }\n\n    async getAttributes() {\n        await this.processString();\n\n        const attributes = [];\n        let branch = attributes;\n\n        let walk = async node => {\n            let curBranch = branch;\n            let elm;\n            let partial;\n\n            if (!node.isClosed && node.type === 'SEQUENCE' && node.value === '*') {\n                node.isClosed = true;\n                node.type = 'ATOM';\n            }\n\n            // If the node was never closed, throw it\n            if (!node.isClosed) {\n                let error = new Error(`Unexpected end of input at position ${this.pos + this.str.length - 1} [E9]`);\n                error.code = 'ParserError9';\n                error.parserContext = { input: this.str, pos: this.pos + this.str.length - 1 };\n                throw error;\n            }\n\n            let type = (node.type || '').toString().toUpperCase();\n\n            switch (type) {\n                case 'LITERAL':\n                case 'STRING':\n                case 'SEQUENCE':\n                    elm = {\n                        type: node.type.toUpperCase(),\n                        value: node.value\n                    };\n                    branch.push(elm);\n                    break;\n\n                case 'ATOM':\n                    if (node.value.toUpperCase() === 'NIL') {\n                        branch.push(null);\n                        break;\n                    }\n                    elm = {\n                        type: node.type.toUpperCase(),\n                        value: node.value\n                    };\n                    branch.push(elm);\n                    break;\n\n                case 'SECTION':\n                    branch = branch[branch.length - 1].section = [];\n                    break;\n\n                case 'LIST':\n                    elm = [];\n                    branch.push(elm);\n                    branch = elm;\n                    break;\n\n                case 'PARTIAL':\n                    partial = node.value.split('.').map(Number);\n                    branch[branch.length - 1].partial = partial;\n                    break;\n            }\n\n            for (let childNode of node.childNodes) {\n                await walk(childNode);\n            }\n\n            branch = curBranch;\n        };\n\n        await walk(this.tree);\n\n        return attributes;\n    }\n\n    createNode(parentNode, startPos) {\n        let node = {\n            childNodes: [],\n            type: false,\n            value: '',\n            isClosed: true\n        };\n\n        if (parentNode) {\n            node.parentNode = parentNode;\n        }\n\n        if (typeof startPos === 'number') {\n            node.startPos = startPos;\n        }\n\n        if (parentNode) {\n            parentNode.childNodes.push(node);\n        }\n\n        return node;\n    }\n\n    async processString() {\n        let chr, i, len;\n\n        const checkSP = () => {\n            // jump to the next non whitespace pos\n            while (this.str.charAt(i + 1) === ' ') {\n                i++;\n            }\n        };\n\n        for (i = 0, len = this.str.length; i < len; i++) {\n            chr = this.str.charAt(i);\n\n            switch (this.state) {\n                case STATE_NORMAL:\n                    switch (chr) {\n                        // DQUOTE starts a new string\n                        case '\"':\n                            this.currentNode = this.createNode(this.currentNode, this.pos + i);\n                            this.currentNode.type = 'string';\n                            this.state = STATE_STRING;\n                            this.currentNode.isClosed = false;\n                            break;\n\n                        // ( starts a new list\n                        case '(':\n                            this.currentNode = this.createNode(this.currentNode, this.pos + i);\n                            this.currentNode.type = 'LIST';\n                            this.currentNode.isClosed = false;\n                            break;\n\n                        // ) closes a list\n                        case ')':\n                            if (this.currentNode.type !== 'LIST') {\n                                let error = new Error(`Unexpected list terminator ) at position ${this.pos + i} [E10]`);\n                                error.code = 'ParserError10';\n                                error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                                throw error;\n                            }\n\n                            this.currentNode.isClosed = true;\n                            this.currentNode.endPos = this.pos + i;\n                            this.currentNode = this.currentNode.parentNode;\n\n                            checkSP();\n                            break;\n\n                        // ] closes section group\n                        case ']':\n                            if (this.currentNode.type !== 'SECTION') {\n                                let error = new Error(`Unexpected section terminator ] at position ${this.pos + i} [E11]`);\n                                error.code = 'ParserError11';\n                                error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                                throw error;\n                            }\n                            this.currentNode.isClosed = true;\n                            this.currentNode.endPos = this.pos + i;\n                            this.currentNode = this.currentNode.parentNode;\n\n                            checkSP();\n                            break;\n\n                        // < starts a new partial\n                        case '<':\n                            if (this.str.charAt(i - 1) !== ']') {\n                                this.currentNode = this.createNode(this.currentNode, this.pos + i);\n                                this.currentNode.type = 'ATOM';\n                                this.currentNode.value = chr;\n                                this.state = STATE_ATOM;\n                            } else {\n                                this.currentNode = this.createNode(this.currentNode, this.pos + i);\n                                this.currentNode.type = 'PARTIAL';\n                                this.state = STATE_PARTIAL;\n                                this.currentNode.isClosed = false;\n                            }\n                            break;\n\n                        // binary literal8\n                        case '~': {\n                            let nextChr = this.str.charAt(i + 1);\n                            if (nextChr !== '{') {\n                                if (imapFormalSyntax['ATOM-CHAR']().indexOf(nextChr) >= 0) {\n                                    // treat as ATOM\n                                    this.currentNode = this.createNode(this.currentNode, this.pos + i);\n                                    this.currentNode.type = 'ATOM';\n                                    this.currentNode.value = chr;\n                                    this.state = STATE_ATOM;\n                                    break;\n                                }\n\n                                let error = new Error(`Unexpected literal8 marker at position ${this.pos + i} [E12]`);\n                                error.code = 'ParserError12';\n                                error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                                throw error;\n                            }\n                            this.expectedLiteralType = 'literal8';\n                            break;\n                        }\n\n                        // { starts a new literal\n                        case '{':\n                            this.currentNode = this.createNode(this.currentNode, this.pos + i);\n                            this.currentNode.type = 'LITERAL';\n                            this.currentNode.literalType = this.expectedLiteralType || 'literal';\n                            this.expectedLiteralType = false;\n                            this.state = STATE_LITERAL;\n                            this.currentNode.isClosed = false;\n                            break;\n\n                        // * starts a new sequence\n                        case '*':\n                            this.currentNode = this.createNode(this.currentNode, this.pos + i);\n                            this.currentNode.type = 'SEQUENCE';\n                            this.currentNode.value = chr;\n                            this.currentNode.isClosed = false;\n                            this.state = STATE_SEQUENCE;\n                            break;\n\n                        // normally a space should never occur\n                        case ' ':\n                            // just ignore\n                            break;\n\n                        // [ starts section\n                        case '[':\n                            // If it is the *first* element after response command, then process as a response argument list\n                            if (['OK', 'NO', 'BAD', 'BYE', 'PREAUTH'].includes(this.parent.command.toUpperCase()) && this.currentNode === this.tree) {\n                                this.currentNode.endPos = this.pos + i;\n\n                                this.currentNode = this.createNode(this.currentNode, this.pos + i);\n                                this.currentNode.type = 'ATOM';\n\n                                this.currentNode = this.createNode(this.currentNode, this.pos + i);\n                                this.currentNode.type = 'SECTION';\n                                this.currentNode.isClosed = false;\n                                this.state = STATE_NORMAL;\n\n                                // RFC2221 defines a response code REFERRAL whose payload is an\n                                // RFC2192/RFC5092 imapurl that we will try to parse as an ATOM but\n                                // fail quite badly at parsing.  Since the imapurl is such a unique\n                                // (and crazy) term, we just specialize that case here.\n                                if (this.str.substr(i + 1, 9).toUpperCase() === 'REFERRAL ') {\n                                    // create the REFERRAL atom\n                                    this.currentNode = this.createNode(this.currentNode, this.pos + i + 1);\n                                    this.currentNode.type = 'ATOM';\n                                    this.currentNode.endPos = this.pos + i + 8;\n                                    this.currentNode.value = 'REFERRAL';\n                                    this.currentNode = this.currentNode.parentNode;\n\n                                    // eat all the way through the ] to be the  IMAPURL token.\n                                    this.currentNode = this.createNode(this.currentNode, this.pos + i + 10);\n                                    // just call this an ATOM, even though IMAPURL might be more correct\n                                    this.currentNode.type = 'ATOM';\n                                    // jump i to the ']'\n                                    i = this.str.indexOf(']', i + 10);\n                                    this.currentNode.endPos = this.pos + i - 1;\n                                    this.currentNode.value = this.str.substring(this.currentNode.startPos - this.pos, this.currentNode.endPos - this.pos + 1);\n                                    this.currentNode = this.currentNode.parentNode;\n\n                                    // close out the SECTION\n                                    this.currentNode.isClosed = true;\n                                    this.currentNode = this.currentNode.parentNode;\n\n                                    checkSP();\n                                }\n\n                                break;\n                            }\n\n                        /* falls through */\n                        default:\n                            // Any ATOM supported char starts a new Atom sequence, otherwise throw an error\n                            // Allow \\ as the first char for atom to support system flags\n                            // Allow % to support LIST '' %\n                            // Allow 8bit characters (presumably unicode)\n                            if (imapFormalSyntax['ATOM-CHAR']().indexOf(chr) < 0 && chr !== '\\\\' && chr !== '%' && chr.charCodeAt(0) < 0x80) {\n                                let error = new Error(`Unexpected char at position ${this.pos + i} [E13: ${JSON.stringify(chr)}]`);\n                                error.code = 'ParserError13';\n                                error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                                throw error;\n                            }\n\n                            this.currentNode = this.createNode(this.currentNode, this.pos + i);\n                            this.currentNode.type = 'ATOM';\n                            this.currentNode.value = chr;\n                            this.state = STATE_ATOM;\n                            break;\n                    }\n                    break;\n\n                case STATE_ATOM:\n                    // space finishes an atom\n                    if (chr === ' ') {\n                        this.currentNode.endPos = this.pos + i - 1;\n                        this.currentNode = this.currentNode.parentNode;\n                        this.state = STATE_NORMAL;\n                        break;\n                    }\n\n                    //\n                    if (\n                        this.currentNode.parentNode &&\n                        ((chr === ')' && this.currentNode.parentNode.type === 'LIST') || (chr === ']' && this.currentNode.parentNode.type === 'SECTION'))\n                    ) {\n                        this.currentNode.endPos = this.pos + i - 1;\n                        this.currentNode = this.currentNode.parentNode;\n\n                        this.currentNode.isClosed = true;\n                        this.currentNode.endPos = this.pos + i;\n                        this.currentNode = this.currentNode.parentNode;\n                        this.state = STATE_NORMAL;\n                        checkSP();\n\n                        break;\n                    }\n\n                    if ((chr === ',' || chr === ':') && RE_DIGITS.test(this.currentNode.value)) {\n                        this.currentNode.type = 'SEQUENCE';\n                        this.currentNode.isClosed = true;\n                        this.state = STATE_SEQUENCE;\n                    }\n\n                    // [ starts a section group for this element\n                    if (chr === '[') {\n                        // allowed only for selected elements\n                        if (['BODY', 'BODY.PEEK', 'BINARY', 'BINARY.PEEK'].indexOf(this.currentNode.value.toUpperCase()) < 0) {\n                            if (/[./]/.test(this.currentNode.value)) {\n                                // could be a path\n                                this.currentNode.value += chr;\n                                break;\n                            } else {\n                                let error = new Error(`Unexpected section start char [ at position ${this.pos + i} [E14]`);\n                                error.code = 'ParserError14';\n                                error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                                throw error;\n                            }\n                        }\n                        this.currentNode.endPos = this.pos + i;\n                        this.currentNode = this.createNode(this.currentNode.parentNode, this.pos + i);\n                        this.currentNode.type = 'SECTION';\n                        this.currentNode.isClosed = false;\n                        this.state = STATE_NORMAL;\n                        break;\n                    }\n\n                    if (chr === '<') {\n                        let error = new Error(`Unexpected start of partial at position ${this.pos + i} [E15]`);\n                        error.code = 'ParserError15';\n                        error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                        throw error;\n                    }\n\n                    // if the char is not ATOM compatible, throw. Allow \\* as an exception\n                    if (\n                        imapFormalSyntax['ATOM-CHAR']().indexOf(chr) < 0 &&\n                        chr.charCodeAt(0) < 0x80 && // allow 8bit (presumably unicode) bytes\n                        chr !== ']' &&\n                        !(chr === '*' && this.currentNode.value === '\\\\') &&\n                        (!this.parent || !this.parent.command || !['NO', 'BAD', 'OK'].includes(this.parent.command))\n                    ) {\n                        let error = new Error(`Unexpected char at position ${this.pos + i} [E16: ${JSON.stringify(chr)}]`);\n                        error.code = 'ParserError16';\n                        error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                        throw error;\n                    } else if (this.currentNode.value === '\\\\*') {\n                        let error = new Error(`Unexpected char at position ${this.pos + i} [E17: ${JSON.stringify(chr)}]`);\n                        error.code = 'ParserError17';\n                        error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                        throw error;\n                    }\n\n                    this.currentNode.value += chr;\n                    break;\n\n                case STATE_STRING:\n                    // DQUOTE ends the string sequence\n                    if (chr === '\"') {\n                        this.currentNode.endPos = this.pos + i;\n                        this.currentNode.isClosed = true;\n                        this.currentNode = this.currentNode.parentNode;\n                        this.state = STATE_NORMAL;\n\n                        checkSP();\n                        break;\n                    }\n\n                    // \\ Escapes the following char\n                    if (chr === '\\\\') {\n                        i++;\n                        if (i >= len) {\n                            let error = new Error(`Unexpected end of input at position ${this.pos + i} [E18]`);\n                            error.code = 'ParserError18';\n                            error.parserContext = { input: this.str, pos: this.pos + i };\n                            throw error;\n                        }\n                        chr = this.str.charAt(i);\n                    }\n\n                    this.currentNode.value += chr;\n                    break;\n\n                case STATE_PARTIAL:\n                    if (chr === '>') {\n                        if (this.currentNode.value.at(-1) === '.') {\n                            let error = new Error(`Unexpected end of partial at position ${this.pos + i} [E19]`);\n                            error.code = 'ParserError19';\n                            error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                            throw error;\n                        }\n                        this.currentNode.endPos = this.pos + i;\n                        this.currentNode.isClosed = true;\n                        this.currentNode = this.currentNode.parentNode;\n                        this.state = STATE_NORMAL;\n                        checkSP();\n                        break;\n                    }\n\n                    if (chr === '.' && (!this.currentNode.value.length || this.currentNode.value.match(/\\./))) {\n                        let error = new Error(`Unexpected partial separator . at position ${this.pos + i} [E20]`);\n                        error.code = 'ParserError20';\n                        error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                        throw error;\n                    }\n\n                    if (imapFormalSyntax.DIGIT().indexOf(chr) < 0 && chr !== '.') {\n                        let error = new Error(`Unexpected char at position ${this.pos + i} [E21: ${JSON.stringify(chr)}]`);\n                        error.code = 'ParserError21';\n                        error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                        throw error;\n                    }\n\n                    if (this.currentNode.value.match(/^0$|\\.0$/) && chr !== '.') {\n                        let error = new Error(`Invalid partial at position ${this.pos + i} [E22: ${JSON.stringify(chr)}]`);\n                        error.code = 'ParserError22';\n                        error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                        throw error;\n                    }\n\n                    this.currentNode.value += chr;\n                    break;\n\n                case STATE_LITERAL:\n                    if (this.currentNode.started) {\n                        // only relevant if literals are not already parsed out from input\n\n                        // Disabled NULL byte check\n                        // See https://github.com/emailjs/emailjs-imap-handler/commit/f11b2822bedabe492236e8263afc630134a3c41c\n                        /*\n                        if (chr === '\\u0000') {\n                            throw new Error('Unexpected \\\\x00 at position ' + (this.pos + i));\n                        }\n                        */\n\n                        this.currentNode.chBuffer[this.currentNode.chPos++] = chr.charCodeAt(0);\n\n                        if (this.currentNode.chPos >= this.currentNode.literalLength) {\n                            this.currentNode.endPos = this.pos + i;\n                            this.currentNode.isClosed = true;\n                            this.currentNode.value = this.currentNode.chBuffer.toString('binary');\n                            this.currentNode.chBuffer = Buffer.alloc(0);\n                            this.currentNode = this.currentNode.parentNode;\n                            this.state = STATE_NORMAL;\n                            checkSP();\n                        }\n                        break;\n                    }\n\n                    if (chr === '+' && this.options.literalPlus) {\n                        this.currentNode.literalPlus = true;\n                        break;\n                    }\n\n                    if (chr === '}') {\n                        if (!('literalLength' in this.currentNode)) {\n                            let error = new Error(`Unexpected literal prefix end char } at position ${this.pos + i} [E23]`);\n                            error.code = 'ParserError23';\n                            error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                            throw error;\n                        }\n                        if (this.str.charAt(i + 1) === '\\n') {\n                            i++;\n                        } else if (this.str.charAt(i + 1) === '\\r' && this.str.charAt(i + 2) === '\\n') {\n                            i += 2;\n                        } else {\n                            let error = new Error(`Unexpected char at position ${this.pos + i} [E24: ${JSON.stringify(chr)}]`);\n                            error.code = 'ParserError24';\n                            error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                            throw error;\n                        }\n\n                        this.currentNode.literalLength = Number(this.currentNode.literalLength);\n\n                        if (!this.currentNode.literalLength) {\n                            // special case where literal content length is 0\n                            // close the node right away, do not wait for additional input\n                            this.currentNode.endPos = this.pos + i;\n                            this.currentNode.isClosed = true;\n                            this.currentNode = this.currentNode.parentNode;\n                            this.state = STATE_NORMAL;\n                            checkSP();\n                        } else if (this.options.literals) {\n                            // use the next precached literal values\n                            this.currentNode.value = this.options.literals.shift();\n\n                            // only APPEND arguments are kept as Buffers\n                            /*\n                            if ((this.parent.command || '').toString().toUpperCase() !== 'APPEND') {\n                                this.currentNode.value = this.currentNode.value.toString('binary');\n                            }\n                            */\n\n                            this.currentNode.endPos = this.pos + i + this.currentNode.value.length;\n\n                            this.currentNode.started = false;\n                            this.currentNode.isClosed = true;\n                            this.currentNode = this.currentNode.parentNode;\n                            this.state = STATE_NORMAL;\n                            checkSP();\n                        } else {\n                            this.currentNode.started = true;\n                            // Allocate expected size buffer. Max size check is already performed\n                            // Maybe should use allocUnsafe instead?\n                            this.currentNode.chBuffer = Buffer.alloc(this.currentNode.literalLength);\n                            this.currentNode.chPos = 0;\n                        }\n                        break;\n                    }\n                    if (imapFormalSyntax.DIGIT().indexOf(chr) < 0) {\n                        let error = new Error(`Unexpected char at position ${this.pos + i} [E25: ${JSON.stringify(chr)}]`);\n                        error.code = 'ParserError25';\n                        error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                        throw error;\n                    }\n                    if (this.currentNode.literalLength === '0') {\n                        let error = new Error(`Invalid literal at position ${this.pos + i} [E26]`);\n                        error.code = 'ParserError26';\n                        error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                        throw error;\n                    }\n                    this.currentNode.literalLength = (this.currentNode.literalLength || '') + chr;\n                    break;\n\n                case STATE_SEQUENCE:\n                    // space finishes the sequence set\n                    if (chr === ' ') {\n                        if (!RE_SINGLE_DIGIT.test(this.currentNode.value.at(-1)) && this.currentNode.value.at(-1) !== '*') {\n                            let error = new Error(`Unexpected whitespace at position ${this.pos + i} [E27]`);\n                            error.code = 'ParserError27';\n                            error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                            throw error;\n                        }\n\n                        if (this.currentNode.value !== '*' && this.currentNode.value.at(-1) === '*' && this.currentNode.value.at(-2) !== ':') {\n                            let error = new Error(`Unexpected whitespace at position ${this.pos + i} [E28]`);\n                            error.code = 'ParserError28';\n                            error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                            throw error;\n                        }\n\n                        this.currentNode.isClosed = true;\n                        this.currentNode.endPos = this.pos + i - 1;\n                        this.currentNode = this.currentNode.parentNode;\n                        this.state = STATE_NORMAL;\n                        break;\n                    } else if (this.currentNode.parentNode && chr === ']' && this.currentNode.parentNode.type === 'SECTION') {\n                        this.currentNode.endPos = this.pos + i - 1;\n                        this.currentNode = this.currentNode.parentNode;\n\n                        this.currentNode.isClosed = true;\n                        this.currentNode.endPos = this.pos + i;\n                        this.currentNode = this.currentNode.parentNode;\n                        this.state = STATE_NORMAL;\n\n                        checkSP();\n                        break;\n                    }\n\n                    if (chr === ':') {\n                        if (!RE_SINGLE_DIGIT.test(this.currentNode.value.at(-1)) && this.currentNode.value.at(-1) !== '*') {\n                            let error = new Error(`Unexpected range separator : at position ${this.pos + i} [E29]`);\n                            error.code = 'ParserError29';\n                            error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                            throw error;\n                        }\n                    } else if (chr === '*') {\n                        if ([',', ':'].indexOf(this.currentNode.value.at(-1)) < 0) {\n                            let error = new Error(`Unexpected range wildcard at position ${this.pos + i} [E30]`);\n                            error.code = 'ParserError30';\n                            error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                            throw error;\n                        }\n                    } else if (chr === ',') {\n                        if (!RE_SINGLE_DIGIT.test(this.currentNode.value.at(-1)) && this.currentNode.value.at(-1) !== '*') {\n                            let error = new Error(`Unexpected sequence separator , at position ${this.pos + i} [E31]`);\n                            error.code = 'ParserError31';\n                            error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                            throw error;\n                        }\n                        if (this.currentNode.value.at(-1) === '*' && this.currentNode.value.at(-2) !== ':') {\n                            let error = new Error(`Unexpected sequence separator , at position ${this.pos + i} [E32]`);\n                            error.code = 'ParserError32';\n                            error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                            throw error;\n                        }\n                    } else if (!RE_SINGLE_DIGIT.test(chr)) {\n                        let error = new Error(`Unexpected char at position ${this.pos + i} [E33: ${JSON.stringify(chr)}]`);\n                        error.code = 'ParserError33';\n                        error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                        throw error;\n                    }\n\n                    if (RE_SINGLE_DIGIT.test(chr) && this.currentNode.value.at(-1) === '*') {\n                        let error = new Error(`Unexpected number at position ${this.pos + i} [E34: ${JSON.stringify(chr)}]`);\n                        error.code = 'ParserError34';\n                        error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                        throw error;\n                    }\n\n                    this.currentNode.value += chr;\n                    break;\n\n                case STATE_TEXT:\n                    this.currentNode.value += chr;\n                    break;\n            }\n        }\n    }\n}\n\nmodule.exports.TokenParser = TokenParser;\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/handler/token-parser.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/imap-commands.js":
|
|
/*!****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/imap-commands.js ***!
|
|
\****************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("/* eslint global-require:0 */\n\n\n\nmodule.exports = new Map([\n ['ID', __webpack_require__(/*! ./commands/id.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/id.js\")],\n ['CAPABILITY', __webpack_require__(/*! ./commands/capability.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/capability.js\")],\n ['NAMESPACE', __webpack_require__(/*! ./commands/namespace.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/namespace.js\")],\n ['LOGIN', __webpack_require__(/*! ./commands/login.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/login.js\")],\n ['LOGOUT', __webpack_require__(/*! ./commands/logout.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/logout.js\")],\n ['STARTTLS', __webpack_require__(/*! ./commands/starttls.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/starttls.js\")],\n ['LIST', __webpack_require__(/*! ./commands/list.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/list.js\")],\n ['ENABLE', __webpack_require__(/*! ./commands/enable.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/enable.js\")],\n ['SELECT', __webpack_require__(/*! ./commands/select.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/select.js\")],\n ['FETCH', __webpack_require__(/*! ./commands/fetch.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/fetch.js\")],\n ['CREATE', __webpack_require__(/*! ./commands/create.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/create.js\")],\n ['DELETE', __webpack_require__(/*! ./commands/delete.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/delete.js\")],\n ['RENAME', __webpack_require__(/*! ./commands/rename.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/rename.js\")],\n ['CLOSE', __webpack_require__(/*! ./commands/close.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/close.js\")],\n ['SUBSCRIBE', __webpack_require__(/*! ./commands/subscribe.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/subscribe.js\")],\n ['UNSUBSCRIBE', __webpack_require__(/*! ./commands/unsubscribe.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/unsubscribe.js\")],\n ['STORE', __webpack_require__(/*! ./commands/store.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/store.js\")],\n ['SEARCH', __webpack_require__(/*! ./commands/search.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/search.js\")],\n ['NOOP', __webpack_require__(/*! ./commands/noop.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/noop.js\")],\n ['EXPUNGE', __webpack_require__(/*! ./commands/expunge.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/expunge.js\")],\n ['APPEND', __webpack_require__(/*! ./commands/append.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/append.js\")],\n ['STATUS', __webpack_require__(/*! ./commands/status.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/status.js\")],\n ['COPY', __webpack_require__(/*! ./commands/copy.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/copy.js\")],\n ['MOVE', __webpack_require__(/*! ./commands/move.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/move.js\")],\n ['COMPRESS', __webpack_require__(/*! ./commands/compress.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/compress.js\")],\n ['QUOTA', __webpack_require__(/*! ./commands/quota.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/quota.js\")],\n ['IDLE', __webpack_require__(/*! ./commands/idle.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/idle.js\")],\n ['AUTHENTICATE', __webpack_require__(/*! ./commands/authenticate.js */ \"(action-browser)/./node_modules/imapflow/lib/commands/authenticate.js\")]\n]);\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvaW1hcC1jb21tYW5kcy5qcyIsIm1hcHBpbmdzIjoiQUFBQTs7QUFFYTs7QUFFYjtBQUNBLFdBQVcsbUJBQU8sQ0FBQyxxRkFBa0I7QUFDckMsbUJBQW1CLG1CQUFPLENBQUMscUdBQTBCO0FBQ3JELGtCQUFrQixtQkFBTyxDQUFDLG1HQUF5QjtBQUNuRCxjQUFjLG1CQUFPLENBQUMsMkZBQXFCO0FBQzNDLGVBQWUsbUJBQU8sQ0FBQyw2RkFBc0I7QUFDN0MsaUJBQWlCLG1CQUFPLENBQUMsaUdBQXdCO0FBQ2pELGFBQWEsbUJBQU8sQ0FBQyx5RkFBb0I7QUFDekMsZUFBZSxtQkFBTyxDQUFDLDZGQUFzQjtBQUM3QyxlQUFlLG1CQUFPLENBQUMsNkZBQXNCO0FBQzdDLGNBQWMsbUJBQU8sQ0FBQywyRkFBcUI7QUFDM0MsZUFBZSxtQkFBTyxDQUFDLDZGQUFzQjtBQUM3QyxlQUFlLG1CQUFPLENBQUMsNkZBQXNCO0FBQzdDLGVBQWUsbUJBQU8sQ0FBQyw2RkFBc0I7QUFDN0MsY0FBYyxtQkFBTyxDQUFDLDJGQUFxQjtBQUMzQyxrQkFBa0IsbUJBQU8sQ0FBQyxtR0FBeUI7QUFDbkQsb0JBQW9CLG1CQUFPLENBQUMsdUdBQTJCO0FBQ3ZELGNBQWMsbUJBQU8sQ0FBQywyRkFBcUI7QUFDM0MsZUFBZSxtQkFBTyxDQUFDLDZGQUFzQjtBQUM3QyxhQUFhLG1CQUFPLENBQUMseUZBQW9CO0FBQ3pDLGdCQUFnQixtQkFBTyxDQUFDLCtGQUF1QjtBQUMvQyxlQUFlLG1CQUFPLENBQUMsNkZBQXNCO0FBQzdDLGVBQWUsbUJBQU8sQ0FBQyw2RkFBc0I7QUFDN0MsYUFBYSxtQkFBTyxDQUFDLHlGQUFvQjtBQUN6QyxhQUFhLG1CQUFPLENBQUMseUZBQW9CO0FBQ3pDLGlCQUFpQixtQkFBTyxDQUFDLGlHQUF3QjtBQUNqRCxjQUFjLG1CQUFPLENBQUMsMkZBQXFCO0FBQzNDLGFBQWEsbUJBQU8sQ0FBQyx5RkFBb0I7QUFDekMscUJBQXFCLG1CQUFPLENBQUMseUdBQTRCO0FBQ3pEIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvaW1hcC1jb21tYW5kcy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQgZ2xvYmFsLXJlcXVpcmU6MCAqL1xuXG4ndXNlIHN0cmljdCc7XG5cbm1vZHVsZS5leHBvcnRzID0gbmV3IE1hcChbXG4gICAgWydJRCcsIHJlcXVpcmUoJy4vY29tbWFuZHMvaWQuanMnKV0sXG4gICAgWydDQVBBQklMSVRZJywgcmVxdWlyZSgnLi9jb21tYW5kcy9jYXBhYmlsaXR5LmpzJyldLFxuICAgIFsnTkFNRVNQQUNFJywgcmVxdWlyZSgnLi9jb21tYW5kcy9uYW1lc3BhY2UuanMnKV0sXG4gICAgWydMT0dJTicsIHJlcXVpcmUoJy4vY29tbWFuZHMvbG9naW4uanMnKV0sXG4gICAgWydMT0dPVVQnLCByZXF1aXJlKCcuL2NvbW1hbmRzL2xvZ291dC5qcycpXSxcbiAgICBbJ1NUQVJUVExTJywgcmVxdWlyZSgnLi9jb21tYW5kcy9zdGFydHRscy5qcycpXSxcbiAgICBbJ0xJU1QnLCByZXF1aXJlKCcuL2NvbW1hbmRzL2xpc3QuanMnKV0sXG4gICAgWydFTkFCTEUnLCByZXF1aXJlKCcuL2NvbW1hbmRzL2VuYWJsZS5qcycpXSxcbiAgICBbJ1NFTEVDVCcsIHJlcXVpcmUoJy4vY29tbWFuZHMvc2VsZWN0LmpzJyldLFxuICAgIFsnRkVUQ0gnLCByZXF1aXJlKCcuL2NvbW1hbmRzL2ZldGNoLmpzJyldLFxuICAgIFsnQ1JFQVRFJywgcmVxdWlyZSgnLi9jb21tYW5kcy9jcmVhdGUuanMnKV0sXG4gICAgWydERUxFVEUnLCByZXF1aXJlKCcuL2NvbW1hbmRzL2RlbGV0ZS5qcycpXSxcbiAgICBbJ1JFTkFNRScsIHJlcXVpcmUoJy4vY29tbWFuZHMvcmVuYW1lLmpzJyldLFxuICAgIFsnQ0xPU0UnLCByZXF1aXJlKCcuL2NvbW1hbmRzL2Nsb3NlLmpzJyldLFxuICAgIFsnU1VCU0NSSUJFJywgcmVxdWlyZSgnLi9jb21tYW5kcy9zdWJzY3JpYmUuanMnKV0sXG4gICAgWydVTlNVQlNDUklCRScsIHJlcXVpcmUoJy4vY29tbWFuZHMvdW5zdWJzY3JpYmUuanMnKV0sXG4gICAgWydTVE9SRScsIHJlcXVpcmUoJy4vY29tbWFuZHMvc3RvcmUuanMnKV0sXG4gICAgWydTRUFSQ0gnLCByZXF1aXJlKCcuL2NvbW1hbmRzL3NlYXJjaC5qcycpXSxcbiAgICBbJ05PT1AnLCByZXF1aXJlKCcuL2NvbW1hbmRzL25vb3AuanMnKV0sXG4gICAgWydFWFBVTkdFJywgcmVxdWlyZSgnLi9jb21tYW5kcy9leHB1bmdlLmpzJyldLFxuICAgIFsnQVBQRU5EJywgcmVxdWlyZSgnLi9jb21tYW5kcy9hcHBlbmQuanMnKV0sXG4gICAgWydTVEFUVVMnLCByZXF1aXJlKCcuL2NvbW1hbmRzL3N0YXR1cy5qcycpXSxcbiAgICBbJ0NPUFknLCByZXF1aXJlKCcuL2NvbW1hbmRzL2NvcHkuanMnKV0sXG4gICAgWydNT1ZFJywgcmVxdWlyZSgnLi9jb21tYW5kcy9tb3ZlLmpzJyldLFxuICAgIFsnQ09NUFJFU1MnLCByZXF1aXJlKCcuL2NvbW1hbmRzL2NvbXByZXNzLmpzJyldLFxuICAgIFsnUVVPVEEnLCByZXF1aXJlKCcuL2NvbW1hbmRzL3F1b3RhLmpzJyldLFxuICAgIFsnSURMRScsIHJlcXVpcmUoJy4vY29tbWFuZHMvaWRsZS5qcycpXSxcbiAgICBbJ0FVVEhFTlRJQ0FURScsIHJlcXVpcmUoJy4vY29tbWFuZHMvYXV0aGVudGljYXRlLmpzJyldXG5dKTtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/imap-commands.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/imap-flow.js":
|
|
/*!************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/imap-flow.js ***!
|
|
\************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\n/**\n * @module imapflow\n */\n\n// TODO:\n// * Use buffers for compiled commands\n// * OAuth2 authentication\n\nconst tls = __webpack_require__(/*! tls */ \"tls\");\nconst net = __webpack_require__(/*! net */ \"net\");\nconst crypto = __webpack_require__(/*! crypto */ \"crypto\");\nconst { EventEmitter } = __webpack_require__(/*! events */ \"events\");\nconst logger = __webpack_require__(/*! ./logger */ \"(action-browser)/./node_modules/imapflow/lib/logger.js\");\nconst libmime = __webpack_require__(/*! libmime */ \"(action-browser)/./node_modules/libmime/lib/libmime.js\");\nconst zlib = __webpack_require__(/*! zlib */ \"zlib\");\nconst { Headers } = __webpack_require__(/*! mailsplit */ \"(action-browser)/./node_modules/imapflow/node_modules/mailsplit/index.js\");\nconst { LimitedPassthrough } = __webpack_require__(/*! ./limited-passthrough */ \"(action-browser)/./node_modules/imapflow/lib/limited-passthrough.js\");\n\nconst { ImapStream } = __webpack_require__(/*! ./handler/imap-stream */ \"(action-browser)/./node_modules/imapflow/lib/handler/imap-stream.js\");\nconst { parser, compiler } = __webpack_require__(/*! ./handler/imap-handler */ \"(action-browser)/./node_modules/imapflow/lib/handler/imap-handler.js\");\nconst packageInfo = __webpack_require__(/*! ../package.json */ \"(action-browser)/./node_modules/imapflow/package.json\");\n\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 FlowedDecoder = __webpack_require__(/*! mailsplit/lib/flowed-decoder */ \"(action-browser)/./node_modules/imapflow/node_modules/mailsplit/lib/flowed-decoder.js\");\nconst { PassThrough } = __webpack_require__(/*! stream */ \"stream\");\n\nconst { proxyConnection } = __webpack_require__(/*! ./proxy-connection */ \"(action-browser)/./node_modules/imapflow/lib/proxy-connection.js\");\n\nconst {\n comparePaths,\n updateCapabilities,\n getFolderTree,\n formatMessageResponse,\n getDecoder,\n packMessageRange,\n normalizePath,\n expandRange,\n AuthenticationFailure,\n getColorFlags\n} = __webpack_require__(/*! ./tools */ \"(action-browser)/./node_modules/imapflow/lib/tools.js\");\n\nconst imapCommands = __webpack_require__(/*! ./imap-commands.js */ \"(action-browser)/./node_modules/imapflow/lib/imap-commands.js\");\n\nconst CONNECT_TIMEOUT = 90 * 1000;\nconst GREETING_TIMEOUT = 16 * 1000;\nconst UPGRADE_TIMEOUT = 10 * 1000;\n\nconst SOCKET_TIMEOUT = 5 * 60 * 1000;\n\nconst states = {\n NOT_AUTHENTICATED: 0x01,\n AUTHENTICATED: 0x02,\n SELECTED: 0x03,\n LOGOUT: 0x04\n};\n\n/**\n * @typedef {Object} MailboxObject\n * @global\n * @property {String} path mailbox path\n * @property {String} delimiter mailbox path delimiter, usually \".\" or \"/\"\n * @property {Set<string>} flags list of flags for this mailbox\n * @property {String} [specialUse] one of special-use flags (if applicable): \"\\All\", \"\\Archive\", \"\\Drafts\", \"\\Flagged\", \"\\Junk\", \"\\Sent\", \"\\Trash\". Additionally INBOX has non-standard \"\\Inbox\" flag set\n * @property {Boolean} listed `true` if mailbox was found from the output of LIST command\n * @property {Boolean} subscribed `true` if mailbox was found from the output of LSUB command\n * @property {Set<string>} permanentFlags A Set of flags available to use in this mailbox. If it is not set or includes special flag \"\\\\\\*\" then any flag can be used.\n * @property {String} [mailboxId] unique mailbox ID if server has `OBJECTID` extension enabled\n * @property {BigInt} [highestModseq] latest known modseq value if server has CONDSTORE or XYMHIGHESTMODSEQ enabled\n * @property {String} [noModseq] if true then the server doesn't support the persistent storage of mod-sequences for the mailbox\n * @property {BigInt} uidValidity Mailbox `UIDVALIDITY` value\n * @property {Number} uidNext Next predicted UID\n * @property {Number} exists Messages in this folder\n */\n\n/**\n * @typedef {Object} MailboxLockObject\n * @global\n * @property {String} path mailbox path\n * @property {Function} release Release current lock\n * @example\n * let lock = await client.getMailboxLock('INBOX');\n * try {\n * // do something in the mailbox\n * } finally {\n * // use finally{} to make sure lock is released even if exception occurs\n * lock.release();\n * }\n */\n\n/**\n * Client and server identification object, where key is one of RFC2971 defined [data fields](https://tools.ietf.org/html/rfc2971#section-3.3) (but not limited to).\n * @typedef {Object} IdInfoObject\n * @global\n * @property {String} [name] Name of the program\n * @property {String} [version] Version number of the program\n * @property {String} [os] Name of the operating system\n * @property {String} [vendor] Vendor of the client/server\n * @property {String} ['support-url'] URL to contact for support\n * @property {Date} [date] Date program was released\n */\n\n/**\n * IMAP client class for accessing IMAP mailboxes\n *\n * @class\n * @extends EventEmitter\n */\nclass ImapFlow extends EventEmitter {\n /**\n * Current module version as a static class property\n * @property {String} version Module version\n * @static\n */\n static version = packageInfo.version;\n\n /**\n * IMAP connection options\n *\n * @property {String} host\n * Hostname of the IMAP server.\n *\n * @property {Number} port\n * Port number for the IMAP server.\n *\n * @property {Boolean} [secure=false]\n * If `true`, establishes the connection directly over TLS (commonly on port 993).\n * If `false`, a plain (unencrypted) connection is used first and, if possible, the connection is upgraded to STARTTLS.\n *\n * @property {Boolean} [doSTARTTLS=undefined]\n * Determines whether to upgrade the connection to TLS via STARTTLS:\n * - **true**: Start unencrypted and upgrade to TLS using STARTTLS before authentication.\n * The connection fails if the server does not support STARTTLS or the upgrade fails.\n * Note that `secure=true` combined with `doSTARTTLS=true` is invalid.\n * - **false**: Never use STARTTLS, even if the server advertises support.\n * This is useful if the server has a broken TLS setup.\n * Combined with `secure=false`, this results in a fully unencrypted connection.\n * Make sure you warn users about the security risks.\n * - **undefined** (default): If `secure=false` (default), attempt to upgrade to TLS via STARTTLS before authentication if the server supports it. If not supported, continue unencrypted. This may expose the connection to a downgrade attack.\n *\n * @property {String} [servername]\n * Server name for SNI or when using an IP address as `host`.\n *\n * @property {Boolean} [disableCompression=false]\n * If `true`, the client does not attempt to use the COMPRESS=DEFLATE extension.\n *\n * @property {Object} auth\n * Authentication options. Authentication occurs automatically during {@link connect}.\n *\n * @property {String} auth.user\n * Username for authentication.\n *\n * @property {String} [auth.pass]\n * Password for regular authentication.\n *\n * @property {String} [auth.accessToken]\n * OAuth2 access token, if using OAuth2 authentication.\n *\n * @property {String} [auth.loginMethod]\n * Optional login method for password-based authentication (e.g., \"LOGIN\", \"AUTH=LOGIN\", or \"AUTH=PLAIN\").\n * If not set, ImapFlow chooses based on available mechanisms.\n *\n * @property {IdInfoObject} [clientInfo]\n * Client identification info sent to the server (via the ID command).\n *\n * @property {Boolean} [disableAutoIdle=false]\n * If `true`, do not start IDLE automatically. Useful when only specific operations are needed.\n *\n * @property {Object} [tls]\n * Additional TLS options. For details, see [Node.js TLS connect](https://nodejs.org/api/tls.html#tls_tls_connect_options_callback).\n *\n * @property {Boolean} [tls.rejectUnauthorized=true]\n * If `false`, allows self-signed or expired certificates.\n *\n * @property {String} [tls.minVersion='TLSv1.2']\n * Minimum accepted TLS version (e.g., `'TLSv1.2'`).\n *\n * @property {Number} [tls.minDHSize=1024]\n * Minimum size (in bits) of the DH parameter for TLS connections.\n *\n * @property {Object|Boolean} [logger]\n * Custom logger instance with `debug(obj)`, `info(obj)`, `warn(obj)`, and `error(obj)` methods.\n * If `false`, logging is disabled. If not provided, ImapFlow logs to console in [pino format](https://getpino.io/).\n *\n * @property {Boolean} [logRaw=false]\n * If `true`, logs all raw data (read and written) in base64 encoding. You can pipe such logs to [eerawlog](https://github.com/postalsys/eerawlog) command for readable output.\n *\n * @property {Boolean} [emitLogs=false]\n * If `true`, emits `'log'` events with the same data passed to the logger.\n *\n * @property {Boolean} [verifyOnly=false]\n * If `true`, disconnects after successful authentication without performing other actions.\n *\n * @property {String} [proxy]\n * Proxy URL. Supports HTTP CONNECT (`http://`, `https://`) and SOCKS (`socks://`, `socks4://`, `socks5://`).\n *\n * @property {Boolean} [qresync=false]\n * If `true`, enables QRESYNC support so that EXPUNGE notifications include `uid` instead of `seq`.\n *\n * @property {Number} [maxIdleTime]\n * If set, breaks and restarts IDLE every `maxIdleTime` milliseconds.\n *\n * @property {String} [missingIdleCommand=\"NOOP\"]\n * Command to use if the server does not support IDLE.\n *\n * @property {Boolean} [disableBinary=false]\n * If `true`, ignores the BINARY extension for FETCH and APPEND operations.\n *\n * @property {Boolean} [disableAutoEnable=false]\n * If `true`, do not automatically enable supported IMAP extensions.\n *\n * @property {Number} [connectionTimeout=90000]\n * Maximum time (in milliseconds) to wait for the connection to establish. Defaults to 90 seconds.\n *\n * @property {Number} [greetingTimeout=16000]\n * Maximum time (in milliseconds) to wait for the server greeting after a connection is established. Defaults to 16 seconds.\n *\n * @property {Number} [socketTimeout=300000]\n * Maximum period of inactivity (in milliseconds) before terminating the connection. Defaults to 5 minutes.\n */\n\n constructor(options) {\n super({ captureRejections: true });\n\n this.options = options || {};\n\n /**\n * Instance ID for logs\n * @type {String}\n */\n this.id = this.options.id || this.getRandomId();\n\n this.clientInfo = Object.assign(\n {\n name: packageInfo.name,\n version: packageInfo.version,\n vendor: 'Postal Systems',\n 'support-url': 'https://github.com/postalsys/imapflow/issues'\n },\n this.options.clientInfo || {}\n );\n\n /**\n * Server identification info. Available after successful `connect()`.\n * If server does not provide identification info then this value is `null`.\n * @example\n * await client.connect();\n * console.log(client.serverInfo.vendor);\n * @type {IdInfoObject|null}\n */\n this.serverInfo = null; //updated by ID\n\n this.log = this.getLogger();\n\n /**\n * Is the connection currently encrypted or not\n * @type {Boolean}\n */\n this.secureConnection = !!this.options.secure;\n\n this.port = Number(this.options.port) || (this.secureConnection ? 993 : 110);\n this.host = this.options.host || 'localhost';\n this.servername = this.options.servername ? this.options.servername : !net.isIP(this.host) ? this.host : false;\n\n if (typeof this.options.secure === 'undefined' && this.port === 993) {\n // if secure option is not set but port is 465, then default to secure\n this.secureConnection = true;\n }\n\n this.logRaw = this.options.logRaw;\n this.streamer = new ImapStream({\n logger: this.log,\n cid: this.id,\n logRaw: this.logRaw,\n secureConnection: this.secureConnection\n });\n\n this.reading = false;\n this.socket = false;\n this.writeSocket = false;\n\n this.states = states;\n this.state = this.states.NOT_AUTHENTICATED;\n\n this.lockCounter = 0;\n this.currentLock = false;\n\n this.tagCounter = 0;\n this.requestTagMap = new Map();\n this.requestQueue = [];\n this.currentRequest = false;\n\n this.writeBytesCounter = 0;\n\n this.commandParts = [];\n\n /**\n * Active IMAP capabilities. Value is either `true` for togglabe capabilities (eg. `UIDPLUS`)\n * or a number for capabilities with a value (eg. `APPENDLIMIT`)\n * @type {Map<string, boolean|number>}\n */\n this.capabilities = new Map();\n this.authCapabilities = new Map();\n\n this.rawCapabilities = null;\n\n this.expectCapabilityUpdate = false; // force CAPABILITY after LOGIN\n\n /**\n * Enabled capabilities. Usually `CONDSTORE` and `UTF8=ACCEPT` if server supports these.\n * @type {Set<string>}\n */\n this.enabled = new Set();\n\n /**\n * Is the connection currently usable or not\n * @type {Boolean}\n */\n this.usable = false;\n\n /**\n * Currently authenticated user or `false` if mailbox is not open\n * or `true` if connection was authenticated by PREAUTH\n * @type {String|Boolean}\n */\n this.authenticated = false;\n\n /**\n * Currently selected mailbox or `false` if mailbox is not open\n * @type {MailboxObject|Boolean}\n */\n this.mailbox = false;\n this.currentSelectCommand = false;\n\n /**\n * Is current mailbox idling (`true`) or not (`false`)\n * @type {Boolean}\n */\n this.idling = false;\n\n this.emitLogs = !!this.options.emitLogs;\n // ordering number for emitted logs\n this.lo = 0;\n\n this.untaggedHandlers = {};\n this.sectionHandlers = {};\n\n this.commands = imapCommands;\n\n this.folders = new Map();\n\n this.currentLock = false;\n this.locks = [];\n\n this.idRequested = false;\n\n this.maxIdleTime = this.options.maxIdleTime || false;\n this.missingIdleCommand = (this.options.missingIdleCommand || '').toString().toUpperCase().trim() || 'NOOP';\n\n this.disableBinary = !!this.options.disableBinary;\n\n this.streamer.on('error', err => {\n if (['Z_BUF_ERROR', 'ECONNRESET', 'EPIPE', 'ETIMEDOUT', 'EHOSTUNREACH'].includes(err.code)) {\n // just close the connection, usually nothing but noise\n return setImmediate(() => this.close());\n }\n\n this.log.error({ err, cid: this.id });\n setImmediate(() => this.close());\n this.emitError(err);\n });\n\n // Has the `connect` method already been called\n this._connectCalled = false;\n }\n\n emitError(err) {\n this.emit('error', err);\n }\n\n getRandomId() {\n let rid = BigInt('0x' + crypto.randomBytes(13).toString('hex')).toString(36);\n if (rid.length < 20) {\n rid = '0'.repeat(20 - rid.length) + rid;\n } else if (rid.length > 20) {\n rid = rid.substr(0, 20);\n }\n return rid;\n }\n\n write(chunk) {\n if (this.socket.destroyed) {\n // do not write after connection end or logout\n const error = new Error('Socket is already closed');\n error.code = 'NoConnection';\n throw error;\n }\n\n if (this.state === this.states.LOGOUT) {\n // should not happen\n const error = new Error('Can not send data after logged out');\n error.code = 'StateLogout';\n throw error;\n }\n\n if (this.writeSocket.destroyed) {\n this.socket.emit('error', 'Write socket destroyed');\n return;\n }\n\n let addLineBreak = !this.commandParts.length;\n if (typeof chunk === 'string') {\n if (addLineBreak) {\n chunk += '\\r\\n';\n }\n chunk = Buffer.from(chunk, 'binary');\n } else if (Buffer.isBuffer(chunk)) {\n if (addLineBreak) {\n chunk = Buffer.concat([chunk, Buffer.from('\\r\\n')]);\n }\n } else {\n return false;\n }\n\n if (this.logRaw) {\n this.log.trace({\n src: 'c',\n msg: 'write to socket',\n data: chunk.toString('base64'),\n compress: !!this._deflate,\n secure: !!this.secureConnection,\n cid: this.id\n });\n }\n\n this.writeBytesCounter += chunk.length;\n\n this.writeSocket.write(chunk);\n }\n\n stats(reset) {\n let result = {\n sent: this.writeBytesCounter || 0,\n received: (this.streamer && this.streamer.readBytesCounter) || 0\n };\n\n if (reset) {\n this.writeBytesCounter = 0;\n if (this.streamer) {\n this.streamer.readBytesCounter = 0;\n }\n }\n\n return result;\n }\n\n async send(data) {\n if (this.state === this.states.LOGOUT) {\n // already logged out\n if (data.tag) {\n let request = this.requestTagMap.get(data.tag);\n if (request) {\n this.requestTagMap.delete(request.tag);\n const error = new Error('Connection not available');\n error.code = 'NoConnection';\n request.reject(error);\n }\n }\n return;\n }\n\n let compiled = await compiler(data, {\n asArray: true,\n literalMinus: this.capabilities.has('LITERAL-') || this.capabilities.has('LITERAL+')\n });\n this.commandParts = compiled;\n\n let logCompiled = await compiler(data, {\n isLogging: true\n });\n\n let options = data.options || {};\n\n this.log.debug({ src: 's', msg: logCompiled.toString(), cid: this.id, comment: options.comment });\n\n this.write(this.commandParts.shift());\n\n if (typeof options.onSend === 'function') {\n options.onSend();\n }\n }\n\n async trySend() {\n if (this.currentRequest || !this.requestQueue.length) {\n return;\n }\n this.currentRequest = this.requestQueue.shift();\n\n await this.send({\n tag: this.currentRequest.tag,\n command: this.currentRequest.command,\n attributes: this.currentRequest.attributes,\n options: this.currentRequest.options\n });\n }\n\n async exec(command, attributes, options) {\n if (this.socket.destroyed) {\n let error = new Error('Connection closed');\n error.code = 'EConnectionClosed';\n throw error;\n }\n\n let tag = (++this.tagCounter).toString(16).toUpperCase();\n\n options = options || {};\n\n return new Promise((resolve, reject) => {\n this.requestTagMap.set(tag, { command, attributes, options, resolve, reject });\n this.requestQueue.push({ tag, command, attributes, options });\n this.trySend().catch(err => {\n this.requestTagMap.delete(tag);\n reject(err);\n });\n });\n }\n\n getUntaggedHandler(command, attributes) {\n if (/^[0-9]+$/.test(command)) {\n let type = attributes && attributes.length && typeof attributes[0].value === 'string' ? attributes[0].value.toUpperCase() : false;\n if (type) {\n // EXISTS, EXPUNGE, RECENT, FETCH etc\n command = type;\n }\n }\n\n command = command.toUpperCase().trim();\n if (this.currentRequest && this.currentRequest.options && this.currentRequest.options.untagged && this.currentRequest.options.untagged[command]) {\n return this.currentRequest.options.untagged[command];\n }\n\n if (this.untaggedHandlers[command]) {\n return this.untaggedHandlers[command];\n }\n }\n\n getSectionHandler(key) {\n if (this.sectionHandlers[key]) {\n return this.sectionHandlers[key];\n }\n }\n\n async reader() {\n let data;\n while ((data = this.streamer.read()) !== null) {\n let parsed;\n\n try {\n parsed = await parser(data.payload, { literals: data.literals });\n if (parsed.tag && !['*', '+'].includes(parsed.tag) && parsed.command) {\n let payload = { response: parsed.command };\n\n if (\n parsed.attributes &&\n parsed.attributes[0] &&\n parsed.attributes[0].section &&\n parsed.attributes[0].section[0] &&\n parsed.attributes[0].section[0].type === 'ATOM'\n ) {\n payload.code = parsed.attributes[0].section[0].value;\n }\n this.emit('response', payload);\n }\n } catch (err) {\n // can not make sense of this\n this.log.error({ src: 's', msg: data.payload.toString(), err, cid: this.id });\n data.next();\n continue;\n }\n\n let logCompiled = await compiler(parsed, {\n isLogging: true\n });\n\n if (/^\\d+$/.test(parsed.command) && parsed.attributes && parsed.attributes[0] && parsed.attributes[0].value === 'FETCH') {\n // too many FETCH responses, might want to filter these out\n this.log.trace({ src: 's', msg: logCompiled.toString(), cid: this.id, nullBytesRemoved: parsed.nullBytesRemoved });\n } else {\n this.log.debug({ src: 's', msg: logCompiled.toString(), cid: this.id, nullBytesRemoved: parsed.nullBytesRemoved });\n }\n\n if (parsed.tag === '+' && this.currentRequest && this.currentRequest.options && typeof this.currentRequest.options.onPlusTag === 'function') {\n await this.currentRequest.options.onPlusTag(parsed);\n data.next();\n continue;\n }\n\n if (parsed.tag === '+' && this.commandParts.length) {\n let content = this.commandParts.shift();\n this.write(content);\n this.log.debug({ src: 'c', msg: `(* ${content.length}B continuation *)`, cid: this.id });\n data.next();\n continue;\n }\n\n let section = parsed.attributes && parsed.attributes.length && parsed.attributes[0] && !parsed.attributes[0].value && parsed.attributes[0].section;\n if (section && section.length && section[0].type === 'ATOM' && typeof section[0].value === 'string') {\n let sectionHandler = this.getSectionHandler(section[0].value.toUpperCase().trim());\n if (sectionHandler) {\n await sectionHandler(section.slice(1));\n }\n }\n\n if (parsed.tag === '*' && parsed.command) {\n let untaggedHandler = this.getUntaggedHandler(parsed.command, parsed.attributes);\n if (untaggedHandler) {\n try {\n await untaggedHandler(parsed);\n } catch (err) {\n this.log.warn({ err, cid: this.id });\n data.next();\n continue;\n }\n }\n }\n\n if (this.requestTagMap.has(parsed.tag)) {\n let request = this.requestTagMap.get(parsed.tag);\n this.requestTagMap.delete(parsed.tag);\n\n if (this.currentRequest && this.currentRequest.tag === parsed.tag) {\n // send next pending command\n this.currentRequest = false;\n await this.trySend();\n }\n\n switch (parsed.command.toUpperCase()) {\n case 'OK':\n case 'BYE':\n await new Promise(resolve => request.resolve({ response: parsed, next: resolve }));\n break;\n\n case 'NO':\n case 'BAD': {\n let txt =\n parsed.attributes &&\n parsed.attributes\n .filter(val => val.type === 'TEXT')\n .map(val => val.value.trim())\n .join(' ');\n\n let err = new Error('Command failed');\n err.response = parsed;\n err.responseStatus = parsed.command.toUpperCase();\n\n try {\n err.executedCommand =\n parsed.tag +\n (\n await compiler(request, {\n isLogging: true\n })\n ).toString();\n } catch (err) {\n // ignore\n }\n\n if (txt) {\n err.responseText = txt;\n\n if (err.responseStatus === 'NO' && txt.includes('Some of the requested messages no longer exist')) {\n // Treat as successful response\n this.log.warn({ msg: 'Partial FETCH response', cid: this.id, err });\n await new Promise(resolve => request.resolve({ response: parsed, next: resolve }));\n break;\n }\n\n let throttleDelay = false;\n\n // MS365 throttling\n // tag BAD Request is throttled. Suggested Backoff Time: 92415 milliseconds\n if (/Request is throttled/i.test(txt) && /Backoff Time/i.test(txt)) {\n let throttlingMatch = txt.match(/Backoff Time[:=\\s]+(\\d+)/i);\n if (throttlingMatch && throttlingMatch[1] && !isNaN(throttlingMatch[1])) {\n throttleDelay = Number(throttlingMatch[1]);\n }\n }\n\n // Wait and return a throttling error\n if (throttleDelay) {\n err.code = 'ETHROTTLE';\n err.throttleReset = throttleDelay;\n\n let delayResponse = throttleDelay;\n if (delayResponse > 5 * 60 * 1000) {\n // max delay cap\n delayResponse = 5 * 60 * 1000;\n }\n\n this.log.warn({ msg: 'Throttling detected', cid: this.id, throttleDelay, delayResponse, err });\n await new Promise(r => setTimeout(r, delayResponse));\n }\n }\n\n request.reject(err);\n break;\n }\n\n default: {\n let err = new Error('Invalid server response');\n err.code = 'InvalidResponse';\n err.response = parsed;\n request.reject(err);\n break;\n }\n }\n }\n\n data.next();\n }\n }\n\n setEventHandlers() {\n this.socketReadable = () => {\n if (!this.reading) {\n this.reading = true;\n this.reader()\n .catch(err => this.log.error({ err, cid: this.id }))\n .finally(() => {\n this.reading = false;\n });\n }\n };\n\n this.streamer.on('readable', this.socketReadable);\n }\n\n setSocketHandlers() {\n this._socketError =\n this._socketError ||\n (err => {\n this.log.error({ err, cid: this.id });\n setImmediate(() => this.close());\n this.emitError(err);\n });\n this._socketClose =\n this._socketClose ||\n (() => {\n this.close();\n });\n this._socketEnd =\n this._socketEnd ||\n (() => {\n this.close();\n });\n\n this._socketTimeout =\n this._socketTimeout ||\n (() => {\n if (this.idling) {\n this.run('NOOP')\n .then(() => this.idle())\n .catch(this._socketError);\n } else {\n this.log.debug({ msg: 'Socket timeout', cid: this.id });\n this.close();\n }\n });\n\n this.socket.on('error', this._socketError);\n this.socket.on('close', this._socketClose);\n this.socket.on('end', this._socketEnd);\n this.socket.on('tlsClientError', this._socketError);\n this.socket.on('timeout', this._socketTimeout);\n\n this.writeSocket.on('error', this._socketError);\n }\n\n clearSocketHandlers() {\n if (this._socketError) {\n this.socket.removeListener('error', this._socketError);\n this.socket.removeListener('tlsClientError', this._socketError);\n }\n if (this._socketClose) {\n this.socket.removeListener('close', this._socketClose);\n }\n if (this._socketEnd) {\n this.socket.removeListener('end', this._socketEnd);\n }\n }\n\n async startSession() {\n await this.run('CAPABILITY');\n\n if (this.capabilities.has('ID')) {\n this.idRequested = await this.run('ID', this.clientInfo);\n }\n\n await this.upgradeToSTARTTLS();\n\n await this.authenticate();\n\n if (!this.idRequested && this.capabilities.has('ID')) {\n // re-request ID after LOGIN\n this.idRequested = await this.run('ID', this.clientInfo);\n }\n\n // Make sure we have namespace set. This should also throw if Exchange actually failed authentication\n let nsResponse = await this.run('NAMESPACE');\n if (nsResponse && nsResponse.error && nsResponse.status === 'BAD' && /User is authenticated but not connected/i.test(nsResponse.text)) {\n // Not a NAMESPACE failure but authentication failure, so report as\n this.authenticated = false;\n let err = new AuthenticationFailure('Authentication failed');\n err.response = nsResponse.text;\n throw err;\n }\n\n if (this.options.verifyOnly) {\n // List all folders and logout\n if (this.options.includeMailboxes) {\n this._mailboxList = await this.list();\n }\n return await this.logout();\n }\n\n // try to use compression (if supported)\n if (!this.options.disableCompression) {\n await this.compress();\n }\n\n if (!this.options.disableAutoEnable) {\n // enable extensions if possible\n await this.run('ENABLE', ['CONDSTORE', 'UTF8=ACCEPT'].concat(this.options.qresync ? 'QRESYNC' : []));\n }\n\n this.usable = true;\n }\n\n async compress() {\n if (!(await this.run('COMPRESS'))) {\n return; // was not able to negotiate compression\n }\n\n // create deflate/inflate streams\n this._deflate = zlib.createDeflateRaw({\n windowBits: 15\n });\n this._inflate = zlib.createInflateRaw();\n\n // route incoming socket via inflate stream\n this.socket.unpipe(this.streamer);\n this.streamer.compress = true;\n this.socket.pipe(this._inflate).pipe(this.streamer);\n this._inflate.on('error', err => {\n this.streamer.emit('error', err);\n });\n\n // route outgoing socket via deflate stream\n this.writeSocket = new PassThrough();\n\n this.writeSocket.destroySoon = () => {\n try {\n if (this.socket) {\n this.socket.destroy();\n }\n this.writeSocket.end();\n } catch (err) {\n this.log.error({ err, info: 'Failed to destroy PassThrough socket', cid: this.id });\n throw err;\n }\n };\n\n Object.defineProperty(this.writeSocket, 'destroyed', {\n get: () => this.socket.destroyed\n });\n\n // we need to force flush deflated data to socket so we can't\n // use normal pipes for this.writeSocket -> this._deflate -> this.socket\n let reading = false;\n let readNext = () => {\n reading = true;\n\n let chunk;\n while ((chunk = this.writeSocket.read()) !== null) {\n if (this._deflate && this._deflate.write(chunk) === false) {\n return this._deflate.once('drain', readNext);\n }\n }\n\n // flush data to socket\n if (this._deflate) {\n this._deflate.flush();\n }\n\n reading = false;\n };\n\n this.writeSocket.on('readable', () => {\n if (!reading) {\n readNext();\n }\n });\n this.writeSocket.on('error', err => {\n this.socket.emit('error', err);\n });\n\n this._deflate.pipe(this.socket);\n this._deflate.on('error', err => {\n this.socket.emit('error', err);\n });\n }\n\n _failSTARTTLS() {\n if (this.options.doSTARTTLS === true) {\n // STARTTLS configured as requirement\n let err = new Error('Server does not support STARTTLS');\n err.tlsFailed = true;\n throw err;\n } else {\n // Opportunistic STARTTLS. But it's not possible right now.\n // Attention: Could be a downgrade attack.\n return false;\n }\n }\n\n /**\n * Tries to upgrade the connection to TLS using STARTTLS.\n * @throws if STARTTLS is required, but not possible.\n * @returns {boolean} true, if the connection is now protected by TLS, either direct TLS or STARTTLS.\n */\n async upgradeToSTARTTLS() {\n if (this.options.doSTARTTLS === true && this.options.secure === true) {\n throw new Error('Misconfiguration: Cannot set both secure=true for TLS and doSTARTTLS=true for STARTTLS.');\n }\n\n if (this.secureConnection) {\n // Already using direct TLS. No need for STARTTLS.\n return true;\n }\n\n if (this.options.doSTARTTLS === false) {\n // STARTTLS explictly disabled by config\n return false;\n }\n\n if (!this.capabilities.has('STARTTLS')) {\n return this._failSTARTTLS();\n }\n\n this.expectCapabilityUpdate = true;\n let canUpgrade = await this.run('STARTTLS');\n if (!canUpgrade) {\n return this._failSTARTTLS();\n }\n\n this.socket.unpipe(this.streamer);\n let upgraded = await new Promise((resolve, reject) => {\n let socketPlain = this.socket;\n let opts = Object.assign(\n {\n socket: this.socket,\n servername: this.servername,\n port: this.port\n },\n this.options.tls || {}\n );\n this.clearSocketHandlers();\n\n socketPlain.once('error', err => {\n clearTimeout(this.connectTimeout);\n clearTimeout(this.upgradeTimeout);\n if (!this.upgrading) {\n // don't care anymore\n return;\n }\n setImmediate(() => this.close());\n this.upgrading = false;\n err.tlsFailed = true;\n reject(err);\n });\n\n this.upgradeTimeout = setTimeout(() => {\n if (!this.upgrading) {\n return;\n }\n setImmediate(() => this.close());\n let err = new Error('Failed to upgrade connection in required time');\n err.tlsFailed = true;\n err.code = 'UPGRADE_TIMEOUT';\n reject(err);\n }, UPGRADE_TIMEOUT);\n\n this.upgrading = true;\n this.socket = tls.connect(opts, () => {\n clearTimeout(this.upgradeTimeout);\n if (this.isClosed) {\n // not sure if this is possible?\n return this.close();\n }\n\n this.secureConnection = true;\n this.upgrading = false;\n this.streamer.secureConnection = true;\n this.socket.pipe(this.streamer);\n this.tls = typeof this.socket.getCipher === 'function' ? this.socket.getCipher() : false;\n if (this.tls) {\n this.tls.authorized = this.socket.authorized;\n this.log.info({\n src: 'tls',\n msg: 'Established TLS session',\n cid: this.id,\n authorized: this.tls.authorized,\n algo: this.tls.standardName || this.tls.name,\n version: this.tls.version\n });\n }\n\n return resolve(true);\n });\n\n this.writeSocket = this.socket;\n\n this.setSocketHandlers();\n });\n\n if (upgraded && this.expectCapabilityUpdate) {\n await this.run('CAPABILITY');\n }\n\n return upgraded;\n }\n\n async setAuthenticationState() {\n this.state = this.states.AUTHENTICATED;\n this.authenticated = true;\n if (this.expectCapabilityUpdate) {\n // update capabilities\n await this.run('CAPABILITY');\n }\n }\n\n async authenticate() {\n if (this.state === this.states.LOGOUT) {\n throw new AuthenticationFailure('Already logged out');\n }\n\n if (this.state !== this.states.NOT_AUTHENTICATED) {\n // nothing to do here, usually happens with PREAUTH greeting\n return true;\n }\n\n if (!this.options.auth) {\n throw new AuthenticationFailure('Please configure the login');\n }\n\n this.expectCapabilityUpdate = true;\n\n let loginMethod = (this.options.auth.loginMethod || '').toString().trim().toUpperCase();\n if (!loginMethod && /\\\\|\\//.test(this.options.auth.user)) {\n // Special override for MS Exchange when authenticating as some other user or non-email account\n loginMethod = 'LOGIN';\n }\n\n if (this.options.auth.accessToken) {\n this.authenticated = await this.run('AUTHENTICATE', this.options.auth.user, { accessToken: this.options.auth.accessToken });\n } else if (this.options.auth.pass) {\n if ((this.capabilities.has('AUTH=LOGIN') || this.capabilities.has('AUTH=PLAIN')) && loginMethod !== 'LOGIN') {\n this.authenticated = await this.run('AUTHENTICATE', this.options.auth.user, { password: this.options.auth.pass, loginMethod });\n } else {\n if (this.capabilities.has('LOGINDISABLED')) {\n throw new AuthenticationFailure('Login is disabled');\n }\n this.authenticated = await this.run('LOGIN', this.options.auth.user, this.options.auth.pass);\n }\n } else {\n throw new AuthenticationFailure('No password configured');\n }\n\n if (this.authenticated) {\n this.log.info({\n src: 'auth',\n msg: 'User authenticated',\n cid: this.id,\n user: this.options.auth.user\n });\n await this.setAuthenticationState();\n return true;\n }\n\n throw new AuthenticationFailure('No matching authentication method');\n }\n\n async initialOK(message) {\n this.greeting = (message.attributes || [])\n .filter(entry => entry.type === 'TEXT')\n .map(entry => entry.value)\n .filter(entry => entry)\n .join('');\n\n clearTimeout(this.greetingTimeout);\n this.untaggedHandlers.OK = null;\n this.untaggedHandlers.PREAUTH = null;\n\n if (this.isClosed) {\n return;\n }\n\n // get out of current parsing \"thread\", so do not await for startSession\n this.startSession()\n .then(() => {\n if (typeof this.initialResolve === 'function') {\n let resolve = this.initialResolve;\n this.initialResolve = false;\n this.initialReject = false;\n return resolve();\n }\n })\n .catch(err => {\n this.log.error({ err, cid: this.id });\n\n if (typeof this.initialReject === 'function') {\n clearTimeout(this.greetingTimeout);\n let reject = this.initialReject;\n this.initialResolve = false;\n this.initialReject = false;\n return reject(err);\n }\n\n setImmediate(() => this.close());\n });\n }\n\n async initialPREAUTH() {\n clearTimeout(this.greetingTimeout);\n this.untaggedHandlers.OK = null;\n this.untaggedHandlers.PREAUTH = null;\n\n if (this.isClosed) {\n return;\n }\n\n this.state = this.states.AUTHENTICATED;\n\n // get out of current parsing \"thread\", so do not await for startSession\n this.startSession()\n .then(() => {\n if (typeof this.initialResolve === 'function') {\n let resolve = this.initialResolve;\n this.initialResolve = false;\n this.initialReject = false;\n return resolve();\n }\n })\n .catch(err => {\n this.log.error({ err, cid: this.id });\n\n if (typeof this.initialReject === 'function') {\n clearTimeout(this.greetingTimeout);\n let reject = this.initialReject;\n this.initialResolve = false;\n this.initialReject = false;\n return reject(err);\n }\n\n setImmediate(() => this.close());\n });\n }\n\n async serverBye() {\n this.untaggedHandlers.BYE = null;\n this.state = this.states.LOGOUT;\n }\n\n async sectionCapability(section) {\n this.rawCapabilities = section;\n this.capabilities = updateCapabilities(section);\n\n if (this.capabilities) {\n for (let [capa] of this.capabilities) {\n if (/^AUTH=/i.test(capa) && !this.authCapabilities.has(capa.toUpperCase())) {\n this.authCapabilities.set(capa.toUpperCase(), false);\n }\n }\n }\n\n if (this.expectCapabilityUpdate) {\n this.expectCapabilityUpdate = false;\n }\n }\n\n async untaggedCapability(untagged) {\n this.rawCapabilities = untagged.attributes;\n this.capabilities = updateCapabilities(untagged.attributes);\n\n if (this.capabilities) {\n for (let [capa] of this.capabilities) {\n if (/^AUTH=/i.test(capa) && !this.authCapabilities.has(capa.toUpperCase())) {\n this.authCapabilities.set(capa.toUpperCase(), false);\n }\n }\n }\n\n if (this.expectCapabilityUpdate) {\n this.expectCapabilityUpdate = false;\n }\n }\n\n async untaggedExists(untagged) {\n if (!this.mailbox) {\n // mailbox closed, ignore\n return;\n }\n\n if (!untagged || !untagged.command || isNaN(untagged.command)) {\n return;\n }\n\n let count = Number(untagged.command);\n if (count === this.mailbox.exists) {\n // nothing changed?\n return;\n }\n\n // keep exists up to date\n let prevCount = this.mailbox.exists;\n this.mailbox.exists = count;\n this.emit('exists', {\n path: this.mailbox.path,\n count,\n prevCount\n });\n }\n\n async untaggedExpunge(untagged) {\n if (!this.mailbox) {\n // mailbox closed, ignore\n return;\n }\n\n if (!untagged || !untagged.command || isNaN(untagged.command)) {\n return;\n }\n\n let seq = Number(untagged.command);\n if (seq && seq <= this.mailbox.exists) {\n this.mailbox.exists--;\n let payload = {\n path: this.mailbox.path,\n seq,\n vanished: false\n };\n\n if (typeof this.options.expungeHandler === 'function') {\n try {\n await this.options.expungeHandler(payload);\n } catch (err) {\n this.log.error({ msg: 'Failed to notify expunge event', payload, error: err, cid: this.id });\n }\n } else {\n this.emit('expunge', payload);\n }\n }\n }\n\n async untaggedVanished(untagged, mailbox) {\n mailbox = mailbox || this.mailbox;\n if (!mailbox) {\n // mailbox closed, ignore\n return;\n }\n\n let tags = [];\n let uids = false;\n\n if (untagged.attributes.length > 1 && Array.isArray(untagged.attributes[0])) {\n tags = untagged.attributes[0].map(entry => (typeof entry.value === 'string' ? entry.value.toUpperCase() : false)).filter(value => value);\n untagged.attributes.shift();\n }\n\n if (untagged.attributes[0] && typeof untagged.attributes[0].value === 'string') {\n uids = untagged.attributes[0].value;\n }\n\n let uidList = expandRange(uids);\n\n for (let uid of uidList) {\n let payload = {\n path: mailbox.path,\n uid,\n vanished: true,\n earlier: tags.includes('EARLIER')\n };\n\n if (typeof this.options.expungeHandler === 'function') {\n try {\n await this.options.expungeHandler(payload);\n } catch (err) {\n this.log.error({ msg: 'Failed to notify expunge event', payload, error: err, cid: this.id });\n }\n } else {\n this.emit('expunge', payload);\n }\n }\n }\n\n async untaggedFetch(untagged, mailbox) {\n mailbox = mailbox || this.mailbox;\n if (!mailbox) {\n // mailbox closed, ignore\n return;\n }\n\n let message = await formatMessageResponse(untagged, mailbox);\n if (message.flags) {\n let updateEvent = {\n path: mailbox.path,\n seq: message.seq\n };\n\n if (message.uid) {\n updateEvent.uid = message.uid;\n }\n\n if (message.modseq) {\n updateEvent.modseq = message.modseq;\n }\n\n updateEvent.flags = message.flags;\n\n if (message.flagColor) {\n updateEvent.flagColor = message.flagColor;\n }\n\n this.emit('flags', updateEvent);\n }\n }\n\n async ensureSelectedMailbox(path) {\n if (!path) {\n return false;\n }\n\n if ((!this.mailbox && path) || (this.mailbox && path && !comparePaths(this, this.mailbox.path, path))) {\n return await this.mailboxOpen(path);\n }\n\n return true;\n }\n\n async resolveRange(range, options) {\n if (typeof range === 'number' || typeof range === 'bigint') {\n range = range.toString();\n }\n\n // special case, some servers allow this, some do not, so replace it with the last known EXISTS value\n if (range === '*') {\n if (!this.mailbox.exists) {\n return false;\n }\n range = this.mailbox.exists.toString();\n options.uid = false; // sequence query\n }\n\n if (range && typeof range === 'object' && !Array.isArray(range)) {\n if (range.all && Object.keys(range).length === 1) {\n range = '1:*';\n } else if (range.uid && Object.keys(range).length === 1) {\n range = range.uid;\n options.uid = true;\n } else {\n // resolve range by searching\n options.uid = true; // force UIDs instead of sequence numbers\n range = await this.run('SEARCH', range, options);\n if (range && range.length) {\n range = packMessageRange(range);\n }\n }\n }\n\n if (Array.isArray(range)) {\n range = range.join(',');\n }\n\n if (!range) {\n return false;\n }\n\n return range;\n }\n\n autoidle() {\n clearTimeout(this.idleStartTimer);\n if (this.options.disableAutoIdle || this.state !== this.states.SELECTED) {\n return;\n }\n this.idleStartTimer = setTimeout(() => {\n this.idle().catch(err => this.log.warn({ err, cid: this.id }));\n }, 15 * 1000);\n }\n\n // PUBLIC API METHODS\n\n /**\n * Initiates a connection against IMAP server. Throws if anything goes wrong. This is something you have to call before you can run any IMAP commands\n *\n * @returns {Promise<void>}\n * @throws Will throw an error if connection or authentication fails\n * @example\n * let client = new ImapFlow({...});\n * await client.connect();\n */\n async connect() {\n if (this._connectCalled) {\n // Prevent re-using ImapFlow instances by allowing to call connect just once.\n throw new Error('Can not re-use ImapFlow instance');\n }\n this._connectCalled = true;\n\n let connector = this.secureConnection ? tls : net;\n\n let opts = Object.assign(\n {\n host: this.host,\n servername: this.servername,\n port: this.port\n },\n this.options.tls || {}\n );\n\n this.untaggedHandlers.OK = (...args) => this.initialOK(...args);\n this.untaggedHandlers.BYE = (...args) => this.serverBye(...args);\n this.untaggedHandlers.PREAUTH = (...args) => this.initialPREAUTH(...args);\n\n this.untaggedHandlers.CAPABILITY = (...args) => this.untaggedCapability(...args);\n this.sectionHandlers.CAPABILITY = (...args) => this.sectionCapability(...args);\n\n this.untaggedHandlers.EXISTS = (...args) => this.untaggedExists(...args);\n this.untaggedHandlers.EXPUNGE = (...args) => this.untaggedExpunge(...args);\n\n // these methods take an optional second argument, so make sure that some random IMAP tag is not used as the second argument\n this.untaggedHandlers.FETCH = untagged => this.untaggedFetch(untagged);\n this.untaggedHandlers.VANISHED = untagged => this.untaggedVanished(untagged);\n\n let socket = false;\n if (this.options.proxy) {\n try {\n socket = await proxyConnection(this.log, this.options.proxy, this.host, this.port);\n if (!socket) {\n throw new Error('Failed to setup proxy connection');\n }\n } catch (err) {\n let error = new Error('Failed to setup proxy connection');\n error.code = err.code || 'ProxyError';\n error._err = err;\n this.log.error({ error, cid: this.id });\n throw error;\n }\n }\n\n await new Promise((resolve, reject) => {\n this.connectTimeout = setTimeout(() => {\n let err = new Error('Failed to establish connection in required time');\n err.code = 'CONNECT_TIMEOUT';\n err.details = {\n connectionTimeout: this.options.connectionTimeout || CONNECT_TIMEOUT\n };\n this.log.error({ err, cid: this.id });\n setImmediate(() => this.close());\n reject(err);\n }, this.options.connectionTimeout || CONNECT_TIMEOUT);\n\n let onConnect = () => {\n clearTimeout(this.connectTimeout);\n this.socket.setKeepAlive(true, 5 * 1000);\n this.socket.setTimeout(this.options.socketTimeout || SOCKET_TIMEOUT);\n\n this.greetingTimeout = setTimeout(() => {\n let err = new Error(`Failed to receive greeting from server in required time${!this.secureConnection ? '. Maybe should use TLS?' : ''}`);\n err.code = 'GREETING_TIMEOUT';\n err.details = {\n greetingTimeout: this.options.greetingTimeout || GREETING_TIMEOUT\n };\n this.log.error({ err, cid: this.id });\n setImmediate(() => this.close());\n reject(err);\n }, this.options.greetingTimeout || GREETING_TIMEOUT);\n\n this.tls = typeof this.socket.getCipher === 'function' ? this.socket.getCipher() : false;\n\n let logInfo = {\n src: 'connection',\n msg: `Established ${this.tls ? 'secure ' : ''}TCP connection`,\n cid: this.id,\n secure: !!this.tls,\n host: this.host,\n servername: this.servername,\n port: this.socket.remotePort,\n address: this.socket.remoteAddress,\n localAddress: this.socket.localAddress,\n localPort: this.socket.localPort\n };\n\n if (this.tls) {\n logInfo.authorized = this.tls.authorized = this.socket.authorized;\n logInfo.algo = this.tls.standardName || this.tls.name;\n logInfo.version = this.tls.version;\n }\n\n this.log.info(logInfo);\n\n this.setSocketHandlers();\n this.socket.pipe(this.streamer);\n\n // executed by initial \"* OK\"\n this.initialResolve = resolve;\n this.initialReject = reject;\n };\n\n if (socket) {\n // socket is already established via proxy\n if (this.secureConnection) {\n // TLS socket requires a handshake\n opts.socket = socket;\n this.socket = connector.connect(opts, onConnect);\n } else {\n // cleartext socket is already usable\n this.socket = socket;\n setImmediate(onConnect);\n }\n } else {\n this.socket = connector.connect(opts, onConnect);\n }\n\n this.writeSocket = this.socket;\n\n this.socket.on('error', err => {\n clearTimeout(this.connectTimeout);\n clearTimeout(this.greetingTimeout);\n setImmediate(() => this.close());\n this.log.error({ err, cid: this.id });\n reject(err);\n });\n\n this.setEventHandlers();\n });\n }\n\n /**\n * Graceful connection close by sending logout command to server. TCP connection is closed once command is finished.\n *\n * @return {Promise<void>}\n * @example\n * let client = new ImapFlow({...});\n * await client.connect();\n * ...\n * await client.logout();\n */\n async logout() {\n return await this.run('LOGOUT');\n }\n\n /**\n * Closes TCP connection without notifying the server.\n *\n * @example\n * let client = new ImapFlow({...});\n * await client.connect();\n * ...\n * client.close();\n */\n close() {\n // clear pending timers\n clearTimeout(this.idleStartTimer);\n clearTimeout(this.upgradeTimeout);\n clearTimeout(this.connectTimeout);\n\n this.usable = false;\n this.idling = false;\n\n if (typeof this.initialReject === 'function' && !this.options.verifyOnly) {\n clearTimeout(this.greetingTimeout);\n let reject = this.initialReject;\n this.initialResolve = false;\n this.initialReject = false;\n let err = new Error('Unexpected close');\n err.code = `ClosedAfterConnect${this.secureConnection ? 'TLS' : 'Text'}`;\n // still has to go through the logic below\n setImmediate(() => reject(err));\n }\n\n if (typeof this.preCheck === 'function') {\n this.preCheck().catch(err => this.log.warn({ err, cid: this.id }));\n }\n\n // reject command that is currently processed\n if (this.currentRequest && this.requestTagMap.has(this.currentRequest.tag)) {\n let request = this.requestTagMap.get(this.currentRequest.tag);\n if (request) {\n this.requestTagMap.delete(request.tag);\n const error = new Error('Connection not available');\n error.code = 'NoConnection';\n request.reject(error);\n }\n this.currentRequest = false;\n }\n\n // reject all other pending commands\n while (this.requestQueue.length) {\n let req = this.requestQueue.shift();\n if (req && this.requestTagMap.has(req.tag)) {\n let request = this.requestTagMap.get(req.tag);\n if (request) {\n this.requestTagMap.delete(request.tag);\n const error = new Error('Connection not available');\n error.code = 'NoConnection';\n request.reject(error);\n }\n }\n }\n\n this.state = this.states.LOGOUT;\n if (this.isClosed) {\n return;\n }\n this.isClosed = true;\n\n if (this.writeSocket && !this.writeSocket.destroyed) {\n try {\n this.writeSocket.destroy();\n } catch (err) {\n this.log.error({ err, cid: this.id });\n }\n }\n\n if (this.socket && !this.socket.destroyed && this.writeSocket !== this.socket) {\n try {\n this.socket.destroy();\n } catch (err) {\n this.log.error({ err, cid: this.id });\n }\n }\n\n this.log.trace({ msg: 'Connection closed', cid: this.id });\n this.emit('close');\n }\n\n /**\n * @typedef {Object} QuotaResponse\n * @global\n * @property {String} path=INBOX mailbox path this quota applies to\n * @property {Object} [storage] Storage quota if provided by server\n * @property {Number} [storage.used] used storage in bytes\n * @property {Number} [storage.limit] total storage available\n * @property {Object} [messages] Message count quota if provided by server\n * @property {Number} [messages.used] stored messages\n * @property {Number} [messages.limit] maximum messages allowed\n */\n\n /**\n * Returns current quota\n *\n * @param {String} [path] Optional mailbox path if you want to check quota for specific folder\n * @returns {Promise<QuotaResponse|Boolean>} Quota information or `false` if QUTOA extension is not supported or requested path does not exist\n *\n * @example\n * let quota = await client.getQuota();\n * console.log(quota.storage.used, quota.storage.available)\n */\n async getQuota(path) {\n path = path || 'INBOX';\n return await this.run('QUOTA', path);\n }\n\n /**\n * @typedef {Object} ListResponse\n * @global\n * @property {String} path mailbox path (unicode string)\n * @property {String} pathAsListed mailbox path as listed in the LIST/LSUB response\n * @property {String} name mailbox name (last part of path after delimiter)\n * @property {String} delimiter mailbox path delimiter, usually \".\" or \"/\"\n * @property {String[]} parent An array of parent folder names. All names are in unicode\n * @property {String} parentPath Same as `parent`, but as a complete string path (unicode string)\n * @property {Set<string>} flags a set of flags for this mailbox\n * @property {String} specialUse one of special-use flags (if applicable): \"\\All\", \"\\Archive\", \"\\Drafts\", \"\\Flagged\", \"\\Junk\", \"\\Sent\", \"\\Trash\". Additionally INBOX has non-standard \"\\Inbox\" flag set\n * @property {Boolean} listed `true` if mailbox was found from the output of LIST command\n * @property {Boolean} subscribed `true` if mailbox was found from the output of LSUB command\n * @property {StatusObject} [status] If `statusQuery` was used, then this value includes the status response\n */\n\n /**\n * @typedef {Object} ListOptions\n * @global\n * @property {Object} [statusQuery] request status items for every listed entry\n * @property {Boolean} [statusQuery.messages] if `true` request count of messages\n * @property {Boolean} [statusQuery.recent] if `true` request count of messages with \\\\Recent tag\n * @property {Boolean} [statusQuery.uidNext] if `true` request predicted next UID\n * @property {Boolean} [statusQuery.uidValidity] if `true` request mailbox `UIDVALIDITY` value\n * @property {Boolean} [statusQuery.unseen] if `true` request count of unseen messages\n * @property {Boolean} [statusQuery.highestModseq] if `true` request last known modseq value\n * @property {Object} [specialUseHints] set specific paths as special use folders, this would override special use flags provided from the server\n * @property {String} [specialUseHints.sent] Path to \"Sent Mail\" folder\n * @property {String} [specialUseHints.trash] Path to \"Trash\" folder\n * @property {String} [specialUseHints.junk] Path to \"Junk Mail\" folder\n * @property {String} [specialUseHints.drafts] Path to \"Drafts\" folder\n */\n\n /**\n * Lists available mailboxes as an Array\n *\n * @param {ListOptions} [options] defines additional listing options\n * @returns {Promise<ListResponse[]>} An array of ListResponse objects\n *\n * @example\n * let list = await client.list();\n * list.forEach(mailbox=>console.log(mailbox.path));\n */\n async list(options) {\n options = options || {};\n let folders = await this.run('LIST', '', '*', options);\n this.folders = new Map(folders.map(folder => [folder.path, folder]));\n return folders;\n }\n\n /**\n * @typedef {Object} ListTreeResponse\n * @global\n * @property {Boolean} root If `true` then this is root node without any additional properties besides *folders*\n * @property {String} path mailbox path\n * @property {String} name mailbox name (last part of path after delimiter)\n * @property {String} delimiter mailbox path delimiter, usually \".\" or \"/\"\n * @property {String[]} flags list of flags for this mailbox\n * @property {String} specialUse one of special-use flags (if applicable): \"\\All\", \"\\Archive\", \"\\Drafts\", \"\\Flagged\", \"\\Junk\", \"\\Sent\", \"\\Trash\". Additionally INBOX has non-standard \"\\Inbox\" flag set\n * @property {Boolean} listed `true` if mailbox was found from the output of LIST command\n * @property {Boolean} subscribed `true` if mailbox was found from the output of LSUB command\n * @property {Boolean} disabled If `true` then this mailbox can not be selected in the UI\n * @property {ListTreeResponse[]} folders An array of subfolders\n */\n\n /**\n * Lists available mailboxes as a tree structured object\n *\n * @param {ListOptions} [options] defines additional listing options\n * @returns {Promise<ListTreeResponse>} Tree structured object\n *\n * @example\n * let tree = await client.listTree();\n * tree.folders.forEach(mailbox=>console.log(mailbox.path));\n */\n async listTree(options) {\n options = options || {};\n let folders = await this.run('LIST', '', '*', options);\n this.folders = new Map(folders.map(folder => [folder.path, folder]));\n return getFolderTree(folders);\n }\n\n /**\n * Performs a no-op call against server\n * @returns {Promise<void>}\n */\n async noop() {\n await this.run('NOOP');\n }\n\n /**\n * @typedef {Object} MailboxCreateResponse\n * @global\n * @property {String} path full mailbox path\n * @property {String} [mailboxId] unique mailbox ID if server supports `OBJECTID` extension (currently Yahoo and some others)\n * @property {Boolean} created If `true` then mailbox was created otherwise it already existed\n */\n\n /**\n * Creates a new mailbox folder and sets up subscription for the created mailbox. Throws on error.\n *\n * @param {string|array} path Full mailbox path. Unicode is allowed. If value is an array then it is joined using current delimiter symbols. Namespace prefix is added automatically if required.\n * @returns {Promise<MailboxCreateResponse>} Mailbox info\n * @throws Will throw an error if mailbox can not be created\n *\n * @example\n * let info = await client.mailboxCreate(['parent', 'child']);\n * console.log(info.path);\n * // \"INBOX.parent.child\" // assumes \"INBOX.\" as namespace prefix and \".\" as delimiter\n */\n async mailboxCreate(path) {\n return await this.run('CREATE', path);\n }\n\n /**\n * @typedef {Object} MailboxRenameResponse\n * @global\n * @property {String} path full mailbox path that was renamed\n * @property {String} newPath new full mailbox path\n */\n\n /**\n * Renames a mailbox. Throws on error.\n *\n * @param {string|array} path Path for the mailbox to rename. Unicode is allowed. If value is an array then it is joined using current delimiter symbols. Namespace prefix is added automatically if required.\n * @param {string|array} newPath New path for the mailbox\n * @returns {Promise<MailboxRenameResponse>} Mailbox info\n * @throws Will throw an error if mailbox does not exist or can not be renamed\n *\n * @example\n * let info = await client.mailboxRename('parent.child', 'Important stuff ❗️');\n * console.log(info.newPath);\n * // \"INBOX.Important stuff ❗️\" // assumes \"INBOX.\" as namespace prefix\n */\n async mailboxRename(path, newPath) {\n return await this.run('RENAME', path, newPath);\n }\n\n /**\n * @typedef {Object} MailboxDeleteResponse\n * @global\n * @property {String} path full mailbox path that was deleted\n */\n\n /**\n * Deletes a mailbox. Throws on error.\n *\n * @param {string|array} path Path for the mailbox to delete. Unicode is allowed. If value is an array then it is joined using current delimiter symbols. Namespace prefix is added automatically if required.\n * @returns {Promise<MailboxDeleteResponse>} Mailbox info\n * @throws Will throw an error if mailbox does not exist or can not be deleted\n *\n * @example\n * let info = await client.mailboxDelete('Important stuff ❗️');\n * console.log(info.path);\n * // \"INBOX.Important stuff ❗️\" // assumes \"INBOX.\" as namespace prefix\n */\n async mailboxDelete(path) {\n return await this.run('DELETE', path);\n }\n\n /**\n * Subscribes to a mailbox\n *\n * @param {string|array} path Path for the mailbox to subscribe to. Unicode is allowed. If value is an array then it is joined using current delimiter symbols. Namespace prefix is added automatically if required.\n * @returns {Promise<Boolean>} `true` if subscription operation succeeded, `false` otherwise\n *\n * @example\n * await client.mailboxSubscribe('Important stuff ❗️');\n */\n async mailboxSubscribe(path) {\n return await this.run('SUBSCRIBE', path);\n }\n\n /**\n * Unsubscribes from a mailbox\n *\n * @param {string|array} path **Path for the mailbox** to unsubscribe from. Unicode is allowed. If value is an array then it is joined using current delimiter symbols. Namespace prefix is added automatically if required.\n * @returns {Promise<Boolean>} `true` if unsubscription operation succeeded, `false` otherwise\n *\n * @example\n * await client.mailboxUnsubscribe('Important stuff ❗️');\n */\n async mailboxUnsubscribe(path) {\n return await this.run('UNSUBSCRIBE', path);\n }\n\n /**\n * Opens a mailbox to access messages. You can perform message operations only against an opened mailbox.\n * Using {@link module:imapflow~ImapFlow#getMailboxLock|getMailboxLock()} instead of `mailboxOpen()` is preferred. Both do the same thing\n * but next `getMailboxLock()` call is not executed until previous one is released.\n *\n * @param {string|array} path **Path for the mailbox** to open\n * @param {Object} [options] optional options\n * @param {Boolean} [options.readOnly=false] If `true` then opens mailbox in read-only mode. You can still try to perform write operations but these would probably fail.\n * @returns {Promise<MailboxObject>} Mailbox info\n * @throws Will throw an error if mailbox does not exist or can not be opened\n *\n * @example\n * let mailbox = await client.mailboxOpen('Important stuff ❗️');\n * console.log(mailbox.exists);\n * // 125\n */\n async mailboxOpen(path, options) {\n return await this.run('SELECT', path, options);\n }\n\n /**\n * Closes a previously opened mailbox\n *\n * @returns {Promise<Boolean>} Did the operation succeed or not\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * await client.mailboxClose();\n */\n async mailboxClose() {\n return await this.run('CLOSE');\n }\n\n /**\n * @typedef {Object} StatusObject\n * @global\n * @property {String} path full mailbox path that was checked\n * @property {Number} [messages] Count of messages\n * @property {Number} [recent] Count of messages with \\\\Recent tag\n * @property {Number} [uidNext] Predicted next UID\n * @property {BigInt} [uidValidity] Mailbox `UIDVALIDITY` value\n * @property {Number} [unseen] Count of unseen messages\n * @property {BigInt} [highestModseq] Last known modseq value (if CONDSTORE extension is enabled)\n */\n\n /**\n * Requests the status of the indicated mailbox. Only requested status values will be returned.\n *\n * @param {String} path mailbox path to check for (unicode string)\n * @param {Object} query defines requested status items\n * @param {Boolean} query.messages if `true` request count of messages\n * @param {Boolean} query.recent if `true` request count of messages with \\\\Recent tag\n * @param {Boolean} query.uidNext if `true` request predicted next UID\n * @param {Boolean} query.uidValidity if `true` request mailbox `UIDVALIDITY` value\n * @param {Boolean} query.unseen if `true` request count of unseen messages\n * @param {Boolean} query.highestModseq if `true` request last known modseq value\n * @returns {Promise<StatusObject>} status of the indicated mailbox\n *\n * @example\n * let status = await client.status('INBOX', {unseen: true});\n * console.log(status.unseen);\n * // 123\n */\n async status(path, query) {\n return await this.run('STATUS', path, query);\n }\n\n /**\n * Starts listening for new or deleted messages from the currently opened mailbox. Only required if {@link ImapFlow#disableAutoIdle} is set to `true`\n * otherwise IDLE is started by default on connection inactivity. NB! If `idle()` is called manually then it does not\n * return until IDLE is finished which means you would have to call some other command out of scope.\n *\n * @returns {Promise<Boolean>} Did the operation succeed or not\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n *\n * await client.idle();\n */\n async idle() {\n if (!this.idling) {\n return await this.run('IDLE', this.maxIdleTime);\n }\n }\n\n /**\n * Sequence range string. Separate different values with commas, number ranges with colons and use \\\\* as the placeholder for the newest message in mailbox\n * @typedef {String} SequenceString\n * @global\n * @example\n * \"1:*\" // for all messages\n * \"1,2,3\" // for messages 1, 2 and 3\n * \"1,2,4:6\" // for messages 1,2,4,5,6\n * \"*\" // for the newest message\n */\n\n /**\n * IMAP search query options. By default all conditions must match. In case of `or` query term at least one condition must match.\n * @typedef {Object} SearchObject\n * @global\n * @property {SequenceString} [seq] message ordering sequence range\n * @property {Boolean} [answered] Messages with (value is `true`) or without (value is `false`) \\\\Answered flag\n * @property {Boolean} [deleted] Messages with (value is `true`) or without (value is `false`) \\\\Deleted flag\n * @property {Boolean} [draft] Messages with (value is `true`) or without (value is `false`) \\\\Draft flag\n * @property {Boolean} [flagged] Messages with (value is `true`) or without (value is `false`) \\\\Flagged flag\n * @property {Boolean} [seen] Messages with (value is `true`) or without (value is `false`) \\\\Seen flag\n * @property {Boolean} [all] If `true` matches all messages\n * @property {Boolean} [new] If `true` matches messages that have the \\\\Recent flag set but not the \\\\Seen flag\n * @property {Boolean} [old] If `true` matches messages that do not have the \\\\Recent flag set\n * @property {Boolean} [recent] If `true` matches messages that have the \\\\Recent flag set\n * @property {String} [from] Matches From: address field\n * @property {String} [to] Matches To: address field\n * @property {String} [cc] Matches Cc: address field\n * @property {String} [bcc] Matches Bcc: address field\n * @property {String} [body] Matches message body\n * @property {String} [subject] Matches message subject\n * @property {Number} [larger] Matches messages larger than value\n * @property {Number} [smaller] Matches messages smaller than value\n * @property {SequenceString} [uid] UID sequence range\n * @property {BigInt} [modseq] Matches messages with modseq higher than value\n * @property {String} [emailId] unique email ID. Only used if server supports `OBJECTID` or `X-GM-EXT-1` extensions\n * @property {String} [threadId] unique thread ID. Only used if server supports `OBJECTID` or `X-GM-EXT-1` extensions\n * @property {Date|string} [before] Matches messages received before date\n * @property {Date|string} [on] Matches messages received on date (ignores time)\n * @property {Date|string} [since] Matches messages received after date\n * @property {Date|string} [sentBefore] Matches messages sent before date\n * @property {Date|string} [sentOn] Matches messages sent on date (ignores time)\n * @property {Date|string} [sentSince] Matches messages sent after date\n * @property {String} [keyword] Matches messages that have the custom flag set\n * @property {String} [unKeyword] Matches messages that do not have the custom flag set\n * @property {Object.<string, Boolean|String>} [header] Matches messages with header key set if value is `true` (**NB!** not supported by all servers) or messages where header partially matches a string value\n * @property {SearchObject[]} [or] An array of 2 or more {@link SearchObject} objects. At least on of these must match\n */\n\n /**\n * Sets flags for a message or message range\n *\n * @param {SequenceString | Number[] | SearchObject} range Range to filter the messages\n * @param {string[]} Array of flags to set. Only flags that are permitted to set are used, other flags are ignored\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n * @param {BigInt} [options.unchangedSince] If set then only messages with a lower or equal `modseq` value are updated. Ignored if server does not support `CONDSTORE` extension.\n * @param {Boolean} [options.useLabels=false] If true then update Gmail labels instead of message flags\n * @returns {Promise<Boolean>} Did the operation succeed or not\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // mark all unseen messages as seen (and remove other flags)\n * await client.messageFlagsSet({seen: false}, ['\\Seen]);\n */\n async messageFlagsSet(range, flags, options) {\n options = options || {};\n\n range = await this.resolveRange(range, options);\n if (!range) {\n return false;\n }\n\n let queryOpts = Object.assign(\n {\n operation: 'set'\n },\n options\n );\n\n return await this.run('STORE', range, flags, queryOpts);\n }\n\n /**\n * Adds flags for a message or message range\n *\n * @param {SequenceString | Number[] | SearchObject} range Range to filter the messages\n * @param {string[]} Array of flags to set. Only flags that are permitted to set are used, other flags are ignored\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n * @param {BigInt} [options.unchangedSince] If set then only messages with a lower or equal `modseq` value are updated. Ignored if server does not support `CONDSTORE` extension.\n * @param {Boolean} [options.useLabels=false] If true then update Gmail labels instead of message flags\n * @returns {Promise<Boolean>} Did the operation succeed or not\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // mark all unseen messages as seen (and keep other flags as is)\n * await client.messageFlagsAdd({seen: false}, ['\\Seen]);\n */\n async messageFlagsAdd(range, flags, options) {\n options = options || {};\n\n range = await this.resolveRange(range, options);\n if (!range) {\n return false;\n }\n\n let queryOpts = Object.assign(\n {\n operation: 'add'\n },\n options\n );\n\n return await this.run('STORE', range, flags, queryOpts);\n }\n\n /**\n * Remove specific flags from a message or message range\n *\n * @param {SequenceString | Number[] | SearchObject} range Range to filter the messages\n * @param {string[]} Array of flags to remove. Only flags that are permitted to set are used, other flags are ignored\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n * @param {BigInt} [options.unchangedSince] If set then only messages with a lower or equal `modseq` value are updated. Ignored if server does not support `CONDSTORE` extension.\n * @param {Boolean} [options.useLabels=false] If true then update Gmail labels instead of message flags\n * @returns {Promise<Boolean>} Did the operation succeed or not\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // mark all seen messages as unseen by removing \\\\Seen flag\n * await client.messageFlagsRemove({seen: true}, ['\\Seen]);\n */\n async messageFlagsRemove(range, flags, options) {\n options = options || {};\n\n range = await this.resolveRange(range, options);\n if (!range) {\n return false;\n }\n\n let queryOpts = Object.assign(\n {\n operation: 'remove'\n },\n options\n );\n\n return await this.run('STORE', range, flags, queryOpts);\n }\n\n /**\n * Sets a colored flag for an email. Only supported by mail clients like Apple Mail\n *\n * @param {SequenceString | Number[] | SearchObject} range Range to filter the messages\n * @param {string} The color to set. One of 'red', 'orange', 'yellow', 'green', 'blue', 'purple', and 'grey'\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n * @param {BigInt} [options.unchangedSince] If set then only messages with a lower or equal `modseq` value are updated. Ignored if server does not support `CONDSTORE` extension.\n * @returns {Promise<Boolean>} Did the operation succeed or not\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // add a purple flag for all emails\n * await client.setFlagColor('1:*', 'Purple');\n */\n async setFlagColor(range, color, options) {\n options = options || {};\n\n range = await this.resolveRange(range, options);\n if (!range) {\n return false;\n }\n\n let flagChanges = getColorFlags(color);\n if (!flagChanges) {\n return false;\n }\n\n let addResults;\n let removeResults;\n\n if (flagChanges.add && flagChanges.add.length) {\n let queryOpts = Object.assign(\n {\n operation: 'add'\n },\n options,\n {\n useLabels: false, // override if set\n // prevent triggering a premature Flags change notification\n silent: flagChanges.remove && flagChanges.remove.length\n }\n );\n\n addResults = await this.run('STORE', range, flagChanges.add, queryOpts);\n }\n\n if (flagChanges.remove && flagChanges.remove.length) {\n let queryOpts = Object.assign(\n {\n operation: 'remove'\n },\n options,\n { useLabels: false } // override if set\n );\n\n removeResults = await this.run('STORE', range, flagChanges.remove, queryOpts);\n }\n\n return addResults || removeResults || false;\n }\n\n /**\n * Delete messages from the currently opened mailbox. Method does not indicate info about deleted messages,\n * instead you should be using {@link ImapFlow#expunge} event for this\n *\n * @param {SequenceString | Number[] | SearchObject} range Range to filter the messages\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n * @returns {Promise<Boolean>} Did the operation succeed or not\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // delete all seen messages\n * await client.messageDelete({seen: true});\n */\n async messageDelete(range, options) {\n options = options || {};\n range = await this.resolveRange(range, options);\n if (!range) {\n return false;\n }\n return await this.run('EXPUNGE', range, options);\n }\n\n /**\n * @typedef {Object} AppendResponseObject\n * @global\n * @property {String} destination full mailbox path where the message was uploaded to\n * @property {BigInt} [uidValidity] mailbox `UIDVALIDITY` if server has `UIDPLUS` extension enabled\n * @property {Number} [uid] UID of the uploaded message if server has `UIDPLUS` extension enabled\n * @property {Number} [seq] sequence number of the uploaded message if path is currently selected mailbox\n */\n\n /**\n * Appends a new message to a mailbox\n *\n * @param {String} path Mailbox path to upload the message to (unicode string)\n * @param {string|Buffer} content RFC822 formatted email message\n * @param {string[]} [flags] an array of flags to be set for the uploaded message\n * @param {Date|string} [idate=now] internal date to be set for the message\n * @returns {Promise<AppendResponseObject>} info about uploaded message\n *\n * @example\n * await client.append('INBOX', rawMessageBuffer, ['\\\\Seen'], new Date(2000, 1, 1));\n */\n async append(path, content, flags, idate) {\n let response = await this.run('APPEND', path, content, flags, idate);\n\n if (!response) {\n return false;\n }\n\n return response;\n }\n\n /**\n * @typedef {Object} CopyResponseObject\n * @global\n * @property {String} path path of source mailbox\n * @property {String} destination path of destination mailbox\n * @property {BigInt} [uidValidity] destination mailbox `UIDVALIDITY` if server has `UIDPLUS` extension enabled\n * @property {Map<number, number>} [uidMap] Map of UID values (if server has `UIDPLUS` extension enabled) where key is UID in source mailbox and value is the UID for the same message in destination mailbox\n */\n\n /**\n * Copies messages from current mailbox to destination mailbox\n *\n * @param {SequenceString | Number[] | SearchObject} range Range of messages to copy\n * @param {String} destination Mailbox path to copy the messages to\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n * @returns {Promise<CopyResponseObject>} info about copies messages\n *\n * @example\n * await client.mailboxOpen('INBOX');\n * // copy all messages to a mailbox called \"Backup\" (must exist)\n * let result = await client.messageCopy('1:*', 'Backup');\n * console.log('Copied %s messages', result.uidMap.size);\n */\n async messageCopy(range, destination, options) {\n options = options || {};\n range = await this.resolveRange(range, options);\n if (!range) {\n return false;\n }\n return await this.run('COPY', range, destination, options);\n }\n\n /**\n * Moves messages from current mailbox to destination mailbox\n *\n * @param {SequenceString | Number[] | SearchObject} range Range of messages to move\n * @param {String} destination Mailbox path to move the messages to\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n * @returns {Promise<CopyResponseObject>} info about moved messages\n *\n * @example\n * await client.mailboxOpen('INBOX');\n * // move all messages to a mailbox called \"Trash\" (must exist)\n * let result = await client.messageMove('1:*', 'Trash');\n * console.log('Moved %s messages', result.uidMap.size);\n */\n async messageMove(range, destination, options) {\n options = options || {};\n range = await this.resolveRange(range, options);\n if (!range) {\n return false;\n }\n return await this.run('MOVE', range, destination, options);\n }\n\n /**\n * Search messages from the currently opened mailbox\n *\n * @param {SearchObject} query Query to filter the messages\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then returns UID numbers instead of sequence numbers\n * @returns {Promise<Number[]>} An array of sequence or UID numbers\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // find all unseen messages\n * let list = await client.search({seen: false});\n * // use OR modifier (array of 2 or more search queries)\n * let list = await client.search({\n * seen: false,\n * or: [\n * {flagged: true},\n * {from: 'andris'},\n * {subject: 'test'}\n * ]});\n */\n async search(query, options) {\n if (!this.mailbox) {\n // no mailbox selected, nothing to do\n return;\n }\n\n let response = await this.run('SEARCH', query, options);\n\n if (!response) {\n return false;\n }\n\n return response;\n }\n\n /**\n * @typedef {Object} FetchQueryObject\n * @global\n * @property {Boolean} [uid] if `true` then include UID in the response\n * @property {Boolean} [flags] if `true` then include flags Set in the response. Also adds `flagColor` to the response if the message is flagged.\n * @property {Boolean} [bodyStructure] if `true` then include parsed BODYSTRUCTURE object in the response\n * @property {Boolean} [envelope] if `true` then include parsed ENVELOPE object in the response\n * @property {Boolean} [internalDate] if `true` then include internal date value in the response\n * @property {Boolean} [size] if `true` then include message size in the response\n * @property {boolean | Object} [source] if `true` then include full message in the response\n * @property {Number} [source.start] include full message in the response starting from *start* byte\n * @property {Number} [source.maxLength] include full message in the response, up to *maxLength* bytes\n * @property {String} [threadId] if `true` then include thread ID in the response (only if server supports either `OBJECTID` or `X-GM-EXT-1` extensions)\n * @property {Boolean} [labels] if `true` then include GMail labels in the response (only if server supports `X-GM-EXT-1` extension)\n * @property {boolean | string[]} [headers] if `true` then includes full headers of the message in the response. If the value is an array of header keys then includes only headers listed in the array\n * @property {string[]} [bodyParts] An array of BODYPART identifiers to include in the response\n */\n\n /**\n * Parsed email address entry\n *\n * @typedef {Object} MessageAddressObject\n * @global\n * @property {String} [name] name of the address object (unicode)\n * @property {String} [address] email address\n */\n\n /**\n * Parsed IMAP ENVELOPE object\n *\n * @typedef {Object} MessageEnvelopeObject\n * @global\n * @property {Date} [date] header date\n * @property {String} [subject] message subject (unicode)\n * @property {String} [messageId] Message ID of the message\n * @property {String} [inReplyTo] Message ID from In-Reply-To header\n * @property {MessageAddressObject[]} [from] Array of addresses from the From: header\n * @property {MessageAddressObject[]} [sender] Array of addresses from the Sender: header\n * @property {MessageAddressObject[]} [replyTo] Array of addresses from the Reply-To: header\n * @property {MessageAddressObject[]} [to] Array of addresses from the To: header\n * @property {MessageAddressObject[]} [cc] Array of addresses from the Cc: header\n * @property {MessageAddressObject[]} [bcc] Array of addresses from the Bcc: header\n */\n\n /**\n * Parsed IMAP BODYSTRUCTURE object\n *\n * @typedef {Object} MessageStructureObject\n * @global\n * @property {String} part Body part number. This value can be used to later fetch the contents of this part of the message\n * @property {String} type Content-Type of this node\n * @property {Object} [parameters] Additional parameters for Content-Type, eg \"charset\"\n * @property {String} [id] Content-ID\n * @property {String} [encoding] Transfer encoding\n * @property {Number} [size] Expected size of the node\n * @property {MessageEnvelopeObject} [envelope] message envelope of embedded RFC822 message\n * @property {String} [disposition] Content disposition\n * @property {Object} [dispositionParameters] Additional parameters for Content-Disposition\n * @property {MessageStructureObject[]} childNodes An array of child nodes if this is a multipart node. Not present for normal nodes\n */\n\n /**\n * Fetched message data\n *\n * @typedef {Object} FetchMessageObject\n * @global\n * @property {Number} seq message sequence number. Always included in the response\n * @property {Number} uid message UID number. Always included in the response\n * @property {Buffer} [source] message source for the requested byte range\n * @property {BigInt} [modseq] message Modseq number. Always included if the server supports CONDSTORE extension\n * @property {String} [emailId] unique email ID. Always included if server supports `OBJECTID` or `X-GM-EXT-1` extensions\n * @property {String} [threadid] unique thread ID. Only present if server supports `OBJECTID` or `X-GM-EXT-1` extension\n * @property {Set<string>} [labels] a Set of labels. Only present if server supports `X-GM-EXT-1` extension\n * @property {Number} [size] message size\n * @property {Set<string>} [flags] a set of message flags\n * @property {String} [flagColor] flag color like \"red\", or \"yellow\". This value is derived from the `flags` Set and it uses the same color rules as Apple Mail\n * @property {MessageEnvelopeObject} [envelope] message envelope\n * @property {MessageStructureObject} [bodyStructure] message body structure\n * @property {Date} [internalDate] message internal date\n * @property {Map<string, Buffer>} [bodyParts] a Map of message body parts where key is requested part identifier and value is a Buffer\n * @property {Buffer} [headers] Requested header lines as Buffer\n */\n\n /**\n * Fetch messages from the currently opened mailbox\n *\n * @param {SequenceString | Number[] | SearchObject} range Range of messages to fetch\n * @param {FetchQueryObject} query Fetch query\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID numbers instead of sequence numbers for `range`\n * @param {BigInt} [options.changedSince] If set then only messages with a higher modseq value are returned. Ignored if server does not support `CONDSTORE` extension.\n * @param {Boolean} [options.binary=false] If `true` then requests a binary response if the server supports this\n * @yields {Promise<FetchMessageObject>} Message data object\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // fetch UID for all messages in a mailbox\n * for await (let msg of client.fetch('1:*', {uid: true})){\n * console.log(msg.uid);\n * // NB! You can not run any IMAP commands in this loop\n * // otherwise you will end up in a deadloop\n * }\n */\n async *fetch(range, query, options) {\n options = options || {};\n\n if (!this.mailbox) {\n // no mailbox selected, nothing to do\n return;\n }\n\n range = await this.resolveRange(range, options);\n if (!range) {\n return false;\n }\n\n let finished = false;\n let push = false;\n let rowQueue = [];\n\n let getNext = () =>\n new Promise((resolve, reject) => {\n let check = () => {\n if (rowQueue.length) {\n let entry = rowQueue.shift();\n if (entry.err) {\n return reject(entry.err);\n } else {\n return resolve(entry.value);\n }\n }\n\n if (finished) {\n return resolve(null);\n }\n\n // wait until data is pushed to queue and try again\n push = () => {\n push = false;\n check();\n };\n };\n check();\n });\n\n this.run('FETCH', range, query, {\n uid: !!options.uid,\n binary: options.binary,\n changedSince: options.changedSince,\n onUntaggedFetch: (untagged, next) => {\n rowQueue.push({\n value: {\n response: untagged,\n next\n }\n });\n if (typeof push === 'function') {\n push();\n }\n }\n })\n .then(() => {\n finished = true;\n if (typeof push === 'function') {\n push();\n }\n })\n .catch(err => {\n rowQueue.push({ err });\n if (typeof push === 'function') {\n push();\n }\n });\n\n let res;\n while ((res = await getNext())) {\n if (this.isClosed || this.socket.destroyed) {\n let error = new Error('Connection closed');\n error.code = 'EConnectionClosed';\n throw error;\n }\n\n if (res !== null) {\n yield res.response;\n res.next();\n }\n }\n\n if (!finished) {\n // FETCH never finished!\n let error = new Error('FETCH did not finish');\n error.code = 'ENotFinished';\n throw error;\n }\n }\n\n /**\n * Fetch messages from the currently opened mailbox.\n *\n * This method will fetch all messages before resolving the promise, unlike .fetch(), which\n * is an async generator. Do not use large ranges like 1:*, as this might exhaust all available\n * memory if the mailbox contains a large number of emails.\n * @param {SequenceString | Number[] | SearchObject} range Range of messages to fetch\n * @param {FetchQueryObject} query Fetch query\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID numbers instead of sequence numbers for `range`\n * @param {BigInt} [options.changedSince] If set then only messages with a higher modseq value are returned. Ignored if server does not support `CONDSTORE` extension.\n * @param {Boolean} [options.binary=false] If `true` then requests a binary response if the server supports this\n * @returns {Promise<FetchMessageObject[]>} Array of Message data object\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // fetch UID for all messages in a mailbox\n * const messages = await client.fetchAll('1:*', {uid: true});\n * for (let msg of messages){\n * console.log(msg.uid);\n * }\n */\n async fetchAll(range, query, options) {\n const results = [];\n const generator = this.fetch(range, query, options);\n for await (const message of generator) {\n results.push(message);\n }\n return results;\n }\n\n /**\n * Fetch a single message from the currently opened mailbox\n *\n * @param {SequenceString} seq Single UID or sequence number of the message to fetch for\n * @param {FetchQueryObject} query Fetch query\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID number instead of sequence number for `seq`\n * @param {Boolean} [options.binary=false] If `true` then requests a binary response if the server supports this\n * @returns {Promise<FetchMessageObject>} Message data object\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // fetch UID for the last email in the selected mailbox\n * let lastMsg = await client.fetchOne('*', {uid: true})\n * console.log(lastMsg.uid);\n */\n async fetchOne(seq, query, options) {\n if (!this.mailbox) {\n // no mailbox selected, nothing to do\n return;\n }\n\n if (seq === '*') {\n if (!this.mailbox.exists) {\n return false;\n }\n seq = this.mailbox.exists.toString();\n options = Object.assign({}, options || {}, { uid: false }); // force into a sequence query\n }\n\n let response = await this.run('FETCH', (seq || '').toString(), query, options);\n\n if (!response || !response.list || !response.list.length) {\n return false;\n }\n\n return response.list[0];\n }\n\n /**\n * @typedef {Object} DownloadObject\n * @global\n * @property {Object} meta content metadata\n * @property {number} meta.expectedSize The fetch response size\n * @property {String} meta.contentType Content-Type of the streamed file. If part was not set then this value is \"message/rfc822\"\n * @property {String} [meta.charset] Charset of the body part. Text parts are automatically converted to UTF-8, attachments are kept as is\n * @property {String} [meta.disposition] Content-Disposition of the streamed file\n * @property {String} [meta.filename] Filename of the streamed body part\n * @property {ReadableStream} content Streamed content\n */\n\n /**\n * Download either full rfc822 formatted message or a specific bodystructure part as a Stream.\n * Bodystructure parts are decoded so the resulting stream is a binary file. Text content\n * is automatically converted to UTF-8 charset.\n *\n * @param {SequenceString} range UID or sequence number for the message to fetch\n * @param {String} [part] If not set then downloads entire rfc822 formatted message, otherwise downloads specific bodystructure part\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID number instead of sequence number for `range`\n * @param {number} [options.maxBytes] If set then limits download size to specified bytes\n * @param {number} [options.chunkSize=65536] How large content parts to ask from the server\n * @returns {Promise<DownloadObject>} Download data object\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // download body part nr '1.2' from latest message\n * let {meta, content} = await client.download('*', '1.2');\n * content.pipe(fs.createWriteStream(meta.filename));\n */\n async download(range, part, options) {\n if (!this.mailbox) {\n // no mailbox selected, nothing to do\n return {};\n }\n\n options = Object.assign(\n {\n chunkSize: 64 * 1024,\n maxBytes: Infinity\n },\n options || {}\n );\n\n let hasMore = true;\n let processed = 0;\n\n let chunkSize = Number(options.chunkSize) || 64 * 1024;\n let maxBytes = Number(options.maxBytes) || Infinity;\n\n let uid = false;\n\n if (part === '1') {\n // First part has special conditions for single node emails as\n // the mime parts for root node are not 1 and 1.MIME but TEXT and HEADERS\n let response = await this.fetchOne(range, { uid: true, bodyStructure: true }, options);\n\n if (!response) {\n return { response: false, chunk: false };\n }\n\n if (!uid && response.uid) {\n uid = response.uid;\n // force UID from now on even if first range was a sequence number\n range = uid;\n options.uid = true;\n }\n\n if (!response.bodyStructure.childNodes) {\n // single text message\n part = 'TEXT';\n }\n }\n\n let getNextPart = async query => {\n query = query || {};\n\n let mimeKey;\n\n if (!part) {\n query.source = {\n start: processed,\n maxLength: chunkSize\n };\n } else {\n part = part.toString().toLowerCase().trim();\n\n if (!query.bodyParts) {\n query.bodyParts = [];\n }\n\n if (query.size) {\n if (/^[\\d.]+$/.test(part)) {\n // fetch meta as well\n mimeKey = part + '.mime';\n query.bodyParts.push(mimeKey);\n } else if (part === 'text') {\n mimeKey = 'header';\n query.bodyParts.push(mimeKey);\n }\n }\n\n query.bodyParts.push({\n key: part,\n start: processed,\n maxLength: chunkSize\n });\n }\n\n let response = await this.fetchOne(range, query, options);\n\n if (!response) {\n return { response: false, chunk: false };\n }\n\n if (!uid && response.uid) {\n uid = response.uid;\n // force UID from now on even if first range was a sequence number\n range = uid;\n options.uid = true;\n }\n\n let chunk = !part ? response.source : response.bodyParts && response.bodyParts.get(part);\n if (!chunk) {\n return {};\n }\n\n processed += chunk.length;\n hasMore = chunk.length >= chunkSize;\n\n let result = { chunk };\n if (query.size) {\n result.response = response;\n }\n\n if (query.bodyParts) {\n if (mimeKey === 'header') {\n result.mime = response.headers;\n } else {\n result.mime = response.bodyParts.get(mimeKey);\n }\n }\n\n return result;\n };\n\n let { response, chunk, mime } = await getNextPart({\n size: true,\n uid: true\n });\n\n if (!response || !chunk) {\n // ???\n return {};\n }\n\n let meta = {\n expectedSize: response.size\n };\n\n if (!part) {\n meta.contentType = 'message/rfc822';\n } else if (mime) {\n let headers = new Headers(mime);\n let contentType = libmime.parseHeaderValue(headers.getFirst('Content-Type'));\n let transferEncoding = libmime.parseHeaderValue(headers.getFirst('Content-Transfer-Encoding'));\n let disposition = libmime.parseHeaderValue(headers.getFirst('Content-Disposition'));\n\n if (contentType.value.toLowerCase().trim()) {\n meta.contentType = contentType.value.toLowerCase().trim();\n }\n\n if (contentType.params.charset) {\n meta.charset = contentType.params.charset.toLowerCase().trim();\n }\n\n if (transferEncoding.value) {\n meta.encoding = transferEncoding.value\n .replace(/\\(.*\\)/g, '')\n .toLowerCase()\n .trim();\n }\n\n if (disposition.value) {\n meta.disposition = disposition.value.toLowerCase().trim() || false;\n try {\n meta.disposition = libmime.decodeWords(meta.disposition);\n } catch (err) {\n // failed to parse disposition, keep as is (most probably an unknown charset is used)\n }\n }\n\n if (contentType.params.format && contentType.params.format.toLowerCase().trim() === 'flowed') {\n meta.flowed = true;\n if (contentType.params.delsp && contentType.params.delsp.toLowerCase().trim() === 'yes') {\n meta.delSp = true;\n }\n }\n\n let filename = disposition.params.filename || contentType.params.name || false;\n if (filename) {\n try {\n filename = libmime.decodeWords(filename);\n } catch (err) {\n // failed to parse filename, keep as is (most probably an unknown charset is used)\n }\n meta.filename = filename;\n }\n }\n\n let stream;\n let output;\n\n switch (meta.encoding) {\n case 'base64':\n output = stream = new libbase64.Decoder();\n break;\n case 'quoted-printable':\n output = stream = new libqp.Decoder();\n break;\n default:\n output = stream = new PassThrough();\n }\n\n let isTextNode = ['text/html', 'text/plain', 'text/x-amp-html'].includes(meta.contentType) || (part === '1' && !meta.contentType);\n if ((!meta.disposition || meta.disposition === 'inline') && isTextNode) {\n // flowed text\n if (meta.flowed) {\n let flowDecoder = new FlowedDecoder({\n delSp: meta.delSp\n });\n output.on('error', err => {\n flowDecoder.emit('error', err);\n });\n output = output.pipe(flowDecoder);\n }\n\n // not utf-8 text\n if (meta.charset && !['ascii', 'usascii', 'utf8'].includes(meta.charset.toLowerCase().replace(/[^a-z0-9]+/g, ''))) {\n try {\n let decoder = getDecoder(meta.charset);\n output.on('error', err => {\n decoder.emit('error', err);\n });\n output = output.pipe(decoder);\n // force to utf-8 for output\n meta.charset = 'utf-8';\n } catch (E) {\n // do not decode charset\n }\n }\n }\n\n let limiter = new LimitedPassthrough({ maxBytes });\n output.on('error', err => {\n limiter.emit('error', err);\n });\n output = output.pipe(limiter);\n\n let writeChunk = chunk => {\n if (limiter.limited) {\n return true;\n }\n return stream.write(chunk);\n };\n\n let fetchAllParts = async () => {\n while (hasMore && !limiter.limited) {\n let { chunk } = await getNextPart();\n if (!chunk) {\n break;\n }\n\n if (writeChunk(chunk) === false) {\n await new Promise(resolve => stream.once('drain', resolve));\n }\n }\n };\n\n setImmediate(() => {\n writeChunk(chunk);\n fetchAllParts()\n .catch(err => stream.emit('error', err))\n .finally(() => stream.end());\n });\n\n return {\n meta,\n content: output\n };\n }\n\n /**\n * Fetch multiple attachments as Buffer values\n *\n * @param {SequenceString} range UID or sequence number for the message to fetch\n * @param {String} parts A list of bodystructure parts\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID number instead of sequence number for `range`\n * @returns {Promise<Object>} Download data object\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // download body parts '2', and '3' from all messages in the selected mailbox\n * let response = await client.downloadMany('*', ['2', '3']);\n * process.stdout.write(response[2].content)\n * process.stdout.write(response[3].content)\n */\n async downloadMany(range, parts, options) {\n if (!this.mailbox) {\n // no mailbox selected, nothing to do\n return {};\n }\n\n options = Object.assign(\n {\n chunkSize: 64 * 1024,\n maxBytes: Infinity\n },\n options || {}\n );\n\n let query = { bodyParts: [] };\n\n for (let part of parts) {\n query.bodyParts.push(part + '.mime');\n query.bodyParts.push(part);\n }\n\n let response = await this.fetchOne(range, query, options);\n\n if (!response || !response.bodyParts) {\n return { response: false };\n }\n\n let data = {};\n\n for (let [part, content] of response.bodyParts) {\n let keyParts = part.split('.mime');\n if (keyParts.length === 1) {\n // content\n let key = keyParts[0];\n if (!data[key]) {\n data[key] = { content };\n } else {\n data[key].content = content;\n }\n } else if (keyParts.length === 2) {\n // header\n let key = keyParts[0];\n if (!data[key]) {\n data[key] = {};\n }\n if (!data[key].meta) {\n data[key].meta = {};\n }\n\n let headers = new Headers(content);\n let contentType = libmime.parseHeaderValue(headers.getFirst('Content-Type'));\n let transferEncoding = libmime.parseHeaderValue(headers.getFirst('Content-Transfer-Encoding'));\n let disposition = libmime.parseHeaderValue(headers.getFirst('Content-Disposition'));\n\n if (contentType.value.toLowerCase().trim()) {\n data[key].meta.contentType = contentType.value.toLowerCase().trim();\n }\n\n if (contentType.params.charset) {\n data[key].meta.charset = contentType.params.charset.toLowerCase().trim();\n }\n\n if (transferEncoding.value) {\n data[key].meta.encoding = transferEncoding.value\n .replace(/\\(.*\\)/g, '')\n .toLowerCase()\n .trim();\n }\n\n if (disposition.value) {\n data[key].meta.disposition = disposition.value.toLowerCase().trim() || false;\n try {\n data[key].meta.disposition = libmime.decodeWords(data[key].meta.disposition);\n } catch (err) {\n // failed to parse disposition, keep as is (most probably an unknown charset is used)\n }\n }\n\n if (contentType.params.format && contentType.params.format.toLowerCase().trim() === 'flowed') {\n data[key].meta.flowed = true;\n if (contentType.params.delsp && contentType.params.delsp.toLowerCase().trim() === 'yes') {\n data[key].meta.delSp = true;\n }\n }\n\n let filename = disposition.params.filename || contentType.params.name || false;\n if (filename) {\n try {\n filename = libmime.decodeWords(filename);\n } catch (err) {\n // failed to parse filename, keep as is (most probably an unknown charset is used)\n }\n data[key].meta.filename = filename;\n }\n }\n }\n\n for (let part of Object.keys(data)) {\n let meta = data[part].meta;\n\n switch (meta.encoding) {\n case 'base64':\n data[part].content = data[part].content ? libbase64.decode(data[part].content.toString()) : null;\n break;\n case 'quoted-printable':\n data[part].content = data[part].content ? libqp.decode(data[part].content.toString()) : null;\n break;\n default:\n // keep as is, already a buffer\n }\n }\n\n return data;\n }\n\n async run(command, ...args) {\n command = command.toUpperCase();\n if (!this.commands.has(command)) {\n return false;\n }\n\n if (this.socket.destroyed) {\n const error = new Error('Connection not available');\n error.code = 'NoConnection';\n throw error;\n }\n\n clearTimeout(this.idleStartTimer);\n\n if (typeof this.preCheck === 'function') {\n await this.preCheck();\n }\n\n let handler = this.commands.get(command);\n\n let result = await handler(this, ...args);\n\n if (command !== 'IDLE') {\n // do not autostart IDLE, if IDLE itself was stopped\n this.autoidle();\n }\n\n return result;\n }\n\n async processLocks(force) {\n if (!force && this.processingLock) {\n this.log.trace({\n msg: 'Mailbox locking queued',\n path: this.mailbox && this.mailbox.path,\n pending: this.locks.length,\n idling: this.idling,\n activeLock: this.currentLock\n ? {\n lockId: this.currentLock.lockId,\n ...(this.currentLock.options?.description && { description: this.currentLock.options?.description })\n }\n : null\n });\n return;\n }\n\n if (!this.locks.length) {\n this.processingLock = false;\n this.log.trace({\n msg: 'Mailbox locking queue processed',\n idling: this.idling\n });\n return;\n }\n\n this.processingLock = true;\n\n const release = () => {\n if (this.currentLock) {\n this.log.trace({\n msg: 'Mailbox lock released',\n lockId: this.currentLock.lockId,\n path: this.mailbox && this.mailbox.path,\n pending: this.locks.length,\n idling: this.idling\n });\n this.currentLock = false;\n }\n this.processLocks(true).catch(err => this.log.error({ err, cid: this.id }));\n };\n\n const lock = this.locks.shift();\n const { resolve, reject, path, options, lockId } = lock;\n\n if (!this.usable || this.socket.destroyed) {\n this.log.trace({ msg: 'Failed to acquire mailbox lock', path, lockId, idling: this.idling });\n // reject all\n let error = new Error('Connection not available');\n error.code = 'NoConnection';\n reject(error);\n return await this.processLocks(true);\n }\n\n if (this.mailbox && this.mailbox.path === path && !!this.mailbox.readOnly === !!options.readOnly) {\n // nothing to do here, already selected\n this.log.trace({\n msg: 'Mailbox lock acquired [existing]',\n path,\n lockId,\n idling: this.idling,\n ...(options.description && { description: options.description })\n });\n this.currentLock = lock;\n return resolve({ path, release });\n } else {\n try {\n // Try to open. Throws if mailbox does not exists or can't open\n await this.mailboxOpen(path, options);\n this.log.trace({\n msg: 'Mailbox lock acquired [selected]',\n path,\n lockId,\n idling: this.idling,\n ...(options.description && { description: options.description })\n });\n this.currentLock = lock;\n return resolve({ path, release });\n } catch (err) {\n if (err.responseStatus === 'NO') {\n try {\n let folders = await this.run('LIST', '', path, { listOnly: true });\n if (!folders || !folders.length) {\n err.mailboxMissing = true;\n }\n } catch (E) {\n this.log.trace({ msg: 'Failed to verify failed mailbox', path, err: E });\n }\n }\n\n this.log.trace({\n msg: 'Failed to acquire mailbox lock',\n path,\n lockId,\n idling: this.idling,\n ...(options.description && { description: options.description }),\n err\n });\n reject(err);\n await this.processLocks(true);\n }\n }\n }\n\n /**\n * Opens a mailbox if not already open and returns a lock. Next call to `getMailboxLock()` is queued\n * until previous lock is released. This is suggested over {@link module:imapflow~ImapFlow#mailboxOpen|mailboxOpen()} as\n * `getMailboxLock()` gives you a weak transaction while `mailboxOpen()` has no guarantees whatsoever that another\n * mailbox is opened while you try to call multiple fetch or store commands.\n *\n * @param {string|array} path **Path for the mailbox** to open\n * @param {Object} [options] optional options\n * @param {Boolean} [options.readOnly=false] If `true` then opens mailbox in read-only mode. You can still try to perform write operations but these would probably fail.\n * @returns {Promise<MailboxLockObject>} Mailbox lock\n * @throws Will throw an error if mailbox does not exist or can not be opened\n *\n * @example\n * let lock = await client.getMailboxLock('INBOX');\n * try {\n * // do something in the mailbox\n * } finally {\n * // use finally{} to make sure lock is released even if exception occurs\n * lock.release();\n * }\n */\n async getMailboxLock(path, options) {\n options = options || {};\n\n path = normalizePath(this, path);\n\n let lockId = ++this.lockCounter;\n this.log.trace({\n msg: 'Requesting lock',\n path,\n lockId,\n ...(options.description && { description: options.description }),\n activeLock: this.currentLock\n ? {\n lockId: this.currentLock.lockId,\n ...(this.currentLock.options?.description && { description: this.currentLock.options?.description })\n }\n : null\n });\n\n return await new Promise((resolve, reject) => {\n this.locks.push({ resolve, reject, path, options, lockId });\n this.processLocks().catch(err => reject(err));\n });\n }\n\n getLogger() {\n let mainLogger =\n this.options.logger && typeof this.options.logger === 'object'\n ? this.options.logger\n : logger.child({\n component: 'imap-connection',\n cid: this.id\n });\n\n let synteticLogger = {};\n let levels = ['trace', 'debug', 'info', 'warn', 'error', 'fatal'];\n for (let level of levels) {\n synteticLogger[level] = (...args) => {\n // using {logger:false} disables logging\n if (this.options.logger !== false) {\n if (logger)\n if (typeof mainLogger[level] !== 'function') {\n // we are checking to make sure the level is supported.\n // if it isn't supported but the level is error or fatal, log to console anyway.\n if (level === 'fatal' || level === 'error') {\n console.log(JSON.stringify(...args));\n }\n } else {\n mainLogger[level](...args);\n }\n }\n\n if (this.emitLogs && args && args[0] && typeof args[0] === 'object') {\n let logEntry = Object.assign({ level, t: Date.now(), cid: this.id, lo: ++this.lo }, args[0]);\n if (logEntry.err && typeof logEntry.err === 'object') {\n let err = logEntry.err;\n logEntry.err = {\n stack: err.stack\n };\n // enumerable error fields\n Object.keys(err).forEach(key => {\n logEntry.err[key] = err[key];\n });\n }\n this.emit('log', logEntry);\n }\n };\n }\n\n return synteticLogger;\n }\n\n unbind() {\n this.socket.unpipe(this.streamer);\n if (this._inflate) {\n this._inflate.unpipe(this.streamer);\n }\n\n this.socket.removeListener('error', this._socketError);\n this.socket.removeListener('close', this._socketClose);\n this.socket.removeListener('end', this._socketEnd);\n this.socket.removeListener('tlsClientError', this._socketError);\n this.socket.removeListener('timeout', this._socketTimeout);\n\n return {\n readSocket: this._inflate || this.socket,\n writeSocket: this.writeSocket || this.socket\n };\n }\n}\n\n/**\n * Connection close event. **NB!** ImapFlow does not handle reconnects automatically.\n * So whenever a 'close' event occurs you must create a new connection yourself.\n *\n * @event module:imapflow~ImapFlow#close\n */\n\n/**\n * Error event. In most cases getting an error event also means that connection is closed\n * and pending operations should return with a failure.\n *\n * @event module:imapflow~ImapFlow#error\n * @type {Error}\n * @example\n * client.on('error', err=>{\n * console.log(`Error occurred: ${err.message}`);\n * });\n */\n\n/**\n * Message count in currently opened mailbox changed\n *\n * @event module:imapflow~ImapFlow#exists\n * @type {Object}\n * @property {String} path mailbox path this event applies to\n * @property {Number} count updated count of messages\n * @property {Number} prevCount message count before this update\n * @example\n * client.on('exists', data=>{\n * console.log(`Message count in \"${data.path}\" is ${data.count}`);\n * });\n */\n\n/**\n * Deleted message sequence number in currently opened mailbox. One event is fired for every deleted email.\n *\n * @event module:imapflow~ImapFlow#expunge\n * @type {Object}\n * @property {String} path mailbox path this event applies to\n * @property {Number} seq sequence number of deleted message\n * @example\n * client.on('expunge', data=>{\n * console.log(`Message #${data.seq} was deleted from \"${data.path}\"`);\n * });\n */\n\n/**\n * Flags were updated for a message. Not all servers fire this event.\n *\n * @event module:imapflow~ImapFlow#flags\n * @type {Object}\n * @property {String} path mailbox path this event applies to\n * @property {Number} seq sequence number of updated message\n * @property {Number} [uid] UID number of updated message (if server provided this value)\n * @property {BigInt} [modseq] Updated modseq number for the mailbox (if server provided this value)\n * @property {Set<string>} flags A set of all flags for the updated message\n * @example\n * client.on('flags', data=>{\n * console.log(`Flag set for #${data.seq} is now \"${Array.from(data.flags).join(', ')}\"`);\n * });\n */\n\n/**\n * Mailbox was opened\n *\n * @event module:imapflow~ImapFlow#mailboxOpen\n * @type {MailboxObject}\n * @example\n * client.on('mailboxOpen', mailbox => {\n * console.log(`Mailbox ${mailbox.path} was opened`);\n * });\n */\n\n/**\n * Mailbox was closed\n *\n * @event module:imapflow~ImapFlow#mailboxClose\n * @type {MailboxObject}\n * @example\n * client.on('mailboxClose', mailbox => {\n * console.log(`Mailbox ${mailbox.path} was closed`);\n * });\n */\n\n/**\n * Log event if `emitLogs=true`\n *\n * @event module:imapflow~ImapFlow#log\n * @type {Object}\n * @example\n * client.on('log', entry => {\n * console.log(`${log.cid} ${log.msg}`);\n * });\n */\n\nmodule.exports.ImapFlow = ImapFlow;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/imapflow/lib/imap-flow.js","mappings":"AAAa;;AAEb;AACA;AACA;;AAEA;AACA;AACA;;AAEA,YAAY,mBAAO,CAAC,gBAAK;AACzB,YAAY,mBAAO,CAAC,gBAAK;AACzB,eAAe,mBAAO,CAAC,sBAAQ;AAC/B,QAAQ,eAAe,EAAE,mBAAO,CAAC,sBAAQ;AACzC,eAAe,mBAAO,CAAC,wEAAU;AACjC,gBAAgB,mBAAO,CAAC,uEAAS;AACjC,aAAa,mBAAO,CAAC,kBAAM;AAC3B,QAAQ,UAAU,EAAE,mBAAO,CAAC,2FAAW;AACvC,QAAQ,qBAAqB,EAAE,mBAAO,CAAC,kGAAuB;;AAE9D,QAAQ,aAAa,EAAE,mBAAO,CAAC,kGAAuB;AACtD,QAAQ,mBAAmB,EAAE,mBAAO,CAAC,oGAAwB;AAC7D,oBAAoB,mBAAO,CAAC,8EAAiB;;AAE7C,cAAc,mBAAO,CAAC,iEAAO;AAC7B,kBAAkB,mBAAO,CAAC,6EAAW;AACrC,sBAAsB,mBAAO,CAAC,2HAA8B;AAC5D,QAAQ,cAAc,EAAE,mBAAO,CAAC,sBAAQ;;AAExC,QAAQ,kBAAkB,EAAE,mBAAO,CAAC,4FAAoB;;AAExD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,EAAE,EAAE,mBAAO,CAAC,sEAAS;;AAErB,qBAAqB,mBAAO,CAAC,yFAAoB;;AAEjD;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,aAAa,QAAQ;AACrB;AACA,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,aAAa;AAC3B,cAAc,QAAQ;AACtB,cAAc,SAAS;AACvB,cAAc,SAAS;AACvB,cAAc,aAAa;AAC3B,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB;;AAEA;AACA,aAAa,QAAQ;AACrB;AACA,cAAc,QAAQ;AACtB,cAAc,UAAU;AACxB;AACA;AACA;AACA;AACA,KAAK;AACL,sBAAsB;AACtB;AACA;AACA;;AAEA;AACA;AACA,aAAa,QAAQ;AACrB;AACA,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,MAAM;AACpB;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA;;AAEA;AACA;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA,kBAAkB,QAAQ;AAC1B,+EAA+E,cAAc;AAC7F;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA;AACA,kBAAkB,cAAc;AAChC;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,gBAAgB;AAClC;AACA;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;;AAEA;AACA,gBAAgB,yBAAyB;;AAEzC;;AAEA;AACA;AACA,kBAAkB;AAClB;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA,gCAAgC;;AAEhC;;AAEA;AACA;AACA,kBAAkB;AAClB;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;;AAEA;;AAEA,6CAA6C;;AAE7C;AACA;AACA,kBAAkB;AAClB;AACA;;AAEA;AACA;AACA,kBAAkB;AAClB;AACA;;AAEA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;;AAEA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;;AAEA;AACA;AACA,kBAAkB;AAClB;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,6BAA6B,mBAAmB;AAChD;AACA;AACA,SAAS;;AAET;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA,UAAU;AACV;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA,SAAS;;AAET;;AAEA,yBAAyB,+EAA+E;;AAExG;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA,0CAA0C,+CAA+C;AACzF,qCAAqC,mCAAmC;AACxE;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,sDAAsD,yBAAyB;AAC/E;AACA,oCAAoC;;AAEpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA,iCAAiC,2DAA2D;AAC5F;AACA;AACA;;AAEA;AACA;AACA,aAAa;;AAEb;AACA;AACA,iCAAiC,gGAAgG;AACjI,cAAc;AACd,iCAAiC,gGAAgG;AACjI;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,iCAAiC,qBAAqB,eAAe,kCAAkC;AACvG;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB,wCAAwC,mBAAmB;AAC3D;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,uEAAuE,iCAAiC;AACxG;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC;AACrC;AACA,0BAA0B;AAC1B;AACA;;AAEA;AACA;;AAEA;AACA;AACA,gDAAgD,kDAAkD;AAClG,+EAA+E,iCAAiC;AAChH;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,gDAAgD,6EAA6E;AAC7H;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,mDAAmD,mBAAmB;AACtE;AACA;AACA,qBAAqB;AACrB;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,iCAAiC,mBAAmB;AACpD;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,aAAa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB;AAClB,qCAAqC,qCAAqC;AAC1E;AACA;AACA,aAAa;;AAEb;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,oBAAoB;AACpB;;AAEA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd,iCAAiC,iEAAiE;AAClG;AACA;AACA;;AAEA;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,iBAAiB,SAAS;AAC1B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;;AAEA;AACA,aAAa;;AAEb;;AAEA;AACA,SAAS;;AAET;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,0FAA0F,4CAA4C;AACtI,UAAU;AACV;AACA,8FAA8F,+CAA+C;AAC7I,cAAc;AACd;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,iCAAiC,mBAAmB;;AAEpD;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,aAAa;AACb;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,iCAAiC,mBAAmB;;AAEpD;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,aAAa;AACb;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,kBAAkB;AAClB,qCAAqC,0EAA0E;AAC/G;AACA,cAAc;AACd;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,kBAAkB;AAClB,qCAAqC,0EAA0E;AAC/G;AACA,cAAc;AACd;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC;AACjC;;AAEA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA,cAAc;AACd;AACA,oCAAoC;AACpC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,qDAAqD,mBAAmB;AACxE,SAAS;AACT;;AAEA;;AAEA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,kCAAkC,IAAI;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA,iCAAiC,qBAAqB;AACtD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,mBAAmB;AACpD;AACA;AACA,aAAa;;AAEb;AACA;AACA;AACA;;AAEA;AACA,kGAAkG,wDAAwD;AAC1J;AACA;AACA;AACA;AACA,qCAAqC,mBAAmB;AACxD;AACA;AACA,iBAAiB;;AAEjB;;AAEA;AACA;AACA,wCAAwC,0BAA0B;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,iCAAiC,mBAAmB;AACpD;AACA,aAAa;;AAEb;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA,gBAAgB;AAChB;AACA,kCAAkC,IAAI;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,kCAAkC,IAAI;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,uCAAuC;AACnF;AACA;AACA;;AAEA;AACA,yDAAyD,mBAAmB;AAC5E;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,cAAc;AACd,iCAAiC,mBAAmB;AACpD;AACA;;AAEA;AACA;AACA;AACA,cAAc;AACd,iCAAiC,mBAAmB;AACpD;AACA;;AAEA,yBAAyB,wCAAwC;AACjE;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B;;AAEA;AACA;AACA;AACA,eAAe,QAAQ;AACvB,iBAAiB,gCAAgC;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,UAAU;AAC5B,kBAAkB,QAAQ;AAC1B,kBAAkB,aAAa;AAC/B,kBAAkB,QAAQ;AAC1B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,cAAc;AAChC;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B;;AAEA;AACA;AACA;AACA,eAAe,aAAa;AAC5B,iBAAiB,yBAAyB;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,SAAS;AAC3B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,UAAU;AAC5B,kBAAkB,QAAQ;AAC1B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,oBAAoB;AACtC;;AAEA;AACA;AACA;AACA,eAAe,aAAa;AAC5B,iBAAiB,2BAA2B;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,SAAS;AAC3B;;AAEA;AACA;AACA;AACA,eAAe,cAAc;AAC7B,iBAAiB,gCAAgC;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B;;AAEA;AACA;AACA;AACA,eAAe,cAAc;AAC7B,eAAe,cAAc;AAC7B,iBAAiB,gCAAgC;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B;;AAEA;AACA;AACA;AACA,eAAe,cAAc;AAC7B,iBAAiB,gCAAgC;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,eAAe,cAAc;AAC7B,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,eAAe,cAAc;AAC7B,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,cAAc,gEAAgE;AAC9E;AACA;AACA,eAAe,cAAc;AAC7B,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,iBAAiB,wBAAwB;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B;;AAEA;AACA;AACA;AACA,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,eAAe,SAAS;AACxB,eAAe,SAAS;AACxB,eAAe,SAAS;AACxB,eAAe,SAAS;AACxB,eAAe,SAAS;AACxB,iBAAiB,uBAAuB;AACxC;AACA;AACA,kDAAkD,aAAa;AAC/D;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,yGAAyG,gCAAgC;AACzI;AACA;AACA;AACA,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB,QAAQ;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,gBAAgB;AAClC,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,gBAAgB;AAClC,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,aAAa;AAC/B,kBAAkB,aAAa;AAC/B,kBAAkB,aAAa;AAC/B,kBAAkB,aAAa;AAC/B,kBAAkB,aAAa;AAC/B,kBAAkB,aAAa;AAC/B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,iCAAiC;AACnD,kBAAkB,gBAAgB,4BAA4B,oBAAoB;AAClF;;AAEA;AACA;AACA;AACA,eAAe,0CAA0C;AACzD,eAAe,UAAU;AACzB,eAAe,QAAQ;AACvB,eAAe,SAAS,uCAAuC,sBAAsB;AACrF,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA,qCAAqC,YAAY;AACjD;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,eAAe,0CAA0C;AACzD,eAAe,UAAU;AACzB,eAAe,QAAQ;AACvB,eAAe,SAAS,uCAAuC,sBAAsB;AACrF,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA,qCAAqC,YAAY;AACjD;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,eAAe,0CAA0C;AACzD,eAAe,UAAU;AACzB,eAAe,QAAQ;AACvB,eAAe,SAAS,uCAAuC,sBAAsB;AACrF,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA,wCAAwC,WAAW;AACnD;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,eAAe,0CAA0C;AACzD,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,SAAS,uCAAuC,sBAAsB;AACrF,eAAe,QAAQ;AACvB,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA,kBAAkB,mBAAmB;AACrC;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,oCAAoC,wBAAwB;AAC5D;AACA,eAAe,0CAA0C;AACzD,eAAe,QAAQ;AACvB,eAAe,SAAS,uCAAuC,sBAAsB;AACrF,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA,mCAAmC,WAAW;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B;;AAEA;AACA;AACA;AACA,eAAe,QAAQ;AACvB,eAAe,eAAe;AAC9B,eAAe,UAAU;AACzB,eAAe,aAAa;AAC5B,iBAAiB,+BAA+B;AAChD;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,qBAAqB;AACvC;;AAEA;AACA;AACA;AACA,eAAe,0CAA0C;AACzD,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,SAAS,uCAAuC,sBAAsB;AACrF,iBAAiB,6BAA6B;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,eAAe,0CAA0C;AACzD,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,SAAS,uCAAuC,sBAAsB;AACrF,iBAAiB,6BAA6B;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,eAAe,cAAc;AAC7B,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,iBAAiB,mBAAmB;AACpC;AACA;AACA;AACA;AACA,uCAAuC,YAAY;AACnD;AACA;AACA;AACA;AACA,YAAY,cAAc;AAC1B,YAAY,eAAe;AAC3B,YAAY;AACZ,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,kBAAkB;AACpC,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,SAAS;AAC3B,kBAAkB,oBAAoB;AACtC,kBAAkB,UAAU;AAC5B;;AAEA;AACA;AACA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B;;AAEA;AACA;AACA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,MAAM;AACxB,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,wBAAwB;AAC1C,kBAAkB,wBAAwB;AAC1C,kBAAkB,wBAAwB;AAC1C,kBAAkB,wBAAwB;AAC1C,kBAAkB,wBAAwB;AAC1C,kBAAkB,wBAAwB;AAC1C;;AAEA;AACA;AACA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,uBAAuB;AACzC,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,0BAA0B;AAC5C;;AAEA;AACA;AACA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,aAAa;AAC/B,kBAAkB,QAAQ;AAC1B,kBAAkB,aAAa;AAC/B,kBAAkB,QAAQ;AAC1B,kBAAkB,uBAAuB;AACzC,kBAAkB,wBAAwB;AAC1C,kBAAkB,MAAM;AACxB,kBAAkB,qBAAqB;AACvC,kBAAkB,QAAQ;AAC1B;;AAEA;AACA;AACA;AACA,eAAe,0CAA0C;AACzD,eAAe,kBAAkB;AACjC,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,gBAAgB,6BAA6B;AAC7C;AACA;AACA;AACA;AACA,kDAAkD,UAAU;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B;AAC1B;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,gCAAgC,KAAK;AACrC;AACA;AACA;AACA,aAAa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,0CAA0C;AACzD,eAAe,kBAAkB;AACjC,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,iBAAiB,+BAA+B;AAChD;AACA;AACA;AACA;AACA,sDAAsD,UAAU;AAChE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,eAAe,gBAAgB;AAC/B,eAAe,kBAAkB;AACjC,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,eAAe,SAAS;AACxB,iBAAiB,6BAA6B;AAC9C;AACA;AACA;AACA;AACA,iDAAiD,UAAU;AAC3D;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,sCAAsC,eAAe,IAAI,YAAY,GAAG;AACxE;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,gBAAgB;AAClC;;AAEA;AACA;AACA;AACA;AACA;AACA,eAAe,gBAAgB;AAC/B,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,iBAAiB,yBAAyB;AAC1C;AACA;AACA;AACA;AACA,YAAY,eAAe;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,wDAAwD,gCAAgC;;AAExF;AACA,yBAAyB;AACzB;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;;AAEA;;AAEA;AACA,yBAAyB;AACzB;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,2BAA2B;AAC3B;AACA;AACA;;AAEA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;;AAEA;AACA;;AAEA,cAAc,wBAAwB;AACtC;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,iBAAiB;AACjB;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;;AAEA,+CAA+C,UAAU;AACzD;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,sBAAsB,QAAQ;AAC9B;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,eAAe,gBAAgB;AAC/B,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,iBAAiB,iBAAiB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA,sBAAsB;;AAEtB;AACA;AACA;AACA;;AAEA;;AAEA;AACA,qBAAqB;AACrB;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC;AAClC,kBAAkB;AAClB;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yEAAyE,oDAAoD;AAC7H;AACA;AACA,aAAa;AACb;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,kEAAkE,mBAAmB;AACrF;;AAEA;AACA,gBAAgB,yCAAyC;;AAEzD;AACA,6BAA6B,0EAA0E;AACvG;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C,kCAAkC;AAC/E,aAAa;AACb;AACA,6BAA6B,eAAe;AAC5C,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAiD,kCAAkC;AACnF,iBAAiB;AACjB;AACA,iCAAiC,eAAe;AAChD,cAAc;AACd;AACA;AACA,yEAAyE,gBAAgB;AACzF;AACA;AACA;AACA,sBAAsB;AACtB,yCAAyC,sDAAsD;AAC/F;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,iDAAiD,kCAAkC;AACnF;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,gEAAgE,0DAA0D;AAC1H;AACA;AACA;AACA,eAAe,cAAc;AAC7B,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,iBAAiB,4BAA4B;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,0BAA0B;AAC1B;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,yCAAyC,kCAAkC;AAC3E;AACA;AACA;AACA,qEAAqE,oDAAoD;AACzH;AACA;AACA,SAAS;;AAET;AACA,8BAA8B,wCAAwC;AACtE;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB;;AAEnB;AACA;AACA;AACA;AACA,0BAA0B,cAAc;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B;AAC1B;AACA;AACA;;AAEA;AACA,mDAAmD,mDAAmD;AACtG;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB;AACzB;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA,sCAAsC,YAAY;AAClD,IAAI;AACJ;;AAEA;AACA;AACA;AACA;AACA,UAAU;AACV,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB;AACA;AACA,wCAAwC,UAAU,OAAO,WAAW;AACpE,IAAI;AACJ;;AAEA;AACA;AACA;AACA;AACA,UAAU;AACV,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB;AACA;AACA,+BAA+B,UAAU,oBAAoB,UAAU;AACvE,IAAI;AACJ;;AAEA;AACA;AACA;AACA;AACA,UAAU;AACV,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,aAAa;AAC3B;AACA;AACA,oCAAoC,UAAU,UAAU,kCAAkC;AAC1F,IAAI;AACJ;;AAEA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA,8BAA8B,cAAc;AAC5C,IAAI;AACJ;;AAEA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA,8BAA8B,cAAc;AAC5C,IAAI;AACJ;;AAEA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA,sBAAsB,SAAS,EAAE,QAAQ;AACzC,IAAI;AACJ;;AAEA,uBAAuB","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/imap-flow.js"],"sourcesContent":["'use strict';\n\n/**\n * @module imapflow\n */\n\n// TODO:\n// * Use buffers for compiled commands\n// * OAuth2 authentication\n\nconst tls = require('tls');\nconst net = require('net');\nconst crypto = require('crypto');\nconst { EventEmitter } = require('events');\nconst logger = require('./logger');\nconst libmime = require('libmime');\nconst zlib = require('zlib');\nconst { Headers } = require('mailsplit');\nconst { LimitedPassthrough } = require('./limited-passthrough');\n\nconst { ImapStream } = require('./handler/imap-stream');\nconst { parser, compiler } = require('./handler/imap-handler');\nconst packageInfo = require('../package.json');\n\nconst libqp = require('libqp');\nconst libbase64 = require('libbase64');\nconst FlowedDecoder = require('mailsplit/lib/flowed-decoder');\nconst { PassThrough } = require('stream');\n\nconst { proxyConnection } = require('./proxy-connection');\n\nconst {\n    comparePaths,\n    updateCapabilities,\n    getFolderTree,\n    formatMessageResponse,\n    getDecoder,\n    packMessageRange,\n    normalizePath,\n    expandRange,\n    AuthenticationFailure,\n    getColorFlags\n} = require('./tools');\n\nconst imapCommands = require('./imap-commands.js');\n\nconst CONNECT_TIMEOUT = 90 * 1000;\nconst GREETING_TIMEOUT = 16 * 1000;\nconst UPGRADE_TIMEOUT = 10 * 1000;\n\nconst SOCKET_TIMEOUT = 5 * 60 * 1000;\n\nconst states = {\n    NOT_AUTHENTICATED: 0x01,\n    AUTHENTICATED: 0x02,\n    SELECTED: 0x03,\n    LOGOUT: 0x04\n};\n\n/**\n * @typedef {Object} MailboxObject\n * @global\n * @property {String} path mailbox path\n * @property {String} delimiter mailbox path delimiter, usually \".\" or \"/\"\n * @property {Set<string>} flags list of flags for this mailbox\n * @property {String} [specialUse] one of special-use flags (if applicable): \"\\All\", \"\\Archive\", \"\\Drafts\", \"\\Flagged\", \"\\Junk\", \"\\Sent\", \"\\Trash\". Additionally INBOX has non-standard \"\\Inbox\" flag set\n * @property {Boolean} listed `true` if mailbox was found from the output of LIST command\n * @property {Boolean} subscribed `true` if mailbox was found from the output of LSUB command\n * @property {Set<string>} permanentFlags A Set of flags available to use in this mailbox. If it is not set or includes special flag \"\\\\\\*\" then any flag can be used.\n * @property {String} [mailboxId] unique mailbox ID if server has `OBJECTID` extension enabled\n * @property {BigInt} [highestModseq] latest known modseq value if server has CONDSTORE or XYMHIGHESTMODSEQ enabled\n * @property {String} [noModseq] if true then the server doesn't support the persistent storage of mod-sequences for the mailbox\n * @property {BigInt} uidValidity Mailbox `UIDVALIDITY` value\n * @property {Number} uidNext Next predicted UID\n * @property {Number} exists Messages in this folder\n */\n\n/**\n * @typedef {Object} MailboxLockObject\n * @global\n * @property {String} path mailbox path\n * @property {Function} release Release current lock\n * @example\n * let lock = await client.getMailboxLock('INBOX');\n * try {\n *   // do something in the mailbox\n * } finally {\n *   // use finally{} to make sure lock is released even if exception occurs\n *   lock.release();\n * }\n */\n\n/**\n * Client and server identification object, where key is one of RFC2971 defined [data fields](https://tools.ietf.org/html/rfc2971#section-3.3) (but not limited to).\n * @typedef {Object} IdInfoObject\n * @global\n * @property {String} [name] Name of the program\n * @property {String} [version] Version number of the program\n * @property {String} [os] Name of the operating system\n * @property {String} [vendor] Vendor of the client/server\n * @property {String} ['support-url'] URL to contact for support\n * @property {Date} [date] Date program was released\n */\n\n/**\n * IMAP client class for accessing IMAP mailboxes\n *\n * @class\n * @extends EventEmitter\n */\nclass ImapFlow extends EventEmitter {\n    /**\n     * Current module version as a static class property\n     * @property {String} version Module version\n     * @static\n     */\n    static version = packageInfo.version;\n\n    /**\n     * IMAP connection options\n     *\n     * @property {String} host\n     *     Hostname of the IMAP server.\n     *\n     * @property {Number} port\n     *     Port number for the IMAP server.\n     *\n     * @property {Boolean} [secure=false]\n     *     If `true`, establishes the connection directly over TLS (commonly on port 993).\n     *     If `false`, a plain (unencrypted) connection is used first and, if possible, the connection is upgraded to STARTTLS.\n     *\n     * @property {Boolean} [doSTARTTLS=undefined]\n     *     Determines whether to upgrade the connection to TLS via STARTTLS:\n     *       - **true**: Start unencrypted and upgrade to TLS using STARTTLS before authentication.\n     *         The connection fails if the server does not support STARTTLS or the upgrade fails.\n     *         Note that `secure=true` combined with `doSTARTTLS=true` is invalid.\n     *       - **false**: Never use STARTTLS, even if the server advertises support.\n     *         This is useful if the server has a broken TLS setup.\n     *         Combined with `secure=false`, this results in a fully unencrypted connection.\n     *         Make sure you warn users about the security risks.\n     *       - **undefined** (default): If `secure=false` (default), attempt to upgrade to TLS via STARTTLS before authentication if the server supports it. If not supported, continue unencrypted. This may expose the connection to a downgrade attack.\n     *\n     * @property {String} [servername]\n     *     Server name for SNI or when using an IP address as `host`.\n     *\n     * @property {Boolean} [disableCompression=false]\n     *     If `true`, the client does not attempt to use the COMPRESS=DEFLATE extension.\n     *\n     * @property {Object} auth\n     *     Authentication options. Authentication occurs automatically during {@link connect}.\n     *\n     * @property {String} auth.user\n     *     Username for authentication.\n     *\n     * @property {String} [auth.pass]\n     *     Password for regular authentication.\n     *\n     * @property {String} [auth.accessToken]\n     *     OAuth2 access token, if using OAuth2 authentication.\n     *\n     * @property {String} [auth.loginMethod]\n     *     Optional login method for password-based authentication (e.g., \"LOGIN\", \"AUTH=LOGIN\", or \"AUTH=PLAIN\").\n     *     If not set, ImapFlow chooses based on available mechanisms.\n     *\n     * @property {IdInfoObject} [clientInfo]\n     *     Client identification info sent to the server (via the ID command).\n     *\n     * @property {Boolean} [disableAutoIdle=false]\n     *     If `true`, do not start IDLE automatically. Useful when only specific operations are needed.\n     *\n     * @property {Object} [tls]\n     *     Additional TLS options. For details, see [Node.js TLS connect](https://nodejs.org/api/tls.html#tls_tls_connect_options_callback).\n     *\n     * @property {Boolean} [tls.rejectUnauthorized=true]\n     *     If `false`, allows self-signed or expired certificates.\n     *\n     * @property {String} [tls.minVersion='TLSv1.2']\n     *     Minimum accepted TLS version (e.g., `'TLSv1.2'`).\n     *\n     * @property {Number} [tls.minDHSize=1024]\n     *     Minimum size (in bits) of the DH parameter for TLS connections.\n     *\n     * @property {Object|Boolean} [logger]\n     *     Custom logger instance with `debug(obj)`, `info(obj)`, `warn(obj)`, and `error(obj)` methods.\n     *     If `false`, logging is disabled. If not provided, ImapFlow logs to console in [pino format](https://getpino.io/).\n     *\n     * @property {Boolean} [logRaw=false]\n     *     If `true`, logs all raw data (read and written) in base64 encoding. You can pipe such logs to [eerawlog](https://github.com/postalsys/eerawlog) command for readable output.\n     *\n     * @property {Boolean} [emitLogs=false]\n     *     If `true`, emits `'log'` events with the same data passed to the logger.\n     *\n     * @property {Boolean} [verifyOnly=false]\n     *     If `true`, disconnects after successful authentication without performing other actions.\n     *\n     * @property {String} [proxy]\n     *     Proxy URL. Supports HTTP CONNECT (`http://`, `https://`) and SOCKS (`socks://`, `socks4://`, `socks5://`).\n     *\n     * @property {Boolean} [qresync=false]\n     *     If `true`, enables QRESYNC support so that EXPUNGE notifications include `uid` instead of `seq`.\n     *\n     * @property {Number} [maxIdleTime]\n     *     If set, breaks and restarts IDLE every `maxIdleTime` milliseconds.\n     *\n     * @property {String} [missingIdleCommand=\"NOOP\"]\n     *     Command to use if the server does not support IDLE.\n     *\n     * @property {Boolean} [disableBinary=false]\n     *     If `true`, ignores the BINARY extension for FETCH and APPEND operations.\n     *\n     * @property {Boolean} [disableAutoEnable=false]\n     *     If `true`, do not automatically enable supported IMAP extensions.\n     *\n     * @property {Number} [connectionTimeout=90000]\n     *     Maximum time (in milliseconds) to wait for the connection to establish. Defaults to 90 seconds.\n     *\n     * @property {Number} [greetingTimeout=16000]\n     *     Maximum time (in milliseconds) to wait for the server greeting after a connection is established. Defaults to 16 seconds.\n     *\n     * @property {Number} [socketTimeout=300000]\n     *     Maximum period of inactivity (in milliseconds) before terminating the connection. Defaults to 5 minutes.\n     */\n\n    constructor(options) {\n        super({ captureRejections: true });\n\n        this.options = options || {};\n\n        /**\n         * Instance ID for logs\n         * @type {String}\n         */\n        this.id = this.options.id || this.getRandomId();\n\n        this.clientInfo = Object.assign(\n            {\n                name: packageInfo.name,\n                version: packageInfo.version,\n                vendor: 'Postal Systems',\n                'support-url': 'https://github.com/postalsys/imapflow/issues'\n            },\n            this.options.clientInfo || {}\n        );\n\n        /**\n         * Server identification info. Available after successful `connect()`.\n         * If server does not provide identification info then this value is `null`.\n         * @example\n         * await client.connect();\n         * console.log(client.serverInfo.vendor);\n         * @type {IdInfoObject|null}\n         */\n        this.serverInfo = null; //updated by ID\n\n        this.log = this.getLogger();\n\n        /**\n         * Is the connection currently encrypted or not\n         * @type {Boolean}\n         */\n        this.secureConnection = !!this.options.secure;\n\n        this.port = Number(this.options.port) || (this.secureConnection ? 993 : 110);\n        this.host = this.options.host || 'localhost';\n        this.servername = this.options.servername ? this.options.servername : !net.isIP(this.host) ? this.host : false;\n\n        if (typeof this.options.secure === 'undefined' && this.port === 993) {\n            // if secure option is not set but port is 465, then default to secure\n            this.secureConnection = true;\n        }\n\n        this.logRaw = this.options.logRaw;\n        this.streamer = new ImapStream({\n            logger: this.log,\n            cid: this.id,\n            logRaw: this.logRaw,\n            secureConnection: this.secureConnection\n        });\n\n        this.reading = false;\n        this.socket = false;\n        this.writeSocket = false;\n\n        this.states = states;\n        this.state = this.states.NOT_AUTHENTICATED;\n\n        this.lockCounter = 0;\n        this.currentLock = false;\n\n        this.tagCounter = 0;\n        this.requestTagMap = new Map();\n        this.requestQueue = [];\n        this.currentRequest = false;\n\n        this.writeBytesCounter = 0;\n\n        this.commandParts = [];\n\n        /**\n         * Active IMAP capabilities. Value is either `true` for togglabe capabilities (eg. `UIDPLUS`)\n         * or a number for capabilities with a value (eg. `APPENDLIMIT`)\n         * @type {Map<string, boolean|number>}\n         */\n        this.capabilities = new Map();\n        this.authCapabilities = new Map();\n\n        this.rawCapabilities = null;\n\n        this.expectCapabilityUpdate = false; // force CAPABILITY after LOGIN\n\n        /**\n         * Enabled capabilities. Usually `CONDSTORE` and `UTF8=ACCEPT` if server supports these.\n         * @type {Set<string>}\n         */\n        this.enabled = new Set();\n\n        /**\n         * Is the connection currently usable or not\n         * @type {Boolean}\n         */\n        this.usable = false;\n\n        /**\n         * Currently authenticated user or `false` if mailbox is not open\n         * or `true` if connection was authenticated by PREAUTH\n         * @type {String|Boolean}\n         */\n        this.authenticated = false;\n\n        /**\n         * Currently selected mailbox or `false` if mailbox is not open\n         * @type {MailboxObject|Boolean}\n         */\n        this.mailbox = false;\n        this.currentSelectCommand = false;\n\n        /**\n         * Is current mailbox idling (`true`) or not (`false`)\n         * @type {Boolean}\n         */\n        this.idling = false;\n\n        this.emitLogs = !!this.options.emitLogs;\n        // ordering number for emitted logs\n        this.lo = 0;\n\n        this.untaggedHandlers = {};\n        this.sectionHandlers = {};\n\n        this.commands = imapCommands;\n\n        this.folders = new Map();\n\n        this.currentLock = false;\n        this.locks = [];\n\n        this.idRequested = false;\n\n        this.maxIdleTime = this.options.maxIdleTime || false;\n        this.missingIdleCommand = (this.options.missingIdleCommand || '').toString().toUpperCase().trim() || 'NOOP';\n\n        this.disableBinary = !!this.options.disableBinary;\n\n        this.streamer.on('error', err => {\n            if (['Z_BUF_ERROR', 'ECONNRESET', 'EPIPE', 'ETIMEDOUT', 'EHOSTUNREACH'].includes(err.code)) {\n                // just close the connection, usually nothing but noise\n                return setImmediate(() => this.close());\n            }\n\n            this.log.error({ err, cid: this.id });\n            setImmediate(() => this.close());\n            this.emitError(err);\n        });\n\n        // Has the `connect` method already been called\n        this._connectCalled = false;\n    }\n\n    emitError(err) {\n        this.emit('error', err);\n    }\n\n    getRandomId() {\n        let rid = BigInt('0x' + crypto.randomBytes(13).toString('hex')).toString(36);\n        if (rid.length < 20) {\n            rid = '0'.repeat(20 - rid.length) + rid;\n        } else if (rid.length > 20) {\n            rid = rid.substr(0, 20);\n        }\n        return rid;\n    }\n\n    write(chunk) {\n        if (this.socket.destroyed) {\n            // do not write after connection end or logout\n            const error = new Error('Socket is already closed');\n            error.code = 'NoConnection';\n            throw error;\n        }\n\n        if (this.state === this.states.LOGOUT) {\n            // should not happen\n            const error = new Error('Can not send data after logged out');\n            error.code = 'StateLogout';\n            throw error;\n        }\n\n        if (this.writeSocket.destroyed) {\n            this.socket.emit('error', 'Write socket destroyed');\n            return;\n        }\n\n        let addLineBreak = !this.commandParts.length;\n        if (typeof chunk === 'string') {\n            if (addLineBreak) {\n                chunk += '\\r\\n';\n            }\n            chunk = Buffer.from(chunk, 'binary');\n        } else if (Buffer.isBuffer(chunk)) {\n            if (addLineBreak) {\n                chunk = Buffer.concat([chunk, Buffer.from('\\r\\n')]);\n            }\n        } else {\n            return false;\n        }\n\n        if (this.logRaw) {\n            this.log.trace({\n                src: 'c',\n                msg: 'write to socket',\n                data: chunk.toString('base64'),\n                compress: !!this._deflate,\n                secure: !!this.secureConnection,\n                cid: this.id\n            });\n        }\n\n        this.writeBytesCounter += chunk.length;\n\n        this.writeSocket.write(chunk);\n    }\n\n    stats(reset) {\n        let result = {\n            sent: this.writeBytesCounter || 0,\n            received: (this.streamer && this.streamer.readBytesCounter) || 0\n        };\n\n        if (reset) {\n            this.writeBytesCounter = 0;\n            if (this.streamer) {\n                this.streamer.readBytesCounter = 0;\n            }\n        }\n\n        return result;\n    }\n\n    async send(data) {\n        if (this.state === this.states.LOGOUT) {\n            // already logged out\n            if (data.tag) {\n                let request = this.requestTagMap.get(data.tag);\n                if (request) {\n                    this.requestTagMap.delete(request.tag);\n                    const error = new Error('Connection not available');\n                    error.code = 'NoConnection';\n                    request.reject(error);\n                }\n            }\n            return;\n        }\n\n        let compiled = await compiler(data, {\n            asArray: true,\n            literalMinus: this.capabilities.has('LITERAL-') || this.capabilities.has('LITERAL+')\n        });\n        this.commandParts = compiled;\n\n        let logCompiled = await compiler(data, {\n            isLogging: true\n        });\n\n        let options = data.options || {};\n\n        this.log.debug({ src: 's', msg: logCompiled.toString(), cid: this.id, comment: options.comment });\n\n        this.write(this.commandParts.shift());\n\n        if (typeof options.onSend === 'function') {\n            options.onSend();\n        }\n    }\n\n    async trySend() {\n        if (this.currentRequest || !this.requestQueue.length) {\n            return;\n        }\n        this.currentRequest = this.requestQueue.shift();\n\n        await this.send({\n            tag: this.currentRequest.tag,\n            command: this.currentRequest.command,\n            attributes: this.currentRequest.attributes,\n            options: this.currentRequest.options\n        });\n    }\n\n    async exec(command, attributes, options) {\n        if (this.socket.destroyed) {\n            let error = new Error('Connection closed');\n            error.code = 'EConnectionClosed';\n            throw error;\n        }\n\n        let tag = (++this.tagCounter).toString(16).toUpperCase();\n\n        options = options || {};\n\n        return new Promise((resolve, reject) => {\n            this.requestTagMap.set(tag, { command, attributes, options, resolve, reject });\n            this.requestQueue.push({ tag, command, attributes, options });\n            this.trySend().catch(err => {\n                this.requestTagMap.delete(tag);\n                reject(err);\n            });\n        });\n    }\n\n    getUntaggedHandler(command, attributes) {\n        if (/^[0-9]+$/.test(command)) {\n            let type = attributes && attributes.length && typeof attributes[0].value === 'string' ? attributes[0].value.toUpperCase() : false;\n            if (type) {\n                // EXISTS, EXPUNGE, RECENT, FETCH etc\n                command = type;\n            }\n        }\n\n        command = command.toUpperCase().trim();\n        if (this.currentRequest && this.currentRequest.options && this.currentRequest.options.untagged && this.currentRequest.options.untagged[command]) {\n            return this.currentRequest.options.untagged[command];\n        }\n\n        if (this.untaggedHandlers[command]) {\n            return this.untaggedHandlers[command];\n        }\n    }\n\n    getSectionHandler(key) {\n        if (this.sectionHandlers[key]) {\n            return this.sectionHandlers[key];\n        }\n    }\n\n    async reader() {\n        let data;\n        while ((data = this.streamer.read()) !== null) {\n            let parsed;\n\n            try {\n                parsed = await parser(data.payload, { literals: data.literals });\n                if (parsed.tag && !['*', '+'].includes(parsed.tag) && parsed.command) {\n                    let payload = { response: parsed.command };\n\n                    if (\n                        parsed.attributes &&\n                        parsed.attributes[0] &&\n                        parsed.attributes[0].section &&\n                        parsed.attributes[0].section[0] &&\n                        parsed.attributes[0].section[0].type === 'ATOM'\n                    ) {\n                        payload.code = parsed.attributes[0].section[0].value;\n                    }\n                    this.emit('response', payload);\n                }\n            } catch (err) {\n                // can not make sense of this\n                this.log.error({ src: 's', msg: data.payload.toString(), err, cid: this.id });\n                data.next();\n                continue;\n            }\n\n            let logCompiled = await compiler(parsed, {\n                isLogging: true\n            });\n\n            if (/^\\d+$/.test(parsed.command) && parsed.attributes && parsed.attributes[0] && parsed.attributes[0].value === 'FETCH') {\n                // too many FETCH responses, might want to filter these out\n                this.log.trace({ src: 's', msg: logCompiled.toString(), cid: this.id, nullBytesRemoved: parsed.nullBytesRemoved });\n            } else {\n                this.log.debug({ src: 's', msg: logCompiled.toString(), cid: this.id, nullBytesRemoved: parsed.nullBytesRemoved });\n            }\n\n            if (parsed.tag === '+' && this.currentRequest && this.currentRequest.options && typeof this.currentRequest.options.onPlusTag === 'function') {\n                await this.currentRequest.options.onPlusTag(parsed);\n                data.next();\n                continue;\n            }\n\n            if (parsed.tag === '+' && this.commandParts.length) {\n                let content = this.commandParts.shift();\n                this.write(content);\n                this.log.debug({ src: 'c', msg: `(* ${content.length}B continuation *)`, cid: this.id });\n                data.next();\n                continue;\n            }\n\n            let section = parsed.attributes && parsed.attributes.length && parsed.attributes[0] && !parsed.attributes[0].value && parsed.attributes[0].section;\n            if (section && section.length && section[0].type === 'ATOM' && typeof section[0].value === 'string') {\n                let sectionHandler = this.getSectionHandler(section[0].value.toUpperCase().trim());\n                if (sectionHandler) {\n                    await sectionHandler(section.slice(1));\n                }\n            }\n\n            if (parsed.tag === '*' && parsed.command) {\n                let untaggedHandler = this.getUntaggedHandler(parsed.command, parsed.attributes);\n                if (untaggedHandler) {\n                    try {\n                        await untaggedHandler(parsed);\n                    } catch (err) {\n                        this.log.warn({ err, cid: this.id });\n                        data.next();\n                        continue;\n                    }\n                }\n            }\n\n            if (this.requestTagMap.has(parsed.tag)) {\n                let request = this.requestTagMap.get(parsed.tag);\n                this.requestTagMap.delete(parsed.tag);\n\n                if (this.currentRequest && this.currentRequest.tag === parsed.tag) {\n                    // send next pending command\n                    this.currentRequest = false;\n                    await this.trySend();\n                }\n\n                switch (parsed.command.toUpperCase()) {\n                    case 'OK':\n                    case 'BYE':\n                        await new Promise(resolve => request.resolve({ response: parsed, next: resolve }));\n                        break;\n\n                    case 'NO':\n                    case 'BAD': {\n                        let txt =\n                            parsed.attributes &&\n                            parsed.attributes\n                                .filter(val => val.type === 'TEXT')\n                                .map(val => val.value.trim())\n                                .join(' ');\n\n                        let err = new Error('Command failed');\n                        err.response = parsed;\n                        err.responseStatus = parsed.command.toUpperCase();\n\n                        try {\n                            err.executedCommand =\n                                parsed.tag +\n                                (\n                                    await compiler(request, {\n                                        isLogging: true\n                                    })\n                                ).toString();\n                        } catch (err) {\n                            // ignore\n                        }\n\n                        if (txt) {\n                            err.responseText = txt;\n\n                            if (err.responseStatus === 'NO' && txt.includes('Some of the requested messages no longer exist')) {\n                                // Treat as successful response\n                                this.log.warn({ msg: 'Partial FETCH response', cid: this.id, err });\n                                await new Promise(resolve => request.resolve({ response: parsed, next: resolve }));\n                                break;\n                            }\n\n                            let throttleDelay = false;\n\n                            // MS365 throttling\n                            // tag BAD Request is throttled. Suggested Backoff Time: 92415 milliseconds\n                            if (/Request is throttled/i.test(txt) && /Backoff Time/i.test(txt)) {\n                                let throttlingMatch = txt.match(/Backoff Time[:=\\s]+(\\d+)/i);\n                                if (throttlingMatch && throttlingMatch[1] && !isNaN(throttlingMatch[1])) {\n                                    throttleDelay = Number(throttlingMatch[1]);\n                                }\n                            }\n\n                            // Wait and return a throttling error\n                            if (throttleDelay) {\n                                err.code = 'ETHROTTLE';\n                                err.throttleReset = throttleDelay;\n\n                                let delayResponse = throttleDelay;\n                                if (delayResponse > 5 * 60 * 1000) {\n                                    // max delay cap\n                                    delayResponse = 5 * 60 * 1000;\n                                }\n\n                                this.log.warn({ msg: 'Throttling detected', cid: this.id, throttleDelay, delayResponse, err });\n                                await new Promise(r => setTimeout(r, delayResponse));\n                            }\n                        }\n\n                        request.reject(err);\n                        break;\n                    }\n\n                    default: {\n                        let err = new Error('Invalid server response');\n                        err.code = 'InvalidResponse';\n                        err.response = parsed;\n                        request.reject(err);\n                        break;\n                    }\n                }\n            }\n\n            data.next();\n        }\n    }\n\n    setEventHandlers() {\n        this.socketReadable = () => {\n            if (!this.reading) {\n                this.reading = true;\n                this.reader()\n                    .catch(err => this.log.error({ err, cid: this.id }))\n                    .finally(() => {\n                        this.reading = false;\n                    });\n            }\n        };\n\n        this.streamer.on('readable', this.socketReadable);\n    }\n\n    setSocketHandlers() {\n        this._socketError =\n            this._socketError ||\n            (err => {\n                this.log.error({ err, cid: this.id });\n                setImmediate(() => this.close());\n                this.emitError(err);\n            });\n        this._socketClose =\n            this._socketClose ||\n            (() => {\n                this.close();\n            });\n        this._socketEnd =\n            this._socketEnd ||\n            (() => {\n                this.close();\n            });\n\n        this._socketTimeout =\n            this._socketTimeout ||\n            (() => {\n                if (this.idling) {\n                    this.run('NOOP')\n                        .then(() => this.idle())\n                        .catch(this._socketError);\n                } else {\n                    this.log.debug({ msg: 'Socket timeout', cid: this.id });\n                    this.close();\n                }\n            });\n\n        this.socket.on('error', this._socketError);\n        this.socket.on('close', this._socketClose);\n        this.socket.on('end', this._socketEnd);\n        this.socket.on('tlsClientError', this._socketError);\n        this.socket.on('timeout', this._socketTimeout);\n\n        this.writeSocket.on('error', this._socketError);\n    }\n\n    clearSocketHandlers() {\n        if (this._socketError) {\n            this.socket.removeListener('error', this._socketError);\n            this.socket.removeListener('tlsClientError', this._socketError);\n        }\n        if (this._socketClose) {\n            this.socket.removeListener('close', this._socketClose);\n        }\n        if (this._socketEnd) {\n            this.socket.removeListener('end', this._socketEnd);\n        }\n    }\n\n    async startSession() {\n        await this.run('CAPABILITY');\n\n        if (this.capabilities.has('ID')) {\n            this.idRequested = await this.run('ID', this.clientInfo);\n        }\n\n        await this.upgradeToSTARTTLS();\n\n        await this.authenticate();\n\n        if (!this.idRequested && this.capabilities.has('ID')) {\n            // re-request ID after LOGIN\n            this.idRequested = await this.run('ID', this.clientInfo);\n        }\n\n        // Make sure we have namespace set. This should also throw if Exchange actually failed authentication\n        let nsResponse = await this.run('NAMESPACE');\n        if (nsResponse && nsResponse.error && nsResponse.status === 'BAD' && /User is authenticated but not connected/i.test(nsResponse.text)) {\n            // Not a NAMESPACE failure but authentication failure, so report as\n            this.authenticated = false;\n            let err = new AuthenticationFailure('Authentication failed');\n            err.response = nsResponse.text;\n            throw err;\n        }\n\n        if (this.options.verifyOnly) {\n            // List all folders and logout\n            if (this.options.includeMailboxes) {\n                this._mailboxList = await this.list();\n            }\n            return await this.logout();\n        }\n\n        // try to use compression (if supported)\n        if (!this.options.disableCompression) {\n            await this.compress();\n        }\n\n        if (!this.options.disableAutoEnable) {\n            // enable extensions if possible\n            await this.run('ENABLE', ['CONDSTORE', 'UTF8=ACCEPT'].concat(this.options.qresync ? 'QRESYNC' : []));\n        }\n\n        this.usable = true;\n    }\n\n    async compress() {\n        if (!(await this.run('COMPRESS'))) {\n            return; // was not able to negotiate compression\n        }\n\n        // create deflate/inflate streams\n        this._deflate = zlib.createDeflateRaw({\n            windowBits: 15\n        });\n        this._inflate = zlib.createInflateRaw();\n\n        // route incoming socket via inflate stream\n        this.socket.unpipe(this.streamer);\n        this.streamer.compress = true;\n        this.socket.pipe(this._inflate).pipe(this.streamer);\n        this._inflate.on('error', err => {\n            this.streamer.emit('error', err);\n        });\n\n        // route outgoing socket via deflate stream\n        this.writeSocket = new PassThrough();\n\n        this.writeSocket.destroySoon = () => {\n            try {\n                if (this.socket) {\n                    this.socket.destroy();\n                }\n                this.writeSocket.end();\n            } catch (err) {\n                this.log.error({ err, info: 'Failed to destroy PassThrough socket', cid: this.id });\n                throw err;\n            }\n        };\n\n        Object.defineProperty(this.writeSocket, 'destroyed', {\n            get: () => this.socket.destroyed\n        });\n\n        // we need to force flush deflated data to socket so we can't\n        // use normal pipes for this.writeSocket -> this._deflate -> this.socket\n        let reading = false;\n        let readNext = () => {\n            reading = true;\n\n            let chunk;\n            while ((chunk = this.writeSocket.read()) !== null) {\n                if (this._deflate && this._deflate.write(chunk) === false) {\n                    return this._deflate.once('drain', readNext);\n                }\n            }\n\n            // flush data to socket\n            if (this._deflate) {\n                this._deflate.flush();\n            }\n\n            reading = false;\n        };\n\n        this.writeSocket.on('readable', () => {\n            if (!reading) {\n                readNext();\n            }\n        });\n        this.writeSocket.on('error', err => {\n            this.socket.emit('error', err);\n        });\n\n        this._deflate.pipe(this.socket);\n        this._deflate.on('error', err => {\n            this.socket.emit('error', err);\n        });\n    }\n\n    _failSTARTTLS() {\n        if (this.options.doSTARTTLS === true) {\n            // STARTTLS configured as requirement\n            let err = new Error('Server does not support STARTTLS');\n            err.tlsFailed = true;\n            throw err;\n        } else {\n            // Opportunistic STARTTLS. But it's not possible right now.\n            // Attention: Could be a downgrade attack.\n            return false;\n        }\n    }\n\n    /**\n     * Tries to upgrade the connection to TLS using STARTTLS.\n     * @throws if STARTTLS is required, but not possible.\n     * @returns {boolean} true, if the connection is now protected by TLS, either direct TLS or STARTTLS.\n     */\n    async upgradeToSTARTTLS() {\n        if (this.options.doSTARTTLS === true && this.options.secure === true) {\n            throw new Error('Misconfiguration: Cannot set both secure=true for TLS and doSTARTTLS=true for STARTTLS.');\n        }\n\n        if (this.secureConnection) {\n            // Already using direct TLS. No need for STARTTLS.\n            return true;\n        }\n\n        if (this.options.doSTARTTLS === false) {\n            // STARTTLS explictly disabled by config\n            return false;\n        }\n\n        if (!this.capabilities.has('STARTTLS')) {\n            return this._failSTARTTLS();\n        }\n\n        this.expectCapabilityUpdate = true;\n        let canUpgrade = await this.run('STARTTLS');\n        if (!canUpgrade) {\n            return this._failSTARTTLS();\n        }\n\n        this.socket.unpipe(this.streamer);\n        let upgraded = await new Promise((resolve, reject) => {\n            let socketPlain = this.socket;\n            let opts = Object.assign(\n                {\n                    socket: this.socket,\n                    servername: this.servername,\n                    port: this.port\n                },\n                this.options.tls || {}\n            );\n            this.clearSocketHandlers();\n\n            socketPlain.once('error', err => {\n                clearTimeout(this.connectTimeout);\n                clearTimeout(this.upgradeTimeout);\n                if (!this.upgrading) {\n                    // don't care anymore\n                    return;\n                }\n                setImmediate(() => this.close());\n                this.upgrading = false;\n                err.tlsFailed = true;\n                reject(err);\n            });\n\n            this.upgradeTimeout = setTimeout(() => {\n                if (!this.upgrading) {\n                    return;\n                }\n                setImmediate(() => this.close());\n                let err = new Error('Failed to upgrade connection in required time');\n                err.tlsFailed = true;\n                err.code = 'UPGRADE_TIMEOUT';\n                reject(err);\n            }, UPGRADE_TIMEOUT);\n\n            this.upgrading = true;\n            this.socket = tls.connect(opts, () => {\n                clearTimeout(this.upgradeTimeout);\n                if (this.isClosed) {\n                    // not sure if this is possible?\n                    return this.close();\n                }\n\n                this.secureConnection = true;\n                this.upgrading = false;\n                this.streamer.secureConnection = true;\n                this.socket.pipe(this.streamer);\n                this.tls = typeof this.socket.getCipher === 'function' ? this.socket.getCipher() : false;\n                if (this.tls) {\n                    this.tls.authorized = this.socket.authorized;\n                    this.log.info({\n                        src: 'tls',\n                        msg: 'Established TLS session',\n                        cid: this.id,\n                        authorized: this.tls.authorized,\n                        algo: this.tls.standardName || this.tls.name,\n                        version: this.tls.version\n                    });\n                }\n\n                return resolve(true);\n            });\n\n            this.writeSocket = this.socket;\n\n            this.setSocketHandlers();\n        });\n\n        if (upgraded && this.expectCapabilityUpdate) {\n            await this.run('CAPABILITY');\n        }\n\n        return upgraded;\n    }\n\n    async setAuthenticationState() {\n        this.state = this.states.AUTHENTICATED;\n        this.authenticated = true;\n        if (this.expectCapabilityUpdate) {\n            // update capabilities\n            await this.run('CAPABILITY');\n        }\n    }\n\n    async authenticate() {\n        if (this.state === this.states.LOGOUT) {\n            throw new AuthenticationFailure('Already logged out');\n        }\n\n        if (this.state !== this.states.NOT_AUTHENTICATED) {\n            // nothing to do here, usually happens with PREAUTH greeting\n            return true;\n        }\n\n        if (!this.options.auth) {\n            throw new AuthenticationFailure('Please configure the login');\n        }\n\n        this.expectCapabilityUpdate = true;\n\n        let loginMethod = (this.options.auth.loginMethod || '').toString().trim().toUpperCase();\n        if (!loginMethod && /\\\\|\\//.test(this.options.auth.user)) {\n            // Special override for MS Exchange when authenticating as some other user or non-email account\n            loginMethod = 'LOGIN';\n        }\n\n        if (this.options.auth.accessToken) {\n            this.authenticated = await this.run('AUTHENTICATE', this.options.auth.user, { accessToken: this.options.auth.accessToken });\n        } else if (this.options.auth.pass) {\n            if ((this.capabilities.has('AUTH=LOGIN') || this.capabilities.has('AUTH=PLAIN')) && loginMethod !== 'LOGIN') {\n                this.authenticated = await this.run('AUTHENTICATE', this.options.auth.user, { password: this.options.auth.pass, loginMethod });\n            } else {\n                if (this.capabilities.has('LOGINDISABLED')) {\n                    throw new AuthenticationFailure('Login is disabled');\n                }\n                this.authenticated = await this.run('LOGIN', this.options.auth.user, this.options.auth.pass);\n            }\n        } else {\n            throw new AuthenticationFailure('No password configured');\n        }\n\n        if (this.authenticated) {\n            this.log.info({\n                src: 'auth',\n                msg: 'User authenticated',\n                cid: this.id,\n                user: this.options.auth.user\n            });\n            await this.setAuthenticationState();\n            return true;\n        }\n\n        throw new AuthenticationFailure('No matching authentication method');\n    }\n\n    async initialOK(message) {\n        this.greeting = (message.attributes || [])\n            .filter(entry => entry.type === 'TEXT')\n            .map(entry => entry.value)\n            .filter(entry => entry)\n            .join('');\n\n        clearTimeout(this.greetingTimeout);\n        this.untaggedHandlers.OK = null;\n        this.untaggedHandlers.PREAUTH = null;\n\n        if (this.isClosed) {\n            return;\n        }\n\n        // get out of current parsing \"thread\", so do not await for startSession\n        this.startSession()\n            .then(() => {\n                if (typeof this.initialResolve === 'function') {\n                    let resolve = this.initialResolve;\n                    this.initialResolve = false;\n                    this.initialReject = false;\n                    return resolve();\n                }\n            })\n            .catch(err => {\n                this.log.error({ err, cid: this.id });\n\n                if (typeof this.initialReject === 'function') {\n                    clearTimeout(this.greetingTimeout);\n                    let reject = this.initialReject;\n                    this.initialResolve = false;\n                    this.initialReject = false;\n                    return reject(err);\n                }\n\n                setImmediate(() => this.close());\n            });\n    }\n\n    async initialPREAUTH() {\n        clearTimeout(this.greetingTimeout);\n        this.untaggedHandlers.OK = null;\n        this.untaggedHandlers.PREAUTH = null;\n\n        if (this.isClosed) {\n            return;\n        }\n\n        this.state = this.states.AUTHENTICATED;\n\n        // get out of current parsing \"thread\", so do not await for startSession\n        this.startSession()\n            .then(() => {\n                if (typeof this.initialResolve === 'function') {\n                    let resolve = this.initialResolve;\n                    this.initialResolve = false;\n                    this.initialReject = false;\n                    return resolve();\n                }\n            })\n            .catch(err => {\n                this.log.error({ err, cid: this.id });\n\n                if (typeof this.initialReject === 'function') {\n                    clearTimeout(this.greetingTimeout);\n                    let reject = this.initialReject;\n                    this.initialResolve = false;\n                    this.initialReject = false;\n                    return reject(err);\n                }\n\n                setImmediate(() => this.close());\n            });\n    }\n\n    async serverBye() {\n        this.untaggedHandlers.BYE = null;\n        this.state = this.states.LOGOUT;\n    }\n\n    async sectionCapability(section) {\n        this.rawCapabilities = section;\n        this.capabilities = updateCapabilities(section);\n\n        if (this.capabilities) {\n            for (let [capa] of this.capabilities) {\n                if (/^AUTH=/i.test(capa) && !this.authCapabilities.has(capa.toUpperCase())) {\n                    this.authCapabilities.set(capa.toUpperCase(), false);\n                }\n            }\n        }\n\n        if (this.expectCapabilityUpdate) {\n            this.expectCapabilityUpdate = false;\n        }\n    }\n\n    async untaggedCapability(untagged) {\n        this.rawCapabilities = untagged.attributes;\n        this.capabilities = updateCapabilities(untagged.attributes);\n\n        if (this.capabilities) {\n            for (let [capa] of this.capabilities) {\n                if (/^AUTH=/i.test(capa) && !this.authCapabilities.has(capa.toUpperCase())) {\n                    this.authCapabilities.set(capa.toUpperCase(), false);\n                }\n            }\n        }\n\n        if (this.expectCapabilityUpdate) {\n            this.expectCapabilityUpdate = false;\n        }\n    }\n\n    async untaggedExists(untagged) {\n        if (!this.mailbox) {\n            // mailbox closed, ignore\n            return;\n        }\n\n        if (!untagged || !untagged.command || isNaN(untagged.command)) {\n            return;\n        }\n\n        let count = Number(untagged.command);\n        if (count === this.mailbox.exists) {\n            // nothing changed?\n            return;\n        }\n\n        // keep exists up to date\n        let prevCount = this.mailbox.exists;\n        this.mailbox.exists = count;\n        this.emit('exists', {\n            path: this.mailbox.path,\n            count,\n            prevCount\n        });\n    }\n\n    async untaggedExpunge(untagged) {\n        if (!this.mailbox) {\n            // mailbox closed, ignore\n            return;\n        }\n\n        if (!untagged || !untagged.command || isNaN(untagged.command)) {\n            return;\n        }\n\n        let seq = Number(untagged.command);\n        if (seq && seq <= this.mailbox.exists) {\n            this.mailbox.exists--;\n            let payload = {\n                path: this.mailbox.path,\n                seq,\n                vanished: false\n            };\n\n            if (typeof this.options.expungeHandler === 'function') {\n                try {\n                    await this.options.expungeHandler(payload);\n                } catch (err) {\n                    this.log.error({ msg: 'Failed to notify expunge event', payload, error: err, cid: this.id });\n                }\n            } else {\n                this.emit('expunge', payload);\n            }\n        }\n    }\n\n    async untaggedVanished(untagged, mailbox) {\n        mailbox = mailbox || this.mailbox;\n        if (!mailbox) {\n            // mailbox closed, ignore\n            return;\n        }\n\n        let tags = [];\n        let uids = false;\n\n        if (untagged.attributes.length > 1 && Array.isArray(untagged.attributes[0])) {\n            tags = untagged.attributes[0].map(entry => (typeof entry.value === 'string' ? entry.value.toUpperCase() : false)).filter(value => value);\n            untagged.attributes.shift();\n        }\n\n        if (untagged.attributes[0] && typeof untagged.attributes[0].value === 'string') {\n            uids = untagged.attributes[0].value;\n        }\n\n        let uidList = expandRange(uids);\n\n        for (let uid of uidList) {\n            let payload = {\n                path: mailbox.path,\n                uid,\n                vanished: true,\n                earlier: tags.includes('EARLIER')\n            };\n\n            if (typeof this.options.expungeHandler === 'function') {\n                try {\n                    await this.options.expungeHandler(payload);\n                } catch (err) {\n                    this.log.error({ msg: 'Failed to notify expunge event', payload, error: err, cid: this.id });\n                }\n            } else {\n                this.emit('expunge', payload);\n            }\n        }\n    }\n\n    async untaggedFetch(untagged, mailbox) {\n        mailbox = mailbox || this.mailbox;\n        if (!mailbox) {\n            // mailbox closed, ignore\n            return;\n        }\n\n        let message = await formatMessageResponse(untagged, mailbox);\n        if (message.flags) {\n            let updateEvent = {\n                path: mailbox.path,\n                seq: message.seq\n            };\n\n            if (message.uid) {\n                updateEvent.uid = message.uid;\n            }\n\n            if (message.modseq) {\n                updateEvent.modseq = message.modseq;\n            }\n\n            updateEvent.flags = message.flags;\n\n            if (message.flagColor) {\n                updateEvent.flagColor = message.flagColor;\n            }\n\n            this.emit('flags', updateEvent);\n        }\n    }\n\n    async ensureSelectedMailbox(path) {\n        if (!path) {\n            return false;\n        }\n\n        if ((!this.mailbox && path) || (this.mailbox && path && !comparePaths(this, this.mailbox.path, path))) {\n            return await this.mailboxOpen(path);\n        }\n\n        return true;\n    }\n\n    async resolveRange(range, options) {\n        if (typeof range === 'number' || typeof range === 'bigint') {\n            range = range.toString();\n        }\n\n        // special case, some servers allow this, some do not, so replace it with the last known EXISTS value\n        if (range === '*') {\n            if (!this.mailbox.exists) {\n                return false;\n            }\n            range = this.mailbox.exists.toString();\n            options.uid = false; // sequence query\n        }\n\n        if (range && typeof range === 'object' && !Array.isArray(range)) {\n            if (range.all && Object.keys(range).length === 1) {\n                range = '1:*';\n            } else if (range.uid && Object.keys(range).length === 1) {\n                range = range.uid;\n                options.uid = true;\n            } else {\n                // resolve range by searching\n                options.uid = true; // force UIDs instead of sequence numbers\n                range = await this.run('SEARCH', range, options);\n                if (range && range.length) {\n                    range = packMessageRange(range);\n                }\n            }\n        }\n\n        if (Array.isArray(range)) {\n            range = range.join(',');\n        }\n\n        if (!range) {\n            return false;\n        }\n\n        return range;\n    }\n\n    autoidle() {\n        clearTimeout(this.idleStartTimer);\n        if (this.options.disableAutoIdle || this.state !== this.states.SELECTED) {\n            return;\n        }\n        this.idleStartTimer = setTimeout(() => {\n            this.idle().catch(err => this.log.warn({ err, cid: this.id }));\n        }, 15 * 1000);\n    }\n\n    // PUBLIC API METHODS\n\n    /**\n     * Initiates a connection against IMAP server. Throws if anything goes wrong. This is something you have to call before you can run any IMAP commands\n     *\n     * @returns {Promise<void>}\n     * @throws Will throw an error if connection or authentication fails\n     * @example\n     * let client = new ImapFlow({...});\n     * await client.connect();\n     */\n    async connect() {\n        if (this._connectCalled) {\n            // Prevent re-using ImapFlow instances by allowing to call connect just once.\n            throw new Error('Can not re-use ImapFlow instance');\n        }\n        this._connectCalled = true;\n\n        let connector = this.secureConnection ? tls : net;\n\n        let opts = Object.assign(\n            {\n                host: this.host,\n                servername: this.servername,\n                port: this.port\n            },\n            this.options.tls || {}\n        );\n\n        this.untaggedHandlers.OK = (...args) => this.initialOK(...args);\n        this.untaggedHandlers.BYE = (...args) => this.serverBye(...args);\n        this.untaggedHandlers.PREAUTH = (...args) => this.initialPREAUTH(...args);\n\n        this.untaggedHandlers.CAPABILITY = (...args) => this.untaggedCapability(...args);\n        this.sectionHandlers.CAPABILITY = (...args) => this.sectionCapability(...args);\n\n        this.untaggedHandlers.EXISTS = (...args) => this.untaggedExists(...args);\n        this.untaggedHandlers.EXPUNGE = (...args) => this.untaggedExpunge(...args);\n\n        // these methods take an optional second argument, so make sure that some random IMAP tag is not used as the second argument\n        this.untaggedHandlers.FETCH = untagged => this.untaggedFetch(untagged);\n        this.untaggedHandlers.VANISHED = untagged => this.untaggedVanished(untagged);\n\n        let socket = false;\n        if (this.options.proxy) {\n            try {\n                socket = await proxyConnection(this.log, this.options.proxy, this.host, this.port);\n                if (!socket) {\n                    throw new Error('Failed to setup proxy connection');\n                }\n            } catch (err) {\n                let error = new Error('Failed to setup proxy connection');\n                error.code = err.code || 'ProxyError';\n                error._err = err;\n                this.log.error({ error, cid: this.id });\n                throw error;\n            }\n        }\n\n        await new Promise((resolve, reject) => {\n            this.connectTimeout = setTimeout(() => {\n                let err = new Error('Failed to establish connection in required time');\n                err.code = 'CONNECT_TIMEOUT';\n                err.details = {\n                    connectionTimeout: this.options.connectionTimeout || CONNECT_TIMEOUT\n                };\n                this.log.error({ err, cid: this.id });\n                setImmediate(() => this.close());\n                reject(err);\n            }, this.options.connectionTimeout || CONNECT_TIMEOUT);\n\n            let onConnect = () => {\n                clearTimeout(this.connectTimeout);\n                this.socket.setKeepAlive(true, 5 * 1000);\n                this.socket.setTimeout(this.options.socketTimeout || SOCKET_TIMEOUT);\n\n                this.greetingTimeout = setTimeout(() => {\n                    let err = new Error(`Failed to receive greeting from server in required time${!this.secureConnection ? '. Maybe should use TLS?' : ''}`);\n                    err.code = 'GREETING_TIMEOUT';\n                    err.details = {\n                        greetingTimeout: this.options.greetingTimeout || GREETING_TIMEOUT\n                    };\n                    this.log.error({ err, cid: this.id });\n                    setImmediate(() => this.close());\n                    reject(err);\n                }, this.options.greetingTimeout || GREETING_TIMEOUT);\n\n                this.tls = typeof this.socket.getCipher === 'function' ? this.socket.getCipher() : false;\n\n                let logInfo = {\n                    src: 'connection',\n                    msg: `Established ${this.tls ? 'secure ' : ''}TCP connection`,\n                    cid: this.id,\n                    secure: !!this.tls,\n                    host: this.host,\n                    servername: this.servername,\n                    port: this.socket.remotePort,\n                    address: this.socket.remoteAddress,\n                    localAddress: this.socket.localAddress,\n                    localPort: this.socket.localPort\n                };\n\n                if (this.tls) {\n                    logInfo.authorized = this.tls.authorized = this.socket.authorized;\n                    logInfo.algo = this.tls.standardName || this.tls.name;\n                    logInfo.version = this.tls.version;\n                }\n\n                this.log.info(logInfo);\n\n                this.setSocketHandlers();\n                this.socket.pipe(this.streamer);\n\n                // executed by initial \"* OK\"\n                this.initialResolve = resolve;\n                this.initialReject = reject;\n            };\n\n            if (socket) {\n                // socket is already established via proxy\n                if (this.secureConnection) {\n                    // TLS socket requires a handshake\n                    opts.socket = socket;\n                    this.socket = connector.connect(opts, onConnect);\n                } else {\n                    // cleartext socket is already usable\n                    this.socket = socket;\n                    setImmediate(onConnect);\n                }\n            } else {\n                this.socket = connector.connect(opts, onConnect);\n            }\n\n            this.writeSocket = this.socket;\n\n            this.socket.on('error', err => {\n                clearTimeout(this.connectTimeout);\n                clearTimeout(this.greetingTimeout);\n                setImmediate(() => this.close());\n                this.log.error({ err, cid: this.id });\n                reject(err);\n            });\n\n            this.setEventHandlers();\n        });\n    }\n\n    /**\n     * Graceful connection close by sending logout command to server. TCP connection is closed once command is finished.\n     *\n     * @return {Promise<void>}\n     * @example\n     * let client = new ImapFlow({...});\n     * await client.connect();\n     * ...\n     * await client.logout();\n     */\n    async logout() {\n        return await this.run('LOGOUT');\n    }\n\n    /**\n     * Closes TCP connection without notifying the server.\n     *\n     * @example\n     * let client = new ImapFlow({...});\n     * await client.connect();\n     * ...\n     * client.close();\n     */\n    close() {\n        // clear pending timers\n        clearTimeout(this.idleStartTimer);\n        clearTimeout(this.upgradeTimeout);\n        clearTimeout(this.connectTimeout);\n\n        this.usable = false;\n        this.idling = false;\n\n        if (typeof this.initialReject === 'function' && !this.options.verifyOnly) {\n            clearTimeout(this.greetingTimeout);\n            let reject = this.initialReject;\n            this.initialResolve = false;\n            this.initialReject = false;\n            let err = new Error('Unexpected close');\n            err.code = `ClosedAfterConnect${this.secureConnection ? 'TLS' : 'Text'}`;\n            // still has to go through the logic below\n            setImmediate(() => reject(err));\n        }\n\n        if (typeof this.preCheck === 'function') {\n            this.preCheck().catch(err => this.log.warn({ err, cid: this.id }));\n        }\n\n        // reject command that is currently processed\n        if (this.currentRequest && this.requestTagMap.has(this.currentRequest.tag)) {\n            let request = this.requestTagMap.get(this.currentRequest.tag);\n            if (request) {\n                this.requestTagMap.delete(request.tag);\n                const error = new Error('Connection not available');\n                error.code = 'NoConnection';\n                request.reject(error);\n            }\n            this.currentRequest = false;\n        }\n\n        // reject all other pending commands\n        while (this.requestQueue.length) {\n            let req = this.requestQueue.shift();\n            if (req && this.requestTagMap.has(req.tag)) {\n                let request = this.requestTagMap.get(req.tag);\n                if (request) {\n                    this.requestTagMap.delete(request.tag);\n                    const error = new Error('Connection not available');\n                    error.code = 'NoConnection';\n                    request.reject(error);\n                }\n            }\n        }\n\n        this.state = this.states.LOGOUT;\n        if (this.isClosed) {\n            return;\n        }\n        this.isClosed = true;\n\n        if (this.writeSocket && !this.writeSocket.destroyed) {\n            try {\n                this.writeSocket.destroy();\n            } catch (err) {\n                this.log.error({ err, cid: this.id });\n            }\n        }\n\n        if (this.socket && !this.socket.destroyed && this.writeSocket !== this.socket) {\n            try {\n                this.socket.destroy();\n            } catch (err) {\n                this.log.error({ err, cid: this.id });\n            }\n        }\n\n        this.log.trace({ msg: 'Connection closed', cid: this.id });\n        this.emit('close');\n    }\n\n    /**\n     * @typedef {Object} QuotaResponse\n     * @global\n     * @property {String} path=INBOX mailbox path this quota applies to\n     * @property {Object} [storage] Storage quota if provided by server\n     * @property {Number} [storage.used] used storage in bytes\n     * @property {Number} [storage.limit] total storage available\n     * @property {Object} [messages] Message count quota if provided by server\n     * @property {Number} [messages.used] stored messages\n     * @property {Number} [messages.limit] maximum messages allowed\n     */\n\n    /**\n     * Returns current quota\n     *\n     * @param {String} [path] Optional mailbox path if you want to check quota for specific folder\n     * @returns {Promise<QuotaResponse|Boolean>} Quota information or `false` if QUTOA extension is not supported or requested path does not exist\n     *\n     * @example\n     * let quota = await client.getQuota();\n     * console.log(quota.storage.used, quota.storage.available)\n     */\n    async getQuota(path) {\n        path = path || 'INBOX';\n        return await this.run('QUOTA', path);\n    }\n\n    /**\n     * @typedef {Object} ListResponse\n     * @global\n     * @property {String} path mailbox path (unicode string)\n     * @property {String} pathAsListed mailbox path as listed in the LIST/LSUB response\n     * @property {String} name mailbox name (last part of path after delimiter)\n     * @property {String} delimiter mailbox path delimiter, usually \".\" or \"/\"\n     * @property {String[]} parent An array of parent folder names. All names are in unicode\n     * @property {String} parentPath Same as `parent`, but as a complete string path (unicode string)\n     * @property {Set<string>} flags a set of flags for this mailbox\n     * @property {String} specialUse one of special-use flags (if applicable): \"\\All\", \"\\Archive\", \"\\Drafts\", \"\\Flagged\", \"\\Junk\", \"\\Sent\", \"\\Trash\". Additionally INBOX has non-standard \"\\Inbox\" flag set\n     * @property {Boolean} listed `true` if mailbox was found from the output of LIST command\n     * @property {Boolean} subscribed `true` if mailbox was found from the output of LSUB command\n     * @property {StatusObject} [status] If `statusQuery` was used, then this value includes the status response\n     */\n\n    /**\n     * @typedef {Object} ListOptions\n     * @global\n     * @property {Object} [statusQuery] request status items for every listed entry\n     * @property {Boolean} [statusQuery.messages] if `true` request count of messages\n     * @property {Boolean} [statusQuery.recent] if `true` request count of messages with \\\\Recent tag\n     * @property {Boolean} [statusQuery.uidNext] if `true` request predicted next UID\n     * @property {Boolean} [statusQuery.uidValidity] if `true` request mailbox `UIDVALIDITY` value\n     * @property {Boolean} [statusQuery.unseen] if `true` request count of unseen messages\n     * @property {Boolean} [statusQuery.highestModseq] if `true` request last known modseq value\n     * @property {Object} [specialUseHints] set specific paths as special use folders, this would override special use flags provided from the server\n     * @property {String} [specialUseHints.sent] Path to \"Sent Mail\" folder\n     * @property {String} [specialUseHints.trash] Path to \"Trash\" folder\n     * @property {String} [specialUseHints.junk] Path to \"Junk Mail\" folder\n     * @property {String} [specialUseHints.drafts] Path to \"Drafts\" folder\n     */\n\n    /**\n     * Lists available mailboxes as an Array\n     *\n     * @param {ListOptions} [options] defines additional listing options\n     * @returns {Promise<ListResponse[]>} An array of ListResponse objects\n     *\n     * @example\n     * let list = await client.list();\n     * list.forEach(mailbox=>console.log(mailbox.path));\n     */\n    async list(options) {\n        options = options || {};\n        let folders = await this.run('LIST', '', '*', options);\n        this.folders = new Map(folders.map(folder => [folder.path, folder]));\n        return folders;\n    }\n\n    /**\n     * @typedef {Object} ListTreeResponse\n     * @global\n     * @property {Boolean} root If `true` then this is root node without any additional properties besides *folders*\n     * @property {String} path mailbox path\n     * @property {String} name mailbox name (last part of path after delimiter)\n     * @property {String} delimiter mailbox path delimiter, usually \".\" or \"/\"\n     * @property {String[]} flags list of flags for this mailbox\n     * @property {String} specialUse one of special-use flags (if applicable): \"\\All\", \"\\Archive\", \"\\Drafts\", \"\\Flagged\", \"\\Junk\", \"\\Sent\", \"\\Trash\". Additionally INBOX has non-standard \"\\Inbox\" flag set\n     * @property {Boolean} listed `true` if mailbox was found from the output of LIST command\n     * @property {Boolean} subscribed `true` if mailbox was found from the output of LSUB command\n     * @property {Boolean} disabled If `true` then this mailbox can not be selected in the UI\n     * @property {ListTreeResponse[]} folders An array of subfolders\n     */\n\n    /**\n     * Lists available mailboxes as a tree structured object\n     *\n     * @param {ListOptions} [options] defines additional listing options\n     * @returns {Promise<ListTreeResponse>} Tree structured object\n     *\n     * @example\n     * let tree = await client.listTree();\n     * tree.folders.forEach(mailbox=>console.log(mailbox.path));\n     */\n    async listTree(options) {\n        options = options || {};\n        let folders = await this.run('LIST', '', '*', options);\n        this.folders = new Map(folders.map(folder => [folder.path, folder]));\n        return getFolderTree(folders);\n    }\n\n    /**\n     * Performs a no-op call against server\n     * @returns {Promise<void>}\n     */\n    async noop() {\n        await this.run('NOOP');\n    }\n\n    /**\n     * @typedef {Object} MailboxCreateResponse\n     * @global\n     * @property {String} path full mailbox path\n     * @property {String} [mailboxId] unique mailbox ID if server supports `OBJECTID` extension (currently Yahoo and some others)\n     * @property {Boolean} created If `true` then mailbox was created otherwise it already existed\n     */\n\n    /**\n     * Creates a new mailbox folder and sets up subscription for the created mailbox. Throws on error.\n     *\n     * @param {string|array} path Full mailbox path. Unicode is allowed. If value is an array then it is joined using current delimiter symbols. Namespace prefix is added automatically if required.\n     * @returns {Promise<MailboxCreateResponse>} Mailbox info\n     * @throws Will throw an error if mailbox can not be created\n     *\n     * @example\n     * let info = await client.mailboxCreate(['parent', 'child']);\n     * console.log(info.path);\n     * // \"INBOX.parent.child\" // assumes \"INBOX.\" as namespace prefix and \".\" as delimiter\n     */\n    async mailboxCreate(path) {\n        return await this.run('CREATE', path);\n    }\n\n    /**\n     * @typedef {Object} MailboxRenameResponse\n     * @global\n     * @property {String} path full mailbox path that was renamed\n     * @property {String} newPath new full mailbox path\n     */\n\n    /**\n     * Renames a mailbox. Throws on error.\n     *\n     * @param {string|array} path  Path for the mailbox to rename. Unicode is allowed. If value is an array then it is joined using current delimiter symbols. Namespace prefix is added automatically if required.\n     * @param {string|array} newPath New path for the mailbox\n     * @returns {Promise<MailboxRenameResponse>} Mailbox info\n     * @throws Will throw an error if mailbox does not exist or can not be renamed\n     *\n     * @example\n     * let info = await client.mailboxRename('parent.child', 'Important stuff ❗️');\n     * console.log(info.newPath);\n     * // \"INBOX.Important stuff ❗️\" // assumes \"INBOX.\" as namespace prefix\n     */\n    async mailboxRename(path, newPath) {\n        return await this.run('RENAME', path, newPath);\n    }\n\n    /**\n     * @typedef {Object} MailboxDeleteResponse\n     * @global\n     * @property {String} path full mailbox path that was deleted\n     */\n\n    /**\n     * Deletes a mailbox. Throws on error.\n     *\n     * @param {string|array} path Path for the mailbox to delete. Unicode is allowed. If value is an array then it is joined using current delimiter symbols. Namespace prefix is added automatically if required.\n     * @returns {Promise<MailboxDeleteResponse>} Mailbox info\n     * @throws Will throw an error if mailbox does not exist or can not be deleted\n     *\n     * @example\n     * let info = await client.mailboxDelete('Important stuff ❗️');\n     * console.log(info.path);\n     * // \"INBOX.Important stuff ❗️\" // assumes \"INBOX.\" as namespace prefix\n     */\n    async mailboxDelete(path) {\n        return await this.run('DELETE', path);\n    }\n\n    /**\n     * Subscribes to a mailbox\n     *\n     * @param {string|array} path Path for the mailbox to subscribe to. Unicode is allowed. If value is an array then it is joined using current delimiter symbols. Namespace prefix is added automatically if required.\n     * @returns {Promise<Boolean>} `true` if subscription operation succeeded, `false` otherwise\n     *\n     * @example\n     * await client.mailboxSubscribe('Important stuff ❗️');\n     */\n    async mailboxSubscribe(path) {\n        return await this.run('SUBSCRIBE', path);\n    }\n\n    /**\n     * Unsubscribes from a mailbox\n     *\n     * @param {string|array} path **Path for the mailbox** to unsubscribe from. Unicode is allowed. If value is an array then it is joined using current delimiter symbols. Namespace prefix is added automatically if required.\n     * @returns {Promise<Boolean>} `true` if unsubscription operation succeeded, `false` otherwise\n     *\n     * @example\n     * await client.mailboxUnsubscribe('Important stuff ❗️');\n     */\n    async mailboxUnsubscribe(path) {\n        return await this.run('UNSUBSCRIBE', path);\n    }\n\n    /**\n     * Opens a mailbox to access messages. You can perform message operations only against an opened mailbox.\n     * Using {@link module:imapflow~ImapFlow#getMailboxLock|getMailboxLock()} instead of `mailboxOpen()` is preferred. Both do the same thing\n     * but next `getMailboxLock()` call is not executed until previous one is released.\n     *\n     * @param {string|array} path **Path for the mailbox** to open\n     * @param {Object} [options] optional options\n     * @param {Boolean} [options.readOnly=false] If `true` then opens mailbox in read-only mode. You can still try to perform write operations but these would probably fail.\n     * @returns {Promise<MailboxObject>} Mailbox info\n     * @throws Will throw an error if mailbox does not exist or can not be opened\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('Important stuff ❗️');\n     * console.log(mailbox.exists);\n     * // 125\n     */\n    async mailboxOpen(path, options) {\n        return await this.run('SELECT', path, options);\n    }\n\n    /**\n     * Closes a previously opened mailbox\n     *\n     * @returns {Promise<Boolean>} Did the operation succeed or not\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * await client.mailboxClose();\n     */\n    async mailboxClose() {\n        return await this.run('CLOSE');\n    }\n\n    /**\n     * @typedef {Object} StatusObject\n     * @global\n     * @property {String} path full mailbox path that was checked\n     * @property {Number} [messages] Count of messages\n     * @property {Number} [recent] Count of messages with \\\\Recent tag\n     * @property {Number} [uidNext] Predicted next UID\n     * @property {BigInt} [uidValidity] Mailbox `UIDVALIDITY` value\n     * @property {Number} [unseen] Count of unseen messages\n     * @property {BigInt} [highestModseq] Last known modseq value (if CONDSTORE extension is enabled)\n     */\n\n    /**\n     * Requests the status of the indicated mailbox. Only requested status values will be returned.\n     *\n     * @param {String} path mailbox path to check for (unicode string)\n     * @param {Object} query defines requested status items\n     * @param {Boolean} query.messages if `true` request count of messages\n     * @param {Boolean} query.recent if `true` request count of messages with \\\\Recent tag\n     * @param {Boolean} query.uidNext if `true` request predicted next UID\n     * @param {Boolean} query.uidValidity if `true` request mailbox `UIDVALIDITY` value\n     * @param {Boolean} query.unseen if `true` request count of unseen messages\n     * @param {Boolean} query.highestModseq if `true` request last known modseq value\n     * @returns {Promise<StatusObject>} status of the indicated mailbox\n     *\n     * @example\n     * let status = await client.status('INBOX', {unseen: true});\n     * console.log(status.unseen);\n     * // 123\n     */\n    async status(path, query) {\n        return await this.run('STATUS', path, query);\n    }\n\n    /**\n     * Starts listening for new or deleted messages from the currently opened mailbox. Only required if {@link ImapFlow#disableAutoIdle} is set to `true`\n     * otherwise IDLE is started by default on connection inactivity. NB! If `idle()` is called manually then it does not\n     * return until IDLE is finished which means you would have to call some other command out of scope.\n     *\n     * @returns {Promise<Boolean>} Did the operation succeed or not\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     *\n     * await client.idle();\n     */\n    async idle() {\n        if (!this.idling) {\n            return await this.run('IDLE', this.maxIdleTime);\n        }\n    }\n\n    /**\n     * Sequence range string. Separate different values with commas, number ranges with colons and use \\\\* as the placeholder for the newest message in mailbox\n     * @typedef {String} SequenceString\n     * @global\n     * @example\n     * \"1:*\" // for all messages\n     * \"1,2,3\" // for messages 1, 2 and 3\n     * \"1,2,4:6\" // for messages 1,2,4,5,6\n     * \"*\" // for the newest message\n     */\n\n    /**\n     * IMAP search query options. By default all conditions must match. In case of `or` query term at least one condition must match.\n     * @typedef {Object} SearchObject\n     * @global\n     * @property {SequenceString} [seq] message ordering sequence range\n     * @property {Boolean} [answered] Messages with (value is `true`) or without (value is `false`) \\\\Answered flag\n     * @property {Boolean} [deleted] Messages with (value is `true`) or without (value is `false`) \\\\Deleted flag\n     * @property {Boolean} [draft] Messages with (value is `true`) or without (value is `false`) \\\\Draft flag\n     * @property {Boolean} [flagged] Messages with (value is `true`) or without (value is `false`) \\\\Flagged flag\n     * @property {Boolean} [seen] Messages with (value is `true`) or without (value is `false`) \\\\Seen flag\n     * @property {Boolean} [all] If `true` matches all messages\n     * @property {Boolean} [new] If `true` matches messages that have the \\\\Recent flag set but not the \\\\Seen flag\n     * @property {Boolean} [old] If `true` matches messages that do not have the \\\\Recent flag set\n     * @property {Boolean} [recent] If `true` matches messages that have the \\\\Recent flag set\n     * @property {String} [from] Matches From: address field\n     * @property {String} [to] Matches To: address field\n     * @property {String} [cc] Matches Cc: address field\n     * @property {String} [bcc] Matches Bcc: address field\n     * @property {String} [body] Matches message body\n     * @property {String} [subject] Matches message subject\n     * @property {Number} [larger] Matches messages larger than value\n     * @property {Number} [smaller] Matches messages smaller than value\n     * @property {SequenceString} [uid] UID sequence range\n     * @property {BigInt} [modseq] Matches messages with modseq higher than value\n     * @property {String} [emailId] unique email ID. Only used if server supports `OBJECTID` or `X-GM-EXT-1` extensions\n     * @property {String} [threadId] unique thread ID. Only used if server supports `OBJECTID` or `X-GM-EXT-1` extensions\n     * @property {Date|string} [before] Matches messages received before date\n     * @property {Date|string} [on] Matches messages received on date (ignores time)\n     * @property {Date|string} [since] Matches messages received after date\n     * @property {Date|string} [sentBefore] Matches messages sent before date\n     * @property {Date|string} [sentOn] Matches messages sent on date (ignores time)\n     * @property {Date|string} [sentSince] Matches messages sent after date\n     * @property {String} [keyword] Matches messages that have the custom flag set\n     * @property {String} [unKeyword] Matches messages that do not have the custom flag set\n     * @property {Object.<string, Boolean|String>} [header] Matches messages with header key set if value is `true` (**NB!** not supported by all servers) or messages where header partially matches a string value\n     * @property {SearchObject[]} [or] An array of 2 or more {@link SearchObject} objects. At least on of these must match\n     */\n\n    /**\n     * Sets flags for a message or message range\n     *\n     * @param {SequenceString | Number[] | SearchObject} range Range to filter the messages\n     * @param {string[]} Array of flags to set. Only flags that are permitted to set are used, other flags are ignored\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n     * @param {BigInt} [options.unchangedSince] If set then only messages with a lower or equal `modseq` value are updated. Ignored if server does not support `CONDSTORE` extension.\n     * @param {Boolean} [options.useLabels=false] If true then update Gmail labels instead of message flags\n     * @returns {Promise<Boolean>} Did the operation succeed or not\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // mark all unseen messages as seen (and remove other flags)\n     * await client.messageFlagsSet({seen: false}, ['\\Seen]);\n     */\n    async messageFlagsSet(range, flags, options) {\n        options = options || {};\n\n        range = await this.resolveRange(range, options);\n        if (!range) {\n            return false;\n        }\n\n        let queryOpts = Object.assign(\n            {\n                operation: 'set'\n            },\n            options\n        );\n\n        return await this.run('STORE', range, flags, queryOpts);\n    }\n\n    /**\n     * Adds flags for a message or message range\n     *\n     * @param {SequenceString | Number[] | SearchObject} range Range to filter the messages\n     * @param {string[]} Array of flags to set. Only flags that are permitted to set are used, other flags are ignored\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n     * @param {BigInt} [options.unchangedSince] If set then only messages with a lower or equal `modseq` value are updated. Ignored if server does not support `CONDSTORE` extension.\n     * @param {Boolean} [options.useLabels=false] If true then update Gmail labels instead of message flags\n     * @returns {Promise<Boolean>} Did the operation succeed or not\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // mark all unseen messages as seen (and keep other flags as is)\n     * await client.messageFlagsAdd({seen: false}, ['\\Seen]);\n     */\n    async messageFlagsAdd(range, flags, options) {\n        options = options || {};\n\n        range = await this.resolveRange(range, options);\n        if (!range) {\n            return false;\n        }\n\n        let queryOpts = Object.assign(\n            {\n                operation: 'add'\n            },\n            options\n        );\n\n        return await this.run('STORE', range, flags, queryOpts);\n    }\n\n    /**\n     * Remove specific flags from a message or message range\n     *\n     * @param {SequenceString | Number[] | SearchObject} range Range to filter the messages\n     * @param {string[]} Array of flags to remove. Only flags that are permitted to set are used, other flags are ignored\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n     * @param {BigInt} [options.unchangedSince] If set then only messages with a lower or equal `modseq` value are updated. Ignored if server does not support `CONDSTORE` extension.\n     * @param {Boolean} [options.useLabels=false] If true then update Gmail labels instead of message flags\n     * @returns {Promise<Boolean>} Did the operation succeed or not\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // mark all seen messages as unseen by removing \\\\Seen flag\n     * await client.messageFlagsRemove({seen: true}, ['\\Seen]);\n     */\n    async messageFlagsRemove(range, flags, options) {\n        options = options || {};\n\n        range = await this.resolveRange(range, options);\n        if (!range) {\n            return false;\n        }\n\n        let queryOpts = Object.assign(\n            {\n                operation: 'remove'\n            },\n            options\n        );\n\n        return await this.run('STORE', range, flags, queryOpts);\n    }\n\n    /**\n     * Sets a colored flag for an email. Only supported by mail clients like Apple Mail\n     *\n     * @param {SequenceString | Number[] | SearchObject} range Range to filter the messages\n     * @param {string} The color to set. One of 'red', 'orange', 'yellow', 'green', 'blue', 'purple', and 'grey'\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n     * @param {BigInt} [options.unchangedSince] If set then only messages with a lower or equal `modseq` value are updated. Ignored if server does not support `CONDSTORE` extension.\n     * @returns {Promise<Boolean>} Did the operation succeed or not\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // add a purple flag for all emails\n     * await client.setFlagColor('1:*', 'Purple');\n     */\n    async setFlagColor(range, color, options) {\n        options = options || {};\n\n        range = await this.resolveRange(range, options);\n        if (!range) {\n            return false;\n        }\n\n        let flagChanges = getColorFlags(color);\n        if (!flagChanges) {\n            return false;\n        }\n\n        let addResults;\n        let removeResults;\n\n        if (flagChanges.add && flagChanges.add.length) {\n            let queryOpts = Object.assign(\n                {\n                    operation: 'add'\n                },\n                options,\n                {\n                    useLabels: false, // override if set\n                    // prevent triggering a premature Flags change notification\n                    silent: flagChanges.remove && flagChanges.remove.length\n                }\n            );\n\n            addResults = await this.run('STORE', range, flagChanges.add, queryOpts);\n        }\n\n        if (flagChanges.remove && flagChanges.remove.length) {\n            let queryOpts = Object.assign(\n                {\n                    operation: 'remove'\n                },\n                options,\n                { useLabels: false } // override if set\n            );\n\n            removeResults = await this.run('STORE', range, flagChanges.remove, queryOpts);\n        }\n\n        return addResults || removeResults || false;\n    }\n\n    /**\n     * Delete messages from the currently opened mailbox. Method does not indicate info about deleted messages,\n     * instead you should be using {@link ImapFlow#expunge} event for this\n     *\n     * @param {SequenceString | Number[] | SearchObject} range Range to filter the messages\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n     * @returns {Promise<Boolean>} Did the operation succeed or not\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // delete all seen messages\n     * await client.messageDelete({seen: true});\n     */\n    async messageDelete(range, options) {\n        options = options || {};\n        range = await this.resolveRange(range, options);\n        if (!range) {\n            return false;\n        }\n        return await this.run('EXPUNGE', range, options);\n    }\n\n    /**\n     * @typedef {Object} AppendResponseObject\n     * @global\n     * @property {String} destination full mailbox path where the message was uploaded to\n     * @property {BigInt} [uidValidity] mailbox `UIDVALIDITY` if server has `UIDPLUS` extension enabled\n     * @property {Number} [uid] UID of the uploaded message if server has `UIDPLUS` extension enabled\n     * @property {Number} [seq] sequence number of the uploaded message if path is currently selected mailbox\n     */\n\n    /**\n     * Appends a new message to a mailbox\n     *\n     * @param {String} path Mailbox path to upload the message to (unicode string)\n     * @param {string|Buffer} content RFC822 formatted email message\n     * @param {string[]} [flags] an array of flags to be set for the uploaded message\n     * @param {Date|string} [idate=now] internal date to be set for the message\n     * @returns {Promise<AppendResponseObject>} info about uploaded message\n     *\n     * @example\n     * await client.append('INBOX', rawMessageBuffer, ['\\\\Seen'], new Date(2000, 1, 1));\n     */\n    async append(path, content, flags, idate) {\n        let response = await this.run('APPEND', path, content, flags, idate);\n\n        if (!response) {\n            return false;\n        }\n\n        return response;\n    }\n\n    /**\n     * @typedef {Object} CopyResponseObject\n     * @global\n     * @property {String} path path of source mailbox\n     * @property {String} destination path of destination mailbox\n     * @property {BigInt} [uidValidity] destination mailbox `UIDVALIDITY` if server has `UIDPLUS` extension enabled\n     * @property {Map<number, number>} [uidMap] Map of UID values (if server has `UIDPLUS` extension enabled) where key is UID in source mailbox and value is the UID for the same message in destination mailbox\n     */\n\n    /**\n     * Copies messages from current mailbox to destination mailbox\n     *\n     * @param {SequenceString | Number[] | SearchObject} range Range of messages to copy\n     * @param {String} destination Mailbox path to copy the messages to\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n     * @returns {Promise<CopyResponseObject>} info about copies messages\n     *\n     * @example\n     * await client.mailboxOpen('INBOX');\n     * // copy all messages to a mailbox called \"Backup\" (must exist)\n     * let result = await client.messageCopy('1:*', 'Backup');\n     * console.log('Copied %s messages', result.uidMap.size);\n     */\n    async messageCopy(range, destination, options) {\n        options = options || {};\n        range = await this.resolveRange(range, options);\n        if (!range) {\n            return false;\n        }\n        return await this.run('COPY', range, destination, options);\n    }\n\n    /**\n     * Moves messages from current mailbox to destination mailbox\n     *\n     * @param {SequenceString | Number[] | SearchObject} range Range of messages to move\n     * @param {String} destination Mailbox path to move the messages to\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n     * @returns {Promise<CopyResponseObject>} info about moved messages\n     *\n     * @example\n     * await client.mailboxOpen('INBOX');\n     * // move all messages to a mailbox called \"Trash\" (must exist)\n     * let result = await client.messageMove('1:*', 'Trash');\n     * console.log('Moved %s messages', result.uidMap.size);\n     */\n    async messageMove(range, destination, options) {\n        options = options || {};\n        range = await this.resolveRange(range, options);\n        if (!range) {\n            return false;\n        }\n        return await this.run('MOVE', range, destination, options);\n    }\n\n    /**\n     * Search messages from the currently opened mailbox\n     *\n     * @param {SearchObject} query Query to filter the messages\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then returns UID numbers instead of sequence numbers\n     * @returns {Promise<Number[]>} An array of sequence or UID numbers\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // find all unseen messages\n     * let list = await client.search({seen: false});\n     * // use OR modifier (array of 2 or more search queries)\n     * let list = await client.search({\n     *   seen: false,\n     *   or: [\n     *     {flagged: true},\n     *     {from: 'andris'},\n     *     {subject: 'test'}\n     *   ]});\n     */\n    async search(query, options) {\n        if (!this.mailbox) {\n            // no mailbox selected, nothing to do\n            return;\n        }\n\n        let response = await this.run('SEARCH', query, options);\n\n        if (!response) {\n            return false;\n        }\n\n        return response;\n    }\n\n    /**\n     * @typedef {Object} FetchQueryObject\n     * @global\n     * @property {Boolean} [uid] if `true` then include UID in the response\n     * @property {Boolean} [flags] if `true` then include flags Set in the response. Also adds `flagColor` to the response if the message is flagged.\n     * @property {Boolean} [bodyStructure] if `true` then include parsed BODYSTRUCTURE object in the response\n     * @property {Boolean} [envelope] if `true` then include parsed ENVELOPE object in the response\n     * @property {Boolean} [internalDate] if `true` then include internal date value in the response\n     * @property {Boolean} [size] if `true` then include message size in the response\n     * @property {boolean | Object} [source] if `true` then include full message in the response\n     * @property {Number} [source.start] include full message in the response starting from *start* byte\n     * @property {Number} [source.maxLength] include full message in the response, up to *maxLength* bytes\n     * @property {String} [threadId] if `true` then include thread ID in the response (only if server supports either `OBJECTID` or `X-GM-EXT-1` extensions)\n     * @property {Boolean} [labels] if `true` then include GMail labels in the response (only if server supports `X-GM-EXT-1` extension)\n     * @property {boolean | string[]} [headers] if `true` then includes full headers of the message in the response. If the value is an array of header keys then includes only headers listed in the array\n     * @property {string[]} [bodyParts] An array of BODYPART identifiers to include in the response\n     */\n\n    /**\n     * Parsed email address entry\n     *\n     * @typedef {Object} MessageAddressObject\n     * @global\n     * @property {String} [name] name of the address object (unicode)\n     * @property {String} [address] email address\n     */\n\n    /**\n     * Parsed IMAP ENVELOPE object\n     *\n     * @typedef {Object} MessageEnvelopeObject\n     * @global\n     * @property {Date} [date] header date\n     * @property {String} [subject] message subject (unicode)\n     * @property {String} [messageId] Message ID of the message\n     * @property {String} [inReplyTo] Message ID from In-Reply-To header\n     * @property {MessageAddressObject[]} [from] Array of addresses from the From: header\n     * @property {MessageAddressObject[]} [sender] Array of addresses from the Sender: header\n     * @property {MessageAddressObject[]} [replyTo] Array of addresses from the Reply-To: header\n     * @property {MessageAddressObject[]} [to] Array of addresses from the To: header\n     * @property {MessageAddressObject[]} [cc] Array of addresses from the Cc: header\n     * @property {MessageAddressObject[]} [bcc] Array of addresses from the Bcc: header\n     */\n\n    /**\n     * Parsed IMAP BODYSTRUCTURE object\n     *\n     * @typedef {Object} MessageStructureObject\n     * @global\n     * @property {String} part Body part number. This value can be used to later fetch the contents of this part of the message\n     * @property {String} type Content-Type of this node\n     * @property {Object} [parameters] Additional parameters for Content-Type, eg \"charset\"\n     * @property {String} [id] Content-ID\n     * @property {String} [encoding] Transfer encoding\n     * @property {Number} [size] Expected size of the node\n     * @property {MessageEnvelopeObject} [envelope] message envelope of embedded RFC822 message\n     * @property {String} [disposition] Content disposition\n     * @property {Object} [dispositionParameters] Additional parameters for Content-Disposition\n     * @property {MessageStructureObject[]} childNodes An array of child nodes if this is a multipart node. Not present for normal nodes\n     */\n\n    /**\n     * Fetched message data\n     *\n     * @typedef {Object} FetchMessageObject\n     * @global\n     * @property {Number} seq message sequence number. Always included in the response\n     * @property {Number} uid message UID number. Always included in the response\n     * @property {Buffer} [source] message source for the requested byte range\n     * @property {BigInt} [modseq] message Modseq number. Always included if the server supports CONDSTORE extension\n     * @property {String} [emailId] unique email ID. Always included if server supports `OBJECTID` or `X-GM-EXT-1` extensions\n     * @property {String} [threadid] unique thread ID. Only present if server supports `OBJECTID` or `X-GM-EXT-1` extension\n     * @property {Set<string>} [labels] a Set of labels. Only present if server supports `X-GM-EXT-1` extension\n     * @property {Number} [size] message size\n     * @property {Set<string>} [flags] a set of message flags\n     * @property {String} [flagColor] flag color like \"red\", or \"yellow\". This value is derived from the `flags` Set and it uses the same color rules as Apple Mail\n     * @property {MessageEnvelopeObject} [envelope] message envelope\n     * @property {MessageStructureObject} [bodyStructure] message body structure\n     * @property {Date} [internalDate] message internal date\n     * @property {Map<string, Buffer>} [bodyParts] a Map of message body parts where key is requested part identifier and value is a Buffer\n     * @property {Buffer} [headers] Requested header lines as Buffer\n     */\n\n    /**\n     * Fetch messages from the currently opened mailbox\n     *\n     * @param {SequenceString | Number[] | SearchObject} range Range of messages to fetch\n     * @param {FetchQueryObject} query Fetch query\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID numbers instead of sequence numbers for `range`\n     * @param {BigInt} [options.changedSince] If set then only messages with a higher modseq value are returned. Ignored if server does not support `CONDSTORE` extension.\n     * @param {Boolean} [options.binary=false] If `true` then requests a binary response if the server supports this\n     * @yields {Promise<FetchMessageObject>} Message data object\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // fetch UID for all messages in a mailbox\n     * for await (let msg of client.fetch('1:*', {uid: true})){\n     *     console.log(msg.uid);\n     *     // NB! You can not run any IMAP commands in this loop\n     *     // otherwise you will end up in a deadloop\n     * }\n     */\n    async *fetch(range, query, options) {\n        options = options || {};\n\n        if (!this.mailbox) {\n            // no mailbox selected, nothing to do\n            return;\n        }\n\n        range = await this.resolveRange(range, options);\n        if (!range) {\n            return false;\n        }\n\n        let finished = false;\n        let push = false;\n        let rowQueue = [];\n\n        let getNext = () =>\n            new Promise((resolve, reject) => {\n                let check = () => {\n                    if (rowQueue.length) {\n                        let entry = rowQueue.shift();\n                        if (entry.err) {\n                            return reject(entry.err);\n                        } else {\n                            return resolve(entry.value);\n                        }\n                    }\n\n                    if (finished) {\n                        return resolve(null);\n                    }\n\n                    // wait until data is pushed to queue and try again\n                    push = () => {\n                        push = false;\n                        check();\n                    };\n                };\n                check();\n            });\n\n        this.run('FETCH', range, query, {\n            uid: !!options.uid,\n            binary: options.binary,\n            changedSince: options.changedSince,\n            onUntaggedFetch: (untagged, next) => {\n                rowQueue.push({\n                    value: {\n                        response: untagged,\n                        next\n                    }\n                });\n                if (typeof push === 'function') {\n                    push();\n                }\n            }\n        })\n            .then(() => {\n                finished = true;\n                if (typeof push === 'function') {\n                    push();\n                }\n            })\n            .catch(err => {\n                rowQueue.push({ err });\n                if (typeof push === 'function') {\n                    push();\n                }\n            });\n\n        let res;\n        while ((res = await getNext())) {\n            if (this.isClosed || this.socket.destroyed) {\n                let error = new Error('Connection closed');\n                error.code = 'EConnectionClosed';\n                throw error;\n            }\n\n            if (res !== null) {\n                yield res.response;\n                res.next();\n            }\n        }\n\n        if (!finished) {\n            // FETCH never finished!\n            let error = new Error('FETCH did not finish');\n            error.code = 'ENotFinished';\n            throw error;\n        }\n    }\n\n    /**\n     * Fetch messages from the currently opened mailbox.\n     *\n     * This method will fetch all messages before resolving the promise, unlike .fetch(), which\n     * is an async generator. Do not use large ranges like 1:*, as this might exhaust all available\n     * memory if the mailbox contains a large number of emails.\n     * @param {SequenceString | Number[] | SearchObject} range Range of messages to fetch\n     * @param {FetchQueryObject} query Fetch query\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID numbers instead of sequence numbers for `range`\n     * @param {BigInt} [options.changedSince] If set then only messages with a higher modseq value are returned. Ignored if server does not support `CONDSTORE` extension.\n     * @param {Boolean} [options.binary=false] If `true` then requests a binary response if the server supports this\n     * @returns {Promise<FetchMessageObject[]>} Array of Message data object\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // fetch UID for all messages in a mailbox\n     * const messages = await client.fetchAll('1:*', {uid: true});\n     * for (let msg of messages){\n     *     console.log(msg.uid);\n     * }\n     */\n    async fetchAll(range, query, options) {\n        const results = [];\n        const generator = this.fetch(range, query, options);\n        for await (const message of generator) {\n            results.push(message);\n        }\n        return results;\n    }\n\n    /**\n     * Fetch a single message from the currently opened mailbox\n     *\n     * @param {SequenceString} seq Single UID or sequence number of the message to fetch for\n     * @param {FetchQueryObject} query Fetch query\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID number instead of sequence number for `seq`\n     * @param {Boolean} [options.binary=false] If `true` then requests a binary response if the server supports this\n     * @returns {Promise<FetchMessageObject>} Message data object\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // fetch UID for the last email in the selected mailbox\n     * let lastMsg = await client.fetchOne('*', {uid: true})\n     * console.log(lastMsg.uid);\n     */\n    async fetchOne(seq, query, options) {\n        if (!this.mailbox) {\n            // no mailbox selected, nothing to do\n            return;\n        }\n\n        if (seq === '*') {\n            if (!this.mailbox.exists) {\n                return false;\n            }\n            seq = this.mailbox.exists.toString();\n            options = Object.assign({}, options || {}, { uid: false }); // force into a sequence query\n        }\n\n        let response = await this.run('FETCH', (seq || '').toString(), query, options);\n\n        if (!response || !response.list || !response.list.length) {\n            return false;\n        }\n\n        return response.list[0];\n    }\n\n    /**\n     * @typedef {Object} DownloadObject\n     * @global\n     * @property {Object} meta content metadata\n     * @property {number} meta.expectedSize The fetch response size\n     * @property {String} meta.contentType Content-Type of the streamed file. If part was not set then this value is \"message/rfc822\"\n     * @property {String} [meta.charset] Charset of the body part. Text parts are automatically converted to UTF-8, attachments are kept as is\n     * @property {String} [meta.disposition] Content-Disposition of the streamed file\n     * @property {String} [meta.filename] Filename of the streamed body part\n     * @property {ReadableStream} content Streamed content\n     */\n\n    /**\n     * Download either full rfc822 formatted message or a specific bodystructure part as a Stream.\n     * Bodystructure parts are decoded so the resulting stream is a binary file. Text content\n     * is automatically converted to UTF-8 charset.\n     *\n     * @param {SequenceString} range UID or sequence number for the message to fetch\n     * @param {String} [part] If not set then downloads entire rfc822 formatted message, otherwise downloads specific bodystructure part\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID number instead of sequence number for `range`\n     * @param {number} [options.maxBytes] If set then limits download size to specified bytes\n     * @param {number} [options.chunkSize=65536] How large content parts to ask from the server\n     * @returns {Promise<DownloadObject>} Download data object\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // download body part nr '1.2' from latest message\n     * let {meta, content} = await client.download('*', '1.2');\n     * content.pipe(fs.createWriteStream(meta.filename));\n     */\n    async download(range, part, options) {\n        if (!this.mailbox) {\n            // no mailbox selected, nothing to do\n            return {};\n        }\n\n        options = Object.assign(\n            {\n                chunkSize: 64 * 1024,\n                maxBytes: Infinity\n            },\n            options || {}\n        );\n\n        let hasMore = true;\n        let processed = 0;\n\n        let chunkSize = Number(options.chunkSize) || 64 * 1024;\n        let maxBytes = Number(options.maxBytes) || Infinity;\n\n        let uid = false;\n\n        if (part === '1') {\n            // First part has special conditions for single node emails as\n            // the mime parts for root node are not 1 and 1.MIME but TEXT and HEADERS\n            let response = await this.fetchOne(range, { uid: true, bodyStructure: true }, options);\n\n            if (!response) {\n                return { response: false, chunk: false };\n            }\n\n            if (!uid && response.uid) {\n                uid = response.uid;\n                // force UID from now on even if first range was a sequence number\n                range = uid;\n                options.uid = true;\n            }\n\n            if (!response.bodyStructure.childNodes) {\n                // single text message\n                part = 'TEXT';\n            }\n        }\n\n        let getNextPart = async query => {\n            query = query || {};\n\n            let mimeKey;\n\n            if (!part) {\n                query.source = {\n                    start: processed,\n                    maxLength: chunkSize\n                };\n            } else {\n                part = part.toString().toLowerCase().trim();\n\n                if (!query.bodyParts) {\n                    query.bodyParts = [];\n                }\n\n                if (query.size) {\n                    if (/^[\\d.]+$/.test(part)) {\n                        // fetch meta as well\n                        mimeKey = part + '.mime';\n                        query.bodyParts.push(mimeKey);\n                    } else if (part === 'text') {\n                        mimeKey = 'header';\n                        query.bodyParts.push(mimeKey);\n                    }\n                }\n\n                query.bodyParts.push({\n                    key: part,\n                    start: processed,\n                    maxLength: chunkSize\n                });\n            }\n\n            let response = await this.fetchOne(range, query, options);\n\n            if (!response) {\n                return { response: false, chunk: false };\n            }\n\n            if (!uid && response.uid) {\n                uid = response.uid;\n                // force UID from now on even if first range was a sequence number\n                range = uid;\n                options.uid = true;\n            }\n\n            let chunk = !part ? response.source : response.bodyParts && response.bodyParts.get(part);\n            if (!chunk) {\n                return {};\n            }\n\n            processed += chunk.length;\n            hasMore = chunk.length >= chunkSize;\n\n            let result = { chunk };\n            if (query.size) {\n                result.response = response;\n            }\n\n            if (query.bodyParts) {\n                if (mimeKey === 'header') {\n                    result.mime = response.headers;\n                } else {\n                    result.mime = response.bodyParts.get(mimeKey);\n                }\n            }\n\n            return result;\n        };\n\n        let { response, chunk, mime } = await getNextPart({\n            size: true,\n            uid: true\n        });\n\n        if (!response || !chunk) {\n            // ???\n            return {};\n        }\n\n        let meta = {\n            expectedSize: response.size\n        };\n\n        if (!part) {\n            meta.contentType = 'message/rfc822';\n        } else if (mime) {\n            let headers = new Headers(mime);\n            let contentType = libmime.parseHeaderValue(headers.getFirst('Content-Type'));\n            let transferEncoding = libmime.parseHeaderValue(headers.getFirst('Content-Transfer-Encoding'));\n            let disposition = libmime.parseHeaderValue(headers.getFirst('Content-Disposition'));\n\n            if (contentType.value.toLowerCase().trim()) {\n                meta.contentType = contentType.value.toLowerCase().trim();\n            }\n\n            if (contentType.params.charset) {\n                meta.charset = contentType.params.charset.toLowerCase().trim();\n            }\n\n            if (transferEncoding.value) {\n                meta.encoding = transferEncoding.value\n                    .replace(/\\(.*\\)/g, '')\n                    .toLowerCase()\n                    .trim();\n            }\n\n            if (disposition.value) {\n                meta.disposition = disposition.value.toLowerCase().trim() || false;\n                try {\n                    meta.disposition = libmime.decodeWords(meta.disposition);\n                } catch (err) {\n                    // failed to parse disposition, keep as is (most probably an unknown charset is used)\n                }\n            }\n\n            if (contentType.params.format && contentType.params.format.toLowerCase().trim() === 'flowed') {\n                meta.flowed = true;\n                if (contentType.params.delsp && contentType.params.delsp.toLowerCase().trim() === 'yes') {\n                    meta.delSp = true;\n                }\n            }\n\n            let filename = disposition.params.filename || contentType.params.name || false;\n            if (filename) {\n                try {\n                    filename = libmime.decodeWords(filename);\n                } catch (err) {\n                    // failed to parse filename, keep as is (most probably an unknown charset is used)\n                }\n                meta.filename = filename;\n            }\n        }\n\n        let stream;\n        let output;\n\n        switch (meta.encoding) {\n            case 'base64':\n                output = stream = new libbase64.Decoder();\n                break;\n            case 'quoted-printable':\n                output = stream = new libqp.Decoder();\n                break;\n            default:\n                output = stream = new PassThrough();\n        }\n\n        let isTextNode = ['text/html', 'text/plain', 'text/x-amp-html'].includes(meta.contentType) || (part === '1' && !meta.contentType);\n        if ((!meta.disposition || meta.disposition === 'inline') && isTextNode) {\n            // flowed text\n            if (meta.flowed) {\n                let flowDecoder = new FlowedDecoder({\n                    delSp: meta.delSp\n                });\n                output.on('error', err => {\n                    flowDecoder.emit('error', err);\n                });\n                output = output.pipe(flowDecoder);\n            }\n\n            // not utf-8 text\n            if (meta.charset && !['ascii', 'usascii', 'utf8'].includes(meta.charset.toLowerCase().replace(/[^a-z0-9]+/g, ''))) {\n                try {\n                    let decoder = getDecoder(meta.charset);\n                    output.on('error', err => {\n                        decoder.emit('error', err);\n                    });\n                    output = output.pipe(decoder);\n                    // force to utf-8 for output\n                    meta.charset = 'utf-8';\n                } catch (E) {\n                    // do not decode charset\n                }\n            }\n        }\n\n        let limiter = new LimitedPassthrough({ maxBytes });\n        output.on('error', err => {\n            limiter.emit('error', err);\n        });\n        output = output.pipe(limiter);\n\n        let writeChunk = chunk => {\n            if (limiter.limited) {\n                return true;\n            }\n            return stream.write(chunk);\n        };\n\n        let fetchAllParts = async () => {\n            while (hasMore && !limiter.limited) {\n                let { chunk } = await getNextPart();\n                if (!chunk) {\n                    break;\n                }\n\n                if (writeChunk(chunk) === false) {\n                    await new Promise(resolve => stream.once('drain', resolve));\n                }\n            }\n        };\n\n        setImmediate(() => {\n            writeChunk(chunk);\n            fetchAllParts()\n                .catch(err => stream.emit('error', err))\n                .finally(() => stream.end());\n        });\n\n        return {\n            meta,\n            content: output\n        };\n    }\n\n    /**\n     * Fetch multiple attachments as Buffer values\n     *\n     * @param {SequenceString} range UID or sequence number for the message to fetch\n     * @param {String} parts A list of bodystructure parts\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID number instead of sequence number for `range`\n     * @returns {Promise<Object>} Download data object\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // download body parts '2', and '3' from all messages in the selected mailbox\n     * let response = await client.downloadMany('*', ['2', '3']);\n     * process.stdout.write(response[2].content)\n     * process.stdout.write(response[3].content)\n     */\n    async downloadMany(range, parts, options) {\n        if (!this.mailbox) {\n            // no mailbox selected, nothing to do\n            return {};\n        }\n\n        options = Object.assign(\n            {\n                chunkSize: 64 * 1024,\n                maxBytes: Infinity\n            },\n            options || {}\n        );\n\n        let query = { bodyParts: [] };\n\n        for (let part of parts) {\n            query.bodyParts.push(part + '.mime');\n            query.bodyParts.push(part);\n        }\n\n        let response = await this.fetchOne(range, query, options);\n\n        if (!response || !response.bodyParts) {\n            return { response: false };\n        }\n\n        let data = {};\n\n        for (let [part, content] of response.bodyParts) {\n            let keyParts = part.split('.mime');\n            if (keyParts.length === 1) {\n                // content\n                let key = keyParts[0];\n                if (!data[key]) {\n                    data[key] = { content };\n                } else {\n                    data[key].content = content;\n                }\n            } else if (keyParts.length === 2) {\n                // header\n                let key = keyParts[0];\n                if (!data[key]) {\n                    data[key] = {};\n                }\n                if (!data[key].meta) {\n                    data[key].meta = {};\n                }\n\n                let headers = new Headers(content);\n                let contentType = libmime.parseHeaderValue(headers.getFirst('Content-Type'));\n                let transferEncoding = libmime.parseHeaderValue(headers.getFirst('Content-Transfer-Encoding'));\n                let disposition = libmime.parseHeaderValue(headers.getFirst('Content-Disposition'));\n\n                if (contentType.value.toLowerCase().trim()) {\n                    data[key].meta.contentType = contentType.value.toLowerCase().trim();\n                }\n\n                if (contentType.params.charset) {\n                    data[key].meta.charset = contentType.params.charset.toLowerCase().trim();\n                }\n\n                if (transferEncoding.value) {\n                    data[key].meta.encoding = transferEncoding.value\n                        .replace(/\\(.*\\)/g, '')\n                        .toLowerCase()\n                        .trim();\n                }\n\n                if (disposition.value) {\n                    data[key].meta.disposition = disposition.value.toLowerCase().trim() || false;\n                    try {\n                        data[key].meta.disposition = libmime.decodeWords(data[key].meta.disposition);\n                    } catch (err) {\n                        // failed to parse disposition, keep as is (most probably an unknown charset is used)\n                    }\n                }\n\n                if (contentType.params.format && contentType.params.format.toLowerCase().trim() === 'flowed') {\n                    data[key].meta.flowed = true;\n                    if (contentType.params.delsp && contentType.params.delsp.toLowerCase().trim() === 'yes') {\n                        data[key].meta.delSp = true;\n                    }\n                }\n\n                let filename = disposition.params.filename || contentType.params.name || false;\n                if (filename) {\n                    try {\n                        filename = libmime.decodeWords(filename);\n                    } catch (err) {\n                        // failed to parse filename, keep as is (most probably an unknown charset is used)\n                    }\n                    data[key].meta.filename = filename;\n                }\n            }\n        }\n\n        for (let part of Object.keys(data)) {\n            let meta = data[part].meta;\n\n            switch (meta.encoding) {\n                case 'base64':\n                    data[part].content = data[part].content ? libbase64.decode(data[part].content.toString()) : null;\n                    break;\n                case 'quoted-printable':\n                    data[part].content = data[part].content ? libqp.decode(data[part].content.toString()) : null;\n                    break;\n                default:\n                // keep as is, already a buffer\n            }\n        }\n\n        return data;\n    }\n\n    async run(command, ...args) {\n        command = command.toUpperCase();\n        if (!this.commands.has(command)) {\n            return false;\n        }\n\n        if (this.socket.destroyed) {\n            const error = new Error('Connection not available');\n            error.code = 'NoConnection';\n            throw error;\n        }\n\n        clearTimeout(this.idleStartTimer);\n\n        if (typeof this.preCheck === 'function') {\n            await this.preCheck();\n        }\n\n        let handler = this.commands.get(command);\n\n        let result = await handler(this, ...args);\n\n        if (command !== 'IDLE') {\n            // do not autostart IDLE, if IDLE itself was stopped\n            this.autoidle();\n        }\n\n        return result;\n    }\n\n    async processLocks(force) {\n        if (!force && this.processingLock) {\n            this.log.trace({\n                msg: 'Mailbox locking queued',\n                path: this.mailbox && this.mailbox.path,\n                pending: this.locks.length,\n                idling: this.idling,\n                activeLock: this.currentLock\n                    ? {\n                          lockId: this.currentLock.lockId,\n                          ...(this.currentLock.options?.description && { description: this.currentLock.options?.description })\n                      }\n                    : null\n            });\n            return;\n        }\n\n        if (!this.locks.length) {\n            this.processingLock = false;\n            this.log.trace({\n                msg: 'Mailbox locking queue processed',\n                idling: this.idling\n            });\n            return;\n        }\n\n        this.processingLock = true;\n\n        const release = () => {\n            if (this.currentLock) {\n                this.log.trace({\n                    msg: 'Mailbox lock released',\n                    lockId: this.currentLock.lockId,\n                    path: this.mailbox && this.mailbox.path,\n                    pending: this.locks.length,\n                    idling: this.idling\n                });\n                this.currentLock = false;\n            }\n            this.processLocks(true).catch(err => this.log.error({ err, cid: this.id }));\n        };\n\n        const lock = this.locks.shift();\n        const { resolve, reject, path, options, lockId } = lock;\n\n        if (!this.usable || this.socket.destroyed) {\n            this.log.trace({ msg: 'Failed to acquire mailbox lock', path, lockId, idling: this.idling });\n            // reject all\n            let error = new Error('Connection not available');\n            error.code = 'NoConnection';\n            reject(error);\n            return await this.processLocks(true);\n        }\n\n        if (this.mailbox && this.mailbox.path === path && !!this.mailbox.readOnly === !!options.readOnly) {\n            // nothing to do here, already selected\n            this.log.trace({\n                msg: 'Mailbox lock acquired [existing]',\n                path,\n                lockId,\n                idling: this.idling,\n                ...(options.description && { description: options.description })\n            });\n            this.currentLock = lock;\n            return resolve({ path, release });\n        } else {\n            try {\n                // Try to open. Throws if mailbox does not exists or can't open\n                await this.mailboxOpen(path, options);\n                this.log.trace({\n                    msg: 'Mailbox lock acquired [selected]',\n                    path,\n                    lockId,\n                    idling: this.idling,\n                    ...(options.description && { description: options.description })\n                });\n                this.currentLock = lock;\n                return resolve({ path, release });\n            } catch (err) {\n                if (err.responseStatus === 'NO') {\n                    try {\n                        let folders = await this.run('LIST', '', path, { listOnly: true });\n                        if (!folders || !folders.length) {\n                            err.mailboxMissing = true;\n                        }\n                    } catch (E) {\n                        this.log.trace({ msg: 'Failed to verify failed mailbox', path, err: E });\n                    }\n                }\n\n                this.log.trace({\n                    msg: 'Failed to acquire mailbox lock',\n                    path,\n                    lockId,\n                    idling: this.idling,\n                    ...(options.description && { description: options.description }),\n                    err\n                });\n                reject(err);\n                await this.processLocks(true);\n            }\n        }\n    }\n\n    /**\n     * Opens a mailbox if not already open and returns a lock. Next call to `getMailboxLock()` is queued\n     * until previous lock is released. This is suggested over {@link module:imapflow~ImapFlow#mailboxOpen|mailboxOpen()} as\n     * `getMailboxLock()` gives you a weak transaction while `mailboxOpen()` has no guarantees whatsoever that another\n     * mailbox is opened while you try to call multiple fetch or store commands.\n     *\n     * @param {string|array} path **Path for the mailbox** to open\n     * @param {Object} [options] optional options\n     * @param {Boolean} [options.readOnly=false] If `true` then opens mailbox in read-only mode. You can still try to perform write operations but these would probably fail.\n     * @returns {Promise<MailboxLockObject>} Mailbox lock\n     * @throws Will throw an error if mailbox does not exist or can not be opened\n     *\n     * @example\n     * let lock = await client.getMailboxLock('INBOX');\n     * try {\n     *   // do something in the mailbox\n     * } finally {\n     *   // use finally{} to make sure lock is released even if exception occurs\n     *   lock.release();\n     * }\n     */\n    async getMailboxLock(path, options) {\n        options = options || {};\n\n        path = normalizePath(this, path);\n\n        let lockId = ++this.lockCounter;\n        this.log.trace({\n            msg: 'Requesting lock',\n            path,\n            lockId,\n            ...(options.description && { description: options.description }),\n            activeLock: this.currentLock\n                ? {\n                      lockId: this.currentLock.lockId,\n                      ...(this.currentLock.options?.description && { description: this.currentLock.options?.description })\n                  }\n                : null\n        });\n\n        return await new Promise((resolve, reject) => {\n            this.locks.push({ resolve, reject, path, options, lockId });\n            this.processLocks().catch(err => reject(err));\n        });\n    }\n\n    getLogger() {\n        let mainLogger =\n            this.options.logger && typeof this.options.logger === 'object'\n                ? this.options.logger\n                : logger.child({\n                      component: 'imap-connection',\n                      cid: this.id\n                  });\n\n        let synteticLogger = {};\n        let levels = ['trace', 'debug', 'info', 'warn', 'error', 'fatal'];\n        for (let level of levels) {\n            synteticLogger[level] = (...args) => {\n                // using {logger:false} disables logging\n                if (this.options.logger !== false) {\n                    if (logger)\n                        if (typeof mainLogger[level] !== 'function') {\n                            // we are checking to make sure the level is supported.\n                            // if it isn't supported but the level is error or fatal, log to console anyway.\n                            if (level === 'fatal' || level === 'error') {\n                                console.log(JSON.stringify(...args));\n                            }\n                        } else {\n                            mainLogger[level](...args);\n                        }\n                }\n\n                if (this.emitLogs && args && args[0] && typeof args[0] === 'object') {\n                    let logEntry = Object.assign({ level, t: Date.now(), cid: this.id, lo: ++this.lo }, args[0]);\n                    if (logEntry.err && typeof logEntry.err === 'object') {\n                        let err = logEntry.err;\n                        logEntry.err = {\n                            stack: err.stack\n                        };\n                        // enumerable error fields\n                        Object.keys(err).forEach(key => {\n                            logEntry.err[key] = err[key];\n                        });\n                    }\n                    this.emit('log', logEntry);\n                }\n            };\n        }\n\n        return synteticLogger;\n    }\n\n    unbind() {\n        this.socket.unpipe(this.streamer);\n        if (this._inflate) {\n            this._inflate.unpipe(this.streamer);\n        }\n\n        this.socket.removeListener('error', this._socketError);\n        this.socket.removeListener('close', this._socketClose);\n        this.socket.removeListener('end', this._socketEnd);\n        this.socket.removeListener('tlsClientError', this._socketError);\n        this.socket.removeListener('timeout', this._socketTimeout);\n\n        return {\n            readSocket: this._inflate || this.socket,\n            writeSocket: this.writeSocket || this.socket\n        };\n    }\n}\n\n/**\n * Connection close event. **NB!** ImapFlow does not handle reconnects automatically.\n * So whenever a 'close' event occurs you must create a new connection yourself.\n *\n * @event module:imapflow~ImapFlow#close\n */\n\n/**\n * Error event. In most cases getting an error event also means that connection is closed\n * and pending operations should return with a failure.\n *\n * @event module:imapflow~ImapFlow#error\n * @type {Error}\n * @example\n * client.on('error', err=>{\n *     console.log(`Error occurred: ${err.message}`);\n * });\n */\n\n/**\n * Message count in currently opened mailbox changed\n *\n * @event module:imapflow~ImapFlow#exists\n * @type {Object}\n * @property {String} path mailbox path this event applies to\n * @property {Number} count updated count of messages\n * @property {Number} prevCount message count before this update\n * @example\n * client.on('exists', data=>{\n *     console.log(`Message count in \"${data.path}\" is ${data.count}`);\n * });\n */\n\n/**\n * Deleted message sequence number in currently opened mailbox. One event is fired for every deleted email.\n *\n * @event module:imapflow~ImapFlow#expunge\n * @type {Object}\n * @property {String} path mailbox path this event applies to\n * @property {Number} seq sequence number of deleted message\n * @example\n * client.on('expunge', data=>{\n *     console.log(`Message #${data.seq} was deleted from \"${data.path}\"`);\n * });\n */\n\n/**\n * Flags were updated for a message. Not all servers fire this event.\n *\n * @event module:imapflow~ImapFlow#flags\n * @type {Object}\n * @property {String} path mailbox path this event applies to\n * @property {Number} seq sequence number of updated message\n * @property {Number} [uid] UID number of updated message (if server provided this value)\n * @property {BigInt} [modseq] Updated modseq number for the mailbox (if server provided this value)\n * @property {Set<string>} flags A set of all flags for the updated message\n * @example\n * client.on('flags', data=>{\n *     console.log(`Flag set for #${data.seq} is now \"${Array.from(data.flags).join(', ')}\"`);\n * });\n */\n\n/**\n * Mailbox was opened\n *\n * @event module:imapflow~ImapFlow#mailboxOpen\n * @type {MailboxObject}\n * @example\n * client.on('mailboxOpen', mailbox => {\n *     console.log(`Mailbox ${mailbox.path} was opened`);\n * });\n */\n\n/**\n * Mailbox was closed\n *\n * @event module:imapflow~ImapFlow#mailboxClose\n * @type {MailboxObject}\n * @example\n * client.on('mailboxClose', mailbox => {\n *     console.log(`Mailbox ${mailbox.path} was closed`);\n * });\n */\n\n/**\n * Log event if `emitLogs=true`\n *\n * @event module:imapflow~ImapFlow#log\n * @type {Object}\n * @example\n * client.on('log', entry => {\n *     console.log(`${log.cid} ${log.msg}`);\n * });\n */\n\nmodule.exports.ImapFlow = ImapFlow;\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/imap-flow.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/jp-decoder.js":
|
|
/*!*************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/jp-decoder.js ***!
|
|
\*************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { Transform } = __webpack_require__(/*! stream */ \"stream\");\nconst encodingJapanese = __webpack_require__(/*! encoding-japanese */ \"(action-browser)/./node_modules/encoding-japanese/src/index.js\");\n\nclass JPDecoder extends Transform {\n constructor(charset) {\n super();\n\n this.charset = charset;\n this.chunks = [];\n this.chunklen = 0;\n }\n\n _transform(chunk, encoding, done) {\n if (typeof chunk === 'string') {\n chunk = Buffer.from(chunk, encoding);\n }\n\n this.chunks.push(chunk);\n this.chunklen += chunk.length;\n done();\n }\n\n _flush(done) {\n let input = Buffer.concat(this.chunks, this.chunklen);\n try {\n let output = encodingJapanese.convert(input, {\n to: 'UNICODE', // to_encoding\n from: this.charset, // from_encoding\n type: 'string'\n });\n if (typeof output === 'string') {\n output = Buffer.from(output);\n }\n this.push(output);\n } catch (err) {\n // keep as is on errors\n this.push(input);\n }\n\n done();\n }\n}\n\nmodule.exports.JPDecoder = JPDecoder;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvanAtZGVjb2Rlci5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYixRQUFRLFlBQVksRUFBRSxtQkFBTyxDQUFDLHNCQUFRO0FBQ3RDLHlCQUF5QixtQkFBTyxDQUFDLHlGQUFtQjs7QUFFcEQ7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVTtBQUNWO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEsd0JBQXdCIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvanAtZGVjb2Rlci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IHsgVHJhbnNmb3JtIH0gPSByZXF1aXJlKCdzdHJlYW0nKTtcbmNvbnN0IGVuY29kaW5nSmFwYW5lc2UgPSByZXF1aXJlKCdlbmNvZGluZy1qYXBhbmVzZScpO1xuXG5jbGFzcyBKUERlY29kZXIgZXh0ZW5kcyBUcmFuc2Zvcm0ge1xuICAgIGNvbnN0cnVjdG9yKGNoYXJzZXQpIHtcbiAgICAgICAgc3VwZXIoKTtcblxuICAgICAgICB0aGlzLmNoYXJzZXQgPSBjaGFyc2V0O1xuICAgICAgICB0aGlzLmNodW5rcyA9IFtdO1xuICAgICAgICB0aGlzLmNodW5rbGVuID0gMDtcbiAgICB9XG5cbiAgICBfdHJhbnNmb3JtKGNodW5rLCBlbmNvZGluZywgZG9uZSkge1xuICAgICAgICBpZiAodHlwZW9mIGNodW5rID09PSAnc3RyaW5nJykge1xuICAgICAgICAgICAgY2h1bmsgPSBCdWZmZXIuZnJvbShjaHVuaywgZW5jb2RpbmcpO1xuICAgICAgICB9XG5cbiAgICAgICAgdGhpcy5jaHVua3MucHVzaChjaHVuayk7XG4gICAgICAgIHRoaXMuY2h1bmtsZW4gKz0gY2h1bmsubGVuZ3RoO1xuICAgICAgICBkb25lKCk7XG4gICAgfVxuXG4gICAgX2ZsdXNoKGRvbmUpIHtcbiAgICAgICAgbGV0IGlucHV0ID0gQnVmZmVyLmNvbmNhdCh0aGlzLmNodW5rcywgdGhpcy5jaHVua2xlbik7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgICBsZXQgb3V0cHV0ID0gZW5jb2RpbmdKYXBhbmVzZS5jb252ZXJ0KGlucHV0LCB7XG4gICAgICAgICAgICAgICAgdG86ICdVTklDT0RFJywgLy8gdG9fZW5jb2RpbmdcbiAgICAgICAgICAgICAgICBmcm9tOiB0aGlzLmNoYXJzZXQsIC8vIGZyb21fZW5jb2RpbmdcbiAgICAgICAgICAgICAgICB0eXBlOiAnc3RyaW5nJ1xuICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICBpZiAodHlwZW9mIG91dHB1dCA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgICAgICAgICBvdXRwdXQgPSBCdWZmZXIuZnJvbShvdXRwdXQpO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgdGhpcy5wdXNoKG91dHB1dCk7XG4gICAgICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICAgICAgLy8ga2VlcCBhcyBpcyBvbiBlcnJvcnNcbiAgICAgICAgICAgIHRoaXMucHVzaChpbnB1dCk7XG4gICAgICAgIH1cblxuICAgICAgICBkb25lKCk7XG4gICAgfVxufVxuXG5tb2R1bGUuZXhwb3J0cy5KUERlY29kZXIgPSBKUERlY29kZXI7XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/jp-decoder.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/limited-passthrough.js":
|
|
/*!**********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/limited-passthrough.js ***!
|
|
\**********************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { Transform } = __webpack_require__(/*! stream */ \"stream\");\n\nclass LimitedPassthrough extends Transform {\n constructor(options) {\n super();\n this.options = options || {};\n this.maxBytes = this.options.maxBytes || Infinity;\n this.processed = 0;\n this.limited = false;\n }\n\n _transform(chunk, encoding, done) {\n if (this.limited) {\n return done();\n }\n\n if (this.processed + chunk.length > this.maxBytes) {\n if (this.maxBytes - this.processed < 1) {\n return done();\n }\n\n chunk = chunk.slice(0, this.maxBytes - this.processed);\n }\n\n this.processed += chunk.length;\n if (this.processed >= this.maxBytes) {\n this.limited = true;\n }\n\n this.push(chunk);\n done();\n }\n}\n\nmodule.exports.LimitedPassthrough = LimitedPassthrough;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvbGltaXRlZC1wYXNzdGhyb3VnaC5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYixRQUFRLFlBQVksRUFBRSxtQkFBTyxDQUFDLHNCQUFROztBQUV0QztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsaUNBQWlDIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvbGltaXRlZC1wYXNzdGhyb3VnaC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IHsgVHJhbnNmb3JtIH0gPSByZXF1aXJlKCdzdHJlYW0nKTtcblxuY2xhc3MgTGltaXRlZFBhc3N0aHJvdWdoIGV4dGVuZHMgVHJhbnNmb3JtIHtcbiAgICBjb25zdHJ1Y3RvcihvcHRpb25zKSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgICAgIHRoaXMub3B0aW9ucyA9IG9wdGlvbnMgfHwge307XG4gICAgICAgIHRoaXMubWF4Qnl0ZXMgPSB0aGlzLm9wdGlvbnMubWF4Qnl0ZXMgfHwgSW5maW5pdHk7XG4gICAgICAgIHRoaXMucHJvY2Vzc2VkID0gMDtcbiAgICAgICAgdGhpcy5saW1pdGVkID0gZmFsc2U7XG4gICAgfVxuXG4gICAgX3RyYW5zZm9ybShjaHVuaywgZW5jb2RpbmcsIGRvbmUpIHtcbiAgICAgICAgaWYgKHRoaXMubGltaXRlZCkge1xuICAgICAgICAgICAgcmV0dXJuIGRvbmUoKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmICh0aGlzLnByb2Nlc3NlZCArIGNodW5rLmxlbmd0aCA+IHRoaXMubWF4Qnl0ZXMpIHtcbiAgICAgICAgICAgIGlmICh0aGlzLm1heEJ5dGVzIC0gdGhpcy5wcm9jZXNzZWQgPCAxKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIGRvbmUoKTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgY2h1bmsgPSBjaHVuay5zbGljZSgwLCB0aGlzLm1heEJ5dGVzIC0gdGhpcy5wcm9jZXNzZWQpO1xuICAgICAgICB9XG5cbiAgICAgICAgdGhpcy5wcm9jZXNzZWQgKz0gY2h1bmsubGVuZ3RoO1xuICAgICAgICBpZiAodGhpcy5wcm9jZXNzZWQgPj0gdGhpcy5tYXhCeXRlcykge1xuICAgICAgICAgICAgdGhpcy5saW1pdGVkID0gdHJ1ZTtcbiAgICAgICAgfVxuXG4gICAgICAgIHRoaXMucHVzaChjaHVuayk7XG4gICAgICAgIGRvbmUoKTtcbiAgICB9XG59XG5cbm1vZHVsZS5leHBvcnRzLkxpbWl0ZWRQYXNzdGhyb3VnaCA9IExpbWl0ZWRQYXNzdGhyb3VnaDtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/limited-passthrough.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/logger.js":
|
|
/*!*********************************************!*\
|
|
!*** ./node_modules/imapflow/lib/logger.js ***!
|
|
\*********************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst logger = __webpack_require__(/*! pino */ \"(action-browser)/./node_modules/pino/pino.js\")();\nlogger.level = 'trace';\nmodule.exports = logger;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvbG9nZ2VyLmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViLGVBQWUsbUJBQU8sQ0FBQywwREFBTTtBQUM3QjtBQUNBIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvbG9nZ2VyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgbG9nZ2VyID0gcmVxdWlyZSgncGlubycpKCk7XG5sb2dnZXIubGV2ZWwgPSAndHJhY2UnO1xubW9kdWxlLmV4cG9ydHMgPSBsb2dnZXI7XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/logger.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/proxy-connection.js":
|
|
/*!*******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/proxy-connection.js ***!
|
|
\*******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst httpProxyClient = __webpack_require__(/*! nodemailer/lib/smtp-connection/http-proxy-client */ \"(action-browser)/./node_modules/imapflow/node_modules/nodemailer/lib/smtp-connection/http-proxy-client.js\");\nconst { SocksClient } = __webpack_require__(/*! socks */ \"(action-browser)/./node_modules/socks/build/index.js\");\nconst util = __webpack_require__(/*! util */ \"util\");\nconst httpProxyClientAsync = util.promisify(httpProxyClient);\nconst dns = (__webpack_require__(/*! dns */ \"dns\").promises);\nconst net = __webpack_require__(/*! net */ \"net\");\n\nconst proxyConnection = async (logger, connectionUrl, host, port) => {\n let proxyUrl = new URL(connectionUrl);\n\n let protocol = proxyUrl.protocol.replace(/:$/, '').toLowerCase();\n\n if (!net.isIP(host)) {\n let resolveResult = await dns.resolve(host);\n if (resolveResult && resolveResult.length) {\n host = resolveResult[0];\n }\n }\n\n switch (protocol) {\n // Connect using a HTTP CONNECT method\n case 'http':\n case 'https': {\n try {\n let socket = await httpProxyClientAsync(proxyUrl.href, port, host);\n if (socket) {\n if (proxyUrl.password) {\n proxyUrl.password = '(hidden)';\n }\n logger.info({\n msg: 'Established a socket via HTTP proxy',\n proxyUrl: proxyUrl.href,\n port,\n host\n });\n }\n return socket;\n } catch (err) {\n if (proxyUrl.password) {\n proxyUrl.password = '(hidden)';\n }\n logger.error({\n msg: 'Failed to establish a socket via HTTP proxy',\n proxyUrl: proxyUrl.href,\n port,\n host,\n err\n });\n throw err;\n }\n }\n\n // SOCKS proxy\n case 'socks':\n case 'socks5':\n case 'socks4':\n case 'socks4a': {\n let proxyType = Number(protocol.replace(/\\D/g, '')) || 5;\n\n let targetHost = proxyUrl.hostname;\n if (!net.isIP(targetHost)) {\n let resolveResult = await dns.resolve(targetHost);\n if (resolveResult && resolveResult.length) {\n targetHost = resolveResult[0];\n }\n }\n\n let connectionOpts = {\n proxy: {\n host: targetHost,\n port: Number(proxyUrl.port) || 1080,\n type: proxyType\n },\n destination: {\n host,\n port\n },\n command: 'connect',\n set_tcp_nodelay: true\n };\n\n if (proxyUrl.username || proxyUrl.password) {\n connectionOpts.proxy.userId = proxyUrl.username;\n connectionOpts.proxy.password = proxyUrl.password;\n }\n\n try {\n const info = await SocksClient.createConnection(connectionOpts);\n if (info && info.socket) {\n if (proxyUrl.password) {\n proxyUrl.password = '(hidden)';\n }\n logger.info({\n msg: 'Established a socket via SOCKS proxy',\n proxyUrl: proxyUrl.href,\n port,\n host\n });\n }\n return info.socket;\n } catch (err) {\n if (proxyUrl.password) {\n proxyUrl.password = '(hidden)';\n }\n logger.error({\n msg: 'Failed to establish a socket via SOCKS proxy',\n proxyUrl: proxyUrl.href,\n port,\n host,\n err\n });\n throw err;\n }\n }\n }\n};\n\nmodule.exports = { proxyConnection };\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvcHJveHktY29ubmVjdGlvbi5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYix3QkFBd0IsbUJBQU8sQ0FBQyxtS0FBa0Q7QUFDbEYsUUFBUSxjQUFjLEVBQUUsbUJBQU8sQ0FBQyxtRUFBTztBQUN2QyxhQUFhLG1CQUFPLENBQUMsa0JBQU07QUFDM0I7QUFDQSxZQUFZLGdEQUF1QjtBQUNuQyxZQUFZLG1CQUFPLENBQUMsZ0JBQUs7O0FBRXpCO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHFCQUFxQjtBQUNyQjtBQUNBO0FBQ0EsY0FBYztBQUNkO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGlCQUFpQjtBQUNqQjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxpQkFBaUI7QUFDakI7QUFDQTtBQUNBO0FBQ0EsaUJBQWlCO0FBQ2pCO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EscUJBQXFCO0FBQ3JCO0FBQ0E7QUFDQSxjQUFjO0FBQ2Q7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsaUJBQWlCO0FBQ2pCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsbUJBQW1CIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvcHJveHktY29ubmVjdGlvbi5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IGh0dHBQcm94eUNsaWVudCA9IHJlcXVpcmUoJ25vZGVtYWlsZXIvbGliL3NtdHAtY29ubmVjdGlvbi9odHRwLXByb3h5LWNsaWVudCcpO1xuY29uc3QgeyBTb2Nrc0NsaWVudCB9ID0gcmVxdWlyZSgnc29ja3MnKTtcbmNvbnN0IHV0aWwgPSByZXF1aXJlKCd1dGlsJyk7XG5jb25zdCBodHRwUHJveHlDbGllbnRBc3luYyA9IHV0aWwucHJvbWlzaWZ5KGh0dHBQcm94eUNsaWVudCk7XG5jb25zdCBkbnMgPSByZXF1aXJlKCdkbnMnKS5wcm9taXNlcztcbmNvbnN0IG5ldCA9IHJlcXVpcmUoJ25ldCcpO1xuXG5jb25zdCBwcm94eUNvbm5lY3Rpb24gPSBhc3luYyAobG9nZ2VyLCBjb25uZWN0aW9uVXJsLCBob3N0LCBwb3J0KSA9PiB7XG4gICAgbGV0IHByb3h5VXJsID0gbmV3IFVSTChjb25uZWN0aW9uVXJsKTtcblxuICAgIGxldCBwcm90b2NvbCA9IHByb3h5VXJsLnByb3RvY29sLnJlcGxhY2UoLzokLywgJycpLnRvTG93ZXJDYXNlKCk7XG5cbiAgICBpZiAoIW5ldC5pc0lQKGhvc3QpKSB7XG4gICAgICAgIGxldCByZXNvbHZlUmVzdWx0ID0gYXdhaXQgZG5zLnJlc29sdmUoaG9zdCk7XG4gICAgICAgIGlmIChyZXNvbHZlUmVzdWx0ICYmIHJlc29sdmVSZXN1bHQubGVuZ3RoKSB7XG4gICAgICAgICAgICBob3N0ID0gcmVzb2x2ZVJlc3VsdFswXTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHN3aXRjaCAocHJvdG9jb2wpIHtcbiAgICAgICAgLy8gQ29ubmVjdCB1c2luZyBhIEhUVFAgQ09OTkVDVCBtZXRob2RcbiAgICAgICAgY2FzZSAnaHR0cCc6XG4gICAgICAgIGNhc2UgJ2h0dHBzJzoge1xuICAgICAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgICAgICBsZXQgc29ja2V0ID0gYXdhaXQgaHR0cFByb3h5Q2xpZW50QXN5bmMocHJveHlVcmwuaHJlZiwgcG9ydCwgaG9zdCk7XG4gICAgICAgICAgICAgICAgaWYgKHNvY2tldCkge1xuICAgICAgICAgICAgICAgICAgICBpZiAocHJveHlVcmwucGFzc3dvcmQpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHByb3h5VXJsLnBhc3N3b3JkID0gJyhoaWRkZW4pJztcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICBsb2dnZXIuaW5mbyh7XG4gICAgICAgICAgICAgICAgICAgICAgICBtc2c6ICdFc3RhYmxpc2hlZCBhIHNvY2tldCB2aWEgSFRUUCBwcm94eScsXG4gICAgICAgICAgICAgICAgICAgICAgICBwcm94eVVybDogcHJveHlVcmwuaHJlZixcbiAgICAgICAgICAgICAgICAgICAgICAgIHBvcnQsXG4gICAgICAgICAgICAgICAgICAgICAgICBob3N0XG4gICAgICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICByZXR1cm4gc29ja2V0O1xuICAgICAgICAgICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICAgICAgICAgICAgaWYgKHByb3h5VXJsLnBhc3N3b3JkKSB7XG4gICAgICAgICAgICAgICAgICAgIHByb3h5VXJsLnBhc3N3b3JkID0gJyhoaWRkZW4pJztcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgbG9nZ2VyLmVycm9yKHtcbiAgICAgICAgICAgICAgICAgICAgbXNnOiAnRmFpbGVkIHRvIGVzdGFibGlzaCBhIHNvY2tldCB2aWEgSFRUUCBwcm94eScsXG4gICAgICAgICAgICAgICAgICAgIHByb3h5VXJsOiBwcm94eVVybC5ocmVmLFxuICAgICAgICAgICAgICAgICAgICBwb3J0LFxuICAgICAgICAgICAgICAgICAgICBob3N0LFxuICAgICAgICAgICAgICAgICAgICBlcnJcbiAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgICAgICB0aHJvdyBlcnI7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICAvLyBTT0NLUyBwcm94eVxuICAgICAgICBjYXNlICdzb2Nrcyc6XG4gICAgICAgIGNhc2UgJ3NvY2tzNSc6XG4gICAgICAgIGNhc2UgJ3NvY2tzNCc6XG4gICAgICAgIGNhc2UgJ3NvY2tzNGEnOiB7XG4gICAgICAgICAgICBsZXQgcHJveHlUeXBlID0gTnVtYmVyKHByb3RvY29sLnJlcGxhY2UoL1xcRC9nLCAnJykpIHx8IDU7XG5cbiAgICAgICAgICAgIGxldCB0YXJnZXRIb3N0ID0gcHJveHlVcmwuaG9zdG5hbWU7XG4gICAgICAgICAgICBpZiAoIW5ldC5pc0lQKHRhcmdldEhvc3QpKSB7XG4gICAgICAgICAgICAgICAgbGV0IHJlc29sdmVSZXN1bHQgPSBhd2FpdCBkbnMucmVzb2x2ZSh0YXJnZXRIb3N0KTtcbiAgICAgICAgICAgICAgICBpZiAocmVzb2x2ZVJlc3VsdCAmJiByZXNvbHZlUmVzdWx0Lmxlbmd0aCkge1xuICAgICAgICAgICAgICAgICAgICB0YXJnZXRIb3N0ID0gcmVzb2x2ZVJlc3VsdFswXTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIGxldCBjb25uZWN0aW9uT3B0cyA9IHtcbiAgICAgICAgICAgICAgICBwcm94eToge1xuICAgICAgICAgICAgICAgICAgICBob3N0OiB0YXJnZXRIb3N0LFxuICAgICAgICAgICAgICAgICAgICBwb3J0OiBOdW1iZXIocHJveHlVcmwucG9ydCkgfHwgMTA4MCxcbiAgICAgICAgICAgICAgICAgICAgdHlwZTogcHJveHlUeXBlXG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICBkZXN0aW5hdGlvbjoge1xuICAgICAgICAgICAgICAgICAgICBob3N0LFxuICAgICAgICAgICAgICAgICAgICBwb3J0XG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICBjb21tYW5kOiAnY29ubmVjdCcsXG4gICAgICAgICAgICAgICAgc2V0X3RjcF9ub2RlbGF5OiB0cnVlXG4gICAgICAgICAgICB9O1xuXG4gICAgICAgICAgICBpZiAocHJveHlVcmwudXNlcm5hbWUgfHwgcHJveHlVcmwucGFzc3dvcmQpIHtcbiAgICAgICAgICAgICAgICBjb25uZWN0aW9uT3B0cy5wcm94eS51c2VySWQgPSBwcm94eVVybC51c2VybmFtZTtcbiAgICAgICAgICAgICAgICBjb25uZWN0aW9uT3B0cy5wcm94eS5wYXNzd29yZCA9IHByb3h5VXJsLnBhc3N3b3JkO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgICAgIGNvbnN0IGluZm8gPSBhd2FpdCBTb2Nrc0NsaWVudC5jcmVhdGVDb25uZWN0aW9uKGNvbm5lY3Rpb25PcHRzKTtcbiAgICAgICAgICAgICAgICBpZiAoaW5mbyAmJiBpbmZvLnNvY2tldCkge1xuICAgICAgICAgICAgICAgICAgICBpZiAocHJveHlVcmwucGFzc3dvcmQpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHByb3h5VXJsLnBhc3N3b3JkID0gJyhoaWRkZW4pJztcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICBsb2dnZXIuaW5mbyh7XG4gICAgICAgICAgICAgICAgICAgICAgICBtc2c6ICdFc3RhYmxpc2hlZCBhIHNvY2tldCB2aWEgU09DS1MgcHJveHknLFxuICAgICAgICAgICAgICAgICAgICAgICAgcHJveHlVcmw6IHByb3h5VXJsLmhyZWYsXG4gICAgICAgICAgICAgICAgICAgICAgICBwb3J0LFxuICAgICAgICAgICAgICAgICAgICAgICAgaG9zdFxuICAgICAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgcmV0dXJuIGluZm8uc29ja2V0O1xuICAgICAgICAgICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICAgICAgICAgICAgaWYgKHByb3h5VXJsLnBhc3N3b3JkKSB7XG4gICAgICAgICAgICAgICAgICAgIHByb3h5VXJsLnBhc3N3b3JkID0gJyhoaWRkZW4pJztcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgbG9nZ2VyLmVycm9yKHtcbiAgICAgICAgICAgICAgICAgICAgbXNnOiAnRmFpbGVkIHRvIGVzdGFibGlzaCBhIHNvY2tldCB2aWEgU09DS1MgcHJveHknLFxuICAgICAgICAgICAgICAgICAgICBwcm94eVVybDogcHJveHlVcmwuaHJlZixcbiAgICAgICAgICAgICAgICAgICAgcG9ydCxcbiAgICAgICAgICAgICAgICAgICAgaG9zdCxcbiAgICAgICAgICAgICAgICAgICAgZXJyXG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICAgICAgdGhyb3cgZXJyO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgfVxufTtcblxubW9kdWxlLmV4cG9ydHMgPSB7IHByb3h5Q29ubmVjdGlvbiB9O1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/proxy-connection.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/search-compiler.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/search-compiler.js ***!
|
|
\******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { formatDate, formatFlag, canUseFlag } = __webpack_require__(/*! ./tools.js */ \"(action-browser)/./node_modules/imapflow/lib/tools.js\");\n\nlet setBoolOpt = (attributes, term, value) => {\n if (!value) {\n if (/^un/i.test(term)) {\n term = term.slice(2);\n } else {\n term = 'UN' + term;\n }\n }\n\n attributes.push({ type: 'ATOM', value: term.toUpperCase() });\n};\n\nlet setOpt = (attributes, term, value, type) => {\n type = type || 'ATOM';\n\n if (value === false || value === null) {\n attributes.push({ type, value: 'NOT' });\n }\n\n attributes.push({ type, value: term.toUpperCase() });\n\n if (Array.isArray(value)) {\n value.forEach(entry => attributes.push({ type, value: (entry || '').toString() }));\n } else {\n attributes.push({ type, value: value.toString() });\n }\n};\n\nlet processDateField = (attributes, term, value) => {\n let date = formatDate(value);\n if (!date) {\n return;\n }\n\n setOpt(attributes, term, date);\n};\n\nlet isUnicodeString = str => {\n if (!str || typeof str !== 'string') {\n return false;\n }\n\n return Buffer.byteLength(str) !== str.length;\n};\n\nmodule.exports.searchCompiler = (connection, query) => {\n const attributes = [];\n\n let hasUnicode = false;\n const mailbox = connection.mailbox;\n\n const walk = params => {\n Object.keys(params || {}).forEach(term => {\n switch (term.toUpperCase()) {\n case 'SEQ': // custom key for sequence range\n {\n let value = params[term];\n if (typeof value === 'number') {\n value = value.toString();\n }\n if (typeof value === 'string' && /^\\S+$/.test(value)) {\n attributes.push({ type: 'SEQUENCE', value });\n }\n }\n break;\n\n case 'ANSWERED':\n case 'DELETED':\n case 'DRAFT':\n case 'FLAGGED':\n case 'SEEN':\n case 'UNANSWERED':\n case 'UNDELETED':\n case 'UNDRAFT':\n case 'UNFLAGGED':\n case 'UNSEEN':\n // toggles UN-prefix for falsy values\n setBoolOpt(attributes, term, !!params[term]);\n break;\n\n case 'ALL':\n case 'NEW':\n case 'OLD':\n case 'RECENT':\n if (params[term]) {\n setBoolOpt(attributes, term, true);\n }\n break;\n\n case 'LARGER':\n case 'SMALLER':\n case 'MODSEQ':\n if (params[term]) {\n setOpt(attributes, term, params[term]);\n }\n break;\n\n case 'BCC':\n case 'BODY':\n case 'CC':\n case 'FROM':\n case 'SUBJECT':\n case 'TEXT':\n case 'TO':\n if (isUnicodeString(params[term])) {\n hasUnicode = true;\n }\n if (params[term]) {\n setOpt(attributes, term, params[term]);\n }\n break;\n\n case 'UID':\n if (params[term]) {\n setOpt(attributes, term, params[term], 'SEQUENCE');\n }\n break;\n\n case 'EMAILID':\n if (connection.capabilities.has('OBJECTID')) {\n setOpt(attributes, 'EMAILID', params[term]);\n } else if (connection.capabilities.has('X-GM-EXT-1')) {\n setOpt(attributes, 'X-GM-MSGID', params[term]);\n }\n break;\n\n case 'THREADID':\n if (connection.capabilities.has('OBJECTID')) {\n setOpt(attributes, 'THREADID', params[term]);\n } else if (connection.capabilities.has('X-GM-EXT-1')) {\n setOpt(attributes, 'X-GM-THRID', params[term]);\n }\n break;\n\n case 'GMRAW':\n case 'GMAILRAW': // alias for GMRAW\n if (connection.capabilities.has('X-GM-EXT-1')) {\n if (isUnicodeString(params[term])) {\n hasUnicode = true;\n }\n setOpt(attributes, 'X-GM-RAW', params[term]);\n } else {\n let error = new Error('Server does not support X-GM-EXT-1 extension required for X-GM-RAW');\n error.code = 'MissingServerExtension';\n throw error;\n }\n break;\n\n case 'BEFORE':\n case 'ON':\n case 'SINCE':\n case 'SENTBEFORE':\n case 'SENTON':\n case 'SENTSINCE':\n processDateField(attributes, term, params[term]);\n break;\n\n case 'KEYWORD':\n case 'UNKEYWORD':\n {\n let flag = formatFlag(params[term]);\n if (canUseFlag(mailbox, flag) || mailbox.flags.has(flag)) {\n setOpt(attributes, term, flag);\n }\n }\n break;\n\n case 'HEADER':\n if (params[term] && typeof params[term] === 'object') {\n Object.keys(params[term]).forEach(header => {\n let value = params[term][header];\n if (value === true) {\n value = '';\n }\n\n if (typeof value !== 'string') {\n return;\n }\n\n if (isUnicodeString(value)) {\n hasUnicode = true;\n }\n\n setOpt(attributes, term, [header.toUpperCase().trim(), value]);\n });\n }\n break;\n\n case 'OR':\n {\n if (!params[term] || !Array.isArray(params[term]) || !params[term].length) {\n break;\n }\n\n if (params[term].length === 1) {\n if (typeof params[term][0] === 'object' && params[term][0]) {\n walk(params[term][0]);\n }\n break;\n }\n\n // OR values has to be grouped by 2\n // OR conditional1 conditional2\n let genOrTree = list => {\n let group = false;\n let groups = [];\n\n list.forEach((entry, i) => {\n if (i % 2 === 0) {\n group = [entry];\n } else {\n group.push(entry);\n groups.push(group);\n group = false;\n }\n });\n\n if (group && group.length) {\n while (group.length === 1 && Array.isArray(group[0])) {\n group = group[0];\n }\n\n groups.push(group);\n }\n\n while (groups.length > 2) {\n groups = genOrTree(groups);\n }\n\n while (groups.length === 1 && Array.isArray(groups[0])) {\n groups = groups[0];\n }\n\n return groups;\n };\n\n let walkOrTree = entry => {\n if (Array.isArray(entry)) {\n if (entry.length > 1) {\n attributes.push({ type: 'ATOM', value: 'OR' });\n }\n entry.forEach(walkOrTree);\n return;\n }\n if (entry && typeof entry === 'object') {\n walk(entry);\n }\n };\n walkOrTree(genOrTree(params[term]));\n }\n break;\n }\n });\n };\n\n walk(query);\n\n if (hasUnicode && !connection.enabled.has('UTF8=ACCEPT')) {\n // Prepend search query with `CHARSET UTF-8`\n attributes.unshift({ type: 'ATOM', value: 'UTF-8' });\n attributes.unshift({ type: 'ATOM', value: 'CHARSET' });\n }\n\n return attributes;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/imapflow/lib/search-compiler.js","mappings":"AAAa;;AAEb,QAAQ,qCAAqC,EAAE,mBAAO,CAAC,yEAAY;;AAEnE;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;;AAEA,sBAAsB,yCAAyC;AAC/D;;AAEA;AACA;;AAEA;AACA,0BAA0B,oBAAoB;AAC9C;;AAEA,sBAAsB,iCAAiC;;AAEvD;AACA,iDAAiD,uCAAuC;AACxF,MAAM;AACN,0BAA0B,+BAA+B;AACzD;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,6BAA6B;AAC7B;;AAEA;AACA;;AAEA;AACA,gCAAgC;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,yBAAyB;AACvE;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;;AAEA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,yBAAyB;AACzB;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,kCAAkC;AAClC;AACA;AACA;AACA;AACA,6BAA6B;;AAE7B;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,sDAAsD,2BAA2B;AACjF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;;AAEA;AACA;AACA,6BAA6B,8BAA8B;AAC3D,6BAA6B,gCAAgC;AAC7D;;AAEA;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/search-compiler.js"],"sourcesContent":["'use strict';\n\nconst { formatDate, formatFlag, canUseFlag } = require('./tools.js');\n\nlet setBoolOpt = (attributes, term, value) => {\n    if (!value) {\n        if (/^un/i.test(term)) {\n            term = term.slice(2);\n        } else {\n            term = 'UN' + term;\n        }\n    }\n\n    attributes.push({ type: 'ATOM', value: term.toUpperCase() });\n};\n\nlet setOpt = (attributes, term, value, type) => {\n    type = type || 'ATOM';\n\n    if (value === false || value === null) {\n        attributes.push({ type, value: 'NOT' });\n    }\n\n    attributes.push({ type, value: term.toUpperCase() });\n\n    if (Array.isArray(value)) {\n        value.forEach(entry => attributes.push({ type, value: (entry || '').toString() }));\n    } else {\n        attributes.push({ type, value: value.toString() });\n    }\n};\n\nlet processDateField = (attributes, term, value) => {\n    let date = formatDate(value);\n    if (!date) {\n        return;\n    }\n\n    setOpt(attributes, term, date);\n};\n\nlet isUnicodeString = str => {\n    if (!str || typeof str !== 'string') {\n        return false;\n    }\n\n    return Buffer.byteLength(str) !== str.length;\n};\n\nmodule.exports.searchCompiler = (connection, query) => {\n    const attributes = [];\n\n    let hasUnicode = false;\n    const mailbox = connection.mailbox;\n\n    const walk = params => {\n        Object.keys(params || {}).forEach(term => {\n            switch (term.toUpperCase()) {\n                case 'SEQ': // custom key for sequence range\n                    {\n                        let value = params[term];\n                        if (typeof value === 'number') {\n                            value = value.toString();\n                        }\n                        if (typeof value === 'string' && /^\\S+$/.test(value)) {\n                            attributes.push({ type: 'SEQUENCE', value });\n                        }\n                    }\n                    break;\n\n                case 'ANSWERED':\n                case 'DELETED':\n                case 'DRAFT':\n                case 'FLAGGED':\n                case 'SEEN':\n                case 'UNANSWERED':\n                case 'UNDELETED':\n                case 'UNDRAFT':\n                case 'UNFLAGGED':\n                case 'UNSEEN':\n                    // toggles UN-prefix for falsy values\n                    setBoolOpt(attributes, term, !!params[term]);\n                    break;\n\n                case 'ALL':\n                case 'NEW':\n                case 'OLD':\n                case 'RECENT':\n                    if (params[term]) {\n                        setBoolOpt(attributes, term, true);\n                    }\n                    break;\n\n                case 'LARGER':\n                case 'SMALLER':\n                case 'MODSEQ':\n                    if (params[term]) {\n                        setOpt(attributes, term, params[term]);\n                    }\n                    break;\n\n                case 'BCC':\n                case 'BODY':\n                case 'CC':\n                case 'FROM':\n                case 'SUBJECT':\n                case 'TEXT':\n                case 'TO':\n                    if (isUnicodeString(params[term])) {\n                        hasUnicode = true;\n                    }\n                    if (params[term]) {\n                        setOpt(attributes, term, params[term]);\n                    }\n                    break;\n\n                case 'UID':\n                    if (params[term]) {\n                        setOpt(attributes, term, params[term], 'SEQUENCE');\n                    }\n                    break;\n\n                case 'EMAILID':\n                    if (connection.capabilities.has('OBJECTID')) {\n                        setOpt(attributes, 'EMAILID', params[term]);\n                    } else if (connection.capabilities.has('X-GM-EXT-1')) {\n                        setOpt(attributes, 'X-GM-MSGID', params[term]);\n                    }\n                    break;\n\n                case 'THREADID':\n                    if (connection.capabilities.has('OBJECTID')) {\n                        setOpt(attributes, 'THREADID', params[term]);\n                    } else if (connection.capabilities.has('X-GM-EXT-1')) {\n                        setOpt(attributes, 'X-GM-THRID', params[term]);\n                    }\n                    break;\n\n                case 'GMRAW':\n                case 'GMAILRAW': // alias for GMRAW\n                    if (connection.capabilities.has('X-GM-EXT-1')) {\n                        if (isUnicodeString(params[term])) {\n                            hasUnicode = true;\n                        }\n                        setOpt(attributes, 'X-GM-RAW', params[term]);\n                    } else {\n                        let error = new Error('Server does not support X-GM-EXT-1 extension required for X-GM-RAW');\n                        error.code = 'MissingServerExtension';\n                        throw error;\n                    }\n                    break;\n\n                case 'BEFORE':\n                case 'ON':\n                case 'SINCE':\n                case 'SENTBEFORE':\n                case 'SENTON':\n                case 'SENTSINCE':\n                    processDateField(attributes, term, params[term]);\n                    break;\n\n                case 'KEYWORD':\n                case 'UNKEYWORD':\n                    {\n                        let flag = formatFlag(params[term]);\n                        if (canUseFlag(mailbox, flag) || mailbox.flags.has(flag)) {\n                            setOpt(attributes, term, flag);\n                        }\n                    }\n                    break;\n\n                case 'HEADER':\n                    if (params[term] && typeof params[term] === 'object') {\n                        Object.keys(params[term]).forEach(header => {\n                            let value = params[term][header];\n                            if (value === true) {\n                                value = '';\n                            }\n\n                            if (typeof value !== 'string') {\n                                return;\n                            }\n\n                            if (isUnicodeString(value)) {\n                                hasUnicode = true;\n                            }\n\n                            setOpt(attributes, term, [header.toUpperCase().trim(), value]);\n                        });\n                    }\n                    break;\n\n                case 'OR':\n                    {\n                        if (!params[term] || !Array.isArray(params[term]) || !params[term].length) {\n                            break;\n                        }\n\n                        if (params[term].length === 1) {\n                            if (typeof params[term][0] === 'object' && params[term][0]) {\n                                walk(params[term][0]);\n                            }\n                            break;\n                        }\n\n                        // OR values has to be grouped by 2\n                        // OR conditional1 conditional2\n                        let genOrTree = list => {\n                            let group = false;\n                            let groups = [];\n\n                            list.forEach((entry, i) => {\n                                if (i % 2 === 0) {\n                                    group = [entry];\n                                } else {\n                                    group.push(entry);\n                                    groups.push(group);\n                                    group = false;\n                                }\n                            });\n\n                            if (group && group.length) {\n                                while (group.length === 1 && Array.isArray(group[0])) {\n                                    group = group[0];\n                                }\n\n                                groups.push(group);\n                            }\n\n                            while (groups.length > 2) {\n                                groups = genOrTree(groups);\n                            }\n\n                            while (groups.length === 1 && Array.isArray(groups[0])) {\n                                groups = groups[0];\n                            }\n\n                            return groups;\n                        };\n\n                        let walkOrTree = entry => {\n                            if (Array.isArray(entry)) {\n                                if (entry.length > 1) {\n                                    attributes.push({ type: 'ATOM', value: 'OR' });\n                                }\n                                entry.forEach(walkOrTree);\n                                return;\n                            }\n                            if (entry && typeof entry === 'object') {\n                                walk(entry);\n                            }\n                        };\n                        walkOrTree(genOrTree(params[term]));\n                    }\n                    break;\n            }\n        });\n    };\n\n    walk(query);\n\n    if (hasUnicode && !connection.enabled.has('UTF8=ACCEPT')) {\n        // Prepend search query with `CHARSET UTF-8`\n        attributes.unshift({ type: 'ATOM', value: 'UTF-8' });\n        attributes.unshift({ type: 'ATOM', value: 'CHARSET' });\n    }\n\n    return attributes;\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/search-compiler.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/special-use.js":
|
|
/*!**************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/special-use.js ***!
|
|
\**************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\nmodule.exports = {\n flags: ['\\\\All', '\\\\Archive', '\\\\Drafts', '\\\\Flagged', '\\\\Junk', '\\\\Sent', '\\\\Trash'],\n names: {\n '\\\\Sent': [\n 'aika',\n 'bidaliak',\n 'bidalita',\n 'dihantar',\n 'e rometsweng',\n 'e tindami',\n 'elküldött',\n 'elküldöttek',\n 'elementos enviados',\n 'éléments envoyés',\n 'enviadas',\n 'enviadas',\n 'enviados',\n 'enviats',\n 'envoyés',\n 'ethunyelweyo',\n 'expediate',\n 'ezipuru',\n 'gesendete',\n 'gesendete elemente',\n 'gestuur',\n 'gönderilmiş öğeler',\n 'göndərilənlər',\n 'iberilen',\n 'inviati',\n 'išsiųstieji',\n 'kuthunyelwe',\n 'lasa',\n 'lähetetyt',\n 'messages envoyés',\n 'naipadala',\n 'nalefa',\n 'napadala',\n 'nosūtītās ziņas',\n 'odeslané',\n 'odeslaná pošta',\n 'padala',\n 'poslane',\n 'poslano',\n 'poslano',\n 'poslané',\n 'poslato',\n 'saadetud',\n 'saadetud kirjad',\n 'saadetud üksused',\n 'sendt',\n 'sendt',\n 'sent',\n 'sent items',\n 'sent messages',\n 'sända poster',\n 'sänt',\n 'terkirim',\n 'ti fi ranṣẹ',\n 'të dërguara',\n 'verzonden',\n 'vilivyotumwa',\n 'wysłane',\n 'đã gửi',\n 'σταλθέντα',\n 'жиберилген',\n 'жіберілгендер',\n 'изпратени',\n 'илгээсэн',\n 'ирсол шуд',\n 'испратено',\n 'надіслані',\n 'отправленные',\n 'пасланыя',\n 'юборилган',\n 'ուղարկված',\n 'נשלחו',\n 'פריטים שנשלחו',\n 'المرسلة',\n 'بھیجے گئے',\n 'سوزمژہ',\n 'لېګل شوی',\n 'موارد ارسال شده',\n 'पाठविले',\n 'पाठविलेले',\n 'प्रेषित',\n 'भेजा गया',\n 'প্রেরিত',\n 'প্রেরিত',\n 'প্ৰেৰিত',\n 'ਭੇਜੇ',\n 'મોકલેલા',\n 'ପଠାଗଲା',\n 'அனுப்பியவை',\n 'పంపించబడింది',\n 'ಕಳುಹಿಸಲಾದ',\n 'അയച്ചു',\n 'යැවු පණිවුඩ',\n 'ส่งแล้ว',\n 'გაგზავნილი',\n 'የተላኩ',\n 'បានផ្ញើ',\n '寄件備份',\n '寄件備份',\n '已发信息',\n '送信済みメール',\n '발신 메시지',\n '보낸 편지함'\n ],\n '\\\\Trash': [\n 'articole șterse',\n 'bin',\n 'borttagna objekt',\n 'deleted',\n 'deleted items',\n 'deleted messages',\n 'elementi eliminati',\n 'elementos borrados',\n 'elementos eliminados',\n 'gelöschte objekte',\n 'gelöschte elemente',\n 'item dipadam',\n 'itens apagados',\n 'itens excluídos',\n 'kustutatud üksused',\n 'mục đã xóa',\n 'odstraněné položky',\n 'odstraněná pošta',\n 'pesan terhapus',\n 'poistetut',\n 'praht',\n 'prügikast',\n 'silinmiş öğeler',\n 'slettede beskeder',\n 'slettede elementer',\n 'trash',\n 'törölt elemek',\n 'törölt',\n 'usunięte wiadomości',\n 'verwijderde items',\n 'vymazané správy',\n 'éléments supprimés',\n 'видалені',\n 'жойылғандар',\n 'удаленные',\n 'פריטים שנמחקו',\n 'العناصر المحذوفة',\n 'موارد حذف شده',\n 'รายการที่ลบ',\n '已删除邮件',\n '已刪除項目',\n '已刪除項目'\n ],\n '\\\\Junk': [\n 'bulk mail',\n 'correo no deseado',\n 'courrier indésirable',\n 'istenmeyen',\n 'istenmeyen e-posta',\n 'junk',\n 'junk e-mail',\n 'junk email',\n 'junk-e-mail',\n 'levélszemét',\n 'nevyžiadaná pošta',\n 'nevyžádaná pošta',\n 'no deseado',\n 'posta indesiderata',\n 'pourriel',\n 'roskaposti',\n 'rämpspost',\n 'skräppost',\n 'spam',\n 'spam',\n 'spamowanie',\n 'søppelpost',\n 'thư rác',\n 'wiadomości-śmieci',\n 'спам',\n 'דואר זבל',\n 'الرسائل العشوائية',\n 'هرزنامه',\n 'สแปม',\n '垃圾郵件',\n '垃圾邮件',\n '垃圾電郵'\n ],\n '\\\\Drafts': [\n 'ba brouillon',\n 'borrador',\n 'borrador',\n 'borradores',\n 'bozze',\n 'brouillons',\n 'bản thảo',\n 'ciorne',\n 'concepten',\n 'draf',\n 'draft',\n 'drafts',\n 'drög',\n 'entwürfe',\n 'esborranys',\n 'garalamalar',\n 'ihe edeturu',\n 'iidrafti',\n 'izinhlaka',\n 'juodraščiai',\n 'kladd',\n 'kladder',\n 'koncepty',\n 'koncepty',\n 'konsep',\n 'konsepte',\n 'kopie robocze',\n 'layihələr',\n 'luonnokset',\n 'melnraksti',\n 'meralo',\n 'mesazhe të padërguara',\n 'mga draft',\n 'mustandid',\n 'nacrti',\n 'nacrti',\n 'osnutki',\n 'piszkozatok',\n 'rascunhos',\n 'rasimu',\n 'skice',\n 'taslaklar',\n 'tsararrun saƙonni',\n 'utkast',\n 'vakiraoka',\n 'vázlatok',\n 'zirriborroak',\n 'àwọn àkọpamọ́',\n 'πρόχειρα',\n 'жобалар',\n 'нацрти',\n 'нооргууд',\n 'сиёҳнавис',\n 'хомаки хатлар',\n 'чарнавікі',\n 'чернетки',\n 'чернови',\n 'черновики',\n 'черновиктер',\n 'սևագրեր',\n 'טיוטות',\n 'مسودات',\n 'مسودات',\n 'موسودې',\n 'پیش نویسها',\n 'ڈرافٹ/',\n 'ड्राफ़्ट',\n 'प्रारूप',\n 'খসড়া',\n 'খসড়া',\n 'ড্ৰাফ্ট',\n 'ਡ੍ਰਾਫਟ',\n 'ડ્રાફ્ટસ',\n 'ଡ୍ରାଫ୍ଟ',\n 'வரைவுகள்',\n 'చిత్తు ప్రతులు',\n 'ಕರಡುಗಳು',\n 'കരടുകള്',\n 'කෙටුම් පත්',\n 'ฉบับร่าง',\n 'მონახაზები',\n 'ረቂቆች',\n 'សារព្រាង',\n '下書き',\n '草稿',\n '草稿',\n '草稿',\n '임시 보관함'\n ],\n\n '\\\\Archive': ['archive']\n },\n\n specialUse(hasSpecialUseExtension, folder) {\n let result;\n\n if (hasSpecialUseExtension) {\n result = {\n flag: module.exports.flags.find(flag => folder.flags.has(flag)),\n source: 'extension'\n };\n }\n\n if (!result || !result.flag) {\n let name = folder.name\n .toLowerCase()\n .replace(/\\u200e/g, '')\n .trim();\n\n result = {\n flag: Object.keys(module.exports.names).find(flag => module.exports.names[flag].includes(name)),\n source: 'name'\n };\n }\n\n return result && result.flag ? result : { flag: null };\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/imapflow/lib/special-use.js","mappings":"AAAa;;AAEb;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;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;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;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;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;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;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,kDAAkD;AAClD;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/special-use.js"],"sourcesContent":["'use strict';\n\nmodule.exports = {\n    flags: ['\\\\All', '\\\\Archive', '\\\\Drafts', '\\\\Flagged', '\\\\Junk', '\\\\Sent', '\\\\Trash'],\n    names: {\n        '\\\\Sent': [\n            'aika',\n            'bidaliak',\n            'bidalita',\n            'dihantar',\n            'e rometsweng',\n            'e tindami',\n            'elküldött',\n            'elküldöttek',\n            'elementos enviados',\n            'éléments envoyés',\n            'enviadas',\n            'enviadas',\n            'enviados',\n            'enviats',\n            'envoyés',\n            'ethunyelweyo',\n            'expediate',\n            'ezipuru',\n            'gesendete',\n            'gesendete elemente',\n            'gestuur',\n            'gönderilmiş öğeler',\n            'göndərilənlər',\n            'iberilen',\n            'inviati',\n            'išsiųstieji',\n            'kuthunyelwe',\n            'lasa',\n            'lähetetyt',\n            'messages envoyés',\n            'naipadala',\n            'nalefa',\n            'napadala',\n            'nosūtītās ziņas',\n            'odeslané',\n            'odeslaná pošta',\n            'padala',\n            'poslane',\n            'poslano',\n            'poslano',\n            'poslané',\n            'poslato',\n            'saadetud',\n            'saadetud kirjad',\n            'saadetud üksused',\n            'sendt',\n            'sendt',\n            'sent',\n            'sent items',\n            'sent messages',\n            'sända poster',\n            'sänt',\n            'terkirim',\n            'ti fi ranṣẹ',\n            'të dërguara',\n            'verzonden',\n            'vilivyotumwa',\n            'wysłane',\n            'đã gửi',\n            'σταλθέντα',\n            'жиберилген',\n            'жіберілгендер',\n            'изпратени',\n            'илгээсэн',\n            'ирсол шуд',\n            'испратено',\n            'надіслані',\n            'отправленные',\n            'пасланыя',\n            'юборилган',\n            'ուղարկված',\n            'נשלחו',\n            'פריטים שנשלחו',\n            'المرسلة',\n            'بھیجے گئے',\n            'سوزمژہ',\n            'لېګل شوی',\n            'موارد ارسال شده',\n            'पाठविले',\n            'पाठविलेले',\n            'प्रेषित',\n            'भेजा गया',\n            'প্রেরিত',\n            'প্রেরিত',\n            'প্ৰেৰিত',\n            'ਭੇਜੇ',\n            'મોકલેલા',\n            'ପଠାଗଲା',\n            'அனுப்பியவை',\n            'పంపించబడింది',\n            'ಕಳುಹಿಸಲಾದ',\n            'അയച്ചു',\n            'යැවු පණිවුඩ',\n            'ส่งแล้ว',\n            'გაგზავნილი',\n            'የተላኩ',\n            'បាន​ផ្ញើ',\n            '寄件備份',\n            '寄件備份',\n            '已发信息',\n            '送信済みﾒｰﾙ',\n            '발신 메시지',\n            '보낸 편지함'\n        ],\n        '\\\\Trash': [\n            'articole șterse',\n            'bin',\n            'borttagna objekt',\n            'deleted',\n            'deleted items',\n            'deleted messages',\n            'elementi eliminati',\n            'elementos borrados',\n            'elementos eliminados',\n            'gelöschte objekte',\n            'gelöschte elemente',\n            'item dipadam',\n            'itens apagados',\n            'itens excluídos',\n            'kustutatud üksused',\n            'mục đã xóa',\n            'odstraněné položky',\n            'odstraněná pošta',\n            'pesan terhapus',\n            'poistetut',\n            'praht',\n            'prügikast',\n            'silinmiş öğeler',\n            'slettede beskeder',\n            'slettede elementer',\n            'trash',\n            'törölt elemek',\n            'törölt',\n            'usunięte wiadomości',\n            'verwijderde items',\n            'vymazané správy',\n            'éléments supprimés',\n            'видалені',\n            'жойылғандар',\n            'удаленные',\n            'פריטים שנמחקו',\n            'العناصر المحذوفة',\n            'موارد حذف شده',\n            'รายการที่ลบ',\n            '已删除邮件',\n            '已刪除項目',\n            '已刪除項目'\n        ],\n        '\\\\Junk': [\n            'bulk mail',\n            'correo no deseado',\n            'courrier indésirable',\n            'istenmeyen',\n            'istenmeyen e-posta',\n            'junk',\n            'junk e-mail',\n            'junk email',\n            'junk-e-mail',\n            'levélszemét',\n            'nevyžiadaná pošta',\n            'nevyžádaná pošta',\n            'no deseado',\n            'posta indesiderata',\n            'pourriel',\n            'roskaposti',\n            'rämpspost',\n            'skräppost',\n            'spam',\n            'spam',\n            'spamowanie',\n            'søppelpost',\n            'thư rác',\n            'wiadomości-śmieci',\n            'спам',\n            'דואר זבל',\n            'الرسائل العشوائية',\n            'هرزنامه',\n            'สแปม',\n            '垃圾郵件',\n            '垃圾邮件',\n            '垃圾電郵'\n        ],\n        '\\\\Drafts': [\n            'ba brouillon',\n            'borrador',\n            'borrador',\n            'borradores',\n            'bozze',\n            'brouillons',\n            'bản thảo',\n            'ciorne',\n            'concepten',\n            'draf',\n            'draft',\n            'drafts',\n            'drög',\n            'entwürfe',\n            'esborranys',\n            'garalamalar',\n            'ihe edeturu',\n            'iidrafti',\n            'izinhlaka',\n            'juodraščiai',\n            'kladd',\n            'kladder',\n            'koncepty',\n            'koncepty',\n            'konsep',\n            'konsepte',\n            'kopie robocze',\n            'layihələr',\n            'luonnokset',\n            'melnraksti',\n            'meralo',\n            'mesazhe të padërguara',\n            'mga draft',\n            'mustandid',\n            'nacrti',\n            'nacrti',\n            'osnutki',\n            'piszkozatok',\n            'rascunhos',\n            'rasimu',\n            'skice',\n            'taslaklar',\n            'tsararrun saƙonni',\n            'utkast',\n            'vakiraoka',\n            'vázlatok',\n            'zirriborroak',\n            'àwọn àkọpamọ́',\n            'πρόχειρα',\n            'жобалар',\n            'нацрти',\n            'нооргууд',\n            'сиёҳнавис',\n            'хомаки хатлар',\n            'чарнавікі',\n            'чернетки',\n            'чернови',\n            'черновики',\n            'черновиктер',\n            'սևագրեր',\n            'טיוטות',\n            'مسودات',\n            'مسودات',\n            'موسودې',\n            'پیش نویسها',\n            'ڈرافٹ/',\n            'ड्राफ़्ट',\n            'प्रारूप',\n            'খসড়া',\n            'খসড়া',\n            'ড্ৰাফ্ট',\n            'ਡ੍ਰਾਫਟ',\n            'ડ્રાફ્ટસ',\n            'ଡ୍ରାଫ୍ଟ',\n            'வரைவுகள்',\n            'చిత్తు ప్రతులు',\n            'ಕರಡುಗಳು',\n            'കരടുകള്‍',\n            'කෙටුම් පත්',\n            'ฉบับร่าง',\n            'მონახაზები',\n            'ረቂቆች',\n            'សារព្រាង',\n            '下書き',\n            '草稿',\n            '草稿',\n            '草稿',\n            '임시 보관함'\n        ],\n\n        '\\\\Archive': ['archive']\n    },\n\n    specialUse(hasSpecialUseExtension, folder) {\n        let result;\n\n        if (hasSpecialUseExtension) {\n            result = {\n                flag: module.exports.flags.find(flag => folder.flags.has(flag)),\n                source: 'extension'\n            };\n        }\n\n        if (!result || !result.flag) {\n            let name = folder.name\n                .toLowerCase()\n                .replace(/\\u200e/g, '')\n                .trim();\n\n            result = {\n                flag: Object.keys(module.exports.names).find(flag => module.exports.names[flag].includes(name)),\n                source: 'name'\n            };\n        }\n\n        return result && result.flag ? result : { flag: null };\n    }\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/special-use.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/lib/tools.js":
|
|
/*!********************************************!*\
|
|
!*** ./node_modules/imapflow/lib/tools.js ***!
|
|
\********************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("/* eslint no-control-regex:0 */\n\n\n\nconst libmime = __webpack_require__(/*! libmime */ \"(action-browser)/./node_modules/libmime/lib/libmime.js\");\nconst { resolveCharset } = __webpack_require__(/*! ./charsets */ \"(action-browser)/./node_modules/imapflow/lib/charsets.js\");\nconst { compiler } = __webpack_require__(/*! ./handler/imap-handler */ \"(action-browser)/./node_modules/imapflow/lib/handler/imap-handler.js\");\nconst { createHash } = __webpack_require__(/*! crypto */ \"crypto\");\nconst { JPDecoder } = __webpack_require__(/*! ./jp-decoder */ \"(action-browser)/./node_modules/imapflow/lib/jp-decoder.js\");\nconst iconv = __webpack_require__(/*! iconv-lite */ \"(action-browser)/./node_modules/iconv-lite/lib/index.js\");\n\nconst FLAG_COLORS = ['red', 'orange', 'yellow', 'green', 'blue', 'purple', 'grey'];\n\nclass AuthenticationFailure extends Error {\n authenticationFailed = true;\n}\n\nconst tools = {\n encodePath(connection, path) {\n path = (path || '').toString();\n if (!connection.enabled.has('UTF8=ACCEPT') && /[&\\x00-\\x08\\x0b-\\x0c\\x0e-\\x1f\\u0080-\\uffff]/.test(path)) {\n try {\n path = iconv.encode(path, 'utf-7-imap').toString();\n } catch (err) {\n // ignore, keep name as is\n }\n }\n return path;\n },\n\n decodePath(connection, path) {\n path = (path || '').toString();\n if (!connection.enabled.has('UTF8=ACCEPT') && /[&]/.test(path)) {\n try {\n path = iconv.decode(Buffer.from(path), 'utf-7-imap').toString();\n } catch (err) {\n // ignore, keep name as is\n }\n }\n return path;\n },\n\n normalizePath(connection, path, skipNamespace) {\n if (Array.isArray(path)) {\n path = path.join((connection.namespace && connection.namespace.delimiter) || '');\n }\n\n if (path.toUpperCase() === 'INBOX') {\n // inbox is not case sensitive\n return 'INBOX';\n }\n\n // ensure namespace prefix if needed\n if (!skipNamespace && connection.namespace && connection.namespace.prefix && path.indexOf(connection.namespace.prefix) !== 0) {\n path = connection.namespace.prefix + path;\n }\n\n return path;\n },\n\n comparePaths(connection, a, b) {\n if (!a || !b) {\n return false;\n }\n return tools.normalizePath(connection, a) === tools.normalizePath(connection, b);\n },\n\n updateCapabilities(list) {\n let map = new Map();\n\n if (list && Array.isArray(list)) {\n list.forEach(val => {\n if (typeof val.value !== 'string') {\n return false;\n }\n let capability = val.value.toUpperCase().trim();\n\n if (capability === 'IMAP4REV1') {\n map.set('IMAP4rev1', true);\n return;\n }\n\n if (capability.indexOf('APPENDLIMIT=') === 0) {\n let splitPos = capability.indexOf('=');\n let appendLimit = Number(capability.substr(splitPos + 1)) || 0;\n map.set('APPENDLIMIT', appendLimit);\n return;\n }\n\n map.set(capability, true);\n });\n }\n\n return map;\n },\n\n AuthenticationFailure,\n\n getStatusCode(response) {\n return response &&\n response.attributes &&\n response.attributes[0] &&\n response.attributes[0].section &&\n response.attributes[0].section[0] &&\n typeof response.attributes[0].section[0].value === 'string'\n ? response.attributes[0].section[0].value.toUpperCase().trim()\n : false;\n },\n\n async getErrorText(response) {\n if (!response) {\n return false;\n }\n\n return (await compiler(response)).toString();\n },\n\n getFolderTree(folders) {\n let tree = {\n root: true,\n folders: []\n };\n\n let getTreeNode = parents => {\n let node = tree;\n if (!parents || !parents.length) {\n return node;\n }\n\n for (let parent of parents) {\n let cur = node.folders && node.folders.find(folder => folder.name === parent);\n if (cur) {\n node = cur;\n } else {\n // not yet set\n cur = {\n name: parent,\n folders: []\n };\n }\n }\n\n return node;\n };\n\n for (let folder of folders) {\n let parent = getTreeNode(folder.parent);\n // see if entry already exists\n let existing = parent.folders && parent.folders.find(existing => existing.name === folder.name);\n if (existing) {\n // update values\n existing.name = folder.name;\n existing.flags = folder.flags;\n existing.path = folder.path;\n existing.subscribed = !!folder.subscribed;\n existing.listed = !!folder.listed;\n existing.status = !!folder.status;\n\n if (folder.specialUse) {\n existing.specialUse = folder.specialUse;\n }\n\n if (folder.flags.has('\\\\Noselect')) {\n existing.disabled = true;\n }\n if (folder.flags.has('\\\\HasChildren') && !existing.folders) {\n existing.folders = [];\n }\n } else {\n // create new\n let data = {\n name: folder.name,\n flags: folder.flags,\n path: folder.path,\n subscribed: !!folder.subscribed,\n listed: !!folder.listed,\n status: !!folder.status\n };\n\n if (folder.delimiter) {\n data.delimiter = folder.delimiter;\n }\n\n if (folder.specialUse) {\n data.specialUse = folder.specialUse;\n }\n\n if (folder.flags.has('\\\\Noselect')) {\n data.disabled = true;\n }\n\n if (folder.flags.has('\\\\HasChildren')) {\n data.folders = [];\n }\n\n if (!parent.folders) {\n parent.folders = [];\n }\n parent.folders.push(data);\n }\n }\n\n return tree;\n },\n\n getFlagColor(flags) {\n if (!flags.has('\\\\Flagged')) {\n return null;\n }\n\n const bit0 = flags.has('$MailFlagBit0') ? 1 : 0;\n const bit1 = flags.has('$MailFlagBit1') ? 2 : 0;\n const bit2 = flags.has('$MailFlagBit2') ? 4 : 0;\n\n const color = bit0 | bit1 | bit2; // eslint-disable-line no-bitwise\n\n return FLAG_COLORS[color] || 'red'; // default to red for the unused \\b111\n },\n\n getColorFlags(color) {\n const colorCode = color ? FLAG_COLORS.indexOf((color || '').toString().toLowerCase().trim()) : null;\n if (colorCode < 0 && colorCode !== null) {\n return null;\n }\n\n const bits = [];\n bits[0] = colorCode & 1; // eslint-disable-line no-bitwise\n bits[1] = colorCode & 2; // eslint-disable-line no-bitwise\n bits[2] = colorCode & 4; // eslint-disable-line no-bitwise\n\n let result = { add: colorCode ? ['\\\\Flagged'] : [], remove: colorCode ? [] : ['\\\\Flagged'] };\n\n for (let i = 0; i < bits.length; i++) {\n if (bits[i]) {\n result.add.push(`$MailFlagBit${i}`);\n } else {\n result.remove.push(`$MailFlagBit${i}`);\n }\n }\n return result;\n },\n\n async formatMessageResponse(untagged, mailbox) {\n let map = {};\n\n map.seq = Number(untagged.command);\n\n let key;\n let attributes = (untagged.attributes && untagged.attributes[1]) || [];\n for (let i = 0, len = attributes.length; i < len; i++) {\n let attribute = attributes[i];\n if (i % 2 === 0) {\n key = (\n await compiler({\n attributes: [attribute]\n })\n )\n .toString()\n .toLowerCase()\n .replace(/<\\d+(\\.\\d+)?>$/, '');\n continue;\n }\n if (typeof key !== 'string') {\n // should not happen\n continue;\n }\n\n let getString = attribute => {\n if (!attribute) {\n return false;\n }\n if (typeof attribute.value === 'string') {\n return attribute.value;\n }\n if (Buffer.isBuffer(attribute.value)) {\n return attribute.value.toString();\n }\n };\n\n let getBuffer = attribute => {\n if (!attribute) {\n return false;\n }\n if (Buffer.isBuffer(attribute.value)) {\n return attribute.value;\n }\n };\n\n let getArray = attribute => {\n if (Array.isArray(attribute)) {\n return attribute.map(entry => (entry && typeof entry.value === 'string' ? entry.value : false)).filter(entry => entry);\n }\n };\n\n switch (key) {\n case 'body[]':\n case 'binary[]':\n map.source = getBuffer(attribute);\n break;\n\n case 'uid':\n map.uid = Number(getString(attribute));\n if (map.uid && (!mailbox.uidNext || mailbox.uidNext <= map.uid)) {\n // current uidNext seems to be outdated, bump it\n mailbox.uidNext = map.uid + 1;\n }\n break;\n\n case 'modseq':\n map.modseq = BigInt(getArray(attribute)[0]);\n if (map.modseq && (!mailbox.highestModseq || mailbox.highestModseq < map.modseq)) {\n // current highestModseq seems to be outdated, bump it\n mailbox.highestModseq = map.modseq;\n }\n break;\n\n case 'emailid':\n map.emailId = getArray(attribute)[0];\n break;\n\n case 'x-gm-msgid':\n map.emailId = getString(attribute);\n break;\n\n case 'threadid':\n map.threadId = getArray(attribute)[0];\n break;\n\n case 'x-gm-thrid':\n map.threadId = getString(attribute);\n break;\n\n case 'x-gm-labels':\n map.labels = new Set(getArray(attribute));\n break;\n\n case 'rfc822.size':\n map.size = Number(getString(attribute)) || 0;\n break;\n\n case 'flags':\n map.flags = new Set(getArray(attribute));\n break;\n\n case 'envelope':\n map.envelope = tools.parseEnvelope(attribute);\n break;\n\n case 'bodystructure':\n map.bodyStructure = tools.parseBodystructure(attribute);\n break;\n\n case 'internaldate': {\n let value = getString(attribute);\n let date = new Date(value);\n if (date.toString() === 'Invalid Date') {\n map.internalDate = value;\n } else {\n map.internalDate = date;\n }\n break;\n }\n\n default: {\n let match = key.match(/(body|binary)\\[/i);\n if (match) {\n let partKey = key.replace(/^(body|binary)\\[|]$/gi, '');\n partKey = partKey.replace(/\\.fields.*$/g, '');\n\n let value = getBuffer(attribute);\n if (partKey === 'header') {\n map.headers = value;\n break;\n }\n\n if (!map.bodyParts) {\n map.bodyParts = new Map();\n }\n map.bodyParts.set(partKey, value);\n break;\n }\n break;\n }\n }\n }\n\n if (map.emailId || map.uid) {\n // define account unique ID for this email\n\n // normalize path to use ascii, so we would always get the same ID\n let path = mailbox.path;\n if (/[0x80-0xff]/.test(path)) {\n try {\n path = iconv.encode(path, 'utf-7-imap').toString();\n } catch (err) {\n // ignore\n }\n }\n\n map.id =\n map.emailId ||\n createHash('md5')\n .update([path, mailbox.uidValidity?.toString() || '', map.uid.toString()].join(':'))\n .digest('hex');\n }\n\n if (map.flags) {\n let flagColor = tools.getFlagColor(map.flags);\n if (flagColor) {\n map.flagColor = flagColor;\n }\n }\n\n return map;\n },\n\n processName(name) {\n name = (name || '').toString();\n if (name.length > 2 && name.at(0) === '\"' && name.at(-1) === '\"') {\n name = name.replace(/^\"|\"$/g, '');\n }\n return name;\n },\n\n parseEnvelope(entry) {\n let getStrValue = obj => {\n if (!obj) {\n return false;\n }\n if (typeof obj.value === 'string') {\n return obj.value;\n }\n if (Buffer.isBuffer(obj.value)) {\n return obj.value.toString();\n }\n return obj.value;\n };\n\n let processAddresses = function (list) {\n return []\n .concat(list || [])\n .map(addr => {\n let address = (getStrValue(addr[2]) || '') + '@' + (getStrValue(addr[3]) || '');\n if (address === '@') {\n address = '';\n }\n return {\n name: tools.processName(libmime.decodeWords(getStrValue(addr[0]))),\n address\n };\n })\n .filter(addr => addr.name || addr.address);\n },\n envelope = {};\n\n if (entry[0] && entry[0].value) {\n let date = new Date(getStrValue(entry[0]));\n if (date.toString() === 'Invalid Date') {\n envelope.date = getStrValue(entry[0]);\n } else {\n envelope.date = date;\n }\n }\n\n if (entry[1] && entry[1].value) {\n envelope.subject = libmime.decodeWords(getStrValue(entry[1]));\n }\n\n if (entry[2] && entry[2].length) {\n envelope.from = processAddresses(entry[2]);\n }\n\n if (entry[3] && entry[3].length) {\n envelope.sender = processAddresses(entry[3]);\n }\n\n if (entry[4] && entry[4].length) {\n envelope.replyTo = processAddresses(entry[4]);\n }\n\n if (entry[5] && entry[5].length) {\n envelope.to = processAddresses(entry[5]);\n }\n\n if (entry[6] && entry[6].length) {\n envelope.cc = processAddresses(entry[6]);\n }\n\n if (entry[7] && entry[7].length) {\n envelope.bcc = processAddresses(entry[7]);\n }\n\n if (entry[8] && entry[8].value) {\n envelope.inReplyTo = (getStrValue(entry[8]) || '').toString().trim();\n }\n\n if (entry[9] && entry[9].value) {\n envelope.messageId = (getStrValue(entry[9]) || '').toString().trim();\n }\n\n return envelope;\n },\n\n getStructuredParams(arr) {\n let key;\n\n let params = {};\n\n [].concat(arr || []).forEach((val, j) => {\n if (j % 2) {\n params[key] = libmime.decodeWords(((val && val.value) || '').toString());\n } else {\n key = ((val && val.value) || '').toString().toLowerCase();\n }\n });\n\n if (params.filename && !params['filename*'] && /^[a-z\\-_0-9]+'[a-z]*'[^'\\x00-\\x08\\x0b\\x0c\\x0e-\\x1f\\u0080-\\uFFFF]+/.test(params.filename)) {\n // seems like encoded value\n let [encoding, , encodedValue] = params.filename.split(\"'\");\n if (resolveCharset(encoding)) {\n params['filename*'] = `${encoding}''${encodedValue}`;\n }\n }\n\n // preprocess values\n Object.keys(params).forEach(key => {\n let actualKey;\n let nr;\n let value;\n\n let match = key.match(/\\*((\\d+)\\*?)?$/);\n\n if (!match) {\n // nothing to do here, does not seem like a continuation param\n return;\n }\n\n actualKey = key.substr(0, match.index).toLowerCase();\n nr = Number(match[2]) || 0;\n\n if (!params[actualKey] || typeof params[actualKey] !== 'object') {\n params[actualKey] = {\n charset: false,\n values: []\n };\n }\n\n value = params[key];\n\n if (nr === 0 && match[0].charAt(match[0].length - 1) === '*' && (match = value.match(/^([^']*)'[^']*'(.*)$/))) {\n params[actualKey].charset = match[1] || 'utf-8';\n value = match[2];\n }\n\n params[actualKey].values.push({ nr, value });\n\n // remove the old reference\n delete params[key];\n });\n\n // concatenate split rfc2231 strings and convert encoded strings to mime encoded words\n Object.keys(params).forEach(key => {\n let value;\n if (params[key] && Array.isArray(params[key].values)) {\n value = params[key].values\n .sort((a, b) => a.nr - b.nr)\n .map(val => (val && val.value) || '')\n .join('');\n\n if (params[key].charset) {\n // convert \"%AB\" to \"=?charset?Q?=AB?=\" and then to unicode\n params[key] = libmime.decodeWords(\n '=?' +\n params[key].charset +\n '?Q?' +\n value\n // fix invalidly encoded chars\n .replace(/[=?_\\s]/g, s => {\n let c = s.charCodeAt(0).toString(16);\n if (s === ' ') {\n return '_';\n } else {\n return '%' + (c.length < 2 ? '0' : '') + c;\n }\n })\n // change from urlencoding to percent encoding\n .replace(/%/g, '=') +\n '?='\n );\n } else {\n params[key] = libmime.decodeWords(value);\n }\n }\n });\n\n return params;\n },\n\n parseBodystructure(entry) {\n let walk = (node, path) => {\n path = path || [];\n\n let curNode = {},\n i = 0,\n part = 0;\n\n if (path.length) {\n curNode.part = path.join('.');\n }\n\n // multipart\n if (Array.isArray(node[0])) {\n curNode.childNodes = [];\n while (Array.isArray(node[i])) {\n curNode.childNodes.push(walk(node[i], path.concat(++part)));\n i++;\n }\n\n // multipart type\n curNode.type = 'multipart/' + ((node[i++] || {}).value || '').toString().toLowerCase();\n\n // extension data (not available for BODY requests)\n\n // body parameter parenthesized list\n if (i < node.length - 1) {\n if (node[i]) {\n curNode.parameters = tools.getStructuredParams(node[i]);\n }\n i++;\n }\n } else {\n // content type\n curNode.type = [((node[i++] || {}).value || '').toString().toLowerCase(), ((node[i++] || {}).value || '').toString().toLowerCase()].join('/');\n\n // body parameter parenthesized list\n if (node[i]) {\n curNode.parameters = tools.getStructuredParams(node[i]);\n }\n i++;\n\n // id\n if (node[i]) {\n curNode.id = ((node[i] || {}).value || '').toString();\n }\n i++;\n\n // description\n if (node[i]) {\n curNode.description = ((node[i] || {}).value || '').toString();\n }\n i++;\n\n // encoding\n if (node[i]) {\n curNode.encoding = ((node[i] || {}).value || '').toString().toLowerCase();\n }\n i++;\n\n // size\n if (node[i]) {\n curNode.size = Number((node[i] || {}).value || 0) || 0;\n }\n i++;\n\n if (curNode.type === 'message/rfc822') {\n // message/rfc adds additional envelope, bodystructure and line count values\n\n // envelope\n if (node[i]) {\n curNode.envelope = tools.parseEnvelope([].concat(node[i] || []));\n }\n i++;\n\n if (node[i]) {\n curNode.childNodes = [\n // rfc822 bodyparts share the same path, difference is between MIME and HEADER\n // path.MIME returns message/rfc822 header\n // path.HEADER returns inlined message header\n walk(node[i], path)\n ];\n }\n i++;\n\n // line count\n if (node[i]) {\n curNode.lineCount = Number((node[i] || {}).value || 0) || 0;\n }\n i++;\n }\n\n if (/^text\\//.test(curNode.type)) {\n // text/* adds additional line count value\n\n // NB! some less known servers do not include the line count value\n // length should be 12+\n if (node.length === 11 && Array.isArray(node[i + 1]) && !Array.isArray(node[i + 2])) {\n // invalid structure, disposition params are shifted\n } else {\n // correct structure, line count number is provided\n if (node[i]) {\n // line count\n curNode.lineCount = Number((node[i] || {}).value || 0) || 0;\n }\n i++;\n }\n }\n\n // extension data (not available for BODY requests)\n\n // md5\n if (i < node.length - 1) {\n if (node[i]) {\n curNode.md5 = ((node[i] || {}).value || '').toString().toLowerCase();\n }\n i++;\n }\n }\n\n // the following are shared extension values (for both multipart and non-multipart parts)\n // not available for BODY requests\n\n // body disposition\n if (i < node.length - 1) {\n if (Array.isArray(node[i]) && node[i].length) {\n curNode.disposition = ((node[i][0] || {}).value || '').toString().toLowerCase();\n if (Array.isArray(node[i][1])) {\n curNode.dispositionParameters = tools.getStructuredParams(node[i][1]);\n }\n }\n i++;\n }\n\n // body language\n if (i < node.length - 1) {\n if (node[i]) {\n curNode.language = [].concat(node[i] || []).map(val => ((val && val.value) || '').toString().toLowerCase());\n }\n i++;\n }\n\n // body location\n // NB! defined as a \"string list\" in RFC3501 but replaced in errata document with \"string\"\n // Errata: http://www.rfc-editor.org/errata_search.php?rfc=3501\n if (i < node.length - 1) {\n if (node[i]) {\n curNode.location = ((node[i] || {}).value || '').toString();\n }\n i++;\n }\n\n return curNode;\n };\n\n return walk(entry);\n },\n\n formatDate(value) {\n if (typeof value === 'string') {\n value = new Date(value);\n }\n\n if (Object.prototype.toString(value) !== '[object Object]' || value.toString() === 'Invalid Date') {\n return;\n }\n\n value = value.toISOString().substr(0, 10);\n value = value.split('-');\n value.reverse();\n\n let months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];\n value[1] = months[Number(value[1]) - 1];\n\n return value.join('-');\n },\n\n formatDateTime(value) {\n if (!value) {\n return;\n }\n\n if (typeof value === 'string') {\n value = new Date(value);\n }\n\n if (Object.prototype.toString(value) !== '[object Object]' || value.toString() === 'Invalid Date') {\n return;\n }\n\n let dateStr = tools.formatDate(value).replace(/^0/, ' '); //starts with date-day-fixed with leading 0 replaced by SP\n let timeStr = value.toISOString().substr(11, 8);\n\n return `${dateStr} ${timeStr} +0000`;\n },\n\n formatFlag(flag) {\n switch (flag.toLowerCase()) {\n case '\\\\recent':\n // can not set or remove\n return false;\n case '\\\\seen':\n case '\\\\answered':\n case '\\\\flagged':\n case '\\\\deleted':\n case '\\\\draft':\n // can not set or remove\n return flag.toLowerCase().replace(/^\\\\./, c => c.toUpperCase());\n }\n return flag;\n },\n\n canUseFlag(mailbox, flag) {\n return !mailbox || !mailbox.permanentFlags || mailbox.permanentFlags.has('\\\\*') || mailbox.permanentFlags.has(flag);\n },\n\n expandRange(range) {\n return range.split(',').flatMap(entry => {\n entry = entry.trim();\n let colon = entry.indexOf(':');\n if (colon < 0) {\n return Number(entry) || 0;\n }\n let first = Number(entry.substr(0, colon)) || 0;\n let second = Number(entry.substr(colon + 1)) || 0;\n if (first === second) {\n return first;\n }\n let list = [];\n if (first < second) {\n for (let i = first; i <= second; i++) {\n list.push(i);\n }\n } else {\n for (let i = first; i >= second; i--) {\n list.push(i);\n }\n }\n return list;\n });\n },\n\n getDecoder(charset) {\n charset = (charset || 'ascii').toString().trim().toLowerCase();\n if (/^jis|^iso-?2022-?jp|^EUCJP/i.test(charset)) {\n // special case not supported by iconv-lite\n return new JPDecoder(charset);\n }\n\n return iconv.decodeStream(charset);\n },\n\n packMessageRange(list) {\n if (typeof uidList === 'string')\n if (!Array.isArray(list)) {\n list = [].concat(list || []);\n }\n\n if (!list.length) {\n return '';\n }\n\n list.sort((a, b) => a - b);\n\n let last = list[list.length - 1];\n let result = [[last]];\n for (let i = list.length - 2; i >= 0; i--) {\n if (list[i] === list[i + 1] - 1) {\n result[0].unshift(list[i]);\n continue;\n }\n result.unshift([list[i]]);\n }\n\n result = result.map(item => {\n if (item.length === 1) {\n return item[0];\n }\n return item.shift() + ':' + item.pop();\n });\n\n return result.join(',');\n }\n};\n\nmodule.exports = tools;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(action-browser)/./node_modules/imapflow/lib/tools.js","mappings":"AAAA;;AAEa;;AAEb,gBAAgB,mBAAO,CAAC,uEAAS;AACjC,QAAQ,iBAAiB,EAAE,mBAAO,CAAC,4EAAY;AAC/C,QAAQ,WAAW,EAAE,mBAAO,CAAC,oGAAwB;AACrD,QAAQ,aAAa,EAAE,mBAAO,CAAC,sBAAQ;AACvC,QAAQ,YAAY,EAAE,mBAAO,CAAC,gFAAc;AAC5C,cAAc,mBAAO,CAAC,2EAAY;;AAElC;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,aAAa;AACb;;AAEA;AACA,KAAK;;AAEL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,0CAA0C;;AAE1C,4CAA4C;AAC5C,KAAK;;AAEL;AACA;AACA;AACA;AACA;;AAEA;AACA,iCAAiC;AACjC,iCAAiC;AACjC,iCAAiC;;AAEjC,uBAAuB;;AAEvB,wBAAwB,iBAAiB;AACzC;AACA,+CAA+C,EAAE;AACjD,cAAc;AACd,kDAAkD,EAAE;AACpD;AACA;AACA;AACA,KAAK;;AAEL;AACA;;AAEA;;AAEA;AACA;AACA,iDAAiD,SAAS;AAC1D;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA,aAAa;AACb;;AAEA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;;AAEA;;AAEA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA,yCAAyC,SAAS,IAAI,aAAa;AACnE;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA,4CAA4C,WAAW;;AAEvD;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sCAAsC;AACtC;AACA;AACA,iCAAiC;AACjC;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA,SAAS;;AAET;AACA,KAAK;;AAEL;AACA;AACA;;AAEA,4BAA4B;AAC5B;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,+DAA+D;;AAE/D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA,iDAAiD,0DAA0D;;AAE3G;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,gDAAgD;AAChD;AACA;;AAEA;AACA;AACA,yDAAyD;AACzD;AACA;;AAEA;AACA;AACA,sDAAsD;AACtD;AACA;;AAEA;AACA;AACA,wDAAwD;AACxD;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,iEAAiE;AACjE;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;AACA,qEAAqE;AACrE;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,qDAAqD;AACrD;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,4DAA4D;AAC5D;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,sDAAsD;AACtD;AACA;AACA;;AAEA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,kEAAkE;AAClE;;AAEA,kBAAkB,SAAS,EAAE,SAAS;AACtC,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC,aAAa;AACjD;AACA;AACA,cAAc;AACd,oCAAoC,aAAa;AACjD;AACA;AACA;AACA;AACA,SAAS;AACT,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,sCAAsC,QAAQ;AAC9C;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA;;AAEA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/tools.js"],"sourcesContent":["/* eslint no-control-regex:0 */\n\n'use strict';\n\nconst libmime = require('libmime');\nconst { resolveCharset } = require('./charsets');\nconst { compiler } = require('./handler/imap-handler');\nconst { createHash } = require('crypto');\nconst { JPDecoder } = require('./jp-decoder');\nconst iconv = require('iconv-lite');\n\nconst FLAG_COLORS = ['red', 'orange', 'yellow', 'green', 'blue', 'purple', 'grey'];\n\nclass AuthenticationFailure extends Error {\n    authenticationFailed = true;\n}\n\nconst tools = {\n    encodePath(connection, path) {\n        path = (path || '').toString();\n        if (!connection.enabled.has('UTF8=ACCEPT') && /[&\\x00-\\x08\\x0b-\\x0c\\x0e-\\x1f\\u0080-\\uffff]/.test(path)) {\n            try {\n                path = iconv.encode(path, 'utf-7-imap').toString();\n            } catch (err) {\n                // ignore, keep name as is\n            }\n        }\n        return path;\n    },\n\n    decodePath(connection, path) {\n        path = (path || '').toString();\n        if (!connection.enabled.has('UTF8=ACCEPT') && /[&]/.test(path)) {\n            try {\n                path = iconv.decode(Buffer.from(path), 'utf-7-imap').toString();\n            } catch (err) {\n                // ignore, keep name as is\n            }\n        }\n        return path;\n    },\n\n    normalizePath(connection, path, skipNamespace) {\n        if (Array.isArray(path)) {\n            path = path.join((connection.namespace && connection.namespace.delimiter) || '');\n        }\n\n        if (path.toUpperCase() === 'INBOX') {\n            // inbox is not case sensitive\n            return 'INBOX';\n        }\n\n        // ensure namespace prefix if needed\n        if (!skipNamespace && connection.namespace && connection.namespace.prefix && path.indexOf(connection.namespace.prefix) !== 0) {\n            path = connection.namespace.prefix + path;\n        }\n\n        return path;\n    },\n\n    comparePaths(connection, a, b) {\n        if (!a || !b) {\n            return false;\n        }\n        return tools.normalizePath(connection, a) === tools.normalizePath(connection, b);\n    },\n\n    updateCapabilities(list) {\n        let map = new Map();\n\n        if (list && Array.isArray(list)) {\n            list.forEach(val => {\n                if (typeof val.value !== 'string') {\n                    return false;\n                }\n                let capability = val.value.toUpperCase().trim();\n\n                if (capability === 'IMAP4REV1') {\n                    map.set('IMAP4rev1', true);\n                    return;\n                }\n\n                if (capability.indexOf('APPENDLIMIT=') === 0) {\n                    let splitPos = capability.indexOf('=');\n                    let appendLimit = Number(capability.substr(splitPos + 1)) || 0;\n                    map.set('APPENDLIMIT', appendLimit);\n                    return;\n                }\n\n                map.set(capability, true);\n            });\n        }\n\n        return map;\n    },\n\n    AuthenticationFailure,\n\n    getStatusCode(response) {\n        return response &&\n            response.attributes &&\n            response.attributes[0] &&\n            response.attributes[0].section &&\n            response.attributes[0].section[0] &&\n            typeof response.attributes[0].section[0].value === 'string'\n            ? response.attributes[0].section[0].value.toUpperCase().trim()\n            : false;\n    },\n\n    async getErrorText(response) {\n        if (!response) {\n            return false;\n        }\n\n        return (await compiler(response)).toString();\n    },\n\n    getFolderTree(folders) {\n        let tree = {\n            root: true,\n            folders: []\n        };\n\n        let getTreeNode = parents => {\n            let node = tree;\n            if (!parents || !parents.length) {\n                return node;\n            }\n\n            for (let parent of parents) {\n                let cur = node.folders && node.folders.find(folder => folder.name === parent);\n                if (cur) {\n                    node = cur;\n                } else {\n                    // not yet set\n                    cur = {\n                        name: parent,\n                        folders: []\n                    };\n                }\n            }\n\n            return node;\n        };\n\n        for (let folder of folders) {\n            let parent = getTreeNode(folder.parent);\n            // see if entry already exists\n            let existing = parent.folders && parent.folders.find(existing => existing.name === folder.name);\n            if (existing) {\n                // update values\n                existing.name = folder.name;\n                existing.flags = folder.flags;\n                existing.path = folder.path;\n                existing.subscribed = !!folder.subscribed;\n                existing.listed = !!folder.listed;\n                existing.status = !!folder.status;\n\n                if (folder.specialUse) {\n                    existing.specialUse = folder.specialUse;\n                }\n\n                if (folder.flags.has('\\\\Noselect')) {\n                    existing.disabled = true;\n                }\n                if (folder.flags.has('\\\\HasChildren') && !existing.folders) {\n                    existing.folders = [];\n                }\n            } else {\n                // create new\n                let data = {\n                    name: folder.name,\n                    flags: folder.flags,\n                    path: folder.path,\n                    subscribed: !!folder.subscribed,\n                    listed: !!folder.listed,\n                    status: !!folder.status\n                };\n\n                if (folder.delimiter) {\n                    data.delimiter = folder.delimiter;\n                }\n\n                if (folder.specialUse) {\n                    data.specialUse = folder.specialUse;\n                }\n\n                if (folder.flags.has('\\\\Noselect')) {\n                    data.disabled = true;\n                }\n\n                if (folder.flags.has('\\\\HasChildren')) {\n                    data.folders = [];\n                }\n\n                if (!parent.folders) {\n                    parent.folders = [];\n                }\n                parent.folders.push(data);\n            }\n        }\n\n        return tree;\n    },\n\n    getFlagColor(flags) {\n        if (!flags.has('\\\\Flagged')) {\n            return null;\n        }\n\n        const bit0 = flags.has('$MailFlagBit0') ? 1 : 0;\n        const bit1 = flags.has('$MailFlagBit1') ? 2 : 0;\n        const bit2 = flags.has('$MailFlagBit2') ? 4 : 0;\n\n        const color = bit0 | bit1 | bit2; // eslint-disable-line no-bitwise\n\n        return FLAG_COLORS[color] || 'red'; // default to red for the unused \\b111\n    },\n\n    getColorFlags(color) {\n        const colorCode = color ? FLAG_COLORS.indexOf((color || '').toString().toLowerCase().trim()) : null;\n        if (colorCode < 0 && colorCode !== null) {\n            return null;\n        }\n\n        const bits = [];\n        bits[0] = colorCode & 1; // eslint-disable-line no-bitwise\n        bits[1] = colorCode & 2; // eslint-disable-line no-bitwise\n        bits[2] = colorCode & 4; // eslint-disable-line no-bitwise\n\n        let result = { add: colorCode ? ['\\\\Flagged'] : [], remove: colorCode ? [] : ['\\\\Flagged'] };\n\n        for (let i = 0; i < bits.length; i++) {\n            if (bits[i]) {\n                result.add.push(`$MailFlagBit${i}`);\n            } else {\n                result.remove.push(`$MailFlagBit${i}`);\n            }\n        }\n        return result;\n    },\n\n    async formatMessageResponse(untagged, mailbox) {\n        let map = {};\n\n        map.seq = Number(untagged.command);\n\n        let key;\n        let attributes = (untagged.attributes && untagged.attributes[1]) || [];\n        for (let i = 0, len = attributes.length; i < len; i++) {\n            let attribute = attributes[i];\n            if (i % 2 === 0) {\n                key = (\n                    await compiler({\n                        attributes: [attribute]\n                    })\n                )\n                    .toString()\n                    .toLowerCase()\n                    .replace(/<\\d+(\\.\\d+)?>$/, '');\n                continue;\n            }\n            if (typeof key !== 'string') {\n                // should not happen\n                continue;\n            }\n\n            let getString = attribute => {\n                if (!attribute) {\n                    return false;\n                }\n                if (typeof attribute.value === 'string') {\n                    return attribute.value;\n                }\n                if (Buffer.isBuffer(attribute.value)) {\n                    return attribute.value.toString();\n                }\n            };\n\n            let getBuffer = attribute => {\n                if (!attribute) {\n                    return false;\n                }\n                if (Buffer.isBuffer(attribute.value)) {\n                    return attribute.value;\n                }\n            };\n\n            let getArray = attribute => {\n                if (Array.isArray(attribute)) {\n                    return attribute.map(entry => (entry && typeof entry.value === 'string' ? entry.value : false)).filter(entry => entry);\n                }\n            };\n\n            switch (key) {\n                case 'body[]':\n                case 'binary[]':\n                    map.source = getBuffer(attribute);\n                    break;\n\n                case 'uid':\n                    map.uid = Number(getString(attribute));\n                    if (map.uid && (!mailbox.uidNext || mailbox.uidNext <= map.uid)) {\n                        // current uidNext seems to be outdated, bump it\n                        mailbox.uidNext = map.uid + 1;\n                    }\n                    break;\n\n                case 'modseq':\n                    map.modseq = BigInt(getArray(attribute)[0]);\n                    if (map.modseq && (!mailbox.highestModseq || mailbox.highestModseq < map.modseq)) {\n                        // current highestModseq seems to be outdated, bump it\n                        mailbox.highestModseq = map.modseq;\n                    }\n                    break;\n\n                case 'emailid':\n                    map.emailId = getArray(attribute)[0];\n                    break;\n\n                case 'x-gm-msgid':\n                    map.emailId = getString(attribute);\n                    break;\n\n                case 'threadid':\n                    map.threadId = getArray(attribute)[0];\n                    break;\n\n                case 'x-gm-thrid':\n                    map.threadId = getString(attribute);\n                    break;\n\n                case 'x-gm-labels':\n                    map.labels = new Set(getArray(attribute));\n                    break;\n\n                case 'rfc822.size':\n                    map.size = Number(getString(attribute)) || 0;\n                    break;\n\n                case 'flags':\n                    map.flags = new Set(getArray(attribute));\n                    break;\n\n                case 'envelope':\n                    map.envelope = tools.parseEnvelope(attribute);\n                    break;\n\n                case 'bodystructure':\n                    map.bodyStructure = tools.parseBodystructure(attribute);\n                    break;\n\n                case 'internaldate': {\n                    let value = getString(attribute);\n                    let date = new Date(value);\n                    if (date.toString() === 'Invalid Date') {\n                        map.internalDate = value;\n                    } else {\n                        map.internalDate = date;\n                    }\n                    break;\n                }\n\n                default: {\n                    let match = key.match(/(body|binary)\\[/i);\n                    if (match) {\n                        let partKey = key.replace(/^(body|binary)\\[|]$/gi, '');\n                        partKey = partKey.replace(/\\.fields.*$/g, '');\n\n                        let value = getBuffer(attribute);\n                        if (partKey === 'header') {\n                            map.headers = value;\n                            break;\n                        }\n\n                        if (!map.bodyParts) {\n                            map.bodyParts = new Map();\n                        }\n                        map.bodyParts.set(partKey, value);\n                        break;\n                    }\n                    break;\n                }\n            }\n        }\n\n        if (map.emailId || map.uid) {\n            // define account unique ID for this email\n\n            // normalize path to use ascii, so we would always get the same ID\n            let path = mailbox.path;\n            if (/[0x80-0xff]/.test(path)) {\n                try {\n                    path = iconv.encode(path, 'utf-7-imap').toString();\n                } catch (err) {\n                    // ignore\n                }\n            }\n\n            map.id =\n                map.emailId ||\n                createHash('md5')\n                    .update([path, mailbox.uidValidity?.toString() || '', map.uid.toString()].join(':'))\n                    .digest('hex');\n        }\n\n        if (map.flags) {\n            let flagColor = tools.getFlagColor(map.flags);\n            if (flagColor) {\n                map.flagColor = flagColor;\n            }\n        }\n\n        return map;\n    },\n\n    processName(name) {\n        name = (name || '').toString();\n        if (name.length > 2 && name.at(0) === '\"' && name.at(-1) === '\"') {\n            name = name.replace(/^\"|\"$/g, '');\n        }\n        return name;\n    },\n\n    parseEnvelope(entry) {\n        let getStrValue = obj => {\n            if (!obj) {\n                return false;\n            }\n            if (typeof obj.value === 'string') {\n                return obj.value;\n            }\n            if (Buffer.isBuffer(obj.value)) {\n                return obj.value.toString();\n            }\n            return obj.value;\n        };\n\n        let processAddresses = function (list) {\n                return []\n                    .concat(list || [])\n                    .map(addr => {\n                        let address = (getStrValue(addr[2]) || '') + '@' + (getStrValue(addr[3]) || '');\n                        if (address === '@') {\n                            address = '';\n                        }\n                        return {\n                            name: tools.processName(libmime.decodeWords(getStrValue(addr[0]))),\n                            address\n                        };\n                    })\n                    .filter(addr => addr.name || addr.address);\n            },\n            envelope = {};\n\n        if (entry[0] && entry[0].value) {\n            let date = new Date(getStrValue(entry[0]));\n            if (date.toString() === 'Invalid Date') {\n                envelope.date = getStrValue(entry[0]);\n            } else {\n                envelope.date = date;\n            }\n        }\n\n        if (entry[1] && entry[1].value) {\n            envelope.subject = libmime.decodeWords(getStrValue(entry[1]));\n        }\n\n        if (entry[2] && entry[2].length) {\n            envelope.from = processAddresses(entry[2]);\n        }\n\n        if (entry[3] && entry[3].length) {\n            envelope.sender = processAddresses(entry[3]);\n        }\n\n        if (entry[4] && entry[4].length) {\n            envelope.replyTo = processAddresses(entry[4]);\n        }\n\n        if (entry[5] && entry[5].length) {\n            envelope.to = processAddresses(entry[5]);\n        }\n\n        if (entry[6] && entry[6].length) {\n            envelope.cc = processAddresses(entry[6]);\n        }\n\n        if (entry[7] && entry[7].length) {\n            envelope.bcc = processAddresses(entry[7]);\n        }\n\n        if (entry[8] && entry[8].value) {\n            envelope.inReplyTo = (getStrValue(entry[8]) || '').toString().trim();\n        }\n\n        if (entry[9] && entry[9].value) {\n            envelope.messageId = (getStrValue(entry[9]) || '').toString().trim();\n        }\n\n        return envelope;\n    },\n\n    getStructuredParams(arr) {\n        let key;\n\n        let params = {};\n\n        [].concat(arr || []).forEach((val, j) => {\n            if (j % 2) {\n                params[key] = libmime.decodeWords(((val && val.value) || '').toString());\n            } else {\n                key = ((val && val.value) || '').toString().toLowerCase();\n            }\n        });\n\n        if (params.filename && !params['filename*'] && /^[a-z\\-_0-9]+'[a-z]*'[^'\\x00-\\x08\\x0b\\x0c\\x0e-\\x1f\\u0080-\\uFFFF]+/.test(params.filename)) {\n            // seems like encoded value\n            let [encoding, , encodedValue] = params.filename.split(\"'\");\n            if (resolveCharset(encoding)) {\n                params['filename*'] = `${encoding}''${encodedValue}`;\n            }\n        }\n\n        // preprocess values\n        Object.keys(params).forEach(key => {\n            let actualKey;\n            let nr;\n            let value;\n\n            let match = key.match(/\\*((\\d+)\\*?)?$/);\n\n            if (!match) {\n                // nothing to do here, does not seem like a continuation param\n                return;\n            }\n\n            actualKey = key.substr(0, match.index).toLowerCase();\n            nr = Number(match[2]) || 0;\n\n            if (!params[actualKey] || typeof params[actualKey] !== 'object') {\n                params[actualKey] = {\n                    charset: false,\n                    values: []\n                };\n            }\n\n            value = params[key];\n\n            if (nr === 0 && match[0].charAt(match[0].length - 1) === '*' && (match = value.match(/^([^']*)'[^']*'(.*)$/))) {\n                params[actualKey].charset = match[1] || 'utf-8';\n                value = match[2];\n            }\n\n            params[actualKey].values.push({ nr, value });\n\n            // remove the old reference\n            delete params[key];\n        });\n\n        // concatenate split rfc2231 strings and convert encoded strings to mime encoded words\n        Object.keys(params).forEach(key => {\n            let value;\n            if (params[key] && Array.isArray(params[key].values)) {\n                value = params[key].values\n                    .sort((a, b) => a.nr - b.nr)\n                    .map(val => (val && val.value) || '')\n                    .join('');\n\n                if (params[key].charset) {\n                    // convert \"%AB\" to \"=?charset?Q?=AB?=\" and then to unicode\n                    params[key] = libmime.decodeWords(\n                        '=?' +\n                            params[key].charset +\n                            '?Q?' +\n                            value\n                                // fix invalidly encoded chars\n                                .replace(/[=?_\\s]/g, s => {\n                                    let c = s.charCodeAt(0).toString(16);\n                                    if (s === ' ') {\n                                        return '_';\n                                    } else {\n                                        return '%' + (c.length < 2 ? '0' : '') + c;\n                                    }\n                                })\n                                // change from urlencoding to percent encoding\n                                .replace(/%/g, '=') +\n                            '?='\n                    );\n                } else {\n                    params[key] = libmime.decodeWords(value);\n                }\n            }\n        });\n\n        return params;\n    },\n\n    parseBodystructure(entry) {\n        let walk = (node, path) => {\n            path = path || [];\n\n            let curNode = {},\n                i = 0,\n                part = 0;\n\n            if (path.length) {\n                curNode.part = path.join('.');\n            }\n\n            // multipart\n            if (Array.isArray(node[0])) {\n                curNode.childNodes = [];\n                while (Array.isArray(node[i])) {\n                    curNode.childNodes.push(walk(node[i], path.concat(++part)));\n                    i++;\n                }\n\n                // multipart type\n                curNode.type = 'multipart/' + ((node[i++] || {}).value || '').toString().toLowerCase();\n\n                // extension data (not available for BODY requests)\n\n                // body parameter parenthesized list\n                if (i < node.length - 1) {\n                    if (node[i]) {\n                        curNode.parameters = tools.getStructuredParams(node[i]);\n                    }\n                    i++;\n                }\n            } else {\n                // content type\n                curNode.type = [((node[i++] || {}).value || '').toString().toLowerCase(), ((node[i++] || {}).value || '').toString().toLowerCase()].join('/');\n\n                // body parameter parenthesized list\n                if (node[i]) {\n                    curNode.parameters = tools.getStructuredParams(node[i]);\n                }\n                i++;\n\n                // id\n                if (node[i]) {\n                    curNode.id = ((node[i] || {}).value || '').toString();\n                }\n                i++;\n\n                // description\n                if (node[i]) {\n                    curNode.description = ((node[i] || {}).value || '').toString();\n                }\n                i++;\n\n                // encoding\n                if (node[i]) {\n                    curNode.encoding = ((node[i] || {}).value || '').toString().toLowerCase();\n                }\n                i++;\n\n                // size\n                if (node[i]) {\n                    curNode.size = Number((node[i] || {}).value || 0) || 0;\n                }\n                i++;\n\n                if (curNode.type === 'message/rfc822') {\n                    // message/rfc adds additional envelope, bodystructure and line count values\n\n                    // envelope\n                    if (node[i]) {\n                        curNode.envelope = tools.parseEnvelope([].concat(node[i] || []));\n                    }\n                    i++;\n\n                    if (node[i]) {\n                        curNode.childNodes = [\n                            // rfc822 bodyparts share the same path, difference is between MIME and HEADER\n                            // path.MIME returns message/rfc822 header\n                            // path.HEADER returns inlined message header\n                            walk(node[i], path)\n                        ];\n                    }\n                    i++;\n\n                    // line count\n                    if (node[i]) {\n                        curNode.lineCount = Number((node[i] || {}).value || 0) || 0;\n                    }\n                    i++;\n                }\n\n                if (/^text\\//.test(curNode.type)) {\n                    // text/* adds additional line count value\n\n                    // NB! some less known servers do not include the line count value\n                    // length should be 12+\n                    if (node.length === 11 && Array.isArray(node[i + 1]) && !Array.isArray(node[i + 2])) {\n                        // invalid structure, disposition params are shifted\n                    } else {\n                        // correct structure, line count number is provided\n                        if (node[i]) {\n                            // line count\n                            curNode.lineCount = Number((node[i] || {}).value || 0) || 0;\n                        }\n                        i++;\n                    }\n                }\n\n                // extension data (not available for BODY requests)\n\n                // md5\n                if (i < node.length - 1) {\n                    if (node[i]) {\n                        curNode.md5 = ((node[i] || {}).value || '').toString().toLowerCase();\n                    }\n                    i++;\n                }\n            }\n\n            // the following are shared extension values (for both multipart and non-multipart parts)\n            // not available for BODY requests\n\n            // body disposition\n            if (i < node.length - 1) {\n                if (Array.isArray(node[i]) && node[i].length) {\n                    curNode.disposition = ((node[i][0] || {}).value || '').toString().toLowerCase();\n                    if (Array.isArray(node[i][1])) {\n                        curNode.dispositionParameters = tools.getStructuredParams(node[i][1]);\n                    }\n                }\n                i++;\n            }\n\n            // body language\n            if (i < node.length - 1) {\n                if (node[i]) {\n                    curNode.language = [].concat(node[i] || []).map(val => ((val && val.value) || '').toString().toLowerCase());\n                }\n                i++;\n            }\n\n            // body location\n            // NB! defined as a \"string list\" in RFC3501 but replaced in errata document with \"string\"\n            // Errata: http://www.rfc-editor.org/errata_search.php?rfc=3501\n            if (i < node.length - 1) {\n                if (node[i]) {\n                    curNode.location = ((node[i] || {}).value || '').toString();\n                }\n                i++;\n            }\n\n            return curNode;\n        };\n\n        return walk(entry);\n    },\n\n    formatDate(value) {\n        if (typeof value === 'string') {\n            value = new Date(value);\n        }\n\n        if (Object.prototype.toString(value) !== '[object Object]' || value.toString() === 'Invalid Date') {\n            return;\n        }\n\n        value = value.toISOString().substr(0, 10);\n        value = value.split('-');\n        value.reverse();\n\n        let months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];\n        value[1] = months[Number(value[1]) - 1];\n\n        return value.join('-');\n    },\n\n    formatDateTime(value) {\n        if (!value) {\n            return;\n        }\n\n        if (typeof value === 'string') {\n            value = new Date(value);\n        }\n\n        if (Object.prototype.toString(value) !== '[object Object]' || value.toString() === 'Invalid Date') {\n            return;\n        }\n\n        let dateStr = tools.formatDate(value).replace(/^0/, ' '); //starts with date-day-fixed with leading 0 replaced by SP\n        let timeStr = value.toISOString().substr(11, 8);\n\n        return `${dateStr} ${timeStr} +0000`;\n    },\n\n    formatFlag(flag) {\n        switch (flag.toLowerCase()) {\n            case '\\\\recent':\n                // can not set or remove\n                return false;\n            case '\\\\seen':\n            case '\\\\answered':\n            case '\\\\flagged':\n            case '\\\\deleted':\n            case '\\\\draft':\n                // can not set or remove\n                return flag.toLowerCase().replace(/^\\\\./, c => c.toUpperCase());\n        }\n        return flag;\n    },\n\n    canUseFlag(mailbox, flag) {\n        return !mailbox || !mailbox.permanentFlags || mailbox.permanentFlags.has('\\\\*') || mailbox.permanentFlags.has(flag);\n    },\n\n    expandRange(range) {\n        return range.split(',').flatMap(entry => {\n            entry = entry.trim();\n            let colon = entry.indexOf(':');\n            if (colon < 0) {\n                return Number(entry) || 0;\n            }\n            let first = Number(entry.substr(0, colon)) || 0;\n            let second = Number(entry.substr(colon + 1)) || 0;\n            if (first === second) {\n                return first;\n            }\n            let list = [];\n            if (first < second) {\n                for (let i = first; i <= second; i++) {\n                    list.push(i);\n                }\n            } else {\n                for (let i = first; i >= second; i--) {\n                    list.push(i);\n                }\n            }\n            return list;\n        });\n    },\n\n    getDecoder(charset) {\n        charset = (charset || 'ascii').toString().trim().toLowerCase();\n        if (/^jis|^iso-?2022-?jp|^EUCJP/i.test(charset)) {\n            // special case not supported by iconv-lite\n            return new JPDecoder(charset);\n        }\n\n        return iconv.decodeStream(charset);\n    },\n\n    packMessageRange(list) {\n        if (typeof uidList === 'string')\n            if (!Array.isArray(list)) {\n                list = [].concat(list || []);\n            }\n\n        if (!list.length) {\n            return '';\n        }\n\n        list.sort((a, b) => a - b);\n\n        let last = list[list.length - 1];\n        let result = [[last]];\n        for (let i = list.length - 2; i >= 0; i--) {\n            if (list[i] === list[i + 1] - 1) {\n                result[0].unshift(list[i]);\n                continue;\n            }\n            result.unshift([list[i]]);\n        }\n\n        result = result.map(item => {\n            if (item.length === 1) {\n                return item[0];\n            }\n            return item.shift() + ':' + item.pop();\n        });\n\n        return result.join(',');\n    }\n};\n\nmodule.exports = tools;\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/lib/tools.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/node_modules/mailsplit/index.js":
|
|
/*!***************************************************************!*\
|
|
!*** ./node_modules/imapflow/node_modules/mailsplit/index.js ***!
|
|
\***************************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst MessageSplitter = __webpack_require__(/*! ./lib/message-splitter */ \"(action-browser)/./node_modules/imapflow/node_modules/mailsplit/lib/message-splitter.js\");\nconst MessageJoiner = __webpack_require__(/*! ./lib/message-joiner */ \"(action-browser)/./node_modules/imapflow/node_modules/mailsplit/lib/message-joiner.js\");\nconst NodeRewriter = __webpack_require__(/*! ./lib/node-rewriter */ \"(action-browser)/./node_modules/imapflow/node_modules/mailsplit/lib/node-rewriter.js\");\nconst NodeStreamer = __webpack_require__(/*! ./lib/node-streamer */ \"(action-browser)/./node_modules/imapflow/node_modules/mailsplit/lib/node-streamer.js\");\nconst Headers = __webpack_require__(/*! ./lib/headers */ \"(action-browser)/./node_modules/imapflow/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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9ub2RlX21vZHVsZXMvbWFpbHNwbGl0L2luZGV4LmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViLHdCQUF3QixtQkFBTyxDQUFDLHVIQUF3QjtBQUN4RCxzQkFBc0IsbUJBQU8sQ0FBQyxtSEFBc0I7QUFDcEQscUJBQXFCLG1CQUFPLENBQUMsaUhBQXFCO0FBQ2xELHFCQUFxQixtQkFBTyxDQUFDLGlIQUFxQjtBQUNsRCxnQkFBZ0IsbUJBQU8sQ0FBQyxxR0FBZTs7QUFFdkM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L25vZGVfbW9kdWxlcy9tYWlsc3BsaXQvaW5kZXguanMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCBNZXNzYWdlU3BsaXR0ZXIgPSByZXF1aXJlKCcuL2xpYi9tZXNzYWdlLXNwbGl0dGVyJyk7XG5jb25zdCBNZXNzYWdlSm9pbmVyID0gcmVxdWlyZSgnLi9saWIvbWVzc2FnZS1qb2luZXInKTtcbmNvbnN0IE5vZGVSZXdyaXRlciA9IHJlcXVpcmUoJy4vbGliL25vZGUtcmV3cml0ZXInKTtcbmNvbnN0IE5vZGVTdHJlYW1lciA9IHJlcXVpcmUoJy4vbGliL25vZGUtc3RyZWFtZXInKTtcbmNvbnN0IEhlYWRlcnMgPSByZXF1aXJlKCcuL2xpYi9oZWFkZXJzJyk7XG5cbm1vZHVsZS5leHBvcnRzID0ge1xuICAgIFNwbGl0dGVyOiBNZXNzYWdlU3BsaXR0ZXIsXG4gICAgSm9pbmVyOiBNZXNzYWdlSm9pbmVyLFxuICAgIFJld3JpdGVyOiBOb2RlUmV3cml0ZXIsXG4gICAgU3RyZWFtZXI6IE5vZGVTdHJlYW1lcixcbiAgICBIZWFkZXJzXG59O1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/node_modules/mailsplit/index.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/node_modules/mailsplit/lib/flowed-decoder.js":
|
|
/*!****************************************************************************!*\
|
|
!*** ./node_modules/imapflow/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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9ub2RlX21vZHVsZXMvbWFpbHNwbGl0L2xpYi9mbG93ZWQtZGVjb2Rlci5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYjs7QUFFQSxrQkFBa0IsdURBQTJCO0FBQzdDLGdCQUFnQixtQkFBTyxDQUFDLHVFQUFTOztBQUVqQztBQUNBO0FBQ0E7QUFDQTtBQUNBLFdBQVcsUUFBUTtBQUNuQjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsNkNBQTZDLHFCQUFxQjtBQUNsRTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9ub2RlX21vZHVsZXMvbWFpbHNwbGl0L2xpYi9mbG93ZWQtZGVjb2Rlci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbi8vIEhlbHBlciBjbGFzcyB0byByZXdyaXRlIG5vZGVzIHdpdGggc3BlY2lmaWMgbWltZSB0eXBlXG5cbmNvbnN0IFRyYW5zZm9ybSA9IHJlcXVpcmUoJ3N0cmVhbScpLlRyYW5zZm9ybTtcbmNvbnN0IGxpYm1pbWUgPSByZXF1aXJlKCdsaWJtaW1lJyk7XG5cbi8qKlxuICogUmVhbGx5IGJhZCBcInN0cmVhbVwiIHRyYW5zZm9ybSB0byBwYXJzZSBmb3JtYXQ9Zmxvd2VkIGNvbnRlbnRcbiAqXG4gKiBAY29uc3RydWN0b3JcbiAqIEBwYXJhbSB7U3RyaW5nfSBkZWxTcCBUcnVlIGlmIGRlbHNwIG9wdGlvbiB3YXMgdXNlZFxuICovXG5jbGFzcyBGbG93ZWREZWNvZGVyIGV4dGVuZHMgVHJhbnNmb3JtIHtcbiAgICBjb25zdHJ1Y3Rvcihjb25maWcpIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICAgICAgdGhpcy5jb25maWcgPSBjb25maWcgfHwge307XG5cbiAgICAgICAgdGhpcy5jaHVua3MgPSBbXTtcbiAgICAgICAgdGhpcy5jaHVua2xlbiA9IDA7XG5cbiAgICAgICAgdGhpcy5saWJtaW1lID0gbmV3IGxpYm1pbWUuTGlibWltZSh7IEljb252OiBjb25maWcuSWNvbnYgfSk7XG4gICAgfVxuXG4gICAgX3RyYW5zZm9ybShjaHVuaywgZW5jb2RpbmcsIGNhbGxiYWNrKSB7XG4gICAgICAgIGlmICghY2h1bmsgfHwgIWNodW5rLmxlbmd0aCkge1xuICAgICAgICAgICAgcmV0dXJuIGNhbGxiYWNrKCk7XG4gICAgICAgIH1cblxuICAgICAgICBpZiAoIWVuY29kaW5nICE9PSAnYnVmZmVyJykge1xuICAgICAgICAgICAgY2h1bmsgPSBCdWZmZXIuZnJvbShjaHVuaywgZW5jb2RpbmcpO1xuICAgICAgICB9XG5cbiAgICAgICAgdGhpcy5jaHVua3MucHVzaChjaHVuayk7XG4gICAgICAgIHRoaXMuY2h1bmtsZW4gKz0gY2h1bmsubGVuZ3RoO1xuXG4gICAgICAgIGNhbGxiYWNrKCk7XG4gICAgfVxuXG4gICAgX2ZsdXNoKGNhbGxiYWNrKSB7XG4gICAgICAgIGlmICh0aGlzLmNodW5rbGVuKSB7XG4gICAgICAgICAgICBsZXQgY3VycmVudEJvZHkgPSBCdWZmZXIuY29uY2F0KHRoaXMuY2h1bmtzLCB0aGlzLmNodW5rbGVuKTtcblxuICAgICAgICAgICAgaWYgKHRoaXMuY29uZmlnLmVuY29kaW5nID09PSAnYmFzZTY0Jykge1xuICAgICAgICAgICAgICAgIGN1cnJlbnRCb2R5ID0gQnVmZmVyLmZyb20oY3VycmVudEJvZHkudG9TdHJpbmcoJ2JpbmFyeScpLCAnYmFzZTY0Jyk7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIGxldCBjb250ZW50ID0gdGhpcy5saWJtaW1lLmRlY29kZUZsb3dlZChjdXJyZW50Qm9keS50b1N0cmluZygnYmluYXJ5JyksIHRoaXMuY29uZmlnLmRlbFNwKTtcbiAgICAgICAgICAgIHRoaXMucHVzaChCdWZmZXIuZnJvbShjb250ZW50LCAnYmluYXJ5JykpO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiBjYWxsYmFjaygpO1xuICAgIH1cbn1cblxubW9kdWxlLmV4cG9ydHMgPSBGbG93ZWREZWNvZGVyO1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/node_modules/mailsplit/lib/flowed-decoder.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/node_modules/mailsplit/lib/headers.js":
|
|
/*!*********************************************************************!*\
|
|
!*** ./node_modules/imapflow/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/imapflow/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/imapflow/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/imapflow/node_modules/mailsplit/lib/headers.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/node_modules/mailsplit/lib/message-joiner.js":
|
|
/*!****************************************************************************!*\
|
|
!*** ./node_modules/imapflow/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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9ub2RlX21vZHVsZXMvbWFpbHNwbGl0L2xpYi9tZXNzYWdlLWpvaW5lci5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYixrQkFBa0IsdURBQTJCOztBQUU3QztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLFVBQVU7QUFDVjtBQUNBLFVBQVU7QUFDVjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbm9kZV9tb2R1bGVzL21haWxzcGxpdC9saWIvbWVzc2FnZS1qb2luZXIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCBUcmFuc2Zvcm0gPSByZXF1aXJlKCdzdHJlYW0nKS5UcmFuc2Zvcm07XG5cbmNsYXNzIE1lc3NhZ2VKb2luZXIgZXh0ZW5kcyBUcmFuc2Zvcm0ge1xuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBsZXQgb3B0aW9ucyA9IHtcbiAgICAgICAgICAgIHJlYWRhYmxlT2JqZWN0TW9kZTogZmFsc2UsXG4gICAgICAgICAgICB3cml0YWJsZU9iamVjdE1vZGU6IHRydWVcbiAgICAgICAgfTtcbiAgICAgICAgc3VwZXIob3B0aW9ucyk7XG4gICAgfVxuXG4gICAgX3RyYW5zZm9ybShvYmosIGVuY29kaW5nLCBjYWxsYmFjaykge1xuICAgICAgICBpZiAoQnVmZmVyLmlzQnVmZmVyKG9iaikpIHtcbiAgICAgICAgICAgIHRoaXMucHVzaChvYmopO1xuICAgICAgICB9IGVsc2UgaWYgKG9iai50eXBlID09PSAnbm9kZScpIHtcbiAgICAgICAgICAgIHRoaXMucHVzaChvYmouZ2V0SGVhZGVycygpKTtcbiAgICAgICAgfSBlbHNlIGlmIChvYmoudmFsdWUpIHtcbiAgICAgICAgICAgIHRoaXMucHVzaChvYmoudmFsdWUpO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiBjYWxsYmFjaygpO1xuICAgIH1cblxuICAgIF9mbHVzaChjYWxsYmFjaykge1xuICAgICAgICByZXR1cm4gY2FsbGJhY2soKTtcbiAgICB9XG59XG5cbm1vZHVsZS5leHBvcnRzID0gTWVzc2FnZUpvaW5lcjtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/node_modules/mailsplit/lib/message-joiner.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/node_modules/mailsplit/lib/message-splitter.js":
|
|
/*!******************************************************************************!*\
|
|
!*** ./node_modules/imapflow/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/imapflow/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/imapflow/node_modules/mailsplit/lib/message-splitter.js","mappings":"AAAa;;AAEb,kBAAkB,uDAA2B;AAC7C,iBAAiB,mBAAO,CAAC,qGAAa;;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/imapflow/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/imapflow/node_modules/mailsplit/lib/message-splitter.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/node_modules/mailsplit/lib/mime-node.js":
|
|
/*!***********************************************************************!*\
|
|
!*** ./node_modules/imapflow/node_modules/mailsplit/lib/mime-node.js ***!
|
|
\***********************************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst Headers = __webpack_require__(/*! ./headers */ \"(action-browser)/./node_modules/imapflow/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/imapflow/node_modules/mailsplit/lib/mime-node.js","mappings":"AAAa;;AAEb,gBAAgB,mBAAO,CAAC,iGAAW;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/imapflow/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/imapflow/node_modules/mailsplit/lib/mime-node.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/node_modules/mailsplit/lib/node-rewriter.js":
|
|
/*!***************************************************************************!*\
|
|
!*** ./node_modules/imapflow/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/imapflow/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/imapflow/node_modules/mailsplit/lib/node-rewriter.js","mappings":"AAAa;;AAEb;;AAEA,kBAAkB,uDAA2B;AAC7C,sBAAsB,mBAAO,CAAC,+GAAkB;;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/imapflow/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/imapflow/node_modules/mailsplit/lib/node-rewriter.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/node_modules/mailsplit/lib/node-streamer.js":
|
|
/*!***************************************************************************!*\
|
|
!*** ./node_modules/imapflow/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/imapflow/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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9ub2RlX21vZHVsZXMvbWFpbHNwbGl0L2xpYi9ub2RlLXN0cmVhbWVyLmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViOztBQUVBLGtCQUFrQix1REFBMkI7QUFDN0Msc0JBQXNCLG1CQUFPLENBQUMsK0dBQWtCOztBQUVoRDtBQUNBO0FBQ0E7QUFDQTtBQUNBLFdBQVcsUUFBUTtBQUNuQixXQUFXLFVBQVU7QUFDckI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxpQkFBaUI7QUFDakI7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxjQUFjO0FBQ2Q7QUFDQTtBQUNBLFVBQVU7QUFDVjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLGNBQWM7QUFDZDtBQUNBOztBQUVBO0FBQ0EsVUFBVTtBQUNWO0FBQ0E7QUFDQTtBQUNBLFVBQVU7QUFDVjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxrQkFBa0I7QUFDbEI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L25vZGVfbW9kdWxlcy9tYWlsc3BsaXQvbGliL25vZGUtc3RyZWFtZXIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG4vLyBIZWxwZXIgY2xhc3MgdG8gcmV3cml0ZSBub2RlcyB3aXRoIHNwZWNpZmljIG1pbWUgdHlwZVxuXG5jb25zdCBUcmFuc2Zvcm0gPSByZXF1aXJlKCdzdHJlYW0nKS5UcmFuc2Zvcm07XG5jb25zdCBGbG93ZWREZWNvZGVyID0gcmVxdWlyZSgnLi9mbG93ZWQtZGVjb2RlcicpO1xuXG4vKipcbiAqIE5vZGVSZXdyaXRlciBUcmFuc2Zvcm0gc3RyZWFtLiBVcGRhdGVzIGNvbnRlbnQgZm9yIGFsbCBub2RlcyB3aXRoIHNwZWNpZmllZCBtaW1lIHR5cGVcbiAqXG4gKiBAY29uc3RydWN0b3JcbiAqIEBwYXJhbSB7U3RyaW5nfSBtaW1lVHlwZSBEZWZpbmUgdGhlIE1pbWUtVHlwZSB0byBsb29rIGZvclxuICogQHBhcmFtIHtGdW5jdGlvbn0gc3RyZWFtQWN0aW9uIEZ1bmN0aW9uIHRvIHJ1biB3aXRoIHRoZSBub2RlIGNvbnRlbnRcbiAqL1xuY2xhc3MgTm9kZVN0cmVhbWVyIGV4dGVuZHMgVHJhbnNmb3JtIHtcbiAgICBjb25zdHJ1Y3RvcihmaWx0ZXJGdW5jLCBzdHJlYW1BY3Rpb24pIHtcbiAgICAgICAgbGV0IG9wdGlvbnMgPSB7XG4gICAgICAgICAgICByZWFkYWJsZU9iamVjdE1vZGU6IHRydWUsXG4gICAgICAgICAgICB3cml0YWJsZU9iamVjdE1vZGU6IHRydWVcbiAgICAgICAgfTtcbiAgICAgICAgc3VwZXIob3B0aW9ucyk7XG5cbiAgICAgICAgdGhpcy5maWx0ZXJGdW5jID0gZmlsdGVyRnVuYztcbiAgICAgICAgdGhpcy5zdHJlYW1BY3Rpb24gPSBzdHJlYW1BY3Rpb247XG5cbiAgICAgICAgdGhpcy5kZWNvZGVyID0gZmFsc2U7XG4gICAgICAgIHRoaXMuY2FuQ29udGludWUgPSBmYWxzZTtcbiAgICAgICAgdGhpcy5jb250aW51ZSA9IGZhbHNlO1xuICAgIH1cblxuICAgIF90cmFuc2Zvcm0oZGF0YSwgZW5jb2RpbmcsIGNhbGxiYWNrKSB7XG4gICAgICAgIHRoaXMucHJvY2Vzc0luY29taW5nKGRhdGEsIGNhbGxiYWNrKTtcbiAgICB9XG5cbiAgICBfZmx1c2goY2FsbGJhY2spIHtcbiAgICAgICAgaWYgKHRoaXMuZGVjb2Rlcikge1xuICAgICAgICAgICAgLy8gZW1pdCBhbiBlbXB0eSBub2RlIGp1c3QgaW4gY2FzZSB0aGVyZSBpcyBwZW5kaW5nIGRhdGEgdG8gZW5kXG4gICAgICAgICAgICByZXR1cm4gdGhpcy5wcm9jZXNzSW5jb21pbmcoXG4gICAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgICAgICB0eXBlOiAnbm9uZSdcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIGNhbGxiYWNrXG4gICAgICAgICAgICApO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiBjYWxsYmFjaygpO1xuICAgIH1cblxuICAgIHByb2Nlc3NJbmNvbWluZyhkYXRhLCBjYWxsYmFjaykge1xuICAgICAgICBpZiAodGhpcy5kZWNvZGVyICYmIGRhdGEudHlwZSA9PT0gJ2JvZHknKSB7XG4gICAgICAgICAgICAvLyBkYXRhIHRvIHBhcnNlXG4gICAgICAgICAgICB0aGlzLnB1c2goZGF0YSk7XG4gICAgICAgICAgICBpZiAoIXRoaXMuZGVjb2Rlci53cml0ZShkYXRhLnZhbHVlKSkge1xuICAgICAgICAgICAgICAgIHJldHVybiB0aGlzLmRlY29kZXIub25jZSgnZHJhaW4nLCBjYWxsYmFjayk7XG4gICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIHJldHVybiBjYWxsYmFjaygpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9IGVsc2UgaWYgKHRoaXMuZGVjb2RlciAmJiBkYXRhLnR5cGUgIT09ICdib2R5Jykge1xuICAgICAgICAgICAgLy8gc3RvcCBkZWNvZGluZy5cbiAgICAgICAgICAgIC8vIHdlIGNhbiBub3QgcHJvY2VzcyB0aGUgY3VycmVudCBkYXRhIGNodW5rIGFzIHdlIG5lZWQgdG8gd2FpdCB1bnRpbFxuICAgICAgICAgICAgLy8gdGhlIHBhcnNlZCBkYXRhIGlzIGNvbXBsZXRlbHkgcHJvY2Vzc2VkLCBzbyB3ZSBzdG9yZSBhIHJlZmVyZW5jZSB0byB0aGVcbiAgICAgICAgICAgIC8vIGNvbnRpbnVlIGNhbGxiYWNrXG5cbiAgICAgICAgICAgIGxldCBkb0NvbnRpbnVlID0gKCkgPT4ge1xuICAgICAgICAgICAgICAgIHRoaXMuY29udGludWUgPSBmYWxzZTtcbiAgICAgICAgICAgICAgICB0aGlzLmRlY29kZXIgPSBmYWxzZTtcbiAgICAgICAgICAgICAgICB0aGlzLmNhbkNvbnRpbnVlID0gZmFsc2U7XG4gICAgICAgICAgICAgICAgdGhpcy5wcm9jZXNzSW5jb21pbmcoZGF0YSwgY2FsbGJhY2spO1xuICAgICAgICAgICAgfTtcblxuICAgICAgICAgICAgaWYgKHRoaXMuY2FuQ29udGludWUpIHtcbiAgICAgICAgICAgICAgICBzZXRJbW1lZGlhdGUoZG9Db250aW51ZSk7XG4gICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIHRoaXMuY29udGludWUgPSAoKSA9PiBkb0NvbnRpbnVlKCk7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIHJldHVybiB0aGlzLmRlY29kZXIuZW5kKCk7XG4gICAgICAgIH0gZWxzZSBpZiAoZGF0YS50eXBlID09PSAnbm9kZScgJiYgdGhpcy5maWx0ZXJGdW5jKGRhdGEpKSB7XG4gICAgICAgICAgICB0aGlzLnB1c2goZGF0YSk7XG4gICAgICAgICAgICAvLyBmb3VuZCBtYXRjaGluZyBub2RlLCBjcmVhdGUgbmV3IGhhbmRsZXJcbiAgICAgICAgICAgIHRoaXMuZW1pdCgnbm9kZScsIHRoaXMuY3JlYXRlRGVjb2RlcihkYXRhKSk7XG4gICAgICAgIH0gZWxzZSBpZiAodGhpcy5yZWFkYWJsZSAmJiBkYXRhLnR5cGUgIT09ICdub25lJykge1xuICAgICAgICAgICAgLy8gd2UgZG9uJ3QgY2FyZSBhYm91dCB0aGlzIGRhdGEsIGp1c3QgcGFzcyBpdCBvdmVyIHRvIHRoZSBqb2luZXJcbiAgICAgICAgICAgIHRoaXMucHVzaChkYXRhKTtcbiAgICAgICAgfVxuICAgICAgICBjYWxsYmFjaygpO1xuICAgIH1cblxuICAgIGNyZWF0ZURlY29kZXIobm9kZSkge1xuICAgICAgICB0aGlzLmRlY29kZXIgPSBub2RlLmdldERlY29kZXIoKTtcblxuICAgICAgICBsZXQgZGVjb2RlciA9IHRoaXMuZGVjb2RlcjtcbiAgICAgICAgZGVjb2Rlci4kcmVhZGluZyA9IGZhbHNlO1xuXG4gICAgICAgIGlmICgvXnRleHRcXC8vLnRlc3Qobm9kZS5jb250ZW50VHlwZSkgJiYgbm9kZS5mbG93ZWQpIHtcbiAgICAgICAgICAgIGxldCBmbG93RGVjb2RlciA9IGRlY29kZXI7XG4gICAgICAgICAgICBkZWNvZGVyID0gbmV3IEZsb3dlZERlY29kZXIoe1xuICAgICAgICAgICAgICAgIGRlbFNwOiBub2RlLmRlbFNwXG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIGZsb3dEZWNvZGVyLm9uKCdlcnJvcicsIGVyciA9PiB7XG4gICAgICAgICAgICAgICAgZGVjb2Rlci5lbWl0KCdlcnJvcicsIGVycik7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIGZsb3dEZWNvZGVyLnBpcGUoZGVjb2Rlcik7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgbm9kZSxcbiAgICAgICAgICAgIGRlY29kZXIsXG4gICAgICAgICAgICBkb25lOiAoKSA9PiB7XG4gICAgICAgICAgICAgICAgaWYgKHR5cGVvZiB0aGlzLmNvbnRpbnVlID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgICAgICAgICAgICAgIC8vIGNhbGxlZCBvbmNlIGlucHV0IHN0cmVhbSBpcyBwcm9jZXNzZWRcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5jb250aW51ZSgpO1xuICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgIC8vIGNhbGxlZCBiZWZvcmUgaW5wdXQgc3RyZWFtIGlzIHByb2Nlc3NlZFxuICAgICAgICAgICAgICAgICAgICB0aGlzLmNhbkNvbnRpbnVlID0gdHJ1ZTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgIH07XG4gICAgfVxufVxuXG5tb2R1bGUuZXhwb3J0cyA9IE5vZGVTdHJlYW1lcjtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/node_modules/mailsplit/lib/node-streamer.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/node_modules/nodemailer/lib/smtp-connection/http-proxy-client.js":
|
|
/*!************************************************************************************************!*\
|
|
!*** ./node_modules/imapflow/node_modules/nodemailer/lib/smtp-connection/http-proxy-client.js ***!
|
|
\************************************************************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\n/**\n * Minimal HTTP/S proxy client\n */\n\nconst net = __webpack_require__(/*! net */ \"net\");\nconst tls = __webpack_require__(/*! tls */ \"tls\");\nconst urllib = __webpack_require__(/*! url */ \"url\");\n\n/**\n * Establishes proxied connection to destinationPort\n *\n * httpProxyClient(\"http://localhost:3128/\", 80, \"google.com\", function(err, socket){\n * socket.write(\"GET / HTTP/1.0\\r\\n\\r\\n\");\n * });\n *\n * @param {String} proxyUrl proxy configuration, etg \"http://proxy.host:3128/\"\n * @param {Number} destinationPort Port to open in destination host\n * @param {String} destinationHost Destination hostname\n * @param {Function} callback Callback to run with the rocket object once connection is established\n */\nfunction httpProxyClient(proxyUrl, destinationPort, destinationHost, callback) {\n let proxy = urllib.parse(proxyUrl);\n\n // create a socket connection to the proxy server\n let options;\n let connect;\n let socket;\n\n options = {\n host: proxy.hostname,\n port: Number(proxy.port) ? Number(proxy.port) : proxy.protocol === 'https:' ? 443 : 80\n };\n\n if (proxy.protocol === 'https:') {\n // we can use untrusted proxies as long as we verify actual SMTP certificates\n options.rejectUnauthorized = false;\n connect = tls.connect.bind(tls);\n } else {\n connect = net.connect.bind(net);\n }\n\n // Error harness for initial connection. Once connection is established, the responsibility\n // to handle errors is passed to whoever uses this socket\n let finished = false;\n let tempSocketErr = err => {\n if (finished) {\n return;\n }\n finished = true;\n try {\n socket.destroy();\n } catch (E) {\n // ignore\n }\n callback(err);\n };\n\n let timeoutErr = () => {\n let err = new Error('Proxy socket timed out');\n err.code = 'ETIMEDOUT';\n tempSocketErr(err);\n };\n\n socket = connect(options, () => {\n if (finished) {\n return;\n }\n\n let reqHeaders = {\n Host: destinationHost + ':' + destinationPort,\n Connection: 'close'\n };\n if (proxy.auth) {\n reqHeaders['Proxy-Authorization'] = 'Basic ' + Buffer.from(proxy.auth).toString('base64');\n }\n\n socket.write(\n // HTTP method\n 'CONNECT ' +\n destinationHost +\n ':' +\n destinationPort +\n ' HTTP/1.1\\r\\n' +\n // HTTP request headers\n Object.keys(reqHeaders)\n .map(key => key + ': ' + reqHeaders[key])\n .join('\\r\\n') +\n // End request\n '\\r\\n\\r\\n'\n );\n\n let headers = '';\n let onSocketData = chunk => {\n let match;\n let remainder;\n\n if (finished) {\n return;\n }\n\n headers += chunk.toString('binary');\n if ((match = headers.match(/\\r\\n\\r\\n/))) {\n socket.removeListener('data', onSocketData);\n\n remainder = headers.substr(match.index + match[0].length);\n headers = headers.substr(0, match.index);\n if (remainder) {\n socket.unshift(Buffer.from(remainder, 'binary'));\n }\n\n // proxy connection is now established\n finished = true;\n\n // check response code\n match = headers.match(/^HTTP\\/\\d+\\.\\d+ (\\d+)/i);\n if (!match || (match[1] || '').charAt(0) !== '2') {\n try {\n socket.destroy();\n } catch (E) {\n // ignore\n }\n return callback(new Error('Invalid response from proxy' + ((match && ': ' + match[1]) || '')));\n }\n\n socket.removeListener('error', tempSocketErr);\n socket.removeListener('timeout', timeoutErr);\n socket.setTimeout(0);\n\n return callback(null, socket);\n }\n };\n socket.on('data', onSocketData);\n });\n\n socket.setTimeout(httpProxyClient.timeout || 30 * 1000);\n socket.on('timeout', timeoutErr);\n\n socket.once('error', tempSocketErr);\n}\n\nmodule.exports = httpProxyClient;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGFjdGlvbi1icm93c2VyKS8uL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9ub2RlX21vZHVsZXMvbm9kZW1haWxlci9saWIvc210cC1jb25uZWN0aW9uL2h0dHAtcHJveHktY2xpZW50LmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViO0FBQ0E7QUFDQTs7QUFFQSxZQUFZLG1CQUFPLENBQUMsZ0JBQUs7QUFDekIsWUFBWSxtQkFBTyxDQUFDLGdCQUFLO0FBQ3pCLGVBQWUsbUJBQU8sQ0FBQyxnQkFBSzs7QUFFNUI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBLFdBQVcsUUFBUTtBQUNuQixXQUFXLFFBQVE7QUFDbkIsV0FBVyxRQUFRO0FBQ25CLFdBQVcsVUFBVTtBQUNyQjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVU7QUFDVjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHNCQUFzQjtBQUN0QjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLOztBQUVMO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbm9kZV9tb2R1bGVzL25vZGVtYWlsZXIvbGliL3NtdHAtY29ubmVjdGlvbi9odHRwLXByb3h5LWNsaWVudC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbi8qKlxuICogTWluaW1hbCBIVFRQL1MgcHJveHkgY2xpZW50XG4gKi9cblxuY29uc3QgbmV0ID0gcmVxdWlyZSgnbmV0Jyk7XG5jb25zdCB0bHMgPSByZXF1aXJlKCd0bHMnKTtcbmNvbnN0IHVybGxpYiA9IHJlcXVpcmUoJ3VybCcpO1xuXG4vKipcbiAqIEVzdGFibGlzaGVzIHByb3hpZWQgY29ubmVjdGlvbiB0byBkZXN0aW5hdGlvblBvcnRcbiAqXG4gKiBodHRwUHJveHlDbGllbnQoXCJodHRwOi8vbG9jYWxob3N0OjMxMjgvXCIsIDgwLCBcImdvb2dsZS5jb21cIiwgZnVuY3Rpb24oZXJyLCBzb2NrZXQpe1xuICogICAgIHNvY2tldC53cml0ZShcIkdFVCAvIEhUVFAvMS4wXFxyXFxuXFxyXFxuXCIpO1xuICogfSk7XG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IHByb3h5VXJsIHByb3h5IGNvbmZpZ3VyYXRpb24sIGV0ZyBcImh0dHA6Ly9wcm94eS5ob3N0OjMxMjgvXCJcbiAqIEBwYXJhbSB7TnVtYmVyfSBkZXN0aW5hdGlvblBvcnQgUG9ydCB0byBvcGVuIGluIGRlc3RpbmF0aW9uIGhvc3RcbiAqIEBwYXJhbSB7U3RyaW5nfSBkZXN0aW5hdGlvbkhvc3QgRGVzdGluYXRpb24gaG9zdG5hbWVcbiAqIEBwYXJhbSB7RnVuY3Rpb259IGNhbGxiYWNrIENhbGxiYWNrIHRvIHJ1biB3aXRoIHRoZSByb2NrZXQgb2JqZWN0IG9uY2UgY29ubmVjdGlvbiBpcyBlc3RhYmxpc2hlZFxuICovXG5mdW5jdGlvbiBodHRwUHJveHlDbGllbnQocHJveHlVcmwsIGRlc3RpbmF0aW9uUG9ydCwgZGVzdGluYXRpb25Ib3N0LCBjYWxsYmFjaykge1xuICAgIGxldCBwcm94eSA9IHVybGxpYi5wYXJzZShwcm94eVVybCk7XG5cbiAgICAvLyBjcmVhdGUgYSBzb2NrZXQgY29ubmVjdGlvbiB0byB0aGUgcHJveHkgc2VydmVyXG4gICAgbGV0IG9wdGlvbnM7XG4gICAgbGV0IGNvbm5lY3Q7XG4gICAgbGV0IHNvY2tldDtcblxuICAgIG9wdGlvbnMgPSB7XG4gICAgICAgIGhvc3Q6IHByb3h5Lmhvc3RuYW1lLFxuICAgICAgICBwb3J0OiBOdW1iZXIocHJveHkucG9ydCkgPyBOdW1iZXIocHJveHkucG9ydCkgOiBwcm94eS5wcm90b2NvbCA9PT0gJ2h0dHBzOicgPyA0NDMgOiA4MFxuICAgIH07XG5cbiAgICBpZiAocHJveHkucHJvdG9jb2wgPT09ICdodHRwczonKSB7XG4gICAgICAgIC8vIHdlIGNhbiB1c2UgdW50cnVzdGVkIHByb3hpZXMgYXMgbG9uZyBhcyB3ZSB2ZXJpZnkgYWN0dWFsIFNNVFAgY2VydGlmaWNhdGVzXG4gICAgICAgIG9wdGlvbnMucmVqZWN0VW5hdXRob3JpemVkID0gZmFsc2U7XG4gICAgICAgIGNvbm5lY3QgPSB0bHMuY29ubmVjdC5iaW5kKHRscyk7XG4gICAgfSBlbHNlIHtcbiAgICAgICAgY29ubmVjdCA9IG5ldC5jb25uZWN0LmJpbmQobmV0KTtcbiAgICB9XG5cbiAgICAvLyBFcnJvciBoYXJuZXNzIGZvciBpbml0aWFsIGNvbm5lY3Rpb24uIE9uY2UgY29ubmVjdGlvbiBpcyBlc3RhYmxpc2hlZCwgdGhlIHJlc3BvbnNpYmlsaXR5XG4gICAgLy8gdG8gaGFuZGxlIGVycm9ycyBpcyBwYXNzZWQgdG8gd2hvZXZlciB1c2VzIHRoaXMgc29ja2V0XG4gICAgbGV0IGZpbmlzaGVkID0gZmFsc2U7XG4gICAgbGV0IHRlbXBTb2NrZXRFcnIgPSBlcnIgPT4ge1xuICAgICAgICBpZiAoZmluaXNoZWQpIHtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuICAgICAgICBmaW5pc2hlZCA9IHRydWU7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgICBzb2NrZXQuZGVzdHJveSgpO1xuICAgICAgICB9IGNhdGNoIChFKSB7XG4gICAgICAgICAgICAvLyBpZ25vcmVcbiAgICAgICAgfVxuICAgICAgICBjYWxsYmFjayhlcnIpO1xuICAgIH07XG5cbiAgICBsZXQgdGltZW91dEVyciA9ICgpID0+IHtcbiAgICAgICAgbGV0IGVyciA9IG5ldyBFcnJvcignUHJveHkgc29ja2V0IHRpbWVkIG91dCcpO1xuICAgICAgICBlcnIuY29kZSA9ICdFVElNRURPVVQnO1xuICAgICAgICB0ZW1wU29ja2V0RXJyKGVycik7XG4gICAgfTtcblxuICAgIHNvY2tldCA9IGNvbm5lY3Qob3B0aW9ucywgKCkgPT4ge1xuICAgICAgICBpZiAoZmluaXNoZWQpIHtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGxldCByZXFIZWFkZXJzID0ge1xuICAgICAgICAgICAgSG9zdDogZGVzdGluYXRpb25Ib3N0ICsgJzonICsgZGVzdGluYXRpb25Qb3J0LFxuICAgICAgICAgICAgQ29ubmVjdGlvbjogJ2Nsb3NlJ1xuICAgICAgICB9O1xuICAgICAgICBpZiAocHJveHkuYXV0aCkge1xuICAgICAgICAgICAgcmVxSGVhZGVyc1snUHJveHktQXV0aG9yaXphdGlvbiddID0gJ0Jhc2ljICcgKyBCdWZmZXIuZnJvbShwcm94eS5hdXRoKS50b1N0cmluZygnYmFzZTY0Jyk7XG4gICAgICAgIH1cblxuICAgICAgICBzb2NrZXQud3JpdGUoXG4gICAgICAgICAgICAvLyBIVFRQIG1ldGhvZFxuICAgICAgICAgICAgJ0NPTk5FQ1QgJyArXG4gICAgICAgICAgICAgICAgZGVzdGluYXRpb25Ib3N0ICtcbiAgICAgICAgICAgICAgICAnOicgK1xuICAgICAgICAgICAgICAgIGRlc3RpbmF0aW9uUG9ydCArXG4gICAgICAgICAgICAgICAgJyBIVFRQLzEuMVxcclxcbicgK1xuICAgICAgICAgICAgICAgIC8vIEhUVFAgcmVxdWVzdCBoZWFkZXJzXG4gICAgICAgICAgICAgICAgT2JqZWN0LmtleXMocmVxSGVhZGVycylcbiAgICAgICAgICAgICAgICAgICAgLm1hcChrZXkgPT4ga2V5ICsgJzogJyArIHJlcUhlYWRlcnNba2V5XSlcbiAgICAgICAgICAgICAgICAgICAgLmpvaW4oJ1xcclxcbicpICtcbiAgICAgICAgICAgICAgICAvLyBFbmQgcmVxdWVzdFxuICAgICAgICAgICAgICAgICdcXHJcXG5cXHJcXG4nXG4gICAgICAgICk7XG5cbiAgICAgICAgbGV0IGhlYWRlcnMgPSAnJztcbiAgICAgICAgbGV0IG9uU29ja2V0RGF0YSA9IGNodW5rID0+IHtcbiAgICAgICAgICAgIGxldCBtYXRjaDtcbiAgICAgICAgICAgIGxldCByZW1haW5kZXI7XG5cbiAgICAgICAgICAgIGlmIChmaW5pc2hlZCkge1xuICAgICAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgaGVhZGVycyArPSBjaHVuay50b1N0cmluZygnYmluYXJ5Jyk7XG4gICAgICAgICAgICBpZiAoKG1hdGNoID0gaGVhZGVycy5tYXRjaCgvXFxyXFxuXFxyXFxuLykpKSB7XG4gICAgICAgICAgICAgICAgc29ja2V0LnJlbW92ZUxpc3RlbmVyKCdkYXRhJywgb25Tb2NrZXREYXRhKTtcblxuICAgICAgICAgICAgICAgIHJlbWFpbmRlciA9IGhlYWRlcnMuc3Vic3RyKG1hdGNoLmluZGV4ICsgbWF0Y2hbMF0ubGVuZ3RoKTtcbiAgICAgICAgICAgICAgICBoZWFkZXJzID0gaGVhZGVycy5zdWJzdHIoMCwgbWF0Y2guaW5kZXgpO1xuICAgICAgICAgICAgICAgIGlmIChyZW1haW5kZXIpIHtcbiAgICAgICAgICAgICAgICAgICAgc29ja2V0LnVuc2hpZnQoQnVmZmVyLmZyb20ocmVtYWluZGVyLCAnYmluYXJ5JykpO1xuICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgIC8vIHByb3h5IGNvbm5lY3Rpb24gaXMgbm93IGVzdGFibGlzaGVkXG4gICAgICAgICAgICAgICAgZmluaXNoZWQgPSB0cnVlO1xuXG4gICAgICAgICAgICAgICAgLy8gY2hlY2sgcmVzcG9uc2UgY29kZVxuICAgICAgICAgICAgICAgIG1hdGNoID0gaGVhZGVycy5tYXRjaCgvXkhUVFBcXC9cXGQrXFwuXFxkKyAoXFxkKykvaSk7XG4gICAgICAgICAgICAgICAgaWYgKCFtYXRjaCB8fCAobWF0Y2hbMV0gfHwgJycpLmNoYXJBdCgwKSAhPT0gJzInKSB7XG4gICAgICAgICAgICAgICAgICAgIHRyeSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBzb2NrZXQuZGVzdHJveSgpO1xuICAgICAgICAgICAgICAgICAgICB9IGNhdGNoIChFKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAvLyBpZ25vcmVcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gY2FsbGJhY2sobmV3IEVycm9yKCdJbnZhbGlkIHJlc3BvbnNlIGZyb20gcHJveHknICsgKChtYXRjaCAmJiAnOiAnICsgbWF0Y2hbMV0pIHx8ICcnKSkpO1xuICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgIHNvY2tldC5yZW1vdmVMaXN0ZW5lcignZXJyb3InLCB0ZW1wU29ja2V0RXJyKTtcbiAgICAgICAgICAgICAgICBzb2NrZXQucmVtb3ZlTGlzdGVuZXIoJ3RpbWVvdXQnLCB0aW1lb3V0RXJyKTtcbiAgICAgICAgICAgICAgICBzb2NrZXQuc2V0VGltZW91dCgwKTtcblxuICAgICAgICAgICAgICAgIHJldHVybiBjYWxsYmFjayhudWxsLCBzb2NrZXQpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9O1xuICAgICAgICBzb2NrZXQub24oJ2RhdGEnLCBvblNvY2tldERhdGEpO1xuICAgIH0pO1xuXG4gICAgc29ja2V0LnNldFRpbWVvdXQoaHR0cFByb3h5Q2xpZW50LnRpbWVvdXQgfHwgMzAgKiAxMDAwKTtcbiAgICBzb2NrZXQub24oJ3RpbWVvdXQnLCB0aW1lb3V0RXJyKTtcblxuICAgIHNvY2tldC5vbmNlKCdlcnJvcicsIHRlbXBTb2NrZXRFcnIpO1xufVxuXG5tb2R1bGUuZXhwb3J0cyA9IGh0dHBQcm94eUNsaWVudDtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(action-browser)/./node_modules/imapflow/node_modules/nodemailer/lib/smtp-connection/http-proxy-client.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(action-browser)/./node_modules/imapflow/package.json":
|
|
/*!********************************************!*\
|
|
!*** ./node_modules/imapflow/package.json ***!
|
|
\********************************************/
|
|
/***/ ((module) => {
|
|
|
|
module.exports = /*#__PURE__*/JSON.parse('{"name":"imapflow","version":"1.0.184","description":"IMAP Client for Node","main":"./lib/imap-flow.js","scripts":{"test":"grunt","prepare":"npm run build","docs":"rm -rf docs && mkdir -p docs && jsdoc lib/imap-flow.js -c jsdoc.json -R README.md --destination docs/ && cp assets/favicon.ico docs","dst":"node types.js","build":"npm run docs && npm run dst","st":"npm run docs && st -d docs -i index.html","update":"rm -rf node_modules package-lock.json && ncu -u && npm install"},"repository":{"type":"git","url":"git+https://github.com/postalsys/imapflow.git"},"keywords":["imap","email","mail"],"author":"Postal Systems OÜ","license":"MIT","bugs":{"url":"https://github.com/postalsys/imapflow/issues"},"homepage":"https://imapflow.com/","devDependencies":{"@babel/eslint-parser":"7.26.8","@babel/eslint-plugin":"7.25.9","@babel/plugin-syntax-class-properties":"7.12.13","@babel/preset-env":"7.26.9","@types/node":"22.13.10","eslint":"8.57.0","eslint-config-nodemailer":"1.2.0","eslint-config-prettier":"9.1.0","grunt":"1.6.1","grunt-cli":"1.5.0","grunt-contrib-nodeunit":"5.0.0","grunt-eslint":"24.3.0","imapflow-jsdoc-template":"3.4.0-imapflow.2","jsdoc":"3.6.11","st":"3.0.1","tsd-jsdoc":"2.5.0"},"dependencies":{"encoding-japanese":"2.2.0","iconv-lite":"0.6.3","libbase64":"1.3.0","libmime":"5.3.6","libqp":"2.1.1","mailsplit":"5.4.3","nodemailer":"6.10.0","pino":"9.6.0","socks":"2.8.4"}}');
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/charsets.js":
|
|
/*!***********************************************!*\
|
|
!*** ./node_modules/imapflow/lib/charsets.js ***!
|
|
\***********************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\nconst CHARACTER_SETS = [\n 'US-ASCII',\n 'ISO-8859-1',\n 'ISO-8859-2',\n 'ISO-8859-3',\n 'ISO-8859-4',\n 'ISO-8859-5',\n 'ISO-8859-6',\n 'ISO-8859-7',\n 'ISO-8859-8',\n 'ISO-8859-9',\n 'ISO-8859-10',\n 'ISO_6937-2-add',\n 'JIS_X0201',\n 'JIS_Encoding',\n 'Shift_JIS',\n 'EUC-JP',\n 'Extended_UNIX_Code_Fixed_Width_for_Japanese',\n 'BS_4730',\n 'SEN_850200_C',\n 'IT',\n 'ES',\n 'DIN_66003',\n 'NS_4551-1',\n 'NF_Z_62-010',\n 'ISO-10646-UTF-1',\n 'ISO_646.basic:1983',\n 'INVARIANT',\n 'ISO_646.irv:1983',\n 'NATS-SEFI',\n 'NATS-SEFI-ADD',\n 'NATS-DANO',\n 'NATS-DANO-ADD',\n 'SEN_850200_B',\n 'KS_C_5601-1987',\n 'ISO-2022-KR',\n 'EUC-KR',\n 'ISO-2022-JP',\n 'ISO-2022-JP-2',\n 'JIS_C6220-1969-jp',\n 'JIS_C6220-1969-ro',\n 'PT',\n 'greek7-old',\n 'latin-greek',\n 'NF_Z_62-010_(1973)',\n 'Latin-greek-1',\n 'ISO_5427',\n 'JIS_C6226-1978',\n 'BS_viewdata',\n 'INIS',\n 'INIS-8',\n 'INIS-cyrillic',\n 'ISO_5427:1981',\n 'ISO_5428:1980',\n 'GB_1988-80',\n 'GB_2312-80',\n 'NS_4551-2',\n 'videotex-suppl',\n 'PT2',\n 'ES2',\n 'MSZ_7795.3',\n 'JIS_C6226-1983',\n 'greek7',\n 'ASMO_449',\n 'iso-ir-90',\n 'JIS_C6229-1984-a',\n 'JIS_C6229-1984-b',\n 'JIS_C6229-1984-b-add',\n 'JIS_C6229-1984-hand',\n 'JIS_C6229-1984-hand-add',\n 'JIS_C6229-1984-kana',\n 'ISO_2033-1983',\n 'ANSI_X3.110-1983',\n 'T.61-7bit',\n 'T.61-8bit',\n 'ECMA-cyrillic',\n 'CSA_Z243.4-1985-1',\n 'CSA_Z243.4-1985-2',\n 'CSA_Z243.4-1985-gr',\n 'ISO-8859-6-E',\n 'ISO-8859-6-I',\n 'T.101-G2',\n 'ISO-8859-8-E',\n 'ISO-8859-8-I',\n 'CSN_369103',\n 'JUS_I.B1.002',\n 'IEC_P27-1',\n 'JUS_I.B1.003-serb',\n 'JUS_I.B1.003-mac',\n 'greek-ccitt',\n 'NC_NC00-10:81',\n 'ISO_6937-2-25',\n 'GOST_19768-74',\n 'ISO_8859-supp',\n 'ISO_10367-box',\n 'latin-lap',\n 'JIS_X0212-1990',\n 'DS_2089',\n 'us-dk',\n 'dk-us',\n 'KSC5636',\n 'UNICODE-1-1-UTF-7',\n 'ISO-2022-CN',\n 'ISO-2022-CN-EXT',\n 'UTF-8',\n 'ISO-8859-13',\n 'ISO-8859-14',\n 'ISO-8859-15',\n 'ISO-8859-16',\n 'GBK',\n 'GB18030',\n 'OSD_EBCDIC_DF04_15',\n 'OSD_EBCDIC_DF03_IRV',\n 'OSD_EBCDIC_DF04_1',\n 'ISO-11548-1',\n 'KZ-1048',\n 'ISO-10646-UCS-2',\n 'ISO-10646-UCS-4',\n 'ISO-10646-UCS-Basic',\n 'ISO-10646-Unicode-Latin1',\n 'ISO-10646-J-1',\n 'ISO-Unicode-IBM-1261',\n 'ISO-Unicode-IBM-1268',\n 'ISO-Unicode-IBM-1276',\n 'ISO-Unicode-IBM-1264',\n 'ISO-Unicode-IBM-1265',\n 'UNICODE-1-1',\n 'SCSU',\n 'UTF-7',\n 'UTF-16BE',\n 'UTF-16LE',\n 'UTF-16',\n 'CESU-8',\n 'UTF-32',\n 'UTF-32BE',\n 'UTF-32LE',\n 'BOCU-1',\n 'ISO-8859-1-Windows-3.0-Latin-1',\n 'ISO-8859-1-Windows-3.1-Latin-1',\n 'ISO-8859-2-Windows-Latin-2',\n 'ISO-8859-9-Windows-Latin-5',\n 'hp-roman8',\n 'Adobe-Standard-Encoding',\n 'Ventura-US',\n 'Ventura-International',\n 'DEC-MCS',\n 'IBM850',\n 'PC8-Danish-Norwegian',\n 'IBM862',\n 'PC8-Turkish',\n 'IBM-Symbols',\n 'IBM-Thai',\n 'HP-Legal',\n 'HP-Pi-font',\n 'HP-Math8',\n 'Adobe-Symbol-Encoding',\n 'HP-DeskTop',\n 'Ventura-Math',\n 'Microsoft-Publishing',\n 'Windows-31J',\n 'GB2312',\n 'Big5',\n 'macintosh',\n 'IBM037',\n 'IBM038',\n 'IBM273',\n 'IBM274',\n 'IBM275',\n 'IBM277',\n 'IBM278',\n 'IBM280',\n 'IBM281',\n 'IBM284',\n 'IBM285',\n 'IBM290',\n 'IBM297',\n 'IBM420',\n 'IBM423',\n 'IBM424',\n 'IBM437',\n 'IBM500',\n 'IBM851',\n 'IBM852',\n 'IBM855',\n 'IBM857',\n 'IBM860',\n 'IBM861',\n 'IBM863',\n 'IBM864',\n 'IBM865',\n 'IBM868',\n 'IBM869',\n 'IBM870',\n 'IBM871',\n 'IBM880',\n 'IBM891',\n 'IBM903',\n 'IBM904',\n 'IBM905',\n 'IBM918',\n 'IBM1026',\n 'EBCDIC-AT-DE',\n 'EBCDIC-AT-DE-A',\n 'EBCDIC-CA-FR',\n 'EBCDIC-DK-NO',\n 'EBCDIC-DK-NO-A',\n 'EBCDIC-FI-SE',\n 'EBCDIC-FI-SE-A',\n 'EBCDIC-FR',\n 'EBCDIC-IT',\n 'EBCDIC-PT',\n 'EBCDIC-ES',\n 'EBCDIC-ES-A',\n 'EBCDIC-ES-S',\n 'EBCDIC-UK',\n 'EBCDIC-US',\n 'UNKNOWN-8BIT',\n 'MNEMONIC',\n 'MNEM',\n 'VISCII',\n 'VIQR',\n 'KOI8-R',\n 'HZ-GB-2312',\n 'IBM866',\n 'IBM775',\n 'KOI8-U',\n 'IBM00858',\n 'IBM00924',\n 'IBM01140',\n 'IBM01141',\n 'IBM01142',\n 'IBM01143',\n 'IBM01144',\n 'IBM01145',\n 'IBM01146',\n 'IBM01147',\n 'IBM01148',\n 'IBM01149',\n 'Big5-HKSCS',\n 'IBM1047',\n 'PTCP154',\n 'Amiga-1251',\n 'KOI7-switched',\n 'BRF',\n 'TSCII',\n 'CP51932',\n 'windows-874',\n 'windows-1250',\n 'windows-1251',\n 'windows-1252',\n 'windows-1253',\n 'windows-1254',\n 'windows-1255',\n 'windows-1256',\n 'windows-1257',\n 'windows-1258',\n 'TIS-620',\n 'CP50220'\n];\n\nconst CHARSET_MAP = new Map();\n\nCHARACTER_SETS.forEach(entry => {\n let key = entry.replace(/[_-\\s]/g, '').toLowerCase();\n let modifiedKey = key\n .replace(/^windows/, 'win')\n .replace(/^usascii/, 'ascii')\n .replace(/^iso8859/, 'latin');\n CHARSET_MAP.set(key, entry);\n if (!CHARSET_MAP.has(modifiedKey)) {\n CHARSET_MAP.set(modifiedKey, entry);\n }\n});\n\nmodule.exports.resolveCharset = charset => {\n let key = charset.replace(/[_-\\s]/g, '').toLowerCase();\n if (CHARSET_MAP.has(key)) {\n return CHARSET_MAP.get(key);\n }\n return null;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/imapflow/lib/charsets.js","mappings":"AAAa;;AAEb;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;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;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;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;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;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;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;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED,6BAA6B;AAC7B;AACA;AACA;AACA;AACA;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/charsets.js"],"sourcesContent":["'use strict';\n\nconst CHARACTER_SETS = [\n    'US-ASCII',\n    'ISO-8859-1',\n    'ISO-8859-2',\n    'ISO-8859-3',\n    'ISO-8859-4',\n    'ISO-8859-5',\n    'ISO-8859-6',\n    'ISO-8859-7',\n    'ISO-8859-8',\n    'ISO-8859-9',\n    'ISO-8859-10',\n    'ISO_6937-2-add',\n    'JIS_X0201',\n    'JIS_Encoding',\n    'Shift_JIS',\n    'EUC-JP',\n    'Extended_UNIX_Code_Fixed_Width_for_Japanese',\n    'BS_4730',\n    'SEN_850200_C',\n    'IT',\n    'ES',\n    'DIN_66003',\n    'NS_4551-1',\n    'NF_Z_62-010',\n    'ISO-10646-UTF-1',\n    'ISO_646.basic:1983',\n    'INVARIANT',\n    'ISO_646.irv:1983',\n    'NATS-SEFI',\n    'NATS-SEFI-ADD',\n    'NATS-DANO',\n    'NATS-DANO-ADD',\n    'SEN_850200_B',\n    'KS_C_5601-1987',\n    'ISO-2022-KR',\n    'EUC-KR',\n    'ISO-2022-JP',\n    'ISO-2022-JP-2',\n    'JIS_C6220-1969-jp',\n    'JIS_C6220-1969-ro',\n    'PT',\n    'greek7-old',\n    'latin-greek',\n    'NF_Z_62-010_(1973)',\n    'Latin-greek-1',\n    'ISO_5427',\n    'JIS_C6226-1978',\n    'BS_viewdata',\n    'INIS',\n    'INIS-8',\n    'INIS-cyrillic',\n    'ISO_5427:1981',\n    'ISO_5428:1980',\n    'GB_1988-80',\n    'GB_2312-80',\n    'NS_4551-2',\n    'videotex-suppl',\n    'PT2',\n    'ES2',\n    'MSZ_7795.3',\n    'JIS_C6226-1983',\n    'greek7',\n    'ASMO_449',\n    'iso-ir-90',\n    'JIS_C6229-1984-a',\n    'JIS_C6229-1984-b',\n    'JIS_C6229-1984-b-add',\n    'JIS_C6229-1984-hand',\n    'JIS_C6229-1984-hand-add',\n    'JIS_C6229-1984-kana',\n    'ISO_2033-1983',\n    'ANSI_X3.110-1983',\n    'T.61-7bit',\n    'T.61-8bit',\n    'ECMA-cyrillic',\n    'CSA_Z243.4-1985-1',\n    'CSA_Z243.4-1985-2',\n    'CSA_Z243.4-1985-gr',\n    'ISO-8859-6-E',\n    'ISO-8859-6-I',\n    'T.101-G2',\n    'ISO-8859-8-E',\n    'ISO-8859-8-I',\n    'CSN_369103',\n    'JUS_I.B1.002',\n    'IEC_P27-1',\n    'JUS_I.B1.003-serb',\n    'JUS_I.B1.003-mac',\n    'greek-ccitt',\n    'NC_NC00-10:81',\n    'ISO_6937-2-25',\n    'GOST_19768-74',\n    'ISO_8859-supp',\n    'ISO_10367-box',\n    'latin-lap',\n    'JIS_X0212-1990',\n    'DS_2089',\n    'us-dk',\n    'dk-us',\n    'KSC5636',\n    'UNICODE-1-1-UTF-7',\n    'ISO-2022-CN',\n    'ISO-2022-CN-EXT',\n    'UTF-8',\n    'ISO-8859-13',\n    'ISO-8859-14',\n    'ISO-8859-15',\n    'ISO-8859-16',\n    'GBK',\n    'GB18030',\n    'OSD_EBCDIC_DF04_15',\n    'OSD_EBCDIC_DF03_IRV',\n    'OSD_EBCDIC_DF04_1',\n    'ISO-11548-1',\n    'KZ-1048',\n    'ISO-10646-UCS-2',\n    'ISO-10646-UCS-4',\n    'ISO-10646-UCS-Basic',\n    'ISO-10646-Unicode-Latin1',\n    'ISO-10646-J-1',\n    'ISO-Unicode-IBM-1261',\n    'ISO-Unicode-IBM-1268',\n    'ISO-Unicode-IBM-1276',\n    'ISO-Unicode-IBM-1264',\n    'ISO-Unicode-IBM-1265',\n    'UNICODE-1-1',\n    'SCSU',\n    'UTF-7',\n    'UTF-16BE',\n    'UTF-16LE',\n    'UTF-16',\n    'CESU-8',\n    'UTF-32',\n    'UTF-32BE',\n    'UTF-32LE',\n    'BOCU-1',\n    'ISO-8859-1-Windows-3.0-Latin-1',\n    'ISO-8859-1-Windows-3.1-Latin-1',\n    'ISO-8859-2-Windows-Latin-2',\n    'ISO-8859-9-Windows-Latin-5',\n    'hp-roman8',\n    'Adobe-Standard-Encoding',\n    'Ventura-US',\n    'Ventura-International',\n    'DEC-MCS',\n    'IBM850',\n    'PC8-Danish-Norwegian',\n    'IBM862',\n    'PC8-Turkish',\n    'IBM-Symbols',\n    'IBM-Thai',\n    'HP-Legal',\n    'HP-Pi-font',\n    'HP-Math8',\n    'Adobe-Symbol-Encoding',\n    'HP-DeskTop',\n    'Ventura-Math',\n    'Microsoft-Publishing',\n    'Windows-31J',\n    'GB2312',\n    'Big5',\n    'macintosh',\n    'IBM037',\n    'IBM038',\n    'IBM273',\n    'IBM274',\n    'IBM275',\n    'IBM277',\n    'IBM278',\n    'IBM280',\n    'IBM281',\n    'IBM284',\n    'IBM285',\n    'IBM290',\n    'IBM297',\n    'IBM420',\n    'IBM423',\n    'IBM424',\n    'IBM437',\n    'IBM500',\n    'IBM851',\n    'IBM852',\n    'IBM855',\n    'IBM857',\n    'IBM860',\n    'IBM861',\n    'IBM863',\n    'IBM864',\n    'IBM865',\n    'IBM868',\n    'IBM869',\n    'IBM870',\n    'IBM871',\n    'IBM880',\n    'IBM891',\n    'IBM903',\n    'IBM904',\n    'IBM905',\n    'IBM918',\n    'IBM1026',\n    'EBCDIC-AT-DE',\n    'EBCDIC-AT-DE-A',\n    'EBCDIC-CA-FR',\n    'EBCDIC-DK-NO',\n    'EBCDIC-DK-NO-A',\n    'EBCDIC-FI-SE',\n    'EBCDIC-FI-SE-A',\n    'EBCDIC-FR',\n    'EBCDIC-IT',\n    'EBCDIC-PT',\n    'EBCDIC-ES',\n    'EBCDIC-ES-A',\n    'EBCDIC-ES-S',\n    'EBCDIC-UK',\n    'EBCDIC-US',\n    'UNKNOWN-8BIT',\n    'MNEMONIC',\n    'MNEM',\n    'VISCII',\n    'VIQR',\n    'KOI8-R',\n    'HZ-GB-2312',\n    'IBM866',\n    'IBM775',\n    'KOI8-U',\n    'IBM00858',\n    'IBM00924',\n    'IBM01140',\n    'IBM01141',\n    'IBM01142',\n    'IBM01143',\n    'IBM01144',\n    'IBM01145',\n    'IBM01146',\n    'IBM01147',\n    'IBM01148',\n    'IBM01149',\n    'Big5-HKSCS',\n    'IBM1047',\n    'PTCP154',\n    'Amiga-1251',\n    'KOI7-switched',\n    'BRF',\n    'TSCII',\n    'CP51932',\n    'windows-874',\n    'windows-1250',\n    'windows-1251',\n    'windows-1252',\n    'windows-1253',\n    'windows-1254',\n    'windows-1255',\n    'windows-1256',\n    'windows-1257',\n    'windows-1258',\n    'TIS-620',\n    'CP50220'\n];\n\nconst CHARSET_MAP = new Map();\n\nCHARACTER_SETS.forEach(entry => {\n    let key = entry.replace(/[_-\\s]/g, '').toLowerCase();\n    let modifiedKey = key\n        .replace(/^windows/, 'win')\n        .replace(/^usascii/, 'ascii')\n        .replace(/^iso8859/, 'latin');\n    CHARSET_MAP.set(key, entry);\n    if (!CHARSET_MAP.has(modifiedKey)) {\n        CHARSET_MAP.set(modifiedKey, entry);\n    }\n});\n\nmodule.exports.resolveCharset = charset => {\n    let key = charset.replace(/[_-\\s]/g, '').toLowerCase();\n    if (CHARSET_MAP.has(key)) {\n        return CHARSET_MAP.get(key);\n    }\n    return null;\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/charsets.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/append.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/append.js ***!
|
|
\******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { getStatusCode, formatFlag, canUseFlag, formatDateTime, normalizePath, encodePath, comparePaths, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(rsc)/./node_modules/imapflow/lib/tools.js\");\n\n// Appends a message to a mailbox\nmodule.exports = async (connection, destination, content, flags, idate) => {\n if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state) || !destination) {\n // nothing to do here\n return;\n }\n\n if (connection.capabilities.has('APPENDLIMIT')) {\n let appendLimit = connection.capabilities.get('APPENDLIMIT');\n if (typeof appendLimit === 'number' && appendLimit < content.length) {\n let err = new Error('Message content too big for APPENDLIMIT=' + appendLimit);\n err.serverResponseCode = 'APPENDLIMIT';\n throw err;\n }\n }\n\n destination = normalizePath(connection, destination);\n\n let expectExists = comparePaths(connection, connection.mailbox.path, destination);\n\n flags = (Array.isArray(flags) ? flags : [].concat(flags || []))\n .map(flag => flag && formatFlag(flag.toString()))\n .filter(flag => flag && canUseFlag(connection.mailbox, flag));\n\n let attributes = [{ type: 'ATOM', value: encodePath(connection, destination) }];\n\n idate = idate ? formatDateTime(idate) : false;\n\n if (flags.length || idate) {\n attributes.push(flags.map(flag => ({ type: 'ATOM', value: flag })));\n }\n\n if (idate) {\n attributes.push({ type: 'STRING', value: idate }); // force quotes as required by date-time\n }\n\n let isLiteral8 = false;\n if (connection.capabilities.has('BINARY') && !connection.disableBinary) {\n if (typeof content === 'string') {\n content = Buffer.from(content);\n }\n // Value is literal8 if it contains NULL bytes. The server must support the BINARY extension\n // and if it does not then send the value as a regular literal and hope for the best\n isLiteral8 = content.indexOf(Buffer.from([0])) >= 0;\n }\n\n attributes.push({ type: 'LITERAL', value: content, isLiteral8 });\n\n let map = { destination };\n if (connection.mailbox && connection.mailbox.path) {\n map.path = connection.mailbox.path;\n }\n\n let response;\n try {\n response = await connection.exec('APPEND', attributes, {\n untagged: expectExists\n ? {\n EXISTS: async untagged => {\n map.seq = Number(untagged.command);\n\n if (expectExists) {\n let prevCount = connection.mailbox.exists;\n if (map.seq !== prevCount) {\n connection.mailbox.exists = map.seq;\n connection.emit('exists', {\n path: connection.mailbox.path,\n count: map.seq,\n prevCount\n });\n }\n }\n }\n }\n : false\n });\n\n let section = response.response.attributes && response.response.attributes[0] && response.response.attributes[0].section;\n if (section && section.length) {\n let responseCode = section[0] && typeof section[0].value === 'string' ? section[0].value : '';\n switch (responseCode.toUpperCase()) {\n case 'APPENDUID':\n {\n let uidValidity = section[1] && typeof section[1].value === 'string' && !isNaN(section[1].value) ? BigInt(section[1].value) : false;\n let uid = section[2] && typeof section[2].value === 'string' && !isNaN(section[2].value) ? Number(section[2].value) : false;\n if (uidValidity) {\n map.uidValidity = uidValidity;\n }\n if (uid) {\n map.uid = uid;\n }\n }\n break;\n }\n }\n\n response.next();\n\n if (expectExists && !map.seq) {\n // try to use NOOP to get the new sequence number\n try {\n response = await connection.exec('NOOP', false, {\n untagged: {\n EXISTS: async untagged => {\n map.seq = Number(untagged.command);\n\n if (expectExists) {\n let prevCount = connection.mailbox.exists;\n if (map.seq !== prevCount) {\n connection.mailbox.exists = map.seq;\n connection.emit('exists', {\n path: connection.mailbox.path,\n count: map.seq,\n prevCount\n });\n }\n }\n }\n },\n comment: 'Sequence not found from APPEND output'\n });\n response.next();\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n }\n }\n\n if (map.seq && !map.uid) {\n let list = await connection.search({ seq: map.seq }, { uid: true });\n if (list && list.length) {\n map.uid = list[0];\n }\n }\n\n return map;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n throw err;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/imapflow/lib/commands/append.js","mappings":"AAAa;;AAEb,QAAQ,+GAA+G,EAAE,mBAAO,CAAC,+DAAa;;AAE9I;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;;AAEA,wBAAwB,0DAA0D;;AAElF;;AAEA;AACA,6CAA6C,2BAA2B;AACxE;;AAEA;AACA,0BAA0B,8BAA8B,GAAG;AAC3D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,sBAAsB,6CAA6C;;AAEnE,gBAAgB;AAChB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC;AACnC;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC;AACrC;AACA;AACA;AACA,qBAAqB;AACrB;AACA,iBAAiB;AACjB;AACA,cAAc;AACd,sCAAsC,yBAAyB;AAC/D;AACA;;AAEA;AACA,iDAAiD,cAAc,IAAI,WAAW;AAC9E;AACA;AACA;AACA;;AAEA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;;AAEA,8BAA8B,yBAAyB;AACvD;AACA;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/commands/append.js"],"sourcesContent":["'use strict';\n\nconst { getStatusCode, formatFlag, canUseFlag, formatDateTime, normalizePath, encodePath, comparePaths, getErrorText } = require('../tools.js');\n\n// Appends a message to a mailbox\nmodule.exports = async (connection, destination, content, flags, idate) => {\n    if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state) || !destination) {\n        // nothing to do here\n        return;\n    }\n\n    if (connection.capabilities.has('APPENDLIMIT')) {\n        let appendLimit = connection.capabilities.get('APPENDLIMIT');\n        if (typeof appendLimit === 'number' && appendLimit < content.length) {\n            let err = new Error('Message content too big for APPENDLIMIT=' + appendLimit);\n            err.serverResponseCode = 'APPENDLIMIT';\n            throw err;\n        }\n    }\n\n    destination = normalizePath(connection, destination);\n\n    let expectExists = comparePaths(connection, connection.mailbox.path, destination);\n\n    flags = (Array.isArray(flags) ? flags : [].concat(flags || []))\n        .map(flag => flag && formatFlag(flag.toString()))\n        .filter(flag => flag && canUseFlag(connection.mailbox, flag));\n\n    let attributes = [{ type: 'ATOM', value: encodePath(connection, destination) }];\n\n    idate = idate ? formatDateTime(idate) : false;\n\n    if (flags.length || idate) {\n        attributes.push(flags.map(flag => ({ type: 'ATOM', value: flag })));\n    }\n\n    if (idate) {\n        attributes.push({ type: 'STRING', value: idate }); // force quotes as required by date-time\n    }\n\n    let isLiteral8 = false;\n    if (connection.capabilities.has('BINARY') && !connection.disableBinary) {\n        if (typeof content === 'string') {\n            content = Buffer.from(content);\n        }\n        // Value is literal8 if it contains NULL bytes. The server must support the BINARY extension\n        // and if it does not then send the value as a regular literal and hope for the best\n        isLiteral8 = content.indexOf(Buffer.from([0])) >= 0;\n    }\n\n    attributes.push({ type: 'LITERAL', value: content, isLiteral8 });\n\n    let map = { destination };\n    if (connection.mailbox && connection.mailbox.path) {\n        map.path = connection.mailbox.path;\n    }\n\n    let response;\n    try {\n        response = await connection.exec('APPEND', attributes, {\n            untagged: expectExists\n                ? {\n                      EXISTS: async untagged => {\n                          map.seq = Number(untagged.command);\n\n                          if (expectExists) {\n                              let prevCount = connection.mailbox.exists;\n                              if (map.seq !== prevCount) {\n                                  connection.mailbox.exists = map.seq;\n                                  connection.emit('exists', {\n                                      path: connection.mailbox.path,\n                                      count: map.seq,\n                                      prevCount\n                                  });\n                              }\n                          }\n                      }\n                  }\n                : false\n        });\n\n        let section = response.response.attributes && response.response.attributes[0] && response.response.attributes[0].section;\n        if (section && section.length) {\n            let responseCode = section[0] && typeof section[0].value === 'string' ? section[0].value : '';\n            switch (responseCode.toUpperCase()) {\n                case 'APPENDUID':\n                    {\n                        let uidValidity = section[1] && typeof section[1].value === 'string' && !isNaN(section[1].value) ? BigInt(section[1].value) : false;\n                        let uid = section[2] && typeof section[2].value === 'string' && !isNaN(section[2].value) ? Number(section[2].value) : false;\n                        if (uidValidity) {\n                            map.uidValidity = uidValidity;\n                        }\n                        if (uid) {\n                            map.uid = uid;\n                        }\n                    }\n                    break;\n            }\n        }\n\n        response.next();\n\n        if (expectExists && !map.seq) {\n            // try to use NOOP to get the new sequence number\n            try {\n                response = await connection.exec('NOOP', false, {\n                    untagged: {\n                        EXISTS: async untagged => {\n                            map.seq = Number(untagged.command);\n\n                            if (expectExists) {\n                                let prevCount = connection.mailbox.exists;\n                                if (map.seq !== prevCount) {\n                                    connection.mailbox.exists = map.seq;\n                                    connection.emit('exists', {\n                                        path: connection.mailbox.path,\n                                        count: map.seq,\n                                        prevCount\n                                    });\n                                }\n                            }\n                        }\n                    },\n                    comment: 'Sequence not found from APPEND output'\n                });\n                response.next();\n            } catch (err) {\n                connection.log.warn({ err, cid: connection.id });\n            }\n        }\n\n        if (map.seq && !map.uid) {\n            let list = await connection.search({ seq: map.seq }, { uid: true });\n            if (list && list.length) {\n                map.uid = list[0];\n            }\n        }\n\n        return map;\n    } catch (err) {\n        let errorCode = getStatusCode(err.response);\n        if (errorCode) {\n            err.serverResponseCode = errorCode;\n        }\n        err.response = await getErrorText(err.response);\n\n        connection.log.warn({ err, cid: connection.id });\n        throw err;\n    }\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/append.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/authenticate.js":
|
|
/*!************************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/authenticate.js ***!
|
|
\************************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { getStatusCode, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(rsc)/./node_modules/imapflow/lib/tools.js\");\n\nasync function authOauth(connection, username, accessToken) {\n let oauthbearer;\n let command;\n let breaker;\n\n if (connection.capabilities.has('AUTH=OAUTHBEARER')) {\n oauthbearer = [`n,a=${username},`, `host=${connection.servername}`, `port=993`, `auth=Bearer ${accessToken}`, '', ''].join('\\x01');\n command = 'OAUTHBEARER';\n breaker = 'AQ==';\n } else if (connection.capabilities.has('AUTH=XOAUTH') || connection.capabilities.has('AUTH=XOAUTH2')) {\n oauthbearer = [`user=${username}`, `auth=Bearer ${accessToken}`, '', ''].join('\\x01');\n command = 'XOAUTH2';\n breaker = '';\n }\n\n let errorResponse = false;\n try {\n let response = await connection.exec(\n 'AUTHENTICATE',\n [\n { type: 'ATOM', value: command },\n { type: 'ATOM', value: Buffer.from(oauthbearer).toString('base64'), sensitive: true }\n ],\n {\n onPlusTag: async resp => {\n if (resp.attributes && resp.attributes[0] && resp.attributes[0].type === 'TEXT') {\n try {\n errorResponse = JSON.parse(Buffer.from(resp.attributes[0].value, 'base64').toString());\n } catch (err) {\n connection.log.debug({ errorResponse: resp.attributes[0].value, err });\n }\n }\n\n connection.log.debug({ src: 'c', msg: breaker, comment: `Error response for ${command}` });\n connection.write(breaker);\n }\n }\n );\n response.next();\n\n connection.authCapabilities.set(`AUTH=${command}`, true);\n\n return username;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.authenticationFailed = true;\n err.response = await getErrorText(err.response);\n if (errorResponse) {\n err.oauthError = errorResponse;\n }\n throw err;\n }\n}\n\nasync function authLogin(connection, username, password) {\n let errorResponse = false;\n try {\n let response = await connection.exec('AUTHENTICATE', [{ type: 'ATOM', value: 'LOGIN' }], {\n onPlusTag: async resp => {\n if (resp.attributes && resp.attributes[0] && resp.attributes[0].type === 'TEXT') {\n let question = Buffer.from(resp.attributes[0].value, 'base64').toString();\n switch (\n question.toLowerCase().replace(/[:\\x00]*$/, '') // eslint-disable-line no-control-regex\n ) {\n case 'username':\n case 'user name': {\n let encodedUsername = Buffer.from(username).toString('base64');\n connection.log.debug({ src: 'c', msg: encodedUsername, comment: `Encoded username for AUTH=LOGIN` });\n connection.write(encodedUsername);\n break;\n }\n\n case 'password':\n connection.log.debug({ src: 'c', msg: '(* value hidden *)', comment: `Encoded password for AUTH=LOGIN` });\n connection.write(Buffer.from(password).toString('base64'));\n break;\n\n default: {\n let error = new Error(`Unknown LOGIN question \"${question}\"`);\n throw error;\n }\n }\n }\n }\n });\n\n response.next();\n\n connection.authCapabilities.set(`AUTH=LOGIN`, true);\n\n return username;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.authenticationFailed = true;\n err.response = await getErrorText(err.response);\n if (errorResponse) {\n err.oauthError = errorResponse;\n }\n throw err;\n }\n}\n\nasync function authPlain(connection, username, password) {\n let errorResponse = false;\n try {\n let response = await connection.exec('AUTHENTICATE', [{ type: 'ATOM', value: 'PLAIN' }], {\n onPlusTag: async () => {\n let encodedResponse = Buffer.from(['', username, password].join('\\x00')).toString('base64');\n let loggedResponse = Buffer.from(['', username, '(* value hidden *)'].join('\\x00')).toString('base64');\n connection.log.debug({ src: 'c', msg: loggedResponse, comment: `Encoded response for AUTH=PLAIN` });\n connection.write(encodedResponse);\n }\n });\n\n response.next();\n\n connection.authCapabilities.set(`AUTH=PLAIN`, true);\n\n return username;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.authenticationFailed = true;\n err.response = await getErrorText(err.response);\n if (errorResponse) {\n err.oauthError = errorResponse;\n }\n throw err;\n }\n}\n\n// Authenticates user using LOGIN\nmodule.exports = async (connection, username, { accessToken, password, loginMethod }) => {\n if (connection.state !== connection.states.NOT_AUTHENTICATED) {\n // nothing to do here\n return;\n }\n\n if (accessToken) {\n // AUTH=OAUTHBEARER and AUTH=XOAUTH in the context of OAuth2 or very similar so we can handle these together\n if (connection.capabilities.has('AUTH=OAUTHBEARER') || connection.capabilities.has('AUTH=XOAUTH') || connection.capabilities.has('AUTH=XOAUTH2')) {\n return await authOauth(connection, username, accessToken);\n }\n }\n\n if (password) {\n if ((!loginMethod && connection.capabilities.has('AUTH=PLAIN')) || loginMethod === 'AUTH=PLAIN') {\n return await authPlain(connection, username, password);\n }\n\n if ((!loginMethod && connection.capabilities.has('AUTH=LOGIN')) || loginMethod === 'AUTH=LOGIN') {\n return await authLogin(connection, username, password);\n }\n }\n\n throw new Error('Unsupported authentication mechanism');\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/imapflow/lib/commands/authenticate.js","mappings":"AAAa;;AAEb,QAAQ,8BAA8B,EAAE,mBAAO,CAAC,+DAAa;;AAE7D;AACA;AACA;AACA;;AAEA;AACA,8BAA8B,SAAS,YAAY,sBAAsB,8BAA8B,YAAY;AACnH;AACA;AACA,MAAM;AACN,+BAA+B,SAAS,kBAAkB,YAAY;AACtE;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,kBAAkB,8BAA8B;AAChD,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B;AAC1B,mDAAmD,8CAA8C;AACjG;AACA;;AAEA,2CAA2C,uDAAuD,QAAQ,GAAG;AAC7G;AACA;AACA;AACA;AACA;;AAEA,gDAAgD,QAAQ;;AAExD;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,gEAAgE,8BAA8B;AAC9F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mDAAmD,4EAA4E;AAC/H;AACA;AACA;;AAEA;AACA,mDAAmD,iFAAiF;AACpI;AACA;;AAEA;AACA,6EAA6E,SAAS;AACtF;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;;AAEA;;AAEA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,gEAAgE,8BAA8B;AAC9F;AACA;AACA;AACA,uCAAuC,2EAA2E;AAClH;AACA;AACA,SAAS;;AAET;;AAEA;;AAEA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,gDAAgD,oCAAoC;AACpF;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/commands/authenticate.js"],"sourcesContent":["'use strict';\n\nconst { getStatusCode, getErrorText } = require('../tools.js');\n\nasync function authOauth(connection, username, accessToken) {\n    let oauthbearer;\n    let command;\n    let breaker;\n\n    if (connection.capabilities.has('AUTH=OAUTHBEARER')) {\n        oauthbearer = [`n,a=${username},`, `host=${connection.servername}`, `port=993`, `auth=Bearer ${accessToken}`, '', ''].join('\\x01');\n        command = 'OAUTHBEARER';\n        breaker = 'AQ==';\n    } else if (connection.capabilities.has('AUTH=XOAUTH') || connection.capabilities.has('AUTH=XOAUTH2')) {\n        oauthbearer = [`user=${username}`, `auth=Bearer ${accessToken}`, '', ''].join('\\x01');\n        command = 'XOAUTH2';\n        breaker = '';\n    }\n\n    let errorResponse = false;\n    try {\n        let response = await connection.exec(\n            'AUTHENTICATE',\n            [\n                { type: 'ATOM', value: command },\n                { type: 'ATOM', value: Buffer.from(oauthbearer).toString('base64'), sensitive: true }\n            ],\n            {\n                onPlusTag: async resp => {\n                    if (resp.attributes && resp.attributes[0] && resp.attributes[0].type === 'TEXT') {\n                        try {\n                            errorResponse = JSON.parse(Buffer.from(resp.attributes[0].value, 'base64').toString());\n                        } catch (err) {\n                            connection.log.debug({ errorResponse: resp.attributes[0].value, err });\n                        }\n                    }\n\n                    connection.log.debug({ src: 'c', msg: breaker, comment: `Error response for ${command}` });\n                    connection.write(breaker);\n                }\n            }\n        );\n        response.next();\n\n        connection.authCapabilities.set(`AUTH=${command}`, true);\n\n        return username;\n    } catch (err) {\n        let errorCode = getStatusCode(err.response);\n        if (errorCode) {\n            err.serverResponseCode = errorCode;\n        }\n        err.authenticationFailed = true;\n        err.response = await getErrorText(err.response);\n        if (errorResponse) {\n            err.oauthError = errorResponse;\n        }\n        throw err;\n    }\n}\n\nasync function authLogin(connection, username, password) {\n    let errorResponse = false;\n    try {\n        let response = await connection.exec('AUTHENTICATE', [{ type: 'ATOM', value: 'LOGIN' }], {\n            onPlusTag: async resp => {\n                if (resp.attributes && resp.attributes[0] && resp.attributes[0].type === 'TEXT') {\n                    let question = Buffer.from(resp.attributes[0].value, 'base64').toString();\n                    switch (\n                        question.toLowerCase().replace(/[:\\x00]*$/, '') // eslint-disable-line no-control-regex\n                    ) {\n                        case 'username':\n                        case 'user name': {\n                            let encodedUsername = Buffer.from(username).toString('base64');\n                            connection.log.debug({ src: 'c', msg: encodedUsername, comment: `Encoded username for AUTH=LOGIN` });\n                            connection.write(encodedUsername);\n                            break;\n                        }\n\n                        case 'password':\n                            connection.log.debug({ src: 'c', msg: '(* value hidden *)', comment: `Encoded password for AUTH=LOGIN` });\n                            connection.write(Buffer.from(password).toString('base64'));\n                            break;\n\n                        default: {\n                            let error = new Error(`Unknown LOGIN question \"${question}\"`);\n                            throw error;\n                        }\n                    }\n                }\n            }\n        });\n\n        response.next();\n\n        connection.authCapabilities.set(`AUTH=LOGIN`, true);\n\n        return username;\n    } catch (err) {\n        let errorCode = getStatusCode(err.response);\n        if (errorCode) {\n            err.serverResponseCode = errorCode;\n        }\n        err.authenticationFailed = true;\n        err.response = await getErrorText(err.response);\n        if (errorResponse) {\n            err.oauthError = errorResponse;\n        }\n        throw err;\n    }\n}\n\nasync function authPlain(connection, username, password) {\n    let errorResponse = false;\n    try {\n        let response = await connection.exec('AUTHENTICATE', [{ type: 'ATOM', value: 'PLAIN' }], {\n            onPlusTag: async () => {\n                let encodedResponse = Buffer.from(['', username, password].join('\\x00')).toString('base64');\n                let loggedResponse = Buffer.from(['', username, '(* value hidden *)'].join('\\x00')).toString('base64');\n                connection.log.debug({ src: 'c', msg: loggedResponse, comment: `Encoded response for AUTH=PLAIN` });\n                connection.write(encodedResponse);\n            }\n        });\n\n        response.next();\n\n        connection.authCapabilities.set(`AUTH=PLAIN`, true);\n\n        return username;\n    } catch (err) {\n        let errorCode = getStatusCode(err.response);\n        if (errorCode) {\n            err.serverResponseCode = errorCode;\n        }\n        err.authenticationFailed = true;\n        err.response = await getErrorText(err.response);\n        if (errorResponse) {\n            err.oauthError = errorResponse;\n        }\n        throw err;\n    }\n}\n\n// Authenticates user using LOGIN\nmodule.exports = async (connection, username, { accessToken, password, loginMethod }) => {\n    if (connection.state !== connection.states.NOT_AUTHENTICATED) {\n        // nothing to do here\n        return;\n    }\n\n    if (accessToken) {\n        // AUTH=OAUTHBEARER and AUTH=XOAUTH in the context of OAuth2 or very similar so we can handle these together\n        if (connection.capabilities.has('AUTH=OAUTHBEARER') || connection.capabilities.has('AUTH=XOAUTH') || connection.capabilities.has('AUTH=XOAUTH2')) {\n            return await authOauth(connection, username, accessToken);\n        }\n    }\n\n    if (password) {\n        if ((!loginMethod && connection.capabilities.has('AUTH=PLAIN')) || loginMethod === 'AUTH=PLAIN') {\n            return await authPlain(connection, username, password);\n        }\n\n        if ((!loginMethod && connection.capabilities.has('AUTH=LOGIN')) || loginMethod === 'AUTH=LOGIN') {\n            return await authLogin(connection, username, password);\n        }\n    }\n\n    throw new Error('Unsupported authentication mechanism');\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/authenticate.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/capability.js":
|
|
/*!**********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/capability.js ***!
|
|
\**********************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\n// Refresh capabilities from server\nmodule.exports = async connection => {\n if (connection.capabilities.size && !connection.expectCapabilityUpdate) {\n return connection.capabilities;\n }\n\n let response;\n try {\n // untagged capability response is processed by global handler\n response = await connection.exec('CAPABILITY');\n\n response.next();\n return connection.capabilities;\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL2NhcGFiaWxpdHkuanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWI7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsTUFBTTtBQUNOLDhCQUE4Qix5QkFBeUI7QUFDdkQ7QUFDQTtBQUNBIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvY2FwYWJpbGl0eS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbi8vIFJlZnJlc2ggY2FwYWJpbGl0aWVzIGZyb20gc2VydmVyXG5tb2R1bGUuZXhwb3J0cyA9IGFzeW5jIGNvbm5lY3Rpb24gPT4ge1xuICAgIGlmIChjb25uZWN0aW9uLmNhcGFiaWxpdGllcy5zaXplICYmICFjb25uZWN0aW9uLmV4cGVjdENhcGFiaWxpdHlVcGRhdGUpIHtcbiAgICAgICAgcmV0dXJuIGNvbm5lY3Rpb24uY2FwYWJpbGl0aWVzO1xuICAgIH1cblxuICAgIGxldCByZXNwb25zZTtcbiAgICB0cnkge1xuICAgICAgICAvLyB1bnRhZ2dlZCBjYXBhYmlsaXR5IHJlc3BvbnNlIGlzIHByb2Nlc3NlZCBieSBnbG9iYWwgaGFuZGxlclxuICAgICAgICByZXNwb25zZSA9IGF3YWl0IGNvbm5lY3Rpb24uZXhlYygnQ0FQQUJJTElUWScpO1xuXG4gICAgICAgIHJlc3BvbnNlLm5leHQoKTtcbiAgICAgICAgcmV0dXJuIGNvbm5lY3Rpb24uY2FwYWJpbGl0aWVzO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICBjb25uZWN0aW9uLmxvZy53YXJuKHsgZXJyLCBjaWQ6IGNvbm5lY3Rpb24uaWQgfSk7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG59O1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/capability.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/close.js":
|
|
/*!*****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/close.js ***!
|
|
\*****************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\n// Closes a mailbox\nmodule.exports = async connection => {\n if (connection.state !== connection.states.SELECTED) {\n // nothing to do here\n return;\n }\n\n let response;\n try {\n response = await connection.exec('CLOSE');\n response.next();\n\n let currentMailbox = connection.mailbox;\n connection.mailbox = false;\n connection.currentSelectCommand = false;\n connection.state = connection.states.AUTHENTICATED;\n\n if (currentMailbox) {\n connection.emit('mailboxClose', currentMailbox);\n }\n return true;\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL2Nsb3NlLmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTiw4QkFBOEIseUJBQXlCO0FBQ3ZEO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL2Nsb3NlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuLy8gQ2xvc2VzIGEgbWFpbGJveFxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyBjb25uZWN0aW9uID0+IHtcbiAgICBpZiAoY29ubmVjdGlvbi5zdGF0ZSAhPT0gY29ubmVjdGlvbi5zdGF0ZXMuU0VMRUNURUQpIHtcbiAgICAgICAgLy8gbm90aGluZyB0byBkbyBoZXJlXG4gICAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBsZXQgcmVzcG9uc2U7XG4gICAgdHJ5IHtcbiAgICAgICAgcmVzcG9uc2UgPSBhd2FpdCBjb25uZWN0aW9uLmV4ZWMoJ0NMT1NFJyk7XG4gICAgICAgIHJlc3BvbnNlLm5leHQoKTtcblxuICAgICAgICBsZXQgY3VycmVudE1haWxib3ggPSBjb25uZWN0aW9uLm1haWxib3g7XG4gICAgICAgIGNvbm5lY3Rpb24ubWFpbGJveCA9IGZhbHNlO1xuICAgICAgICBjb25uZWN0aW9uLmN1cnJlbnRTZWxlY3RDb21tYW5kID0gZmFsc2U7XG4gICAgICAgIGNvbm5lY3Rpb24uc3RhdGUgPSBjb25uZWN0aW9uLnN0YXRlcy5BVVRIRU5USUNBVEVEO1xuXG4gICAgICAgIGlmIChjdXJyZW50TWFpbGJveCkge1xuICAgICAgICAgICAgY29ubmVjdGlvbi5lbWl0KCdtYWlsYm94Q2xvc2UnLCBjdXJyZW50TWFpbGJveCk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICAgIGNvbm5lY3Rpb24ubG9nLndhcm4oeyBlcnIsIGNpZDogY29ubmVjdGlvbi5pZCB9KTtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbn07XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/close.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/compress.js":
|
|
/*!********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/compress.js ***!
|
|
\********************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\n// Requests compression from server\nmodule.exports = async connection => {\n if (!connection.capabilities.has('COMPRESS=DEFLATE') || connection._inflate) {\n // nothing to do here\n return false;\n }\n\n let response;\n try {\n response = await connection.exec('COMPRESS', [{ type: 'ATOM', value: 'DEFLATE' }]);\n response.next();\n return true;\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL2NvbXByZXNzLmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0Esd0RBQXdELGdDQUFnQztBQUN4RjtBQUNBO0FBQ0EsTUFBTTtBQUNOLDhCQUE4Qix5QkFBeUI7QUFDdkQ7QUFDQTtBQUNBIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvY29tcHJlc3MuanMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG4vLyBSZXF1ZXN0cyBjb21wcmVzc2lvbiBmcm9tIHNlcnZlclxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyBjb25uZWN0aW9uID0+IHtcbiAgICBpZiAoIWNvbm5lY3Rpb24uY2FwYWJpbGl0aWVzLmhhcygnQ09NUFJFU1M9REVGTEFURScpIHx8IGNvbm5lY3Rpb24uX2luZmxhdGUpIHtcbiAgICAgICAgLy8gbm90aGluZyB0byBkbyBoZXJlXG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG5cbiAgICBsZXQgcmVzcG9uc2U7XG4gICAgdHJ5IHtcbiAgICAgICAgcmVzcG9uc2UgPSBhd2FpdCBjb25uZWN0aW9uLmV4ZWMoJ0NPTVBSRVNTJywgW3sgdHlwZTogJ0FUT00nLCB2YWx1ZTogJ0RFRkxBVEUnIH1dKTtcbiAgICAgICAgcmVzcG9uc2UubmV4dCgpO1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgY29ubmVjdGlvbi5sb2cud2Fybih7IGVyciwgY2lkOiBjb25uZWN0aW9uLmlkIH0pO1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxufTtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/compress.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/copy.js":
|
|
/*!****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/copy.js ***!
|
|
\****************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { getStatusCode, normalizePath, encodePath, expandRange, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(rsc)/./node_modules/imapflow/lib/tools.js\");\n\n// Copies messages from current mailbox to some other mailbox\nmodule.exports = async (connection, range, destination, options) => {\n if (connection.state !== connection.states.SELECTED || !range || !destination) {\n // nothing to do here\n return;\n }\n\n options = options || {};\n destination = normalizePath(connection, destination);\n\n let attributes = [\n { type: 'SEQUENCE', value: range },\n { type: 'ATOM', value: encodePath(connection, destination) }\n ];\n\n let response;\n try {\n response = await connection.exec(options.uid ? 'UID COPY' : 'COPY', attributes);\n response.next();\n\n let map = { path: connection.mailbox.path, destination };\n let section = response.response.attributes && response.response.attributes[0] && response.response.attributes[0].section;\n let responseCode = section && section.length && section[0] && typeof section[0].value === 'string' ? section[0].value : '';\n switch (responseCode) {\n case 'COPYUID':\n {\n let uidValidity = section[1] && typeof section[1].value === 'string' && !isNaN(section[1].value) ? BigInt(section[1].value) : false;\n if (uidValidity) {\n map.uidValidity = uidValidity;\n }\n\n let sourceUids = section[2] && typeof section[2].value === 'string' ? expandRange(section[2].value) : false;\n let destinationUids = section[3] && typeof section[3].value === 'string' ? expandRange(section[3].value) : false;\n if (sourceUids && destinationUids && sourceUids.length === destinationUids.length) {\n map.uidMap = new Map(sourceUids.map((uid, i) => [uid, destinationUids[i]]));\n }\n }\n break;\n }\n\n return map;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL2NvcHkuanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWIsUUFBUSxzRUFBc0UsRUFBRSxtQkFBTyxDQUFDLCtEQUFhOztBQUVyRztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBLFVBQVUsZ0NBQWdDO0FBQzFDLFVBQVU7QUFDVjs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxvQkFBb0I7QUFDcEI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSw4QkFBOEIseUJBQXlCO0FBQ3ZEO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL2NvcHkuanMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCB7IGdldFN0YXR1c0NvZGUsIG5vcm1hbGl6ZVBhdGgsIGVuY29kZVBhdGgsIGV4cGFuZFJhbmdlLCBnZXRFcnJvclRleHQgfSA9IHJlcXVpcmUoJy4uL3Rvb2xzLmpzJyk7XG5cbi8vIENvcGllcyBtZXNzYWdlcyBmcm9tIGN1cnJlbnQgbWFpbGJveCB0byBzb21lIG90aGVyIG1haWxib3hcbm1vZHVsZS5leHBvcnRzID0gYXN5bmMgKGNvbm5lY3Rpb24sIHJhbmdlLCBkZXN0aW5hdGlvbiwgb3B0aW9ucykgPT4ge1xuICAgIGlmIChjb25uZWN0aW9uLnN0YXRlICE9PSBjb25uZWN0aW9uLnN0YXRlcy5TRUxFQ1RFRCB8fCAhcmFuZ2UgfHwgIWRlc3RpbmF0aW9uKSB7XG4gICAgICAgIC8vIG5vdGhpbmcgdG8gZG8gaGVyZVxuICAgICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgb3B0aW9ucyA9IG9wdGlvbnMgfHwge307XG4gICAgZGVzdGluYXRpb24gPSBub3JtYWxpemVQYXRoKGNvbm5lY3Rpb24sIGRlc3RpbmF0aW9uKTtcblxuICAgIGxldCBhdHRyaWJ1dGVzID0gW1xuICAgICAgICB7IHR5cGU6ICdTRVFVRU5DRScsIHZhbHVlOiByYW5nZSB9LFxuICAgICAgICB7IHR5cGU6ICdBVE9NJywgdmFsdWU6IGVuY29kZVBhdGgoY29ubmVjdGlvbiwgZGVzdGluYXRpb24pIH1cbiAgICBdO1xuXG4gICAgbGV0IHJlc3BvbnNlO1xuICAgIHRyeSB7XG4gICAgICAgIHJlc3BvbnNlID0gYXdhaXQgY29ubmVjdGlvbi5leGVjKG9wdGlvbnMudWlkID8gJ1VJRCBDT1BZJyA6ICdDT1BZJywgYXR0cmlidXRlcyk7XG4gICAgICAgIHJlc3BvbnNlLm5leHQoKTtcblxuICAgICAgICBsZXQgbWFwID0geyBwYXRoOiBjb25uZWN0aW9uLm1haWxib3gucGF0aCwgZGVzdGluYXRpb24gfTtcbiAgICAgICAgbGV0IHNlY3Rpb24gPSByZXNwb25zZS5yZXNwb25zZS5hdHRyaWJ1dGVzICYmIHJlc3BvbnNlLnJlc3BvbnNlLmF0dHJpYnV0ZXNbMF0gJiYgcmVzcG9uc2UucmVzcG9uc2UuYXR0cmlidXRlc1swXS5zZWN0aW9uO1xuICAgICAgICBsZXQgcmVzcG9uc2VDb2RlID0gc2VjdGlvbiAmJiBzZWN0aW9uLmxlbmd0aCAmJiBzZWN0aW9uWzBdICYmIHR5cGVvZiBzZWN0aW9uWzBdLnZhbHVlID09PSAnc3RyaW5nJyA/IHNlY3Rpb25bMF0udmFsdWUgOiAnJztcbiAgICAgICAgc3dpdGNoIChyZXNwb25zZUNvZGUpIHtcbiAgICAgICAgICAgIGNhc2UgJ0NPUFlVSUQnOlxuICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgbGV0IHVpZFZhbGlkaXR5ID0gc2VjdGlvblsxXSAmJiB0eXBlb2Ygc2VjdGlvblsxXS52YWx1ZSA9PT0gJ3N0cmluZycgJiYgIWlzTmFOKHNlY3Rpb25bMV0udmFsdWUpID8gQmlnSW50KHNlY3Rpb25bMV0udmFsdWUpIDogZmFsc2U7XG4gICAgICAgICAgICAgICAgICAgIGlmICh1aWRWYWxpZGl0eSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgbWFwLnVpZFZhbGlkaXR5ID0gdWlkVmFsaWRpdHk7XG4gICAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgICBsZXQgc291cmNlVWlkcyA9IHNlY3Rpb25bMl0gJiYgdHlwZW9mIHNlY3Rpb25bMl0udmFsdWUgPT09ICdzdHJpbmcnID8gZXhwYW5kUmFuZ2Uoc2VjdGlvblsyXS52YWx1ZSkgOiBmYWxzZTtcbiAgICAgICAgICAgICAgICAgICAgbGV0IGRlc3RpbmF0aW9uVWlkcyA9IHNlY3Rpb25bM10gJiYgdHlwZW9mIHNlY3Rpb25bM10udmFsdWUgPT09ICdzdHJpbmcnID8gZXhwYW5kUmFuZ2Uoc2VjdGlvblszXS52YWx1ZSkgOiBmYWxzZTtcbiAgICAgICAgICAgICAgICAgICAgaWYgKHNvdXJjZVVpZHMgJiYgZGVzdGluYXRpb25VaWRzICYmIHNvdXJjZVVpZHMubGVuZ3RoID09PSBkZXN0aW5hdGlvblVpZHMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBtYXAudWlkTWFwID0gbmV3IE1hcChzb3VyY2VVaWRzLm1hcCgodWlkLCBpKSA9PiBbdWlkLCBkZXN0aW5hdGlvblVpZHNbaV1dKSk7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgYnJlYWs7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gbWFwO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICBsZXQgZXJyb3JDb2RlID0gZ2V0U3RhdHVzQ29kZShlcnIucmVzcG9uc2UpO1xuICAgICAgICBpZiAoZXJyb3JDb2RlKSB7XG4gICAgICAgICAgICBlcnIuc2VydmVyUmVzcG9uc2VDb2RlID0gZXJyb3JDb2RlO1xuICAgICAgICB9XG4gICAgICAgIGVyci5yZXNwb25zZSA9IGF3YWl0IGdldEVycm9yVGV4dChlcnIucmVzcG9uc2UpO1xuXG4gICAgICAgIGNvbm5lY3Rpb24ubG9nLndhcm4oeyBlcnIsIGNpZDogY29ubmVjdGlvbi5pZCB9KTtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbn07XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/copy.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/create.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/create.js ***!
|
|
\******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { encodePath, normalizePath, getStatusCode, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(rsc)/./node_modules/imapflow/lib/tools.js\");\n\n// Creates a new mailbox\nmodule.exports = async (connection, path) => {\n if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state)) {\n // nothing to do here\n return;\n }\n\n path = normalizePath(connection, path);\n\n let response;\n try {\n let map = {\n path\n };\n response = await connection.exec('CREATE', [{ type: 'ATOM', value: encodePath(connection, path) }]);\n\n let section =\n response.response.attributes &&\n response.response.attributes[0] &&\n response.response.attributes[0].section &&\n response.response.attributes[0].section.length\n ? response.response.attributes[0].section\n : false;\n\n if (section) {\n let key;\n section.forEach((attribute, i) => {\n if (i % 2 === 0) {\n key = attribute && typeof attribute.value === 'string' ? attribute.value : false;\n return;\n }\n\n if (!key) {\n return;\n }\n\n let value;\n switch (key.toLowerCase()) {\n case 'mailboxid':\n key = 'mailboxId';\n value = Array.isArray(attribute) && attribute[0] && typeof attribute[0].value === 'string' ? attribute[0].value : false;\n break;\n }\n\n if (key && value) {\n map[key] = value;\n }\n });\n }\n\n map.created = true;\n response.next();\n\n //make sure we are subscribed to the new folder as well\n await connection.run('SUBSCRIBE', path);\n\n return map;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n switch (errorCode) {\n case 'ALREADYEXISTS':\n // no need to do anything, mailbox already exists\n return {\n path,\n created: false\n };\n }\n\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n\n connection.log.warn({ err, cid: connection.id });\n throw err;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL2NyZWF0ZS5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYixRQUFRLHlEQUF5RCxFQUFFLG1CQUFPLENBQUMsK0RBQWE7O0FBRXhGO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esc0RBQXNELG1EQUFtRDs7QUFFekc7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQSw4QkFBOEIseUJBQXlCO0FBQ3ZEO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL2NyZWF0ZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IHsgZW5jb2RlUGF0aCwgbm9ybWFsaXplUGF0aCwgZ2V0U3RhdHVzQ29kZSwgZ2V0RXJyb3JUZXh0IH0gPSByZXF1aXJlKCcuLi90b29scy5qcycpO1xuXG4vLyBDcmVhdGVzIGEgbmV3IG1haWxib3hcbm1vZHVsZS5leHBvcnRzID0gYXN5bmMgKGNvbm5lY3Rpb24sIHBhdGgpID0+IHtcbiAgICBpZiAoIVtjb25uZWN0aW9uLnN0YXRlcy5BVVRIRU5USUNBVEVELCBjb25uZWN0aW9uLnN0YXRlcy5TRUxFQ1RFRF0uaW5jbHVkZXMoY29ubmVjdGlvbi5zdGF0ZSkpIHtcbiAgICAgICAgLy8gbm90aGluZyB0byBkbyBoZXJlXG4gICAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBwYXRoID0gbm9ybWFsaXplUGF0aChjb25uZWN0aW9uLCBwYXRoKTtcblxuICAgIGxldCByZXNwb25zZTtcbiAgICB0cnkge1xuICAgICAgICBsZXQgbWFwID0ge1xuICAgICAgICAgICAgcGF0aFxuICAgICAgICB9O1xuICAgICAgICByZXNwb25zZSA9IGF3YWl0IGNvbm5lY3Rpb24uZXhlYygnQ1JFQVRFJywgW3sgdHlwZTogJ0FUT00nLCB2YWx1ZTogZW5jb2RlUGF0aChjb25uZWN0aW9uLCBwYXRoKSB9XSk7XG5cbiAgICAgICAgbGV0IHNlY3Rpb24gPVxuICAgICAgICAgICAgcmVzcG9uc2UucmVzcG9uc2UuYXR0cmlidXRlcyAmJlxuICAgICAgICAgICAgcmVzcG9uc2UucmVzcG9uc2UuYXR0cmlidXRlc1swXSAmJlxuICAgICAgICAgICAgcmVzcG9uc2UucmVzcG9uc2UuYXR0cmlidXRlc1swXS5zZWN0aW9uICYmXG4gICAgICAgICAgICByZXNwb25zZS5yZXNwb25zZS5hdHRyaWJ1dGVzWzBdLnNlY3Rpb24ubGVuZ3RoXG4gICAgICAgICAgICAgICAgPyByZXNwb25zZS5yZXNwb25zZS5hdHRyaWJ1dGVzWzBdLnNlY3Rpb25cbiAgICAgICAgICAgICAgICA6IGZhbHNlO1xuXG4gICAgICAgIGlmIChzZWN0aW9uKSB7XG4gICAgICAgICAgICBsZXQga2V5O1xuICAgICAgICAgICAgc2VjdGlvbi5mb3JFYWNoKChhdHRyaWJ1dGUsIGkpID0+IHtcbiAgICAgICAgICAgICAgICBpZiAoaSAlIDIgPT09IDApIHtcbiAgICAgICAgICAgICAgICAgICAga2V5ID0gYXR0cmlidXRlICYmIHR5cGVvZiBhdHRyaWJ1dGUudmFsdWUgPT09ICdzdHJpbmcnID8gYXR0cmlidXRlLnZhbHVlIDogZmFsc2U7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICBpZiAoIWtleSkge1xuICAgICAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgbGV0IHZhbHVlO1xuICAgICAgICAgICAgICAgIHN3aXRjaCAoa2V5LnRvTG93ZXJDYXNlKCkpIHtcbiAgICAgICAgICAgICAgICAgICAgY2FzZSAnbWFpbGJveGlkJzpcbiAgICAgICAgICAgICAgICAgICAgICAgIGtleSA9ICdtYWlsYm94SWQnO1xuICAgICAgICAgICAgICAgICAgICAgICAgdmFsdWUgPSBBcnJheS5pc0FycmF5KGF0dHJpYnV0ZSkgJiYgYXR0cmlidXRlWzBdICYmIHR5cGVvZiBhdHRyaWJ1dGVbMF0udmFsdWUgPT09ICdzdHJpbmcnID8gYXR0cmlidXRlWzBdLnZhbHVlIDogZmFsc2U7XG4gICAgICAgICAgICAgICAgICAgICAgICBicmVhaztcbiAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICBpZiAoa2V5ICYmIHZhbHVlKSB7XG4gICAgICAgICAgICAgICAgICAgIG1hcFtrZXldID0gdmFsdWU7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfSk7XG4gICAgICAgIH1cblxuICAgICAgICBtYXAuY3JlYXRlZCA9IHRydWU7XG4gICAgICAgIHJlc3BvbnNlLm5leHQoKTtcblxuICAgICAgICAvL21ha2Ugc3VyZSB3ZSBhcmUgc3Vic2NyaWJlZCB0byB0aGUgbmV3IGZvbGRlciBhcyB3ZWxsXG4gICAgICAgIGF3YWl0IGNvbm5lY3Rpb24ucnVuKCdTVUJTQ1JJQkUnLCBwYXRoKTtcblxuICAgICAgICByZXR1cm4gbWFwO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICBsZXQgZXJyb3JDb2RlID0gZ2V0U3RhdHVzQ29kZShlcnIucmVzcG9uc2UpO1xuICAgICAgICBpZiAoZXJyb3JDb2RlKSB7XG4gICAgICAgICAgICBlcnIuc2VydmVyUmVzcG9uc2VDb2RlID0gZXJyb3JDb2RlO1xuICAgICAgICB9XG4gICAgICAgIGVyci5yZXNwb25zZSA9IGF3YWl0IGdldEVycm9yVGV4dChlcnIucmVzcG9uc2UpO1xuXG4gICAgICAgIHN3aXRjaCAoZXJyb3JDb2RlKSB7XG4gICAgICAgICAgICBjYXNlICdBTFJFQURZRVhJU1RTJzpcbiAgICAgICAgICAgICAgICAvLyBubyBuZWVkIHRvIGRvIGFueXRoaW5nLCBtYWlsYm94IGFscmVhZHkgZXhpc3RzXG4gICAgICAgICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgICAgICAgICAgcGF0aCxcbiAgICAgICAgICAgICAgICAgICAgY3JlYXRlZDogZmFsc2VcbiAgICAgICAgICAgICAgICB9O1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKGVycm9yQ29kZSkge1xuICAgICAgICAgICAgZXJyLnNlcnZlclJlc3BvbnNlQ29kZSA9IGVycm9yQ29kZTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbm5lY3Rpb24ubG9nLndhcm4oeyBlcnIsIGNpZDogY29ubmVjdGlvbi5pZCB9KTtcbiAgICAgICAgdGhyb3cgZXJyO1xuICAgIH1cbn07XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/create.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/delete.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/delete.js ***!
|
|
\******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { encodePath, normalizePath, getStatusCode, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(rsc)/./node_modules/imapflow/lib/tools.js\");\n\n// Deletes an existing mailbox\nmodule.exports = async (connection, path) => {\n if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state)) {\n // nothing to do here\n return;\n }\n\n path = normalizePath(connection, path);\n\n if (connection.states.SELECTED && connection.mailbox.path === path) {\n await connection.run('CLOSE');\n }\n\n let response;\n try {\n let map = {\n path\n };\n response = await connection.exec('DELETE', [{ type: 'ATOM', value: encodePath(connection, path) }]);\n response.next();\n return map;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n throw err;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL2RlbGV0ZS5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYixRQUFRLHlEQUF5RCxFQUFFLG1CQUFPLENBQUMsK0RBQWE7O0FBRXhGO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHNEQUFzRCxtREFBbUQ7QUFDekc7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDhCQUE4Qix5QkFBeUI7QUFDdkQ7QUFDQTtBQUNBIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvZGVsZXRlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgeyBlbmNvZGVQYXRoLCBub3JtYWxpemVQYXRoLCBnZXRTdGF0dXNDb2RlLCBnZXRFcnJvclRleHQgfSA9IHJlcXVpcmUoJy4uL3Rvb2xzLmpzJyk7XG5cbi8vIERlbGV0ZXMgYW4gZXhpc3RpbmcgbWFpbGJveFxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyAoY29ubmVjdGlvbiwgcGF0aCkgPT4ge1xuICAgIGlmICghW2Nvbm5lY3Rpb24uc3RhdGVzLkFVVEhFTlRJQ0FURUQsIGNvbm5lY3Rpb24uc3RhdGVzLlNFTEVDVEVEXS5pbmNsdWRlcyhjb25uZWN0aW9uLnN0YXRlKSkge1xuICAgICAgICAvLyBub3RoaW5nIHRvIGRvIGhlcmVcbiAgICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIHBhdGggPSBub3JtYWxpemVQYXRoKGNvbm5lY3Rpb24sIHBhdGgpO1xuXG4gICAgaWYgKGNvbm5lY3Rpb24uc3RhdGVzLlNFTEVDVEVEICYmIGNvbm5lY3Rpb24ubWFpbGJveC5wYXRoID09PSBwYXRoKSB7XG4gICAgICAgIGF3YWl0IGNvbm5lY3Rpb24ucnVuKCdDTE9TRScpO1xuICAgIH1cblxuICAgIGxldCByZXNwb25zZTtcbiAgICB0cnkge1xuICAgICAgICBsZXQgbWFwID0ge1xuICAgICAgICAgICAgcGF0aFxuICAgICAgICB9O1xuICAgICAgICByZXNwb25zZSA9IGF3YWl0IGNvbm5lY3Rpb24uZXhlYygnREVMRVRFJywgW3sgdHlwZTogJ0FUT00nLCB2YWx1ZTogZW5jb2RlUGF0aChjb25uZWN0aW9uLCBwYXRoKSB9XSk7XG4gICAgICAgIHJlc3BvbnNlLm5leHQoKTtcbiAgICAgICAgcmV0dXJuIG1hcDtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgbGV0IGVycm9yQ29kZSA9IGdldFN0YXR1c0NvZGUoZXJyLnJlc3BvbnNlKTtcbiAgICAgICAgaWYgKGVycm9yQ29kZSkge1xuICAgICAgICAgICAgZXJyLnNlcnZlclJlc3BvbnNlQ29kZSA9IGVycm9yQ29kZTtcbiAgICAgICAgfVxuICAgICAgICBlcnIucmVzcG9uc2UgPSBhd2FpdCBnZXRFcnJvclRleHQoZXJyLnJlc3BvbnNlKTtcblxuICAgICAgICBjb25uZWN0aW9uLmxvZy53YXJuKHsgZXJyLCBjaWQ6IGNvbm5lY3Rpb24uaWQgfSk7XG4gICAgICAgIHRocm93IGVycjtcbiAgICB9XG59O1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/delete.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/enable.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/enable.js ***!
|
|
\******************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\n// Enables extensions\nmodule.exports = async (connection, extensionList) => {\n if (!connection.capabilities.has('ENABLE') || connection.state !== connection.states.AUTHENTICATED) {\n // nothing to do here\n return;\n }\n\n extensionList = extensionList.filter(extension => connection.capabilities.has(extension.toUpperCase()));\n if (!extensionList.length) {\n return;\n }\n\n let response;\n try {\n let enabled = new Set();\n response = await connection.exec(\n 'ENABLE',\n extensionList.map(extension => ({ type: 'ATOM', value: extension.toUpperCase() })),\n {\n untagged: {\n ENABLED: async untagged => {\n if (!untagged.attributes || !untagged.attributes.length) {\n return;\n }\n untagged.attributes.forEach(attr => {\n if (attr.value && typeof attr.value === 'string') {\n enabled.add(attr.value.toUpperCase().trim());\n }\n });\n }\n }\n }\n );\n connection.enabled = enabled;\n response.next();\n return enabled;\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL2VuYWJsZS5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDhDQUE4Qyw4Q0FBOEM7QUFDNUY7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx5QkFBeUI7QUFDekI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ04sOEJBQThCLHlCQUF5QjtBQUN2RDtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L2xpYi9jb21tYW5kcy9lbmFibGUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG4vLyBFbmFibGVzIGV4dGVuc2lvbnNcbm1vZHVsZS5leHBvcnRzID0gYXN5bmMgKGNvbm5lY3Rpb24sIGV4dGVuc2lvbkxpc3QpID0+IHtcbiAgICBpZiAoIWNvbm5lY3Rpb24uY2FwYWJpbGl0aWVzLmhhcygnRU5BQkxFJykgfHwgY29ubmVjdGlvbi5zdGF0ZSAhPT0gY29ubmVjdGlvbi5zdGF0ZXMuQVVUSEVOVElDQVRFRCkge1xuICAgICAgICAvLyBub3RoaW5nIHRvIGRvIGhlcmVcbiAgICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGV4dGVuc2lvbkxpc3QgPSBleHRlbnNpb25MaXN0LmZpbHRlcihleHRlbnNpb24gPT4gY29ubmVjdGlvbi5jYXBhYmlsaXRpZXMuaGFzKGV4dGVuc2lvbi50b1VwcGVyQ2FzZSgpKSk7XG4gICAgaWYgKCFleHRlbnNpb25MaXN0Lmxlbmd0aCkge1xuICAgICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgbGV0IHJlc3BvbnNlO1xuICAgIHRyeSB7XG4gICAgICAgIGxldCBlbmFibGVkID0gbmV3IFNldCgpO1xuICAgICAgICByZXNwb25zZSA9IGF3YWl0IGNvbm5lY3Rpb24uZXhlYyhcbiAgICAgICAgICAgICdFTkFCTEUnLFxuICAgICAgICAgICAgZXh0ZW5zaW9uTGlzdC5tYXAoZXh0ZW5zaW9uID0+ICh7IHR5cGU6ICdBVE9NJywgdmFsdWU6IGV4dGVuc2lvbi50b1VwcGVyQ2FzZSgpIH0pKSxcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICB1bnRhZ2dlZDoge1xuICAgICAgICAgICAgICAgICAgICBFTkFCTEVEOiBhc3luYyB1bnRhZ2dlZCA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAoIXVudGFnZ2VkLmF0dHJpYnV0ZXMgfHwgIXVudGFnZ2VkLmF0dHJpYnV0ZXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICAgICAgdW50YWdnZWQuYXR0cmlidXRlcy5mb3JFYWNoKGF0dHIgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmIChhdHRyLnZhbHVlICYmIHR5cGVvZiBhdHRyLnZhbHVlID09PSAnc3RyaW5nJykge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBlbmFibGVkLmFkZChhdHRyLnZhbHVlLnRvVXBwZXJDYXNlKCkudHJpbSgpKTtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgKTtcbiAgICAgICAgY29ubmVjdGlvbi5lbmFibGVkID0gZW5hYmxlZDtcbiAgICAgICAgcmVzcG9uc2UubmV4dCgpO1xuICAgICAgICByZXR1cm4gZW5hYmxlZDtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgY29ubmVjdGlvbi5sb2cud2Fybih7IGVyciwgY2lkOiBjb25uZWN0aW9uLmlkIH0pO1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxufTtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/enable.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/expunge.js":
|
|
/*!*******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/expunge.js ***!
|
|
\*******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { getStatusCode, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(rsc)/./node_modules/imapflow/lib/tools.js\");\n\n// Deletes specified messages\nmodule.exports = async (connection, range, options) => {\n if (connection.state !== connection.states.SELECTED || !range) {\n // nothing to do here\n return;\n }\n\n options = options || {};\n\n await connection.messageFlagsAdd(range, ['\\\\Deleted'], options);\n\n let byUid = options.uid && connection.capabilities.has('UIDPLUS');\n let command = byUid ? 'UID EXPUNGE' : 'EXPUNGE';\n let attributes = byUid ? [{ type: 'SEQUENCE', value: range }] : false;\n\n let response;\n try {\n response = await connection.exec(command, attributes);\n\n // A OK [HIGHESTMODSEQ 9122] Expunge completed (0.010 + 0.000 + 0.012 secs).\n let section = response.response.attributes && response.response.attributes[0] && response.response.attributes[0].section;\n let responseCode = section && section.length && section[0] && typeof section[0].value === 'string' ? section[0].value : '';\n if (responseCode.toUpperCase() === 'HIGHESTMODSEQ') {\n let highestModseq = section[1] && typeof section[1].value === 'string' && !isNaN(section[1].value) ? BigInt(section[1].value) : false;\n if (highestModseq && (!connection.mailbox.highestModseq || highestModseq > connection.mailbox.highestModseq)) {\n connection.mailbox.highestModseq = highestModseq;\n }\n }\n\n response.next();\n return true;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL2V4cHVuZ2UuanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWIsUUFBUSw4QkFBOEIsRUFBRSxtQkFBTyxDQUFDLCtEQUFhOztBQUU3RDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTtBQUNBLGdDQUFnQyxnQ0FBZ0M7O0FBRWhFO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDhCQUE4Qix5QkFBeUI7QUFDdkQ7QUFDQTtBQUNBIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvZXhwdW5nZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IHsgZ2V0U3RhdHVzQ29kZSwgZ2V0RXJyb3JUZXh0IH0gPSByZXF1aXJlKCcuLi90b29scy5qcycpO1xuXG4vLyBEZWxldGVzIHNwZWNpZmllZCBtZXNzYWdlc1xubW9kdWxlLmV4cG9ydHMgPSBhc3luYyAoY29ubmVjdGlvbiwgcmFuZ2UsIG9wdGlvbnMpID0+IHtcbiAgICBpZiAoY29ubmVjdGlvbi5zdGF0ZSAhPT0gY29ubmVjdGlvbi5zdGF0ZXMuU0VMRUNURUQgfHwgIXJhbmdlKSB7XG4gICAgICAgIC8vIG5vdGhpbmcgdG8gZG8gaGVyZVxuICAgICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgb3B0aW9ucyA9IG9wdGlvbnMgfHwge307XG5cbiAgICBhd2FpdCBjb25uZWN0aW9uLm1lc3NhZ2VGbGFnc0FkZChyYW5nZSwgWydcXFxcRGVsZXRlZCddLCBvcHRpb25zKTtcblxuICAgIGxldCBieVVpZCA9IG9wdGlvbnMudWlkICYmIGNvbm5lY3Rpb24uY2FwYWJpbGl0aWVzLmhhcygnVUlEUExVUycpO1xuICAgIGxldCBjb21tYW5kID0gYnlVaWQgPyAnVUlEIEVYUFVOR0UnIDogJ0VYUFVOR0UnO1xuICAgIGxldCBhdHRyaWJ1dGVzID0gYnlVaWQgPyBbeyB0eXBlOiAnU0VRVUVOQ0UnLCB2YWx1ZTogcmFuZ2UgfV0gOiBmYWxzZTtcblxuICAgIGxldCByZXNwb25zZTtcbiAgICB0cnkge1xuICAgICAgICByZXNwb25zZSA9IGF3YWl0IGNvbm5lY3Rpb24uZXhlYyhjb21tYW5kLCBhdHRyaWJ1dGVzKTtcblxuICAgICAgICAvLyBBIE9LIFtISUdIRVNUTU9EU0VRIDkxMjJdIEV4cHVuZ2UgY29tcGxldGVkICgwLjAxMCArIDAuMDAwICsgMC4wMTIgc2VjcykuXG4gICAgICAgIGxldCBzZWN0aW9uID0gcmVzcG9uc2UucmVzcG9uc2UuYXR0cmlidXRlcyAmJiByZXNwb25zZS5yZXNwb25zZS5hdHRyaWJ1dGVzWzBdICYmIHJlc3BvbnNlLnJlc3BvbnNlLmF0dHJpYnV0ZXNbMF0uc2VjdGlvbjtcbiAgICAgICAgbGV0IHJlc3BvbnNlQ29kZSA9IHNlY3Rpb24gJiYgc2VjdGlvbi5sZW5ndGggJiYgc2VjdGlvblswXSAmJiB0eXBlb2Ygc2VjdGlvblswXS52YWx1ZSA9PT0gJ3N0cmluZycgPyBzZWN0aW9uWzBdLnZhbHVlIDogJyc7XG4gICAgICAgIGlmIChyZXNwb25zZUNvZGUudG9VcHBlckNhc2UoKSA9PT0gJ0hJR0hFU1RNT0RTRVEnKSB7XG4gICAgICAgICAgICBsZXQgaGlnaGVzdE1vZHNlcSA9IHNlY3Rpb25bMV0gJiYgdHlwZW9mIHNlY3Rpb25bMV0udmFsdWUgPT09ICdzdHJpbmcnICYmICFpc05hTihzZWN0aW9uWzFdLnZhbHVlKSA/IEJpZ0ludChzZWN0aW9uWzFdLnZhbHVlKSA6IGZhbHNlO1xuICAgICAgICAgICAgaWYgKGhpZ2hlc3RNb2RzZXEgJiYgKCFjb25uZWN0aW9uLm1haWxib3guaGlnaGVzdE1vZHNlcSB8fCBoaWdoZXN0TW9kc2VxID4gY29ubmVjdGlvbi5tYWlsYm94LmhpZ2hlc3RNb2RzZXEpKSB7XG4gICAgICAgICAgICAgICAgY29ubmVjdGlvbi5tYWlsYm94LmhpZ2hlc3RNb2RzZXEgPSBoaWdoZXN0TW9kc2VxO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmVzcG9uc2UubmV4dCgpO1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgbGV0IGVycm9yQ29kZSA9IGdldFN0YXR1c0NvZGUoZXJyLnJlc3BvbnNlKTtcbiAgICAgICAgaWYgKGVycm9yQ29kZSkge1xuICAgICAgICAgICAgZXJyLnNlcnZlclJlc3BvbnNlQ29kZSA9IGVycm9yQ29kZTtcbiAgICAgICAgfVxuICAgICAgICBlcnIucmVzcG9uc2UgPSBhd2FpdCBnZXRFcnJvclRleHQoZXJyLnJlc3BvbnNlKTtcblxuICAgICAgICBjb25uZWN0aW9uLmxvZy53YXJuKHsgZXJyLCBjaWQ6IGNvbm5lY3Rpb24uaWQgfSk7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG59O1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/expunge.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/fetch.js":
|
|
/*!*****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/fetch.js ***!
|
|
\*****************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { formatMessageResponse } = __webpack_require__(/*! ../tools */ \"(rsc)/./node_modules/imapflow/lib/tools.js\");\n\n// Fetches emails from server\nmodule.exports = async (connection, range, query, options) => {\n if (connection.state !== connection.states.SELECTED || !range) {\n // nothing to do here\n return;\n }\n\n options = options || {};\n\n let mailbox = connection.mailbox;\n\n const commandKey = connection.capabilities.has('BINARY') && options.binary && !connection.disableBinary ? 'BINARY' : 'BODY';\n\n let retryCount = 0;\n while (retryCount < 4) {\n let messages = {\n count: 0,\n list: []\n };\n\n let response;\n try {\n let attributes = [{ type: 'SEQUENCE', value: (range || '*').toString() }];\n\n let queryStructure = [];\n\n let setBodyPeek = (attributes, partial) => {\n let bodyPeek = {\n type: 'ATOM',\n value: `${commandKey}.PEEK`,\n section: [],\n partial\n };\n\n if (Array.isArray(attributes)) {\n attributes.forEach(attribute => {\n bodyPeek.section.push(attribute);\n });\n } else if (attributes) {\n bodyPeek.section.push(attributes);\n }\n\n queryStructure.push(bodyPeek);\n };\n\n ['all', 'fast', 'full', 'uid', 'flags', 'bodyStructure', 'envelope', 'internalDate'].forEach(key => {\n if (query[key]) {\n queryStructure.push({ type: 'ATOM', value: key.toUpperCase() });\n }\n });\n\n if (query.size) {\n queryStructure.push({ type: 'ATOM', value: 'RFC822.SIZE' });\n }\n\n if (query.source) {\n let partial;\n if (typeof query.source === 'object' && (query.source.start || query.source.maxLength)) {\n partial = [Number(query.source.start) || 0];\n if (query.source.maxLength && !isNaN(query.source.maxLength)) {\n partial.push(Number(query.source.maxLength));\n }\n }\n queryStructure.push({ type: 'ATOM', value: `${commandKey}.PEEK`, section: [], partial });\n }\n\n // if possible, always request for unique email id\n if (connection.capabilities.has('OBJECTID')) {\n queryStructure.push({ type: 'ATOM', value: 'EMAILID' });\n } else if (connection.capabilities.has('X-GM-EXT-1')) {\n queryStructure.push({ type: 'ATOM', value: 'X-GM-MSGID' });\n }\n\n if (query.threadId) {\n if (connection.capabilities.has('OBJECTID')) {\n queryStructure.push({ type: 'ATOM', value: 'THREADID' });\n } else if (connection.capabilities.has('X-GM-EXT-1')) {\n queryStructure.push({ type: 'ATOM', value: 'X-GM-THRID' });\n }\n }\n\n if (query.labels) {\n if (connection.capabilities.has('X-GM-EXT-1')) {\n queryStructure.push({ type: 'ATOM', value: 'X-GM-LABELS' });\n }\n }\n\n // always ask for modseq if possible\n if (connection.enabled.has('CONDSTORE') && !mailbox.noModseq) {\n queryStructure.push({ type: 'ATOM', value: 'MODSEQ' });\n }\n\n // always make sure to include UID in the request as well even though server might auto-add it itself\n if (!query.uid) {\n queryStructure.push({ type: 'ATOM', value: 'UID' });\n }\n\n if (query.headers) {\n if (Array.isArray(query.headers)) {\n setBodyPeek([{ type: 'ATOM', value: 'HEADER.FIELDS' }, query.headers.map(header => ({ type: 'ATOM', value: header }))]);\n } else {\n setBodyPeek({ type: 'ATOM', value: 'HEADER' });\n }\n }\n\n if (query.bodyParts && query.bodyParts.length) {\n query.bodyParts.forEach(part => {\n if (!part) {\n return;\n }\n let key;\n let partial;\n if (typeof part === 'object') {\n if (!part.key || typeof part.key !== 'string') {\n return;\n }\n key = part.key.toUpperCase();\n if (part.start || part.maxLength) {\n partial = [Number(part.start) || 0];\n if (part.maxLength && !isNaN(part.maxLength)) {\n partial.push(Number(part.maxLength));\n }\n }\n } else if (typeof part === 'string') {\n key = part.toUpperCase();\n } else {\n return;\n }\n\n setBodyPeek({ type: 'ATOM', value: key }, partial);\n });\n }\n\n if (queryStructure.length === 1) {\n queryStructure = queryStructure.pop();\n }\n\n attributes.push(queryStructure);\n\n if (options.changedSince && connection.enabled.has('CONDSTORE') && !mailbox.noModseq) {\n let changedSinceArgs = [\n {\n type: 'ATOM',\n value: 'CHANGEDSINCE'\n },\n {\n type: 'ATOM',\n value: options.changedSince.toString()\n }\n ];\n\n if (options.uid && connection.enabled.has('QRESYNC')) {\n changedSinceArgs.push({\n type: 'ATOM',\n value: 'VANISHED'\n });\n }\n\n attributes.push(changedSinceArgs);\n }\n\n response = await connection.exec(options.uid ? 'UID FETCH' : 'FETCH', attributes, {\n untagged: {\n FETCH: async untagged => {\n messages.count++;\n let formatted = await formatMessageResponse(untagged, mailbox);\n if (typeof options.onUntaggedFetch === 'function') {\n await new Promise((resolve, reject) => {\n options.onUntaggedFetch(formatted, err => {\n if (err) {\n reject(err);\n } else {\n resolve();\n }\n });\n });\n } else {\n messages.list.push(formatted);\n }\n }\n }\n });\n\n response.next();\n return messages;\n } catch (err) {\n if (err.code === 'ETHROTTLE') {\n // retrying\n connection.log.warn({\n msg: 'Retrying throttled request',\n cid: connection.id,\n code: err.code,\n response: err.responseText,\n throttleReset: err.throttleReset,\n retryCount\n });\n retryCount++;\n continue;\n }\n\n connection.log.warn({ err, cid: connection.id });\n throw err;\n }\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/imapflow/lib/commands/fetch.js","mappings":"AAAa;;AAEb,QAAQ,wBAAwB,EAAE,mBAAO,CAAC,4DAAU;;AAEpD;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,gCAAgC,oDAAoD;;AAEpF;;AAEA;AACA;AACA;AACA,8BAA8B,WAAW;AACzC;AACA;AACA;;AAEA;AACA;AACA;AACA,qBAAqB;AACrB,kBAAkB;AAClB;AACA;;AAEA;AACA;;AAEA;AACA;AACA,0CAA0C,wCAAwC;AAClF;AACA,aAAa;;AAEb;AACA,sCAAsC,oCAAoC;AAC1E;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sCAAsC,wBAAwB,WAAW,8BAA8B;AACvG;;AAEA;AACA;AACA,sCAAsC,gCAAgC;AACtE,cAAc;AACd,sCAAsC,mCAAmC;AACzE;;AAEA;AACA;AACA,0CAA0C,iCAAiC;AAC3E,kBAAkB;AAClB,0CAA0C,mCAAmC;AAC7E;AACA;;AAEA;AACA;AACA,0CAA0C,oCAAoC;AAC9E;AACA;;AAEA;AACA;AACA,sCAAsC,+BAA+B;AACrE;;AAEA;AACA;AACA,sCAAsC,4BAA4B;AAClE;;AAEA;AACA;AACA,mCAAmC,sCAAsC,iCAAiC,6BAA6B;AACvI,kBAAkB;AAClB,kCAAkC,+BAA+B;AACjE;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA,sBAAsB;AACtB;AACA;;AAEA,kCAAkC,0BAA0B;AAC5D,iBAAiB;AACjB;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sCAAsC;AACtC;AACA;AACA,iCAAiC;AACjC,6BAA6B;AAC7B,0BAA0B;AAC1B;AACA;AACA;AACA;AACA,aAAa;;AAEb;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;;AAEA,kCAAkC,yBAAyB;AAC3D;AACA;AACA;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/commands/fetch.js"],"sourcesContent":["'use strict';\n\nconst { formatMessageResponse } = require('../tools');\n\n// Fetches emails from server\nmodule.exports = async (connection, range, query, options) => {\n    if (connection.state !== connection.states.SELECTED || !range) {\n        // nothing to do here\n        return;\n    }\n\n    options = options || {};\n\n    let mailbox = connection.mailbox;\n\n    const commandKey = connection.capabilities.has('BINARY') && options.binary && !connection.disableBinary ? 'BINARY' : 'BODY';\n\n    let retryCount = 0;\n    while (retryCount < 4) {\n        let messages = {\n            count: 0,\n            list: []\n        };\n\n        let response;\n        try {\n            let attributes = [{ type: 'SEQUENCE', value: (range || '*').toString() }];\n\n            let queryStructure = [];\n\n            let setBodyPeek = (attributes, partial) => {\n                let bodyPeek = {\n                    type: 'ATOM',\n                    value: `${commandKey}.PEEK`,\n                    section: [],\n                    partial\n                };\n\n                if (Array.isArray(attributes)) {\n                    attributes.forEach(attribute => {\n                        bodyPeek.section.push(attribute);\n                    });\n                } else if (attributes) {\n                    bodyPeek.section.push(attributes);\n                }\n\n                queryStructure.push(bodyPeek);\n            };\n\n            ['all', 'fast', 'full', 'uid', 'flags', 'bodyStructure', 'envelope', 'internalDate'].forEach(key => {\n                if (query[key]) {\n                    queryStructure.push({ type: 'ATOM', value: key.toUpperCase() });\n                }\n            });\n\n            if (query.size) {\n                queryStructure.push({ type: 'ATOM', value: 'RFC822.SIZE' });\n            }\n\n            if (query.source) {\n                let partial;\n                if (typeof query.source === 'object' && (query.source.start || query.source.maxLength)) {\n                    partial = [Number(query.source.start) || 0];\n                    if (query.source.maxLength && !isNaN(query.source.maxLength)) {\n                        partial.push(Number(query.source.maxLength));\n                    }\n                }\n                queryStructure.push({ type: 'ATOM', value: `${commandKey}.PEEK`, section: [], partial });\n            }\n\n            // if possible, always request for unique email id\n            if (connection.capabilities.has('OBJECTID')) {\n                queryStructure.push({ type: 'ATOM', value: 'EMAILID' });\n            } else if (connection.capabilities.has('X-GM-EXT-1')) {\n                queryStructure.push({ type: 'ATOM', value: 'X-GM-MSGID' });\n            }\n\n            if (query.threadId) {\n                if (connection.capabilities.has('OBJECTID')) {\n                    queryStructure.push({ type: 'ATOM', value: 'THREADID' });\n                } else if (connection.capabilities.has('X-GM-EXT-1')) {\n                    queryStructure.push({ type: 'ATOM', value: 'X-GM-THRID' });\n                }\n            }\n\n            if (query.labels) {\n                if (connection.capabilities.has('X-GM-EXT-1')) {\n                    queryStructure.push({ type: 'ATOM', value: 'X-GM-LABELS' });\n                }\n            }\n\n            // always ask for modseq if possible\n            if (connection.enabled.has('CONDSTORE') && !mailbox.noModseq) {\n                queryStructure.push({ type: 'ATOM', value: 'MODSEQ' });\n            }\n\n            // always make sure to include UID in the request as well even though server might auto-add it itself\n            if (!query.uid) {\n                queryStructure.push({ type: 'ATOM', value: 'UID' });\n            }\n\n            if (query.headers) {\n                if (Array.isArray(query.headers)) {\n                    setBodyPeek([{ type: 'ATOM', value: 'HEADER.FIELDS' }, query.headers.map(header => ({ type: 'ATOM', value: header }))]);\n                } else {\n                    setBodyPeek({ type: 'ATOM', value: 'HEADER' });\n                }\n            }\n\n            if (query.bodyParts && query.bodyParts.length) {\n                query.bodyParts.forEach(part => {\n                    if (!part) {\n                        return;\n                    }\n                    let key;\n                    let partial;\n                    if (typeof part === 'object') {\n                        if (!part.key || typeof part.key !== 'string') {\n                            return;\n                        }\n                        key = part.key.toUpperCase();\n                        if (part.start || part.maxLength) {\n                            partial = [Number(part.start) || 0];\n                            if (part.maxLength && !isNaN(part.maxLength)) {\n                                partial.push(Number(part.maxLength));\n                            }\n                        }\n                    } else if (typeof part === 'string') {\n                        key = part.toUpperCase();\n                    } else {\n                        return;\n                    }\n\n                    setBodyPeek({ type: 'ATOM', value: key }, partial);\n                });\n            }\n\n            if (queryStructure.length === 1) {\n                queryStructure = queryStructure.pop();\n            }\n\n            attributes.push(queryStructure);\n\n            if (options.changedSince && connection.enabled.has('CONDSTORE') && !mailbox.noModseq) {\n                let changedSinceArgs = [\n                    {\n                        type: 'ATOM',\n                        value: 'CHANGEDSINCE'\n                    },\n                    {\n                        type: 'ATOM',\n                        value: options.changedSince.toString()\n                    }\n                ];\n\n                if (options.uid && connection.enabled.has('QRESYNC')) {\n                    changedSinceArgs.push({\n                        type: 'ATOM',\n                        value: 'VANISHED'\n                    });\n                }\n\n                attributes.push(changedSinceArgs);\n            }\n\n            response = await connection.exec(options.uid ? 'UID FETCH' : 'FETCH', attributes, {\n                untagged: {\n                    FETCH: async untagged => {\n                        messages.count++;\n                        let formatted = await formatMessageResponse(untagged, mailbox);\n                        if (typeof options.onUntaggedFetch === 'function') {\n                            await new Promise((resolve, reject) => {\n                                options.onUntaggedFetch(formatted, err => {\n                                    if (err) {\n                                        reject(err);\n                                    } else {\n                                        resolve();\n                                    }\n                                });\n                            });\n                        } else {\n                            messages.list.push(formatted);\n                        }\n                    }\n                }\n            });\n\n            response.next();\n            return messages;\n        } catch (err) {\n            if (err.code === 'ETHROTTLE') {\n                // retrying\n                connection.log.warn({\n                    msg: 'Retrying throttled request',\n                    cid: connection.id,\n                    code: err.code,\n                    response: err.responseText,\n                    throttleReset: err.throttleReset,\n                    retryCount\n                });\n                retryCount++;\n                continue;\n            }\n\n            connection.log.warn({ err, cid: connection.id });\n            throw err;\n        }\n    }\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/fetch.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/id.js":
|
|
/*!**************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/id.js ***!
|
|
\**************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { formatDateTime } = __webpack_require__(/*! ../tools.js */ \"(rsc)/./node_modules/imapflow/lib/tools.js\");\n\n// Sends ID info to server and updates server info data based on response\nmodule.exports = async (connection, clientInfo) => {\n if (!connection.capabilities.has('ID')) {\n // nothing to do here\n return;\n }\n\n let response;\n try {\n let map = {};\n\n // convert object into an array of value tuples\n let formattedClientInfo = !clientInfo\n ? null\n : Object.keys(clientInfo)\n .map(key => [key, formatValue(key, clientInfo[key])])\n .filter(entry => entry[1])\n .flatMap(entry => entry);\n\n if (formattedClientInfo && !formattedClientInfo.length) {\n // value array has no elements\n formattedClientInfo = null;\n }\n\n response = await connection.exec('ID', [formattedClientInfo], {\n untagged: {\n ID: async untagged => {\n let params = untagged.attributes && untagged.attributes[0];\n let key;\n (Array.isArray(params) ? params : [].concat(params || [])).forEach((val, i) => {\n if (i % 2 === 0) {\n key = val.value;\n } else if (typeof key === 'string' && typeof val.value === 'string') {\n map[key.toLowerCase().trim()] = val.value;\n }\n });\n }\n }\n });\n connection.serverInfo = map;\n response.next();\n return map;\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n\nfunction formatValue(key, value) {\n switch (key.toLowerCase()) {\n case 'date':\n // Date has to be in imap date-time format\n return formatDateTime(value);\n default:\n // Other values are strings without newlines\n return (value || '').toString().replace(/\\s+/g, ' ');\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL2lkLmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViLFFBQVEsaUJBQWlCLEVBQUUsbUJBQU8sQ0FBQywrREFBYTs7QUFFaEQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsMEJBQTBCO0FBQzFCO0FBQ0E7QUFDQSxxQkFBcUI7QUFDckI7QUFDQTtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ04sOEJBQThCLHlCQUF5QjtBQUN2RDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L2xpYi9jb21tYW5kcy9pZC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IHsgZm9ybWF0RGF0ZVRpbWUgfSA9IHJlcXVpcmUoJy4uL3Rvb2xzLmpzJyk7XG5cbi8vIFNlbmRzIElEIGluZm8gdG8gc2VydmVyIGFuZCB1cGRhdGVzIHNlcnZlciBpbmZvIGRhdGEgYmFzZWQgb24gcmVzcG9uc2Vcbm1vZHVsZS5leHBvcnRzID0gYXN5bmMgKGNvbm5lY3Rpb24sIGNsaWVudEluZm8pID0+IHtcbiAgICBpZiAoIWNvbm5lY3Rpb24uY2FwYWJpbGl0aWVzLmhhcygnSUQnKSkge1xuICAgICAgICAvLyBub3RoaW5nIHRvIGRvIGhlcmVcbiAgICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGxldCByZXNwb25zZTtcbiAgICB0cnkge1xuICAgICAgICBsZXQgbWFwID0ge307XG5cbiAgICAgICAgLy8gY29udmVydCBvYmplY3QgaW50byBhbiBhcnJheSBvZiB2YWx1ZSB0dXBsZXNcbiAgICAgICAgbGV0IGZvcm1hdHRlZENsaWVudEluZm8gPSAhY2xpZW50SW5mb1xuICAgICAgICAgICAgPyBudWxsXG4gICAgICAgICAgICA6IE9iamVjdC5rZXlzKGNsaWVudEluZm8pXG4gICAgICAgICAgICAgICAgICAubWFwKGtleSA9PiBba2V5LCBmb3JtYXRWYWx1ZShrZXksIGNsaWVudEluZm9ba2V5XSldKVxuICAgICAgICAgICAgICAgICAgLmZpbHRlcihlbnRyeSA9PiBlbnRyeVsxXSlcbiAgICAgICAgICAgICAgICAgIC5mbGF0TWFwKGVudHJ5ID0+IGVudHJ5KTtcblxuICAgICAgICBpZiAoZm9ybWF0dGVkQ2xpZW50SW5mbyAmJiAhZm9ybWF0dGVkQ2xpZW50SW5mby5sZW5ndGgpIHtcbiAgICAgICAgICAgIC8vIHZhbHVlIGFycmF5IGhhcyBubyBlbGVtZW50c1xuICAgICAgICAgICAgZm9ybWF0dGVkQ2xpZW50SW5mbyA9IG51bGw7XG4gICAgICAgIH1cblxuICAgICAgICByZXNwb25zZSA9IGF3YWl0IGNvbm5lY3Rpb24uZXhlYygnSUQnLCBbZm9ybWF0dGVkQ2xpZW50SW5mb10sIHtcbiAgICAgICAgICAgIHVudGFnZ2VkOiB7XG4gICAgICAgICAgICAgICAgSUQ6IGFzeW5jIHVudGFnZ2VkID0+IHtcbiAgICAgICAgICAgICAgICAgICAgbGV0IHBhcmFtcyA9IHVudGFnZ2VkLmF0dHJpYnV0ZXMgJiYgdW50YWdnZWQuYXR0cmlidXRlc1swXTtcbiAgICAgICAgICAgICAgICAgICAgbGV0IGtleTtcbiAgICAgICAgICAgICAgICAgICAgKEFycmF5LmlzQXJyYXkocGFyYW1zKSA/IHBhcmFtcyA6IFtdLmNvbmNhdChwYXJhbXMgfHwgW10pKS5mb3JFYWNoKCh2YWwsIGkpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICAgIGlmIChpICUgMiA9PT0gMCkge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGtleSA9IHZhbC52YWx1ZTtcbiAgICAgICAgICAgICAgICAgICAgICAgIH0gZWxzZSBpZiAodHlwZW9mIGtleSA9PT0gJ3N0cmluZycgJiYgdHlwZW9mIHZhbC52YWx1ZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBtYXBba2V5LnRvTG93ZXJDYXNlKCkudHJpbSgpXSA9IHZhbC52YWx1ZTtcbiAgICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICAgICAgY29ubmVjdGlvbi5zZXJ2ZXJJbmZvID0gbWFwO1xuICAgICAgICByZXNwb25zZS5uZXh0KCk7XG4gICAgICAgIHJldHVybiBtYXA7XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICAgIGNvbm5lY3Rpb24ubG9nLndhcm4oeyBlcnIsIGNpZDogY29ubmVjdGlvbi5pZCB9KTtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbn07XG5cbmZ1bmN0aW9uIGZvcm1hdFZhbHVlKGtleSwgdmFsdWUpIHtcbiAgICBzd2l0Y2ggKGtleS50b0xvd2VyQ2FzZSgpKSB7XG4gICAgICAgIGNhc2UgJ2RhdGUnOlxuICAgICAgICAgICAgLy8gRGF0ZSBoYXMgdG8gYmUgaW4gaW1hcCBkYXRlLXRpbWUgZm9ybWF0XG4gICAgICAgICAgICByZXR1cm4gZm9ybWF0RGF0ZVRpbWUodmFsdWUpO1xuICAgICAgICBkZWZhdWx0OlxuICAgICAgICAgICAgLy8gT3RoZXIgdmFsdWVzIGFyZSBzdHJpbmdzIHdpdGhvdXQgbmV3bGluZXNcbiAgICAgICAgICAgIHJldHVybiAodmFsdWUgfHwgJycpLnRvU3RyaW5nKCkucmVwbGFjZSgvXFxzKy9nLCAnICcpO1xuICAgIH1cbn1cbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/id.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/idle.js":
|
|
/*!****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/idle.js ***!
|
|
\****************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\nconst NOOP_INTERVAL = 2 * 60 * 1000;\n\nasync function runIdle(connection) {\n let response;\n\n let preCheckWaitQueue = [];\n try {\n connection.idling = true;\n\n //let idleSent = false;\n let doneRequested = false;\n let doneSent = false;\n let canEnd = false;\n\n let preCheck = async () => {\n doneRequested = true;\n if (canEnd && !doneSent) {\n connection.log.debug({\n src: 'c',\n msg: `DONE`,\n comment: `breaking IDLE`,\n lockId: connection.currentLock?.lockId,\n path: connection.mailbox && connection.mailbox.path\n });\n connection.write('DONE');\n doneSent = true;\n\n connection.idling = false;\n connection.preCheck = false; // unset itself\n\n while (preCheckWaitQueue.length) {\n let { resolve } = preCheckWaitQueue.shift();\n resolve();\n }\n }\n };\n\n let connectionPreCheck = () => {\n let handler = new Promise((resolve, reject) => {\n preCheckWaitQueue.push({ resolve, reject });\n });\n\n connection.log.trace({\n msg: 'Requesting IDLE break',\n lockId: connection.currentLock?.lockId,\n path: connection.mailbox && connection.mailbox.path,\n queued: preCheckWaitQueue.length,\n doneRequested,\n canEnd,\n doneSent\n });\n\n preCheck().catch(err => connection.log.warn({ err, cid: connection.id }));\n\n return handler;\n };\n\n connection.preCheck = connectionPreCheck;\n\n response = await connection.exec('IDLE', false, {\n onPlusTag: async () => {\n connection.log.debug({ msg: `Initiated IDLE, waiting for server input`, lockId: connection.currentLock?.lockId, doneRequested });\n canEnd = true;\n if (doneRequested) {\n try {\n await preCheck();\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n }\n }\n },\n onSend: () => {\n //idleSent = true;\n }\n });\n\n // unset before response.next() if preCheck function is not already cleared (usually is)\n if (typeof connection.preCheck === 'function' && connection.preCheck === connectionPreCheck) {\n connection.log.trace({\n msg: 'Clearing pre-check function',\n lockId: connection.currentLock?.lockId,\n path: connection.mailbox && connection.mailbox.path,\n queued: preCheckWaitQueue.length,\n doneRequested,\n canEnd,\n doneSent\n });\n connection.preCheck = false;\n while (preCheckWaitQueue.length) {\n let { resolve } = preCheckWaitQueue.shift();\n resolve();\n }\n }\n\n response.next();\n return;\n } catch (err) {\n connection.preCheck = false;\n connection.idling = false;\n\n connection.log.warn({ err, cid: connection.id });\n while (preCheckWaitQueue.length) {\n let { reject } = preCheckWaitQueue.shift();\n reject(err);\n }\n return false;\n }\n}\n\n// Listens for changes in mailbox\nmodule.exports = async (connection, maxIdleTime) => {\n if (connection.state !== connection.states.SELECTED) {\n // nothing to do here\n return;\n }\n\n if (connection.capabilities.has('IDLE')) {\n let idleTimer;\n let stillIdling = false;\n let runIdleLoop = async () => {\n if (maxIdleTime) {\n idleTimer = setTimeout(() => {\n if (connection.idling) {\n if (typeof connection.preCheck === 'function') {\n stillIdling = true;\n // request IDLE break if IDLE has been running for allowed time\n connection.log.trace({ msg: 'Max allowed IDLE time reached', cid: connection.id });\n connection.preCheck().catch(err => connection.log.warn({ err, cid: connection.id }));\n }\n }\n }, maxIdleTime);\n }\n let resp = await runIdle(connection);\n clearTimeout(idleTimer);\n if (stillIdling) {\n stillIdling = false;\n return runIdleLoop();\n }\n return resp;\n };\n return runIdleLoop();\n }\n\n let idleTimer;\n return new Promise(resolve => {\n if (!connection.currentSelectCommand) {\n return resolve();\n }\n\n // no IDLE support, fallback to NOOP'ing\n connection.preCheck = async () => {\n connection.preCheck = false; // unset itself\n clearTimeout(idleTimer);\n connection.log.debug({ src: 'c', msg: `breaking NOOP loop` });\n connection.idling = false;\n resolve();\n };\n\n let selectCommand = connection.currentSelectCommand;\n\n let idleCheck = async () => {\n let response;\n switch (connection.missingIdleCommand) {\n case 'SELECT':\n // FIXME: somehow a loop occurs after some time of idling with SELECT\n connection.log.debug({ src: 'c', msg: `Running SELECT to detect changes in folder` });\n response = await connection.exec(selectCommand.command, selectCommand.arguments);\n break;\n\n case 'STATUS':\n {\n let statusArgs = [selectCommand.arguments[0], []]; // path\n for (let key of ['MESSAGES', 'UIDNEXT', 'UIDVALIDITY', 'UNSEEN']) {\n statusArgs[1].push({ type: 'ATOM', value: key.toUpperCase() });\n }\n connection.log.debug({ src: 'c', msg: `Running STATUS to detect changes in folder` });\n response = await connection.exec('STATUS', statusArgs);\n }\n break;\n\n case 'NOOP':\n default:\n response = await connection.exec('NOOP', false, { comment: 'IDLE not supported' });\n break;\n }\n response.next();\n };\n\n let noopInterval = maxIdleTime ? Math.min(NOOP_INTERVAL, maxIdleTime) : NOOP_INTERVAL;\n\n let runLoop = () => {\n idleCheck()\n .then(() => {\n clearTimeout(idleTimer);\n idleTimer = setTimeout(runLoop, noopInterval);\n })\n .catch(err => {\n clearTimeout(idleTimer);\n connection.preCheck = false;\n connection.log.warn({ err, cid: connection.id });\n resolve();\n });\n };\n\n connection.log.debug({ src: 'c', msg: `initiated NOOP loop` });\n connection.idling = true;\n runLoop();\n });\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/imapflow/lib/commands/idle.js","mappings":"AAAa;;AAEb;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;;AAEA;AACA,6CAA6C;;AAE7C;AACA,0BAA0B,UAAU;AACpC;AACA;AACA;AACA;;AAEA;AACA;AACA,yCAAyC,iBAAiB;AAC1D,aAAa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;;AAEb,0DAA0D,yBAAyB;;AAEnF;AACA;;AAEA;;AAEA;AACA;AACA,uCAAuC,wGAAwG;AAC/I;AACA;AACA;AACA;AACA,sBAAsB;AACtB,8CAA8C,yBAAyB;AACvE;AACA;AACA,aAAa;AACb;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,sBAAsB,UAAU;AAChC;AACA;AACA;;AAEA;AACA;AACA,MAAM;AACN;AACA;;AAEA,8BAA8B,yBAAyB;AACvD;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mDAAmD,0DAA0D;AAC7G,qFAAqF,yBAAyB;AAC9G;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,yCAAyC;AACzC;AACA,mCAAmC,qCAAqC;AACxE;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,2CAA2C,6DAA6D;AACxG;AACA;;AAEA;AACA;AACA,2EAA2E;AAC3E;AACA,iDAAiD,wCAAwC;AACzF;AACA,+CAA+C,6DAA6D;AAC5G;AACA;AACA;;AAEA;AACA;AACA,sEAAsE,+BAA+B;AACrG;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA,0CAA0C,yBAAyB;AACnE;AACA,iBAAiB;AACjB;;AAEA,+BAA+B,sCAAsC;AACrE;AACA;AACA,KAAK;AACL","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/commands/idle.js"],"sourcesContent":["'use strict';\n\nconst NOOP_INTERVAL = 2 * 60 * 1000;\n\nasync function runIdle(connection) {\n    let response;\n\n    let preCheckWaitQueue = [];\n    try {\n        connection.idling = true;\n\n        //let idleSent = false;\n        let doneRequested = false;\n        let doneSent = false;\n        let canEnd = false;\n\n        let preCheck = async () => {\n            doneRequested = true;\n            if (canEnd && !doneSent) {\n                connection.log.debug({\n                    src: 'c',\n                    msg: `DONE`,\n                    comment: `breaking IDLE`,\n                    lockId: connection.currentLock?.lockId,\n                    path: connection.mailbox && connection.mailbox.path\n                });\n                connection.write('DONE');\n                doneSent = true;\n\n                connection.idling = false;\n                connection.preCheck = false; // unset itself\n\n                while (preCheckWaitQueue.length) {\n                    let { resolve } = preCheckWaitQueue.shift();\n                    resolve();\n                }\n            }\n        };\n\n        let connectionPreCheck = () => {\n            let handler = new Promise((resolve, reject) => {\n                preCheckWaitQueue.push({ resolve, reject });\n            });\n\n            connection.log.trace({\n                msg: 'Requesting IDLE break',\n                lockId: connection.currentLock?.lockId,\n                path: connection.mailbox && connection.mailbox.path,\n                queued: preCheckWaitQueue.length,\n                doneRequested,\n                canEnd,\n                doneSent\n            });\n\n            preCheck().catch(err => connection.log.warn({ err, cid: connection.id }));\n\n            return handler;\n        };\n\n        connection.preCheck = connectionPreCheck;\n\n        response = await connection.exec('IDLE', false, {\n            onPlusTag: async () => {\n                connection.log.debug({ msg: `Initiated IDLE, waiting for server input`, lockId: connection.currentLock?.lockId, doneRequested });\n                canEnd = true;\n                if (doneRequested) {\n                    try {\n                        await preCheck();\n                    } catch (err) {\n                        connection.log.warn({ err, cid: connection.id });\n                    }\n                }\n            },\n            onSend: () => {\n                //idleSent = true;\n            }\n        });\n\n        // unset before response.next() if preCheck function is not already cleared (usually is)\n        if (typeof connection.preCheck === 'function' && connection.preCheck === connectionPreCheck) {\n            connection.log.trace({\n                msg: 'Clearing pre-check function',\n                lockId: connection.currentLock?.lockId,\n                path: connection.mailbox && connection.mailbox.path,\n                queued: preCheckWaitQueue.length,\n                doneRequested,\n                canEnd,\n                doneSent\n            });\n            connection.preCheck = false;\n            while (preCheckWaitQueue.length) {\n                let { resolve } = preCheckWaitQueue.shift();\n                resolve();\n            }\n        }\n\n        response.next();\n        return;\n    } catch (err) {\n        connection.preCheck = false;\n        connection.idling = false;\n\n        connection.log.warn({ err, cid: connection.id });\n        while (preCheckWaitQueue.length) {\n            let { reject } = preCheckWaitQueue.shift();\n            reject(err);\n        }\n        return false;\n    }\n}\n\n// Listens for changes in mailbox\nmodule.exports = async (connection, maxIdleTime) => {\n    if (connection.state !== connection.states.SELECTED) {\n        // nothing to do here\n        return;\n    }\n\n    if (connection.capabilities.has('IDLE')) {\n        let idleTimer;\n        let stillIdling = false;\n        let runIdleLoop = async () => {\n            if (maxIdleTime) {\n                idleTimer = setTimeout(() => {\n                    if (connection.idling) {\n                        if (typeof connection.preCheck === 'function') {\n                            stillIdling = true;\n                            // request IDLE break if IDLE has been running for allowed time\n                            connection.log.trace({ msg: 'Max allowed IDLE time reached', cid: connection.id });\n                            connection.preCheck().catch(err => connection.log.warn({ err, cid: connection.id }));\n                        }\n                    }\n                }, maxIdleTime);\n            }\n            let resp = await runIdle(connection);\n            clearTimeout(idleTimer);\n            if (stillIdling) {\n                stillIdling = false;\n                return runIdleLoop();\n            }\n            return resp;\n        };\n        return runIdleLoop();\n    }\n\n    let idleTimer;\n    return new Promise(resolve => {\n        if (!connection.currentSelectCommand) {\n            return resolve();\n        }\n\n        // no IDLE support, fallback to NOOP'ing\n        connection.preCheck = async () => {\n            connection.preCheck = false; // unset itself\n            clearTimeout(idleTimer);\n            connection.log.debug({ src: 'c', msg: `breaking NOOP loop` });\n            connection.idling = false;\n            resolve();\n        };\n\n        let selectCommand = connection.currentSelectCommand;\n\n        let idleCheck = async () => {\n            let response;\n            switch (connection.missingIdleCommand) {\n                case 'SELECT':\n                    // FIXME: somehow a loop occurs after some time of idling with SELECT\n                    connection.log.debug({ src: 'c', msg: `Running SELECT to detect changes in folder` });\n                    response = await connection.exec(selectCommand.command, selectCommand.arguments);\n                    break;\n\n                case 'STATUS':\n                    {\n                        let statusArgs = [selectCommand.arguments[0], []]; // path\n                        for (let key of ['MESSAGES', 'UIDNEXT', 'UIDVALIDITY', 'UNSEEN']) {\n                            statusArgs[1].push({ type: 'ATOM', value: key.toUpperCase() });\n                        }\n                        connection.log.debug({ src: 'c', msg: `Running STATUS to detect changes in folder` });\n                        response = await connection.exec('STATUS', statusArgs);\n                    }\n                    break;\n\n                case 'NOOP':\n                default:\n                    response = await connection.exec('NOOP', false, { comment: 'IDLE not supported' });\n                    break;\n            }\n            response.next();\n        };\n\n        let noopInterval = maxIdleTime ? Math.min(NOOP_INTERVAL, maxIdleTime) : NOOP_INTERVAL;\n\n        let runLoop = () => {\n            idleCheck()\n                .then(() => {\n                    clearTimeout(idleTimer);\n                    idleTimer = setTimeout(runLoop, noopInterval);\n                })\n                .catch(err => {\n                    clearTimeout(idleTimer);\n                    connection.preCheck = false;\n                    connection.log.warn({ err, cid: connection.id });\n                    resolve();\n                });\n        };\n\n        connection.log.debug({ src: 'c', msg: `initiated NOOP loop` });\n        connection.idling = true;\n        runLoop();\n    });\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/idle.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/list.js":
|
|
/*!****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/list.js ***!
|
|
\****************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { decodePath, encodePath, normalizePath } = __webpack_require__(/*! ../tools.js */ \"(rsc)/./node_modules/imapflow/lib/tools.js\");\nconst { specialUse } = __webpack_require__(/*! ../special-use */ \"(rsc)/./node_modules/imapflow/lib/special-use.js\");\n\n// Lists mailboxes from server\nmodule.exports = async (connection, reference, mailbox, options) => {\n options = options || {};\n\n const FLAG_SORT_ORDER = ['\\\\Inbox', '\\\\Flagged', '\\\\Sent', '\\\\Drafts', '\\\\All', '\\\\Archive', '\\\\Junk', '\\\\Trash'];\n const SOURCE_SORT_ORDER = ['user', 'extension', 'name'];\n\n let listCommand = connection.capabilities.has('XLIST') && !connection.capabilities.has('SPECIAL-USE') ? 'XLIST' : 'LIST';\n\n let response;\n try {\n let entries = [];\n\n let statusMap = new Map();\n let returnArgs = [];\n let statusQueryAttributes = [];\n\n if (options.statusQuery) {\n Object.keys(options.statusQuery || {}).forEach(key => {\n if (!options.statusQuery[key]) {\n return;\n }\n\n switch (key.toUpperCase()) {\n case 'MESSAGES':\n case 'RECENT':\n case 'UIDNEXT':\n case 'UIDVALIDITY':\n case 'UNSEEN':\n statusQueryAttributes.push({ type: 'ATOM', value: key.toUpperCase() });\n break;\n\n case 'HIGHESTMODSEQ':\n if (connection.capabilities.has('CONDSTORE')) {\n statusQueryAttributes.push({ type: 'ATOM', value: key.toUpperCase() });\n }\n break;\n }\n });\n }\n\n if (listCommand === 'LIST' && connection.capabilities.has('LIST-STATUS') && statusQueryAttributes.length) {\n returnArgs.push({ type: 'ATOM', value: 'STATUS' }, statusQueryAttributes);\n if (connection.capabilities.has('SPECIAL-USE')) {\n returnArgs.push({ type: 'ATOM', value: 'SPECIAL-USE' });\n }\n }\n\n let specialUseMatches = {};\n let addSpecialUseMatch = (entry, type, source) => {\n if (!specialUseMatches[type]) {\n specialUseMatches[type] = [];\n }\n specialUseMatches[type].push({ entry, source });\n };\n\n let specialUseHints = {};\n if (options.specialUseHints && typeof options.specialUseHints === 'object') {\n for (let type of Object.keys(options.specialUseHints)) {\n if (\n ['sent', 'junk', 'trash', 'drafts', 'archive'].includes(type) &&\n options.specialUseHints[type] &&\n typeof options.specialUseHints[type] === 'string'\n ) {\n specialUseHints[normalizePath(connection, options.specialUseHints[type])] = `\\\\${type.replace(/^./, c => c.toUpperCase())}`;\n }\n }\n }\n\n let runList = async (reference, mailbox) => {\n const cmdArgs = [encodePath(connection, reference), encodePath(connection, mailbox)];\n\n if (returnArgs.length) {\n cmdArgs.push({ type: 'ATOM', value: 'RETURN' }, returnArgs);\n }\n\n response = await connection.exec(listCommand, cmdArgs, {\n untagged: {\n [listCommand]: async untagged => {\n if (!untagged.attributes || !untagged.attributes.length) {\n return;\n }\n\n let entry = {\n path: normalizePath(connection, decodePath(connection, (untagged.attributes[2] && untagged.attributes[2].value) || '')),\n pathAsListed: (untagged.attributes[2] && untagged.attributes[2].value) || '',\n flags: new Set(untagged.attributes[0].map(entry => entry.value)),\n delimiter: untagged.attributes[1] && untagged.attributes[1].value,\n listed: true\n };\n\n if (specialUseHints[entry.path]) {\n addSpecialUseMatch(entry, specialUseHints[entry.path], 'user');\n }\n\n if (listCommand === 'XLIST' && entry.flags.has('\\\\Inbox')) {\n // XLIST specific flag, ignore\n entry.flags.delete('\\\\Inbox');\n if (entry.path !== 'INBOX') {\n // XLIST may use localised inbox name\n addSpecialUseMatch(entry, '\\\\Inbox', 'extension');\n }\n }\n\n if (entry.path.toUpperCase() === 'INBOX') {\n addSpecialUseMatch(entry, '\\\\Inbox', 'name');\n }\n\n if (entry.delimiter && entry.path.charAt(0) === entry.delimiter) {\n entry.path = entry.path.slice(1);\n }\n\n entry.parentPath = entry.delimiter && entry.path ? entry.path.substr(0, entry.path.lastIndexOf(entry.delimiter)) : '';\n entry.parent = entry.delimiter ? entry.path.split(entry.delimiter) : [entry.path];\n entry.name = entry.parent.pop();\n\n let { flag: specialUseFlag, source: flagSource } = specialUse(\n connection.capabilities.has('XLIST') || connection.capabilities.has('SPECIAL-USE'),\n entry\n );\n\n if (specialUseFlag) {\n addSpecialUseMatch(entry, specialUseFlag, flagSource);\n }\n\n entries.push(entry);\n },\n\n STATUS: async untagged => {\n let statusPath = normalizePath(connection, decodePath(connection, (untagged.attributes[0] && untagged.attributes[0].value) || ''));\n let statusList = untagged.attributes && Array.isArray(untagged.attributes[1]) ? untagged.attributes[1] : false;\n if (!statusList || !statusPath) {\n return;\n }\n\n let key;\n\n let map = { path: statusPath };\n\n statusList.forEach((entry, i) => {\n if (i % 2 === 0) {\n key = entry && typeof entry.value === 'string' ? entry.value : false;\n return;\n }\n if (!key || !entry || typeof entry.value !== 'string') {\n return;\n }\n let value = false;\n switch (key.toUpperCase()) {\n case 'MESSAGES':\n key = 'messages';\n value = !isNaN(entry.value) ? Number(entry.value) : false;\n break;\n\n case 'RECENT':\n key = 'recent';\n value = !isNaN(entry.value) ? Number(entry.value) : false;\n break;\n\n case 'UIDNEXT':\n key = 'uidNext';\n value = !isNaN(entry.value) ? Number(entry.value) : false;\n break;\n\n case 'UIDVALIDITY':\n key = 'uidValidity';\n value = !isNaN(entry.value) ? BigInt(entry.value) : false;\n break;\n\n case 'UNSEEN':\n key = 'unseen';\n value = !isNaN(entry.value) ? Number(entry.value) : false;\n break;\n\n case 'HIGHESTMODSEQ':\n key = 'highestModseq';\n value = !isNaN(entry.value) ? BigInt(entry.value) : false;\n break;\n }\n if (value === false) {\n return;\n }\n\n map[key] = value;\n });\n\n statusMap.set(statusPath, map);\n }\n }\n });\n response.next();\n };\n\n let normalizedReference = normalizePath(connection, reference || '');\n await runList(normalizedReference, normalizePath(connection, mailbox || '', true));\n\n if (options.listOnly) {\n return entries;\n }\n\n if (normalizedReference && !specialUseMatches['\\\\Inbox']) {\n // INBOX was most probably not included in the listing if namespace was used\n await runList('', 'INBOX');\n }\n\n if (options.statusQuery) {\n for (let entry of entries) {\n if (!entry.flags.has('\\\\Noselect') && !entry.flags.has('\\\\NonExistent')) {\n if (statusMap.has(entry.path)) {\n entry.status = statusMap.get(entry.path);\n } else if (!statusMap.size) {\n // run STATUS command\n try {\n entry.status = await connection.run('STATUS', entry.path, options.statusQuery);\n } catch (err) {\n entry.status = { error: err };\n }\n }\n }\n }\n }\n\n response = await connection.exec(\n 'LSUB',\n [encodePath(connection, normalizePath(connection, reference || '')), encodePath(connection, normalizePath(connection, mailbox || '', true))],\n {\n untagged: {\n LSUB: async untagged => {\n if (!untagged.attributes || !untagged.attributes.length) {\n return;\n }\n\n let entry = {\n path: normalizePath(connection, decodePath(connection, (untagged.attributes[2] && untagged.attributes[2].value) || '')),\n pathAsListed: (untagged.attributes[2] && untagged.attributes[2].value) || '',\n flags: new Set(untagged.attributes[0].map(entry => entry.value)),\n delimiter: untagged.attributes[1] && untagged.attributes[1].value,\n subscribed: true\n };\n\n if (entry.path.toUpperCase() === 'INBOX') {\n addSpecialUseMatch(entry, '\\\\Inbox', 'name');\n }\n\n if (entry.delimiter && entry.path.charAt(0) === entry.delimiter) {\n entry.path = entry.path.slice(1);\n }\n\n entry.parentPath = entry.delimiter && entry.path ? entry.path.substr(0, entry.path.lastIndexOf(entry.delimiter)) : '';\n entry.parent = entry.delimiter ? entry.path.split(entry.delimiter) : [entry.path];\n entry.name = entry.parent.pop();\n\n let existing = entries.find(existing => existing.path === entry.path);\n if (existing) {\n existing.subscribed = true;\n entry.flags.forEach(flag => existing.flags.add(flag));\n } else {\n // ignore non-listed folders\n /*\n let specialUseFlag = specialUse(connection.capabilities.has('XLIST') || connection.capabilities.has('SPECIAL-USE'), entry);\n if (specialUseFlag && !flagsSeen.has(specialUseFlag)) {\n entry.specialUse = specialUseFlag;\n }\n entries.push(entry);\n */\n }\n }\n }\n }\n );\n response.next();\n\n for (let type of Object.keys(specialUseMatches)) {\n let sortedEntries = specialUseMatches[type].sort((a, b) => {\n let aSource = SOURCE_SORT_ORDER.indexOf(a.source);\n let bSource = SOURCE_SORT_ORDER.indexOf(b.source);\n if (aSource === bSource) {\n return a.entry.path.localeCompare(b.entry.path);\n }\n return aSource - bSource;\n });\n\n if (!sortedEntries[0].entry.specialUse) {\n sortedEntries[0].entry.specialUse = type;\n sortedEntries[0].entry.specialUseSource = sortedEntries[0].source;\n }\n }\n\n let inboxEntry = entries.find(entry => entry.specialUse === '\\\\Inbox');\n if (inboxEntry && !inboxEntry.subscribed) {\n // override server settings and make INBOX always as subscribed\n inboxEntry.subscribed = true;\n }\n\n return entries.sort((a, b) => {\n if (a.specialUse && !b.specialUse) {\n return -1;\n }\n if (!a.specialUse && b.specialUse) {\n return 1;\n }\n if (a.specialUse && b.specialUse) {\n return FLAG_SORT_ORDER.indexOf(a.specialUse) - FLAG_SORT_ORDER.indexOf(b.specialUse);\n }\n\n let aList = [].concat(a.parent).concat(a.name);\n let bList = [].concat(b.parent).concat(b.name);\n\n for (let i = 0; i < aList.length; i++) {\n let aPart = aList[i];\n let bPart = bList[i];\n if (aPart !== bPart) {\n return aPart.localeCompare(bPart || '');\n }\n }\n\n return a.path.localeCompare(b.path);\n });\n } catch (err) {\n connection.log.warn({ msg: 'Failed to list folders', err, cid: connection.id });\n throw err;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/imapflow/lib/commands/list.js","mappings":"AAAa;;AAEb,QAAQ,wCAAwC,EAAE,mBAAO,CAAC,+DAAa;AACvE,QAAQ,aAAa,EAAE,mBAAO,CAAC,wEAAgB;;AAE/C;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,iDAAiD;AACjD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,qDAAqD,wCAAwC;AAC7F;;AAEA;AACA;AACA,yDAAyD,wCAAwC;AACjG;AACA;AACA;AACA,aAAa;AACb;;AAEA;AACA,8BAA8B,+BAA+B;AAC7D;AACA,kCAAkC,oCAAoC;AACtE;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,2CAA2C,eAAe;AAC1D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qGAAqG,yCAAyC;AAC9I;AACA;AACA;;AAEA;AACA;;AAEA;AACA,+BAA+B,+BAA+B;AAC9D;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,8BAA8B,2CAA2C;AACzE;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,qBAAqB;;AAErB;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,oCAAoC;;AAEpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,yBAAyB;;AAEzB;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;AACA,0BAA0B;AAC1B,6CAA6C;AAC7C;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,0BAA0B;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;;AAEb;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,4BAA4B,kBAAkB;AAC9C;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,SAAS;AACT,MAAM;AACN,8BAA8B,wDAAwD;AACtF;AACA;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/commands/list.js"],"sourcesContent":["'use strict';\n\nconst { decodePath, encodePath, normalizePath } = require('../tools.js');\nconst { specialUse } = require('../special-use');\n\n// Lists mailboxes from server\nmodule.exports = async (connection, reference, mailbox, options) => {\n    options = options || {};\n\n    const FLAG_SORT_ORDER = ['\\\\Inbox', '\\\\Flagged', '\\\\Sent', '\\\\Drafts', '\\\\All', '\\\\Archive', '\\\\Junk', '\\\\Trash'];\n    const SOURCE_SORT_ORDER = ['user', 'extension', 'name'];\n\n    let listCommand = connection.capabilities.has('XLIST') && !connection.capabilities.has('SPECIAL-USE') ? 'XLIST' : 'LIST';\n\n    let response;\n    try {\n        let entries = [];\n\n        let statusMap = new Map();\n        let returnArgs = [];\n        let statusQueryAttributes = [];\n\n        if (options.statusQuery) {\n            Object.keys(options.statusQuery || {}).forEach(key => {\n                if (!options.statusQuery[key]) {\n                    return;\n                }\n\n                switch (key.toUpperCase()) {\n                    case 'MESSAGES':\n                    case 'RECENT':\n                    case 'UIDNEXT':\n                    case 'UIDVALIDITY':\n                    case 'UNSEEN':\n                        statusQueryAttributes.push({ type: 'ATOM', value: key.toUpperCase() });\n                        break;\n\n                    case 'HIGHESTMODSEQ':\n                        if (connection.capabilities.has('CONDSTORE')) {\n                            statusQueryAttributes.push({ type: 'ATOM', value: key.toUpperCase() });\n                        }\n                        break;\n                }\n            });\n        }\n\n        if (listCommand === 'LIST' && connection.capabilities.has('LIST-STATUS') && statusQueryAttributes.length) {\n            returnArgs.push({ type: 'ATOM', value: 'STATUS' }, statusQueryAttributes);\n            if (connection.capabilities.has('SPECIAL-USE')) {\n                returnArgs.push({ type: 'ATOM', value: 'SPECIAL-USE' });\n            }\n        }\n\n        let specialUseMatches = {};\n        let addSpecialUseMatch = (entry, type, source) => {\n            if (!specialUseMatches[type]) {\n                specialUseMatches[type] = [];\n            }\n            specialUseMatches[type].push({ entry, source });\n        };\n\n        let specialUseHints = {};\n        if (options.specialUseHints && typeof options.specialUseHints === 'object') {\n            for (let type of Object.keys(options.specialUseHints)) {\n                if (\n                    ['sent', 'junk', 'trash', 'drafts', 'archive'].includes(type) &&\n                    options.specialUseHints[type] &&\n                    typeof options.specialUseHints[type] === 'string'\n                ) {\n                    specialUseHints[normalizePath(connection, options.specialUseHints[type])] = `\\\\${type.replace(/^./, c => c.toUpperCase())}`;\n                }\n            }\n        }\n\n        let runList = async (reference, mailbox) => {\n            const cmdArgs = [encodePath(connection, reference), encodePath(connection, mailbox)];\n\n            if (returnArgs.length) {\n                cmdArgs.push({ type: 'ATOM', value: 'RETURN' }, returnArgs);\n            }\n\n            response = await connection.exec(listCommand, cmdArgs, {\n                untagged: {\n                    [listCommand]: async untagged => {\n                        if (!untagged.attributes || !untagged.attributes.length) {\n                            return;\n                        }\n\n                        let entry = {\n                            path: normalizePath(connection, decodePath(connection, (untagged.attributes[2] && untagged.attributes[2].value) || '')),\n                            pathAsListed: (untagged.attributes[2] && untagged.attributes[2].value) || '',\n                            flags: new Set(untagged.attributes[0].map(entry => entry.value)),\n                            delimiter: untagged.attributes[1] && untagged.attributes[1].value,\n                            listed: true\n                        };\n\n                        if (specialUseHints[entry.path]) {\n                            addSpecialUseMatch(entry, specialUseHints[entry.path], 'user');\n                        }\n\n                        if (listCommand === 'XLIST' && entry.flags.has('\\\\Inbox')) {\n                            // XLIST specific flag, ignore\n                            entry.flags.delete('\\\\Inbox');\n                            if (entry.path !== 'INBOX') {\n                                // XLIST may use localised inbox name\n                                addSpecialUseMatch(entry, '\\\\Inbox', 'extension');\n                            }\n                        }\n\n                        if (entry.path.toUpperCase() === 'INBOX') {\n                            addSpecialUseMatch(entry, '\\\\Inbox', 'name');\n                        }\n\n                        if (entry.delimiter && entry.path.charAt(0) === entry.delimiter) {\n                            entry.path = entry.path.slice(1);\n                        }\n\n                        entry.parentPath = entry.delimiter && entry.path ? entry.path.substr(0, entry.path.lastIndexOf(entry.delimiter)) : '';\n                        entry.parent = entry.delimiter ? entry.path.split(entry.delimiter) : [entry.path];\n                        entry.name = entry.parent.pop();\n\n                        let { flag: specialUseFlag, source: flagSource } = specialUse(\n                            connection.capabilities.has('XLIST') || connection.capabilities.has('SPECIAL-USE'),\n                            entry\n                        );\n\n                        if (specialUseFlag) {\n                            addSpecialUseMatch(entry, specialUseFlag, flagSource);\n                        }\n\n                        entries.push(entry);\n                    },\n\n                    STATUS: async untagged => {\n                        let statusPath = normalizePath(connection, decodePath(connection, (untagged.attributes[0] && untagged.attributes[0].value) || ''));\n                        let statusList = untagged.attributes && Array.isArray(untagged.attributes[1]) ? untagged.attributes[1] : false;\n                        if (!statusList || !statusPath) {\n                            return;\n                        }\n\n                        let key;\n\n                        let map = { path: statusPath };\n\n                        statusList.forEach((entry, i) => {\n                            if (i % 2 === 0) {\n                                key = entry && typeof entry.value === 'string' ? entry.value : false;\n                                return;\n                            }\n                            if (!key || !entry || typeof entry.value !== 'string') {\n                                return;\n                            }\n                            let value = false;\n                            switch (key.toUpperCase()) {\n                                case 'MESSAGES':\n                                    key = 'messages';\n                                    value = !isNaN(entry.value) ? Number(entry.value) : false;\n                                    break;\n\n                                case 'RECENT':\n                                    key = 'recent';\n                                    value = !isNaN(entry.value) ? Number(entry.value) : false;\n                                    break;\n\n                                case 'UIDNEXT':\n                                    key = 'uidNext';\n                                    value = !isNaN(entry.value) ? Number(entry.value) : false;\n                                    break;\n\n                                case 'UIDVALIDITY':\n                                    key = 'uidValidity';\n                                    value = !isNaN(entry.value) ? BigInt(entry.value) : false;\n                                    break;\n\n                                case 'UNSEEN':\n                                    key = 'unseen';\n                                    value = !isNaN(entry.value) ? Number(entry.value) : false;\n                                    break;\n\n                                case 'HIGHESTMODSEQ':\n                                    key = 'highestModseq';\n                                    value = !isNaN(entry.value) ? BigInt(entry.value) : false;\n                                    break;\n                            }\n                            if (value === false) {\n                                return;\n                            }\n\n                            map[key] = value;\n                        });\n\n                        statusMap.set(statusPath, map);\n                    }\n                }\n            });\n            response.next();\n        };\n\n        let normalizedReference = normalizePath(connection, reference || '');\n        await runList(normalizedReference, normalizePath(connection, mailbox || '', true));\n\n        if (options.listOnly) {\n            return entries;\n        }\n\n        if (normalizedReference && !specialUseMatches['\\\\Inbox']) {\n            // INBOX was most probably not included in the listing if namespace was used\n            await runList('', 'INBOX');\n        }\n\n        if (options.statusQuery) {\n            for (let entry of entries) {\n                if (!entry.flags.has('\\\\Noselect') && !entry.flags.has('\\\\NonExistent')) {\n                    if (statusMap.has(entry.path)) {\n                        entry.status = statusMap.get(entry.path);\n                    } else if (!statusMap.size) {\n                        // run STATUS command\n                        try {\n                            entry.status = await connection.run('STATUS', entry.path, options.statusQuery);\n                        } catch (err) {\n                            entry.status = { error: err };\n                        }\n                    }\n                }\n            }\n        }\n\n        response = await connection.exec(\n            'LSUB',\n            [encodePath(connection, normalizePath(connection, reference || '')), encodePath(connection, normalizePath(connection, mailbox || '', true))],\n            {\n                untagged: {\n                    LSUB: async untagged => {\n                        if (!untagged.attributes || !untagged.attributes.length) {\n                            return;\n                        }\n\n                        let entry = {\n                            path: normalizePath(connection, decodePath(connection, (untagged.attributes[2] && untagged.attributes[2].value) || '')),\n                            pathAsListed: (untagged.attributes[2] && untagged.attributes[2].value) || '',\n                            flags: new Set(untagged.attributes[0].map(entry => entry.value)),\n                            delimiter: untagged.attributes[1] && untagged.attributes[1].value,\n                            subscribed: true\n                        };\n\n                        if (entry.path.toUpperCase() === 'INBOX') {\n                            addSpecialUseMatch(entry, '\\\\Inbox', 'name');\n                        }\n\n                        if (entry.delimiter && entry.path.charAt(0) === entry.delimiter) {\n                            entry.path = entry.path.slice(1);\n                        }\n\n                        entry.parentPath = entry.delimiter && entry.path ? entry.path.substr(0, entry.path.lastIndexOf(entry.delimiter)) : '';\n                        entry.parent = entry.delimiter ? entry.path.split(entry.delimiter) : [entry.path];\n                        entry.name = entry.parent.pop();\n\n                        let existing = entries.find(existing => existing.path === entry.path);\n                        if (existing) {\n                            existing.subscribed = true;\n                            entry.flags.forEach(flag => existing.flags.add(flag));\n                        } else {\n                            // ignore non-listed folders\n                            /*\n                            let specialUseFlag = specialUse(connection.capabilities.has('XLIST') || connection.capabilities.has('SPECIAL-USE'), entry);\n                            if (specialUseFlag && !flagsSeen.has(specialUseFlag)) {\n                                entry.specialUse = specialUseFlag;\n                            }\n                            entries.push(entry);\n                            */\n                        }\n                    }\n                }\n            }\n        );\n        response.next();\n\n        for (let type of Object.keys(specialUseMatches)) {\n            let sortedEntries = specialUseMatches[type].sort((a, b) => {\n                let aSource = SOURCE_SORT_ORDER.indexOf(a.source);\n                let bSource = SOURCE_SORT_ORDER.indexOf(b.source);\n                if (aSource === bSource) {\n                    return a.entry.path.localeCompare(b.entry.path);\n                }\n                return aSource - bSource;\n            });\n\n            if (!sortedEntries[0].entry.specialUse) {\n                sortedEntries[0].entry.specialUse = type;\n                sortedEntries[0].entry.specialUseSource = sortedEntries[0].source;\n            }\n        }\n\n        let inboxEntry = entries.find(entry => entry.specialUse === '\\\\Inbox');\n        if (inboxEntry && !inboxEntry.subscribed) {\n            // override server settings and make INBOX always as subscribed\n            inboxEntry.subscribed = true;\n        }\n\n        return entries.sort((a, b) => {\n            if (a.specialUse && !b.specialUse) {\n                return -1;\n            }\n            if (!a.specialUse && b.specialUse) {\n                return 1;\n            }\n            if (a.specialUse && b.specialUse) {\n                return FLAG_SORT_ORDER.indexOf(a.specialUse) - FLAG_SORT_ORDER.indexOf(b.specialUse);\n            }\n\n            let aList = [].concat(a.parent).concat(a.name);\n            let bList = [].concat(b.parent).concat(b.name);\n\n            for (let i = 0; i < aList.length; i++) {\n                let aPart = aList[i];\n                let bPart = bList[i];\n                if (aPart !== bPart) {\n                    return aPart.localeCompare(bPart || '');\n                }\n            }\n\n            return a.path.localeCompare(b.path);\n        });\n    } catch (err) {\n        connection.log.warn({ msg: 'Failed to list folders', err, cid: connection.id });\n        throw err;\n    }\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/list.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/login.js":
|
|
/*!*****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/login.js ***!
|
|
\*****************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { getStatusCode, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(rsc)/./node_modules/imapflow/lib/tools.js\");\n\n// Authenticates user using LOGIN\nmodule.exports = async (connection, username, password) => {\n if (connection.state !== connection.states.NOT_AUTHENTICATED) {\n // nothing to do here\n return;\n }\n\n try {\n let response = await connection.exec('LOGIN', [\n { type: 'STRING', value: username },\n { type: 'STRING', value: password, sensitive: true }\n ]);\n response.next();\n\n connection.authCapabilities.set('LOGIN', true);\n\n return username;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.authenticationFailed = true;\n err.response = await getErrorText(err.response);\n throw err;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL2xvZ2luLmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViLFFBQVEsOEJBQThCLEVBQUUsbUJBQU8sQ0FBQywrREFBYTs7QUFFN0Q7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxjQUFjLGlDQUFpQztBQUMvQyxjQUFjO0FBQ2Q7QUFDQTs7QUFFQTs7QUFFQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L2xpYi9jb21tYW5kcy9sb2dpbi5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IHsgZ2V0U3RhdHVzQ29kZSwgZ2V0RXJyb3JUZXh0IH0gPSByZXF1aXJlKCcuLi90b29scy5qcycpO1xuXG4vLyBBdXRoZW50aWNhdGVzIHVzZXIgdXNpbmcgTE9HSU5cbm1vZHVsZS5leHBvcnRzID0gYXN5bmMgKGNvbm5lY3Rpb24sIHVzZXJuYW1lLCBwYXNzd29yZCkgPT4ge1xuICAgIGlmIChjb25uZWN0aW9uLnN0YXRlICE9PSBjb25uZWN0aW9uLnN0YXRlcy5OT1RfQVVUSEVOVElDQVRFRCkge1xuICAgICAgICAvLyBub3RoaW5nIHRvIGRvIGhlcmVcbiAgICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIHRyeSB7XG4gICAgICAgIGxldCByZXNwb25zZSA9IGF3YWl0IGNvbm5lY3Rpb24uZXhlYygnTE9HSU4nLCBbXG4gICAgICAgICAgICB7IHR5cGU6ICdTVFJJTkcnLCB2YWx1ZTogdXNlcm5hbWUgfSxcbiAgICAgICAgICAgIHsgdHlwZTogJ1NUUklORycsIHZhbHVlOiBwYXNzd29yZCwgc2Vuc2l0aXZlOiB0cnVlIH1cbiAgICAgICAgXSk7XG4gICAgICAgIHJlc3BvbnNlLm5leHQoKTtcblxuICAgICAgICBjb25uZWN0aW9uLmF1dGhDYXBhYmlsaXRpZXMuc2V0KCdMT0dJTicsIHRydWUpO1xuXG4gICAgICAgIHJldHVybiB1c2VybmFtZTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgbGV0IGVycm9yQ29kZSA9IGdldFN0YXR1c0NvZGUoZXJyLnJlc3BvbnNlKTtcbiAgICAgICAgaWYgKGVycm9yQ29kZSkge1xuICAgICAgICAgICAgZXJyLnNlcnZlclJlc3BvbnNlQ29kZSA9IGVycm9yQ29kZTtcbiAgICAgICAgfVxuICAgICAgICBlcnIuYXV0aGVudGljYXRpb25GYWlsZWQgPSB0cnVlO1xuICAgICAgICBlcnIucmVzcG9uc2UgPSBhd2FpdCBnZXRFcnJvclRleHQoZXJyLnJlc3BvbnNlKTtcbiAgICAgICAgdGhyb3cgZXJyO1xuICAgIH1cbn07XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/login.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/logout.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/logout.js ***!
|
|
\******************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\n// Logs out user and closes connection\nmodule.exports = async connection => {\n if (connection.state === connection.states.LOGOUT) {\n // nothing to do here\n return false;\n }\n\n if (connection.state === connection.states.NOT_AUTHENTICATED) {\n connection.state = connection.states.LOGOUT;\n connection.close();\n return false;\n }\n\n let response;\n try {\n response = await connection.exec('LOGOUT');\n return true;\n } catch (err) {\n if (err.code === 'NoConnection') {\n return true;\n }\n connection.log.warn({ err, cid: connection.id });\n return false;\n } finally {\n // close even if command failed\n connection.state = connection.states.LOGOUT;\n if (response && typeof response.next === 'function') {\n response.next();\n }\n connection.close();\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL2xvZ291dC5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQSw4QkFBOEIseUJBQXlCO0FBQ3ZEO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L2xpYi9jb21tYW5kcy9sb2dvdXQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG4vLyBMb2dzIG91dCB1c2VyIGFuZCBjbG9zZXMgY29ubmVjdGlvblxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyBjb25uZWN0aW9uID0+IHtcbiAgICBpZiAoY29ubmVjdGlvbi5zdGF0ZSA9PT0gY29ubmVjdGlvbi5zdGF0ZXMuTE9HT1VUKSB7XG4gICAgICAgIC8vIG5vdGhpbmcgdG8gZG8gaGVyZVxuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuXG4gICAgaWYgKGNvbm5lY3Rpb24uc3RhdGUgPT09IGNvbm5lY3Rpb24uc3RhdGVzLk5PVF9BVVRIRU5USUNBVEVEKSB7XG4gICAgICAgIGNvbm5lY3Rpb24uc3RhdGUgPSBjb25uZWN0aW9uLnN0YXRlcy5MT0dPVVQ7XG4gICAgICAgIGNvbm5lY3Rpb24uY2xvc2UoKTtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cblxuICAgIGxldCByZXNwb25zZTtcbiAgICB0cnkge1xuICAgICAgICByZXNwb25zZSA9IGF3YWl0IGNvbm5lY3Rpb24uZXhlYygnTE9HT1VUJyk7XG4gICAgICAgIHJldHVybiB0cnVlO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICBpZiAoZXJyLmNvZGUgPT09ICdOb0Nvbm5lY3Rpb24nKSB7XG4gICAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgfVxuICAgICAgICBjb25uZWN0aW9uLmxvZy53YXJuKHsgZXJyLCBjaWQ6IGNvbm5lY3Rpb24uaWQgfSk7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9IGZpbmFsbHkge1xuICAgICAgICAvLyBjbG9zZSBldmVuIGlmIGNvbW1hbmQgZmFpbGVkXG4gICAgICAgIGNvbm5lY3Rpb24uc3RhdGUgPSBjb25uZWN0aW9uLnN0YXRlcy5MT0dPVVQ7XG4gICAgICAgIGlmIChyZXNwb25zZSAmJiB0eXBlb2YgcmVzcG9uc2UubmV4dCA9PT0gJ2Z1bmN0aW9uJykge1xuICAgICAgICAgICAgcmVzcG9uc2UubmV4dCgpO1xuICAgICAgICB9XG4gICAgICAgIGNvbm5lY3Rpb24uY2xvc2UoKTtcbiAgICB9XG59O1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/logout.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/move.js":
|
|
/*!****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/move.js ***!
|
|
\****************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { getStatusCode, normalizePath, encodePath, expandRange, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(rsc)/./node_modules/imapflow/lib/tools.js\");\n\n// Moves messages from current mailbox to some other mailbox\nmodule.exports = async (connection, range, destination, options) => {\n if (connection.state !== connection.states.SELECTED || !range || !destination) {\n // nothing to do here\n return;\n }\n\n options = options || {};\n destination = normalizePath(connection, destination);\n\n let attributes = [\n { type: 'SEQUENCE', value: range },\n { type: 'ATOM', value: encodePath(connection, destination) }\n ];\n\n let map = { path: connection.mailbox.path, destination };\n\n if (!connection.capabilities.has('MOVE')) {\n let result = await connection.messageCopy(range, destination, options);\n await connection.messageDelete(range, Object.assign({ silent: true }, options));\n return result;\n }\n\n let checkMoveInfo = response => {\n let section = response.attributes && response.attributes[0] && response.attributes[0].section;\n let responseCode = section && section.length && section[0] && typeof section[0].value === 'string' ? section[0].value : '';\n switch (responseCode) {\n case 'COPYUID':\n {\n let uidValidity = section[1] && typeof section[1].value === 'string' && !isNaN(section[1].value) ? BigInt(section[1].value) : false;\n if (uidValidity) {\n map.uidValidity = uidValidity;\n }\n\n let sourceUids = section[2] && typeof section[2].value === 'string' ? expandRange(section[2].value) : false;\n let destinationUids = section[3] && typeof section[3].value === 'string' ? expandRange(section[3].value) : false;\n if (sourceUids && destinationUids && sourceUids.length === destinationUids.length) {\n map.uidMap = new Map(sourceUids.map((uid, i) => [uid, destinationUids[i]]));\n }\n }\n break;\n }\n };\n\n let response;\n try {\n response = await connection.exec(options.uid ? 'UID MOVE' : 'MOVE', attributes, {\n untagged: {\n OK: async untagged => {\n checkMoveInfo(untagged);\n }\n }\n });\n response.next();\n\n checkMoveInfo(response.response);\n return map;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL21vdmUuanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWIsUUFBUSxzRUFBc0UsRUFBRSxtQkFBTyxDQUFDLCtEQUFhOztBQUVyRztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBLFVBQVUsZ0NBQWdDO0FBQzFDLFVBQVU7QUFDVjs7QUFFQSxnQkFBZ0I7O0FBRWhCO0FBQ0E7QUFDQSw4REFBOEQsY0FBYztBQUM1RTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNUOztBQUVBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSw4QkFBOEIseUJBQXlCO0FBQ3ZEO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL21vdmUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCB7IGdldFN0YXR1c0NvZGUsIG5vcm1hbGl6ZVBhdGgsIGVuY29kZVBhdGgsIGV4cGFuZFJhbmdlLCBnZXRFcnJvclRleHQgfSA9IHJlcXVpcmUoJy4uL3Rvb2xzLmpzJyk7XG5cbi8vIE1vdmVzIG1lc3NhZ2VzIGZyb20gY3VycmVudCBtYWlsYm94IHRvIHNvbWUgb3RoZXIgbWFpbGJveFxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyAoY29ubmVjdGlvbiwgcmFuZ2UsIGRlc3RpbmF0aW9uLCBvcHRpb25zKSA9PiB7XG4gICAgaWYgKGNvbm5lY3Rpb24uc3RhdGUgIT09IGNvbm5lY3Rpb24uc3RhdGVzLlNFTEVDVEVEIHx8ICFyYW5nZSB8fCAhZGVzdGluYXRpb24pIHtcbiAgICAgICAgLy8gbm90aGluZyB0byBkbyBoZXJlXG4gICAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBvcHRpb25zID0gb3B0aW9ucyB8fCB7fTtcbiAgICBkZXN0aW5hdGlvbiA9IG5vcm1hbGl6ZVBhdGgoY29ubmVjdGlvbiwgZGVzdGluYXRpb24pO1xuXG4gICAgbGV0IGF0dHJpYnV0ZXMgPSBbXG4gICAgICAgIHsgdHlwZTogJ1NFUVVFTkNFJywgdmFsdWU6IHJhbmdlIH0sXG4gICAgICAgIHsgdHlwZTogJ0FUT00nLCB2YWx1ZTogZW5jb2RlUGF0aChjb25uZWN0aW9uLCBkZXN0aW5hdGlvbikgfVxuICAgIF07XG5cbiAgICBsZXQgbWFwID0geyBwYXRoOiBjb25uZWN0aW9uLm1haWxib3gucGF0aCwgZGVzdGluYXRpb24gfTtcblxuICAgIGlmICghY29ubmVjdGlvbi5jYXBhYmlsaXRpZXMuaGFzKCdNT1ZFJykpIHtcbiAgICAgICAgbGV0IHJlc3VsdCA9IGF3YWl0IGNvbm5lY3Rpb24ubWVzc2FnZUNvcHkocmFuZ2UsIGRlc3RpbmF0aW9uLCBvcHRpb25zKTtcbiAgICAgICAgYXdhaXQgY29ubmVjdGlvbi5tZXNzYWdlRGVsZXRlKHJhbmdlLCBPYmplY3QuYXNzaWduKHsgc2lsZW50OiB0cnVlIH0sIG9wdGlvbnMpKTtcbiAgICAgICAgcmV0dXJuIHJlc3VsdDtcbiAgICB9XG5cbiAgICBsZXQgY2hlY2tNb3ZlSW5mbyA9IHJlc3BvbnNlID0+IHtcbiAgICAgICAgbGV0IHNlY3Rpb24gPSByZXNwb25zZS5hdHRyaWJ1dGVzICYmIHJlc3BvbnNlLmF0dHJpYnV0ZXNbMF0gJiYgcmVzcG9uc2UuYXR0cmlidXRlc1swXS5zZWN0aW9uO1xuICAgICAgICBsZXQgcmVzcG9uc2VDb2RlID0gc2VjdGlvbiAmJiBzZWN0aW9uLmxlbmd0aCAmJiBzZWN0aW9uWzBdICYmIHR5cGVvZiBzZWN0aW9uWzBdLnZhbHVlID09PSAnc3RyaW5nJyA/IHNlY3Rpb25bMF0udmFsdWUgOiAnJztcbiAgICAgICAgc3dpdGNoIChyZXNwb25zZUNvZGUpIHtcbiAgICAgICAgICAgIGNhc2UgJ0NPUFlVSUQnOlxuICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgbGV0IHVpZFZhbGlkaXR5ID0gc2VjdGlvblsxXSAmJiB0eXBlb2Ygc2VjdGlvblsxXS52YWx1ZSA9PT0gJ3N0cmluZycgJiYgIWlzTmFOKHNlY3Rpb25bMV0udmFsdWUpID8gQmlnSW50KHNlY3Rpb25bMV0udmFsdWUpIDogZmFsc2U7XG4gICAgICAgICAgICAgICAgICAgIGlmICh1aWRWYWxpZGl0eSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgbWFwLnVpZFZhbGlkaXR5ID0gdWlkVmFsaWRpdHk7XG4gICAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgICBsZXQgc291cmNlVWlkcyA9IHNlY3Rpb25bMl0gJiYgdHlwZW9mIHNlY3Rpb25bMl0udmFsdWUgPT09ICdzdHJpbmcnID8gZXhwYW5kUmFuZ2Uoc2VjdGlvblsyXS52YWx1ZSkgOiBmYWxzZTtcbiAgICAgICAgICAgICAgICAgICAgbGV0IGRlc3RpbmF0aW9uVWlkcyA9IHNlY3Rpb25bM10gJiYgdHlwZW9mIHNlY3Rpb25bM10udmFsdWUgPT09ICdzdHJpbmcnID8gZXhwYW5kUmFuZ2Uoc2VjdGlvblszXS52YWx1ZSkgOiBmYWxzZTtcbiAgICAgICAgICAgICAgICAgICAgaWYgKHNvdXJjZVVpZHMgJiYgZGVzdGluYXRpb25VaWRzICYmIHNvdXJjZVVpZHMubGVuZ3RoID09PSBkZXN0aW5hdGlvblVpZHMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBtYXAudWlkTWFwID0gbmV3IE1hcChzb3VyY2VVaWRzLm1hcCgodWlkLCBpKSA9PiBbdWlkLCBkZXN0aW5hdGlvblVpZHNbaV1dKSk7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgYnJlYWs7XG4gICAgICAgIH1cbiAgICB9O1xuXG4gICAgbGV0IHJlc3BvbnNlO1xuICAgIHRyeSB7XG4gICAgICAgIHJlc3BvbnNlID0gYXdhaXQgY29ubmVjdGlvbi5leGVjKG9wdGlvbnMudWlkID8gJ1VJRCBNT1ZFJyA6ICdNT1ZFJywgYXR0cmlidXRlcywge1xuICAgICAgICAgICAgdW50YWdnZWQ6IHtcbiAgICAgICAgICAgICAgICBPSzogYXN5bmMgdW50YWdnZWQgPT4ge1xuICAgICAgICAgICAgICAgICAgICBjaGVja01vdmVJbmZvKHVudGFnZ2VkKTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgICAgICByZXNwb25zZS5uZXh0KCk7XG5cbiAgICAgICAgY2hlY2tNb3ZlSW5mbyhyZXNwb25zZS5yZXNwb25zZSk7XG4gICAgICAgIHJldHVybiBtYXA7XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICAgIGxldCBlcnJvckNvZGUgPSBnZXRTdGF0dXNDb2RlKGVyci5yZXNwb25zZSk7XG4gICAgICAgIGlmIChlcnJvckNvZGUpIHtcbiAgICAgICAgICAgIGVyci5zZXJ2ZXJSZXNwb25zZUNvZGUgPSBlcnJvckNvZGU7XG4gICAgICAgIH1cbiAgICAgICAgZXJyLnJlc3BvbnNlID0gYXdhaXQgZ2V0RXJyb3JUZXh0KGVyci5yZXNwb25zZSk7XG5cbiAgICAgICAgY29ubmVjdGlvbi5sb2cud2Fybih7IGVyciwgY2lkOiBjb25uZWN0aW9uLmlkIH0pO1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxufTtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/move.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/namespace.js":
|
|
/*!*********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/namespace.js ***!
|
|
\*********************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\n// Requests NAMESPACE info from server\nmodule.exports = async connection => {\n if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state)) {\n // nothing to do here\n return;\n }\n\n if (!connection.capabilities.has('NAMESPACE')) {\n // try to derive from listing\n let { prefix, delimiter } = await getListPrefix(connection);\n if (delimiter && prefix && prefix.charAt(prefix.length - 1) !== delimiter) {\n prefix += delimiter;\n }\n let map = {\n personal: [{ prefix: prefix || '', delimiter }],\n other: false,\n shared: false\n };\n connection.namespaces = map;\n connection.namespace = connection.namespaces.personal[0];\n return connection.namespace;\n }\n\n let response;\n try {\n let map = {};\n response = await connection.exec('NAMESPACE', false, {\n untagged: {\n NAMESPACE: async untagged => {\n if (!untagged.attributes || !untagged.attributes.length) {\n return;\n }\n map.personal = getNamsepaceInfo(untagged.attributes[0]);\n map.other = getNamsepaceInfo(untagged.attributes[1]);\n map.shared = getNamsepaceInfo(untagged.attributes[2]);\n }\n }\n });\n connection.namespaces = map;\n\n // make sure that we have the first personal namespace always set\n if (!connection.namespaces.personal[0]) {\n connection.namespaces.personal[0] = { prefix: '', delimiter: '.' };\n }\n connection.namespaces.personal[0].prefix = connection.namespaces.personal[0].prefix || '';\n response.next();\n\n connection.namespace = connection.namespaces.personal[0];\n\n return connection.namespace;\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n return {\n error: true,\n status: err.responseStatus,\n text: err.responseText\n };\n }\n};\n\nasync function getListPrefix(connection) {\n let response;\n try {\n let map = {};\n response = await connection.exec('LIST', ['', ''], {\n untagged: {\n LIST: async untagged => {\n if (!untagged.attributes || !untagged.attributes.length) {\n return;\n }\n\n map.flags = new Set(untagged.attributes[0].map(entry => entry.value));\n map.delimiter = untagged.attributes[1] && untagged.attributes[1].value;\n map.prefix = (untagged.attributes[2] && untagged.attributes[2].value) || '';\n if (map.delimiter && map.prefix.charAt(0) === map.delimiter) {\n map.prefix = map.prefix.slice(1);\n }\n }\n }\n });\n response.next();\n return map;\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n return {};\n }\n}\n\nfunction getNamsepaceInfo(attribute) {\n if (!attribute || !attribute.length) {\n return false;\n }\n\n return attribute\n .filter(entry => entry.length >= 2 && typeof entry[0].value === 'string' && typeof entry[1].value === 'string')\n .map(entry => {\n let prefix = entry[0].value;\n let delimiter = entry[1].value;\n\n if (delimiter && prefix && prefix.charAt(prefix.length - 1) !== delimiter) {\n prefix += delimiter;\n }\n return { prefix, delimiter };\n });\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL25hbWVzcGFjZS5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLGNBQWMsb0JBQW9CO0FBQ2xDO0FBQ0E7QUFDQTtBQUNBO0FBQ0EseUJBQXlCLGlDQUFpQztBQUMxRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNUOztBQUVBO0FBQ0E7QUFDQSxrREFBa0Q7QUFDbEQ7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0EsTUFBTTtBQUNOLDhCQUE4Qix5QkFBeUI7QUFDdkQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0EsTUFBTTtBQUNOLDhCQUE4Qix5QkFBeUI7QUFDdkQ7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EscUJBQXFCO0FBQ3JCLFNBQVM7QUFDVCIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL25hbWVzcGFjZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbi8vIFJlcXVlc3RzIE5BTUVTUEFDRSBpbmZvIGZyb20gc2VydmVyXG5tb2R1bGUuZXhwb3J0cyA9IGFzeW5jIGNvbm5lY3Rpb24gPT4ge1xuICAgIGlmICghW2Nvbm5lY3Rpb24uc3RhdGVzLkFVVEhFTlRJQ0FURUQsIGNvbm5lY3Rpb24uc3RhdGVzLlNFTEVDVEVEXS5pbmNsdWRlcyhjb25uZWN0aW9uLnN0YXRlKSkge1xuICAgICAgICAvLyBub3RoaW5nIHRvIGRvIGhlcmVcbiAgICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGlmICghY29ubmVjdGlvbi5jYXBhYmlsaXRpZXMuaGFzKCdOQU1FU1BBQ0UnKSkge1xuICAgICAgICAvLyB0cnkgdG8gZGVyaXZlIGZyb20gbGlzdGluZ1xuICAgICAgICBsZXQgeyBwcmVmaXgsIGRlbGltaXRlciB9ID0gYXdhaXQgZ2V0TGlzdFByZWZpeChjb25uZWN0aW9uKTtcbiAgICAgICAgaWYgKGRlbGltaXRlciAmJiBwcmVmaXggJiYgcHJlZml4LmNoYXJBdChwcmVmaXgubGVuZ3RoIC0gMSkgIT09IGRlbGltaXRlcikge1xuICAgICAgICAgICAgcHJlZml4ICs9IGRlbGltaXRlcjtcbiAgICAgICAgfVxuICAgICAgICBsZXQgbWFwID0ge1xuICAgICAgICAgICAgcGVyc29uYWw6IFt7IHByZWZpeDogcHJlZml4IHx8ICcnLCBkZWxpbWl0ZXIgfV0sXG4gICAgICAgICAgICBvdGhlcjogZmFsc2UsXG4gICAgICAgICAgICBzaGFyZWQ6IGZhbHNlXG4gICAgICAgIH07XG4gICAgICAgIGNvbm5lY3Rpb24ubmFtZXNwYWNlcyA9IG1hcDtcbiAgICAgICAgY29ubmVjdGlvbi5uYW1lc3BhY2UgPSBjb25uZWN0aW9uLm5hbWVzcGFjZXMucGVyc29uYWxbMF07XG4gICAgICAgIHJldHVybiBjb25uZWN0aW9uLm5hbWVzcGFjZTtcbiAgICB9XG5cbiAgICBsZXQgcmVzcG9uc2U7XG4gICAgdHJ5IHtcbiAgICAgICAgbGV0IG1hcCA9IHt9O1xuICAgICAgICByZXNwb25zZSA9IGF3YWl0IGNvbm5lY3Rpb24uZXhlYygnTkFNRVNQQUNFJywgZmFsc2UsIHtcbiAgICAgICAgICAgIHVudGFnZ2VkOiB7XG4gICAgICAgICAgICAgICAgTkFNRVNQQUNFOiBhc3luYyB1bnRhZ2dlZCA9PiB7XG4gICAgICAgICAgICAgICAgICAgIGlmICghdW50YWdnZWQuYXR0cmlidXRlcyB8fCAhdW50YWdnZWQuYXR0cmlidXRlcy5sZW5ndGgpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICBtYXAucGVyc29uYWwgPSBnZXROYW1zZXBhY2VJbmZvKHVudGFnZ2VkLmF0dHJpYnV0ZXNbMF0pO1xuICAgICAgICAgICAgICAgICAgICBtYXAub3RoZXIgPSBnZXROYW1zZXBhY2VJbmZvKHVudGFnZ2VkLmF0dHJpYnV0ZXNbMV0pO1xuICAgICAgICAgICAgICAgICAgICBtYXAuc2hhcmVkID0gZ2V0TmFtc2VwYWNlSW5mbyh1bnRhZ2dlZC5hdHRyaWJ1dGVzWzJdKTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgICAgICBjb25uZWN0aW9uLm5hbWVzcGFjZXMgPSBtYXA7XG5cbiAgICAgICAgLy8gbWFrZSBzdXJlIHRoYXQgd2UgaGF2ZSB0aGUgZmlyc3QgcGVyc29uYWwgbmFtZXNwYWNlIGFsd2F5cyBzZXRcbiAgICAgICAgaWYgKCFjb25uZWN0aW9uLm5hbWVzcGFjZXMucGVyc29uYWxbMF0pIHtcbiAgICAgICAgICAgIGNvbm5lY3Rpb24ubmFtZXNwYWNlcy5wZXJzb25hbFswXSA9IHsgcHJlZml4OiAnJywgZGVsaW1pdGVyOiAnLicgfTtcbiAgICAgICAgfVxuICAgICAgICBjb25uZWN0aW9uLm5hbWVzcGFjZXMucGVyc29uYWxbMF0ucHJlZml4ID0gY29ubmVjdGlvbi5uYW1lc3BhY2VzLnBlcnNvbmFsWzBdLnByZWZpeCB8fCAnJztcbiAgICAgICAgcmVzcG9uc2UubmV4dCgpO1xuXG4gICAgICAgIGNvbm5lY3Rpb24ubmFtZXNwYWNlID0gY29ubmVjdGlvbi5uYW1lc3BhY2VzLnBlcnNvbmFsWzBdO1xuXG4gICAgICAgIHJldHVybiBjb25uZWN0aW9uLm5hbWVzcGFjZTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgY29ubmVjdGlvbi5sb2cud2Fybih7IGVyciwgY2lkOiBjb25uZWN0aW9uLmlkIH0pO1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgZXJyb3I6IHRydWUsXG4gICAgICAgICAgICBzdGF0dXM6IGVyci5yZXNwb25zZVN0YXR1cyxcbiAgICAgICAgICAgIHRleHQ6IGVyci5yZXNwb25zZVRleHRcbiAgICAgICAgfTtcbiAgICB9XG59O1xuXG5hc3luYyBmdW5jdGlvbiBnZXRMaXN0UHJlZml4KGNvbm5lY3Rpb24pIHtcbiAgICBsZXQgcmVzcG9uc2U7XG4gICAgdHJ5IHtcbiAgICAgICAgbGV0IG1hcCA9IHt9O1xuICAgICAgICByZXNwb25zZSA9IGF3YWl0IGNvbm5lY3Rpb24uZXhlYygnTElTVCcsIFsnJywgJyddLCB7XG4gICAgICAgICAgICB1bnRhZ2dlZDoge1xuICAgICAgICAgICAgICAgIExJU1Q6IGFzeW5jIHVudGFnZ2VkID0+IHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKCF1bnRhZ2dlZC5hdHRyaWJ1dGVzIHx8ICF1bnRhZ2dlZC5hdHRyaWJ1dGVzLmxlbmd0aCkge1xuICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgICAgbWFwLmZsYWdzID0gbmV3IFNldCh1bnRhZ2dlZC5hdHRyaWJ1dGVzWzBdLm1hcChlbnRyeSA9PiBlbnRyeS52YWx1ZSkpO1xuICAgICAgICAgICAgICAgICAgICBtYXAuZGVsaW1pdGVyID0gdW50YWdnZWQuYXR0cmlidXRlc1sxXSAmJiB1bnRhZ2dlZC5hdHRyaWJ1dGVzWzFdLnZhbHVlO1xuICAgICAgICAgICAgICAgICAgICBtYXAucHJlZml4ID0gKHVudGFnZ2VkLmF0dHJpYnV0ZXNbMl0gJiYgdW50YWdnZWQuYXR0cmlidXRlc1syXS52YWx1ZSkgfHwgJyc7XG4gICAgICAgICAgICAgICAgICAgIGlmIChtYXAuZGVsaW1pdGVyICYmIG1hcC5wcmVmaXguY2hhckF0KDApID09PSBtYXAuZGVsaW1pdGVyKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBtYXAucHJlZml4ID0gbWFwLnByZWZpeC5zbGljZSgxKTtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgICAgIHJlc3BvbnNlLm5leHQoKTtcbiAgICAgICAgcmV0dXJuIG1hcDtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgY29ubmVjdGlvbi5sb2cud2Fybih7IGVyciwgY2lkOiBjb25uZWN0aW9uLmlkIH0pO1xuICAgICAgICByZXR1cm4ge307XG4gICAgfVxufVxuXG5mdW5jdGlvbiBnZXROYW1zZXBhY2VJbmZvKGF0dHJpYnV0ZSkge1xuICAgIGlmICghYXR0cmlidXRlIHx8ICFhdHRyaWJ1dGUubGVuZ3RoKSB7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG5cbiAgICByZXR1cm4gYXR0cmlidXRlXG4gICAgICAgIC5maWx0ZXIoZW50cnkgPT4gZW50cnkubGVuZ3RoID49IDIgJiYgdHlwZW9mIGVudHJ5WzBdLnZhbHVlID09PSAnc3RyaW5nJyAmJiB0eXBlb2YgZW50cnlbMV0udmFsdWUgPT09ICdzdHJpbmcnKVxuICAgICAgICAubWFwKGVudHJ5ID0+IHtcbiAgICAgICAgICAgIGxldCBwcmVmaXggPSBlbnRyeVswXS52YWx1ZTtcbiAgICAgICAgICAgIGxldCBkZWxpbWl0ZXIgPSBlbnRyeVsxXS52YWx1ZTtcblxuICAgICAgICAgICAgaWYgKGRlbGltaXRlciAmJiBwcmVmaXggJiYgcHJlZml4LmNoYXJBdChwcmVmaXgubGVuZ3RoIC0gMSkgIT09IGRlbGltaXRlcikge1xuICAgICAgICAgICAgICAgIHByZWZpeCArPSBkZWxpbWl0ZXI7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICByZXR1cm4geyBwcmVmaXgsIGRlbGltaXRlciB9O1xuICAgICAgICB9KTtcbn1cbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/namespace.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/noop.js":
|
|
/*!****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/noop.js ***!
|
|
\****************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\n// Sends a NO-OP command\nmodule.exports = async connection => {\n try {\n let response = await connection.exec('NOOP', false, { comment: 'Requested by command' });\n response.next();\n return true;\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL25vb3AuanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWI7QUFDQTtBQUNBO0FBQ0EsOERBQThELGlDQUFpQztBQUMvRjtBQUNBO0FBQ0EsTUFBTTtBQUNOLDhCQUE4Qix5QkFBeUI7QUFDdkQ7QUFDQTtBQUNBIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvbm9vcC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbi8vIFNlbmRzIGEgTk8tT1AgY29tbWFuZFxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyBjb25uZWN0aW9uID0+IHtcbiAgICB0cnkge1xuICAgICAgICBsZXQgcmVzcG9uc2UgPSBhd2FpdCBjb25uZWN0aW9uLmV4ZWMoJ05PT1AnLCBmYWxzZSwgeyBjb21tZW50OiAnUmVxdWVzdGVkIGJ5IGNvbW1hbmQnIH0pO1xuICAgICAgICByZXNwb25zZS5uZXh0KCk7XG4gICAgICAgIHJldHVybiB0cnVlO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICBjb25uZWN0aW9uLmxvZy53YXJuKHsgZXJyLCBjaWQ6IGNvbm5lY3Rpb24uaWQgfSk7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG59O1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/noop.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/quota.js":
|
|
/*!*****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/quota.js ***!
|
|
\*****************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { encodePath, getStatusCode, normalizePath, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(rsc)/./node_modules/imapflow/lib/tools.js\");\n\n// Requests quota information for a mailbox\nmodule.exports = async (connection, path) => {\n if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state) || !path) {\n // nothing to do here\n return;\n }\n\n if (!connection.capabilities.has('QUOTA')) {\n return false;\n }\n\n path = normalizePath(connection, path);\n\n let map = { path };\n\n let processQuotaResponse = untagged => {\n let attributes = untagged.attributes && untagged.attributes[1];\n if (!attributes || !attributes.length) {\n return false;\n }\n\n let key = false;\n attributes.forEach((attribute, i) => {\n if (i % 3 === 0) {\n key = attribute && typeof attribute.value === 'string' ? attribute.value.toLowerCase() : false;\n return;\n }\n if (!key) {\n return;\n }\n\n let value = attribute && typeof attribute.value === 'string' && !isNaN(attribute.value) ? Number(attribute.value) : false;\n if (value === false) {\n return;\n }\n\n if (i % 3 === 1) {\n // usage\n if (!map[key]) {\n map[key] = {};\n }\n map[key].usage = value * (key === 'storage' ? 1024 : 1);\n }\n\n if (i % 3 === 2) {\n // limit\n if (!map[key]) {\n map[key] = {};\n }\n map[key].limit = value * (key === 'storage' ? 1024 : 1);\n\n if (map[key].limit) {\n map[key].status = Math.round(((map[key].usage || 0) / map[key].limit) * 100) + '%';\n }\n }\n });\n };\n\n let quotaFound = false;\n let response;\n try {\n response = await connection.exec('GETQUOTAROOT', [{ type: 'ATOM', value: encodePath(connection, path) }], {\n untagged: {\n QUOTAROOT: async untagged => {\n let quotaRoot =\n untagged.attributes && untagged.attributes[1] && typeof untagged.attributes[1].value === 'string'\n ? untagged.attributes[1].value\n : false;\n if (quotaRoot) {\n map.quotaRoot = quotaRoot;\n }\n },\n QUOTA: async untagged => {\n quotaFound = true;\n processQuotaResponse(untagged);\n }\n }\n });\n\n response.next();\n\n if (map.quotaRoot && !quotaFound) {\n response = await connection.exec('GETQUOTA', [{ type: 'ATOM', value: map.quotaRoot }], {\n untagged: {\n QUOTA: async untagged => {\n processQuotaResponse(untagged);\n }\n }\n });\n }\n\n return map;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL3F1b3RhLmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViLFFBQVEseURBQXlELEVBQUUsbUJBQU8sQ0FBQywrREFBYTs7QUFFeEY7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQSxnQkFBZ0I7O0FBRWhCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDs7QUFFQTtBQUNBO0FBQ0E7QUFDQSw0REFBNEQsbURBQW1EO0FBQy9HO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGlCQUFpQjtBQUNqQjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUzs7QUFFVDs7QUFFQTtBQUNBLDREQUE0RCxvQ0FBb0M7QUFDaEc7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjs7QUFFQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDhCQUE4Qix5QkFBeUI7QUFDdkQ7QUFDQTtBQUNBIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvcXVvdGEuanMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCB7IGVuY29kZVBhdGgsIGdldFN0YXR1c0NvZGUsIG5vcm1hbGl6ZVBhdGgsIGdldEVycm9yVGV4dCB9ID0gcmVxdWlyZSgnLi4vdG9vbHMuanMnKTtcblxuLy8gUmVxdWVzdHMgcXVvdGEgaW5mb3JtYXRpb24gZm9yIGEgbWFpbGJveFxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyAoY29ubmVjdGlvbiwgcGF0aCkgPT4ge1xuICAgIGlmICghW2Nvbm5lY3Rpb24uc3RhdGVzLkFVVEhFTlRJQ0FURUQsIGNvbm5lY3Rpb24uc3RhdGVzLlNFTEVDVEVEXS5pbmNsdWRlcyhjb25uZWN0aW9uLnN0YXRlKSB8fCAhcGF0aCkge1xuICAgICAgICAvLyBub3RoaW5nIHRvIGRvIGhlcmVcbiAgICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGlmICghY29ubmVjdGlvbi5jYXBhYmlsaXRpZXMuaGFzKCdRVU9UQScpKSB7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG5cbiAgICBwYXRoID0gbm9ybWFsaXplUGF0aChjb25uZWN0aW9uLCBwYXRoKTtcblxuICAgIGxldCBtYXAgPSB7IHBhdGggfTtcblxuICAgIGxldCBwcm9jZXNzUXVvdGFSZXNwb25zZSA9IHVudGFnZ2VkID0+IHtcbiAgICAgICAgbGV0IGF0dHJpYnV0ZXMgPSB1bnRhZ2dlZC5hdHRyaWJ1dGVzICYmIHVudGFnZ2VkLmF0dHJpYnV0ZXNbMV07XG4gICAgICAgIGlmICghYXR0cmlidXRlcyB8fCAhYXR0cmlidXRlcy5sZW5ndGgpIHtcbiAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgfVxuXG4gICAgICAgIGxldCBrZXkgPSBmYWxzZTtcbiAgICAgICAgYXR0cmlidXRlcy5mb3JFYWNoKChhdHRyaWJ1dGUsIGkpID0+IHtcbiAgICAgICAgICAgIGlmIChpICUgMyA9PT0gMCkge1xuICAgICAgICAgICAgICAgIGtleSA9IGF0dHJpYnV0ZSAmJiB0eXBlb2YgYXR0cmlidXRlLnZhbHVlID09PSAnc3RyaW5nJyA/IGF0dHJpYnV0ZS52YWx1ZS50b0xvd2VyQ2FzZSgpIDogZmFsc2U7XG4gICAgICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgaWYgKCFrZXkpIHtcbiAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIGxldCB2YWx1ZSA9IGF0dHJpYnV0ZSAmJiB0eXBlb2YgYXR0cmlidXRlLnZhbHVlID09PSAnc3RyaW5nJyAmJiAhaXNOYU4oYXR0cmlidXRlLnZhbHVlKSA/IE51bWJlcihhdHRyaWJ1dGUudmFsdWUpIDogZmFsc2U7XG4gICAgICAgICAgICBpZiAodmFsdWUgPT09IGZhbHNlKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICBpZiAoaSAlIDMgPT09IDEpIHtcbiAgICAgICAgICAgICAgICAvLyB1c2FnZVxuICAgICAgICAgICAgICAgIGlmICghbWFwW2tleV0pIHtcbiAgICAgICAgICAgICAgICAgICAgbWFwW2tleV0gPSB7fTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgbWFwW2tleV0udXNhZ2UgPSB2YWx1ZSAqIChrZXkgPT09ICdzdG9yYWdlJyA/IDEwMjQgOiAxKTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgaWYgKGkgJSAzID09PSAyKSB7XG4gICAgICAgICAgICAgICAgLy8gbGltaXRcbiAgICAgICAgICAgICAgICBpZiAoIW1hcFtrZXldKSB7XG4gICAgICAgICAgICAgICAgICAgIG1hcFtrZXldID0ge307XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIG1hcFtrZXldLmxpbWl0ID0gdmFsdWUgKiAoa2V5ID09PSAnc3RvcmFnZScgPyAxMDI0IDogMSk7XG5cbiAgICAgICAgICAgICAgICBpZiAobWFwW2tleV0ubGltaXQpIHtcbiAgICAgICAgICAgICAgICAgICAgbWFwW2tleV0uc3RhdHVzID0gTWF0aC5yb3VuZCgoKG1hcFtrZXldLnVzYWdlIHx8IDApIC8gbWFwW2tleV0ubGltaXQpICogMTAwKSArICclJztcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgIH07XG5cbiAgICBsZXQgcXVvdGFGb3VuZCA9IGZhbHNlO1xuICAgIGxldCByZXNwb25zZTtcbiAgICB0cnkge1xuICAgICAgICByZXNwb25zZSA9IGF3YWl0IGNvbm5lY3Rpb24uZXhlYygnR0VUUVVPVEFST09UJywgW3sgdHlwZTogJ0FUT00nLCB2YWx1ZTogZW5jb2RlUGF0aChjb25uZWN0aW9uLCBwYXRoKSB9XSwge1xuICAgICAgICAgICAgdW50YWdnZWQ6IHtcbiAgICAgICAgICAgICAgICBRVU9UQVJPT1Q6IGFzeW5jIHVudGFnZ2VkID0+IHtcbiAgICAgICAgICAgICAgICAgICAgbGV0IHF1b3RhUm9vdCA9XG4gICAgICAgICAgICAgICAgICAgICAgICB1bnRhZ2dlZC5hdHRyaWJ1dGVzICYmIHVudGFnZ2VkLmF0dHJpYnV0ZXNbMV0gJiYgdHlwZW9mIHVudGFnZ2VkLmF0dHJpYnV0ZXNbMV0udmFsdWUgPT09ICdzdHJpbmcnXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPyB1bnRhZ2dlZC5hdHRyaWJ1dGVzWzFdLnZhbHVlXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgOiBmYWxzZTtcbiAgICAgICAgICAgICAgICAgICAgaWYgKHF1b3RhUm9vdCkge1xuICAgICAgICAgICAgICAgICAgICAgICAgbWFwLnF1b3RhUm9vdCA9IHF1b3RhUm9vdDtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgUVVPVEE6IGFzeW5jIHVudGFnZ2VkID0+IHtcbiAgICAgICAgICAgICAgICAgICAgcXVvdGFGb3VuZCA9IHRydWU7XG4gICAgICAgICAgICAgICAgICAgIHByb2Nlc3NRdW90YVJlc3BvbnNlKHVudGFnZ2VkKTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgIH0pO1xuXG4gICAgICAgIHJlc3BvbnNlLm5leHQoKTtcblxuICAgICAgICBpZiAobWFwLnF1b3RhUm9vdCAmJiAhcXVvdGFGb3VuZCkge1xuICAgICAgICAgICAgcmVzcG9uc2UgPSBhd2FpdCBjb25uZWN0aW9uLmV4ZWMoJ0dFVFFVT1RBJywgW3sgdHlwZTogJ0FUT00nLCB2YWx1ZTogbWFwLnF1b3RhUm9vdCB9XSwge1xuICAgICAgICAgICAgICAgIHVudGFnZ2VkOiB7XG4gICAgICAgICAgICAgICAgICAgIFFVT1RBOiBhc3luYyB1bnRhZ2dlZCA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICBwcm9jZXNzUXVvdGFSZXNwb25zZSh1bnRhZ2dlZCk7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBtYXA7XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICAgIGxldCBlcnJvckNvZGUgPSBnZXRTdGF0dXNDb2RlKGVyci5yZXNwb25zZSk7XG4gICAgICAgIGlmIChlcnJvckNvZGUpIHtcbiAgICAgICAgICAgIGVyci5zZXJ2ZXJSZXNwb25zZUNvZGUgPSBlcnJvckNvZGU7XG4gICAgICAgIH1cbiAgICAgICAgZXJyLnJlc3BvbnNlID0gYXdhaXQgZ2V0RXJyb3JUZXh0KGVyci5yZXNwb25zZSk7XG5cbiAgICAgICAgY29ubmVjdGlvbi5sb2cud2Fybih7IGVyciwgY2lkOiBjb25uZWN0aW9uLmlkIH0pO1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxufTtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/quota.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/rename.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/rename.js ***!
|
|
\******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { encodePath, normalizePath, getStatusCode, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(rsc)/./node_modules/imapflow/lib/tools.js\");\n\n// Renames existing mailbox\nmodule.exports = async (connection, path, newPath) => {\n if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state)) {\n // nothing to do here\n return;\n }\n\n path = normalizePath(connection, path);\n newPath = normalizePath(connection, newPath);\n\n if (connection.states.SELECTED && connection.mailbox.path === path) {\n await connection.run('CLOSE');\n }\n\n let response;\n try {\n let map = {\n path,\n newPath\n };\n response = await connection.exec('RENAME', [\n { type: 'ATOM', value: encodePath(connection, path) },\n { type: 'ATOM', value: encodePath(connection, newPath) }\n ]);\n response.next();\n return map;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n throw err;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL3JlbmFtZS5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYixRQUFRLHlEQUF5RCxFQUFFLG1CQUFPLENBQUMsK0RBQWE7O0FBRXhGO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGNBQWMsbURBQW1EO0FBQ2pFLGNBQWM7QUFDZDtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSw4QkFBOEIseUJBQXlCO0FBQ3ZEO0FBQ0E7QUFDQSIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL3JlbmFtZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IHsgZW5jb2RlUGF0aCwgbm9ybWFsaXplUGF0aCwgZ2V0U3RhdHVzQ29kZSwgZ2V0RXJyb3JUZXh0IH0gPSByZXF1aXJlKCcuLi90b29scy5qcycpO1xuXG4vLyBSZW5hbWVzIGV4aXN0aW5nIG1haWxib3hcbm1vZHVsZS5leHBvcnRzID0gYXN5bmMgKGNvbm5lY3Rpb24sIHBhdGgsIG5ld1BhdGgpID0+IHtcbiAgICBpZiAoIVtjb25uZWN0aW9uLnN0YXRlcy5BVVRIRU5USUNBVEVELCBjb25uZWN0aW9uLnN0YXRlcy5TRUxFQ1RFRF0uaW5jbHVkZXMoY29ubmVjdGlvbi5zdGF0ZSkpIHtcbiAgICAgICAgLy8gbm90aGluZyB0byBkbyBoZXJlXG4gICAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBwYXRoID0gbm9ybWFsaXplUGF0aChjb25uZWN0aW9uLCBwYXRoKTtcbiAgICBuZXdQYXRoID0gbm9ybWFsaXplUGF0aChjb25uZWN0aW9uLCBuZXdQYXRoKTtcblxuICAgIGlmIChjb25uZWN0aW9uLnN0YXRlcy5TRUxFQ1RFRCAmJiBjb25uZWN0aW9uLm1haWxib3gucGF0aCA9PT0gcGF0aCkge1xuICAgICAgICBhd2FpdCBjb25uZWN0aW9uLnJ1bignQ0xPU0UnKTtcbiAgICB9XG5cbiAgICBsZXQgcmVzcG9uc2U7XG4gICAgdHJ5IHtcbiAgICAgICAgbGV0IG1hcCA9IHtcbiAgICAgICAgICAgIHBhdGgsXG4gICAgICAgICAgICBuZXdQYXRoXG4gICAgICAgIH07XG4gICAgICAgIHJlc3BvbnNlID0gYXdhaXQgY29ubmVjdGlvbi5leGVjKCdSRU5BTUUnLCBbXG4gICAgICAgICAgICB7IHR5cGU6ICdBVE9NJywgdmFsdWU6IGVuY29kZVBhdGgoY29ubmVjdGlvbiwgcGF0aCkgfSxcbiAgICAgICAgICAgIHsgdHlwZTogJ0FUT00nLCB2YWx1ZTogZW5jb2RlUGF0aChjb25uZWN0aW9uLCBuZXdQYXRoKSB9XG4gICAgICAgIF0pO1xuICAgICAgICByZXNwb25zZS5uZXh0KCk7XG4gICAgICAgIHJldHVybiBtYXA7XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICAgIGxldCBlcnJvckNvZGUgPSBnZXRTdGF0dXNDb2RlKGVyci5yZXNwb25zZSk7XG4gICAgICAgIGlmIChlcnJvckNvZGUpIHtcbiAgICAgICAgICAgIGVyci5zZXJ2ZXJSZXNwb25zZUNvZGUgPSBlcnJvckNvZGU7XG4gICAgICAgIH1cbiAgICAgICAgZXJyLnJlc3BvbnNlID0gYXdhaXQgZ2V0RXJyb3JUZXh0KGVyci5yZXNwb25zZSk7XG5cbiAgICAgICAgY29ubmVjdGlvbi5sb2cud2Fybih7IGVyciwgY2lkOiBjb25uZWN0aW9uLmlkIH0pO1xuICAgICAgICB0aHJvdyBlcnI7XG4gICAgfVxufTtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/rename.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/search.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/search.js ***!
|
|
\******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { getStatusCode, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(rsc)/./node_modules/imapflow/lib/tools.js\");\nconst { searchCompiler } = __webpack_require__(/*! ../search-compiler.js */ \"(rsc)/./node_modules/imapflow/lib/search-compiler.js\");\n\n// Updates flags for a message\nmodule.exports = async (connection, query, options) => {\n if (connection.state !== connection.states.SELECTED) {\n // nothing to do here\n return false;\n }\n\n options = options || {};\n\n let attributes;\n\n if (!query || query === true || (typeof query === 'object' && (!Object.keys(query).length || (Object.keys(query).length === 1 && query.all)))) {\n // search for all messages\n attributes = [{ type: 'ATOM', value: 'ALL' }];\n } else if (query && typeof query === 'object') {\n // normal query\n attributes = searchCompiler(connection, query);\n } else {\n return false;\n }\n\n let results = new Set();\n let response;\n try {\n response = await connection.exec(options.uid ? 'UID SEARCH' : 'SEARCH', attributes, {\n untagged: {\n SEARCH: async untagged => {\n if (untagged && untagged.attributes && untagged.attributes.length) {\n untagged.attributes.forEach(attribute => {\n if (attribute && attribute.value && typeof attribute.value === 'string' && !isNaN(attribute.value)) {\n results.add(Number(attribute.value));\n }\n });\n }\n }\n }\n });\n response.next();\n return Array.from(results).sort((a, b) => a - b);\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL3NlYXJjaC5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYixRQUFRLDhCQUE4QixFQUFFLG1CQUFPLENBQUMsK0RBQWE7QUFDN0QsUUFBUSxpQkFBaUIsRUFBRSxtQkFBTyxDQUFDLG1GQUF1Qjs7QUFFMUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBOztBQUVBO0FBQ0E7QUFDQSx3QkFBd0IsNEJBQTRCO0FBQ3BELE1BQU07QUFDTjtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHlCQUF5QjtBQUN6QjtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDhCQUE4Qix5QkFBeUI7QUFDdkQ7QUFDQTtBQUNBIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvc2VhcmNoLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgeyBnZXRTdGF0dXNDb2RlLCBnZXRFcnJvclRleHQgfSA9IHJlcXVpcmUoJy4uL3Rvb2xzLmpzJyk7XG5jb25zdCB7IHNlYXJjaENvbXBpbGVyIH0gPSByZXF1aXJlKCcuLi9zZWFyY2gtY29tcGlsZXIuanMnKTtcblxuLy8gVXBkYXRlcyBmbGFncyBmb3IgYSBtZXNzYWdlXG5tb2R1bGUuZXhwb3J0cyA9IGFzeW5jIChjb25uZWN0aW9uLCBxdWVyeSwgb3B0aW9ucykgPT4ge1xuICAgIGlmIChjb25uZWN0aW9uLnN0YXRlICE9PSBjb25uZWN0aW9uLnN0YXRlcy5TRUxFQ1RFRCkge1xuICAgICAgICAvLyBub3RoaW5nIHRvIGRvIGhlcmVcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cblxuICAgIG9wdGlvbnMgPSBvcHRpb25zIHx8IHt9O1xuXG4gICAgbGV0IGF0dHJpYnV0ZXM7XG5cbiAgICBpZiAoIXF1ZXJ5IHx8IHF1ZXJ5ID09PSB0cnVlIHx8ICh0eXBlb2YgcXVlcnkgPT09ICdvYmplY3QnICYmICghT2JqZWN0LmtleXMocXVlcnkpLmxlbmd0aCB8fCAoT2JqZWN0LmtleXMocXVlcnkpLmxlbmd0aCA9PT0gMSAmJiBxdWVyeS5hbGwpKSkpIHtcbiAgICAgICAgLy8gc2VhcmNoIGZvciBhbGwgbWVzc2FnZXNcbiAgICAgICAgYXR0cmlidXRlcyA9IFt7IHR5cGU6ICdBVE9NJywgdmFsdWU6ICdBTEwnIH1dO1xuICAgIH0gZWxzZSBpZiAocXVlcnkgJiYgdHlwZW9mIHF1ZXJ5ID09PSAnb2JqZWN0Jykge1xuICAgICAgICAvLyBub3JtYWwgcXVlcnlcbiAgICAgICAgYXR0cmlidXRlcyA9IHNlYXJjaENvbXBpbGVyKGNvbm5lY3Rpb24sIHF1ZXJ5KTtcbiAgICB9IGVsc2Uge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuXG4gICAgbGV0IHJlc3VsdHMgPSBuZXcgU2V0KCk7XG4gICAgbGV0IHJlc3BvbnNlO1xuICAgIHRyeSB7XG4gICAgICAgIHJlc3BvbnNlID0gYXdhaXQgY29ubmVjdGlvbi5leGVjKG9wdGlvbnMudWlkID8gJ1VJRCBTRUFSQ0gnIDogJ1NFQVJDSCcsIGF0dHJpYnV0ZXMsIHtcbiAgICAgICAgICAgIHVudGFnZ2VkOiB7XG4gICAgICAgICAgICAgICAgU0VBUkNIOiBhc3luYyB1bnRhZ2dlZCA9PiB7XG4gICAgICAgICAgICAgICAgICAgIGlmICh1bnRhZ2dlZCAmJiB1bnRhZ2dlZC5hdHRyaWJ1dGVzICYmIHVudGFnZ2VkLmF0dHJpYnV0ZXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICB1bnRhZ2dlZC5hdHRyaWJ1dGVzLmZvckVhY2goYXR0cmlidXRlID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZiAoYXR0cmlidXRlICYmIGF0dHJpYnV0ZS52YWx1ZSAmJiB0eXBlb2YgYXR0cmlidXRlLnZhbHVlID09PSAnc3RyaW5nJyAmJiAhaXNOYU4oYXR0cmlidXRlLnZhbHVlKSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICByZXN1bHRzLmFkZChOdW1iZXIoYXR0cmlidXRlLnZhbHVlKSk7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgICAgICByZXNwb25zZS5uZXh0KCk7XG4gICAgICAgIHJldHVybiBBcnJheS5mcm9tKHJlc3VsdHMpLnNvcnQoKGEsIGIpID0+IGEgLSBiKTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgbGV0IGVycm9yQ29kZSA9IGdldFN0YXR1c0NvZGUoZXJyLnJlc3BvbnNlKTtcbiAgICAgICAgaWYgKGVycm9yQ29kZSkge1xuICAgICAgICAgICAgZXJyLnNlcnZlclJlc3BvbnNlQ29kZSA9IGVycm9yQ29kZTtcbiAgICAgICAgfVxuICAgICAgICBlcnIucmVzcG9uc2UgPSBhd2FpdCBnZXRFcnJvclRleHQoZXJyLnJlc3BvbnNlKTtcblxuICAgICAgICBjb25uZWN0aW9uLmxvZy53YXJuKHsgZXJyLCBjaWQ6IGNvbm5lY3Rpb24uaWQgfSk7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG59O1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/search.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/select.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/select.js ***!
|
|
\******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { encodePath, normalizePath, getStatusCode, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(rsc)/./node_modules/imapflow/lib/tools.js\");\n\n// Selects a mailbox\nmodule.exports = async (connection, path, options) => {\n if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state)) {\n // nothing to do here\n return;\n }\n options = options || {};\n\n path = normalizePath(connection, path);\n\n if (!connection.folders.has(path)) {\n let folders = await connection.run('LIST', '', path);\n if (!folders) {\n throw new Error('Failed to fetch folders');\n }\n folders.forEach(folder => {\n connection.folders.set(folder.path, folder);\n });\n }\n\n let folderListData = connection.folders.has(path) ? connection.folders.get(path) : false;\n\n let response;\n try {\n let map = { path };\n if (folderListData) {\n ['delimiter', 'specialUse', 'subscribed', 'listed'].forEach(key => {\n if (folderListData[key]) {\n map[key] = folderListData[key];\n }\n });\n }\n\n let extraArgs = [];\n if (connection.enabled.has('QRESYNC') && options.changedSince && options.uidValidity) {\n extraArgs.push([\n { type: 'ATOM', value: 'QRESYNC' },\n [\n { type: 'ATOM', value: options.uidValidity?.toString() },\n { type: 'ATOM', value: options.changedSince.toString() }\n ]\n ]);\n map.qresync = true;\n }\n\n let encodedPath = encodePath(connection, path);\n\n let selectCommand = {\n command: !options.readOnly ? 'SELECT' : 'EXAMINE',\n arguments: [{ type: encodedPath.indexOf('&') >= 0 ? 'STRING' : 'ATOM', value: encodedPath }].concat(extraArgs || [])\n };\n\n response = await connection.exec(selectCommand.command, selectCommand.arguments, {\n untagged: {\n OK: async untagged => {\n if (!untagged.attributes || !untagged.attributes.length) {\n return;\n }\n let section = !untagged.attributes[0].value && untagged.attributes[0].section;\n if (section && section.length > 1 && section[0].type === 'ATOM' && typeof section[0].value === 'string') {\n let key = section[0].value.toLowerCase();\n let value;\n\n if (typeof section[1].value === 'string') {\n value = section[1].value;\n } else if (Array.isArray(section[1])) {\n value = section[1].map(entry => (typeof entry.value === 'string' ? entry.value : false)).filter(entry => entry);\n }\n\n switch (key) {\n case 'highestmodseq':\n key = 'highestModseq';\n if (/^[0-9]+$/.test(value)) {\n value = BigInt(value);\n }\n break;\n\n case 'mailboxid':\n key = 'mailboxId';\n if (Array.isArray(value) && value.length) {\n value = value[0];\n }\n break;\n\n case 'permanentflags':\n key = 'permanentFlags';\n value = new Set(value);\n break;\n\n case 'uidnext':\n key = 'uidNext';\n value = Number(value);\n break;\n\n case 'uidvalidity':\n key = 'uidValidity';\n if (/^[0-9]+$/.test(value)) {\n value = BigInt(value);\n }\n break;\n }\n\n map[key] = value;\n }\n\n if (section && section.length === 1 && section[0].type === 'ATOM' && typeof section[0].value === 'string') {\n let key = section[0].value.toLowerCase();\n switch (key) {\n case 'nomodseq':\n key = 'noModseq';\n map[key] = true;\n break;\n }\n }\n },\n FLAGS: async untagged => {\n if (!untagged.attributes || (!untagged.attributes.length && Array.isArray(untagged.attributes[0]))) {\n return;\n }\n let flags = untagged.attributes[0].map(flag => (typeof flag.value === 'string' ? flag.value : false)).filter(flag => flag);\n map.flags = new Set(flags);\n },\n EXISTS: async untagged => {\n let num = Number(untagged.command);\n if (isNaN(num)) {\n return false;\n }\n\n map.exists = num;\n },\n VANISHED: async untagged => {\n await connection.untaggedVanished(\n untagged,\n // mailbox is not yet open, so use a dummy mailbox object\n { path, uidNext: false, uidValidity: false }\n );\n },\n // we should only get an untagged FETCH for a SELECT/EXAMINE if QRESYNC was asked for\n FETCH: async untagged => {\n await connection.untaggedFetch(\n untagged,\n // mailbox is not yet open, so use a dummy mailbox object\n { path, uidNext: false, uidValidity: false }\n );\n }\n }\n });\n\n let section = !response.response.attributes[0].value && response.response.attributes[0].section;\n if (section && section.length && section[0].type === 'ATOM' && typeof section[0].value === 'string') {\n switch (section[0].value.toUpperCase()) {\n case 'READ-ONLY':\n map.readOnly = true;\n break;\n case 'READ-WRITE':\n default:\n map.readOnly = false;\n break;\n }\n }\n\n if (\n map.qresync &&\n // UIDVALIDITY must be the same\n (options.uidValidity !== map.uidValidity ||\n // HIGHESTMODSEQ response must be present\n !map.highestModseq ||\n // NOMODSEQ is not allowed\n map.noModseq)\n ) {\n // QRESYNC does not apply here, so unset it\n map.qresync = false;\n }\n\n let currentMailbox = connection.mailbox;\n connection.mailbox = false;\n\n if (currentMailbox && currentMailbox.path !== path) {\n connection.emit('mailboxClose', currentMailbox);\n }\n\n connection.mailbox = map;\n connection.currentSelectCommand = selectCommand;\n connection.state = connection.states.SELECTED;\n\n if (!currentMailbox || currentMailbox.path !== path) {\n connection.emit('mailboxOpen', connection.mailbox);\n }\n\n response.next();\n return map;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n if (connection.state === connection.states.SELECTED) {\n // reset selected state\n\n let currentMailbox = connection.mailbox;\n\n connection.mailbox = false;\n connection.currentSelectCommand = false;\n connection.state = connection.states.AUTHENTICATED;\n\n if (currentMailbox) {\n connection.emit('mailboxClose', currentMailbox);\n }\n }\n\n connection.log.warn({ err, cid: connection.id });\n throw err;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/imapflow/lib/commands/select.js","mappings":"AAAa;;AAEb,QAAQ,yDAAyD,EAAE,mBAAO,CAAC,+DAAa;;AAExF;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;;AAEA;AACA;AACA,oBAAoB;AACpB;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;;AAEA;AACA;AACA;AACA,kBAAkB,gCAAgC;AAClD;AACA,sBAAsB,sDAAsD;AAC5E,sBAAsB;AACtB;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,0BAA0B,6EAA6E;AACvG;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,0BAA0B;AAC1B;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA,0BAA0B;AAC1B;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA,0BAA0B;AAC1B;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,8BAA8B,yBAAyB;AACvD;AACA;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/commands/select.js"],"sourcesContent":["'use strict';\n\nconst { encodePath, normalizePath, getStatusCode, getErrorText } = require('../tools.js');\n\n// Selects a mailbox\nmodule.exports = async (connection, path, options) => {\n    if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state)) {\n        // nothing to do here\n        return;\n    }\n    options = options || {};\n\n    path = normalizePath(connection, path);\n\n    if (!connection.folders.has(path)) {\n        let folders = await connection.run('LIST', '', path);\n        if (!folders) {\n            throw new Error('Failed to fetch folders');\n        }\n        folders.forEach(folder => {\n            connection.folders.set(folder.path, folder);\n        });\n    }\n\n    let folderListData = connection.folders.has(path) ? connection.folders.get(path) : false;\n\n    let response;\n    try {\n        let map = { path };\n        if (folderListData) {\n            ['delimiter', 'specialUse', 'subscribed', 'listed'].forEach(key => {\n                if (folderListData[key]) {\n                    map[key] = folderListData[key];\n                }\n            });\n        }\n\n        let extraArgs = [];\n        if (connection.enabled.has('QRESYNC') && options.changedSince && options.uidValidity) {\n            extraArgs.push([\n                { type: 'ATOM', value: 'QRESYNC' },\n                [\n                    { type: 'ATOM', value: options.uidValidity?.toString() },\n                    { type: 'ATOM', value: options.changedSince.toString() }\n                ]\n            ]);\n            map.qresync = true;\n        }\n\n        let encodedPath = encodePath(connection, path);\n\n        let selectCommand = {\n            command: !options.readOnly ? 'SELECT' : 'EXAMINE',\n            arguments: [{ type: encodedPath.indexOf('&') >= 0 ? 'STRING' : 'ATOM', value: encodedPath }].concat(extraArgs || [])\n        };\n\n        response = await connection.exec(selectCommand.command, selectCommand.arguments, {\n            untagged: {\n                OK: async untagged => {\n                    if (!untagged.attributes || !untagged.attributes.length) {\n                        return;\n                    }\n                    let section = !untagged.attributes[0].value && untagged.attributes[0].section;\n                    if (section && section.length > 1 && section[0].type === 'ATOM' && typeof section[0].value === 'string') {\n                        let key = section[0].value.toLowerCase();\n                        let value;\n\n                        if (typeof section[1].value === 'string') {\n                            value = section[1].value;\n                        } else if (Array.isArray(section[1])) {\n                            value = section[1].map(entry => (typeof entry.value === 'string' ? entry.value : false)).filter(entry => entry);\n                        }\n\n                        switch (key) {\n                            case 'highestmodseq':\n                                key = 'highestModseq';\n                                if (/^[0-9]+$/.test(value)) {\n                                    value = BigInt(value);\n                                }\n                                break;\n\n                            case 'mailboxid':\n                                key = 'mailboxId';\n                                if (Array.isArray(value) && value.length) {\n                                    value = value[0];\n                                }\n                                break;\n\n                            case 'permanentflags':\n                                key = 'permanentFlags';\n                                value = new Set(value);\n                                break;\n\n                            case 'uidnext':\n                                key = 'uidNext';\n                                value = Number(value);\n                                break;\n\n                            case 'uidvalidity':\n                                key = 'uidValidity';\n                                if (/^[0-9]+$/.test(value)) {\n                                    value = BigInt(value);\n                                }\n                                break;\n                        }\n\n                        map[key] = value;\n                    }\n\n                    if (section && section.length === 1 && section[0].type === 'ATOM' && typeof section[0].value === 'string') {\n                        let key = section[0].value.toLowerCase();\n                        switch (key) {\n                            case 'nomodseq':\n                                key = 'noModseq';\n                                map[key] = true;\n                                break;\n                        }\n                    }\n                },\n                FLAGS: async untagged => {\n                    if (!untagged.attributes || (!untagged.attributes.length && Array.isArray(untagged.attributes[0]))) {\n                        return;\n                    }\n                    let flags = untagged.attributes[0].map(flag => (typeof flag.value === 'string' ? flag.value : false)).filter(flag => flag);\n                    map.flags = new Set(flags);\n                },\n                EXISTS: async untagged => {\n                    let num = Number(untagged.command);\n                    if (isNaN(num)) {\n                        return false;\n                    }\n\n                    map.exists = num;\n                },\n                VANISHED: async untagged => {\n                    await connection.untaggedVanished(\n                        untagged,\n                        // mailbox is not yet open, so use a dummy mailbox object\n                        { path, uidNext: false, uidValidity: false }\n                    );\n                },\n                // we should only get an untagged FETCH for a SELECT/EXAMINE if QRESYNC was asked for\n                FETCH: async untagged => {\n                    await connection.untaggedFetch(\n                        untagged,\n                        // mailbox is not yet open, so use a dummy mailbox object\n                        { path, uidNext: false, uidValidity: false }\n                    );\n                }\n            }\n        });\n\n        let section = !response.response.attributes[0].value && response.response.attributes[0].section;\n        if (section && section.length && section[0].type === 'ATOM' && typeof section[0].value === 'string') {\n            switch (section[0].value.toUpperCase()) {\n                case 'READ-ONLY':\n                    map.readOnly = true;\n                    break;\n                case 'READ-WRITE':\n                default:\n                    map.readOnly = false;\n                    break;\n            }\n        }\n\n        if (\n            map.qresync &&\n            // UIDVALIDITY must be the same\n            (options.uidValidity !== map.uidValidity ||\n                // HIGHESTMODSEQ response must be present\n                !map.highestModseq ||\n                // NOMODSEQ is not allowed\n                map.noModseq)\n        ) {\n            // QRESYNC does not apply here, so unset it\n            map.qresync = false;\n        }\n\n        let currentMailbox = connection.mailbox;\n        connection.mailbox = false;\n\n        if (currentMailbox && currentMailbox.path !== path) {\n            connection.emit('mailboxClose', currentMailbox);\n        }\n\n        connection.mailbox = map;\n        connection.currentSelectCommand = selectCommand;\n        connection.state = connection.states.SELECTED;\n\n        if (!currentMailbox || currentMailbox.path !== path) {\n            connection.emit('mailboxOpen', connection.mailbox);\n        }\n\n        response.next();\n        return map;\n    } catch (err) {\n        let errorCode = getStatusCode(err.response);\n        if (errorCode) {\n            err.serverResponseCode = errorCode;\n        }\n        err.response = await getErrorText(err.response);\n\n        if (connection.state === connection.states.SELECTED) {\n            // reset selected state\n\n            let currentMailbox = connection.mailbox;\n\n            connection.mailbox = false;\n            connection.currentSelectCommand = false;\n            connection.state = connection.states.AUTHENTICATED;\n\n            if (currentMailbox) {\n                connection.emit('mailboxClose', currentMailbox);\n            }\n        }\n\n        connection.log.warn({ err, cid: connection.id });\n        throw err;\n    }\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/select.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/starttls.js":
|
|
/*!********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/starttls.js ***!
|
|
\********************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\n// Requests STARTTLS info from server\nmodule.exports = async connection => {\n if (!connection.capabilities.has('STARTTLS') || connection.secureConnection) {\n // nothing to do here\n return false;\n }\n\n let response;\n try {\n response = await connection.exec('STARTTLS');\n response.next();\n return true;\n } catch (err) {\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL3N0YXJ0dGxzLmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOLDhCQUE4Qix5QkFBeUI7QUFDdkQ7QUFDQTtBQUNBIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvY29tbWFuZHMvc3RhcnR0bHMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG4vLyBSZXF1ZXN0cyBTVEFSVFRMUyBpbmZvIGZyb20gc2VydmVyXG5tb2R1bGUuZXhwb3J0cyA9IGFzeW5jIGNvbm5lY3Rpb24gPT4ge1xuICAgIGlmICghY29ubmVjdGlvbi5jYXBhYmlsaXRpZXMuaGFzKCdTVEFSVFRMUycpIHx8IGNvbm5lY3Rpb24uc2VjdXJlQ29ubmVjdGlvbikge1xuICAgICAgICAvLyBub3RoaW5nIHRvIGRvIGhlcmVcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cblxuICAgIGxldCByZXNwb25zZTtcbiAgICB0cnkge1xuICAgICAgICByZXNwb25zZSA9IGF3YWl0IGNvbm5lY3Rpb24uZXhlYygnU1RBUlRUTFMnKTtcbiAgICAgICAgcmVzcG9uc2UubmV4dCgpO1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgY29ubmVjdGlvbi5sb2cud2Fybih7IGVyciwgY2lkOiBjb25uZWN0aW9uLmlkIH0pO1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxufTtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/starttls.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/status.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/status.js ***!
|
|
\******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { encodePath, normalizePath } = __webpack_require__(/*! ../tools.js */ \"(rsc)/./node_modules/imapflow/lib/tools.js\");\n\n// Requests info about a mailbox\nmodule.exports = async (connection, path, query) => {\n if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state) || !path) {\n // nothing to do here\n return false;\n }\n\n path = normalizePath(connection, path);\n let encodedPath = encodePath(connection, path);\n\n let attributes = [{ type: encodedPath.indexOf('&') >= 0 ? 'STRING' : 'ATOM', value: encodedPath }];\n\n let queryAttributes = [];\n Object.keys(query || {}).forEach(key => {\n if (!query[key]) {\n return;\n }\n\n switch (key.toUpperCase()) {\n case 'MESSAGES':\n case 'RECENT':\n case 'UIDNEXT':\n case 'UIDVALIDITY':\n case 'UNSEEN':\n queryAttributes.push({ type: 'ATOM', value: key.toUpperCase() });\n break;\n\n case 'HIGHESTMODSEQ':\n if (connection.capabilities.has('CONDSTORE')) {\n queryAttributes.push({ type: 'ATOM', value: key.toUpperCase() });\n }\n break;\n }\n });\n\n if (!queryAttributes.length) {\n return false;\n }\n\n attributes.push(queryAttributes);\n\n let response;\n try {\n let map = { path };\n response = await connection.exec('STATUS', attributes, {\n untagged: {\n STATUS: async untagged => {\n // If STATUS is for current mailbox then update mailbox values\n let updateCurrent = connection.state === connection.states.SELECTED && path === connection.mailbox.path;\n\n let list = untagged.attributes && Array.isArray(untagged.attributes[1]) ? untagged.attributes[1] : false;\n if (!list) {\n return;\n }\n let key;\n list.forEach((entry, i) => {\n if (i % 2 === 0) {\n key = entry && typeof entry.value === 'string' ? entry.value : false;\n return;\n }\n if (!key || !entry || typeof entry.value !== 'string') {\n return;\n }\n let value = false;\n switch (key.toUpperCase()) {\n case 'MESSAGES':\n key = 'messages';\n value = !isNaN(entry.value) ? Number(entry.value) : false;\n if (updateCurrent) {\n let prevCount = connection.mailbox.exists;\n if (prevCount !== value) {\n // somehow message count in current folder has changed?\n connection.mailbox.exists = value;\n connection.emit('exists', {\n path,\n count: value,\n prevCount\n });\n }\n }\n break;\n\n case 'RECENT':\n key = 'recent';\n value = !isNaN(entry.value) ? Number(entry.value) : false;\n break;\n\n case 'UIDNEXT':\n key = 'uidNext';\n value = !isNaN(entry.value) ? Number(entry.value) : false;\n if (updateCurrent) {\n connection.mailbox.uidNext = value;\n }\n break;\n\n case 'UIDVALIDITY':\n key = 'uidValidity';\n value = !isNaN(entry.value) ? BigInt(entry.value) : false;\n break;\n\n case 'UNSEEN':\n key = 'unseen';\n value = !isNaN(entry.value) ? Number(entry.value) : false;\n break;\n\n case 'HIGHESTMODSEQ':\n key = 'highestModseq';\n value = !isNaN(entry.value) ? BigInt(entry.value) : false;\n if (updateCurrent) {\n connection.mailbox.highestModseq = value;\n }\n break;\n }\n if (value === false) {\n return;\n }\n\n map[key] = value;\n });\n }\n }\n });\n response.next();\n return map;\n } catch (err) {\n if (err.responseStatus === 'NO') {\n let folders = await connection.run('LIST', '', path, { listOnly: true });\n if (folders && !folders.length) {\n let error = new Error(`Mailbox doesn't exist: ${path}`);\n error.code = 'NotFound';\n error.response = err;\n throw error;\n }\n }\n\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/imapflow/lib/commands/status.js","mappings":"AAAa;;AAEb,QAAQ,4BAA4B,EAAE,mBAAO,CAAC,+DAAa;;AAE3D;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,wBAAwB,6EAA6E;;AAErG;AACA,2BAA2B;AAC3B;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,uCAAuC,wCAAwC;AAC/E;;AAEA;AACA;AACA,2CAA2C,wCAAwC;AACnF;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;;AAEA;;AAEA;AACA;AACA,oBAAoB;AACpB;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,yCAAyC;AACzC;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,qBAAqB;AACrB;AACA;AACA,SAAS;AACT;AACA;AACA,MAAM;AACN;AACA,mEAAmE,gBAAgB;AACnF;AACA,gEAAgE,KAAK;AACrE;AACA;AACA;AACA;AACA;;AAEA,8BAA8B,yBAAyB;AACvD;AACA;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/commands/status.js"],"sourcesContent":["'use strict';\n\nconst { encodePath, normalizePath } = require('../tools.js');\n\n// Requests info about a mailbox\nmodule.exports = async (connection, path, query) => {\n    if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state) || !path) {\n        // nothing to do here\n        return false;\n    }\n\n    path = normalizePath(connection, path);\n    let encodedPath = encodePath(connection, path);\n\n    let attributes = [{ type: encodedPath.indexOf('&') >= 0 ? 'STRING' : 'ATOM', value: encodedPath }];\n\n    let queryAttributes = [];\n    Object.keys(query || {}).forEach(key => {\n        if (!query[key]) {\n            return;\n        }\n\n        switch (key.toUpperCase()) {\n            case 'MESSAGES':\n            case 'RECENT':\n            case 'UIDNEXT':\n            case 'UIDVALIDITY':\n            case 'UNSEEN':\n                queryAttributes.push({ type: 'ATOM', value: key.toUpperCase() });\n                break;\n\n            case 'HIGHESTMODSEQ':\n                if (connection.capabilities.has('CONDSTORE')) {\n                    queryAttributes.push({ type: 'ATOM', value: key.toUpperCase() });\n                }\n                break;\n        }\n    });\n\n    if (!queryAttributes.length) {\n        return false;\n    }\n\n    attributes.push(queryAttributes);\n\n    let response;\n    try {\n        let map = { path };\n        response = await connection.exec('STATUS', attributes, {\n            untagged: {\n                STATUS: async untagged => {\n                    // If STATUS is for current mailbox then update mailbox values\n                    let updateCurrent = connection.state === connection.states.SELECTED && path === connection.mailbox.path;\n\n                    let list = untagged.attributes && Array.isArray(untagged.attributes[1]) ? untagged.attributes[1] : false;\n                    if (!list) {\n                        return;\n                    }\n                    let key;\n                    list.forEach((entry, i) => {\n                        if (i % 2 === 0) {\n                            key = entry && typeof entry.value === 'string' ? entry.value : false;\n                            return;\n                        }\n                        if (!key || !entry || typeof entry.value !== 'string') {\n                            return;\n                        }\n                        let value = false;\n                        switch (key.toUpperCase()) {\n                            case 'MESSAGES':\n                                key = 'messages';\n                                value = !isNaN(entry.value) ? Number(entry.value) : false;\n                                if (updateCurrent) {\n                                    let prevCount = connection.mailbox.exists;\n                                    if (prevCount !== value) {\n                                        // somehow message count in current folder has changed?\n                                        connection.mailbox.exists = value;\n                                        connection.emit('exists', {\n                                            path,\n                                            count: value,\n                                            prevCount\n                                        });\n                                    }\n                                }\n                                break;\n\n                            case 'RECENT':\n                                key = 'recent';\n                                value = !isNaN(entry.value) ? Number(entry.value) : false;\n                                break;\n\n                            case 'UIDNEXT':\n                                key = 'uidNext';\n                                value = !isNaN(entry.value) ? Number(entry.value) : false;\n                                if (updateCurrent) {\n                                    connection.mailbox.uidNext = value;\n                                }\n                                break;\n\n                            case 'UIDVALIDITY':\n                                key = 'uidValidity';\n                                value = !isNaN(entry.value) ? BigInt(entry.value) : false;\n                                break;\n\n                            case 'UNSEEN':\n                                key = 'unseen';\n                                value = !isNaN(entry.value) ? Number(entry.value) : false;\n                                break;\n\n                            case 'HIGHESTMODSEQ':\n                                key = 'highestModseq';\n                                value = !isNaN(entry.value) ? BigInt(entry.value) : false;\n                                if (updateCurrent) {\n                                    connection.mailbox.highestModseq = value;\n                                }\n                                break;\n                        }\n                        if (value === false) {\n                            return;\n                        }\n\n                        map[key] = value;\n                    });\n                }\n            }\n        });\n        response.next();\n        return map;\n    } catch (err) {\n        if (err.responseStatus === 'NO') {\n            let folders = await connection.run('LIST', '', path, { listOnly: true });\n            if (folders && !folders.length) {\n                let error = new Error(`Mailbox doesn't exist: ${path}`);\n                error.code = 'NotFound';\n                error.response = err;\n                throw error;\n            }\n        }\n\n        connection.log.warn({ err, cid: connection.id });\n        return false;\n    }\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/status.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/store.js":
|
|
/*!*****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/store.js ***!
|
|
\*****************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { getStatusCode, formatFlag, canUseFlag, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(rsc)/./node_modules/imapflow/lib/tools.js\");\n\n// Updates flags for a message\nmodule.exports = async (connection, range, flags, options) => {\n if (connection.state !== connection.states.SELECTED || !range || (options.useLabels && !connection.capabilities.has('X-GM-EXT-1'))) {\n // nothing to do here\n return false;\n }\n\n options = options || {};\n let operation;\n\n operation = 'FLAGS';\n\n if (options.useLabels) {\n operation = 'X-GM-LABELS';\n } else if (options.silent) {\n operation = `${operation}.SILENT`;\n }\n\n switch ((options.operation || '').toLowerCase()) {\n case 'set':\n // do nothing, keep operation value as is\n break;\n case 'remove':\n operation = `-${operation}`;\n break;\n case 'add':\n default:\n operation = `+${operation}`;\n break;\n }\n\n flags = (Array.isArray(flags) ? flags : [].concat(flags || []))\n .map(flag => {\n flag = formatFlag(flag);\n\n if (!canUseFlag(connection.mailbox, flag) && operation !== 'remove') {\n // it does not seem that we can set this flag\n return false;\n }\n\n return flag;\n })\n .filter(flag => flag);\n\n if (!flags.length && options.operation !== 'set') {\n // nothing to do here\n return false;\n }\n\n let attributes = [{ type: 'SEQUENCE', value: range }, { type: 'ATOM', value: operation }, flags.map(flag => ({ type: 'ATOM', value: flag }))];\n\n if (options.unchangedSince && connection.enabled.has('CONDSTORE') && !connection.mailbox.noModseq) {\n attributes.push([\n {\n type: 'ATOM',\n value: 'UNCHANGEDSINCE'\n },\n {\n type: 'ATOM',\n value: options.unchangedSince.toString()\n }\n ]);\n }\n\n let response;\n try {\n response = await connection.exec(options.uid ? 'UID STORE' : 'STORE', attributes);\n response.next();\n return true;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL3N0b3JlLmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViLFFBQVEsc0RBQXNELEVBQUUsbUJBQU8sQ0FBQywrREFBYTs7QUFFckY7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBLE1BQU07QUFDTix1QkFBdUIsVUFBVTtBQUNqQzs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsNEJBQTRCLFVBQVU7QUFDdEM7QUFDQTtBQUNBO0FBQ0EsNEJBQTRCLFVBQVU7QUFDdEM7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxTQUFTO0FBQ1Q7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsd0JBQXdCLGdDQUFnQyxJQUFJLGdDQUFnQyx1QkFBdUIsMkJBQTJCOztBQUU5STtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsOEJBQThCLHlCQUF5QjtBQUN2RDtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L2xpYi9jb21tYW5kcy9zdG9yZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IHsgZ2V0U3RhdHVzQ29kZSwgZm9ybWF0RmxhZywgY2FuVXNlRmxhZywgZ2V0RXJyb3JUZXh0IH0gPSByZXF1aXJlKCcuLi90b29scy5qcycpO1xuXG4vLyBVcGRhdGVzIGZsYWdzIGZvciBhIG1lc3NhZ2Vcbm1vZHVsZS5leHBvcnRzID0gYXN5bmMgKGNvbm5lY3Rpb24sIHJhbmdlLCBmbGFncywgb3B0aW9ucykgPT4ge1xuICAgIGlmIChjb25uZWN0aW9uLnN0YXRlICE9PSBjb25uZWN0aW9uLnN0YXRlcy5TRUxFQ1RFRCB8fCAhcmFuZ2UgfHwgKG9wdGlvbnMudXNlTGFiZWxzICYmICFjb25uZWN0aW9uLmNhcGFiaWxpdGllcy5oYXMoJ1gtR00tRVhULTEnKSkpIHtcbiAgICAgICAgLy8gbm90aGluZyB0byBkbyBoZXJlXG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG5cbiAgICBvcHRpb25zID0gb3B0aW9ucyB8fCB7fTtcbiAgICBsZXQgb3BlcmF0aW9uO1xuXG4gICAgb3BlcmF0aW9uID0gJ0ZMQUdTJztcblxuICAgIGlmIChvcHRpb25zLnVzZUxhYmVscykge1xuICAgICAgICBvcGVyYXRpb24gPSAnWC1HTS1MQUJFTFMnO1xuICAgIH0gZWxzZSBpZiAob3B0aW9ucy5zaWxlbnQpIHtcbiAgICAgICAgb3BlcmF0aW9uID0gYCR7b3BlcmF0aW9ufS5TSUxFTlRgO1xuICAgIH1cblxuICAgIHN3aXRjaCAoKG9wdGlvbnMub3BlcmF0aW9uIHx8ICcnKS50b0xvd2VyQ2FzZSgpKSB7XG4gICAgICAgIGNhc2UgJ3NldCc6XG4gICAgICAgICAgICAvLyBkbyBub3RoaW5nLCBrZWVwIG9wZXJhdGlvbiB2YWx1ZSBhcyBpc1xuICAgICAgICAgICAgYnJlYWs7XG4gICAgICAgIGNhc2UgJ3JlbW92ZSc6XG4gICAgICAgICAgICBvcGVyYXRpb24gPSBgLSR7b3BlcmF0aW9ufWA7XG4gICAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSAnYWRkJzpcbiAgICAgICAgZGVmYXVsdDpcbiAgICAgICAgICAgIG9wZXJhdGlvbiA9IGArJHtvcGVyYXRpb259YDtcbiAgICAgICAgICAgIGJyZWFrO1xuICAgIH1cblxuICAgIGZsYWdzID0gKEFycmF5LmlzQXJyYXkoZmxhZ3MpID8gZmxhZ3MgOiBbXS5jb25jYXQoZmxhZ3MgfHwgW10pKVxuICAgICAgICAubWFwKGZsYWcgPT4ge1xuICAgICAgICAgICAgZmxhZyA9IGZvcm1hdEZsYWcoZmxhZyk7XG5cbiAgICAgICAgICAgIGlmICghY2FuVXNlRmxhZyhjb25uZWN0aW9uLm1haWxib3gsIGZsYWcpICYmIG9wZXJhdGlvbiAhPT0gJ3JlbW92ZScpIHtcbiAgICAgICAgICAgICAgICAvLyBpdCBkb2VzIG5vdCBzZWVtIHRoYXQgd2UgY2FuIHNldCB0aGlzIGZsYWdcbiAgICAgICAgICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIHJldHVybiBmbGFnO1xuICAgICAgICB9KVxuICAgICAgICAuZmlsdGVyKGZsYWcgPT4gZmxhZyk7XG5cbiAgICBpZiAoIWZsYWdzLmxlbmd0aCAmJiBvcHRpb25zLm9wZXJhdGlvbiAhPT0gJ3NldCcpIHtcbiAgICAgICAgLy8gbm90aGluZyB0byBkbyBoZXJlXG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG5cbiAgICBsZXQgYXR0cmlidXRlcyA9IFt7IHR5cGU6ICdTRVFVRU5DRScsIHZhbHVlOiByYW5nZSB9LCB7IHR5cGU6ICdBVE9NJywgdmFsdWU6IG9wZXJhdGlvbiB9LCBmbGFncy5tYXAoZmxhZyA9PiAoeyB0eXBlOiAnQVRPTScsIHZhbHVlOiBmbGFnIH0pKV07XG5cbiAgICBpZiAob3B0aW9ucy51bmNoYW5nZWRTaW5jZSAmJiBjb25uZWN0aW9uLmVuYWJsZWQuaGFzKCdDT05EU1RPUkUnKSAmJiAhY29ubmVjdGlvbi5tYWlsYm94Lm5vTW9kc2VxKSB7XG4gICAgICAgIGF0dHJpYnV0ZXMucHVzaChbXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgdHlwZTogJ0FUT00nLFxuICAgICAgICAgICAgICAgIHZhbHVlOiAnVU5DSEFOR0VEU0lOQ0UnXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIHR5cGU6ICdBVE9NJyxcbiAgICAgICAgICAgICAgICB2YWx1ZTogb3B0aW9ucy51bmNoYW5nZWRTaW5jZS50b1N0cmluZygpXG4gICAgICAgICAgICB9XG4gICAgICAgIF0pO1xuICAgIH1cblxuICAgIGxldCByZXNwb25zZTtcbiAgICB0cnkge1xuICAgICAgICByZXNwb25zZSA9IGF3YWl0IGNvbm5lY3Rpb24uZXhlYyhvcHRpb25zLnVpZCA/ICdVSUQgU1RPUkUnIDogJ1NUT1JFJywgYXR0cmlidXRlcyk7XG4gICAgICAgIHJlc3BvbnNlLm5leHQoKTtcbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICAgIGxldCBlcnJvckNvZGUgPSBnZXRTdGF0dXNDb2RlKGVyci5yZXNwb25zZSk7XG4gICAgICAgIGlmIChlcnJvckNvZGUpIHtcbiAgICAgICAgICAgIGVyci5zZXJ2ZXJSZXNwb25zZUNvZGUgPSBlcnJvckNvZGU7XG4gICAgICAgIH1cbiAgICAgICAgZXJyLnJlc3BvbnNlID0gYXdhaXQgZ2V0RXJyb3JUZXh0KGVyci5yZXNwb25zZSk7XG5cbiAgICAgICAgY29ubmVjdGlvbi5sb2cud2Fybih7IGVyciwgY2lkOiBjb25uZWN0aW9uLmlkIH0pO1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxufTtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/store.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/subscribe.js":
|
|
/*!*********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/subscribe.js ***!
|
|
\*********************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { encodePath, normalizePath, getStatusCode, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(rsc)/./node_modules/imapflow/lib/tools.js\");\n\n// Subscribes to a mailbox\nmodule.exports = async (connection, path) => {\n if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state)) {\n // nothing to do here\n return;\n }\n\n path = normalizePath(connection, path);\n\n let response;\n try {\n response = await connection.exec('SUBSCRIBE', [{ type: 'ATOM', value: encodePath(connection, path) }]);\n response.next();\n return true;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL3N1YnNjcmliZS5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYixRQUFRLHlEQUF5RCxFQUFFLG1CQUFPLENBQUMsK0RBQWE7O0FBRXhGO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0EseURBQXlELG1EQUFtRDtBQUM1RztBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsOEJBQThCLHlCQUF5QjtBQUN2RDtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L2xpYi9jb21tYW5kcy9zdWJzY3JpYmUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCB7IGVuY29kZVBhdGgsIG5vcm1hbGl6ZVBhdGgsIGdldFN0YXR1c0NvZGUsIGdldEVycm9yVGV4dCB9ID0gcmVxdWlyZSgnLi4vdG9vbHMuanMnKTtcblxuLy8gU3Vic2NyaWJlcyB0byBhIG1haWxib3hcbm1vZHVsZS5leHBvcnRzID0gYXN5bmMgKGNvbm5lY3Rpb24sIHBhdGgpID0+IHtcbiAgICBpZiAoIVtjb25uZWN0aW9uLnN0YXRlcy5BVVRIRU5USUNBVEVELCBjb25uZWN0aW9uLnN0YXRlcy5TRUxFQ1RFRF0uaW5jbHVkZXMoY29ubmVjdGlvbi5zdGF0ZSkpIHtcbiAgICAgICAgLy8gbm90aGluZyB0byBkbyBoZXJlXG4gICAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBwYXRoID0gbm9ybWFsaXplUGF0aChjb25uZWN0aW9uLCBwYXRoKTtcblxuICAgIGxldCByZXNwb25zZTtcbiAgICB0cnkge1xuICAgICAgICByZXNwb25zZSA9IGF3YWl0IGNvbm5lY3Rpb24uZXhlYygnU1VCU0NSSUJFJywgW3sgdHlwZTogJ0FUT00nLCB2YWx1ZTogZW5jb2RlUGF0aChjb25uZWN0aW9uLCBwYXRoKSB9XSk7XG4gICAgICAgIHJlc3BvbnNlLm5leHQoKTtcbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICAgIGxldCBlcnJvckNvZGUgPSBnZXRTdGF0dXNDb2RlKGVyci5yZXNwb25zZSk7XG4gICAgICAgIGlmIChlcnJvckNvZGUpIHtcbiAgICAgICAgICAgIGVyci5zZXJ2ZXJSZXNwb25zZUNvZGUgPSBlcnJvckNvZGU7XG4gICAgICAgIH1cbiAgICAgICAgZXJyLnJlc3BvbnNlID0gYXdhaXQgZ2V0RXJyb3JUZXh0KGVyci5yZXNwb25zZSk7XG5cbiAgICAgICAgY29ubmVjdGlvbi5sb2cud2Fybih7IGVyciwgY2lkOiBjb25uZWN0aW9uLmlkIH0pO1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxufTtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/subscribe.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/commands/unsubscribe.js":
|
|
/*!***********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/commands/unsubscribe.js ***!
|
|
\***********************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { encodePath, normalizePath, getStatusCode, getErrorText } = __webpack_require__(/*! ../tools.js */ \"(rsc)/./node_modules/imapflow/lib/tools.js\");\n\n// Unsubscribes from a mailbox\nmodule.exports = async (connection, path) => {\n if (![connection.states.AUTHENTICATED, connection.states.SELECTED].includes(connection.state)) {\n // nothing to do here\n return;\n }\n\n path = normalizePath(connection, path);\n\n let response;\n try {\n response = await connection.exec('UNSUBSCRIBE', [{ type: 'ATOM', value: encodePath(connection, path) }]);\n response.next();\n return true;\n } catch (err) {\n let errorCode = getStatusCode(err.response);\n if (errorCode) {\n err.serverResponseCode = errorCode;\n }\n\n err.response = await getErrorText(err.response);\n\n connection.log.warn({ err, cid: connection.id });\n return false;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2NvbW1hbmRzL3Vuc3Vic2NyaWJlLmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViLFFBQVEseURBQXlELEVBQUUsbUJBQU8sQ0FBQywrREFBYTs7QUFFeEY7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQSwyREFBMkQsbURBQW1EO0FBQzlHO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUEsOEJBQThCLHlCQUF5QjtBQUN2RDtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L2xpYi9jb21tYW5kcy91bnN1YnNjcmliZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IHsgZW5jb2RlUGF0aCwgbm9ybWFsaXplUGF0aCwgZ2V0U3RhdHVzQ29kZSwgZ2V0RXJyb3JUZXh0IH0gPSByZXF1aXJlKCcuLi90b29scy5qcycpO1xuXG4vLyBVbnN1YnNjcmliZXMgZnJvbSBhIG1haWxib3hcbm1vZHVsZS5leHBvcnRzID0gYXN5bmMgKGNvbm5lY3Rpb24sIHBhdGgpID0+IHtcbiAgICBpZiAoIVtjb25uZWN0aW9uLnN0YXRlcy5BVVRIRU5USUNBVEVELCBjb25uZWN0aW9uLnN0YXRlcy5TRUxFQ1RFRF0uaW5jbHVkZXMoY29ubmVjdGlvbi5zdGF0ZSkpIHtcbiAgICAgICAgLy8gbm90aGluZyB0byBkbyBoZXJlXG4gICAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBwYXRoID0gbm9ybWFsaXplUGF0aChjb25uZWN0aW9uLCBwYXRoKTtcblxuICAgIGxldCByZXNwb25zZTtcbiAgICB0cnkge1xuICAgICAgICByZXNwb25zZSA9IGF3YWl0IGNvbm5lY3Rpb24uZXhlYygnVU5TVUJTQ1JJQkUnLCBbeyB0eXBlOiAnQVRPTScsIHZhbHVlOiBlbmNvZGVQYXRoKGNvbm5lY3Rpb24sIHBhdGgpIH1dKTtcbiAgICAgICAgcmVzcG9uc2UubmV4dCgpO1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgbGV0IGVycm9yQ29kZSA9IGdldFN0YXR1c0NvZGUoZXJyLnJlc3BvbnNlKTtcbiAgICAgICAgaWYgKGVycm9yQ29kZSkge1xuICAgICAgICAgICAgZXJyLnNlcnZlclJlc3BvbnNlQ29kZSA9IGVycm9yQ29kZTtcbiAgICAgICAgfVxuXG4gICAgICAgIGVyci5yZXNwb25zZSA9IGF3YWl0IGdldEVycm9yVGV4dChlcnIucmVzcG9uc2UpO1xuXG4gICAgICAgIGNvbm5lY3Rpb24ubG9nLndhcm4oeyBlcnIsIGNpZDogY29ubmVjdGlvbi5pZCB9KTtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbn07XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/commands/unsubscribe.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/handler/imap-compiler.js":
|
|
/*!************************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/handler/imap-compiler.js ***!
|
|
\************************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("/* eslint no-console: 0, new-cap: 0 */\n\n\n\nconst imapFormalSyntax = __webpack_require__(/*! ./imap-formal-syntax */ \"(rsc)/./node_modules/imapflow/lib/handler/imap-formal-syntax.js\");\n\nconst formatRespEntry = (entry, returnEmpty) => {\n if (typeof entry === 'string') {\n return Buffer.from(entry);\n }\n\n if (typeof entry === 'number') {\n return Buffer.from(entry.toString());\n }\n\n if (Buffer.isBuffer(entry)) {\n return entry;\n }\n\n if (returnEmpty) {\n return null;\n }\n\n return Buffer.alloc(0);\n};\n\n/**\n * Compiles an input object into\n */\nmodule.exports = async (response, options) => {\n let { asArray, isLogging, literalPlus, literalMinus } = options || {};\n const respParts = [];\n\n let resp = [].concat(formatRespEntry(response.tag, true) || []).concat(response.command ? formatRespEntry(' ' + response.command) : []);\n let val;\n let lastType;\n\n let walk = async (node, options) => {\n options = options || {};\n\n let lastRespEntry = resp.length && resp[resp.length - 1];\n let lastRespByte = (lastRespEntry && lastRespEntry.length && lastRespEntry[lastRespEntry.length - 1]) || '';\n if (typeof lastRespByte === 'number') {\n lastRespByte = String.fromCharCode(lastRespByte);\n }\n\n if (lastType === 'LITERAL' || (!['(', '<', '['].includes(lastRespByte) && resp.length)) {\n if (options.subArray) {\n // ignore separator\n } else {\n resp.push(formatRespEntry(' '));\n }\n }\n\n if (node && node.buffer && !Buffer.isBuffer(node)) {\n // mongodb binary\n node = node.buffer;\n }\n\n if (Array.isArray(node)) {\n lastType = 'LIST';\n resp.push(formatRespEntry('('));\n\n // check if we need to skip separator WS between two arrays\n let subArray = node.length > 1 && Array.isArray(node[0]);\n\n for (let child of node) {\n if (subArray && !Array.isArray(child)) {\n subArray = false;\n }\n await walk(child, { subArray });\n }\n\n resp.push(formatRespEntry(')'));\n return;\n }\n\n if (!node && typeof node !== 'string' && typeof node !== 'number' && !Buffer.isBuffer(node)) {\n resp.push(formatRespEntry('NIL'));\n return;\n }\n\n if (typeof node === 'string' || Buffer.isBuffer(node)) {\n if (isLogging && node.length > 100) {\n resp.push(formatRespEntry('\"(* ' + node.length + 'B string *)\"'));\n } else {\n resp.push(formatRespEntry(JSON.stringify(node.toString())));\n }\n return;\n }\n\n if (typeof node === 'number') {\n resp.push(formatRespEntry(Math.round(node) || 0)); // Only integers allowed\n return;\n }\n\n lastType = node.type;\n\n if (isLogging && node.sensitive) {\n resp.push(formatRespEntry('\"(* value hidden *)\"'));\n return;\n }\n\n switch (node.type.toUpperCase()) {\n case 'LITERAL':\n if (isLogging) {\n resp.push(formatRespEntry('\"(* ' + node.value.length + 'B literal *)\"'));\n } else {\n let literalLength = !node.value ? 0 : Math.max(node.value.length, 0);\n\n let canAppend = !asArray || literalPlus || (literalMinus && literalLength <= 4096);\n let usePlus = canAppend && (literalMinus || literalPlus);\n\n resp.push(formatRespEntry(`${node.isLiteral8 ? '~' : ''}{${literalLength}${usePlus ? '+' : ''}}\\r\\n`));\n\n if (canAppend) {\n if (node.value && node.value.length) {\n resp.push(formatRespEntry(node.value));\n }\n } else {\n respParts.push(resp);\n resp = [].concat(formatRespEntry(node.value, true) || []);\n }\n }\n break;\n\n case 'STRING':\n if (isLogging && node.value.length > 100) {\n resp.push(formatRespEntry('\"(* ' + node.value.length + 'B string *)\"'));\n } else {\n resp.push(formatRespEntry(JSON.stringify((node.value || '').toString())));\n }\n break;\n\n case 'TEXT':\n case 'SEQUENCE':\n if (node.value) {\n resp.push(formatRespEntry(node.value));\n }\n break;\n\n case 'NUMBER':\n resp.push(formatRespEntry(node.value || 0));\n break;\n\n case 'ATOM':\n case 'SECTION':\n val = (node.value || '').toString();\n\n if (!node.section || val) {\n if (node.value === '' || imapFormalSyntax.verify(val.charAt(0) === '\\\\' ? val.substr(1) : val, imapFormalSyntax['ATOM-CHAR']()) >= 0) {\n val = JSON.stringify(val);\n }\n\n resp.push(formatRespEntry(val));\n }\n\n if (node.section) {\n resp.push(formatRespEntry('['));\n\n for (let child of node.section) {\n await walk(child);\n }\n\n resp.push(formatRespEntry(']'));\n }\n if (node.partial) {\n resp.push(formatRespEntry(`<${node.partial.join('.')}>`));\n }\n break;\n }\n };\n\n if (response.attributes) {\n let attributes = Array.isArray(response.attributes) ? response.attributes : [].concat(response.attributes);\n for (let child of attributes) {\n await walk(child);\n }\n }\n\n if (resp.length) {\n respParts.push(resp);\n }\n\n for (let i = 0; i < respParts.length; i++) {\n respParts[i] = Buffer.concat(respParts[i]);\n }\n\n return asArray ? respParts : respParts.flatMap(entry => entry);\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/imapflow/lib/handler/imap-compiler.js","mappings":"AAAA;;AAEa;;AAEb,yBAAyB,mBAAO,CAAC,6FAAsB;;AAEvD;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,UAAU,gDAAgD;AAC1D;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,oCAAoC,UAAU;AAC9C;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;;AAEA;AACA,+DAA+D;AAC/D;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;;AAEA;AACA;;AAEA,iDAAiD,4BAA4B,EAAE,cAAc,EAAE,oBAAoB;;AAEnH;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,kDAAkD,uBAAuB;AACzE;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,oBAAoB,sBAAsB;AAC1C;AACA;;AAEA;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/handler/imap-compiler.js"],"sourcesContent":["/* eslint no-console: 0, new-cap: 0 */\n\n'use strict';\n\nconst imapFormalSyntax = require('./imap-formal-syntax');\n\nconst formatRespEntry = (entry, returnEmpty) => {\n    if (typeof entry === 'string') {\n        return Buffer.from(entry);\n    }\n\n    if (typeof entry === 'number') {\n        return Buffer.from(entry.toString());\n    }\n\n    if (Buffer.isBuffer(entry)) {\n        return entry;\n    }\n\n    if (returnEmpty) {\n        return null;\n    }\n\n    return Buffer.alloc(0);\n};\n\n/**\n * Compiles an input object into\n */\nmodule.exports = async (response, options) => {\n    let { asArray, isLogging, literalPlus, literalMinus } = options || {};\n    const respParts = [];\n\n    let resp = [].concat(formatRespEntry(response.tag, true) || []).concat(response.command ? formatRespEntry(' ' + response.command) : []);\n    let val;\n    let lastType;\n\n    let walk = async (node, options) => {\n        options = options || {};\n\n        let lastRespEntry = resp.length && resp[resp.length - 1];\n        let lastRespByte = (lastRespEntry && lastRespEntry.length && lastRespEntry[lastRespEntry.length - 1]) || '';\n        if (typeof lastRespByte === 'number') {\n            lastRespByte = String.fromCharCode(lastRespByte);\n        }\n\n        if (lastType === 'LITERAL' || (!['(', '<', '['].includes(lastRespByte) && resp.length)) {\n            if (options.subArray) {\n                // ignore separator\n            } else {\n                resp.push(formatRespEntry(' '));\n            }\n        }\n\n        if (node && node.buffer && !Buffer.isBuffer(node)) {\n            // mongodb binary\n            node = node.buffer;\n        }\n\n        if (Array.isArray(node)) {\n            lastType = 'LIST';\n            resp.push(formatRespEntry('('));\n\n            // check if we need to skip separator WS between two arrays\n            let subArray = node.length > 1 && Array.isArray(node[0]);\n\n            for (let child of node) {\n                if (subArray && !Array.isArray(child)) {\n                    subArray = false;\n                }\n                await walk(child, { subArray });\n            }\n\n            resp.push(formatRespEntry(')'));\n            return;\n        }\n\n        if (!node && typeof node !== 'string' && typeof node !== 'number' && !Buffer.isBuffer(node)) {\n            resp.push(formatRespEntry('NIL'));\n            return;\n        }\n\n        if (typeof node === 'string' || Buffer.isBuffer(node)) {\n            if (isLogging && node.length > 100) {\n                resp.push(formatRespEntry('\"(* ' + node.length + 'B string *)\"'));\n            } else {\n                resp.push(formatRespEntry(JSON.stringify(node.toString())));\n            }\n            return;\n        }\n\n        if (typeof node === 'number') {\n            resp.push(formatRespEntry(Math.round(node) || 0)); // Only integers allowed\n            return;\n        }\n\n        lastType = node.type;\n\n        if (isLogging && node.sensitive) {\n            resp.push(formatRespEntry('\"(* value hidden *)\"'));\n            return;\n        }\n\n        switch (node.type.toUpperCase()) {\n            case 'LITERAL':\n                if (isLogging) {\n                    resp.push(formatRespEntry('\"(* ' + node.value.length + 'B literal *)\"'));\n                } else {\n                    let literalLength = !node.value ? 0 : Math.max(node.value.length, 0);\n\n                    let canAppend = !asArray || literalPlus || (literalMinus && literalLength <= 4096);\n                    let usePlus = canAppend && (literalMinus || literalPlus);\n\n                    resp.push(formatRespEntry(`${node.isLiteral8 ? '~' : ''}{${literalLength}${usePlus ? '+' : ''}}\\r\\n`));\n\n                    if (canAppend) {\n                        if (node.value && node.value.length) {\n                            resp.push(formatRespEntry(node.value));\n                        }\n                    } else {\n                        respParts.push(resp);\n                        resp = [].concat(formatRespEntry(node.value, true) || []);\n                    }\n                }\n                break;\n\n            case 'STRING':\n                if (isLogging && node.value.length > 100) {\n                    resp.push(formatRespEntry('\"(* ' + node.value.length + 'B string *)\"'));\n                } else {\n                    resp.push(formatRespEntry(JSON.stringify((node.value || '').toString())));\n                }\n                break;\n\n            case 'TEXT':\n            case 'SEQUENCE':\n                if (node.value) {\n                    resp.push(formatRespEntry(node.value));\n                }\n                break;\n\n            case 'NUMBER':\n                resp.push(formatRespEntry(node.value || 0));\n                break;\n\n            case 'ATOM':\n            case 'SECTION':\n                val = (node.value || '').toString();\n\n                if (!node.section || val) {\n                    if (node.value === '' || imapFormalSyntax.verify(val.charAt(0) === '\\\\' ? val.substr(1) : val, imapFormalSyntax['ATOM-CHAR']()) >= 0) {\n                        val = JSON.stringify(val);\n                    }\n\n                    resp.push(formatRespEntry(val));\n                }\n\n                if (node.section) {\n                    resp.push(formatRespEntry('['));\n\n                    for (let child of node.section) {\n                        await walk(child);\n                    }\n\n                    resp.push(formatRespEntry(']'));\n                }\n                if (node.partial) {\n                    resp.push(formatRespEntry(`<${node.partial.join('.')}>`));\n                }\n                break;\n        }\n    };\n\n    if (response.attributes) {\n        let attributes = Array.isArray(response.attributes) ? response.attributes : [].concat(response.attributes);\n        for (let child of attributes) {\n            await walk(child);\n        }\n    }\n\n    if (resp.length) {\n        respParts.push(resp);\n    }\n\n    for (let i = 0; i < respParts.length; i++) {\n        respParts[i] = Buffer.concat(respParts[i]);\n    }\n\n    return asArray ? respParts : respParts.flatMap(entry => entry);\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/handler/imap-compiler.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/handler/imap-formal-syntax.js":
|
|
/*!*****************************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/handler/imap-formal-syntax.js ***!
|
|
\*****************************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("/* eslint object-shorthand:0, new-cap: 0, no-useless-concat: 0 */\n\n\n\n// IMAP Formal Syntax\n// http://tools.ietf.org/html/rfc3501#section-9\n\nfunction expandRange(start, end) {\n let chars = [];\n for (let i = start; i <= end; i++) {\n chars.push(i);\n }\n return String.fromCharCode(...chars);\n}\n\nfunction excludeChars(source, exclude) {\n let sourceArr = Array.prototype.slice.call(source);\n for (let i = sourceArr.length - 1; i >= 0; i--) {\n if (exclude.indexOf(sourceArr[i]) >= 0) {\n sourceArr.splice(i, 1);\n }\n }\n return sourceArr.join('');\n}\n\nmodule.exports = {\n CHAR() {\n let value = expandRange(0x01, 0x7f);\n this.CHAR = function () {\n return value;\n };\n return value;\n },\n\n CHAR8() {\n let value = expandRange(0x01, 0xff);\n this.CHAR8 = function () {\n return value;\n };\n return value;\n },\n\n SP() {\n return ' ';\n },\n\n CTL() {\n let value = expandRange(0x00, 0x1f) + '\\x7F';\n this.CTL = function () {\n return value;\n };\n return value;\n },\n\n DQUOTE() {\n return '\"';\n },\n\n ALPHA() {\n let value = expandRange(0x41, 0x5a) + expandRange(0x61, 0x7a);\n this.ALPHA = function () {\n return value;\n };\n return value;\n },\n\n DIGIT() {\n let value = expandRange(0x30, 0x39);\n this.DIGIT = function () {\n return value;\n };\n return value;\n },\n\n 'ATOM-CHAR'() {\n let value = excludeChars(this.CHAR(), this['atom-specials']());\n this['ATOM-CHAR'] = function () {\n return value;\n };\n return value;\n },\n\n 'ASTRING-CHAR'() {\n let value = this['ATOM-CHAR']() + this['resp-specials']();\n this['ASTRING-CHAR'] = function () {\n return value;\n };\n return value;\n },\n\n 'TEXT-CHAR'() {\n let value = excludeChars(this.CHAR(), '\\r\\n');\n this['TEXT-CHAR'] = function () {\n return value;\n };\n return value;\n },\n\n 'atom-specials'() {\n let value = '(' + ')' + '{' + this.SP() + this.CTL() + this['list-wildcards']() + this['quoted-specials']() + this['resp-specials']();\n this['atom-specials'] = function () {\n return value;\n };\n return value;\n },\n\n 'list-wildcards'() {\n return '%' + '*';\n },\n\n 'quoted-specials'() {\n let value = this.DQUOTE() + '\\\\';\n this['quoted-specials'] = function () {\n return value;\n };\n return value;\n },\n\n 'resp-specials'() {\n return ']';\n },\n\n tag() {\n let value = excludeChars(this['ASTRING-CHAR'](), '+');\n this.tag = function () {\n return value;\n };\n return value;\n },\n\n command() {\n let value = this.ALPHA() + this.DIGIT() + '-';\n this.command = function () {\n return value;\n };\n return value;\n },\n\n verify(str, allowedChars) {\n for (let i = 0, len = str.length; i < len; i++) {\n if (allowedChars.indexOf(str.charAt(i)) < 0) {\n return i;\n }\n }\n return -1;\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2hhbmRsZXIvaW1hcC1mb3JtYWwtc3ludGF4LmpzIiwibWFwcGluZ3MiOiJBQUFBOztBQUVhOztBQUViO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLHdCQUF3QixVQUFVO0FBQ2xDO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSx1Q0FBdUMsUUFBUTtBQUMvQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLOztBQUVMO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7O0FBRUw7QUFDQTtBQUNBLEtBQUs7O0FBRUw7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLOztBQUVMO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7O0FBRUw7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLOztBQUVMO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7O0FBRUw7QUFDQSxrQ0FBa0M7QUFDbEM7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLOztBQUVMO0FBQ0E7QUFDQSxLQUFLOztBQUVMO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7O0FBRUw7QUFDQTtBQUNBLEtBQUs7O0FBRUw7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLOztBQUVMO0FBQ0EsMENBQTBDLFNBQVM7QUFDbkQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L2xpYi9oYW5kbGVyL2ltYXAtZm9ybWFsLXN5bnRheC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQgb2JqZWN0LXNob3J0aGFuZDowLCBuZXctY2FwOiAwLCBuby11c2VsZXNzLWNvbmNhdDogMCAqL1xuXG4ndXNlIHN0cmljdCc7XG5cbi8vIElNQVAgRm9ybWFsIFN5bnRheFxuLy8gaHR0cDovL3Rvb2xzLmlldGYub3JnL2h0bWwvcmZjMzUwMSNzZWN0aW9uLTlcblxuZnVuY3Rpb24gZXhwYW5kUmFuZ2Uoc3RhcnQsIGVuZCkge1xuICAgIGxldCBjaGFycyA9IFtdO1xuICAgIGZvciAobGV0IGkgPSBzdGFydDsgaSA8PSBlbmQ7IGkrKykge1xuICAgICAgICBjaGFycy5wdXNoKGkpO1xuICAgIH1cbiAgICByZXR1cm4gU3RyaW5nLmZyb21DaGFyQ29kZSguLi5jaGFycyk7XG59XG5cbmZ1bmN0aW9uIGV4Y2x1ZGVDaGFycyhzb3VyY2UsIGV4Y2x1ZGUpIHtcbiAgICBsZXQgc291cmNlQXJyID0gQXJyYXkucHJvdG90eXBlLnNsaWNlLmNhbGwoc291cmNlKTtcbiAgICBmb3IgKGxldCBpID0gc291cmNlQXJyLmxlbmd0aCAtIDE7IGkgPj0gMDsgaS0tKSB7XG4gICAgICAgIGlmIChleGNsdWRlLmluZGV4T2Yoc291cmNlQXJyW2ldKSA+PSAwKSB7XG4gICAgICAgICAgICBzb3VyY2VBcnIuc3BsaWNlKGksIDEpO1xuICAgICAgICB9XG4gICAgfVxuICAgIHJldHVybiBzb3VyY2VBcnIuam9pbignJyk7XG59XG5cbm1vZHVsZS5leHBvcnRzID0ge1xuICAgIENIQVIoKSB7XG4gICAgICAgIGxldCB2YWx1ZSA9IGV4cGFuZFJhbmdlKDB4MDEsIDB4N2YpO1xuICAgICAgICB0aGlzLkNIQVIgPSBmdW5jdGlvbiAoKSB7XG4gICAgICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgICAgIH07XG4gICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICB9LFxuXG4gICAgQ0hBUjgoKSB7XG4gICAgICAgIGxldCB2YWx1ZSA9IGV4cGFuZFJhbmdlKDB4MDEsIDB4ZmYpO1xuICAgICAgICB0aGlzLkNIQVI4ID0gZnVuY3Rpb24gKCkge1xuICAgICAgICAgICAgcmV0dXJuIHZhbHVlO1xuICAgICAgICB9O1xuICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgfSxcblxuICAgIFNQKCkge1xuICAgICAgICByZXR1cm4gJyAnO1xuICAgIH0sXG5cbiAgICBDVEwoKSB7XG4gICAgICAgIGxldCB2YWx1ZSA9IGV4cGFuZFJhbmdlKDB4MDAsIDB4MWYpICsgJ1xceDdGJztcbiAgICAgICAgdGhpcy5DVEwgPSBmdW5jdGlvbiAoKSB7XG4gICAgICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgICAgIH07XG4gICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICB9LFxuXG4gICAgRFFVT1RFKCkge1xuICAgICAgICByZXR1cm4gJ1wiJztcbiAgICB9LFxuXG4gICAgQUxQSEEoKSB7XG4gICAgICAgIGxldCB2YWx1ZSA9IGV4cGFuZFJhbmdlKDB4NDEsIDB4NWEpICsgZXhwYW5kUmFuZ2UoMHg2MSwgMHg3YSk7XG4gICAgICAgIHRoaXMuQUxQSEEgPSBmdW5jdGlvbiAoKSB7XG4gICAgICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgICAgIH07XG4gICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICB9LFxuXG4gICAgRElHSVQoKSB7XG4gICAgICAgIGxldCB2YWx1ZSA9IGV4cGFuZFJhbmdlKDB4MzAsIDB4MzkpO1xuICAgICAgICB0aGlzLkRJR0lUID0gZnVuY3Rpb24gKCkge1xuICAgICAgICAgICAgcmV0dXJuIHZhbHVlO1xuICAgICAgICB9O1xuICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgfSxcblxuICAgICdBVE9NLUNIQVInKCkge1xuICAgICAgICBsZXQgdmFsdWUgPSBleGNsdWRlQ2hhcnModGhpcy5DSEFSKCksIHRoaXNbJ2F0b20tc3BlY2lhbHMnXSgpKTtcbiAgICAgICAgdGhpc1snQVRPTS1DSEFSJ10gPSBmdW5jdGlvbiAoKSB7XG4gICAgICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgICAgIH07XG4gICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICB9LFxuXG4gICAgJ0FTVFJJTkctQ0hBUicoKSB7XG4gICAgICAgIGxldCB2YWx1ZSA9IHRoaXNbJ0FUT00tQ0hBUiddKCkgKyB0aGlzWydyZXNwLXNwZWNpYWxzJ10oKTtcbiAgICAgICAgdGhpc1snQVNUUklORy1DSEFSJ10gPSBmdW5jdGlvbiAoKSB7XG4gICAgICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgICAgIH07XG4gICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICB9LFxuXG4gICAgJ1RFWFQtQ0hBUicoKSB7XG4gICAgICAgIGxldCB2YWx1ZSA9IGV4Y2x1ZGVDaGFycyh0aGlzLkNIQVIoKSwgJ1xcclxcbicpO1xuICAgICAgICB0aGlzWydURVhULUNIQVInXSA9IGZ1bmN0aW9uICgpIHtcbiAgICAgICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICAgICAgfTtcbiAgICAgICAgcmV0dXJuIHZhbHVlO1xuICAgIH0sXG5cbiAgICAnYXRvbS1zcGVjaWFscycoKSB7XG4gICAgICAgIGxldCB2YWx1ZSA9ICcoJyArICcpJyArICd7JyArIHRoaXMuU1AoKSArIHRoaXMuQ1RMKCkgKyB0aGlzWydsaXN0LXdpbGRjYXJkcyddKCkgKyB0aGlzWydxdW90ZWQtc3BlY2lhbHMnXSgpICsgdGhpc1sncmVzcC1zcGVjaWFscyddKCk7XG4gICAgICAgIHRoaXNbJ2F0b20tc3BlY2lhbHMnXSA9IGZ1bmN0aW9uICgpIHtcbiAgICAgICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICAgICAgfTtcbiAgICAgICAgcmV0dXJuIHZhbHVlO1xuICAgIH0sXG5cbiAgICAnbGlzdC13aWxkY2FyZHMnKCkge1xuICAgICAgICByZXR1cm4gJyUnICsgJyonO1xuICAgIH0sXG5cbiAgICAncXVvdGVkLXNwZWNpYWxzJygpIHtcbiAgICAgICAgbGV0IHZhbHVlID0gdGhpcy5EUVVPVEUoKSArICdcXFxcJztcbiAgICAgICAgdGhpc1sncXVvdGVkLXNwZWNpYWxzJ10gPSBmdW5jdGlvbiAoKSB7XG4gICAgICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgICAgIH07XG4gICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICB9LFxuXG4gICAgJ3Jlc3Atc3BlY2lhbHMnKCkge1xuICAgICAgICByZXR1cm4gJ10nO1xuICAgIH0sXG5cbiAgICB0YWcoKSB7XG4gICAgICAgIGxldCB2YWx1ZSA9IGV4Y2x1ZGVDaGFycyh0aGlzWydBU1RSSU5HLUNIQVInXSgpLCAnKycpO1xuICAgICAgICB0aGlzLnRhZyA9IGZ1bmN0aW9uICgpIHtcbiAgICAgICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICAgICAgfTtcbiAgICAgICAgcmV0dXJuIHZhbHVlO1xuICAgIH0sXG5cbiAgICBjb21tYW5kKCkge1xuICAgICAgICBsZXQgdmFsdWUgPSB0aGlzLkFMUEhBKCkgKyB0aGlzLkRJR0lUKCkgKyAnLSc7XG4gICAgICAgIHRoaXMuY29tbWFuZCA9IGZ1bmN0aW9uICgpIHtcbiAgICAgICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICAgICAgfTtcbiAgICAgICAgcmV0dXJuIHZhbHVlO1xuICAgIH0sXG5cbiAgICB2ZXJpZnkoc3RyLCBhbGxvd2VkQ2hhcnMpIHtcbiAgICAgICAgZm9yIChsZXQgaSA9IDAsIGxlbiA9IHN0ci5sZW5ndGg7IGkgPCBsZW47IGkrKykge1xuICAgICAgICAgICAgaWYgKGFsbG93ZWRDaGFycy5pbmRleE9mKHN0ci5jaGFyQXQoaSkpIDwgMCkge1xuICAgICAgICAgICAgICAgIHJldHVybiBpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIHJldHVybiAtMTtcbiAgICB9XG59O1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/handler/imap-formal-syntax.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/handler/imap-handler.js":
|
|
/*!***********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/handler/imap-handler.js ***!
|
|
\***********************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst parser = __webpack_require__(/*! ./imap-parser */ \"(rsc)/./node_modules/imapflow/lib/handler/imap-parser.js\");\nconst compiler = __webpack_require__(/*! ./imap-compiler */ \"(rsc)/./node_modules/imapflow/lib/handler/imap-compiler.js\");\n\nmodule.exports = {\n parser,\n compiler\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2hhbmRsZXIvaW1hcC1oYW5kbGVyLmpzIiwibWFwcGluZ3MiOiJBQUFhOztBQUViLGVBQWUsbUJBQU8sQ0FBQywrRUFBZTtBQUN0QyxpQkFBaUIsbUJBQU8sQ0FBQyxtRkFBaUI7O0FBRTFDO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvaGFuZGxlci9pbWFwLWhhbmRsZXIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCBwYXJzZXIgPSByZXF1aXJlKCcuL2ltYXAtcGFyc2VyJyk7XG5jb25zdCBjb21waWxlciA9IHJlcXVpcmUoJy4vaW1hcC1jb21waWxlcicpO1xuXG5tb2R1bGUuZXhwb3J0cyA9IHtcbiAgICBwYXJzZXIsXG4gICAgY29tcGlsZXJcbn07XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/handler/imap-handler.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/handler/imap-parser.js":
|
|
/*!**********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/handler/imap-parser.js ***!
|
|
\**********************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst imapFormalSyntax = __webpack_require__(/*! ./imap-formal-syntax */ \"(rsc)/./node_modules/imapflow/lib/handler/imap-formal-syntax.js\");\nconst { ParserInstance } = __webpack_require__(/*! ./parser-instance */ \"(rsc)/./node_modules/imapflow/lib/handler/parser-instance.js\");\n\nmodule.exports = async (command, options) => {\n options = options || {};\n\n let nullBytesRemoved = 0;\n\n // special case with a buggy IMAP server where responses are padded with zero bytes\n if (command[0] === 0) {\n // find the first non null byte and trim\n for (let i = 0; i < command.length; i++) {\n if (command[i] !== 0) {\n // trim to here\n command = command.slice(i);\n nullBytesRemoved = i;\n break;\n }\n }\n }\n\n const parser = new ParserInstance(command, options);\n const response = {};\n\n try {\n response.tag = await parser.getTag();\n\n await parser.getSpace();\n\n response.command = await parser.getCommand();\n\n if (nullBytesRemoved) {\n response.nullBytesRemoved = nullBytesRemoved;\n }\n\n if (['UID', 'AUTHENTICATE'].indexOf((response.command || '').toUpperCase()) >= 0) {\n await parser.getSpace();\n response.command += ' ' + (await parser.getElement(imapFormalSyntax.command()));\n }\n\n if (parser.remainder.trim().length) {\n await parser.getSpace();\n response.attributes = await parser.getAttributes();\n }\n\n if (parser.humanReadable) {\n response.attributes = (response.attributes || []).concat({\n type: 'TEXT',\n value: parser.humanReadable\n });\n }\n } catch (err) {\n if (err.code === 'ParserErrorExchange' && err.parserContext && err.parserContext.value) {\n return err.parserContext.value;\n }\n throw err;\n }\n\n return response;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2hhbmRsZXIvaW1hcC1wYXJzZXIuanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWIseUJBQXlCLG1CQUFPLENBQUMsNkZBQXNCO0FBQ3ZELFFBQVEsaUJBQWlCLEVBQUUsbUJBQU8sQ0FBQyx1RkFBbUI7O0FBRXREO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0Esd0JBQXdCLG9CQUFvQjtBQUM1QztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9saWIvaGFuZGxlci9pbWFwLXBhcnNlci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IGltYXBGb3JtYWxTeW50YXggPSByZXF1aXJlKCcuL2ltYXAtZm9ybWFsLXN5bnRheCcpO1xuY29uc3QgeyBQYXJzZXJJbnN0YW5jZSB9ID0gcmVxdWlyZSgnLi9wYXJzZXItaW5zdGFuY2UnKTtcblxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyAoY29tbWFuZCwgb3B0aW9ucykgPT4ge1xuICAgIG9wdGlvbnMgPSBvcHRpb25zIHx8IHt9O1xuXG4gICAgbGV0IG51bGxCeXRlc1JlbW92ZWQgPSAwO1xuXG4gICAgLy8gc3BlY2lhbCBjYXNlIHdpdGggYSBidWdneSBJTUFQIHNlcnZlciB3aGVyZSByZXNwb25zZXMgYXJlIHBhZGRlZCB3aXRoIHplcm8gYnl0ZXNcbiAgICBpZiAoY29tbWFuZFswXSA9PT0gMCkge1xuICAgICAgICAvLyBmaW5kIHRoZSBmaXJzdCBub24gbnVsbCBieXRlIGFuZCB0cmltXG4gICAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgY29tbWFuZC5sZW5ndGg7IGkrKykge1xuICAgICAgICAgICAgaWYgKGNvbW1hbmRbaV0gIT09IDApIHtcbiAgICAgICAgICAgICAgICAvLyB0cmltIHRvIGhlcmVcbiAgICAgICAgICAgICAgICBjb21tYW5kID0gY29tbWFuZC5zbGljZShpKTtcbiAgICAgICAgICAgICAgICBudWxsQnl0ZXNSZW1vdmVkID0gaTtcbiAgICAgICAgICAgICAgICBicmVhaztcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgIH1cblxuICAgIGNvbnN0IHBhcnNlciA9IG5ldyBQYXJzZXJJbnN0YW5jZShjb21tYW5kLCBvcHRpb25zKTtcbiAgICBjb25zdCByZXNwb25zZSA9IHt9O1xuXG4gICAgdHJ5IHtcbiAgICAgICAgcmVzcG9uc2UudGFnID0gYXdhaXQgcGFyc2VyLmdldFRhZygpO1xuXG4gICAgICAgIGF3YWl0IHBhcnNlci5nZXRTcGFjZSgpO1xuXG4gICAgICAgIHJlc3BvbnNlLmNvbW1hbmQgPSBhd2FpdCBwYXJzZXIuZ2V0Q29tbWFuZCgpO1xuXG4gICAgICAgIGlmIChudWxsQnl0ZXNSZW1vdmVkKSB7XG4gICAgICAgICAgICByZXNwb25zZS5udWxsQnl0ZXNSZW1vdmVkID0gbnVsbEJ5dGVzUmVtb3ZlZDtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChbJ1VJRCcsICdBVVRIRU5USUNBVEUnXS5pbmRleE9mKChyZXNwb25zZS5jb21tYW5kIHx8ICcnKS50b1VwcGVyQ2FzZSgpKSA+PSAwKSB7XG4gICAgICAgICAgICBhd2FpdCBwYXJzZXIuZ2V0U3BhY2UoKTtcbiAgICAgICAgICAgIHJlc3BvbnNlLmNvbW1hbmQgKz0gJyAnICsgKGF3YWl0IHBhcnNlci5nZXRFbGVtZW50KGltYXBGb3JtYWxTeW50YXguY29tbWFuZCgpKSk7XG4gICAgICAgIH1cblxuICAgICAgICBpZiAocGFyc2VyLnJlbWFpbmRlci50cmltKCkubGVuZ3RoKSB7XG4gICAgICAgICAgICBhd2FpdCBwYXJzZXIuZ2V0U3BhY2UoKTtcbiAgICAgICAgICAgIHJlc3BvbnNlLmF0dHJpYnV0ZXMgPSBhd2FpdCBwYXJzZXIuZ2V0QXR0cmlidXRlcygpO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKHBhcnNlci5odW1hblJlYWRhYmxlKSB7XG4gICAgICAgICAgICByZXNwb25zZS5hdHRyaWJ1dGVzID0gKHJlc3BvbnNlLmF0dHJpYnV0ZXMgfHwgW10pLmNvbmNhdCh7XG4gICAgICAgICAgICAgICAgdHlwZTogJ1RFWFQnLFxuICAgICAgICAgICAgICAgIHZhbHVlOiBwYXJzZXIuaHVtYW5SZWFkYWJsZVxuICAgICAgICAgICAgfSk7XG4gICAgICAgIH1cbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgaWYgKGVyci5jb2RlID09PSAnUGFyc2VyRXJyb3JFeGNoYW5nZScgJiYgZXJyLnBhcnNlckNvbnRleHQgJiYgZXJyLnBhcnNlckNvbnRleHQudmFsdWUpIHtcbiAgICAgICAgICAgIHJldHVybiBlcnIucGFyc2VyQ29udGV4dC52YWx1ZTtcbiAgICAgICAgfVxuICAgICAgICB0aHJvdyBlcnI7XG4gICAgfVxuXG4gICAgcmV0dXJuIHJlc3BvbnNlO1xufTtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/handler/imap-parser.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/handler/imap-stream.js":
|
|
/*!**********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/handler/imap-stream.js ***!
|
|
\**********************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst Transform = (__webpack_require__(/*! stream */ \"stream\").Transform);\nconst logger = __webpack_require__(/*! ../logger */ \"(rsc)/./node_modules/imapflow/lib/logger.js\");\n\nconst LINE = 0x01;\nconst LITERAL = 0x02;\n\nconst LF = 0x0a;\nconst CR = 0x0d;\nconst NUM_0 = 0x30;\nconst NUM_9 = 0x39;\nconst CURLY_OPEN = 0x7b;\nconst CURLY_CLOSE = 0x7d;\n\nclass ImapStream extends Transform {\n constructor(options) {\n super({\n //writableHighWaterMark: 3,\n readableObjectMode: true,\n writableObjectMode: false\n });\n\n this.options = options || {};\n this.cid = this.options.cid;\n\n this.log =\n this.options.logger && typeof this.options.logger === 'object'\n ? this.options.logger\n : logger.child({\n component: 'imap-connection',\n cid: this.cid\n });\n\n this.readBytesCounter = 0;\n\n this.state = LINE;\n this.literalWaiting = 0;\n this.inputBuffer = []; // lines\n this.lineBuffer = []; // current line\n this.literalBuffer = [];\n this.literals = [];\n\n this.compress = false;\n this.secureConnection = this.options.secureConnection;\n\n this.processingInput = false;\n this.inputQueue = []; // unprocessed input chunks\n }\n\n checkLiteralMarker(line) {\n if (!line || !line.length) {\n return false;\n }\n\n let pos = line.length - 1;\n\n if (line[pos] === LF) {\n pos--;\n } else {\n return false;\n }\n if (pos >= 0 && line[pos] === CR) {\n pos--;\n }\n if (pos < 0) {\n return false;\n }\n\n if (!pos || line[pos] !== CURLY_CLOSE) {\n return false;\n }\n pos--;\n\n let numBytes = [];\n for (; pos > 0; pos--) {\n let c = line[pos];\n if (c >= NUM_0 && c <= NUM_9) {\n numBytes.unshift(c);\n continue;\n }\n if (c === CURLY_OPEN && numBytes.length) {\n this.state = LITERAL;\n this.literalWaiting = Number(Buffer.from(numBytes).toString());\n return true;\n }\n return false;\n }\n return false;\n }\n\n async processInputChunk(chunk, startPos) {\n startPos = startPos || 0;\n if (startPos >= chunk.length) {\n return;\n }\n\n switch (this.state) {\n case LINE: {\n let lineStart = startPos;\n for (let i = startPos, len = chunk.length; i < len; i++) {\n if (chunk[i] === LF) {\n // line end found\n this.lineBuffer.push(chunk.slice(lineStart, i + 1));\n lineStart = i + 1;\n\n let line = Buffer.concat(this.lineBuffer);\n\n this.inputBuffer.push(line);\n this.lineBuffer = [];\n\n // try to detect if this is a literal start\n if (this.checkLiteralMarker(line)) {\n // switch into line mode and start over\n return await this.processInputChunk(chunk, lineStart);\n }\n\n // reached end of command input, emit it\n let payload = this.inputBuffer.length === 1 ? this.inputBuffer[0] : Buffer.concat(this.inputBuffer);\n let literals = this.literals;\n this.inputBuffer = [];\n this.literals = [];\n\n if (payload.length) {\n // remove final line terminator\n let skipBytes = 0;\n if (payload.length >= 1 && payload[payload.length - 1] === LF) {\n skipBytes++;\n if (payload.length >= 2 && payload[payload.length - 2] === CR) {\n skipBytes++;\n }\n }\n\n if (skipBytes) {\n payload = payload.slice(0, payload.length - skipBytes);\n }\n\n if (payload.length) {\n await new Promise(resolve => {\n this.push({ payload, literals, next: resolve });\n });\n }\n }\n }\n }\n if (lineStart < chunk.length) {\n this.lineBuffer.push(chunk.slice(lineStart));\n }\n break;\n }\n\n case LITERAL: {\n // exactly until end of chunk\n if (chunk.length === startPos + this.literalWaiting) {\n if (!startPos) {\n this.literalBuffer.push(chunk);\n } else {\n this.literalBuffer.push(chunk.slice(startPos));\n }\n\n this.literalWaiting -= chunk.length;\n this.literals.push(Buffer.concat(this.literalBuffer));\n this.literalBuffer = [];\n this.state = LINE;\n\n return;\n } else if (chunk.length > startPos + this.literalWaiting) {\n let partial = chunk.slice(startPos, startPos + this.literalWaiting);\n this.literalBuffer.push(partial);\n startPos += partial.length;\n this.literalWaiting -= partial.length;\n this.literals.push(Buffer.concat(this.literalBuffer));\n this.literalBuffer = [];\n this.state = LINE;\n\n return await this.processInputChunk(chunk, startPos);\n } else {\n let partial = chunk.slice(startPos);\n this.literalBuffer.push(partial);\n startPos += partial.length;\n this.literalWaiting -= partial.length;\n return;\n }\n }\n }\n }\n\n async processInput() {\n let data;\n while ((data = this.inputQueue.shift())) {\n await this.processInputChunk(data.chunk);\n // mark chunk as processed\n data.next();\n }\n }\n\n _transform(chunk, encoding, next) {\n if (typeof chunk === 'string') {\n chunk = Buffer.from(chunk, encoding);\n }\n\n if (!chunk || !chunk.length) {\n return next();\n }\n\n this.readBytesCounter += chunk.length;\n\n if (this.options.logRaw) {\n this.log.trace({\n src: 's',\n msg: 'read from socket',\n data: chunk.toString('base64'),\n compress: !!this.compress,\n secure: !!this.secureConnection,\n cid: this.cid\n });\n }\n\n if (chunk && chunk.length) {\n this.inputQueue.push({ chunk, next });\n }\n\n if (!this.processingInput) {\n this.processingInput = true;\n this.processInput()\n .catch(err => this.emit('error', err))\n .finally(() => (this.processingInput = false));\n }\n }\n\n _flush(next) {\n next();\n }\n}\n\nmodule.exports.ImapStream = ImapStream;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/imapflow/lib/handler/imap-stream.js","mappings":"AAAa;;AAEb,kBAAkB,uDAA2B;AAC7C,eAAe,mBAAO,CAAC,8DAAW;;AAElC;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB;;AAEnB;;AAEA;AACA;AACA,+BAA+B;AAC/B,8BAA8B;AAC9B;AACA;;AAEA;AACA;;AAEA;AACA,8BAA8B;AAC9B;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,eAAe,SAAS;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,2DAA2D,SAAS;AACpE;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,gDAAgD,kCAAkC;AAClF,iCAAiC;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;;AAEA;AACA,mCAAmC,aAAa;AAChD;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,yBAAyB","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/handler/imap-stream.js"],"sourcesContent":["'use strict';\n\nconst Transform = require('stream').Transform;\nconst logger = require('../logger');\n\nconst LINE = 0x01;\nconst LITERAL = 0x02;\n\nconst LF = 0x0a;\nconst CR = 0x0d;\nconst NUM_0 = 0x30;\nconst NUM_9 = 0x39;\nconst CURLY_OPEN = 0x7b;\nconst CURLY_CLOSE = 0x7d;\n\nclass ImapStream extends Transform {\n    constructor(options) {\n        super({\n            //writableHighWaterMark: 3,\n            readableObjectMode: true,\n            writableObjectMode: false\n        });\n\n        this.options = options || {};\n        this.cid = this.options.cid;\n\n        this.log =\n            this.options.logger && typeof this.options.logger === 'object'\n                ? this.options.logger\n                : logger.child({\n                      component: 'imap-connection',\n                      cid: this.cid\n                  });\n\n        this.readBytesCounter = 0;\n\n        this.state = LINE;\n        this.literalWaiting = 0;\n        this.inputBuffer = []; // lines\n        this.lineBuffer = []; // current line\n        this.literalBuffer = [];\n        this.literals = [];\n\n        this.compress = false;\n        this.secureConnection = this.options.secureConnection;\n\n        this.processingInput = false;\n        this.inputQueue = []; // unprocessed input chunks\n    }\n\n    checkLiteralMarker(line) {\n        if (!line || !line.length) {\n            return false;\n        }\n\n        let pos = line.length - 1;\n\n        if (line[pos] === LF) {\n            pos--;\n        } else {\n            return false;\n        }\n        if (pos >= 0 && line[pos] === CR) {\n            pos--;\n        }\n        if (pos < 0) {\n            return false;\n        }\n\n        if (!pos || line[pos] !== CURLY_CLOSE) {\n            return false;\n        }\n        pos--;\n\n        let numBytes = [];\n        for (; pos > 0; pos--) {\n            let c = line[pos];\n            if (c >= NUM_0 && c <= NUM_9) {\n                numBytes.unshift(c);\n                continue;\n            }\n            if (c === CURLY_OPEN && numBytes.length) {\n                this.state = LITERAL;\n                this.literalWaiting = Number(Buffer.from(numBytes).toString());\n                return true;\n            }\n            return false;\n        }\n        return false;\n    }\n\n    async processInputChunk(chunk, startPos) {\n        startPos = startPos || 0;\n        if (startPos >= chunk.length) {\n            return;\n        }\n\n        switch (this.state) {\n            case LINE: {\n                let lineStart = startPos;\n                for (let i = startPos, len = chunk.length; i < len; i++) {\n                    if (chunk[i] === LF) {\n                        // line end found\n                        this.lineBuffer.push(chunk.slice(lineStart, i + 1));\n                        lineStart = i + 1;\n\n                        let line = Buffer.concat(this.lineBuffer);\n\n                        this.inputBuffer.push(line);\n                        this.lineBuffer = [];\n\n                        // try to detect if this is a literal start\n                        if (this.checkLiteralMarker(line)) {\n                            // switch into line mode and start over\n                            return await this.processInputChunk(chunk, lineStart);\n                        }\n\n                        // reached end of command input, emit it\n                        let payload = this.inputBuffer.length === 1 ? this.inputBuffer[0] : Buffer.concat(this.inputBuffer);\n                        let literals = this.literals;\n                        this.inputBuffer = [];\n                        this.literals = [];\n\n                        if (payload.length) {\n                            // remove final line terminator\n                            let skipBytes = 0;\n                            if (payload.length >= 1 && payload[payload.length - 1] === LF) {\n                                skipBytes++;\n                                if (payload.length >= 2 && payload[payload.length - 2] === CR) {\n                                    skipBytes++;\n                                }\n                            }\n\n                            if (skipBytes) {\n                                payload = payload.slice(0, payload.length - skipBytes);\n                            }\n\n                            if (payload.length) {\n                                await new Promise(resolve => {\n                                    this.push({ payload, literals, next: resolve });\n                                });\n                            }\n                        }\n                    }\n                }\n                if (lineStart < chunk.length) {\n                    this.lineBuffer.push(chunk.slice(lineStart));\n                }\n                break;\n            }\n\n            case LITERAL: {\n                // exactly until end of chunk\n                if (chunk.length === startPos + this.literalWaiting) {\n                    if (!startPos) {\n                        this.literalBuffer.push(chunk);\n                    } else {\n                        this.literalBuffer.push(chunk.slice(startPos));\n                    }\n\n                    this.literalWaiting -= chunk.length;\n                    this.literals.push(Buffer.concat(this.literalBuffer));\n                    this.literalBuffer = [];\n                    this.state = LINE;\n\n                    return;\n                } else if (chunk.length > startPos + this.literalWaiting) {\n                    let partial = chunk.slice(startPos, startPos + this.literalWaiting);\n                    this.literalBuffer.push(partial);\n                    startPos += partial.length;\n                    this.literalWaiting -= partial.length;\n                    this.literals.push(Buffer.concat(this.literalBuffer));\n                    this.literalBuffer = [];\n                    this.state = LINE;\n\n                    return await this.processInputChunk(chunk, startPos);\n                } else {\n                    let partial = chunk.slice(startPos);\n                    this.literalBuffer.push(partial);\n                    startPos += partial.length;\n                    this.literalWaiting -= partial.length;\n                    return;\n                }\n            }\n        }\n    }\n\n    async processInput() {\n        let data;\n        while ((data = this.inputQueue.shift())) {\n            await this.processInputChunk(data.chunk);\n            // mark chunk as processed\n            data.next();\n        }\n    }\n\n    _transform(chunk, encoding, next) {\n        if (typeof chunk === 'string') {\n            chunk = Buffer.from(chunk, encoding);\n        }\n\n        if (!chunk || !chunk.length) {\n            return next();\n        }\n\n        this.readBytesCounter += chunk.length;\n\n        if (this.options.logRaw) {\n            this.log.trace({\n                src: 's',\n                msg: 'read from socket',\n                data: chunk.toString('base64'),\n                compress: !!this.compress,\n                secure: !!this.secureConnection,\n                cid: this.cid\n            });\n        }\n\n        if (chunk && chunk.length) {\n            this.inputQueue.push({ chunk, next });\n        }\n\n        if (!this.processingInput) {\n            this.processingInput = true;\n            this.processInput()\n                .catch(err => this.emit('error', err))\n                .finally(() => (this.processingInput = false));\n        }\n    }\n\n    _flush(next) {\n        next();\n    }\n}\n\nmodule.exports.ImapStream = ImapStream;\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/handler/imap-stream.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/handler/parser-instance.js":
|
|
/*!**************************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/handler/parser-instance.js ***!
|
|
\**************************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("/* eslint new-cap: 0 */\n\n\n\nconst imapFormalSyntax = __webpack_require__(/*! ./imap-formal-syntax */ \"(rsc)/./node_modules/imapflow/lib/handler/imap-formal-syntax.js\");\n\nconst { TokenParser } = __webpack_require__(/*! ./token-parser */ \"(rsc)/./node_modules/imapflow/lib/handler/token-parser.js\");\n\nclass ParserInstance {\n constructor(input, options) {\n this.input = (input || '').toString();\n this.options = options || {};\n this.remainder = this.input;\n this.pos = 0;\n }\n\n async getTag() {\n if (!this.tag) {\n this.tag = await this.getElement(imapFormalSyntax.tag() + '*+', true);\n }\n return this.tag;\n }\n\n async getCommand() {\n if (this.tag === '+') {\n // special case\n this.humanReadable = this.remainder.trim();\n this.remainder = '';\n\n return '';\n }\n\n if (!this.command) {\n this.command = await this.getElement(imapFormalSyntax.command());\n }\n\n switch ((this.command || '').toString().toUpperCase()) {\n case 'OK':\n case 'NO':\n case 'BAD':\n case 'PREAUTH':\n case 'BYE':\n {\n let match = this.remainder.match(/^\\s+\\[/);\n if (match) {\n let nesting = 1;\n for (let i = match[0].length; i <= this.remainder.length; i++) {\n let c = this.remainder[i];\n\n if (c === '[') {\n nesting++;\n } else if (c === ']') {\n nesting--;\n }\n if (!nesting) {\n this.humanReadable = this.remainder.substring(i + 1).trim();\n this.remainder = this.remainder.substring(0, i + 1);\n break;\n }\n }\n } else {\n this.humanReadable = this.remainder.trim();\n this.remainder = '';\n }\n }\n break;\n }\n\n return this.command;\n }\n\n async getElement(syntax) {\n let match, element, errPos;\n\n if (this.remainder.match(/^\\s/)) {\n let error = new Error(`Unexpected whitespace at position ${this.pos} [E1]`);\n error.code = 'ParserError1';\n error.parserContext = { input: this.input, pos: this.pos };\n throw error;\n }\n\n if ((match = this.remainder.match(/^\\s*[^\\s]+(?=\\s|$)/))) {\n element = match[0];\n if ((errPos = imapFormalSyntax.verify(element, syntax)) >= 0) {\n if (this.tag === 'Server' && element === 'Unavailable.') {\n // Exchange error\n let error = new Error(`Server returned an error: ${this.input}`);\n error.code = 'ParserErrorExchange';\n error.parserContext = {\n input: this.input,\n element,\n pos: this.pos,\n value: {\n tag: '*',\n command: 'BAD',\n attributes: [{ type: 'TEXT', value: this.input }]\n }\n };\n throw error;\n }\n\n let error = new Error(`Unexpected char at position ${this.pos + errPos} [E2: ${JSON.stringify(element.charAt(errPos))}]`);\n error.code = 'ParserError2';\n error.parserContext = { input: this.input, element, pos: this.pos };\n throw error;\n }\n } else {\n let error = new Error(`Unexpected end of input at position ${this.pos} [E3]`);\n error.code = 'ParserError3';\n error.parserContext = { input: this.input, pos: this.pos };\n throw error;\n }\n\n this.pos += match[0].length;\n this.remainder = this.remainder.substr(match[0].length);\n\n return element;\n }\n\n async getSpace() {\n if (!this.remainder.length) {\n if (this.tag === '+' && this.pos === 1) {\n // special case, empty + response\n return;\n }\n\n let error = new Error(`Unexpected end of input at position ${this.pos} [E4]`);\n error.code = 'ParserError4';\n error.parserContext = { input: this.input, pos: this.pos };\n throw error;\n }\n\n if (imapFormalSyntax.verify(this.remainder.charAt(0), imapFormalSyntax.SP()) >= 0) {\n let error = new Error(`Unexpected char at position ${this.pos} [E5: ${JSON.stringify(this.remainder.charAt(0))}]`);\n error.code = 'ParserError5';\n error.parserContext = { input: this.input, element: this.remainder, pos: this.pos };\n throw error;\n }\n\n this.pos++;\n this.remainder = this.remainder.substr(1);\n }\n\n async getAttributes() {\n if (!this.remainder.length) {\n let error = new Error(`Unexpected end of input at position ${this.pos} [E6]`);\n error.code = 'ParserError6';\n error.parserContext = { input: this.input, pos: this.pos };\n throw error;\n }\n\n if (this.remainder.match(/^\\s/)) {\n let error = new Error(`Unexpected whitespace at position ${this.pos} [E7]`);\n error.code = 'ParserError7';\n error.parserContext = { input: this.input, element: this.remainder, pos: this.pos };\n throw error;\n }\n\n const tokenParser = new TokenParser(this, this.pos, this.remainder, this.options);\n\n return await tokenParser.getAttributes();\n }\n}\n\nmodule.exports.ParserInstance = ParserInstance;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/imapflow/lib/handler/parser-instance.js","mappings":"AAAA;;AAEa;;AAEb,yBAAyB,mBAAO,CAAC,6FAAsB;;AAEvD,QAAQ,cAAc,EAAE,mBAAO,CAAC,iFAAgB;;AAEhD;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sDAAsD,4BAA4B;AAClF;;AAEA;AACA;AACA,8BAA8B;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA,uEAAuE,UAAU;AACjF;AACA,oCAAoC;AACpC;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,uEAAuE,WAAW;AAClF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C,iCAAiC;AAC5E;AACA;AACA;AACA;;AAEA,qEAAqE,mBAAmB,OAAO,uCAAuC;AACtI;AACA,wCAAwC;AACxC;AACA;AACA,UAAU;AACV,yEAAyE,UAAU;AACnF;AACA,oCAAoC;AACpC;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA,yEAAyE,UAAU;AACnF;AACA,oCAAoC;AACpC;AACA;;AAEA;AACA,iEAAiE,UAAU,OAAO,yCAAyC;AAC3H;AACA,oCAAoC;AACpC;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,yEAAyE,UAAU;AACnF;AACA,oCAAoC;AACpC;AACA;;AAEA;AACA,uEAAuE,UAAU;AACjF;AACA,oCAAoC;AACpC;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA,6BAA6B","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/handler/parser-instance.js"],"sourcesContent":["/* eslint new-cap: 0 */\n\n'use strict';\n\nconst imapFormalSyntax = require('./imap-formal-syntax');\n\nconst { TokenParser } = require('./token-parser');\n\nclass ParserInstance {\n    constructor(input, options) {\n        this.input = (input || '').toString();\n        this.options = options || {};\n        this.remainder = this.input;\n        this.pos = 0;\n    }\n\n    async getTag() {\n        if (!this.tag) {\n            this.tag = await this.getElement(imapFormalSyntax.tag() + '*+', true);\n        }\n        return this.tag;\n    }\n\n    async getCommand() {\n        if (this.tag === '+') {\n            // special case\n            this.humanReadable = this.remainder.trim();\n            this.remainder = '';\n\n            return '';\n        }\n\n        if (!this.command) {\n            this.command = await this.getElement(imapFormalSyntax.command());\n        }\n\n        switch ((this.command || '').toString().toUpperCase()) {\n            case 'OK':\n            case 'NO':\n            case 'BAD':\n            case 'PREAUTH':\n            case 'BYE':\n                {\n                    let match = this.remainder.match(/^\\s+\\[/);\n                    if (match) {\n                        let nesting = 1;\n                        for (let i = match[0].length; i <= this.remainder.length; i++) {\n                            let c = this.remainder[i];\n\n                            if (c === '[') {\n                                nesting++;\n                            } else if (c === ']') {\n                                nesting--;\n                            }\n                            if (!nesting) {\n                                this.humanReadable = this.remainder.substring(i + 1).trim();\n                                this.remainder = this.remainder.substring(0, i + 1);\n                                break;\n                            }\n                        }\n                    } else {\n                        this.humanReadable = this.remainder.trim();\n                        this.remainder = '';\n                    }\n                }\n                break;\n        }\n\n        return this.command;\n    }\n\n    async getElement(syntax) {\n        let match, element, errPos;\n\n        if (this.remainder.match(/^\\s/)) {\n            let error = new Error(`Unexpected whitespace at position ${this.pos} [E1]`);\n            error.code = 'ParserError1';\n            error.parserContext = { input: this.input, pos: this.pos };\n            throw error;\n        }\n\n        if ((match = this.remainder.match(/^\\s*[^\\s]+(?=\\s|$)/))) {\n            element = match[0];\n            if ((errPos = imapFormalSyntax.verify(element, syntax)) >= 0) {\n                if (this.tag === 'Server' && element === 'Unavailable.') {\n                    // Exchange error\n                    let error = new Error(`Server returned an error: ${this.input}`);\n                    error.code = 'ParserErrorExchange';\n                    error.parserContext = {\n                        input: this.input,\n                        element,\n                        pos: this.pos,\n                        value: {\n                            tag: '*',\n                            command: 'BAD',\n                            attributes: [{ type: 'TEXT', value: this.input }]\n                        }\n                    };\n                    throw error;\n                }\n\n                let error = new Error(`Unexpected char at position ${this.pos + errPos} [E2: ${JSON.stringify(element.charAt(errPos))}]`);\n                error.code = 'ParserError2';\n                error.parserContext = { input: this.input, element, pos: this.pos };\n                throw error;\n            }\n        } else {\n            let error = new Error(`Unexpected end of input at position ${this.pos} [E3]`);\n            error.code = 'ParserError3';\n            error.parserContext = { input: this.input, pos: this.pos };\n            throw error;\n        }\n\n        this.pos += match[0].length;\n        this.remainder = this.remainder.substr(match[0].length);\n\n        return element;\n    }\n\n    async getSpace() {\n        if (!this.remainder.length) {\n            if (this.tag === '+' && this.pos === 1) {\n                // special case, empty + response\n                return;\n            }\n\n            let error = new Error(`Unexpected end of input at position ${this.pos} [E4]`);\n            error.code = 'ParserError4';\n            error.parserContext = { input: this.input, pos: this.pos };\n            throw error;\n        }\n\n        if (imapFormalSyntax.verify(this.remainder.charAt(0), imapFormalSyntax.SP()) >= 0) {\n            let error = new Error(`Unexpected char at position ${this.pos} [E5: ${JSON.stringify(this.remainder.charAt(0))}]`);\n            error.code = 'ParserError5';\n            error.parserContext = { input: this.input, element: this.remainder, pos: this.pos };\n            throw error;\n        }\n\n        this.pos++;\n        this.remainder = this.remainder.substr(1);\n    }\n\n    async getAttributes() {\n        if (!this.remainder.length) {\n            let error = new Error(`Unexpected end of input at position ${this.pos} [E6]`);\n            error.code = 'ParserError6';\n            error.parserContext = { input: this.input, pos: this.pos };\n            throw error;\n        }\n\n        if (this.remainder.match(/^\\s/)) {\n            let error = new Error(`Unexpected whitespace at position ${this.pos} [E7]`);\n            error.code = 'ParserError7';\n            error.parserContext = { input: this.input, element: this.remainder, pos: this.pos };\n            throw error;\n        }\n\n        const tokenParser = new TokenParser(this, this.pos, this.remainder, this.options);\n\n        return await tokenParser.getAttributes();\n    }\n}\n\nmodule.exports.ParserInstance = ParserInstance;\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/handler/parser-instance.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/handler/token-parser.js":
|
|
/*!***********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/handler/token-parser.js ***!
|
|
\***********************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("/* eslint new-cap: 0 */\n\n\n\nconst imapFormalSyntax = __webpack_require__(/*! ./imap-formal-syntax */ \"(rsc)/./node_modules/imapflow/lib/handler/imap-formal-syntax.js\");\n\nconst STATE_ATOM = 0x001;\nconst STATE_LITERAL = 0x002;\nconst STATE_NORMAL = 0x003;\nconst STATE_PARTIAL = 0x004;\nconst STATE_SEQUENCE = 0x005;\nconst STATE_STRING = 0x006;\nconst STATE_TEXT = 0x007;\n\nconst RE_DIGITS = /^\\d+$/;\nconst RE_SINGLE_DIGIT = /^\\d$/;\n\nclass TokenParser {\n constructor(parent, startPos, str, options) {\n this.str = (str || '').toString();\n this.options = options || {};\n this.parent = parent;\n\n this.tree = this.currentNode = this.createNode();\n this.pos = startPos || 0;\n\n this.currentNode.type = 'TREE';\n\n this.state = STATE_NORMAL;\n }\n\n async getAttributes() {\n await this.processString();\n\n const attributes = [];\n let branch = attributes;\n\n let walk = async node => {\n let curBranch = branch;\n let elm;\n let partial;\n\n if (!node.isClosed && node.type === 'SEQUENCE' && node.value === '*') {\n node.isClosed = true;\n node.type = 'ATOM';\n }\n\n // If the node was never closed, throw it\n if (!node.isClosed) {\n let error = new Error(`Unexpected end of input at position ${this.pos + this.str.length - 1} [E9]`);\n error.code = 'ParserError9';\n error.parserContext = { input: this.str, pos: this.pos + this.str.length - 1 };\n throw error;\n }\n\n let type = (node.type || '').toString().toUpperCase();\n\n switch (type) {\n case 'LITERAL':\n case 'STRING':\n case 'SEQUENCE':\n elm = {\n type: node.type.toUpperCase(),\n value: node.value\n };\n branch.push(elm);\n break;\n\n case 'ATOM':\n if (node.value.toUpperCase() === 'NIL') {\n branch.push(null);\n break;\n }\n elm = {\n type: node.type.toUpperCase(),\n value: node.value\n };\n branch.push(elm);\n break;\n\n case 'SECTION':\n branch = branch[branch.length - 1].section = [];\n break;\n\n case 'LIST':\n elm = [];\n branch.push(elm);\n branch = elm;\n break;\n\n case 'PARTIAL':\n partial = node.value.split('.').map(Number);\n branch[branch.length - 1].partial = partial;\n break;\n }\n\n for (let childNode of node.childNodes) {\n await walk(childNode);\n }\n\n branch = curBranch;\n };\n\n await walk(this.tree);\n\n return attributes;\n }\n\n createNode(parentNode, startPos) {\n let node = {\n childNodes: [],\n type: false,\n value: '',\n isClosed: true\n };\n\n if (parentNode) {\n node.parentNode = parentNode;\n }\n\n if (typeof startPos === 'number') {\n node.startPos = startPos;\n }\n\n if (parentNode) {\n parentNode.childNodes.push(node);\n }\n\n return node;\n }\n\n async processString() {\n let chr, i, len;\n\n const checkSP = () => {\n // jump to the next non whitespace pos\n while (this.str.charAt(i + 1) === ' ') {\n i++;\n }\n };\n\n for (i = 0, len = this.str.length; i < len; i++) {\n chr = this.str.charAt(i);\n\n switch (this.state) {\n case STATE_NORMAL:\n switch (chr) {\n // DQUOTE starts a new string\n case '\"':\n this.currentNode = this.createNode(this.currentNode, this.pos + i);\n this.currentNode.type = 'string';\n this.state = STATE_STRING;\n this.currentNode.isClosed = false;\n break;\n\n // ( starts a new list\n case '(':\n this.currentNode = this.createNode(this.currentNode, this.pos + i);\n this.currentNode.type = 'LIST';\n this.currentNode.isClosed = false;\n break;\n\n // ) closes a list\n case ')':\n if (this.currentNode.type !== 'LIST') {\n let error = new Error(`Unexpected list terminator ) at position ${this.pos + i} [E10]`);\n error.code = 'ParserError10';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n this.currentNode.isClosed = true;\n this.currentNode.endPos = this.pos + i;\n this.currentNode = this.currentNode.parentNode;\n\n checkSP();\n break;\n\n // ] closes section group\n case ']':\n if (this.currentNode.type !== 'SECTION') {\n let error = new Error(`Unexpected section terminator ] at position ${this.pos + i} [E11]`);\n error.code = 'ParserError11';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n this.currentNode.isClosed = true;\n this.currentNode.endPos = this.pos + i;\n this.currentNode = this.currentNode.parentNode;\n\n checkSP();\n break;\n\n // < starts a new partial\n case '<':\n if (this.str.charAt(i - 1) !== ']') {\n this.currentNode = this.createNode(this.currentNode, this.pos + i);\n this.currentNode.type = 'ATOM';\n this.currentNode.value = chr;\n this.state = STATE_ATOM;\n } else {\n this.currentNode = this.createNode(this.currentNode, this.pos + i);\n this.currentNode.type = 'PARTIAL';\n this.state = STATE_PARTIAL;\n this.currentNode.isClosed = false;\n }\n break;\n\n // binary literal8\n case '~': {\n let nextChr = this.str.charAt(i + 1);\n if (nextChr !== '{') {\n if (imapFormalSyntax['ATOM-CHAR']().indexOf(nextChr) >= 0) {\n // treat as ATOM\n this.currentNode = this.createNode(this.currentNode, this.pos + i);\n this.currentNode.type = 'ATOM';\n this.currentNode.value = chr;\n this.state = STATE_ATOM;\n break;\n }\n\n let error = new Error(`Unexpected literal8 marker at position ${this.pos + i} [E12]`);\n error.code = 'ParserError12';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n this.expectedLiteralType = 'literal8';\n break;\n }\n\n // { starts a new literal\n case '{':\n this.currentNode = this.createNode(this.currentNode, this.pos + i);\n this.currentNode.type = 'LITERAL';\n this.currentNode.literalType = this.expectedLiteralType || 'literal';\n this.expectedLiteralType = false;\n this.state = STATE_LITERAL;\n this.currentNode.isClosed = false;\n break;\n\n // * starts a new sequence\n case '*':\n this.currentNode = this.createNode(this.currentNode, this.pos + i);\n this.currentNode.type = 'SEQUENCE';\n this.currentNode.value = chr;\n this.currentNode.isClosed = false;\n this.state = STATE_SEQUENCE;\n break;\n\n // normally a space should never occur\n case ' ':\n // just ignore\n break;\n\n // [ starts section\n case '[':\n // If it is the *first* element after response command, then process as a response argument list\n if (['OK', 'NO', 'BAD', 'BYE', 'PREAUTH'].includes(this.parent.command.toUpperCase()) && this.currentNode === this.tree) {\n this.currentNode.endPos = this.pos + i;\n\n this.currentNode = this.createNode(this.currentNode, this.pos + i);\n this.currentNode.type = 'ATOM';\n\n this.currentNode = this.createNode(this.currentNode, this.pos + i);\n this.currentNode.type = 'SECTION';\n this.currentNode.isClosed = false;\n this.state = STATE_NORMAL;\n\n // RFC2221 defines a response code REFERRAL whose payload is an\n // RFC2192/RFC5092 imapurl that we will try to parse as an ATOM but\n // fail quite badly at parsing. Since the imapurl is such a unique\n // (and crazy) term, we just specialize that case here.\n if (this.str.substr(i + 1, 9).toUpperCase() === 'REFERRAL ') {\n // create the REFERRAL atom\n this.currentNode = this.createNode(this.currentNode, this.pos + i + 1);\n this.currentNode.type = 'ATOM';\n this.currentNode.endPos = this.pos + i + 8;\n this.currentNode.value = 'REFERRAL';\n this.currentNode = this.currentNode.parentNode;\n\n // eat all the way through the ] to be the IMAPURL token.\n this.currentNode = this.createNode(this.currentNode, this.pos + i + 10);\n // just call this an ATOM, even though IMAPURL might be more correct\n this.currentNode.type = 'ATOM';\n // jump i to the ']'\n i = this.str.indexOf(']', i + 10);\n this.currentNode.endPos = this.pos + i - 1;\n this.currentNode.value = this.str.substring(this.currentNode.startPos - this.pos, this.currentNode.endPos - this.pos + 1);\n this.currentNode = this.currentNode.parentNode;\n\n // close out the SECTION\n this.currentNode.isClosed = true;\n this.currentNode = this.currentNode.parentNode;\n\n checkSP();\n }\n\n break;\n }\n\n /* falls through */\n default:\n // Any ATOM supported char starts a new Atom sequence, otherwise throw an error\n // Allow \\ as the first char for atom to support system flags\n // Allow % to support LIST '' %\n // Allow 8bit characters (presumably unicode)\n if (imapFormalSyntax['ATOM-CHAR']().indexOf(chr) < 0 && chr !== '\\\\' && chr !== '%' && chr.charCodeAt(0) < 0x80) {\n let error = new Error(`Unexpected char at position ${this.pos + i} [E13: ${JSON.stringify(chr)}]`);\n error.code = 'ParserError13';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n this.currentNode = this.createNode(this.currentNode, this.pos + i);\n this.currentNode.type = 'ATOM';\n this.currentNode.value = chr;\n this.state = STATE_ATOM;\n break;\n }\n break;\n\n case STATE_ATOM:\n // space finishes an atom\n if (chr === ' ') {\n this.currentNode.endPos = this.pos + i - 1;\n this.currentNode = this.currentNode.parentNode;\n this.state = STATE_NORMAL;\n break;\n }\n\n //\n if (\n this.currentNode.parentNode &&\n ((chr === ')' && this.currentNode.parentNode.type === 'LIST') || (chr === ']' && this.currentNode.parentNode.type === 'SECTION'))\n ) {\n this.currentNode.endPos = this.pos + i - 1;\n this.currentNode = this.currentNode.parentNode;\n\n this.currentNode.isClosed = true;\n this.currentNode.endPos = this.pos + i;\n this.currentNode = this.currentNode.parentNode;\n this.state = STATE_NORMAL;\n checkSP();\n\n break;\n }\n\n if ((chr === ',' || chr === ':') && RE_DIGITS.test(this.currentNode.value)) {\n this.currentNode.type = 'SEQUENCE';\n this.currentNode.isClosed = true;\n this.state = STATE_SEQUENCE;\n }\n\n // [ starts a section group for this element\n if (chr === '[') {\n // allowed only for selected elements\n if (['BODY', 'BODY.PEEK', 'BINARY', 'BINARY.PEEK'].indexOf(this.currentNode.value.toUpperCase()) < 0) {\n if (/[./]/.test(this.currentNode.value)) {\n // could be a path\n this.currentNode.value += chr;\n break;\n } else {\n let error = new Error(`Unexpected section start char [ at position ${this.pos + i} [E14]`);\n error.code = 'ParserError14';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n }\n this.currentNode.endPos = this.pos + i;\n this.currentNode = this.createNode(this.currentNode.parentNode, this.pos + i);\n this.currentNode.type = 'SECTION';\n this.currentNode.isClosed = false;\n this.state = STATE_NORMAL;\n break;\n }\n\n if (chr === '<') {\n let error = new Error(`Unexpected start of partial at position ${this.pos + i} [E15]`);\n error.code = 'ParserError15';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n // if the char is not ATOM compatible, throw. Allow \\* as an exception\n if (\n imapFormalSyntax['ATOM-CHAR']().indexOf(chr) < 0 &&\n chr.charCodeAt(0) < 0x80 && // allow 8bit (presumably unicode) bytes\n chr !== ']' &&\n !(chr === '*' && this.currentNode.value === '\\\\') &&\n (!this.parent || !this.parent.command || !['NO', 'BAD', 'OK'].includes(this.parent.command))\n ) {\n let error = new Error(`Unexpected char at position ${this.pos + i} [E16: ${JSON.stringify(chr)}]`);\n error.code = 'ParserError16';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n } else if (this.currentNode.value === '\\\\*') {\n let error = new Error(`Unexpected char at position ${this.pos + i} [E17: ${JSON.stringify(chr)}]`);\n error.code = 'ParserError17';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n this.currentNode.value += chr;\n break;\n\n case STATE_STRING:\n // DQUOTE ends the string sequence\n if (chr === '\"') {\n this.currentNode.endPos = this.pos + i;\n this.currentNode.isClosed = true;\n this.currentNode = this.currentNode.parentNode;\n this.state = STATE_NORMAL;\n\n checkSP();\n break;\n }\n\n // \\ Escapes the following char\n if (chr === '\\\\') {\n i++;\n if (i >= len) {\n let error = new Error(`Unexpected end of input at position ${this.pos + i} [E18]`);\n error.code = 'ParserError18';\n error.parserContext = { input: this.str, pos: this.pos + i };\n throw error;\n }\n chr = this.str.charAt(i);\n }\n\n this.currentNode.value += chr;\n break;\n\n case STATE_PARTIAL:\n if (chr === '>') {\n if (this.currentNode.value.at(-1) === '.') {\n let error = new Error(`Unexpected end of partial at position ${this.pos + i} [E19]`);\n error.code = 'ParserError19';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n this.currentNode.endPos = this.pos + i;\n this.currentNode.isClosed = true;\n this.currentNode = this.currentNode.parentNode;\n this.state = STATE_NORMAL;\n checkSP();\n break;\n }\n\n if (chr === '.' && (!this.currentNode.value.length || this.currentNode.value.match(/\\./))) {\n let error = new Error(`Unexpected partial separator . at position ${this.pos + i} [E20]`);\n error.code = 'ParserError20';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n if (imapFormalSyntax.DIGIT().indexOf(chr) < 0 && chr !== '.') {\n let error = new Error(`Unexpected char at position ${this.pos + i} [E21: ${JSON.stringify(chr)}]`);\n error.code = 'ParserError21';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n if (this.currentNode.value.match(/^0$|\\.0$/) && chr !== '.') {\n let error = new Error(`Invalid partial at position ${this.pos + i} [E22: ${JSON.stringify(chr)}]`);\n error.code = 'ParserError22';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n this.currentNode.value += chr;\n break;\n\n case STATE_LITERAL:\n if (this.currentNode.started) {\n // only relevant if literals are not already parsed out from input\n\n // Disabled NULL byte check\n // See https://github.com/emailjs/emailjs-imap-handler/commit/f11b2822bedabe492236e8263afc630134a3c41c\n /*\n if (chr === '\\u0000') {\n throw new Error('Unexpected \\\\x00 at position ' + (this.pos + i));\n }\n */\n\n this.currentNode.chBuffer[this.currentNode.chPos++] = chr.charCodeAt(0);\n\n if (this.currentNode.chPos >= this.currentNode.literalLength) {\n this.currentNode.endPos = this.pos + i;\n this.currentNode.isClosed = true;\n this.currentNode.value = this.currentNode.chBuffer.toString('binary');\n this.currentNode.chBuffer = Buffer.alloc(0);\n this.currentNode = this.currentNode.parentNode;\n this.state = STATE_NORMAL;\n checkSP();\n }\n break;\n }\n\n if (chr === '+' && this.options.literalPlus) {\n this.currentNode.literalPlus = true;\n break;\n }\n\n if (chr === '}') {\n if (!('literalLength' in this.currentNode)) {\n let error = new Error(`Unexpected literal prefix end char } at position ${this.pos + i} [E23]`);\n error.code = 'ParserError23';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n if (this.str.charAt(i + 1) === '\\n') {\n i++;\n } else if (this.str.charAt(i + 1) === '\\r' && this.str.charAt(i + 2) === '\\n') {\n i += 2;\n } else {\n let error = new Error(`Unexpected char at position ${this.pos + i} [E24: ${JSON.stringify(chr)}]`);\n error.code = 'ParserError24';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n this.currentNode.literalLength = Number(this.currentNode.literalLength);\n\n if (!this.currentNode.literalLength) {\n // special case where literal content length is 0\n // close the node right away, do not wait for additional input\n this.currentNode.endPos = this.pos + i;\n this.currentNode.isClosed = true;\n this.currentNode = this.currentNode.parentNode;\n this.state = STATE_NORMAL;\n checkSP();\n } else if (this.options.literals) {\n // use the next precached literal values\n this.currentNode.value = this.options.literals.shift();\n\n // only APPEND arguments are kept as Buffers\n /*\n if ((this.parent.command || '').toString().toUpperCase() !== 'APPEND') {\n this.currentNode.value = this.currentNode.value.toString('binary');\n }\n */\n\n this.currentNode.endPos = this.pos + i + this.currentNode.value.length;\n\n this.currentNode.started = false;\n this.currentNode.isClosed = true;\n this.currentNode = this.currentNode.parentNode;\n this.state = STATE_NORMAL;\n checkSP();\n } else {\n this.currentNode.started = true;\n // Allocate expected size buffer. Max size check is already performed\n // Maybe should use allocUnsafe instead?\n this.currentNode.chBuffer = Buffer.alloc(this.currentNode.literalLength);\n this.currentNode.chPos = 0;\n }\n break;\n }\n if (imapFormalSyntax.DIGIT().indexOf(chr) < 0) {\n let error = new Error(`Unexpected char at position ${this.pos + i} [E25: ${JSON.stringify(chr)}]`);\n error.code = 'ParserError25';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n if (this.currentNode.literalLength === '0') {\n let error = new Error(`Invalid literal at position ${this.pos + i} [E26]`);\n error.code = 'ParserError26';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n this.currentNode.literalLength = (this.currentNode.literalLength || '') + chr;\n break;\n\n case STATE_SEQUENCE:\n // space finishes the sequence set\n if (chr === ' ') {\n if (!RE_SINGLE_DIGIT.test(this.currentNode.value.at(-1)) && this.currentNode.value.at(-1) !== '*') {\n let error = new Error(`Unexpected whitespace at position ${this.pos + i} [E27]`);\n error.code = 'ParserError27';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n if (this.currentNode.value !== '*' && this.currentNode.value.at(-1) === '*' && this.currentNode.value.at(-2) !== ':') {\n let error = new Error(`Unexpected whitespace at position ${this.pos + i} [E28]`);\n error.code = 'ParserError28';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n this.currentNode.isClosed = true;\n this.currentNode.endPos = this.pos + i - 1;\n this.currentNode = this.currentNode.parentNode;\n this.state = STATE_NORMAL;\n break;\n } else if (this.currentNode.parentNode && chr === ']' && this.currentNode.parentNode.type === 'SECTION') {\n this.currentNode.endPos = this.pos + i - 1;\n this.currentNode = this.currentNode.parentNode;\n\n this.currentNode.isClosed = true;\n this.currentNode.endPos = this.pos + i;\n this.currentNode = this.currentNode.parentNode;\n this.state = STATE_NORMAL;\n\n checkSP();\n break;\n }\n\n if (chr === ':') {\n if (!RE_SINGLE_DIGIT.test(this.currentNode.value.at(-1)) && this.currentNode.value.at(-1) !== '*') {\n let error = new Error(`Unexpected range separator : at position ${this.pos + i} [E29]`);\n error.code = 'ParserError29';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n } else if (chr === '*') {\n if ([',', ':'].indexOf(this.currentNode.value.at(-1)) < 0) {\n let error = new Error(`Unexpected range wildcard at position ${this.pos + i} [E30]`);\n error.code = 'ParserError30';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n } else if (chr === ',') {\n if (!RE_SINGLE_DIGIT.test(this.currentNode.value.at(-1)) && this.currentNode.value.at(-1) !== '*') {\n let error = new Error(`Unexpected sequence separator , at position ${this.pos + i} [E31]`);\n error.code = 'ParserError31';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n if (this.currentNode.value.at(-1) === '*' && this.currentNode.value.at(-2) !== ':') {\n let error = new Error(`Unexpected sequence separator , at position ${this.pos + i} [E32]`);\n error.code = 'ParserError32';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n } else if (!RE_SINGLE_DIGIT.test(chr)) {\n let error = new Error(`Unexpected char at position ${this.pos + i} [E33: ${JSON.stringify(chr)}]`);\n error.code = 'ParserError33';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n if (RE_SINGLE_DIGIT.test(chr) && this.currentNode.value.at(-1) === '*') {\n let error = new Error(`Unexpected number at position ${this.pos + i} [E34: ${JSON.stringify(chr)}]`);\n error.code = 'ParserError34';\n error.parserContext = { input: this.str, pos: this.pos + i, chr };\n throw error;\n }\n\n this.currentNode.value += chr;\n break;\n\n case STATE_TEXT:\n this.currentNode.value += chr;\n break;\n }\n }\n }\n}\n\nmodule.exports.TokenParser = TokenParser;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/imapflow/lib/handler/token-parser.js","mappings":"AAAA;;AAEa;;AAEb,yBAAyB,mBAAO,CAAC,6FAAsB;;AAEvD;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,6EAA6E,gCAAgC;AAC7G;AACA,wCAAwC;AACxC;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA,2CAA2C,SAAS;AACpD;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,kGAAkG,cAAc;AAChH;AACA,wDAAwD;AACxD;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,qGAAqG,cAAc;AACnH;AACA,wDAAwD;AACxD;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B;AAC9B;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,8CAA8C;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,gGAAgG,cAAc;AAC9G;AACA,wDAAwD;AACxD;AACA;AACA;AACA;AACA;;AAEA,6BAA6B;AAC7B,+BAA+B;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qFAAqF,cAAc,QAAQ,oBAAoB;AAC/H;AACA,wDAAwD;AACxD;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B;AAC9B,qGAAqG,cAAc;AACnH;AACA,wDAAwD;AACxD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,yFAAyF,cAAc;AACvG;AACA,gDAAgD;AAChD;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6EAA6E,cAAc,QAAQ,oBAAoB;AACvH;AACA,gDAAgD;AAChD;AACA,sBAAsB;AACtB,6EAA6E,cAAc,QAAQ,oBAAoB;AACvH;AACA,gDAAgD;AAChD;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,yFAAyF,cAAc;AACvG;AACA,oDAAoD;AACpD;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,2FAA2F,cAAc;AACzG;AACA,oDAAoD;AACpD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,4FAA4F,cAAc;AAC1G;AACA,gDAAgD;AAChD;AACA;;AAEA;AACA,6EAA6E,cAAc,QAAQ,oBAAoB;AACvH;AACA,gDAAgD;AAChD;AACA;;AAEA;AACA,6EAA6E,cAAc,QAAQ,oBAAoB;AACvH;AACA,gDAAgD;AAChD;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,kCAAkC;AAClC;AACA,wFAAwF,cAAc,cAAc;AACpH;AACA,oDAAoD;AACpD;AACA;AACA;AACA;AACA,0BAA0B;AAC1B;AACA,0BAA0B;AAC1B,iFAAiF,cAAc,QAAQ,oBAAoB;AAC3H;AACA,oDAAoD;AACpD;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B;AAC1B;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,0BAA0B;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6EAA6E,cAAc,QAAQ,oBAAoB;AACvH;AACA,gDAAgD;AAChD;AACA;AACA;AACA,6EAA6E,cAAc;AAC3F;AACA,gDAAgD;AAChD;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,uFAAuF,cAAc;AACrG;AACA,oDAAoD;AACpD;AACA;;AAEA;AACA,uFAAuF,cAAc;AACrG;AACA,oDAAoD;AACpD;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,8FAA8F,cAAc;AAC5G;AACA,oDAAoD;AACpD;AACA;AACA,sBAAsB;AACtB;AACA,2FAA2F,cAAc;AACzG;AACA,oDAAoD;AACpD;AACA;AACA,sBAAsB;AACtB;AACA,iGAAiG,cAAc;AAC/G;AACA,oDAAoD;AACpD;AACA;AACA;AACA,iGAAiG,cAAc;AAC/G;AACA,oDAAoD;AACpD;AACA;AACA,sBAAsB;AACtB,6EAA6E,cAAc,QAAQ,oBAAoB;AACvH;AACA,gDAAgD;AAChD;AACA;;AAEA;AACA,+EAA+E,cAAc,QAAQ,oBAAoB;AACzH;AACA,gDAAgD;AAChD;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,0BAA0B","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/handler/token-parser.js"],"sourcesContent":["/* eslint new-cap: 0 */\n\n'use strict';\n\nconst imapFormalSyntax = require('./imap-formal-syntax');\n\nconst STATE_ATOM = 0x001;\nconst STATE_LITERAL = 0x002;\nconst STATE_NORMAL = 0x003;\nconst STATE_PARTIAL = 0x004;\nconst STATE_SEQUENCE = 0x005;\nconst STATE_STRING = 0x006;\nconst STATE_TEXT = 0x007;\n\nconst RE_DIGITS = /^\\d+$/;\nconst RE_SINGLE_DIGIT = /^\\d$/;\n\nclass TokenParser {\n    constructor(parent, startPos, str, options) {\n        this.str = (str || '').toString();\n        this.options = options || {};\n        this.parent = parent;\n\n        this.tree = this.currentNode = this.createNode();\n        this.pos = startPos || 0;\n\n        this.currentNode.type = 'TREE';\n\n        this.state = STATE_NORMAL;\n    }\n\n    async getAttributes() {\n        await this.processString();\n\n        const attributes = [];\n        let branch = attributes;\n\n        let walk = async node => {\n            let curBranch = branch;\n            let elm;\n            let partial;\n\n            if (!node.isClosed && node.type === 'SEQUENCE' && node.value === '*') {\n                node.isClosed = true;\n                node.type = 'ATOM';\n            }\n\n            // If the node was never closed, throw it\n            if (!node.isClosed) {\n                let error = new Error(`Unexpected end of input at position ${this.pos + this.str.length - 1} [E9]`);\n                error.code = 'ParserError9';\n                error.parserContext = { input: this.str, pos: this.pos + this.str.length - 1 };\n                throw error;\n            }\n\n            let type = (node.type || '').toString().toUpperCase();\n\n            switch (type) {\n                case 'LITERAL':\n                case 'STRING':\n                case 'SEQUENCE':\n                    elm = {\n                        type: node.type.toUpperCase(),\n                        value: node.value\n                    };\n                    branch.push(elm);\n                    break;\n\n                case 'ATOM':\n                    if (node.value.toUpperCase() === 'NIL') {\n                        branch.push(null);\n                        break;\n                    }\n                    elm = {\n                        type: node.type.toUpperCase(),\n                        value: node.value\n                    };\n                    branch.push(elm);\n                    break;\n\n                case 'SECTION':\n                    branch = branch[branch.length - 1].section = [];\n                    break;\n\n                case 'LIST':\n                    elm = [];\n                    branch.push(elm);\n                    branch = elm;\n                    break;\n\n                case 'PARTIAL':\n                    partial = node.value.split('.').map(Number);\n                    branch[branch.length - 1].partial = partial;\n                    break;\n            }\n\n            for (let childNode of node.childNodes) {\n                await walk(childNode);\n            }\n\n            branch = curBranch;\n        };\n\n        await walk(this.tree);\n\n        return attributes;\n    }\n\n    createNode(parentNode, startPos) {\n        let node = {\n            childNodes: [],\n            type: false,\n            value: '',\n            isClosed: true\n        };\n\n        if (parentNode) {\n            node.parentNode = parentNode;\n        }\n\n        if (typeof startPos === 'number') {\n            node.startPos = startPos;\n        }\n\n        if (parentNode) {\n            parentNode.childNodes.push(node);\n        }\n\n        return node;\n    }\n\n    async processString() {\n        let chr, i, len;\n\n        const checkSP = () => {\n            // jump to the next non whitespace pos\n            while (this.str.charAt(i + 1) === ' ') {\n                i++;\n            }\n        };\n\n        for (i = 0, len = this.str.length; i < len; i++) {\n            chr = this.str.charAt(i);\n\n            switch (this.state) {\n                case STATE_NORMAL:\n                    switch (chr) {\n                        // DQUOTE starts a new string\n                        case '\"':\n                            this.currentNode = this.createNode(this.currentNode, this.pos + i);\n                            this.currentNode.type = 'string';\n                            this.state = STATE_STRING;\n                            this.currentNode.isClosed = false;\n                            break;\n\n                        // ( starts a new list\n                        case '(':\n                            this.currentNode = this.createNode(this.currentNode, this.pos + i);\n                            this.currentNode.type = 'LIST';\n                            this.currentNode.isClosed = false;\n                            break;\n\n                        // ) closes a list\n                        case ')':\n                            if (this.currentNode.type !== 'LIST') {\n                                let error = new Error(`Unexpected list terminator ) at position ${this.pos + i} [E10]`);\n                                error.code = 'ParserError10';\n                                error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                                throw error;\n                            }\n\n                            this.currentNode.isClosed = true;\n                            this.currentNode.endPos = this.pos + i;\n                            this.currentNode = this.currentNode.parentNode;\n\n                            checkSP();\n                            break;\n\n                        // ] closes section group\n                        case ']':\n                            if (this.currentNode.type !== 'SECTION') {\n                                let error = new Error(`Unexpected section terminator ] at position ${this.pos + i} [E11]`);\n                                error.code = 'ParserError11';\n                                error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                                throw error;\n                            }\n                            this.currentNode.isClosed = true;\n                            this.currentNode.endPos = this.pos + i;\n                            this.currentNode = this.currentNode.parentNode;\n\n                            checkSP();\n                            break;\n\n                        // < starts a new partial\n                        case '<':\n                            if (this.str.charAt(i - 1) !== ']') {\n                                this.currentNode = this.createNode(this.currentNode, this.pos + i);\n                                this.currentNode.type = 'ATOM';\n                                this.currentNode.value = chr;\n                                this.state = STATE_ATOM;\n                            } else {\n                                this.currentNode = this.createNode(this.currentNode, this.pos + i);\n                                this.currentNode.type = 'PARTIAL';\n                                this.state = STATE_PARTIAL;\n                                this.currentNode.isClosed = false;\n                            }\n                            break;\n\n                        // binary literal8\n                        case '~': {\n                            let nextChr = this.str.charAt(i + 1);\n                            if (nextChr !== '{') {\n                                if (imapFormalSyntax['ATOM-CHAR']().indexOf(nextChr) >= 0) {\n                                    // treat as ATOM\n                                    this.currentNode = this.createNode(this.currentNode, this.pos + i);\n                                    this.currentNode.type = 'ATOM';\n                                    this.currentNode.value = chr;\n                                    this.state = STATE_ATOM;\n                                    break;\n                                }\n\n                                let error = new Error(`Unexpected literal8 marker at position ${this.pos + i} [E12]`);\n                                error.code = 'ParserError12';\n                                error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                                throw error;\n                            }\n                            this.expectedLiteralType = 'literal8';\n                            break;\n                        }\n\n                        // { starts a new literal\n                        case '{':\n                            this.currentNode = this.createNode(this.currentNode, this.pos + i);\n                            this.currentNode.type = 'LITERAL';\n                            this.currentNode.literalType = this.expectedLiteralType || 'literal';\n                            this.expectedLiteralType = false;\n                            this.state = STATE_LITERAL;\n                            this.currentNode.isClosed = false;\n                            break;\n\n                        // * starts a new sequence\n                        case '*':\n                            this.currentNode = this.createNode(this.currentNode, this.pos + i);\n                            this.currentNode.type = 'SEQUENCE';\n                            this.currentNode.value = chr;\n                            this.currentNode.isClosed = false;\n                            this.state = STATE_SEQUENCE;\n                            break;\n\n                        // normally a space should never occur\n                        case ' ':\n                            // just ignore\n                            break;\n\n                        // [ starts section\n                        case '[':\n                            // If it is the *first* element after response command, then process as a response argument list\n                            if (['OK', 'NO', 'BAD', 'BYE', 'PREAUTH'].includes(this.parent.command.toUpperCase()) && this.currentNode === this.tree) {\n                                this.currentNode.endPos = this.pos + i;\n\n                                this.currentNode = this.createNode(this.currentNode, this.pos + i);\n                                this.currentNode.type = 'ATOM';\n\n                                this.currentNode = this.createNode(this.currentNode, this.pos + i);\n                                this.currentNode.type = 'SECTION';\n                                this.currentNode.isClosed = false;\n                                this.state = STATE_NORMAL;\n\n                                // RFC2221 defines a response code REFERRAL whose payload is an\n                                // RFC2192/RFC5092 imapurl that we will try to parse as an ATOM but\n                                // fail quite badly at parsing.  Since the imapurl is such a unique\n                                // (and crazy) term, we just specialize that case here.\n                                if (this.str.substr(i + 1, 9).toUpperCase() === 'REFERRAL ') {\n                                    // create the REFERRAL atom\n                                    this.currentNode = this.createNode(this.currentNode, this.pos + i + 1);\n                                    this.currentNode.type = 'ATOM';\n                                    this.currentNode.endPos = this.pos + i + 8;\n                                    this.currentNode.value = 'REFERRAL';\n                                    this.currentNode = this.currentNode.parentNode;\n\n                                    // eat all the way through the ] to be the  IMAPURL token.\n                                    this.currentNode = this.createNode(this.currentNode, this.pos + i + 10);\n                                    // just call this an ATOM, even though IMAPURL might be more correct\n                                    this.currentNode.type = 'ATOM';\n                                    // jump i to the ']'\n                                    i = this.str.indexOf(']', i + 10);\n                                    this.currentNode.endPos = this.pos + i - 1;\n                                    this.currentNode.value = this.str.substring(this.currentNode.startPos - this.pos, this.currentNode.endPos - this.pos + 1);\n                                    this.currentNode = this.currentNode.parentNode;\n\n                                    // close out the SECTION\n                                    this.currentNode.isClosed = true;\n                                    this.currentNode = this.currentNode.parentNode;\n\n                                    checkSP();\n                                }\n\n                                break;\n                            }\n\n                        /* falls through */\n                        default:\n                            // Any ATOM supported char starts a new Atom sequence, otherwise throw an error\n                            // Allow \\ as the first char for atom to support system flags\n                            // Allow % to support LIST '' %\n                            // Allow 8bit characters (presumably unicode)\n                            if (imapFormalSyntax['ATOM-CHAR']().indexOf(chr) < 0 && chr !== '\\\\' && chr !== '%' && chr.charCodeAt(0) < 0x80) {\n                                let error = new Error(`Unexpected char at position ${this.pos + i} [E13: ${JSON.stringify(chr)}]`);\n                                error.code = 'ParserError13';\n                                error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                                throw error;\n                            }\n\n                            this.currentNode = this.createNode(this.currentNode, this.pos + i);\n                            this.currentNode.type = 'ATOM';\n                            this.currentNode.value = chr;\n                            this.state = STATE_ATOM;\n                            break;\n                    }\n                    break;\n\n                case STATE_ATOM:\n                    // space finishes an atom\n                    if (chr === ' ') {\n                        this.currentNode.endPos = this.pos + i - 1;\n                        this.currentNode = this.currentNode.parentNode;\n                        this.state = STATE_NORMAL;\n                        break;\n                    }\n\n                    //\n                    if (\n                        this.currentNode.parentNode &&\n                        ((chr === ')' && this.currentNode.parentNode.type === 'LIST') || (chr === ']' && this.currentNode.parentNode.type === 'SECTION'))\n                    ) {\n                        this.currentNode.endPos = this.pos + i - 1;\n                        this.currentNode = this.currentNode.parentNode;\n\n                        this.currentNode.isClosed = true;\n                        this.currentNode.endPos = this.pos + i;\n                        this.currentNode = this.currentNode.parentNode;\n                        this.state = STATE_NORMAL;\n                        checkSP();\n\n                        break;\n                    }\n\n                    if ((chr === ',' || chr === ':') && RE_DIGITS.test(this.currentNode.value)) {\n                        this.currentNode.type = 'SEQUENCE';\n                        this.currentNode.isClosed = true;\n                        this.state = STATE_SEQUENCE;\n                    }\n\n                    // [ starts a section group for this element\n                    if (chr === '[') {\n                        // allowed only for selected elements\n                        if (['BODY', 'BODY.PEEK', 'BINARY', 'BINARY.PEEK'].indexOf(this.currentNode.value.toUpperCase()) < 0) {\n                            if (/[./]/.test(this.currentNode.value)) {\n                                // could be a path\n                                this.currentNode.value += chr;\n                                break;\n                            } else {\n                                let error = new Error(`Unexpected section start char [ at position ${this.pos + i} [E14]`);\n                                error.code = 'ParserError14';\n                                error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                                throw error;\n                            }\n                        }\n                        this.currentNode.endPos = this.pos + i;\n                        this.currentNode = this.createNode(this.currentNode.parentNode, this.pos + i);\n                        this.currentNode.type = 'SECTION';\n                        this.currentNode.isClosed = false;\n                        this.state = STATE_NORMAL;\n                        break;\n                    }\n\n                    if (chr === '<') {\n                        let error = new Error(`Unexpected start of partial at position ${this.pos + i} [E15]`);\n                        error.code = 'ParserError15';\n                        error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                        throw error;\n                    }\n\n                    // if the char is not ATOM compatible, throw. Allow \\* as an exception\n                    if (\n                        imapFormalSyntax['ATOM-CHAR']().indexOf(chr) < 0 &&\n                        chr.charCodeAt(0) < 0x80 && // allow 8bit (presumably unicode) bytes\n                        chr !== ']' &&\n                        !(chr === '*' && this.currentNode.value === '\\\\') &&\n                        (!this.parent || !this.parent.command || !['NO', 'BAD', 'OK'].includes(this.parent.command))\n                    ) {\n                        let error = new Error(`Unexpected char at position ${this.pos + i} [E16: ${JSON.stringify(chr)}]`);\n                        error.code = 'ParserError16';\n                        error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                        throw error;\n                    } else if (this.currentNode.value === '\\\\*') {\n                        let error = new Error(`Unexpected char at position ${this.pos + i} [E17: ${JSON.stringify(chr)}]`);\n                        error.code = 'ParserError17';\n                        error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                        throw error;\n                    }\n\n                    this.currentNode.value += chr;\n                    break;\n\n                case STATE_STRING:\n                    // DQUOTE ends the string sequence\n                    if (chr === '\"') {\n                        this.currentNode.endPos = this.pos + i;\n                        this.currentNode.isClosed = true;\n                        this.currentNode = this.currentNode.parentNode;\n                        this.state = STATE_NORMAL;\n\n                        checkSP();\n                        break;\n                    }\n\n                    // \\ Escapes the following char\n                    if (chr === '\\\\') {\n                        i++;\n                        if (i >= len) {\n                            let error = new Error(`Unexpected end of input at position ${this.pos + i} [E18]`);\n                            error.code = 'ParserError18';\n                            error.parserContext = { input: this.str, pos: this.pos + i };\n                            throw error;\n                        }\n                        chr = this.str.charAt(i);\n                    }\n\n                    this.currentNode.value += chr;\n                    break;\n\n                case STATE_PARTIAL:\n                    if (chr === '>') {\n                        if (this.currentNode.value.at(-1) === '.') {\n                            let error = new Error(`Unexpected end of partial at position ${this.pos + i} [E19]`);\n                            error.code = 'ParserError19';\n                            error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                            throw error;\n                        }\n                        this.currentNode.endPos = this.pos + i;\n                        this.currentNode.isClosed = true;\n                        this.currentNode = this.currentNode.parentNode;\n                        this.state = STATE_NORMAL;\n                        checkSP();\n                        break;\n                    }\n\n                    if (chr === '.' && (!this.currentNode.value.length || this.currentNode.value.match(/\\./))) {\n                        let error = new Error(`Unexpected partial separator . at position ${this.pos + i} [E20]`);\n                        error.code = 'ParserError20';\n                        error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                        throw error;\n                    }\n\n                    if (imapFormalSyntax.DIGIT().indexOf(chr) < 0 && chr !== '.') {\n                        let error = new Error(`Unexpected char at position ${this.pos + i} [E21: ${JSON.stringify(chr)}]`);\n                        error.code = 'ParserError21';\n                        error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                        throw error;\n                    }\n\n                    if (this.currentNode.value.match(/^0$|\\.0$/) && chr !== '.') {\n                        let error = new Error(`Invalid partial at position ${this.pos + i} [E22: ${JSON.stringify(chr)}]`);\n                        error.code = 'ParserError22';\n                        error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                        throw error;\n                    }\n\n                    this.currentNode.value += chr;\n                    break;\n\n                case STATE_LITERAL:\n                    if (this.currentNode.started) {\n                        // only relevant if literals are not already parsed out from input\n\n                        // Disabled NULL byte check\n                        // See https://github.com/emailjs/emailjs-imap-handler/commit/f11b2822bedabe492236e8263afc630134a3c41c\n                        /*\n                        if (chr === '\\u0000') {\n                            throw new Error('Unexpected \\\\x00 at position ' + (this.pos + i));\n                        }\n                        */\n\n                        this.currentNode.chBuffer[this.currentNode.chPos++] = chr.charCodeAt(0);\n\n                        if (this.currentNode.chPos >= this.currentNode.literalLength) {\n                            this.currentNode.endPos = this.pos + i;\n                            this.currentNode.isClosed = true;\n                            this.currentNode.value = this.currentNode.chBuffer.toString('binary');\n                            this.currentNode.chBuffer = Buffer.alloc(0);\n                            this.currentNode = this.currentNode.parentNode;\n                            this.state = STATE_NORMAL;\n                            checkSP();\n                        }\n                        break;\n                    }\n\n                    if (chr === '+' && this.options.literalPlus) {\n                        this.currentNode.literalPlus = true;\n                        break;\n                    }\n\n                    if (chr === '}') {\n                        if (!('literalLength' in this.currentNode)) {\n                            let error = new Error(`Unexpected literal prefix end char } at position ${this.pos + i} [E23]`);\n                            error.code = 'ParserError23';\n                            error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                            throw error;\n                        }\n                        if (this.str.charAt(i + 1) === '\\n') {\n                            i++;\n                        } else if (this.str.charAt(i + 1) === '\\r' && this.str.charAt(i + 2) === '\\n') {\n                            i += 2;\n                        } else {\n                            let error = new Error(`Unexpected char at position ${this.pos + i} [E24: ${JSON.stringify(chr)}]`);\n                            error.code = 'ParserError24';\n                            error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                            throw error;\n                        }\n\n                        this.currentNode.literalLength = Number(this.currentNode.literalLength);\n\n                        if (!this.currentNode.literalLength) {\n                            // special case where literal content length is 0\n                            // close the node right away, do not wait for additional input\n                            this.currentNode.endPos = this.pos + i;\n                            this.currentNode.isClosed = true;\n                            this.currentNode = this.currentNode.parentNode;\n                            this.state = STATE_NORMAL;\n                            checkSP();\n                        } else if (this.options.literals) {\n                            // use the next precached literal values\n                            this.currentNode.value = this.options.literals.shift();\n\n                            // only APPEND arguments are kept as Buffers\n                            /*\n                            if ((this.parent.command || '').toString().toUpperCase() !== 'APPEND') {\n                                this.currentNode.value = this.currentNode.value.toString('binary');\n                            }\n                            */\n\n                            this.currentNode.endPos = this.pos + i + this.currentNode.value.length;\n\n                            this.currentNode.started = false;\n                            this.currentNode.isClosed = true;\n                            this.currentNode = this.currentNode.parentNode;\n                            this.state = STATE_NORMAL;\n                            checkSP();\n                        } else {\n                            this.currentNode.started = true;\n                            // Allocate expected size buffer. Max size check is already performed\n                            // Maybe should use allocUnsafe instead?\n                            this.currentNode.chBuffer = Buffer.alloc(this.currentNode.literalLength);\n                            this.currentNode.chPos = 0;\n                        }\n                        break;\n                    }\n                    if (imapFormalSyntax.DIGIT().indexOf(chr) < 0) {\n                        let error = new Error(`Unexpected char at position ${this.pos + i} [E25: ${JSON.stringify(chr)}]`);\n                        error.code = 'ParserError25';\n                        error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                        throw error;\n                    }\n                    if (this.currentNode.literalLength === '0') {\n                        let error = new Error(`Invalid literal at position ${this.pos + i} [E26]`);\n                        error.code = 'ParserError26';\n                        error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                        throw error;\n                    }\n                    this.currentNode.literalLength = (this.currentNode.literalLength || '') + chr;\n                    break;\n\n                case STATE_SEQUENCE:\n                    // space finishes the sequence set\n                    if (chr === ' ') {\n                        if (!RE_SINGLE_DIGIT.test(this.currentNode.value.at(-1)) && this.currentNode.value.at(-1) !== '*') {\n                            let error = new Error(`Unexpected whitespace at position ${this.pos + i} [E27]`);\n                            error.code = 'ParserError27';\n                            error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                            throw error;\n                        }\n\n                        if (this.currentNode.value !== '*' && this.currentNode.value.at(-1) === '*' && this.currentNode.value.at(-2) !== ':') {\n                            let error = new Error(`Unexpected whitespace at position ${this.pos + i} [E28]`);\n                            error.code = 'ParserError28';\n                            error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                            throw error;\n                        }\n\n                        this.currentNode.isClosed = true;\n                        this.currentNode.endPos = this.pos + i - 1;\n                        this.currentNode = this.currentNode.parentNode;\n                        this.state = STATE_NORMAL;\n                        break;\n                    } else if (this.currentNode.parentNode && chr === ']' && this.currentNode.parentNode.type === 'SECTION') {\n                        this.currentNode.endPos = this.pos + i - 1;\n                        this.currentNode = this.currentNode.parentNode;\n\n                        this.currentNode.isClosed = true;\n                        this.currentNode.endPos = this.pos + i;\n                        this.currentNode = this.currentNode.parentNode;\n                        this.state = STATE_NORMAL;\n\n                        checkSP();\n                        break;\n                    }\n\n                    if (chr === ':') {\n                        if (!RE_SINGLE_DIGIT.test(this.currentNode.value.at(-1)) && this.currentNode.value.at(-1) !== '*') {\n                            let error = new Error(`Unexpected range separator : at position ${this.pos + i} [E29]`);\n                            error.code = 'ParserError29';\n                            error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                            throw error;\n                        }\n                    } else if (chr === '*') {\n                        if ([',', ':'].indexOf(this.currentNode.value.at(-1)) < 0) {\n                            let error = new Error(`Unexpected range wildcard at position ${this.pos + i} [E30]`);\n                            error.code = 'ParserError30';\n                            error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                            throw error;\n                        }\n                    } else if (chr === ',') {\n                        if (!RE_SINGLE_DIGIT.test(this.currentNode.value.at(-1)) && this.currentNode.value.at(-1) !== '*') {\n                            let error = new Error(`Unexpected sequence separator , at position ${this.pos + i} [E31]`);\n                            error.code = 'ParserError31';\n                            error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                            throw error;\n                        }\n                        if (this.currentNode.value.at(-1) === '*' && this.currentNode.value.at(-2) !== ':') {\n                            let error = new Error(`Unexpected sequence separator , at position ${this.pos + i} [E32]`);\n                            error.code = 'ParserError32';\n                            error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                            throw error;\n                        }\n                    } else if (!RE_SINGLE_DIGIT.test(chr)) {\n                        let error = new Error(`Unexpected char at position ${this.pos + i} [E33: ${JSON.stringify(chr)}]`);\n                        error.code = 'ParserError33';\n                        error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                        throw error;\n                    }\n\n                    if (RE_SINGLE_DIGIT.test(chr) && this.currentNode.value.at(-1) === '*') {\n                        let error = new Error(`Unexpected number at position ${this.pos + i} [E34: ${JSON.stringify(chr)}]`);\n                        error.code = 'ParserError34';\n                        error.parserContext = { input: this.str, pos: this.pos + i, chr };\n                        throw error;\n                    }\n\n                    this.currentNode.value += chr;\n                    break;\n\n                case STATE_TEXT:\n                    this.currentNode.value += chr;\n                    break;\n            }\n        }\n    }\n}\n\nmodule.exports.TokenParser = TokenParser;\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/handler/token-parser.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/imap-commands.js":
|
|
/*!****************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/imap-commands.js ***!
|
|
\****************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("/* eslint global-require:0 */\n\n\n\nmodule.exports = new Map([\n ['ID', __webpack_require__(/*! ./commands/id.js */ \"(rsc)/./node_modules/imapflow/lib/commands/id.js\")],\n ['CAPABILITY', __webpack_require__(/*! ./commands/capability.js */ \"(rsc)/./node_modules/imapflow/lib/commands/capability.js\")],\n ['NAMESPACE', __webpack_require__(/*! ./commands/namespace.js */ \"(rsc)/./node_modules/imapflow/lib/commands/namespace.js\")],\n ['LOGIN', __webpack_require__(/*! ./commands/login.js */ \"(rsc)/./node_modules/imapflow/lib/commands/login.js\")],\n ['LOGOUT', __webpack_require__(/*! ./commands/logout.js */ \"(rsc)/./node_modules/imapflow/lib/commands/logout.js\")],\n ['STARTTLS', __webpack_require__(/*! ./commands/starttls.js */ \"(rsc)/./node_modules/imapflow/lib/commands/starttls.js\")],\n ['LIST', __webpack_require__(/*! ./commands/list.js */ \"(rsc)/./node_modules/imapflow/lib/commands/list.js\")],\n ['ENABLE', __webpack_require__(/*! ./commands/enable.js */ \"(rsc)/./node_modules/imapflow/lib/commands/enable.js\")],\n ['SELECT', __webpack_require__(/*! ./commands/select.js */ \"(rsc)/./node_modules/imapflow/lib/commands/select.js\")],\n ['FETCH', __webpack_require__(/*! ./commands/fetch.js */ \"(rsc)/./node_modules/imapflow/lib/commands/fetch.js\")],\n ['CREATE', __webpack_require__(/*! ./commands/create.js */ \"(rsc)/./node_modules/imapflow/lib/commands/create.js\")],\n ['DELETE', __webpack_require__(/*! ./commands/delete.js */ \"(rsc)/./node_modules/imapflow/lib/commands/delete.js\")],\n ['RENAME', __webpack_require__(/*! ./commands/rename.js */ \"(rsc)/./node_modules/imapflow/lib/commands/rename.js\")],\n ['CLOSE', __webpack_require__(/*! ./commands/close.js */ \"(rsc)/./node_modules/imapflow/lib/commands/close.js\")],\n ['SUBSCRIBE', __webpack_require__(/*! ./commands/subscribe.js */ \"(rsc)/./node_modules/imapflow/lib/commands/subscribe.js\")],\n ['UNSUBSCRIBE', __webpack_require__(/*! ./commands/unsubscribe.js */ \"(rsc)/./node_modules/imapflow/lib/commands/unsubscribe.js\")],\n ['STORE', __webpack_require__(/*! ./commands/store.js */ \"(rsc)/./node_modules/imapflow/lib/commands/store.js\")],\n ['SEARCH', __webpack_require__(/*! ./commands/search.js */ \"(rsc)/./node_modules/imapflow/lib/commands/search.js\")],\n ['NOOP', __webpack_require__(/*! ./commands/noop.js */ \"(rsc)/./node_modules/imapflow/lib/commands/noop.js\")],\n ['EXPUNGE', __webpack_require__(/*! ./commands/expunge.js */ \"(rsc)/./node_modules/imapflow/lib/commands/expunge.js\")],\n ['APPEND', __webpack_require__(/*! ./commands/append.js */ \"(rsc)/./node_modules/imapflow/lib/commands/append.js\")],\n ['STATUS', __webpack_require__(/*! ./commands/status.js */ \"(rsc)/./node_modules/imapflow/lib/commands/status.js\")],\n ['COPY', __webpack_require__(/*! ./commands/copy.js */ \"(rsc)/./node_modules/imapflow/lib/commands/copy.js\")],\n ['MOVE', __webpack_require__(/*! ./commands/move.js */ \"(rsc)/./node_modules/imapflow/lib/commands/move.js\")],\n ['COMPRESS', __webpack_require__(/*! ./commands/compress.js */ \"(rsc)/./node_modules/imapflow/lib/commands/compress.js\")],\n ['QUOTA', __webpack_require__(/*! ./commands/quota.js */ \"(rsc)/./node_modules/imapflow/lib/commands/quota.js\")],\n ['IDLE', __webpack_require__(/*! ./commands/idle.js */ \"(rsc)/./node_modules/imapflow/lib/commands/idle.js\")],\n ['AUTHENTICATE', __webpack_require__(/*! ./commands/authenticate.js */ \"(rsc)/./node_modules/imapflow/lib/commands/authenticate.js\")]\n]);\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2ltYXAtY29tbWFuZHMuanMiLCJtYXBwaW5ncyI6IkFBQUE7O0FBRWE7O0FBRWI7QUFDQSxXQUFXLG1CQUFPLENBQUMsMEVBQWtCO0FBQ3JDLG1CQUFtQixtQkFBTyxDQUFDLDBGQUEwQjtBQUNyRCxrQkFBa0IsbUJBQU8sQ0FBQyx3RkFBeUI7QUFDbkQsY0FBYyxtQkFBTyxDQUFDLGdGQUFxQjtBQUMzQyxlQUFlLG1CQUFPLENBQUMsa0ZBQXNCO0FBQzdDLGlCQUFpQixtQkFBTyxDQUFDLHNGQUF3QjtBQUNqRCxhQUFhLG1CQUFPLENBQUMsOEVBQW9CO0FBQ3pDLGVBQWUsbUJBQU8sQ0FBQyxrRkFBc0I7QUFDN0MsZUFBZSxtQkFBTyxDQUFDLGtGQUFzQjtBQUM3QyxjQUFjLG1CQUFPLENBQUMsZ0ZBQXFCO0FBQzNDLGVBQWUsbUJBQU8sQ0FBQyxrRkFBc0I7QUFDN0MsZUFBZSxtQkFBTyxDQUFDLGtGQUFzQjtBQUM3QyxlQUFlLG1CQUFPLENBQUMsa0ZBQXNCO0FBQzdDLGNBQWMsbUJBQU8sQ0FBQyxnRkFBcUI7QUFDM0Msa0JBQWtCLG1CQUFPLENBQUMsd0ZBQXlCO0FBQ25ELG9CQUFvQixtQkFBTyxDQUFDLDRGQUEyQjtBQUN2RCxjQUFjLG1CQUFPLENBQUMsZ0ZBQXFCO0FBQzNDLGVBQWUsbUJBQU8sQ0FBQyxrRkFBc0I7QUFDN0MsYUFBYSxtQkFBTyxDQUFDLDhFQUFvQjtBQUN6QyxnQkFBZ0IsbUJBQU8sQ0FBQyxvRkFBdUI7QUFDL0MsZUFBZSxtQkFBTyxDQUFDLGtGQUFzQjtBQUM3QyxlQUFlLG1CQUFPLENBQUMsa0ZBQXNCO0FBQzdDLGFBQWEsbUJBQU8sQ0FBQyw4RUFBb0I7QUFDekMsYUFBYSxtQkFBTyxDQUFDLDhFQUFvQjtBQUN6QyxpQkFBaUIsbUJBQU8sQ0FBQyxzRkFBd0I7QUFDakQsY0FBYyxtQkFBTyxDQUFDLGdGQUFxQjtBQUMzQyxhQUFhLG1CQUFPLENBQUMsOEVBQW9CO0FBQ3pDLHFCQUFxQixtQkFBTyxDQUFDLDhGQUE0QjtBQUN6RCIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2ltYXAtY29tbWFuZHMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50IGdsb2JhbC1yZXF1aXJlOjAgKi9cblxuJ3VzZSBzdHJpY3QnO1xuXG5tb2R1bGUuZXhwb3J0cyA9IG5ldyBNYXAoW1xuICAgIFsnSUQnLCByZXF1aXJlKCcuL2NvbW1hbmRzL2lkLmpzJyldLFxuICAgIFsnQ0FQQUJJTElUWScsIHJlcXVpcmUoJy4vY29tbWFuZHMvY2FwYWJpbGl0eS5qcycpXSxcbiAgICBbJ05BTUVTUEFDRScsIHJlcXVpcmUoJy4vY29tbWFuZHMvbmFtZXNwYWNlLmpzJyldLFxuICAgIFsnTE9HSU4nLCByZXF1aXJlKCcuL2NvbW1hbmRzL2xvZ2luLmpzJyldLFxuICAgIFsnTE9HT1VUJywgcmVxdWlyZSgnLi9jb21tYW5kcy9sb2dvdXQuanMnKV0sXG4gICAgWydTVEFSVFRMUycsIHJlcXVpcmUoJy4vY29tbWFuZHMvc3RhcnR0bHMuanMnKV0sXG4gICAgWydMSVNUJywgcmVxdWlyZSgnLi9jb21tYW5kcy9saXN0LmpzJyldLFxuICAgIFsnRU5BQkxFJywgcmVxdWlyZSgnLi9jb21tYW5kcy9lbmFibGUuanMnKV0sXG4gICAgWydTRUxFQ1QnLCByZXF1aXJlKCcuL2NvbW1hbmRzL3NlbGVjdC5qcycpXSxcbiAgICBbJ0ZFVENIJywgcmVxdWlyZSgnLi9jb21tYW5kcy9mZXRjaC5qcycpXSxcbiAgICBbJ0NSRUFURScsIHJlcXVpcmUoJy4vY29tbWFuZHMvY3JlYXRlLmpzJyldLFxuICAgIFsnREVMRVRFJywgcmVxdWlyZSgnLi9jb21tYW5kcy9kZWxldGUuanMnKV0sXG4gICAgWydSRU5BTUUnLCByZXF1aXJlKCcuL2NvbW1hbmRzL3JlbmFtZS5qcycpXSxcbiAgICBbJ0NMT1NFJywgcmVxdWlyZSgnLi9jb21tYW5kcy9jbG9zZS5qcycpXSxcbiAgICBbJ1NVQlNDUklCRScsIHJlcXVpcmUoJy4vY29tbWFuZHMvc3Vic2NyaWJlLmpzJyldLFxuICAgIFsnVU5TVUJTQ1JJQkUnLCByZXF1aXJlKCcuL2NvbW1hbmRzL3Vuc3Vic2NyaWJlLmpzJyldLFxuICAgIFsnU1RPUkUnLCByZXF1aXJlKCcuL2NvbW1hbmRzL3N0b3JlLmpzJyldLFxuICAgIFsnU0VBUkNIJywgcmVxdWlyZSgnLi9jb21tYW5kcy9zZWFyY2guanMnKV0sXG4gICAgWydOT09QJywgcmVxdWlyZSgnLi9jb21tYW5kcy9ub29wLmpzJyldLFxuICAgIFsnRVhQVU5HRScsIHJlcXVpcmUoJy4vY29tbWFuZHMvZXhwdW5nZS5qcycpXSxcbiAgICBbJ0FQUEVORCcsIHJlcXVpcmUoJy4vY29tbWFuZHMvYXBwZW5kLmpzJyldLFxuICAgIFsnU1RBVFVTJywgcmVxdWlyZSgnLi9jb21tYW5kcy9zdGF0dXMuanMnKV0sXG4gICAgWydDT1BZJywgcmVxdWlyZSgnLi9jb21tYW5kcy9jb3B5LmpzJyldLFxuICAgIFsnTU9WRScsIHJlcXVpcmUoJy4vY29tbWFuZHMvbW92ZS5qcycpXSxcbiAgICBbJ0NPTVBSRVNTJywgcmVxdWlyZSgnLi9jb21tYW5kcy9jb21wcmVzcy5qcycpXSxcbiAgICBbJ1FVT1RBJywgcmVxdWlyZSgnLi9jb21tYW5kcy9xdW90YS5qcycpXSxcbiAgICBbJ0lETEUnLCByZXF1aXJlKCcuL2NvbW1hbmRzL2lkbGUuanMnKV0sXG4gICAgWydBVVRIRU5USUNBVEUnLCByZXF1aXJlKCcuL2NvbW1hbmRzL2F1dGhlbnRpY2F0ZS5qcycpXVxuXSk7XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/imap-commands.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/imap-flow.js":
|
|
/*!************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/imap-flow.js ***!
|
|
\************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\n/**\n * @module imapflow\n */\n\n// TODO:\n// * Use buffers for compiled commands\n// * OAuth2 authentication\n\nconst tls = __webpack_require__(/*! tls */ \"tls\");\nconst net = __webpack_require__(/*! net */ \"net\");\nconst crypto = __webpack_require__(/*! crypto */ \"crypto\");\nconst { EventEmitter } = __webpack_require__(/*! events */ \"events\");\nconst logger = __webpack_require__(/*! ./logger */ \"(rsc)/./node_modules/imapflow/lib/logger.js\");\nconst libmime = __webpack_require__(/*! libmime */ \"(rsc)/./node_modules/libmime/lib/libmime.js\");\nconst zlib = __webpack_require__(/*! zlib */ \"zlib\");\nconst { Headers } = __webpack_require__(/*! mailsplit */ \"(rsc)/./node_modules/imapflow/node_modules/mailsplit/index.js\");\nconst { LimitedPassthrough } = __webpack_require__(/*! ./limited-passthrough */ \"(rsc)/./node_modules/imapflow/lib/limited-passthrough.js\");\n\nconst { ImapStream } = __webpack_require__(/*! ./handler/imap-stream */ \"(rsc)/./node_modules/imapflow/lib/handler/imap-stream.js\");\nconst { parser, compiler } = __webpack_require__(/*! ./handler/imap-handler */ \"(rsc)/./node_modules/imapflow/lib/handler/imap-handler.js\");\nconst packageInfo = __webpack_require__(/*! ../package.json */ \"(rsc)/./node_modules/imapflow/package.json\");\n\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 FlowedDecoder = __webpack_require__(/*! mailsplit/lib/flowed-decoder */ \"(rsc)/./node_modules/imapflow/node_modules/mailsplit/lib/flowed-decoder.js\");\nconst { PassThrough } = __webpack_require__(/*! stream */ \"stream\");\n\nconst { proxyConnection } = __webpack_require__(/*! ./proxy-connection */ \"(rsc)/./node_modules/imapflow/lib/proxy-connection.js\");\n\nconst {\n comparePaths,\n updateCapabilities,\n getFolderTree,\n formatMessageResponse,\n getDecoder,\n packMessageRange,\n normalizePath,\n expandRange,\n AuthenticationFailure,\n getColorFlags\n} = __webpack_require__(/*! ./tools */ \"(rsc)/./node_modules/imapflow/lib/tools.js\");\n\nconst imapCommands = __webpack_require__(/*! ./imap-commands.js */ \"(rsc)/./node_modules/imapflow/lib/imap-commands.js\");\n\nconst CONNECT_TIMEOUT = 90 * 1000;\nconst GREETING_TIMEOUT = 16 * 1000;\nconst UPGRADE_TIMEOUT = 10 * 1000;\n\nconst SOCKET_TIMEOUT = 5 * 60 * 1000;\n\nconst states = {\n NOT_AUTHENTICATED: 0x01,\n AUTHENTICATED: 0x02,\n SELECTED: 0x03,\n LOGOUT: 0x04\n};\n\n/**\n * @typedef {Object} MailboxObject\n * @global\n * @property {String} path mailbox path\n * @property {String} delimiter mailbox path delimiter, usually \".\" or \"/\"\n * @property {Set<string>} flags list of flags for this mailbox\n * @property {String} [specialUse] one of special-use flags (if applicable): \"\\All\", \"\\Archive\", \"\\Drafts\", \"\\Flagged\", \"\\Junk\", \"\\Sent\", \"\\Trash\". Additionally INBOX has non-standard \"\\Inbox\" flag set\n * @property {Boolean} listed `true` if mailbox was found from the output of LIST command\n * @property {Boolean} subscribed `true` if mailbox was found from the output of LSUB command\n * @property {Set<string>} permanentFlags A Set of flags available to use in this mailbox. If it is not set or includes special flag \"\\\\\\*\" then any flag can be used.\n * @property {String} [mailboxId] unique mailbox ID if server has `OBJECTID` extension enabled\n * @property {BigInt} [highestModseq] latest known modseq value if server has CONDSTORE or XYMHIGHESTMODSEQ enabled\n * @property {String} [noModseq] if true then the server doesn't support the persistent storage of mod-sequences for the mailbox\n * @property {BigInt} uidValidity Mailbox `UIDVALIDITY` value\n * @property {Number} uidNext Next predicted UID\n * @property {Number} exists Messages in this folder\n */\n\n/**\n * @typedef {Object} MailboxLockObject\n * @global\n * @property {String} path mailbox path\n * @property {Function} release Release current lock\n * @example\n * let lock = await client.getMailboxLock('INBOX');\n * try {\n * // do something in the mailbox\n * } finally {\n * // use finally{} to make sure lock is released even if exception occurs\n * lock.release();\n * }\n */\n\n/**\n * Client and server identification object, where key is one of RFC2971 defined [data fields](https://tools.ietf.org/html/rfc2971#section-3.3) (but not limited to).\n * @typedef {Object} IdInfoObject\n * @global\n * @property {String} [name] Name of the program\n * @property {String} [version] Version number of the program\n * @property {String} [os] Name of the operating system\n * @property {String} [vendor] Vendor of the client/server\n * @property {String} ['support-url'] URL to contact for support\n * @property {Date} [date] Date program was released\n */\n\n/**\n * IMAP client class for accessing IMAP mailboxes\n *\n * @class\n * @extends EventEmitter\n */\nclass ImapFlow extends EventEmitter {\n /**\n * Current module version as a static class property\n * @property {String} version Module version\n * @static\n */\n static version = packageInfo.version;\n\n /**\n * IMAP connection options\n *\n * @property {String} host\n * Hostname of the IMAP server.\n *\n * @property {Number} port\n * Port number for the IMAP server.\n *\n * @property {Boolean} [secure=false]\n * If `true`, establishes the connection directly over TLS (commonly on port 993).\n * If `false`, a plain (unencrypted) connection is used first and, if possible, the connection is upgraded to STARTTLS.\n *\n * @property {Boolean} [doSTARTTLS=undefined]\n * Determines whether to upgrade the connection to TLS via STARTTLS:\n * - **true**: Start unencrypted and upgrade to TLS using STARTTLS before authentication.\n * The connection fails if the server does not support STARTTLS or the upgrade fails.\n * Note that `secure=true` combined with `doSTARTTLS=true` is invalid.\n * - **false**: Never use STARTTLS, even if the server advertises support.\n * This is useful if the server has a broken TLS setup.\n * Combined with `secure=false`, this results in a fully unencrypted connection.\n * Make sure you warn users about the security risks.\n * - **undefined** (default): If `secure=false` (default), attempt to upgrade to TLS via STARTTLS before authentication if the server supports it. If not supported, continue unencrypted. This may expose the connection to a downgrade attack.\n *\n * @property {String} [servername]\n * Server name for SNI or when using an IP address as `host`.\n *\n * @property {Boolean} [disableCompression=false]\n * If `true`, the client does not attempt to use the COMPRESS=DEFLATE extension.\n *\n * @property {Object} auth\n * Authentication options. Authentication occurs automatically during {@link connect}.\n *\n * @property {String} auth.user\n * Username for authentication.\n *\n * @property {String} [auth.pass]\n * Password for regular authentication.\n *\n * @property {String} [auth.accessToken]\n * OAuth2 access token, if using OAuth2 authentication.\n *\n * @property {String} [auth.loginMethod]\n * Optional login method for password-based authentication (e.g., \"LOGIN\", \"AUTH=LOGIN\", or \"AUTH=PLAIN\").\n * If not set, ImapFlow chooses based on available mechanisms.\n *\n * @property {IdInfoObject} [clientInfo]\n * Client identification info sent to the server (via the ID command).\n *\n * @property {Boolean} [disableAutoIdle=false]\n * If `true`, do not start IDLE automatically. Useful when only specific operations are needed.\n *\n * @property {Object} [tls]\n * Additional TLS options. For details, see [Node.js TLS connect](https://nodejs.org/api/tls.html#tls_tls_connect_options_callback).\n *\n * @property {Boolean} [tls.rejectUnauthorized=true]\n * If `false`, allows self-signed or expired certificates.\n *\n * @property {String} [tls.minVersion='TLSv1.2']\n * Minimum accepted TLS version (e.g., `'TLSv1.2'`).\n *\n * @property {Number} [tls.minDHSize=1024]\n * Minimum size (in bits) of the DH parameter for TLS connections.\n *\n * @property {Object|Boolean} [logger]\n * Custom logger instance with `debug(obj)`, `info(obj)`, `warn(obj)`, and `error(obj)` methods.\n * If `false`, logging is disabled. If not provided, ImapFlow logs to console in [pino format](https://getpino.io/).\n *\n * @property {Boolean} [logRaw=false]\n * If `true`, logs all raw data (read and written) in base64 encoding. You can pipe such logs to [eerawlog](https://github.com/postalsys/eerawlog) command for readable output.\n *\n * @property {Boolean} [emitLogs=false]\n * If `true`, emits `'log'` events with the same data passed to the logger.\n *\n * @property {Boolean} [verifyOnly=false]\n * If `true`, disconnects after successful authentication without performing other actions.\n *\n * @property {String} [proxy]\n * Proxy URL. Supports HTTP CONNECT (`http://`, `https://`) and SOCKS (`socks://`, `socks4://`, `socks5://`).\n *\n * @property {Boolean} [qresync=false]\n * If `true`, enables QRESYNC support so that EXPUNGE notifications include `uid` instead of `seq`.\n *\n * @property {Number} [maxIdleTime]\n * If set, breaks and restarts IDLE every `maxIdleTime` milliseconds.\n *\n * @property {String} [missingIdleCommand=\"NOOP\"]\n * Command to use if the server does not support IDLE.\n *\n * @property {Boolean} [disableBinary=false]\n * If `true`, ignores the BINARY extension for FETCH and APPEND operations.\n *\n * @property {Boolean} [disableAutoEnable=false]\n * If `true`, do not automatically enable supported IMAP extensions.\n *\n * @property {Number} [connectionTimeout=90000]\n * Maximum time (in milliseconds) to wait for the connection to establish. Defaults to 90 seconds.\n *\n * @property {Number} [greetingTimeout=16000]\n * Maximum time (in milliseconds) to wait for the server greeting after a connection is established. Defaults to 16 seconds.\n *\n * @property {Number} [socketTimeout=300000]\n * Maximum period of inactivity (in milliseconds) before terminating the connection. Defaults to 5 minutes.\n */\n\n constructor(options) {\n super({ captureRejections: true });\n\n this.options = options || {};\n\n /**\n * Instance ID for logs\n * @type {String}\n */\n this.id = this.options.id || this.getRandomId();\n\n this.clientInfo = Object.assign(\n {\n name: packageInfo.name,\n version: packageInfo.version,\n vendor: 'Postal Systems',\n 'support-url': 'https://github.com/postalsys/imapflow/issues'\n },\n this.options.clientInfo || {}\n );\n\n /**\n * Server identification info. Available after successful `connect()`.\n * If server does not provide identification info then this value is `null`.\n * @example\n * await client.connect();\n * console.log(client.serverInfo.vendor);\n * @type {IdInfoObject|null}\n */\n this.serverInfo = null; //updated by ID\n\n this.log = this.getLogger();\n\n /**\n * Is the connection currently encrypted or not\n * @type {Boolean}\n */\n this.secureConnection = !!this.options.secure;\n\n this.port = Number(this.options.port) || (this.secureConnection ? 993 : 110);\n this.host = this.options.host || 'localhost';\n this.servername = this.options.servername ? this.options.servername : !net.isIP(this.host) ? this.host : false;\n\n if (typeof this.options.secure === 'undefined' && this.port === 993) {\n // if secure option is not set but port is 465, then default to secure\n this.secureConnection = true;\n }\n\n this.logRaw = this.options.logRaw;\n this.streamer = new ImapStream({\n logger: this.log,\n cid: this.id,\n logRaw: this.logRaw,\n secureConnection: this.secureConnection\n });\n\n this.reading = false;\n this.socket = false;\n this.writeSocket = false;\n\n this.states = states;\n this.state = this.states.NOT_AUTHENTICATED;\n\n this.lockCounter = 0;\n this.currentLock = false;\n\n this.tagCounter = 0;\n this.requestTagMap = new Map();\n this.requestQueue = [];\n this.currentRequest = false;\n\n this.writeBytesCounter = 0;\n\n this.commandParts = [];\n\n /**\n * Active IMAP capabilities. Value is either `true` for togglabe capabilities (eg. `UIDPLUS`)\n * or a number for capabilities with a value (eg. `APPENDLIMIT`)\n * @type {Map<string, boolean|number>}\n */\n this.capabilities = new Map();\n this.authCapabilities = new Map();\n\n this.rawCapabilities = null;\n\n this.expectCapabilityUpdate = false; // force CAPABILITY after LOGIN\n\n /**\n * Enabled capabilities. Usually `CONDSTORE` and `UTF8=ACCEPT` if server supports these.\n * @type {Set<string>}\n */\n this.enabled = new Set();\n\n /**\n * Is the connection currently usable or not\n * @type {Boolean}\n */\n this.usable = false;\n\n /**\n * Currently authenticated user or `false` if mailbox is not open\n * or `true` if connection was authenticated by PREAUTH\n * @type {String|Boolean}\n */\n this.authenticated = false;\n\n /**\n * Currently selected mailbox or `false` if mailbox is not open\n * @type {MailboxObject|Boolean}\n */\n this.mailbox = false;\n this.currentSelectCommand = false;\n\n /**\n * Is current mailbox idling (`true`) or not (`false`)\n * @type {Boolean}\n */\n this.idling = false;\n\n this.emitLogs = !!this.options.emitLogs;\n // ordering number for emitted logs\n this.lo = 0;\n\n this.untaggedHandlers = {};\n this.sectionHandlers = {};\n\n this.commands = imapCommands;\n\n this.folders = new Map();\n\n this.currentLock = false;\n this.locks = [];\n\n this.idRequested = false;\n\n this.maxIdleTime = this.options.maxIdleTime || false;\n this.missingIdleCommand = (this.options.missingIdleCommand || '').toString().toUpperCase().trim() || 'NOOP';\n\n this.disableBinary = !!this.options.disableBinary;\n\n this.streamer.on('error', err => {\n if (['Z_BUF_ERROR', 'ECONNRESET', 'EPIPE', 'ETIMEDOUT', 'EHOSTUNREACH'].includes(err.code)) {\n // just close the connection, usually nothing but noise\n return setImmediate(() => this.close());\n }\n\n this.log.error({ err, cid: this.id });\n setImmediate(() => this.close());\n this.emitError(err);\n });\n\n // Has the `connect` method already been called\n this._connectCalled = false;\n }\n\n emitError(err) {\n this.emit('error', err);\n }\n\n getRandomId() {\n let rid = BigInt('0x' + crypto.randomBytes(13).toString('hex')).toString(36);\n if (rid.length < 20) {\n rid = '0'.repeat(20 - rid.length) + rid;\n } else if (rid.length > 20) {\n rid = rid.substr(0, 20);\n }\n return rid;\n }\n\n write(chunk) {\n if (this.socket.destroyed) {\n // do not write after connection end or logout\n const error = new Error('Socket is already closed');\n error.code = 'NoConnection';\n throw error;\n }\n\n if (this.state === this.states.LOGOUT) {\n // should not happen\n const error = new Error('Can not send data after logged out');\n error.code = 'StateLogout';\n throw error;\n }\n\n if (this.writeSocket.destroyed) {\n this.socket.emit('error', 'Write socket destroyed');\n return;\n }\n\n let addLineBreak = !this.commandParts.length;\n if (typeof chunk === 'string') {\n if (addLineBreak) {\n chunk += '\\r\\n';\n }\n chunk = Buffer.from(chunk, 'binary');\n } else if (Buffer.isBuffer(chunk)) {\n if (addLineBreak) {\n chunk = Buffer.concat([chunk, Buffer.from('\\r\\n')]);\n }\n } else {\n return false;\n }\n\n if (this.logRaw) {\n this.log.trace({\n src: 'c',\n msg: 'write to socket',\n data: chunk.toString('base64'),\n compress: !!this._deflate,\n secure: !!this.secureConnection,\n cid: this.id\n });\n }\n\n this.writeBytesCounter += chunk.length;\n\n this.writeSocket.write(chunk);\n }\n\n stats(reset) {\n let result = {\n sent: this.writeBytesCounter || 0,\n received: (this.streamer && this.streamer.readBytesCounter) || 0\n };\n\n if (reset) {\n this.writeBytesCounter = 0;\n if (this.streamer) {\n this.streamer.readBytesCounter = 0;\n }\n }\n\n return result;\n }\n\n async send(data) {\n if (this.state === this.states.LOGOUT) {\n // already logged out\n if (data.tag) {\n let request = this.requestTagMap.get(data.tag);\n if (request) {\n this.requestTagMap.delete(request.tag);\n const error = new Error('Connection not available');\n error.code = 'NoConnection';\n request.reject(error);\n }\n }\n return;\n }\n\n let compiled = await compiler(data, {\n asArray: true,\n literalMinus: this.capabilities.has('LITERAL-') || this.capabilities.has('LITERAL+')\n });\n this.commandParts = compiled;\n\n let logCompiled = await compiler(data, {\n isLogging: true\n });\n\n let options = data.options || {};\n\n this.log.debug({ src: 's', msg: logCompiled.toString(), cid: this.id, comment: options.comment });\n\n this.write(this.commandParts.shift());\n\n if (typeof options.onSend === 'function') {\n options.onSend();\n }\n }\n\n async trySend() {\n if (this.currentRequest || !this.requestQueue.length) {\n return;\n }\n this.currentRequest = this.requestQueue.shift();\n\n await this.send({\n tag: this.currentRequest.tag,\n command: this.currentRequest.command,\n attributes: this.currentRequest.attributes,\n options: this.currentRequest.options\n });\n }\n\n async exec(command, attributes, options) {\n if (this.socket.destroyed) {\n let error = new Error('Connection closed');\n error.code = 'EConnectionClosed';\n throw error;\n }\n\n let tag = (++this.tagCounter).toString(16).toUpperCase();\n\n options = options || {};\n\n return new Promise((resolve, reject) => {\n this.requestTagMap.set(tag, { command, attributes, options, resolve, reject });\n this.requestQueue.push({ tag, command, attributes, options });\n this.trySend().catch(err => {\n this.requestTagMap.delete(tag);\n reject(err);\n });\n });\n }\n\n getUntaggedHandler(command, attributes) {\n if (/^[0-9]+$/.test(command)) {\n let type = attributes && attributes.length && typeof attributes[0].value === 'string' ? attributes[0].value.toUpperCase() : false;\n if (type) {\n // EXISTS, EXPUNGE, RECENT, FETCH etc\n command = type;\n }\n }\n\n command = command.toUpperCase().trim();\n if (this.currentRequest && this.currentRequest.options && this.currentRequest.options.untagged && this.currentRequest.options.untagged[command]) {\n return this.currentRequest.options.untagged[command];\n }\n\n if (this.untaggedHandlers[command]) {\n return this.untaggedHandlers[command];\n }\n }\n\n getSectionHandler(key) {\n if (this.sectionHandlers[key]) {\n return this.sectionHandlers[key];\n }\n }\n\n async reader() {\n let data;\n while ((data = this.streamer.read()) !== null) {\n let parsed;\n\n try {\n parsed = await parser(data.payload, { literals: data.literals });\n if (parsed.tag && !['*', '+'].includes(parsed.tag) && parsed.command) {\n let payload = { response: parsed.command };\n\n if (\n parsed.attributes &&\n parsed.attributes[0] &&\n parsed.attributes[0].section &&\n parsed.attributes[0].section[0] &&\n parsed.attributes[0].section[0].type === 'ATOM'\n ) {\n payload.code = parsed.attributes[0].section[0].value;\n }\n this.emit('response', payload);\n }\n } catch (err) {\n // can not make sense of this\n this.log.error({ src: 's', msg: data.payload.toString(), err, cid: this.id });\n data.next();\n continue;\n }\n\n let logCompiled = await compiler(parsed, {\n isLogging: true\n });\n\n if (/^\\d+$/.test(parsed.command) && parsed.attributes && parsed.attributes[0] && parsed.attributes[0].value === 'FETCH') {\n // too many FETCH responses, might want to filter these out\n this.log.trace({ src: 's', msg: logCompiled.toString(), cid: this.id, nullBytesRemoved: parsed.nullBytesRemoved });\n } else {\n this.log.debug({ src: 's', msg: logCompiled.toString(), cid: this.id, nullBytesRemoved: parsed.nullBytesRemoved });\n }\n\n if (parsed.tag === '+' && this.currentRequest && this.currentRequest.options && typeof this.currentRequest.options.onPlusTag === 'function') {\n await this.currentRequest.options.onPlusTag(parsed);\n data.next();\n continue;\n }\n\n if (parsed.tag === '+' && this.commandParts.length) {\n let content = this.commandParts.shift();\n this.write(content);\n this.log.debug({ src: 'c', msg: `(* ${content.length}B continuation *)`, cid: this.id });\n data.next();\n continue;\n }\n\n let section = parsed.attributes && parsed.attributes.length && parsed.attributes[0] && !parsed.attributes[0].value && parsed.attributes[0].section;\n if (section && section.length && section[0].type === 'ATOM' && typeof section[0].value === 'string') {\n let sectionHandler = this.getSectionHandler(section[0].value.toUpperCase().trim());\n if (sectionHandler) {\n await sectionHandler(section.slice(1));\n }\n }\n\n if (parsed.tag === '*' && parsed.command) {\n let untaggedHandler = this.getUntaggedHandler(parsed.command, parsed.attributes);\n if (untaggedHandler) {\n try {\n await untaggedHandler(parsed);\n } catch (err) {\n this.log.warn({ err, cid: this.id });\n data.next();\n continue;\n }\n }\n }\n\n if (this.requestTagMap.has(parsed.tag)) {\n let request = this.requestTagMap.get(parsed.tag);\n this.requestTagMap.delete(parsed.tag);\n\n if (this.currentRequest && this.currentRequest.tag === parsed.tag) {\n // send next pending command\n this.currentRequest = false;\n await this.trySend();\n }\n\n switch (parsed.command.toUpperCase()) {\n case 'OK':\n case 'BYE':\n await new Promise(resolve => request.resolve({ response: parsed, next: resolve }));\n break;\n\n case 'NO':\n case 'BAD': {\n let txt =\n parsed.attributes &&\n parsed.attributes\n .filter(val => val.type === 'TEXT')\n .map(val => val.value.trim())\n .join(' ');\n\n let err = new Error('Command failed');\n err.response = parsed;\n err.responseStatus = parsed.command.toUpperCase();\n\n try {\n err.executedCommand =\n parsed.tag +\n (\n await compiler(request, {\n isLogging: true\n })\n ).toString();\n } catch (err) {\n // ignore\n }\n\n if (txt) {\n err.responseText = txt;\n\n if (err.responseStatus === 'NO' && txt.includes('Some of the requested messages no longer exist')) {\n // Treat as successful response\n this.log.warn({ msg: 'Partial FETCH response', cid: this.id, err });\n await new Promise(resolve => request.resolve({ response: parsed, next: resolve }));\n break;\n }\n\n let throttleDelay = false;\n\n // MS365 throttling\n // tag BAD Request is throttled. Suggested Backoff Time: 92415 milliseconds\n if (/Request is throttled/i.test(txt) && /Backoff Time/i.test(txt)) {\n let throttlingMatch = txt.match(/Backoff Time[:=\\s]+(\\d+)/i);\n if (throttlingMatch && throttlingMatch[1] && !isNaN(throttlingMatch[1])) {\n throttleDelay = Number(throttlingMatch[1]);\n }\n }\n\n // Wait and return a throttling error\n if (throttleDelay) {\n err.code = 'ETHROTTLE';\n err.throttleReset = throttleDelay;\n\n let delayResponse = throttleDelay;\n if (delayResponse > 5 * 60 * 1000) {\n // max delay cap\n delayResponse = 5 * 60 * 1000;\n }\n\n this.log.warn({ msg: 'Throttling detected', cid: this.id, throttleDelay, delayResponse, err });\n await new Promise(r => setTimeout(r, delayResponse));\n }\n }\n\n request.reject(err);\n break;\n }\n\n default: {\n let err = new Error('Invalid server response');\n err.code = 'InvalidResponse';\n err.response = parsed;\n request.reject(err);\n break;\n }\n }\n }\n\n data.next();\n }\n }\n\n setEventHandlers() {\n this.socketReadable = () => {\n if (!this.reading) {\n this.reading = true;\n this.reader()\n .catch(err => this.log.error({ err, cid: this.id }))\n .finally(() => {\n this.reading = false;\n });\n }\n };\n\n this.streamer.on('readable', this.socketReadable);\n }\n\n setSocketHandlers() {\n this._socketError =\n this._socketError ||\n (err => {\n this.log.error({ err, cid: this.id });\n setImmediate(() => this.close());\n this.emitError(err);\n });\n this._socketClose =\n this._socketClose ||\n (() => {\n this.close();\n });\n this._socketEnd =\n this._socketEnd ||\n (() => {\n this.close();\n });\n\n this._socketTimeout =\n this._socketTimeout ||\n (() => {\n if (this.idling) {\n this.run('NOOP')\n .then(() => this.idle())\n .catch(this._socketError);\n } else {\n this.log.debug({ msg: 'Socket timeout', cid: this.id });\n this.close();\n }\n });\n\n this.socket.on('error', this._socketError);\n this.socket.on('close', this._socketClose);\n this.socket.on('end', this._socketEnd);\n this.socket.on('tlsClientError', this._socketError);\n this.socket.on('timeout', this._socketTimeout);\n\n this.writeSocket.on('error', this._socketError);\n }\n\n clearSocketHandlers() {\n if (this._socketError) {\n this.socket.removeListener('error', this._socketError);\n this.socket.removeListener('tlsClientError', this._socketError);\n }\n if (this._socketClose) {\n this.socket.removeListener('close', this._socketClose);\n }\n if (this._socketEnd) {\n this.socket.removeListener('end', this._socketEnd);\n }\n }\n\n async startSession() {\n await this.run('CAPABILITY');\n\n if (this.capabilities.has('ID')) {\n this.idRequested = await this.run('ID', this.clientInfo);\n }\n\n await this.upgradeToSTARTTLS();\n\n await this.authenticate();\n\n if (!this.idRequested && this.capabilities.has('ID')) {\n // re-request ID after LOGIN\n this.idRequested = await this.run('ID', this.clientInfo);\n }\n\n // Make sure we have namespace set. This should also throw if Exchange actually failed authentication\n let nsResponse = await this.run('NAMESPACE');\n if (nsResponse && nsResponse.error && nsResponse.status === 'BAD' && /User is authenticated but not connected/i.test(nsResponse.text)) {\n // Not a NAMESPACE failure but authentication failure, so report as\n this.authenticated = false;\n let err = new AuthenticationFailure('Authentication failed');\n err.response = nsResponse.text;\n throw err;\n }\n\n if (this.options.verifyOnly) {\n // List all folders and logout\n if (this.options.includeMailboxes) {\n this._mailboxList = await this.list();\n }\n return await this.logout();\n }\n\n // try to use compression (if supported)\n if (!this.options.disableCompression) {\n await this.compress();\n }\n\n if (!this.options.disableAutoEnable) {\n // enable extensions if possible\n await this.run('ENABLE', ['CONDSTORE', 'UTF8=ACCEPT'].concat(this.options.qresync ? 'QRESYNC' : []));\n }\n\n this.usable = true;\n }\n\n async compress() {\n if (!(await this.run('COMPRESS'))) {\n return; // was not able to negotiate compression\n }\n\n // create deflate/inflate streams\n this._deflate = zlib.createDeflateRaw({\n windowBits: 15\n });\n this._inflate = zlib.createInflateRaw();\n\n // route incoming socket via inflate stream\n this.socket.unpipe(this.streamer);\n this.streamer.compress = true;\n this.socket.pipe(this._inflate).pipe(this.streamer);\n this._inflate.on('error', err => {\n this.streamer.emit('error', err);\n });\n\n // route outgoing socket via deflate stream\n this.writeSocket = new PassThrough();\n\n this.writeSocket.destroySoon = () => {\n try {\n if (this.socket) {\n this.socket.destroy();\n }\n this.writeSocket.end();\n } catch (err) {\n this.log.error({ err, info: 'Failed to destroy PassThrough socket', cid: this.id });\n throw err;\n }\n };\n\n Object.defineProperty(this.writeSocket, 'destroyed', {\n get: () => this.socket.destroyed\n });\n\n // we need to force flush deflated data to socket so we can't\n // use normal pipes for this.writeSocket -> this._deflate -> this.socket\n let reading = false;\n let readNext = () => {\n reading = true;\n\n let chunk;\n while ((chunk = this.writeSocket.read()) !== null) {\n if (this._deflate && this._deflate.write(chunk) === false) {\n return this._deflate.once('drain', readNext);\n }\n }\n\n // flush data to socket\n if (this._deflate) {\n this._deflate.flush();\n }\n\n reading = false;\n };\n\n this.writeSocket.on('readable', () => {\n if (!reading) {\n readNext();\n }\n });\n this.writeSocket.on('error', err => {\n this.socket.emit('error', err);\n });\n\n this._deflate.pipe(this.socket);\n this._deflate.on('error', err => {\n this.socket.emit('error', err);\n });\n }\n\n _failSTARTTLS() {\n if (this.options.doSTARTTLS === true) {\n // STARTTLS configured as requirement\n let err = new Error('Server does not support STARTTLS');\n err.tlsFailed = true;\n throw err;\n } else {\n // Opportunistic STARTTLS. But it's not possible right now.\n // Attention: Could be a downgrade attack.\n return false;\n }\n }\n\n /**\n * Tries to upgrade the connection to TLS using STARTTLS.\n * @throws if STARTTLS is required, but not possible.\n * @returns {boolean} true, if the connection is now protected by TLS, either direct TLS or STARTTLS.\n */\n async upgradeToSTARTTLS() {\n if (this.options.doSTARTTLS === true && this.options.secure === true) {\n throw new Error('Misconfiguration: Cannot set both secure=true for TLS and doSTARTTLS=true for STARTTLS.');\n }\n\n if (this.secureConnection) {\n // Already using direct TLS. No need for STARTTLS.\n return true;\n }\n\n if (this.options.doSTARTTLS === false) {\n // STARTTLS explictly disabled by config\n return false;\n }\n\n if (!this.capabilities.has('STARTTLS')) {\n return this._failSTARTTLS();\n }\n\n this.expectCapabilityUpdate = true;\n let canUpgrade = await this.run('STARTTLS');\n if (!canUpgrade) {\n return this._failSTARTTLS();\n }\n\n this.socket.unpipe(this.streamer);\n let upgraded = await new Promise((resolve, reject) => {\n let socketPlain = this.socket;\n let opts = Object.assign(\n {\n socket: this.socket,\n servername: this.servername,\n port: this.port\n },\n this.options.tls || {}\n );\n this.clearSocketHandlers();\n\n socketPlain.once('error', err => {\n clearTimeout(this.connectTimeout);\n clearTimeout(this.upgradeTimeout);\n if (!this.upgrading) {\n // don't care anymore\n return;\n }\n setImmediate(() => this.close());\n this.upgrading = false;\n err.tlsFailed = true;\n reject(err);\n });\n\n this.upgradeTimeout = setTimeout(() => {\n if (!this.upgrading) {\n return;\n }\n setImmediate(() => this.close());\n let err = new Error('Failed to upgrade connection in required time');\n err.tlsFailed = true;\n err.code = 'UPGRADE_TIMEOUT';\n reject(err);\n }, UPGRADE_TIMEOUT);\n\n this.upgrading = true;\n this.socket = tls.connect(opts, () => {\n clearTimeout(this.upgradeTimeout);\n if (this.isClosed) {\n // not sure if this is possible?\n return this.close();\n }\n\n this.secureConnection = true;\n this.upgrading = false;\n this.streamer.secureConnection = true;\n this.socket.pipe(this.streamer);\n this.tls = typeof this.socket.getCipher === 'function' ? this.socket.getCipher() : false;\n if (this.tls) {\n this.tls.authorized = this.socket.authorized;\n this.log.info({\n src: 'tls',\n msg: 'Established TLS session',\n cid: this.id,\n authorized: this.tls.authorized,\n algo: this.tls.standardName || this.tls.name,\n version: this.tls.version\n });\n }\n\n return resolve(true);\n });\n\n this.writeSocket = this.socket;\n\n this.setSocketHandlers();\n });\n\n if (upgraded && this.expectCapabilityUpdate) {\n await this.run('CAPABILITY');\n }\n\n return upgraded;\n }\n\n async setAuthenticationState() {\n this.state = this.states.AUTHENTICATED;\n this.authenticated = true;\n if (this.expectCapabilityUpdate) {\n // update capabilities\n await this.run('CAPABILITY');\n }\n }\n\n async authenticate() {\n if (this.state === this.states.LOGOUT) {\n throw new AuthenticationFailure('Already logged out');\n }\n\n if (this.state !== this.states.NOT_AUTHENTICATED) {\n // nothing to do here, usually happens with PREAUTH greeting\n return true;\n }\n\n if (!this.options.auth) {\n throw new AuthenticationFailure('Please configure the login');\n }\n\n this.expectCapabilityUpdate = true;\n\n let loginMethod = (this.options.auth.loginMethod || '').toString().trim().toUpperCase();\n if (!loginMethod && /\\\\|\\//.test(this.options.auth.user)) {\n // Special override for MS Exchange when authenticating as some other user or non-email account\n loginMethod = 'LOGIN';\n }\n\n if (this.options.auth.accessToken) {\n this.authenticated = await this.run('AUTHENTICATE', this.options.auth.user, { accessToken: this.options.auth.accessToken });\n } else if (this.options.auth.pass) {\n if ((this.capabilities.has('AUTH=LOGIN') || this.capabilities.has('AUTH=PLAIN')) && loginMethod !== 'LOGIN') {\n this.authenticated = await this.run('AUTHENTICATE', this.options.auth.user, { password: this.options.auth.pass, loginMethod });\n } else {\n if (this.capabilities.has('LOGINDISABLED')) {\n throw new AuthenticationFailure('Login is disabled');\n }\n this.authenticated = await this.run('LOGIN', this.options.auth.user, this.options.auth.pass);\n }\n } else {\n throw new AuthenticationFailure('No password configured');\n }\n\n if (this.authenticated) {\n this.log.info({\n src: 'auth',\n msg: 'User authenticated',\n cid: this.id,\n user: this.options.auth.user\n });\n await this.setAuthenticationState();\n return true;\n }\n\n throw new AuthenticationFailure('No matching authentication method');\n }\n\n async initialOK(message) {\n this.greeting = (message.attributes || [])\n .filter(entry => entry.type === 'TEXT')\n .map(entry => entry.value)\n .filter(entry => entry)\n .join('');\n\n clearTimeout(this.greetingTimeout);\n this.untaggedHandlers.OK = null;\n this.untaggedHandlers.PREAUTH = null;\n\n if (this.isClosed) {\n return;\n }\n\n // get out of current parsing \"thread\", so do not await for startSession\n this.startSession()\n .then(() => {\n if (typeof this.initialResolve === 'function') {\n let resolve = this.initialResolve;\n this.initialResolve = false;\n this.initialReject = false;\n return resolve();\n }\n })\n .catch(err => {\n this.log.error({ err, cid: this.id });\n\n if (typeof this.initialReject === 'function') {\n clearTimeout(this.greetingTimeout);\n let reject = this.initialReject;\n this.initialResolve = false;\n this.initialReject = false;\n return reject(err);\n }\n\n setImmediate(() => this.close());\n });\n }\n\n async initialPREAUTH() {\n clearTimeout(this.greetingTimeout);\n this.untaggedHandlers.OK = null;\n this.untaggedHandlers.PREAUTH = null;\n\n if (this.isClosed) {\n return;\n }\n\n this.state = this.states.AUTHENTICATED;\n\n // get out of current parsing \"thread\", so do not await for startSession\n this.startSession()\n .then(() => {\n if (typeof this.initialResolve === 'function') {\n let resolve = this.initialResolve;\n this.initialResolve = false;\n this.initialReject = false;\n return resolve();\n }\n })\n .catch(err => {\n this.log.error({ err, cid: this.id });\n\n if (typeof this.initialReject === 'function') {\n clearTimeout(this.greetingTimeout);\n let reject = this.initialReject;\n this.initialResolve = false;\n this.initialReject = false;\n return reject(err);\n }\n\n setImmediate(() => this.close());\n });\n }\n\n async serverBye() {\n this.untaggedHandlers.BYE = null;\n this.state = this.states.LOGOUT;\n }\n\n async sectionCapability(section) {\n this.rawCapabilities = section;\n this.capabilities = updateCapabilities(section);\n\n if (this.capabilities) {\n for (let [capa] of this.capabilities) {\n if (/^AUTH=/i.test(capa) && !this.authCapabilities.has(capa.toUpperCase())) {\n this.authCapabilities.set(capa.toUpperCase(), false);\n }\n }\n }\n\n if (this.expectCapabilityUpdate) {\n this.expectCapabilityUpdate = false;\n }\n }\n\n async untaggedCapability(untagged) {\n this.rawCapabilities = untagged.attributes;\n this.capabilities = updateCapabilities(untagged.attributes);\n\n if (this.capabilities) {\n for (let [capa] of this.capabilities) {\n if (/^AUTH=/i.test(capa) && !this.authCapabilities.has(capa.toUpperCase())) {\n this.authCapabilities.set(capa.toUpperCase(), false);\n }\n }\n }\n\n if (this.expectCapabilityUpdate) {\n this.expectCapabilityUpdate = false;\n }\n }\n\n async untaggedExists(untagged) {\n if (!this.mailbox) {\n // mailbox closed, ignore\n return;\n }\n\n if (!untagged || !untagged.command || isNaN(untagged.command)) {\n return;\n }\n\n let count = Number(untagged.command);\n if (count === this.mailbox.exists) {\n // nothing changed?\n return;\n }\n\n // keep exists up to date\n let prevCount = this.mailbox.exists;\n this.mailbox.exists = count;\n this.emit('exists', {\n path: this.mailbox.path,\n count,\n prevCount\n });\n }\n\n async untaggedExpunge(untagged) {\n if (!this.mailbox) {\n // mailbox closed, ignore\n return;\n }\n\n if (!untagged || !untagged.command || isNaN(untagged.command)) {\n return;\n }\n\n let seq = Number(untagged.command);\n if (seq && seq <= this.mailbox.exists) {\n this.mailbox.exists--;\n let payload = {\n path: this.mailbox.path,\n seq,\n vanished: false\n };\n\n if (typeof this.options.expungeHandler === 'function') {\n try {\n await this.options.expungeHandler(payload);\n } catch (err) {\n this.log.error({ msg: 'Failed to notify expunge event', payload, error: err, cid: this.id });\n }\n } else {\n this.emit('expunge', payload);\n }\n }\n }\n\n async untaggedVanished(untagged, mailbox) {\n mailbox = mailbox || this.mailbox;\n if (!mailbox) {\n // mailbox closed, ignore\n return;\n }\n\n let tags = [];\n let uids = false;\n\n if (untagged.attributes.length > 1 && Array.isArray(untagged.attributes[0])) {\n tags = untagged.attributes[0].map(entry => (typeof entry.value === 'string' ? entry.value.toUpperCase() : false)).filter(value => value);\n untagged.attributes.shift();\n }\n\n if (untagged.attributes[0] && typeof untagged.attributes[0].value === 'string') {\n uids = untagged.attributes[0].value;\n }\n\n let uidList = expandRange(uids);\n\n for (let uid of uidList) {\n let payload = {\n path: mailbox.path,\n uid,\n vanished: true,\n earlier: tags.includes('EARLIER')\n };\n\n if (typeof this.options.expungeHandler === 'function') {\n try {\n await this.options.expungeHandler(payload);\n } catch (err) {\n this.log.error({ msg: 'Failed to notify expunge event', payload, error: err, cid: this.id });\n }\n } else {\n this.emit('expunge', payload);\n }\n }\n }\n\n async untaggedFetch(untagged, mailbox) {\n mailbox = mailbox || this.mailbox;\n if (!mailbox) {\n // mailbox closed, ignore\n return;\n }\n\n let message = await formatMessageResponse(untagged, mailbox);\n if (message.flags) {\n let updateEvent = {\n path: mailbox.path,\n seq: message.seq\n };\n\n if (message.uid) {\n updateEvent.uid = message.uid;\n }\n\n if (message.modseq) {\n updateEvent.modseq = message.modseq;\n }\n\n updateEvent.flags = message.flags;\n\n if (message.flagColor) {\n updateEvent.flagColor = message.flagColor;\n }\n\n this.emit('flags', updateEvent);\n }\n }\n\n async ensureSelectedMailbox(path) {\n if (!path) {\n return false;\n }\n\n if ((!this.mailbox && path) || (this.mailbox && path && !comparePaths(this, this.mailbox.path, path))) {\n return await this.mailboxOpen(path);\n }\n\n return true;\n }\n\n async resolveRange(range, options) {\n if (typeof range === 'number' || typeof range === 'bigint') {\n range = range.toString();\n }\n\n // special case, some servers allow this, some do not, so replace it with the last known EXISTS value\n if (range === '*') {\n if (!this.mailbox.exists) {\n return false;\n }\n range = this.mailbox.exists.toString();\n options.uid = false; // sequence query\n }\n\n if (range && typeof range === 'object' && !Array.isArray(range)) {\n if (range.all && Object.keys(range).length === 1) {\n range = '1:*';\n } else if (range.uid && Object.keys(range).length === 1) {\n range = range.uid;\n options.uid = true;\n } else {\n // resolve range by searching\n options.uid = true; // force UIDs instead of sequence numbers\n range = await this.run('SEARCH', range, options);\n if (range && range.length) {\n range = packMessageRange(range);\n }\n }\n }\n\n if (Array.isArray(range)) {\n range = range.join(',');\n }\n\n if (!range) {\n return false;\n }\n\n return range;\n }\n\n autoidle() {\n clearTimeout(this.idleStartTimer);\n if (this.options.disableAutoIdle || this.state !== this.states.SELECTED) {\n return;\n }\n this.idleStartTimer = setTimeout(() => {\n this.idle().catch(err => this.log.warn({ err, cid: this.id }));\n }, 15 * 1000);\n }\n\n // PUBLIC API METHODS\n\n /**\n * Initiates a connection against IMAP server. Throws if anything goes wrong. This is something you have to call before you can run any IMAP commands\n *\n * @returns {Promise<void>}\n * @throws Will throw an error if connection or authentication fails\n * @example\n * let client = new ImapFlow({...});\n * await client.connect();\n */\n async connect() {\n if (this._connectCalled) {\n // Prevent re-using ImapFlow instances by allowing to call connect just once.\n throw new Error('Can not re-use ImapFlow instance');\n }\n this._connectCalled = true;\n\n let connector = this.secureConnection ? tls : net;\n\n let opts = Object.assign(\n {\n host: this.host,\n servername: this.servername,\n port: this.port\n },\n this.options.tls || {}\n );\n\n this.untaggedHandlers.OK = (...args) => this.initialOK(...args);\n this.untaggedHandlers.BYE = (...args) => this.serverBye(...args);\n this.untaggedHandlers.PREAUTH = (...args) => this.initialPREAUTH(...args);\n\n this.untaggedHandlers.CAPABILITY = (...args) => this.untaggedCapability(...args);\n this.sectionHandlers.CAPABILITY = (...args) => this.sectionCapability(...args);\n\n this.untaggedHandlers.EXISTS = (...args) => this.untaggedExists(...args);\n this.untaggedHandlers.EXPUNGE = (...args) => this.untaggedExpunge(...args);\n\n // these methods take an optional second argument, so make sure that some random IMAP tag is not used as the second argument\n this.untaggedHandlers.FETCH = untagged => this.untaggedFetch(untagged);\n this.untaggedHandlers.VANISHED = untagged => this.untaggedVanished(untagged);\n\n let socket = false;\n if (this.options.proxy) {\n try {\n socket = await proxyConnection(this.log, this.options.proxy, this.host, this.port);\n if (!socket) {\n throw new Error('Failed to setup proxy connection');\n }\n } catch (err) {\n let error = new Error('Failed to setup proxy connection');\n error.code = err.code || 'ProxyError';\n error._err = err;\n this.log.error({ error, cid: this.id });\n throw error;\n }\n }\n\n await new Promise((resolve, reject) => {\n this.connectTimeout = setTimeout(() => {\n let err = new Error('Failed to establish connection in required time');\n err.code = 'CONNECT_TIMEOUT';\n err.details = {\n connectionTimeout: this.options.connectionTimeout || CONNECT_TIMEOUT\n };\n this.log.error({ err, cid: this.id });\n setImmediate(() => this.close());\n reject(err);\n }, this.options.connectionTimeout || CONNECT_TIMEOUT);\n\n let onConnect = () => {\n clearTimeout(this.connectTimeout);\n this.socket.setKeepAlive(true, 5 * 1000);\n this.socket.setTimeout(this.options.socketTimeout || SOCKET_TIMEOUT);\n\n this.greetingTimeout = setTimeout(() => {\n let err = new Error(`Failed to receive greeting from server in required time${!this.secureConnection ? '. Maybe should use TLS?' : ''}`);\n err.code = 'GREETING_TIMEOUT';\n err.details = {\n greetingTimeout: this.options.greetingTimeout || GREETING_TIMEOUT\n };\n this.log.error({ err, cid: this.id });\n setImmediate(() => this.close());\n reject(err);\n }, this.options.greetingTimeout || GREETING_TIMEOUT);\n\n this.tls = typeof this.socket.getCipher === 'function' ? this.socket.getCipher() : false;\n\n let logInfo = {\n src: 'connection',\n msg: `Established ${this.tls ? 'secure ' : ''}TCP connection`,\n cid: this.id,\n secure: !!this.tls,\n host: this.host,\n servername: this.servername,\n port: this.socket.remotePort,\n address: this.socket.remoteAddress,\n localAddress: this.socket.localAddress,\n localPort: this.socket.localPort\n };\n\n if (this.tls) {\n logInfo.authorized = this.tls.authorized = this.socket.authorized;\n logInfo.algo = this.tls.standardName || this.tls.name;\n logInfo.version = this.tls.version;\n }\n\n this.log.info(logInfo);\n\n this.setSocketHandlers();\n this.socket.pipe(this.streamer);\n\n // executed by initial \"* OK\"\n this.initialResolve = resolve;\n this.initialReject = reject;\n };\n\n if (socket) {\n // socket is already established via proxy\n if (this.secureConnection) {\n // TLS socket requires a handshake\n opts.socket = socket;\n this.socket = connector.connect(opts, onConnect);\n } else {\n // cleartext socket is already usable\n this.socket = socket;\n setImmediate(onConnect);\n }\n } else {\n this.socket = connector.connect(opts, onConnect);\n }\n\n this.writeSocket = this.socket;\n\n this.socket.on('error', err => {\n clearTimeout(this.connectTimeout);\n clearTimeout(this.greetingTimeout);\n setImmediate(() => this.close());\n this.log.error({ err, cid: this.id });\n reject(err);\n });\n\n this.setEventHandlers();\n });\n }\n\n /**\n * Graceful connection close by sending logout command to server. TCP connection is closed once command is finished.\n *\n * @return {Promise<void>}\n * @example\n * let client = new ImapFlow({...});\n * await client.connect();\n * ...\n * await client.logout();\n */\n async logout() {\n return await this.run('LOGOUT');\n }\n\n /**\n * Closes TCP connection without notifying the server.\n *\n * @example\n * let client = new ImapFlow({...});\n * await client.connect();\n * ...\n * client.close();\n */\n close() {\n // clear pending timers\n clearTimeout(this.idleStartTimer);\n clearTimeout(this.upgradeTimeout);\n clearTimeout(this.connectTimeout);\n\n this.usable = false;\n this.idling = false;\n\n if (typeof this.initialReject === 'function' && !this.options.verifyOnly) {\n clearTimeout(this.greetingTimeout);\n let reject = this.initialReject;\n this.initialResolve = false;\n this.initialReject = false;\n let err = new Error('Unexpected close');\n err.code = `ClosedAfterConnect${this.secureConnection ? 'TLS' : 'Text'}`;\n // still has to go through the logic below\n setImmediate(() => reject(err));\n }\n\n if (typeof this.preCheck === 'function') {\n this.preCheck().catch(err => this.log.warn({ err, cid: this.id }));\n }\n\n // reject command that is currently processed\n if (this.currentRequest && this.requestTagMap.has(this.currentRequest.tag)) {\n let request = this.requestTagMap.get(this.currentRequest.tag);\n if (request) {\n this.requestTagMap.delete(request.tag);\n const error = new Error('Connection not available');\n error.code = 'NoConnection';\n request.reject(error);\n }\n this.currentRequest = false;\n }\n\n // reject all other pending commands\n while (this.requestQueue.length) {\n let req = this.requestQueue.shift();\n if (req && this.requestTagMap.has(req.tag)) {\n let request = this.requestTagMap.get(req.tag);\n if (request) {\n this.requestTagMap.delete(request.tag);\n const error = new Error('Connection not available');\n error.code = 'NoConnection';\n request.reject(error);\n }\n }\n }\n\n this.state = this.states.LOGOUT;\n if (this.isClosed) {\n return;\n }\n this.isClosed = true;\n\n if (this.writeSocket && !this.writeSocket.destroyed) {\n try {\n this.writeSocket.destroy();\n } catch (err) {\n this.log.error({ err, cid: this.id });\n }\n }\n\n if (this.socket && !this.socket.destroyed && this.writeSocket !== this.socket) {\n try {\n this.socket.destroy();\n } catch (err) {\n this.log.error({ err, cid: this.id });\n }\n }\n\n this.log.trace({ msg: 'Connection closed', cid: this.id });\n this.emit('close');\n }\n\n /**\n * @typedef {Object} QuotaResponse\n * @global\n * @property {String} path=INBOX mailbox path this quota applies to\n * @property {Object} [storage] Storage quota if provided by server\n * @property {Number} [storage.used] used storage in bytes\n * @property {Number} [storage.limit] total storage available\n * @property {Object} [messages] Message count quota if provided by server\n * @property {Number} [messages.used] stored messages\n * @property {Number} [messages.limit] maximum messages allowed\n */\n\n /**\n * Returns current quota\n *\n * @param {String} [path] Optional mailbox path if you want to check quota for specific folder\n * @returns {Promise<QuotaResponse|Boolean>} Quota information or `false` if QUTOA extension is not supported or requested path does not exist\n *\n * @example\n * let quota = await client.getQuota();\n * console.log(quota.storage.used, quota.storage.available)\n */\n async getQuota(path) {\n path = path || 'INBOX';\n return await this.run('QUOTA', path);\n }\n\n /**\n * @typedef {Object} ListResponse\n * @global\n * @property {String} path mailbox path (unicode string)\n * @property {String} pathAsListed mailbox path as listed in the LIST/LSUB response\n * @property {String} name mailbox name (last part of path after delimiter)\n * @property {String} delimiter mailbox path delimiter, usually \".\" or \"/\"\n * @property {String[]} parent An array of parent folder names. All names are in unicode\n * @property {String} parentPath Same as `parent`, but as a complete string path (unicode string)\n * @property {Set<string>} flags a set of flags for this mailbox\n * @property {String} specialUse one of special-use flags (if applicable): \"\\All\", \"\\Archive\", \"\\Drafts\", \"\\Flagged\", \"\\Junk\", \"\\Sent\", \"\\Trash\". Additionally INBOX has non-standard \"\\Inbox\" flag set\n * @property {Boolean} listed `true` if mailbox was found from the output of LIST command\n * @property {Boolean} subscribed `true` if mailbox was found from the output of LSUB command\n * @property {StatusObject} [status] If `statusQuery` was used, then this value includes the status response\n */\n\n /**\n * @typedef {Object} ListOptions\n * @global\n * @property {Object} [statusQuery] request status items for every listed entry\n * @property {Boolean} [statusQuery.messages] if `true` request count of messages\n * @property {Boolean} [statusQuery.recent] if `true` request count of messages with \\\\Recent tag\n * @property {Boolean} [statusQuery.uidNext] if `true` request predicted next UID\n * @property {Boolean} [statusQuery.uidValidity] if `true` request mailbox `UIDVALIDITY` value\n * @property {Boolean} [statusQuery.unseen] if `true` request count of unseen messages\n * @property {Boolean} [statusQuery.highestModseq] if `true` request last known modseq value\n * @property {Object} [specialUseHints] set specific paths as special use folders, this would override special use flags provided from the server\n * @property {String} [specialUseHints.sent] Path to \"Sent Mail\" folder\n * @property {String} [specialUseHints.trash] Path to \"Trash\" folder\n * @property {String} [specialUseHints.junk] Path to \"Junk Mail\" folder\n * @property {String} [specialUseHints.drafts] Path to \"Drafts\" folder\n */\n\n /**\n * Lists available mailboxes as an Array\n *\n * @param {ListOptions} [options] defines additional listing options\n * @returns {Promise<ListResponse[]>} An array of ListResponse objects\n *\n * @example\n * let list = await client.list();\n * list.forEach(mailbox=>console.log(mailbox.path));\n */\n async list(options) {\n options = options || {};\n let folders = await this.run('LIST', '', '*', options);\n this.folders = new Map(folders.map(folder => [folder.path, folder]));\n return folders;\n }\n\n /**\n * @typedef {Object} ListTreeResponse\n * @global\n * @property {Boolean} root If `true` then this is root node without any additional properties besides *folders*\n * @property {String} path mailbox path\n * @property {String} name mailbox name (last part of path after delimiter)\n * @property {String} delimiter mailbox path delimiter, usually \".\" or \"/\"\n * @property {String[]} flags list of flags for this mailbox\n * @property {String} specialUse one of special-use flags (if applicable): \"\\All\", \"\\Archive\", \"\\Drafts\", \"\\Flagged\", \"\\Junk\", \"\\Sent\", \"\\Trash\". Additionally INBOX has non-standard \"\\Inbox\" flag set\n * @property {Boolean} listed `true` if mailbox was found from the output of LIST command\n * @property {Boolean} subscribed `true` if mailbox was found from the output of LSUB command\n * @property {Boolean} disabled If `true` then this mailbox can not be selected in the UI\n * @property {ListTreeResponse[]} folders An array of subfolders\n */\n\n /**\n * Lists available mailboxes as a tree structured object\n *\n * @param {ListOptions} [options] defines additional listing options\n * @returns {Promise<ListTreeResponse>} Tree structured object\n *\n * @example\n * let tree = await client.listTree();\n * tree.folders.forEach(mailbox=>console.log(mailbox.path));\n */\n async listTree(options) {\n options = options || {};\n let folders = await this.run('LIST', '', '*', options);\n this.folders = new Map(folders.map(folder => [folder.path, folder]));\n return getFolderTree(folders);\n }\n\n /**\n * Performs a no-op call against server\n * @returns {Promise<void>}\n */\n async noop() {\n await this.run('NOOP');\n }\n\n /**\n * @typedef {Object} MailboxCreateResponse\n * @global\n * @property {String} path full mailbox path\n * @property {String} [mailboxId] unique mailbox ID if server supports `OBJECTID` extension (currently Yahoo and some others)\n * @property {Boolean} created If `true` then mailbox was created otherwise it already existed\n */\n\n /**\n * Creates a new mailbox folder and sets up subscription for the created mailbox. Throws on error.\n *\n * @param {string|array} path Full mailbox path. Unicode is allowed. If value is an array then it is joined using current delimiter symbols. Namespace prefix is added automatically if required.\n * @returns {Promise<MailboxCreateResponse>} Mailbox info\n * @throws Will throw an error if mailbox can not be created\n *\n * @example\n * let info = await client.mailboxCreate(['parent', 'child']);\n * console.log(info.path);\n * // \"INBOX.parent.child\" // assumes \"INBOX.\" as namespace prefix and \".\" as delimiter\n */\n async mailboxCreate(path) {\n return await this.run('CREATE', path);\n }\n\n /**\n * @typedef {Object} MailboxRenameResponse\n * @global\n * @property {String} path full mailbox path that was renamed\n * @property {String} newPath new full mailbox path\n */\n\n /**\n * Renames a mailbox. Throws on error.\n *\n * @param {string|array} path Path for the mailbox to rename. Unicode is allowed. If value is an array then it is joined using current delimiter symbols. Namespace prefix is added automatically if required.\n * @param {string|array} newPath New path for the mailbox\n * @returns {Promise<MailboxRenameResponse>} Mailbox info\n * @throws Will throw an error if mailbox does not exist or can not be renamed\n *\n * @example\n * let info = await client.mailboxRename('parent.child', 'Important stuff ❗️');\n * console.log(info.newPath);\n * // \"INBOX.Important stuff ❗️\" // assumes \"INBOX.\" as namespace prefix\n */\n async mailboxRename(path, newPath) {\n return await this.run('RENAME', path, newPath);\n }\n\n /**\n * @typedef {Object} MailboxDeleteResponse\n * @global\n * @property {String} path full mailbox path that was deleted\n */\n\n /**\n * Deletes a mailbox. Throws on error.\n *\n * @param {string|array} path Path for the mailbox to delete. Unicode is allowed. If value is an array then it is joined using current delimiter symbols. Namespace prefix is added automatically if required.\n * @returns {Promise<MailboxDeleteResponse>} Mailbox info\n * @throws Will throw an error if mailbox does not exist or can not be deleted\n *\n * @example\n * let info = await client.mailboxDelete('Important stuff ❗️');\n * console.log(info.path);\n * // \"INBOX.Important stuff ❗️\" // assumes \"INBOX.\" as namespace prefix\n */\n async mailboxDelete(path) {\n return await this.run('DELETE', path);\n }\n\n /**\n * Subscribes to a mailbox\n *\n * @param {string|array} path Path for the mailbox to subscribe to. Unicode is allowed. If value is an array then it is joined using current delimiter symbols. Namespace prefix is added automatically if required.\n * @returns {Promise<Boolean>} `true` if subscription operation succeeded, `false` otherwise\n *\n * @example\n * await client.mailboxSubscribe('Important stuff ❗️');\n */\n async mailboxSubscribe(path) {\n return await this.run('SUBSCRIBE', path);\n }\n\n /**\n * Unsubscribes from a mailbox\n *\n * @param {string|array} path **Path for the mailbox** to unsubscribe from. Unicode is allowed. If value is an array then it is joined using current delimiter symbols. Namespace prefix is added automatically if required.\n * @returns {Promise<Boolean>} `true` if unsubscription operation succeeded, `false` otherwise\n *\n * @example\n * await client.mailboxUnsubscribe('Important stuff ❗️');\n */\n async mailboxUnsubscribe(path) {\n return await this.run('UNSUBSCRIBE', path);\n }\n\n /**\n * Opens a mailbox to access messages. You can perform message operations only against an opened mailbox.\n * Using {@link module:imapflow~ImapFlow#getMailboxLock|getMailboxLock()} instead of `mailboxOpen()` is preferred. Both do the same thing\n * but next `getMailboxLock()` call is not executed until previous one is released.\n *\n * @param {string|array} path **Path for the mailbox** to open\n * @param {Object} [options] optional options\n * @param {Boolean} [options.readOnly=false] If `true` then opens mailbox in read-only mode. You can still try to perform write operations but these would probably fail.\n * @returns {Promise<MailboxObject>} Mailbox info\n * @throws Will throw an error if mailbox does not exist or can not be opened\n *\n * @example\n * let mailbox = await client.mailboxOpen('Important stuff ❗️');\n * console.log(mailbox.exists);\n * // 125\n */\n async mailboxOpen(path, options) {\n return await this.run('SELECT', path, options);\n }\n\n /**\n * Closes a previously opened mailbox\n *\n * @returns {Promise<Boolean>} Did the operation succeed or not\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * await client.mailboxClose();\n */\n async mailboxClose() {\n return await this.run('CLOSE');\n }\n\n /**\n * @typedef {Object} StatusObject\n * @global\n * @property {String} path full mailbox path that was checked\n * @property {Number} [messages] Count of messages\n * @property {Number} [recent] Count of messages with \\\\Recent tag\n * @property {Number} [uidNext] Predicted next UID\n * @property {BigInt} [uidValidity] Mailbox `UIDVALIDITY` value\n * @property {Number} [unseen] Count of unseen messages\n * @property {BigInt} [highestModseq] Last known modseq value (if CONDSTORE extension is enabled)\n */\n\n /**\n * Requests the status of the indicated mailbox. Only requested status values will be returned.\n *\n * @param {String} path mailbox path to check for (unicode string)\n * @param {Object} query defines requested status items\n * @param {Boolean} query.messages if `true` request count of messages\n * @param {Boolean} query.recent if `true` request count of messages with \\\\Recent tag\n * @param {Boolean} query.uidNext if `true` request predicted next UID\n * @param {Boolean} query.uidValidity if `true` request mailbox `UIDVALIDITY` value\n * @param {Boolean} query.unseen if `true` request count of unseen messages\n * @param {Boolean} query.highestModseq if `true` request last known modseq value\n * @returns {Promise<StatusObject>} status of the indicated mailbox\n *\n * @example\n * let status = await client.status('INBOX', {unseen: true});\n * console.log(status.unseen);\n * // 123\n */\n async status(path, query) {\n return await this.run('STATUS', path, query);\n }\n\n /**\n * Starts listening for new or deleted messages from the currently opened mailbox. Only required if {@link ImapFlow#disableAutoIdle} is set to `true`\n * otherwise IDLE is started by default on connection inactivity. NB! If `idle()` is called manually then it does not\n * return until IDLE is finished which means you would have to call some other command out of scope.\n *\n * @returns {Promise<Boolean>} Did the operation succeed or not\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n *\n * await client.idle();\n */\n async idle() {\n if (!this.idling) {\n return await this.run('IDLE', this.maxIdleTime);\n }\n }\n\n /**\n * Sequence range string. Separate different values with commas, number ranges with colons and use \\\\* as the placeholder for the newest message in mailbox\n * @typedef {String} SequenceString\n * @global\n * @example\n * \"1:*\" // for all messages\n * \"1,2,3\" // for messages 1, 2 and 3\n * \"1,2,4:6\" // for messages 1,2,4,5,6\n * \"*\" // for the newest message\n */\n\n /**\n * IMAP search query options. By default all conditions must match. In case of `or` query term at least one condition must match.\n * @typedef {Object} SearchObject\n * @global\n * @property {SequenceString} [seq] message ordering sequence range\n * @property {Boolean} [answered] Messages with (value is `true`) or without (value is `false`) \\\\Answered flag\n * @property {Boolean} [deleted] Messages with (value is `true`) or without (value is `false`) \\\\Deleted flag\n * @property {Boolean} [draft] Messages with (value is `true`) or without (value is `false`) \\\\Draft flag\n * @property {Boolean} [flagged] Messages with (value is `true`) or without (value is `false`) \\\\Flagged flag\n * @property {Boolean} [seen] Messages with (value is `true`) or without (value is `false`) \\\\Seen flag\n * @property {Boolean} [all] If `true` matches all messages\n * @property {Boolean} [new] If `true` matches messages that have the \\\\Recent flag set but not the \\\\Seen flag\n * @property {Boolean} [old] If `true` matches messages that do not have the \\\\Recent flag set\n * @property {Boolean} [recent] If `true` matches messages that have the \\\\Recent flag set\n * @property {String} [from] Matches From: address field\n * @property {String} [to] Matches To: address field\n * @property {String} [cc] Matches Cc: address field\n * @property {String} [bcc] Matches Bcc: address field\n * @property {String} [body] Matches message body\n * @property {String} [subject] Matches message subject\n * @property {Number} [larger] Matches messages larger than value\n * @property {Number} [smaller] Matches messages smaller than value\n * @property {SequenceString} [uid] UID sequence range\n * @property {BigInt} [modseq] Matches messages with modseq higher than value\n * @property {String} [emailId] unique email ID. Only used if server supports `OBJECTID` or `X-GM-EXT-1` extensions\n * @property {String} [threadId] unique thread ID. Only used if server supports `OBJECTID` or `X-GM-EXT-1` extensions\n * @property {Date|string} [before] Matches messages received before date\n * @property {Date|string} [on] Matches messages received on date (ignores time)\n * @property {Date|string} [since] Matches messages received after date\n * @property {Date|string} [sentBefore] Matches messages sent before date\n * @property {Date|string} [sentOn] Matches messages sent on date (ignores time)\n * @property {Date|string} [sentSince] Matches messages sent after date\n * @property {String} [keyword] Matches messages that have the custom flag set\n * @property {String} [unKeyword] Matches messages that do not have the custom flag set\n * @property {Object.<string, Boolean|String>} [header] Matches messages with header key set if value is `true` (**NB!** not supported by all servers) or messages where header partially matches a string value\n * @property {SearchObject[]} [or] An array of 2 or more {@link SearchObject} objects. At least on of these must match\n */\n\n /**\n * Sets flags for a message or message range\n *\n * @param {SequenceString | Number[] | SearchObject} range Range to filter the messages\n * @param {string[]} Array of flags to set. Only flags that are permitted to set are used, other flags are ignored\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n * @param {BigInt} [options.unchangedSince] If set then only messages with a lower or equal `modseq` value are updated. Ignored if server does not support `CONDSTORE` extension.\n * @param {Boolean} [options.useLabels=false] If true then update Gmail labels instead of message flags\n * @returns {Promise<Boolean>} Did the operation succeed or not\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // mark all unseen messages as seen (and remove other flags)\n * await client.messageFlagsSet({seen: false}, ['\\Seen]);\n */\n async messageFlagsSet(range, flags, options) {\n options = options || {};\n\n range = await this.resolveRange(range, options);\n if (!range) {\n return false;\n }\n\n let queryOpts = Object.assign(\n {\n operation: 'set'\n },\n options\n );\n\n return await this.run('STORE', range, flags, queryOpts);\n }\n\n /**\n * Adds flags for a message or message range\n *\n * @param {SequenceString | Number[] | SearchObject} range Range to filter the messages\n * @param {string[]} Array of flags to set. Only flags that are permitted to set are used, other flags are ignored\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n * @param {BigInt} [options.unchangedSince] If set then only messages with a lower or equal `modseq` value are updated. Ignored if server does not support `CONDSTORE` extension.\n * @param {Boolean} [options.useLabels=false] If true then update Gmail labels instead of message flags\n * @returns {Promise<Boolean>} Did the operation succeed or not\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // mark all unseen messages as seen (and keep other flags as is)\n * await client.messageFlagsAdd({seen: false}, ['\\Seen]);\n */\n async messageFlagsAdd(range, flags, options) {\n options = options || {};\n\n range = await this.resolveRange(range, options);\n if (!range) {\n return false;\n }\n\n let queryOpts = Object.assign(\n {\n operation: 'add'\n },\n options\n );\n\n return await this.run('STORE', range, flags, queryOpts);\n }\n\n /**\n * Remove specific flags from a message or message range\n *\n * @param {SequenceString | Number[] | SearchObject} range Range to filter the messages\n * @param {string[]} Array of flags to remove. Only flags that are permitted to set are used, other flags are ignored\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n * @param {BigInt} [options.unchangedSince] If set then only messages with a lower or equal `modseq` value are updated. Ignored if server does not support `CONDSTORE` extension.\n * @param {Boolean} [options.useLabels=false] If true then update Gmail labels instead of message flags\n * @returns {Promise<Boolean>} Did the operation succeed or not\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // mark all seen messages as unseen by removing \\\\Seen flag\n * await client.messageFlagsRemove({seen: true}, ['\\Seen]);\n */\n async messageFlagsRemove(range, flags, options) {\n options = options || {};\n\n range = await this.resolveRange(range, options);\n if (!range) {\n return false;\n }\n\n let queryOpts = Object.assign(\n {\n operation: 'remove'\n },\n options\n );\n\n return await this.run('STORE', range, flags, queryOpts);\n }\n\n /**\n * Sets a colored flag for an email. Only supported by mail clients like Apple Mail\n *\n * @param {SequenceString | Number[] | SearchObject} range Range to filter the messages\n * @param {string} The color to set. One of 'red', 'orange', 'yellow', 'green', 'blue', 'purple', and 'grey'\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n * @param {BigInt} [options.unchangedSince] If set then only messages with a lower or equal `modseq` value are updated. Ignored if server does not support `CONDSTORE` extension.\n * @returns {Promise<Boolean>} Did the operation succeed or not\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // add a purple flag for all emails\n * await client.setFlagColor('1:*', 'Purple');\n */\n async setFlagColor(range, color, options) {\n options = options || {};\n\n range = await this.resolveRange(range, options);\n if (!range) {\n return false;\n }\n\n let flagChanges = getColorFlags(color);\n if (!flagChanges) {\n return false;\n }\n\n let addResults;\n let removeResults;\n\n if (flagChanges.add && flagChanges.add.length) {\n let queryOpts = Object.assign(\n {\n operation: 'add'\n },\n options,\n {\n useLabels: false, // override if set\n // prevent triggering a premature Flags change notification\n silent: flagChanges.remove && flagChanges.remove.length\n }\n );\n\n addResults = await this.run('STORE', range, flagChanges.add, queryOpts);\n }\n\n if (flagChanges.remove && flagChanges.remove.length) {\n let queryOpts = Object.assign(\n {\n operation: 'remove'\n },\n options,\n { useLabels: false } // override if set\n );\n\n removeResults = await this.run('STORE', range, flagChanges.remove, queryOpts);\n }\n\n return addResults || removeResults || false;\n }\n\n /**\n * Delete messages from the currently opened mailbox. Method does not indicate info about deleted messages,\n * instead you should be using {@link ImapFlow#expunge} event for this\n *\n * @param {SequenceString | Number[] | SearchObject} range Range to filter the messages\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n * @returns {Promise<Boolean>} Did the operation succeed or not\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // delete all seen messages\n * await client.messageDelete({seen: true});\n */\n async messageDelete(range, options) {\n options = options || {};\n range = await this.resolveRange(range, options);\n if (!range) {\n return false;\n }\n return await this.run('EXPUNGE', range, options);\n }\n\n /**\n * @typedef {Object} AppendResponseObject\n * @global\n * @property {String} destination full mailbox path where the message was uploaded to\n * @property {BigInt} [uidValidity] mailbox `UIDVALIDITY` if server has `UIDPLUS` extension enabled\n * @property {Number} [uid] UID of the uploaded message if server has `UIDPLUS` extension enabled\n * @property {Number} [seq] sequence number of the uploaded message if path is currently selected mailbox\n */\n\n /**\n * Appends a new message to a mailbox\n *\n * @param {String} path Mailbox path to upload the message to (unicode string)\n * @param {string|Buffer} content RFC822 formatted email message\n * @param {string[]} [flags] an array of flags to be set for the uploaded message\n * @param {Date|string} [idate=now] internal date to be set for the message\n * @returns {Promise<AppendResponseObject>} info about uploaded message\n *\n * @example\n * await client.append('INBOX', rawMessageBuffer, ['\\\\Seen'], new Date(2000, 1, 1));\n */\n async append(path, content, flags, idate) {\n let response = await this.run('APPEND', path, content, flags, idate);\n\n if (!response) {\n return false;\n }\n\n return response;\n }\n\n /**\n * @typedef {Object} CopyResponseObject\n * @global\n * @property {String} path path of source mailbox\n * @property {String} destination path of destination mailbox\n * @property {BigInt} [uidValidity] destination mailbox `UIDVALIDITY` if server has `UIDPLUS` extension enabled\n * @property {Map<number, number>} [uidMap] Map of UID values (if server has `UIDPLUS` extension enabled) where key is UID in source mailbox and value is the UID for the same message in destination mailbox\n */\n\n /**\n * Copies messages from current mailbox to destination mailbox\n *\n * @param {SequenceString | Number[] | SearchObject} range Range of messages to copy\n * @param {String} destination Mailbox path to copy the messages to\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n * @returns {Promise<CopyResponseObject>} info about copies messages\n *\n * @example\n * await client.mailboxOpen('INBOX');\n * // copy all messages to a mailbox called \"Backup\" (must exist)\n * let result = await client.messageCopy('1:*', 'Backup');\n * console.log('Copied %s messages', result.uidMap.size);\n */\n async messageCopy(range, destination, options) {\n options = options || {};\n range = await this.resolveRange(range, options);\n if (!range) {\n return false;\n }\n return await this.run('COPY', range, destination, options);\n }\n\n /**\n * Moves messages from current mailbox to destination mailbox\n *\n * @param {SequenceString | Number[] | SearchObject} range Range of messages to move\n * @param {String} destination Mailbox path to move the messages to\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n * @returns {Promise<CopyResponseObject>} info about moved messages\n *\n * @example\n * await client.mailboxOpen('INBOX');\n * // move all messages to a mailbox called \"Trash\" (must exist)\n * let result = await client.messageMove('1:*', 'Trash');\n * console.log('Moved %s messages', result.uidMap.size);\n */\n async messageMove(range, destination, options) {\n options = options || {};\n range = await this.resolveRange(range, options);\n if (!range) {\n return false;\n }\n return await this.run('MOVE', range, destination, options);\n }\n\n /**\n * Search messages from the currently opened mailbox\n *\n * @param {SearchObject} query Query to filter the messages\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then returns UID numbers instead of sequence numbers\n * @returns {Promise<Number[]>} An array of sequence or UID numbers\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // find all unseen messages\n * let list = await client.search({seen: false});\n * // use OR modifier (array of 2 or more search queries)\n * let list = await client.search({\n * seen: false,\n * or: [\n * {flagged: true},\n * {from: 'andris'},\n * {subject: 'test'}\n * ]});\n */\n async search(query, options) {\n if (!this.mailbox) {\n // no mailbox selected, nothing to do\n return;\n }\n\n let response = await this.run('SEARCH', query, options);\n\n if (!response) {\n return false;\n }\n\n return response;\n }\n\n /**\n * @typedef {Object} FetchQueryObject\n * @global\n * @property {Boolean} [uid] if `true` then include UID in the response\n * @property {Boolean} [flags] if `true` then include flags Set in the response. Also adds `flagColor` to the response if the message is flagged.\n * @property {Boolean} [bodyStructure] if `true` then include parsed BODYSTRUCTURE object in the response\n * @property {Boolean} [envelope] if `true` then include parsed ENVELOPE object in the response\n * @property {Boolean} [internalDate] if `true` then include internal date value in the response\n * @property {Boolean} [size] if `true` then include message size in the response\n * @property {boolean | Object} [source] if `true` then include full message in the response\n * @property {Number} [source.start] include full message in the response starting from *start* byte\n * @property {Number} [source.maxLength] include full message in the response, up to *maxLength* bytes\n * @property {String} [threadId] if `true` then include thread ID in the response (only if server supports either `OBJECTID` or `X-GM-EXT-1` extensions)\n * @property {Boolean} [labels] if `true` then include GMail labels in the response (only if server supports `X-GM-EXT-1` extension)\n * @property {boolean | string[]} [headers] if `true` then includes full headers of the message in the response. If the value is an array of header keys then includes only headers listed in the array\n * @property {string[]} [bodyParts] An array of BODYPART identifiers to include in the response\n */\n\n /**\n * Parsed email address entry\n *\n * @typedef {Object} MessageAddressObject\n * @global\n * @property {String} [name] name of the address object (unicode)\n * @property {String} [address] email address\n */\n\n /**\n * Parsed IMAP ENVELOPE object\n *\n * @typedef {Object} MessageEnvelopeObject\n * @global\n * @property {Date} [date] header date\n * @property {String} [subject] message subject (unicode)\n * @property {String} [messageId] Message ID of the message\n * @property {String} [inReplyTo] Message ID from In-Reply-To header\n * @property {MessageAddressObject[]} [from] Array of addresses from the From: header\n * @property {MessageAddressObject[]} [sender] Array of addresses from the Sender: header\n * @property {MessageAddressObject[]} [replyTo] Array of addresses from the Reply-To: header\n * @property {MessageAddressObject[]} [to] Array of addresses from the To: header\n * @property {MessageAddressObject[]} [cc] Array of addresses from the Cc: header\n * @property {MessageAddressObject[]} [bcc] Array of addresses from the Bcc: header\n */\n\n /**\n * Parsed IMAP BODYSTRUCTURE object\n *\n * @typedef {Object} MessageStructureObject\n * @global\n * @property {String} part Body part number. This value can be used to later fetch the contents of this part of the message\n * @property {String} type Content-Type of this node\n * @property {Object} [parameters] Additional parameters for Content-Type, eg \"charset\"\n * @property {String} [id] Content-ID\n * @property {String} [encoding] Transfer encoding\n * @property {Number} [size] Expected size of the node\n * @property {MessageEnvelopeObject} [envelope] message envelope of embedded RFC822 message\n * @property {String} [disposition] Content disposition\n * @property {Object} [dispositionParameters] Additional parameters for Content-Disposition\n * @property {MessageStructureObject[]} childNodes An array of child nodes if this is a multipart node. Not present for normal nodes\n */\n\n /**\n * Fetched message data\n *\n * @typedef {Object} FetchMessageObject\n * @global\n * @property {Number} seq message sequence number. Always included in the response\n * @property {Number} uid message UID number. Always included in the response\n * @property {Buffer} [source] message source for the requested byte range\n * @property {BigInt} [modseq] message Modseq number. Always included if the server supports CONDSTORE extension\n * @property {String} [emailId] unique email ID. Always included if server supports `OBJECTID` or `X-GM-EXT-1` extensions\n * @property {String} [threadid] unique thread ID. Only present if server supports `OBJECTID` or `X-GM-EXT-1` extension\n * @property {Set<string>} [labels] a Set of labels. Only present if server supports `X-GM-EXT-1` extension\n * @property {Number} [size] message size\n * @property {Set<string>} [flags] a set of message flags\n * @property {String} [flagColor] flag color like \"red\", or \"yellow\". This value is derived from the `flags` Set and it uses the same color rules as Apple Mail\n * @property {MessageEnvelopeObject} [envelope] message envelope\n * @property {MessageStructureObject} [bodyStructure] message body structure\n * @property {Date} [internalDate] message internal date\n * @property {Map<string, Buffer>} [bodyParts] a Map of message body parts where key is requested part identifier and value is a Buffer\n * @property {Buffer} [headers] Requested header lines as Buffer\n */\n\n /**\n * Fetch messages from the currently opened mailbox\n *\n * @param {SequenceString | Number[] | SearchObject} range Range of messages to fetch\n * @param {FetchQueryObject} query Fetch query\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID numbers instead of sequence numbers for `range`\n * @param {BigInt} [options.changedSince] If set then only messages with a higher modseq value are returned. Ignored if server does not support `CONDSTORE` extension.\n * @param {Boolean} [options.binary=false] If `true` then requests a binary response if the server supports this\n * @yields {Promise<FetchMessageObject>} Message data object\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // fetch UID for all messages in a mailbox\n * for await (let msg of client.fetch('1:*', {uid: true})){\n * console.log(msg.uid);\n * // NB! You can not run any IMAP commands in this loop\n * // otherwise you will end up in a deadloop\n * }\n */\n async *fetch(range, query, options) {\n options = options || {};\n\n if (!this.mailbox) {\n // no mailbox selected, nothing to do\n return;\n }\n\n range = await this.resolveRange(range, options);\n if (!range) {\n return false;\n }\n\n let finished = false;\n let push = false;\n let rowQueue = [];\n\n let getNext = () =>\n new Promise((resolve, reject) => {\n let check = () => {\n if (rowQueue.length) {\n let entry = rowQueue.shift();\n if (entry.err) {\n return reject(entry.err);\n } else {\n return resolve(entry.value);\n }\n }\n\n if (finished) {\n return resolve(null);\n }\n\n // wait until data is pushed to queue and try again\n push = () => {\n push = false;\n check();\n };\n };\n check();\n });\n\n this.run('FETCH', range, query, {\n uid: !!options.uid,\n binary: options.binary,\n changedSince: options.changedSince,\n onUntaggedFetch: (untagged, next) => {\n rowQueue.push({\n value: {\n response: untagged,\n next\n }\n });\n if (typeof push === 'function') {\n push();\n }\n }\n })\n .then(() => {\n finished = true;\n if (typeof push === 'function') {\n push();\n }\n })\n .catch(err => {\n rowQueue.push({ err });\n if (typeof push === 'function') {\n push();\n }\n });\n\n let res;\n while ((res = await getNext())) {\n if (this.isClosed || this.socket.destroyed) {\n let error = new Error('Connection closed');\n error.code = 'EConnectionClosed';\n throw error;\n }\n\n if (res !== null) {\n yield res.response;\n res.next();\n }\n }\n\n if (!finished) {\n // FETCH never finished!\n let error = new Error('FETCH did not finish');\n error.code = 'ENotFinished';\n throw error;\n }\n }\n\n /**\n * Fetch messages from the currently opened mailbox.\n *\n * This method will fetch all messages before resolving the promise, unlike .fetch(), which\n * is an async generator. Do not use large ranges like 1:*, as this might exhaust all available\n * memory if the mailbox contains a large number of emails.\n * @param {SequenceString | Number[] | SearchObject} range Range of messages to fetch\n * @param {FetchQueryObject} query Fetch query\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID numbers instead of sequence numbers for `range`\n * @param {BigInt} [options.changedSince] If set then only messages with a higher modseq value are returned. Ignored if server does not support `CONDSTORE` extension.\n * @param {Boolean} [options.binary=false] If `true` then requests a binary response if the server supports this\n * @returns {Promise<FetchMessageObject[]>} Array of Message data object\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // fetch UID for all messages in a mailbox\n * const messages = await client.fetchAll('1:*', {uid: true});\n * for (let msg of messages){\n * console.log(msg.uid);\n * }\n */\n async fetchAll(range, query, options) {\n const results = [];\n const generator = this.fetch(range, query, options);\n for await (const message of generator) {\n results.push(message);\n }\n return results;\n }\n\n /**\n * Fetch a single message from the currently opened mailbox\n *\n * @param {SequenceString} seq Single UID or sequence number of the message to fetch for\n * @param {FetchQueryObject} query Fetch query\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID number instead of sequence number for `seq`\n * @param {Boolean} [options.binary=false] If `true` then requests a binary response if the server supports this\n * @returns {Promise<FetchMessageObject>} Message data object\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // fetch UID for the last email in the selected mailbox\n * let lastMsg = await client.fetchOne('*', {uid: true})\n * console.log(lastMsg.uid);\n */\n async fetchOne(seq, query, options) {\n if (!this.mailbox) {\n // no mailbox selected, nothing to do\n return;\n }\n\n if (seq === '*') {\n if (!this.mailbox.exists) {\n return false;\n }\n seq = this.mailbox.exists.toString();\n options = Object.assign({}, options || {}, { uid: false }); // force into a sequence query\n }\n\n let response = await this.run('FETCH', (seq || '').toString(), query, options);\n\n if (!response || !response.list || !response.list.length) {\n return false;\n }\n\n return response.list[0];\n }\n\n /**\n * @typedef {Object} DownloadObject\n * @global\n * @property {Object} meta content metadata\n * @property {number} meta.expectedSize The fetch response size\n * @property {String} meta.contentType Content-Type of the streamed file. If part was not set then this value is \"message/rfc822\"\n * @property {String} [meta.charset] Charset of the body part. Text parts are automatically converted to UTF-8, attachments are kept as is\n * @property {String} [meta.disposition] Content-Disposition of the streamed file\n * @property {String} [meta.filename] Filename of the streamed body part\n * @property {ReadableStream} content Streamed content\n */\n\n /**\n * Download either full rfc822 formatted message or a specific bodystructure part as a Stream.\n * Bodystructure parts are decoded so the resulting stream is a binary file. Text content\n * is automatically converted to UTF-8 charset.\n *\n * @param {SequenceString} range UID or sequence number for the message to fetch\n * @param {String} [part] If not set then downloads entire rfc822 formatted message, otherwise downloads specific bodystructure part\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID number instead of sequence number for `range`\n * @param {number} [options.maxBytes] If set then limits download size to specified bytes\n * @param {number} [options.chunkSize=65536] How large content parts to ask from the server\n * @returns {Promise<DownloadObject>} Download data object\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // download body part nr '1.2' from latest message\n * let {meta, content} = await client.download('*', '1.2');\n * content.pipe(fs.createWriteStream(meta.filename));\n */\n async download(range, part, options) {\n if (!this.mailbox) {\n // no mailbox selected, nothing to do\n return {};\n }\n\n options = Object.assign(\n {\n chunkSize: 64 * 1024,\n maxBytes: Infinity\n },\n options || {}\n );\n\n let hasMore = true;\n let processed = 0;\n\n let chunkSize = Number(options.chunkSize) || 64 * 1024;\n let maxBytes = Number(options.maxBytes) || Infinity;\n\n let uid = false;\n\n if (part === '1') {\n // First part has special conditions for single node emails as\n // the mime parts for root node are not 1 and 1.MIME but TEXT and HEADERS\n let response = await this.fetchOne(range, { uid: true, bodyStructure: true }, options);\n\n if (!response) {\n return { response: false, chunk: false };\n }\n\n if (!uid && response.uid) {\n uid = response.uid;\n // force UID from now on even if first range was a sequence number\n range = uid;\n options.uid = true;\n }\n\n if (!response.bodyStructure.childNodes) {\n // single text message\n part = 'TEXT';\n }\n }\n\n let getNextPart = async query => {\n query = query || {};\n\n let mimeKey;\n\n if (!part) {\n query.source = {\n start: processed,\n maxLength: chunkSize\n };\n } else {\n part = part.toString().toLowerCase().trim();\n\n if (!query.bodyParts) {\n query.bodyParts = [];\n }\n\n if (query.size) {\n if (/^[\\d.]+$/.test(part)) {\n // fetch meta as well\n mimeKey = part + '.mime';\n query.bodyParts.push(mimeKey);\n } else if (part === 'text') {\n mimeKey = 'header';\n query.bodyParts.push(mimeKey);\n }\n }\n\n query.bodyParts.push({\n key: part,\n start: processed,\n maxLength: chunkSize\n });\n }\n\n let response = await this.fetchOne(range, query, options);\n\n if (!response) {\n return { response: false, chunk: false };\n }\n\n if (!uid && response.uid) {\n uid = response.uid;\n // force UID from now on even if first range was a sequence number\n range = uid;\n options.uid = true;\n }\n\n let chunk = !part ? response.source : response.bodyParts && response.bodyParts.get(part);\n if (!chunk) {\n return {};\n }\n\n processed += chunk.length;\n hasMore = chunk.length >= chunkSize;\n\n let result = { chunk };\n if (query.size) {\n result.response = response;\n }\n\n if (query.bodyParts) {\n if (mimeKey === 'header') {\n result.mime = response.headers;\n } else {\n result.mime = response.bodyParts.get(mimeKey);\n }\n }\n\n return result;\n };\n\n let { response, chunk, mime } = await getNextPart({\n size: true,\n uid: true\n });\n\n if (!response || !chunk) {\n // ???\n return {};\n }\n\n let meta = {\n expectedSize: response.size\n };\n\n if (!part) {\n meta.contentType = 'message/rfc822';\n } else if (mime) {\n let headers = new Headers(mime);\n let contentType = libmime.parseHeaderValue(headers.getFirst('Content-Type'));\n let transferEncoding = libmime.parseHeaderValue(headers.getFirst('Content-Transfer-Encoding'));\n let disposition = libmime.parseHeaderValue(headers.getFirst('Content-Disposition'));\n\n if (contentType.value.toLowerCase().trim()) {\n meta.contentType = contentType.value.toLowerCase().trim();\n }\n\n if (contentType.params.charset) {\n meta.charset = contentType.params.charset.toLowerCase().trim();\n }\n\n if (transferEncoding.value) {\n meta.encoding = transferEncoding.value\n .replace(/\\(.*\\)/g, '')\n .toLowerCase()\n .trim();\n }\n\n if (disposition.value) {\n meta.disposition = disposition.value.toLowerCase().trim() || false;\n try {\n meta.disposition = libmime.decodeWords(meta.disposition);\n } catch (err) {\n // failed to parse disposition, keep as is (most probably an unknown charset is used)\n }\n }\n\n if (contentType.params.format && contentType.params.format.toLowerCase().trim() === 'flowed') {\n meta.flowed = true;\n if (contentType.params.delsp && contentType.params.delsp.toLowerCase().trim() === 'yes') {\n meta.delSp = true;\n }\n }\n\n let filename = disposition.params.filename || contentType.params.name || false;\n if (filename) {\n try {\n filename = libmime.decodeWords(filename);\n } catch (err) {\n // failed to parse filename, keep as is (most probably an unknown charset is used)\n }\n meta.filename = filename;\n }\n }\n\n let stream;\n let output;\n\n switch (meta.encoding) {\n case 'base64':\n output = stream = new libbase64.Decoder();\n break;\n case 'quoted-printable':\n output = stream = new libqp.Decoder();\n break;\n default:\n output = stream = new PassThrough();\n }\n\n let isTextNode = ['text/html', 'text/plain', 'text/x-amp-html'].includes(meta.contentType) || (part === '1' && !meta.contentType);\n if ((!meta.disposition || meta.disposition === 'inline') && isTextNode) {\n // flowed text\n if (meta.flowed) {\n let flowDecoder = new FlowedDecoder({\n delSp: meta.delSp\n });\n output.on('error', err => {\n flowDecoder.emit('error', err);\n });\n output = output.pipe(flowDecoder);\n }\n\n // not utf-8 text\n if (meta.charset && !['ascii', 'usascii', 'utf8'].includes(meta.charset.toLowerCase().replace(/[^a-z0-9]+/g, ''))) {\n try {\n let decoder = getDecoder(meta.charset);\n output.on('error', err => {\n decoder.emit('error', err);\n });\n output = output.pipe(decoder);\n // force to utf-8 for output\n meta.charset = 'utf-8';\n } catch (E) {\n // do not decode charset\n }\n }\n }\n\n let limiter = new LimitedPassthrough({ maxBytes });\n output.on('error', err => {\n limiter.emit('error', err);\n });\n output = output.pipe(limiter);\n\n let writeChunk = chunk => {\n if (limiter.limited) {\n return true;\n }\n return stream.write(chunk);\n };\n\n let fetchAllParts = async () => {\n while (hasMore && !limiter.limited) {\n let { chunk } = await getNextPart();\n if (!chunk) {\n break;\n }\n\n if (writeChunk(chunk) === false) {\n await new Promise(resolve => stream.once('drain', resolve));\n }\n }\n };\n\n setImmediate(() => {\n writeChunk(chunk);\n fetchAllParts()\n .catch(err => stream.emit('error', err))\n .finally(() => stream.end());\n });\n\n return {\n meta,\n content: output\n };\n }\n\n /**\n * Fetch multiple attachments as Buffer values\n *\n * @param {SequenceString} range UID or sequence number for the message to fetch\n * @param {String} parts A list of bodystructure parts\n * @param {Object} [options]\n * @param {Boolean} [options.uid] If `true` then uses UID number instead of sequence number for `range`\n * @returns {Promise<Object>} Download data object\n *\n * @example\n * let mailbox = await client.mailboxOpen('INBOX');\n * // download body parts '2', and '3' from all messages in the selected mailbox\n * let response = await client.downloadMany('*', ['2', '3']);\n * process.stdout.write(response[2].content)\n * process.stdout.write(response[3].content)\n */\n async downloadMany(range, parts, options) {\n if (!this.mailbox) {\n // no mailbox selected, nothing to do\n return {};\n }\n\n options = Object.assign(\n {\n chunkSize: 64 * 1024,\n maxBytes: Infinity\n },\n options || {}\n );\n\n let query = { bodyParts: [] };\n\n for (let part of parts) {\n query.bodyParts.push(part + '.mime');\n query.bodyParts.push(part);\n }\n\n let response = await this.fetchOne(range, query, options);\n\n if (!response || !response.bodyParts) {\n return { response: false };\n }\n\n let data = {};\n\n for (let [part, content] of response.bodyParts) {\n let keyParts = part.split('.mime');\n if (keyParts.length === 1) {\n // content\n let key = keyParts[0];\n if (!data[key]) {\n data[key] = { content };\n } else {\n data[key].content = content;\n }\n } else if (keyParts.length === 2) {\n // header\n let key = keyParts[0];\n if (!data[key]) {\n data[key] = {};\n }\n if (!data[key].meta) {\n data[key].meta = {};\n }\n\n let headers = new Headers(content);\n let contentType = libmime.parseHeaderValue(headers.getFirst('Content-Type'));\n let transferEncoding = libmime.parseHeaderValue(headers.getFirst('Content-Transfer-Encoding'));\n let disposition = libmime.parseHeaderValue(headers.getFirst('Content-Disposition'));\n\n if (contentType.value.toLowerCase().trim()) {\n data[key].meta.contentType = contentType.value.toLowerCase().trim();\n }\n\n if (contentType.params.charset) {\n data[key].meta.charset = contentType.params.charset.toLowerCase().trim();\n }\n\n if (transferEncoding.value) {\n data[key].meta.encoding = transferEncoding.value\n .replace(/\\(.*\\)/g, '')\n .toLowerCase()\n .trim();\n }\n\n if (disposition.value) {\n data[key].meta.disposition = disposition.value.toLowerCase().trim() || false;\n try {\n data[key].meta.disposition = libmime.decodeWords(data[key].meta.disposition);\n } catch (err) {\n // failed to parse disposition, keep as is (most probably an unknown charset is used)\n }\n }\n\n if (contentType.params.format && contentType.params.format.toLowerCase().trim() === 'flowed') {\n data[key].meta.flowed = true;\n if (contentType.params.delsp && contentType.params.delsp.toLowerCase().trim() === 'yes') {\n data[key].meta.delSp = true;\n }\n }\n\n let filename = disposition.params.filename || contentType.params.name || false;\n if (filename) {\n try {\n filename = libmime.decodeWords(filename);\n } catch (err) {\n // failed to parse filename, keep as is (most probably an unknown charset is used)\n }\n data[key].meta.filename = filename;\n }\n }\n }\n\n for (let part of Object.keys(data)) {\n let meta = data[part].meta;\n\n switch (meta.encoding) {\n case 'base64':\n data[part].content = data[part].content ? libbase64.decode(data[part].content.toString()) : null;\n break;\n case 'quoted-printable':\n data[part].content = data[part].content ? libqp.decode(data[part].content.toString()) : null;\n break;\n default:\n // keep as is, already a buffer\n }\n }\n\n return data;\n }\n\n async run(command, ...args) {\n command = command.toUpperCase();\n if (!this.commands.has(command)) {\n return false;\n }\n\n if (this.socket.destroyed) {\n const error = new Error('Connection not available');\n error.code = 'NoConnection';\n throw error;\n }\n\n clearTimeout(this.idleStartTimer);\n\n if (typeof this.preCheck === 'function') {\n await this.preCheck();\n }\n\n let handler = this.commands.get(command);\n\n let result = await handler(this, ...args);\n\n if (command !== 'IDLE') {\n // do not autostart IDLE, if IDLE itself was stopped\n this.autoidle();\n }\n\n return result;\n }\n\n async processLocks(force) {\n if (!force && this.processingLock) {\n this.log.trace({\n msg: 'Mailbox locking queued',\n path: this.mailbox && this.mailbox.path,\n pending: this.locks.length,\n idling: this.idling,\n activeLock: this.currentLock\n ? {\n lockId: this.currentLock.lockId,\n ...(this.currentLock.options?.description && { description: this.currentLock.options?.description })\n }\n : null\n });\n return;\n }\n\n if (!this.locks.length) {\n this.processingLock = false;\n this.log.trace({\n msg: 'Mailbox locking queue processed',\n idling: this.idling\n });\n return;\n }\n\n this.processingLock = true;\n\n const release = () => {\n if (this.currentLock) {\n this.log.trace({\n msg: 'Mailbox lock released',\n lockId: this.currentLock.lockId,\n path: this.mailbox && this.mailbox.path,\n pending: this.locks.length,\n idling: this.idling\n });\n this.currentLock = false;\n }\n this.processLocks(true).catch(err => this.log.error({ err, cid: this.id }));\n };\n\n const lock = this.locks.shift();\n const { resolve, reject, path, options, lockId } = lock;\n\n if (!this.usable || this.socket.destroyed) {\n this.log.trace({ msg: 'Failed to acquire mailbox lock', path, lockId, idling: this.idling });\n // reject all\n let error = new Error('Connection not available');\n error.code = 'NoConnection';\n reject(error);\n return await this.processLocks(true);\n }\n\n if (this.mailbox && this.mailbox.path === path && !!this.mailbox.readOnly === !!options.readOnly) {\n // nothing to do here, already selected\n this.log.trace({\n msg: 'Mailbox lock acquired [existing]',\n path,\n lockId,\n idling: this.idling,\n ...(options.description && { description: options.description })\n });\n this.currentLock = lock;\n return resolve({ path, release });\n } else {\n try {\n // Try to open. Throws if mailbox does not exists or can't open\n await this.mailboxOpen(path, options);\n this.log.trace({\n msg: 'Mailbox lock acquired [selected]',\n path,\n lockId,\n idling: this.idling,\n ...(options.description && { description: options.description })\n });\n this.currentLock = lock;\n return resolve({ path, release });\n } catch (err) {\n if (err.responseStatus === 'NO') {\n try {\n let folders = await this.run('LIST', '', path, { listOnly: true });\n if (!folders || !folders.length) {\n err.mailboxMissing = true;\n }\n } catch (E) {\n this.log.trace({ msg: 'Failed to verify failed mailbox', path, err: E });\n }\n }\n\n this.log.trace({\n msg: 'Failed to acquire mailbox lock',\n path,\n lockId,\n idling: this.idling,\n ...(options.description && { description: options.description }),\n err\n });\n reject(err);\n await this.processLocks(true);\n }\n }\n }\n\n /**\n * Opens a mailbox if not already open and returns a lock. Next call to `getMailboxLock()` is queued\n * until previous lock is released. This is suggested over {@link module:imapflow~ImapFlow#mailboxOpen|mailboxOpen()} as\n * `getMailboxLock()` gives you a weak transaction while `mailboxOpen()` has no guarantees whatsoever that another\n * mailbox is opened while you try to call multiple fetch or store commands.\n *\n * @param {string|array} path **Path for the mailbox** to open\n * @param {Object} [options] optional options\n * @param {Boolean} [options.readOnly=false] If `true` then opens mailbox in read-only mode. You can still try to perform write operations but these would probably fail.\n * @returns {Promise<MailboxLockObject>} Mailbox lock\n * @throws Will throw an error if mailbox does not exist or can not be opened\n *\n * @example\n * let lock = await client.getMailboxLock('INBOX');\n * try {\n * // do something in the mailbox\n * } finally {\n * // use finally{} to make sure lock is released even if exception occurs\n * lock.release();\n * }\n */\n async getMailboxLock(path, options) {\n options = options || {};\n\n path = normalizePath(this, path);\n\n let lockId = ++this.lockCounter;\n this.log.trace({\n msg: 'Requesting lock',\n path,\n lockId,\n ...(options.description && { description: options.description }),\n activeLock: this.currentLock\n ? {\n lockId: this.currentLock.lockId,\n ...(this.currentLock.options?.description && { description: this.currentLock.options?.description })\n }\n : null\n });\n\n return await new Promise((resolve, reject) => {\n this.locks.push({ resolve, reject, path, options, lockId });\n this.processLocks().catch(err => reject(err));\n });\n }\n\n getLogger() {\n let mainLogger =\n this.options.logger && typeof this.options.logger === 'object'\n ? this.options.logger\n : logger.child({\n component: 'imap-connection',\n cid: this.id\n });\n\n let synteticLogger = {};\n let levels = ['trace', 'debug', 'info', 'warn', 'error', 'fatal'];\n for (let level of levels) {\n synteticLogger[level] = (...args) => {\n // using {logger:false} disables logging\n if (this.options.logger !== false) {\n if (logger)\n if (typeof mainLogger[level] !== 'function') {\n // we are checking to make sure the level is supported.\n // if it isn't supported but the level is error or fatal, log to console anyway.\n if (level === 'fatal' || level === 'error') {\n console.log(JSON.stringify(...args));\n }\n } else {\n mainLogger[level](...args);\n }\n }\n\n if (this.emitLogs && args && args[0] && typeof args[0] === 'object') {\n let logEntry = Object.assign({ level, t: Date.now(), cid: this.id, lo: ++this.lo }, args[0]);\n if (logEntry.err && typeof logEntry.err === 'object') {\n let err = logEntry.err;\n logEntry.err = {\n stack: err.stack\n };\n // enumerable error fields\n Object.keys(err).forEach(key => {\n logEntry.err[key] = err[key];\n });\n }\n this.emit('log', logEntry);\n }\n };\n }\n\n return synteticLogger;\n }\n\n unbind() {\n this.socket.unpipe(this.streamer);\n if (this._inflate) {\n this._inflate.unpipe(this.streamer);\n }\n\n this.socket.removeListener('error', this._socketError);\n this.socket.removeListener('close', this._socketClose);\n this.socket.removeListener('end', this._socketEnd);\n this.socket.removeListener('tlsClientError', this._socketError);\n this.socket.removeListener('timeout', this._socketTimeout);\n\n return {\n readSocket: this._inflate || this.socket,\n writeSocket: this.writeSocket || this.socket\n };\n }\n}\n\n/**\n * Connection close event. **NB!** ImapFlow does not handle reconnects automatically.\n * So whenever a 'close' event occurs you must create a new connection yourself.\n *\n * @event module:imapflow~ImapFlow#close\n */\n\n/**\n * Error event. In most cases getting an error event also means that connection is closed\n * and pending operations should return with a failure.\n *\n * @event module:imapflow~ImapFlow#error\n * @type {Error}\n * @example\n * client.on('error', err=>{\n * console.log(`Error occurred: ${err.message}`);\n * });\n */\n\n/**\n * Message count in currently opened mailbox changed\n *\n * @event module:imapflow~ImapFlow#exists\n * @type {Object}\n * @property {String} path mailbox path this event applies to\n * @property {Number} count updated count of messages\n * @property {Number} prevCount message count before this update\n * @example\n * client.on('exists', data=>{\n * console.log(`Message count in \"${data.path}\" is ${data.count}`);\n * });\n */\n\n/**\n * Deleted message sequence number in currently opened mailbox. One event is fired for every deleted email.\n *\n * @event module:imapflow~ImapFlow#expunge\n * @type {Object}\n * @property {String} path mailbox path this event applies to\n * @property {Number} seq sequence number of deleted message\n * @example\n * client.on('expunge', data=>{\n * console.log(`Message #${data.seq} was deleted from \"${data.path}\"`);\n * });\n */\n\n/**\n * Flags were updated for a message. Not all servers fire this event.\n *\n * @event module:imapflow~ImapFlow#flags\n * @type {Object}\n * @property {String} path mailbox path this event applies to\n * @property {Number} seq sequence number of updated message\n * @property {Number} [uid] UID number of updated message (if server provided this value)\n * @property {BigInt} [modseq] Updated modseq number for the mailbox (if server provided this value)\n * @property {Set<string>} flags A set of all flags for the updated message\n * @example\n * client.on('flags', data=>{\n * console.log(`Flag set for #${data.seq} is now \"${Array.from(data.flags).join(', ')}\"`);\n * });\n */\n\n/**\n * Mailbox was opened\n *\n * @event module:imapflow~ImapFlow#mailboxOpen\n * @type {MailboxObject}\n * @example\n * client.on('mailboxOpen', mailbox => {\n * console.log(`Mailbox ${mailbox.path} was opened`);\n * });\n */\n\n/**\n * Mailbox was closed\n *\n * @event module:imapflow~ImapFlow#mailboxClose\n * @type {MailboxObject}\n * @example\n * client.on('mailboxClose', mailbox => {\n * console.log(`Mailbox ${mailbox.path} was closed`);\n * });\n */\n\n/**\n * Log event if `emitLogs=true`\n *\n * @event module:imapflow~ImapFlow#log\n * @type {Object}\n * @example\n * client.on('log', entry => {\n * console.log(`${log.cid} ${log.msg}`);\n * });\n */\n\nmodule.exports.ImapFlow = ImapFlow;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/imapflow/lib/imap-flow.js","mappings":"AAAa;;AAEb;AACA;AACA;;AAEA;AACA;AACA;;AAEA,YAAY,mBAAO,CAAC,gBAAK;AACzB,YAAY,mBAAO,CAAC,gBAAK;AACzB,eAAe,mBAAO,CAAC,sBAAQ;AAC/B,QAAQ,eAAe,EAAE,mBAAO,CAAC,sBAAQ;AACzC,eAAe,mBAAO,CAAC,6DAAU;AACjC,gBAAgB,mBAAO,CAAC,4DAAS;AACjC,aAAa,mBAAO,CAAC,kBAAM;AAC3B,QAAQ,UAAU,EAAE,mBAAO,CAAC,gFAAW;AACvC,QAAQ,qBAAqB,EAAE,mBAAO,CAAC,uFAAuB;;AAE9D,QAAQ,aAAa,EAAE,mBAAO,CAAC,uFAAuB;AACtD,QAAQ,mBAAmB,EAAE,mBAAO,CAAC,yFAAwB;AAC7D,oBAAoB,mBAAO,CAAC,mEAAiB;;AAE7C,cAAc,mBAAO,CAAC,sDAAO;AAC7B,kBAAkB,mBAAO,CAAC,kEAAW;AACrC,sBAAsB,mBAAO,CAAC,gHAA8B;AAC5D,QAAQ,cAAc,EAAE,mBAAO,CAAC,sBAAQ;;AAExC,QAAQ,kBAAkB,EAAE,mBAAO,CAAC,iFAAoB;;AAExD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,EAAE,EAAE,mBAAO,CAAC,2DAAS;;AAErB,qBAAqB,mBAAO,CAAC,8EAAoB;;AAEjD;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,aAAa,QAAQ;AACrB;AACA,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,aAAa;AAC3B,cAAc,QAAQ;AACtB,cAAc,SAAS;AACvB,cAAc,SAAS;AACvB,cAAc,aAAa;AAC3B,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB;;AAEA;AACA,aAAa,QAAQ;AACrB;AACA,cAAc,QAAQ;AACtB,cAAc,UAAU;AACxB;AACA;AACA;AACA;AACA,KAAK;AACL,sBAAsB;AACtB;AACA;AACA;;AAEA;AACA;AACA,aAAa,QAAQ;AACrB;AACA,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,MAAM;AACpB;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA;;AAEA;AACA;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA,kBAAkB,QAAQ;AAC1B,+EAA+E,cAAc;AAC7F;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA;AACA,kBAAkB,cAAc;AAChC;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,gBAAgB;AAClC;AACA;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA,kBAAkB,SAAS;AAC3B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;AACA,kBAAkB,QAAQ;AAC1B;AACA;;AAEA;AACA,gBAAgB,yBAAyB;;AAEzC;;AAEA;AACA;AACA,kBAAkB;AAClB;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA,gCAAgC;;AAEhC;;AAEA;AACA;AACA,kBAAkB;AAClB;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;;AAEA;;AAEA,6CAA6C;;AAE7C;AACA;AACA,kBAAkB;AAClB;AACA;;AAEA;AACA;AACA,kBAAkB;AAClB;AACA;;AAEA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;;AAEA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;;AAEA;AACA;AACA,kBAAkB;AAClB;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,6BAA6B,mBAAmB;AAChD;AACA;AACA,SAAS;;AAET;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA,UAAU;AACV;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA,SAAS;;AAET;;AAEA,yBAAyB,+EAA+E;;AAExG;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA,0CAA0C,+CAA+C;AACzF,qCAAqC,mCAAmC;AACxE;AACA;AACA;AACA,aAAa;AACb,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,sDAAsD,yBAAyB;AAC/E;AACA,oCAAoC;;AAEpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA,iCAAiC,2DAA2D;AAC5F;AACA;AACA;;AAEA;AACA;AACA,aAAa;;AAEb;AACA;AACA,iCAAiC,gGAAgG;AACjI,cAAc;AACd,iCAAiC,gGAAgG;AACjI;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,iCAAiC,qBAAqB,eAAe,kCAAkC;AACvG;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB,wCAAwC,mBAAmB;AAC3D;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,uEAAuE,iCAAiC;AACxG;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC;AACrC;AACA,0BAA0B;AAC1B;AACA;;AAEA;AACA;;AAEA;AACA;AACA,gDAAgD,kDAAkD;AAClG,+EAA+E,iCAAiC;AAChH;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,gDAAgD,6EAA6E;AAC7H;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,mDAAmD,mBAAmB;AACtE;AACA;AACA,qBAAqB;AACrB;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,iCAAiC,mBAAmB;AACpD;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,aAAa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB;AAClB,qCAAqC,qCAAqC;AAC1E;AACA;AACA,aAAa;;AAEb;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,oBAAoB;AACpB;;AAEA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd,iCAAiC,iEAAiE;AAClG;AACA;AACA;;AAEA;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,iBAAiB,SAAS;AAC1B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;;AAEA;AACA,aAAa;;AAEb;;AAEA;AACA,SAAS;;AAET;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,0FAA0F,4CAA4C;AACtI,UAAU;AACV;AACA,8FAA8F,+CAA+C;AAC7I,cAAc;AACd;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,iCAAiC,mBAAmB;;AAEpD;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,aAAa;AACb;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,iCAAiC,mBAAmB;;AAEpD;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,aAAa;AACb;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,kBAAkB;AAClB,qCAAqC,0EAA0E;AAC/G;AACA,cAAc;AACd;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,kBAAkB;AAClB,qCAAqC,0EAA0E;AAC/G;AACA,cAAc;AACd;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC;AACjC;;AAEA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA,cAAc;AACd;AACA,oCAAoC;AACpC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,qDAAqD,mBAAmB;AACxE,SAAS;AACT;;AAEA;;AAEA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,kCAAkC,IAAI;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA,iCAAiC,qBAAqB;AACtD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,mBAAmB;AACpD;AACA;AACA,aAAa;;AAEb;AACA;AACA;AACA;;AAEA;AACA,kGAAkG,wDAAwD;AAC1J;AACA;AACA;AACA;AACA,qCAAqC,mBAAmB;AACxD;AACA;AACA,iBAAiB;;AAEjB;;AAEA;AACA;AACA,wCAAwC,0BAA0B;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,iCAAiC,mBAAmB;AACpD;AACA,aAAa;;AAEb;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA,gBAAgB;AAChB;AACA,kCAAkC,IAAI;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,kCAAkC,IAAI;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,uCAAuC;AACnF;AACA;AACA;;AAEA;AACA,yDAAyD,mBAAmB;AAC5E;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,cAAc;AACd,iCAAiC,mBAAmB;AACpD;AACA;;AAEA;AACA;AACA;AACA,cAAc;AACd,iCAAiC,mBAAmB;AACpD;AACA;;AAEA,yBAAyB,wCAAwC;AACjE;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B;;AAEA;AACA;AACA;AACA,eAAe,QAAQ;AACvB,iBAAiB,gCAAgC;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,UAAU;AAC5B,kBAAkB,QAAQ;AAC1B,kBAAkB,aAAa;AAC/B,kBAAkB,QAAQ;AAC1B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,cAAc;AAChC;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B;;AAEA;AACA;AACA;AACA,eAAe,aAAa;AAC5B,iBAAiB,yBAAyB;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,SAAS;AAC3B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,UAAU;AAC5B,kBAAkB,QAAQ;AAC1B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,oBAAoB;AACtC;;AAEA;AACA;AACA;AACA,eAAe,aAAa;AAC5B,iBAAiB,2BAA2B;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,SAAS;AAC3B;;AAEA;AACA;AACA;AACA,eAAe,cAAc;AAC7B,iBAAiB,gCAAgC;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B;;AAEA;AACA;AACA;AACA,eAAe,cAAc;AAC7B,eAAe,cAAc;AAC7B,iBAAiB,gCAAgC;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B;;AAEA;AACA;AACA;AACA,eAAe,cAAc;AAC7B,iBAAiB,gCAAgC;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,eAAe,cAAc;AAC7B,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,eAAe,cAAc;AAC7B,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,cAAc,gEAAgE;AAC9E;AACA;AACA,eAAe,cAAc;AAC7B,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,iBAAiB,wBAAwB;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B;;AAEA;AACA;AACA;AACA,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,eAAe,SAAS;AACxB,eAAe,SAAS;AACxB,eAAe,SAAS;AACxB,eAAe,SAAS;AACxB,eAAe,SAAS;AACxB,iBAAiB,uBAAuB;AACxC;AACA;AACA,kDAAkD,aAAa;AAC/D;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,yGAAyG,gCAAgC;AACzI;AACA;AACA;AACA,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB,QAAQ;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,gBAAgB;AAClC,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,gBAAgB;AAClC,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,aAAa;AAC/B,kBAAkB,aAAa;AAC/B,kBAAkB,aAAa;AAC/B,kBAAkB,aAAa;AAC/B,kBAAkB,aAAa;AAC/B,kBAAkB,aAAa;AAC/B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,iCAAiC;AACnD,kBAAkB,gBAAgB,4BAA4B,oBAAoB;AAClF;;AAEA;AACA;AACA;AACA,eAAe,0CAA0C;AACzD,eAAe,UAAU;AACzB,eAAe,QAAQ;AACvB,eAAe,SAAS,uCAAuC,sBAAsB;AACrF,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA,qCAAqC,YAAY;AACjD;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,eAAe,0CAA0C;AACzD,eAAe,UAAU;AACzB,eAAe,QAAQ;AACvB,eAAe,SAAS,uCAAuC,sBAAsB;AACrF,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA,qCAAqC,YAAY;AACjD;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,eAAe,0CAA0C;AACzD,eAAe,UAAU;AACzB,eAAe,QAAQ;AACvB,eAAe,SAAS,uCAAuC,sBAAsB;AACrF,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA,wCAAwC,WAAW;AACnD;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,eAAe,0CAA0C;AACzD,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,SAAS,uCAAuC,sBAAsB;AACrF,eAAe,QAAQ;AACvB,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA,kBAAkB,mBAAmB;AACrC;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,oCAAoC,wBAAwB;AAC5D;AACA,eAAe,0CAA0C;AACzD,eAAe,QAAQ;AACvB,eAAe,SAAS,uCAAuC,sBAAsB;AACrF,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;AACA,mCAAmC,WAAW;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B;;AAEA;AACA;AACA;AACA,eAAe,QAAQ;AACvB,eAAe,eAAe;AAC9B,eAAe,UAAU;AACzB,eAAe,aAAa;AAC5B,iBAAiB,+BAA+B;AAChD;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,qBAAqB;AACvC;;AAEA;AACA;AACA;AACA,eAAe,0CAA0C;AACzD,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,SAAS,uCAAuC,sBAAsB;AACrF,iBAAiB,6BAA6B;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,eAAe,0CAA0C;AACzD,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,SAAS,uCAAuC,sBAAsB;AACrF,iBAAiB,6BAA6B;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,eAAe,cAAc;AAC7B,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,iBAAiB,mBAAmB;AACpC;AACA;AACA;AACA;AACA,uCAAuC,YAAY;AACnD;AACA;AACA;AACA;AACA,YAAY,cAAc;AAC1B,YAAY,eAAe;AAC3B,YAAY;AACZ,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,SAAS;AAC3B,kBAAkB,kBAAkB;AACpC,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,SAAS;AAC3B,kBAAkB,oBAAoB;AACtC,kBAAkB,UAAU;AAC5B;;AAEA;AACA;AACA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B;;AAEA;AACA;AACA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,MAAM;AACxB,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,wBAAwB;AAC1C,kBAAkB,wBAAwB;AAC1C,kBAAkB,wBAAwB;AAC1C,kBAAkB,wBAAwB;AAC1C,kBAAkB,wBAAwB;AAC1C,kBAAkB,wBAAwB;AAC1C;;AAEA;AACA;AACA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,uBAAuB;AACzC,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,0BAA0B;AAC5C;;AAEA;AACA;AACA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,aAAa;AAC/B,kBAAkB,QAAQ;AAC1B,kBAAkB,aAAa;AAC/B,kBAAkB,QAAQ;AAC1B,kBAAkB,uBAAuB;AACzC,kBAAkB,wBAAwB;AAC1C,kBAAkB,MAAM;AACxB,kBAAkB,qBAAqB;AACvC,kBAAkB,QAAQ;AAC1B;;AAEA;AACA;AACA;AACA,eAAe,0CAA0C;AACzD,eAAe,kBAAkB;AACjC,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,gBAAgB,6BAA6B;AAC7C;AACA;AACA;AACA;AACA,kDAAkD,UAAU;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B;AAC1B;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,gCAAgC,KAAK;AACrC;AACA;AACA;AACA,aAAa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,0CAA0C;AACzD,eAAe,kBAAkB;AACjC,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,iBAAiB,+BAA+B;AAChD;AACA;AACA;AACA;AACA,sDAAsD,UAAU;AAChE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,eAAe,gBAAgB;AAC/B,eAAe,kBAAkB;AACjC,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,eAAe,SAAS;AACxB,iBAAiB,6BAA6B;AAC9C;AACA;AACA;AACA;AACA,iDAAiD,UAAU;AAC3D;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,sCAAsC,eAAe,IAAI,YAAY,GAAG;AACxE;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,iBAAiB,QAAQ;AACzB;AACA,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,QAAQ;AAC1B,kBAAkB,gBAAgB;AAClC;;AAEA;AACA;AACA;AACA;AACA;AACA,eAAe,gBAAgB;AAC/B,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,iBAAiB,yBAAyB;AAC1C;AACA;AACA;AACA;AACA,YAAY,eAAe;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,wDAAwD,gCAAgC;;AAExF;AACA,yBAAyB;AACzB;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;;AAEA;;AAEA;AACA,yBAAyB;AACzB;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,2BAA2B;AAC3B;AACA;AACA;;AAEA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;;AAEA;AACA;;AAEA,cAAc,wBAAwB;AACtC;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,iBAAiB;AACjB;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;;AAEA,+CAA+C,UAAU;AACzD;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,sBAAsB,QAAQ;AAC9B;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,eAAe,gBAAgB;AAC/B,eAAe,QAAQ;AACvB,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,iBAAiB,iBAAiB;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA,sBAAsB;;AAEtB;AACA;AACA;AACA;;AAEA;;AAEA;AACA,qBAAqB;AACrB;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC;AAClC,kBAAkB;AAClB;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yEAAyE,oDAAoD;AAC7H;AACA;AACA,aAAa;AACb;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA,kEAAkE,mBAAmB;AACrF;;AAEA;AACA,gBAAgB,yCAAyC;;AAEzD;AACA,6BAA6B,0EAA0E;AACvG;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C,kCAAkC;AAC/E,aAAa;AACb;AACA,6BAA6B,eAAe;AAC5C,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAiD,kCAAkC;AACnF,iBAAiB;AACjB;AACA,iCAAiC,eAAe;AAChD,cAAc;AACd;AACA;AACA,yEAAyE,gBAAgB;AACzF;AACA;AACA;AACA,sBAAsB;AACtB,yCAAyC,sDAAsD;AAC/F;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,iDAAiD,kCAAkC;AACnF;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,gEAAgE,0DAA0D;AAC1H;AACA;AACA;AACA,eAAe,cAAc;AAC7B,eAAe,QAAQ;AACvB,eAAe,SAAS;AACxB,iBAAiB,4BAA4B;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,0BAA0B;AAC1B;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,yCAAyC,kCAAkC;AAC3E;AACA;AACA;AACA,qEAAqE,oDAAoD;AACzH;AACA;AACA,SAAS;;AAET;AACA,8BAA8B,wCAAwC;AACtE;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB;;AAEnB;AACA;AACA;AACA;AACA,0BAA0B,cAAc;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B;AAC1B;AACA;AACA;;AAEA;AACA,mDAAmD,mDAAmD;AACtG;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB;AACzB;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA,sCAAsC,YAAY;AAClD,IAAI;AACJ;;AAEA;AACA;AACA;AACA;AACA,UAAU;AACV,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB;AACA;AACA,wCAAwC,UAAU,OAAO,WAAW;AACpE,IAAI;AACJ;;AAEA;AACA;AACA;AACA;AACA,UAAU;AACV,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB;AACA;AACA,+BAA+B,UAAU,oBAAoB,UAAU;AACvE,IAAI;AACJ;;AAEA;AACA;AACA;AACA;AACA,UAAU;AACV,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,aAAa;AAC3B;AACA;AACA,oCAAoC,UAAU,UAAU,kCAAkC;AAC1F,IAAI;AACJ;;AAEA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA,8BAA8B,cAAc;AAC5C,IAAI;AACJ;;AAEA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA,8BAA8B,cAAc;AAC5C,IAAI;AACJ;;AAEA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA,sBAAsB,SAAS,EAAE,QAAQ;AACzC,IAAI;AACJ;;AAEA,uBAAuB","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/imap-flow.js"],"sourcesContent":["'use strict';\n\n/**\n * @module imapflow\n */\n\n// TODO:\n// * Use buffers for compiled commands\n// * OAuth2 authentication\n\nconst tls = require('tls');\nconst net = require('net');\nconst crypto = require('crypto');\nconst { EventEmitter } = require('events');\nconst logger = require('./logger');\nconst libmime = require('libmime');\nconst zlib = require('zlib');\nconst { Headers } = require('mailsplit');\nconst { LimitedPassthrough } = require('./limited-passthrough');\n\nconst { ImapStream } = require('./handler/imap-stream');\nconst { parser, compiler } = require('./handler/imap-handler');\nconst packageInfo = require('../package.json');\n\nconst libqp = require('libqp');\nconst libbase64 = require('libbase64');\nconst FlowedDecoder = require('mailsplit/lib/flowed-decoder');\nconst { PassThrough } = require('stream');\n\nconst { proxyConnection } = require('./proxy-connection');\n\nconst {\n    comparePaths,\n    updateCapabilities,\n    getFolderTree,\n    formatMessageResponse,\n    getDecoder,\n    packMessageRange,\n    normalizePath,\n    expandRange,\n    AuthenticationFailure,\n    getColorFlags\n} = require('./tools');\n\nconst imapCommands = require('./imap-commands.js');\n\nconst CONNECT_TIMEOUT = 90 * 1000;\nconst GREETING_TIMEOUT = 16 * 1000;\nconst UPGRADE_TIMEOUT = 10 * 1000;\n\nconst SOCKET_TIMEOUT = 5 * 60 * 1000;\n\nconst states = {\n    NOT_AUTHENTICATED: 0x01,\n    AUTHENTICATED: 0x02,\n    SELECTED: 0x03,\n    LOGOUT: 0x04\n};\n\n/**\n * @typedef {Object} MailboxObject\n * @global\n * @property {String} path mailbox path\n * @property {String} delimiter mailbox path delimiter, usually \".\" or \"/\"\n * @property {Set<string>} flags list of flags for this mailbox\n * @property {String} [specialUse] one of special-use flags (if applicable): \"\\All\", \"\\Archive\", \"\\Drafts\", \"\\Flagged\", \"\\Junk\", \"\\Sent\", \"\\Trash\". Additionally INBOX has non-standard \"\\Inbox\" flag set\n * @property {Boolean} listed `true` if mailbox was found from the output of LIST command\n * @property {Boolean} subscribed `true` if mailbox was found from the output of LSUB command\n * @property {Set<string>} permanentFlags A Set of flags available to use in this mailbox. If it is not set or includes special flag \"\\\\\\*\" then any flag can be used.\n * @property {String} [mailboxId] unique mailbox ID if server has `OBJECTID` extension enabled\n * @property {BigInt} [highestModseq] latest known modseq value if server has CONDSTORE or XYMHIGHESTMODSEQ enabled\n * @property {String} [noModseq] if true then the server doesn't support the persistent storage of mod-sequences for the mailbox\n * @property {BigInt} uidValidity Mailbox `UIDVALIDITY` value\n * @property {Number} uidNext Next predicted UID\n * @property {Number} exists Messages in this folder\n */\n\n/**\n * @typedef {Object} MailboxLockObject\n * @global\n * @property {String} path mailbox path\n * @property {Function} release Release current lock\n * @example\n * let lock = await client.getMailboxLock('INBOX');\n * try {\n *   // do something in the mailbox\n * } finally {\n *   // use finally{} to make sure lock is released even if exception occurs\n *   lock.release();\n * }\n */\n\n/**\n * Client and server identification object, where key is one of RFC2971 defined [data fields](https://tools.ietf.org/html/rfc2971#section-3.3) (but not limited to).\n * @typedef {Object} IdInfoObject\n * @global\n * @property {String} [name] Name of the program\n * @property {String} [version] Version number of the program\n * @property {String} [os] Name of the operating system\n * @property {String} [vendor] Vendor of the client/server\n * @property {String} ['support-url'] URL to contact for support\n * @property {Date} [date] Date program was released\n */\n\n/**\n * IMAP client class for accessing IMAP mailboxes\n *\n * @class\n * @extends EventEmitter\n */\nclass ImapFlow extends EventEmitter {\n    /**\n     * Current module version as a static class property\n     * @property {String} version Module version\n     * @static\n     */\n    static version = packageInfo.version;\n\n    /**\n     * IMAP connection options\n     *\n     * @property {String} host\n     *     Hostname of the IMAP server.\n     *\n     * @property {Number} port\n     *     Port number for the IMAP server.\n     *\n     * @property {Boolean} [secure=false]\n     *     If `true`, establishes the connection directly over TLS (commonly on port 993).\n     *     If `false`, a plain (unencrypted) connection is used first and, if possible, the connection is upgraded to STARTTLS.\n     *\n     * @property {Boolean} [doSTARTTLS=undefined]\n     *     Determines whether to upgrade the connection to TLS via STARTTLS:\n     *       - **true**: Start unencrypted and upgrade to TLS using STARTTLS before authentication.\n     *         The connection fails if the server does not support STARTTLS or the upgrade fails.\n     *         Note that `secure=true` combined with `doSTARTTLS=true` is invalid.\n     *       - **false**: Never use STARTTLS, even if the server advertises support.\n     *         This is useful if the server has a broken TLS setup.\n     *         Combined with `secure=false`, this results in a fully unencrypted connection.\n     *         Make sure you warn users about the security risks.\n     *       - **undefined** (default): If `secure=false` (default), attempt to upgrade to TLS via STARTTLS before authentication if the server supports it. If not supported, continue unencrypted. This may expose the connection to a downgrade attack.\n     *\n     * @property {String} [servername]\n     *     Server name for SNI or when using an IP address as `host`.\n     *\n     * @property {Boolean} [disableCompression=false]\n     *     If `true`, the client does not attempt to use the COMPRESS=DEFLATE extension.\n     *\n     * @property {Object} auth\n     *     Authentication options. Authentication occurs automatically during {@link connect}.\n     *\n     * @property {String} auth.user\n     *     Username for authentication.\n     *\n     * @property {String} [auth.pass]\n     *     Password for regular authentication.\n     *\n     * @property {String} [auth.accessToken]\n     *     OAuth2 access token, if using OAuth2 authentication.\n     *\n     * @property {String} [auth.loginMethod]\n     *     Optional login method for password-based authentication (e.g., \"LOGIN\", \"AUTH=LOGIN\", or \"AUTH=PLAIN\").\n     *     If not set, ImapFlow chooses based on available mechanisms.\n     *\n     * @property {IdInfoObject} [clientInfo]\n     *     Client identification info sent to the server (via the ID command).\n     *\n     * @property {Boolean} [disableAutoIdle=false]\n     *     If `true`, do not start IDLE automatically. Useful when only specific operations are needed.\n     *\n     * @property {Object} [tls]\n     *     Additional TLS options. For details, see [Node.js TLS connect](https://nodejs.org/api/tls.html#tls_tls_connect_options_callback).\n     *\n     * @property {Boolean} [tls.rejectUnauthorized=true]\n     *     If `false`, allows self-signed or expired certificates.\n     *\n     * @property {String} [tls.minVersion='TLSv1.2']\n     *     Minimum accepted TLS version (e.g., `'TLSv1.2'`).\n     *\n     * @property {Number} [tls.minDHSize=1024]\n     *     Minimum size (in bits) of the DH parameter for TLS connections.\n     *\n     * @property {Object|Boolean} [logger]\n     *     Custom logger instance with `debug(obj)`, `info(obj)`, `warn(obj)`, and `error(obj)` methods.\n     *     If `false`, logging is disabled. If not provided, ImapFlow logs to console in [pino format](https://getpino.io/).\n     *\n     * @property {Boolean} [logRaw=false]\n     *     If `true`, logs all raw data (read and written) in base64 encoding. You can pipe such logs to [eerawlog](https://github.com/postalsys/eerawlog) command for readable output.\n     *\n     * @property {Boolean} [emitLogs=false]\n     *     If `true`, emits `'log'` events with the same data passed to the logger.\n     *\n     * @property {Boolean} [verifyOnly=false]\n     *     If `true`, disconnects after successful authentication without performing other actions.\n     *\n     * @property {String} [proxy]\n     *     Proxy URL. Supports HTTP CONNECT (`http://`, `https://`) and SOCKS (`socks://`, `socks4://`, `socks5://`).\n     *\n     * @property {Boolean} [qresync=false]\n     *     If `true`, enables QRESYNC support so that EXPUNGE notifications include `uid` instead of `seq`.\n     *\n     * @property {Number} [maxIdleTime]\n     *     If set, breaks and restarts IDLE every `maxIdleTime` milliseconds.\n     *\n     * @property {String} [missingIdleCommand=\"NOOP\"]\n     *     Command to use if the server does not support IDLE.\n     *\n     * @property {Boolean} [disableBinary=false]\n     *     If `true`, ignores the BINARY extension for FETCH and APPEND operations.\n     *\n     * @property {Boolean} [disableAutoEnable=false]\n     *     If `true`, do not automatically enable supported IMAP extensions.\n     *\n     * @property {Number} [connectionTimeout=90000]\n     *     Maximum time (in milliseconds) to wait for the connection to establish. Defaults to 90 seconds.\n     *\n     * @property {Number} [greetingTimeout=16000]\n     *     Maximum time (in milliseconds) to wait for the server greeting after a connection is established. Defaults to 16 seconds.\n     *\n     * @property {Number} [socketTimeout=300000]\n     *     Maximum period of inactivity (in milliseconds) before terminating the connection. Defaults to 5 minutes.\n     */\n\n    constructor(options) {\n        super({ captureRejections: true });\n\n        this.options = options || {};\n\n        /**\n         * Instance ID for logs\n         * @type {String}\n         */\n        this.id = this.options.id || this.getRandomId();\n\n        this.clientInfo = Object.assign(\n            {\n                name: packageInfo.name,\n                version: packageInfo.version,\n                vendor: 'Postal Systems',\n                'support-url': 'https://github.com/postalsys/imapflow/issues'\n            },\n            this.options.clientInfo || {}\n        );\n\n        /**\n         * Server identification info. Available after successful `connect()`.\n         * If server does not provide identification info then this value is `null`.\n         * @example\n         * await client.connect();\n         * console.log(client.serverInfo.vendor);\n         * @type {IdInfoObject|null}\n         */\n        this.serverInfo = null; //updated by ID\n\n        this.log = this.getLogger();\n\n        /**\n         * Is the connection currently encrypted or not\n         * @type {Boolean}\n         */\n        this.secureConnection = !!this.options.secure;\n\n        this.port = Number(this.options.port) || (this.secureConnection ? 993 : 110);\n        this.host = this.options.host || 'localhost';\n        this.servername = this.options.servername ? this.options.servername : !net.isIP(this.host) ? this.host : false;\n\n        if (typeof this.options.secure === 'undefined' && this.port === 993) {\n            // if secure option is not set but port is 465, then default to secure\n            this.secureConnection = true;\n        }\n\n        this.logRaw = this.options.logRaw;\n        this.streamer = new ImapStream({\n            logger: this.log,\n            cid: this.id,\n            logRaw: this.logRaw,\n            secureConnection: this.secureConnection\n        });\n\n        this.reading = false;\n        this.socket = false;\n        this.writeSocket = false;\n\n        this.states = states;\n        this.state = this.states.NOT_AUTHENTICATED;\n\n        this.lockCounter = 0;\n        this.currentLock = false;\n\n        this.tagCounter = 0;\n        this.requestTagMap = new Map();\n        this.requestQueue = [];\n        this.currentRequest = false;\n\n        this.writeBytesCounter = 0;\n\n        this.commandParts = [];\n\n        /**\n         * Active IMAP capabilities. Value is either `true` for togglabe capabilities (eg. `UIDPLUS`)\n         * or a number for capabilities with a value (eg. `APPENDLIMIT`)\n         * @type {Map<string, boolean|number>}\n         */\n        this.capabilities = new Map();\n        this.authCapabilities = new Map();\n\n        this.rawCapabilities = null;\n\n        this.expectCapabilityUpdate = false; // force CAPABILITY after LOGIN\n\n        /**\n         * Enabled capabilities. Usually `CONDSTORE` and `UTF8=ACCEPT` if server supports these.\n         * @type {Set<string>}\n         */\n        this.enabled = new Set();\n\n        /**\n         * Is the connection currently usable or not\n         * @type {Boolean}\n         */\n        this.usable = false;\n\n        /**\n         * Currently authenticated user or `false` if mailbox is not open\n         * or `true` if connection was authenticated by PREAUTH\n         * @type {String|Boolean}\n         */\n        this.authenticated = false;\n\n        /**\n         * Currently selected mailbox or `false` if mailbox is not open\n         * @type {MailboxObject|Boolean}\n         */\n        this.mailbox = false;\n        this.currentSelectCommand = false;\n\n        /**\n         * Is current mailbox idling (`true`) or not (`false`)\n         * @type {Boolean}\n         */\n        this.idling = false;\n\n        this.emitLogs = !!this.options.emitLogs;\n        // ordering number for emitted logs\n        this.lo = 0;\n\n        this.untaggedHandlers = {};\n        this.sectionHandlers = {};\n\n        this.commands = imapCommands;\n\n        this.folders = new Map();\n\n        this.currentLock = false;\n        this.locks = [];\n\n        this.idRequested = false;\n\n        this.maxIdleTime = this.options.maxIdleTime || false;\n        this.missingIdleCommand = (this.options.missingIdleCommand || '').toString().toUpperCase().trim() || 'NOOP';\n\n        this.disableBinary = !!this.options.disableBinary;\n\n        this.streamer.on('error', err => {\n            if (['Z_BUF_ERROR', 'ECONNRESET', 'EPIPE', 'ETIMEDOUT', 'EHOSTUNREACH'].includes(err.code)) {\n                // just close the connection, usually nothing but noise\n                return setImmediate(() => this.close());\n            }\n\n            this.log.error({ err, cid: this.id });\n            setImmediate(() => this.close());\n            this.emitError(err);\n        });\n\n        // Has the `connect` method already been called\n        this._connectCalled = false;\n    }\n\n    emitError(err) {\n        this.emit('error', err);\n    }\n\n    getRandomId() {\n        let rid = BigInt('0x' + crypto.randomBytes(13).toString('hex')).toString(36);\n        if (rid.length < 20) {\n            rid = '0'.repeat(20 - rid.length) + rid;\n        } else if (rid.length > 20) {\n            rid = rid.substr(0, 20);\n        }\n        return rid;\n    }\n\n    write(chunk) {\n        if (this.socket.destroyed) {\n            // do not write after connection end or logout\n            const error = new Error('Socket is already closed');\n            error.code = 'NoConnection';\n            throw error;\n        }\n\n        if (this.state === this.states.LOGOUT) {\n            // should not happen\n            const error = new Error('Can not send data after logged out');\n            error.code = 'StateLogout';\n            throw error;\n        }\n\n        if (this.writeSocket.destroyed) {\n            this.socket.emit('error', 'Write socket destroyed');\n            return;\n        }\n\n        let addLineBreak = !this.commandParts.length;\n        if (typeof chunk === 'string') {\n            if (addLineBreak) {\n                chunk += '\\r\\n';\n            }\n            chunk = Buffer.from(chunk, 'binary');\n        } else if (Buffer.isBuffer(chunk)) {\n            if (addLineBreak) {\n                chunk = Buffer.concat([chunk, Buffer.from('\\r\\n')]);\n            }\n        } else {\n            return false;\n        }\n\n        if (this.logRaw) {\n            this.log.trace({\n                src: 'c',\n                msg: 'write to socket',\n                data: chunk.toString('base64'),\n                compress: !!this._deflate,\n                secure: !!this.secureConnection,\n                cid: this.id\n            });\n        }\n\n        this.writeBytesCounter += chunk.length;\n\n        this.writeSocket.write(chunk);\n    }\n\n    stats(reset) {\n        let result = {\n            sent: this.writeBytesCounter || 0,\n            received: (this.streamer && this.streamer.readBytesCounter) || 0\n        };\n\n        if (reset) {\n            this.writeBytesCounter = 0;\n            if (this.streamer) {\n                this.streamer.readBytesCounter = 0;\n            }\n        }\n\n        return result;\n    }\n\n    async send(data) {\n        if (this.state === this.states.LOGOUT) {\n            // already logged out\n            if (data.tag) {\n                let request = this.requestTagMap.get(data.tag);\n                if (request) {\n                    this.requestTagMap.delete(request.tag);\n                    const error = new Error('Connection not available');\n                    error.code = 'NoConnection';\n                    request.reject(error);\n                }\n            }\n            return;\n        }\n\n        let compiled = await compiler(data, {\n            asArray: true,\n            literalMinus: this.capabilities.has('LITERAL-') || this.capabilities.has('LITERAL+')\n        });\n        this.commandParts = compiled;\n\n        let logCompiled = await compiler(data, {\n            isLogging: true\n        });\n\n        let options = data.options || {};\n\n        this.log.debug({ src: 's', msg: logCompiled.toString(), cid: this.id, comment: options.comment });\n\n        this.write(this.commandParts.shift());\n\n        if (typeof options.onSend === 'function') {\n            options.onSend();\n        }\n    }\n\n    async trySend() {\n        if (this.currentRequest || !this.requestQueue.length) {\n            return;\n        }\n        this.currentRequest = this.requestQueue.shift();\n\n        await this.send({\n            tag: this.currentRequest.tag,\n            command: this.currentRequest.command,\n            attributes: this.currentRequest.attributes,\n            options: this.currentRequest.options\n        });\n    }\n\n    async exec(command, attributes, options) {\n        if (this.socket.destroyed) {\n            let error = new Error('Connection closed');\n            error.code = 'EConnectionClosed';\n            throw error;\n        }\n\n        let tag = (++this.tagCounter).toString(16).toUpperCase();\n\n        options = options || {};\n\n        return new Promise((resolve, reject) => {\n            this.requestTagMap.set(tag, { command, attributes, options, resolve, reject });\n            this.requestQueue.push({ tag, command, attributes, options });\n            this.trySend().catch(err => {\n                this.requestTagMap.delete(tag);\n                reject(err);\n            });\n        });\n    }\n\n    getUntaggedHandler(command, attributes) {\n        if (/^[0-9]+$/.test(command)) {\n            let type = attributes && attributes.length && typeof attributes[0].value === 'string' ? attributes[0].value.toUpperCase() : false;\n            if (type) {\n                // EXISTS, EXPUNGE, RECENT, FETCH etc\n                command = type;\n            }\n        }\n\n        command = command.toUpperCase().trim();\n        if (this.currentRequest && this.currentRequest.options && this.currentRequest.options.untagged && this.currentRequest.options.untagged[command]) {\n            return this.currentRequest.options.untagged[command];\n        }\n\n        if (this.untaggedHandlers[command]) {\n            return this.untaggedHandlers[command];\n        }\n    }\n\n    getSectionHandler(key) {\n        if (this.sectionHandlers[key]) {\n            return this.sectionHandlers[key];\n        }\n    }\n\n    async reader() {\n        let data;\n        while ((data = this.streamer.read()) !== null) {\n            let parsed;\n\n            try {\n                parsed = await parser(data.payload, { literals: data.literals });\n                if (parsed.tag && !['*', '+'].includes(parsed.tag) && parsed.command) {\n                    let payload = { response: parsed.command };\n\n                    if (\n                        parsed.attributes &&\n                        parsed.attributes[0] &&\n                        parsed.attributes[0].section &&\n                        parsed.attributes[0].section[0] &&\n                        parsed.attributes[0].section[0].type === 'ATOM'\n                    ) {\n                        payload.code = parsed.attributes[0].section[0].value;\n                    }\n                    this.emit('response', payload);\n                }\n            } catch (err) {\n                // can not make sense of this\n                this.log.error({ src: 's', msg: data.payload.toString(), err, cid: this.id });\n                data.next();\n                continue;\n            }\n\n            let logCompiled = await compiler(parsed, {\n                isLogging: true\n            });\n\n            if (/^\\d+$/.test(parsed.command) && parsed.attributes && parsed.attributes[0] && parsed.attributes[0].value === 'FETCH') {\n                // too many FETCH responses, might want to filter these out\n                this.log.trace({ src: 's', msg: logCompiled.toString(), cid: this.id, nullBytesRemoved: parsed.nullBytesRemoved });\n            } else {\n                this.log.debug({ src: 's', msg: logCompiled.toString(), cid: this.id, nullBytesRemoved: parsed.nullBytesRemoved });\n            }\n\n            if (parsed.tag === '+' && this.currentRequest && this.currentRequest.options && typeof this.currentRequest.options.onPlusTag === 'function') {\n                await this.currentRequest.options.onPlusTag(parsed);\n                data.next();\n                continue;\n            }\n\n            if (parsed.tag === '+' && this.commandParts.length) {\n                let content = this.commandParts.shift();\n                this.write(content);\n                this.log.debug({ src: 'c', msg: `(* ${content.length}B continuation *)`, cid: this.id });\n                data.next();\n                continue;\n            }\n\n            let section = parsed.attributes && parsed.attributes.length && parsed.attributes[0] && !parsed.attributes[0].value && parsed.attributes[0].section;\n            if (section && section.length && section[0].type === 'ATOM' && typeof section[0].value === 'string') {\n                let sectionHandler = this.getSectionHandler(section[0].value.toUpperCase().trim());\n                if (sectionHandler) {\n                    await sectionHandler(section.slice(1));\n                }\n            }\n\n            if (parsed.tag === '*' && parsed.command) {\n                let untaggedHandler = this.getUntaggedHandler(parsed.command, parsed.attributes);\n                if (untaggedHandler) {\n                    try {\n                        await untaggedHandler(parsed);\n                    } catch (err) {\n                        this.log.warn({ err, cid: this.id });\n                        data.next();\n                        continue;\n                    }\n                }\n            }\n\n            if (this.requestTagMap.has(parsed.tag)) {\n                let request = this.requestTagMap.get(parsed.tag);\n                this.requestTagMap.delete(parsed.tag);\n\n                if (this.currentRequest && this.currentRequest.tag === parsed.tag) {\n                    // send next pending command\n                    this.currentRequest = false;\n                    await this.trySend();\n                }\n\n                switch (parsed.command.toUpperCase()) {\n                    case 'OK':\n                    case 'BYE':\n                        await new Promise(resolve => request.resolve({ response: parsed, next: resolve }));\n                        break;\n\n                    case 'NO':\n                    case 'BAD': {\n                        let txt =\n                            parsed.attributes &&\n                            parsed.attributes\n                                .filter(val => val.type === 'TEXT')\n                                .map(val => val.value.trim())\n                                .join(' ');\n\n                        let err = new Error('Command failed');\n                        err.response = parsed;\n                        err.responseStatus = parsed.command.toUpperCase();\n\n                        try {\n                            err.executedCommand =\n                                parsed.tag +\n                                (\n                                    await compiler(request, {\n                                        isLogging: true\n                                    })\n                                ).toString();\n                        } catch (err) {\n                            // ignore\n                        }\n\n                        if (txt) {\n                            err.responseText = txt;\n\n                            if (err.responseStatus === 'NO' && txt.includes('Some of the requested messages no longer exist')) {\n                                // Treat as successful response\n                                this.log.warn({ msg: 'Partial FETCH response', cid: this.id, err });\n                                await new Promise(resolve => request.resolve({ response: parsed, next: resolve }));\n                                break;\n                            }\n\n                            let throttleDelay = false;\n\n                            // MS365 throttling\n                            // tag BAD Request is throttled. Suggested Backoff Time: 92415 milliseconds\n                            if (/Request is throttled/i.test(txt) && /Backoff Time/i.test(txt)) {\n                                let throttlingMatch = txt.match(/Backoff Time[:=\\s]+(\\d+)/i);\n                                if (throttlingMatch && throttlingMatch[1] && !isNaN(throttlingMatch[1])) {\n                                    throttleDelay = Number(throttlingMatch[1]);\n                                }\n                            }\n\n                            // Wait and return a throttling error\n                            if (throttleDelay) {\n                                err.code = 'ETHROTTLE';\n                                err.throttleReset = throttleDelay;\n\n                                let delayResponse = throttleDelay;\n                                if (delayResponse > 5 * 60 * 1000) {\n                                    // max delay cap\n                                    delayResponse = 5 * 60 * 1000;\n                                }\n\n                                this.log.warn({ msg: 'Throttling detected', cid: this.id, throttleDelay, delayResponse, err });\n                                await new Promise(r => setTimeout(r, delayResponse));\n                            }\n                        }\n\n                        request.reject(err);\n                        break;\n                    }\n\n                    default: {\n                        let err = new Error('Invalid server response');\n                        err.code = 'InvalidResponse';\n                        err.response = parsed;\n                        request.reject(err);\n                        break;\n                    }\n                }\n            }\n\n            data.next();\n        }\n    }\n\n    setEventHandlers() {\n        this.socketReadable = () => {\n            if (!this.reading) {\n                this.reading = true;\n                this.reader()\n                    .catch(err => this.log.error({ err, cid: this.id }))\n                    .finally(() => {\n                        this.reading = false;\n                    });\n            }\n        };\n\n        this.streamer.on('readable', this.socketReadable);\n    }\n\n    setSocketHandlers() {\n        this._socketError =\n            this._socketError ||\n            (err => {\n                this.log.error({ err, cid: this.id });\n                setImmediate(() => this.close());\n                this.emitError(err);\n            });\n        this._socketClose =\n            this._socketClose ||\n            (() => {\n                this.close();\n            });\n        this._socketEnd =\n            this._socketEnd ||\n            (() => {\n                this.close();\n            });\n\n        this._socketTimeout =\n            this._socketTimeout ||\n            (() => {\n                if (this.idling) {\n                    this.run('NOOP')\n                        .then(() => this.idle())\n                        .catch(this._socketError);\n                } else {\n                    this.log.debug({ msg: 'Socket timeout', cid: this.id });\n                    this.close();\n                }\n            });\n\n        this.socket.on('error', this._socketError);\n        this.socket.on('close', this._socketClose);\n        this.socket.on('end', this._socketEnd);\n        this.socket.on('tlsClientError', this._socketError);\n        this.socket.on('timeout', this._socketTimeout);\n\n        this.writeSocket.on('error', this._socketError);\n    }\n\n    clearSocketHandlers() {\n        if (this._socketError) {\n            this.socket.removeListener('error', this._socketError);\n            this.socket.removeListener('tlsClientError', this._socketError);\n        }\n        if (this._socketClose) {\n            this.socket.removeListener('close', this._socketClose);\n        }\n        if (this._socketEnd) {\n            this.socket.removeListener('end', this._socketEnd);\n        }\n    }\n\n    async startSession() {\n        await this.run('CAPABILITY');\n\n        if (this.capabilities.has('ID')) {\n            this.idRequested = await this.run('ID', this.clientInfo);\n        }\n\n        await this.upgradeToSTARTTLS();\n\n        await this.authenticate();\n\n        if (!this.idRequested && this.capabilities.has('ID')) {\n            // re-request ID after LOGIN\n            this.idRequested = await this.run('ID', this.clientInfo);\n        }\n\n        // Make sure we have namespace set. This should also throw if Exchange actually failed authentication\n        let nsResponse = await this.run('NAMESPACE');\n        if (nsResponse && nsResponse.error && nsResponse.status === 'BAD' && /User is authenticated but not connected/i.test(nsResponse.text)) {\n            // Not a NAMESPACE failure but authentication failure, so report as\n            this.authenticated = false;\n            let err = new AuthenticationFailure('Authentication failed');\n            err.response = nsResponse.text;\n            throw err;\n        }\n\n        if (this.options.verifyOnly) {\n            // List all folders and logout\n            if (this.options.includeMailboxes) {\n                this._mailboxList = await this.list();\n            }\n            return await this.logout();\n        }\n\n        // try to use compression (if supported)\n        if (!this.options.disableCompression) {\n            await this.compress();\n        }\n\n        if (!this.options.disableAutoEnable) {\n            // enable extensions if possible\n            await this.run('ENABLE', ['CONDSTORE', 'UTF8=ACCEPT'].concat(this.options.qresync ? 'QRESYNC' : []));\n        }\n\n        this.usable = true;\n    }\n\n    async compress() {\n        if (!(await this.run('COMPRESS'))) {\n            return; // was not able to negotiate compression\n        }\n\n        // create deflate/inflate streams\n        this._deflate = zlib.createDeflateRaw({\n            windowBits: 15\n        });\n        this._inflate = zlib.createInflateRaw();\n\n        // route incoming socket via inflate stream\n        this.socket.unpipe(this.streamer);\n        this.streamer.compress = true;\n        this.socket.pipe(this._inflate).pipe(this.streamer);\n        this._inflate.on('error', err => {\n            this.streamer.emit('error', err);\n        });\n\n        // route outgoing socket via deflate stream\n        this.writeSocket = new PassThrough();\n\n        this.writeSocket.destroySoon = () => {\n            try {\n                if (this.socket) {\n                    this.socket.destroy();\n                }\n                this.writeSocket.end();\n            } catch (err) {\n                this.log.error({ err, info: 'Failed to destroy PassThrough socket', cid: this.id });\n                throw err;\n            }\n        };\n\n        Object.defineProperty(this.writeSocket, 'destroyed', {\n            get: () => this.socket.destroyed\n        });\n\n        // we need to force flush deflated data to socket so we can't\n        // use normal pipes for this.writeSocket -> this._deflate -> this.socket\n        let reading = false;\n        let readNext = () => {\n            reading = true;\n\n            let chunk;\n            while ((chunk = this.writeSocket.read()) !== null) {\n                if (this._deflate && this._deflate.write(chunk) === false) {\n                    return this._deflate.once('drain', readNext);\n                }\n            }\n\n            // flush data to socket\n            if (this._deflate) {\n                this._deflate.flush();\n            }\n\n            reading = false;\n        };\n\n        this.writeSocket.on('readable', () => {\n            if (!reading) {\n                readNext();\n            }\n        });\n        this.writeSocket.on('error', err => {\n            this.socket.emit('error', err);\n        });\n\n        this._deflate.pipe(this.socket);\n        this._deflate.on('error', err => {\n            this.socket.emit('error', err);\n        });\n    }\n\n    _failSTARTTLS() {\n        if (this.options.doSTARTTLS === true) {\n            // STARTTLS configured as requirement\n            let err = new Error('Server does not support STARTTLS');\n            err.tlsFailed = true;\n            throw err;\n        } else {\n            // Opportunistic STARTTLS. But it's not possible right now.\n            // Attention: Could be a downgrade attack.\n            return false;\n        }\n    }\n\n    /**\n     * Tries to upgrade the connection to TLS using STARTTLS.\n     * @throws if STARTTLS is required, but not possible.\n     * @returns {boolean} true, if the connection is now protected by TLS, either direct TLS or STARTTLS.\n     */\n    async upgradeToSTARTTLS() {\n        if (this.options.doSTARTTLS === true && this.options.secure === true) {\n            throw new Error('Misconfiguration: Cannot set both secure=true for TLS and doSTARTTLS=true for STARTTLS.');\n        }\n\n        if (this.secureConnection) {\n            // Already using direct TLS. No need for STARTTLS.\n            return true;\n        }\n\n        if (this.options.doSTARTTLS === false) {\n            // STARTTLS explictly disabled by config\n            return false;\n        }\n\n        if (!this.capabilities.has('STARTTLS')) {\n            return this._failSTARTTLS();\n        }\n\n        this.expectCapabilityUpdate = true;\n        let canUpgrade = await this.run('STARTTLS');\n        if (!canUpgrade) {\n            return this._failSTARTTLS();\n        }\n\n        this.socket.unpipe(this.streamer);\n        let upgraded = await new Promise((resolve, reject) => {\n            let socketPlain = this.socket;\n            let opts = Object.assign(\n                {\n                    socket: this.socket,\n                    servername: this.servername,\n                    port: this.port\n                },\n                this.options.tls || {}\n            );\n            this.clearSocketHandlers();\n\n            socketPlain.once('error', err => {\n                clearTimeout(this.connectTimeout);\n                clearTimeout(this.upgradeTimeout);\n                if (!this.upgrading) {\n                    // don't care anymore\n                    return;\n                }\n                setImmediate(() => this.close());\n                this.upgrading = false;\n                err.tlsFailed = true;\n                reject(err);\n            });\n\n            this.upgradeTimeout = setTimeout(() => {\n                if (!this.upgrading) {\n                    return;\n                }\n                setImmediate(() => this.close());\n                let err = new Error('Failed to upgrade connection in required time');\n                err.tlsFailed = true;\n                err.code = 'UPGRADE_TIMEOUT';\n                reject(err);\n            }, UPGRADE_TIMEOUT);\n\n            this.upgrading = true;\n            this.socket = tls.connect(opts, () => {\n                clearTimeout(this.upgradeTimeout);\n                if (this.isClosed) {\n                    // not sure if this is possible?\n                    return this.close();\n                }\n\n                this.secureConnection = true;\n                this.upgrading = false;\n                this.streamer.secureConnection = true;\n                this.socket.pipe(this.streamer);\n                this.tls = typeof this.socket.getCipher === 'function' ? this.socket.getCipher() : false;\n                if (this.tls) {\n                    this.tls.authorized = this.socket.authorized;\n                    this.log.info({\n                        src: 'tls',\n                        msg: 'Established TLS session',\n                        cid: this.id,\n                        authorized: this.tls.authorized,\n                        algo: this.tls.standardName || this.tls.name,\n                        version: this.tls.version\n                    });\n                }\n\n                return resolve(true);\n            });\n\n            this.writeSocket = this.socket;\n\n            this.setSocketHandlers();\n        });\n\n        if (upgraded && this.expectCapabilityUpdate) {\n            await this.run('CAPABILITY');\n        }\n\n        return upgraded;\n    }\n\n    async setAuthenticationState() {\n        this.state = this.states.AUTHENTICATED;\n        this.authenticated = true;\n        if (this.expectCapabilityUpdate) {\n            // update capabilities\n            await this.run('CAPABILITY');\n        }\n    }\n\n    async authenticate() {\n        if (this.state === this.states.LOGOUT) {\n            throw new AuthenticationFailure('Already logged out');\n        }\n\n        if (this.state !== this.states.NOT_AUTHENTICATED) {\n            // nothing to do here, usually happens with PREAUTH greeting\n            return true;\n        }\n\n        if (!this.options.auth) {\n            throw new AuthenticationFailure('Please configure the login');\n        }\n\n        this.expectCapabilityUpdate = true;\n\n        let loginMethod = (this.options.auth.loginMethod || '').toString().trim().toUpperCase();\n        if (!loginMethod && /\\\\|\\//.test(this.options.auth.user)) {\n            // Special override for MS Exchange when authenticating as some other user or non-email account\n            loginMethod = 'LOGIN';\n        }\n\n        if (this.options.auth.accessToken) {\n            this.authenticated = await this.run('AUTHENTICATE', this.options.auth.user, { accessToken: this.options.auth.accessToken });\n        } else if (this.options.auth.pass) {\n            if ((this.capabilities.has('AUTH=LOGIN') || this.capabilities.has('AUTH=PLAIN')) && loginMethod !== 'LOGIN') {\n                this.authenticated = await this.run('AUTHENTICATE', this.options.auth.user, { password: this.options.auth.pass, loginMethod });\n            } else {\n                if (this.capabilities.has('LOGINDISABLED')) {\n                    throw new AuthenticationFailure('Login is disabled');\n                }\n                this.authenticated = await this.run('LOGIN', this.options.auth.user, this.options.auth.pass);\n            }\n        } else {\n            throw new AuthenticationFailure('No password configured');\n        }\n\n        if (this.authenticated) {\n            this.log.info({\n                src: 'auth',\n                msg: 'User authenticated',\n                cid: this.id,\n                user: this.options.auth.user\n            });\n            await this.setAuthenticationState();\n            return true;\n        }\n\n        throw new AuthenticationFailure('No matching authentication method');\n    }\n\n    async initialOK(message) {\n        this.greeting = (message.attributes || [])\n            .filter(entry => entry.type === 'TEXT')\n            .map(entry => entry.value)\n            .filter(entry => entry)\n            .join('');\n\n        clearTimeout(this.greetingTimeout);\n        this.untaggedHandlers.OK = null;\n        this.untaggedHandlers.PREAUTH = null;\n\n        if (this.isClosed) {\n            return;\n        }\n\n        // get out of current parsing \"thread\", so do not await for startSession\n        this.startSession()\n            .then(() => {\n                if (typeof this.initialResolve === 'function') {\n                    let resolve = this.initialResolve;\n                    this.initialResolve = false;\n                    this.initialReject = false;\n                    return resolve();\n                }\n            })\n            .catch(err => {\n                this.log.error({ err, cid: this.id });\n\n                if (typeof this.initialReject === 'function') {\n                    clearTimeout(this.greetingTimeout);\n                    let reject = this.initialReject;\n                    this.initialResolve = false;\n                    this.initialReject = false;\n                    return reject(err);\n                }\n\n                setImmediate(() => this.close());\n            });\n    }\n\n    async initialPREAUTH() {\n        clearTimeout(this.greetingTimeout);\n        this.untaggedHandlers.OK = null;\n        this.untaggedHandlers.PREAUTH = null;\n\n        if (this.isClosed) {\n            return;\n        }\n\n        this.state = this.states.AUTHENTICATED;\n\n        // get out of current parsing \"thread\", so do not await for startSession\n        this.startSession()\n            .then(() => {\n                if (typeof this.initialResolve === 'function') {\n                    let resolve = this.initialResolve;\n                    this.initialResolve = false;\n                    this.initialReject = false;\n                    return resolve();\n                }\n            })\n            .catch(err => {\n                this.log.error({ err, cid: this.id });\n\n                if (typeof this.initialReject === 'function') {\n                    clearTimeout(this.greetingTimeout);\n                    let reject = this.initialReject;\n                    this.initialResolve = false;\n                    this.initialReject = false;\n                    return reject(err);\n                }\n\n                setImmediate(() => this.close());\n            });\n    }\n\n    async serverBye() {\n        this.untaggedHandlers.BYE = null;\n        this.state = this.states.LOGOUT;\n    }\n\n    async sectionCapability(section) {\n        this.rawCapabilities = section;\n        this.capabilities = updateCapabilities(section);\n\n        if (this.capabilities) {\n            for (let [capa] of this.capabilities) {\n                if (/^AUTH=/i.test(capa) && !this.authCapabilities.has(capa.toUpperCase())) {\n                    this.authCapabilities.set(capa.toUpperCase(), false);\n                }\n            }\n        }\n\n        if (this.expectCapabilityUpdate) {\n            this.expectCapabilityUpdate = false;\n        }\n    }\n\n    async untaggedCapability(untagged) {\n        this.rawCapabilities = untagged.attributes;\n        this.capabilities = updateCapabilities(untagged.attributes);\n\n        if (this.capabilities) {\n            for (let [capa] of this.capabilities) {\n                if (/^AUTH=/i.test(capa) && !this.authCapabilities.has(capa.toUpperCase())) {\n                    this.authCapabilities.set(capa.toUpperCase(), false);\n                }\n            }\n        }\n\n        if (this.expectCapabilityUpdate) {\n            this.expectCapabilityUpdate = false;\n        }\n    }\n\n    async untaggedExists(untagged) {\n        if (!this.mailbox) {\n            // mailbox closed, ignore\n            return;\n        }\n\n        if (!untagged || !untagged.command || isNaN(untagged.command)) {\n            return;\n        }\n\n        let count = Number(untagged.command);\n        if (count === this.mailbox.exists) {\n            // nothing changed?\n            return;\n        }\n\n        // keep exists up to date\n        let prevCount = this.mailbox.exists;\n        this.mailbox.exists = count;\n        this.emit('exists', {\n            path: this.mailbox.path,\n            count,\n            prevCount\n        });\n    }\n\n    async untaggedExpunge(untagged) {\n        if (!this.mailbox) {\n            // mailbox closed, ignore\n            return;\n        }\n\n        if (!untagged || !untagged.command || isNaN(untagged.command)) {\n            return;\n        }\n\n        let seq = Number(untagged.command);\n        if (seq && seq <= this.mailbox.exists) {\n            this.mailbox.exists--;\n            let payload = {\n                path: this.mailbox.path,\n                seq,\n                vanished: false\n            };\n\n            if (typeof this.options.expungeHandler === 'function') {\n                try {\n                    await this.options.expungeHandler(payload);\n                } catch (err) {\n                    this.log.error({ msg: 'Failed to notify expunge event', payload, error: err, cid: this.id });\n                }\n            } else {\n                this.emit('expunge', payload);\n            }\n        }\n    }\n\n    async untaggedVanished(untagged, mailbox) {\n        mailbox = mailbox || this.mailbox;\n        if (!mailbox) {\n            // mailbox closed, ignore\n            return;\n        }\n\n        let tags = [];\n        let uids = false;\n\n        if (untagged.attributes.length > 1 && Array.isArray(untagged.attributes[0])) {\n            tags = untagged.attributes[0].map(entry => (typeof entry.value === 'string' ? entry.value.toUpperCase() : false)).filter(value => value);\n            untagged.attributes.shift();\n        }\n\n        if (untagged.attributes[0] && typeof untagged.attributes[0].value === 'string') {\n            uids = untagged.attributes[0].value;\n        }\n\n        let uidList = expandRange(uids);\n\n        for (let uid of uidList) {\n            let payload = {\n                path: mailbox.path,\n                uid,\n                vanished: true,\n                earlier: tags.includes('EARLIER')\n            };\n\n            if (typeof this.options.expungeHandler === 'function') {\n                try {\n                    await this.options.expungeHandler(payload);\n                } catch (err) {\n                    this.log.error({ msg: 'Failed to notify expunge event', payload, error: err, cid: this.id });\n                }\n            } else {\n                this.emit('expunge', payload);\n            }\n        }\n    }\n\n    async untaggedFetch(untagged, mailbox) {\n        mailbox = mailbox || this.mailbox;\n        if (!mailbox) {\n            // mailbox closed, ignore\n            return;\n        }\n\n        let message = await formatMessageResponse(untagged, mailbox);\n        if (message.flags) {\n            let updateEvent = {\n                path: mailbox.path,\n                seq: message.seq\n            };\n\n            if (message.uid) {\n                updateEvent.uid = message.uid;\n            }\n\n            if (message.modseq) {\n                updateEvent.modseq = message.modseq;\n            }\n\n            updateEvent.flags = message.flags;\n\n            if (message.flagColor) {\n                updateEvent.flagColor = message.flagColor;\n            }\n\n            this.emit('flags', updateEvent);\n        }\n    }\n\n    async ensureSelectedMailbox(path) {\n        if (!path) {\n            return false;\n        }\n\n        if ((!this.mailbox && path) || (this.mailbox && path && !comparePaths(this, this.mailbox.path, path))) {\n            return await this.mailboxOpen(path);\n        }\n\n        return true;\n    }\n\n    async resolveRange(range, options) {\n        if (typeof range === 'number' || typeof range === 'bigint') {\n            range = range.toString();\n        }\n\n        // special case, some servers allow this, some do not, so replace it with the last known EXISTS value\n        if (range === '*') {\n            if (!this.mailbox.exists) {\n                return false;\n            }\n            range = this.mailbox.exists.toString();\n            options.uid = false; // sequence query\n        }\n\n        if (range && typeof range === 'object' && !Array.isArray(range)) {\n            if (range.all && Object.keys(range).length === 1) {\n                range = '1:*';\n            } else if (range.uid && Object.keys(range).length === 1) {\n                range = range.uid;\n                options.uid = true;\n            } else {\n                // resolve range by searching\n                options.uid = true; // force UIDs instead of sequence numbers\n                range = await this.run('SEARCH', range, options);\n                if (range && range.length) {\n                    range = packMessageRange(range);\n                }\n            }\n        }\n\n        if (Array.isArray(range)) {\n            range = range.join(',');\n        }\n\n        if (!range) {\n            return false;\n        }\n\n        return range;\n    }\n\n    autoidle() {\n        clearTimeout(this.idleStartTimer);\n        if (this.options.disableAutoIdle || this.state !== this.states.SELECTED) {\n            return;\n        }\n        this.idleStartTimer = setTimeout(() => {\n            this.idle().catch(err => this.log.warn({ err, cid: this.id }));\n        }, 15 * 1000);\n    }\n\n    // PUBLIC API METHODS\n\n    /**\n     * Initiates a connection against IMAP server. Throws if anything goes wrong. This is something you have to call before you can run any IMAP commands\n     *\n     * @returns {Promise<void>}\n     * @throws Will throw an error if connection or authentication fails\n     * @example\n     * let client = new ImapFlow({...});\n     * await client.connect();\n     */\n    async connect() {\n        if (this._connectCalled) {\n            // Prevent re-using ImapFlow instances by allowing to call connect just once.\n            throw new Error('Can not re-use ImapFlow instance');\n        }\n        this._connectCalled = true;\n\n        let connector = this.secureConnection ? tls : net;\n\n        let opts = Object.assign(\n            {\n                host: this.host,\n                servername: this.servername,\n                port: this.port\n            },\n            this.options.tls || {}\n        );\n\n        this.untaggedHandlers.OK = (...args) => this.initialOK(...args);\n        this.untaggedHandlers.BYE = (...args) => this.serverBye(...args);\n        this.untaggedHandlers.PREAUTH = (...args) => this.initialPREAUTH(...args);\n\n        this.untaggedHandlers.CAPABILITY = (...args) => this.untaggedCapability(...args);\n        this.sectionHandlers.CAPABILITY = (...args) => this.sectionCapability(...args);\n\n        this.untaggedHandlers.EXISTS = (...args) => this.untaggedExists(...args);\n        this.untaggedHandlers.EXPUNGE = (...args) => this.untaggedExpunge(...args);\n\n        // these methods take an optional second argument, so make sure that some random IMAP tag is not used as the second argument\n        this.untaggedHandlers.FETCH = untagged => this.untaggedFetch(untagged);\n        this.untaggedHandlers.VANISHED = untagged => this.untaggedVanished(untagged);\n\n        let socket = false;\n        if (this.options.proxy) {\n            try {\n                socket = await proxyConnection(this.log, this.options.proxy, this.host, this.port);\n                if (!socket) {\n                    throw new Error('Failed to setup proxy connection');\n                }\n            } catch (err) {\n                let error = new Error('Failed to setup proxy connection');\n                error.code = err.code || 'ProxyError';\n                error._err = err;\n                this.log.error({ error, cid: this.id });\n                throw error;\n            }\n        }\n\n        await new Promise((resolve, reject) => {\n            this.connectTimeout = setTimeout(() => {\n                let err = new Error('Failed to establish connection in required time');\n                err.code = 'CONNECT_TIMEOUT';\n                err.details = {\n                    connectionTimeout: this.options.connectionTimeout || CONNECT_TIMEOUT\n                };\n                this.log.error({ err, cid: this.id });\n                setImmediate(() => this.close());\n                reject(err);\n            }, this.options.connectionTimeout || CONNECT_TIMEOUT);\n\n            let onConnect = () => {\n                clearTimeout(this.connectTimeout);\n                this.socket.setKeepAlive(true, 5 * 1000);\n                this.socket.setTimeout(this.options.socketTimeout || SOCKET_TIMEOUT);\n\n                this.greetingTimeout = setTimeout(() => {\n                    let err = new Error(`Failed to receive greeting from server in required time${!this.secureConnection ? '. Maybe should use TLS?' : ''}`);\n                    err.code = 'GREETING_TIMEOUT';\n                    err.details = {\n                        greetingTimeout: this.options.greetingTimeout || GREETING_TIMEOUT\n                    };\n                    this.log.error({ err, cid: this.id });\n                    setImmediate(() => this.close());\n                    reject(err);\n                }, this.options.greetingTimeout || GREETING_TIMEOUT);\n\n                this.tls = typeof this.socket.getCipher === 'function' ? this.socket.getCipher() : false;\n\n                let logInfo = {\n                    src: 'connection',\n                    msg: `Established ${this.tls ? 'secure ' : ''}TCP connection`,\n                    cid: this.id,\n                    secure: !!this.tls,\n                    host: this.host,\n                    servername: this.servername,\n                    port: this.socket.remotePort,\n                    address: this.socket.remoteAddress,\n                    localAddress: this.socket.localAddress,\n                    localPort: this.socket.localPort\n                };\n\n                if (this.tls) {\n                    logInfo.authorized = this.tls.authorized = this.socket.authorized;\n                    logInfo.algo = this.tls.standardName || this.tls.name;\n                    logInfo.version = this.tls.version;\n                }\n\n                this.log.info(logInfo);\n\n                this.setSocketHandlers();\n                this.socket.pipe(this.streamer);\n\n                // executed by initial \"* OK\"\n                this.initialResolve = resolve;\n                this.initialReject = reject;\n            };\n\n            if (socket) {\n                // socket is already established via proxy\n                if (this.secureConnection) {\n                    // TLS socket requires a handshake\n                    opts.socket = socket;\n                    this.socket = connector.connect(opts, onConnect);\n                } else {\n                    // cleartext socket is already usable\n                    this.socket = socket;\n                    setImmediate(onConnect);\n                }\n            } else {\n                this.socket = connector.connect(opts, onConnect);\n            }\n\n            this.writeSocket = this.socket;\n\n            this.socket.on('error', err => {\n                clearTimeout(this.connectTimeout);\n                clearTimeout(this.greetingTimeout);\n                setImmediate(() => this.close());\n                this.log.error({ err, cid: this.id });\n                reject(err);\n            });\n\n            this.setEventHandlers();\n        });\n    }\n\n    /**\n     * Graceful connection close by sending logout command to server. TCP connection is closed once command is finished.\n     *\n     * @return {Promise<void>}\n     * @example\n     * let client = new ImapFlow({...});\n     * await client.connect();\n     * ...\n     * await client.logout();\n     */\n    async logout() {\n        return await this.run('LOGOUT');\n    }\n\n    /**\n     * Closes TCP connection without notifying the server.\n     *\n     * @example\n     * let client = new ImapFlow({...});\n     * await client.connect();\n     * ...\n     * client.close();\n     */\n    close() {\n        // clear pending timers\n        clearTimeout(this.idleStartTimer);\n        clearTimeout(this.upgradeTimeout);\n        clearTimeout(this.connectTimeout);\n\n        this.usable = false;\n        this.idling = false;\n\n        if (typeof this.initialReject === 'function' && !this.options.verifyOnly) {\n            clearTimeout(this.greetingTimeout);\n            let reject = this.initialReject;\n            this.initialResolve = false;\n            this.initialReject = false;\n            let err = new Error('Unexpected close');\n            err.code = `ClosedAfterConnect${this.secureConnection ? 'TLS' : 'Text'}`;\n            // still has to go through the logic below\n            setImmediate(() => reject(err));\n        }\n\n        if (typeof this.preCheck === 'function') {\n            this.preCheck().catch(err => this.log.warn({ err, cid: this.id }));\n        }\n\n        // reject command that is currently processed\n        if (this.currentRequest && this.requestTagMap.has(this.currentRequest.tag)) {\n            let request = this.requestTagMap.get(this.currentRequest.tag);\n            if (request) {\n                this.requestTagMap.delete(request.tag);\n                const error = new Error('Connection not available');\n                error.code = 'NoConnection';\n                request.reject(error);\n            }\n            this.currentRequest = false;\n        }\n\n        // reject all other pending commands\n        while (this.requestQueue.length) {\n            let req = this.requestQueue.shift();\n            if (req && this.requestTagMap.has(req.tag)) {\n                let request = this.requestTagMap.get(req.tag);\n                if (request) {\n                    this.requestTagMap.delete(request.tag);\n                    const error = new Error('Connection not available');\n                    error.code = 'NoConnection';\n                    request.reject(error);\n                }\n            }\n        }\n\n        this.state = this.states.LOGOUT;\n        if (this.isClosed) {\n            return;\n        }\n        this.isClosed = true;\n\n        if (this.writeSocket && !this.writeSocket.destroyed) {\n            try {\n                this.writeSocket.destroy();\n            } catch (err) {\n                this.log.error({ err, cid: this.id });\n            }\n        }\n\n        if (this.socket && !this.socket.destroyed && this.writeSocket !== this.socket) {\n            try {\n                this.socket.destroy();\n            } catch (err) {\n                this.log.error({ err, cid: this.id });\n            }\n        }\n\n        this.log.trace({ msg: 'Connection closed', cid: this.id });\n        this.emit('close');\n    }\n\n    /**\n     * @typedef {Object} QuotaResponse\n     * @global\n     * @property {String} path=INBOX mailbox path this quota applies to\n     * @property {Object} [storage] Storage quota if provided by server\n     * @property {Number} [storage.used] used storage in bytes\n     * @property {Number} [storage.limit] total storage available\n     * @property {Object} [messages] Message count quota if provided by server\n     * @property {Number} [messages.used] stored messages\n     * @property {Number} [messages.limit] maximum messages allowed\n     */\n\n    /**\n     * Returns current quota\n     *\n     * @param {String} [path] Optional mailbox path if you want to check quota for specific folder\n     * @returns {Promise<QuotaResponse|Boolean>} Quota information or `false` if QUTOA extension is not supported or requested path does not exist\n     *\n     * @example\n     * let quota = await client.getQuota();\n     * console.log(quota.storage.used, quota.storage.available)\n     */\n    async getQuota(path) {\n        path = path || 'INBOX';\n        return await this.run('QUOTA', path);\n    }\n\n    /**\n     * @typedef {Object} ListResponse\n     * @global\n     * @property {String} path mailbox path (unicode string)\n     * @property {String} pathAsListed mailbox path as listed in the LIST/LSUB response\n     * @property {String} name mailbox name (last part of path after delimiter)\n     * @property {String} delimiter mailbox path delimiter, usually \".\" or \"/\"\n     * @property {String[]} parent An array of parent folder names. All names are in unicode\n     * @property {String} parentPath Same as `parent`, but as a complete string path (unicode string)\n     * @property {Set<string>} flags a set of flags for this mailbox\n     * @property {String} specialUse one of special-use flags (if applicable): \"\\All\", \"\\Archive\", \"\\Drafts\", \"\\Flagged\", \"\\Junk\", \"\\Sent\", \"\\Trash\". Additionally INBOX has non-standard \"\\Inbox\" flag set\n     * @property {Boolean} listed `true` if mailbox was found from the output of LIST command\n     * @property {Boolean} subscribed `true` if mailbox was found from the output of LSUB command\n     * @property {StatusObject} [status] If `statusQuery` was used, then this value includes the status response\n     */\n\n    /**\n     * @typedef {Object} ListOptions\n     * @global\n     * @property {Object} [statusQuery] request status items for every listed entry\n     * @property {Boolean} [statusQuery.messages] if `true` request count of messages\n     * @property {Boolean} [statusQuery.recent] if `true` request count of messages with \\\\Recent tag\n     * @property {Boolean} [statusQuery.uidNext] if `true` request predicted next UID\n     * @property {Boolean} [statusQuery.uidValidity] if `true` request mailbox `UIDVALIDITY` value\n     * @property {Boolean} [statusQuery.unseen] if `true` request count of unseen messages\n     * @property {Boolean} [statusQuery.highestModseq] if `true` request last known modseq value\n     * @property {Object} [specialUseHints] set specific paths as special use folders, this would override special use flags provided from the server\n     * @property {String} [specialUseHints.sent] Path to \"Sent Mail\" folder\n     * @property {String} [specialUseHints.trash] Path to \"Trash\" folder\n     * @property {String} [specialUseHints.junk] Path to \"Junk Mail\" folder\n     * @property {String} [specialUseHints.drafts] Path to \"Drafts\" folder\n     */\n\n    /**\n     * Lists available mailboxes as an Array\n     *\n     * @param {ListOptions} [options] defines additional listing options\n     * @returns {Promise<ListResponse[]>} An array of ListResponse objects\n     *\n     * @example\n     * let list = await client.list();\n     * list.forEach(mailbox=>console.log(mailbox.path));\n     */\n    async list(options) {\n        options = options || {};\n        let folders = await this.run('LIST', '', '*', options);\n        this.folders = new Map(folders.map(folder => [folder.path, folder]));\n        return folders;\n    }\n\n    /**\n     * @typedef {Object} ListTreeResponse\n     * @global\n     * @property {Boolean} root If `true` then this is root node without any additional properties besides *folders*\n     * @property {String} path mailbox path\n     * @property {String} name mailbox name (last part of path after delimiter)\n     * @property {String} delimiter mailbox path delimiter, usually \".\" or \"/\"\n     * @property {String[]} flags list of flags for this mailbox\n     * @property {String} specialUse one of special-use flags (if applicable): \"\\All\", \"\\Archive\", \"\\Drafts\", \"\\Flagged\", \"\\Junk\", \"\\Sent\", \"\\Trash\". Additionally INBOX has non-standard \"\\Inbox\" flag set\n     * @property {Boolean} listed `true` if mailbox was found from the output of LIST command\n     * @property {Boolean} subscribed `true` if mailbox was found from the output of LSUB command\n     * @property {Boolean} disabled If `true` then this mailbox can not be selected in the UI\n     * @property {ListTreeResponse[]} folders An array of subfolders\n     */\n\n    /**\n     * Lists available mailboxes as a tree structured object\n     *\n     * @param {ListOptions} [options] defines additional listing options\n     * @returns {Promise<ListTreeResponse>} Tree structured object\n     *\n     * @example\n     * let tree = await client.listTree();\n     * tree.folders.forEach(mailbox=>console.log(mailbox.path));\n     */\n    async listTree(options) {\n        options = options || {};\n        let folders = await this.run('LIST', '', '*', options);\n        this.folders = new Map(folders.map(folder => [folder.path, folder]));\n        return getFolderTree(folders);\n    }\n\n    /**\n     * Performs a no-op call against server\n     * @returns {Promise<void>}\n     */\n    async noop() {\n        await this.run('NOOP');\n    }\n\n    /**\n     * @typedef {Object} MailboxCreateResponse\n     * @global\n     * @property {String} path full mailbox path\n     * @property {String} [mailboxId] unique mailbox ID if server supports `OBJECTID` extension (currently Yahoo and some others)\n     * @property {Boolean} created If `true` then mailbox was created otherwise it already existed\n     */\n\n    /**\n     * Creates a new mailbox folder and sets up subscription for the created mailbox. Throws on error.\n     *\n     * @param {string|array} path Full mailbox path. Unicode is allowed. If value is an array then it is joined using current delimiter symbols. Namespace prefix is added automatically if required.\n     * @returns {Promise<MailboxCreateResponse>} Mailbox info\n     * @throws Will throw an error if mailbox can not be created\n     *\n     * @example\n     * let info = await client.mailboxCreate(['parent', 'child']);\n     * console.log(info.path);\n     * // \"INBOX.parent.child\" // assumes \"INBOX.\" as namespace prefix and \".\" as delimiter\n     */\n    async mailboxCreate(path) {\n        return await this.run('CREATE', path);\n    }\n\n    /**\n     * @typedef {Object} MailboxRenameResponse\n     * @global\n     * @property {String} path full mailbox path that was renamed\n     * @property {String} newPath new full mailbox path\n     */\n\n    /**\n     * Renames a mailbox. Throws on error.\n     *\n     * @param {string|array} path  Path for the mailbox to rename. Unicode is allowed. If value is an array then it is joined using current delimiter symbols. Namespace prefix is added automatically if required.\n     * @param {string|array} newPath New path for the mailbox\n     * @returns {Promise<MailboxRenameResponse>} Mailbox info\n     * @throws Will throw an error if mailbox does not exist or can not be renamed\n     *\n     * @example\n     * let info = await client.mailboxRename('parent.child', 'Important stuff ❗️');\n     * console.log(info.newPath);\n     * // \"INBOX.Important stuff ❗️\" // assumes \"INBOX.\" as namespace prefix\n     */\n    async mailboxRename(path, newPath) {\n        return await this.run('RENAME', path, newPath);\n    }\n\n    /**\n     * @typedef {Object} MailboxDeleteResponse\n     * @global\n     * @property {String} path full mailbox path that was deleted\n     */\n\n    /**\n     * Deletes a mailbox. Throws on error.\n     *\n     * @param {string|array} path Path for the mailbox to delete. Unicode is allowed. If value is an array then it is joined using current delimiter symbols. Namespace prefix is added automatically if required.\n     * @returns {Promise<MailboxDeleteResponse>} Mailbox info\n     * @throws Will throw an error if mailbox does not exist or can not be deleted\n     *\n     * @example\n     * let info = await client.mailboxDelete('Important stuff ❗️');\n     * console.log(info.path);\n     * // \"INBOX.Important stuff ❗️\" // assumes \"INBOX.\" as namespace prefix\n     */\n    async mailboxDelete(path) {\n        return await this.run('DELETE', path);\n    }\n\n    /**\n     * Subscribes to a mailbox\n     *\n     * @param {string|array} path Path for the mailbox to subscribe to. Unicode is allowed. If value is an array then it is joined using current delimiter symbols. Namespace prefix is added automatically if required.\n     * @returns {Promise<Boolean>} `true` if subscription operation succeeded, `false` otherwise\n     *\n     * @example\n     * await client.mailboxSubscribe('Important stuff ❗️');\n     */\n    async mailboxSubscribe(path) {\n        return await this.run('SUBSCRIBE', path);\n    }\n\n    /**\n     * Unsubscribes from a mailbox\n     *\n     * @param {string|array} path **Path for the mailbox** to unsubscribe from. Unicode is allowed. If value is an array then it is joined using current delimiter symbols. Namespace prefix is added automatically if required.\n     * @returns {Promise<Boolean>} `true` if unsubscription operation succeeded, `false` otherwise\n     *\n     * @example\n     * await client.mailboxUnsubscribe('Important stuff ❗️');\n     */\n    async mailboxUnsubscribe(path) {\n        return await this.run('UNSUBSCRIBE', path);\n    }\n\n    /**\n     * Opens a mailbox to access messages. You can perform message operations only against an opened mailbox.\n     * Using {@link module:imapflow~ImapFlow#getMailboxLock|getMailboxLock()} instead of `mailboxOpen()` is preferred. Both do the same thing\n     * but next `getMailboxLock()` call is not executed until previous one is released.\n     *\n     * @param {string|array} path **Path for the mailbox** to open\n     * @param {Object} [options] optional options\n     * @param {Boolean} [options.readOnly=false] If `true` then opens mailbox in read-only mode. You can still try to perform write operations but these would probably fail.\n     * @returns {Promise<MailboxObject>} Mailbox info\n     * @throws Will throw an error if mailbox does not exist or can not be opened\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('Important stuff ❗️');\n     * console.log(mailbox.exists);\n     * // 125\n     */\n    async mailboxOpen(path, options) {\n        return await this.run('SELECT', path, options);\n    }\n\n    /**\n     * Closes a previously opened mailbox\n     *\n     * @returns {Promise<Boolean>} Did the operation succeed or not\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * await client.mailboxClose();\n     */\n    async mailboxClose() {\n        return await this.run('CLOSE');\n    }\n\n    /**\n     * @typedef {Object} StatusObject\n     * @global\n     * @property {String} path full mailbox path that was checked\n     * @property {Number} [messages] Count of messages\n     * @property {Number} [recent] Count of messages with \\\\Recent tag\n     * @property {Number} [uidNext] Predicted next UID\n     * @property {BigInt} [uidValidity] Mailbox `UIDVALIDITY` value\n     * @property {Number} [unseen] Count of unseen messages\n     * @property {BigInt} [highestModseq] Last known modseq value (if CONDSTORE extension is enabled)\n     */\n\n    /**\n     * Requests the status of the indicated mailbox. Only requested status values will be returned.\n     *\n     * @param {String} path mailbox path to check for (unicode string)\n     * @param {Object} query defines requested status items\n     * @param {Boolean} query.messages if `true` request count of messages\n     * @param {Boolean} query.recent if `true` request count of messages with \\\\Recent tag\n     * @param {Boolean} query.uidNext if `true` request predicted next UID\n     * @param {Boolean} query.uidValidity if `true` request mailbox `UIDVALIDITY` value\n     * @param {Boolean} query.unseen if `true` request count of unseen messages\n     * @param {Boolean} query.highestModseq if `true` request last known modseq value\n     * @returns {Promise<StatusObject>} status of the indicated mailbox\n     *\n     * @example\n     * let status = await client.status('INBOX', {unseen: true});\n     * console.log(status.unseen);\n     * // 123\n     */\n    async status(path, query) {\n        return await this.run('STATUS', path, query);\n    }\n\n    /**\n     * Starts listening for new or deleted messages from the currently opened mailbox. Only required if {@link ImapFlow#disableAutoIdle} is set to `true`\n     * otherwise IDLE is started by default on connection inactivity. NB! If `idle()` is called manually then it does not\n     * return until IDLE is finished which means you would have to call some other command out of scope.\n     *\n     * @returns {Promise<Boolean>} Did the operation succeed or not\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     *\n     * await client.idle();\n     */\n    async idle() {\n        if (!this.idling) {\n            return await this.run('IDLE', this.maxIdleTime);\n        }\n    }\n\n    /**\n     * Sequence range string. Separate different values with commas, number ranges with colons and use \\\\* as the placeholder for the newest message in mailbox\n     * @typedef {String} SequenceString\n     * @global\n     * @example\n     * \"1:*\" // for all messages\n     * \"1,2,3\" // for messages 1, 2 and 3\n     * \"1,2,4:6\" // for messages 1,2,4,5,6\n     * \"*\" // for the newest message\n     */\n\n    /**\n     * IMAP search query options. By default all conditions must match. In case of `or` query term at least one condition must match.\n     * @typedef {Object} SearchObject\n     * @global\n     * @property {SequenceString} [seq] message ordering sequence range\n     * @property {Boolean} [answered] Messages with (value is `true`) or without (value is `false`) \\\\Answered flag\n     * @property {Boolean} [deleted] Messages with (value is `true`) or without (value is `false`) \\\\Deleted flag\n     * @property {Boolean} [draft] Messages with (value is `true`) or without (value is `false`) \\\\Draft flag\n     * @property {Boolean} [flagged] Messages with (value is `true`) or without (value is `false`) \\\\Flagged flag\n     * @property {Boolean} [seen] Messages with (value is `true`) or without (value is `false`) \\\\Seen flag\n     * @property {Boolean} [all] If `true` matches all messages\n     * @property {Boolean} [new] If `true` matches messages that have the \\\\Recent flag set but not the \\\\Seen flag\n     * @property {Boolean} [old] If `true` matches messages that do not have the \\\\Recent flag set\n     * @property {Boolean} [recent] If `true` matches messages that have the \\\\Recent flag set\n     * @property {String} [from] Matches From: address field\n     * @property {String} [to] Matches To: address field\n     * @property {String} [cc] Matches Cc: address field\n     * @property {String} [bcc] Matches Bcc: address field\n     * @property {String} [body] Matches message body\n     * @property {String} [subject] Matches message subject\n     * @property {Number} [larger] Matches messages larger than value\n     * @property {Number} [smaller] Matches messages smaller than value\n     * @property {SequenceString} [uid] UID sequence range\n     * @property {BigInt} [modseq] Matches messages with modseq higher than value\n     * @property {String} [emailId] unique email ID. Only used if server supports `OBJECTID` or `X-GM-EXT-1` extensions\n     * @property {String} [threadId] unique thread ID. Only used if server supports `OBJECTID` or `X-GM-EXT-1` extensions\n     * @property {Date|string} [before] Matches messages received before date\n     * @property {Date|string} [on] Matches messages received on date (ignores time)\n     * @property {Date|string} [since] Matches messages received after date\n     * @property {Date|string} [sentBefore] Matches messages sent before date\n     * @property {Date|string} [sentOn] Matches messages sent on date (ignores time)\n     * @property {Date|string} [sentSince] Matches messages sent after date\n     * @property {String} [keyword] Matches messages that have the custom flag set\n     * @property {String} [unKeyword] Matches messages that do not have the custom flag set\n     * @property {Object.<string, Boolean|String>} [header] Matches messages with header key set if value is `true` (**NB!** not supported by all servers) or messages where header partially matches a string value\n     * @property {SearchObject[]} [or] An array of 2 or more {@link SearchObject} objects. At least on of these must match\n     */\n\n    /**\n     * Sets flags for a message or message range\n     *\n     * @param {SequenceString | Number[] | SearchObject} range Range to filter the messages\n     * @param {string[]} Array of flags to set. Only flags that are permitted to set are used, other flags are ignored\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n     * @param {BigInt} [options.unchangedSince] If set then only messages with a lower or equal `modseq` value are updated. Ignored if server does not support `CONDSTORE` extension.\n     * @param {Boolean} [options.useLabels=false] If true then update Gmail labels instead of message flags\n     * @returns {Promise<Boolean>} Did the operation succeed or not\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // mark all unseen messages as seen (and remove other flags)\n     * await client.messageFlagsSet({seen: false}, ['\\Seen]);\n     */\n    async messageFlagsSet(range, flags, options) {\n        options = options || {};\n\n        range = await this.resolveRange(range, options);\n        if (!range) {\n            return false;\n        }\n\n        let queryOpts = Object.assign(\n            {\n                operation: 'set'\n            },\n            options\n        );\n\n        return await this.run('STORE', range, flags, queryOpts);\n    }\n\n    /**\n     * Adds flags for a message or message range\n     *\n     * @param {SequenceString | Number[] | SearchObject} range Range to filter the messages\n     * @param {string[]} Array of flags to set. Only flags that are permitted to set are used, other flags are ignored\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n     * @param {BigInt} [options.unchangedSince] If set then only messages with a lower or equal `modseq` value are updated. Ignored if server does not support `CONDSTORE` extension.\n     * @param {Boolean} [options.useLabels=false] If true then update Gmail labels instead of message flags\n     * @returns {Promise<Boolean>} Did the operation succeed or not\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // mark all unseen messages as seen (and keep other flags as is)\n     * await client.messageFlagsAdd({seen: false}, ['\\Seen]);\n     */\n    async messageFlagsAdd(range, flags, options) {\n        options = options || {};\n\n        range = await this.resolveRange(range, options);\n        if (!range) {\n            return false;\n        }\n\n        let queryOpts = Object.assign(\n            {\n                operation: 'add'\n            },\n            options\n        );\n\n        return await this.run('STORE', range, flags, queryOpts);\n    }\n\n    /**\n     * Remove specific flags from a message or message range\n     *\n     * @param {SequenceString | Number[] | SearchObject} range Range to filter the messages\n     * @param {string[]} Array of flags to remove. Only flags that are permitted to set are used, other flags are ignored\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n     * @param {BigInt} [options.unchangedSince] If set then only messages with a lower or equal `modseq` value are updated. Ignored if server does not support `CONDSTORE` extension.\n     * @param {Boolean} [options.useLabels=false] If true then update Gmail labels instead of message flags\n     * @returns {Promise<Boolean>} Did the operation succeed or not\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // mark all seen messages as unseen by removing \\\\Seen flag\n     * await client.messageFlagsRemove({seen: true}, ['\\Seen]);\n     */\n    async messageFlagsRemove(range, flags, options) {\n        options = options || {};\n\n        range = await this.resolveRange(range, options);\n        if (!range) {\n            return false;\n        }\n\n        let queryOpts = Object.assign(\n            {\n                operation: 'remove'\n            },\n            options\n        );\n\n        return await this.run('STORE', range, flags, queryOpts);\n    }\n\n    /**\n     * Sets a colored flag for an email. Only supported by mail clients like Apple Mail\n     *\n     * @param {SequenceString | Number[] | SearchObject} range Range to filter the messages\n     * @param {string} The color to set. One of 'red', 'orange', 'yellow', 'green', 'blue', 'purple', and 'grey'\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n     * @param {BigInt} [options.unchangedSince] If set then only messages with a lower or equal `modseq` value are updated. Ignored if server does not support `CONDSTORE` extension.\n     * @returns {Promise<Boolean>} Did the operation succeed or not\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // add a purple flag for all emails\n     * await client.setFlagColor('1:*', 'Purple');\n     */\n    async setFlagColor(range, color, options) {\n        options = options || {};\n\n        range = await this.resolveRange(range, options);\n        if (!range) {\n            return false;\n        }\n\n        let flagChanges = getColorFlags(color);\n        if (!flagChanges) {\n            return false;\n        }\n\n        let addResults;\n        let removeResults;\n\n        if (flagChanges.add && flagChanges.add.length) {\n            let queryOpts = Object.assign(\n                {\n                    operation: 'add'\n                },\n                options,\n                {\n                    useLabels: false, // override if set\n                    // prevent triggering a premature Flags change notification\n                    silent: flagChanges.remove && flagChanges.remove.length\n                }\n            );\n\n            addResults = await this.run('STORE', range, flagChanges.add, queryOpts);\n        }\n\n        if (flagChanges.remove && flagChanges.remove.length) {\n            let queryOpts = Object.assign(\n                {\n                    operation: 'remove'\n                },\n                options,\n                { useLabels: false } // override if set\n            );\n\n            removeResults = await this.run('STORE', range, flagChanges.remove, queryOpts);\n        }\n\n        return addResults || removeResults || false;\n    }\n\n    /**\n     * Delete messages from the currently opened mailbox. Method does not indicate info about deleted messages,\n     * instead you should be using {@link ImapFlow#expunge} event for this\n     *\n     * @param {SequenceString | Number[] | SearchObject} range Range to filter the messages\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n     * @returns {Promise<Boolean>} Did the operation succeed or not\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // delete all seen messages\n     * await client.messageDelete({seen: true});\n     */\n    async messageDelete(range, options) {\n        options = options || {};\n        range = await this.resolveRange(range, options);\n        if (!range) {\n            return false;\n        }\n        return await this.run('EXPUNGE', range, options);\n    }\n\n    /**\n     * @typedef {Object} AppendResponseObject\n     * @global\n     * @property {String} destination full mailbox path where the message was uploaded to\n     * @property {BigInt} [uidValidity] mailbox `UIDVALIDITY` if server has `UIDPLUS` extension enabled\n     * @property {Number} [uid] UID of the uploaded message if server has `UIDPLUS` extension enabled\n     * @property {Number} [seq] sequence number of the uploaded message if path is currently selected mailbox\n     */\n\n    /**\n     * Appends a new message to a mailbox\n     *\n     * @param {String} path Mailbox path to upload the message to (unicode string)\n     * @param {string|Buffer} content RFC822 formatted email message\n     * @param {string[]} [flags] an array of flags to be set for the uploaded message\n     * @param {Date|string} [idate=now] internal date to be set for the message\n     * @returns {Promise<AppendResponseObject>} info about uploaded message\n     *\n     * @example\n     * await client.append('INBOX', rawMessageBuffer, ['\\\\Seen'], new Date(2000, 1, 1));\n     */\n    async append(path, content, flags, idate) {\n        let response = await this.run('APPEND', path, content, flags, idate);\n\n        if (!response) {\n            return false;\n        }\n\n        return response;\n    }\n\n    /**\n     * @typedef {Object} CopyResponseObject\n     * @global\n     * @property {String} path path of source mailbox\n     * @property {String} destination path of destination mailbox\n     * @property {BigInt} [uidValidity] destination mailbox `UIDVALIDITY` if server has `UIDPLUS` extension enabled\n     * @property {Map<number, number>} [uidMap] Map of UID values (if server has `UIDPLUS` extension enabled) where key is UID in source mailbox and value is the UID for the same message in destination mailbox\n     */\n\n    /**\n     * Copies messages from current mailbox to destination mailbox\n     *\n     * @param {SequenceString | Number[] | SearchObject} range Range of messages to copy\n     * @param {String} destination Mailbox path to copy the messages to\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n     * @returns {Promise<CopyResponseObject>} info about copies messages\n     *\n     * @example\n     * await client.mailboxOpen('INBOX');\n     * // copy all messages to a mailbox called \"Backup\" (must exist)\n     * let result = await client.messageCopy('1:*', 'Backup');\n     * console.log('Copied %s messages', result.uidMap.size);\n     */\n    async messageCopy(range, destination, options) {\n        options = options || {};\n        range = await this.resolveRange(range, options);\n        if (!range) {\n            return false;\n        }\n        return await this.run('COPY', range, destination, options);\n    }\n\n    /**\n     * Moves messages from current mailbox to destination mailbox\n     *\n     * @param {SequenceString | Number[] | SearchObject} range Range of messages to move\n     * @param {String} destination Mailbox path to move the messages to\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID {@link SequenceString} instead of sequence numbers\n     * @returns {Promise<CopyResponseObject>} info about moved messages\n     *\n     * @example\n     * await client.mailboxOpen('INBOX');\n     * // move all messages to a mailbox called \"Trash\" (must exist)\n     * let result = await client.messageMove('1:*', 'Trash');\n     * console.log('Moved %s messages', result.uidMap.size);\n     */\n    async messageMove(range, destination, options) {\n        options = options || {};\n        range = await this.resolveRange(range, options);\n        if (!range) {\n            return false;\n        }\n        return await this.run('MOVE', range, destination, options);\n    }\n\n    /**\n     * Search messages from the currently opened mailbox\n     *\n     * @param {SearchObject} query Query to filter the messages\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then returns UID numbers instead of sequence numbers\n     * @returns {Promise<Number[]>} An array of sequence or UID numbers\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // find all unseen messages\n     * let list = await client.search({seen: false});\n     * // use OR modifier (array of 2 or more search queries)\n     * let list = await client.search({\n     *   seen: false,\n     *   or: [\n     *     {flagged: true},\n     *     {from: 'andris'},\n     *     {subject: 'test'}\n     *   ]});\n     */\n    async search(query, options) {\n        if (!this.mailbox) {\n            // no mailbox selected, nothing to do\n            return;\n        }\n\n        let response = await this.run('SEARCH', query, options);\n\n        if (!response) {\n            return false;\n        }\n\n        return response;\n    }\n\n    /**\n     * @typedef {Object} FetchQueryObject\n     * @global\n     * @property {Boolean} [uid] if `true` then include UID in the response\n     * @property {Boolean} [flags] if `true` then include flags Set in the response. Also adds `flagColor` to the response if the message is flagged.\n     * @property {Boolean} [bodyStructure] if `true` then include parsed BODYSTRUCTURE object in the response\n     * @property {Boolean} [envelope] if `true` then include parsed ENVELOPE object in the response\n     * @property {Boolean} [internalDate] if `true` then include internal date value in the response\n     * @property {Boolean} [size] if `true` then include message size in the response\n     * @property {boolean | Object} [source] if `true` then include full message in the response\n     * @property {Number} [source.start] include full message in the response starting from *start* byte\n     * @property {Number} [source.maxLength] include full message in the response, up to *maxLength* bytes\n     * @property {String} [threadId] if `true` then include thread ID in the response (only if server supports either `OBJECTID` or `X-GM-EXT-1` extensions)\n     * @property {Boolean} [labels] if `true` then include GMail labels in the response (only if server supports `X-GM-EXT-1` extension)\n     * @property {boolean | string[]} [headers] if `true` then includes full headers of the message in the response. If the value is an array of header keys then includes only headers listed in the array\n     * @property {string[]} [bodyParts] An array of BODYPART identifiers to include in the response\n     */\n\n    /**\n     * Parsed email address entry\n     *\n     * @typedef {Object} MessageAddressObject\n     * @global\n     * @property {String} [name] name of the address object (unicode)\n     * @property {String} [address] email address\n     */\n\n    /**\n     * Parsed IMAP ENVELOPE object\n     *\n     * @typedef {Object} MessageEnvelopeObject\n     * @global\n     * @property {Date} [date] header date\n     * @property {String} [subject] message subject (unicode)\n     * @property {String} [messageId] Message ID of the message\n     * @property {String} [inReplyTo] Message ID from In-Reply-To header\n     * @property {MessageAddressObject[]} [from] Array of addresses from the From: header\n     * @property {MessageAddressObject[]} [sender] Array of addresses from the Sender: header\n     * @property {MessageAddressObject[]} [replyTo] Array of addresses from the Reply-To: header\n     * @property {MessageAddressObject[]} [to] Array of addresses from the To: header\n     * @property {MessageAddressObject[]} [cc] Array of addresses from the Cc: header\n     * @property {MessageAddressObject[]} [bcc] Array of addresses from the Bcc: header\n     */\n\n    /**\n     * Parsed IMAP BODYSTRUCTURE object\n     *\n     * @typedef {Object} MessageStructureObject\n     * @global\n     * @property {String} part Body part number. This value can be used to later fetch the contents of this part of the message\n     * @property {String} type Content-Type of this node\n     * @property {Object} [parameters] Additional parameters for Content-Type, eg \"charset\"\n     * @property {String} [id] Content-ID\n     * @property {String} [encoding] Transfer encoding\n     * @property {Number} [size] Expected size of the node\n     * @property {MessageEnvelopeObject} [envelope] message envelope of embedded RFC822 message\n     * @property {String} [disposition] Content disposition\n     * @property {Object} [dispositionParameters] Additional parameters for Content-Disposition\n     * @property {MessageStructureObject[]} childNodes An array of child nodes if this is a multipart node. Not present for normal nodes\n     */\n\n    /**\n     * Fetched message data\n     *\n     * @typedef {Object} FetchMessageObject\n     * @global\n     * @property {Number} seq message sequence number. Always included in the response\n     * @property {Number} uid message UID number. Always included in the response\n     * @property {Buffer} [source] message source for the requested byte range\n     * @property {BigInt} [modseq] message Modseq number. Always included if the server supports CONDSTORE extension\n     * @property {String} [emailId] unique email ID. Always included if server supports `OBJECTID` or `X-GM-EXT-1` extensions\n     * @property {String} [threadid] unique thread ID. Only present if server supports `OBJECTID` or `X-GM-EXT-1` extension\n     * @property {Set<string>} [labels] a Set of labels. Only present if server supports `X-GM-EXT-1` extension\n     * @property {Number} [size] message size\n     * @property {Set<string>} [flags] a set of message flags\n     * @property {String} [flagColor] flag color like \"red\", or \"yellow\". This value is derived from the `flags` Set and it uses the same color rules as Apple Mail\n     * @property {MessageEnvelopeObject} [envelope] message envelope\n     * @property {MessageStructureObject} [bodyStructure] message body structure\n     * @property {Date} [internalDate] message internal date\n     * @property {Map<string, Buffer>} [bodyParts] a Map of message body parts where key is requested part identifier and value is a Buffer\n     * @property {Buffer} [headers] Requested header lines as Buffer\n     */\n\n    /**\n     * Fetch messages from the currently opened mailbox\n     *\n     * @param {SequenceString | Number[] | SearchObject} range Range of messages to fetch\n     * @param {FetchQueryObject} query Fetch query\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID numbers instead of sequence numbers for `range`\n     * @param {BigInt} [options.changedSince] If set then only messages with a higher modseq value are returned. Ignored if server does not support `CONDSTORE` extension.\n     * @param {Boolean} [options.binary=false] If `true` then requests a binary response if the server supports this\n     * @yields {Promise<FetchMessageObject>} Message data object\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // fetch UID for all messages in a mailbox\n     * for await (let msg of client.fetch('1:*', {uid: true})){\n     *     console.log(msg.uid);\n     *     // NB! You can not run any IMAP commands in this loop\n     *     // otherwise you will end up in a deadloop\n     * }\n     */\n    async *fetch(range, query, options) {\n        options = options || {};\n\n        if (!this.mailbox) {\n            // no mailbox selected, nothing to do\n            return;\n        }\n\n        range = await this.resolveRange(range, options);\n        if (!range) {\n            return false;\n        }\n\n        let finished = false;\n        let push = false;\n        let rowQueue = [];\n\n        let getNext = () =>\n            new Promise((resolve, reject) => {\n                let check = () => {\n                    if (rowQueue.length) {\n                        let entry = rowQueue.shift();\n                        if (entry.err) {\n                            return reject(entry.err);\n                        } else {\n                            return resolve(entry.value);\n                        }\n                    }\n\n                    if (finished) {\n                        return resolve(null);\n                    }\n\n                    // wait until data is pushed to queue and try again\n                    push = () => {\n                        push = false;\n                        check();\n                    };\n                };\n                check();\n            });\n\n        this.run('FETCH', range, query, {\n            uid: !!options.uid,\n            binary: options.binary,\n            changedSince: options.changedSince,\n            onUntaggedFetch: (untagged, next) => {\n                rowQueue.push({\n                    value: {\n                        response: untagged,\n                        next\n                    }\n                });\n                if (typeof push === 'function') {\n                    push();\n                }\n            }\n        })\n            .then(() => {\n                finished = true;\n                if (typeof push === 'function') {\n                    push();\n                }\n            })\n            .catch(err => {\n                rowQueue.push({ err });\n                if (typeof push === 'function') {\n                    push();\n                }\n            });\n\n        let res;\n        while ((res = await getNext())) {\n            if (this.isClosed || this.socket.destroyed) {\n                let error = new Error('Connection closed');\n                error.code = 'EConnectionClosed';\n                throw error;\n            }\n\n            if (res !== null) {\n                yield res.response;\n                res.next();\n            }\n        }\n\n        if (!finished) {\n            // FETCH never finished!\n            let error = new Error('FETCH did not finish');\n            error.code = 'ENotFinished';\n            throw error;\n        }\n    }\n\n    /**\n     * Fetch messages from the currently opened mailbox.\n     *\n     * This method will fetch all messages before resolving the promise, unlike .fetch(), which\n     * is an async generator. Do not use large ranges like 1:*, as this might exhaust all available\n     * memory if the mailbox contains a large number of emails.\n     * @param {SequenceString | Number[] | SearchObject} range Range of messages to fetch\n     * @param {FetchQueryObject} query Fetch query\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID numbers instead of sequence numbers for `range`\n     * @param {BigInt} [options.changedSince] If set then only messages with a higher modseq value are returned. Ignored if server does not support `CONDSTORE` extension.\n     * @param {Boolean} [options.binary=false] If `true` then requests a binary response if the server supports this\n     * @returns {Promise<FetchMessageObject[]>} Array of Message data object\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // fetch UID for all messages in a mailbox\n     * const messages = await client.fetchAll('1:*', {uid: true});\n     * for (let msg of messages){\n     *     console.log(msg.uid);\n     * }\n     */\n    async fetchAll(range, query, options) {\n        const results = [];\n        const generator = this.fetch(range, query, options);\n        for await (const message of generator) {\n            results.push(message);\n        }\n        return results;\n    }\n\n    /**\n     * Fetch a single message from the currently opened mailbox\n     *\n     * @param {SequenceString} seq Single UID or sequence number of the message to fetch for\n     * @param {FetchQueryObject} query Fetch query\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID number instead of sequence number for `seq`\n     * @param {Boolean} [options.binary=false] If `true` then requests a binary response if the server supports this\n     * @returns {Promise<FetchMessageObject>} Message data object\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // fetch UID for the last email in the selected mailbox\n     * let lastMsg = await client.fetchOne('*', {uid: true})\n     * console.log(lastMsg.uid);\n     */\n    async fetchOne(seq, query, options) {\n        if (!this.mailbox) {\n            // no mailbox selected, nothing to do\n            return;\n        }\n\n        if (seq === '*') {\n            if (!this.mailbox.exists) {\n                return false;\n            }\n            seq = this.mailbox.exists.toString();\n            options = Object.assign({}, options || {}, { uid: false }); // force into a sequence query\n        }\n\n        let response = await this.run('FETCH', (seq || '').toString(), query, options);\n\n        if (!response || !response.list || !response.list.length) {\n            return false;\n        }\n\n        return response.list[0];\n    }\n\n    /**\n     * @typedef {Object} DownloadObject\n     * @global\n     * @property {Object} meta content metadata\n     * @property {number} meta.expectedSize The fetch response size\n     * @property {String} meta.contentType Content-Type of the streamed file. If part was not set then this value is \"message/rfc822\"\n     * @property {String} [meta.charset] Charset of the body part. Text parts are automatically converted to UTF-8, attachments are kept as is\n     * @property {String} [meta.disposition] Content-Disposition of the streamed file\n     * @property {String} [meta.filename] Filename of the streamed body part\n     * @property {ReadableStream} content Streamed content\n     */\n\n    /**\n     * Download either full rfc822 formatted message or a specific bodystructure part as a Stream.\n     * Bodystructure parts are decoded so the resulting stream is a binary file. Text content\n     * is automatically converted to UTF-8 charset.\n     *\n     * @param {SequenceString} range UID or sequence number for the message to fetch\n     * @param {String} [part] If not set then downloads entire rfc822 formatted message, otherwise downloads specific bodystructure part\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID number instead of sequence number for `range`\n     * @param {number} [options.maxBytes] If set then limits download size to specified bytes\n     * @param {number} [options.chunkSize=65536] How large content parts to ask from the server\n     * @returns {Promise<DownloadObject>} Download data object\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // download body part nr '1.2' from latest message\n     * let {meta, content} = await client.download('*', '1.2');\n     * content.pipe(fs.createWriteStream(meta.filename));\n     */\n    async download(range, part, options) {\n        if (!this.mailbox) {\n            // no mailbox selected, nothing to do\n            return {};\n        }\n\n        options = Object.assign(\n            {\n                chunkSize: 64 * 1024,\n                maxBytes: Infinity\n            },\n            options || {}\n        );\n\n        let hasMore = true;\n        let processed = 0;\n\n        let chunkSize = Number(options.chunkSize) || 64 * 1024;\n        let maxBytes = Number(options.maxBytes) || Infinity;\n\n        let uid = false;\n\n        if (part === '1') {\n            // First part has special conditions for single node emails as\n            // the mime parts for root node are not 1 and 1.MIME but TEXT and HEADERS\n            let response = await this.fetchOne(range, { uid: true, bodyStructure: true }, options);\n\n            if (!response) {\n                return { response: false, chunk: false };\n            }\n\n            if (!uid && response.uid) {\n                uid = response.uid;\n                // force UID from now on even if first range was a sequence number\n                range = uid;\n                options.uid = true;\n            }\n\n            if (!response.bodyStructure.childNodes) {\n                // single text message\n                part = 'TEXT';\n            }\n        }\n\n        let getNextPart = async query => {\n            query = query || {};\n\n            let mimeKey;\n\n            if (!part) {\n                query.source = {\n                    start: processed,\n                    maxLength: chunkSize\n                };\n            } else {\n                part = part.toString().toLowerCase().trim();\n\n                if (!query.bodyParts) {\n                    query.bodyParts = [];\n                }\n\n                if (query.size) {\n                    if (/^[\\d.]+$/.test(part)) {\n                        // fetch meta as well\n                        mimeKey = part + '.mime';\n                        query.bodyParts.push(mimeKey);\n                    } else if (part === 'text') {\n                        mimeKey = 'header';\n                        query.bodyParts.push(mimeKey);\n                    }\n                }\n\n                query.bodyParts.push({\n                    key: part,\n                    start: processed,\n                    maxLength: chunkSize\n                });\n            }\n\n            let response = await this.fetchOne(range, query, options);\n\n            if (!response) {\n                return { response: false, chunk: false };\n            }\n\n            if (!uid && response.uid) {\n                uid = response.uid;\n                // force UID from now on even if first range was a sequence number\n                range = uid;\n                options.uid = true;\n            }\n\n            let chunk = !part ? response.source : response.bodyParts && response.bodyParts.get(part);\n            if (!chunk) {\n                return {};\n            }\n\n            processed += chunk.length;\n            hasMore = chunk.length >= chunkSize;\n\n            let result = { chunk };\n            if (query.size) {\n                result.response = response;\n            }\n\n            if (query.bodyParts) {\n                if (mimeKey === 'header') {\n                    result.mime = response.headers;\n                } else {\n                    result.mime = response.bodyParts.get(mimeKey);\n                }\n            }\n\n            return result;\n        };\n\n        let { response, chunk, mime } = await getNextPart({\n            size: true,\n            uid: true\n        });\n\n        if (!response || !chunk) {\n            // ???\n            return {};\n        }\n\n        let meta = {\n            expectedSize: response.size\n        };\n\n        if (!part) {\n            meta.contentType = 'message/rfc822';\n        } else if (mime) {\n            let headers = new Headers(mime);\n            let contentType = libmime.parseHeaderValue(headers.getFirst('Content-Type'));\n            let transferEncoding = libmime.parseHeaderValue(headers.getFirst('Content-Transfer-Encoding'));\n            let disposition = libmime.parseHeaderValue(headers.getFirst('Content-Disposition'));\n\n            if (contentType.value.toLowerCase().trim()) {\n                meta.contentType = contentType.value.toLowerCase().trim();\n            }\n\n            if (contentType.params.charset) {\n                meta.charset = contentType.params.charset.toLowerCase().trim();\n            }\n\n            if (transferEncoding.value) {\n                meta.encoding = transferEncoding.value\n                    .replace(/\\(.*\\)/g, '')\n                    .toLowerCase()\n                    .trim();\n            }\n\n            if (disposition.value) {\n                meta.disposition = disposition.value.toLowerCase().trim() || false;\n                try {\n                    meta.disposition = libmime.decodeWords(meta.disposition);\n                } catch (err) {\n                    // failed to parse disposition, keep as is (most probably an unknown charset is used)\n                }\n            }\n\n            if (contentType.params.format && contentType.params.format.toLowerCase().trim() === 'flowed') {\n                meta.flowed = true;\n                if (contentType.params.delsp && contentType.params.delsp.toLowerCase().trim() === 'yes') {\n                    meta.delSp = true;\n                }\n            }\n\n            let filename = disposition.params.filename || contentType.params.name || false;\n            if (filename) {\n                try {\n                    filename = libmime.decodeWords(filename);\n                } catch (err) {\n                    // failed to parse filename, keep as is (most probably an unknown charset is used)\n                }\n                meta.filename = filename;\n            }\n        }\n\n        let stream;\n        let output;\n\n        switch (meta.encoding) {\n            case 'base64':\n                output = stream = new libbase64.Decoder();\n                break;\n            case 'quoted-printable':\n                output = stream = new libqp.Decoder();\n                break;\n            default:\n                output = stream = new PassThrough();\n        }\n\n        let isTextNode = ['text/html', 'text/plain', 'text/x-amp-html'].includes(meta.contentType) || (part === '1' && !meta.contentType);\n        if ((!meta.disposition || meta.disposition === 'inline') && isTextNode) {\n            // flowed text\n            if (meta.flowed) {\n                let flowDecoder = new FlowedDecoder({\n                    delSp: meta.delSp\n                });\n                output.on('error', err => {\n                    flowDecoder.emit('error', err);\n                });\n                output = output.pipe(flowDecoder);\n            }\n\n            // not utf-8 text\n            if (meta.charset && !['ascii', 'usascii', 'utf8'].includes(meta.charset.toLowerCase().replace(/[^a-z0-9]+/g, ''))) {\n                try {\n                    let decoder = getDecoder(meta.charset);\n                    output.on('error', err => {\n                        decoder.emit('error', err);\n                    });\n                    output = output.pipe(decoder);\n                    // force to utf-8 for output\n                    meta.charset = 'utf-8';\n                } catch (E) {\n                    // do not decode charset\n                }\n            }\n        }\n\n        let limiter = new LimitedPassthrough({ maxBytes });\n        output.on('error', err => {\n            limiter.emit('error', err);\n        });\n        output = output.pipe(limiter);\n\n        let writeChunk = chunk => {\n            if (limiter.limited) {\n                return true;\n            }\n            return stream.write(chunk);\n        };\n\n        let fetchAllParts = async () => {\n            while (hasMore && !limiter.limited) {\n                let { chunk } = await getNextPart();\n                if (!chunk) {\n                    break;\n                }\n\n                if (writeChunk(chunk) === false) {\n                    await new Promise(resolve => stream.once('drain', resolve));\n                }\n            }\n        };\n\n        setImmediate(() => {\n            writeChunk(chunk);\n            fetchAllParts()\n                .catch(err => stream.emit('error', err))\n                .finally(() => stream.end());\n        });\n\n        return {\n            meta,\n            content: output\n        };\n    }\n\n    /**\n     * Fetch multiple attachments as Buffer values\n     *\n     * @param {SequenceString} range UID or sequence number for the message to fetch\n     * @param {String} parts A list of bodystructure parts\n     * @param {Object} [options]\n     * @param {Boolean} [options.uid] If `true` then uses UID number instead of sequence number for `range`\n     * @returns {Promise<Object>} Download data object\n     *\n     * @example\n     * let mailbox = await client.mailboxOpen('INBOX');\n     * // download body parts '2', and '3' from all messages in the selected mailbox\n     * let response = await client.downloadMany('*', ['2', '3']);\n     * process.stdout.write(response[2].content)\n     * process.stdout.write(response[3].content)\n     */\n    async downloadMany(range, parts, options) {\n        if (!this.mailbox) {\n            // no mailbox selected, nothing to do\n            return {};\n        }\n\n        options = Object.assign(\n            {\n                chunkSize: 64 * 1024,\n                maxBytes: Infinity\n            },\n            options || {}\n        );\n\n        let query = { bodyParts: [] };\n\n        for (let part of parts) {\n            query.bodyParts.push(part + '.mime');\n            query.bodyParts.push(part);\n        }\n\n        let response = await this.fetchOne(range, query, options);\n\n        if (!response || !response.bodyParts) {\n            return { response: false };\n        }\n\n        let data = {};\n\n        for (let [part, content] of response.bodyParts) {\n            let keyParts = part.split('.mime');\n            if (keyParts.length === 1) {\n                // content\n                let key = keyParts[0];\n                if (!data[key]) {\n                    data[key] = { content };\n                } else {\n                    data[key].content = content;\n                }\n            } else if (keyParts.length === 2) {\n                // header\n                let key = keyParts[0];\n                if (!data[key]) {\n                    data[key] = {};\n                }\n                if (!data[key].meta) {\n                    data[key].meta = {};\n                }\n\n                let headers = new Headers(content);\n                let contentType = libmime.parseHeaderValue(headers.getFirst('Content-Type'));\n                let transferEncoding = libmime.parseHeaderValue(headers.getFirst('Content-Transfer-Encoding'));\n                let disposition = libmime.parseHeaderValue(headers.getFirst('Content-Disposition'));\n\n                if (contentType.value.toLowerCase().trim()) {\n                    data[key].meta.contentType = contentType.value.toLowerCase().trim();\n                }\n\n                if (contentType.params.charset) {\n                    data[key].meta.charset = contentType.params.charset.toLowerCase().trim();\n                }\n\n                if (transferEncoding.value) {\n                    data[key].meta.encoding = transferEncoding.value\n                        .replace(/\\(.*\\)/g, '')\n                        .toLowerCase()\n                        .trim();\n                }\n\n                if (disposition.value) {\n                    data[key].meta.disposition = disposition.value.toLowerCase().trim() || false;\n                    try {\n                        data[key].meta.disposition = libmime.decodeWords(data[key].meta.disposition);\n                    } catch (err) {\n                        // failed to parse disposition, keep as is (most probably an unknown charset is used)\n                    }\n                }\n\n                if (contentType.params.format && contentType.params.format.toLowerCase().trim() === 'flowed') {\n                    data[key].meta.flowed = true;\n                    if (contentType.params.delsp && contentType.params.delsp.toLowerCase().trim() === 'yes') {\n                        data[key].meta.delSp = true;\n                    }\n                }\n\n                let filename = disposition.params.filename || contentType.params.name || false;\n                if (filename) {\n                    try {\n                        filename = libmime.decodeWords(filename);\n                    } catch (err) {\n                        // failed to parse filename, keep as is (most probably an unknown charset is used)\n                    }\n                    data[key].meta.filename = filename;\n                }\n            }\n        }\n\n        for (let part of Object.keys(data)) {\n            let meta = data[part].meta;\n\n            switch (meta.encoding) {\n                case 'base64':\n                    data[part].content = data[part].content ? libbase64.decode(data[part].content.toString()) : null;\n                    break;\n                case 'quoted-printable':\n                    data[part].content = data[part].content ? libqp.decode(data[part].content.toString()) : null;\n                    break;\n                default:\n                // keep as is, already a buffer\n            }\n        }\n\n        return data;\n    }\n\n    async run(command, ...args) {\n        command = command.toUpperCase();\n        if (!this.commands.has(command)) {\n            return false;\n        }\n\n        if (this.socket.destroyed) {\n            const error = new Error('Connection not available');\n            error.code = 'NoConnection';\n            throw error;\n        }\n\n        clearTimeout(this.idleStartTimer);\n\n        if (typeof this.preCheck === 'function') {\n            await this.preCheck();\n        }\n\n        let handler = this.commands.get(command);\n\n        let result = await handler(this, ...args);\n\n        if (command !== 'IDLE') {\n            // do not autostart IDLE, if IDLE itself was stopped\n            this.autoidle();\n        }\n\n        return result;\n    }\n\n    async processLocks(force) {\n        if (!force && this.processingLock) {\n            this.log.trace({\n                msg: 'Mailbox locking queued',\n                path: this.mailbox && this.mailbox.path,\n                pending: this.locks.length,\n                idling: this.idling,\n                activeLock: this.currentLock\n                    ? {\n                          lockId: this.currentLock.lockId,\n                          ...(this.currentLock.options?.description && { description: this.currentLock.options?.description })\n                      }\n                    : null\n            });\n            return;\n        }\n\n        if (!this.locks.length) {\n            this.processingLock = false;\n            this.log.trace({\n                msg: 'Mailbox locking queue processed',\n                idling: this.idling\n            });\n            return;\n        }\n\n        this.processingLock = true;\n\n        const release = () => {\n            if (this.currentLock) {\n                this.log.trace({\n                    msg: 'Mailbox lock released',\n                    lockId: this.currentLock.lockId,\n                    path: this.mailbox && this.mailbox.path,\n                    pending: this.locks.length,\n                    idling: this.idling\n                });\n                this.currentLock = false;\n            }\n            this.processLocks(true).catch(err => this.log.error({ err, cid: this.id }));\n        };\n\n        const lock = this.locks.shift();\n        const { resolve, reject, path, options, lockId } = lock;\n\n        if (!this.usable || this.socket.destroyed) {\n            this.log.trace({ msg: 'Failed to acquire mailbox lock', path, lockId, idling: this.idling });\n            // reject all\n            let error = new Error('Connection not available');\n            error.code = 'NoConnection';\n            reject(error);\n            return await this.processLocks(true);\n        }\n\n        if (this.mailbox && this.mailbox.path === path && !!this.mailbox.readOnly === !!options.readOnly) {\n            // nothing to do here, already selected\n            this.log.trace({\n                msg: 'Mailbox lock acquired [existing]',\n                path,\n                lockId,\n                idling: this.idling,\n                ...(options.description && { description: options.description })\n            });\n            this.currentLock = lock;\n            return resolve({ path, release });\n        } else {\n            try {\n                // Try to open. Throws if mailbox does not exists or can't open\n                await this.mailboxOpen(path, options);\n                this.log.trace({\n                    msg: 'Mailbox lock acquired [selected]',\n                    path,\n                    lockId,\n                    idling: this.idling,\n                    ...(options.description && { description: options.description })\n                });\n                this.currentLock = lock;\n                return resolve({ path, release });\n            } catch (err) {\n                if (err.responseStatus === 'NO') {\n                    try {\n                        let folders = await this.run('LIST', '', path, { listOnly: true });\n                        if (!folders || !folders.length) {\n                            err.mailboxMissing = true;\n                        }\n                    } catch (E) {\n                        this.log.trace({ msg: 'Failed to verify failed mailbox', path, err: E });\n                    }\n                }\n\n                this.log.trace({\n                    msg: 'Failed to acquire mailbox lock',\n                    path,\n                    lockId,\n                    idling: this.idling,\n                    ...(options.description && { description: options.description }),\n                    err\n                });\n                reject(err);\n                await this.processLocks(true);\n            }\n        }\n    }\n\n    /**\n     * Opens a mailbox if not already open and returns a lock. Next call to `getMailboxLock()` is queued\n     * until previous lock is released. This is suggested over {@link module:imapflow~ImapFlow#mailboxOpen|mailboxOpen()} as\n     * `getMailboxLock()` gives you a weak transaction while `mailboxOpen()` has no guarantees whatsoever that another\n     * mailbox is opened while you try to call multiple fetch or store commands.\n     *\n     * @param {string|array} path **Path for the mailbox** to open\n     * @param {Object} [options] optional options\n     * @param {Boolean} [options.readOnly=false] If `true` then opens mailbox in read-only mode. You can still try to perform write operations but these would probably fail.\n     * @returns {Promise<MailboxLockObject>} Mailbox lock\n     * @throws Will throw an error if mailbox does not exist or can not be opened\n     *\n     * @example\n     * let lock = await client.getMailboxLock('INBOX');\n     * try {\n     *   // do something in the mailbox\n     * } finally {\n     *   // use finally{} to make sure lock is released even if exception occurs\n     *   lock.release();\n     * }\n     */\n    async getMailboxLock(path, options) {\n        options = options || {};\n\n        path = normalizePath(this, path);\n\n        let lockId = ++this.lockCounter;\n        this.log.trace({\n            msg: 'Requesting lock',\n            path,\n            lockId,\n            ...(options.description && { description: options.description }),\n            activeLock: this.currentLock\n                ? {\n                      lockId: this.currentLock.lockId,\n                      ...(this.currentLock.options?.description && { description: this.currentLock.options?.description })\n                  }\n                : null\n        });\n\n        return await new Promise((resolve, reject) => {\n            this.locks.push({ resolve, reject, path, options, lockId });\n            this.processLocks().catch(err => reject(err));\n        });\n    }\n\n    getLogger() {\n        let mainLogger =\n            this.options.logger && typeof this.options.logger === 'object'\n                ? this.options.logger\n                : logger.child({\n                      component: 'imap-connection',\n                      cid: this.id\n                  });\n\n        let synteticLogger = {};\n        let levels = ['trace', 'debug', 'info', 'warn', 'error', 'fatal'];\n        for (let level of levels) {\n            synteticLogger[level] = (...args) => {\n                // using {logger:false} disables logging\n                if (this.options.logger !== false) {\n                    if (logger)\n                        if (typeof mainLogger[level] !== 'function') {\n                            // we are checking to make sure the level is supported.\n                            // if it isn't supported but the level is error or fatal, log to console anyway.\n                            if (level === 'fatal' || level === 'error') {\n                                console.log(JSON.stringify(...args));\n                            }\n                        } else {\n                            mainLogger[level](...args);\n                        }\n                }\n\n                if (this.emitLogs && args && args[0] && typeof args[0] === 'object') {\n                    let logEntry = Object.assign({ level, t: Date.now(), cid: this.id, lo: ++this.lo }, args[0]);\n                    if (logEntry.err && typeof logEntry.err === 'object') {\n                        let err = logEntry.err;\n                        logEntry.err = {\n                            stack: err.stack\n                        };\n                        // enumerable error fields\n                        Object.keys(err).forEach(key => {\n                            logEntry.err[key] = err[key];\n                        });\n                    }\n                    this.emit('log', logEntry);\n                }\n            };\n        }\n\n        return synteticLogger;\n    }\n\n    unbind() {\n        this.socket.unpipe(this.streamer);\n        if (this._inflate) {\n            this._inflate.unpipe(this.streamer);\n        }\n\n        this.socket.removeListener('error', this._socketError);\n        this.socket.removeListener('close', this._socketClose);\n        this.socket.removeListener('end', this._socketEnd);\n        this.socket.removeListener('tlsClientError', this._socketError);\n        this.socket.removeListener('timeout', this._socketTimeout);\n\n        return {\n            readSocket: this._inflate || this.socket,\n            writeSocket: this.writeSocket || this.socket\n        };\n    }\n}\n\n/**\n * Connection close event. **NB!** ImapFlow does not handle reconnects automatically.\n * So whenever a 'close' event occurs you must create a new connection yourself.\n *\n * @event module:imapflow~ImapFlow#close\n */\n\n/**\n * Error event. In most cases getting an error event also means that connection is closed\n * and pending operations should return with a failure.\n *\n * @event module:imapflow~ImapFlow#error\n * @type {Error}\n * @example\n * client.on('error', err=>{\n *     console.log(`Error occurred: ${err.message}`);\n * });\n */\n\n/**\n * Message count in currently opened mailbox changed\n *\n * @event module:imapflow~ImapFlow#exists\n * @type {Object}\n * @property {String} path mailbox path this event applies to\n * @property {Number} count updated count of messages\n * @property {Number} prevCount message count before this update\n * @example\n * client.on('exists', data=>{\n *     console.log(`Message count in \"${data.path}\" is ${data.count}`);\n * });\n */\n\n/**\n * Deleted message sequence number in currently opened mailbox. One event is fired for every deleted email.\n *\n * @event module:imapflow~ImapFlow#expunge\n * @type {Object}\n * @property {String} path mailbox path this event applies to\n * @property {Number} seq sequence number of deleted message\n * @example\n * client.on('expunge', data=>{\n *     console.log(`Message #${data.seq} was deleted from \"${data.path}\"`);\n * });\n */\n\n/**\n * Flags were updated for a message. Not all servers fire this event.\n *\n * @event module:imapflow~ImapFlow#flags\n * @type {Object}\n * @property {String} path mailbox path this event applies to\n * @property {Number} seq sequence number of updated message\n * @property {Number} [uid] UID number of updated message (if server provided this value)\n * @property {BigInt} [modseq] Updated modseq number for the mailbox (if server provided this value)\n * @property {Set<string>} flags A set of all flags for the updated message\n * @example\n * client.on('flags', data=>{\n *     console.log(`Flag set for #${data.seq} is now \"${Array.from(data.flags).join(', ')}\"`);\n * });\n */\n\n/**\n * Mailbox was opened\n *\n * @event module:imapflow~ImapFlow#mailboxOpen\n * @type {MailboxObject}\n * @example\n * client.on('mailboxOpen', mailbox => {\n *     console.log(`Mailbox ${mailbox.path} was opened`);\n * });\n */\n\n/**\n * Mailbox was closed\n *\n * @event module:imapflow~ImapFlow#mailboxClose\n * @type {MailboxObject}\n * @example\n * client.on('mailboxClose', mailbox => {\n *     console.log(`Mailbox ${mailbox.path} was closed`);\n * });\n */\n\n/**\n * Log event if `emitLogs=true`\n *\n * @event module:imapflow~ImapFlow#log\n * @type {Object}\n * @example\n * client.on('log', entry => {\n *     console.log(`${log.cid} ${log.msg}`);\n * });\n */\n\nmodule.exports.ImapFlow = ImapFlow;\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/imap-flow.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/jp-decoder.js":
|
|
/*!*************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/jp-decoder.js ***!
|
|
\*************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { Transform } = __webpack_require__(/*! stream */ \"stream\");\nconst encodingJapanese = __webpack_require__(/*! encoding-japanese */ \"(rsc)/./node_modules/encoding-japanese/src/index.js\");\n\nclass JPDecoder extends Transform {\n constructor(charset) {\n super();\n\n this.charset = charset;\n this.chunks = [];\n this.chunklen = 0;\n }\n\n _transform(chunk, encoding, done) {\n if (typeof chunk === 'string') {\n chunk = Buffer.from(chunk, encoding);\n }\n\n this.chunks.push(chunk);\n this.chunklen += chunk.length;\n done();\n }\n\n _flush(done) {\n let input = Buffer.concat(this.chunks, this.chunklen);\n try {\n let output = encodingJapanese.convert(input, {\n to: 'UNICODE', // to_encoding\n from: this.charset, // from_encoding\n type: 'string'\n });\n if (typeof output === 'string') {\n output = Buffer.from(output);\n }\n this.push(output);\n } catch (err) {\n // keep as is on errors\n this.push(input);\n }\n\n done();\n }\n}\n\nmodule.exports.JPDecoder = JPDecoder;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2pwLWRlY29kZXIuanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWIsUUFBUSxZQUFZLEVBQUUsbUJBQU8sQ0FBQyxzQkFBUTtBQUN0Qyx5QkFBeUIsbUJBQU8sQ0FBQyw4RUFBbUI7O0FBRXBEO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVU7QUFDVjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBLHdCQUF3QiIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2pwLWRlY29kZXIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCB7IFRyYW5zZm9ybSB9ID0gcmVxdWlyZSgnc3RyZWFtJyk7XG5jb25zdCBlbmNvZGluZ0phcGFuZXNlID0gcmVxdWlyZSgnZW5jb2RpbmctamFwYW5lc2UnKTtcblxuY2xhc3MgSlBEZWNvZGVyIGV4dGVuZHMgVHJhbnNmb3JtIHtcbiAgICBjb25zdHJ1Y3RvcihjaGFyc2V0KSB7XG4gICAgICAgIHN1cGVyKCk7XG5cbiAgICAgICAgdGhpcy5jaGFyc2V0ID0gY2hhcnNldDtcbiAgICAgICAgdGhpcy5jaHVua3MgPSBbXTtcbiAgICAgICAgdGhpcy5jaHVua2xlbiA9IDA7XG4gICAgfVxuXG4gICAgX3RyYW5zZm9ybShjaHVuaywgZW5jb2RpbmcsIGRvbmUpIHtcbiAgICAgICAgaWYgKHR5cGVvZiBjaHVuayA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgICAgIGNodW5rID0gQnVmZmVyLmZyb20oY2h1bmssIGVuY29kaW5nKTtcbiAgICAgICAgfVxuXG4gICAgICAgIHRoaXMuY2h1bmtzLnB1c2goY2h1bmspO1xuICAgICAgICB0aGlzLmNodW5rbGVuICs9IGNodW5rLmxlbmd0aDtcbiAgICAgICAgZG9uZSgpO1xuICAgIH1cblxuICAgIF9mbHVzaChkb25lKSB7XG4gICAgICAgIGxldCBpbnB1dCA9IEJ1ZmZlci5jb25jYXQodGhpcy5jaHVua3MsIHRoaXMuY2h1bmtsZW4pO1xuICAgICAgICB0cnkge1xuICAgICAgICAgICAgbGV0IG91dHB1dCA9IGVuY29kaW5nSmFwYW5lc2UuY29udmVydChpbnB1dCwge1xuICAgICAgICAgICAgICAgIHRvOiAnVU5JQ09ERScsIC8vIHRvX2VuY29kaW5nXG4gICAgICAgICAgICAgICAgZnJvbTogdGhpcy5jaGFyc2V0LCAvLyBmcm9tX2VuY29kaW5nXG4gICAgICAgICAgICAgICAgdHlwZTogJ3N0cmluZydcbiAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgaWYgKHR5cGVvZiBvdXRwdXQgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgICAgICAgICAgb3V0cHV0ID0gQnVmZmVyLmZyb20ob3V0cHV0KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHRoaXMucHVzaChvdXRwdXQpO1xuICAgICAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgICAgICAgIC8vIGtlZXAgYXMgaXMgb24gZXJyb3JzXG4gICAgICAgICAgICB0aGlzLnB1c2goaW5wdXQpO1xuICAgICAgICB9XG5cbiAgICAgICAgZG9uZSgpO1xuICAgIH1cbn1cblxubW9kdWxlLmV4cG9ydHMuSlBEZWNvZGVyID0gSlBEZWNvZGVyO1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/jp-decoder.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/limited-passthrough.js":
|
|
/*!**********************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/limited-passthrough.js ***!
|
|
\**********************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { Transform } = __webpack_require__(/*! stream */ \"stream\");\n\nclass LimitedPassthrough extends Transform {\n constructor(options) {\n super();\n this.options = options || {};\n this.maxBytes = this.options.maxBytes || Infinity;\n this.processed = 0;\n this.limited = false;\n }\n\n _transform(chunk, encoding, done) {\n if (this.limited) {\n return done();\n }\n\n if (this.processed + chunk.length > this.maxBytes) {\n if (this.maxBytes - this.processed < 1) {\n return done();\n }\n\n chunk = chunk.slice(0, this.maxBytes - this.processed);\n }\n\n this.processed += chunk.length;\n if (this.processed >= this.maxBytes) {\n this.limited = true;\n }\n\n this.push(chunk);\n done();\n }\n}\n\nmodule.exports.LimitedPassthrough = LimitedPassthrough;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2xpbWl0ZWQtcGFzc3Rocm91Z2guanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWIsUUFBUSxZQUFZLEVBQUUsbUJBQU8sQ0FBQyxzQkFBUTs7QUFFdEM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLGlDQUFpQyIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2xpbWl0ZWQtcGFzc3Rocm91Z2guanMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCB7IFRyYW5zZm9ybSB9ID0gcmVxdWlyZSgnc3RyZWFtJyk7XG5cbmNsYXNzIExpbWl0ZWRQYXNzdGhyb3VnaCBleHRlbmRzIFRyYW5zZm9ybSB7XG4gICAgY29uc3RydWN0b3Iob3B0aW9ucykge1xuICAgICAgICBzdXBlcigpO1xuICAgICAgICB0aGlzLm9wdGlvbnMgPSBvcHRpb25zIHx8IHt9O1xuICAgICAgICB0aGlzLm1heEJ5dGVzID0gdGhpcy5vcHRpb25zLm1heEJ5dGVzIHx8IEluZmluaXR5O1xuICAgICAgICB0aGlzLnByb2Nlc3NlZCA9IDA7XG4gICAgICAgIHRoaXMubGltaXRlZCA9IGZhbHNlO1xuICAgIH1cblxuICAgIF90cmFuc2Zvcm0oY2h1bmssIGVuY29kaW5nLCBkb25lKSB7XG4gICAgICAgIGlmICh0aGlzLmxpbWl0ZWQpIHtcbiAgICAgICAgICAgIHJldHVybiBkb25lKCk7XG4gICAgICAgIH1cblxuICAgICAgICBpZiAodGhpcy5wcm9jZXNzZWQgKyBjaHVuay5sZW5ndGggPiB0aGlzLm1heEJ5dGVzKSB7XG4gICAgICAgICAgICBpZiAodGhpcy5tYXhCeXRlcyAtIHRoaXMucHJvY2Vzc2VkIDwgMSkge1xuICAgICAgICAgICAgICAgIHJldHVybiBkb25lKCk7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIGNodW5rID0gY2h1bmsuc2xpY2UoMCwgdGhpcy5tYXhCeXRlcyAtIHRoaXMucHJvY2Vzc2VkKTtcbiAgICAgICAgfVxuXG4gICAgICAgIHRoaXMucHJvY2Vzc2VkICs9IGNodW5rLmxlbmd0aDtcbiAgICAgICAgaWYgKHRoaXMucHJvY2Vzc2VkID49IHRoaXMubWF4Qnl0ZXMpIHtcbiAgICAgICAgICAgIHRoaXMubGltaXRlZCA9IHRydWU7XG4gICAgICAgIH1cblxuICAgICAgICB0aGlzLnB1c2goY2h1bmspO1xuICAgICAgICBkb25lKCk7XG4gICAgfVxufVxuXG5tb2R1bGUuZXhwb3J0cy5MaW1pdGVkUGFzc3Rocm91Z2ggPSBMaW1pdGVkUGFzc3Rocm91Z2g7XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/limited-passthrough.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/logger.js":
|
|
/*!*********************************************!*\
|
|
!*** ./node_modules/imapflow/lib/logger.js ***!
|
|
\*********************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst logger = __webpack_require__(/*! pino */ \"(rsc)/./node_modules/pino/pino.js\")();\nlogger.level = 'trace';\nmodule.exports = logger;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2xvZ2dlci5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYixlQUFlLG1CQUFPLENBQUMsK0NBQU07QUFDN0I7QUFDQSIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL2xvZ2dlci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIHN0cmljdCc7XG5cbmNvbnN0IGxvZ2dlciA9IHJlcXVpcmUoJ3Bpbm8nKSgpO1xubG9nZ2VyLmxldmVsID0gJ3RyYWNlJztcbm1vZHVsZS5leHBvcnRzID0gbG9nZ2VyO1xuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/logger.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/proxy-connection.js":
|
|
/*!*******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/proxy-connection.js ***!
|
|
\*******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst httpProxyClient = __webpack_require__(/*! nodemailer/lib/smtp-connection/http-proxy-client */ \"(rsc)/./node_modules/imapflow/node_modules/nodemailer/lib/smtp-connection/http-proxy-client.js\");\nconst { SocksClient } = __webpack_require__(/*! socks */ \"(rsc)/./node_modules/socks/build/index.js\");\nconst util = __webpack_require__(/*! util */ \"util\");\nconst httpProxyClientAsync = util.promisify(httpProxyClient);\nconst dns = (__webpack_require__(/*! dns */ \"dns\").promises);\nconst net = __webpack_require__(/*! net */ \"net\");\n\nconst proxyConnection = async (logger, connectionUrl, host, port) => {\n let proxyUrl = new URL(connectionUrl);\n\n let protocol = proxyUrl.protocol.replace(/:$/, '').toLowerCase();\n\n if (!net.isIP(host)) {\n let resolveResult = await dns.resolve(host);\n if (resolveResult && resolveResult.length) {\n host = resolveResult[0];\n }\n }\n\n switch (protocol) {\n // Connect using a HTTP CONNECT method\n case 'http':\n case 'https': {\n try {\n let socket = await httpProxyClientAsync(proxyUrl.href, port, host);\n if (socket) {\n if (proxyUrl.password) {\n proxyUrl.password = '(hidden)';\n }\n logger.info({\n msg: 'Established a socket via HTTP proxy',\n proxyUrl: proxyUrl.href,\n port,\n host\n });\n }\n return socket;\n } catch (err) {\n if (proxyUrl.password) {\n proxyUrl.password = '(hidden)';\n }\n logger.error({\n msg: 'Failed to establish a socket via HTTP proxy',\n proxyUrl: proxyUrl.href,\n port,\n host,\n err\n });\n throw err;\n }\n }\n\n // SOCKS proxy\n case 'socks':\n case 'socks5':\n case 'socks4':\n case 'socks4a': {\n let proxyType = Number(protocol.replace(/\\D/g, '')) || 5;\n\n let targetHost = proxyUrl.hostname;\n if (!net.isIP(targetHost)) {\n let resolveResult = await dns.resolve(targetHost);\n if (resolveResult && resolveResult.length) {\n targetHost = resolveResult[0];\n }\n }\n\n let connectionOpts = {\n proxy: {\n host: targetHost,\n port: Number(proxyUrl.port) || 1080,\n type: proxyType\n },\n destination: {\n host,\n port\n },\n command: 'connect',\n set_tcp_nodelay: true\n };\n\n if (proxyUrl.username || proxyUrl.password) {\n connectionOpts.proxy.userId = proxyUrl.username;\n connectionOpts.proxy.password = proxyUrl.password;\n }\n\n try {\n const info = await SocksClient.createConnection(connectionOpts);\n if (info && info.socket) {\n if (proxyUrl.password) {\n proxyUrl.password = '(hidden)';\n }\n logger.info({\n msg: 'Established a socket via SOCKS proxy',\n proxyUrl: proxyUrl.href,\n port,\n host\n });\n }\n return info.socket;\n } catch (err) {\n if (proxyUrl.password) {\n proxyUrl.password = '(hidden)';\n }\n logger.error({\n msg: 'Failed to establish a socket via SOCKS proxy',\n proxyUrl: proxyUrl.href,\n port,\n host,\n err\n });\n throw err;\n }\n }\n }\n};\n\nmodule.exports = { proxyConnection };\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL3Byb3h5LWNvbm5lY3Rpb24uanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWIsd0JBQXdCLG1CQUFPLENBQUMsd0pBQWtEO0FBQ2xGLFFBQVEsY0FBYyxFQUFFLG1CQUFPLENBQUMsd0RBQU87QUFDdkMsYUFBYSxtQkFBTyxDQUFDLGtCQUFNO0FBQzNCO0FBQ0EsWUFBWSxnREFBdUI7QUFDbkMsWUFBWSxtQkFBTyxDQUFDLGdCQUFLOztBQUV6QjtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxxQkFBcUI7QUFDckI7QUFDQTtBQUNBLGNBQWM7QUFDZDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxpQkFBaUI7QUFDakI7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsaUJBQWlCO0FBQ2pCO0FBQ0E7QUFDQTtBQUNBLGlCQUFpQjtBQUNqQjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHFCQUFxQjtBQUNyQjtBQUNBO0FBQ0EsY0FBYztBQUNkO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGlCQUFpQjtBQUNqQjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLG1CQUFtQiIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbGliL3Byb3h5LWNvbm5lY3Rpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG5jb25zdCBodHRwUHJveHlDbGllbnQgPSByZXF1aXJlKCdub2RlbWFpbGVyL2xpYi9zbXRwLWNvbm5lY3Rpb24vaHR0cC1wcm94eS1jbGllbnQnKTtcbmNvbnN0IHsgU29ja3NDbGllbnQgfSA9IHJlcXVpcmUoJ3NvY2tzJyk7XG5jb25zdCB1dGlsID0gcmVxdWlyZSgndXRpbCcpO1xuY29uc3QgaHR0cFByb3h5Q2xpZW50QXN5bmMgPSB1dGlsLnByb21pc2lmeShodHRwUHJveHlDbGllbnQpO1xuY29uc3QgZG5zID0gcmVxdWlyZSgnZG5zJykucHJvbWlzZXM7XG5jb25zdCBuZXQgPSByZXF1aXJlKCduZXQnKTtcblxuY29uc3QgcHJveHlDb25uZWN0aW9uID0gYXN5bmMgKGxvZ2dlciwgY29ubmVjdGlvblVybCwgaG9zdCwgcG9ydCkgPT4ge1xuICAgIGxldCBwcm94eVVybCA9IG5ldyBVUkwoY29ubmVjdGlvblVybCk7XG5cbiAgICBsZXQgcHJvdG9jb2wgPSBwcm94eVVybC5wcm90b2NvbC5yZXBsYWNlKC86JC8sICcnKS50b0xvd2VyQ2FzZSgpO1xuXG4gICAgaWYgKCFuZXQuaXNJUChob3N0KSkge1xuICAgICAgICBsZXQgcmVzb2x2ZVJlc3VsdCA9IGF3YWl0IGRucy5yZXNvbHZlKGhvc3QpO1xuICAgICAgICBpZiAocmVzb2x2ZVJlc3VsdCAmJiByZXNvbHZlUmVzdWx0Lmxlbmd0aCkge1xuICAgICAgICAgICAgaG9zdCA9IHJlc29sdmVSZXN1bHRbMF07XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBzd2l0Y2ggKHByb3RvY29sKSB7XG4gICAgICAgIC8vIENvbm5lY3QgdXNpbmcgYSBIVFRQIENPTk5FQ1QgbWV0aG9kXG4gICAgICAgIGNhc2UgJ2h0dHAnOlxuICAgICAgICBjYXNlICdodHRwcyc6IHtcbiAgICAgICAgICAgIHRyeSB7XG4gICAgICAgICAgICAgICAgbGV0IHNvY2tldCA9IGF3YWl0IGh0dHBQcm94eUNsaWVudEFzeW5jKHByb3h5VXJsLmhyZWYsIHBvcnQsIGhvc3QpO1xuICAgICAgICAgICAgICAgIGlmIChzb2NrZXQpIHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKHByb3h5VXJsLnBhc3N3b3JkKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBwcm94eVVybC5wYXNzd29yZCA9ICcoaGlkZGVuKSc7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgbG9nZ2VyLmluZm8oe1xuICAgICAgICAgICAgICAgICAgICAgICAgbXNnOiAnRXN0YWJsaXNoZWQgYSBzb2NrZXQgdmlhIEhUVFAgcHJveHknLFxuICAgICAgICAgICAgICAgICAgICAgICAgcHJveHlVcmw6IHByb3h5VXJsLmhyZWYsXG4gICAgICAgICAgICAgICAgICAgICAgICBwb3J0LFxuICAgICAgICAgICAgICAgICAgICAgICAgaG9zdFxuICAgICAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgcmV0dXJuIHNvY2tldDtcbiAgICAgICAgICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICAgICAgICAgIGlmIChwcm94eVVybC5wYXNzd29yZCkge1xuICAgICAgICAgICAgICAgICAgICBwcm94eVVybC5wYXNzd29yZCA9ICcoaGlkZGVuKSc7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIGxvZ2dlci5lcnJvcih7XG4gICAgICAgICAgICAgICAgICAgIG1zZzogJ0ZhaWxlZCB0byBlc3RhYmxpc2ggYSBzb2NrZXQgdmlhIEhUVFAgcHJveHknLFxuICAgICAgICAgICAgICAgICAgICBwcm94eVVybDogcHJveHlVcmwuaHJlZixcbiAgICAgICAgICAgICAgICAgICAgcG9ydCxcbiAgICAgICAgICAgICAgICAgICAgaG9zdCxcbiAgICAgICAgICAgICAgICAgICAgZXJyXG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICAgICAgdGhyb3cgZXJyO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgLy8gU09DS1MgcHJveHlcbiAgICAgICAgY2FzZSAnc29ja3MnOlxuICAgICAgICBjYXNlICdzb2NrczUnOlxuICAgICAgICBjYXNlICdzb2NrczQnOlxuICAgICAgICBjYXNlICdzb2NrczRhJzoge1xuICAgICAgICAgICAgbGV0IHByb3h5VHlwZSA9IE51bWJlcihwcm90b2NvbC5yZXBsYWNlKC9cXEQvZywgJycpKSB8fCA1O1xuXG4gICAgICAgICAgICBsZXQgdGFyZ2V0SG9zdCA9IHByb3h5VXJsLmhvc3RuYW1lO1xuICAgICAgICAgICAgaWYgKCFuZXQuaXNJUCh0YXJnZXRIb3N0KSkge1xuICAgICAgICAgICAgICAgIGxldCByZXNvbHZlUmVzdWx0ID0gYXdhaXQgZG5zLnJlc29sdmUodGFyZ2V0SG9zdCk7XG4gICAgICAgICAgICAgICAgaWYgKHJlc29sdmVSZXN1bHQgJiYgcmVzb2x2ZVJlc3VsdC5sZW5ndGgpIHtcbiAgICAgICAgICAgICAgICAgICAgdGFyZ2V0SG9zdCA9IHJlc29sdmVSZXN1bHRbMF07XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICBsZXQgY29ubmVjdGlvbk9wdHMgPSB7XG4gICAgICAgICAgICAgICAgcHJveHk6IHtcbiAgICAgICAgICAgICAgICAgICAgaG9zdDogdGFyZ2V0SG9zdCxcbiAgICAgICAgICAgICAgICAgICAgcG9ydDogTnVtYmVyKHByb3h5VXJsLnBvcnQpIHx8IDEwODAsXG4gICAgICAgICAgICAgICAgICAgIHR5cGU6IHByb3h5VHlwZVxuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgZGVzdGluYXRpb246IHtcbiAgICAgICAgICAgICAgICAgICAgaG9zdCxcbiAgICAgICAgICAgICAgICAgICAgcG9ydFxuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgY29tbWFuZDogJ2Nvbm5lY3QnLFxuICAgICAgICAgICAgICAgIHNldF90Y3Bfbm9kZWxheTogdHJ1ZVxuICAgICAgICAgICAgfTtcblxuICAgICAgICAgICAgaWYgKHByb3h5VXJsLnVzZXJuYW1lIHx8IHByb3h5VXJsLnBhc3N3b3JkKSB7XG4gICAgICAgICAgICAgICAgY29ubmVjdGlvbk9wdHMucHJveHkudXNlcklkID0gcHJveHlVcmwudXNlcm5hbWU7XG4gICAgICAgICAgICAgICAgY29ubmVjdGlvbk9wdHMucHJveHkucGFzc3dvcmQgPSBwcm94eVVybC5wYXNzd29yZDtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgICAgICBjb25zdCBpbmZvID0gYXdhaXQgU29ja3NDbGllbnQuY3JlYXRlQ29ubmVjdGlvbihjb25uZWN0aW9uT3B0cyk7XG4gICAgICAgICAgICAgICAgaWYgKGluZm8gJiYgaW5mby5zb2NrZXQpIHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKHByb3h5VXJsLnBhc3N3b3JkKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBwcm94eVVybC5wYXNzd29yZCA9ICcoaGlkZGVuKSc7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgbG9nZ2VyLmluZm8oe1xuICAgICAgICAgICAgICAgICAgICAgICAgbXNnOiAnRXN0YWJsaXNoZWQgYSBzb2NrZXQgdmlhIFNPQ0tTIHByb3h5JyxcbiAgICAgICAgICAgICAgICAgICAgICAgIHByb3h5VXJsOiBwcm94eVVybC5ocmVmLFxuICAgICAgICAgICAgICAgICAgICAgICAgcG9ydCxcbiAgICAgICAgICAgICAgICAgICAgICAgIGhvc3RcbiAgICAgICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIHJldHVybiBpbmZvLnNvY2tldDtcbiAgICAgICAgICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICAgICAgICAgIGlmIChwcm94eVVybC5wYXNzd29yZCkge1xuICAgICAgICAgICAgICAgICAgICBwcm94eVVybC5wYXNzd29yZCA9ICcoaGlkZGVuKSc7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIGxvZ2dlci5lcnJvcih7XG4gICAgICAgICAgICAgICAgICAgIG1zZzogJ0ZhaWxlZCB0byBlc3RhYmxpc2ggYSBzb2NrZXQgdmlhIFNPQ0tTIHByb3h5JyxcbiAgICAgICAgICAgICAgICAgICAgcHJveHlVcmw6IHByb3h5VXJsLmhyZWYsXG4gICAgICAgICAgICAgICAgICAgIHBvcnQsXG4gICAgICAgICAgICAgICAgICAgIGhvc3QsXG4gICAgICAgICAgICAgICAgICAgIGVyclxuICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgICAgIHRocm93IGVycjtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgIH1cbn07XG5cbm1vZHVsZS5leHBvcnRzID0geyBwcm94eUNvbm5lY3Rpb24gfTtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/proxy-connection.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/search-compiler.js":
|
|
/*!******************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/search-compiler.js ***!
|
|
\******************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst { formatDate, formatFlag, canUseFlag } = __webpack_require__(/*! ./tools.js */ \"(rsc)/./node_modules/imapflow/lib/tools.js\");\n\nlet setBoolOpt = (attributes, term, value) => {\n if (!value) {\n if (/^un/i.test(term)) {\n term = term.slice(2);\n } else {\n term = 'UN' + term;\n }\n }\n\n attributes.push({ type: 'ATOM', value: term.toUpperCase() });\n};\n\nlet setOpt = (attributes, term, value, type) => {\n type = type || 'ATOM';\n\n if (value === false || value === null) {\n attributes.push({ type, value: 'NOT' });\n }\n\n attributes.push({ type, value: term.toUpperCase() });\n\n if (Array.isArray(value)) {\n value.forEach(entry => attributes.push({ type, value: (entry || '').toString() }));\n } else {\n attributes.push({ type, value: value.toString() });\n }\n};\n\nlet processDateField = (attributes, term, value) => {\n let date = formatDate(value);\n if (!date) {\n return;\n }\n\n setOpt(attributes, term, date);\n};\n\nlet isUnicodeString = str => {\n if (!str || typeof str !== 'string') {\n return false;\n }\n\n return Buffer.byteLength(str) !== str.length;\n};\n\nmodule.exports.searchCompiler = (connection, query) => {\n const attributes = [];\n\n let hasUnicode = false;\n const mailbox = connection.mailbox;\n\n const walk = params => {\n Object.keys(params || {}).forEach(term => {\n switch (term.toUpperCase()) {\n case 'SEQ': // custom key for sequence range\n {\n let value = params[term];\n if (typeof value === 'number') {\n value = value.toString();\n }\n if (typeof value === 'string' && /^\\S+$/.test(value)) {\n attributes.push({ type: 'SEQUENCE', value });\n }\n }\n break;\n\n case 'ANSWERED':\n case 'DELETED':\n case 'DRAFT':\n case 'FLAGGED':\n case 'SEEN':\n case 'UNANSWERED':\n case 'UNDELETED':\n case 'UNDRAFT':\n case 'UNFLAGGED':\n case 'UNSEEN':\n // toggles UN-prefix for falsy values\n setBoolOpt(attributes, term, !!params[term]);\n break;\n\n case 'ALL':\n case 'NEW':\n case 'OLD':\n case 'RECENT':\n if (params[term]) {\n setBoolOpt(attributes, term, true);\n }\n break;\n\n case 'LARGER':\n case 'SMALLER':\n case 'MODSEQ':\n if (params[term]) {\n setOpt(attributes, term, params[term]);\n }\n break;\n\n case 'BCC':\n case 'BODY':\n case 'CC':\n case 'FROM':\n case 'SUBJECT':\n case 'TEXT':\n case 'TO':\n if (isUnicodeString(params[term])) {\n hasUnicode = true;\n }\n if (params[term]) {\n setOpt(attributes, term, params[term]);\n }\n break;\n\n case 'UID':\n if (params[term]) {\n setOpt(attributes, term, params[term], 'SEQUENCE');\n }\n break;\n\n case 'EMAILID':\n if (connection.capabilities.has('OBJECTID')) {\n setOpt(attributes, 'EMAILID', params[term]);\n } else if (connection.capabilities.has('X-GM-EXT-1')) {\n setOpt(attributes, 'X-GM-MSGID', params[term]);\n }\n break;\n\n case 'THREADID':\n if (connection.capabilities.has('OBJECTID')) {\n setOpt(attributes, 'THREADID', params[term]);\n } else if (connection.capabilities.has('X-GM-EXT-1')) {\n setOpt(attributes, 'X-GM-THRID', params[term]);\n }\n break;\n\n case 'GMRAW':\n case 'GMAILRAW': // alias for GMRAW\n if (connection.capabilities.has('X-GM-EXT-1')) {\n if (isUnicodeString(params[term])) {\n hasUnicode = true;\n }\n setOpt(attributes, 'X-GM-RAW', params[term]);\n } else {\n let error = new Error('Server does not support X-GM-EXT-1 extension required for X-GM-RAW');\n error.code = 'MissingServerExtension';\n throw error;\n }\n break;\n\n case 'BEFORE':\n case 'ON':\n case 'SINCE':\n case 'SENTBEFORE':\n case 'SENTON':\n case 'SENTSINCE':\n processDateField(attributes, term, params[term]);\n break;\n\n case 'KEYWORD':\n case 'UNKEYWORD':\n {\n let flag = formatFlag(params[term]);\n if (canUseFlag(mailbox, flag) || mailbox.flags.has(flag)) {\n setOpt(attributes, term, flag);\n }\n }\n break;\n\n case 'HEADER':\n if (params[term] && typeof params[term] === 'object') {\n Object.keys(params[term]).forEach(header => {\n let value = params[term][header];\n if (value === true) {\n value = '';\n }\n\n if (typeof value !== 'string') {\n return;\n }\n\n if (isUnicodeString(value)) {\n hasUnicode = true;\n }\n\n setOpt(attributes, term, [header.toUpperCase().trim(), value]);\n });\n }\n break;\n\n case 'OR':\n {\n if (!params[term] || !Array.isArray(params[term]) || !params[term].length) {\n break;\n }\n\n if (params[term].length === 1) {\n if (typeof params[term][0] === 'object' && params[term][0]) {\n walk(params[term][0]);\n }\n break;\n }\n\n // OR values has to be grouped by 2\n // OR conditional1 conditional2\n let genOrTree = list => {\n let group = false;\n let groups = [];\n\n list.forEach((entry, i) => {\n if (i % 2 === 0) {\n group = [entry];\n } else {\n group.push(entry);\n groups.push(group);\n group = false;\n }\n });\n\n if (group && group.length) {\n while (group.length === 1 && Array.isArray(group[0])) {\n group = group[0];\n }\n\n groups.push(group);\n }\n\n while (groups.length > 2) {\n groups = genOrTree(groups);\n }\n\n while (groups.length === 1 && Array.isArray(groups[0])) {\n groups = groups[0];\n }\n\n return groups;\n };\n\n let walkOrTree = entry => {\n if (Array.isArray(entry)) {\n if (entry.length > 1) {\n attributes.push({ type: 'ATOM', value: 'OR' });\n }\n entry.forEach(walkOrTree);\n return;\n }\n if (entry && typeof entry === 'object') {\n walk(entry);\n }\n };\n walkOrTree(genOrTree(params[term]));\n }\n break;\n }\n });\n };\n\n walk(query);\n\n if (hasUnicode && !connection.enabled.has('UTF8=ACCEPT')) {\n // Prepend search query with `CHARSET UTF-8`\n attributes.unshift({ type: 'ATOM', value: 'UTF-8' });\n attributes.unshift({ type: 'ATOM', value: 'CHARSET' });\n }\n\n return attributes;\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/imapflow/lib/search-compiler.js","mappings":"AAAa;;AAEb,QAAQ,qCAAqC,EAAE,mBAAO,CAAC,8DAAY;;AAEnE;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;;AAEA,sBAAsB,yCAAyC;AAC/D;;AAEA;AACA;;AAEA;AACA,0BAA0B,oBAAoB;AAC9C;;AAEA,sBAAsB,iCAAiC;;AAEvD;AACA,iDAAiD,uCAAuC;AACxF,MAAM;AACN,0BAA0B,+BAA+B;AACzD;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,6BAA6B;AAC7B;;AAEA;AACA;;AAEA;AACA,gCAAgC;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,yBAAyB;AACvE;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;;AAEA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,yBAAyB;AACzB;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,kCAAkC;AAClC;AACA;AACA;AACA;AACA,6BAA6B;;AAE7B;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,sDAAsD,2BAA2B;AACjF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;;AAEA;AACA;AACA,6BAA6B,8BAA8B;AAC3D,6BAA6B,gCAAgC;AAC7D;;AAEA;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/search-compiler.js"],"sourcesContent":["'use strict';\n\nconst { formatDate, formatFlag, canUseFlag } = require('./tools.js');\n\nlet setBoolOpt = (attributes, term, value) => {\n    if (!value) {\n        if (/^un/i.test(term)) {\n            term = term.slice(2);\n        } else {\n            term = 'UN' + term;\n        }\n    }\n\n    attributes.push({ type: 'ATOM', value: term.toUpperCase() });\n};\n\nlet setOpt = (attributes, term, value, type) => {\n    type = type || 'ATOM';\n\n    if (value === false || value === null) {\n        attributes.push({ type, value: 'NOT' });\n    }\n\n    attributes.push({ type, value: term.toUpperCase() });\n\n    if (Array.isArray(value)) {\n        value.forEach(entry => attributes.push({ type, value: (entry || '').toString() }));\n    } else {\n        attributes.push({ type, value: value.toString() });\n    }\n};\n\nlet processDateField = (attributes, term, value) => {\n    let date = formatDate(value);\n    if (!date) {\n        return;\n    }\n\n    setOpt(attributes, term, date);\n};\n\nlet isUnicodeString = str => {\n    if (!str || typeof str !== 'string') {\n        return false;\n    }\n\n    return Buffer.byteLength(str) !== str.length;\n};\n\nmodule.exports.searchCompiler = (connection, query) => {\n    const attributes = [];\n\n    let hasUnicode = false;\n    const mailbox = connection.mailbox;\n\n    const walk = params => {\n        Object.keys(params || {}).forEach(term => {\n            switch (term.toUpperCase()) {\n                case 'SEQ': // custom key for sequence range\n                    {\n                        let value = params[term];\n                        if (typeof value === 'number') {\n                            value = value.toString();\n                        }\n                        if (typeof value === 'string' && /^\\S+$/.test(value)) {\n                            attributes.push({ type: 'SEQUENCE', value });\n                        }\n                    }\n                    break;\n\n                case 'ANSWERED':\n                case 'DELETED':\n                case 'DRAFT':\n                case 'FLAGGED':\n                case 'SEEN':\n                case 'UNANSWERED':\n                case 'UNDELETED':\n                case 'UNDRAFT':\n                case 'UNFLAGGED':\n                case 'UNSEEN':\n                    // toggles UN-prefix for falsy values\n                    setBoolOpt(attributes, term, !!params[term]);\n                    break;\n\n                case 'ALL':\n                case 'NEW':\n                case 'OLD':\n                case 'RECENT':\n                    if (params[term]) {\n                        setBoolOpt(attributes, term, true);\n                    }\n                    break;\n\n                case 'LARGER':\n                case 'SMALLER':\n                case 'MODSEQ':\n                    if (params[term]) {\n                        setOpt(attributes, term, params[term]);\n                    }\n                    break;\n\n                case 'BCC':\n                case 'BODY':\n                case 'CC':\n                case 'FROM':\n                case 'SUBJECT':\n                case 'TEXT':\n                case 'TO':\n                    if (isUnicodeString(params[term])) {\n                        hasUnicode = true;\n                    }\n                    if (params[term]) {\n                        setOpt(attributes, term, params[term]);\n                    }\n                    break;\n\n                case 'UID':\n                    if (params[term]) {\n                        setOpt(attributes, term, params[term], 'SEQUENCE');\n                    }\n                    break;\n\n                case 'EMAILID':\n                    if (connection.capabilities.has('OBJECTID')) {\n                        setOpt(attributes, 'EMAILID', params[term]);\n                    } else if (connection.capabilities.has('X-GM-EXT-1')) {\n                        setOpt(attributes, 'X-GM-MSGID', params[term]);\n                    }\n                    break;\n\n                case 'THREADID':\n                    if (connection.capabilities.has('OBJECTID')) {\n                        setOpt(attributes, 'THREADID', params[term]);\n                    } else if (connection.capabilities.has('X-GM-EXT-1')) {\n                        setOpt(attributes, 'X-GM-THRID', params[term]);\n                    }\n                    break;\n\n                case 'GMRAW':\n                case 'GMAILRAW': // alias for GMRAW\n                    if (connection.capabilities.has('X-GM-EXT-1')) {\n                        if (isUnicodeString(params[term])) {\n                            hasUnicode = true;\n                        }\n                        setOpt(attributes, 'X-GM-RAW', params[term]);\n                    } else {\n                        let error = new Error('Server does not support X-GM-EXT-1 extension required for X-GM-RAW');\n                        error.code = 'MissingServerExtension';\n                        throw error;\n                    }\n                    break;\n\n                case 'BEFORE':\n                case 'ON':\n                case 'SINCE':\n                case 'SENTBEFORE':\n                case 'SENTON':\n                case 'SENTSINCE':\n                    processDateField(attributes, term, params[term]);\n                    break;\n\n                case 'KEYWORD':\n                case 'UNKEYWORD':\n                    {\n                        let flag = formatFlag(params[term]);\n                        if (canUseFlag(mailbox, flag) || mailbox.flags.has(flag)) {\n                            setOpt(attributes, term, flag);\n                        }\n                    }\n                    break;\n\n                case 'HEADER':\n                    if (params[term] && typeof params[term] === 'object') {\n                        Object.keys(params[term]).forEach(header => {\n                            let value = params[term][header];\n                            if (value === true) {\n                                value = '';\n                            }\n\n                            if (typeof value !== 'string') {\n                                return;\n                            }\n\n                            if (isUnicodeString(value)) {\n                                hasUnicode = true;\n                            }\n\n                            setOpt(attributes, term, [header.toUpperCase().trim(), value]);\n                        });\n                    }\n                    break;\n\n                case 'OR':\n                    {\n                        if (!params[term] || !Array.isArray(params[term]) || !params[term].length) {\n                            break;\n                        }\n\n                        if (params[term].length === 1) {\n                            if (typeof params[term][0] === 'object' && params[term][0]) {\n                                walk(params[term][0]);\n                            }\n                            break;\n                        }\n\n                        // OR values has to be grouped by 2\n                        // OR conditional1 conditional2\n                        let genOrTree = list => {\n                            let group = false;\n                            let groups = [];\n\n                            list.forEach((entry, i) => {\n                                if (i % 2 === 0) {\n                                    group = [entry];\n                                } else {\n                                    group.push(entry);\n                                    groups.push(group);\n                                    group = false;\n                                }\n                            });\n\n                            if (group && group.length) {\n                                while (group.length === 1 && Array.isArray(group[0])) {\n                                    group = group[0];\n                                }\n\n                                groups.push(group);\n                            }\n\n                            while (groups.length > 2) {\n                                groups = genOrTree(groups);\n                            }\n\n                            while (groups.length === 1 && Array.isArray(groups[0])) {\n                                groups = groups[0];\n                            }\n\n                            return groups;\n                        };\n\n                        let walkOrTree = entry => {\n                            if (Array.isArray(entry)) {\n                                if (entry.length > 1) {\n                                    attributes.push({ type: 'ATOM', value: 'OR' });\n                                }\n                                entry.forEach(walkOrTree);\n                                return;\n                            }\n                            if (entry && typeof entry === 'object') {\n                                walk(entry);\n                            }\n                        };\n                        walkOrTree(genOrTree(params[term]));\n                    }\n                    break;\n            }\n        });\n    };\n\n    walk(query);\n\n    if (hasUnicode && !connection.enabled.has('UTF8=ACCEPT')) {\n        // Prepend search query with `CHARSET UTF-8`\n        attributes.unshift({ type: 'ATOM', value: 'UTF-8' });\n        attributes.unshift({ type: 'ATOM', value: 'CHARSET' });\n    }\n\n    return attributes;\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/search-compiler.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/special-use.js":
|
|
/*!**************************************************!*\
|
|
!*** ./node_modules/imapflow/lib/special-use.js ***!
|
|
\**************************************************/
|
|
/***/ ((module) => {
|
|
|
|
eval("\n\nmodule.exports = {\n flags: ['\\\\All', '\\\\Archive', '\\\\Drafts', '\\\\Flagged', '\\\\Junk', '\\\\Sent', '\\\\Trash'],\n names: {\n '\\\\Sent': [\n 'aika',\n 'bidaliak',\n 'bidalita',\n 'dihantar',\n 'e rometsweng',\n 'e tindami',\n 'elküldött',\n 'elküldöttek',\n 'elementos enviados',\n 'éléments envoyés',\n 'enviadas',\n 'enviadas',\n 'enviados',\n 'enviats',\n 'envoyés',\n 'ethunyelweyo',\n 'expediate',\n 'ezipuru',\n 'gesendete',\n 'gesendete elemente',\n 'gestuur',\n 'gönderilmiş öğeler',\n 'göndərilənlər',\n 'iberilen',\n 'inviati',\n 'išsiųstieji',\n 'kuthunyelwe',\n 'lasa',\n 'lähetetyt',\n 'messages envoyés',\n 'naipadala',\n 'nalefa',\n 'napadala',\n 'nosūtītās ziņas',\n 'odeslané',\n 'odeslaná pošta',\n 'padala',\n 'poslane',\n 'poslano',\n 'poslano',\n 'poslané',\n 'poslato',\n 'saadetud',\n 'saadetud kirjad',\n 'saadetud üksused',\n 'sendt',\n 'sendt',\n 'sent',\n 'sent items',\n 'sent messages',\n 'sända poster',\n 'sänt',\n 'terkirim',\n 'ti fi ranṣẹ',\n 'të dërguara',\n 'verzonden',\n 'vilivyotumwa',\n 'wysłane',\n 'đã gửi',\n 'σταλθέντα',\n 'жиберилген',\n 'жіберілгендер',\n 'изпратени',\n 'илгээсэн',\n 'ирсол шуд',\n 'испратено',\n 'надіслані',\n 'отправленные',\n 'пасланыя',\n 'юборилган',\n 'ուղարկված',\n 'נשלחו',\n 'פריטים שנשלחו',\n 'المرسلة',\n 'بھیجے گئے',\n 'سوزمژہ',\n 'لېګل شوی',\n 'موارد ارسال شده',\n 'पाठविले',\n 'पाठविलेले',\n 'प्रेषित',\n 'भेजा गया',\n 'প্রেরিত',\n 'প্রেরিত',\n 'প্ৰেৰিত',\n 'ਭੇਜੇ',\n 'મોકલેલા',\n 'ପଠାଗଲା',\n 'அனுப்பியவை',\n 'పంపించబడింది',\n 'ಕಳುಹಿಸಲಾದ',\n 'അയച്ചു',\n 'යැවු පණිවුඩ',\n 'ส่งแล้ว',\n 'გაგზავნილი',\n 'የተላኩ',\n 'បានផ្ញើ',\n '寄件備份',\n '寄件備份',\n '已发信息',\n '送信済みメール',\n '발신 메시지',\n '보낸 편지함'\n ],\n '\\\\Trash': [\n 'articole șterse',\n 'bin',\n 'borttagna objekt',\n 'deleted',\n 'deleted items',\n 'deleted messages',\n 'elementi eliminati',\n 'elementos borrados',\n 'elementos eliminados',\n 'gelöschte objekte',\n 'gelöschte elemente',\n 'item dipadam',\n 'itens apagados',\n 'itens excluídos',\n 'kustutatud üksused',\n 'mục đã xóa',\n 'odstraněné položky',\n 'odstraněná pošta',\n 'pesan terhapus',\n 'poistetut',\n 'praht',\n 'prügikast',\n 'silinmiş öğeler',\n 'slettede beskeder',\n 'slettede elementer',\n 'trash',\n 'törölt elemek',\n 'törölt',\n 'usunięte wiadomości',\n 'verwijderde items',\n 'vymazané správy',\n 'éléments supprimés',\n 'видалені',\n 'жойылғандар',\n 'удаленные',\n 'פריטים שנמחקו',\n 'العناصر المحذوفة',\n 'موارد حذف شده',\n 'รายการที่ลบ',\n '已删除邮件',\n '已刪除項目',\n '已刪除項目'\n ],\n '\\\\Junk': [\n 'bulk mail',\n 'correo no deseado',\n 'courrier indésirable',\n 'istenmeyen',\n 'istenmeyen e-posta',\n 'junk',\n 'junk e-mail',\n 'junk email',\n 'junk-e-mail',\n 'levélszemét',\n 'nevyžiadaná pošta',\n 'nevyžádaná pošta',\n 'no deseado',\n 'posta indesiderata',\n 'pourriel',\n 'roskaposti',\n 'rämpspost',\n 'skräppost',\n 'spam',\n 'spam',\n 'spamowanie',\n 'søppelpost',\n 'thư rác',\n 'wiadomości-śmieci',\n 'спам',\n 'דואר זבל',\n 'الرسائل العشوائية',\n 'هرزنامه',\n 'สแปม',\n '垃圾郵件',\n '垃圾邮件',\n '垃圾電郵'\n ],\n '\\\\Drafts': [\n 'ba brouillon',\n 'borrador',\n 'borrador',\n 'borradores',\n 'bozze',\n 'brouillons',\n 'bản thảo',\n 'ciorne',\n 'concepten',\n 'draf',\n 'draft',\n 'drafts',\n 'drög',\n 'entwürfe',\n 'esborranys',\n 'garalamalar',\n 'ihe edeturu',\n 'iidrafti',\n 'izinhlaka',\n 'juodraščiai',\n 'kladd',\n 'kladder',\n 'koncepty',\n 'koncepty',\n 'konsep',\n 'konsepte',\n 'kopie robocze',\n 'layihələr',\n 'luonnokset',\n 'melnraksti',\n 'meralo',\n 'mesazhe të padërguara',\n 'mga draft',\n 'mustandid',\n 'nacrti',\n 'nacrti',\n 'osnutki',\n 'piszkozatok',\n 'rascunhos',\n 'rasimu',\n 'skice',\n 'taslaklar',\n 'tsararrun saƙonni',\n 'utkast',\n 'vakiraoka',\n 'vázlatok',\n 'zirriborroak',\n 'àwọn àkọpamọ́',\n 'πρόχειρα',\n 'жобалар',\n 'нацрти',\n 'нооргууд',\n 'сиёҳнавис',\n 'хомаки хатлар',\n 'чарнавікі',\n 'чернетки',\n 'чернови',\n 'черновики',\n 'черновиктер',\n 'սևագրեր',\n 'טיוטות',\n 'مسودات',\n 'مسودات',\n 'موسودې',\n 'پیش نویسها',\n 'ڈرافٹ/',\n 'ड्राफ़्ट',\n 'प्रारूप',\n 'খসড়া',\n 'খসড়া',\n 'ড্ৰাফ্ট',\n 'ਡ੍ਰਾਫਟ',\n 'ડ્રાફ્ટસ',\n 'ଡ୍ରାଫ୍ଟ',\n 'வரைவுகள்',\n 'చిత్తు ప్రతులు',\n 'ಕರಡುಗಳು',\n 'കരടുകള്',\n 'කෙටුම් පත්',\n 'ฉบับร่าง',\n 'მონახაზები',\n 'ረቂቆች',\n 'សារព្រាង',\n '下書き',\n '草稿',\n '草稿',\n '草稿',\n '임시 보관함'\n ],\n\n '\\\\Archive': ['archive']\n },\n\n specialUse(hasSpecialUseExtension, folder) {\n let result;\n\n if (hasSpecialUseExtension) {\n result = {\n flag: module.exports.flags.find(flag => folder.flags.has(flag)),\n source: 'extension'\n };\n }\n\n if (!result || !result.flag) {\n let name = folder.name\n .toLowerCase()\n .replace(/\\u200e/g, '')\n .trim();\n\n result = {\n flag: Object.keys(module.exports.names).find(flag => module.exports.names[flag].includes(name)),\n source: 'name'\n };\n }\n\n return result && result.flag ? result : { flag: null };\n }\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/imapflow/lib/special-use.js","mappings":"AAAa;;AAEb;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;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;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;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;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;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;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,kDAAkD;AAClD;AACA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/special-use.js"],"sourcesContent":["'use strict';\n\nmodule.exports = {\n    flags: ['\\\\All', '\\\\Archive', '\\\\Drafts', '\\\\Flagged', '\\\\Junk', '\\\\Sent', '\\\\Trash'],\n    names: {\n        '\\\\Sent': [\n            'aika',\n            'bidaliak',\n            'bidalita',\n            'dihantar',\n            'e rometsweng',\n            'e tindami',\n            'elküldött',\n            'elküldöttek',\n            'elementos enviados',\n            'éléments envoyés',\n            'enviadas',\n            'enviadas',\n            'enviados',\n            'enviats',\n            'envoyés',\n            'ethunyelweyo',\n            'expediate',\n            'ezipuru',\n            'gesendete',\n            'gesendete elemente',\n            'gestuur',\n            'gönderilmiş öğeler',\n            'göndərilənlər',\n            'iberilen',\n            'inviati',\n            'išsiųstieji',\n            'kuthunyelwe',\n            'lasa',\n            'lähetetyt',\n            'messages envoyés',\n            'naipadala',\n            'nalefa',\n            'napadala',\n            'nosūtītās ziņas',\n            'odeslané',\n            'odeslaná pošta',\n            'padala',\n            'poslane',\n            'poslano',\n            'poslano',\n            'poslané',\n            'poslato',\n            'saadetud',\n            'saadetud kirjad',\n            'saadetud üksused',\n            'sendt',\n            'sendt',\n            'sent',\n            'sent items',\n            'sent messages',\n            'sända poster',\n            'sänt',\n            'terkirim',\n            'ti fi ranṣẹ',\n            'të dërguara',\n            'verzonden',\n            'vilivyotumwa',\n            'wysłane',\n            'đã gửi',\n            'σταλθέντα',\n            'жиберилген',\n            'жіберілгендер',\n            'изпратени',\n            'илгээсэн',\n            'ирсол шуд',\n            'испратено',\n            'надіслані',\n            'отправленные',\n            'пасланыя',\n            'юборилган',\n            'ուղարկված',\n            'נשלחו',\n            'פריטים שנשלחו',\n            'المرسلة',\n            'بھیجے گئے',\n            'سوزمژہ',\n            'لېګل شوی',\n            'موارد ارسال شده',\n            'पाठविले',\n            'पाठविलेले',\n            'प्रेषित',\n            'भेजा गया',\n            'প্রেরিত',\n            'প্রেরিত',\n            'প্ৰেৰিত',\n            'ਭੇਜੇ',\n            'મોકલેલા',\n            'ପଠାଗଲା',\n            'அனுப்பியவை',\n            'పంపించబడింది',\n            'ಕಳುಹಿಸಲಾದ',\n            'അയച്ചു',\n            'යැවු පණිවුඩ',\n            'ส่งแล้ว',\n            'გაგზავნილი',\n            'የተላኩ',\n            'បាន​ផ្ញើ',\n            '寄件備份',\n            '寄件備份',\n            '已发信息',\n            '送信済みﾒｰﾙ',\n            '발신 메시지',\n            '보낸 편지함'\n        ],\n        '\\\\Trash': [\n            'articole șterse',\n            'bin',\n            'borttagna objekt',\n            'deleted',\n            'deleted items',\n            'deleted messages',\n            'elementi eliminati',\n            'elementos borrados',\n            'elementos eliminados',\n            'gelöschte objekte',\n            'gelöschte elemente',\n            'item dipadam',\n            'itens apagados',\n            'itens excluídos',\n            'kustutatud üksused',\n            'mục đã xóa',\n            'odstraněné položky',\n            'odstraněná pošta',\n            'pesan terhapus',\n            'poistetut',\n            'praht',\n            'prügikast',\n            'silinmiş öğeler',\n            'slettede beskeder',\n            'slettede elementer',\n            'trash',\n            'törölt elemek',\n            'törölt',\n            'usunięte wiadomości',\n            'verwijderde items',\n            'vymazané správy',\n            'éléments supprimés',\n            'видалені',\n            'жойылғандар',\n            'удаленные',\n            'פריטים שנמחקו',\n            'العناصر المحذوفة',\n            'موارد حذف شده',\n            'รายการที่ลบ',\n            '已删除邮件',\n            '已刪除項目',\n            '已刪除項目'\n        ],\n        '\\\\Junk': [\n            'bulk mail',\n            'correo no deseado',\n            'courrier indésirable',\n            'istenmeyen',\n            'istenmeyen e-posta',\n            'junk',\n            'junk e-mail',\n            'junk email',\n            'junk-e-mail',\n            'levélszemét',\n            'nevyžiadaná pošta',\n            'nevyžádaná pošta',\n            'no deseado',\n            'posta indesiderata',\n            'pourriel',\n            'roskaposti',\n            'rämpspost',\n            'skräppost',\n            'spam',\n            'spam',\n            'spamowanie',\n            'søppelpost',\n            'thư rác',\n            'wiadomości-śmieci',\n            'спам',\n            'דואר זבל',\n            'الرسائل العشوائية',\n            'هرزنامه',\n            'สแปม',\n            '垃圾郵件',\n            '垃圾邮件',\n            '垃圾電郵'\n        ],\n        '\\\\Drafts': [\n            'ba brouillon',\n            'borrador',\n            'borrador',\n            'borradores',\n            'bozze',\n            'brouillons',\n            'bản thảo',\n            'ciorne',\n            'concepten',\n            'draf',\n            'draft',\n            'drafts',\n            'drög',\n            'entwürfe',\n            'esborranys',\n            'garalamalar',\n            'ihe edeturu',\n            'iidrafti',\n            'izinhlaka',\n            'juodraščiai',\n            'kladd',\n            'kladder',\n            'koncepty',\n            'koncepty',\n            'konsep',\n            'konsepte',\n            'kopie robocze',\n            'layihələr',\n            'luonnokset',\n            'melnraksti',\n            'meralo',\n            'mesazhe të padërguara',\n            'mga draft',\n            'mustandid',\n            'nacrti',\n            'nacrti',\n            'osnutki',\n            'piszkozatok',\n            'rascunhos',\n            'rasimu',\n            'skice',\n            'taslaklar',\n            'tsararrun saƙonni',\n            'utkast',\n            'vakiraoka',\n            'vázlatok',\n            'zirriborroak',\n            'àwọn àkọpamọ́',\n            'πρόχειρα',\n            'жобалар',\n            'нацрти',\n            'нооргууд',\n            'сиёҳнавис',\n            'хомаки хатлар',\n            'чарнавікі',\n            'чернетки',\n            'чернови',\n            'черновики',\n            'черновиктер',\n            'սևագրեր',\n            'טיוטות',\n            'مسودات',\n            'مسودات',\n            'موسودې',\n            'پیش نویسها',\n            'ڈرافٹ/',\n            'ड्राफ़्ट',\n            'प्रारूप',\n            'খসড়া',\n            'খসড়া',\n            'ড্ৰাফ্ট',\n            'ਡ੍ਰਾਫਟ',\n            'ડ્રાફ્ટસ',\n            'ଡ୍ରାଫ୍ଟ',\n            'வரைவுகள்',\n            'చిత్తు ప్రతులు',\n            'ಕರಡುಗಳು',\n            'കരടുകള്‍',\n            'කෙටුම් පත්',\n            'ฉบับร่าง',\n            'მონახაზები',\n            'ረቂቆች',\n            'សារព្រាង',\n            '下書き',\n            '草稿',\n            '草稿',\n            '草稿',\n            '임시 보관함'\n        ],\n\n        '\\\\Archive': ['archive']\n    },\n\n    specialUse(hasSpecialUseExtension, folder) {\n        let result;\n\n        if (hasSpecialUseExtension) {\n            result = {\n                flag: module.exports.flags.find(flag => folder.flags.has(flag)),\n                source: 'extension'\n            };\n        }\n\n        if (!result || !result.flag) {\n            let name = folder.name\n                .toLowerCase()\n                .replace(/\\u200e/g, '')\n                .trim();\n\n            result = {\n                flag: Object.keys(module.exports.names).find(flag => module.exports.names[flag].includes(name)),\n                source: 'name'\n            };\n        }\n\n        return result && result.flag ? result : { flag: null };\n    }\n};\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/special-use.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/lib/tools.js":
|
|
/*!********************************************!*\
|
|
!*** ./node_modules/imapflow/lib/tools.js ***!
|
|
\********************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("/* eslint no-control-regex:0 */\n\n\n\nconst libmime = __webpack_require__(/*! libmime */ \"(rsc)/./node_modules/libmime/lib/libmime.js\");\nconst { resolveCharset } = __webpack_require__(/*! ./charsets */ \"(rsc)/./node_modules/imapflow/lib/charsets.js\");\nconst { compiler } = __webpack_require__(/*! ./handler/imap-handler */ \"(rsc)/./node_modules/imapflow/lib/handler/imap-handler.js\");\nconst { createHash } = __webpack_require__(/*! crypto */ \"crypto\");\nconst { JPDecoder } = __webpack_require__(/*! ./jp-decoder */ \"(rsc)/./node_modules/imapflow/lib/jp-decoder.js\");\nconst iconv = __webpack_require__(/*! iconv-lite */ \"(rsc)/./node_modules/iconv-lite/lib/index.js\");\n\nconst FLAG_COLORS = ['red', 'orange', 'yellow', 'green', 'blue', 'purple', 'grey'];\n\nclass AuthenticationFailure extends Error {\n authenticationFailed = true;\n}\n\nconst tools = {\n encodePath(connection, path) {\n path = (path || '').toString();\n if (!connection.enabled.has('UTF8=ACCEPT') && /[&\\x00-\\x08\\x0b-\\x0c\\x0e-\\x1f\\u0080-\\uffff]/.test(path)) {\n try {\n path = iconv.encode(path, 'utf-7-imap').toString();\n } catch (err) {\n // ignore, keep name as is\n }\n }\n return path;\n },\n\n decodePath(connection, path) {\n path = (path || '').toString();\n if (!connection.enabled.has('UTF8=ACCEPT') && /[&]/.test(path)) {\n try {\n path = iconv.decode(Buffer.from(path), 'utf-7-imap').toString();\n } catch (err) {\n // ignore, keep name as is\n }\n }\n return path;\n },\n\n normalizePath(connection, path, skipNamespace) {\n if (Array.isArray(path)) {\n path = path.join((connection.namespace && connection.namespace.delimiter) || '');\n }\n\n if (path.toUpperCase() === 'INBOX') {\n // inbox is not case sensitive\n return 'INBOX';\n }\n\n // ensure namespace prefix if needed\n if (!skipNamespace && connection.namespace && connection.namespace.prefix && path.indexOf(connection.namespace.prefix) !== 0) {\n path = connection.namespace.prefix + path;\n }\n\n return path;\n },\n\n comparePaths(connection, a, b) {\n if (!a || !b) {\n return false;\n }\n return tools.normalizePath(connection, a) === tools.normalizePath(connection, b);\n },\n\n updateCapabilities(list) {\n let map = new Map();\n\n if (list && Array.isArray(list)) {\n list.forEach(val => {\n if (typeof val.value !== 'string') {\n return false;\n }\n let capability = val.value.toUpperCase().trim();\n\n if (capability === 'IMAP4REV1') {\n map.set('IMAP4rev1', true);\n return;\n }\n\n if (capability.indexOf('APPENDLIMIT=') === 0) {\n let splitPos = capability.indexOf('=');\n let appendLimit = Number(capability.substr(splitPos + 1)) || 0;\n map.set('APPENDLIMIT', appendLimit);\n return;\n }\n\n map.set(capability, true);\n });\n }\n\n return map;\n },\n\n AuthenticationFailure,\n\n getStatusCode(response) {\n return response &&\n response.attributes &&\n response.attributes[0] &&\n response.attributes[0].section &&\n response.attributes[0].section[0] &&\n typeof response.attributes[0].section[0].value === 'string'\n ? response.attributes[0].section[0].value.toUpperCase().trim()\n : false;\n },\n\n async getErrorText(response) {\n if (!response) {\n return false;\n }\n\n return (await compiler(response)).toString();\n },\n\n getFolderTree(folders) {\n let tree = {\n root: true,\n folders: []\n };\n\n let getTreeNode = parents => {\n let node = tree;\n if (!parents || !parents.length) {\n return node;\n }\n\n for (let parent of parents) {\n let cur = node.folders && node.folders.find(folder => folder.name === parent);\n if (cur) {\n node = cur;\n } else {\n // not yet set\n cur = {\n name: parent,\n folders: []\n };\n }\n }\n\n return node;\n };\n\n for (let folder of folders) {\n let parent = getTreeNode(folder.parent);\n // see if entry already exists\n let existing = parent.folders && parent.folders.find(existing => existing.name === folder.name);\n if (existing) {\n // update values\n existing.name = folder.name;\n existing.flags = folder.flags;\n existing.path = folder.path;\n existing.subscribed = !!folder.subscribed;\n existing.listed = !!folder.listed;\n existing.status = !!folder.status;\n\n if (folder.specialUse) {\n existing.specialUse = folder.specialUse;\n }\n\n if (folder.flags.has('\\\\Noselect')) {\n existing.disabled = true;\n }\n if (folder.flags.has('\\\\HasChildren') && !existing.folders) {\n existing.folders = [];\n }\n } else {\n // create new\n let data = {\n name: folder.name,\n flags: folder.flags,\n path: folder.path,\n subscribed: !!folder.subscribed,\n listed: !!folder.listed,\n status: !!folder.status\n };\n\n if (folder.delimiter) {\n data.delimiter = folder.delimiter;\n }\n\n if (folder.specialUse) {\n data.specialUse = folder.specialUse;\n }\n\n if (folder.flags.has('\\\\Noselect')) {\n data.disabled = true;\n }\n\n if (folder.flags.has('\\\\HasChildren')) {\n data.folders = [];\n }\n\n if (!parent.folders) {\n parent.folders = [];\n }\n parent.folders.push(data);\n }\n }\n\n return tree;\n },\n\n getFlagColor(flags) {\n if (!flags.has('\\\\Flagged')) {\n return null;\n }\n\n const bit0 = flags.has('$MailFlagBit0') ? 1 : 0;\n const bit1 = flags.has('$MailFlagBit1') ? 2 : 0;\n const bit2 = flags.has('$MailFlagBit2') ? 4 : 0;\n\n const color = bit0 | bit1 | bit2; // eslint-disable-line no-bitwise\n\n return FLAG_COLORS[color] || 'red'; // default to red for the unused \\b111\n },\n\n getColorFlags(color) {\n const colorCode = color ? FLAG_COLORS.indexOf((color || '').toString().toLowerCase().trim()) : null;\n if (colorCode < 0 && colorCode !== null) {\n return null;\n }\n\n const bits = [];\n bits[0] = colorCode & 1; // eslint-disable-line no-bitwise\n bits[1] = colorCode & 2; // eslint-disable-line no-bitwise\n bits[2] = colorCode & 4; // eslint-disable-line no-bitwise\n\n let result = { add: colorCode ? ['\\\\Flagged'] : [], remove: colorCode ? [] : ['\\\\Flagged'] };\n\n for (let i = 0; i < bits.length; i++) {\n if (bits[i]) {\n result.add.push(`$MailFlagBit${i}`);\n } else {\n result.remove.push(`$MailFlagBit${i}`);\n }\n }\n return result;\n },\n\n async formatMessageResponse(untagged, mailbox) {\n let map = {};\n\n map.seq = Number(untagged.command);\n\n let key;\n let attributes = (untagged.attributes && untagged.attributes[1]) || [];\n for (let i = 0, len = attributes.length; i < len; i++) {\n let attribute = attributes[i];\n if (i % 2 === 0) {\n key = (\n await compiler({\n attributes: [attribute]\n })\n )\n .toString()\n .toLowerCase()\n .replace(/<\\d+(\\.\\d+)?>$/, '');\n continue;\n }\n if (typeof key !== 'string') {\n // should not happen\n continue;\n }\n\n let getString = attribute => {\n if (!attribute) {\n return false;\n }\n if (typeof attribute.value === 'string') {\n return attribute.value;\n }\n if (Buffer.isBuffer(attribute.value)) {\n return attribute.value.toString();\n }\n };\n\n let getBuffer = attribute => {\n if (!attribute) {\n return false;\n }\n if (Buffer.isBuffer(attribute.value)) {\n return attribute.value;\n }\n };\n\n let getArray = attribute => {\n if (Array.isArray(attribute)) {\n return attribute.map(entry => (entry && typeof entry.value === 'string' ? entry.value : false)).filter(entry => entry);\n }\n };\n\n switch (key) {\n case 'body[]':\n case 'binary[]':\n map.source = getBuffer(attribute);\n break;\n\n case 'uid':\n map.uid = Number(getString(attribute));\n if (map.uid && (!mailbox.uidNext || mailbox.uidNext <= map.uid)) {\n // current uidNext seems to be outdated, bump it\n mailbox.uidNext = map.uid + 1;\n }\n break;\n\n case 'modseq':\n map.modseq = BigInt(getArray(attribute)[0]);\n if (map.modseq && (!mailbox.highestModseq || mailbox.highestModseq < map.modseq)) {\n // current highestModseq seems to be outdated, bump it\n mailbox.highestModseq = map.modseq;\n }\n break;\n\n case 'emailid':\n map.emailId = getArray(attribute)[0];\n break;\n\n case 'x-gm-msgid':\n map.emailId = getString(attribute);\n break;\n\n case 'threadid':\n map.threadId = getArray(attribute)[0];\n break;\n\n case 'x-gm-thrid':\n map.threadId = getString(attribute);\n break;\n\n case 'x-gm-labels':\n map.labels = new Set(getArray(attribute));\n break;\n\n case 'rfc822.size':\n map.size = Number(getString(attribute)) || 0;\n break;\n\n case 'flags':\n map.flags = new Set(getArray(attribute));\n break;\n\n case 'envelope':\n map.envelope = tools.parseEnvelope(attribute);\n break;\n\n case 'bodystructure':\n map.bodyStructure = tools.parseBodystructure(attribute);\n break;\n\n case 'internaldate': {\n let value = getString(attribute);\n let date = new Date(value);\n if (date.toString() === 'Invalid Date') {\n map.internalDate = value;\n } else {\n map.internalDate = date;\n }\n break;\n }\n\n default: {\n let match = key.match(/(body|binary)\\[/i);\n if (match) {\n let partKey = key.replace(/^(body|binary)\\[|]$/gi, '');\n partKey = partKey.replace(/\\.fields.*$/g, '');\n\n let value = getBuffer(attribute);\n if (partKey === 'header') {\n map.headers = value;\n break;\n }\n\n if (!map.bodyParts) {\n map.bodyParts = new Map();\n }\n map.bodyParts.set(partKey, value);\n break;\n }\n break;\n }\n }\n }\n\n if (map.emailId || map.uid) {\n // define account unique ID for this email\n\n // normalize path to use ascii, so we would always get the same ID\n let path = mailbox.path;\n if (/[0x80-0xff]/.test(path)) {\n try {\n path = iconv.encode(path, 'utf-7-imap').toString();\n } catch (err) {\n // ignore\n }\n }\n\n map.id =\n map.emailId ||\n createHash('md5')\n .update([path, mailbox.uidValidity?.toString() || '', map.uid.toString()].join(':'))\n .digest('hex');\n }\n\n if (map.flags) {\n let flagColor = tools.getFlagColor(map.flags);\n if (flagColor) {\n map.flagColor = flagColor;\n }\n }\n\n return map;\n },\n\n processName(name) {\n name = (name || '').toString();\n if (name.length > 2 && name.at(0) === '\"' && name.at(-1) === '\"') {\n name = name.replace(/^\"|\"$/g, '');\n }\n return name;\n },\n\n parseEnvelope(entry) {\n let getStrValue = obj => {\n if (!obj) {\n return false;\n }\n if (typeof obj.value === 'string') {\n return obj.value;\n }\n if (Buffer.isBuffer(obj.value)) {\n return obj.value.toString();\n }\n return obj.value;\n };\n\n let processAddresses = function (list) {\n return []\n .concat(list || [])\n .map(addr => {\n let address = (getStrValue(addr[2]) || '') + '@' + (getStrValue(addr[3]) || '');\n if (address === '@') {\n address = '';\n }\n return {\n name: tools.processName(libmime.decodeWords(getStrValue(addr[0]))),\n address\n };\n })\n .filter(addr => addr.name || addr.address);\n },\n envelope = {};\n\n if (entry[0] && entry[0].value) {\n let date = new Date(getStrValue(entry[0]));\n if (date.toString() === 'Invalid Date') {\n envelope.date = getStrValue(entry[0]);\n } else {\n envelope.date = date;\n }\n }\n\n if (entry[1] && entry[1].value) {\n envelope.subject = libmime.decodeWords(getStrValue(entry[1]));\n }\n\n if (entry[2] && entry[2].length) {\n envelope.from = processAddresses(entry[2]);\n }\n\n if (entry[3] && entry[3].length) {\n envelope.sender = processAddresses(entry[3]);\n }\n\n if (entry[4] && entry[4].length) {\n envelope.replyTo = processAddresses(entry[4]);\n }\n\n if (entry[5] && entry[5].length) {\n envelope.to = processAddresses(entry[5]);\n }\n\n if (entry[6] && entry[6].length) {\n envelope.cc = processAddresses(entry[6]);\n }\n\n if (entry[7] && entry[7].length) {\n envelope.bcc = processAddresses(entry[7]);\n }\n\n if (entry[8] && entry[8].value) {\n envelope.inReplyTo = (getStrValue(entry[8]) || '').toString().trim();\n }\n\n if (entry[9] && entry[9].value) {\n envelope.messageId = (getStrValue(entry[9]) || '').toString().trim();\n }\n\n return envelope;\n },\n\n getStructuredParams(arr) {\n let key;\n\n let params = {};\n\n [].concat(arr || []).forEach((val, j) => {\n if (j % 2) {\n params[key] = libmime.decodeWords(((val && val.value) || '').toString());\n } else {\n key = ((val && val.value) || '').toString().toLowerCase();\n }\n });\n\n if (params.filename && !params['filename*'] && /^[a-z\\-_0-9]+'[a-z]*'[^'\\x00-\\x08\\x0b\\x0c\\x0e-\\x1f\\u0080-\\uFFFF]+/.test(params.filename)) {\n // seems like encoded value\n let [encoding, , encodedValue] = params.filename.split(\"'\");\n if (resolveCharset(encoding)) {\n params['filename*'] = `${encoding}''${encodedValue}`;\n }\n }\n\n // preprocess values\n Object.keys(params).forEach(key => {\n let actualKey;\n let nr;\n let value;\n\n let match = key.match(/\\*((\\d+)\\*?)?$/);\n\n if (!match) {\n // nothing to do here, does not seem like a continuation param\n return;\n }\n\n actualKey = key.substr(0, match.index).toLowerCase();\n nr = Number(match[2]) || 0;\n\n if (!params[actualKey] || typeof params[actualKey] !== 'object') {\n params[actualKey] = {\n charset: false,\n values: []\n };\n }\n\n value = params[key];\n\n if (nr === 0 && match[0].charAt(match[0].length - 1) === '*' && (match = value.match(/^([^']*)'[^']*'(.*)$/))) {\n params[actualKey].charset = match[1] || 'utf-8';\n value = match[2];\n }\n\n params[actualKey].values.push({ nr, value });\n\n // remove the old reference\n delete params[key];\n });\n\n // concatenate split rfc2231 strings and convert encoded strings to mime encoded words\n Object.keys(params).forEach(key => {\n let value;\n if (params[key] && Array.isArray(params[key].values)) {\n value = params[key].values\n .sort((a, b) => a.nr - b.nr)\n .map(val => (val && val.value) || '')\n .join('');\n\n if (params[key].charset) {\n // convert \"%AB\" to \"=?charset?Q?=AB?=\" and then to unicode\n params[key] = libmime.decodeWords(\n '=?' +\n params[key].charset +\n '?Q?' +\n value\n // fix invalidly encoded chars\n .replace(/[=?_\\s]/g, s => {\n let c = s.charCodeAt(0).toString(16);\n if (s === ' ') {\n return '_';\n } else {\n return '%' + (c.length < 2 ? '0' : '') + c;\n }\n })\n // change from urlencoding to percent encoding\n .replace(/%/g, '=') +\n '?='\n );\n } else {\n params[key] = libmime.decodeWords(value);\n }\n }\n });\n\n return params;\n },\n\n parseBodystructure(entry) {\n let walk = (node, path) => {\n path = path || [];\n\n let curNode = {},\n i = 0,\n part = 0;\n\n if (path.length) {\n curNode.part = path.join('.');\n }\n\n // multipart\n if (Array.isArray(node[0])) {\n curNode.childNodes = [];\n while (Array.isArray(node[i])) {\n curNode.childNodes.push(walk(node[i], path.concat(++part)));\n i++;\n }\n\n // multipart type\n curNode.type = 'multipart/' + ((node[i++] || {}).value || '').toString().toLowerCase();\n\n // extension data (not available for BODY requests)\n\n // body parameter parenthesized list\n if (i < node.length - 1) {\n if (node[i]) {\n curNode.parameters = tools.getStructuredParams(node[i]);\n }\n i++;\n }\n } else {\n // content type\n curNode.type = [((node[i++] || {}).value || '').toString().toLowerCase(), ((node[i++] || {}).value || '').toString().toLowerCase()].join('/');\n\n // body parameter parenthesized list\n if (node[i]) {\n curNode.parameters = tools.getStructuredParams(node[i]);\n }\n i++;\n\n // id\n if (node[i]) {\n curNode.id = ((node[i] || {}).value || '').toString();\n }\n i++;\n\n // description\n if (node[i]) {\n curNode.description = ((node[i] || {}).value || '').toString();\n }\n i++;\n\n // encoding\n if (node[i]) {\n curNode.encoding = ((node[i] || {}).value || '').toString().toLowerCase();\n }\n i++;\n\n // size\n if (node[i]) {\n curNode.size = Number((node[i] || {}).value || 0) || 0;\n }\n i++;\n\n if (curNode.type === 'message/rfc822') {\n // message/rfc adds additional envelope, bodystructure and line count values\n\n // envelope\n if (node[i]) {\n curNode.envelope = tools.parseEnvelope([].concat(node[i] || []));\n }\n i++;\n\n if (node[i]) {\n curNode.childNodes = [\n // rfc822 bodyparts share the same path, difference is between MIME and HEADER\n // path.MIME returns message/rfc822 header\n // path.HEADER returns inlined message header\n walk(node[i], path)\n ];\n }\n i++;\n\n // line count\n if (node[i]) {\n curNode.lineCount = Number((node[i] || {}).value || 0) || 0;\n }\n i++;\n }\n\n if (/^text\\//.test(curNode.type)) {\n // text/* adds additional line count value\n\n // NB! some less known servers do not include the line count value\n // length should be 12+\n if (node.length === 11 && Array.isArray(node[i + 1]) && !Array.isArray(node[i + 2])) {\n // invalid structure, disposition params are shifted\n } else {\n // correct structure, line count number is provided\n if (node[i]) {\n // line count\n curNode.lineCount = Number((node[i] || {}).value || 0) || 0;\n }\n i++;\n }\n }\n\n // extension data (not available for BODY requests)\n\n // md5\n if (i < node.length - 1) {\n if (node[i]) {\n curNode.md5 = ((node[i] || {}).value || '').toString().toLowerCase();\n }\n i++;\n }\n }\n\n // the following are shared extension values (for both multipart and non-multipart parts)\n // not available for BODY requests\n\n // body disposition\n if (i < node.length - 1) {\n if (Array.isArray(node[i]) && node[i].length) {\n curNode.disposition = ((node[i][0] || {}).value || '').toString().toLowerCase();\n if (Array.isArray(node[i][1])) {\n curNode.dispositionParameters = tools.getStructuredParams(node[i][1]);\n }\n }\n i++;\n }\n\n // body language\n if (i < node.length - 1) {\n if (node[i]) {\n curNode.language = [].concat(node[i] || []).map(val => ((val && val.value) || '').toString().toLowerCase());\n }\n i++;\n }\n\n // body location\n // NB! defined as a \"string list\" in RFC3501 but replaced in errata document with \"string\"\n // Errata: http://www.rfc-editor.org/errata_search.php?rfc=3501\n if (i < node.length - 1) {\n if (node[i]) {\n curNode.location = ((node[i] || {}).value || '').toString();\n }\n i++;\n }\n\n return curNode;\n };\n\n return walk(entry);\n },\n\n formatDate(value) {\n if (typeof value === 'string') {\n value = new Date(value);\n }\n\n if (Object.prototype.toString(value) !== '[object Object]' || value.toString() === 'Invalid Date') {\n return;\n }\n\n value = value.toISOString().substr(0, 10);\n value = value.split('-');\n value.reverse();\n\n let months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];\n value[1] = months[Number(value[1]) - 1];\n\n return value.join('-');\n },\n\n formatDateTime(value) {\n if (!value) {\n return;\n }\n\n if (typeof value === 'string') {\n value = new Date(value);\n }\n\n if (Object.prototype.toString(value) !== '[object Object]' || value.toString() === 'Invalid Date') {\n return;\n }\n\n let dateStr = tools.formatDate(value).replace(/^0/, ' '); //starts with date-day-fixed with leading 0 replaced by SP\n let timeStr = value.toISOString().substr(11, 8);\n\n return `${dateStr} ${timeStr} +0000`;\n },\n\n formatFlag(flag) {\n switch (flag.toLowerCase()) {\n case '\\\\recent':\n // can not set or remove\n return false;\n case '\\\\seen':\n case '\\\\answered':\n case '\\\\flagged':\n case '\\\\deleted':\n case '\\\\draft':\n // can not set or remove\n return flag.toLowerCase().replace(/^\\\\./, c => c.toUpperCase());\n }\n return flag;\n },\n\n canUseFlag(mailbox, flag) {\n return !mailbox || !mailbox.permanentFlags || mailbox.permanentFlags.has('\\\\*') || mailbox.permanentFlags.has(flag);\n },\n\n expandRange(range) {\n return range.split(',').flatMap(entry => {\n entry = entry.trim();\n let colon = entry.indexOf(':');\n if (colon < 0) {\n return Number(entry) || 0;\n }\n let first = Number(entry.substr(0, colon)) || 0;\n let second = Number(entry.substr(colon + 1)) || 0;\n if (first === second) {\n return first;\n }\n let list = [];\n if (first < second) {\n for (let i = first; i <= second; i++) {\n list.push(i);\n }\n } else {\n for (let i = first; i >= second; i--) {\n list.push(i);\n }\n }\n return list;\n });\n },\n\n getDecoder(charset) {\n charset = (charset || 'ascii').toString().trim().toLowerCase();\n if (/^jis|^iso-?2022-?jp|^EUCJP/i.test(charset)) {\n // special case not supported by iconv-lite\n return new JPDecoder(charset);\n }\n\n return iconv.decodeStream(charset);\n },\n\n packMessageRange(list) {\n if (typeof uidList === 'string')\n if (!Array.isArray(list)) {\n list = [].concat(list || []);\n }\n\n if (!list.length) {\n return '';\n }\n\n list.sort((a, b) => a - b);\n\n let last = list[list.length - 1];\n let result = [[last]];\n for (let i = list.length - 2; i >= 0; i--) {\n if (list[i] === list[i + 1] - 1) {\n result[0].unshift(list[i]);\n continue;\n }\n result.unshift([list[i]]);\n }\n\n result = result.map(item => {\n if (item.length === 1) {\n return item[0];\n }\n return item.shift() + ':' + item.pop();\n });\n\n return result.join(',');\n }\n};\n\nmodule.exports = tools;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/imapflow/lib/tools.js","mappings":"AAAA;;AAEa;;AAEb,gBAAgB,mBAAO,CAAC,4DAAS;AACjC,QAAQ,iBAAiB,EAAE,mBAAO,CAAC,iEAAY;AAC/C,QAAQ,WAAW,EAAE,mBAAO,CAAC,yFAAwB;AACrD,QAAQ,aAAa,EAAE,mBAAO,CAAC,sBAAQ;AACvC,QAAQ,YAAY,EAAE,mBAAO,CAAC,qEAAc;AAC5C,cAAc,mBAAO,CAAC,gEAAY;;AAElC;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,aAAa;AACb;;AAEA;AACA,KAAK;;AAEL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,0CAA0C;;AAE1C,4CAA4C;AAC5C,KAAK;;AAEL;AACA;AACA;AACA;AACA;;AAEA;AACA,iCAAiC;AACjC,iCAAiC;AACjC,iCAAiC;;AAEjC,uBAAuB;;AAEvB,wBAAwB,iBAAiB;AACzC;AACA,+CAA+C,EAAE;AACjD,cAAc;AACd,kDAAkD,EAAE;AACpD;AACA;AACA;AACA,KAAK;;AAEL;AACA;;AAEA;;AAEA;AACA;AACA,iDAAiD,SAAS;AAC1D;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA,aAAa;AACb;;AAEA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;;AAEA;;AAEA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA,yCAAyC,SAAS,IAAI,aAAa;AACnE;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA,4CAA4C,WAAW;;AAEvD;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sCAAsC;AACtC;AACA;AACA,iCAAiC;AACjC;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA,SAAS;;AAET;AACA,KAAK;;AAEL;AACA;AACA;;AAEA,4BAA4B;AAC5B;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,+DAA+D;;AAE/D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA,iDAAiD,0DAA0D;;AAE3G;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,gDAAgD;AAChD;AACA;;AAEA;AACA;AACA,yDAAyD;AACzD;AACA;;AAEA;AACA;AACA,sDAAsD;AACtD;AACA;;AAEA;AACA;AACA,wDAAwD;AACxD;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,iEAAiE;AACjE;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;AACA,qEAAqE;AACrE;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,qDAAqD;AACrD;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,4DAA4D;AAC5D;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,sDAAsD;AACtD;AACA;AACA;;AAEA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,kEAAkE;AAClE;;AAEA,kBAAkB,SAAS,EAAE,SAAS;AACtC,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC,aAAa;AACjD;AACA;AACA,cAAc;AACd,oCAAoC,aAAa;AACjD;AACA;AACA;AACA;AACA,SAAS;AACT,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,sCAAsC,QAAQ;AAC9C;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA;;AAEA","sources":["/home/alma/nextgen/Neah-mail/node_modules/imapflow/lib/tools.js"],"sourcesContent":["/* eslint no-control-regex:0 */\n\n'use strict';\n\nconst libmime = require('libmime');\nconst { resolveCharset } = require('./charsets');\nconst { compiler } = require('./handler/imap-handler');\nconst { createHash } = require('crypto');\nconst { JPDecoder } = require('./jp-decoder');\nconst iconv = require('iconv-lite');\n\nconst FLAG_COLORS = ['red', 'orange', 'yellow', 'green', 'blue', 'purple', 'grey'];\n\nclass AuthenticationFailure extends Error {\n    authenticationFailed = true;\n}\n\nconst tools = {\n    encodePath(connection, path) {\n        path = (path || '').toString();\n        if (!connection.enabled.has('UTF8=ACCEPT') && /[&\\x00-\\x08\\x0b-\\x0c\\x0e-\\x1f\\u0080-\\uffff]/.test(path)) {\n            try {\n                path = iconv.encode(path, 'utf-7-imap').toString();\n            } catch (err) {\n                // ignore, keep name as is\n            }\n        }\n        return path;\n    },\n\n    decodePath(connection, path) {\n        path = (path || '').toString();\n        if (!connection.enabled.has('UTF8=ACCEPT') && /[&]/.test(path)) {\n            try {\n                path = iconv.decode(Buffer.from(path), 'utf-7-imap').toString();\n            } catch (err) {\n                // ignore, keep name as is\n            }\n        }\n        return path;\n    },\n\n    normalizePath(connection, path, skipNamespace) {\n        if (Array.isArray(path)) {\n            path = path.join((connection.namespace && connection.namespace.delimiter) || '');\n        }\n\n        if (path.toUpperCase() === 'INBOX') {\n            // inbox is not case sensitive\n            return 'INBOX';\n        }\n\n        // ensure namespace prefix if needed\n        if (!skipNamespace && connection.namespace && connection.namespace.prefix && path.indexOf(connection.namespace.prefix) !== 0) {\n            path = connection.namespace.prefix + path;\n        }\n\n        return path;\n    },\n\n    comparePaths(connection, a, b) {\n        if (!a || !b) {\n            return false;\n        }\n        return tools.normalizePath(connection, a) === tools.normalizePath(connection, b);\n    },\n\n    updateCapabilities(list) {\n        let map = new Map();\n\n        if (list && Array.isArray(list)) {\n            list.forEach(val => {\n                if (typeof val.value !== 'string') {\n                    return false;\n                }\n                let capability = val.value.toUpperCase().trim();\n\n                if (capability === 'IMAP4REV1') {\n                    map.set('IMAP4rev1', true);\n                    return;\n                }\n\n                if (capability.indexOf('APPENDLIMIT=') === 0) {\n                    let splitPos = capability.indexOf('=');\n                    let appendLimit = Number(capability.substr(splitPos + 1)) || 0;\n                    map.set('APPENDLIMIT', appendLimit);\n                    return;\n                }\n\n                map.set(capability, true);\n            });\n        }\n\n        return map;\n    },\n\n    AuthenticationFailure,\n\n    getStatusCode(response) {\n        return response &&\n            response.attributes &&\n            response.attributes[0] &&\n            response.attributes[0].section &&\n            response.attributes[0].section[0] &&\n            typeof response.attributes[0].section[0].value === 'string'\n            ? response.attributes[0].section[0].value.toUpperCase().trim()\n            : false;\n    },\n\n    async getErrorText(response) {\n        if (!response) {\n            return false;\n        }\n\n        return (await compiler(response)).toString();\n    },\n\n    getFolderTree(folders) {\n        let tree = {\n            root: true,\n            folders: []\n        };\n\n        let getTreeNode = parents => {\n            let node = tree;\n            if (!parents || !parents.length) {\n                return node;\n            }\n\n            for (let parent of parents) {\n                let cur = node.folders && node.folders.find(folder => folder.name === parent);\n                if (cur) {\n                    node = cur;\n                } else {\n                    // not yet set\n                    cur = {\n                        name: parent,\n                        folders: []\n                    };\n                }\n            }\n\n            return node;\n        };\n\n        for (let folder of folders) {\n            let parent = getTreeNode(folder.parent);\n            // see if entry already exists\n            let existing = parent.folders && parent.folders.find(existing => existing.name === folder.name);\n            if (existing) {\n                // update values\n                existing.name = folder.name;\n                existing.flags = folder.flags;\n                existing.path = folder.path;\n                existing.subscribed = !!folder.subscribed;\n                existing.listed = !!folder.listed;\n                existing.status = !!folder.status;\n\n                if (folder.specialUse) {\n                    existing.specialUse = folder.specialUse;\n                }\n\n                if (folder.flags.has('\\\\Noselect')) {\n                    existing.disabled = true;\n                }\n                if (folder.flags.has('\\\\HasChildren') && !existing.folders) {\n                    existing.folders = [];\n                }\n            } else {\n                // create new\n                let data = {\n                    name: folder.name,\n                    flags: folder.flags,\n                    path: folder.path,\n                    subscribed: !!folder.subscribed,\n                    listed: !!folder.listed,\n                    status: !!folder.status\n                };\n\n                if (folder.delimiter) {\n                    data.delimiter = folder.delimiter;\n                }\n\n                if (folder.specialUse) {\n                    data.specialUse = folder.specialUse;\n                }\n\n                if (folder.flags.has('\\\\Noselect')) {\n                    data.disabled = true;\n                }\n\n                if (folder.flags.has('\\\\HasChildren')) {\n                    data.folders = [];\n                }\n\n                if (!parent.folders) {\n                    parent.folders = [];\n                }\n                parent.folders.push(data);\n            }\n        }\n\n        return tree;\n    },\n\n    getFlagColor(flags) {\n        if (!flags.has('\\\\Flagged')) {\n            return null;\n        }\n\n        const bit0 = flags.has('$MailFlagBit0') ? 1 : 0;\n        const bit1 = flags.has('$MailFlagBit1') ? 2 : 0;\n        const bit2 = flags.has('$MailFlagBit2') ? 4 : 0;\n\n        const color = bit0 | bit1 | bit2; // eslint-disable-line no-bitwise\n\n        return FLAG_COLORS[color] || 'red'; // default to red for the unused \\b111\n    },\n\n    getColorFlags(color) {\n        const colorCode = color ? FLAG_COLORS.indexOf((color || '').toString().toLowerCase().trim()) : null;\n        if (colorCode < 0 && colorCode !== null) {\n            return null;\n        }\n\n        const bits = [];\n        bits[0] = colorCode & 1; // eslint-disable-line no-bitwise\n        bits[1] = colorCode & 2; // eslint-disable-line no-bitwise\n        bits[2] = colorCode & 4; // eslint-disable-line no-bitwise\n\n        let result = { add: colorCode ? ['\\\\Flagged'] : [], remove: colorCode ? [] : ['\\\\Flagged'] };\n\n        for (let i = 0; i < bits.length; i++) {\n            if (bits[i]) {\n                result.add.push(`$MailFlagBit${i}`);\n            } else {\n                result.remove.push(`$MailFlagBit${i}`);\n            }\n        }\n        return result;\n    },\n\n    async formatMessageResponse(untagged, mailbox) {\n        let map = {};\n\n        map.seq = Number(untagged.command);\n\n        let key;\n        let attributes = (untagged.attributes && untagged.attributes[1]) || [];\n        for (let i = 0, len = attributes.length; i < len; i++) {\n            let attribute = attributes[i];\n            if (i % 2 === 0) {\n                key = (\n                    await compiler({\n                        attributes: [attribute]\n                    })\n                )\n                    .toString()\n                    .toLowerCase()\n                    .replace(/<\\d+(\\.\\d+)?>$/, '');\n                continue;\n            }\n            if (typeof key !== 'string') {\n                // should not happen\n                continue;\n            }\n\n            let getString = attribute => {\n                if (!attribute) {\n                    return false;\n                }\n                if (typeof attribute.value === 'string') {\n                    return attribute.value;\n                }\n                if (Buffer.isBuffer(attribute.value)) {\n                    return attribute.value.toString();\n                }\n            };\n\n            let getBuffer = attribute => {\n                if (!attribute) {\n                    return false;\n                }\n                if (Buffer.isBuffer(attribute.value)) {\n                    return attribute.value;\n                }\n            };\n\n            let getArray = attribute => {\n                if (Array.isArray(attribute)) {\n                    return attribute.map(entry => (entry && typeof entry.value === 'string' ? entry.value : false)).filter(entry => entry);\n                }\n            };\n\n            switch (key) {\n                case 'body[]':\n                case 'binary[]':\n                    map.source = getBuffer(attribute);\n                    break;\n\n                case 'uid':\n                    map.uid = Number(getString(attribute));\n                    if (map.uid && (!mailbox.uidNext || mailbox.uidNext <= map.uid)) {\n                        // current uidNext seems to be outdated, bump it\n                        mailbox.uidNext = map.uid + 1;\n                    }\n                    break;\n\n                case 'modseq':\n                    map.modseq = BigInt(getArray(attribute)[0]);\n                    if (map.modseq && (!mailbox.highestModseq || mailbox.highestModseq < map.modseq)) {\n                        // current highestModseq seems to be outdated, bump it\n                        mailbox.highestModseq = map.modseq;\n                    }\n                    break;\n\n                case 'emailid':\n                    map.emailId = getArray(attribute)[0];\n                    break;\n\n                case 'x-gm-msgid':\n                    map.emailId = getString(attribute);\n                    break;\n\n                case 'threadid':\n                    map.threadId = getArray(attribute)[0];\n                    break;\n\n                case 'x-gm-thrid':\n                    map.threadId = getString(attribute);\n                    break;\n\n                case 'x-gm-labels':\n                    map.labels = new Set(getArray(attribute));\n                    break;\n\n                case 'rfc822.size':\n                    map.size = Number(getString(attribute)) || 0;\n                    break;\n\n                case 'flags':\n                    map.flags = new Set(getArray(attribute));\n                    break;\n\n                case 'envelope':\n                    map.envelope = tools.parseEnvelope(attribute);\n                    break;\n\n                case 'bodystructure':\n                    map.bodyStructure = tools.parseBodystructure(attribute);\n                    break;\n\n                case 'internaldate': {\n                    let value = getString(attribute);\n                    let date = new Date(value);\n                    if (date.toString() === 'Invalid Date') {\n                        map.internalDate = value;\n                    } else {\n                        map.internalDate = date;\n                    }\n                    break;\n                }\n\n                default: {\n                    let match = key.match(/(body|binary)\\[/i);\n                    if (match) {\n                        let partKey = key.replace(/^(body|binary)\\[|]$/gi, '');\n                        partKey = partKey.replace(/\\.fields.*$/g, '');\n\n                        let value = getBuffer(attribute);\n                        if (partKey === 'header') {\n                            map.headers = value;\n                            break;\n                        }\n\n                        if (!map.bodyParts) {\n                            map.bodyParts = new Map();\n                        }\n                        map.bodyParts.set(partKey, value);\n                        break;\n                    }\n                    break;\n                }\n            }\n        }\n\n        if (map.emailId || map.uid) {\n            // define account unique ID for this email\n\n            // normalize path to use ascii, so we would always get the same ID\n            let path = mailbox.path;\n            if (/[0x80-0xff]/.test(path)) {\n                try {\n                    path = iconv.encode(path, 'utf-7-imap').toString();\n                } catch (err) {\n                    // ignore\n                }\n            }\n\n            map.id =\n                map.emailId ||\n                createHash('md5')\n                    .update([path, mailbox.uidValidity?.toString() || '', map.uid.toString()].join(':'))\n                    .digest('hex');\n        }\n\n        if (map.flags) {\n            let flagColor = tools.getFlagColor(map.flags);\n            if (flagColor) {\n                map.flagColor = flagColor;\n            }\n        }\n\n        return map;\n    },\n\n    processName(name) {\n        name = (name || '').toString();\n        if (name.length > 2 && name.at(0) === '\"' && name.at(-1) === '\"') {\n            name = name.replace(/^\"|\"$/g, '');\n        }\n        return name;\n    },\n\n    parseEnvelope(entry) {\n        let getStrValue = obj => {\n            if (!obj) {\n                return false;\n            }\n            if (typeof obj.value === 'string') {\n                return obj.value;\n            }\n            if (Buffer.isBuffer(obj.value)) {\n                return obj.value.toString();\n            }\n            return obj.value;\n        };\n\n        let processAddresses = function (list) {\n                return []\n                    .concat(list || [])\n                    .map(addr => {\n                        let address = (getStrValue(addr[2]) || '') + '@' + (getStrValue(addr[3]) || '');\n                        if (address === '@') {\n                            address = '';\n                        }\n                        return {\n                            name: tools.processName(libmime.decodeWords(getStrValue(addr[0]))),\n                            address\n                        };\n                    })\n                    .filter(addr => addr.name || addr.address);\n            },\n            envelope = {};\n\n        if (entry[0] && entry[0].value) {\n            let date = new Date(getStrValue(entry[0]));\n            if (date.toString() === 'Invalid Date') {\n                envelope.date = getStrValue(entry[0]);\n            } else {\n                envelope.date = date;\n            }\n        }\n\n        if (entry[1] && entry[1].value) {\n            envelope.subject = libmime.decodeWords(getStrValue(entry[1]));\n        }\n\n        if (entry[2] && entry[2].length) {\n            envelope.from = processAddresses(entry[2]);\n        }\n\n        if (entry[3] && entry[3].length) {\n            envelope.sender = processAddresses(entry[3]);\n        }\n\n        if (entry[4] && entry[4].length) {\n            envelope.replyTo = processAddresses(entry[4]);\n        }\n\n        if (entry[5] && entry[5].length) {\n            envelope.to = processAddresses(entry[5]);\n        }\n\n        if (entry[6] && entry[6].length) {\n            envelope.cc = processAddresses(entry[6]);\n        }\n\n        if (entry[7] && entry[7].length) {\n            envelope.bcc = processAddresses(entry[7]);\n        }\n\n        if (entry[8] && entry[8].value) {\n            envelope.inReplyTo = (getStrValue(entry[8]) || '').toString().trim();\n        }\n\n        if (entry[9] && entry[9].value) {\n            envelope.messageId = (getStrValue(entry[9]) || '').toString().trim();\n        }\n\n        return envelope;\n    },\n\n    getStructuredParams(arr) {\n        let key;\n\n        let params = {};\n\n        [].concat(arr || []).forEach((val, j) => {\n            if (j % 2) {\n                params[key] = libmime.decodeWords(((val && val.value) || '').toString());\n            } else {\n                key = ((val && val.value) || '').toString().toLowerCase();\n            }\n        });\n\n        if (params.filename && !params['filename*'] && /^[a-z\\-_0-9]+'[a-z]*'[^'\\x00-\\x08\\x0b\\x0c\\x0e-\\x1f\\u0080-\\uFFFF]+/.test(params.filename)) {\n            // seems like encoded value\n            let [encoding, , encodedValue] = params.filename.split(\"'\");\n            if (resolveCharset(encoding)) {\n                params['filename*'] = `${encoding}''${encodedValue}`;\n            }\n        }\n\n        // preprocess values\n        Object.keys(params).forEach(key => {\n            let actualKey;\n            let nr;\n            let value;\n\n            let match = key.match(/\\*((\\d+)\\*?)?$/);\n\n            if (!match) {\n                // nothing to do here, does not seem like a continuation param\n                return;\n            }\n\n            actualKey = key.substr(0, match.index).toLowerCase();\n            nr = Number(match[2]) || 0;\n\n            if (!params[actualKey] || typeof params[actualKey] !== 'object') {\n                params[actualKey] = {\n                    charset: false,\n                    values: []\n                };\n            }\n\n            value = params[key];\n\n            if (nr === 0 && match[0].charAt(match[0].length - 1) === '*' && (match = value.match(/^([^']*)'[^']*'(.*)$/))) {\n                params[actualKey].charset = match[1] || 'utf-8';\n                value = match[2];\n            }\n\n            params[actualKey].values.push({ nr, value });\n\n            // remove the old reference\n            delete params[key];\n        });\n\n        // concatenate split rfc2231 strings and convert encoded strings to mime encoded words\n        Object.keys(params).forEach(key => {\n            let value;\n            if (params[key] && Array.isArray(params[key].values)) {\n                value = params[key].values\n                    .sort((a, b) => a.nr - b.nr)\n                    .map(val => (val && val.value) || '')\n                    .join('');\n\n                if (params[key].charset) {\n                    // convert \"%AB\" to \"=?charset?Q?=AB?=\" and then to unicode\n                    params[key] = libmime.decodeWords(\n                        '=?' +\n                            params[key].charset +\n                            '?Q?' +\n                            value\n                                // fix invalidly encoded chars\n                                .replace(/[=?_\\s]/g, s => {\n                                    let c = s.charCodeAt(0).toString(16);\n                                    if (s === ' ') {\n                                        return '_';\n                                    } else {\n                                        return '%' + (c.length < 2 ? '0' : '') + c;\n                                    }\n                                })\n                                // change from urlencoding to percent encoding\n                                .replace(/%/g, '=') +\n                            '?='\n                    );\n                } else {\n                    params[key] = libmime.decodeWords(value);\n                }\n            }\n        });\n\n        return params;\n    },\n\n    parseBodystructure(entry) {\n        let walk = (node, path) => {\n            path = path || [];\n\n            let curNode = {},\n                i = 0,\n                part = 0;\n\n            if (path.length) {\n                curNode.part = path.join('.');\n            }\n\n            // multipart\n            if (Array.isArray(node[0])) {\n                curNode.childNodes = [];\n                while (Array.isArray(node[i])) {\n                    curNode.childNodes.push(walk(node[i], path.concat(++part)));\n                    i++;\n                }\n\n                // multipart type\n                curNode.type = 'multipart/' + ((node[i++] || {}).value || '').toString().toLowerCase();\n\n                // extension data (not available for BODY requests)\n\n                // body parameter parenthesized list\n                if (i < node.length - 1) {\n                    if (node[i]) {\n                        curNode.parameters = tools.getStructuredParams(node[i]);\n                    }\n                    i++;\n                }\n            } else {\n                // content type\n                curNode.type = [((node[i++] || {}).value || '').toString().toLowerCase(), ((node[i++] || {}).value || '').toString().toLowerCase()].join('/');\n\n                // body parameter parenthesized list\n                if (node[i]) {\n                    curNode.parameters = tools.getStructuredParams(node[i]);\n                }\n                i++;\n\n                // id\n                if (node[i]) {\n                    curNode.id = ((node[i] || {}).value || '').toString();\n                }\n                i++;\n\n                // description\n                if (node[i]) {\n                    curNode.description = ((node[i] || {}).value || '').toString();\n                }\n                i++;\n\n                // encoding\n                if (node[i]) {\n                    curNode.encoding = ((node[i] || {}).value || '').toString().toLowerCase();\n                }\n                i++;\n\n                // size\n                if (node[i]) {\n                    curNode.size = Number((node[i] || {}).value || 0) || 0;\n                }\n                i++;\n\n                if (curNode.type === 'message/rfc822') {\n                    // message/rfc adds additional envelope, bodystructure and line count values\n\n                    // envelope\n                    if (node[i]) {\n                        curNode.envelope = tools.parseEnvelope([].concat(node[i] || []));\n                    }\n                    i++;\n\n                    if (node[i]) {\n                        curNode.childNodes = [\n                            // rfc822 bodyparts share the same path, difference is between MIME and HEADER\n                            // path.MIME returns message/rfc822 header\n                            // path.HEADER returns inlined message header\n                            walk(node[i], path)\n                        ];\n                    }\n                    i++;\n\n                    // line count\n                    if (node[i]) {\n                        curNode.lineCount = Number((node[i] || {}).value || 0) || 0;\n                    }\n                    i++;\n                }\n\n                if (/^text\\//.test(curNode.type)) {\n                    // text/* adds additional line count value\n\n                    // NB! some less known servers do not include the line count value\n                    // length should be 12+\n                    if (node.length === 11 && Array.isArray(node[i + 1]) && !Array.isArray(node[i + 2])) {\n                        // invalid structure, disposition params are shifted\n                    } else {\n                        // correct structure, line count number is provided\n                        if (node[i]) {\n                            // line count\n                            curNode.lineCount = Number((node[i] || {}).value || 0) || 0;\n                        }\n                        i++;\n                    }\n                }\n\n                // extension data (not available for BODY requests)\n\n                // md5\n                if (i < node.length - 1) {\n                    if (node[i]) {\n                        curNode.md5 = ((node[i] || {}).value || '').toString().toLowerCase();\n                    }\n                    i++;\n                }\n            }\n\n            // the following are shared extension values (for both multipart and non-multipart parts)\n            // not available for BODY requests\n\n            // body disposition\n            if (i < node.length - 1) {\n                if (Array.isArray(node[i]) && node[i].length) {\n                    curNode.disposition = ((node[i][0] || {}).value || '').toString().toLowerCase();\n                    if (Array.isArray(node[i][1])) {\n                        curNode.dispositionParameters = tools.getStructuredParams(node[i][1]);\n                    }\n                }\n                i++;\n            }\n\n            // body language\n            if (i < node.length - 1) {\n                if (node[i]) {\n                    curNode.language = [].concat(node[i] || []).map(val => ((val && val.value) || '').toString().toLowerCase());\n                }\n                i++;\n            }\n\n            // body location\n            // NB! defined as a \"string list\" in RFC3501 but replaced in errata document with \"string\"\n            // Errata: http://www.rfc-editor.org/errata_search.php?rfc=3501\n            if (i < node.length - 1) {\n                if (node[i]) {\n                    curNode.location = ((node[i] || {}).value || '').toString();\n                }\n                i++;\n            }\n\n            return curNode;\n        };\n\n        return walk(entry);\n    },\n\n    formatDate(value) {\n        if (typeof value === 'string') {\n            value = new Date(value);\n        }\n\n        if (Object.prototype.toString(value) !== '[object Object]' || value.toString() === 'Invalid Date') {\n            return;\n        }\n\n        value = value.toISOString().substr(0, 10);\n        value = value.split('-');\n        value.reverse();\n\n        let months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];\n        value[1] = months[Number(value[1]) - 1];\n\n        return value.join('-');\n    },\n\n    formatDateTime(value) {\n        if (!value) {\n            return;\n        }\n\n        if (typeof value === 'string') {\n            value = new Date(value);\n        }\n\n        if (Object.prototype.toString(value) !== '[object Object]' || value.toString() === 'Invalid Date') {\n            return;\n        }\n\n        let dateStr = tools.formatDate(value).replace(/^0/, ' '); //starts with date-day-fixed with leading 0 replaced by SP\n        let timeStr = value.toISOString().substr(11, 8);\n\n        return `${dateStr} ${timeStr} +0000`;\n    },\n\n    formatFlag(flag) {\n        switch (flag.toLowerCase()) {\n            case '\\\\recent':\n                // can not set or remove\n                return false;\n            case '\\\\seen':\n            case '\\\\answered':\n            case '\\\\flagged':\n            case '\\\\deleted':\n            case '\\\\draft':\n                // can not set or remove\n                return flag.toLowerCase().replace(/^\\\\./, c => c.toUpperCase());\n        }\n        return flag;\n    },\n\n    canUseFlag(mailbox, flag) {\n        return !mailbox || !mailbox.permanentFlags || mailbox.permanentFlags.has('\\\\*') || mailbox.permanentFlags.has(flag);\n    },\n\n    expandRange(range) {\n        return range.split(',').flatMap(entry => {\n            entry = entry.trim();\n            let colon = entry.indexOf(':');\n            if (colon < 0) {\n                return Number(entry) || 0;\n            }\n            let first = Number(entry.substr(0, colon)) || 0;\n            let second = Number(entry.substr(colon + 1)) || 0;\n            if (first === second) {\n                return first;\n            }\n            let list = [];\n            if (first < second) {\n                for (let i = first; i <= second; i++) {\n                    list.push(i);\n                }\n            } else {\n                for (let i = first; i >= second; i--) {\n                    list.push(i);\n                }\n            }\n            return list;\n        });\n    },\n\n    getDecoder(charset) {\n        charset = (charset || 'ascii').toString().trim().toLowerCase();\n        if (/^jis|^iso-?2022-?jp|^EUCJP/i.test(charset)) {\n            // special case not supported by iconv-lite\n            return new JPDecoder(charset);\n        }\n\n        return iconv.decodeStream(charset);\n    },\n\n    packMessageRange(list) {\n        if (typeof uidList === 'string')\n            if (!Array.isArray(list)) {\n                list = [].concat(list || []);\n            }\n\n        if (!list.length) {\n            return '';\n        }\n\n        list.sort((a, b) => a - b);\n\n        let last = list[list.length - 1];\n        let result = [[last]];\n        for (let i = list.length - 2; i >= 0; i--) {\n            if (list[i] === list[i + 1] - 1) {\n                result[0].unshift(list[i]);\n                continue;\n            }\n            result.unshift([list[i]]);\n        }\n\n        result = result.map(item => {\n            if (item.length === 1) {\n                return item[0];\n            }\n            return item.shift() + ':' + item.pop();\n        });\n\n        return result.join(',');\n    }\n};\n\nmodule.exports = tools;\n"],"names":[],"ignoreList":[0],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/lib/tools.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/node_modules/mailsplit/index.js":
|
|
/*!***************************************************************!*\
|
|
!*** ./node_modules/imapflow/node_modules/mailsplit/index.js ***!
|
|
\***************************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst MessageSplitter = __webpack_require__(/*! ./lib/message-splitter */ \"(rsc)/./node_modules/imapflow/node_modules/mailsplit/lib/message-splitter.js\");\nconst MessageJoiner = __webpack_require__(/*! ./lib/message-joiner */ \"(rsc)/./node_modules/imapflow/node_modules/mailsplit/lib/message-joiner.js\");\nconst NodeRewriter = __webpack_require__(/*! ./lib/node-rewriter */ \"(rsc)/./node_modules/imapflow/node_modules/mailsplit/lib/node-rewriter.js\");\nconst NodeStreamer = __webpack_require__(/*! ./lib/node-streamer */ \"(rsc)/./node_modules/imapflow/node_modules/mailsplit/lib/node-streamer.js\");\nconst Headers = __webpack_require__(/*! ./lib/headers */ \"(rsc)/./node_modules/imapflow/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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbm9kZV9tb2R1bGVzL21haWxzcGxpdC9pbmRleC5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYix3QkFBd0IsbUJBQU8sQ0FBQyw0R0FBd0I7QUFDeEQsc0JBQXNCLG1CQUFPLENBQUMsd0dBQXNCO0FBQ3BELHFCQUFxQixtQkFBTyxDQUFDLHNHQUFxQjtBQUNsRCxxQkFBcUIsbUJBQU8sQ0FBQyxzR0FBcUI7QUFDbEQsZ0JBQWdCLG1CQUFPLENBQUMsMEZBQWU7O0FBRXZDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9ub2RlX21vZHVsZXMvbWFpbHNwbGl0L2luZGV4LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgTWVzc2FnZVNwbGl0dGVyID0gcmVxdWlyZSgnLi9saWIvbWVzc2FnZS1zcGxpdHRlcicpO1xuY29uc3QgTWVzc2FnZUpvaW5lciA9IHJlcXVpcmUoJy4vbGliL21lc3NhZ2Utam9pbmVyJyk7XG5jb25zdCBOb2RlUmV3cml0ZXIgPSByZXF1aXJlKCcuL2xpYi9ub2RlLXJld3JpdGVyJyk7XG5jb25zdCBOb2RlU3RyZWFtZXIgPSByZXF1aXJlKCcuL2xpYi9ub2RlLXN0cmVhbWVyJyk7XG5jb25zdCBIZWFkZXJzID0gcmVxdWlyZSgnLi9saWIvaGVhZGVycycpO1xuXG5tb2R1bGUuZXhwb3J0cyA9IHtcbiAgICBTcGxpdHRlcjogTWVzc2FnZVNwbGl0dGVyLFxuICAgIEpvaW5lcjogTWVzc2FnZUpvaW5lcixcbiAgICBSZXdyaXRlcjogTm9kZVJld3JpdGVyLFxuICAgIFN0cmVhbWVyOiBOb2RlU3RyZWFtZXIsXG4gICAgSGVhZGVyc1xufTtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/node_modules/mailsplit/index.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/node_modules/mailsplit/lib/flowed-decoder.js":
|
|
/*!****************************************************************************!*\
|
|
!*** ./node_modules/imapflow/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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbm9kZV9tb2R1bGVzL21haWxzcGxpdC9saWIvZmxvd2VkLWRlY29kZXIuanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWI7O0FBRUEsa0JBQWtCLHVEQUEyQjtBQUM3QyxnQkFBZ0IsbUJBQU8sQ0FBQyw0REFBUzs7QUFFakM7QUFDQTtBQUNBO0FBQ0E7QUFDQSxXQUFXLFFBQVE7QUFDbkI7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBLDZDQUE2QyxxQkFBcUI7QUFDbEU7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSIsInNvdXJjZXMiOlsiL2hvbWUvYWxtYS9uZXh0Z2VuL05lYWgtbWFpbC9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbm9kZV9tb2R1bGVzL21haWxzcGxpdC9saWIvZmxvd2VkLWRlY29kZXIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG4vLyBIZWxwZXIgY2xhc3MgdG8gcmV3cml0ZSBub2RlcyB3aXRoIHNwZWNpZmljIG1pbWUgdHlwZVxuXG5jb25zdCBUcmFuc2Zvcm0gPSByZXF1aXJlKCdzdHJlYW0nKS5UcmFuc2Zvcm07XG5jb25zdCBsaWJtaW1lID0gcmVxdWlyZSgnbGlibWltZScpO1xuXG4vKipcbiAqIFJlYWxseSBiYWQgXCJzdHJlYW1cIiB0cmFuc2Zvcm0gdG8gcGFyc2UgZm9ybWF0PWZsb3dlZCBjb250ZW50XG4gKlxuICogQGNvbnN0cnVjdG9yXG4gKiBAcGFyYW0ge1N0cmluZ30gZGVsU3AgVHJ1ZSBpZiBkZWxzcCBvcHRpb24gd2FzIHVzZWRcbiAqL1xuY2xhc3MgRmxvd2VkRGVjb2RlciBleHRlbmRzIFRyYW5zZm9ybSB7XG4gICAgY29uc3RydWN0b3IoY29uZmlnKSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgICAgIHRoaXMuY29uZmlnID0gY29uZmlnIHx8IHt9O1xuXG4gICAgICAgIHRoaXMuY2h1bmtzID0gW107XG4gICAgICAgIHRoaXMuY2h1bmtsZW4gPSAwO1xuXG4gICAgICAgIHRoaXMubGlibWltZSA9IG5ldyBsaWJtaW1lLkxpYm1pbWUoeyBJY29udjogY29uZmlnLkljb252IH0pO1xuICAgIH1cblxuICAgIF90cmFuc2Zvcm0oY2h1bmssIGVuY29kaW5nLCBjYWxsYmFjaykge1xuICAgICAgICBpZiAoIWNodW5rIHx8ICFjaHVuay5sZW5ndGgpIHtcbiAgICAgICAgICAgIHJldHVybiBjYWxsYmFjaygpO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKCFlbmNvZGluZyAhPT0gJ2J1ZmZlcicpIHtcbiAgICAgICAgICAgIGNodW5rID0gQnVmZmVyLmZyb20oY2h1bmssIGVuY29kaW5nKTtcbiAgICAgICAgfVxuXG4gICAgICAgIHRoaXMuY2h1bmtzLnB1c2goY2h1bmspO1xuICAgICAgICB0aGlzLmNodW5rbGVuICs9IGNodW5rLmxlbmd0aDtcblxuICAgICAgICBjYWxsYmFjaygpO1xuICAgIH1cblxuICAgIF9mbHVzaChjYWxsYmFjaykge1xuICAgICAgICBpZiAodGhpcy5jaHVua2xlbikge1xuICAgICAgICAgICAgbGV0IGN1cnJlbnRCb2R5ID0gQnVmZmVyLmNvbmNhdCh0aGlzLmNodW5rcywgdGhpcy5jaHVua2xlbik7XG5cbiAgICAgICAgICAgIGlmICh0aGlzLmNvbmZpZy5lbmNvZGluZyA9PT0gJ2Jhc2U2NCcpIHtcbiAgICAgICAgICAgICAgICBjdXJyZW50Qm9keSA9IEJ1ZmZlci5mcm9tKGN1cnJlbnRCb2R5LnRvU3RyaW5nKCdiaW5hcnknKSwgJ2Jhc2U2NCcpO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICBsZXQgY29udGVudCA9IHRoaXMubGlibWltZS5kZWNvZGVGbG93ZWQoY3VycmVudEJvZHkudG9TdHJpbmcoJ2JpbmFyeScpLCB0aGlzLmNvbmZpZy5kZWxTcCk7XG4gICAgICAgICAgICB0aGlzLnB1c2goQnVmZmVyLmZyb20oY29udGVudCwgJ2JpbmFyeScpKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gY2FsbGJhY2soKTtcbiAgICB9XG59XG5cbm1vZHVsZS5leHBvcnRzID0gRmxvd2VkRGVjb2RlcjtcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/node_modules/mailsplit/lib/flowed-decoder.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/node_modules/mailsplit/lib/headers.js":
|
|
/*!*********************************************************************!*\
|
|
!*** ./node_modules/imapflow/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/imapflow/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/imapflow/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/imapflow/node_modules/mailsplit/lib/headers.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/node_modules/mailsplit/lib/message-joiner.js":
|
|
/*!****************************************************************************!*\
|
|
!*** ./node_modules/imapflow/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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbm9kZV9tb2R1bGVzL21haWxzcGxpdC9saWIvbWVzc2FnZS1qb2luZXIuanMiLCJtYXBwaW5ncyI6IkFBQWE7O0FBRWIsa0JBQWtCLHVEQUEyQjs7QUFFN0M7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxVQUFVO0FBQ1Y7QUFDQSxVQUFVO0FBQ1Y7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUEiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L25vZGVfbW9kdWxlcy9tYWlsc3BsaXQvbGliL21lc3NhZ2Utam9pbmVyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuY29uc3QgVHJhbnNmb3JtID0gcmVxdWlyZSgnc3RyZWFtJykuVHJhbnNmb3JtO1xuXG5jbGFzcyBNZXNzYWdlSm9pbmVyIGV4dGVuZHMgVHJhbnNmb3JtIHtcbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgbGV0IG9wdGlvbnMgPSB7XG4gICAgICAgICAgICByZWFkYWJsZU9iamVjdE1vZGU6IGZhbHNlLFxuICAgICAgICAgICAgd3JpdGFibGVPYmplY3RNb2RlOiB0cnVlXG4gICAgICAgIH07XG4gICAgICAgIHN1cGVyKG9wdGlvbnMpO1xuICAgIH1cblxuICAgIF90cmFuc2Zvcm0ob2JqLCBlbmNvZGluZywgY2FsbGJhY2spIHtcbiAgICAgICAgaWYgKEJ1ZmZlci5pc0J1ZmZlcihvYmopKSB7XG4gICAgICAgICAgICB0aGlzLnB1c2gob2JqKTtcbiAgICAgICAgfSBlbHNlIGlmIChvYmoudHlwZSA9PT0gJ25vZGUnKSB7XG4gICAgICAgICAgICB0aGlzLnB1c2gob2JqLmdldEhlYWRlcnMoKSk7XG4gICAgICAgIH0gZWxzZSBpZiAob2JqLnZhbHVlKSB7XG4gICAgICAgICAgICB0aGlzLnB1c2gob2JqLnZhbHVlKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gY2FsbGJhY2soKTtcbiAgICB9XG5cbiAgICBfZmx1c2goY2FsbGJhY2spIHtcbiAgICAgICAgcmV0dXJuIGNhbGxiYWNrKCk7XG4gICAgfVxufVxuXG5tb2R1bGUuZXhwb3J0cyA9IE1lc3NhZ2VKb2luZXI7XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/node_modules/mailsplit/lib/message-joiner.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/node_modules/mailsplit/lib/message-splitter.js":
|
|
/*!******************************************************************************!*\
|
|
!*** ./node_modules/imapflow/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/imapflow/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/imapflow/node_modules/mailsplit/lib/message-splitter.js","mappings":"AAAa;;AAEb,kBAAkB,uDAA2B;AAC7C,iBAAiB,mBAAO,CAAC,0FAAa;;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/imapflow/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/imapflow/node_modules/mailsplit/lib/message-splitter.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/node_modules/mailsplit/lib/mime-node.js":
|
|
/*!***********************************************************************!*\
|
|
!*** ./node_modules/imapflow/node_modules/mailsplit/lib/mime-node.js ***!
|
|
\***********************************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\nconst Headers = __webpack_require__(/*! ./headers */ \"(rsc)/./node_modules/imapflow/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/imapflow/node_modules/mailsplit/lib/mime-node.js","mappings":"AAAa;;AAEb,gBAAgB,mBAAO,CAAC,sFAAW;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/imapflow/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/imapflow/node_modules/mailsplit/lib/mime-node.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/node_modules/mailsplit/lib/node-rewriter.js":
|
|
/*!***************************************************************************!*\
|
|
!*** ./node_modules/imapflow/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/imapflow/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/imapflow/node_modules/mailsplit/lib/node-rewriter.js","mappings":"AAAa;;AAEb;;AAEA,kBAAkB,uDAA2B;AAC7C,sBAAsB,mBAAO,CAAC,oGAAkB;;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/imapflow/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/imapflow/node_modules/mailsplit/lib/node-rewriter.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/node_modules/mailsplit/lib/node-streamer.js":
|
|
/*!***************************************************************************!*\
|
|
!*** ./node_modules/imapflow/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/imapflow/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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbm9kZV9tb2R1bGVzL21haWxzcGxpdC9saWIvbm9kZS1zdHJlYW1lci5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYjs7QUFFQSxrQkFBa0IsdURBQTJCO0FBQzdDLHNCQUFzQixtQkFBTyxDQUFDLG9HQUFrQjs7QUFFaEQ7QUFDQTtBQUNBO0FBQ0E7QUFDQSxXQUFXLFFBQVE7QUFDbkIsV0FBVyxVQUFVO0FBQ3JCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsaUJBQWlCO0FBQ2pCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsY0FBYztBQUNkO0FBQ0E7QUFDQSxVQUFVO0FBQ1Y7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxjQUFjO0FBQ2Q7QUFDQTs7QUFFQTtBQUNBLFVBQVU7QUFDVjtBQUNBO0FBQ0E7QUFDQSxVQUFVO0FBQ1Y7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esa0JBQWtCO0FBQ2xCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBIiwic291cmNlcyI6WyIvaG9tZS9hbG1hL25leHRnZW4vTmVhaC1tYWlsL25vZGVfbW9kdWxlcy9pbWFwZmxvdy9ub2RlX21vZHVsZXMvbWFpbHNwbGl0L2xpYi9ub2RlLXN0cmVhbWVyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIid1c2Ugc3RyaWN0JztcblxuLy8gSGVscGVyIGNsYXNzIHRvIHJld3JpdGUgbm9kZXMgd2l0aCBzcGVjaWZpYyBtaW1lIHR5cGVcblxuY29uc3QgVHJhbnNmb3JtID0gcmVxdWlyZSgnc3RyZWFtJykuVHJhbnNmb3JtO1xuY29uc3QgRmxvd2VkRGVjb2RlciA9IHJlcXVpcmUoJy4vZmxvd2VkLWRlY29kZXInKTtcblxuLyoqXG4gKiBOb2RlUmV3cml0ZXIgVHJhbnNmb3JtIHN0cmVhbS4gVXBkYXRlcyBjb250ZW50IGZvciBhbGwgbm9kZXMgd2l0aCBzcGVjaWZpZWQgbWltZSB0eXBlXG4gKlxuICogQGNvbnN0cnVjdG9yXG4gKiBAcGFyYW0ge1N0cmluZ30gbWltZVR5cGUgRGVmaW5lIHRoZSBNaW1lLVR5cGUgdG8gbG9vayBmb3JcbiAqIEBwYXJhbSB7RnVuY3Rpb259IHN0cmVhbUFjdGlvbiBGdW5jdGlvbiB0byBydW4gd2l0aCB0aGUgbm9kZSBjb250ZW50XG4gKi9cbmNsYXNzIE5vZGVTdHJlYW1lciBleHRlbmRzIFRyYW5zZm9ybSB7XG4gICAgY29uc3RydWN0b3IoZmlsdGVyRnVuYywgc3RyZWFtQWN0aW9uKSB7XG4gICAgICAgIGxldCBvcHRpb25zID0ge1xuICAgICAgICAgICAgcmVhZGFibGVPYmplY3RNb2RlOiB0cnVlLFxuICAgICAgICAgICAgd3JpdGFibGVPYmplY3RNb2RlOiB0cnVlXG4gICAgICAgIH07XG4gICAgICAgIHN1cGVyKG9wdGlvbnMpO1xuXG4gICAgICAgIHRoaXMuZmlsdGVyRnVuYyA9IGZpbHRlckZ1bmM7XG4gICAgICAgIHRoaXMuc3RyZWFtQWN0aW9uID0gc3RyZWFtQWN0aW9uO1xuXG4gICAgICAgIHRoaXMuZGVjb2RlciA9IGZhbHNlO1xuICAgICAgICB0aGlzLmNhbkNvbnRpbnVlID0gZmFsc2U7XG4gICAgICAgIHRoaXMuY29udGludWUgPSBmYWxzZTtcbiAgICB9XG5cbiAgICBfdHJhbnNmb3JtKGRhdGEsIGVuY29kaW5nLCBjYWxsYmFjaykge1xuICAgICAgICB0aGlzLnByb2Nlc3NJbmNvbWluZyhkYXRhLCBjYWxsYmFjayk7XG4gICAgfVxuXG4gICAgX2ZsdXNoKGNhbGxiYWNrKSB7XG4gICAgICAgIGlmICh0aGlzLmRlY29kZXIpIHtcbiAgICAgICAgICAgIC8vIGVtaXQgYW4gZW1wdHkgbm9kZSBqdXN0IGluIGNhc2UgdGhlcmUgaXMgcGVuZGluZyBkYXRhIHRvIGVuZFxuICAgICAgICAgICAgcmV0dXJuIHRoaXMucHJvY2Vzc0luY29taW5nKFxuICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgdHlwZTogJ25vbmUnXG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICBjYWxsYmFja1xuICAgICAgICAgICAgKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gY2FsbGJhY2soKTtcbiAgICB9XG5cbiAgICBwcm9jZXNzSW5jb21pbmcoZGF0YSwgY2FsbGJhY2spIHtcbiAgICAgICAgaWYgKHRoaXMuZGVjb2RlciAmJiBkYXRhLnR5cGUgPT09ICdib2R5Jykge1xuICAgICAgICAgICAgLy8gZGF0YSB0byBwYXJzZVxuICAgICAgICAgICAgdGhpcy5wdXNoKGRhdGEpO1xuICAgICAgICAgICAgaWYgKCF0aGlzLmRlY29kZXIud3JpdGUoZGF0YS52YWx1ZSkpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gdGhpcy5kZWNvZGVyLm9uY2UoJ2RyYWluJywgY2FsbGJhY2spO1xuICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gY2FsbGJhY2soKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSBlbHNlIGlmICh0aGlzLmRlY29kZXIgJiYgZGF0YS50eXBlICE9PSAnYm9keScpIHtcbiAgICAgICAgICAgIC8vIHN0b3AgZGVjb2RpbmcuXG4gICAgICAgICAgICAvLyB3ZSBjYW4gbm90IHByb2Nlc3MgdGhlIGN1cnJlbnQgZGF0YSBjaHVuayBhcyB3ZSBuZWVkIHRvIHdhaXQgdW50aWxcbiAgICAgICAgICAgIC8vIHRoZSBwYXJzZWQgZGF0YSBpcyBjb21wbGV0ZWx5IHByb2Nlc3NlZCwgc28gd2Ugc3RvcmUgYSByZWZlcmVuY2UgdG8gdGhlXG4gICAgICAgICAgICAvLyBjb250aW51ZSBjYWxsYmFja1xuXG4gICAgICAgICAgICBsZXQgZG9Db250aW51ZSA9ICgpID0+IHtcbiAgICAgICAgICAgICAgICB0aGlzLmNvbnRpbnVlID0gZmFsc2U7XG4gICAgICAgICAgICAgICAgdGhpcy5kZWNvZGVyID0gZmFsc2U7XG4gICAgICAgICAgICAgICAgdGhpcy5jYW5Db250aW51ZSA9IGZhbHNlO1xuICAgICAgICAgICAgICAgIHRoaXMucHJvY2Vzc0luY29taW5nKGRhdGEsIGNhbGxiYWNrKTtcbiAgICAgICAgICAgIH07XG5cbiAgICAgICAgICAgIGlmICh0aGlzLmNhbkNvbnRpbnVlKSB7XG4gICAgICAgICAgICAgICAgc2V0SW1tZWRpYXRlKGRvQ29udGludWUpO1xuICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICB0aGlzLmNvbnRpbnVlID0gKCkgPT4gZG9Db250aW51ZSgpO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICByZXR1cm4gdGhpcy5kZWNvZGVyLmVuZCgpO1xuICAgICAgICB9IGVsc2UgaWYgKGRhdGEudHlwZSA9PT0gJ25vZGUnICYmIHRoaXMuZmlsdGVyRnVuYyhkYXRhKSkge1xuICAgICAgICAgICAgdGhpcy5wdXNoKGRhdGEpO1xuICAgICAgICAgICAgLy8gZm91bmQgbWF0Y2hpbmcgbm9kZSwgY3JlYXRlIG5ldyBoYW5kbGVyXG4gICAgICAgICAgICB0aGlzLmVtaXQoJ25vZGUnLCB0aGlzLmNyZWF0ZURlY29kZXIoZGF0YSkpO1xuICAgICAgICB9IGVsc2UgaWYgKHRoaXMucmVhZGFibGUgJiYgZGF0YS50eXBlICE9PSAnbm9uZScpIHtcbiAgICAgICAgICAgIC8vIHdlIGRvbid0IGNhcmUgYWJvdXQgdGhpcyBkYXRhLCBqdXN0IHBhc3MgaXQgb3ZlciB0byB0aGUgam9pbmVyXG4gICAgICAgICAgICB0aGlzLnB1c2goZGF0YSk7XG4gICAgICAgIH1cbiAgICAgICAgY2FsbGJhY2soKTtcbiAgICB9XG5cbiAgICBjcmVhdGVEZWNvZGVyKG5vZGUpIHtcbiAgICAgICAgdGhpcy5kZWNvZGVyID0gbm9kZS5nZXREZWNvZGVyKCk7XG5cbiAgICAgICAgbGV0IGRlY29kZXIgPSB0aGlzLmRlY29kZXI7XG4gICAgICAgIGRlY29kZXIuJHJlYWRpbmcgPSBmYWxzZTtcblxuICAgICAgICBpZiAoL150ZXh0XFwvLy50ZXN0KG5vZGUuY29udGVudFR5cGUpICYmIG5vZGUuZmxvd2VkKSB7XG4gICAgICAgICAgICBsZXQgZmxvd0RlY29kZXIgPSBkZWNvZGVyO1xuICAgICAgICAgICAgZGVjb2RlciA9IG5ldyBGbG93ZWREZWNvZGVyKHtcbiAgICAgICAgICAgICAgICBkZWxTcDogbm9kZS5kZWxTcFxuICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICBmbG93RGVjb2Rlci5vbignZXJyb3InLCBlcnIgPT4ge1xuICAgICAgICAgICAgICAgIGRlY29kZXIuZW1pdCgnZXJyb3InLCBlcnIpO1xuICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICBmbG93RGVjb2Rlci5waXBlKGRlY29kZXIpO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIG5vZGUsXG4gICAgICAgICAgICBkZWNvZGVyLFxuICAgICAgICAgICAgZG9uZTogKCkgPT4ge1xuICAgICAgICAgICAgICAgIGlmICh0eXBlb2YgdGhpcy5jb250aW51ZSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgICAgICAgICAgICAgICAgICAvLyBjYWxsZWQgb25jZSBpbnB1dCBzdHJlYW0gaXMgcHJvY2Vzc2VkXG4gICAgICAgICAgICAgICAgICAgIHRoaXMuY29udGludWUoKTtcbiAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICAvLyBjYWxsZWQgYmVmb3JlIGlucHV0IHN0cmVhbSBpcyBwcm9jZXNzZWRcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5jYW5Db250aW51ZSA9IHRydWU7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICB9O1xuICAgIH1cbn1cblxubW9kdWxlLmV4cG9ydHMgPSBOb2RlU3RyZWFtZXI7XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/node_modules/mailsplit/lib/node-streamer.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/node_modules/nodemailer/lib/smtp-connection/http-proxy-client.js":
|
|
/*!************************************************************************************************!*\
|
|
!*** ./node_modules/imapflow/node_modules/nodemailer/lib/smtp-connection/http-proxy-client.js ***!
|
|
\************************************************************************************************/
|
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|
|
|
eval("\n\n/**\n * Minimal HTTP/S proxy client\n */\n\nconst net = __webpack_require__(/*! net */ \"net\");\nconst tls = __webpack_require__(/*! tls */ \"tls\");\nconst urllib = __webpack_require__(/*! url */ \"url\");\n\n/**\n * Establishes proxied connection to destinationPort\n *\n * httpProxyClient(\"http://localhost:3128/\", 80, \"google.com\", function(err, socket){\n * socket.write(\"GET / HTTP/1.0\\r\\n\\r\\n\");\n * });\n *\n * @param {String} proxyUrl proxy configuration, etg \"http://proxy.host:3128/\"\n * @param {Number} destinationPort Port to open in destination host\n * @param {String} destinationHost Destination hostname\n * @param {Function} callback Callback to run with the rocket object once connection is established\n */\nfunction httpProxyClient(proxyUrl, destinationPort, destinationHost, callback) {\n let proxy = urllib.parse(proxyUrl);\n\n // create a socket connection to the proxy server\n let options;\n let connect;\n let socket;\n\n options = {\n host: proxy.hostname,\n port: Number(proxy.port) ? Number(proxy.port) : proxy.protocol === 'https:' ? 443 : 80\n };\n\n if (proxy.protocol === 'https:') {\n // we can use untrusted proxies as long as we verify actual SMTP certificates\n options.rejectUnauthorized = false;\n connect = tls.connect.bind(tls);\n } else {\n connect = net.connect.bind(net);\n }\n\n // Error harness for initial connection. Once connection is established, the responsibility\n // to handle errors is passed to whoever uses this socket\n let finished = false;\n let tempSocketErr = err => {\n if (finished) {\n return;\n }\n finished = true;\n try {\n socket.destroy();\n } catch (E) {\n // ignore\n }\n callback(err);\n };\n\n let timeoutErr = () => {\n let err = new Error('Proxy socket timed out');\n err.code = 'ETIMEDOUT';\n tempSocketErr(err);\n };\n\n socket = connect(options, () => {\n if (finished) {\n return;\n }\n\n let reqHeaders = {\n Host: destinationHost + ':' + destinationPort,\n Connection: 'close'\n };\n if (proxy.auth) {\n reqHeaders['Proxy-Authorization'] = 'Basic ' + Buffer.from(proxy.auth).toString('base64');\n }\n\n socket.write(\n // HTTP method\n 'CONNECT ' +\n destinationHost +\n ':' +\n destinationPort +\n ' HTTP/1.1\\r\\n' +\n // HTTP request headers\n Object.keys(reqHeaders)\n .map(key => key + ': ' + reqHeaders[key])\n .join('\\r\\n') +\n // End request\n '\\r\\n\\r\\n'\n );\n\n let headers = '';\n let onSocketData = chunk => {\n let match;\n let remainder;\n\n if (finished) {\n return;\n }\n\n headers += chunk.toString('binary');\n if ((match = headers.match(/\\r\\n\\r\\n/))) {\n socket.removeListener('data', onSocketData);\n\n remainder = headers.substr(match.index + match[0].length);\n headers = headers.substr(0, match.index);\n if (remainder) {\n socket.unshift(Buffer.from(remainder, 'binary'));\n }\n\n // proxy connection is now established\n finished = true;\n\n // check response code\n match = headers.match(/^HTTP\\/\\d+\\.\\d+ (\\d+)/i);\n if (!match || (match[1] || '').charAt(0) !== '2') {\n try {\n socket.destroy();\n } catch (E) {\n // ignore\n }\n return callback(new Error('Invalid response from proxy' + ((match && ': ' + match[1]) || '')));\n }\n\n socket.removeListener('error', tempSocketErr);\n socket.removeListener('timeout', timeoutErr);\n socket.setTimeout(0);\n\n return callback(null, socket);\n }\n };\n socket.on('data', onSocketData);\n });\n\n socket.setTimeout(httpProxyClient.timeout || 30 * 1000);\n socket.on('timeout', timeoutErr);\n\n socket.once('error', tempSocketErr);\n}\n\nmodule.exports = httpProxyClient;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvaW1hcGZsb3cvbm9kZV9tb2R1bGVzL25vZGVtYWlsZXIvbGliL3NtdHAtY29ubmVjdGlvbi9odHRwLXByb3h5LWNsaWVudC5qcyIsIm1hcHBpbmdzIjoiQUFBYTs7QUFFYjtBQUNBO0FBQ0E7O0FBRUEsWUFBWSxtQkFBTyxDQUFDLGdCQUFLO0FBQ3pCLFlBQVksbUJBQU8sQ0FBQyxnQkFBSztBQUN6QixlQUFlLG1CQUFPLENBQUMsZ0JBQUs7O0FBRTVCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQSxXQUFXLFFBQVE7QUFDbkIsV0FBVyxRQUFRO0FBQ25CLFdBQVcsUUFBUTtBQUNuQixXQUFXLFVBQVU7QUFDckI7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVO0FBQ1Y7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxzQkFBc0I7QUFDdEI7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBOztBQUVBO0FBQ0E7O0FBRUEiLCJzb3VyY2VzIjpbIi9ob21lL2FsbWEvbmV4dGdlbi9OZWFoLW1haWwvbm9kZV9tb2R1bGVzL2ltYXBmbG93L25vZGVfbW9kdWxlcy9ub2RlbWFpbGVyL2xpYi9zbXRwLWNvbm5lY3Rpb24vaHR0cC1wcm94eS1jbGllbnQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG4vKipcbiAqIE1pbmltYWwgSFRUUC9TIHByb3h5IGNsaWVudFxuICovXG5cbmNvbnN0IG5ldCA9IHJlcXVpcmUoJ25ldCcpO1xuY29uc3QgdGxzID0gcmVxdWlyZSgndGxzJyk7XG5jb25zdCB1cmxsaWIgPSByZXF1aXJlKCd1cmwnKTtcblxuLyoqXG4gKiBFc3RhYmxpc2hlcyBwcm94aWVkIGNvbm5lY3Rpb24gdG8gZGVzdGluYXRpb25Qb3J0XG4gKlxuICogaHR0cFByb3h5Q2xpZW50KFwiaHR0cDovL2xvY2FsaG9zdDozMTI4L1wiLCA4MCwgXCJnb29nbGUuY29tXCIsIGZ1bmN0aW9uKGVyciwgc29ja2V0KXtcbiAqICAgICBzb2NrZXQud3JpdGUoXCJHRVQgLyBIVFRQLzEuMFxcclxcblxcclxcblwiKTtcbiAqIH0pO1xuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBwcm94eVVybCBwcm94eSBjb25maWd1cmF0aW9uLCBldGcgXCJodHRwOi8vcHJveHkuaG9zdDozMTI4L1wiXG4gKiBAcGFyYW0ge051bWJlcn0gZGVzdGluYXRpb25Qb3J0IFBvcnQgdG8gb3BlbiBpbiBkZXN0aW5hdGlvbiBob3N0XG4gKiBAcGFyYW0ge1N0cmluZ30gZGVzdGluYXRpb25Ib3N0IERlc3RpbmF0aW9uIGhvc3RuYW1lXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBjYWxsYmFjayBDYWxsYmFjayB0byBydW4gd2l0aCB0aGUgcm9ja2V0IG9iamVjdCBvbmNlIGNvbm5lY3Rpb24gaXMgZXN0YWJsaXNoZWRcbiAqL1xuZnVuY3Rpb24gaHR0cFByb3h5Q2xpZW50KHByb3h5VXJsLCBkZXN0aW5hdGlvblBvcnQsIGRlc3RpbmF0aW9uSG9zdCwgY2FsbGJhY2spIHtcbiAgICBsZXQgcHJveHkgPSB1cmxsaWIucGFyc2UocHJveHlVcmwpO1xuXG4gICAgLy8gY3JlYXRlIGEgc29ja2V0IGNvbm5lY3Rpb24gdG8gdGhlIHByb3h5IHNlcnZlclxuICAgIGxldCBvcHRpb25zO1xuICAgIGxldCBjb25uZWN0O1xuICAgIGxldCBzb2NrZXQ7XG5cbiAgICBvcHRpb25zID0ge1xuICAgICAgICBob3N0OiBwcm94eS5ob3N0bmFtZSxcbiAgICAgICAgcG9ydDogTnVtYmVyKHByb3h5LnBvcnQpID8gTnVtYmVyKHByb3h5LnBvcnQpIDogcHJveHkucHJvdG9jb2wgPT09ICdodHRwczonID8gNDQzIDogODBcbiAgICB9O1xuXG4gICAgaWYgKHByb3h5LnByb3RvY29sID09PSAnaHR0cHM6Jykge1xuICAgICAgICAvLyB3ZSBjYW4gdXNlIHVudHJ1c3RlZCBwcm94aWVzIGFzIGxvbmcgYXMgd2UgdmVyaWZ5IGFjdHVhbCBTTVRQIGNlcnRpZmljYXRlc1xuICAgICAgICBvcHRpb25zLnJlamVjdFVuYXV0aG9yaXplZCA9IGZhbHNlO1xuICAgICAgICBjb25uZWN0ID0gdGxzLmNvbm5lY3QuYmluZCh0bHMpO1xuICAgIH0gZWxzZSB7XG4gICAgICAgIGNvbm5lY3QgPSBuZXQuY29ubmVjdC5iaW5kKG5ldCk7XG4gICAgfVxuXG4gICAgLy8gRXJyb3IgaGFybmVzcyBmb3IgaW5pdGlhbCBjb25uZWN0aW9uLiBPbmNlIGNvbm5lY3Rpb24gaXMgZXN0YWJsaXNoZWQsIHRoZSByZXNwb25zaWJpbGl0eVxuICAgIC8vIHRvIGhhbmRsZSBlcnJvcnMgaXMgcGFzc2VkIHRvIHdob2V2ZXIgdXNlcyB0aGlzIHNvY2tldFxuICAgIGxldCBmaW5pc2hlZCA9IGZhbHNlO1xuICAgIGxldCB0ZW1wU29ja2V0RXJyID0gZXJyID0+IHtcbiAgICAgICAgaWYgKGZpbmlzaGVkKSB7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cbiAgICAgICAgZmluaXNoZWQgPSB0cnVlO1xuICAgICAgICB0cnkge1xuICAgICAgICAgICAgc29ja2V0LmRlc3Ryb3koKTtcbiAgICAgICAgfSBjYXRjaCAoRSkge1xuICAgICAgICAgICAgLy8gaWdub3JlXG4gICAgICAgIH1cbiAgICAgICAgY2FsbGJhY2soZXJyKTtcbiAgICB9O1xuXG4gICAgbGV0IHRpbWVvdXRFcnIgPSAoKSA9PiB7XG4gICAgICAgIGxldCBlcnIgPSBuZXcgRXJyb3IoJ1Byb3h5IHNvY2tldCB0aW1lZCBvdXQnKTtcbiAgICAgICAgZXJyLmNvZGUgPSAnRVRJTUVET1VUJztcbiAgICAgICAgdGVtcFNvY2tldEVycihlcnIpO1xuICAgIH07XG5cbiAgICBzb2NrZXQgPSBjb25uZWN0KG9wdGlvbnMsICgpID0+IHtcbiAgICAgICAgaWYgKGZpbmlzaGVkKSB7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICBsZXQgcmVxSGVhZGVycyA9IHtcbiAgICAgICAgICAgIEhvc3Q6IGRlc3RpbmF0aW9uSG9zdCArICc6JyArIGRlc3RpbmF0aW9uUG9ydCxcbiAgICAgICAgICAgIENvbm5lY3Rpb246ICdjbG9zZSdcbiAgICAgICAgfTtcbiAgICAgICAgaWYgKHByb3h5LmF1dGgpIHtcbiAgICAgICAgICAgIHJlcUhlYWRlcnNbJ1Byb3h5LUF1dGhvcml6YXRpb24nXSA9ICdCYXNpYyAnICsgQnVmZmVyLmZyb20ocHJveHkuYXV0aCkudG9TdHJpbmcoJ2Jhc2U2NCcpO1xuICAgICAgICB9XG5cbiAgICAgICAgc29ja2V0LndyaXRlKFxuICAgICAgICAgICAgLy8gSFRUUCBtZXRob2RcbiAgICAgICAgICAgICdDT05ORUNUICcgK1xuICAgICAgICAgICAgICAgIGRlc3RpbmF0aW9uSG9zdCArXG4gICAgICAgICAgICAgICAgJzonICtcbiAgICAgICAgICAgICAgICBkZXN0aW5hdGlvblBvcnQgK1xuICAgICAgICAgICAgICAgICcgSFRUUC8xLjFcXHJcXG4nICtcbiAgICAgICAgICAgICAgICAvLyBIVFRQIHJlcXVlc3QgaGVhZGVyc1xuICAgICAgICAgICAgICAgIE9iamVjdC5rZXlzKHJlcUhlYWRlcnMpXG4gICAgICAgICAgICAgICAgICAgIC5tYXAoa2V5ID0+IGtleSArICc6ICcgKyByZXFIZWFkZXJzW2tleV0pXG4gICAgICAgICAgICAgICAgICAgIC5qb2luKCdcXHJcXG4nKSArXG4gICAgICAgICAgICAgICAgLy8gRW5kIHJlcXVlc3RcbiAgICAgICAgICAgICAgICAnXFxyXFxuXFxyXFxuJ1xuICAgICAgICApO1xuXG4gICAgICAgIGxldCBoZWFkZXJzID0gJyc7XG4gICAgICAgIGxldCBvblNvY2tldERhdGEgPSBjaHVuayA9PiB7XG4gICAgICAgICAgICBsZXQgbWF0Y2g7XG4gICAgICAgICAgICBsZXQgcmVtYWluZGVyO1xuXG4gICAgICAgICAgICBpZiAoZmluaXNoZWQpIHtcbiAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIGhlYWRlcnMgKz0gY2h1bmsudG9TdHJpbmcoJ2JpbmFyeScpO1xuICAgICAgICAgICAgaWYgKChtYXRjaCA9IGhlYWRlcnMubWF0Y2goL1xcclxcblxcclxcbi8pKSkge1xuICAgICAgICAgICAgICAgIHNvY2tldC5yZW1vdmVMaXN0ZW5lcignZGF0YScsIG9uU29ja2V0RGF0YSk7XG5cbiAgICAgICAgICAgICAgICByZW1haW5kZXIgPSBoZWFkZXJzLnN1YnN0cihtYXRjaC5pbmRleCArIG1hdGNoWzBdLmxlbmd0aCk7XG4gICAgICAgICAgICAgICAgaGVhZGVycyA9IGhlYWRlcnMuc3Vic3RyKDAsIG1hdGNoLmluZGV4KTtcbiAgICAgICAgICAgICAgICBpZiAocmVtYWluZGVyKSB7XG4gICAgICAgICAgICAgICAgICAgIHNvY2tldC51bnNoaWZ0KEJ1ZmZlci5mcm9tKHJlbWFpbmRlciwgJ2JpbmFyeScpKTtcbiAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAvLyBwcm94eSBjb25uZWN0aW9uIGlzIG5vdyBlc3RhYmxpc2hlZFxuICAgICAgICAgICAgICAgIGZpbmlzaGVkID0gdHJ1ZTtcblxuICAgICAgICAgICAgICAgIC8vIGNoZWNrIHJlc3BvbnNlIGNvZGVcbiAgICAgICAgICAgICAgICBtYXRjaCA9IGhlYWRlcnMubWF0Y2goL15IVFRQXFwvXFxkK1xcLlxcZCsgKFxcZCspL2kpO1xuICAgICAgICAgICAgICAgIGlmICghbWF0Y2ggfHwgKG1hdGNoWzFdIHx8ICcnKS5jaGFyQXQoMCkgIT09ICcyJykge1xuICAgICAgICAgICAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgICAgICAgICAgICAgc29ja2V0LmRlc3Ryb3koKTtcbiAgICAgICAgICAgICAgICAgICAgfSBjYXRjaCAoRSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgLy8gaWdub3JlXG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIGNhbGxiYWNrKG5ldyBFcnJvcignSW52YWxpZCByZXNwb25zZSBmcm9tIHByb3h5JyArICgobWF0Y2ggJiYgJzogJyArIG1hdGNoWzFdKSB8fCAnJykpKTtcbiAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICBzb2NrZXQucmVtb3ZlTGlzdGVuZXIoJ2Vycm9yJywgdGVtcFNvY2tldEVycik7XG4gICAgICAgICAgICAgICAgc29ja2V0LnJlbW92ZUxpc3RlbmVyKCd0aW1lb3V0JywgdGltZW91dEVycik7XG4gICAgICAgICAgICAgICAgc29ja2V0LnNldFRpbWVvdXQoMCk7XG5cbiAgICAgICAgICAgICAgICByZXR1cm4gY2FsbGJhY2sobnVsbCwgc29ja2V0KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfTtcbiAgICAgICAgc29ja2V0Lm9uKCdkYXRhJywgb25Tb2NrZXREYXRhKTtcbiAgICB9KTtcblxuICAgIHNvY2tldC5zZXRUaW1lb3V0KGh0dHBQcm94eUNsaWVudC50aW1lb3V0IHx8IDMwICogMTAwMCk7XG4gICAgc29ja2V0Lm9uKCd0aW1lb3V0JywgdGltZW91dEVycik7XG5cbiAgICBzb2NrZXQub25jZSgnZXJyb3InLCB0ZW1wU29ja2V0RXJyKTtcbn1cblxubW9kdWxlLmV4cG9ydHMgPSBodHRwUHJveHlDbGllbnQ7XG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/imapflow/node_modules/nodemailer/lib/smtp-connection/http-proxy-client.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/imapflow/package.json":
|
|
/*!********************************************!*\
|
|
!*** ./node_modules/imapflow/package.json ***!
|
|
\********************************************/
|
|
/***/ ((module) => {
|
|
|
|
module.exports = /*#__PURE__*/JSON.parse('{"name":"imapflow","version":"1.0.184","description":"IMAP Client for Node","main":"./lib/imap-flow.js","scripts":{"test":"grunt","prepare":"npm run build","docs":"rm -rf docs && mkdir -p docs && jsdoc lib/imap-flow.js -c jsdoc.json -R README.md --destination docs/ && cp assets/favicon.ico docs","dst":"node types.js","build":"npm run docs && npm run dst","st":"npm run docs && st -d docs -i index.html","update":"rm -rf node_modules package-lock.json && ncu -u && npm install"},"repository":{"type":"git","url":"git+https://github.com/postalsys/imapflow.git"},"keywords":["imap","email","mail"],"author":"Postal Systems OÜ","license":"MIT","bugs":{"url":"https://github.com/postalsys/imapflow/issues"},"homepage":"https://imapflow.com/","devDependencies":{"@babel/eslint-parser":"7.26.8","@babel/eslint-plugin":"7.25.9","@babel/plugin-syntax-class-properties":"7.12.13","@babel/preset-env":"7.26.9","@types/node":"22.13.10","eslint":"8.57.0","eslint-config-nodemailer":"1.2.0","eslint-config-prettier":"9.1.0","grunt":"1.6.1","grunt-cli":"1.5.0","grunt-contrib-nodeunit":"5.0.0","grunt-eslint":"24.3.0","imapflow-jsdoc-template":"3.4.0-imapflow.2","jsdoc":"3.6.11","st":"3.0.1","tsd-jsdoc":"2.5.0"},"dependencies":{"encoding-japanese":"2.2.0","iconv-lite":"0.6.3","libbase64":"1.3.0","libmime":"5.3.6","libqp":"2.1.1","mailsplit":"5.4.3","nodemailer":"6.10.0","pino":"9.6.0","socks":"2.8.4"}}');
|
|
|
|
/***/ })
|
|
|
|
};
|
|
; |