20a3481c9d47433ca91423cfcf9dec9da480810a
[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 _0xa9e0=['id\x20=\x20?','toParam','values','CmHopper','phone','getTags','findOne','rawAttributes','options','nolimit','setTags','ids','getHoppers','ContactId','includeAll','getHopperHistories','include','getHopperFinals','getJscriptySessions','uploadCsv','binding_keys','No\x20association\x20keys\x20specified!','binding_values','No\x20association\x20values\x20specified!','Incorrect\x20binding\x20parameters\x20passed!','No\x20phone\x20column\x20specified','firstName','No\x20firstName\x20column\x20specified','server/files/tmp','filename','chmodSync','child_process','CompanyId','socket_timestamp','json','File\x20uploaded\x20correctly!','pid','upload','createReadStream','file','parse','meta','import','agent','No\x20ListId\x20specified','binding','Unable\x20to\x20synchronize\x20socket,\x20no\x20timestamp\x20passed','fork','../../components/import/cm/csv2','stringify','message','start\x20child\x20process\x20correctly!','exit','error\x20child\x20process','html-pdf','eml-format','rimraf','request-promise','bluebird','mustache','util','path','sox','ejs','lodash','squel','desk.js','papaparse','ioredis','../../components/auth/service','../../components/parsers/qs','../../components/parsers/advancedSearch','../../config/license/hardware','../../config/license/util','../../mysqldb','redis','defaults','localhost','./cmContact.socket','register','status','count','offset','limit','set','Content-Range','update','destroy','then','sendStatus','stack','name','send','index','CmContact','describe','keys','length','startsWith','cf_','push','CmCustomField','trimStart','all','fieldType','type','model','filters','intersection','query','fields','attributes','hasOwnProperty','sort','where','pick','select','field','from','tools_tags','cm_contacts','left_join','cm_user_has_contacts','uc.CmContactId\x20=\x20c.id','cm_contact_has_tags','ct.CmContactId\x20=\x20c.id','t.id\x20=\x20ct.TagId','expr','search','parseSearch','conditions','Tag','value','split','map','forEach','CONCAT(\x27,\x27,\x20`TagIds`,\x20\x27,\x27)\x20LIKE\x20?','User','and','uc.UserId\x20=\x20?','dateOfBirth','datetime','DATE','start','end','isNil','Contact','ListId','c.ListId\x20IN\x20?','concat','\x20=\x20?','isArray','tag','filter','replace','\x27\x27\x27\x27','MATCH\x20(c.firstName,\x20c.lastName,\x20c.phone,\x20c.mobile,\x20c.fax,\x20c.email)\x20AGAINST\x20(?\x20IN\x20BOOLEAN\x20MODE)','getFullTextValue','isNumeric','c.phone\x20LIKE\x20?','c.mobile\x20LIKE\x20?','isEmail','c.firstName\x20LIKE\x20?','group','Sequelize','QueryTypes','SELECT','clone','c.id','order','DESC','isEmpty','having','resolve','user','getLists','sequelize','toString','keyBy','merge','c.phone','c.mobile','c.fax','c.email','c.ListId','c.deletedAt','GROUP_CONCAT(DISTINCT\x20t.id)','TagIds','Tags','rows','catch','find','params','columnName','findAll','displayName','alias','body','get','mergeWith','tags','join','info','[CmContact][merge]\x20to\x20%s\x20from\x20%s','[CmContact][merge][destroy][CmHopper],\x20%s','[CmContact][merge][destroy][CmHopperBlack],\x20%s','create','ChatInteraction','ChatMessage','ChatOfflineMessage','MailInteraction','MailMessage','SmsInteraction','SmsMessage','FaxInteraction','FaxMessage','OpenchannelMessage','CmHopperFinal','CmHopperHistory','VoiceCallReport','FaxQueueReport','SmsQueueReport','JscriptySessionReport','bulkCreate','duplicates','$or','findOrCreate','spread','error','show','color','$and','omit','format','cf_%d','pickBy','setFields'];(function(_0x1078e7,_0x56c88e){var _0x1f3a1f=function(_0x3d95c4){while(--_0x3d95c4){_0x1078e7['push'](_0x1078e7['shift']());}};_0x1f3a1f(++_0x56c88e);}(_0xa9e0,0x123));var _0x0a9e=function(_0x4b7b62,_0x4920a9){_0x4b7b62=_0x4b7b62-0x0;var _0x2280df=_0xa9e0[_0x4b7b62];return _0x2280df;};'use strict';var pdf=require(_0x0a9e('0x0'));var emlformat=require(_0x0a9e('0x1'));var rimraf=require(_0x0a9e('0x2'));var zipdir=require('zip-dir');var jsonpatch=require('fast-json-patch');var rp=require(_0x0a9e('0x3'));var moment=require('moment');var BPromise=require(_0x0a9e('0x4'));var Mustache=require(_0x0a9e('0x5'));var util=require(_0x0a9e('0x6'));var path=require(_0x0a9e('0x7'));var sox=require(_0x0a9e('0x8'));var csv=require('to-csv');var ejs=require(_0x0a9e('0x9'));var fs=require('fs');var _=require(_0x0a9e('0xa'));var squel=require(_0x0a9e('0xb'));var crypto=require('crypto');var jsforce=require('jsforce');var deskjs=require(_0x0a9e('0xc'));var toCsv=require('to-csv');var querystring=require('querystring');var Papa=require(_0x0a9e('0xd'));var Redis=require(_0x0a9e('0xe'));var authService=require(_0x0a9e('0xf'));var qs=require(_0x0a9e('0x10'));var as=require(_0x0a9e('0x11'));var hardwareService=require(_0x0a9e('0x12'));var logger=require('../../config/logger')('api');var utils=require('../../config/utils');var config=require('../../config/environment');var licenseUtil=require(_0x0a9e('0x13'));var db=require(_0x0a9e('0x14'))['db'];config[_0x0a9e('0x15')]=_[_0x0a9e('0x16')](config[_0x0a9e('0x15')],{'host':_0x0a9e('0x17'),'port':0x18eb});var socket=require('socket.io-emitter')(new Redis(config[_0x0a9e('0x15')]));require(_0x0a9e('0x18'))[_0x0a9e('0x19')](socket);function respondWithStatusCode(_0x281129,_0x44dcfd){_0x44dcfd=_0x44dcfd||0xcc;return function(_0x4d5611){if(_0x4d5611){return _0x281129['sendStatus'](_0x44dcfd);}return _0x281129[_0x0a9e('0x1a')](_0x44dcfd)['end']();};}function respondWithResult(_0x1985b6,_0x519dfd){_0x519dfd=_0x519dfd||0xc8;return function(_0x16033c){if(_0x16033c){return _0x1985b6[_0x0a9e('0x1a')](_0x519dfd)['json'](_0x16033c);}};}function respondWithFilteredResult(_0x225616,_0x5a0a06){return function(_0x459eb1){if(_0x459eb1){var _0x478723=_0x459eb1[_0x0a9e('0x1b')],_0x106033=_0x5a0a06[_0x0a9e('0x1c')],_0x205fd6=_0x5a0a06[_0x0a9e('0x1c')]+_0x5a0a06[_0x0a9e('0x1d')],_0x31b1ca;if(_0x205fd6>=_0x478723){_0x205fd6=_0x478723;_0x31b1ca=0xc8;}else{_0x31b1ca=0xce;}_0x225616[_0x0a9e('0x1a')](_0x31b1ca);return _0x225616[_0x0a9e('0x1e')](_0x0a9e('0x1f'),_0x106033+'-'+_0x205fd6+'/'+_0x478723)['json'](_0x459eb1);}return null;};}function patchUpdates(_0x2c3407){return function(_0x155cce){try{jsonpatch['apply'](_0x155cce,_0x2c3407,!![]);}catch(_0x20f109){return BPromise['reject'](_0x20f109);}return _0x155cce['save']();};}function saveUpdates(_0x3a02e1,_0x432e56){return function(_0x38e7c4){if(_0x38e7c4){return _0x38e7c4[_0x0a9e('0x20')](_0x3a02e1)['then'](function(_0xfb6e48){return _0xfb6e48;});}return null;};}function removeEntity(_0x2fb0e4,_0x3b45bc){return function(_0x4d00e6){if(_0x4d00e6){return _0x4d00e6[_0x0a9e('0x21')]()[_0x0a9e('0x22')](function(){_0x2fb0e4[_0x0a9e('0x1a')](0xcc)['end']();});}};}function handleEntityNotFound(_0x59181e,_0x197ec0){return function(_0x3a8e58){if(!_0x3a8e58){_0x59181e[_0x0a9e('0x23')](0x194);}return _0x3a8e58;};}function handleError(_0x33161b,_0x526cf3){_0x526cf3=_0x526cf3||0x1f4;return function(_0x384319){logger['error'](_0x384319[_0x0a9e('0x24')]);if(_0x384319['name']){delete _0x384319[_0x0a9e('0x25')];}_0x33161b[_0x0a9e('0x1a')](_0x526cf3)[_0x0a9e('0x26')](_0x384319);};}exports[_0x0a9e('0x27')]=function(_0x140511,_0x1538a4){var _0x11c3b6={},_0x14de77={},_0x5a101a={'count':0x0,'rows':[]};return db[_0x0a9e('0x28')][_0x0a9e('0x29')]()[_0x0a9e('0x22')](function(_0x2ec755){var _0x5c877d=[];for(var _0x15b200=0x0;_0x15b200<Object[_0x0a9e('0x2a')](_0x2ec755)[_0x0a9e('0x2b')];_0x15b200++){var _0x824a4f=Object[_0x0a9e('0x2a')](_0x2ec755)[_0x15b200];if(_[_0x0a9e('0x2c')](_0x824a4f,_0x0a9e('0x2d'))){_0x5c877d[_0x0a9e('0x2e')](db[_0x0a9e('0x2f')]['findOne']({'where':{'id':_[_0x0a9e('0x30')](_0x824a4f,'cf_')},'raw':!![]}));}}return BPromise[_0x0a9e('0x31')](_0x5c877d)[_0x0a9e('0x22')](function(_0x1122db){for(var _0x33bdb7=0x0;_0x33bdb7<_0x1122db[_0x0a9e('0x2b')];_0x33bdb7++){if(_0x1122db[_0x33bdb7]){var _0x5180f1=_0x0a9e('0x2d')+_0x1122db[_0x33bdb7]['id'];var _0x46f0a5=_0x2ec755[_0x5180f1];_0x46f0a5[_0x0a9e('0x32')]=_0x1122db[_0x33bdb7][_0x0a9e('0x33')];}}return _0x2ec755;});})[_0x0a9e('0x22')](function(_0x409319){_0x14de77[_0x0a9e('0x34')]=_[_0x0a9e('0x2a')](_0x409319);_0x14de77['query']=_[_0x0a9e('0x2a')](_0x140511['query']);_0x14de77[_0x0a9e('0x35')]=_[_0x0a9e('0x36')](_0x14de77[_0x0a9e('0x34')],_0x14de77[_0x0a9e('0x37')]);_0x11c3b6['attributes']=_[_0x0a9e('0x36')](_0x14de77[_0x0a9e('0x34')],qs[_0x0a9e('0x38')](_0x140511[_0x0a9e('0x37')]['fields']));_0x11c3b6['attributes']=_0x11c3b6[_0x0a9e('0x39')]['length']?_0x11c3b6[_0x0a9e('0x39')]:_0x14de77[_0x0a9e('0x34')];if(!_0x140511[_0x0a9e('0x37')][_0x0a9e('0x3a')]('nolimit')){_0x11c3b6[_0x0a9e('0x1d')]=qs[_0x0a9e('0x1d')](_0x140511[_0x0a9e('0x37')]['limit']);_0x11c3b6[_0x0a9e('0x1c')]=qs[_0x0a9e('0x1c')](_0x140511[_0x0a9e('0x37')]['offset']);}_0x11c3b6['order']=qs[_0x0a9e('0x3b')](_0x140511[_0x0a9e('0x37')]['sort']);_0x11c3b6[_0x0a9e('0x3c')]=qs[_0x0a9e('0x35')](_[_0x0a9e('0x3d')](_0x140511[_0x0a9e('0x37')],_0x14de77['filters']),_0x409319);var _0x5a594b=[];var _0x15e37d=squel[_0x0a9e('0x3e')]()['field']('id')[_0x0a9e('0x3f')](_0x0a9e('0x25'))[_0x0a9e('0x3f')]('color')[_0x0a9e('0x40')](_0x0a9e('0x41'));var _0x274e8e=squel[_0x0a9e('0x3e')]()[_0x0a9e('0x40')](_0x0a9e('0x42'),'c')[_0x0a9e('0x43')](_0x0a9e('0x44'),'uc',_0x0a9e('0x45'))[_0x0a9e('0x43')](_0x0a9e('0x46'),'ct',_0x0a9e('0x47'))[_0x0a9e('0x43')](_0x0a9e('0x41'),'t',_0x0a9e('0x48'))['where']('c.deletedAt\x20IS\x20NULL');var _0x473fdc=squel[_0x0a9e('0x49')]();var _0x405c8f=[];var _0x315881=squel[_0x0a9e('0x49')]();var _0xc9a702;if(_0x140511[_0x0a9e('0x37')][_0x0a9e('0x4a')]){_0xc9a702=as[_0x0a9e('0x4b')](_0x140511[_0x0a9e('0x37')][_0x0a9e('0x4a')]);var _0x35ed4a=_0xc9a702['sqlOperator'];for(var _0x117c99=0x0;_0x117c99<_0xc9a702[_0x0a9e('0x4c')][_0x0a9e('0x2b')];_0x117c99++){var _0xfbd5ad=_0xc9a702[_0x0a9e('0x4c')][_0x117c99];var _0xbe9d19='c';var _0x21eb86=_(_0x409319)[_0x0a9e('0x2a')]()['find'](function(_0x2e9d90){return _0x2e9d90===_0xfbd5ad['field'];});if(_0x21eb86)_0x21eb86=_0x409319[_0xfbd5ad[_0x0a9e('0x3f')]];if(!_0x21eb86){if(_0xfbd5ad[_0x0a9e('0x3f')]===_0x0a9e('0x4d')){var _0x562fb4=_0xfbd5ad[_0x0a9e('0x4e')][_0x0a9e('0x4f')](',')[_0x0a9e('0x50')](function(_0x34aa5a){return Number(_0x34aa5a);});_0x562fb4[_0x0a9e('0x51')](function(_0x37be73){_0x315881['or'](_0x0a9e('0x52'),'%,'+_0x37be73+',%');});_0x405c8f=_['union'](_0x405c8f,_0x562fb4);}else if(_0xfbd5ad[_0x0a9e('0x3f')]===_0x0a9e('0x53')){_0x473fdc[_0x0a9e('0x54')](_0x0a9e('0x55'),_0xfbd5ad[_0x0a9e('0x4e')]);}}else{if(_0xfbd5ad[_0x0a9e('0x3f')]===_0x0a9e('0x56')||_0x21eb86[_0x0a9e('0x32')]===_0x0a9e('0x57'))_0xfbd5ad['castTo']=_0x0a9e('0x58');var _0x3fe430=as['buildExpression'](_0xbe9d19,_0x21eb86['type'],_0xfbd5ad);_0x473fdc[_0x35ed4a](_0x3fe430['text'],_0x3fe430[_0x0a9e('0x4e')][_0x0a9e('0x59')],_0x3fe430[_0x0a9e('0x4e')][_0x0a9e('0x5a')]);}}}else{var _0x61bb17=_(Object[_0x0a9e('0x2a')](_0x140511[_0x0a9e('0x37')]))[_0x0a9e('0x50')](function(_0x5d38ae){return _0x409319['hasOwnProperty'](_0x5d38ae)?_0x5d38ae:undefined;})['filter'](function(_0x39d77d){return!_[_0x0a9e('0x5b')](_0x39d77d);})[_0x0a9e('0x4e')]();if(_0x140511['query'][_0x0a9e('0x5c')])_0x61bb17[_0x0a9e('0x2e')]('Contact');if(!_['isEmpty'](_0x61bb17)){_0x61bb17[_0x0a9e('0x51')](function(_0x59c6ff){if(_0x59c6ff===_0x0a9e('0x5d')){_0x274e8e['where'](_0x0a9e('0x5e'),[][_0x0a9e('0x5f')](_0x140511[_0x0a9e('0x37')][_0x59c6ff]));}else if(_0x59c6ff==='Contact'){var _0x2f82da='%'+_0x140511[_0x0a9e('0x37')][_0x59c6ff]+'%';_0x274e8e['where']('CONCAT_WS(\x27\x20\x27,\x20c.firstName,\x20c.lastName,\x20c.email)\x20LIKE\x20?',_0x2f82da);}else{_0x274e8e[_0x0a9e('0x3c')]('c.'+_0x59c6ff+_0x0a9e('0x60'),_0x140511['query'][_0x59c6ff]);}});}if(_0x140511[_0x0a9e('0x37')]['tag']){_0x405c8f=_[_0x0a9e('0x61')](_0x140511['query'][_0x0a9e('0x62')])?_0x140511['query']['tag']:new Array(_0x140511['query'][_0x0a9e('0x62')]);_0x405c8f['forEach'](function(_0x2f7092){_0x315881['or'](_0x0a9e('0x52'),'%,'+_0x2f7092+',%');});}if(_0x140511[_0x0a9e('0x37')][_0x0a9e('0x63')]){var _0x232830=_0x140511[_0x0a9e('0x37')][_0x0a9e('0x63')][_0x0a9e('0x64')]('\x5c','\x5c\x5c')['replace']('\x27\x27',_0x0a9e('0x65'));if(_0x232830[_0x0a9e('0x4f')]('\x20')[_0x0a9e('0x2b')]>0x1){_0x473fdc['or'](_0x0a9e('0x66'),qs[_0x0a9e('0x67')](_0x232830),null);}else{if(qs[_0x0a9e('0x68')](_0x232830)){_0x473fdc['or']('c.id\x20LIKE\x20?',_0x232830+'%');_0x473fdc['or'](_0x0a9e('0x69'),_0x232830+'%');_0x473fdc['or'](_0x0a9e('0x6a'),_0x232830+'%');_0x473fdc['or']('c.fax\x20LIKE\x20?',_0x232830+'%');}else if(qs[_0x0a9e('0x6b')](_0x232830)){_0x473fdc['or']('c.email\x20LIKE\x20?',_0x232830+'%');}else{_0x473fdc['or'](_0x0a9e('0x6c'),'%'+_0x232830+'%');_0x473fdc['or']('c.lastName\x20LIKE\x20?','%'+_0x232830+'%');_0x473fdc['or']('c.email\x20LIKE\x20?','%'+_0x232830+'%');}}}}_0x274e8e['where'](_0x473fdc);_0x274e8e[_0x0a9e('0x6d')]('c.id');var _0x2244d6={'type':db[_0x0a9e('0x6e')][_0x0a9e('0x6f')][_0x0a9e('0x70')],'raw':!![]};var _0x1cca9f=_0x274e8e[_0x0a9e('0x71')]()['field'](_0x0a9e('0x72'));if(_0x11c3b6['order']){_0x11c3b6[_0x0a9e('0x73')][_0x0a9e('0x51')](function(_0x51aaf7){_0x274e8e['order']('c.'+_0x51aaf7[0x0],_0x51aaf7[0x1]===_0x0a9e('0x74')?![]:!![]);});}if(!_[_0x0a9e('0x75')](_0x405c8f)){_0x274e8e[_0x0a9e('0x76')](_0x315881);_0x1cca9f[_0x0a9e('0x3c')]('t.id\x20IN\x20?',_0x405c8f);}BPromise[_0x0a9e('0x77')]()[_0x0a9e('0x22')](function(){if(_0xc9a702&&!_['some'](_0xc9a702[_0x0a9e('0x4c')],[_0x0a9e('0x3f'),_0x0a9e('0x53')])){return _0x140511[_0x0a9e('0x78')][_0x0a9e('0x79')]({'attributes':['id'],'raw':!![]})['then'](function(_0x176840){if(_[_0x0a9e('0x75')](_0x176840)){_0x1cca9f[_0x0a9e('0x3c')]('c.ListId\x20IS\x20NULL');_0x274e8e[_0x0a9e('0x3c')]('c.ListId\x20IS\x20NULL');}else{_0x1cca9f['where'](_0x0a9e('0x5e'),_[_0x0a9e('0x50')](_0x176840,'id'));_0x274e8e[_0x0a9e('0x3c')](_0x0a9e('0x5e'),_[_0x0a9e('0x50')](_0x176840,'id'));}});}else{return;}})[_0x0a9e('0x22')](function(){db[_0x0a9e('0x7a')][_0x0a9e('0x37')](_0x1cca9f[_0x0a9e('0x7b')](),_0x2244d6)[_0x0a9e('0x22')](function(_0x2e89b7){_0x5a101a[_0x0a9e('0x1b')]=_0x2e89b7[_0x0a9e('0x2b')];if(_0x5a101a[_0x0a9e('0x1b')]===0x0)return[];return db[_0x0a9e('0x7a')][_0x0a9e('0x37')](_0x15e37d[_0x0a9e('0x7b')](),_0x2244d6);})[_0x0a9e('0x22')](function(_0x5150a4){_0x5a594b=_[_0x0a9e('0x7c')](_0x5150a4,'id');_0x2244d6=_[_0x0a9e('0x7d')](_0x2244d6,{'model':db[_0x0a9e('0x28')],'mapToModel':!![],'raw':!![],'nest':!![]});if(_0x140511['query'][_0x0a9e('0x38')]){_0x11c3b6[_0x0a9e('0x39')]['forEach'](function(_0x83f0b2){_0x274e8e[_0x0a9e('0x3f')]('c.'+_0x83f0b2);});}else{_0x274e8e[_0x0a9e('0x3f')](_0x0a9e('0x72'));_0x274e8e[_0x0a9e('0x3f')]('c.firstName');_0x274e8e['field']('c.lastName');_0x274e8e[_0x0a9e('0x3f')](_0x0a9e('0x7e'));_0x274e8e[_0x0a9e('0x3f')](_0x0a9e('0x7f'));_0x274e8e[_0x0a9e('0x3f')](_0x0a9e('0x80'));_0x274e8e[_0x0a9e('0x3f')](_0x0a9e('0x81'));_0x274e8e['field'](_0x0a9e('0x82'));_0x274e8e[_0x0a9e('0x3f')](_0x0a9e('0x83'));_0x274e8e['field'](_0x0a9e('0x84'),'TagIds');}if(_0x11c3b6[_0x0a9e('0x1d')])_0x274e8e[_0x0a9e('0x1d')](_0x11c3b6['limit']);if(_0x11c3b6[_0x0a9e('0x1c')])_0x274e8e[_0x0a9e('0x1c')](_0x11c3b6[_0x0a9e('0x1c')]);return db[_0x0a9e('0x7a')]['query'](_0x274e8e[_0x0a9e('0x7b')](),_0x2244d6);})[_0x0a9e('0x22')](function(_0x371533){_0x371533[_0x0a9e('0x51')](function(_0x5b7fc3){if(_0x5b7fc3[_0x0a9e('0x85')]){_0x5b7fc3[_0x0a9e('0x86')]=[];_0x5b7fc3[_0x0a9e('0x85')][_0x0a9e('0x4f')](',')['forEach'](function(_0x290d43){_0x5b7fc3[_0x0a9e('0x86')][_0x0a9e('0x2e')](_0x5a594b[_0x290d43]);});}delete _0x5b7fc3[_0x0a9e('0x85')];});_0x5a101a[_0x0a9e('0x87')]=_0x371533;return _0x5a101a;})[_0x0a9e('0x22')](respondWithFilteredResult(_0x1538a4,_0x11c3b6));});})[_0x0a9e('0x88')](handleError(_0x1538a4,null));};exports[_0x0a9e('0x21')]=function(_0x1a7b03,_0x336dc3){return db[_0x0a9e('0x28')][_0x0a9e('0x89')]({'where':{'id':_0x1a7b03[_0x0a9e('0x8a')]['id']}})[_0x0a9e('0x22')](handleEntityNotFound(_0x336dc3,null))['then'](removeEntity(_0x336dc3,null))[_0x0a9e('0x88')](handleError(_0x336dc3,null));};exports[_0x0a9e('0x29')]=function(_0xc599b3,_0x563627){return db[_0x0a9e('0x28')][_0x0a9e('0x29')]()[_0x0a9e('0x22')](function(_0x2b9463){delete _0x2b9463['tags'];for(var _0x541e80=0x0;_0x541e80<Object[_0x0a9e('0x2a')](_0x2b9463)[_0x0a9e('0x2b')];_0x541e80++){var _0x4c54fa=Object[_0x0a9e('0x2a')](_0x2b9463)[_0x541e80];if(!_['startsWith'](_0x4c54fa,_0x0a9e('0x2d'))){_0x2b9463[_0x4c54fa][_0x0a9e('0x8b')]=_0x4c54fa;_0x2b9463[_0x4c54fa]['displayName']=_0x4c54fa;}}return _0x2b9463;})[_0x0a9e('0x22')](function(_0x41cf12){var _0x2d2286={'where':{'$or':[{'ListId':_0xc599b3[_0x0a9e('0x37')]['id']},{'ListId':null}]},'raw':!![]};return db[_0x0a9e('0x2f')][_0x0a9e('0x8c')](_0x2d2286)[_0x0a9e('0x22')](function(_0x482ca2){for(var _0x2973d3=0x0;_0x2973d3<_0x482ca2[_0x0a9e('0x2b')];_0x2973d3++){var _0x45c109=_0x0a9e('0x2d')+_0x482ca2[_0x2973d3]['id'];_0x41cf12[_0x45c109]['columnName']=_0x45c109;_0x41cf12[_0x45c109][_0x0a9e('0x8d')]=_0x482ca2[_0x2973d3][_0x0a9e('0x8e')];_0x41cf12[_0x45c109]['custom']={'type':_0x482ca2[_0x2973d3][_0x0a9e('0x33')],'values':_0x482ca2[_0x2973d3]['values']};}Object[_0x0a9e('0x2a')](_0x41cf12)[_0x0a9e('0x51')](function(_0x3003eb){if(!_0x41cf12[_0x3003eb][_0x0a9e('0x3a')]('columnName')){delete _0x41cf12[_0x3003eb];}});return _0x41cf12;});})['then'](respondWithResult(_0x563627,null))[_0x0a9e('0x88')](handleError(_0x563627,null));};exports[_0x0a9e('0x7d')]=function(_0x94dcf5,_0x5ac73d){var _0x3b4a9f;var _0x36e975;var _0x524e38;if(_0x94dcf5['body']['id']){delete _0x94dcf5[_0x0a9e('0x8f')]['id'];}return db['CmContact']['findAll']({'where':{'id':[_0x94dcf5['body']['to'],_0x94dcf5[_0x0a9e('0x8f')][_0x0a9e('0x40')]]}})[_0x0a9e('0x22')](function(_0x3bfadf){if(_0x3bfadf){if(_0x3bfadf[_0x0a9e('0x2b')]!==0x2){return null;}_0x3bfadf[0x0]=_0x3bfadf[0x0][_0x0a9e('0x90')]({'plain':!![]});_0x3bfadf[0x1]=_0x3bfadf[0x1]['get']({'plain':!![]});delete _0x3bfadf[0x0]['id'];delete _0x3bfadf[0x1]['id'];return _[_0x0a9e('0x91')](_0x3bfadf[0x0],_0x3bfadf[0x1],function(_0x5955f1,_0x2871c1){if(Array[_0x0a9e('0x61')](_0x2871c1)&&!_0x2871c1[_0x0a9e('0x2b')]){return _0x5955f1;}else if(!_0x2871c1){return _0x5955f1;}});}})[_0x0a9e('0x22')](handleEntityNotFound(_0x5ac73d,null))['then'](function(_0x46c9ac){if(_0x46c9ac){if(_0x46c9ac[_0x0a9e('0x92')]&&_[_0x0a9e('0x61')](_0x46c9ac['tags'])){_0x46c9ac[_0x0a9e('0x92')]=_0x46c9ac[_0x0a9e('0x92')][_0x0a9e('0x93')]();}logger[_0x0a9e('0x94')](_0x0a9e('0x95'),_0x94dcf5[_0x0a9e('0x8f')]['to'],_0x94dcf5[_0x0a9e('0x8f')][_0x0a9e('0x40')]);return db['CmHopper'][_0x0a9e('0x21')]({'where':{'ContactId':[_0x94dcf5[_0x0a9e('0x8f')]['to'],_0x94dcf5['body'][_0x0a9e('0x40')]]}})[_0x0a9e('0x22')](function(_0x3a1974){logger['info'](_0x0a9e('0x96'),_0x3a1974);return db['CmHopperBlack'][_0x0a9e('0x21')]({'where':{'ContactId':[_0x94dcf5[_0x0a9e('0x8f')]['to'],_0x94dcf5[_0x0a9e('0x8f')][_0x0a9e('0x40')]]}})[_0x0a9e('0x22')](function(_0x16341a){logger[_0x0a9e('0x94')](_0x0a9e('0x97'),_0x16341a);return db['CmContact'][_0x0a9e('0x98')](_0x46c9ac);});});}})[_0x0a9e('0x22')](function(_0x17f692){if(_0x17f692){_0x3b4a9f=_0x17f692;_0x36e975={'ContactId':_0x3b4a9f['id']};_0x524e38={'where':{'ContactId':[_0x94dcf5[_0x0a9e('0x8f')]['to'],_0x94dcf5[_0x0a9e('0x8f')][_0x0a9e('0x40')]]}};return db[_0x0a9e('0x99')][_0x0a9e('0x20')](_0x36e975,_0x524e38);}})[_0x0a9e('0x22')](function(){if(_0x3b4a9f){return db[_0x0a9e('0x9a')][_0x0a9e('0x20')](_0x36e975,_0x524e38);}})[_0x0a9e('0x22')](function(){if(_0x3b4a9f){return db[_0x0a9e('0x9b')]['update'](_0x36e975,_0x524e38);}})[_0x0a9e('0x22')](function(){if(_0x3b4a9f){return db[_0x0a9e('0x9c')][_0x0a9e('0x20')](_0x36e975,_0x524e38);}})[_0x0a9e('0x22')](function(){if(_0x3b4a9f){return db[_0x0a9e('0x9d')]['update'](_0x36e975,_0x524e38);}})[_0x0a9e('0x22')](function(){if(_0x3b4a9f){return db[_0x0a9e('0x9c')]['update'](_0x36e975,_0x524e38);}})[_0x0a9e('0x22')](function(){if(_0x3b4a9f){return db['MailMessage'][_0x0a9e('0x20')](_0x36e975,_0x524e38);}})[_0x0a9e('0x22')](function(){if(_0x3b4a9f){return db[_0x0a9e('0x9e')][_0x0a9e('0x20')](_0x36e975,_0x524e38);}})['then'](function(){if(_0x3b4a9f){return db[_0x0a9e('0x9f')]['update'](_0x36e975,_0x524e38);}})[_0x0a9e('0x22')](function(){if(_0x3b4a9f){return db[_0x0a9e('0xa0')]['update'](_0x36e975,_0x524e38);}})[_0x0a9e('0x22')](function(){if(_0x3b4a9f){return db[_0x0a9e('0xa1')][_0x0a9e('0x20')](_0x36e975,_0x524e38);}})['then'](function(){if(_0x3b4a9f){return db['OpenchannelInteraction'][_0x0a9e('0x20')](_0x36e975,_0x524e38);}})[_0x0a9e('0x22')](function(){if(_0x3b4a9f){return db[_0x0a9e('0xa2')][_0x0a9e('0x20')](_0x36e975,_0x524e38);}})[_0x0a9e('0x22')](function(){if(_0x3b4a9f){return db[_0x0a9e('0xa3')][_0x0a9e('0x20')](_0x36e975,_0x524e38);}})[_0x0a9e('0x22')](function(){if(_0x3b4a9f){return db[_0x0a9e('0xa4')]['update'](_0x36e975,_0x524e38);}})[_0x0a9e('0x22')](function(){if(_0x3b4a9f){return db['ReportAgentPreview'][_0x0a9e('0x20')](_0x36e975,_0x524e38);}})[_0x0a9e('0x22')](function(){if(_0x3b4a9f){return db[_0x0a9e('0xa5')][_0x0a9e('0x20')](_0x36e975,_0x524e38);}})[_0x0a9e('0x22')](function(){if(_0x3b4a9f){return db['ChatQueueReport'][_0x0a9e('0x20')](_0x36e975,_0x524e38);}})[_0x0a9e('0x22')](function(){if(_0x3b4a9f){return db[_0x0a9e('0xa6')][_0x0a9e('0x20')](_0x36e975,_0x524e38);}})[_0x0a9e('0x22')](function(){if(_0x3b4a9f){return db['MailQueueReport']['update'](_0x36e975,_0x524e38);}})[_0x0a9e('0x22')](function(){if(_0x3b4a9f){return db['OpenchannelQueueReport'][_0x0a9e('0x20')](_0x36e975,_0x524e38);}})[_0x0a9e('0x22')](function(){if(_0x3b4a9f){return db[_0x0a9e('0xa7')][_0x0a9e('0x20')](_0x36e975,_0x524e38);}})[_0x0a9e('0x22')](function(){if(_0x3b4a9f){return db[_0x0a9e('0xa8')]['update'](_0x36e975,_0x524e38);}})['then'](function(){if(_0x3b4a9f){return db[_0x0a9e('0x28')]['destroy']({'where':{'id':[_0x94dcf5[_0x0a9e('0x8f')]['to'],_0x94dcf5['body'][_0x0a9e('0x40')]]}});}})['then'](function(){if(_0x3b4a9f){return _0x3b4a9f;}})['then'](respondWithResult(_0x5ac73d,null))[_0x0a9e('0x88')](handleError(_0x5ac73d,null));};exports[_0x0a9e('0x98')]=function(_0x5e9b0b,_0x170af6){return db[_0x0a9e('0x28')][_0x0a9e('0x29')]()[_0x0a9e('0x22')](function(_0x2eb028){if(_0x5e9b0b['body']['tags']&&_[_0x0a9e('0x61')](_0x5e9b0b[_0x0a9e('0x8f')][_0x0a9e('0x92')])){if(_0x5e9b0b[_0x0a9e('0x8f')][_0x0a9e('0x92')]['length']){_0x5e9b0b[_0x0a9e('0x8f')][_0x0a9e('0x92')]=_0x5e9b0b['body'][_0x0a9e('0x92')][_0x0a9e('0x93')](';')+';';}else{_0x5e9b0b[_0x0a9e('0x8f')][_0x0a9e('0x92')]=null;}}else{_0x5e9b0b[_0x0a9e('0x8f')][_0x0a9e('0x92')]=null;}return db[_0x0a9e('0x28')][_0x0a9e('0x98')](_0x5e9b0b[_0x0a9e('0x8f')],{'fields':_[_0x0a9e('0x2a')](_0x2eb028),'raw':!![]});})['then'](respondWithResult(_0x170af6,0xc9))[_0x0a9e('0x88')](handleError(_0x170af6,null));};exports[_0x0a9e('0xa9')]=function(_0x2ada60,_0x1c4232){var _0x1d0b02=[];var _0x547e37=0x0;var _0x500868=0x0;var _0x21902c=0x0;return db[_0x0a9e('0x28')][_0x0a9e('0x29')]()[_0x0a9e('0x22')](function(_0x34f7b5){return BPromise['each'](_0x2ada60[_0x0a9e('0x8f')],function(_0x3c775a){var _0x3450ae={'where':{'$or':[]},'defaults':_0x3c775a,'fields':_['keys'](_0x34f7b5),'raw':!![]};if(_0x3c775a[_0x0a9e('0xaa')]){for(var _0x59aa7b=0x0;_0x59aa7b<_0x3c775a[_0x0a9e('0xaa')]['length'];_0x59aa7b++){var _0x25b745={};_0x25b745[_0x3c775a[_0x0a9e('0xaa')][_0x59aa7b]]=_0x3c775a[_0x3c775a[_0x0a9e('0xaa')][_0x59aa7b]];_0x3450ae['where'][_0x0a9e('0xab')]['push'](_0x25b745);}_0x3450ae[_0x0a9e('0x3c')][_0x0a9e('0x5d')]=_0x3c775a[_0x0a9e('0x5d')];}return db[_0x0a9e('0x28')][_0x0a9e('0xac')](_0x3450ae)[_0x0a9e('0xad')](function(_0x4014c7,_0xe89aaa){if(_0xe89aaa){_0x547e37++;}else{_0x21902c++;}})[_0x0a9e('0x88')](function(_0x27d1f5){console[_0x0a9e('0xae')](_0x27d1f5);_0x500868++;});});})[_0x0a9e('0x22')](function(_0x2415fe){if(_0x2415fe){return{'success':_0x547e37,'failure':_0x500868,'duplicates':_0x21902c};}})[_0x0a9e('0x22')](respondWithResult(_0x1c4232,0xc9))[_0x0a9e('0x88')](handleError(_0x1c4232,null));};exports[_0x0a9e('0xaf')]=function(_0x5b93dd,_0x556443,_0x6eaaf0){var _0x5c4be0;return db[_0x0a9e('0x28')][_0x0a9e('0x29')]()['then'](function(_0x1a3754){return db[_0x0a9e('0x28')][_0x0a9e('0x89')]({'where':{'id':_0x5b93dd[_0x0a9e('0x8a')]['id']},'include':[{'model':db['Tag'],'as':_0x0a9e('0x86'),'attributes':['id',_0x0a9e('0x25'),_0x0a9e('0xb0')],'required':_0x5b93dd[_0x0a9e('0x37')]['tag']?!![]:![]}],'attributes':_[_0x0a9e('0x2a')](_0x1a3754)});})[_0x0a9e('0x22')](function(_0x2b7092){_0x5c4be0=_0x2b7092['get']({'plain':!![]});var _0x2650eb={'where':{'$and':[{'ListId':{'$ne':null}}]}};if(_0x2b7092&&_0x2b7092[_0x0a9e('0x5d')]){if(_0x2b7092[_0x0a9e('0x5d')]){_0x2650eb['where'][_0x0a9e('0xb1')][_0x0a9e('0x2e')]({'ListId':{'$ne':_0x2b7092[_0x0a9e('0x5d')]}});}}return db[_0x0a9e('0x2f')][_0x0a9e('0x8c')](_0x2650eb);})['then'](function(_0x3211d2){return _[_0x0a9e('0xb2')](_0x5c4be0,_['map'](_0x3211d2,function(_0x3bab3e){return util[_0x0a9e('0xb3')](_0x0a9e('0xb4'),_0x3bab3e['id']);}));})['then'](handleEntityNotFound(_0x556443,null))['then'](respondWithResult(_0x556443,null))['catch'](handleError(_0x556443,null));};exports[_0x0a9e('0x20')]=function(_0x4a70ce,_0x55f91a){var _0x183244;if(_0x4a70ce[_0x0a9e('0x8f')]['id']){delete _0x4a70ce[_0x0a9e('0x8f')]['id'];}return db['CmContact'][_0x0a9e('0x89')]({'where':{'id':_0x4a70ce[_0x0a9e('0x8a')]['id']}})[_0x0a9e('0x22')](handleEntityNotFound(_0x55f91a,null))[_0x0a9e('0x22')](saveUpdates(_0x4a70ce[_0x0a9e('0x8f')],null))[_0x0a9e('0x22')](function(_0x40e6e7){_0x183244=_0x40e6e7;var _0x328ec5={'where':{'$and':[{'ListId':{'$ne':null}}]}};if(_0x40e6e7&&_0x40e6e7[_0x0a9e('0x5d')]){if(_0x40e6e7['ListId']){_0x328ec5[_0x0a9e('0x3c')]['$and'][_0x0a9e('0x2e')]({'ListId':{'$ne':_0x40e6e7[_0x0a9e('0x5d')]}});}}return db[_0x0a9e('0x2f')][_0x0a9e('0x8c')](_0x328ec5);})[_0x0a9e('0x22')](function(_0x344cd4){if(_0x344cd4){return _['omit'](_[_0x0a9e('0xb5')](_0x4a70ce[_0x0a9e('0x8f')],function(_0xe25eb5,_0x1af799){return _['startsWith'](_0x1af799,_0x0a9e('0x2d'));}),_[_0x0a9e('0x50')](_0x344cd4,function(_0x43beea){return util[_0x0a9e('0xb3')](_0x0a9e('0xb4'),_0x43beea['id']);}));}})[_0x0a9e('0x22')](function(_0x238c24){if(_0x238c24&&!_[_0x0a9e('0x75')](_0x238c24)){var _0x3299b7=squel[_0x0a9e('0x20')]()['table'](_0x0a9e('0x42'))[_0x0a9e('0xb6')](_0x238c24)[_0x0a9e('0x3c')](_0x0a9e('0xb7'),_0x4a70ce[_0x0a9e('0x8a')]['id'])[_0x0a9e('0xb8')]();return db[_0x0a9e('0x7a')][_0x0a9e('0x37')](_0x3299b7['text'],{'replacements':_0x3299b7[_0x0a9e('0xb9')]});}})[_0x0a9e('0x22')](function(){if(_0x4a70ce[_0x0a9e('0x8f')]['phone']&&_0x183244){return db[_0x0a9e('0xba')][_0x0a9e('0x20')]({'phone':_0x4a70ce[_0x0a9e('0x8f')][_0x0a9e('0xbb')]},{'where':{'ContactId':_0x183244['id']}});}})[_0x0a9e('0x22')](function(){return _0x183244;})[_0x0a9e('0x22')](respondWithResult(_0x55f91a,null))[_0x0a9e('0x88')](handleError(_0x55f91a,null));};exports[_0x0a9e('0xbc')]=function(_0x401601,_0x451010,_0x5a7dad){var _0x251753={};var _0x446e6={};var _0x15a9ed;var _0x3db98f;return db[_0x0a9e('0x28')][_0x0a9e('0xbd')]({'where':{'id':_0x401601['params']['id']}})[_0x0a9e('0x22')](handleEntityNotFound(_0x451010,null))['then'](function(_0x5bd139){if(_0x5bd139){_0x15a9ed=_0x5bd139;_0x446e6['model']=_[_0x0a9e('0x2a')](db[_0x0a9e('0x4d')][_0x0a9e('0xbe')]);_0x446e6[_0x0a9e('0x37')]=_['keys'](_0x401601[_0x0a9e('0x37')]);_0x446e6[_0x0a9e('0x35')]=_[_0x0a9e('0x36')](_0x446e6[_0x0a9e('0x34')],_0x446e6[_0x0a9e('0x37')]);_0x251753['attributes']=_['intersection'](_0x446e6[_0x0a9e('0x34')],qs[_0x0a9e('0x38')](_0x401601[_0x0a9e('0x37')]['fields']));_0x251753[_0x0a9e('0x39')]=_0x251753[_0x0a9e('0x39')][_0x0a9e('0x2b')]?_0x251753['attributes']:_0x446e6[_0x0a9e('0x34')];_0x251753[_0x0a9e('0x73')]=qs[_0x0a9e('0x3b')](_0x401601['query'][_0x0a9e('0x3b')]);_0x251753[_0x0a9e('0x3c')]=qs[_0x0a9e('0x35')](_['pick'](_0x401601['query'],_0x446e6['filters']));if(_0x401601[_0x0a9e('0x37')][_0x0a9e('0x63')]){_0x251753[_0x0a9e('0x3c')]=_[_0x0a9e('0x7d')](_0x251753['where'],{'$or':_[_0x0a9e('0x50')](_0x251753['attributes'],function(_0x3b4af9){var _0x2ff2ab={};_0x2ff2ab[_0x3b4af9]={'$like':'%'+_0x401601[_0x0a9e('0x37')]['filter']+'%'};return _0x2ff2ab;})});}_0x251753=_[_0x0a9e('0x7d')]({},_0x251753,_0x401601[_0x0a9e('0xbf')]);return _0x15a9ed[_0x0a9e('0xbc')](_0x251753);}})['then'](function(_0x40eb5d){if(_0x40eb5d){_0x3db98f=_0x40eb5d['length'];if(!_0x401601[_0x0a9e('0x37')]['hasOwnProperty'](_0x0a9e('0xc0'))){_0x251753['limit']=qs[_0x0a9e('0x1d')](_0x401601[_0x0a9e('0x37')][_0x0a9e('0x1d')]);_0x251753[_0x0a9e('0x1c')]=qs[_0x0a9e('0x1c')](_0x401601[_0x0a9e('0x37')][_0x0a9e('0x1c')]);}return _0x15a9ed['getTags'](_0x251753);}})[_0x0a9e('0x22')](function(_0x1c9ea2){if(_0x1c9ea2){return _0x1c9ea2?{'count':_0x3db98f,'rows':_0x1c9ea2}:null;}})['then'](respondWithResult(_0x451010,null))[_0x0a9e('0x88')](handleError(_0x451010,null));};exports[_0x0a9e('0xc1')]=function(_0x548693,_0x39070b,_0x2a93a7){if(_0x548693[_0x0a9e('0x8f')]['id']){delete _0x548693['body']['id'];}return db[_0x0a9e('0x28')][_0x0a9e('0xbd')]({'where':{'id':_0x548693[_0x0a9e('0x8a')]['id']}})[_0x0a9e('0x22')](handleEntityNotFound(_0x39070b,null))[_0x0a9e('0x22')](function(_0x29fdfe){if(_0x29fdfe){return _0x29fdfe[_0x0a9e('0xc1')](_0x548693[_0x0a9e('0x8f')][_0x0a9e('0xc2')]||[]);}return null;})[_0x0a9e('0x22')](respondWithResult(_0x39070b,null))['catch'](handleError(_0x39070b,null));};exports[_0x0a9e('0xc3')]=function(_0x53c7de,_0x3c9854,_0x2968e2){var _0x5b9c76={'raw':![],'where':{}};var _0x315e31={};var _0x5d577b={'count':0x0,'rows':[]};return db[_0x0a9e('0x28')]['findOne']({'where':{'id':_0x53c7de[_0x0a9e('0x8a')]['id']}})[_0x0a9e('0x22')](handleEntityNotFound(_0x3c9854,null))[_0x0a9e('0x22')](function(_0x55a599){if(_0x55a599){_0x315e31[_0x0a9e('0x34')]=_[_0x0a9e('0x2a')](db[_0x0a9e('0xba')][_0x0a9e('0xbe')]);_0x315e31[_0x0a9e('0x37')]=_[_0x0a9e('0x2a')](_0x53c7de[_0x0a9e('0x37')]);_0x315e31['filters']=_[_0x0a9e('0x36')](_0x315e31[_0x0a9e('0x34')],_0x315e31[_0x0a9e('0x37')]);_0x5b9c76[_0x0a9e('0x39')]=_[_0x0a9e('0x36')](_0x315e31[_0x0a9e('0x34')],qs[_0x0a9e('0x38')](_0x53c7de['query']['fields']));_0x5b9c76[_0x0a9e('0x39')]=_0x5b9c76[_0x0a9e('0x39')][_0x0a9e('0x2b')]?_0x5b9c76[_0x0a9e('0x39')]:_0x315e31[_0x0a9e('0x34')];if(!_0x53c7de[_0x0a9e('0x37')][_0x0a9e('0x3a')]('nolimit')){_0x5b9c76[_0x0a9e('0x1d')]=qs[_0x0a9e('0x1d')](_0x53c7de[_0x0a9e('0x37')][_0x0a9e('0x1d')]);_0x5b9c76[_0x0a9e('0x1c')]=qs[_0x0a9e('0x1c')](_0x53c7de[_0x0a9e('0x37')]['offset']);}_0x5b9c76[_0x0a9e('0x73')]=qs[_0x0a9e('0x3b')](_0x53c7de[_0x0a9e('0x37')]['sort']);_0x5b9c76[_0x0a9e('0x3c')]=qs[_0x0a9e('0x35')](_[_0x0a9e('0x3d')](_0x53c7de[_0x0a9e('0x37')],_0x315e31['filters']));_0x5b9c76[_0x0a9e('0x3c')][_0x0a9e('0xc4')]=_0x55a599['id'];if(_0x53c7de[_0x0a9e('0x37')][_0x0a9e('0x63')]){_0x5b9c76[_0x0a9e('0x3c')]=_[_0x0a9e('0x7d')](_0x5b9c76[_0x0a9e('0x3c')],{'$or':_[_0x0a9e('0x50')](_0x5b9c76['attributes'],function(_0x3ede01){var _0x266aa1={};_0x266aa1[_0x3ede01]={'$like':'%'+_0x53c7de[_0x0a9e('0x37')][_0x0a9e('0x63')]+'%'};return _0x266aa1;})});}_0x5b9c76=_['merge']({},_0x5b9c76,_0x53c7de['options']);return db[_0x0a9e('0xba')][_0x0a9e('0x1b')]({'where':_0x5b9c76[_0x0a9e('0x3c')]})['then'](function(_0x3ccede){_0x5d577b[_0x0a9e('0x1b')]=_0x3ccede;if(_0x53c7de['query'][_0x0a9e('0xc5')]){_0x5b9c76['include']=[{'all':!![]}];}return db[_0x0a9e('0xba')]['findAll'](_0x5b9c76);})['then'](function(_0x48eaa3){_0x5d577b[_0x0a9e('0x87')]=_0x48eaa3;return _0x5d577b;});}})[_0x0a9e('0x22')](respondWithFilteredResult(_0x3c9854,_0x5b9c76))[_0x0a9e('0x88')](handleError(_0x3c9854,null));};exports[_0x0a9e('0xc6')]=function(_0x7d59a9,_0xe17af8,_0x48fbef){var _0x5fb7ce={'raw':!![],'where':{}};var _0x213e5f={};var _0x1713a7={'count':0x0,'rows':[]};return db[_0x0a9e('0x28')][_0x0a9e('0xbd')]({'where':{'id':_0x7d59a9[_0x0a9e('0x8a')]['id']}})[_0x0a9e('0x22')](handleEntityNotFound(_0xe17af8,null))['then'](function(_0x49baaa){if(_0x49baaa){_0x213e5f[_0x0a9e('0x34')]=_['keys'](db[_0x0a9e('0xa4')][_0x0a9e('0xbe')]);_0x213e5f[_0x0a9e('0x37')]=_[_0x0a9e('0x2a')](_0x7d59a9[_0x0a9e('0x37')]);_0x213e5f[_0x0a9e('0x35')]=_['intersection'](_0x213e5f[_0x0a9e('0x34')],_0x213e5f['query']);_0x5fb7ce['attributes']=_[_0x0a9e('0x36')](_0x213e5f['model'],qs[_0x0a9e('0x38')](_0x7d59a9['query']['fields']));_0x5fb7ce[_0x0a9e('0x39')]=_0x5fb7ce['attributes'][_0x0a9e('0x2b')]?_0x5fb7ce[_0x0a9e('0x39')]:_0x213e5f[_0x0a9e('0x34')];if(!_0x7d59a9['query'][_0x0a9e('0x3a')](_0x0a9e('0xc0'))){_0x5fb7ce[_0x0a9e('0x1d')]=qs['limit'](_0x7d59a9['query'][_0x0a9e('0x1d')]);_0x5fb7ce[_0x0a9e('0x1c')]=qs[_0x0a9e('0x1c')](_0x7d59a9[_0x0a9e('0x37')][_0x0a9e('0x1c')]);}_0x5fb7ce[_0x0a9e('0x73')]=qs[_0x0a9e('0x3b')](_0x7d59a9[_0x0a9e('0x37')][_0x0a9e('0x3b')]);_0x5fb7ce[_0x0a9e('0x3c')]=qs['filters'](_['pick'](_0x7d59a9['query'],_0x213e5f[_0x0a9e('0x35')]));_0x5fb7ce[_0x0a9e('0x3c')][_0x0a9e('0xc4')]=_0x49baaa['id'];if(_0x7d59a9[_0x0a9e('0x37')][_0x0a9e('0x63')]){_0x5fb7ce[_0x0a9e('0x3c')]=_[_0x0a9e('0x7d')](_0x5fb7ce[_0x0a9e('0x3c')],{'$or':_['map'](_0x5fb7ce['attributes'],function(_0x2869cc){var _0x98a973={};_0x98a973[_0x2869cc]={'$like':'%'+_0x7d59a9['query'][_0x0a9e('0x63')]+'%'};return _0x98a973;})});}_0x5fb7ce=_[_0x0a9e('0x7d')]({},_0x5fb7ce,_0x7d59a9[_0x0a9e('0xbf')]);return db[_0x0a9e('0xa4')][_0x0a9e('0x1b')]({'where':_0x5fb7ce[_0x0a9e('0x3c')]})[_0x0a9e('0x22')](function(_0x262281){_0x1713a7[_0x0a9e('0x1b')]=_0x262281;if(_0x7d59a9[_0x0a9e('0x37')][_0x0a9e('0xc5')]){_0x5fb7ce[_0x0a9e('0xc7')]=[{'all':!![]}];}return db['CmHopperHistory'][_0x0a9e('0x8c')](_0x5fb7ce);})[_0x0a9e('0x22')](function(_0x3cf607){_0x1713a7[_0x0a9e('0x87')]=_0x3cf607;return _0x1713a7;});}})[_0x0a9e('0x22')](respondWithFilteredResult(_0xe17af8,_0x5fb7ce))[_0x0a9e('0x88')](handleError(_0xe17af8,null));};exports[_0x0a9e('0xc8')]=function(_0x23bec3,_0x3a9c0f,_0x3f1959){var _0x6b048e={'raw':!![],'where':{}};var _0x3ba472={};var _0x4e6eb9={'count':0x0,'rows':[]};return db['CmContact'][_0x0a9e('0xbd')]({'where':{'id':_0x23bec3[_0x0a9e('0x8a')]['id']}})[_0x0a9e('0x22')](handleEntityNotFound(_0x3a9c0f,null))[_0x0a9e('0x22')](function(_0x33359a){if(_0x33359a){_0x3ba472[_0x0a9e('0x34')]=_[_0x0a9e('0x2a')](db['CmHopperFinal'][_0x0a9e('0xbe')]);_0x3ba472['query']=_[_0x0a9e('0x2a')](_0x23bec3[_0x0a9e('0x37')]);_0x3ba472[_0x0a9e('0x35')]=_[_0x0a9e('0x36')](_0x3ba472[_0x0a9e('0x34')],_0x3ba472[_0x0a9e('0x37')]);_0x6b048e[_0x0a9e('0x39')]=_[_0x0a9e('0x36')](_0x3ba472[_0x0a9e('0x34')],qs[_0x0a9e('0x38')](_0x23bec3[_0x0a9e('0x37')][_0x0a9e('0x38')]));_0x6b048e[_0x0a9e('0x39')]=_0x6b048e[_0x0a9e('0x39')][_0x0a9e('0x2b')]?_0x6b048e[_0x0a9e('0x39')]:_0x3ba472['model'];if(!_0x23bec3['query'][_0x0a9e('0x3a')](_0x0a9e('0xc0'))){_0x6b048e['limit']=qs['limit'](_0x23bec3[_0x0a9e('0x37')][_0x0a9e('0x1d')]);_0x6b048e[_0x0a9e('0x1c')]=qs['offset'](_0x23bec3[_0x0a9e('0x37')]['offset']);}_0x6b048e[_0x0a9e('0x73')]=qs['sort'](_0x23bec3[_0x0a9e('0x37')]['sort']);_0x6b048e[_0x0a9e('0x3c')]=qs[_0x0a9e('0x35')](_[_0x0a9e('0x3d')](_0x23bec3['query'],_0x3ba472[_0x0a9e('0x35')]));_0x6b048e['where']['ContactId']=_0x33359a['id'];if(_0x23bec3[_0x0a9e('0x37')][_0x0a9e('0x63')]){_0x6b048e[_0x0a9e('0x3c')]=_[_0x0a9e('0x7d')](_0x6b048e[_0x0a9e('0x3c')],{'$or':_[_0x0a9e('0x50')](_0x6b048e[_0x0a9e('0x39')],function(_0x82504f){var _0x1a3143={};_0x1a3143[_0x82504f]={'$like':'%'+_0x23bec3[_0x0a9e('0x37')][_0x0a9e('0x63')]+'%'};return _0x1a3143;})});}_0x6b048e=_[_0x0a9e('0x7d')]({},_0x6b048e,_0x23bec3[_0x0a9e('0xbf')]);return db[_0x0a9e('0xa3')][_0x0a9e('0x1b')]({'where':_0x6b048e[_0x0a9e('0x3c')]})[_0x0a9e('0x22')](function(_0x643f66){_0x4e6eb9[_0x0a9e('0x1b')]=_0x643f66;if(_0x23bec3['query'][_0x0a9e('0xc5')]){_0x6b048e[_0x0a9e('0xc7')]=[{'all':!![]}];}return db[_0x0a9e('0xa3')][_0x0a9e('0x8c')](_0x6b048e);})['then'](function(_0x49c3be){_0x4e6eb9['rows']=_0x49c3be;return _0x4e6eb9;});}})[_0x0a9e('0x22')](respondWithFilteredResult(_0x3a9c0f,_0x6b048e))['catch'](handleError(_0x3a9c0f,null));};exports[_0x0a9e('0xc9')]=function(_0x1fafc2,_0x130ae8,_0x43fe24){var _0x294c49={'raw':!![],'where':{}};var _0x28b8d2={};var _0x32617d={'count':0x0,'rows':[]};return db[_0x0a9e('0x28')][_0x0a9e('0xbd')]({'where':{'id':_0x1fafc2[_0x0a9e('0x8a')]['id']}})['then'](handleEntityNotFound(_0x130ae8,null))[_0x0a9e('0x22')](function(_0x47a018){if(_0x47a018){_0x28b8d2[_0x0a9e('0x34')]=_['keys'](db[_0x0a9e('0xa8')][_0x0a9e('0xbe')]);_0x28b8d2[_0x0a9e('0x37')]=_['keys'](_0x1fafc2[_0x0a9e('0x37')]);_0x28b8d2[_0x0a9e('0x35')]=_['intersection'](_0x28b8d2['model'],_0x28b8d2[_0x0a9e('0x37')]);_0x294c49[_0x0a9e('0x39')]=_[_0x0a9e('0x36')](_0x28b8d2['model'],qs['fields'](_0x1fafc2['query'][_0x0a9e('0x38')]));_0x294c49[_0x0a9e('0x39')]=_0x294c49[_0x0a9e('0x39')][_0x0a9e('0x2b')]?_0x294c49[_0x0a9e('0x39')]:_0x28b8d2[_0x0a9e('0x34')];if(!_0x1fafc2[_0x0a9e('0x37')][_0x0a9e('0x3a')](_0x0a9e('0xc0'))){_0x294c49[_0x0a9e('0x1d')]=qs[_0x0a9e('0x1d')](_0x1fafc2[_0x0a9e('0x37')][_0x0a9e('0x1d')]);_0x294c49[_0x0a9e('0x1c')]=qs[_0x0a9e('0x1c')](_0x1fafc2[_0x0a9e('0x37')][_0x0a9e('0x1c')]);}_0x294c49[_0x0a9e('0x73')]=qs['sort'](_0x1fafc2[_0x0a9e('0x37')][_0x0a9e('0x3b')]);_0x294c49[_0x0a9e('0x3c')]=qs[_0x0a9e('0x35')](_[_0x0a9e('0x3d')](_0x1fafc2[_0x0a9e('0x37')],_0x28b8d2['filters']));_0x294c49[_0x0a9e('0x3c')][_0x0a9e('0xc4')]=_0x47a018['id'];if(_0x1fafc2[_0x0a9e('0x37')][_0x0a9e('0x63')]){_0x294c49[_0x0a9e('0x3c')]=_[_0x0a9e('0x7d')](_0x294c49[_0x0a9e('0x3c')],{'$or':_[_0x0a9e('0x50')](_0x294c49[_0x0a9e('0x39')],function(_0x541af6){var _0x5d27c1={};_0x5d27c1[_0x541af6]={'$like':'%'+_0x1fafc2[_0x0a9e('0x37')][_0x0a9e('0x63')]+'%'};return _0x5d27c1;})});}_0x294c49=_['merge']({},_0x294c49,_0x1fafc2[_0x0a9e('0xbf')]);return db[_0x0a9e('0xa8')]['count']({'where':_0x294c49[_0x0a9e('0x3c')]})['then'](function(_0x3468a4){_0x32617d[_0x0a9e('0x1b')]=_0x3468a4;if(_0x1fafc2['query'][_0x0a9e('0xc5')]){_0x294c49[_0x0a9e('0xc7')]=[{'all':!![]}];}return db['JscriptySessionReport'][_0x0a9e('0x8c')](_0x294c49);})[_0x0a9e('0x22')](function(_0x53ad2b){_0x32617d[_0x0a9e('0x87')]=_0x53ad2b;return _0x32617d;});}})[_0x0a9e('0x22')](respondWithFilteredResult(_0x130ae8,_0x294c49))[_0x0a9e('0x88')](handleError(_0x130ae8,null));};exports[_0x0a9e('0xca')]=function(_0x8f68ec,_0x17a0d5,_0x5d525f){try{if(!_0x8f68ec[_0x0a9e('0x8f')][_0x0a9e('0x5d')]){throw new Error('No\x20ListId\x20specified');}if(!_0x8f68ec[_0x0a9e('0x8f')][_0x0a9e('0xcb')]){throw new Error(_0x0a9e('0xcc'));}if(!_0x8f68ec[_0x0a9e('0x8f')][_0x0a9e('0xcd')]){throw new Error(_0x0a9e('0xce'));}if(!_0x8f68ec[_0x0a9e('0x8f')]['socket_timestamp']){throw new Error('Unable\x20to\x20synchronize\x20socket,\x20no\x20timestamp\x20passed');}var _0x5a2013=_0x8f68ec['body']['binding_keys'][_0x0a9e('0x4f')](',');var _0x23ef4e=_0x8f68ec['body']['binding_values'][_0x0a9e('0x4f')](',');if(!_0x5a2013['length']||!_0x23ef4e[_0x0a9e('0x2b')]||_0x5a2013[_0x0a9e('0x2b')]!==_0x23ef4e[_0x0a9e('0x2b')]){throw new Error(_0x0a9e('0xcf'));}_0x8f68ec[_0x0a9e('0x8f')][_0x0a9e('0x38')]=_['zipObject'](_0x5a2013,_0x23ef4e);if(!_0x8f68ec[_0x0a9e('0x8f')][_0x0a9e('0x38')]['phone']){throw new Error(_0x0a9e('0xd0'));}if(!_0x8f68ec[_0x0a9e('0x8f')][_0x0a9e('0x38')][_0x0a9e('0xd1')]){throw new Error(_0x0a9e('0xd2'));}var _0x2f1cc0=path[_0x0a9e('0x93')](config['root'],_0x0a9e('0xd3'),_0x8f68ec['file'][_0x0a9e('0xd4')]);fs[_0x0a9e('0xd5')](_0x2f1cc0,parseInt('0777',0x8));var _0x28b7de=require(_0x0a9e('0xd6'))['fork'](path[_0x0a9e('0x93')](__dirname,'../../components/import/cm/csv'),[_0x2f1cc0,_0x8f68ec[_0x0a9e('0x8f')][_0x0a9e('0xcb')],_0x8f68ec['body'][_0x0a9e('0xcd')],_0x8f68ec['body'][_0x0a9e('0x5d')],_0x8f68ec[_0x0a9e('0x8f')][_0x0a9e('0xd7')],_0x8f68ec[_0x0a9e('0x8f')][_0x0a9e('0xaa')],_0x8f68ec[_0x0a9e('0x8f')][_0x0a9e('0xd8')]]);return _0x17a0d5['status'](0xc8)[_0x0a9e('0xd9')]({'message':_0x0a9e('0xda'),'pid':_0x28b7de[_0x0a9e('0xdb')]});}catch(_0x1b1971){return _0x17a0d5[_0x0a9e('0x1a')](0x1f4)['send'](_0x1b1971);}};exports[_0x0a9e('0xdc')]=function(_0x49a6b2,_0x5d1159,_0x3a459c){var _0x58efc5=fs[_0x0a9e('0xdd')](_0x49a6b2[_0x0a9e('0xde')]['path']);Papa[_0x0a9e('0xdf')](_0x58efc5,{'header':!![],'skipEmptyLines':!![],'preview':0x1,'complete':function(_0x4043e7){return _0x5d1159[_0x0a9e('0x1a')](0xc8)[_0x0a9e('0xd9')]({'file':_0x49a6b2[_0x0a9e('0xde')],'fields':_0x4043e7[_0x0a9e('0xe0')][_0x0a9e('0x38')]});}});};exports[_0x0a9e('0xe1')]=function(_0x3d02ae,_0x5871d7,_0x26f1c6){return db[_0x0a9e('0x53')][_0x0a9e('0x8c')]({'raw':!![],'attributes':['id'],'where':{'role':_0x0a9e('0xe2')}})['then'](function(_0x38d95a){var _0x439f25=![];if(!_0x3d02ae[_0x0a9e('0x8f')]['ListId']){throw new Error(_0x0a9e('0xe3'));}if(!_0x3d02ae[_0x0a9e('0x8f')][_0x0a9e('0xe4')]['phone']){throw new Error(_0x0a9e('0xd0'));}if(!_0x3d02ae['body'][_0x0a9e('0xe4')][_0x0a9e('0xd1')]){throw new Error(_0x0a9e('0xd2'));}if(!_0x3d02ae[_0x0a9e('0x8f')][_0x0a9e('0xd8')]){throw new Error(_0x0a9e('0xe5'));}var _0x81f0f5=require('child_process')[_0x0a9e('0xe6')](path[_0x0a9e('0x93')](__dirname,_0x0a9e('0xe7')),[_0x3d02ae[_0x0a9e('0x8a')]['id'],JSON[_0x0a9e('0xe8')](_0x3d02ae[_0x0a9e('0x8f')]),JSON[_0x0a9e('0xe8')](_0x38d95a)]);_0x81f0f5['on'](_0x0a9e('0xe9'),function(_0x2310ca){_0x439f25=!![];return _0x5871d7[_0x0a9e('0x1a')](0xc8)[_0x0a9e('0xd9')]({'message':_0x0a9e('0xea'),'pid':_0x81f0f5[_0x0a9e('0xdb')]});});_0x81f0f5['on'](_0x0a9e('0xeb'),function(_0xdce963){if(_0xdce963&&!_0x439f25){return _0x5871d7[_0x0a9e('0x1a')](0x1f4)[_0x0a9e('0xd9')]({'message':_0x0a9e('0xec'),'pid':_0x81f0f5[_0x0a9e('0xdb')]});}});})[_0x0a9e('0x88')](handleError(_0x5871d7,null));};