Built motion from commit 0900f080.|2.5.45
[motion2.git] / server / api / mailInteraction / mailInteraction.controller.js
index 8484e9f..42bbbac 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0x94eb=['nolimit','limit','order','sort','where','pick','field','color','from','tools_tags','u.id','ui.MailInteractionId','user_has_mail_interactions','users','left_join','c.id\x20=\x20i.ContactId\x20AND\x20c.deletedAt\x20IS\x20NULL','o.id\x20=\x20i.UserId','a.id\x20=\x20i.MailAccountId','mail_messages','t.id\x20=\x20it.TagId','expr','search','sqlOperator','conditions','unreadMessages','value','having','operator','$substring','length','MATCH\x20(c.firstName,\x20c.lastName,\x20c.phone,\x20c.mobile,\x20c.fax,\x20c.email)\x20AGAINST\x20(?\x20IN\x20BOOLEAN\x20MODE)','ContactId','buildExpression','text','start','end','Tag','map','CONCAT(\x27,\x27,\x20`TagIds`,\x20\x27,\x27)\x20LIKE\x20?','User','CONCAT_WS(\x27\x20\x27,\x20o.name,\x20o.fullname)\x20LIKE\x20?','find','UserId','plainBody','some','isEmpty','i.MailAccountId\x20IN\x20?','concat','createdAt','parse','$gte','$lte','i.createdAt\x20BETWEEN\x20?\x20AND\x20?','null','\x20=\x20?','read','`unreadMessages`\x20>\x200','tag','filter','replace','isEmail','MATCH\x20(i.to,\x20i.subject)\x20AGAINST\x20(?\x20IN\x20BOOLEAN\x20MODE)','MATCH\x20(me.plainBody,\x20me.subject)\x20AGAINST\x20(?\x20IN\x20BOOLEAN\x20MODE)','getFullTextValue','group','i.id','Sequelize','QueryTypes','SELECT','contactName','DESC','t.id\x20IN\x20?','resolve','MailAccountId','user','role','agent','getMailAccounts','i.MailAccountId\x20IS\x20NULL','sequelize','merge','SUM(me.read\x20=\x200\x20AND\x20me.direction\x20=\x20\x27in\x27)','a.key','Account.key','a.mandatoryDisposition','Account.mandatoryDisposition','i.updatedAt','i.lastMsgAt','i.lastMsgDirection','i.subject','i.secondDisposition','i.thirdDisposition','i.to','i.MailAccountId','i.UserId','c.firstName','Contact.firstName','c.lastName','Contact.lastName','c.email','c.phone','Contact.phone','c.mobile','Contact.mobile','c.fax','Contact.fax','o.fullname','o.internal','Owner.internal','toString','ui.MailInteractionId\x20IN\x20?','MailInteractionId','Setting','enableEmailPreview','push','rows','show','params','fields','includeAll','include','create','body','describe','addMessage','MailMessage','ids','getMessages','format','YYYY-MM-DD\x20HH:mm:ss','options','findAll','addTags','setTags','omit','spread','emit','mailInteractionTags:save','removeTags','download','unix','join','server','files','tmp','root','transcript-%d-%s.zip','Attachment','Attachments','Messages','bcc','each','subject','ddd,\x20DD\x20MMM\x20YYYY\x20HH:mm:ss\x20ZZ','headers','Bcc','basename','existsSync','attachments','readFileSync','build','writeFileSync','message%d.eml','err','unlinkSync','html-pdf','eml-format','rimraf','zip-dir','fast-json-patch','request-promise','moment','bluebird','mustache','util','path','sox','to-csv','ejs','lodash','crypto','desk.js','querystring','papaparse','ioredis','../../components/auth/service','../../components/parsers/qs','../../components/parsers/advancedSearch','../../config/logger','api','../../config/utils','../../config/environment','redis','socket.io-emitter','./mailInteraction.socket','register','sendStatus','status','json','count','offset','set','apply','reject','save','update','destroy','then','error','stack','name','Users','TagIds','Tags','split','forEach','MailInteraction','findOne','lastMsgBody','lastMsgText','trimStart','fromString','catch','index','rawAttributes','fieldName','type','key','model','query','keys','filters','intersection','attributes','hasOwnProperty'];(function(_0x67aa29,_0x43ccea){var _0x5bf35f=function(_0x26f5f4){while(--_0x26f5f4){_0x67aa29['push'](_0x67aa29['shift']());}};_0x5bf35f(++_0x43ccea);}(_0x94eb,0xa5));var _0xb94e=function(_0x12891e,_0x428d9c){_0x12891e=_0x12891e-0x0;var _0x23398e=_0x94eb[_0x12891e];return _0x23398e;};'use strict';var pdf=require(_0xb94e('0x0'));var emlformat=require(_0xb94e('0x1'));var rimraf=require(_0xb94e('0x2'));var zipdir=require(_0xb94e('0x3'));var jsonpatch=require(_0xb94e('0x4'));var rp=require(_0xb94e('0x5'));var moment=require(_0xb94e('0x6'));var BPromise=require(_0xb94e('0x7'));var Mustache=require(_0xb94e('0x8'));var util=require(_0xb94e('0x9'));var path=require(_0xb94e('0xa'));var sox=require(_0xb94e('0xb'));var csv=require(_0xb94e('0xc'));var ejs=require(_0xb94e('0xd'));var fs=require('fs');var _=require(_0xb94e('0xe'));var squel=require('squel');var crypto=require(_0xb94e('0xf'));var jsforce=require('jsforce');var deskjs=require(_0xb94e('0x10'));var toCsv=require(_0xb94e('0xc'));var querystring=require(_0xb94e('0x11'));var Papa=require(_0xb94e('0x12'));var htmlToText=require('html-to-text');var Redis=require(_0xb94e('0x13'));var authService=require(_0xb94e('0x14'));var qs=require(_0xb94e('0x15'));var as=require(_0xb94e('0x16'));var hardwareService=require('../../config/license/hardware');var logger=require(_0xb94e('0x17'))(_0xb94e('0x18'));var utils=require(_0xb94e('0x19'));var config=require(_0xb94e('0x1a'));var licenseUtil=require('../../config/license/util');var db=require('../../mysqldb')['db'];config['redis']=_['defaults'](config[_0xb94e('0x1b')],{'host':'localhost','port':0x18eb});var socket=require(_0xb94e('0x1c'))(new Redis(config[_0xb94e('0x1b')]));require(_0xb94e('0x1d'))[_0xb94e('0x1e')](socket);function respondWithStatusCode(_0x822378,_0x3a4c01){_0x3a4c01=_0x3a4c01||0xcc;return function(_0x1b98a7){if(_0x1b98a7){return _0x822378[_0xb94e('0x1f')](_0x3a4c01);}return _0x822378['status'](_0x3a4c01)['end']();};}function respondWithResult(_0x90f4f8,_0x3f679b){_0x3f679b=_0x3f679b||0xc8;return function(_0x3cb9f8){if(_0x3cb9f8){return _0x90f4f8[_0xb94e('0x20')](_0x3f679b)[_0xb94e('0x21')](_0x3cb9f8);}};}function respondWithFilteredResult(_0x4a47be,_0x54eb69){return function(_0x685e8c){if(_0x685e8c){var _0x2baa6f=_0x685e8c[_0xb94e('0x22')],_0x40f0ec=_0x54eb69[_0xb94e('0x23')],_0x3b0d3e=_0x54eb69[_0xb94e('0x23')]+_0x54eb69['limit'],_0x4fc06e;if(_0x3b0d3e>=_0x2baa6f){_0x3b0d3e=_0x2baa6f;_0x4fc06e=0xc8;}else{_0x4fc06e=0xce;}_0x4a47be[_0xb94e('0x20')](_0x4fc06e);return _0x4a47be[_0xb94e('0x24')]('Content-Range',_0x40f0ec+'-'+_0x3b0d3e+'/'+_0x2baa6f)[_0xb94e('0x21')](_0x685e8c);}return null;};}function patchUpdates(_0x46db3e){return function(_0x41448b){try{jsonpatch[_0xb94e('0x25')](_0x41448b,_0x46db3e,!![]);}catch(_0x4bbac9){return BPromise[_0xb94e('0x26')](_0x4bbac9);}return _0x41448b[_0xb94e('0x27')]();};}function saveUpdates(_0x38f52a,_0x522562){return function(_0x285949){if(_0x285949){return _0x285949[_0xb94e('0x28')](_0x38f52a)['then'](function(_0x1cd4ec){return _0x1cd4ec;});}return null;};}function removeEntity(_0x1b821e,_0x297654){return function(_0x2d3add){if(_0x2d3add){return _0x2d3add[_0xb94e('0x29')]()[_0xb94e('0x2a')](function(){_0x1b821e[_0xb94e('0x20')](0xcc)['end']();});}};}function handleEntityNotFound(_0x1df810,_0x3d271e){return function(_0x4ac535){if(!_0x4ac535){_0x1df810['sendStatus'](0x194);}return _0x4ac535;};}function handleError(_0x1f3265,_0x1752c1){_0x1752c1=_0x1752c1||0x1f4;return function(_0x4a3ce2){logger[_0xb94e('0x2b')](_0x4a3ce2[_0xb94e('0x2c')]);if(_0x4a3ce2[_0xb94e('0x2d')]){delete _0x4a3ce2[_0xb94e('0x2d')];}_0x1f3265[_0xb94e('0x20')](_0x1752c1)['send'](_0x4a3ce2);};}function getInteractionUsers(_0x1d8018,_0xfa2e1f){return new BPromise(function(_0x580c14,_0x58f1ac){try{if(_0xfa2e1f[_0x1d8018['id']]){_0x1d8018[_0xb94e('0x2e')]=_['map'](_0xfa2e1f[_0x1d8018['id']],function(_0x451474){return{'id':_0x451474['id'],'fullname':_0x451474['fullname']};});}}catch(_0x96912f){_0x58f1ac(_0x96912f);}_0x580c14(_0x1d8018);});}function getInteractionTags(_0x287ebd,_0x1925ed){return new BPromise(function(_0x9eef51,_0x11760f){try{if(_0x287ebd[_0xb94e('0x2f')]){_0x287ebd[_0xb94e('0x30')]=[];_0x287ebd[_0xb94e('0x2f')][_0xb94e('0x31')](',')[_0xb94e('0x32')](function(_0x197b74){_0x287ebd[_0xb94e('0x30')]['push'](_0x1925ed[_0x197b74]);});}delete _0x287ebd[_0xb94e('0x2f')];}catch(_0x32bc5b){_0x11760f(_0x32bc5b);}_0x9eef51(_0x287ebd);});}function getLastMessageText(_0x5b6750){return new BPromise(function(_0x1c197c,_0x57ad90){return db[_0xb94e('0x33')][_0xb94e('0x34')]({'where':{'id':_0x5b6750['id']},'attributes':[_0xb94e('0x35'),'lastMsgText'],'raw':!![]})[_0xb94e('0x2a')](function(_0x1c14ec){if(!_0x1c14ec[_0xb94e('0x36')]){_0x5b6750[_0xb94e('0x36')]=_[_0xb94e('0x37')](htmlToText[_0xb94e('0x38')](_0x1c14ec['lastMsgBody'],{'preserveNewlines':!![],'singleNewLineParagraphs':!![],'uppercaseHeadings':![],'noLinkBrackets':!![],'ignoreImage':!![]}));}else{_0x5b6750[_0xb94e('0x36')]=_0x1c14ec[_0xb94e('0x36')];}_0x1c197c(_0x5b6750);})['catch'](function(_0x3598ae){_0x57ad90(_0x3598ae);});});}function updateMailInteraction(_0x30122e,_0x50af42,_0x5720e5,_0x3b6106){return new BPromise(function(_0x371829,_0xc372ca){return getInteractionUsers(_0x30122e,_0x5720e5)['then'](function(_0x1c9c8b){return getInteractionTags(_0x1c9c8b,_0x50af42);})[_0xb94e('0x2a')](function(_0x53d62d){if(_0x3b6106){_0x371829(getLastMessageText(_0x53d62d));}else{_0x371829(_0x53d62d);}})[_0xb94e('0x39')](function(_0x319282){_0xc372ca(_0x319282);});});}exports[_0xb94e('0x3a')]=function(_0x8f6cc1,_0xbae9ca){var _0x3438ec={},_0x5747f6={},_0x3e53e2={'count':0x0,'rows':[]};var _0xe0cdd9=_['map'](db[_0xb94e('0x33')][_0xb94e('0x3b')],function(_0x39c9b4){return{'name':_0x39c9b4[_0xb94e('0x3c')],'type':_0x39c9b4[_0xb94e('0x3d')][_0xb94e('0x3e')]};});_0x5747f6[_0xb94e('0x3f')]=_['map'](_0xe0cdd9,_0xb94e('0x2d'));_0x5747f6[_0xb94e('0x40')]=_[_0xb94e('0x41')](_0x8f6cc1['query']);_0x5747f6[_0xb94e('0x42')]=_[_0xb94e('0x43')](_0x5747f6['model'],_0x5747f6[_0xb94e('0x40')]);_0x3438ec[_0xb94e('0x44')]=_[_0xb94e('0x43')](_0x5747f6[_0xb94e('0x3f')],qs['fields'](_0x8f6cc1[_0xb94e('0x40')]['fields']));_0x3438ec[_0xb94e('0x44')]=_0x3438ec['attributes']['length']?_0x3438ec[_0xb94e('0x44')]:_0x5747f6['model'];if(!_0x8f6cc1[_0xb94e('0x40')][_0xb94e('0x45')](_0xb94e('0x46'))){_0x3438ec[_0xb94e('0x47')]=qs['limit'](_0x8f6cc1[_0xb94e('0x40')][_0xb94e('0x47')]);_0x3438ec[_0xb94e('0x23')]=qs[_0xb94e('0x23')](_0x8f6cc1['query'][_0xb94e('0x23')]);}_0x3438ec[_0xb94e('0x48')]=qs[_0xb94e('0x49')](_0x8f6cc1['query'][_0xb94e('0x49')]);_0x3438ec[_0xb94e('0x4a')]=qs[_0xb94e('0x42')](_[_0xb94e('0x4b')](_0x8f6cc1[_0xb94e('0x40')],_0x5747f6[_0xb94e('0x42')]),_0xe0cdd9);var _0x3b3aec=[];var _0x5660a8=squel['select']()[_0xb94e('0x4c')]('id')['field'](_0xb94e('0x2d'))[_0xb94e('0x4c')](_0xb94e('0x4d'))[_0xb94e('0x4e')](_0xb94e('0x4f'));var _0x52dce6=squel['select']()[_0xb94e('0x4c')](_0xb94e('0x50'))[_0xb94e('0x4c')]('u.fullname')['field'](_0xb94e('0x51'))[_0xb94e('0x4e')](_0xb94e('0x52'),'ui')['left_join'](_0xb94e('0x53'),'u','u.id\x20=\x20ui.UserId');var _0x530adf=squel['select']()[_0xb94e('0x4e')]('mail_interactions','i')[_0xb94e('0x54')]('cm_contacts','c',_0xb94e('0x55'))[_0xb94e('0x54')](_0xb94e('0x53'),'o',_0xb94e('0x56'))[_0xb94e('0x54')]('mail_accounts','a',_0xb94e('0x57'))['left_join'](_0xb94e('0x58'),'me','me.MailInteractionId\x20=\x20i.id')['left_join']('mail_interaction_has_tags','it','it.MailInteractionId\x20=\x20i.id')['left_join']('tools_tags','t',_0xb94e('0x59'));var _0x316282=squel['expr']();var _0x4861a9=[];var _0x3c2b06=squel[_0xb94e('0x5a')]();var _0x19cddf;if(_0x8f6cc1[_0xb94e('0x40')][_0xb94e('0x5b')]){_0x19cddf=as['parseSearch'](_0x8f6cc1[_0xb94e('0x40')]['search']);var _0x609307=_0x19cddf[_0xb94e('0x5c')];for(var _0x25e190=0x0;_0x25e190<_0x19cddf[_0xb94e('0x5d')]['length'];_0x25e190++){var _0x1ed28a=_0x19cddf[_0xb94e('0x5d')][_0x25e190];var _0x597501='i';var _0x2ac545=_['find'](_0xe0cdd9,['name',_0x1ed28a[_0xb94e('0x4c')]]);if(!_0x2ac545){switch(_0x1ed28a[_0xb94e('0x4c')]){case _0xb94e('0x5e'):if(_0x1ed28a[_0xb94e('0x5f')]==0x1){_0x530adf[_0xb94e('0x60')]('`'+_0x1ed28a[_0xb94e('0x4c')]+'`\x20=\x200');}else{_0x530adf[_0xb94e('0x60')]('`'+_0x1ed28a[_0xb94e('0x4c')]+'`\x20>\x200');}break;case'Contact':if(_0x1ed28a[_0xb94e('0x61')]===_0xb94e('0x62')){if(_0x1ed28a[_0xb94e('0x5f')]['split']('\x20')[_0xb94e('0x63')]>0x1){_0x316282[_0x609307](_0xb94e('0x64'),qs['getFullTextValue'](_0x1ed28a[_0xb94e('0x5f')]),null);}else{var _0x2b3554='%'+_0x1ed28a[_0xb94e('0x5f')]+'%';_0x316282[_0x609307]('c.firstName\x20LIKE\x20?\x20OR\x20c.lastName\x20LIKE\x20?\x20OR\x20c.email\x20LIKE\x20?',_0x2b3554,_0x2b3554,_0x2b3554);}}else{_0x2ac545=_['find'](_0xe0cdd9,[_0xb94e('0x2d'),_0xb94e('0x65')]);_0x1ed28a[_0xb94e('0x4c')]=_0xb94e('0x65');_0x538372=as[_0xb94e('0x66')](_0x597501,_0x2ac545[_0xb94e('0x3d')],_0x1ed28a);_0x316282[_0x609307](_0x538372[_0xb94e('0x67')],_0x538372[_0xb94e('0x5f')][_0xb94e('0x68')],_0x538372[_0xb94e('0x5f')][_0xb94e('0x69')]);}break;case _0xb94e('0x6a'):var _0x4062f7=_0x1ed28a[_0xb94e('0x5f')][_0xb94e('0x31')](',')[_0xb94e('0x6b')](function(_0xa65f25){return Number(_0xa65f25);});_0x4062f7[_0xb94e('0x32')](function(_0x516b34){_0x3c2b06['or'](_0xb94e('0x6c'),'%,'+_0x516b34+',%');});_0x4861a9=_['union'](_0x4861a9,_0x4062f7);break;case _0xb94e('0x6d'):if(_0x1ed28a[_0xb94e('0x61')]===_0xb94e('0x62')){_0x316282[_0x609307](_0xb94e('0x6e'),'%'+_0x1ed28a[_0xb94e('0x5f')]+'%',null);}else{_0x2ac545=_[_0xb94e('0x6f')](_0xe0cdd9,[_0xb94e('0x2d'),'UserId']);_0x1ed28a[_0xb94e('0x4c')]=_0xb94e('0x70');_0x538372=as['buildExpression'](_0x597501,_0x2ac545[_0xb94e('0x3d')],_0x1ed28a);_0x316282[_0x609307](_0x538372['text'],_0x538372[_0xb94e('0x5f')][_0xb94e('0x68')],_0x538372[_0xb94e('0x5f')][_0xb94e('0x69')]);}break;case _0xb94e('0x71'):_0x538372=as[_0xb94e('0x66')]('me',null,_0x1ed28a);_0x316282[_0x609307](_0x538372['text'],_0x538372[_0xb94e('0x5f')][_0xb94e('0x68')],_0x538372[_0xb94e('0x5f')][_0xb94e('0x69')]);break;}}else{var _0x538372=as[_0xb94e('0x66')](_0x597501,_0x2ac545[_0xb94e('0x3d')],_0x1ed28a);_0x316282[_0x609307](_0x538372[_0xb94e('0x67')],_0x538372[_0xb94e('0x5f')][_0xb94e('0x68')],_0x538372[_0xb94e('0x5f')][_0xb94e('0x69')]);}}}else{var _0x1ed56b=_(_0x8f6cc1[_0xb94e('0x40')])[_0xb94e('0x41')]()['map'](function(_0x2a7a6e){return _[_0xb94e('0x72')](_0xe0cdd9,['name',_0x2a7a6e])?_0x2a7a6e:undefined;})['compact']()['value']();if(!_[_0xb94e('0x73')](_0x1ed56b)){_0x1ed56b[_0xb94e('0x32')](function(_0x113bae){if(_0x113bae==='MailAccountId'){_0x530adf[_0xb94e('0x4a')](_0xb94e('0x74'),[][_0xb94e('0x75')](_0x8f6cc1[_0xb94e('0x40')][_0x113bae]));}else if(_0x113bae===_0xb94e('0x76')){var _0x2bec4d=JSON[_0xb94e('0x77')](_0x8f6cc1[_0xb94e('0x40')][_0x113bae])[_0xb94e('0x78')];var _0x4f76fe=JSON['parse'](_0x8f6cc1[_0xb94e('0x40')][_0x113bae])[_0xb94e('0x79')];_0x530adf[_0xb94e('0x4a')](_0xb94e('0x7a'),_0x2bec4d,_0x4f76fe);}else{if(_0x8f6cc1[_0xb94e('0x40')][_0x113bae]===_0xb94e('0x7b')){_0x530adf['where']('i.'+_0x113bae+'\x20IS\x20NULL');}else{_0x530adf[_0xb94e('0x4a')]('i.'+_0x113bae+_0xb94e('0x7c'),_0x8f6cc1[_0xb94e('0x40')][_0x113bae]);}}});}if(_0x8f6cc1[_0xb94e('0x40')][_0xb94e('0x7d')]){if(_0x8f6cc1[_0xb94e('0x40')]['read']==0x1){_0x530adf[_0xb94e('0x60')]('`unreadMessages`\x20=\x200');}else{_0x530adf['having'](_0xb94e('0x7e'));}}if(_0x8f6cc1[_0xb94e('0x40')]['tag']){_0x4861a9=_['isArray'](_0x8f6cc1[_0xb94e('0x40')][_0xb94e('0x7f')])?_0x8f6cc1[_0xb94e('0x40')]['tag']:new Array(_0x8f6cc1['query'][_0xb94e('0x7f')]);_0x4861a9[_0xb94e('0x32')](function(_0x3297e3){_0x3c2b06['or'](_0xb94e('0x6c'),'%,'+_0x3297e3+',%');});}if(_0x8f6cc1[_0xb94e('0x40')][_0xb94e('0x80')]){var _0x128014=_0x8f6cc1[_0xb94e('0x40')][_0xb94e('0x80')][_0xb94e('0x81')]('\x5c','\x5c\x5c')[_0xb94e('0x81')](/'/g,'\x27\x27');if(qs['isNumeric'](_0x128014)){_0x316282['or']('i.id\x20LIKE\x20?',_0x128014+'%');}else if(qs[_0xb94e('0x82')](_0x128014)){_0x316282['or']('c.email\x20LIKE\x20?',_0x128014+'%');}else{_0x316282['or'](_0xb94e('0x83'),qs['getFullTextValue'](_0x128014))['or'](_0xb94e('0x84'),qs[_0xb94e('0x85')](_0x128014));}}}_0x530adf[_0xb94e('0x4a')](_0x316282);_0x530adf[_0xb94e('0x86')](_0xb94e('0x87'));var _0x5fb63b={'type':db[_0xb94e('0x88')][_0xb94e('0x89')][_0xb94e('0x8a')],'raw':!![]};var _0x47b195=_0x530adf['clone']();_0x47b195['field']('i.id');_0x47b195[_0xb94e('0x4c')]('SUM(me.read\x20=\x200\x20AND\x20me.direction\x20=\x20\x27in\x27)',_0xb94e('0x5e'));if(_0x3438ec[_0xb94e('0x48')]){_0x3438ec[_0xb94e('0x48')][_0xb94e('0x32')](function(_0xd95cb0){var _0x5a7f2f=_0xd95cb0[0x0]===_0xb94e('0x8b')?_0xd95cb0[0x0]:'i.'+_0xd95cb0[0x0];_0x530adf[_0xb94e('0x48')](_0x5a7f2f,_0xd95cb0[0x1]===_0xb94e('0x8c')?![]:!![]);});}if(!_[_0xb94e('0x73')](_0x4861a9)){_0x530adf[_0xb94e('0x60')](_0x3c2b06);_0x47b195[_0xb94e('0x4a')](_0xb94e('0x8d'),_0x4861a9);}BPromise[_0xb94e('0x8e')]()['then'](function(){if(!_0x19cddf){if(_0x8f6cc1[_0xb94e('0x40')][_0xb94e('0x8f')]||_0x8f6cc1[_0xb94e('0x40')]['journey'])return;_0x47b195[_0xb94e('0x4a')]('i.MailAccountId\x20IS\x20NOT\x20NULL');_0x530adf[_0xb94e('0x4a')]('i.MailAccountId\x20IS\x20NOT\x20NULL');return;}if(_0x8f6cc1[_0xb94e('0x90')][_0xb94e('0x91')]!==_0xb94e('0x92'))return;return _0x8f6cc1[_0xb94e('0x90')][_0xb94e('0x93')]({'attributes':['id'],'raw':!![]})['then'](function(_0x33d5f9){if(_[_0xb94e('0x73')](_0x33d5f9)){_0x47b195['where'](_0xb94e('0x94'));_0x530adf[_0xb94e('0x4a')]('i.MailAccountId\x20IS\x20NULL');}else{_0x47b195[_0xb94e('0x4a')](_0xb94e('0x74'),_[_0xb94e('0x6b')](_0x33d5f9,'id'));_0x530adf[_0xb94e('0x4a')](_0xb94e('0x74'),_[_0xb94e('0x6b')](_0x33d5f9,'id'));}});})[_0xb94e('0x2a')](function(){if(_0x8f6cc1[_0xb94e('0x90')][_0xb94e('0x91')]===_0xb94e('0x92')&&!_0x19cddf&&!_0x8f6cc1[_0xb94e('0x40')][_0xb94e('0x8f')])return[];return db[_0xb94e('0x95')][_0xb94e('0x40')](_0x47b195['toString'](),_0x5fb63b);})[_0xb94e('0x2a')](function(_0x54530b){_0x3e53e2['count']=_0x54530b[_0xb94e('0x63')];if(_0x3e53e2['count']===0x0)return[];return db[_0xb94e('0x95')][_0xb94e('0x40')](_0x5660a8['toString'](),_0x5fb63b)[_0xb94e('0x2a')](function(_0x22dbb9){_0x3b3aec=_['keyBy'](_0x22dbb9,'id');_0x5fb63b=_[_0xb94e('0x96')](_0x5fb63b,{'model':db[_0xb94e('0x33')],'mapToModel':!![],'raw':!![],'nest':!![]});if(_0x8f6cc1[_0xb94e('0x40')]['fields']){_0x3438ec[_0xb94e('0x44')]['forEach'](function(_0x3e1f6f){_0x530adf[_0xb94e('0x4c')]('i.'+_0x3e1f6f);});}else{_0x530adf[_0xb94e('0x4c')](_0xb94e('0x97'),'unreadMessages');_0x530adf[_0xb94e('0x4c')](_0xb94e('0x98'),_0xb94e('0x99'));_0x530adf[_0xb94e('0x4c')](_0xb94e('0x9a'),_0xb94e('0x9b'));_0x530adf[_0xb94e('0x4c')]('CASE\x20WHEN\x20i.to\x20IS\x20NOT\x20NULL\x20AND\x20i.to\x20<>\x20\x27\x27\x20AND\x20i.to\x20NOT\x20LIKE\x20(\x27%\x27\x20+\x20a.email\x20+\x20\x27%\x27)\x20THEN\x20SUBSTRING_INDEX(i.to,\x20\x27<\x27,\x201)\x20WHEN\x20(c.firstName\x20IS\x20NOT\x20NULL\x20AND\x20c.firstName\x20<>\x20\x27\x27)\x20OR\x20(c.lastName\x20IS\x20NOT\x20NULL\x20AND\x20c.lastName\x20<>\x20\x27\x27)\x20THEN\x20CONCAT(IFNULL(c.firstName,\x20\x27\x27),\x20\x27\x20\x27,\x20IFNULL(c.lastName,\x20\x27\x27))\x20ELSE\x20\x27Unknown\x27\x20END',_0xb94e('0x8b'));_0x530adf[_0xb94e('0x4c')](_0xb94e('0x87'));_0x530adf[_0xb94e('0x4c')]('i.createdAt');_0x530adf['field'](_0xb94e('0x9c'));_0x530adf[_0xb94e('0x4c')]('i.closed');_0x530adf['field']('i.closedAt');_0x530adf['field']('i.attach');_0x530adf[_0xb94e('0x4c')](_0xb94e('0x9d'));_0x530adf['field'](_0xb94e('0x9e'));_0x530adf[_0xb94e('0x4c')](_0xb94e('0x9f'));_0x530adf['field']('i.disposition');_0x530adf[_0xb94e('0x4c')](_0xb94e('0xa0'));_0x530adf[_0xb94e('0x4c')](_0xb94e('0xa1'));_0x530adf[_0xb94e('0x4c')]('i.substatus');_0x530adf[_0xb94e('0x4c')](_0xb94e('0xa2'));_0x530adf[_0xb94e('0x4c')]('i.ContactId');_0x530adf['field'](_0xb94e('0xa3'));_0x530adf[_0xb94e('0x4c')](_0xb94e('0xa4'));_0x530adf[_0xb94e('0x4c')](_0xb94e('0xa5'),_0xb94e('0xa6'));_0x530adf[_0xb94e('0x4c')](_0xb94e('0xa7'),_0xb94e('0xa8'));_0x530adf[_0xb94e('0x4c')](_0xb94e('0xa9'),'Contact.email');_0x530adf[_0xb94e('0x4c')](_0xb94e('0xaa'),_0xb94e('0xab'));_0x530adf[_0xb94e('0x4c')](_0xb94e('0xac'),_0xb94e('0xad'));_0x530adf[_0xb94e('0x4c')](_0xb94e('0xae'),_0xb94e('0xaf'));_0x530adf[_0xb94e('0x4c')](_0xb94e('0xb0'),'Owner.fullname');_0x530adf['field'](_0xb94e('0xb1'),_0xb94e('0xb2'));_0x530adf[_0xb94e('0x4c')]('GROUP_CONCAT(DISTINCT\x20t.id)',_0xb94e('0x2f'));}if(_0x3438ec[_0xb94e('0x47')])_0x530adf[_0xb94e('0x47')](_0x3438ec[_0xb94e('0x47')]);if(_0x3438ec[_0xb94e('0x23')])_0x530adf[_0xb94e('0x23')](_0x3438ec['offset']);return db[_0xb94e('0x95')][_0xb94e('0x40')](_0x530adf[_0xb94e('0xb3')](),_0x5fb63b);})[_0xb94e('0x2a')](function(_0x1a98d4){_0x52dce6['where'](_0xb94e('0xb4'),_[_0xb94e('0x6b')](_0x1a98d4,'id'));return db['sequelize'][_0xb94e('0x40')](_0x52dce6[_0xb94e('0xb3')](),_0x5fb63b)[_0xb94e('0x2a')](function(_0x5a0a05){var _0x5170fb=_['groupBy'](_0x5a0a05,_0xb94e('0xb5'));var _0x2fbe6f=[];return db[_0xb94e('0xb6')][_0xb94e('0x34')]({'attributes':[_0xb94e('0xb7')],'raw':!![]})[_0xb94e('0x2a')](function(_0x26498b){var _0x31b649=_0x26498b[_0xb94e('0xb7')];_0x1a98d4['forEach'](function(_0x364cac){_0x2fbe6f[_0xb94e('0xb8')](updateMailInteraction(_0x364cac,_0x3b3aec,_0x5170fb,_0x31b649));});return BPromise['all'](_0x2fbe6f);});});});})[_0xb94e('0x2a')](function(_0x3b0f04){_0x3e53e2[_0xb94e('0xb9')]=_0x3b0f04;return _0x3e53e2;})[_0xb94e('0x2a')](respondWithFilteredResult(_0xbae9ca,_0x3438ec))['catch'](handleError(_0xbae9ca,null));};exports[_0xb94e('0xba')]=function(_0x6838fb,_0x511510){var _0x568c23={'raw':![],'where':{'id':_0x6838fb[_0xb94e('0xbb')]['id']}},_0x21e772={};_0x21e772[_0xb94e('0x3f')]=_[_0xb94e('0x41')](db[_0xb94e('0x33')][_0xb94e('0x3b')]);_0x21e772[_0xb94e('0x40')]=_[_0xb94e('0x41')](_0x6838fb[_0xb94e('0x40')]);_0x21e772[_0xb94e('0x42')]=_['intersection'](_0x21e772['model'],_0x21e772[_0xb94e('0x40')]);_0x568c23[_0xb94e('0x44')]=_[_0xb94e('0x43')](_0x21e772[_0xb94e('0x3f')],qs[_0xb94e('0xbc')](_0x6838fb['query'][_0xb94e('0xbc')]));_0x568c23[_0xb94e('0x44')]=_0x568c23[_0xb94e('0x44')]['length']?_0x568c23['attributes']:_0x21e772[_0xb94e('0x3f')];if(_0x6838fb[_0xb94e('0x40')][_0xb94e('0xbd')]){_0x568c23[_0xb94e('0xbe')]=[{'all':!![]}];}_0x568c23=_[_0xb94e('0x96')]({},_0x568c23,_0x6838fb['options']);return db[_0xb94e('0x33')][_0xb94e('0x6f')](_0x568c23)['then'](handleEntityNotFound(_0x511510,null))['then'](respondWithResult(_0x511510,null))[_0xb94e('0x39')](handleError(_0x511510,null));};exports[_0xb94e('0xbf')]=function(_0x29a563,_0x1b9877){return db[_0xb94e('0x33')][_0xb94e('0xbf')](_0x29a563[_0xb94e('0xc0')],{})[_0xb94e('0x2a')](respondWithResult(_0x1b9877,0xc9))[_0xb94e('0x39')](handleError(_0x1b9877,null));};exports[_0xb94e('0x28')]=function(_0x493c50,_0x73c426){if(_0x493c50[_0xb94e('0xc0')]['id']){delete _0x493c50['body']['id'];}return db[_0xb94e('0x33')][_0xb94e('0x6f')]({'where':{'id':_0x493c50[_0xb94e('0xbb')]['id']}})['then'](handleEntityNotFound(_0x73c426,null))[_0xb94e('0x2a')](saveUpdates(_0x493c50[_0xb94e('0xc0')],null))[_0xb94e('0x2a')](respondWithResult(_0x73c426,null))[_0xb94e('0x39')](handleError(_0x73c426,null));};exports[_0xb94e('0x29')]=function(_0x54276e,_0x4ac2dd){return db[_0xb94e('0x33')][_0xb94e('0x6f')]({'where':{'id':_0x54276e[_0xb94e('0xbb')]['id']}})['then'](handleEntityNotFound(_0x4ac2dd,null))[_0xb94e('0x2a')](removeEntity(_0x4ac2dd,null))[_0xb94e('0x39')](handleError(_0x4ac2dd,null));};exports[_0xb94e('0xc1')]=function(_0xb1e66b,_0x3f32af){return db[_0xb94e('0x33')]['describe']()[_0xb94e('0x2a')](respondWithResult(_0x3f32af,null))[_0xb94e('0x39')](handleError(_0x3f32af,null));};exports[_0xb94e('0xc2')]=function(_0x52fa9c,_0x327af1,_0xe13d85){return db[_0xb94e('0xc3')][_0xb94e('0x6f')]({'where':{'id':_0x52fa9c[_0xb94e('0xbb')]['id']}})['then'](handleEntityNotFound(_0x327af1,null))[_0xb94e('0x2a')](function(_0x5b1325){if(_0x5b1325){return _0x5b1325[_0xb94e('0xc2')](_0x52fa9c['body'][_0xb94e('0xc4')],_['omit'](_0x52fa9c['body'],['ids','id'])||{});}})[_0xb94e('0x2a')](respondWithResult(_0x327af1,null))[_0xb94e('0x39')](handleError(_0x327af1,null));};exports[_0xb94e('0xc5')]=function(_0x192dd6,_0x5c633a,_0x2dbd94){var _0x2e311f={'raw':![],'where':{}};var _0x297b8e={};var _0x4271d3={'count':0x0,'rows':[]};return db['MailInteraction']['findOne']({'where':{'id':_0x192dd6[_0xb94e('0xbb')]['id']}})[_0xb94e('0x2a')](handleEntityNotFound(_0x5c633a,null))[_0xb94e('0x2a')](function(_0x3af0d3){if(_0x3af0d3){_0x297b8e[_0xb94e('0x3f')]=_['keys'](db[_0xb94e('0xc3')][_0xb94e('0x3b')]);_0x297b8e[_0xb94e('0x40')]=_['keys'](_0x192dd6[_0xb94e('0x40')]);_0x297b8e[_0xb94e('0x42')]=_[_0xb94e('0x43')](_0x297b8e[_0xb94e('0x3f')],_0x297b8e[_0xb94e('0x40')]);_0x2e311f['attributes']=_[_0xb94e('0x43')](_0x297b8e[_0xb94e('0x3f')],qs['fields'](_0x192dd6[_0xb94e('0x40')]['fields']));_0x2e311f['attributes']=_0x2e311f[_0xb94e('0x44')]['length']?_0x2e311f[_0xb94e('0x44')]:_0x297b8e[_0xb94e('0x3f')];if(!_0x192dd6[_0xb94e('0x40')][_0xb94e('0x45')](_0xb94e('0x46'))){_0x2e311f['limit']=qs[_0xb94e('0x47')](_0x192dd6['query'][_0xb94e('0x47')]);_0x2e311f['offset']=qs[_0xb94e('0x23')](_0x192dd6[_0xb94e('0x40')][_0xb94e('0x23')]);}_0x2e311f[_0xb94e('0x48')]=qs[_0xb94e('0x49')](_0x192dd6[_0xb94e('0x40')][_0xb94e('0x49')]);_0x2e311f[_0xb94e('0x4a')]=qs[_0xb94e('0x42')](_[_0xb94e('0x4b')](_0x192dd6[_0xb94e('0x40')],_0x297b8e[_0xb94e('0x42')]));_0x2e311f[_0xb94e('0x4a')][_0xb94e('0xb5')]=_0x3af0d3['id'];if(_0x192dd6[_0xb94e('0x40')]['filter']){_0x2e311f['where']=_['merge'](_0x2e311f[_0xb94e('0x4a')],{'$or':_[_0xb94e('0x6b')](_0x2e311f[_0xb94e('0x44')],function(_0x3fd9f0){var _0x222ea0={};_0x222ea0[_0x3fd9f0]={'$like':'%'+_0x192dd6[_0xb94e('0x40')]['filter']+'%'};return _0x222ea0;})});}if(_0x192dd6['query'][_0xb94e('0x78')]){var _0x26e17b=_0x192dd6[_0xb94e('0x40')][_0xb94e('0x78')][_0xb94e('0x31')](',');var _0xa327dd={};_0xa327dd[_0x26e17b[0x0]]={'$gte':moment(_0x26e17b[0x1])[_0xb94e('0xc6')](_0xb94e('0xc7'))};_0x2e311f['where']=_[_0xb94e('0x96')](_0x2e311f[_0xb94e('0x4a')],_0xa327dd);}_0x2e311f=_['merge']({},_0x2e311f,_0x192dd6[_0xb94e('0xc8')]);return db[_0xb94e('0xc3')][_0xb94e('0x22')]({'where':_0x2e311f[_0xb94e('0x4a')]})[_0xb94e('0x2a')](function(_0x2232a3){_0x4271d3['count']=_0x2232a3;if(_0x192dd6[_0xb94e('0x40')]['includeAll']){_0x2e311f[_0xb94e('0xbe')]=[{'all':!![]}];}return db[_0xb94e('0xc3')][_0xb94e('0xc9')](_0x2e311f);})[_0xb94e('0x2a')](function(_0x3c35e0){_0x4271d3[_0xb94e('0xb9')]=_0x3c35e0;return _0x4271d3;});}})[_0xb94e('0x2a')](respondWithFilteredResult(_0x5c633a,_0x2e311f))['catch'](handleError(_0x5c633a,null));};exports[_0xb94e('0xca')]=function(_0x68dcaa,_0x427bf2,_0xfb128){return db[_0xb94e('0x33')][_0xb94e('0x6f')]({'where':{'id':_0x68dcaa[_0xb94e('0xbb')]['id']}})[_0xb94e('0x2a')](handleEntityNotFound(_0x427bf2,null))[_0xb94e('0x2a')](function(_0x887254){if(_0x887254){return _0x887254[_0xb94e('0xcb')](_0x68dcaa[_0xb94e('0xc0')][_0xb94e('0xc4')],_[_0xb94e('0xcc')](_0x68dcaa[_0xb94e('0xc0')],[_0xb94e('0xc4'),'id'])||{})[_0xb94e('0xcd')](function(){return db[_0xb94e('0x6a')]['findAll']({'attributes':['id','name','color'],'where':{'id':_0x68dcaa[_0xb94e('0xc0')][_0xb94e('0xc4')]}});})[_0xb94e('0x2a')](function(_0x5e2359){socket[_0xb94e('0xce')](_0xb94e('0xcf'),{'id':Number(_0x68dcaa['params']['id']),'tags':_0x5e2359||[]});return{'id':Number(_0x68dcaa['params']['id']),'tags':_0x5e2359||[]};});}})[_0xb94e('0x2a')](respondWithResult(_0x427bf2,null))[_0xb94e('0x39')](handleError(_0x427bf2,null));};exports[_0xb94e('0xd0')]=function(_0x560e16,_0x5a9db8,_0xc563ee){return db[_0xb94e('0x33')]['find']({'where':{'id':_0x560e16[_0xb94e('0xbb')]['id']}})[_0xb94e('0x2a')](handleEntityNotFound(_0x5a9db8,null))['then'](function(_0x554c0d){if(_0x554c0d){return _0x554c0d['removeTags'](_0x560e16[_0xb94e('0x40')][_0xb94e('0xc4')]);}})[_0xb94e('0x2a')](respondWithStatusCode(_0x5a9db8,null))[_0xb94e('0x39')](handleError(_0x5a9db8,null));};exports[_0xb94e('0xd1')]=function(_0x5c8e79,_0x5c9a27){var _0xc554b5=moment()[_0xb94e('0xd2')]()['toString']();var _0xc3f758=path[_0xb94e('0xd3')](config['root'],_0xb94e('0xd4'),_0xb94e('0xd5'),_0xb94e('0xd6'));var _0x44e8a9=path[_0xb94e('0xd3')](config[_0xb94e('0xd7')],_0xb94e('0xd4'),'files','attachments');var _0x5be5df=path[_0xb94e('0xd3')](_0xc3f758,_0xc554b5);var _0x115eac=util['format'](_0xb94e('0xd8'),_0x5c8e79[_0xb94e('0xbb')]['id'],_0xc554b5);var _0xc903b4=path[_0xb94e('0xd3')](_0xc3f758,_0x115eac);var _0x422182=[];if(_0x5c8e79[_0xb94e('0x40')]['attachments']){_0x422182[_0xb94e('0xb8')]({'model':db[_0xb94e('0xd9')],'as':_0xb94e('0xda'),'raw':!![]});}var _0x37616c=[{'model':db[_0xb94e('0xc3')],'as':_0xb94e('0xdb'),'attributes':['id',_0xb94e('0xc0'),'from','to','cc',_0xb94e('0xdc'),'subject','createdAt'],'where':{'secret':![]},'order':qs[_0xb94e('0x49')]('id'),'include':_0x422182}];return db[_0xb94e('0x33')][_0xb94e('0x6f')]({'where':{'id':_0x5c8e79[_0xb94e('0xbb')]['id']},'include':_0x37616c})['then'](handleEntityNotFound(_0x5c9a27,null))['then'](function(_0x2177ff){if(_0x2177ff&&_0x2177ff[_0xb94e('0xdb')]){var _0x406a46=_0x2177ff['get']({'plain':!![]});fs['mkdirSync'](_0x5be5df);return BPromise[_0xb94e('0xdd')](_0x406a46[_0xb94e('0xdb')],function(_0x3d1590,_0x223d28){var _0x535cb5={'from':_0x3d1590['from'],'to':_0x3d1590['to'],'subject':_0x3d1590[_0xb94e('0xde')],'html':_0x3d1590[_0xb94e('0xc0')],'headers':{'Date':moment(_0x3d1590[_0xb94e('0x76')])[_0xb94e('0xc6')](_0xb94e('0xdf'))},'attachments':[]};if(_0x3d1590['cc']){_0x535cb5['headers']['Cc']=_0x3d1590['cc'];}if(_0x3d1590[_0xb94e('0xdc')]){_0x535cb5[_0xb94e('0xe0')][_0xb94e('0xe1')]=_0x3d1590[_0xb94e('0xdc')];}return new BPromise(function(_0x214a6a,_0x46c7ba){if(_0x3d1590['Attachments']){for(var _0x306eb4=0x0;_0x306eb4<_0x3d1590[_0xb94e('0xda')][_0xb94e('0x63')];_0x306eb4++){var _0x51d229=_0x3d1590['Attachments'][_0x306eb4];var _0x2a2319=path[_0xb94e('0xd3')](_0x44e8a9,_0x51d229[_0xb94e('0xe2')]);if(fs[_0xb94e('0xe3')](_0x2a2319)){_0x535cb5[_0xb94e('0xe4')][_0xb94e('0xb8')]({'name':_0x51d229[_0xb94e('0x2d')],'contentType':_0x51d229[_0xb94e('0x3d')],'data':fs[_0xb94e('0xe5')](_0x2a2319)});}}}emlformat[_0xb94e('0xe6')](_0x535cb5,function(_0x5a9185,_0x2e5f84){if(_0x5a9185)return _0x46c7ba(_0x5a9185);fs[_0xb94e('0xe7')](path[_0xb94e('0xd3')](_0x5be5df,util['format'](_0xb94e('0xe8'),_0x223d28)),_0x2e5f84);return _0x214a6a(_0x2e5f84);});});})['then'](function(){return new BPromise(function(_0x5ef619,_0x170015){zipdir(_0x5be5df,{'saveTo':_0xc903b4},function(_0x1040ca,_0x49ac46){if(_0x1040ca)return _0x170015(_0x1040ca);return _0x5ef619(_0x49ac46);});})[_0xb94e('0x2a')](function(){return new BPromise(function(_0x157963,_0xe3b21){rimraf(_0x5be5df,function(_0x2587cb){if(_0x2587cb)_0xe3b21(_0x2587cb);return _0x157963();});});})[_0xb94e('0x2a')](function(){return _0x5c9a27[_0xb94e('0xd1')](_0xc903b4,_0x115eac,function(_0x1d49a3){if(_0x1d49a3){console['log'](_0xb94e('0xe9'),_0x1d49a3);}else{fs[_0xb94e('0xea')](_0xc903b4);}});});});}else{return _0x5c9a27['sendStatus'](0xc8);}})[_0xb94e('0x39')](handleError(_0x5c9a27,null));};
\ No newline at end of file
+var _0x236d=['$substring','MATCH\x20(c.firstName,\x20c.lastName,\x20c.phone,\x20c.mobile,\x20c.fax,\x20c.email)\x20AGAINST\x20(?\x20IN\x20BOOLEAN\x20MODE)','find','ContactId','buildExpression','text','start','Tag','CONCAT(\x27,\x27,\x20`TagIds`,\x20\x27,\x27)\x20LIKE\x20?','type','compact','isEmpty','MailAccountId','concat','parse','$gte','$lte','\x20=\x20?','read','`unreadMessages`\x20=\x200','`unreadMessages`\x20>\x200','tag','isArray','filter','replace','isNumeric','c.email\x20LIKE\x20?','MATCH\x20(i.to,\x20i.subject)\x20AGAINST\x20(?\x20IN\x20BOOLEAN\x20MODE)','MATCH\x20(me.plainBody,\x20me.subject)\x20AGAINST\x20(?\x20IN\x20BOOLEAN\x20MODE)','group','Sequelize','SELECT','clone','i.id','order','contactName','role','user','i.MailAccountId\x20IS\x20NULL','i.MailAccountId\x20IN\x20?','agent','sequelize','toString','MailInteraction','SUM(me.read\x20=\x200\x20AND\x20me.direction\x20=\x20\x27in\x27)','a.key','Account.key','a.mandatoryDisposition','Account.mandatoryDisposition','i.createdAt','i.closedAt','i.attach','i.lastMsgAt','i.lastMsgDirection','i.subject','i.secondDisposition','i.thirdDisposition','i.substatus','i.to','i.ContactId','i.MailAccountId','i.UserId','c.firstName','c.lastName','Contact.lastName','c.email','Contact.email','Contact.phone','Contact.mobile','Contact.fax','o.fullname','o.internal','Owner.internal','GROUP_CONCAT(DISTINCT\x20t.id)','groupBy','Setting','rows','show','fields','includeAll','include','merge','create','body','params','describe','addMessage','ids','omit','getMessages','filters','pick','MailInteractionId','options','findAll','inlineCss','true','addTags','setTags','spread','emit','removeTags','download','join','root','server','files','attachments','Attachment','Messages','subject','createdAt','get','mkdirSync','each','decode','headers','bcc','Attachments','basename','readFileSync','build','writeFileSync','format','message%d.eml','unlinkSync','eml-format','rimraf','moment','util','path','lodash','squel','../../components/parsers/qs','../../components/parsers/advancedSearch','../../config/logger','api','html-entities','redis','localhost','./mailInteraction.socket','register','sendStatus','end','status','json','offset','undefined','limit','count','Content-Range','update','then','destroy','name','Users','map','fullname','TagIds','Tags','split','forEach','push','MailMessage','findOne','out','plainBody','-id','lastMsgText','catch','waiting','talking','answered','unmanaged','total','closed','UserId','index','rawAttributes','fieldName','model','query','keys','intersection','attributes','hasOwnProperty','nolimit','sort','where','select','field','color','from','tools_tags','ui.MailInteractionId','user_has_mail_interactions','left_join','mail_interactions','cm_contacts','c.id\x20=\x20i.ContactId\x20AND\x20c.deletedAt\x20IS\x20NULL','users','o.id\x20=\x20i.UserId','me.MailInteractionId\x20=\x20i.id','it.MailInteractionId\x20=\x20i.id','t.id\x20=\x20it.TagId','expr','parseSearch','search','sqlOperator','conditions','length','unreadMessages','value','having','`\x20>\x200','Contact','operator'];(function(_0x4dbfce,_0xaf8cdf){var _0x1f3e53=function(_0x589c63){while(--_0x589c63){_0x4dbfce['push'](_0x4dbfce['shift']());}};_0x1f3e53(++_0xaf8cdf);}(_0x236d,0x7e));var _0xd236=function(_0x321bb2,_0x202794){_0x321bb2=_0x321bb2-0x0;var _0x9c12ed=_0x236d[_0x321bb2];return _0x9c12ed;};'use strict';var emlformat=require(_0xd236('0x0'));var rimraf=require(_0xd236('0x1'));var zipdir=require('zip-dir');var moment=require(_0xd236('0x2'));var BPromise=require('bluebird');var util=require(_0xd236('0x3'));var path=require(_0xd236('0x4'));var fs=require('fs');var _=require(_0xd236('0x5'));var squel=require(_0xd236('0x6'));var juice=require('juice');var Redis=require('ioredis');var qs=require(_0xd236('0x7'));var as=require(_0xd236('0x8'));var logger=require(_0xd236('0x9'))(_0xd236('0xa'));var config=require('../../config/environment');var db=require('../../mysqldb')['db'];var htmlEntities=require(_0xd236('0xb'));config[_0xd236('0xc')]=_['defaults'](config[_0xd236('0xc')],{'host':_0xd236('0xd'),'port':0x18eb});var socket=require('socket.io-emitter')(new Redis(config[_0xd236('0xc')]));require(_0xd236('0xe'))[_0xd236('0xf')](socket);function respondWithStatusCode(_0x594013,_0x470524){_0x470524=_0x470524||0xcc;return function(_0x2e4986){if(_0x2e4986){return _0x594013[_0xd236('0x10')](_0x470524);}return _0x594013['status'](_0x470524)[_0xd236('0x11')]();};}function respondWithResult(_0x2fe18d,_0x3d1076){_0x3d1076=_0x3d1076||0xc8;return function(_0x160cb1){if(_0x160cb1){return _0x2fe18d[_0xd236('0x12')](_0x3d1076)[_0xd236('0x13')](_0x160cb1);}};}function respondWithFilteredResult(_0x206b35,_0x974c47){return function(_0x22435c){if(_0x22435c){var _0x3d7465=typeof _0x974c47[_0xd236('0x14')]===_0xd236('0x15')&&typeof _0x974c47[_0xd236('0x16')]===_0xd236('0x15');var _0xd851b5=_0x22435c[_0xd236('0x17')];var _0x2a076d=_0x3d7465?0x0:_0x974c47[_0xd236('0x14')];var _0x24ce6e=_0x3d7465?_0x22435c[_0xd236('0x17')]:_0x974c47['offset']+_0x974c47['limit'];var _0x216a25;if(_0x24ce6e>=_0xd851b5){_0x24ce6e=_0xd851b5;_0x216a25=0xc8;}else{_0x216a25=0xce;}_0x206b35[_0xd236('0x12')](_0x216a25);return _0x206b35['set'](_0xd236('0x18'),_0x2a076d+'-'+_0x24ce6e+'/'+_0xd851b5)[_0xd236('0x13')](_0x22435c);}return null;};}function saveUpdates(_0x132752){return function(_0x595fd4){if(_0x595fd4){return _0x595fd4[_0xd236('0x19')](_0x132752)[_0xd236('0x1a')](function(_0x31f0bb){return _0x31f0bb;});}return null;};}function removeEntity(_0x551b53){return function(_0x25220d){if(_0x25220d){return _0x25220d[_0xd236('0x1b')]()[_0xd236('0x1a')](function(){_0x551b53[_0xd236('0x12')](0xcc)[_0xd236('0x11')]();});}};}function handleEntityNotFound(_0x58cc3f){return function(_0x2a1255){if(!_0x2a1255){_0x58cc3f[_0xd236('0x10')](0x194);}return _0x2a1255;};}function handleError(_0x1e4ddb,_0x3d1e4e){_0x3d1e4e=_0x3d1e4e||0x1f4;return function(_0xf28313){logger['error'](_0xf28313['stack']);if(_0xf28313[_0xd236('0x1c')]){delete _0xf28313['name'];}_0x1e4ddb[_0xd236('0x12')](_0x3d1e4e)['send'](_0xf28313);};}function getInteractionUsers(_0x2be060,_0x2174f5){return new BPromise(function(_0x234930,_0x49d822){try{if(_0x2174f5[_0x2be060['id']]){_0x2be060[_0xd236('0x1d')]=_[_0xd236('0x1e')](_0x2174f5[_0x2be060['id']],function(_0x6d3372){return{'id':_0x6d3372['id'],'fullname':_0x6d3372[_0xd236('0x1f')]};});}}catch(_0x3a30d8){_0x49d822(_0x3a30d8);}_0x234930(_0x2be060);});}function getInteractionTags(_0x17f927,_0x41cf34){return new BPromise(function(_0x21eeab,_0x2cbb03){try{if(_0x17f927[_0xd236('0x20')]){_0x17f927[_0xd236('0x21')]=[];_0x17f927[_0xd236('0x20')][_0xd236('0x22')](',')[_0xd236('0x23')](function(_0x3108f4){_0x17f927[_0xd236('0x21')][_0xd236('0x24')](_0x41cf34[_0x3108f4]);});}delete _0x17f927[_0xd236('0x20')];}catch(_0x463fc8){_0x2cbb03(_0x463fc8);}_0x21eeab(_0x17f927);});}function getLastMessageText(_0x98d8b0){return new BPromise(function(_0x119de7,_0x37b099){return db[_0xd236('0x25')][_0xd236('0x26')]({'where':{'$and':[{'MailInteractionId':_0x98d8b0['id']},{'$or':[{'direction':'in'},{'$and':[{'direction':_0xd236('0x27')},{'secret':![]},{'UserId':{'$ne':null}}]}]}]},'attributes':[_0xd236('0x28')],'order':_0xd236('0x29'),'raw':!![]})[_0xd236('0x1a')](function(_0x3d5f6d){if(_0x3d5f6d&&_0x3d5f6d['plainBody']){_0x98d8b0[_0xd236('0x2a')]=_['trimStart'](_0x3d5f6d[_0xd236('0x28')]);}_0x119de7(_0x98d8b0);})[_0xd236('0x2b')](function(_0x73a2fb){_0x37b099(_0x73a2fb);});});}function updateMailInteraction(_0x58cfb7,_0x1c1692,_0x37b5f7,_0x3bba5d){return new BPromise(function(_0x33400d,_0x2b8e83){return getInteractionUsers(_0x58cfb7,_0x37b5f7)[_0xd236('0x1a')](function(_0x42361d){return getInteractionTags(_0x42361d,_0x1c1692);})['then'](function(_0x2fa782){return getStateInteraction(_0x2fa782);})['then'](function(_0x284748){if(_0x3bba5d){_0x33400d(getLastMessageText(_0x284748));}else{_0x33400d(_0x284748);}})['catch'](function(_0x1fd01b){_0x2b8e83(_0x1fd01b);});});}function getStateInteraction(_0xb75faa){return new BPromise(function(_0x366128){_0xb75faa[_0xd236('0x2c')]=0x0;_0xb75faa[_0xd236('0x2d')]=0x0;_0xb75faa[_0xd236('0x2e')]=0x0;_0xb75faa[_0xd236('0x2f')]=0x0;_0xb75faa[_0xd236('0x30')]=0x0;if(!_0xb75faa[_0xd236('0x31')]&&!_0xb75faa[_0xd236('0x32')]){_0xb75faa[_0xd236('0x2c')]+=0x1;}if(!_0xb75faa[_0xd236('0x31')]&&_0xb75faa[_0xd236('0x32')]){_0xb75faa['talking']+=0x1;if(_0xb75faa[_0xd236('0x2c')]){_0xb75faa[_0xd236('0x2c')]-=0x1;}}if(_0xb75faa[_0xd236('0x31')]&&_0xb75faa['UserId']){_0xb75faa[_0xd236('0x2e')]+=0x1;if(_0xb75faa[_0xd236('0x2d')]){_0xb75faa[_0xd236('0x2d')]-=0x1;}}if(_0xb75faa[_0xd236('0x31')]&&!_0xb75faa[_0xd236('0x32')]){_0xb75faa[_0xd236('0x2f')]+=0x1;if(_0xb75faa['waiting']){_0xb75faa[_0xd236('0x2c')]-=0x1;}}_0xb75faa[_0xd236('0x30')]+=0x1;_0x366128(_0xb75faa);});}exports[_0xd236('0x33')]=function(_0x3c798f,_0x3c74f1){var _0x222495={},_0x4a9d27={},_0x35b950={'count':0x0,'rows':[]};var _0x2cd22e=_[_0xd236('0x1e')](db['MailInteraction'][_0xd236('0x34')],function(_0x5a8b18){return{'name':_0x5a8b18[_0xd236('0x35')],'type':_0x5a8b18['type']['key']};});_0x4a9d27[_0xd236('0x36')]=_[_0xd236('0x1e')](_0x2cd22e,_0xd236('0x1c'));_0x4a9d27[_0xd236('0x37')]=_[_0xd236('0x38')](_0x3c798f['query']);_0x4a9d27['filters']=_[_0xd236('0x39')](_0x4a9d27[_0xd236('0x36')],_0x4a9d27['query']);_0x222495[_0xd236('0x3a')]=_[_0xd236('0x39')](_0x4a9d27[_0xd236('0x36')],qs['fields'](_0x3c798f['query']['fields']));_0x222495[_0xd236('0x3a')]=_0x222495['attributes']['length']?_0x222495[_0xd236('0x3a')]:_0x4a9d27[_0xd236('0x36')];if(!_0x3c798f[_0xd236('0x37')][_0xd236('0x3b')](_0xd236('0x3c'))){_0x222495['limit']=qs['limit'](_0x3c798f[_0xd236('0x37')][_0xd236('0x16')]);_0x222495[_0xd236('0x14')]=qs[_0xd236('0x14')](_0x3c798f[_0xd236('0x37')][_0xd236('0x14')]);}_0x222495['order']=qs[_0xd236('0x3d')](_0x3c798f['query'][_0xd236('0x3d')]);_0x222495[_0xd236('0x3e')]=qs['filters'](_['pick'](_0x3c798f['query'],_0x4a9d27['filters']),_0x2cd22e);var _0x43ba74=[];var _0x11afc6=squel[_0xd236('0x3f')]()[_0xd236('0x40')]('id')[_0xd236('0x40')]('name')['field'](_0xd236('0x41'))[_0xd236('0x42')](_0xd236('0x43'));var _0x208548=squel[_0xd236('0x3f')]()[_0xd236('0x40')]('u.id')[_0xd236('0x40')]('u.fullname')[_0xd236('0x40')](_0xd236('0x44'))['from'](_0xd236('0x45'),'ui')[_0xd236('0x46')]('users','u','u.id\x20=\x20ui.UserId');var _0x135cfc=squel[_0xd236('0x3f')]()[_0xd236('0x42')](_0xd236('0x47'),'i')['left_join'](_0xd236('0x48'),'c',_0xd236('0x49'))[_0xd236('0x46')](_0xd236('0x4a'),'o',_0xd236('0x4b'))[_0xd236('0x46')]('mail_accounts','a','a.id\x20=\x20i.MailAccountId')[_0xd236('0x46')]('mail_messages','me',_0xd236('0x4c'))[_0xd236('0x46')]('mail_interaction_has_tags','it',_0xd236('0x4d'))[_0xd236('0x46')]('tools_tags','t',_0xd236('0x4e'));var _0x2d6549=squel[_0xd236('0x4f')]();var _0x3246b9=[];var _0x5b9337=squel['expr']();var _0x20b51b;if(_0x3c798f[_0xd236('0x37')]['search']){_0x20b51b=as[_0xd236('0x50')](_0x3c798f[_0xd236('0x37')][_0xd236('0x51')]);var _0x26b0c9=_0x20b51b[_0xd236('0x52')];for(var _0x54f23f=0x0;_0x54f23f<_0x20b51b[_0xd236('0x53')][_0xd236('0x54')];_0x54f23f++){var _0x2eefac=_0x20b51b['conditions'][_0x54f23f];var _0x284e3f='i';var _0x524d53=_['find'](_0x2cd22e,[_0xd236('0x1c'),_0x2eefac[_0xd236('0x40')]]);if(!_0x524d53){switch(_0x2eefac[_0xd236('0x40')]){case _0xd236('0x55'):if(_0x2eefac[_0xd236('0x56')]==0x1){_0x135cfc[_0xd236('0x57')]('`'+_0x2eefac[_0xd236('0x40')]+'`\x20=\x200');}else{_0x135cfc[_0xd236('0x57')]('`'+_0x2eefac[_0xd236('0x40')]+_0xd236('0x58'));}break;case _0xd236('0x59'):if(_0x2eefac[_0xd236('0x5a')]===_0xd236('0x5b')){if(_0x2eefac['value'][_0xd236('0x22')]('\x20')[_0xd236('0x54')]>0x1){_0x2d6549[_0x26b0c9](_0xd236('0x5c'),qs['getFullTextValue'](_0x2eefac[_0xd236('0x56')]),null);}else{var _0x6f83a2='%'+_0x2eefac[_0xd236('0x56')]+'%';_0x2d6549[_0x26b0c9]('c.firstName\x20LIKE\x20?\x20OR\x20c.lastName\x20LIKE\x20?\x20OR\x20c.email\x20LIKE\x20?',_0x6f83a2,_0x6f83a2,_0x6f83a2);}}else{_0x524d53=_[_0xd236('0x5d')](_0x2cd22e,[_0xd236('0x1c'),_0xd236('0x5e')]);_0x2eefac[_0xd236('0x40')]='ContactId';_0x13e6cd=as[_0xd236('0x5f')](_0x284e3f,_0x524d53['type'],_0x2eefac);_0x2d6549[_0x26b0c9](_0x13e6cd[_0xd236('0x60')],_0x13e6cd['value'][_0xd236('0x61')],_0x13e6cd['value'][_0xd236('0x11')]);}break;case _0xd236('0x62'):var _0x5a1653=_0x2eefac[_0xd236('0x56')]['split'](',')[_0xd236('0x1e')](function(_0xe32357){return Number(_0xe32357);});_0x5a1653['forEach'](function(_0xc0c0f0){_0x5b9337['or'](_0xd236('0x63'),'%,'+_0xc0c0f0+',%');});_0x3246b9=_['union'](_0x3246b9,_0x5a1653);break;case'User':if(_0x2eefac[_0xd236('0x5a')]===_0xd236('0x5b')){_0x2d6549[_0x26b0c9]('CONCAT_WS(\x27\x20\x27,\x20o.name,\x20o.fullname)\x20LIKE\x20?','%'+_0x2eefac[_0xd236('0x56')]+'%',null);}else{_0x524d53=_['find'](_0x2cd22e,[_0xd236('0x1c'),_0xd236('0x32')]);_0x2eefac['field']=_0xd236('0x32');_0x13e6cd=as[_0xd236('0x5f')](_0x284e3f,_0x524d53[_0xd236('0x64')],_0x2eefac);_0x2d6549[_0x26b0c9](_0x13e6cd[_0xd236('0x60')],_0x13e6cd['value'][_0xd236('0x61')],_0x13e6cd[_0xd236('0x56')][_0xd236('0x11')]);}break;case'plainBody':_0x13e6cd=as[_0xd236('0x5f')]('me',null,_0x2eefac);_0x2d6549[_0x26b0c9](_0x13e6cd['text'],_0x13e6cd[_0xd236('0x56')][_0xd236('0x61')],_0x13e6cd[_0xd236('0x56')]['end']);break;}}else{var _0x13e6cd=as[_0xd236('0x5f')](_0x284e3f,_0x524d53[_0xd236('0x64')],_0x2eefac);_0x2d6549[_0x26b0c9](_0x13e6cd[_0xd236('0x60')],_0x13e6cd['value'][_0xd236('0x61')],_0x13e6cd[_0xd236('0x56')][_0xd236('0x11')]);}}}else{var _0x350711=_(_0x3c798f['query'])[_0xd236('0x38')]()[_0xd236('0x1e')](function(_0x5ec566){return _['some'](_0x2cd22e,[_0xd236('0x1c'),_0x5ec566])?_0x5ec566:undefined;})[_0xd236('0x65')]()[_0xd236('0x56')]();if(!_[_0xd236('0x66')](_0x350711)){_0x350711[_0xd236('0x23')](function(_0x372d9a){if(_0x372d9a===_0xd236('0x67')){_0x135cfc[_0xd236('0x3e')]('i.MailAccountId\x20IN\x20?',[][_0xd236('0x68')](_0x3c798f[_0xd236('0x37')][_0x372d9a]));}else if(_0x372d9a==='createdAt'){var _0x11712e=JSON[_0xd236('0x69')](_0x3c798f['query'][_0x372d9a])[_0xd236('0x6a')];var _0x1cdc97=JSON['parse'](_0x3c798f[_0xd236('0x37')][_0x372d9a])[_0xd236('0x6b')];_0x135cfc[_0xd236('0x3e')]('i.createdAt\x20BETWEEN\x20?\x20AND\x20?',_0x11712e,_0x1cdc97);}else{if(_0x3c798f['query'][_0x372d9a]==='null'){_0x135cfc[_0xd236('0x3e')]('i.'+_0x372d9a+'\x20IS\x20NULL');}else{_0x135cfc['where']('i.'+_0x372d9a+_0xd236('0x6c'),_0x3c798f[_0xd236('0x37')][_0x372d9a]);}}});}if(_0x3c798f[_0xd236('0x37')][_0xd236('0x6d')]){if(_0x3c798f['query'][_0xd236('0x6d')]==0x1){_0x135cfc[_0xd236('0x57')](_0xd236('0x6e'));}else{_0x135cfc['having'](_0xd236('0x6f'));}}if(_0x3c798f[_0xd236('0x37')][_0xd236('0x70')]){_0x3246b9=_[_0xd236('0x71')](_0x3c798f[_0xd236('0x37')]['tag'])?_0x3c798f['query'][_0xd236('0x70')]:new Array(_0x3c798f['query'][_0xd236('0x70')]);_0x3246b9[_0xd236('0x23')](function(_0x114afa){_0x5b9337['or']('CONCAT(\x27,\x27,\x20`TagIds`,\x20\x27,\x27)\x20LIKE\x20?','%,'+_0x114afa+',%');});}if(_0x3c798f[_0xd236('0x37')][_0xd236('0x72')]){var _0x516bb1=_0x3c798f[_0xd236('0x37')][_0xd236('0x72')]['replace']('\x5c','\x5c\x5c')[_0xd236('0x73')](/'/g,'\x27\x27');if(qs[_0xd236('0x74')](_0x516bb1)){_0x2d6549['or']('i.id\x20LIKE\x20?',_0x516bb1+'%');}else if(qs['isEmail'](_0x516bb1)){_0x2d6549['or'](_0xd236('0x75'),_0x516bb1+'%');}else{_0x2d6549['or'](_0xd236('0x76'),qs['getFullTextValue'](_0x516bb1))['or'](_0xd236('0x77'),qs['getFullTextValue'](_0x516bb1));}}}_0x135cfc[_0xd236('0x3e')](_0x2d6549);_0x135cfc[_0xd236('0x78')]('i.id');var _0x26f817={'type':db[_0xd236('0x79')]['QueryTypes'][_0xd236('0x7a')],'raw':!![]};var _0x5864d9=_0x135cfc[_0xd236('0x7b')]();_0x5864d9[_0xd236('0x40')](_0xd236('0x7c'));_0x5864d9[_0xd236('0x40')]('SUM(me.read\x20=\x200\x20AND\x20me.direction\x20=\x20\x27in\x27)','unreadMessages');if(_0x222495[_0xd236('0x7d')]){_0x222495['order'][_0xd236('0x23')](function(_0x1677b1){var _0x58d0a0=_0x1677b1[0x0]===_0xd236('0x7e')?_0x1677b1[0x0]:'i.'+_0x1677b1[0x0];_0x135cfc[_0xd236('0x7d')](_0x58d0a0,_0x1677b1[0x1]==='DESC'?![]:!![]);});}if(!_[_0xd236('0x66')](_0x3246b9)){_0x135cfc[_0xd236('0x57')](_0x5b9337);_0x5864d9[_0xd236('0x3e')]('t.id\x20IN\x20?',_0x3246b9);}BPromise['resolve']()[_0xd236('0x1a')](function(){if(!_0x20b51b){if(_0x3c798f[_0xd236('0x37')][_0xd236('0x67')])return;_0x5864d9[_0xd236('0x3e')]('i.MailAccountId\x20IS\x20NOT\x20NULL');_0x135cfc[_0xd236('0x3e')]('i.MailAccountId\x20IS\x20NOT\x20NULL');return;}if(_0x3c798f['user'][_0xd236('0x7f')]!=='agent')return;return _0x3c798f[_0xd236('0x80')]['getMailAccounts']({'attributes':['id'],'raw':!![]})[_0xd236('0x1a')](function(_0x7f9b05){if(_[_0xd236('0x66')](_0x7f9b05)){_0x5864d9[_0xd236('0x3e')](_0xd236('0x81'));_0x135cfc['where'](_0xd236('0x81'));}else{_0x5864d9[_0xd236('0x3e')](_0xd236('0x82'),_[_0xd236('0x1e')](_0x7f9b05,'id'));_0x135cfc['where'](_0xd236('0x82'),_[_0xd236('0x1e')](_0x7f9b05,'id'));}});})[_0xd236('0x1a')](function(){if(_0x3c798f[_0xd236('0x80')][_0xd236('0x7f')]===_0xd236('0x83')&&!_0x20b51b&&!_0x3c798f[_0xd236('0x37')][_0xd236('0x67')])return[];return db[_0xd236('0x84')][_0xd236('0x37')](_0x5864d9[_0xd236('0x85')](),_0x26f817);})[_0xd236('0x1a')](function(_0x487546){_0x35b950[_0xd236('0x17')]=_0x487546[_0xd236('0x54')];if(_0x35b950[_0xd236('0x17')]===0x0)return[];return db[_0xd236('0x84')][_0xd236('0x37')](_0x11afc6[_0xd236('0x85')](),_0x26f817)[_0xd236('0x1a')](function(_0x4a4339){_0x43ba74=_['keyBy'](_0x4a4339,'id');_0x26f817=_['merge'](_0x26f817,{'model':db[_0xd236('0x86')],'mapToModel':!![],'raw':!![],'nest':!![]});if(_0x3c798f[_0xd236('0x37')]['fields']){_0x222495[_0xd236('0x3a')][_0xd236('0x23')](function(_0x6f16c6){_0x135cfc[_0xd236('0x40')]('i.'+_0x6f16c6);});}else{_0x135cfc['field'](_0xd236('0x87'),_0xd236('0x55'));_0x135cfc[_0xd236('0x40')](_0xd236('0x88'),_0xd236('0x89'));_0x135cfc[_0xd236('0x40')](_0xd236('0x8a'),_0xd236('0x8b'));_0x135cfc[_0xd236('0x40')]('CASE\x20WHEN\x20i.to\x20IS\x20NOT\x20NULL\x20AND\x20i.to\x20<>\x20\x27\x27\x20AND\x20i.to\x20NOT\x20LIKE\x20(\x27%\x27\x20+\x20a.email\x20+\x20\x27%\x27)\x20THEN\x20SUBSTRING_INDEX(i.to,\x20\x27<\x27,\x201)\x20WHEN\x20(c.firstName\x20IS\x20NOT\x20NULL\x20AND\x20c.firstName\x20<>\x20\x27\x27)\x20OR\x20(c.lastName\x20IS\x20NOT\x20NULL\x20AND\x20c.lastName\x20<>\x20\x27\x27)\x20THEN\x20CONCAT(IFNULL(c.firstName,\x20\x27\x27),\x20\x27\x20\x27,\x20IFNULL(c.lastName,\x20\x27\x27))\x20ELSE\x20\x27Unknown\x27\x20END','contactName');_0x135cfc[_0xd236('0x40')](_0xd236('0x7c'));_0x135cfc['field'](_0xd236('0x8c'));_0x135cfc[_0xd236('0x40')]('i.updatedAt');_0x135cfc[_0xd236('0x40')]('i.closed');_0x135cfc['field'](_0xd236('0x8d'));_0x135cfc[_0xd236('0x40')](_0xd236('0x8e'));_0x135cfc['field'](_0xd236('0x8f'));_0x135cfc[_0xd236('0x40')](_0xd236('0x90'));_0x135cfc[_0xd236('0x40')](_0xd236('0x91'));_0x135cfc[_0xd236('0x40')]('i.disposition');_0x135cfc[_0xd236('0x40')](_0xd236('0x92'));_0x135cfc[_0xd236('0x40')](_0xd236('0x93'));_0x135cfc['field'](_0xd236('0x94'));_0x135cfc[_0xd236('0x40')](_0xd236('0x95'));_0x135cfc[_0xd236('0x40')](_0xd236('0x96'));_0x135cfc['field'](_0xd236('0x97'));_0x135cfc[_0xd236('0x40')](_0xd236('0x98'));_0x135cfc['field'](_0xd236('0x99'),'Contact.firstName');_0x135cfc['field'](_0xd236('0x9a'),_0xd236('0x9b'));_0x135cfc[_0xd236('0x40')](_0xd236('0x9c'),_0xd236('0x9d'));_0x135cfc[_0xd236('0x40')]('c.phone',_0xd236('0x9e'));_0x135cfc[_0xd236('0x40')]('c.mobile',_0xd236('0x9f'));_0x135cfc[_0xd236('0x40')]('c.fax',_0xd236('0xa0'));_0x135cfc[_0xd236('0x40')](_0xd236('0xa1'),'Owner.fullname');_0x135cfc[_0xd236('0x40')](_0xd236('0xa2'),_0xd236('0xa3'));_0x135cfc[_0xd236('0x40')](_0xd236('0xa4'),_0xd236('0x20'));}if(_0x222495[_0xd236('0x16')])_0x135cfc[_0xd236('0x16')](_0x222495[_0xd236('0x16')]);if(_0x222495['offset'])_0x135cfc[_0xd236('0x14')](_0x222495[_0xd236('0x14')]);return db[_0xd236('0x84')][_0xd236('0x37')](_0x135cfc[_0xd236('0x85')](),_0x26f817);})[_0xd236('0x1a')](function(_0x491807){if(_0x491807[_0xd236('0x54')]>0x0)_0x208548[_0xd236('0x3e')]('ui.MailInteractionId\x20IN\x20?',_['map'](_0x491807,'id'));return db[_0xd236('0x84')]['query'](_0x208548[_0xd236('0x85')](),_0x26f817)['then'](function(_0x45d366){var _0x1d9e32=_[_0xd236('0xa5')](_0x45d366,'MailInteractionId');var _0x5bb55c=[];return db[_0xd236('0xa6')]['findOne']({'attributes':['enableEmailPreview'],'raw':!![]})[_0xd236('0x1a')](function(_0x5680a3){var _0x530560=_0x5680a3['enableEmailPreview'];_0x491807[_0xd236('0x23')](function(_0xa3995f){_0x5bb55c['push'](updateMailInteraction(_0xa3995f,_0x43ba74,_0x1d9e32,_0x530560));});return BPromise['all'](_0x5bb55c);});});});})[_0xd236('0x1a')](function(_0x175b35){_0x35b950[_0xd236('0xa7')]=_0x175b35;return _0x35b950;})[_0xd236('0x1a')](respondWithFilteredResult(_0x3c74f1,_0x222495))[_0xd236('0x2b')](handleError(_0x3c74f1,null));};exports[_0xd236('0xa8')]=function(_0x36697b,_0x4710d8){var _0x399309={'raw':![],'where':{'id':_0x36697b['params']['id']}},_0x3889a3={};_0x3889a3[_0xd236('0x36')]=_[_0xd236('0x38')](db[_0xd236('0x86')][_0xd236('0x34')]);_0x3889a3[_0xd236('0x37')]=_[_0xd236('0x38')](_0x36697b[_0xd236('0x37')]);_0x3889a3['filters']=_[_0xd236('0x39')](_0x3889a3[_0xd236('0x36')],_0x3889a3['query']);_0x399309[_0xd236('0x3a')]=_[_0xd236('0x39')](_0x3889a3[_0xd236('0x36')],qs[_0xd236('0xa9')](_0x36697b[_0xd236('0x37')][_0xd236('0xa9')]));_0x399309[_0xd236('0x3a')]=_0x399309[_0xd236('0x3a')][_0xd236('0x54')]?_0x399309[_0xd236('0x3a')]:_0x3889a3[_0xd236('0x36')];if(_0x36697b[_0xd236('0x37')][_0xd236('0xaa')]){_0x399309[_0xd236('0xab')]=[{'all':!![]}];}_0x399309=_[_0xd236('0xac')]({},_0x399309,_0x36697b['options']);return db[_0xd236('0x86')][_0xd236('0x5d')](_0x399309)[_0xd236('0x1a')](handleEntityNotFound(_0x4710d8,null))[_0xd236('0x1a')](respondWithResult(_0x4710d8,null))[_0xd236('0x2b')](handleError(_0x4710d8,null));};exports[_0xd236('0xad')]=function(_0x2577d0,_0x3e9162){return db[_0xd236('0x86')][_0xd236('0xad')](_0x2577d0['body'],{})['then'](respondWithResult(_0x3e9162,0xc9))[_0xd236('0x2b')](handleError(_0x3e9162,null));};exports[_0xd236('0x19')]=function(_0x3c3e73,_0x3d0378){if(_0x3c3e73[_0xd236('0xae')]['id']){delete _0x3c3e73[_0xd236('0xae')]['id'];}return db[_0xd236('0x86')]['find']({'where':{'id':_0x3c3e73[_0xd236('0xaf')]['id']}})[_0xd236('0x1a')](handleEntityNotFound(_0x3d0378,null))['then'](saveUpdates(_0x3c3e73['body'],null))[_0xd236('0x1a')](respondWithResult(_0x3d0378,null))[_0xd236('0x2b')](handleError(_0x3d0378,null));};exports[_0xd236('0x1b')]=function(_0x592eae,_0x2c4598){return db['MailInteraction'][_0xd236('0x5d')]({'where':{'id':_0x592eae[_0xd236('0xaf')]['id']}})[_0xd236('0x1a')](handleEntityNotFound(_0x2c4598,null))[_0xd236('0x1a')](removeEntity(_0x2c4598,null))[_0xd236('0x2b')](handleError(_0x2c4598,null));};exports['describe']=function(_0x591378,_0x1f1fcb){return db[_0xd236('0x86')][_0xd236('0xb0')]()[_0xd236('0x1a')](respondWithResult(_0x1f1fcb,null))['catch'](handleError(_0x1f1fcb,null));};exports[_0xd236('0xb1')]=function(_0x192a5a,_0x1cb3c8){return db[_0xd236('0x25')][_0xd236('0x5d')]({'where':{'id':_0x192a5a[_0xd236('0xaf')]['id']}})[_0xd236('0x1a')](handleEntityNotFound(_0x1cb3c8,null))[_0xd236('0x1a')](function(_0x2748d9){if(_0x2748d9){return _0x2748d9[_0xd236('0xb1')](_0x192a5a[_0xd236('0xae')][_0xd236('0xb2')],_[_0xd236('0xb3')](_0x192a5a[_0xd236('0xae')],[_0xd236('0xb2'),'id'])||{});}})['then'](respondWithResult(_0x1cb3c8,null))[_0xd236('0x2b')](handleError(_0x1cb3c8,null));};exports[_0xd236('0xb4')]=function(_0x5c2fbd,_0x2d0759){var _0x1d4aac={'raw':![],'where':{}};var _0x35db65={};var _0x5580aa={'count':0x0,'rows':[]};return db[_0xd236('0x86')]['findOne']({'where':{'id':_0x5c2fbd[_0xd236('0xaf')]['id']}})['then'](handleEntityNotFound(_0x2d0759,null))[_0xd236('0x1a')](function(_0x275928){if(_0x275928){_0x35db65[_0xd236('0x36')]=_[_0xd236('0x38')](db[_0xd236('0x25')][_0xd236('0x34')]);_0x35db65[_0xd236('0x37')]=_['keys'](_0x5c2fbd['query']);_0x35db65[_0xd236('0xb5')]=_[_0xd236('0x39')](_0x35db65[_0xd236('0x36')],_0x35db65[_0xd236('0x37')]);_0x1d4aac[_0xd236('0x3a')]=_[_0xd236('0x39')](_0x35db65[_0xd236('0x36')],qs[_0xd236('0xa9')](_0x5c2fbd['query'][_0xd236('0xa9')]));_0x1d4aac[_0xd236('0x3a')]=_0x1d4aac[_0xd236('0x3a')][_0xd236('0x54')]?_0x1d4aac[_0xd236('0x3a')]:_0x35db65[_0xd236('0x36')];if(!_0x5c2fbd[_0xd236('0x37')][_0xd236('0x3b')]('nolimit')){_0x1d4aac['limit']=qs[_0xd236('0x16')](_0x5c2fbd[_0xd236('0x37')]['limit']);_0x1d4aac['offset']=qs['offset'](_0x5c2fbd[_0xd236('0x37')][_0xd236('0x14')]);}_0x1d4aac[_0xd236('0x7d')]=qs['sort'](_0x5c2fbd[_0xd236('0x37')]['sort']);_0x1d4aac[_0xd236('0x3e')]=qs[_0xd236('0xb5')](_[_0xd236('0xb6')](_0x5c2fbd['query'],_0x35db65[_0xd236('0xb5')]));_0x1d4aac['where'][_0xd236('0xb7')]=_0x275928['id'];if(_0x5c2fbd[_0xd236('0x37')][_0xd236('0x72')]){_0x1d4aac[_0xd236('0x3e')]=_[_0xd236('0xac')](_0x1d4aac[_0xd236('0x3e')],{'$or':_[_0xd236('0x1e')](_0x1d4aac['attributes'],function(_0x2ccb10){var _0x25d144={};_0x25d144[_0x2ccb10]={'$like':'%'+_0x5c2fbd[_0xd236('0x37')]['filter']+'%'};return _0x25d144;})});}if(_0x5c2fbd[_0xd236('0x37')]['$gte']){var _0x3ca52a=_0x5c2fbd[_0xd236('0x37')][_0xd236('0x6a')][_0xd236('0x22')](',');var _0x72c65b={};_0x72c65b[_0x3ca52a[0x0]]={'$gte':moment(_0x3ca52a[0x1])['format']('YYYY-MM-DD\x20HH:mm:ss')};_0x1d4aac[_0xd236('0x3e')]=_[_0xd236('0xac')](_0x1d4aac[_0xd236('0x3e')],_0x72c65b);}_0x1d4aac=_[_0xd236('0xac')]({},_0x1d4aac,_0x5c2fbd[_0xd236('0xb8')]);return db['MailMessage'][_0xd236('0x17')]({'where':_0x1d4aac[_0xd236('0x3e')]})['then'](function(_0x4a973e){_0x5580aa[_0xd236('0x17')]=_0x4a973e;if(_0x5c2fbd['query'][_0xd236('0xaa')]){_0x1d4aac[_0xd236('0xab')]=[{'all':!![]}];}return db[_0xd236('0x25')][_0xd236('0xb9')](_0x1d4aac);})[_0xd236('0x1a')](function(_0x517093){if(_0x5c2fbd[_0xd236('0x37')][_0xd236('0xba')]===_0xd236('0xbb')){for(var _0x49db9b=0x0;_0x49db9b<_0x517093[_0xd236('0x54')];_0x49db9b++){_0x517093[_0x49db9b][_0xd236('0xae')]=juice(_0x517093[_0x49db9b][_0xd236('0xae')]);}}_0x5580aa[_0xd236('0xa7')]=_0x517093;return _0x5580aa;});}})[_0xd236('0x1a')](respondWithFilteredResult(_0x2d0759,_0x1d4aac))[_0xd236('0x2b')](handleError(_0x2d0759,null));};exports[_0xd236('0xbc')]=function(_0x3d5640,_0x5675cd){return db[_0xd236('0x86')][_0xd236('0x5d')]({'where':{'id':_0x3d5640[_0xd236('0xaf')]['id']}})[_0xd236('0x1a')](handleEntityNotFound(_0x5675cd,null))[_0xd236('0x1a')](function(_0x417baf){if(_0x417baf){return _0x417baf[_0xd236('0xbd')](_0x3d5640['body']['ids'],_[_0xd236('0xb3')](_0x3d5640[_0xd236('0xae')],[_0xd236('0xb2'),'id'])||{})[_0xd236('0xbe')](function(){return db[_0xd236('0x62')]['findAll']({'attributes':['id',_0xd236('0x1c'),_0xd236('0x41')],'where':{'id':_0x3d5640[_0xd236('0xae')][_0xd236('0xb2')]}});})[_0xd236('0x1a')](function(_0x463d8e){socket[_0xd236('0xbf')]('mailInteractionTags:save',{'id':Number(_0x3d5640[_0xd236('0xaf')]['id']),'tags':_0x463d8e||[]});return{'id':Number(_0x3d5640[_0xd236('0xaf')]['id']),'tags':_0x463d8e||[]};});}})[_0xd236('0x1a')](respondWithResult(_0x5675cd,null))[_0xd236('0x2b')](handleError(_0x5675cd,null));};exports[_0xd236('0xc0')]=function(_0x79f609,_0x20186a){return db['MailInteraction'][_0xd236('0x5d')]({'where':{'id':_0x79f609[_0xd236('0xaf')]['id']}})[_0xd236('0x1a')](handleEntityNotFound(_0x20186a,null))[_0xd236('0x1a')](function(_0x4af2c5){if(_0x4af2c5){return _0x4af2c5['removeTags'](_0x79f609['query'][_0xd236('0xb2')]);}})[_0xd236('0x1a')](respondWithStatusCode(_0x20186a,null))['catch'](handleError(_0x20186a,null));};exports[_0xd236('0xc1')]=function(_0x7b1bf1,_0x3a48ca){var _0x3ff47e=moment()['unix']()['toString']();var _0x5575cd=path[_0xd236('0xc2')](config[_0xd236('0xc3')],_0xd236('0xc4'),_0xd236('0xc5'),'tmp');var _0xd4b52d=path['join'](config['root'],_0xd236('0xc4'),'files',_0xd236('0xc6'));var _0x463764=path['join'](_0x5575cd,_0x3ff47e);var _0x3f72ad=util['format']('transcript-%d-%s.zip',_0x7b1bf1[_0xd236('0xaf')]['id'],_0x3ff47e);var _0x922e0e=path[_0xd236('0xc2')](_0x5575cd,_0x3f72ad);var _0x4f4996=[];if(_0x7b1bf1['query'][_0xd236('0xc6')]){_0x4f4996[_0xd236('0x24')]({'model':db[_0xd236('0xc7')],'as':'Attachments','raw':!![]});}var _0x1a6e2f=[{'model':db[_0xd236('0x25')],'as':_0xd236('0xc8'),'attributes':['id',_0xd236('0xae'),_0xd236('0x42'),'to','cc','bcc',_0xd236('0xc9'),_0xd236('0xca')],'where':{'secret':![]},'order':qs[_0xd236('0x3d')]('id'),'include':_0x4f4996}];return db[_0xd236('0x86')][_0xd236('0x5d')]({'where':{'id':_0x7b1bf1['params']['id']},'include':_0x1a6e2f})[_0xd236('0x1a')](handleEntityNotFound(_0x3a48ca,null))[_0xd236('0x1a')](function(_0x586d6e){if(_0x586d6e&&_0x586d6e[_0xd236('0xc8')]){var _0x5beaee=_0x586d6e[_0xd236('0xcb')]({'plain':!![]});fs[_0xd236('0xcc')](_0x463764);return BPromise[_0xd236('0xcd')](_0x5beaee['Messages'],function(_0x16f7cb,_0x3c1ff1){var _0xa831ea={'from':_0x16f7cb['from'],'to':_0x16f7cb['to'],'subject':_0x16f7cb[_0xd236('0xc9')],'html':htmlEntities[_0xd236('0xce')](_0x16f7cb[_0xd236('0xae')]),'headers':{'Date':moment(_0x16f7cb[_0xd236('0xca')])['format']('ddd,\x20DD\x20MMM\x20YYYY\x20HH:mm:ss\x20ZZ')},'attachments':[]};if(_0x16f7cb['cc']){_0xa831ea[_0xd236('0xcf')]['Cc']=_0x16f7cb['cc'];}if(_0x16f7cb[_0xd236('0xd0')]){_0xa831ea[_0xd236('0xcf')]['Bcc']=_0x16f7cb[_0xd236('0xd0')];}return new BPromise(function(_0x22ace9,_0x2c49f7){if(_0x16f7cb[_0xd236('0xd1')]){for(var _0x51f67e=0x0;_0x51f67e<_0x16f7cb[_0xd236('0xd1')]['length'];_0x51f67e++){var _0x3d7dc0=_0x16f7cb[_0xd236('0xd1')][_0x51f67e];var _0x1bfb28=path[_0xd236('0xc2')](_0xd4b52d,_0x3d7dc0[_0xd236('0xd2')]);if(fs['existsSync'](_0x1bfb28)){_0xa831ea[_0xd236('0xc6')][_0xd236('0x24')]({'name':_0x3d7dc0[_0xd236('0x1c')],'contentType':_0x3d7dc0['type'],'data':fs[_0xd236('0xd3')](_0x1bfb28)});}}}emlformat[_0xd236('0xd4')](_0xa831ea,function(_0x260a1d,_0x14692a){if(_0x260a1d)return _0x2c49f7(_0x260a1d);fs[_0xd236('0xd5')](path[_0xd236('0xc2')](_0x463764,util[_0xd236('0xd6')](_0xd236('0xd7'),_0x3c1ff1)),_0x14692a);return _0x22ace9(_0x14692a);});});})[_0xd236('0x1a')](function(){return new BPromise(function(_0x8caef1,_0x247f4a){zipdir(_0x463764,{'saveTo':_0x922e0e},function(_0x4d3958,_0x11045c){if(_0x4d3958)return _0x247f4a(_0x4d3958);return _0x8caef1(_0x11045c);});})['then'](function(){return new BPromise(function(_0x8e697f,_0x40360f){rimraf(_0x463764,function(_0x464e3b){if(_0x464e3b)_0x40360f(_0x464e3b);return _0x8e697f();});});})[_0xd236('0x1a')](function(){return _0x3a48ca['download'](_0x922e0e,_0x3f72ad,function(_0x5d8108){if(!_0x5d8108)fs[_0xd236('0xd8')](_0x922e0e);});});});}else{return _0x3a48ca[_0xd236('0x10')](0xc8);}})[_0xd236('0x2b')](handleError(_0x3a48ca,null));};
\ No newline at end of file