Built motion from commit 85328c08.|2.5.50
[motion2.git] / server / api / mailInteraction / mailInteraction.controller.js
1 // *************************************************************************
2 // *                                                                       *
3 // * xCALLY Motion -  The Omnichannel Contact Center                       *
4 // * Copyright (c) Xenialab s.r.l. All Rights Reserved                     *
5 // *                                                                       *
6 // *************************************************************************
7 // *                                                                       *
8 // * Email: info@xcally.com                                                *
9 // * Website: https://www.xcally.com                                       *
10 // *                                                                       *
11 // *************************************************************************
12 // *                                                                       *
13 // * The SOFTWARE PRODUCT is protected by copyright laws and international *
14 // * copyright treaties, as well as other intellectual property laws and   *
15 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                         *
16 // *                                                                       *
17 // *************************************************************************
18 var _0x53ec=['u.id\x20=\x20ui.UserId','mail_interactions','cm_contacts','c.id\x20=\x20i.ContactId\x20AND\x20c.deletedAt\x20IS\x20NULL','o.id\x20=\x20i.UserId','a.id\x20=\x20i.MailAccountId','mail_messages','mail_interaction_has_tags','it.MailInteractionId\x20=\x20i.id','t.id\x20=\x20it.TagId','expr','search','parseSearch','sqlOperator','conditions','find','unreadMessages','having','`\x20>\x200','Contact','$substring','value','MATCH\x20(c.firstName,\x20c.lastName,\x20c.phone,\x20c.mobile,\x20c.fax,\x20c.email)\x20AGAINST\x20(?\x20IN\x20BOOLEAN\x20MODE)','ContactId','buildExpression','type','start','Tag','split','CONCAT(\x27,\x27,\x20`TagIds`,\x20\x27,\x27)\x20LIKE\x20?','union','operator','CONCAT_WS(\x27\x20\x27,\x20o.name,\x20o.fullname)\x20LIKE\x20?','text','some','compact','MailAccountId','concat','createdAt','parse','$lte','null','\x20IS\x20NULL','\x20=\x20?','`unreadMessages`\x20=\x200','`unreadMessages`\x20>\x200','tag','filter','replace','isNumeric','i.id\x20LIKE\x20?','c.email\x20LIKE\x20?','getFullTextValue','MATCH\x20(me.plainBody,\x20me.subject)\x20AGAINST\x20(?\x20IN\x20BOOLEAN\x20MODE)','group','i.id','Sequelize','QueryTypes','SELECT','clone','SUM(me.read\x20=\x200\x20AND\x20me.direction\x20=\x20\x27in\x27)','DESC','t.id\x20IN\x20?','i.MailAccountId\x20IS\x20NOT\x20NULL','user','agent','getMailAccounts','isEmpty','i.MailAccountId\x20IS\x20NULL','i.MailAccountId\x20IN\x20?','role','sequelize','toString','keyBy','merge','a.key','Account.key','Account.mandatoryDisposition','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','i.createdAt','i.closed','i.attach','i.lastMsgAt','i.disposition','i.secondDisposition','i.thirdDisposition','i.substatus','i.to','i.MailAccountId','i.UserId','c.firstName','Contact.firstName','c.lastName','Contact.lastName','c.email','Contact.email','c.phone','Contact.phone','c.mobile','Contact.mobile','c.fax','Contact.fax','o.fullname','Owner.fullname','o.internal','GROUP_CONCAT(DISTINCT\x20t.id)','ui.MailInteractionId\x20IN\x20?','groupBy','MailInteractionId','Setting','enableEmailPreview','all','rows','show','params','keys','include','body','describe','addMessage','hasOwnProperty','$gte','format','YYYY-MM-DD\x20HH:mm:ss','options','includeAll','findAll','inlineCss','true','addTags','setTags','ids','omit','spread','emit','mailInteractionTags:save','removeTags','download','unix','join','root','files','attachments','transcript-%d-%s.zip','Attachment','Attachments','Messages','bcc','subject','get','mkdirSync','each','decode','ddd,\x20DD\x20MMM\x20YYYY\x20HH:mm:ss\x20ZZ','headers','Bcc','existsSync','build','writeFileSync','message%d.eml','unlinkSync','eml-format','rimraf','zip-dir','moment','bluebird','util','lodash','juice','ioredis','../../components/parsers/advancedSearch','api','../../config/environment','html-entities','redis','defaults','localhost','socket.io-emitter','./mailInteraction.socket','register','end','offset','undefined','limit','count','status','set','Content-Range','update','then','destroy','sendStatus','error','stack','name','Users','map','fullname','TagIds','forEach','push','MailMessage','findOne','plainBody','-id','trimStart','catch','waiting','talking','unmanaged','closed','UserId','answered','index','MailInteraction','rawAttributes','model','query','intersection','attributes','fields','length','nolimit','order','sort','where','filters','pick','select','field','color','from','tools_tags','u.id','u.fullname','ui.MailInteractionId','user_has_mail_interactions','left_join','users'];(function(_0x4b7bb7,_0x39f014){var _0x19a88e=function(_0x53acc9){while(--_0x53acc9){_0x4b7bb7['push'](_0x4b7bb7['shift']());}};_0x19a88e(++_0x39f014);}(_0x53ec,0x192));var _0xc53e=function(_0x17e75e,_0x24753e){_0x17e75e=_0x17e75e-0x0;var _0x25f451=_0x53ec[_0x17e75e];return _0x25f451;};'use strict';var emlformat=require(_0xc53e('0x0'));var rimraf=require(_0xc53e('0x1'));var zipdir=require(_0xc53e('0x2'));var moment=require(_0xc53e('0x3'));var BPromise=require(_0xc53e('0x4'));var util=require(_0xc53e('0x5'));var path=require('path');var fs=require('fs');var _=require(_0xc53e('0x6'));var squel=require('squel');var juice=require(_0xc53e('0x7'));var Redis=require(_0xc53e('0x8'));var qs=require('../../components/parsers/qs');var as=require(_0xc53e('0x9'));var logger=require('../../config/logger')(_0xc53e('0xa'));var config=require(_0xc53e('0xb'));var db=require('../../mysqldb')['db'];var htmlEntities=require(_0xc53e('0xc'));config[_0xc53e('0xd')]=_[_0xc53e('0xe')](config[_0xc53e('0xd')],{'host':_0xc53e('0xf'),'port':0x18eb});var socket=require(_0xc53e('0x10'))(new Redis(config[_0xc53e('0xd')]));require(_0xc53e('0x11'))[_0xc53e('0x12')](socket);function respondWithStatusCode(_0x4b7cfa,_0x57e818){_0x57e818=_0x57e818||0xcc;return function(_0x35128a){if(_0x35128a){return _0x4b7cfa['sendStatus'](_0x57e818);}return _0x4b7cfa['status'](_0x57e818)[_0xc53e('0x13')]();};}function respondWithResult(_0x9ffbcb,_0x863fa){_0x863fa=_0x863fa||0xc8;return function(_0x4203aa){if(_0x4203aa){return _0x9ffbcb['status'](_0x863fa)['json'](_0x4203aa);}};}function respondWithFilteredResult(_0x1c06cd,_0x19a772){return function(_0x7cd798){if(_0x7cd798){var _0x3d2e17=typeof _0x19a772[_0xc53e('0x14')]===_0xc53e('0x15')&&typeof _0x19a772[_0xc53e('0x16')]===_0xc53e('0x15');var _0x455e4d=_0x7cd798[_0xc53e('0x17')];var _0x5b0a88=_0x3d2e17?0x0:_0x19a772[_0xc53e('0x14')];var _0x191567=_0x3d2e17?_0x7cd798[_0xc53e('0x17')]:_0x19a772[_0xc53e('0x14')]+_0x19a772[_0xc53e('0x16')];var _0x270c78;if(_0x191567>=_0x455e4d){_0x191567=_0x455e4d;_0x270c78=0xc8;}else{_0x270c78=0xce;}_0x1c06cd[_0xc53e('0x18')](_0x270c78);return _0x1c06cd[_0xc53e('0x19')](_0xc53e('0x1a'),_0x5b0a88+'-'+_0x191567+'/'+_0x455e4d)['json'](_0x7cd798);}return null;};}function saveUpdates(_0x546fab){return function(_0x35b7b2){if(_0x35b7b2){return _0x35b7b2[_0xc53e('0x1b')](_0x546fab)[_0xc53e('0x1c')](function(_0x2e85df){return _0x2e85df;});}return null;};}function removeEntity(_0x20066e){return function(_0x2cfe2b){if(_0x2cfe2b){return _0x2cfe2b[_0xc53e('0x1d')]()[_0xc53e('0x1c')](function(){_0x20066e[_0xc53e('0x18')](0xcc)[_0xc53e('0x13')]();});}};}function handleEntityNotFound(_0x17d825){return function(_0x44fd93){if(!_0x44fd93){_0x17d825[_0xc53e('0x1e')](0x194);}return _0x44fd93;};}function handleError(_0x4fb695,_0x47cfdd){_0x47cfdd=_0x47cfdd||0x1f4;return function(_0x531ede){logger[_0xc53e('0x1f')](_0x531ede[_0xc53e('0x20')]);if(_0x531ede[_0xc53e('0x21')]){delete _0x531ede[_0xc53e('0x21')];}_0x4fb695[_0xc53e('0x18')](_0x47cfdd)['send'](_0x531ede);};}function getInteractionUsers(_0x5e5377,_0xe06e42){return new BPromise(function(_0x496167,_0x1ae55e){try{if(_0xe06e42[_0x5e5377['id']]){_0x5e5377[_0xc53e('0x22')]=_[_0xc53e('0x23')](_0xe06e42[_0x5e5377['id']],function(_0x1166e6){return{'id':_0x1166e6['id'],'fullname':_0x1166e6[_0xc53e('0x24')]};});}}catch(_0x4df8cf){_0x1ae55e(_0x4df8cf);}_0x496167(_0x5e5377);});}function getInteractionTags(_0x398e7a,_0x4b9f6a){return new BPromise(function(_0x4d9a68,_0x5c65d3){try{if(_0x398e7a[_0xc53e('0x25')]){_0x398e7a['Tags']=[];_0x398e7a[_0xc53e('0x25')]['split'](',')[_0xc53e('0x26')](function(_0x5112d2){_0x398e7a['Tags'][_0xc53e('0x27')](_0x4b9f6a[_0x5112d2]);});}delete _0x398e7a[_0xc53e('0x25')];}catch(_0x42dec1){_0x5c65d3(_0x42dec1);}_0x4d9a68(_0x398e7a);});}function getLastMessageText(_0x2fa20b){return new BPromise(function(_0x6415f6,_0xf97d78){return db[_0xc53e('0x28')][_0xc53e('0x29')]({'where':{'$and':[{'MailInteractionId':_0x2fa20b['id']},{'$or':[{'direction':'in'},{'$and':[{'direction':'out'},{'secret':![]},{'UserId':{'$ne':null}}]}]}]},'attributes':[_0xc53e('0x2a')],'order':_0xc53e('0x2b'),'raw':!![]})[_0xc53e('0x1c')](function(_0x56206b){if(_0x56206b&&_0x56206b[_0xc53e('0x2a')]){_0x2fa20b['lastMsgText']=_[_0xc53e('0x2c')](_0x56206b[_0xc53e('0x2a')]);}_0x6415f6(_0x2fa20b);})['catch'](function(_0x5a64e2){_0xf97d78(_0x5a64e2);});});}function updateMailInteraction(_0x3cd8a1,_0x42efad,_0x3f4547,_0x30d037){return new BPromise(function(_0x1b95c2,_0x45fedc){return getInteractionUsers(_0x3cd8a1,_0x3f4547)[_0xc53e('0x1c')](function(_0x168d25){return getInteractionTags(_0x168d25,_0x42efad);})['then'](function(_0x24e9e5){return getStateInteraction(_0x24e9e5);})[_0xc53e('0x1c')](function(_0x19020b){if(_0x30d037){_0x1b95c2(getLastMessageText(_0x19020b));}else{_0x1b95c2(_0x19020b);}})[_0xc53e('0x2d')](function(_0x1eca5b){_0x45fedc(_0x1eca5b);});});}function getStateInteraction(_0x12b32c){return new BPromise(function(_0x1920c8){_0x12b32c[_0xc53e('0x2e')]=0x0;_0x12b32c[_0xc53e('0x2f')]=0x0;_0x12b32c['answered']=0x0;_0x12b32c[_0xc53e('0x30')]=0x0;_0x12b32c['total']=0x0;if(!_0x12b32c[_0xc53e('0x31')]&&!_0x12b32c[_0xc53e('0x32')]){_0x12b32c['waiting']+=0x1;}if(!_0x12b32c[_0xc53e('0x31')]&&_0x12b32c[_0xc53e('0x32')]){_0x12b32c[_0xc53e('0x2f')]+=0x1;if(_0x12b32c['waiting']){_0x12b32c[_0xc53e('0x2e')]-=0x1;}}if(_0x12b32c[_0xc53e('0x31')]&&_0x12b32c[_0xc53e('0x32')]){_0x12b32c[_0xc53e('0x33')]+=0x1;if(_0x12b32c[_0xc53e('0x2f')]){_0x12b32c[_0xc53e('0x2f')]-=0x1;}}if(_0x12b32c[_0xc53e('0x31')]&&!_0x12b32c['UserId']){_0x12b32c[_0xc53e('0x30')]+=0x1;if(_0x12b32c[_0xc53e('0x2e')]){_0x12b32c[_0xc53e('0x2e')]-=0x1;}}_0x12b32c['total']+=0x1;_0x1920c8(_0x12b32c);});}exports[_0xc53e('0x34')]=function(_0x5e8ab7,_0xaa00cd){var _0x15052d={},_0x40c4f5={},_0xad1232={'count':0x0,'rows':[]};var _0x3036e7=_['map'](db[_0xc53e('0x35')][_0xc53e('0x36')],function(_0x4a5529){return{'name':_0x4a5529['fieldName'],'type':_0x4a5529['type']['key']};});_0x40c4f5[_0xc53e('0x37')]=_[_0xc53e('0x23')](_0x3036e7,'name');_0x40c4f5[_0xc53e('0x38')]=_['keys'](_0x5e8ab7['query']);_0x40c4f5['filters']=_[_0xc53e('0x39')](_0x40c4f5['model'],_0x40c4f5['query']);_0x15052d[_0xc53e('0x3a')]=_['intersection'](_0x40c4f5[_0xc53e('0x37')],qs[_0xc53e('0x3b')](_0x5e8ab7['query'][_0xc53e('0x3b')]));_0x15052d[_0xc53e('0x3a')]=_0x15052d['attributes'][_0xc53e('0x3c')]?_0x15052d['attributes']:_0x40c4f5['model'];if(!_0x5e8ab7['query']['hasOwnProperty'](_0xc53e('0x3d'))){_0x15052d[_0xc53e('0x16')]=qs[_0xc53e('0x16')](_0x5e8ab7['query'][_0xc53e('0x16')]);_0x15052d[_0xc53e('0x14')]=qs['offset'](_0x5e8ab7['query'][_0xc53e('0x14')]);}_0x15052d[_0xc53e('0x3e')]=qs[_0xc53e('0x3f')](_0x5e8ab7['query'][_0xc53e('0x3f')]);_0x15052d[_0xc53e('0x40')]=qs[_0xc53e('0x41')](_[_0xc53e('0x42')](_0x5e8ab7[_0xc53e('0x38')],_0x40c4f5[_0xc53e('0x41')]),_0x3036e7);var _0x372ce6=[];var _0x49b2e8=squel[_0xc53e('0x43')]()[_0xc53e('0x44')]('id')[_0xc53e('0x44')]('name')[_0xc53e('0x44')](_0xc53e('0x45'))[_0xc53e('0x46')](_0xc53e('0x47'));var _0xa7d256=squel[_0xc53e('0x43')]()['field'](_0xc53e('0x48'))[_0xc53e('0x44')](_0xc53e('0x49'))['field'](_0xc53e('0x4a'))[_0xc53e('0x46')](_0xc53e('0x4b'),'ui')[_0xc53e('0x4c')](_0xc53e('0x4d'),'u',_0xc53e('0x4e'));var _0x1a5a8f=squel[_0xc53e('0x43')]()[_0xc53e('0x46')](_0xc53e('0x4f'),'i')['left_join'](_0xc53e('0x50'),'c',_0xc53e('0x51'))[_0xc53e('0x4c')](_0xc53e('0x4d'),'o',_0xc53e('0x52'))['left_join']('mail_accounts','a',_0xc53e('0x53'))['left_join'](_0xc53e('0x54'),'me','me.MailInteractionId\x20=\x20i.id')[_0xc53e('0x4c')](_0xc53e('0x55'),'it',_0xc53e('0x56'))['left_join'](_0xc53e('0x47'),'t',_0xc53e('0x57'));var _0x395913=squel['expr']();var _0x2f7df2=[];var _0x501f0a=squel[_0xc53e('0x58')]();var _0x3f1ca5;if(_0x5e8ab7['query'][_0xc53e('0x59')]){_0x3f1ca5=as[_0xc53e('0x5a')](_0x5e8ab7['query'][_0xc53e('0x59')]);var _0x36d321=_0x3f1ca5[_0xc53e('0x5b')];for(var _0x1ff92d=0x0;_0x1ff92d<_0x3f1ca5[_0xc53e('0x5c')][_0xc53e('0x3c')];_0x1ff92d++){var _0x27b6d4=_0x3f1ca5[_0xc53e('0x5c')][_0x1ff92d];var _0x8e5630='i';var _0x219ed4=_[_0xc53e('0x5d')](_0x3036e7,['name',_0x27b6d4[_0xc53e('0x44')]]);if(!_0x219ed4){switch(_0x27b6d4['field']){case _0xc53e('0x5e'):if(_0x27b6d4['value']==0x1){_0x1a5a8f[_0xc53e('0x5f')]('`'+_0x27b6d4[_0xc53e('0x44')]+'`\x20=\x200');}else{_0x1a5a8f[_0xc53e('0x5f')]('`'+_0x27b6d4[_0xc53e('0x44')]+_0xc53e('0x60'));}break;case _0xc53e('0x61'):if(_0x27b6d4['operator']===_0xc53e('0x62')){if(_0x27b6d4[_0xc53e('0x63')]['split']('\x20')['length']>0x1){_0x395913[_0x36d321](_0xc53e('0x64'),qs['getFullTextValue'](_0x27b6d4['value']),null);}else{var _0x57c822='%'+_0x27b6d4[_0xc53e('0x63')]+'%';_0x395913[_0x36d321]('c.firstName\x20LIKE\x20?\x20OR\x20c.lastName\x20LIKE\x20?\x20OR\x20c.email\x20LIKE\x20?',_0x57c822,_0x57c822,_0x57c822);}}else{_0x219ed4=_[_0xc53e('0x5d')](_0x3036e7,['name',_0xc53e('0x65')]);_0x27b6d4[_0xc53e('0x44')]=_0xc53e('0x65');_0x40c8ba=as[_0xc53e('0x66')](_0x8e5630,_0x219ed4[_0xc53e('0x67')],_0x27b6d4);_0x395913[_0x36d321](_0x40c8ba['text'],_0x40c8ba['value'][_0xc53e('0x68')],_0x40c8ba[_0xc53e('0x63')][_0xc53e('0x13')]);}break;case _0xc53e('0x69'):var _0x11278d=_0x27b6d4[_0xc53e('0x63')][_0xc53e('0x6a')](',')[_0xc53e('0x23')](function(_0x13bf71){return Number(_0x13bf71);});_0x11278d[_0xc53e('0x26')](function(_0x30333b){_0x501f0a['or'](_0xc53e('0x6b'),'%,'+_0x30333b+',%');});_0x2f7df2=_[_0xc53e('0x6c')](_0x2f7df2,_0x11278d);break;case'User':if(_0x27b6d4[_0xc53e('0x6d')]==='$substring'){_0x395913[_0x36d321](_0xc53e('0x6e'),'%'+_0x27b6d4[_0xc53e('0x63')]+'%',null);}else{_0x219ed4=_[_0xc53e('0x5d')](_0x3036e7,[_0xc53e('0x21'),_0xc53e('0x32')]);_0x27b6d4[_0xc53e('0x44')]=_0xc53e('0x32');_0x40c8ba=as[_0xc53e('0x66')](_0x8e5630,_0x219ed4['type'],_0x27b6d4);_0x395913[_0x36d321](_0x40c8ba['text'],_0x40c8ba['value'][_0xc53e('0x68')],_0x40c8ba[_0xc53e('0x63')][_0xc53e('0x13')]);}break;case _0xc53e('0x2a'):_0x40c8ba=as[_0xc53e('0x66')]('me',null,_0x27b6d4);_0x395913[_0x36d321](_0x40c8ba[_0xc53e('0x6f')],_0x40c8ba[_0xc53e('0x63')]['start'],_0x40c8ba['value']['end']);break;}}else{var _0x40c8ba=as[_0xc53e('0x66')](_0x8e5630,_0x219ed4['type'],_0x27b6d4);_0x395913[_0x36d321](_0x40c8ba[_0xc53e('0x6f')],_0x40c8ba[_0xc53e('0x63')][_0xc53e('0x68')],_0x40c8ba[_0xc53e('0x63')][_0xc53e('0x13')]);}}}else{var _0x20cb31=_(_0x5e8ab7['query'])['keys']()[_0xc53e('0x23')](function(_0xb7391){return _[_0xc53e('0x70')](_0x3036e7,[_0xc53e('0x21'),_0xb7391])?_0xb7391:undefined;})[_0xc53e('0x71')]()[_0xc53e('0x63')]();if(!_['isEmpty'](_0x20cb31)){_0x20cb31[_0xc53e('0x26')](function(_0x15f6cb){if(_0x15f6cb===_0xc53e('0x72')){_0x1a5a8f[_0xc53e('0x40')]('i.MailAccountId\x20IN\x20?',[][_0xc53e('0x73')](_0x5e8ab7[_0xc53e('0x38')][_0x15f6cb]));}else if(_0x15f6cb===_0xc53e('0x74')){var _0x22f311=JSON[_0xc53e('0x75')](_0x5e8ab7[_0xc53e('0x38')][_0x15f6cb])['$gte'];var _0x1020a0=JSON[_0xc53e('0x75')](_0x5e8ab7[_0xc53e('0x38')][_0x15f6cb])[_0xc53e('0x76')];_0x1a5a8f['where']('i.createdAt\x20BETWEEN\x20?\x20AND\x20?',_0x22f311,_0x1020a0);}else{if(_0x5e8ab7[_0xc53e('0x38')][_0x15f6cb]===_0xc53e('0x77')){_0x1a5a8f[_0xc53e('0x40')]('i.'+_0x15f6cb+_0xc53e('0x78'));}else{_0x1a5a8f['where']('i.'+_0x15f6cb+_0xc53e('0x79'),_0x5e8ab7['query'][_0x15f6cb]);}}});}if(_0x5e8ab7[_0xc53e('0x38')]['read']){if(_0x5e8ab7[_0xc53e('0x38')]['read']==0x1){_0x1a5a8f[_0xc53e('0x5f')](_0xc53e('0x7a'));}else{_0x1a5a8f['having'](_0xc53e('0x7b'));}}if(_0x5e8ab7[_0xc53e('0x38')]['tag']){_0x2f7df2=_['isArray'](_0x5e8ab7[_0xc53e('0x38')][_0xc53e('0x7c')])?_0x5e8ab7['query']['tag']:new Array(_0x5e8ab7[_0xc53e('0x38')]['tag']);_0x2f7df2[_0xc53e('0x26')](function(_0x5bfdbb){_0x501f0a['or'](_0xc53e('0x6b'),'%,'+_0x5bfdbb+',%');});}if(_0x5e8ab7[_0xc53e('0x38')][_0xc53e('0x7d')]){var _0x388874=_0x5e8ab7[_0xc53e('0x38')][_0xc53e('0x7d')][_0xc53e('0x7e')]('\x5c','\x5c\x5c')[_0xc53e('0x7e')](/'/g,'\x27\x27');if(qs[_0xc53e('0x7f')](_0x388874)){_0x395913['or'](_0xc53e('0x80'),_0x388874+'%');}else if(qs['isEmail'](_0x388874)){_0x395913['or'](_0xc53e('0x81'),_0x388874+'%');}else{_0x395913['or']('MATCH\x20(i.to,\x20i.subject)\x20AGAINST\x20(?\x20IN\x20BOOLEAN\x20MODE)',qs[_0xc53e('0x82')](_0x388874))['or'](_0xc53e('0x83'),qs[_0xc53e('0x82')](_0x388874));}}}_0x1a5a8f[_0xc53e('0x40')](_0x395913);_0x1a5a8f[_0xc53e('0x84')](_0xc53e('0x85'));var _0x1e3499={'type':db[_0xc53e('0x86')][_0xc53e('0x87')][_0xc53e('0x88')],'raw':!![]};var _0x5deb38=_0x1a5a8f[_0xc53e('0x89')]();_0x5deb38['field'](_0xc53e('0x85'));_0x5deb38[_0xc53e('0x44')](_0xc53e('0x8a'),'unreadMessages');if(_0x15052d[_0xc53e('0x3e')]){_0x15052d[_0xc53e('0x3e')][_0xc53e('0x26')](function(_0xec3738){var _0x3a84a2=_0xec3738[0x0]==='contactName'?_0xec3738[0x0]:'i.'+_0xec3738[0x0];_0x1a5a8f[_0xc53e('0x3e')](_0x3a84a2,_0xec3738[0x1]===_0xc53e('0x8b')?![]:!![]);});}if(!_['isEmpty'](_0x2f7df2)){_0x1a5a8f[_0xc53e('0x5f')](_0x501f0a);_0x5deb38[_0xc53e('0x40')](_0xc53e('0x8c'),_0x2f7df2);}BPromise['resolve']()[_0xc53e('0x1c')](function(){if(!_0x3f1ca5){if(_0x5e8ab7[_0xc53e('0x38')]['MailAccountId'])return;_0x5deb38[_0xc53e('0x40')](_0xc53e('0x8d'));_0x1a5a8f['where']('i.MailAccountId\x20IS\x20NOT\x20NULL');return;}if(_0x5e8ab7[_0xc53e('0x8e')]['role']!==_0xc53e('0x8f'))return;return _0x5e8ab7[_0xc53e('0x8e')][_0xc53e('0x90')]({'attributes':['id'],'raw':!![]})['then'](function(_0xea93fa){if(_[_0xc53e('0x91')](_0xea93fa)){_0x5deb38[_0xc53e('0x40')]('i.MailAccountId\x20IS\x20NULL');_0x1a5a8f[_0xc53e('0x40')](_0xc53e('0x92'));}else{_0x5deb38[_0xc53e('0x40')](_0xc53e('0x93'),_[_0xc53e('0x23')](_0xea93fa,'id'));_0x1a5a8f['where'](_0xc53e('0x93'),_[_0xc53e('0x23')](_0xea93fa,'id'));}});})[_0xc53e('0x1c')](function(){if(_0x5e8ab7[_0xc53e('0x8e')][_0xc53e('0x94')]===_0xc53e('0x8f')&&!_0x3f1ca5&&!_0x5e8ab7[_0xc53e('0x38')][_0xc53e('0x72')])return[];return db[_0xc53e('0x95')]['query'](_0x5deb38[_0xc53e('0x96')](),_0x1e3499);})[_0xc53e('0x1c')](function(_0x1c06bc){_0xad1232[_0xc53e('0x17')]=_0x1c06bc[_0xc53e('0x3c')];if(_0xad1232[_0xc53e('0x17')]===0x0)return[];return db[_0xc53e('0x95')][_0xc53e('0x38')](_0x49b2e8[_0xc53e('0x96')](),_0x1e3499)['then'](function(_0x3a54ef){_0x372ce6=_[_0xc53e('0x97')](_0x3a54ef,'id');_0x1e3499=_[_0xc53e('0x98')](_0x1e3499,{'model':db[_0xc53e('0x35')],'mapToModel':!![],'raw':!![],'nest':!![]});if(_0x5e8ab7['query'][_0xc53e('0x3b')]){_0x15052d[_0xc53e('0x3a')][_0xc53e('0x26')](function(_0x92c9bc){_0x1a5a8f['field']('i.'+_0x92c9bc);});}else{_0x1a5a8f[_0xc53e('0x44')](_0xc53e('0x8a'),_0xc53e('0x5e'));_0x1a5a8f[_0xc53e('0x44')](_0xc53e('0x99'),_0xc53e('0x9a'));_0x1a5a8f[_0xc53e('0x44')]('a.mandatoryDisposition',_0xc53e('0x9b'));_0x1a5a8f['field'](_0xc53e('0x9c'),_0xc53e('0x9d'));_0x1a5a8f[_0xc53e('0x44')]('i.id');_0x1a5a8f[_0xc53e('0x44')](_0xc53e('0x9e'));_0x1a5a8f[_0xc53e('0x44')]('i.updatedAt');_0x1a5a8f[_0xc53e('0x44')](_0xc53e('0x9f'));_0x1a5a8f[_0xc53e('0x44')]('i.closedAt');_0x1a5a8f[_0xc53e('0x44')](_0xc53e('0xa0'));_0x1a5a8f[_0xc53e('0x44')](_0xc53e('0xa1'));_0x1a5a8f[_0xc53e('0x44')]('i.lastMsgDirection');_0x1a5a8f['field']('i.subject');_0x1a5a8f[_0xc53e('0x44')](_0xc53e('0xa2'));_0x1a5a8f[_0xc53e('0x44')](_0xc53e('0xa3'));_0x1a5a8f['field'](_0xc53e('0xa4'));_0x1a5a8f['field'](_0xc53e('0xa5'));_0x1a5a8f[_0xc53e('0x44')](_0xc53e('0xa6'));_0x1a5a8f[_0xc53e('0x44')]('i.ContactId');_0x1a5a8f[_0xc53e('0x44')](_0xc53e('0xa7'));_0x1a5a8f[_0xc53e('0x44')](_0xc53e('0xa8'));_0x1a5a8f[_0xc53e('0x44')](_0xc53e('0xa9'),_0xc53e('0xaa'));_0x1a5a8f[_0xc53e('0x44')](_0xc53e('0xab'),_0xc53e('0xac'));_0x1a5a8f[_0xc53e('0x44')](_0xc53e('0xad'),_0xc53e('0xae'));_0x1a5a8f[_0xc53e('0x44')](_0xc53e('0xaf'),_0xc53e('0xb0'));_0x1a5a8f[_0xc53e('0x44')](_0xc53e('0xb1'),_0xc53e('0xb2'));_0x1a5a8f[_0xc53e('0x44')](_0xc53e('0xb3'),_0xc53e('0xb4'));_0x1a5a8f[_0xc53e('0x44')](_0xc53e('0xb5'),_0xc53e('0xb6'));_0x1a5a8f['field'](_0xc53e('0xb7'),'Owner.internal');_0x1a5a8f[_0xc53e('0x44')](_0xc53e('0xb8'),'TagIds');}if(_0x15052d[_0xc53e('0x16')])_0x1a5a8f[_0xc53e('0x16')](_0x15052d[_0xc53e('0x16')]);if(_0x15052d[_0xc53e('0x14')])_0x1a5a8f[_0xc53e('0x14')](_0x15052d[_0xc53e('0x14')]);return db[_0xc53e('0x95')][_0xc53e('0x38')](_0x1a5a8f[_0xc53e('0x96')](),_0x1e3499);})['then'](function(_0x37c8e6){if(_0x37c8e6['length']>0x0)_0xa7d256[_0xc53e('0x40')](_0xc53e('0xb9'),_[_0xc53e('0x23')](_0x37c8e6,'id'));return db[_0xc53e('0x95')][_0xc53e('0x38')](_0xa7d256[_0xc53e('0x96')](),_0x1e3499)[_0xc53e('0x1c')](function(_0x38dae0){var _0x42a005=_[_0xc53e('0xba')](_0x38dae0,_0xc53e('0xbb'));var _0xa5a39d=[];return db[_0xc53e('0xbc')]['findOne']({'attributes':[_0xc53e('0xbd')],'raw':!![]})['then'](function(_0x2f7842){var _0x251dea=_0x2f7842[_0xc53e('0xbd')];_0x37c8e6[_0xc53e('0x26')](function(_0x5a2a2f){_0xa5a39d['push'](updateMailInteraction(_0x5a2a2f,_0x372ce6,_0x42a005,_0x251dea));});return BPromise[_0xc53e('0xbe')](_0xa5a39d);});});});})[_0xc53e('0x1c')](function(_0x349308){_0xad1232[_0xc53e('0xbf')]=_0x349308;return _0xad1232;})['then'](respondWithFilteredResult(_0xaa00cd,_0x15052d))['catch'](handleError(_0xaa00cd,null));};exports[_0xc53e('0xc0')]=function(_0x162568,_0x5be038){var _0x3628c3={'raw':![],'where':{'id':_0x162568[_0xc53e('0xc1')]['id']}},_0x2faa4e={};_0x2faa4e['model']=_[_0xc53e('0xc2')](db[_0xc53e('0x35')][_0xc53e('0x36')]);_0x2faa4e[_0xc53e('0x38')]=_[_0xc53e('0xc2')](_0x162568['query']);_0x2faa4e[_0xc53e('0x41')]=_[_0xc53e('0x39')](_0x2faa4e[_0xc53e('0x37')],_0x2faa4e[_0xc53e('0x38')]);_0x3628c3[_0xc53e('0x3a')]=_[_0xc53e('0x39')](_0x2faa4e[_0xc53e('0x37')],qs[_0xc53e('0x3b')](_0x162568[_0xc53e('0x38')][_0xc53e('0x3b')]));_0x3628c3[_0xc53e('0x3a')]=_0x3628c3[_0xc53e('0x3a')][_0xc53e('0x3c')]?_0x3628c3['attributes']:_0x2faa4e[_0xc53e('0x37')];if(_0x162568[_0xc53e('0x38')]['includeAll']){_0x3628c3[_0xc53e('0xc3')]=[{'all':!![]}];}_0x3628c3=_['merge']({},_0x3628c3,_0x162568['options']);return db[_0xc53e('0x35')]['find'](_0x3628c3)[_0xc53e('0x1c')](handleEntityNotFound(_0x5be038,null))['then'](respondWithResult(_0x5be038,null))[_0xc53e('0x2d')](handleError(_0x5be038,null));};exports['create']=function(_0x457aac,_0x376d94){return db[_0xc53e('0x35')]['create'](_0x457aac[_0xc53e('0xc4')],{})['then'](respondWithResult(_0x376d94,0xc9))[_0xc53e('0x2d')](handleError(_0x376d94,null));};exports[_0xc53e('0x1b')]=function(_0x1c3cb2,_0x1fd95d){if(_0x1c3cb2[_0xc53e('0xc4')]['id']){delete _0x1c3cb2[_0xc53e('0xc4')]['id'];}return db[_0xc53e('0x35')][_0xc53e('0x5d')]({'where':{'id':_0x1c3cb2[_0xc53e('0xc1')]['id']}})[_0xc53e('0x1c')](handleEntityNotFound(_0x1fd95d,null))['then'](saveUpdates(_0x1c3cb2['body'],null))[_0xc53e('0x1c')](respondWithResult(_0x1fd95d,null))['catch'](handleError(_0x1fd95d,null));};exports[_0xc53e('0x1d')]=function(_0xbc960,_0x14baae){return db[_0xc53e('0x35')][_0xc53e('0x5d')]({'where':{'id':_0xbc960[_0xc53e('0xc1')]['id']}})[_0xc53e('0x1c')](handleEntityNotFound(_0x14baae,null))[_0xc53e('0x1c')](removeEntity(_0x14baae,null))['catch'](handleError(_0x14baae,null));};exports[_0xc53e('0xc5')]=function(_0x4e46bf,_0x34cb12){return db[_0xc53e('0x35')][_0xc53e('0xc5')]()[_0xc53e('0x1c')](respondWithResult(_0x34cb12,null))[_0xc53e('0x2d')](handleError(_0x34cb12,null));};exports[_0xc53e('0xc6')]=function(_0x227e0c,_0x4c0802){return db[_0xc53e('0x28')][_0xc53e('0x5d')]({'where':{'id':_0x227e0c[_0xc53e('0xc1')]['id']}})[_0xc53e('0x1c')](handleEntityNotFound(_0x4c0802,null))[_0xc53e('0x1c')](function(_0x590fb6){if(_0x590fb6){return _0x590fb6[_0xc53e('0xc6')](_0x227e0c[_0xc53e('0xc4')]['ids'],_['omit'](_0x227e0c[_0xc53e('0xc4')],['ids','id'])||{});}})[_0xc53e('0x1c')](respondWithResult(_0x4c0802,null))[_0xc53e('0x2d')](handleError(_0x4c0802,null));};exports['getMessages']=function(_0x4dc196,_0x258eea){var _0x4e23d8={'raw':![],'where':{}};var _0x204208={};var _0x4d43e1={'count':0x0,'rows':[]};return db[_0xc53e('0x35')][_0xc53e('0x29')]({'where':{'id':_0x4dc196[_0xc53e('0xc1')]['id']}})[_0xc53e('0x1c')](handleEntityNotFound(_0x258eea,null))[_0xc53e('0x1c')](function(_0x49bbc9){if(_0x49bbc9){_0x204208[_0xc53e('0x37')]=_['keys'](db['MailMessage'][_0xc53e('0x36')]);_0x204208[_0xc53e('0x38')]=_[_0xc53e('0xc2')](_0x4dc196[_0xc53e('0x38')]);_0x204208[_0xc53e('0x41')]=_[_0xc53e('0x39')](_0x204208[_0xc53e('0x37')],_0x204208[_0xc53e('0x38')]);_0x4e23d8[_0xc53e('0x3a')]=_[_0xc53e('0x39')](_0x204208[_0xc53e('0x37')],qs[_0xc53e('0x3b')](_0x4dc196['query'][_0xc53e('0x3b')]));_0x4e23d8[_0xc53e('0x3a')]=_0x4e23d8[_0xc53e('0x3a')][_0xc53e('0x3c')]?_0x4e23d8[_0xc53e('0x3a')]:_0x204208['model'];if(!_0x4dc196['query'][_0xc53e('0xc7')](_0xc53e('0x3d'))){_0x4e23d8[_0xc53e('0x16')]=qs[_0xc53e('0x16')](_0x4dc196[_0xc53e('0x38')][_0xc53e('0x16')]);_0x4e23d8[_0xc53e('0x14')]=qs[_0xc53e('0x14')](_0x4dc196[_0xc53e('0x38')][_0xc53e('0x14')]);}_0x4e23d8[_0xc53e('0x3e')]=qs[_0xc53e('0x3f')](_0x4dc196[_0xc53e('0x38')]['sort']);_0x4e23d8[_0xc53e('0x40')]=qs[_0xc53e('0x41')](_['pick'](_0x4dc196[_0xc53e('0x38')],_0x204208[_0xc53e('0x41')]));_0x4e23d8[_0xc53e('0x40')]['MailInteractionId']=_0x49bbc9['id'];if(_0x4dc196['query'][_0xc53e('0x7d')]){_0x4e23d8[_0xc53e('0x40')]=_[_0xc53e('0x98')](_0x4e23d8[_0xc53e('0x40')],{'$or':_['map'](_0x4e23d8[_0xc53e('0x3a')],function(_0x8be8f5){var _0xbcbbc5={};_0xbcbbc5[_0x8be8f5]={'$like':'%'+_0x4dc196['query']['filter']+'%'};return _0xbcbbc5;})});}if(_0x4dc196[_0xc53e('0x38')][_0xc53e('0xc8')]){var _0x186a02=_0x4dc196['query'][_0xc53e('0xc8')][_0xc53e('0x6a')](',');var _0x4ae803={};_0x4ae803[_0x186a02[0x0]]={'$gte':moment(_0x186a02[0x1])[_0xc53e('0xc9')](_0xc53e('0xca'))};_0x4e23d8[_0xc53e('0x40')]=_[_0xc53e('0x98')](_0x4e23d8[_0xc53e('0x40')],_0x4ae803);}_0x4e23d8=_['merge']({},_0x4e23d8,_0x4dc196[_0xc53e('0xcb')]);return db[_0xc53e('0x28')][_0xc53e('0x17')]({'where':_0x4e23d8['where']})['then'](function(_0x10f044){_0x4d43e1[_0xc53e('0x17')]=_0x10f044;if(_0x4dc196[_0xc53e('0x38')][_0xc53e('0xcc')]){_0x4e23d8[_0xc53e('0xc3')]=[{'all':!![]}];}return db['MailMessage'][_0xc53e('0xcd')](_0x4e23d8);})['then'](function(_0x22ee61){if(_0x4dc196[_0xc53e('0x38')][_0xc53e('0xce')]===_0xc53e('0xcf')){for(var _0x3b6672=0x0;_0x3b6672<_0x22ee61[_0xc53e('0x3c')];_0x3b6672++){_0x22ee61[_0x3b6672][_0xc53e('0xc4')]=juice(_0x22ee61[_0x3b6672][_0xc53e('0xc4')]);}}_0x4d43e1[_0xc53e('0xbf')]=_0x22ee61;return _0x4d43e1;});}})['then'](respondWithFilteredResult(_0x258eea,_0x4e23d8))[_0xc53e('0x2d')](handleError(_0x258eea,null));};exports[_0xc53e('0xd0')]=function(_0x456563,_0x19957d){return db[_0xc53e('0x35')][_0xc53e('0x5d')]({'where':{'id':_0x456563['params']['id']}})[_0xc53e('0x1c')](handleEntityNotFound(_0x19957d,null))[_0xc53e('0x1c')](function(_0x3db2cd){if(_0x3db2cd){return _0x3db2cd[_0xc53e('0xd1')](_0x456563[_0xc53e('0xc4')][_0xc53e('0xd2')],_[_0xc53e('0xd3')](_0x456563[_0xc53e('0xc4')],['ids','id'])||{})[_0xc53e('0xd4')](function(){return db['Tag'][_0xc53e('0xcd')]({'attributes':['id',_0xc53e('0x21'),_0xc53e('0x45')],'where':{'id':_0x456563[_0xc53e('0xc4')]['ids']}});})[_0xc53e('0x1c')](function(_0x266956){socket[_0xc53e('0xd5')](_0xc53e('0xd6'),{'id':Number(_0x456563[_0xc53e('0xc1')]['id']),'tags':_0x266956||[]});return{'id':Number(_0x456563[_0xc53e('0xc1')]['id']),'tags':_0x266956||[]};});}})[_0xc53e('0x1c')](respondWithResult(_0x19957d,null))[_0xc53e('0x2d')](handleError(_0x19957d,null));};exports[_0xc53e('0xd7')]=function(_0x14e64c,_0x1d6421){return db[_0xc53e('0x35')][_0xc53e('0x5d')]({'where':{'id':_0x14e64c[_0xc53e('0xc1')]['id']}})[_0xc53e('0x1c')](handleEntityNotFound(_0x1d6421,null))[_0xc53e('0x1c')](function(_0x2085b0){if(_0x2085b0){return _0x2085b0[_0xc53e('0xd7')](_0x14e64c['query']['ids']);}})[_0xc53e('0x1c')](respondWithStatusCode(_0x1d6421,null))[_0xc53e('0x2d')](handleError(_0x1d6421,null));};exports[_0xc53e('0xd8')]=function(_0x1d5e24,_0x1ee499){var _0x2767e3=moment()[_0xc53e('0xd9')]()[_0xc53e('0x96')]();var _0x3613d7=path[_0xc53e('0xda')](config[_0xc53e('0xdb')],'server',_0xc53e('0xdc'),'tmp');var _0x41b78c=path[_0xc53e('0xda')](config[_0xc53e('0xdb')],'server',_0xc53e('0xdc'),_0xc53e('0xdd'));var _0xbca6e4=path[_0xc53e('0xda')](_0x3613d7,_0x2767e3);var _0x121214=util[_0xc53e('0xc9')](_0xc53e('0xde'),_0x1d5e24['params']['id'],_0x2767e3);var _0x3a1978=path[_0xc53e('0xda')](_0x3613d7,_0x121214);var _0xaaf0c8=[];if(_0x1d5e24[_0xc53e('0x38')][_0xc53e('0xdd')]){_0xaaf0c8['push']({'model':db[_0xc53e('0xdf')],'as':_0xc53e('0xe0'),'raw':!![]});}var _0x53853a=[{'model':db[_0xc53e('0x28')],'as':_0xc53e('0xe1'),'attributes':['id','body',_0xc53e('0x46'),'to','cc',_0xc53e('0xe2'),_0xc53e('0xe3'),_0xc53e('0x74')],'where':{'secret':![]},'order':qs['sort']('id'),'include':_0xaaf0c8}];return db[_0xc53e('0x35')][_0xc53e('0x5d')]({'where':{'id':_0x1d5e24['params']['id']},'include':_0x53853a})[_0xc53e('0x1c')](handleEntityNotFound(_0x1ee499,null))[_0xc53e('0x1c')](function(_0x503976){if(_0x503976&&_0x503976[_0xc53e('0xe1')]){var _0x41e169=_0x503976[_0xc53e('0xe4')]({'plain':!![]});fs[_0xc53e('0xe5')](_0xbca6e4);return BPromise[_0xc53e('0xe6')](_0x41e169[_0xc53e('0xe1')],function(_0x1535bd,_0xb94a71){var _0xbcbe2e={'from':_0x1535bd['from'],'to':_0x1535bd['to'],'subject':_0x1535bd[_0xc53e('0xe3')],'html':htmlEntities[_0xc53e('0xe7')](_0x1535bd[_0xc53e('0xc4')]),'headers':{'Date':moment(_0x1535bd['createdAt'])[_0xc53e('0xc9')](_0xc53e('0xe8'))},'attachments':[]};if(_0x1535bd['cc']){_0xbcbe2e['headers']['Cc']=_0x1535bd['cc'];}if(_0x1535bd[_0xc53e('0xe2')]){_0xbcbe2e[_0xc53e('0xe9')][_0xc53e('0xea')]=_0x1535bd[_0xc53e('0xe2')];}return new BPromise(function(_0x19c9f0,_0x258b57){if(_0x1535bd['Attachments']){for(var _0x3b7fdc=0x0;_0x3b7fdc<_0x1535bd['Attachments']['length'];_0x3b7fdc++){var _0x109a05=_0x1535bd[_0xc53e('0xe0')][_0x3b7fdc];var _0x5672e2=path[_0xc53e('0xda')](_0x41b78c,_0x109a05['basename']);if(fs[_0xc53e('0xeb')](_0x5672e2)){_0xbcbe2e[_0xc53e('0xdd')]['push']({'name':_0x109a05[_0xc53e('0x21')],'contentType':_0x109a05[_0xc53e('0x67')],'data':fs['readFileSync'](_0x5672e2)});}}}emlformat[_0xc53e('0xec')](_0xbcbe2e,function(_0x3abb4e,_0x94f8d4){if(_0x3abb4e)return _0x258b57(_0x3abb4e);fs[_0xc53e('0xed')](path[_0xc53e('0xda')](_0xbca6e4,util[_0xc53e('0xc9')](_0xc53e('0xee'),_0xb94a71)),_0x94f8d4);return _0x19c9f0(_0x94f8d4);});});})[_0xc53e('0x1c')](function(){return new BPromise(function(_0x5c10ad,_0x5cae03){zipdir(_0xbca6e4,{'saveTo':_0x3a1978},function(_0x5ec237,_0x4a9220){if(_0x5ec237)return _0x5cae03(_0x5ec237);return _0x5c10ad(_0x4a9220);});})[_0xc53e('0x1c')](function(){return new BPromise(function(_0x3f2db3,_0x3580ee){rimraf(_0xbca6e4,function(_0x1f5769){if(_0x1f5769)_0x3580ee(_0x1f5769);return _0x3f2db3();});});})['then'](function(){return _0x1ee499[_0xc53e('0xd8')](_0x3a1978,_0x121214,function(_0x3dd6b0){if(!_0x3dd6b0)fs[_0xc53e('0xef')](_0x3a1978);});});});}else{return _0x1ee499[_0xc53e('0x1e')](0xc8);}})['catch'](handleError(_0x1ee499,null));};