Built motion from commit 87cd5f02.|2.5.48
[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 _0xa899=['tag','isArray','CONCAT(\x27,\x27,\x20`TagIds`,\x20\x27,\x27)\x20LIKE\x20?','filter','replace','isNumeric','i.id\x20LIKE\x20?','isEmail','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)','getFullTextValue','group','i.id','SUM(me.read\x20=\x200\x20AND\x20me.direction\x20=\x20\x27in\x27)','order','DESC','t.id\x20IN\x20?','resolve','i.MailAccountId\x20IS\x20NOT\x20NULL','user','role','agent','getMailAccounts','i.MailAccountId\x20IS\x20NULL','sequelize','toString','count','keyBy','merge','fields','a.key','a.mandatoryDisposition','Account.mandatoryDisposition','i.closed','i.closedAt','i.attach','i.lastMsgDirection','i.subject','i.substatus','i.to','i.ContactId','i.MailAccountId','i.UserId','Contact.firstName','Contact.lastName','c.email','Contact.email','Contact.phone','c.mobile','Contact.mobile','c.fax','Contact.fax','o.fullname','Owner.fullname','o.internal','Owner.internal','GROUP_CONCAT(DISTINCT\x20t.id)','groupBy','MailInteractionId','findOne','enableEmailPreview','show','params','MailInteraction','options','create','body','describe','addMessage','ids','omit','getMessages','hasOwnProperty','sort','pick','format','YYYY-MM-DD\x20HH:mm:ss','MailMessage','findAll','inlineCss','true','rows','addTags','setTags','spread','mailInteractionTags:save','removeTags','download','join','root','files','attachments','Attachment','Attachments','Messages','bcc','createdAt','get','each','subject','decode','ddd,\x20DD\x20MMM\x20YYYY\x20HH:mm:ss\x20ZZ','headers','Bcc','basename','existsSync','readFileSync','build','writeFileSync','message%d.eml','unlinkSync','eml-format','rimraf','zip-dir','bluebird','util','path','lodash','squel','juice','ioredis','../../components/parsers/qs','../../components/parsers/advancedSearch','../../config/logger','api','../../config/environment','../../mysqldb','defaults','redis','socket.io-emitter','./mailInteraction.socket','register','sendStatus','status','undefined','limit','offset','Content-Range','then','destroy','end','error','stack','Users','map','TagIds','Tags','split','push','out','-id','lastMsgText','plainBody','catch','waiting','talking','answered','unmanaged','total','closed','UserId','index','rawAttributes','fieldName','type','query','keys','filters','intersection','model','attributes','length','nolimit','where','select','field','name','color','from','tools_tags','u.id','u.fullname','user_has_mail_interactions','left_join','users','u.id\x20=\x20ui.UserId','mail_interactions','cm_contacts','o.id\x20=\x20i.UserId','mail_accounts','a.id\x20=\x20i.MailAccountId','me.MailInteractionId\x20=\x20i.id','mail_interaction_has_tags','t.id\x20=\x20it.TagId','expr','unreadMessages','having','`\x20=\x200','`\x20>\x200','Contact','operator','$substring','value','MATCH\x20(c.firstName,\x20c.lastName,\x20c.phone,\x20c.mobile,\x20c.fax,\x20c.email)\x20AGAINST\x20(?\x20IN\x20BOOLEAN\x20MODE)','c.firstName\x20LIKE\x20?\x20OR\x20c.lastName\x20LIKE\x20?\x20OR\x20c.email\x20LIKE\x20?','find','ContactId','buildExpression','Tag','union','User','CONCAT_WS(\x27\x20\x27,\x20o.name,\x20o.fullname)\x20LIKE\x20?','text','start','compact','isEmpty','forEach','MailAccountId','i.MailAccountId\x20IN\x20?','concat','parse','$gte','i.createdAt\x20BETWEEN\x20?\x20AND\x20?','null','\x20=\x20?','read','`unreadMessages`\x20=\x200','`unreadMessages`\x20>\x200'];(function(_0x54b0f3,_0x1fe2f7){var _0x5ae957=function(_0x2749eb){while(--_0x2749eb){_0x54b0f3['push'](_0x54b0f3['shift']());}};_0x5ae957(++_0x1fe2f7);}(_0xa899,0x155));var _0x9a89=function(_0x187718,_0x427383){_0x187718=_0x187718-0x0;var _0x29ddf4=_0xa899[_0x187718];return _0x29ddf4;};'use strict';var emlformat=require(_0x9a89('0x0'));var rimraf=require(_0x9a89('0x1'));var zipdir=require(_0x9a89('0x2'));var moment=require('moment');var BPromise=require(_0x9a89('0x3'));var util=require(_0x9a89('0x4'));var path=require(_0x9a89('0x5'));var fs=require('fs');var _=require(_0x9a89('0x6'));var squel=require(_0x9a89('0x7'));var juice=require(_0x9a89('0x8'));var Redis=require(_0x9a89('0x9'));var qs=require(_0x9a89('0xa'));var as=require(_0x9a89('0xb'));var logger=require(_0x9a89('0xc'))(_0x9a89('0xd'));var config=require(_0x9a89('0xe'));var db=require(_0x9a89('0xf'))['db'];var htmlEntities=require('html-entities');config['redis']=_[_0x9a89('0x10')](config[_0x9a89('0x11')],{'host':'localhost','port':0x18eb});var socket=require(_0x9a89('0x12'))(new Redis(config['redis']));require(_0x9a89('0x13'))[_0x9a89('0x14')](socket);function respondWithStatusCode(_0x401680,_0x2e90c2){_0x2e90c2=_0x2e90c2||0xcc;return function(_0x18467c){if(_0x18467c){return _0x401680[_0x9a89('0x15')](_0x2e90c2);}return _0x401680[_0x9a89('0x16')](_0x2e90c2)['end']();};}function respondWithResult(_0x51eb91,_0x4342c8){_0x4342c8=_0x4342c8||0xc8;return function(_0x8b7403){if(_0x8b7403){return _0x51eb91[_0x9a89('0x16')](_0x4342c8)['json'](_0x8b7403);}};}function respondWithFilteredResult(_0x5e4c98,_0x53acb4){return function(_0x1c66a3){if(_0x1c66a3){var _0xf08a5a=typeof _0x53acb4['offset']===_0x9a89('0x17')&&typeof _0x53acb4[_0x9a89('0x18')]===_0x9a89('0x17');var _0x203ee9=_0x1c66a3['count'];var _0x11a933=_0xf08a5a?0x0:_0x53acb4[_0x9a89('0x19')];var _0x5adef3=_0xf08a5a?_0x1c66a3['count']:_0x53acb4[_0x9a89('0x19')]+_0x53acb4['limit'];var _0xba2eaa;if(_0x5adef3>=_0x203ee9){_0x5adef3=_0x203ee9;_0xba2eaa=0xc8;}else{_0xba2eaa=0xce;}_0x5e4c98[_0x9a89('0x16')](_0xba2eaa);return _0x5e4c98['set'](_0x9a89('0x1a'),_0x11a933+'-'+_0x5adef3+'/'+_0x203ee9)['json'](_0x1c66a3);}return null;};}function saveUpdates(_0x2d648f){return function(_0x3d54ed){if(_0x3d54ed){return _0x3d54ed['update'](_0x2d648f)[_0x9a89('0x1b')](function(_0x3759cb){return _0x3759cb;});}return null;};}function removeEntity(_0xf60649){return function(_0x1619e0){if(_0x1619e0){return _0x1619e0[_0x9a89('0x1c')]()[_0x9a89('0x1b')](function(){_0xf60649[_0x9a89('0x16')](0xcc)[_0x9a89('0x1d')]();});}};}function handleEntityNotFound(_0x583227){return function(_0x51618d){if(!_0x51618d){_0x583227[_0x9a89('0x15')](0x194);}return _0x51618d;};}function handleError(_0x330121,_0xea8910){_0xea8910=_0xea8910||0x1f4;return function(_0x2e83aa){logger[_0x9a89('0x1e')](_0x2e83aa[_0x9a89('0x1f')]);if(_0x2e83aa['name']){delete _0x2e83aa['name'];}_0x330121[_0x9a89('0x16')](_0xea8910)['send'](_0x2e83aa);};}function getInteractionUsers(_0x3f5723,_0x2cca01){return new BPromise(function(_0xd8bad3,_0x3b1807){try{if(_0x2cca01[_0x3f5723['id']]){_0x3f5723[_0x9a89('0x20')]=_[_0x9a89('0x21')](_0x2cca01[_0x3f5723['id']],function(_0x3ab9e5){return{'id':_0x3ab9e5['id'],'fullname':_0x3ab9e5['fullname']};});}}catch(_0x1a5005){_0x3b1807(_0x1a5005);}_0xd8bad3(_0x3f5723);});}function getInteractionTags(_0x5002a2,_0xd64312){return new BPromise(function(_0x5a888b,_0x5817e4){try{if(_0x5002a2[_0x9a89('0x22')]){_0x5002a2[_0x9a89('0x23')]=[];_0x5002a2['TagIds'][_0x9a89('0x24')](',')['forEach'](function(_0x27f442){_0x5002a2[_0x9a89('0x23')][_0x9a89('0x25')](_0xd64312[_0x27f442]);});}delete _0x5002a2[_0x9a89('0x22')];}catch(_0x2324c0){_0x5817e4(_0x2324c0);}_0x5a888b(_0x5002a2);});}function getLastMessageText(_0x90b975){return new BPromise(function(_0x1da14a,_0x5e5751){return db['MailMessage']['findOne']({'where':{'$and':[{'MailInteractionId':_0x90b975['id']},{'$or':[{'direction':'in'},{'$and':[{'direction':_0x9a89('0x26')},{'secret':![]},{'UserId':{'$ne':null}}]}]}]},'attributes':['plainBody'],'order':_0x9a89('0x27'),'raw':!![]})[_0x9a89('0x1b')](function(_0x264c44){if(_0x264c44&&_0x264c44['plainBody']){_0x90b975[_0x9a89('0x28')]=_['trimStart'](_0x264c44[_0x9a89('0x29')]);}_0x1da14a(_0x90b975);})[_0x9a89('0x2a')](function(_0x48a9aa){_0x5e5751(_0x48a9aa);});});}function updateMailInteraction(_0x35fcc5,_0xe5921,_0x49ffe5,_0x5ae0e9){return new BPromise(function(_0x163055,_0x124490){return getInteractionUsers(_0x35fcc5,_0x49ffe5)[_0x9a89('0x1b')](function(_0x356ac8){return getInteractionTags(_0x356ac8,_0xe5921);})[_0x9a89('0x1b')](function(_0x1a7325){return getStateInteraction(_0x1a7325);})[_0x9a89('0x1b')](function(_0x330f2c){if(_0x5ae0e9){_0x163055(getLastMessageText(_0x330f2c));}else{_0x163055(_0x330f2c);}})['catch'](function(_0x409b5e){_0x124490(_0x409b5e);});});}function getStateInteraction(_0x1b36db){return new BPromise(function(_0x265177){_0x1b36db[_0x9a89('0x2b')]=0x0;_0x1b36db[_0x9a89('0x2c')]=0x0;_0x1b36db[_0x9a89('0x2d')]=0x0;_0x1b36db[_0x9a89('0x2e')]=0x0;_0x1b36db[_0x9a89('0x2f')]=0x0;if(!_0x1b36db[_0x9a89('0x30')]&&!_0x1b36db[_0x9a89('0x31')]){_0x1b36db['waiting']+=0x1;}if(!_0x1b36db[_0x9a89('0x30')]&&_0x1b36db[_0x9a89('0x31')]){_0x1b36db[_0x9a89('0x2c')]+=0x1;if(_0x1b36db[_0x9a89('0x2b')]){_0x1b36db[_0x9a89('0x2b')]-=0x1;}}if(_0x1b36db[_0x9a89('0x30')]&&_0x1b36db[_0x9a89('0x31')]){_0x1b36db[_0x9a89('0x2d')]+=0x1;if(_0x1b36db[_0x9a89('0x2c')]){_0x1b36db[_0x9a89('0x2c')]-=0x1;}}if(_0x1b36db[_0x9a89('0x30')]&&!_0x1b36db[_0x9a89('0x31')]){_0x1b36db['unmanaged']+=0x1;if(_0x1b36db[_0x9a89('0x2b')]){_0x1b36db['waiting']-=0x1;}}_0x1b36db[_0x9a89('0x2f')]+=0x1;_0x265177(_0x1b36db);});}exports[_0x9a89('0x32')]=function(_0x26112d,_0x2f88e9){var _0x158981={},_0x2d4b6f={},_0x474fad={'count':0x0,'rows':[]};var _0x337429=_[_0x9a89('0x21')](db['MailInteraction'][_0x9a89('0x33')],function(_0xb656cb){return{'name':_0xb656cb[_0x9a89('0x34')],'type':_0xb656cb[_0x9a89('0x35')]['key']};});_0x2d4b6f['model']=_[_0x9a89('0x21')](_0x337429,'name');_0x2d4b6f[_0x9a89('0x36')]=_[_0x9a89('0x37')](_0x26112d[_0x9a89('0x36')]);_0x2d4b6f[_0x9a89('0x38')]=_[_0x9a89('0x39')](_0x2d4b6f[_0x9a89('0x3a')],_0x2d4b6f[_0x9a89('0x36')]);_0x158981[_0x9a89('0x3b')]=_['intersection'](_0x2d4b6f['model'],qs['fields'](_0x26112d[_0x9a89('0x36')]['fields']));_0x158981['attributes']=_0x158981[_0x9a89('0x3b')][_0x9a89('0x3c')]?_0x158981[_0x9a89('0x3b')]:_0x2d4b6f['model'];if(!_0x26112d[_0x9a89('0x36')]['hasOwnProperty'](_0x9a89('0x3d'))){_0x158981['limit']=qs[_0x9a89('0x18')](_0x26112d[_0x9a89('0x36')][_0x9a89('0x18')]);_0x158981['offset']=qs[_0x9a89('0x19')](_0x26112d[_0x9a89('0x36')][_0x9a89('0x19')]);}_0x158981['order']=qs['sort'](_0x26112d[_0x9a89('0x36')]['sort']);_0x158981[_0x9a89('0x3e')]=qs[_0x9a89('0x38')](_['pick'](_0x26112d[_0x9a89('0x36')],_0x2d4b6f[_0x9a89('0x38')]),_0x337429);var _0x4ae6c9=[];var _0x4b4636=squel[_0x9a89('0x3f')]()[_0x9a89('0x40')]('id')['field'](_0x9a89('0x41'))['field'](_0x9a89('0x42'))[_0x9a89('0x43')](_0x9a89('0x44'));var _0x38cddb=squel[_0x9a89('0x3f')]()['field'](_0x9a89('0x45'))['field'](_0x9a89('0x46'))[_0x9a89('0x40')]('ui.MailInteractionId')[_0x9a89('0x43')](_0x9a89('0x47'),'ui')[_0x9a89('0x48')](_0x9a89('0x49'),'u',_0x9a89('0x4a'));var _0x14b44e=squel[_0x9a89('0x3f')]()[_0x9a89('0x43')](_0x9a89('0x4b'),'i')[_0x9a89('0x48')](_0x9a89('0x4c'),'c','c.id\x20=\x20i.ContactId\x20AND\x20c.deletedAt\x20IS\x20NULL')[_0x9a89('0x48')](_0x9a89('0x49'),'o',_0x9a89('0x4d'))['left_join'](_0x9a89('0x4e'),'a',_0x9a89('0x4f'))['left_join']('mail_messages','me',_0x9a89('0x50'))[_0x9a89('0x48')](_0x9a89('0x51'),'it','it.MailInteractionId\x20=\x20i.id')[_0x9a89('0x48')](_0x9a89('0x44'),'t',_0x9a89('0x52'));var _0x4f1f1b=squel[_0x9a89('0x53')]();var _0x5e6b95=[];var _0x283960=squel['expr']();var _0x5cc567;if(_0x26112d[_0x9a89('0x36')]['search']){_0x5cc567=as['parseSearch'](_0x26112d['query']['search']);var _0x5bf1bf=_0x5cc567['sqlOperator'];for(var _0x348925=0x0;_0x348925<_0x5cc567['conditions'][_0x9a89('0x3c')];_0x348925++){var _0x197685=_0x5cc567['conditions'][_0x348925];var _0x2e78cf='i';var _0x5c7215=_['find'](_0x337429,[_0x9a89('0x41'),_0x197685[_0x9a89('0x40')]]);if(!_0x5c7215){switch(_0x197685[_0x9a89('0x40')]){case _0x9a89('0x54'):if(_0x197685['value']==0x1){_0x14b44e[_0x9a89('0x55')]('`'+_0x197685['field']+_0x9a89('0x56'));}else{_0x14b44e[_0x9a89('0x55')]('`'+_0x197685[_0x9a89('0x40')]+_0x9a89('0x57'));}break;case _0x9a89('0x58'):if(_0x197685[_0x9a89('0x59')]===_0x9a89('0x5a')){if(_0x197685[_0x9a89('0x5b')][_0x9a89('0x24')]('\x20')[_0x9a89('0x3c')]>0x1){_0x4f1f1b[_0x5bf1bf](_0x9a89('0x5c'),qs['getFullTextValue'](_0x197685[_0x9a89('0x5b')]),null);}else{var _0x14f003='%'+_0x197685[_0x9a89('0x5b')]+'%';_0x4f1f1b[_0x5bf1bf](_0x9a89('0x5d'),_0x14f003,_0x14f003,_0x14f003);}}else{_0x5c7215=_[_0x9a89('0x5e')](_0x337429,['name','ContactId']);_0x197685[_0x9a89('0x40')]=_0x9a89('0x5f');_0x42b771=as[_0x9a89('0x60')](_0x2e78cf,_0x5c7215['type'],_0x197685);_0x4f1f1b[_0x5bf1bf](_0x42b771['text'],_0x42b771['value']['start'],_0x42b771['value'][_0x9a89('0x1d')]);}break;case _0x9a89('0x61'):var _0x16ee90=_0x197685['value']['split'](',')[_0x9a89('0x21')](function(_0x4ecaa4){return Number(_0x4ecaa4);});_0x16ee90['forEach'](function(_0xed2f1f){_0x283960['or']('CONCAT(\x27,\x27,\x20`TagIds`,\x20\x27,\x27)\x20LIKE\x20?','%,'+_0xed2f1f+',%');});_0x5e6b95=_[_0x9a89('0x62')](_0x5e6b95,_0x16ee90);break;case _0x9a89('0x63'):if(_0x197685['operator']===_0x9a89('0x5a')){_0x4f1f1b[_0x5bf1bf](_0x9a89('0x64'),'%'+_0x197685['value']+'%',null);}else{_0x5c7215=_[_0x9a89('0x5e')](_0x337429,[_0x9a89('0x41'),_0x9a89('0x31')]);_0x197685['field']=_0x9a89('0x31');_0x42b771=as[_0x9a89('0x60')](_0x2e78cf,_0x5c7215['type'],_0x197685);_0x4f1f1b[_0x5bf1bf](_0x42b771[_0x9a89('0x65')],_0x42b771[_0x9a89('0x5b')][_0x9a89('0x66')],_0x42b771['value'][_0x9a89('0x1d')]);}break;case _0x9a89('0x29'):_0x42b771=as[_0x9a89('0x60')]('me',null,_0x197685);_0x4f1f1b[_0x5bf1bf](_0x42b771[_0x9a89('0x65')],_0x42b771['value'][_0x9a89('0x66')],_0x42b771['value'][_0x9a89('0x1d')]);break;}}else{var _0x42b771=as[_0x9a89('0x60')](_0x2e78cf,_0x5c7215[_0x9a89('0x35')],_0x197685);_0x4f1f1b[_0x5bf1bf](_0x42b771[_0x9a89('0x65')],_0x42b771[_0x9a89('0x5b')][_0x9a89('0x66')],_0x42b771[_0x9a89('0x5b')]['end']);}}}else{var _0x5bad90=_(_0x26112d[_0x9a89('0x36')])['keys']()[_0x9a89('0x21')](function(_0x674a9e){return _['some'](_0x337429,['name',_0x674a9e])?_0x674a9e:undefined;})[_0x9a89('0x67')]()[_0x9a89('0x5b')]();if(!_[_0x9a89('0x68')](_0x5bad90)){_0x5bad90[_0x9a89('0x69')](function(_0x2b0efd){if(_0x2b0efd===_0x9a89('0x6a')){_0x14b44e[_0x9a89('0x3e')](_0x9a89('0x6b'),[][_0x9a89('0x6c')](_0x26112d[_0x9a89('0x36')][_0x2b0efd]));}else if(_0x2b0efd==='createdAt'){var _0x333365=JSON[_0x9a89('0x6d')](_0x26112d['query'][_0x2b0efd])[_0x9a89('0x6e')];var _0x5ddfdb=JSON['parse'](_0x26112d[_0x9a89('0x36')][_0x2b0efd])['$lte'];_0x14b44e[_0x9a89('0x3e')](_0x9a89('0x6f'),_0x333365,_0x5ddfdb);}else{if(_0x26112d[_0x9a89('0x36')][_0x2b0efd]===_0x9a89('0x70')){_0x14b44e[_0x9a89('0x3e')]('i.'+_0x2b0efd+'\x20IS\x20NULL');}else{_0x14b44e['where']('i.'+_0x2b0efd+_0x9a89('0x71'),_0x26112d['query'][_0x2b0efd]);}}});}if(_0x26112d[_0x9a89('0x36')][_0x9a89('0x72')]){if(_0x26112d[_0x9a89('0x36')]['read']==0x1){_0x14b44e[_0x9a89('0x55')](_0x9a89('0x73'));}else{_0x14b44e[_0x9a89('0x55')](_0x9a89('0x74'));}}if(_0x26112d['query'][_0x9a89('0x75')]){_0x5e6b95=_[_0x9a89('0x76')](_0x26112d[_0x9a89('0x36')][_0x9a89('0x75')])?_0x26112d['query'][_0x9a89('0x75')]:new Array(_0x26112d[_0x9a89('0x36')][_0x9a89('0x75')]);_0x5e6b95[_0x9a89('0x69')](function(_0xad008c){_0x283960['or'](_0x9a89('0x77'),'%,'+_0xad008c+',%');});}if(_0x26112d['query'][_0x9a89('0x78')]){var _0x12c6b5=_0x26112d['query'][_0x9a89('0x78')][_0x9a89('0x79')]('\x5c','\x5c\x5c')[_0x9a89('0x79')](/'/g,'\x27\x27');if(qs[_0x9a89('0x7a')](_0x12c6b5)){_0x4f1f1b['or'](_0x9a89('0x7b'),_0x12c6b5+'%');}else if(qs[_0x9a89('0x7c')](_0x12c6b5)){_0x4f1f1b['or'](_0x9a89('0x7d'),_0x12c6b5+'%');}else{_0x4f1f1b['or'](_0x9a89('0x7e'),qs['getFullTextValue'](_0x12c6b5))['or'](_0x9a89('0x7f'),qs[_0x9a89('0x80')](_0x12c6b5));}}}_0x14b44e[_0x9a89('0x3e')](_0x4f1f1b);_0x14b44e[_0x9a89('0x81')](_0x9a89('0x82'));var _0x1a679d={'type':db['Sequelize']['QueryTypes']['SELECT'],'raw':!![]};var _0x4e6691=_0x14b44e['clone']();_0x4e6691[_0x9a89('0x40')](_0x9a89('0x82'));_0x4e6691[_0x9a89('0x40')](_0x9a89('0x83'),_0x9a89('0x54'));if(_0x158981[_0x9a89('0x84')]){_0x158981[_0x9a89('0x84')]['forEach'](function(_0x2fdf08){var _0x16255f=_0x2fdf08[0x0]==='contactName'?_0x2fdf08[0x0]:'i.'+_0x2fdf08[0x0];_0x14b44e['order'](_0x16255f,_0x2fdf08[0x1]===_0x9a89('0x85')?![]:!![]);});}if(!_[_0x9a89('0x68')](_0x5e6b95)){_0x14b44e[_0x9a89('0x55')](_0x283960);_0x4e6691[_0x9a89('0x3e')](_0x9a89('0x86'),_0x5e6b95);}BPromise[_0x9a89('0x87')]()[_0x9a89('0x1b')](function(){if(!_0x5cc567){if(_0x26112d[_0x9a89('0x36')]['MailAccountId'])return;_0x4e6691['where']('i.MailAccountId\x20IS\x20NOT\x20NULL');_0x14b44e[_0x9a89('0x3e')](_0x9a89('0x88'));return;}if(_0x26112d[_0x9a89('0x89')][_0x9a89('0x8a')]!==_0x9a89('0x8b'))return;return _0x26112d[_0x9a89('0x89')][_0x9a89('0x8c')]({'attributes':['id'],'raw':!![]})[_0x9a89('0x1b')](function(_0x5e6a0c){if(_[_0x9a89('0x68')](_0x5e6a0c)){_0x4e6691[_0x9a89('0x3e')](_0x9a89('0x8d'));_0x14b44e['where'](_0x9a89('0x8d'));}else{_0x4e6691[_0x9a89('0x3e')](_0x9a89('0x6b'),_[_0x9a89('0x21')](_0x5e6a0c,'id'));_0x14b44e['where'](_0x9a89('0x6b'),_['map'](_0x5e6a0c,'id'));}});})['then'](function(){if(_0x26112d['user'][_0x9a89('0x8a')]===_0x9a89('0x8b')&&!_0x5cc567&&!_0x26112d['query']['MailAccountId'])return[];return db[_0x9a89('0x8e')][_0x9a89('0x36')](_0x4e6691[_0x9a89('0x8f')](),_0x1a679d);})[_0x9a89('0x1b')](function(_0x23a24e){_0x474fad[_0x9a89('0x90')]=_0x23a24e[_0x9a89('0x3c')];if(_0x474fad['count']===0x0)return[];return db[_0x9a89('0x8e')]['query'](_0x4b4636[_0x9a89('0x8f')](),_0x1a679d)[_0x9a89('0x1b')](function(_0x3b15c3){_0x4ae6c9=_[_0x9a89('0x91')](_0x3b15c3,'id');_0x1a679d=_[_0x9a89('0x92')](_0x1a679d,{'model':db['MailInteraction'],'mapToModel':!![],'raw':!![],'nest':!![]});if(_0x26112d[_0x9a89('0x36')][_0x9a89('0x93')]){_0x158981['attributes'][_0x9a89('0x69')](function(_0xb14bab){_0x14b44e[_0x9a89('0x40')]('i.'+_0xb14bab);});}else{_0x14b44e['field'](_0x9a89('0x83'),_0x9a89('0x54'));_0x14b44e['field'](_0x9a89('0x94'),'Account.key');_0x14b44e[_0x9a89('0x40')](_0x9a89('0x95'),_0x9a89('0x96'));_0x14b44e[_0x9a89('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');_0x14b44e[_0x9a89('0x40')](_0x9a89('0x82'));_0x14b44e['field']('i.createdAt');_0x14b44e[_0x9a89('0x40')]('i.updatedAt');_0x14b44e[_0x9a89('0x40')](_0x9a89('0x97'));_0x14b44e[_0x9a89('0x40')](_0x9a89('0x98'));_0x14b44e[_0x9a89('0x40')](_0x9a89('0x99'));_0x14b44e['field']('i.lastMsgAt');_0x14b44e[_0x9a89('0x40')](_0x9a89('0x9a'));_0x14b44e['field'](_0x9a89('0x9b'));_0x14b44e[_0x9a89('0x40')]('i.disposition');_0x14b44e['field']('i.secondDisposition');_0x14b44e[_0x9a89('0x40')]('i.thirdDisposition');_0x14b44e['field'](_0x9a89('0x9c'));_0x14b44e[_0x9a89('0x40')](_0x9a89('0x9d'));_0x14b44e[_0x9a89('0x40')](_0x9a89('0x9e'));_0x14b44e[_0x9a89('0x40')](_0x9a89('0x9f'));_0x14b44e[_0x9a89('0x40')](_0x9a89('0xa0'));_0x14b44e[_0x9a89('0x40')]('c.firstName',_0x9a89('0xa1'));_0x14b44e[_0x9a89('0x40')]('c.lastName',_0x9a89('0xa2'));_0x14b44e['field'](_0x9a89('0xa3'),_0x9a89('0xa4'));_0x14b44e[_0x9a89('0x40')]('c.phone',_0x9a89('0xa5'));_0x14b44e[_0x9a89('0x40')](_0x9a89('0xa6'),_0x9a89('0xa7'));_0x14b44e[_0x9a89('0x40')](_0x9a89('0xa8'),_0x9a89('0xa9'));_0x14b44e['field'](_0x9a89('0xaa'),_0x9a89('0xab'));_0x14b44e[_0x9a89('0x40')](_0x9a89('0xac'),_0x9a89('0xad'));_0x14b44e['field'](_0x9a89('0xae'),_0x9a89('0x22'));}if(_0x158981['limit'])_0x14b44e[_0x9a89('0x18')](_0x158981[_0x9a89('0x18')]);if(_0x158981[_0x9a89('0x19')])_0x14b44e[_0x9a89('0x19')](_0x158981[_0x9a89('0x19')]);return db['sequelize'][_0x9a89('0x36')](_0x14b44e['toString'](),_0x1a679d);})['then'](function(_0x2942f7){if(_0x2942f7[_0x9a89('0x3c')]>0x0)_0x38cddb[_0x9a89('0x3e')]('ui.MailInteractionId\x20IN\x20?',_['map'](_0x2942f7,'id'));return db[_0x9a89('0x8e')]['query'](_0x38cddb[_0x9a89('0x8f')](),_0x1a679d)[_0x9a89('0x1b')](function(_0x53fbb9){var _0x70af2b=_[_0x9a89('0xaf')](_0x53fbb9,_0x9a89('0xb0'));var _0x33a6c9=[];return db['Setting'][_0x9a89('0xb1')]({'attributes':[_0x9a89('0xb2')],'raw':!![]})['then'](function(_0x38ebf2){var _0x1b6a97=_0x38ebf2[_0x9a89('0xb2')];_0x2942f7[_0x9a89('0x69')](function(_0x59ab18){_0x33a6c9[_0x9a89('0x25')](updateMailInteraction(_0x59ab18,_0x4ae6c9,_0x70af2b,_0x1b6a97));});return BPromise['all'](_0x33a6c9);});});});})[_0x9a89('0x1b')](function(_0x49119a){_0x474fad['rows']=_0x49119a;return _0x474fad;})[_0x9a89('0x1b')](respondWithFilteredResult(_0x2f88e9,_0x158981))[_0x9a89('0x2a')](handleError(_0x2f88e9,null));};exports[_0x9a89('0xb3')]=function(_0x33bbaf,_0x43b699){var _0x3ad9ec={'raw':![],'where':{'id':_0x33bbaf[_0x9a89('0xb4')]['id']}},_0x1bb324={};_0x1bb324[_0x9a89('0x3a')]=_[_0x9a89('0x37')](db[_0x9a89('0xb5')]['rawAttributes']);_0x1bb324[_0x9a89('0x36')]=_['keys'](_0x33bbaf[_0x9a89('0x36')]);_0x1bb324[_0x9a89('0x38')]=_['intersection'](_0x1bb324[_0x9a89('0x3a')],_0x1bb324[_0x9a89('0x36')]);_0x3ad9ec[_0x9a89('0x3b')]=_[_0x9a89('0x39')](_0x1bb324[_0x9a89('0x3a')],qs[_0x9a89('0x93')](_0x33bbaf[_0x9a89('0x36')][_0x9a89('0x93')]));_0x3ad9ec[_0x9a89('0x3b')]=_0x3ad9ec['attributes'][_0x9a89('0x3c')]?_0x3ad9ec[_0x9a89('0x3b')]:_0x1bb324[_0x9a89('0x3a')];if(_0x33bbaf['query']['includeAll']){_0x3ad9ec['include']=[{'all':!![]}];}_0x3ad9ec=_[_0x9a89('0x92')]({},_0x3ad9ec,_0x33bbaf[_0x9a89('0xb6')]);return db[_0x9a89('0xb5')]['find'](_0x3ad9ec)['then'](handleEntityNotFound(_0x43b699,null))[_0x9a89('0x1b')](respondWithResult(_0x43b699,null))[_0x9a89('0x2a')](handleError(_0x43b699,null));};exports['create']=function(_0x2cdb9d,_0x4eeb21){return db[_0x9a89('0xb5')][_0x9a89('0xb7')](_0x2cdb9d[_0x9a89('0xb8')],{})[_0x9a89('0x1b')](respondWithResult(_0x4eeb21,0xc9))[_0x9a89('0x2a')](handleError(_0x4eeb21,null));};exports['update']=function(_0x2f68,_0x329e59){if(_0x2f68[_0x9a89('0xb8')]['id']){delete _0x2f68['body']['id'];}return db[_0x9a89('0xb5')]['find']({'where':{'id':_0x2f68[_0x9a89('0xb4')]['id']}})[_0x9a89('0x1b')](handleEntityNotFound(_0x329e59,null))[_0x9a89('0x1b')](saveUpdates(_0x2f68[_0x9a89('0xb8')],null))[_0x9a89('0x1b')](respondWithResult(_0x329e59,null))[_0x9a89('0x2a')](handleError(_0x329e59,null));};exports[_0x9a89('0x1c')]=function(_0x10c36c,_0x3b9a8c){return db[_0x9a89('0xb5')][_0x9a89('0x5e')]({'where':{'id':_0x10c36c[_0x9a89('0xb4')]['id']}})[_0x9a89('0x1b')](handleEntityNotFound(_0x3b9a8c,null))[_0x9a89('0x1b')](removeEntity(_0x3b9a8c,null))[_0x9a89('0x2a')](handleError(_0x3b9a8c,null));};exports[_0x9a89('0xb9')]=function(_0x194b23,_0x2b0371){return db[_0x9a89('0xb5')][_0x9a89('0xb9')]()['then'](respondWithResult(_0x2b0371,null))['catch'](handleError(_0x2b0371,null));};exports[_0x9a89('0xba')]=function(_0xc194d9,_0x516595){return db['MailMessage']['find']({'where':{'id':_0xc194d9[_0x9a89('0xb4')]['id']}})[_0x9a89('0x1b')](handleEntityNotFound(_0x516595,null))[_0x9a89('0x1b')](function(_0x4dfd7b){if(_0x4dfd7b){return _0x4dfd7b[_0x9a89('0xba')](_0xc194d9['body'][_0x9a89('0xbb')],_[_0x9a89('0xbc')](_0xc194d9[_0x9a89('0xb8')],[_0x9a89('0xbb'),'id'])||{});}})[_0x9a89('0x1b')](respondWithResult(_0x516595,null))[_0x9a89('0x2a')](handleError(_0x516595,null));};exports[_0x9a89('0xbd')]=function(_0x4c3bb8,_0x430d77){var _0x3dccc6={'raw':![],'where':{}};var _0x3752b8={};var _0x335300={'count':0x0,'rows':[]};return db[_0x9a89('0xb5')][_0x9a89('0xb1')]({'where':{'id':_0x4c3bb8[_0x9a89('0xb4')]['id']}})[_0x9a89('0x1b')](handleEntityNotFound(_0x430d77,null))['then'](function(_0xb13343){if(_0xb13343){_0x3752b8[_0x9a89('0x3a')]=_[_0x9a89('0x37')](db['MailMessage'][_0x9a89('0x33')]);_0x3752b8[_0x9a89('0x36')]=_[_0x9a89('0x37')](_0x4c3bb8[_0x9a89('0x36')]);_0x3752b8[_0x9a89('0x38')]=_['intersection'](_0x3752b8[_0x9a89('0x3a')],_0x3752b8[_0x9a89('0x36')]);_0x3dccc6[_0x9a89('0x3b')]=_[_0x9a89('0x39')](_0x3752b8['model'],qs['fields'](_0x4c3bb8[_0x9a89('0x36')][_0x9a89('0x93')]));_0x3dccc6[_0x9a89('0x3b')]=_0x3dccc6[_0x9a89('0x3b')][_0x9a89('0x3c')]?_0x3dccc6[_0x9a89('0x3b')]:_0x3752b8[_0x9a89('0x3a')];if(!_0x4c3bb8['query'][_0x9a89('0xbe')](_0x9a89('0x3d'))){_0x3dccc6[_0x9a89('0x18')]=qs[_0x9a89('0x18')](_0x4c3bb8['query'][_0x9a89('0x18')]);_0x3dccc6[_0x9a89('0x19')]=qs['offset'](_0x4c3bb8[_0x9a89('0x36')][_0x9a89('0x19')]);}_0x3dccc6['order']=qs['sort'](_0x4c3bb8['query'][_0x9a89('0xbf')]);_0x3dccc6[_0x9a89('0x3e')]=qs[_0x9a89('0x38')](_[_0x9a89('0xc0')](_0x4c3bb8[_0x9a89('0x36')],_0x3752b8[_0x9a89('0x38')]));_0x3dccc6[_0x9a89('0x3e')][_0x9a89('0xb0')]=_0xb13343['id'];if(_0x4c3bb8[_0x9a89('0x36')][_0x9a89('0x78')]){_0x3dccc6[_0x9a89('0x3e')]=_['merge'](_0x3dccc6['where'],{'$or':_['map'](_0x3dccc6[_0x9a89('0x3b')],function(_0x1f4d70){var _0x2a93e8={};_0x2a93e8[_0x1f4d70]={'$like':'%'+_0x4c3bb8['query'][_0x9a89('0x78')]+'%'};return _0x2a93e8;})});}if(_0x4c3bb8[_0x9a89('0x36')]['$gte']){var _0x31c7b7=_0x4c3bb8[_0x9a89('0x36')][_0x9a89('0x6e')][_0x9a89('0x24')](',');var _0xcd9d3e={};_0xcd9d3e[_0x31c7b7[0x0]]={'$gte':moment(_0x31c7b7[0x1])[_0x9a89('0xc1')](_0x9a89('0xc2'))};_0x3dccc6[_0x9a89('0x3e')]=_[_0x9a89('0x92')](_0x3dccc6[_0x9a89('0x3e')],_0xcd9d3e);}_0x3dccc6=_[_0x9a89('0x92')]({},_0x3dccc6,_0x4c3bb8[_0x9a89('0xb6')]);return db[_0x9a89('0xc3')][_0x9a89('0x90')]({'where':_0x3dccc6[_0x9a89('0x3e')]})[_0x9a89('0x1b')](function(_0x2270b7){_0x335300[_0x9a89('0x90')]=_0x2270b7;if(_0x4c3bb8['query']['includeAll']){_0x3dccc6['include']=[{'all':!![]}];}return db[_0x9a89('0xc3')][_0x9a89('0xc4')](_0x3dccc6);})[_0x9a89('0x1b')](function(_0x291967){if(_0x4c3bb8[_0x9a89('0x36')][_0x9a89('0xc5')]===_0x9a89('0xc6')){for(var _0x30c36e=0x0;_0x30c36e<_0x291967[_0x9a89('0x3c')];_0x30c36e++){_0x291967[_0x30c36e][_0x9a89('0xb8')]=juice(_0x291967[_0x30c36e][_0x9a89('0xb8')]);}}_0x335300[_0x9a89('0xc7')]=_0x291967;return _0x335300;});}})[_0x9a89('0x1b')](respondWithFilteredResult(_0x430d77,_0x3dccc6))[_0x9a89('0x2a')](handleError(_0x430d77,null));};exports[_0x9a89('0xc8')]=function(_0x4f26c9,_0x59083b){return db[_0x9a89('0xb5')][_0x9a89('0x5e')]({'where':{'id':_0x4f26c9[_0x9a89('0xb4')]['id']}})[_0x9a89('0x1b')](handleEntityNotFound(_0x59083b,null))[_0x9a89('0x1b')](function(_0x3f7018){if(_0x3f7018){return _0x3f7018[_0x9a89('0xc9')](_0x4f26c9[_0x9a89('0xb8')][_0x9a89('0xbb')],_[_0x9a89('0xbc')](_0x4f26c9[_0x9a89('0xb8')],[_0x9a89('0xbb'),'id'])||{})[_0x9a89('0xca')](function(){return db[_0x9a89('0x61')][_0x9a89('0xc4')]({'attributes':['id',_0x9a89('0x41'),_0x9a89('0x42')],'where':{'id':_0x4f26c9[_0x9a89('0xb8')][_0x9a89('0xbb')]}});})[_0x9a89('0x1b')](function(_0x410af5){socket['emit'](_0x9a89('0xcb'),{'id':Number(_0x4f26c9[_0x9a89('0xb4')]['id']),'tags':_0x410af5||[]});return{'id':Number(_0x4f26c9['params']['id']),'tags':_0x410af5||[]};});}})[_0x9a89('0x1b')](respondWithResult(_0x59083b,null))[_0x9a89('0x2a')](handleError(_0x59083b,null));};exports[_0x9a89('0xcc')]=function(_0x1bfb64,_0x5bb002){return db[_0x9a89('0xb5')]['find']({'where':{'id':_0x1bfb64[_0x9a89('0xb4')]['id']}})['then'](handleEntityNotFound(_0x5bb002,null))[_0x9a89('0x1b')](function(_0x3f87fb){if(_0x3f87fb){return _0x3f87fb[_0x9a89('0xcc')](_0x1bfb64[_0x9a89('0x36')]['ids']);}})[_0x9a89('0x1b')](respondWithStatusCode(_0x5bb002,null))[_0x9a89('0x2a')](handleError(_0x5bb002,null));};exports[_0x9a89('0xcd')]=function(_0x2641f1,_0x41de73){var _0x2184ac=moment()['unix']()[_0x9a89('0x8f')]();var _0xc6bcad=path[_0x9a89('0xce')](config[_0x9a89('0xcf')],'server','files','tmp');var _0x5b892a=path[_0x9a89('0xce')](config[_0x9a89('0xcf')],'server',_0x9a89('0xd0'),_0x9a89('0xd1'));var _0x4d58d6=path[_0x9a89('0xce')](_0xc6bcad,_0x2184ac);var _0x34ba8e=util[_0x9a89('0xc1')]('transcript-%d-%s.zip',_0x2641f1[_0x9a89('0xb4')]['id'],_0x2184ac);var _0x5dc34d=path[_0x9a89('0xce')](_0xc6bcad,_0x34ba8e);var _0x32e1e6=[];if(_0x2641f1[_0x9a89('0x36')][_0x9a89('0xd1')]){_0x32e1e6[_0x9a89('0x25')]({'model':db[_0x9a89('0xd2')],'as':_0x9a89('0xd3'),'raw':!![]});}var _0x18ba74=[{'model':db['MailMessage'],'as':_0x9a89('0xd4'),'attributes':['id','body',_0x9a89('0x43'),'to','cc',_0x9a89('0xd5'),'subject',_0x9a89('0xd6')],'where':{'secret':![]},'order':qs['sort']('id'),'include':_0x32e1e6}];return db[_0x9a89('0xb5')]['find']({'where':{'id':_0x2641f1[_0x9a89('0xb4')]['id']},'include':_0x18ba74})[_0x9a89('0x1b')](handleEntityNotFound(_0x41de73,null))[_0x9a89('0x1b')](function(_0x3a99b0){if(_0x3a99b0&&_0x3a99b0[_0x9a89('0xd4')]){var _0x451a54=_0x3a99b0[_0x9a89('0xd7')]({'plain':!![]});fs['mkdirSync'](_0x4d58d6);return BPromise[_0x9a89('0xd8')](_0x451a54[_0x9a89('0xd4')],function(_0x16469d,_0x22bcd6){var _0x15aec={'from':_0x16469d[_0x9a89('0x43')],'to':_0x16469d['to'],'subject':_0x16469d[_0x9a89('0xd9')],'html':htmlEntities[_0x9a89('0xda')](_0x16469d['body']),'headers':{'Date':moment(_0x16469d[_0x9a89('0xd6')])[_0x9a89('0xc1')](_0x9a89('0xdb'))},'attachments':[]};if(_0x16469d['cc']){_0x15aec[_0x9a89('0xdc')]['Cc']=_0x16469d['cc'];}if(_0x16469d[_0x9a89('0xd5')]){_0x15aec[_0x9a89('0xdc')][_0x9a89('0xdd')]=_0x16469d[_0x9a89('0xd5')];}return new BPromise(function(_0x599cf0,_0x119eed){if(_0x16469d[_0x9a89('0xd3')]){for(var _0x4a74f8=0x0;_0x4a74f8<_0x16469d[_0x9a89('0xd3')][_0x9a89('0x3c')];_0x4a74f8++){var _0x21e819=_0x16469d[_0x9a89('0xd3')][_0x4a74f8];var _0x1b9caa=path[_0x9a89('0xce')](_0x5b892a,_0x21e819[_0x9a89('0xde')]);if(fs[_0x9a89('0xdf')](_0x1b9caa)){_0x15aec[_0x9a89('0xd1')][_0x9a89('0x25')]({'name':_0x21e819[_0x9a89('0x41')],'contentType':_0x21e819[_0x9a89('0x35')],'data':fs[_0x9a89('0xe0')](_0x1b9caa)});}}}emlformat[_0x9a89('0xe1')](_0x15aec,function(_0x2eac59,_0x38ddfb){if(_0x2eac59)return _0x119eed(_0x2eac59);fs[_0x9a89('0xe2')](path[_0x9a89('0xce')](_0x4d58d6,util[_0x9a89('0xc1')](_0x9a89('0xe3'),_0x22bcd6)),_0x38ddfb);return _0x599cf0(_0x38ddfb);});});})[_0x9a89('0x1b')](function(){return new BPromise(function(_0x6dd9a1,_0x2bdcfe){zipdir(_0x4d58d6,{'saveTo':_0x5dc34d},function(_0x5e083e,_0x1846fe){if(_0x5e083e)return _0x2bdcfe(_0x5e083e);return _0x6dd9a1(_0x1846fe);});})[_0x9a89('0x1b')](function(){return new BPromise(function(_0x43649d,_0x430ebc){rimraf(_0x4d58d6,function(_0x4266ed){if(_0x4266ed)_0x430ebc(_0x4266ed);return _0x43649d();});});})[_0x9a89('0x1b')](function(){return _0x41de73[_0x9a89('0xcd')](_0x5dc34d,_0x34ba8e,function(_0x5c1b32){if(!_0x5c1b32)fs[_0x9a89('0xe4')](_0x5dc34d);});});});}else{return _0x41de73[_0x9a89('0x15')](0xc8);}})[_0x9a89('0x2a')](handleError(_0x41de73,null));};