abbc18562554b1be80d47c288d384ee3cb989f20
[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 _0x5bf6=['../../config/license/hardware','../../config/logger','api','../../config/utils','../../config/environment','../../config/license/util','../../mysqldb','redis','defaults','socket.io-emitter','./cmContact.socket','register','status','end','json','offset','limit','set','Content-Range','apply','reject','save','update','then','sendStatus','name','send','index','CmContact','describe','length','startsWith','cf_','push','CmCustomField','findOne','all','model','keys','query','filters','intersection','attributes','fields','hasOwnProperty','order','sort','where','pick','select','field','from','tools_tags','left_join','cm_user_has_contacts','uc.CmContactId\x20=\x20c.id','cm_contact_has_tags','t.id\x20=\x20ct.TagId','c.deletedAt\x20IS\x20NULL','expr','parseSearch','search','sqlOperator','conditions','Tag','value','split','map','forEach','CONCAT(\x27,\x27,\x20`TagIds`,\x20\x27,\x27)\x20LIKE\x20?','User','and','uc.UserId\x20=\x20?','fieldType','datetime','castTo','DATE','buildExpression','type','text','start','filter','Contact','isEmpty','c.ListId\x20IN\x20?','concat','tag','replace','MATCH\x20(c.firstName,\x20c.lastName,\x20c.phone,\x20c.mobile,\x20c.fax,\x20c.email)\x20AGAINST\x20(?\x20IN\x20BOOLEAN\x20MODE)','c.id\x20LIKE\x20?','c.phone\x20LIKE\x20?','c.fax\x20LIKE\x20?','isEmail','c.email\x20LIKE\x20?','c.firstName\x20LIKE\x20?','c.lastName\x20LIKE\x20?','Sequelize','QueryTypes','SELECT','clone','c.id','t.id\x20IN\x20?','resolve','user','agent','some','getLists','c.ListId\x20IS\x20NULL','role','ListId','sequelize','toString','count','keyBy','c.firstName','c.lastName','c.phone','c.mobile','c.email','c.ListId','c.deletedAt','c.CompanyId','GROUP_CONCAT(DISTINCT\x20t.id)','TagIds','Tags','rows','catch','destroy','find','tags','displayName','columnName','alias','custom','merge','body','findAll','get','isArray','info','[CmContact][merge]\x20to\x20%s\x20from\x20%s','CmHopper','[CmContact][merge][destroy][CmHopper],\x20%s','ChatInteraction','ChatMessage','ChatOfflineMessage','MailInteraction','MailMessage','SmsInteraction','SmsMessage','FaxInteraction','CmHopperHistory','ReportAgentPreview','VoiceCallReport','ChatQueueReport','FaxQueueReport','MailQueueReport','SmsQueueReport','JscriptySessionReport','create','bulkCreate','each','duplicates','$or','findOrCreate','params','color','$and','omit','cf_%d','pickBy','table','setFields','id\x20=\x20?','values','phone','getTags','rawAttributes','options','nolimit','setTags','ids','getHoppers','ContactId','includeAll','include','getHopperHistories','getHopperFinals','CmHopperFinal','getJscriptySessions','No\x20ListId\x20specified','binding_keys','No\x20association\x20keys\x20specified!','binding_values','No\x20association\x20values\x20specified!','Incorrect\x20binding\x20parameters\x20passed!','zipObject','firstName','join','root','filename','chmodSync','0777','child_process','fork','File\x20uploaded\x20correctly!','pid','upload','createReadStream','file','parse','meta','import','binding','socket_timestamp','stringify','start\x20child\x20process\x20correctly!','exit','error\x20child\x20process','getJourney','mail','fax','whatsapp','voice','channel','includes','Invalid\x20channel','toLowerCase','range','isValid','Invalid\x20date\x20for\x20range\x20from\x20filter','Invalid\x20date\x20for\x20range\x20to\x20filter','uniqueid','source','callerid','duration','note','userDisposition','userSecondDisposition','userThirdDisposition','fullname','createdAt','DESC','findAndCountAll','startCase','chat','Website','Account','closed','closedAt','disposition','secondDisposition','thirdDisposition','UserId','key','browserName','customerIp','deviceModel','osName','ratingType','ratingValue','referer','subject','substatus','openchannel','externalUrl','threadId','Owner','flatten','sortBy','html-pdf','eml-format','rimraf','zip-dir','fast-json-patch','request-promise','moment','mustache','util','path','sox','to-csv','lodash','squel','jsforce','desk.js','querystring','papaparse','../../components/auth/service','../../components/parsers/advancedSearch'];(function(_0x33d38e,_0x52ca70){var _0x45712f=function(_0x323f42){while(--_0x323f42){_0x33d38e['push'](_0x33d38e['shift']());}};_0x45712f(++_0x52ca70);}(_0x5bf6,0x10e));var _0x65bf=function(_0x47e549,_0x2e53d6){_0x47e549=_0x47e549-0x0;var _0x251374=_0x5bf6[_0x47e549];return _0x251374;};'use strict';var pdf=require(_0x65bf('0x0'));var emlformat=require(_0x65bf('0x1'));var rimraf=require(_0x65bf('0x2'));var zipdir=require(_0x65bf('0x3'));var jsonpatch=require(_0x65bf('0x4'));var rp=require(_0x65bf('0x5'));var moment=require(_0x65bf('0x6'));var BPromise=require('bluebird');var Mustache=require(_0x65bf('0x7'));var util=require(_0x65bf('0x8'));var path=require(_0x65bf('0x9'));var sox=require(_0x65bf('0xa'));var csv=require(_0x65bf('0xb'));var ejs=require('ejs');var fs=require('fs');var _=require(_0x65bf('0xc'));var squel=require(_0x65bf('0xd'));var crypto=require('crypto');var jsforce=require(_0x65bf('0xe'));var deskjs=require(_0x65bf('0xf'));var toCsv=require('to-csv');var querystring=require(_0x65bf('0x10'));var Papa=require(_0x65bf('0x11'));var Redis=require('ioredis');var authService=require(_0x65bf('0x12'));var qs=require('../../components/parsers/qs');var as=require(_0x65bf('0x13'));var hardwareService=require(_0x65bf('0x14'));var logger=require(_0x65bf('0x15'))(_0x65bf('0x16'));var utils=require(_0x65bf('0x17'));var config=require(_0x65bf('0x18'));var licenseUtil=require(_0x65bf('0x19'));var db=require(_0x65bf('0x1a'))['db'];config[_0x65bf('0x1b')]=_[_0x65bf('0x1c')](config['redis'],{'host':'localhost','port':0x18eb});var socket=require(_0x65bf('0x1d'))(new Redis(config['redis']));require(_0x65bf('0x1e'))[_0x65bf('0x1f')](socket);function respondWithStatusCode(_0x3d0f94,_0x206b36){_0x206b36=_0x206b36||0xcc;return function(_0x2e798b){if(_0x2e798b){return _0x3d0f94['sendStatus'](_0x206b36);}return _0x3d0f94[_0x65bf('0x20')](_0x206b36)[_0x65bf('0x21')]();};}function respondWithResult(_0x1e50c5,_0x66415f){_0x66415f=_0x66415f||0xc8;return function(_0x314f35){if(_0x314f35){return _0x1e50c5['status'](_0x66415f)[_0x65bf('0x22')](_0x314f35);}};}function respondWithFilteredResult(_0x252455,_0x53ed70){return function(_0x147841){if(_0x147841){var _0x4ba745=_0x147841['count'],_0x1c48e9=_0x53ed70[_0x65bf('0x23')],_0x3a0bca=_0x53ed70[_0x65bf('0x23')]+_0x53ed70[_0x65bf('0x24')],_0xe7c358;if(_0x3a0bca>=_0x4ba745){_0x3a0bca=_0x4ba745;_0xe7c358=0xc8;}else{_0xe7c358=0xce;}_0x252455[_0x65bf('0x20')](_0xe7c358);return _0x252455[_0x65bf('0x25')](_0x65bf('0x26'),_0x1c48e9+'-'+_0x3a0bca+'/'+_0x4ba745)[_0x65bf('0x22')](_0x147841);}return null;};}function patchUpdates(_0x44c0ae){return function(_0x17c23b){try{jsonpatch[_0x65bf('0x27')](_0x17c23b,_0x44c0ae,!![]);}catch(_0x2dd960){return BPromise[_0x65bf('0x28')](_0x2dd960);}return _0x17c23b[_0x65bf('0x29')]();};}function saveUpdates(_0xbb6ea3,_0x3fe5f6){return function(_0x3ffe10){if(_0x3ffe10){return _0x3ffe10[_0x65bf('0x2a')](_0xbb6ea3)[_0x65bf('0x2b')](function(_0x156b56){return _0x156b56;});}return null;};}function removeEntity(_0x21b04e,_0x2b4813){return function(_0x4c0dd2){if(_0x4c0dd2){return _0x4c0dd2['destroy']()['then'](function(){_0x21b04e[_0x65bf('0x20')](0xcc)['end']();});}};}function handleEntityNotFound(_0x3af5ba,_0x446f1b){return function(_0x408d9e){if(!_0x408d9e){_0x3af5ba[_0x65bf('0x2c')](0x194);}return _0x408d9e;};}function handleError(_0x348160,_0x488aad){_0x488aad=_0x488aad||0x1f4;return function(_0x199313){logger['error'](_0x199313['stack']);if(_0x199313['name']){delete _0x199313[_0x65bf('0x2d')];}_0x348160[_0x65bf('0x20')](_0x488aad)[_0x65bf('0x2e')](_0x199313);};}exports[_0x65bf('0x2f')]=function(_0x32b4b6,_0x2f6167){var _0x493c57={},_0x2ceac0={},_0xd43e29={'count':0x0,'rows':[]};return db[_0x65bf('0x30')][_0x65bf('0x31')]()[_0x65bf('0x2b')](function(_0x2c1db3){var _0x4e7878=[];for(var _0x5a224e=0x0;_0x5a224e<Object['keys'](_0x2c1db3)[_0x65bf('0x32')];_0x5a224e++){var _0x303d44=Object['keys'](_0x2c1db3)[_0x5a224e];if(_[_0x65bf('0x33')](_0x303d44,_0x65bf('0x34'))){_0x4e7878[_0x65bf('0x35')](db[_0x65bf('0x36')][_0x65bf('0x37')]({'where':{'id':_['trimStart'](_0x303d44,_0x65bf('0x34'))},'raw':!![]}));}}return BPromise[_0x65bf('0x38')](_0x4e7878)[_0x65bf('0x2b')](function(_0x5ae71f){for(var _0x1650aa=0x0;_0x1650aa<_0x5ae71f[_0x65bf('0x32')];_0x1650aa++){if(_0x5ae71f[_0x1650aa]){var _0x2b496d=_0x65bf('0x34')+_0x5ae71f[_0x1650aa]['id'];var _0x4f98b1=_0x2c1db3[_0x2b496d];_0x4f98b1['fieldType']=_0x5ae71f[_0x1650aa]['type'];}}return _0x2c1db3;});})['then'](function(_0x2dd670){_0x2ceac0[_0x65bf('0x39')]=_[_0x65bf('0x3a')](_0x2dd670);_0x2ceac0[_0x65bf('0x3b')]=_[_0x65bf('0x3a')](_0x32b4b6[_0x65bf('0x3b')]);_0x2ceac0[_0x65bf('0x3c')]=_[_0x65bf('0x3d')](_0x2ceac0[_0x65bf('0x39')],_0x2ceac0[_0x65bf('0x3b')]);_0x493c57[_0x65bf('0x3e')]=_[_0x65bf('0x3d')](_0x2ceac0[_0x65bf('0x39')],qs['fields'](_0x32b4b6[_0x65bf('0x3b')][_0x65bf('0x3f')]));_0x493c57[_0x65bf('0x3e')]=_0x493c57[_0x65bf('0x3e')][_0x65bf('0x32')]?_0x493c57[_0x65bf('0x3e')]:_0x2ceac0[_0x65bf('0x39')];if(!_0x32b4b6[_0x65bf('0x3b')][_0x65bf('0x40')]('nolimit')){_0x493c57[_0x65bf('0x24')]=qs[_0x65bf('0x24')](_0x32b4b6[_0x65bf('0x3b')]['limit']);_0x493c57[_0x65bf('0x23')]=qs[_0x65bf('0x23')](_0x32b4b6[_0x65bf('0x3b')][_0x65bf('0x23')]);}_0x493c57[_0x65bf('0x41')]=qs[_0x65bf('0x42')](_0x32b4b6['query'][_0x65bf('0x42')]);_0x493c57[_0x65bf('0x43')]=qs[_0x65bf('0x3c')](_[_0x65bf('0x44')](_0x32b4b6[_0x65bf('0x3b')],_0x2ceac0[_0x65bf('0x3c')]),_0x2dd670);var _0x42dfe9=[];var _0x42c9bd=squel[_0x65bf('0x45')]()['field']('id')[_0x65bf('0x46')](_0x65bf('0x2d'))[_0x65bf('0x46')]('color')[_0x65bf('0x47')](_0x65bf('0x48'));var _0x2984f9=squel[_0x65bf('0x45')]()[_0x65bf('0x47')]('cm_contacts','c')[_0x65bf('0x49')](_0x65bf('0x4a'),'uc',_0x65bf('0x4b'))[_0x65bf('0x49')](_0x65bf('0x4c'),'ct','ct.CmContactId\x20=\x20c.id')[_0x65bf('0x49')](_0x65bf('0x48'),'t',_0x65bf('0x4d'))[_0x65bf('0x43')](_0x65bf('0x4e'));var _0x1bad76=squel[_0x65bf('0x4f')]();var _0x3d3317=[];var _0xd18ff0=squel[_0x65bf('0x4f')]();var _0xf78ccd;if(_0x32b4b6[_0x65bf('0x3b')]['search']){_0xf78ccd=as[_0x65bf('0x50')](_0x32b4b6[_0x65bf('0x3b')][_0x65bf('0x51')]);var _0x3a3c20=_0xf78ccd[_0x65bf('0x52')];for(var _0x48eb8b=0x0;_0x48eb8b<_0xf78ccd[_0x65bf('0x53')][_0x65bf('0x32')];_0x48eb8b++){var _0x3f1e6f=_0xf78ccd[_0x65bf('0x53')][_0x48eb8b];var _0x5eb9a5='c';var _0x542ec9=_(_0x2dd670)[_0x65bf('0x3a')]()['find'](function(_0x58a6fd){return _0x58a6fd===_0x3f1e6f[_0x65bf('0x46')];});if(_0x542ec9)_0x542ec9=_0x2dd670[_0x3f1e6f['field']];if(!_0x542ec9){if(_0x3f1e6f[_0x65bf('0x46')]===_0x65bf('0x54')){var _0x44becf=_0x3f1e6f[_0x65bf('0x55')][_0x65bf('0x56')](',')[_0x65bf('0x57')](function(_0x216760){return Number(_0x216760);});_0x44becf[_0x65bf('0x58')](function(_0x2b9b05){_0xd18ff0['or'](_0x65bf('0x59'),'%,'+_0x2b9b05+',%');});_0x3d3317=_['union'](_0x3d3317,_0x44becf);}else if(_0x3f1e6f[_0x65bf('0x46')]===_0x65bf('0x5a')){_0x1bad76[_0x65bf('0x5b')](_0x65bf('0x5c'),_0x3f1e6f[_0x65bf('0x55')]);}}else{if(_0x3f1e6f[_0x65bf('0x46')]==='dateOfBirth'||_0x542ec9[_0x65bf('0x5d')]===_0x65bf('0x5e'))_0x3f1e6f[_0x65bf('0x5f')]=_0x65bf('0x60');var _0x2cbccc=as[_0x65bf('0x61')](_0x5eb9a5,_0x542ec9[_0x65bf('0x62')],_0x3f1e6f);_0x1bad76[_0x3a3c20](_0x2cbccc[_0x65bf('0x63')],_0x2cbccc['value'][_0x65bf('0x64')],_0x2cbccc['value'][_0x65bf('0x21')]);}}}else{var _0x574fa2=_(Object[_0x65bf('0x3a')](_0x32b4b6['query']))[_0x65bf('0x57')](function(_0x4922ce){return _0x2dd670[_0x65bf('0x40')](_0x4922ce)?_0x4922ce:undefined;})[_0x65bf('0x65')](function(_0x32f586){return!_['isNil'](_0x32f586);})['value']();if(_0x32b4b6['query'][_0x65bf('0x66')])_0x574fa2[_0x65bf('0x35')](_0x65bf('0x66'));if(!_[_0x65bf('0x67')](_0x574fa2)){_0x574fa2[_0x65bf('0x58')](function(_0x2266a5){if(_0x2266a5==='ListId'){_0x2984f9['where'](_0x65bf('0x68'),[][_0x65bf('0x69')](_0x32b4b6[_0x65bf('0x3b')][_0x2266a5]));}else if(_0x2266a5==='Contact'){var _0x4e5637='%'+_0x32b4b6[_0x65bf('0x3b')][_0x2266a5]+'%';_0x2984f9['where']('CONCAT_WS(\x27\x20\x27,\x20c.firstName,\x20c.lastName,\x20c.email)\x20LIKE\x20?',_0x4e5637);}else{_0x2984f9[_0x65bf('0x43')]('c.'+_0x2266a5+'\x20=\x20?',_0x32b4b6['query'][_0x2266a5]);}});}if(_0x32b4b6[_0x65bf('0x3b')]['tag']){_0x3d3317=_['isArray'](_0x32b4b6['query'][_0x65bf('0x6a')])?_0x32b4b6[_0x65bf('0x3b')][_0x65bf('0x6a')]:new Array(_0x32b4b6['query'][_0x65bf('0x6a')]);_0x3d3317[_0x65bf('0x58')](function(_0x521039){_0xd18ff0['or']('CONCAT(\x27,\x27,\x20`TagIds`,\x20\x27,\x27)\x20LIKE\x20?','%,'+_0x521039+',%');});}if(_0x32b4b6[_0x65bf('0x3b')][_0x65bf('0x65')]){var _0xc7dbd1=_0x32b4b6[_0x65bf('0x3b')]['filter'][_0x65bf('0x6b')]('\x5c','\x5c\x5c')[_0x65bf('0x6b')](/'/g,'\x27\x27');if(_0xc7dbd1[_0x65bf('0x56')]('\x20')['length']>0x1){_0x1bad76['or'](_0x65bf('0x6c'),qs['getFullTextValue'](_0xc7dbd1),null);}else{if(qs['isNumeric'](_0xc7dbd1)){_0x1bad76['or'](_0x65bf('0x6d'),_0xc7dbd1+'%');_0x1bad76['or'](_0x65bf('0x6e'),_0xc7dbd1+'%');_0x1bad76['or']('c.mobile\x20LIKE\x20?',_0xc7dbd1+'%');_0x1bad76['or'](_0x65bf('0x6f'),_0xc7dbd1+'%');}else if(qs[_0x65bf('0x70')](_0xc7dbd1)){_0x1bad76['or'](_0x65bf('0x71'),_0xc7dbd1+'%');}else{_0x1bad76['or'](_0x65bf('0x72'),'%'+_0xc7dbd1+'%');_0x1bad76['or'](_0x65bf('0x73'),'%'+_0xc7dbd1+'%');_0x1bad76['or']('c.email\x20LIKE\x20?','%'+_0xc7dbd1+'%');}}}}_0x2984f9[_0x65bf('0x43')](_0x1bad76);_0x2984f9['group']('c.id');var _0x21fe36={'type':db[_0x65bf('0x74')][_0x65bf('0x75')][_0x65bf('0x76')],'raw':!![]};var _0x6aa6d5=_0x2984f9[_0x65bf('0x77')]()[_0x65bf('0x46')](_0x65bf('0x78'));if(_0x493c57[_0x65bf('0x41')]){_0x493c57['order']['forEach'](function(_0x1fd5d9){_0x2984f9[_0x65bf('0x41')]('c.'+_0x1fd5d9[0x0],_0x1fd5d9[0x1]==='DESC'?![]:!![]);});}if(!_[_0x65bf('0x67')](_0x3d3317)){_0x2984f9['having'](_0xd18ff0);_0x6aa6d5['where'](_0x65bf('0x79'),_0x3d3317);}BPromise[_0x65bf('0x7a')]()[_0x65bf('0x2b')](function(){if(!_0xf78ccd)return;if(_0x32b4b6[_0x65bf('0x7b')]['role']!==_0x65bf('0x7c'))return;if(!_[_0x65bf('0x7d')](_0xf78ccd[_0x65bf('0x53')],[_0x65bf('0x46'),_0x65bf('0x5a')])){return _0x32b4b6['user'][_0x65bf('0x7e')]({'attributes':['id'],'raw':!![]})[_0x65bf('0x2b')](function(_0x55ae17){if(_[_0x65bf('0x67')](_0x55ae17)){_0x6aa6d5['where'](_0x65bf('0x7f'));_0x2984f9[_0x65bf('0x43')](_0x65bf('0x7f'));}else{_0x6aa6d5[_0x65bf('0x43')]('c.ListId\x20IN\x20?',_[_0x65bf('0x57')](_0x55ae17,'id'));_0x2984f9['where'](_0x65bf('0x68'),_[_0x65bf('0x57')](_0x55ae17,'id'));}});}})['then'](function(){if(_0x32b4b6[_0x65bf('0x7b')][_0x65bf('0x80')]===_0x65bf('0x7c')&&!_0xf78ccd&&!_0x32b4b6['query'][_0x65bf('0x81')])return[];return db[_0x65bf('0x82')]['query'](_0x6aa6d5[_0x65bf('0x83')](),_0x21fe36);})[_0x65bf('0x2b')](function(_0x332e2b){_0xd43e29[_0x65bf('0x84')]=_0x332e2b['length'];if(_0xd43e29[_0x65bf('0x84')]===0x0)return[];return db[_0x65bf('0x82')]['query'](_0x42c9bd[_0x65bf('0x83')](),_0x21fe36)[_0x65bf('0x2b')](function(_0x591cac){_0x42dfe9=_[_0x65bf('0x85')](_0x591cac,'id');_0x21fe36=_['merge'](_0x21fe36,{'model':db[_0x65bf('0x30')],'mapToModel':!![],'raw':!![],'nest':!![]});if(_0x32b4b6[_0x65bf('0x3b')][_0x65bf('0x3f')]){_0x493c57[_0x65bf('0x3e')][_0x65bf('0x58')](function(_0x1c9e44){_0x2984f9[_0x65bf('0x46')]('c.'+_0x1c9e44);});}else{_0x2984f9[_0x65bf('0x46')]('c.id');_0x2984f9[_0x65bf('0x46')](_0x65bf('0x86'));_0x2984f9[_0x65bf('0x46')](_0x65bf('0x87'));_0x2984f9[_0x65bf('0x46')](_0x65bf('0x88'));_0x2984f9[_0x65bf('0x46')](_0x65bf('0x89'));_0x2984f9['field']('c.fax');_0x2984f9[_0x65bf('0x46')](_0x65bf('0x8a'));_0x2984f9['field'](_0x65bf('0x8b'));_0x2984f9['field']('c.createdAt');_0x2984f9[_0x65bf('0x46')](_0x65bf('0x8c'));_0x2984f9[_0x65bf('0x46')](_0x65bf('0x8d'));_0x2984f9['field'](_0x65bf('0x8e'),'TagIds');}if(_0x493c57[_0x65bf('0x24')])_0x2984f9[_0x65bf('0x24')](_0x493c57[_0x65bf('0x24')]);if(_0x493c57[_0x65bf('0x23')])_0x2984f9[_0x65bf('0x23')](_0x493c57[_0x65bf('0x23')]);return db[_0x65bf('0x82')]['query'](_0x2984f9[_0x65bf('0x83')](),_0x21fe36);});})[_0x65bf('0x2b')](function(_0x498f70){_0x498f70[_0x65bf('0x58')](function(_0x282211){if(_0x282211[_0x65bf('0x8f')]){_0x282211[_0x65bf('0x90')]=[];_0x282211[_0x65bf('0x8f')]['split'](',')[_0x65bf('0x58')](function(_0x5174ad){_0x282211[_0x65bf('0x90')]['push'](_0x42dfe9[_0x5174ad]);});}delete _0x282211[_0x65bf('0x8f')];});_0xd43e29[_0x65bf('0x91')]=_0x498f70;return _0xd43e29;})['then'](respondWithFilteredResult(_0x2f6167,_0x493c57));})[_0x65bf('0x92')](handleError(_0x2f6167,null));};exports[_0x65bf('0x93')]=function(_0x5125a0,_0x17a2d1){return db[_0x65bf('0x30')][_0x65bf('0x94')]({'where':{'id':_0x5125a0['params']['id']}})['then'](handleEntityNotFound(_0x17a2d1,null))[_0x65bf('0x2b')](removeEntity(_0x17a2d1,null))['catch'](handleError(_0x17a2d1,null));};exports[_0x65bf('0x31')]=function(_0x393e9d,_0x364b55){return db['CmContact'][_0x65bf('0x31')]()['then'](function(_0x38a3a6){delete _0x38a3a6[_0x65bf('0x95')];for(var _0x470994=0x0;_0x470994<Object[_0x65bf('0x3a')](_0x38a3a6)[_0x65bf('0x32')];_0x470994++){var _0x168aef=Object[_0x65bf('0x3a')](_0x38a3a6)[_0x470994];if(!_[_0x65bf('0x33')](_0x168aef,_0x65bf('0x34'))){_0x38a3a6[_0x168aef]['columnName']=_0x168aef;_0x38a3a6[_0x168aef][_0x65bf('0x96')]=_0x168aef;}}return _0x38a3a6;})[_0x65bf('0x2b')](function(_0x24bbd5){var _0x27cc22={'where':{'$or':[{'ListId':_0x393e9d[_0x65bf('0x3b')]['id']},{'ListId':null}]},'raw':!![]};return db[_0x65bf('0x36')]['findAll'](_0x27cc22)['then'](function(_0x1df147){for(var _0xc0d611=0x0;_0xc0d611<_0x1df147[_0x65bf('0x32')];_0xc0d611++){var _0x10b558=_0x65bf('0x34')+_0x1df147[_0xc0d611]['id'];_0x24bbd5[_0x10b558][_0x65bf('0x97')]=_0x10b558;_0x24bbd5[_0x10b558][_0x65bf('0x96')]=_0x1df147[_0xc0d611][_0x65bf('0x98')];_0x24bbd5[_0x10b558][_0x65bf('0x99')]={'type':_0x1df147[_0xc0d611][_0x65bf('0x62')],'values':_0x1df147[_0xc0d611]['values']};}Object[_0x65bf('0x3a')](_0x24bbd5)[_0x65bf('0x58')](function(_0x1be1c1){if(!_0x24bbd5[_0x1be1c1][_0x65bf('0x40')]('columnName')){delete _0x24bbd5[_0x1be1c1];}});return _0x24bbd5;});})[_0x65bf('0x2b')](respondWithResult(_0x364b55,null))[_0x65bf('0x92')](handleError(_0x364b55,null));};exports[_0x65bf('0x9a')]=function(_0x4d2df8,_0x3bc83c){var _0x1fb839;var _0x346a2c;var _0x10a17a;if(_0x4d2df8['body']['id']){delete _0x4d2df8[_0x65bf('0x9b')]['id'];}return db[_0x65bf('0x30')][_0x65bf('0x9c')]({'where':{'id':[_0x4d2df8['body']['to'],_0x4d2df8[_0x65bf('0x9b')]['from']]}})[_0x65bf('0x2b')](function(_0x261a5b){if(_0x261a5b){if(_0x261a5b[_0x65bf('0x32')]!==0x2){return null;}_0x261a5b[0x0]=_0x261a5b[0x0]['get']({'plain':!![]});_0x261a5b[0x1]=_0x261a5b[0x1][_0x65bf('0x9d')]({'plain':!![]});delete _0x261a5b[0x0]['id'];delete _0x261a5b[0x1]['id'];return _['mergeWith'](_0x261a5b[0x0],_0x261a5b[0x1],function(_0x116ac9,_0x3e039e){if(Array[_0x65bf('0x9e')](_0x3e039e)&&!_0x3e039e[_0x65bf('0x32')]){return _0x116ac9;}else if(!_0x3e039e){return _0x116ac9;}});}})['then'](handleEntityNotFound(_0x3bc83c,null))['then'](function(_0x1f90e6){if(_0x1f90e6){if(_0x1f90e6['tags']&&_[_0x65bf('0x9e')](_0x1f90e6[_0x65bf('0x95')])){_0x1f90e6[_0x65bf('0x95')]=_0x1f90e6[_0x65bf('0x95')]['join']();}logger[_0x65bf('0x9f')](_0x65bf('0xa0'),_0x4d2df8[_0x65bf('0x9b')]['to'],_0x4d2df8['body'][_0x65bf('0x47')]);return db[_0x65bf('0xa1')][_0x65bf('0x93')]({'where':{'ContactId':[_0x4d2df8[_0x65bf('0x9b')]['to'],_0x4d2df8[_0x65bf('0x9b')][_0x65bf('0x47')]]}})['then'](function(_0x44deca){logger[_0x65bf('0x9f')](_0x65bf('0xa2'),_0x44deca);return db['CmHopperBlack']['destroy']({'where':{'ContactId':[_0x4d2df8[_0x65bf('0x9b')]['to'],_0x4d2df8['body'][_0x65bf('0x47')]]}})[_0x65bf('0x2b')](function(_0x480360){logger['info']('[CmContact][merge][destroy][CmHopperBlack],\x20%s',_0x480360);return db[_0x65bf('0x30')]['create'](_0x1f90e6);});});}})[_0x65bf('0x2b')](function(_0x2344d2){if(_0x2344d2){_0x1fb839=_0x2344d2;_0x346a2c={'ContactId':_0x1fb839['id']};_0x10a17a={'where':{'ContactId':[_0x4d2df8['body']['to'],_0x4d2df8[_0x65bf('0x9b')]['from']]}};return db[_0x65bf('0xa3')][_0x65bf('0x2a')](_0x346a2c,_0x10a17a);}})['then'](function(){if(_0x1fb839){return db[_0x65bf('0xa4')]['update'](_0x346a2c,_0x10a17a);}})[_0x65bf('0x2b')](function(){if(_0x1fb839){return db[_0x65bf('0xa5')][_0x65bf('0x2a')](_0x346a2c,_0x10a17a);}})[_0x65bf('0x2b')](function(){if(_0x1fb839){return db[_0x65bf('0xa6')][_0x65bf('0x2a')](_0x346a2c,_0x10a17a);}})[_0x65bf('0x2b')](function(){if(_0x1fb839){return db[_0x65bf('0xa7')][_0x65bf('0x2a')](_0x346a2c,_0x10a17a);}})[_0x65bf('0x2b')](function(){if(_0x1fb839){return db['MailInteraction']['update'](_0x346a2c,_0x10a17a);}})[_0x65bf('0x2b')](function(){if(_0x1fb839){return db[_0x65bf('0xa7')][_0x65bf('0x2a')](_0x346a2c,_0x10a17a);}})[_0x65bf('0x2b')](function(){if(_0x1fb839){return db[_0x65bf('0xa8')][_0x65bf('0x2a')](_0x346a2c,_0x10a17a);}})[_0x65bf('0x2b')](function(){if(_0x1fb839){return db[_0x65bf('0xa9')][_0x65bf('0x2a')](_0x346a2c,_0x10a17a);}})['then'](function(){if(_0x1fb839){return db[_0x65bf('0xaa')][_0x65bf('0x2a')](_0x346a2c,_0x10a17a);}})[_0x65bf('0x2b')](function(){if(_0x1fb839){return db['FaxMessage'][_0x65bf('0x2a')](_0x346a2c,_0x10a17a);}})[_0x65bf('0x2b')](function(){if(_0x1fb839){return db['OpenchannelInteraction'][_0x65bf('0x2a')](_0x346a2c,_0x10a17a);}})['then'](function(){if(_0x1fb839){return db['OpenchannelMessage'][_0x65bf('0x2a')](_0x346a2c,_0x10a17a);}})[_0x65bf('0x2b')](function(){if(_0x1fb839){return db['CmHopperFinal'][_0x65bf('0x2a')](_0x346a2c,_0x10a17a);}})[_0x65bf('0x2b')](function(){if(_0x1fb839){return db[_0x65bf('0xab')][_0x65bf('0x2a')](_0x346a2c,_0x10a17a);}})['then'](function(){if(_0x1fb839){return db[_0x65bf('0xac')][_0x65bf('0x2a')](_0x346a2c,_0x10a17a);}})[_0x65bf('0x2b')](function(){if(_0x1fb839){return db[_0x65bf('0xad')][_0x65bf('0x2a')](_0x346a2c,_0x10a17a);}})[_0x65bf('0x2b')](function(){if(_0x1fb839){return db[_0x65bf('0xae')]['update'](_0x346a2c,_0x10a17a);}})[_0x65bf('0x2b')](function(){if(_0x1fb839){return db[_0x65bf('0xaf')]['update'](_0x346a2c,_0x10a17a);}})[_0x65bf('0x2b')](function(){if(_0x1fb839){return db[_0x65bf('0xb0')][_0x65bf('0x2a')](_0x346a2c,_0x10a17a);}})[_0x65bf('0x2b')](function(){if(_0x1fb839){return db['OpenchannelQueueReport'][_0x65bf('0x2a')](_0x346a2c,_0x10a17a);}})[_0x65bf('0x2b')](function(){if(_0x1fb839){return db[_0x65bf('0xb1')][_0x65bf('0x2a')](_0x346a2c,_0x10a17a);}})['then'](function(){if(_0x1fb839){return db[_0x65bf('0xb2')][_0x65bf('0x2a')](_0x346a2c,_0x10a17a);}})['then'](function(){if(_0x1fb839){return db[_0x65bf('0x30')][_0x65bf('0x93')]({'where':{'id':[_0x4d2df8['body']['to'],_0x4d2df8[_0x65bf('0x9b')][_0x65bf('0x47')]]}});}})[_0x65bf('0x2b')](function(){if(_0x1fb839){return _0x1fb839;}})['then'](respondWithResult(_0x3bc83c,null))['catch'](handleError(_0x3bc83c,null));};exports[_0x65bf('0xb3')]=function(_0x351fce,_0x4ccb61){return db[_0x65bf('0x30')]['describe']()[_0x65bf('0x2b')](function(_0x333f30){if(_0x351fce[_0x65bf('0x9b')][_0x65bf('0x95')]&&_[_0x65bf('0x9e')](_0x351fce['body'][_0x65bf('0x95')])){if(_0x351fce[_0x65bf('0x9b')][_0x65bf('0x95')][_0x65bf('0x32')]){_0x351fce[_0x65bf('0x9b')][_0x65bf('0x95')]=_0x351fce['body'][_0x65bf('0x95')]['join'](';')+';';}else{_0x351fce[_0x65bf('0x9b')][_0x65bf('0x95')]=null;}}else{_0x351fce[_0x65bf('0x9b')]['tags']=null;}return db[_0x65bf('0x30')][_0x65bf('0xb3')](_0x351fce[_0x65bf('0x9b')],{'fields':_[_0x65bf('0x3a')](_0x333f30),'raw':!![]});})[_0x65bf('0x2b')](respondWithResult(_0x4ccb61,0xc9))[_0x65bf('0x92')](handleError(_0x4ccb61,null));};exports[_0x65bf('0xb4')]=function(_0x89d875,_0x564a10){var _0xbd91e9=[];var _0x56121b=0x0;var _0x4cbf4a=0x0;var _0x360171=0x0;return db[_0x65bf('0x30')][_0x65bf('0x31')]()[_0x65bf('0x2b')](function(_0x55cc82){return BPromise[_0x65bf('0xb5')](_0x89d875['body'],function(_0x336cd9){var _0x185ddc={'where':{'$or':[]},'defaults':_0x336cd9,'fields':_['keys'](_0x55cc82),'raw':!![]};if(_0x336cd9[_0x65bf('0xb6')]){for(var _0x722d1=0x0;_0x722d1<_0x336cd9['duplicates'][_0x65bf('0x32')];_0x722d1++){var _0x51ff52={};_0x51ff52[_0x336cd9[_0x65bf('0xb6')][_0x722d1]]=_0x336cd9[_0x336cd9[_0x65bf('0xb6')][_0x722d1]];_0x185ddc[_0x65bf('0x43')][_0x65bf('0xb7')][_0x65bf('0x35')](_0x51ff52);}_0x185ddc['where'][_0x65bf('0x81')]=_0x336cd9[_0x65bf('0x81')];}return db[_0x65bf('0x30')][_0x65bf('0xb8')](_0x185ddc)['spread'](function(_0x3199b8,_0xd879a2){if(_0xd879a2){_0x56121b++;}else{_0x360171++;}})[_0x65bf('0x92')](function(_0x4a63a4){console['error'](_0x4a63a4);_0x4cbf4a++;});});})[_0x65bf('0x2b')](function(_0x46c9da){if(_0x46c9da){return{'success':_0x56121b,'failure':_0x4cbf4a,'duplicates':_0x360171};}})[_0x65bf('0x2b')](respondWithResult(_0x564a10,0xc9))['catch'](handleError(_0x564a10,null));};exports['show']=function(_0x38e2a0,_0x51450e,_0x4895d3){var _0x34c85e;return db[_0x65bf('0x30')][_0x65bf('0x31')]()['then'](function(_0x536405){return db[_0x65bf('0x30')][_0x65bf('0x94')]({'where':{'id':_0x38e2a0[_0x65bf('0xb9')]['id']},'include':[{'model':db[_0x65bf('0x54')],'as':_0x65bf('0x90'),'attributes':['id','name',_0x65bf('0xba')],'required':_0x38e2a0[_0x65bf('0x3b')]['tag']?!![]:![]}],'attributes':_[_0x65bf('0x3a')](_0x536405)});})[_0x65bf('0x2b')](function(_0x51f021){_0x34c85e=_0x51f021[_0x65bf('0x9d')]({'plain':!![]});var _0xbe3477={'where':{'$and':[{'ListId':{'$ne':null}}]}};if(_0x51f021&&_0x51f021[_0x65bf('0x81')]){if(_0x51f021[_0x65bf('0x81')]){_0xbe3477[_0x65bf('0x43')][_0x65bf('0xbb')][_0x65bf('0x35')]({'ListId':{'$ne':_0x51f021['ListId']}});}}return db[_0x65bf('0x36')]['findAll'](_0xbe3477);})[_0x65bf('0x2b')](function(_0xeef164){return _[_0x65bf('0xbc')](_0x34c85e,_[_0x65bf('0x57')](_0xeef164,function(_0x797162){return util['format'](_0x65bf('0xbd'),_0x797162['id']);}));})[_0x65bf('0x2b')](handleEntityNotFound(_0x51450e,null))['then'](respondWithResult(_0x51450e,null))[_0x65bf('0x92')](handleError(_0x51450e,null));};exports[_0x65bf('0x2a')]=function(_0x2187f8,_0x1268fc){var _0x46c48b;if(_0x2187f8[_0x65bf('0x9b')]['id']){delete _0x2187f8[_0x65bf('0x9b')]['id'];}return db[_0x65bf('0x30')][_0x65bf('0x94')]({'where':{'id':_0x2187f8[_0x65bf('0xb9')]['id']}})['then'](handleEntityNotFound(_0x1268fc,null))['then'](saveUpdates(_0x2187f8[_0x65bf('0x9b')],null))[_0x65bf('0x2b')](function(_0x4cf97e){_0x46c48b=_0x4cf97e;var _0x251a48={'where':{'$and':[{'ListId':{'$ne':null}}]}};if(_0x4cf97e&&_0x4cf97e[_0x65bf('0x81')]){if(_0x4cf97e[_0x65bf('0x81')]){_0x251a48[_0x65bf('0x43')][_0x65bf('0xbb')][_0x65bf('0x35')]({'ListId':{'$ne':_0x4cf97e[_0x65bf('0x81')]}});}}return db[_0x65bf('0x36')]['findAll'](_0x251a48);})[_0x65bf('0x2b')](function(_0x3e9e15){if(_0x3e9e15){return _[_0x65bf('0xbc')](_[_0x65bf('0xbe')](_0x2187f8[_0x65bf('0x9b')],function(_0x53297d,_0x311925){return _[_0x65bf('0x33')](_0x311925,'cf_');}),_['map'](_0x3e9e15,function(_0x189094){return util['format'](_0x65bf('0xbd'),_0x189094['id']);}));}})['then'](function(_0x3e9e32){if(_0x3e9e32&&!_[_0x65bf('0x67')](_0x3e9e32)){var _0x169166=squel['update']()[_0x65bf('0xbf')]('cm_contacts')[_0x65bf('0xc0')](_0x3e9e32)[_0x65bf('0x43')](_0x65bf('0xc1'),_0x2187f8[_0x65bf('0xb9')]['id'])['toParam']();return db[_0x65bf('0x82')][_0x65bf('0x3b')](_0x169166[_0x65bf('0x63')],{'replacements':_0x169166[_0x65bf('0xc2')]});}})[_0x65bf('0x2b')](function(){if(_0x2187f8[_0x65bf('0x9b')]['phone']&&_0x46c48b){return db[_0x65bf('0xa1')][_0x65bf('0x2a')]({'phone':_0x2187f8[_0x65bf('0x9b')][_0x65bf('0xc3')]},{'where':{'ContactId':_0x46c48b['id']}});}})[_0x65bf('0x2b')](function(){return _0x46c48b;})['then'](respondWithResult(_0x1268fc,null))[_0x65bf('0x92')](handleError(_0x1268fc,null));};exports[_0x65bf('0xc4')]=function(_0x256e12,_0x36d283,_0x55c1e1){var _0x5b4b52={};var _0x429435={};var _0xa81d77;var _0x454ec8;return db[_0x65bf('0x30')][_0x65bf('0x37')]({'where':{'id':_0x256e12[_0x65bf('0xb9')]['id']}})[_0x65bf('0x2b')](handleEntityNotFound(_0x36d283,null))[_0x65bf('0x2b')](function(_0x57849d){if(_0x57849d){_0xa81d77=_0x57849d;_0x429435[_0x65bf('0x39')]=_[_0x65bf('0x3a')](db[_0x65bf('0x54')][_0x65bf('0xc5')]);_0x429435[_0x65bf('0x3b')]=_['keys'](_0x256e12[_0x65bf('0x3b')]);_0x429435[_0x65bf('0x3c')]=_['intersection'](_0x429435[_0x65bf('0x39')],_0x429435['query']);_0x5b4b52[_0x65bf('0x3e')]=_[_0x65bf('0x3d')](_0x429435[_0x65bf('0x39')],qs[_0x65bf('0x3f')](_0x256e12['query']['fields']));_0x5b4b52[_0x65bf('0x3e')]=_0x5b4b52[_0x65bf('0x3e')][_0x65bf('0x32')]?_0x5b4b52['attributes']:_0x429435[_0x65bf('0x39')];_0x5b4b52[_0x65bf('0x41')]=qs[_0x65bf('0x42')](_0x256e12[_0x65bf('0x3b')][_0x65bf('0x42')]);_0x5b4b52[_0x65bf('0x43')]=qs[_0x65bf('0x3c')](_['pick'](_0x256e12[_0x65bf('0x3b')],_0x429435[_0x65bf('0x3c')]));if(_0x256e12[_0x65bf('0x3b')]['filter']){_0x5b4b52[_0x65bf('0x43')]=_[_0x65bf('0x9a')](_0x5b4b52[_0x65bf('0x43')],{'$or':_[_0x65bf('0x57')](_0x5b4b52[_0x65bf('0x3e')],function(_0x22f2fa){var _0x3c27fc={};_0x3c27fc[_0x22f2fa]={'$like':'%'+_0x256e12[_0x65bf('0x3b')][_0x65bf('0x65')]+'%'};return _0x3c27fc;})});}_0x5b4b52=_[_0x65bf('0x9a')]({},_0x5b4b52,_0x256e12[_0x65bf('0xc6')]);return _0xa81d77['getTags'](_0x5b4b52);}})['then'](function(_0x19c952){if(_0x19c952){_0x454ec8=_0x19c952[_0x65bf('0x32')];if(!_0x256e12[_0x65bf('0x3b')]['hasOwnProperty'](_0x65bf('0xc7'))){_0x5b4b52['limit']=qs['limit'](_0x256e12[_0x65bf('0x3b')][_0x65bf('0x24')]);_0x5b4b52['offset']=qs[_0x65bf('0x23')](_0x256e12[_0x65bf('0x3b')][_0x65bf('0x23')]);}return _0xa81d77[_0x65bf('0xc4')](_0x5b4b52);}})[_0x65bf('0x2b')](function(_0x57426a){if(_0x57426a){return _0x57426a?{'count':_0x454ec8,'rows':_0x57426a}:null;}})[_0x65bf('0x2b')](respondWithResult(_0x36d283,null))[_0x65bf('0x92')](handleError(_0x36d283,null));};exports[_0x65bf('0xc8')]=function(_0x22d176,_0x43749f,_0x18bcf0){if(_0x22d176[_0x65bf('0x9b')]['id']){delete _0x22d176[_0x65bf('0x9b')]['id'];}return db[_0x65bf('0x30')][_0x65bf('0x37')]({'where':{'id':_0x22d176[_0x65bf('0xb9')]['id']}})['then'](handleEntityNotFound(_0x43749f,null))['then'](function(_0xbe16fd){if(_0xbe16fd){return _0xbe16fd[_0x65bf('0xc8')](_0x22d176['body'][_0x65bf('0xc9')]||[]);}return null;})['then'](respondWithResult(_0x43749f,null))['catch'](handleError(_0x43749f,null));};exports[_0x65bf('0xca')]=function(_0x31e4e1,_0x2aca88,_0x6a902){var _0x210087={'raw':![],'where':{}};var _0x47b4c0={};var _0x163073={'count':0x0,'rows':[]};return db[_0x65bf('0x30')][_0x65bf('0x37')]({'where':{'id':_0x31e4e1[_0x65bf('0xb9')]['id']}})[_0x65bf('0x2b')](handleEntityNotFound(_0x2aca88,null))['then'](function(_0x189999){if(_0x189999){_0x47b4c0[_0x65bf('0x39')]=_[_0x65bf('0x3a')](db[_0x65bf('0xa1')][_0x65bf('0xc5')]);_0x47b4c0[_0x65bf('0x3b')]=_[_0x65bf('0x3a')](_0x31e4e1[_0x65bf('0x3b')]);_0x47b4c0[_0x65bf('0x3c')]=_['intersection'](_0x47b4c0[_0x65bf('0x39')],_0x47b4c0[_0x65bf('0x3b')]);_0x210087['attributes']=_[_0x65bf('0x3d')](_0x47b4c0[_0x65bf('0x39')],qs['fields'](_0x31e4e1['query'][_0x65bf('0x3f')]));_0x210087[_0x65bf('0x3e')]=_0x210087[_0x65bf('0x3e')]['length']?_0x210087[_0x65bf('0x3e')]:_0x47b4c0[_0x65bf('0x39')];if(!_0x31e4e1[_0x65bf('0x3b')][_0x65bf('0x40')](_0x65bf('0xc7'))){_0x210087[_0x65bf('0x24')]=qs['limit'](_0x31e4e1[_0x65bf('0x3b')][_0x65bf('0x24')]);_0x210087[_0x65bf('0x23')]=qs[_0x65bf('0x23')](_0x31e4e1[_0x65bf('0x3b')][_0x65bf('0x23')]);}_0x210087[_0x65bf('0x41')]=qs['sort'](_0x31e4e1['query']['sort']);_0x210087[_0x65bf('0x43')]=qs['filters'](_['pick'](_0x31e4e1[_0x65bf('0x3b')],_0x47b4c0[_0x65bf('0x3c')]));_0x210087[_0x65bf('0x43')][_0x65bf('0xcb')]=_0x189999['id'];if(_0x31e4e1[_0x65bf('0x3b')][_0x65bf('0x65')]){_0x210087['where']=_[_0x65bf('0x9a')](_0x210087['where'],{'$or':_[_0x65bf('0x57')](_0x210087['attributes'],function(_0x4e109d){var _0xe41260={};_0xe41260[_0x4e109d]={'$like':'%'+_0x31e4e1[_0x65bf('0x3b')][_0x65bf('0x65')]+'%'};return _0xe41260;})});}_0x210087=_[_0x65bf('0x9a')]({},_0x210087,_0x31e4e1[_0x65bf('0xc6')]);return db[_0x65bf('0xa1')][_0x65bf('0x84')]({'where':_0x210087['where']})[_0x65bf('0x2b')](function(_0x5462e5){_0x163073[_0x65bf('0x84')]=_0x5462e5;if(_0x31e4e1[_0x65bf('0x3b')][_0x65bf('0xcc')]){_0x210087[_0x65bf('0xcd')]=[{'all':!![]}];}return db[_0x65bf('0xa1')]['findAll'](_0x210087);})[_0x65bf('0x2b')](function(_0xec28f8){_0x163073[_0x65bf('0x91')]=_0xec28f8;return _0x163073;});}})['then'](respondWithFilteredResult(_0x2aca88,_0x210087))[_0x65bf('0x92')](handleError(_0x2aca88,null));};exports[_0x65bf('0xce')]=function(_0x3e1b91,_0x1978d8,_0x5100c4){var _0x54be73={'raw':!![],'where':{}};var _0x2ad0e1={};var _0x691b71={'count':0x0,'rows':[]};return db['CmContact'][_0x65bf('0x37')]({'where':{'id':_0x3e1b91[_0x65bf('0xb9')]['id']}})[_0x65bf('0x2b')](handleEntityNotFound(_0x1978d8,null))['then'](function(_0x13cc0e){if(_0x13cc0e){_0x2ad0e1[_0x65bf('0x39')]=_[_0x65bf('0x3a')](db[_0x65bf('0xab')][_0x65bf('0xc5')]);_0x2ad0e1[_0x65bf('0x3b')]=_['keys'](_0x3e1b91[_0x65bf('0x3b')]);_0x2ad0e1[_0x65bf('0x3c')]=_[_0x65bf('0x3d')](_0x2ad0e1[_0x65bf('0x39')],_0x2ad0e1[_0x65bf('0x3b')]);_0x54be73[_0x65bf('0x3e')]=_['intersection'](_0x2ad0e1[_0x65bf('0x39')],qs[_0x65bf('0x3f')](_0x3e1b91[_0x65bf('0x3b')][_0x65bf('0x3f')]));_0x54be73['attributes']=_0x54be73['attributes'][_0x65bf('0x32')]?_0x54be73[_0x65bf('0x3e')]:_0x2ad0e1['model'];if(!_0x3e1b91[_0x65bf('0x3b')][_0x65bf('0x40')]('nolimit')){_0x54be73[_0x65bf('0x24')]=qs[_0x65bf('0x24')](_0x3e1b91[_0x65bf('0x3b')][_0x65bf('0x24')]);_0x54be73[_0x65bf('0x23')]=qs['offset'](_0x3e1b91['query'][_0x65bf('0x23')]);}_0x54be73[_0x65bf('0x41')]=qs['sort'](_0x3e1b91['query'][_0x65bf('0x42')]);_0x54be73[_0x65bf('0x43')]=qs[_0x65bf('0x3c')](_[_0x65bf('0x44')](_0x3e1b91['query'],_0x2ad0e1[_0x65bf('0x3c')]));_0x54be73['where'][_0x65bf('0xcb')]=_0x13cc0e['id'];if(_0x3e1b91[_0x65bf('0x3b')][_0x65bf('0x65')]){_0x54be73[_0x65bf('0x43')]=_[_0x65bf('0x9a')](_0x54be73[_0x65bf('0x43')],{'$or':_['map'](_0x54be73[_0x65bf('0x3e')],function(_0x2a8666){var _0x96c27c={};_0x96c27c[_0x2a8666]={'$like':'%'+_0x3e1b91[_0x65bf('0x3b')][_0x65bf('0x65')]+'%'};return _0x96c27c;})});}_0x54be73=_[_0x65bf('0x9a')]({},_0x54be73,_0x3e1b91[_0x65bf('0xc6')]);return db[_0x65bf('0xab')]['count']({'where':_0x54be73[_0x65bf('0x43')]})[_0x65bf('0x2b')](function(_0x1da7d7){_0x691b71['count']=_0x1da7d7;if(_0x3e1b91['query'][_0x65bf('0xcc')]){_0x54be73[_0x65bf('0xcd')]=[{'all':!![]}];}return db[_0x65bf('0xab')][_0x65bf('0x9c')](_0x54be73);})[_0x65bf('0x2b')](function(_0x195d8d){_0x691b71[_0x65bf('0x91')]=_0x195d8d;return _0x691b71;});}})[_0x65bf('0x2b')](respondWithFilteredResult(_0x1978d8,_0x54be73))[_0x65bf('0x92')](handleError(_0x1978d8,null));};exports[_0x65bf('0xcf')]=function(_0xe3e5c1,_0xb9dc81,_0x1edf1c){var _0x26c3c6={'raw':!![],'where':{}};var _0x3125d5={};var _0x3198c0={'count':0x0,'rows':[]};return db['CmContact']['findOne']({'where':{'id':_0xe3e5c1[_0x65bf('0xb9')]['id']}})[_0x65bf('0x2b')](handleEntityNotFound(_0xb9dc81,null))[_0x65bf('0x2b')](function(_0x3b2606){if(_0x3b2606){_0x3125d5[_0x65bf('0x39')]=_['keys'](db[_0x65bf('0xd0')]['rawAttributes']);_0x3125d5[_0x65bf('0x3b')]=_[_0x65bf('0x3a')](_0xe3e5c1[_0x65bf('0x3b')]);_0x3125d5[_0x65bf('0x3c')]=_['intersection'](_0x3125d5[_0x65bf('0x39')],_0x3125d5[_0x65bf('0x3b')]);_0x26c3c6[_0x65bf('0x3e')]=_[_0x65bf('0x3d')](_0x3125d5[_0x65bf('0x39')],qs[_0x65bf('0x3f')](_0xe3e5c1['query'][_0x65bf('0x3f')]));_0x26c3c6[_0x65bf('0x3e')]=_0x26c3c6[_0x65bf('0x3e')][_0x65bf('0x32')]?_0x26c3c6[_0x65bf('0x3e')]:_0x3125d5[_0x65bf('0x39')];if(!_0xe3e5c1[_0x65bf('0x3b')][_0x65bf('0x40')](_0x65bf('0xc7'))){_0x26c3c6['limit']=qs[_0x65bf('0x24')](_0xe3e5c1[_0x65bf('0x3b')][_0x65bf('0x24')]);_0x26c3c6[_0x65bf('0x23')]=qs[_0x65bf('0x23')](_0xe3e5c1[_0x65bf('0x3b')]['offset']);}_0x26c3c6[_0x65bf('0x41')]=qs['sort'](_0xe3e5c1[_0x65bf('0x3b')][_0x65bf('0x42')]);_0x26c3c6['where']=qs['filters'](_[_0x65bf('0x44')](_0xe3e5c1[_0x65bf('0x3b')],_0x3125d5[_0x65bf('0x3c')]));_0x26c3c6[_0x65bf('0x43')]['ContactId']=_0x3b2606['id'];if(_0xe3e5c1['query'][_0x65bf('0x65')]){_0x26c3c6['where']=_[_0x65bf('0x9a')](_0x26c3c6[_0x65bf('0x43')],{'$or':_[_0x65bf('0x57')](_0x26c3c6[_0x65bf('0x3e')],function(_0x5f651a){var _0x174ac0={};_0x174ac0[_0x5f651a]={'$like':'%'+_0xe3e5c1[_0x65bf('0x3b')]['filter']+'%'};return _0x174ac0;})});}_0x26c3c6=_[_0x65bf('0x9a')]({},_0x26c3c6,_0xe3e5c1[_0x65bf('0xc6')]);return db['CmHopperFinal'][_0x65bf('0x84')]({'where':_0x26c3c6[_0x65bf('0x43')]})[_0x65bf('0x2b')](function(_0x1337fa){_0x3198c0['count']=_0x1337fa;if(_0xe3e5c1[_0x65bf('0x3b')]['includeAll']){_0x26c3c6[_0x65bf('0xcd')]=[{'all':!![]}];}return db[_0x65bf('0xd0')][_0x65bf('0x9c')](_0x26c3c6);})[_0x65bf('0x2b')](function(_0x5dc409){_0x3198c0[_0x65bf('0x91')]=_0x5dc409;return _0x3198c0;});}})[_0x65bf('0x2b')](respondWithFilteredResult(_0xb9dc81,_0x26c3c6))[_0x65bf('0x92')](handleError(_0xb9dc81,null));};exports[_0x65bf('0xd1')]=function(_0x494aec,_0x44b1c5,_0x29d9c4){var _0x19dc32={'raw':!![],'where':{}};var _0x321fb7={};var _0x5a79cf={'count':0x0,'rows':[]};return db[_0x65bf('0x30')][_0x65bf('0x37')]({'where':{'id':_0x494aec[_0x65bf('0xb9')]['id']}})[_0x65bf('0x2b')](handleEntityNotFound(_0x44b1c5,null))[_0x65bf('0x2b')](function(_0x371b3e){if(_0x371b3e){_0x321fb7['model']=_[_0x65bf('0x3a')](db[_0x65bf('0xb2')][_0x65bf('0xc5')]);_0x321fb7[_0x65bf('0x3b')]=_[_0x65bf('0x3a')](_0x494aec['query']);_0x321fb7[_0x65bf('0x3c')]=_[_0x65bf('0x3d')](_0x321fb7['model'],_0x321fb7[_0x65bf('0x3b')]);_0x19dc32[_0x65bf('0x3e')]=_[_0x65bf('0x3d')](_0x321fb7[_0x65bf('0x39')],qs['fields'](_0x494aec[_0x65bf('0x3b')][_0x65bf('0x3f')]));_0x19dc32['attributes']=_0x19dc32[_0x65bf('0x3e')][_0x65bf('0x32')]?_0x19dc32['attributes']:_0x321fb7[_0x65bf('0x39')];if(!_0x494aec['query'][_0x65bf('0x40')](_0x65bf('0xc7'))){_0x19dc32['limit']=qs[_0x65bf('0x24')](_0x494aec[_0x65bf('0x3b')][_0x65bf('0x24')]);_0x19dc32['offset']=qs[_0x65bf('0x23')](_0x494aec['query']['offset']);}_0x19dc32[_0x65bf('0x41')]=qs[_0x65bf('0x42')](_0x494aec[_0x65bf('0x3b')][_0x65bf('0x42')]);_0x19dc32['where']=qs['filters'](_['pick'](_0x494aec[_0x65bf('0x3b')],_0x321fb7[_0x65bf('0x3c')]));_0x19dc32[_0x65bf('0x43')][_0x65bf('0xcb')]=_0x371b3e['id'];if(_0x494aec[_0x65bf('0x3b')][_0x65bf('0x65')]){_0x19dc32[_0x65bf('0x43')]=_[_0x65bf('0x9a')](_0x19dc32['where'],{'$or':_[_0x65bf('0x57')](_0x19dc32[_0x65bf('0x3e')],function(_0x480acb){var _0x1780f3={};_0x1780f3[_0x480acb]={'$like':'%'+_0x494aec[_0x65bf('0x3b')][_0x65bf('0x65')]+'%'};return _0x1780f3;})});}_0x19dc32=_['merge']({},_0x19dc32,_0x494aec[_0x65bf('0xc6')]);return db[_0x65bf('0xb2')][_0x65bf('0x84')]({'where':_0x19dc32[_0x65bf('0x43')]})['then'](function(_0x5d5a04){_0x5a79cf[_0x65bf('0x84')]=_0x5d5a04;if(_0x494aec['query'][_0x65bf('0xcc')]){_0x19dc32[_0x65bf('0xcd')]=[{'all':!![]}];}return db[_0x65bf('0xb2')][_0x65bf('0x9c')](_0x19dc32);})[_0x65bf('0x2b')](function(_0x519b77){_0x5a79cf[_0x65bf('0x91')]=_0x519b77;return _0x5a79cf;});}})[_0x65bf('0x2b')](respondWithFilteredResult(_0x44b1c5,_0x19dc32))[_0x65bf('0x92')](handleError(_0x44b1c5,null));};exports['uploadCsv']=function(_0x1523d2,_0x654635,_0x15cd52){try{if(!_0x1523d2[_0x65bf('0x9b')][_0x65bf('0x81')]){throw new Error(_0x65bf('0xd2'));}if(!_0x1523d2[_0x65bf('0x9b')][_0x65bf('0xd3')]){throw new Error(_0x65bf('0xd4'));}if(!_0x1523d2[_0x65bf('0x9b')][_0x65bf('0xd5')]){throw new Error(_0x65bf('0xd6'));}if(!_0x1523d2[_0x65bf('0x9b')]['socket_timestamp']){throw new Error('Unable\x20to\x20synchronize\x20socket,\x20no\x20timestamp\x20passed');}var _0x451e80=_0x1523d2[_0x65bf('0x9b')][_0x65bf('0xd3')]['split'](',');var _0xabf929=_0x1523d2[_0x65bf('0x9b')][_0x65bf('0xd5')][_0x65bf('0x56')](',');if(!_0x451e80['length']||!_0xabf929['length']||_0x451e80[_0x65bf('0x32')]!==_0xabf929[_0x65bf('0x32')]){throw new Error(_0x65bf('0xd7'));}_0x1523d2['body']['fields']=_[_0x65bf('0xd8')](_0x451e80,_0xabf929);if(!_0x1523d2[_0x65bf('0x9b')][_0x65bf('0x3f')]['phone']){throw new Error('No\x20phone\x20column\x20specified');}if(!_0x1523d2[_0x65bf('0x9b')][_0x65bf('0x3f')][_0x65bf('0xd9')]){throw new Error('No\x20firstName\x20column\x20specified');}var _0x56cba6=path[_0x65bf('0xda')](config[_0x65bf('0xdb')],'server/files/tmp',_0x1523d2['file'][_0x65bf('0xdc')]);fs[_0x65bf('0xdd')](_0x56cba6,parseInt(_0x65bf('0xde'),0x8));var _0x454a78=require(_0x65bf('0xdf'))[_0x65bf('0xe0')](path['join'](__dirname,'../../components/import/cm/csv'),[_0x56cba6,_0x1523d2[_0x65bf('0x9b')]['binding_keys'],_0x1523d2[_0x65bf('0x9b')][_0x65bf('0xd5')],_0x1523d2['body'][_0x65bf('0x81')],_0x1523d2['body']['CompanyId'],_0x1523d2[_0x65bf('0x9b')][_0x65bf('0xb6')],_0x1523d2['body']['socket_timestamp']]);return _0x654635[_0x65bf('0x20')](0xc8)['json']({'message':_0x65bf('0xe1'),'pid':_0x454a78[_0x65bf('0xe2')]});}catch(_0x43ab6d){return _0x654635[_0x65bf('0x20')](0x1f4)['send'](_0x43ab6d);}};exports[_0x65bf('0xe3')]=function(_0x473c37,_0x123d0d,_0x23ac6f){var _0x54bfac=fs[_0x65bf('0xe4')](_0x473c37[_0x65bf('0xe5')][_0x65bf('0x9')]);Papa[_0x65bf('0xe6')](_0x54bfac,{'header':!![],'skipEmptyLines':!![],'preview':0x1,'complete':function(_0x13cb48){return _0x123d0d[_0x65bf('0x20')](0xc8)[_0x65bf('0x22')]({'file':_0x473c37[_0x65bf('0xe5')],'fields':_0x13cb48[_0x65bf('0xe7')][_0x65bf('0x3f')]});}});};exports[_0x65bf('0xe8')]=function(_0x389cb9,_0x30ee1a,_0x2e8803){return db[_0x65bf('0x5a')][_0x65bf('0x9c')]({'raw':!![],'attributes':['id'],'where':{'role':_0x65bf('0x7c')}})['then'](function(_0x57eda5){var _0x48f1cb=![];if(!_0x389cb9[_0x65bf('0x9b')][_0x65bf('0x81')]){throw new Error(_0x65bf('0xd2'));}if(!_0x389cb9[_0x65bf('0x9b')][_0x65bf('0xe9')][_0x65bf('0xc3')]){throw new Error('No\x20phone\x20column\x20specified');}if(!_0x389cb9['body'][_0x65bf('0xe9')][_0x65bf('0xd9')]){throw new Error('No\x20firstName\x20column\x20specified');}if(!_0x389cb9[_0x65bf('0x9b')][_0x65bf('0xea')]){throw new Error('Unable\x20to\x20synchronize\x20socket,\x20no\x20timestamp\x20passed');}var _0x2a5c8f=require(_0x65bf('0xdf'))[_0x65bf('0xe0')](path['join'](__dirname,'../../components/import/cm/csv2'),[_0x389cb9[_0x65bf('0xb9')]['id'],JSON[_0x65bf('0xeb')](_0x389cb9['body']),JSON[_0x65bf('0xeb')](_0x57eda5)]);_0x2a5c8f['on']('message',function(_0x127059){_0x48f1cb=!![];return _0x30ee1a['status'](0xc8)[_0x65bf('0x22')]({'message':_0x65bf('0xec'),'pid':_0x2a5c8f[_0x65bf('0xe2')]});});_0x2a5c8f['on'](_0x65bf('0xed'),function(_0x3d37a2){if(_0x3d37a2&&!_0x48f1cb){return _0x30ee1a['status'](0x1f4)[_0x65bf('0x22')]({'message':_0x65bf('0xee'),'pid':_0x2a5c8f[_0x65bf('0xe2')]});}});})['catch'](handleError(_0x30ee1a,null));};exports[_0x65bf('0xef')]=function(_0x7e8795,_0x44a337){var _0x1ca473=[_0x65bf('0xf0'),'chat','sms','openchannel',_0x65bf('0xf1'),_0x65bf('0xf2'),_0x65bf('0xf3')];var _0x4e404={'offset':0x0,'order':qs[_0x65bf('0x42')]('-createdAt')},_0x428886={'count':0x0,'rows':[]};Promise[_0x65bf('0x7a')]()[_0x65bf('0x2b')](function(){if(_0x7e8795[_0x65bf('0x3b')][_0x65bf('0xf4')]){if(!_[_0x65bf('0xf5')](_0x1ca473,_0x7e8795[_0x65bf('0x3b')][_0x65bf('0xf4')]['toLowerCase']())){throw new Error(_0x65bf('0xf6'));}_0x1ca473=[_0x7e8795['query'][_0x65bf('0xf4')][_0x65bf('0xf7')]()];}if(_0x7e8795[_0x65bf('0x3b')][_0x65bf('0xf8')]){try{var _0x5debb7=JSON[_0x65bf('0xe6')](_0x7e8795['query'][_0x65bf('0xf8')]);if(!moment(_0x5debb7[_0x65bf('0x47')])[_0x65bf('0xf9')]()){throw new Error(_0x65bf('0xfa'));}if(!moment(_0x5debb7['to'])['isValid']()){throw new Error(_0x65bf('0xfb'));}}catch(_0x175694){throw new Error('Invalid\x20createdAt\x20filter');}}if(!_0x7e8795[_0x65bf('0x3b')]['hasOwnProperty'](_0x65bf('0xc7'))){_0x4e404[_0x65bf('0x24')]=qs[_0x65bf('0x24')](_0x7e8795[_0x65bf('0x3b')]['limit']||0xa);_0x4e404[_0x65bf('0x23')]=qs[_0x65bf('0x23')](_0x7e8795[_0x65bf('0x3b')][_0x65bf('0x23')]);}var _0x1e45e3=_0x1ca473['map'](function(_0x133c3b){if(_0x133c3b==='voice'){var _0x5ba23f={'attributes':['id',_0x65bf('0xfc'),_0x65bf('0x62'),_0x65bf('0xfd'),'destination',_0x65bf('0xfe'),'starttime','endtime',_0x65bf('0xff'),_0x65bf('0x100'),'createdAt',_0x65bf('0x101'),_0x65bf('0x102'),_0x65bf('0x103')],'where':{'ContactId':_0x7e8795[_0x65bf('0xb9')]['id']},'include':[{'model':db['User'],'as':'User','attributes':['id',_0x65bf('0x2d'),_0x65bf('0x104'),'alias']}],'order':[[_0x65bf('0x105'),_0x65bf('0x106')]]};if(_0x7e8795[_0x65bf('0x3b')]['range']){_0x5ba23f[_0x65bf('0x43')][_0x65bf('0x105')]={'$gte':_0x5debb7[_0x65bf('0x47')],'$lte':_0x5debb7['to']};}return db['VoiceCallReport'][_0x65bf('0x107')](_0x5ba23f)['then'](function(_0x2e4eaf){_0x428886[_0x65bf('0x84')]+=_0x2e4eaf['count'];return _['map'](_0x2e4eaf[_0x65bf('0x91')],function(_0x774bc6){var _0x74cdbf=_0x774bc6[_0x65bf('0x9d')]({'plain':!![]});_0x74cdbf[_0x65bf('0xf4')]=_0x133c3b;if(_0x74cdbf[_0x65bf('0x5a')]){_0x74cdbf[_0x65bf('0x5a')]={'id':_0x74cdbf[_0x65bf('0x5a')]['id'],'name':_0x74cdbf['User'][_0x65bf('0x2d')],'fullname':_0x74cdbf['User']['fullname'],'alias':_0x74cdbf['User']['alias']};}return _0x74cdbf;});});}else{var _0x43e6c1=_[_0x65bf('0x108')](_0x133c3b)+(_0x133c3b===_0x65bf('0x109')?_0x65bf('0x10a'):_0x65bf('0x10b'));var _0x593a64={'attributes':['id',_0x65bf('0x10c'),_0x65bf('0x10d'),_0x65bf('0x105'),_0x65bf('0x100'),_0x65bf('0x10e'),_0x65bf('0x10f'),_0x65bf('0x110'),_0x65bf('0x111'),_0x43e6c1+'Id'],'where':{'ContactId':_0x7e8795[_0x65bf('0xb9')]['id']},'include':[{'model':db[_0x43e6c1],'as':_0x65bf('0x10b'),'attributes':['id',_0x65bf('0x2d'),_0x65bf('0x112')]},{'model':db['User'],'as':'Owner','attributes':['id',_0x65bf('0x2d'),_0x65bf('0x104')]},{'model':db[_0x65bf('0x54')],'as':_0x65bf('0x90'),'attributes':['id',_0x65bf('0x2d'),_0x65bf('0xba')],'through':{'attributes':[]}}],'order':[[_0x65bf('0x105'),_0x65bf('0x106')]]};if(_0x7e8795['query']['range']){_0x593a64['where'][_0x65bf('0x105')]={'$gte':_0x5debb7[_0x65bf('0x47')],'$lte':_0x5debb7['to']};}switch(_0x133c3b){case _0x65bf('0x109'):_0x593a64[_0x65bf('0x3e')][_0x65bf('0x35')](_0x65bf('0x113'),_0x65bf('0x114'),'customerPort',_0x65bf('0x115'),_0x65bf('0x116'),'ratingMessage',_0x65bf('0x117'),_0x65bf('0x118'),_0x65bf('0x119'));break;case _0x65bf('0xf0'):_0x593a64['attributes'][_0x65bf('0x35')](_0x65bf('0x11a'),_0x65bf('0x11b'));break;case _0x65bf('0x11c'):_0x593a64[_0x65bf('0x3e')][_0x65bf('0x35')](_0x65bf('0x11d'),_0x65bf('0x11e'));break;}return db[_[_0x65bf('0x108')](_0x133c3b)+'Interaction']['findAndCountAll'](_0x593a64)[_0x65bf('0x2b')](function(_0x241096){_0x428886[_0x65bf('0x84')]+=_0x241096[_0x65bf('0x84')];return _[_0x65bf('0x57')](_0x241096[_0x65bf('0x91')],function(_0x142fbf){var _0x2e97f4=_0x142fbf['get']({'plain':!![]});_0x2e97f4[_0x65bf('0xf4')]=_0x133c3b;if(_0x2e97f4[_0x65bf('0x11f')]){_0x2e97f4['Owner']={'id':_0x2e97f4[_0x65bf('0x11f')]['id'],'name':_0x2e97f4[_0x65bf('0x11f')][_0x65bf('0x2d')],'fullname':_0x2e97f4[_0x65bf('0x11f')][_0x65bf('0x104')]};}return _0x2e97f4;});});}});return Promise['all'](_0x1e45e3);})[_0x65bf('0x2b')](function(_0x40509b){return _(_0x40509b)[_0x65bf('0x120')]()[_0x65bf('0x121')](_0x65bf('0x105'))['reverse']()['value']();})[_0x65bf('0x2b')](function(_0x46b9a8){_0x428886[_0x65bf('0x91')]=_0x4e404['limit']?_0x46b9a8['slice'](_0x4e404[_0x65bf('0x23')],_0x4e404['offset']+_0x4e404[_0x65bf('0x24')]):_0x46b9a8;return _0x428886;})[_0x65bf('0x2b')](respondWithFilteredResult(_0x44a337,_0x4e404))['catch'](handleError(_0x44a337,null));};