Built motion from commit 753c950e.|2.5.42
[motion2.git] / server / api / cmContact / cmContact.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 _0xa727=['c.lastName','c.phone','c.fax','c.email','c.ListId','c.createdAt','c.deletedAt','c.CompanyId','GROUP_CONCAT(DISTINCT\x20t.id)','TagIds','Tags','rows','catch','describe','tags','columnName','analytics','findAll','displayName','alias','custom','values','body','get','isArray','join','info','[CmContact][merge][destroy][CmHopper],\x20%s','CmHopperBlack','[CmContact][merge][destroy][CmHopperBlack],\x20%s','create','ChatInteraction','ChatMessage','MailInteraction','MailMessage','SmsInteraction','SmsMessage','FaxInteraction','FaxMessage','OpenchannelInteraction','CmHopperFinal','CmHopperHistory','ReportAgentPreview','VoiceCallReport','ChatQueueReport','FaxQueueReport','MailQueueReport','OpenchannelQueueReport','SmsQueueReport','JscriptySessionReport','WhatsappMessage','WhatsappQueueReport','bulkCreate','each','duplicates','$or','spread','show','params','$and','omit','format','cf_%d','table','cm_contacts','setFields','id\x20=\x20?','text','phone','getTags','rawAttributes','pick','options','setTags','ids','getHoppers','CmHopper','ContactId','includeAll','include','getHopperHistories','getHopperFinals','uploadCsv','No\x20ListId\x20specified','binding_keys','No\x20association\x20keys\x20specified!','binding_values','No\x20association\x20values\x20specified!','Incorrect\x20binding\x20parameters\x20passed!','zipObject','No\x20phone\x20column\x20specified','firstName','No\x20firstName\x20column\x20specified','root','server/files/tmp','file','filename','chmodSync','0777','child_process','fork','../../components/import/cm/csv','CompanyId','socket_timestamp','File\x20uploaded\x20correctly!','pid','upload','createReadStream','meta','import','agent','binding','Unable\x20to\x20synchronize\x20socket,\x20no\x20timestamp\x20passed','../../components/import/cm/csv2','stringify','message','start\x20child\x20process\x20correctly!','exit','error\x20child\x20process','getJourney','mail','sms','openchannel','fax','whatsapp','voice','channel','toLowerCase','parse','range','Invalid\x20date\x20for\x20range\x20from\x20filter','isValid','Invalid\x20date\x20for\x20range\x20to\x20filter','Invalid\x20createdAt\x20filter','uniqueid','destination','callerid','starttime','endtime','duration','note','createdAt','userDisposition','userSecondDisposition','userThirdDisposition','UserId','DESC','fullname','chat','Website','closed','closedAt','disposition','thirdDisposition','Account','Owner','customerIp','customerPort','osName','ratingType','ratingValue','referer','subject','externalUrl','threadId','startCase','Interaction','findAndCountAll','flatten','reverse','slice','moment','bluebird','util','path','lodash','squel','ioredis','../../components/parsers/advancedSearch','../../config/logger','../../mysqldb','redis','localhost','socket.io-emitter','./cmContact.socket','register','status','json','offset','undefined','count','set','update','then','destroy','end','error','stack','name','send','index','CmContact','keys','length','startsWith','cf_','push','CmCustomField','findOne','trimStart','all','fieldType','type','model','query','filters','attributes','intersection','fields','hasOwnProperty','nolimit','limit','order','sort','where','field','color','from','left_join','cm_user_has_contacts','cm_contact_has_tags','t.id\x20=\x20ct.TagId','c.deletedAt\x20IS\x20NULL','expr','search','parseSearch','conditions','find','Tag','value','split','CONCAT(\x27,\x27,\x20`TagIds`,\x20\x27,\x27)\x20LIKE\x20?','union','and','uc.UserId\x20=\x20?','dateOfBirth','datetime','castTo','DATE','buildExpression','start','map','filter','isNil','Contact','isEmpty','forEach','ListId','c.ListId\x20IN\x20?','concat','CONCAT_WS(\x27\x20\x27,\x20c.firstName,\x20c.lastName,\x20c.email)\x20LIKE\x20?','\x20=\x20?','tag','replace','MATCH\x20(c.firstName,\x20c.lastName,\x20c.phone,\x20c.mobile,\x20c.fax,\x20c.email)\x20AGAINST\x20(?\x20IN\x20BOOLEAN\x20MODE)','getFullTextValue','isNumeric','c.id\x20LIKE\x20?','c.phone\x20LIKE\x20?','isEmail','c.email\x20LIKE\x20?','c.firstName\x20LIKE\x20?','c.lastName\x20LIKE\x20?','group','c.id','Sequelize','QueryTypes','SELECT','clone','having','t.id\x20IN\x20?','resolve','user','role','some','User','getLists','c.ListId\x20IS\x20NULL','sequelize','toString','keyBy','merge','c.firstName'];(function(_0x122ef9,_0x451d2a){var _0x42fba0=function(_0x17c9d3){while(--_0x17c9d3){_0x122ef9['push'](_0x122ef9['shift']());}};_0x42fba0(++_0x451d2a);}(_0xa727,0x1d0));var _0x7a72=function(_0x55e52a,_0x5db621){_0x55e52a=_0x55e52a-0x0;var _0x4b7634=_0xa727[_0x55e52a];return _0x4b7634;};'use strict';var moment=require(_0x7a72('0x0'));var BPromise=require(_0x7a72('0x1'));var util=require(_0x7a72('0x2'));var path=require(_0x7a72('0x3'));var fs=require('fs');var _=require(_0x7a72('0x4'));var squel=require(_0x7a72('0x5'));var Papa=require('papaparse');var Redis=require(_0x7a72('0x6'));var qs=require('../../components/parsers/qs');var as=require(_0x7a72('0x7'));var logger=require(_0x7a72('0x8'))('api');var config=require('../../config/environment');var db=require(_0x7a72('0x9'))['db'];config[_0x7a72('0xa')]=_['defaults'](config[_0x7a72('0xa')],{'host':_0x7a72('0xb'),'port':0x18eb});var socket=require(_0x7a72('0xc'))(new Redis(config[_0x7a72('0xa')]));require(_0x7a72('0xd'))[_0x7a72('0xe')](socket);function respondWithResult(_0x59126b,_0x572223){_0x572223=_0x572223||0xc8;return function(_0x222f0e){if(_0x222f0e){return _0x59126b[_0x7a72('0xf')](_0x572223)[_0x7a72('0x10')](_0x222f0e);}};}function respondWithFilteredResult(_0x2f84c3,_0x3bb99a){return function(_0x4980ec){if(_0x4980ec){var _0x15e1ff=typeof _0x3bb99a[_0x7a72('0x11')]===_0x7a72('0x12')&&typeof _0x3bb99a['limit']===_0x7a72('0x12');var _0x40d13c=_0x4980ec[_0x7a72('0x13')];var _0x1c720b=_0x15e1ff?0x0:_0x3bb99a[_0x7a72('0x11')];var _0x1d1e6c=_0x15e1ff?_0x4980ec['count']:_0x3bb99a[_0x7a72('0x11')]+_0x3bb99a['limit'];var _0x446987;if(_0x1d1e6c>=_0x40d13c){_0x1d1e6c=_0x40d13c;_0x446987=0xc8;}else{_0x446987=0xce;}_0x2f84c3[_0x7a72('0xf')](_0x446987);return _0x2f84c3[_0x7a72('0x14')]('Content-Range',_0x1c720b+'-'+_0x1d1e6c+'/'+_0x40d13c)[_0x7a72('0x10')](_0x4980ec);}return null;};}function saveUpdates(_0x445419){return function(_0xe8d651){if(_0xe8d651){return _0xe8d651[_0x7a72('0x15')](_0x445419)[_0x7a72('0x16')](function(_0x1bdf54){return _0x1bdf54;});}return null;};}function removeEntity(_0x49b85c){return function(_0x3763eb){if(_0x3763eb){return _0x3763eb[_0x7a72('0x17')]()[_0x7a72('0x16')](function(){_0x49b85c[_0x7a72('0xf')](0xcc)[_0x7a72('0x18')]();});}};}function handleEntityNotFound(_0x591450){return function(_0x2ad5dc){if(!_0x2ad5dc){_0x591450['sendStatus'](0x194);}return _0x2ad5dc;};}function handleError(_0x3bf191,_0x36fff2){_0x36fff2=_0x36fff2||0x1f4;return function(_0x357098){logger[_0x7a72('0x19')](_0x357098[_0x7a72('0x1a')]);if(_0x357098[_0x7a72('0x1b')]){delete _0x357098[_0x7a72('0x1b')];}_0x3bf191['status'](_0x36fff2)[_0x7a72('0x1c')](_0x357098);};}exports[_0x7a72('0x1d')]=function(_0x1d2ef9,_0x2804ac){var _0x9342f2={},_0x3b5454={},_0x69d537={'count':0x0,'rows':[]};return db[_0x7a72('0x1e')]['describe']()['then'](function(_0x82e37){var _0x2f040c=[];for(var _0x43bedc=0x0;_0x43bedc<Object[_0x7a72('0x1f')](_0x82e37)[_0x7a72('0x20')];_0x43bedc++){var _0xcf610=Object[_0x7a72('0x1f')](_0x82e37)[_0x43bedc];if(_[_0x7a72('0x21')](_0xcf610,_0x7a72('0x22'))){_0x2f040c[_0x7a72('0x23')](db[_0x7a72('0x24')][_0x7a72('0x25')]({'where':{'id':_[_0x7a72('0x26')](_0xcf610,_0x7a72('0x22'))},'raw':!![]}));}}return BPromise[_0x7a72('0x27')](_0x2f040c)[_0x7a72('0x16')](function(_0x42ef59){for(var _0x49838e=0x0;_0x49838e<_0x42ef59[_0x7a72('0x20')];_0x49838e++){if(_0x42ef59[_0x49838e]){var _0x1d39eb='cf_'+_0x42ef59[_0x49838e]['id'];var _0x8d7a74=_0x82e37[_0x1d39eb];_0x8d7a74[_0x7a72('0x28')]=_0x42ef59[_0x49838e][_0x7a72('0x29')];}}return _0x82e37;});})[_0x7a72('0x16')](function(_0x40ee1c){_0x3b5454[_0x7a72('0x2a')]=_[_0x7a72('0x1f')](_0x40ee1c);_0x3b5454[_0x7a72('0x2b')]=_[_0x7a72('0x1f')](_0x1d2ef9[_0x7a72('0x2b')]);_0x3b5454[_0x7a72('0x2c')]=_['intersection'](_0x3b5454[_0x7a72('0x2a')],_0x3b5454['query']);_0x9342f2[_0x7a72('0x2d')]=_[_0x7a72('0x2e')](_0x3b5454[_0x7a72('0x2a')],qs['fields'](_0x1d2ef9[_0x7a72('0x2b')][_0x7a72('0x2f')]));_0x9342f2[_0x7a72('0x2d')]=_0x9342f2['attributes']['length']?_0x9342f2[_0x7a72('0x2d')]:_0x3b5454[_0x7a72('0x2a')];if(!_0x1d2ef9[_0x7a72('0x2b')][_0x7a72('0x30')](_0x7a72('0x31'))){_0x9342f2[_0x7a72('0x32')]=qs[_0x7a72('0x32')](_0x1d2ef9['query']['limit']);_0x9342f2[_0x7a72('0x11')]=qs[_0x7a72('0x11')](_0x1d2ef9['query'][_0x7a72('0x11')]);}_0x9342f2[_0x7a72('0x33')]=qs[_0x7a72('0x34')](_0x1d2ef9[_0x7a72('0x2b')][_0x7a72('0x34')]);_0x9342f2[_0x7a72('0x35')]=qs[_0x7a72('0x2c')](_['pick'](_0x1d2ef9['query'],_0x3b5454[_0x7a72('0x2c')]),_0x40ee1c);var _0x52fa7b=[];var _0x39c36c=squel['select']()['field']('id')[_0x7a72('0x36')](_0x7a72('0x1b'))['field'](_0x7a72('0x37'))['from']('tools_tags');var _0x208be4=squel['select']()[_0x7a72('0x38')]('cm_contacts','c')[_0x7a72('0x39')](_0x7a72('0x3a'),'uc','uc.CmContactId\x20=\x20c.id')[_0x7a72('0x39')](_0x7a72('0x3b'),'ct','ct.CmContactId\x20=\x20c.id')[_0x7a72('0x39')]('tools_tags','t',_0x7a72('0x3c'))[_0x7a72('0x35')](_0x7a72('0x3d'));var _0x4a6ff3=squel[_0x7a72('0x3e')]();var _0x68221f=[];var _0x154bc6=squel['expr']();var _0x10b798;if(_0x1d2ef9[_0x7a72('0x2b')][_0x7a72('0x3f')]){_0x10b798=as[_0x7a72('0x40')](_0x1d2ef9['query']['search']);var _0x2fe500=_0x10b798['sqlOperator'];for(var _0x128f79=0x0;_0x128f79<_0x10b798[_0x7a72('0x41')][_0x7a72('0x20')];_0x128f79++){var _0x4fe049=_0x10b798[_0x7a72('0x41')][_0x128f79];var _0x520b78='c';var _0x3dc70d=_(_0x40ee1c)[_0x7a72('0x1f')]()[_0x7a72('0x42')](function(_0xf9fac4){return _0xf9fac4===_0x4fe049[_0x7a72('0x36')];});if(_0x3dc70d)_0x3dc70d=_0x40ee1c[_0x4fe049[_0x7a72('0x36')]];if(!_0x3dc70d){if(_0x4fe049[_0x7a72('0x36')]===_0x7a72('0x43')){var _0x4425e1=_0x4fe049[_0x7a72('0x44')][_0x7a72('0x45')](',')['map'](function(_0x2739ce){return Number(_0x2739ce);});_0x4425e1['forEach'](function(_0x7151d2){_0x154bc6['or'](_0x7a72('0x46'),'%,'+_0x7151d2+',%');});_0x68221f=_[_0x7a72('0x47')](_0x68221f,_0x4425e1);}else if(_0x4fe049[_0x7a72('0x36')]==='User'){_0x4a6ff3[_0x7a72('0x48')](_0x7a72('0x49'),_0x4fe049[_0x7a72('0x44')]);}}else{if(_0x4fe049[_0x7a72('0x36')]===_0x7a72('0x4a')||_0x3dc70d[_0x7a72('0x28')]===_0x7a72('0x4b'))_0x4fe049[_0x7a72('0x4c')]=_0x7a72('0x4d');var _0x5c5a32=as[_0x7a72('0x4e')](_0x520b78,_0x3dc70d[_0x7a72('0x29')],_0x4fe049);_0x4a6ff3[_0x2fe500](_0x5c5a32['text'],_0x5c5a32[_0x7a72('0x44')][_0x7a72('0x4f')],_0x5c5a32[_0x7a72('0x44')][_0x7a72('0x18')]);}}}else{var _0x33b779=_(Object[_0x7a72('0x1f')](_0x1d2ef9[_0x7a72('0x2b')]))[_0x7a72('0x50')](function(_0x2b1c65){return _0x40ee1c['hasOwnProperty'](_0x2b1c65)?_0x2b1c65:undefined;})[_0x7a72('0x51')](function(_0x4b4657){return!_[_0x7a72('0x52')](_0x4b4657);})[_0x7a72('0x44')]();if(_0x1d2ef9['query']['Contact'])_0x33b779[_0x7a72('0x23')](_0x7a72('0x53'));if(!_[_0x7a72('0x54')](_0x33b779)){_0x33b779[_0x7a72('0x55')](function(_0x1d137d){if(_0x1d137d===_0x7a72('0x56')){_0x208be4['where'](_0x7a72('0x57'),[][_0x7a72('0x58')](_0x1d2ef9[_0x7a72('0x2b')][_0x1d137d]));}else if(_0x1d137d===_0x7a72('0x53')){var _0x345406='%'+_0x1d2ef9[_0x7a72('0x2b')][_0x1d137d]+'%';_0x208be4[_0x7a72('0x35')](_0x7a72('0x59'),_0x345406);}else{_0x208be4['where']('c.'+_0x1d137d+_0x7a72('0x5a'),_0x1d2ef9['query'][_0x1d137d]);}});}if(_0x1d2ef9[_0x7a72('0x2b')][_0x7a72('0x5b')]){_0x68221f=_['isArray'](_0x1d2ef9[_0x7a72('0x2b')][_0x7a72('0x5b')])?_0x1d2ef9[_0x7a72('0x2b')][_0x7a72('0x5b')]:new Array(_0x1d2ef9[_0x7a72('0x2b')][_0x7a72('0x5b')]);_0x68221f['forEach'](function(_0xd71797){_0x154bc6['or'](_0x7a72('0x46'),'%,'+_0xd71797+',%');});}if(_0x1d2ef9[_0x7a72('0x2b')][_0x7a72('0x51')]){var _0x3af4a3=_0x1d2ef9['query'][_0x7a72('0x51')][_0x7a72('0x5c')]('\x5c','\x5c\x5c')[_0x7a72('0x5c')](/'/g,'\x27\x27');if(_0x3af4a3[_0x7a72('0x45')]('\x20')[_0x7a72('0x20')]>0x1){_0x4a6ff3['or'](_0x7a72('0x5d'),qs[_0x7a72('0x5e')](_0x3af4a3),null);}else{if(qs[_0x7a72('0x5f')](_0x3af4a3)){_0x4a6ff3['or'](_0x7a72('0x60'),_0x3af4a3+'%');_0x4a6ff3['or'](_0x7a72('0x61'),_0x3af4a3+'%');_0x4a6ff3['or']('c.mobile\x20LIKE\x20?',_0x3af4a3+'%');_0x4a6ff3['or']('c.fax\x20LIKE\x20?',_0x3af4a3+'%');}else if(qs[_0x7a72('0x62')](_0x3af4a3)){_0x4a6ff3['or'](_0x7a72('0x63'),_0x3af4a3+'%');}else{_0x4a6ff3['or'](_0x7a72('0x64'),'%'+_0x3af4a3+'%');_0x4a6ff3['or'](_0x7a72('0x65'),'%'+_0x3af4a3+'%');_0x4a6ff3['or']('c.email\x20LIKE\x20?','%'+_0x3af4a3+'%');}}}}_0x208be4[_0x7a72('0x35')](_0x4a6ff3);_0x208be4[_0x7a72('0x66')](_0x7a72('0x67'));var _0x224857={'type':db[_0x7a72('0x68')][_0x7a72('0x69')][_0x7a72('0x6a')],'raw':!![]};var _0x50439f=_0x208be4[_0x7a72('0x6b')]()[_0x7a72('0x36')](_0x7a72('0x67'));if(_0x9342f2[_0x7a72('0x33')]){_0x9342f2[_0x7a72('0x33')][_0x7a72('0x55')](function(_0x441949){_0x208be4[_0x7a72('0x33')]('c.'+_0x441949[0x0],_0x441949[0x1]==='DESC'?![]:!![]);});}if(!_['isEmpty'](_0x68221f)){_0x208be4[_0x7a72('0x6c')](_0x154bc6);_0x50439f[_0x7a72('0x35')](_0x7a72('0x6d'),_0x68221f);}BPromise[_0x7a72('0x6e')]()[_0x7a72('0x16')](function(){if(!_0x10b798)return;if(_0x1d2ef9[_0x7a72('0x6f')][_0x7a72('0x70')]!=='agent')return;if(!_[_0x7a72('0x71')](_0x10b798[_0x7a72('0x41')],[_0x7a72('0x36'),_0x7a72('0x72')])){return _0x1d2ef9[_0x7a72('0x6f')][_0x7a72('0x73')]({'attributes':['id'],'raw':!![]})['then'](function(_0x59e7d0){if(_['isEmpty'](_0x59e7d0)){_0x50439f[_0x7a72('0x35')](_0x7a72('0x74'));_0x208be4[_0x7a72('0x35')](_0x7a72('0x74'));}else{_0x50439f[_0x7a72('0x35')](_0x7a72('0x57'),_[_0x7a72('0x50')](_0x59e7d0,'id'));_0x208be4['where'](_0x7a72('0x57'),_[_0x7a72('0x50')](_0x59e7d0,'id'));}});}})[_0x7a72('0x16')](function(){if(_0x1d2ef9['user'][_0x7a72('0x70')]==='agent'&&!_0x10b798&&!_0x1d2ef9[_0x7a72('0x2b')]['ListId'])return[];return db[_0x7a72('0x75')][_0x7a72('0x2b')](_0x50439f[_0x7a72('0x76')](),_0x224857);})[_0x7a72('0x16')](function(_0x4e0588){_0x69d537[_0x7a72('0x13')]=_0x4e0588[_0x7a72('0x20')];if(_0x69d537[_0x7a72('0x13')]===0x0)return[];return db[_0x7a72('0x75')][_0x7a72('0x2b')](_0x39c36c[_0x7a72('0x76')](),_0x224857)[_0x7a72('0x16')](function(_0x355b53){_0x52fa7b=_[_0x7a72('0x77')](_0x355b53,'id');_0x224857=_[_0x7a72('0x78')](_0x224857,{'model':db[_0x7a72('0x1e')],'mapToModel':!![],'raw':!![],'nest':!![]});if(_0x1d2ef9[_0x7a72('0x2b')][_0x7a72('0x2f')]){_0x9342f2['attributes'][_0x7a72('0x55')](function(_0x2d0cb2){_0x208be4[_0x7a72('0x36')]('c.'+_0x2d0cb2);});}else{_0x208be4[_0x7a72('0x36')](_0x7a72('0x67'));_0x208be4[_0x7a72('0x36')](_0x7a72('0x79'));_0x208be4[_0x7a72('0x36')](_0x7a72('0x7a'));_0x208be4['field'](_0x7a72('0x7b'));_0x208be4[_0x7a72('0x36')]('c.mobile');_0x208be4['field'](_0x7a72('0x7c'));_0x208be4[_0x7a72('0x36')](_0x7a72('0x7d'));_0x208be4[_0x7a72('0x36')](_0x7a72('0x7e'));_0x208be4[_0x7a72('0x36')](_0x7a72('0x7f'));_0x208be4[_0x7a72('0x36')](_0x7a72('0x80'));_0x208be4[_0x7a72('0x36')](_0x7a72('0x81'));_0x208be4['field'](_0x7a72('0x82'),_0x7a72('0x83'));}if(_0x9342f2['limit'])_0x208be4[_0x7a72('0x32')](_0x9342f2[_0x7a72('0x32')]);if(_0x9342f2[_0x7a72('0x11')])_0x208be4[_0x7a72('0x11')](_0x9342f2[_0x7a72('0x11')]);return db[_0x7a72('0x75')][_0x7a72('0x2b')](_0x208be4[_0x7a72('0x76')](),_0x224857);});})[_0x7a72('0x16')](function(_0x56b56e){_0x56b56e['forEach'](function(_0x590f43){if(_0x590f43[_0x7a72('0x83')]){_0x590f43[_0x7a72('0x84')]=[];_0x590f43[_0x7a72('0x83')][_0x7a72('0x45')](',')[_0x7a72('0x55')](function(_0x1557c3){_0x590f43[_0x7a72('0x84')][_0x7a72('0x23')](_0x52fa7b[_0x1557c3]);});}delete _0x590f43[_0x7a72('0x83')];});_0x69d537[_0x7a72('0x85')]=_0x56b56e;return _0x69d537;})['then'](respondWithFilteredResult(_0x2804ac,_0x9342f2));})[_0x7a72('0x86')](handleError(_0x2804ac,null));};exports[_0x7a72('0x17')]=function(_0x2c0747,_0x7fb379){return db['CmContact'][_0x7a72('0x42')]({'where':{'id':_0x2c0747['params']['id']}})[_0x7a72('0x16')](handleEntityNotFound(_0x7fb379,null))[_0x7a72('0x16')](removeEntity(_0x7fb379,null))[_0x7a72('0x86')](handleError(_0x7fb379,null));};exports[_0x7a72('0x87')]=function(_0x20217d,_0x5482b9){return db[_0x7a72('0x1e')][_0x7a72('0x87')]()[_0x7a72('0x16')](function(_0x247e70){delete _0x247e70[_0x7a72('0x88')];for(var _0x12d4b5=0x0;_0x12d4b5<Object[_0x7a72('0x1f')](_0x247e70)[_0x7a72('0x20')];_0x12d4b5++){var _0x3505be=Object['keys'](_0x247e70)[_0x12d4b5];if(!_[_0x7a72('0x21')](_0x3505be,_0x7a72('0x22'))){_0x247e70[_0x3505be][_0x7a72('0x89')]=_0x3505be;_0x247e70[_0x3505be]['displayName']=_0x3505be;}}return _0x247e70;})[_0x7a72('0x16')](function(_0x3a4e3c){var _0x56aae3={'where':Boolean(_0x20217d[_0x7a72('0x2b')][_0x7a72('0x8a')])===!![]?undefined:{'$or':[{'ListId':_0x20217d[_0x7a72('0x2b')]['id']},{'ListId':null}]},'raw':!![]};return db[_0x7a72('0x24')][_0x7a72('0x8b')](_0x56aae3)[_0x7a72('0x16')](function(_0x3bd962){for(var _0x577a9b=0x0;_0x577a9b<_0x3bd962[_0x7a72('0x20')];_0x577a9b++){var _0x575999=_0x7a72('0x22')+_0x3bd962[_0x577a9b]['id'];_0x3a4e3c[_0x575999][_0x7a72('0x89')]=_0x575999;_0x3a4e3c[_0x575999][_0x7a72('0x8c')]=_0x3bd962[_0x577a9b][_0x7a72('0x8d')];_0x3a4e3c[_0x575999][_0x7a72('0x8e')]={'type':_0x3bd962[_0x577a9b][_0x7a72('0x29')],'values':_0x3bd962[_0x577a9b][_0x7a72('0x8f')]};}Object['keys'](_0x3a4e3c)[_0x7a72('0x55')](function(_0x3f9001){if(!_0x3a4e3c[_0x3f9001][_0x7a72('0x30')]('columnName')){delete _0x3a4e3c[_0x3f9001];}});return _0x3a4e3c;});})[_0x7a72('0x16')](respondWithResult(_0x5482b9,null))[_0x7a72('0x86')](handleError(_0x5482b9,null));};exports[_0x7a72('0x78')]=function(_0x491b93,_0x4e2778){var _0x28a14b;var _0x5eaf7a;var _0x59d9a9;if(_0x491b93['body']['id']){delete _0x491b93['body']['id'];}return db['CmContact'][_0x7a72('0x8b')]({'where':{'id':[_0x491b93[_0x7a72('0x90')]['to'],_0x491b93[_0x7a72('0x90')]['from']]}})['then'](function(_0x44cf84){if(_0x44cf84){if(_0x44cf84['length']!==0x2){return null;}_0x44cf84[0x0]=_0x44cf84[0x0]['get']({'plain':!![]});_0x44cf84[0x1]=_0x44cf84[0x1][_0x7a72('0x91')]({'plain':!![]});delete _0x44cf84[0x0]['id'];delete _0x44cf84[0x1]['id'];return _['mergeWith'](_0x44cf84[0x0],_0x44cf84[0x1],function(_0x2b4c62,_0x43f4e7){if(Array[_0x7a72('0x92')](_0x43f4e7)&&!_0x43f4e7['length']){return _0x2b4c62;}else if(!_0x43f4e7){return _0x2b4c62;}});}})[_0x7a72('0x16')](handleEntityNotFound(_0x4e2778,null))[_0x7a72('0x16')](function(_0x478644){if(_0x478644){if(_0x478644[_0x7a72('0x88')]&&_[_0x7a72('0x92')](_0x478644[_0x7a72('0x88')])){_0x478644['tags']=_0x478644[_0x7a72('0x88')][_0x7a72('0x93')]();}logger[_0x7a72('0x94')]('[CmContact][merge]\x20to\x20%s\x20from\x20%s',_0x491b93[_0x7a72('0x90')]['to'],_0x491b93[_0x7a72('0x90')][_0x7a72('0x38')]);return db['CmHopper'][_0x7a72('0x17')]({'where':{'ContactId':[_0x491b93[_0x7a72('0x90')]['to'],_0x491b93[_0x7a72('0x90')]['from']]}})['then'](function(_0x9f92e4){logger['info'](_0x7a72('0x95'),_0x9f92e4);return db[_0x7a72('0x96')]['destroy']({'where':{'ContactId':[_0x491b93[_0x7a72('0x90')]['to'],_0x491b93[_0x7a72('0x90')][_0x7a72('0x38')]]}})[_0x7a72('0x16')](function(_0x1459e3){logger['info'](_0x7a72('0x97'),_0x1459e3);return db['CmContact'][_0x7a72('0x98')](_0x478644);});});}})[_0x7a72('0x16')](function(_0x2e657e){if(_0x2e657e){_0x28a14b=_0x2e657e;_0x5eaf7a={'ContactId':_0x28a14b['id']};_0x59d9a9={'where':{'ContactId':[_0x491b93[_0x7a72('0x90')]['to'],_0x491b93[_0x7a72('0x90')]['from']]}};return db[_0x7a72('0x99')][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})[_0x7a72('0x16')](function(){if(_0x28a14b){return db[_0x7a72('0x9a')][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})[_0x7a72('0x16')](function(){if(_0x28a14b){return db['ChatOfflineMessage'][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})[_0x7a72('0x16')](function(){if(_0x28a14b){return db[_0x7a72('0x9b')]['update'](_0x5eaf7a,_0x59d9a9);}})['then'](function(){if(_0x28a14b){return db[_0x7a72('0x9c')]['update'](_0x5eaf7a,_0x59d9a9);}})[_0x7a72('0x16')](function(){if(_0x28a14b){return db[_0x7a72('0x9b')][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})['then'](function(){if(_0x28a14b){return db['MailMessage'][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})[_0x7a72('0x16')](function(){if(_0x28a14b){return db[_0x7a72('0x9d')][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})[_0x7a72('0x16')](function(){if(_0x28a14b){return db[_0x7a72('0x9e')][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})['then'](function(){if(_0x28a14b){return db[_0x7a72('0x9f')][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})[_0x7a72('0x16')](function(){if(_0x28a14b){return db[_0x7a72('0xa0')][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})['then'](function(){if(_0x28a14b){return db[_0x7a72('0xa1')][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})[_0x7a72('0x16')](function(){if(_0x28a14b){return db['OpenchannelMessage'][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})[_0x7a72('0x16')](function(){if(_0x28a14b){return db[_0x7a72('0xa2')][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})[_0x7a72('0x16')](function(){if(_0x28a14b){return db[_0x7a72('0xa3')][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})['then'](function(){if(_0x28a14b){return db[_0x7a72('0xa4')][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})[_0x7a72('0x16')](function(){if(_0x28a14b){return db[_0x7a72('0xa5')][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})[_0x7a72('0x16')](function(){if(_0x28a14b){return db[_0x7a72('0xa6')][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})[_0x7a72('0x16')](function(){if(_0x28a14b){return db[_0x7a72('0xa7')][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})[_0x7a72('0x16')](function(){if(_0x28a14b){return db[_0x7a72('0xa8')][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})[_0x7a72('0x16')](function(){if(_0x28a14b){return db[_0x7a72('0xa9')][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})[_0x7a72('0x16')](function(){if(_0x28a14b){return db[_0x7a72('0xaa')]['update'](_0x5eaf7a,_0x59d9a9);}})[_0x7a72('0x16')](function(){if(_0x28a14b){return db[_0x7a72('0xab')]['update'](_0x5eaf7a,_0x59d9a9);}})[_0x7a72('0x16')](function(){if(_0x28a14b){return db['WhatsappInteraction'][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})[_0x7a72('0x16')](function(){if(_0x28a14b){return db[_0x7a72('0xac')][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})[_0x7a72('0x16')](function(){if(_0x28a14b){return db[_0x7a72('0xad')][_0x7a72('0x15')](_0x5eaf7a,_0x59d9a9);}})[_0x7a72('0x16')](function(){if(_0x28a14b){return db[_0x7a72('0x1e')][_0x7a72('0x17')]({'where':{'id':[_0x491b93['body']['to'],_0x491b93[_0x7a72('0x90')][_0x7a72('0x38')]]}});}})[_0x7a72('0x16')](function(){if(_0x28a14b){return _0x28a14b;}})[_0x7a72('0x16')](respondWithResult(_0x4e2778,null))[_0x7a72('0x86')](handleError(_0x4e2778,null));};exports[_0x7a72('0x98')]=function(_0x467817,_0x453307){return db[_0x7a72('0x1e')][_0x7a72('0x87')]()[_0x7a72('0x16')](function(_0x282759){if(_0x467817['body'][_0x7a72('0x88')]&&_[_0x7a72('0x92')](_0x467817['body']['tags'])){if(_0x467817[_0x7a72('0x90')]['tags'][_0x7a72('0x20')]){_0x467817[_0x7a72('0x90')][_0x7a72('0x88')]=_0x467817[_0x7a72('0x90')][_0x7a72('0x88')][_0x7a72('0x93')](';')+';';}else{_0x467817[_0x7a72('0x90')]['tags']=null;}}else{_0x467817[_0x7a72('0x90')][_0x7a72('0x88')]=null;}return db[_0x7a72('0x1e')][_0x7a72('0x98')](_0x467817['body'],{'fields':_[_0x7a72('0x1f')](_0x282759),'raw':!![]});})[_0x7a72('0x16')](respondWithResult(_0x453307,0xc9))[_0x7a72('0x86')](handleError(_0x453307,null));};exports[_0x7a72('0xae')]=function(_0x5e0a30,_0xfdbd3a){var _0x11b31f=0x0;var _0x2d9cd6=0x0;var _0x3913c0=0x0;return db[_0x7a72('0x1e')][_0x7a72('0x87')]()[_0x7a72('0x16')](function(_0x1bea1e){return BPromise[_0x7a72('0xaf')](_0x5e0a30[_0x7a72('0x90')],function(_0x3fc2dd){var _0x1344d6={'where':{'$or':[]},'defaults':_0x3fc2dd,'fields':_[_0x7a72('0x1f')](_0x1bea1e),'raw':!![]};if(_0x3fc2dd['duplicates']){for(var _0x371f73=0x0;_0x371f73<_0x3fc2dd['duplicates'][_0x7a72('0x20')];_0x371f73++){var _0x5aa742={};_0x5aa742[_0x3fc2dd[_0x7a72('0xb0')][_0x371f73]]=_0x3fc2dd[_0x3fc2dd[_0x7a72('0xb0')][_0x371f73]];_0x1344d6[_0x7a72('0x35')][_0x7a72('0xb1')][_0x7a72('0x23')](_0x5aa742);}_0x1344d6[_0x7a72('0x35')][_0x7a72('0x56')]=_0x3fc2dd[_0x7a72('0x56')];}return db[_0x7a72('0x1e')]['findOrCreate'](_0x1344d6)[_0x7a72('0xb2')](function(_0x2ee11d,_0x536d68){if(_0x536d68){_0x11b31f++;}else{_0x3913c0++;}})[_0x7a72('0x86')](function(){_0x2d9cd6++;});});})[_0x7a72('0x16')](function(_0x98e644){if(_0x98e644){return{'success':_0x11b31f,'failure':_0x2d9cd6,'duplicates':_0x3913c0};}})[_0x7a72('0x16')](respondWithResult(_0xfdbd3a,0xc9))['catch'](handleError(_0xfdbd3a,null));};exports[_0x7a72('0xb3')]=function(_0xe50d76,_0x37aafa){var _0x3e9438;return db[_0x7a72('0x1e')][_0x7a72('0x87')]()['then'](function(_0x62bba9){return db['CmContact'][_0x7a72('0x42')]({'where':{'id':_0xe50d76[_0x7a72('0xb4')]['id']},'include':[{'model':db['Tag'],'as':_0x7a72('0x84'),'attributes':['id',_0x7a72('0x1b'),'color'],'required':_0xe50d76['query'][_0x7a72('0x5b')]?!![]:![]}],'attributes':_['keys'](_0x62bba9)});})[_0x7a72('0x16')](function(_0x111d82){if(!_[_0x7a72('0x52')](_0x111d82)){_0x3e9438=_0x111d82[_0x7a72('0x91')]({'plain':!![]});var _0x5eb8b0={'where':{'$and':[{'ListId':{'$ne':null}}]}};if(_0x111d82&&_0x111d82[_0x7a72('0x56')]){if(_0x111d82['ListId']){_0x5eb8b0[_0x7a72('0x35')][_0x7a72('0xb5')][_0x7a72('0x23')]({'ListId':{'$ne':_0x111d82[_0x7a72('0x56')]}});}}return db[_0x7a72('0x24')][_0x7a72('0x8b')](_0x5eb8b0);}})[_0x7a72('0x16')](function(_0xaf6b71){if(!_['isNil'](_0xaf6b71)){return _[_0x7a72('0xb6')](_0x3e9438,_[_0x7a72('0x50')](_0xaf6b71,function(_0x1c7049){return util[_0x7a72('0xb7')]('cf_%d',_0x1c7049['id']);}));}})[_0x7a72('0x16')](handleEntityNotFound(_0x37aafa,null))['then'](respondWithResult(_0x37aafa,null))['catch'](handleError(_0x37aafa,null));};exports['update']=function(_0x4ece5a,_0x3093e0){var _0x14ea67;if(_0x4ece5a[_0x7a72('0x90')]['id']){delete _0x4ece5a[_0x7a72('0x90')]['id'];}return db['CmContact'][_0x7a72('0x42')]({'where':{'id':_0x4ece5a[_0x7a72('0xb4')]['id']}})['then'](handleEntityNotFound(_0x3093e0,null))['then'](saveUpdates(_0x4ece5a[_0x7a72('0x90')],null))['then'](function(_0x1ab1e2){_0x14ea67=_0x1ab1e2;var _0x5f21a5={'where':{'$and':[{'ListId':{'$ne':null}}]}};if(_0x1ab1e2&&_0x1ab1e2['ListId']){if(_0x1ab1e2[_0x7a72('0x56')]){_0x5f21a5['where'][_0x7a72('0xb5')]['push']({'ListId':{'$ne':_0x1ab1e2[_0x7a72('0x56')]}});}}return db[_0x7a72('0x24')]['findAll'](_0x5f21a5);})[_0x7a72('0x16')](function(_0x5ac6d1){if(_0x5ac6d1){return _[_0x7a72('0xb6')](_['pickBy'](_0x4ece5a[_0x7a72('0x90')],function(_0x27ffb6,_0xc6df1b){return _[_0x7a72('0x21')](_0xc6df1b,_0x7a72('0x22'));}),_[_0x7a72('0x50')](_0x5ac6d1,function(_0x456260){return util[_0x7a72('0xb7')](_0x7a72('0xb8'),_0x456260['id']);}));}})[_0x7a72('0x16')](function(_0x434fe0){if(_0x434fe0&&!_[_0x7a72('0x54')](_0x434fe0)){var _0x219ada=squel[_0x7a72('0x15')]()[_0x7a72('0xb9')](_0x7a72('0xba'))[_0x7a72('0xbb')](_0x434fe0)[_0x7a72('0x35')](_0x7a72('0xbc'),_0x4ece5a[_0x7a72('0xb4')]['id'])['toParam']();return db[_0x7a72('0x75')][_0x7a72('0x2b')](_0x219ada[_0x7a72('0xbd')],{'replacements':_0x219ada[_0x7a72('0x8f')]});}})[_0x7a72('0x16')](function(){if(_0x4ece5a[_0x7a72('0x90')][_0x7a72('0xbe')]&&_0x14ea67){return db['CmHopper'][_0x7a72('0x15')]({'phone':_0x4ece5a[_0x7a72('0x90')][_0x7a72('0xbe')]},{'where':{'ContactId':_0x14ea67['id']}});}})[_0x7a72('0x16')](function(){return _0x14ea67;})['then'](respondWithResult(_0x3093e0,null))[_0x7a72('0x86')](handleError(_0x3093e0,null));};exports[_0x7a72('0xbf')]=function(_0x3ae544,_0x3b76aa){var _0x5b93d9={};var _0x28074b={};var _0x277975;var _0x413966;return db[_0x7a72('0x1e')]['findOne']({'where':{'id':_0x3ae544[_0x7a72('0xb4')]['id']}})[_0x7a72('0x16')](handleEntityNotFound(_0x3b76aa,null))[_0x7a72('0x16')](function(_0x4c45bf){if(_0x4c45bf){_0x277975=_0x4c45bf;_0x28074b[_0x7a72('0x2a')]=_[_0x7a72('0x1f')](db[_0x7a72('0x43')][_0x7a72('0xc0')]);_0x28074b[_0x7a72('0x2b')]=_[_0x7a72('0x1f')](_0x3ae544[_0x7a72('0x2b')]);_0x28074b[_0x7a72('0x2c')]=_['intersection'](_0x28074b[_0x7a72('0x2a')],_0x28074b['query']);_0x5b93d9[_0x7a72('0x2d')]=_[_0x7a72('0x2e')](_0x28074b[_0x7a72('0x2a')],qs[_0x7a72('0x2f')](_0x3ae544[_0x7a72('0x2b')]['fields']));_0x5b93d9['attributes']=_0x5b93d9[_0x7a72('0x2d')]['length']?_0x5b93d9['attributes']:_0x28074b[_0x7a72('0x2a')];_0x5b93d9[_0x7a72('0x33')]=qs['sort'](_0x3ae544[_0x7a72('0x2b')]['sort']);_0x5b93d9[_0x7a72('0x35')]=qs[_0x7a72('0x2c')](_[_0x7a72('0xc1')](_0x3ae544[_0x7a72('0x2b')],_0x28074b[_0x7a72('0x2c')]));if(_0x3ae544[_0x7a72('0x2b')][_0x7a72('0x51')]){_0x5b93d9[_0x7a72('0x35')]=_[_0x7a72('0x78')](_0x5b93d9[_0x7a72('0x35')],{'$or':_[_0x7a72('0x50')](_0x5b93d9['attributes'],function(_0xf1d18e){var _0xf828c5={};_0xf828c5[_0xf1d18e]={'$like':'%'+_0x3ae544[_0x7a72('0x2b')]['filter']+'%'};return _0xf828c5;})});}_0x5b93d9=_['merge']({},_0x5b93d9,_0x3ae544[_0x7a72('0xc2')]);return _0x277975[_0x7a72('0xbf')](_0x5b93d9);}})[_0x7a72('0x16')](function(_0x378412){if(_0x378412){_0x413966=_0x378412[_0x7a72('0x20')];if(!_0x3ae544[_0x7a72('0x2b')]['hasOwnProperty']('nolimit')){_0x5b93d9[_0x7a72('0x32')]=qs[_0x7a72('0x32')](_0x3ae544['query'][_0x7a72('0x32')]);_0x5b93d9[_0x7a72('0x11')]=qs[_0x7a72('0x11')](_0x3ae544[_0x7a72('0x2b')]['offset']);}return _0x277975['getTags'](_0x5b93d9);}})[_0x7a72('0x16')](function(_0x2b974a){if(_0x2b974a){return _0x2b974a?{'count':_0x413966,'rows':_0x2b974a}:null;}})[_0x7a72('0x16')](respondWithResult(_0x3b76aa,null))[_0x7a72('0x86')](handleError(_0x3b76aa,null));};exports[_0x7a72('0xc3')]=function(_0x3cc3dc,_0x2fedf5){if(_0x3cc3dc[_0x7a72('0x90')]['id']){delete _0x3cc3dc[_0x7a72('0x90')]['id'];}return db[_0x7a72('0x1e')][_0x7a72('0x25')]({'where':{'id':_0x3cc3dc['params']['id']}})[_0x7a72('0x16')](handleEntityNotFound(_0x2fedf5,null))[_0x7a72('0x16')](function(_0x1835ee){if(_0x1835ee){return _0x1835ee['setTags'](_0x3cc3dc[_0x7a72('0x90')][_0x7a72('0xc4')]||[]);}return null;})[_0x7a72('0x16')](respondWithResult(_0x2fedf5,null))[_0x7a72('0x86')](handleError(_0x2fedf5,null));};exports[_0x7a72('0xc5')]=function(_0x9cbbbf,_0x4c2bb6){var _0x187cdf={'raw':![],'where':{}};var _0x237a82={};var _0x545ab8={'count':0x0,'rows':[]};return db[_0x7a72('0x1e')][_0x7a72('0x25')]({'where':{'id':_0x9cbbbf[_0x7a72('0xb4')]['id']}})[_0x7a72('0x16')](handleEntityNotFound(_0x4c2bb6,null))[_0x7a72('0x16')](function(_0x5d9b71){if(_0x5d9b71){_0x237a82[_0x7a72('0x2a')]=_[_0x7a72('0x1f')](db[_0x7a72('0xc6')][_0x7a72('0xc0')]);_0x237a82[_0x7a72('0x2b')]=_[_0x7a72('0x1f')](_0x9cbbbf[_0x7a72('0x2b')]);_0x237a82['filters']=_[_0x7a72('0x2e')](_0x237a82[_0x7a72('0x2a')],_0x237a82[_0x7a72('0x2b')]);_0x187cdf[_0x7a72('0x2d')]=_[_0x7a72('0x2e')](_0x237a82[_0x7a72('0x2a')],qs[_0x7a72('0x2f')](_0x9cbbbf['query']['fields']));_0x187cdf[_0x7a72('0x2d')]=_0x187cdf[_0x7a72('0x2d')]['length']?_0x187cdf[_0x7a72('0x2d')]:_0x237a82[_0x7a72('0x2a')];if(!_0x9cbbbf[_0x7a72('0x2b')][_0x7a72('0x30')](_0x7a72('0x31'))){_0x187cdf[_0x7a72('0x32')]=qs[_0x7a72('0x32')](_0x9cbbbf[_0x7a72('0x2b')][_0x7a72('0x32')]);_0x187cdf[_0x7a72('0x11')]=qs[_0x7a72('0x11')](_0x9cbbbf[_0x7a72('0x2b')][_0x7a72('0x11')]);}_0x187cdf[_0x7a72('0x33')]=qs[_0x7a72('0x34')](_0x9cbbbf[_0x7a72('0x2b')][_0x7a72('0x34')]);_0x187cdf['where']=qs[_0x7a72('0x2c')](_[_0x7a72('0xc1')](_0x9cbbbf['query'],_0x237a82[_0x7a72('0x2c')]));_0x187cdf[_0x7a72('0x35')][_0x7a72('0xc7')]=_0x5d9b71['id'];if(_0x9cbbbf[_0x7a72('0x2b')][_0x7a72('0x51')]){_0x187cdf[_0x7a72('0x35')]=_[_0x7a72('0x78')](_0x187cdf[_0x7a72('0x35')],{'$or':_['map'](_0x187cdf[_0x7a72('0x2d')],function(_0x27bb30){var _0x33547e={};_0x33547e[_0x27bb30]={'$like':'%'+_0x9cbbbf[_0x7a72('0x2b')]['filter']+'%'};return _0x33547e;})});}_0x187cdf=_[_0x7a72('0x78')]({},_0x187cdf,_0x9cbbbf['options']);return db['CmHopper'][_0x7a72('0x13')]({'where':_0x187cdf['where']})['then'](function(_0x3b03b4){_0x545ab8[_0x7a72('0x13')]=_0x3b03b4;if(_0x9cbbbf[_0x7a72('0x2b')][_0x7a72('0xc8')]){_0x187cdf[_0x7a72('0xc9')]=[{'all':!![]}];}return db['CmHopper'][_0x7a72('0x8b')](_0x187cdf);})[_0x7a72('0x16')](function(_0x45f715){_0x545ab8[_0x7a72('0x85')]=_0x45f715;return _0x545ab8;});}})['then'](respondWithFilteredResult(_0x4c2bb6,_0x187cdf))['catch'](handleError(_0x4c2bb6,null));};exports[_0x7a72('0xca')]=function(_0x47d9e4,_0x43a303){var _0x2cee93={'raw':!![],'where':{}};var _0x18cf3a={};var _0x2f49aa={'count':0x0,'rows':[]};return db['CmContact']['findOne']({'where':{'id':_0x47d9e4[_0x7a72('0xb4')]['id']}})[_0x7a72('0x16')](handleEntityNotFound(_0x43a303,null))[_0x7a72('0x16')](function(_0x54a122){if(_0x54a122){_0x18cf3a[_0x7a72('0x2a')]=_['keys'](db['CmHopperHistory'][_0x7a72('0xc0')]);_0x18cf3a[_0x7a72('0x2b')]=_['keys'](_0x47d9e4[_0x7a72('0x2b')]);_0x18cf3a[_0x7a72('0x2c')]=_[_0x7a72('0x2e')](_0x18cf3a[_0x7a72('0x2a')],_0x18cf3a[_0x7a72('0x2b')]);_0x2cee93['attributes']=_[_0x7a72('0x2e')](_0x18cf3a[_0x7a72('0x2a')],qs['fields'](_0x47d9e4[_0x7a72('0x2b')][_0x7a72('0x2f')]));_0x2cee93['attributes']=_0x2cee93[_0x7a72('0x2d')][_0x7a72('0x20')]?_0x2cee93[_0x7a72('0x2d')]:_0x18cf3a[_0x7a72('0x2a')];if(!_0x47d9e4['query'][_0x7a72('0x30')](_0x7a72('0x31'))){_0x2cee93[_0x7a72('0x32')]=qs[_0x7a72('0x32')](_0x47d9e4[_0x7a72('0x2b')][_0x7a72('0x32')]);_0x2cee93[_0x7a72('0x11')]=qs[_0x7a72('0x11')](_0x47d9e4['query'][_0x7a72('0x11')]);}_0x2cee93[_0x7a72('0x33')]=qs[_0x7a72('0x34')](_0x47d9e4[_0x7a72('0x2b')][_0x7a72('0x34')]);_0x2cee93[_0x7a72('0x35')]=qs[_0x7a72('0x2c')](_[_0x7a72('0xc1')](_0x47d9e4['query'],_0x18cf3a['filters']));_0x2cee93[_0x7a72('0x35')]['ContactId']=_0x54a122['id'];if(_0x47d9e4['query'][_0x7a72('0x51')]){_0x2cee93[_0x7a72('0x35')]=_[_0x7a72('0x78')](_0x2cee93[_0x7a72('0x35')],{'$or':_[_0x7a72('0x50')](_0x2cee93[_0x7a72('0x2d')],function(_0x27e683){var _0x198c96={};_0x198c96[_0x27e683]={'$like':'%'+_0x47d9e4[_0x7a72('0x2b')]['filter']+'%'};return _0x198c96;})});}_0x2cee93=_['merge']({},_0x2cee93,_0x47d9e4['options']);return db['CmHopperHistory'][_0x7a72('0x13')]({'where':_0x2cee93[_0x7a72('0x35')]})['then'](function(_0x25e933){_0x2f49aa[_0x7a72('0x13')]=_0x25e933;if(_0x47d9e4[_0x7a72('0x2b')][_0x7a72('0xc8')]){_0x2cee93[_0x7a72('0xc9')]=[{'all':!![]}];}return db['CmHopperHistory'][_0x7a72('0x8b')](_0x2cee93);})[_0x7a72('0x16')](function(_0x52cfff){_0x2f49aa['rows']=_0x52cfff;return _0x2f49aa;});}})[_0x7a72('0x16')](respondWithFilteredResult(_0x43a303,_0x2cee93))[_0x7a72('0x86')](handleError(_0x43a303,null));};exports[_0x7a72('0xcb')]=function(_0x1173c4,_0x239b19){var _0xeb13dc={'raw':!![],'where':{}};var _0x54f01c={};var _0x42b8d7={'count':0x0,'rows':[]};return db[_0x7a72('0x1e')][_0x7a72('0x25')]({'where':{'id':_0x1173c4[_0x7a72('0xb4')]['id']}})[_0x7a72('0x16')](handleEntityNotFound(_0x239b19,null))[_0x7a72('0x16')](function(_0x351738){if(_0x351738){_0x54f01c['model']=_[_0x7a72('0x1f')](db[_0x7a72('0xa2')]['rawAttributes']);_0x54f01c[_0x7a72('0x2b')]=_['keys'](_0x1173c4[_0x7a72('0x2b')]);_0x54f01c['filters']=_[_0x7a72('0x2e')](_0x54f01c[_0x7a72('0x2a')],_0x54f01c[_0x7a72('0x2b')]);_0xeb13dc[_0x7a72('0x2d')]=_[_0x7a72('0x2e')](_0x54f01c[_0x7a72('0x2a')],qs['fields'](_0x1173c4['query']['fields']));_0xeb13dc[_0x7a72('0x2d')]=_0xeb13dc[_0x7a72('0x2d')]['length']?_0xeb13dc[_0x7a72('0x2d')]:_0x54f01c[_0x7a72('0x2a')];if(!_0x1173c4[_0x7a72('0x2b')]['hasOwnProperty'](_0x7a72('0x31'))){_0xeb13dc[_0x7a72('0x32')]=qs[_0x7a72('0x32')](_0x1173c4[_0x7a72('0x2b')][_0x7a72('0x32')]);_0xeb13dc['offset']=qs[_0x7a72('0x11')](_0x1173c4[_0x7a72('0x2b')][_0x7a72('0x11')]);}_0xeb13dc[_0x7a72('0x33')]=qs['sort'](_0x1173c4[_0x7a72('0x2b')][_0x7a72('0x34')]);_0xeb13dc[_0x7a72('0x35')]=qs[_0x7a72('0x2c')](_[_0x7a72('0xc1')](_0x1173c4[_0x7a72('0x2b')],_0x54f01c['filters']));_0xeb13dc['where']['ContactId']=_0x351738['id'];if(_0x1173c4['query'][_0x7a72('0x51')]){_0xeb13dc[_0x7a72('0x35')]=_[_0x7a72('0x78')](_0xeb13dc['where'],{'$or':_[_0x7a72('0x50')](_0xeb13dc[_0x7a72('0x2d')],function(_0xa8efe2){var _0x1d0386={};_0x1d0386[_0xa8efe2]={'$like':'%'+_0x1173c4[_0x7a72('0x2b')][_0x7a72('0x51')]+'%'};return _0x1d0386;})});}_0xeb13dc=_['merge']({},_0xeb13dc,_0x1173c4[_0x7a72('0xc2')]);return db[_0x7a72('0xa2')][_0x7a72('0x13')]({'where':_0xeb13dc[_0x7a72('0x35')]})[_0x7a72('0x16')](function(_0x1abba4){_0x42b8d7[_0x7a72('0x13')]=_0x1abba4;if(_0x1173c4[_0x7a72('0x2b')]['includeAll']){_0xeb13dc[_0x7a72('0xc9')]=[{'all':!![]}];}return db[_0x7a72('0xa2')][_0x7a72('0x8b')](_0xeb13dc);})[_0x7a72('0x16')](function(_0x2aba81){_0x42b8d7[_0x7a72('0x85')]=_0x2aba81;return _0x42b8d7;});}})[_0x7a72('0x16')](respondWithFilteredResult(_0x239b19,_0xeb13dc))['catch'](handleError(_0x239b19,null));};exports['getJscriptySessions']=function(_0x525b89,_0x461415){var _0xabde74={'raw':!![],'where':{}};var _0x27f7fd={};var _0x530ea0={'count':0x0,'rows':[]};return db['CmContact']['findOne']({'where':{'id':_0x525b89[_0x7a72('0xb4')]['id']}})[_0x7a72('0x16')](handleEntityNotFound(_0x461415,null))['then'](function(_0x4e227f){if(_0x4e227f){_0x27f7fd['model']=_[_0x7a72('0x1f')](db[_0x7a72('0xab')]['rawAttributes']);_0x27f7fd[_0x7a72('0x2b')]=_[_0x7a72('0x1f')](_0x525b89[_0x7a72('0x2b')]);_0x27f7fd[_0x7a72('0x2c')]=_[_0x7a72('0x2e')](_0x27f7fd[_0x7a72('0x2a')],_0x27f7fd['query']);_0xabde74['attributes']=_[_0x7a72('0x2e')](_0x27f7fd[_0x7a72('0x2a')],qs[_0x7a72('0x2f')](_0x525b89[_0x7a72('0x2b')]['fields']));_0xabde74[_0x7a72('0x2d')]=_0xabde74[_0x7a72('0x2d')][_0x7a72('0x20')]?_0xabde74[_0x7a72('0x2d')]:_0x27f7fd['model'];if(!_0x525b89[_0x7a72('0x2b')]['hasOwnProperty'](_0x7a72('0x31'))){_0xabde74['limit']=qs[_0x7a72('0x32')](_0x525b89[_0x7a72('0x2b')][_0x7a72('0x32')]);_0xabde74[_0x7a72('0x11')]=qs[_0x7a72('0x11')](_0x525b89[_0x7a72('0x2b')][_0x7a72('0x11')]);}_0xabde74[_0x7a72('0x33')]=qs[_0x7a72('0x34')](_0x525b89[_0x7a72('0x2b')]['sort']);_0xabde74['where']=qs[_0x7a72('0x2c')](_['pick'](_0x525b89['query'],_0x27f7fd[_0x7a72('0x2c')]));_0xabde74['where'][_0x7a72('0xc7')]=_0x4e227f['id'];if(_0x525b89[_0x7a72('0x2b')][_0x7a72('0x51')]){_0xabde74[_0x7a72('0x35')]=_[_0x7a72('0x78')](_0xabde74[_0x7a72('0x35')],{'$or':_[_0x7a72('0x50')](_0xabde74[_0x7a72('0x2d')],function(_0x48c6a8){var _0x571848={};_0x571848[_0x48c6a8]={'$like':'%'+_0x525b89['query'][_0x7a72('0x51')]+'%'};return _0x571848;})});}_0xabde74=_['merge']({},_0xabde74,_0x525b89[_0x7a72('0xc2')]);return db[_0x7a72('0xab')][_0x7a72('0x13')]({'where':_0xabde74[_0x7a72('0x35')]})['then'](function(_0x2a5fed){_0x530ea0[_0x7a72('0x13')]=_0x2a5fed;if(_0x525b89['query'][_0x7a72('0xc8')]){_0xabde74[_0x7a72('0xc9')]=[{'all':!![]}];}return db[_0x7a72('0xab')][_0x7a72('0x8b')](_0xabde74);})[_0x7a72('0x16')](function(_0x4dfe3d){_0x530ea0[_0x7a72('0x85')]=_0x4dfe3d;return _0x530ea0;});}})[_0x7a72('0x16')](respondWithFilteredResult(_0x461415,_0xabde74))[_0x7a72('0x86')](handleError(_0x461415,null));};exports[_0x7a72('0xcc')]=function(_0x5940f3,_0x73d72c){try{if(!_0x5940f3[_0x7a72('0x90')]['ListId']){throw new Error(_0x7a72('0xcd'));}if(!_0x5940f3[_0x7a72('0x90')][_0x7a72('0xce')]){throw new Error(_0x7a72('0xcf'));}if(!_0x5940f3[_0x7a72('0x90')][_0x7a72('0xd0')]){throw new Error(_0x7a72('0xd1'));}if(!_0x5940f3[_0x7a72('0x90')]['socket_timestamp']){throw new Error('Unable\x20to\x20synchronize\x20socket,\x20no\x20timestamp\x20passed');}var _0xf2c0a=_0x5940f3['body'][_0x7a72('0xce')][_0x7a72('0x45')](',');var _0x1777e1=_0x5940f3[_0x7a72('0x90')]['binding_values'][_0x7a72('0x45')](',');if(!_0xf2c0a[_0x7a72('0x20')]||!_0x1777e1[_0x7a72('0x20')]||_0xf2c0a[_0x7a72('0x20')]!==_0x1777e1[_0x7a72('0x20')]){throw new Error(_0x7a72('0xd2'));}_0x5940f3['body'][_0x7a72('0x2f')]=_[_0x7a72('0xd3')](_0xf2c0a,_0x1777e1);if(!_0x5940f3[_0x7a72('0x90')]['fields'][_0x7a72('0xbe')]){throw new Error(_0x7a72('0xd4'));}if(!_0x5940f3[_0x7a72('0x90')][_0x7a72('0x2f')][_0x7a72('0xd5')]){throw new Error(_0x7a72('0xd6'));}var _0x507161=path['join'](config[_0x7a72('0xd7')],_0x7a72('0xd8'),_0x5940f3[_0x7a72('0xd9')][_0x7a72('0xda')]);fs[_0x7a72('0xdb')](_0x507161,parseInt(_0x7a72('0xdc'),0x8));var _0x10e1aa=require(_0x7a72('0xdd'))[_0x7a72('0xde')](path[_0x7a72('0x93')](__dirname,_0x7a72('0xdf')),[_0x507161,_0x5940f3[_0x7a72('0x90')]['binding_keys'],_0x5940f3['body'][_0x7a72('0xd0')],_0x5940f3[_0x7a72('0x90')][_0x7a72('0x56')],_0x5940f3['body'][_0x7a72('0xe0')],_0x5940f3['body']['duplicates'],_0x5940f3[_0x7a72('0x90')][_0x7a72('0xe1')]]);return _0x73d72c['status'](0xc8)[_0x7a72('0x10')]({'message':_0x7a72('0xe2'),'pid':_0x10e1aa[_0x7a72('0xe3')]});}catch(_0x43646d){return _0x73d72c[_0x7a72('0xf')](0x1f4)[_0x7a72('0x1c')](_0x43646d);}};exports[_0x7a72('0xe4')]=function(_0x4a75b9,_0x1420de){var _0x1e51ce=fs[_0x7a72('0xe5')](_0x4a75b9[_0x7a72('0xd9')][_0x7a72('0x3')]);Papa['parse'](_0x1e51ce,{'header':!![],'skipEmptyLines':!![],'preview':0x1,'complete':function(_0x8ab507){return _0x1420de['status'](0xc8)[_0x7a72('0x10')]({'file':_0x4a75b9['file'],'fields':_0x8ab507[_0x7a72('0xe6')][_0x7a72('0x2f')]});}});};exports[_0x7a72('0xe7')]=function(_0x307a40,_0x1136f2){return db[_0x7a72('0x72')][_0x7a72('0x8b')]({'raw':!![],'attributes':['id'],'where':{'role':_0x7a72('0xe8')}})['then'](function(_0x27919c){var _0x163157=![];if(!_0x307a40[_0x7a72('0x90')][_0x7a72('0x56')]){throw new Error(_0x7a72('0xcd'));}if(!_0x307a40[_0x7a72('0x90')][_0x7a72('0xe9')][_0x7a72('0xbe')]){throw new Error(_0x7a72('0xd4'));}if(!_0x307a40[_0x7a72('0x90')][_0x7a72('0xe9')]['firstName']){throw new Error(_0x7a72('0xd6'));}if(!_0x307a40[_0x7a72('0x90')][_0x7a72('0xe1')]){throw new Error(_0x7a72('0xea'));}var _0x4729d9=require(_0x7a72('0xdd'))[_0x7a72('0xde')](path[_0x7a72('0x93')](__dirname,_0x7a72('0xeb')),[_0x307a40['params']['id'],JSON[_0x7a72('0xec')](_0x307a40['body']),JSON[_0x7a72('0xec')](_0x27919c)]);_0x4729d9['on'](_0x7a72('0xed'),function(){_0x163157=!![];return _0x1136f2[_0x7a72('0xf')](0xc8)[_0x7a72('0x10')]({'message':_0x7a72('0xee'),'pid':_0x4729d9[_0x7a72('0xe3')]});});_0x4729d9['on'](_0x7a72('0xef'),function(_0x4e2fac){if(_0x4e2fac&&!_0x163157){return _0x1136f2[_0x7a72('0xf')](0x1f4)[_0x7a72('0x10')]({'message':_0x7a72('0xf0'),'pid':_0x4729d9[_0x7a72('0xe3')]});}});})[_0x7a72('0x86')](handleError(_0x1136f2,null));};exports[_0x7a72('0xf1')]=function(_0x22a542,_0x48e776){var _0x334611=[_0x7a72('0xf2'),'chat',_0x7a72('0xf3'),_0x7a72('0xf4'),_0x7a72('0xf5'),_0x7a72('0xf6'),_0x7a72('0xf7')];var _0x21b196={'offset':0x0,'order':qs[_0x7a72('0x34')]('-createdAt')},_0x2ec529={'count':0x0,'rows':[]};Promise[_0x7a72('0x6e')]()[_0x7a72('0x16')](function(){if(_0x22a542[_0x7a72('0x2b')]['channel']){if(!_['includes'](_0x334611,_0x22a542[_0x7a72('0x2b')][_0x7a72('0xf8')][_0x7a72('0xf9')]())){throw new Error('Invalid\x20channel');}_0x334611=[_0x22a542[_0x7a72('0x2b')][_0x7a72('0xf8')]['toLowerCase']()];}if(_0x22a542[_0x7a72('0x2b')]['range']){try{var _0x5c17c7=JSON[_0x7a72('0xfa')](_0x22a542[_0x7a72('0x2b')][_0x7a72('0xfb')]);if(!moment(_0x5c17c7[_0x7a72('0x38')])['isValid']()){throw new Error(_0x7a72('0xfc'));}if(!moment(_0x5c17c7['to'])[_0x7a72('0xfd')]()){throw new Error(_0x7a72('0xfe'));}}catch(_0x59be5e){throw new Error(_0x7a72('0xff'));}}if(!_0x22a542[_0x7a72('0x2b')][_0x7a72('0x30')](_0x7a72('0x31'))){_0x21b196[_0x7a72('0x32')]=qs[_0x7a72('0x32')](_0x22a542['query'][_0x7a72('0x32')]||0xa);_0x21b196[_0x7a72('0x11')]=qs[_0x7a72('0x11')](_0x22a542[_0x7a72('0x2b')][_0x7a72('0x11')]);}var _0x264e62=_0x334611[_0x7a72('0x50')](function(_0x1ce339){if(_0x1ce339===_0x7a72('0xf7')){var _0x597fbc={'attributes':['id',_0x7a72('0x100'),_0x7a72('0x29'),'source',_0x7a72('0x101'),_0x7a72('0x102'),_0x7a72('0x103'),_0x7a72('0x104'),_0x7a72('0x105'),_0x7a72('0x106'),_0x7a72('0x107'),_0x7a72('0x108'),_0x7a72('0x109'),_0x7a72('0x10a'),_0x7a72('0x10b')],'where':{'ContactId':_0x22a542[_0x7a72('0xb4')]['id']},'include':[{'model':db[_0x7a72('0x72')],'as':_0x7a72('0x72'),'attributes':['id',_0x7a72('0x1b'),'fullname',_0x7a72('0x8d')]}],'order':[[_0x7a72('0x107'),_0x7a72('0x10c')]]};if(_0x22a542[_0x7a72('0x2b')][_0x7a72('0xfb')]){_0x597fbc[_0x7a72('0x35')][_0x7a72('0x107')]={'$gte':_0x5c17c7[_0x7a72('0x38')],'$lte':_0x5c17c7['to']};}return db[_0x7a72('0xa5')]['findAndCountAll'](_0x597fbc)[_0x7a72('0x16')](function(_0x54d4a5){_0x2ec529['count']+=_0x54d4a5['count'];return _[_0x7a72('0x50')](_0x54d4a5[_0x7a72('0x85')],function(_0x3808e2){var _0x1e93c1=_0x3808e2[_0x7a72('0x91')]({'plain':!![]});_0x1e93c1[_0x7a72('0xf8')]=_0x1ce339;if(_0x1e93c1[_0x7a72('0x72')]){_0x1e93c1[_0x7a72('0x72')]={'id':_0x1e93c1['User']['id'],'name':_0x1e93c1[_0x7a72('0x72')][_0x7a72('0x1b')],'fullname':_0x1e93c1[_0x7a72('0x72')][_0x7a72('0x10d')],'alias':_0x1e93c1[_0x7a72('0x72')][_0x7a72('0x8d')]};}return _0x1e93c1;});});}else{var _0x549a25=_['startCase'](_0x1ce339)+(_0x1ce339===_0x7a72('0x10e')?_0x7a72('0x10f'):'Account');var _0x224260={'attributes':['id',_0x7a72('0x110'),_0x7a72('0x111'),_0x7a72('0x107'),_0x7a72('0x106'),_0x7a72('0x112'),'secondDisposition',_0x7a72('0x113'),_0x7a72('0x10b'),_0x549a25+'Id'],'where':{'ContactId':_0x22a542['params']['id']},'include':[{'model':db[_0x549a25],'as':_0x7a72('0x114'),'attributes':['id',_0x7a72('0x1b'),'key']},{'model':db[_0x7a72('0x72')],'as':_0x7a72('0x115'),'attributes':['id',_0x7a72('0x1b'),'fullname']},{'model':db[_0x7a72('0x43')],'as':_0x7a72('0x84'),'attributes':['id',_0x7a72('0x1b'),'color'],'through':{'attributes':[]}}],'order':[['createdAt',_0x7a72('0x10c')]]};if(_0x22a542[_0x7a72('0x2b')][_0x7a72('0xfb')]){_0x224260[_0x7a72('0x35')]['createdAt']={'$gte':_0x5c17c7[_0x7a72('0x38')],'$lte':_0x5c17c7['to']};}switch(_0x1ce339){case _0x7a72('0x10e'):_0x224260[_0x7a72('0x2d')][_0x7a72('0x23')]('browserName',_0x7a72('0x116'),_0x7a72('0x117'),'deviceModel',_0x7a72('0x118'),'ratingMessage',_0x7a72('0x119'),_0x7a72('0x11a'),_0x7a72('0x11b'));break;case _0x7a72('0xf2'):_0x224260['attributes'][_0x7a72('0x23')](_0x7a72('0x11c'),'substatus');break;case _0x7a72('0xf4'):_0x224260[_0x7a72('0x2d')][_0x7a72('0x23')](_0x7a72('0x11d'),_0x7a72('0x11e'));break;}return db[_[_0x7a72('0x11f')](_0x1ce339)+_0x7a72('0x120')][_0x7a72('0x121')](_0x224260)[_0x7a72('0x16')](function(_0x3e2597){_0x2ec529[_0x7a72('0x13')]+=_0x3e2597[_0x7a72('0x13')];return _[_0x7a72('0x50')](_0x3e2597['rows'],function(_0x20a559){var _0x3ee755=_0x20a559[_0x7a72('0x91')]({'plain':!![]});_0x3ee755[_0x7a72('0xf8')]=_0x1ce339;if(_0x3ee755[_0x7a72('0x115')]){_0x3ee755[_0x7a72('0x115')]={'id':_0x3ee755[_0x7a72('0x115')]['id'],'name':_0x3ee755['Owner'][_0x7a72('0x1b')],'fullname':_0x3ee755[_0x7a72('0x115')][_0x7a72('0x10d')]};}return _0x3ee755;});});}});return Promise[_0x7a72('0x27')](_0x264e62);})[_0x7a72('0x16')](function(_0x2c6212){return _(_0x2c6212)[_0x7a72('0x122')]()['sortBy'](_0x7a72('0x107'))[_0x7a72('0x123')]()['value']();})['then'](function(_0x1798fd){_0x2ec529['rows']=_0x21b196['limit']?_0x1798fd[_0x7a72('0x124')](_0x21b196['offset'],_0x21b196[_0x7a72('0x11')]+_0x21b196[_0x7a72('0x32')]):_0x1798fd;return _0x2ec529;})['then'](respondWithFilteredResult(_0x48e776,_0x21b196))['catch'](handleError(_0x48e776,null));};