Built motion from commit 10af8726.|2.6.34
[motion2.git] / server / api / cmHopperFinal / cmHopperFinal.controller.js
index d338fff..33b1514 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0xe6e9=['CampaignId\x20=\x20?','findOne','html-pdf','eml-format','rimraf','fast-json-patch','request-promise','moment','bluebird','mustache','path','sox','to-csv','ejs','lodash','crypto','jsforce','desk.js','querystring','papaparse','../../components/auth/service','../../components/parsers/qs','../../components/parsers/advancedSearch','../../config/license/hardware','api','../../config/utils','../../mysqldb','status','end','json','count','offset','limit','set','Content-Range','apply','reject','save','update','then','destroy','sendStatus','error','stack','send','index','CmHopperFinal','rawAttributes','fieldName','type','key','model','name','query','intersection','attributes','length','hasOwnProperty','nolimit','order','filters','pick','merge','where','map','VIRTUAL','filter','options','includeAll','catch','show','params','keys','fields','include','find','body','uniqueid','countContactsQueueCampaignHopperFinal','findAll','COUNT','literal','`state`\x20=\x200,\x201,\x20null','noSuchContacts','sequelize','`state`\x20=\x203,\x201,\x20null','noAnswerContacts','`state`\x20=\x205,\x201,\x20null','busyContacts','congestionContacts','`state`\x20=\x2010\x20,\x201,\x20null','dropContacts','abandonedContacts','`state`\x20=\x2022,\x201,\x20null','reCallContacts','`state`\x20=\x2019,\x201,\x20null','answeringMachine','`state`\x20=\x208,\x201,\x20null','`state`\x20=\x2011\x20,\x201,\x20null','moveContactsQueueCampaignHopperFinal','insert','cm_hopper','fromQuery','phone','scheduledAt','ContactId','VoiceQueueId','select','field','ANY_VALUE(ContactId)','ANY_VALUE(ListId)','ListId','NOW()','updatedAt','from','cm_hopper_final','VoiceQueueId\x20=\x20?','toString','state\x20=\x20?','state','calleridnum\x20IS\x20NOT\x20NULL','calleridnum\x20NOT\x20IN\x20(?)','calleridnum','state\x20=\x204','moveContactsIvrCampaignHopperFinal','into','CampaignId','createdAt'];(function(_0x30f395,_0x3629b5){var _0x2ea0ee=function(_0x35a9af){while(--_0x35a9af){_0x30f395['push'](_0x30f395['shift']());}};_0x2ea0ee(++_0x3629b5);}(_0xe6e9,0x182));var _0x9e6e=function(_0x3c438e,_0x37bd4a){_0x3c438e=_0x3c438e-0x0;var _0x31892b=_0xe6e9[_0x3c438e];return _0x31892b;};'use strict';var pdf=require(_0x9e6e('0x0'));var emlformat=require(_0x9e6e('0x1'));var rimraf=require(_0x9e6e('0x2'));var zipdir=require('zip-dir');var jsonpatch=require(_0x9e6e('0x3'));var rp=require(_0x9e6e('0x4'));var moment=require(_0x9e6e('0x5'));var BPromise=require(_0x9e6e('0x6'));var Mustache=require(_0x9e6e('0x7'));var util=require('util');var path=require(_0x9e6e('0x8'));var sox=require(_0x9e6e('0x9'));var csv=require(_0x9e6e('0xa'));var ejs=require(_0x9e6e('0xb'));var fs=require('fs');var _=require(_0x9e6e('0xc'));var squel=require('squel');var crypto=require(_0x9e6e('0xd'));var jsforce=require(_0x9e6e('0xe'));var deskjs=require(_0x9e6e('0xf'));var toCsv=require(_0x9e6e('0xa'));var querystring=require(_0x9e6e('0x10'));var Papa=require(_0x9e6e('0x11'));var Redis=require('ioredis');var authService=require(_0x9e6e('0x12'));var qs=require(_0x9e6e('0x13'));var as=require(_0x9e6e('0x14'));var hardwareService=require(_0x9e6e('0x15'));var logger=require('../../config/logger')(_0x9e6e('0x16'));var utils=require(_0x9e6e('0x17'));var config=require('../../config/environment');var db=require(_0x9e6e('0x18'))['db'];function respondWithStatusCode(_0x2e431d,_0x1b85f1){_0x1b85f1=_0x1b85f1||0xcc;return function(_0x363f0c){if(_0x363f0c){return _0x2e431d['sendStatus'](_0x1b85f1);}return _0x2e431d[_0x9e6e('0x19')](_0x1b85f1)[_0x9e6e('0x1a')]();};}function respondWithResult(_0x1235ab,_0x2981d0){_0x2981d0=_0x2981d0||0xc8;return function(_0x3ade25){if(_0x3ade25){return _0x1235ab[_0x9e6e('0x19')](_0x2981d0)[_0x9e6e('0x1b')](_0x3ade25);}};}function respondWithFilteredResult(_0x6bc20c,_0x3080b1){return function(_0x2dbdba){if(_0x2dbdba){var _0x1941da=_0x2dbdba[_0x9e6e('0x1c')],_0x236850=_0x3080b1[_0x9e6e('0x1d')],_0x2e5472=_0x3080b1[_0x9e6e('0x1d')]+_0x3080b1[_0x9e6e('0x1e')],_0xc9fd3c;if(_0x2e5472>=_0x1941da){_0x2e5472=_0x1941da;_0xc9fd3c=0xc8;}else{_0xc9fd3c=0xce;}_0x6bc20c[_0x9e6e('0x19')](_0xc9fd3c);return _0x6bc20c[_0x9e6e('0x1f')](_0x9e6e('0x20'),_0x236850+'-'+_0x2e5472+'/'+_0x1941da)['json'](_0x2dbdba);}return null;};}function patchUpdates(_0x54ba62){return function(_0x5e956c){try{jsonpatch[_0x9e6e('0x21')](_0x5e956c,_0x54ba62,!![]);}catch(_0x4027ba){return BPromise[_0x9e6e('0x22')](_0x4027ba);}return _0x5e956c[_0x9e6e('0x23')]();};}function saveUpdates(_0x35dd6d,_0x3b9299){return function(_0x195727){if(_0x195727){return _0x195727[_0x9e6e('0x24')](_0x35dd6d)[_0x9e6e('0x25')](function(_0x434aa3){return _0x434aa3;});}return null;};}function removeEntity(_0x379da6,_0x3b3527){return function(_0x28ae35){if(_0x28ae35){return _0x28ae35[_0x9e6e('0x26')]()[_0x9e6e('0x25')](function(){_0x379da6[_0x9e6e('0x19')](0xcc)['end']();});}};}function handleEntityNotFound(_0x223fd4,_0x4202cd){return function(_0x3aee5c){if(!_0x3aee5c){_0x223fd4[_0x9e6e('0x27')](0x194);}return _0x3aee5c;};}function handleError(_0x5dc500,_0x5b1aad){_0x5b1aad=_0x5b1aad||0x1f4;return function(_0x1e9b87){logger[_0x9e6e('0x28')](_0x1e9b87[_0x9e6e('0x29')]);if(_0x1e9b87['name']){delete _0x1e9b87['name'];}_0x5dc500[_0x9e6e('0x19')](_0x5b1aad)[_0x9e6e('0x2a')](_0x1e9b87);};}exports[_0x9e6e('0x2b')]=function(_0x2bc8d5,_0x4d30c1){var _0x4d1616={},_0x188387={},_0x4abc8f={'count':0x0,'rows':[]};var _0x438a84=_['map'](db[_0x9e6e('0x2c')][_0x9e6e('0x2d')],function(_0x4a0c94){return{'name':_0x4a0c94[_0x9e6e('0x2e')],'type':_0x4a0c94[_0x9e6e('0x2f')][_0x9e6e('0x30')]};});_0x188387[_0x9e6e('0x31')]=_['map'](_0x438a84,_0x9e6e('0x32'));_0x188387['query']=_['keys'](_0x2bc8d5[_0x9e6e('0x33')]);_0x188387['filters']=_[_0x9e6e('0x34')](_0x188387[_0x9e6e('0x31')],_0x188387[_0x9e6e('0x33')]);_0x4d1616[_0x9e6e('0x35')]=_['intersection'](_0x188387[_0x9e6e('0x31')],qs['fields'](_0x2bc8d5[_0x9e6e('0x33')]['fields']));_0x4d1616['attributes']=_0x4d1616[_0x9e6e('0x35')][_0x9e6e('0x36')]?_0x4d1616[_0x9e6e('0x35')]:_0x188387['model'];if(!_0x2bc8d5[_0x9e6e('0x33')][_0x9e6e('0x37')](_0x9e6e('0x38'))){_0x4d1616['limit']=qs[_0x9e6e('0x1e')](_0x2bc8d5[_0x9e6e('0x33')][_0x9e6e('0x1e')]);_0x4d1616['offset']=qs['offset'](_0x2bc8d5['query'][_0x9e6e('0x1d')]);}_0x4d1616[_0x9e6e('0x39')]=qs['sort'](_0x2bc8d5[_0x9e6e('0x33')]['sort']);_0x4d1616['where']=qs[_0x9e6e('0x3a')](_[_0x9e6e('0x3b')](_0x2bc8d5[_0x9e6e('0x33')],_0x188387['filters']),_0x438a84);if(_0x2bc8d5[_0x9e6e('0x33')]['filter']){_0x4d1616['where']=_[_0x9e6e('0x3c')](_0x4d1616[_0x9e6e('0x3d')],{'$or':_[_0x9e6e('0x3e')](_0x438a84,function(_0x4c0e75){if(_0x4c0e75[_0x9e6e('0x2f')]!==_0x9e6e('0x3f')){var _0x2a7b0a={};_0x2a7b0a[_0x4c0e75[_0x9e6e('0x32')]]={'$like':'%'+_0x2bc8d5[_0x9e6e('0x33')][_0x9e6e('0x40')]+'%'};return _0x2a7b0a;}})});}_0x4d1616=_['merge']({},_0x4d1616,_0x2bc8d5[_0x9e6e('0x41')]);var _0x38f653={'where':_0x4d1616['where']};return db[_0x9e6e('0x2c')][_0x9e6e('0x1c')](_0x38f653)[_0x9e6e('0x25')](function(_0x361e7a){_0x4abc8f['count']=_0x361e7a;if(_0x2bc8d5['query'][_0x9e6e('0x42')]){_0x4d1616['include']=[{'all':!![]}];}return db['CmHopperFinal']['findAll'](_0x4d1616);})['then'](function(_0x5afa1b){_0x4abc8f['rows']=_0x5afa1b;return _0x4abc8f;})[_0x9e6e('0x25')](respondWithFilteredResult(_0x4d30c1,_0x4d1616))[_0x9e6e('0x43')](handleError(_0x4d30c1,null));};exports[_0x9e6e('0x44')]=function(_0x38d706,_0x2546b3){var _0x272461={'raw':!![],'where':{'id':_0x38d706[_0x9e6e('0x45')]['id']}},_0x4d8acd={};_0x4d8acd[_0x9e6e('0x31')]=_[_0x9e6e('0x46')](db[_0x9e6e('0x2c')][_0x9e6e('0x2d')]);_0x4d8acd['query']=_['keys'](_0x38d706['query']);_0x4d8acd[_0x9e6e('0x3a')]=_[_0x9e6e('0x34')](_0x4d8acd[_0x9e6e('0x31')],_0x4d8acd[_0x9e6e('0x33')]);_0x272461[_0x9e6e('0x35')]=_[_0x9e6e('0x34')](_0x4d8acd[_0x9e6e('0x31')],qs['fields'](_0x38d706[_0x9e6e('0x33')][_0x9e6e('0x47')]));_0x272461['attributes']=_0x272461[_0x9e6e('0x35')][_0x9e6e('0x36')]?_0x272461['attributes']:_0x4d8acd['model'];if(_0x38d706[_0x9e6e('0x33')][_0x9e6e('0x42')]){_0x272461[_0x9e6e('0x48')]=[{'all':!![]}];}_0x272461=_['merge']({},_0x272461,_0x38d706[_0x9e6e('0x41')]);return db[_0x9e6e('0x2c')][_0x9e6e('0x49')](_0x272461)[_0x9e6e('0x25')](handleEntityNotFound(_0x2546b3,null))[_0x9e6e('0x25')](respondWithResult(_0x2546b3,null))['catch'](handleError(_0x2546b3,null));};exports['describe']=function(_0x10aa43,_0x1c10a0){return db['CmHopperFinal']['describe']()[_0x9e6e('0x25')](respondWithResult(_0x1c10a0,null))[_0x9e6e('0x43')](handleError(_0x1c10a0,null));};exports['update']=function(_0x22f916,_0x44a54f){if(_0x22f916[_0x9e6e('0x4a')][_0x9e6e('0x4b')]){delete _0x22f916[_0x9e6e('0x4a')][_0x9e6e('0x4b')];}return db[_0x9e6e('0x2c')][_0x9e6e('0x49')]({'where':{'uniqueid':_0x22f916[_0x9e6e('0x45')]['id']}})[_0x9e6e('0x25')](handleEntityNotFound(_0x44a54f,null))[_0x9e6e('0x25')](saveUpdates(_0x22f916[_0x9e6e('0x4a')],null))[_0x9e6e('0x25')](respondWithResult(_0x44a54f,null))[_0x9e6e('0x43')](handleError(_0x44a54f,null));};exports[_0x9e6e('0x4c')]=function(_0xf5d3eb,_0x26d53f,_0x3512df){return db['CmHopperFinal'][_0x9e6e('0x4d')]({'raw':![],'where':{'VoiceQueueId':_0xf5d3eb['params']['id']},'attributes':[[db['sequelize']['fn'](_0x9e6e('0x4e'),db['sequelize']['fn']('IF',db['sequelize'][_0x9e6e('0x4f')](_0x9e6e('0x50')))),_0x9e6e('0x51')],[db['sequelize']['fn'](_0x9e6e('0x4e'),db['sequelize']['fn']('IF',db[_0x9e6e('0x52')]['literal'](_0x9e6e('0x53')))),_0x9e6e('0x54')],[db[_0x9e6e('0x52')]['fn'](_0x9e6e('0x4e'),db[_0x9e6e('0x52')]['fn']('IF',db[_0x9e6e('0x52')][_0x9e6e('0x4f')](_0x9e6e('0x55')))),_0x9e6e('0x56')],[db[_0x9e6e('0x52')]['fn']('COUNT',db['sequelize']['fn']('IF',db[_0x9e6e('0x52')][_0x9e6e('0x4f')]('`state`\x20=\x208,\x201,\x20null'))),_0x9e6e('0x57')],[db[_0x9e6e('0x52')]['fn'](_0x9e6e('0x4e'),db[_0x9e6e('0x52')]['fn']('IF',db[_0x9e6e('0x52')]['literal'](_0x9e6e('0x58')))),_0x9e6e('0x59')],[db[_0x9e6e('0x52')]['fn'](_0x9e6e('0x4e'),db['sequelize']['fn']('IF',db[_0x9e6e('0x52')][_0x9e6e('0x4f')]('`state`\x20=\x2011\x20,\x201,\x20null'))),_0x9e6e('0x5a')],[db[_0x9e6e('0x52')]['fn'](_0x9e6e('0x4e'),db[_0x9e6e('0x52')]['fn']('IF',db[_0x9e6e('0x52')][_0x9e6e('0x4f')](_0x9e6e('0x5b')))),_0x9e6e('0x5c')],[db[_0x9e6e('0x52')]['fn'](_0x9e6e('0x4e'),db['sequelize']['fn']('IF',db[_0x9e6e('0x52')]['literal'](_0x9e6e('0x5d')))),_0x9e6e('0x5e')]]})['then'](handleEntityNotFound(_0x26d53f,null))[_0x9e6e('0x25')](respondWithResult(_0x26d53f,null))[_0x9e6e('0x43')](handleError(_0x26d53f,null));};exports['countContactsIvrCampaignHopperFinal']=function(_0x4dacc0,_0x5d9905,_0x1fde16){return db['CmHopperFinal'][_0x9e6e('0x4d')]({'raw':![],'where':{'CampaignId':_0x4dacc0['params']['id']},'attributes':[[db[_0x9e6e('0x52')]['fn'](_0x9e6e('0x4e'),db[_0x9e6e('0x52')]['fn']('IF',db['sequelize'][_0x9e6e('0x4f')](_0x9e6e('0x50')))),'noSuchContacts'],[db[_0x9e6e('0x52')]['fn']('COUNT',db['sequelize']['fn']('IF',db[_0x9e6e('0x52')]['literal'](_0x9e6e('0x53')))),'noAnswerContacts'],[db[_0x9e6e('0x52')]['fn'](_0x9e6e('0x4e'),db[_0x9e6e('0x52')]['fn']('IF',db[_0x9e6e('0x52')][_0x9e6e('0x4f')](_0x9e6e('0x55')))),'busyContacts'],[db[_0x9e6e('0x52')]['fn'](_0x9e6e('0x4e'),db[_0x9e6e('0x52')]['fn']('IF',db['sequelize'][_0x9e6e('0x4f')](_0x9e6e('0x5f')))),_0x9e6e('0x57')],[db[_0x9e6e('0x52')]['fn']('COUNT',db[_0x9e6e('0x52')]['fn']('IF',db[_0x9e6e('0x52')][_0x9e6e('0x4f')](_0x9e6e('0x58')))),_0x9e6e('0x59')],[db[_0x9e6e('0x52')]['fn'](_0x9e6e('0x4e'),db[_0x9e6e('0x52')]['fn']('IF',db[_0x9e6e('0x52')][_0x9e6e('0x4f')](_0x9e6e('0x60')))),_0x9e6e('0x5a')],[db[_0x9e6e('0x52')]['fn'](_0x9e6e('0x4e'),db[_0x9e6e('0x52')]['fn']('IF',db['sequelize']['literal'](_0x9e6e('0x5b')))),'reCallContacts'],[db['sequelize']['fn'](_0x9e6e('0x4e'),db[_0x9e6e('0x52')]['fn']('IF',db['sequelize']['literal'](_0x9e6e('0x5d')))),_0x9e6e('0x5e')]]})[_0x9e6e('0x25')](handleEntityNotFound(_0x5d9905,null))[_0x9e6e('0x25')](respondWithResult(_0x5d9905,null))[_0x9e6e('0x43')](handleError(_0x5d9905,null));};exports[_0x9e6e('0x61')]=function(_0x1718f1,_0xba73a5,_0x5ab96e){return db['VoiceQueue'][_0x9e6e('0x49')]({'where':{'id':_0x1718f1['params']['id']}})[_0x9e6e('0x25')](handleEntityNotFound(_0xba73a5,null))[_0x9e6e('0x25')](function(_0x191a55){var _0x3445fb;if(_0x191a55){_0x3445fb=squel[_0x9e6e('0x62')]()['into'](_0x9e6e('0x63'))[_0x9e6e('0x64')]([_0x9e6e('0x65'),_0x9e6e('0x66'),_0x9e6e('0x67'),'ListId',_0x9e6e('0x68'),'createdAt','updatedAt'],squel[_0x9e6e('0x69')]()[_0x9e6e('0x6a')]('ANY_VALUE(calleridnum)',_0x9e6e('0x65'))[_0x9e6e('0x6a')]('NOW()','scheduledAt')[_0x9e6e('0x6a')](_0x9e6e('0x6b'),_0x9e6e('0x67'))[_0x9e6e('0x6a')](_0x9e6e('0x6c'),_0x9e6e('0x6d'))[_0x9e6e('0x6a')]('ANY_VALUE(VoiceQueueId)','VoiceQueueId')[_0x9e6e('0x6a')](_0x9e6e('0x6e'),'createdAt')[_0x9e6e('0x6a')](_0x9e6e('0x6e'),_0x9e6e('0x6f'))[_0x9e6e('0x70')](_0x9e6e('0x71'))['where'](_0x9e6e('0x72'),_0x1718f1[_0x9e6e('0x45')]['id'][_0x9e6e('0x73')]())['where'](_0x9e6e('0x74'),_0x1718f1[_0x9e6e('0x4a')][_0x9e6e('0x75')][_0x9e6e('0x73')]())['where'](_0x9e6e('0x76'))[_0x9e6e('0x3d')](_0x9e6e('0x77'),squel[_0x9e6e('0x69')]()[_0x9e6e('0x6a')](_0x9e6e('0x65'))[_0x9e6e('0x70')]('cm_hopper')['where']('VoiceQueueId\x20=\x20?',_0x1718f1[_0x9e6e('0x45')]['id'][_0x9e6e('0x73')]()))[_0x9e6e('0x3d')]('calleridnum\x20NOT\x20IN\x20(?)',squel[_0x9e6e('0x69')]()[_0x9e6e('0x6a')](_0x9e6e('0x78'))['from'](_0x9e6e('0x71'))[_0x9e6e('0x3d')](_0x9e6e('0x72'),_0x1718f1['params']['id'][_0x9e6e('0x73')]())[_0x9e6e('0x3d')](_0x9e6e('0x79')))['group'](_0x9e6e('0x67')))[_0x9e6e('0x73')]();return db[_0x9e6e('0x52')]['query'](_0x3445fb);}return[];})[_0x9e6e('0x25')](respondWithResult(_0xba73a5,null))[_0x9e6e('0x43')](handleError(_0xba73a5,null));};exports[_0x9e6e('0x7a')]=function(_0x3e1500,_0x3fe7d0,_0x177e63){return db['Campaign']['find']({'where':{'id':_0x3e1500[_0x9e6e('0x45')]['id']}})[_0x9e6e('0x25')](handleEntityNotFound(_0x3fe7d0,null))[_0x9e6e('0x25')](function(_0x4fefaa){var _0x5c20c0;if(_0x4fefaa){_0x5c20c0=squel['insert']()[_0x9e6e('0x7b')](_0x9e6e('0x63'))[_0x9e6e('0x64')](['phone','scheduledAt',_0x9e6e('0x67'),_0x9e6e('0x6d'),_0x9e6e('0x7c'),_0x9e6e('0x7d'),'updatedAt'],squel[_0x9e6e('0x69')]()[_0x9e6e('0x6a')]('ANY_VALUE(calleridnum)',_0x9e6e('0x65'))[_0x9e6e('0x6a')](_0x9e6e('0x6e'),'scheduledAt')[_0x9e6e('0x6a')](_0x9e6e('0x6b'),'ContactId')[_0x9e6e('0x6a')](_0x9e6e('0x6c'),'ListId')[_0x9e6e('0x6a')]('ANY_VALUE(CampaignId)',_0x9e6e('0x7c'))[_0x9e6e('0x6a')](_0x9e6e('0x6e'),_0x9e6e('0x7d'))['field'](_0x9e6e('0x6e'),'updatedAt')[_0x9e6e('0x70')](_0x9e6e('0x71'))[_0x9e6e('0x3d')](_0x9e6e('0x7e'),_0x3e1500[_0x9e6e('0x45')]['id']['toString']())[_0x9e6e('0x3d')](_0x9e6e('0x74'),_0x3e1500['body'][_0x9e6e('0x75')][_0x9e6e('0x73')]())[_0x9e6e('0x3d')](_0x9e6e('0x76'))[_0x9e6e('0x3d')](_0x9e6e('0x77'),squel[_0x9e6e('0x69')]()['field'](_0x9e6e('0x65'))[_0x9e6e('0x70')](_0x9e6e('0x63'))[_0x9e6e('0x3d')]('CampaignId\x20=\x20?',_0x3e1500[_0x9e6e('0x45')]['id'][_0x9e6e('0x73')]()))[_0x9e6e('0x3d')](_0x9e6e('0x77'),squel[_0x9e6e('0x69')]()[_0x9e6e('0x6a')]('calleridnum')[_0x9e6e('0x70')]('cm_hopper_final')['where'](_0x9e6e('0x7e'),_0x3e1500['params']['id'][_0x9e6e('0x73')]())[_0x9e6e('0x3d')](_0x9e6e('0x79')))['group'](_0x9e6e('0x67')))[_0x9e6e('0x73')]();return db['sequelize'][_0x9e6e('0x33')](_0x5c20c0);}return[];})[_0x9e6e('0x25')](respondWithResult(_0x3fe7d0,null))[_0x9e6e('0x43')](handleError(_0x3fe7d0,null));};exports['checkContactHopper']=function(_0x5dbf3a,_0xb235e6,_0xdd0e5c){return db['CmHopper'][_0x9e6e('0x7f')]({'where':{'VoiceQueueId':_0x5dbf3a[_0x9e6e('0x4a')][_0x9e6e('0x68')],'CampaignId':_0x5dbf3a[_0x9e6e('0x4a')][_0x9e6e('0x7c')],'ContactId':_0x5dbf3a[_0x9e6e('0x4a')]['ContactId']}})[_0x9e6e('0x25')](handleEntityNotFound(_0xb235e6,null))['then'](function(_0x315bb8){if(_0x315bb8){return _0x315bb8;}return null;})[_0x9e6e('0x25')](respondWithResult(_0xb235e6,null))[_0x9e6e('0x43')](handleError(_0xb235e6,null));};
\ No newline at end of file
+var _0x7a54=['calleridnum\x20NOT\x20IN\x20(?)','calleridnum','Campaign','CampaignId','ANY_VALUE(CampaignId)','CampaignId\x20=\x20?','state\x20=\x204','group','checkContactHopper','findOne','eml-format','rimraf','zip-dir','request-promise','moment','mustache','util','path','sox','to-csv','fs-extra','squel','crypto','desk.js','ioredis','../../components/auth/service','../../components/parsers/advancedSearch','api','../../config/utils','../../config/environment','../../config/license/util','../../mysqldb','sendStatus','status','end','json','offset','undefined','count','limit','set','Content-Range','reject','save','update','then','destroy','error','stack','name','send','index','CmHopperFinal','fieldName','type','model','map','query','filters','intersection','attributes','fields','hasOwnProperty','nolimit','order','sort','where','pick','filter','VIRTUAL','includeAll','include','findAll','rows','show','params','length','merge','options','find','catch','uniqueid','body','countContactsQueueCampaignHopperFinal','COUNT','sequelize','`state`\x20=\x200,\x201,\x20null','`state`\x20=\x203,\x201,\x20null','noAnswerContacts','literal','busyContacts','congestionContacts','`state`\x20=\x2010\x20,\x201,\x20null','`state`\x20=\x2011\x20,\x201,\x20null','reCallContacts','`state`\x20=\x2019,\x201,\x20null','answeringMachine','countContactsIvrCampaignHopperFinal','`state`\x20=\x205,\x201,\x20null','`state`\x20=\x208,\x201,\x20null','dropContacts','abandonedContacts','`state`\x20=\x2022,\x201,\x20null','moveContactsQueueCampaignHopperFinal','insert','into','cm_hopper','ContactId','ListId','VoiceQueueId','createdAt','select','field','ANY_VALUE(calleridnum)','phone','NOW()','scheduledAt','ANY_VALUE(ContactId)','ANY_VALUE(ListId)','updatedAt','from','cm_hopper_final','VoiceQueueId\x20=\x20?','toString','state\x20=\x20?','calleridnum\x20IS\x20NOT\x20NULL'];(function(_0x16e072,_0x58f2b9){var _0x67a82d=function(_0x15abcd){while(--_0x15abcd){_0x16e072['push'](_0x16e072['shift']());}};_0x67a82d(++_0x58f2b9);}(_0x7a54,0x106));var _0x47a5=function(_0x1d5f99,_0x4c81bd){_0x1d5f99=_0x1d5f99-0x0;var _0x28c0b5=_0x7a54[_0x1d5f99];return _0x28c0b5;};'use strict';var emlformat=require(_0x47a5('0x0'));var rimraf=require(_0x47a5('0x1'));var zipdir=require(_0x47a5('0x2'));var jsonpatch=require('fast-json-patch');var rp=require(_0x47a5('0x3'));var moment=require(_0x47a5('0x4'));var BPromise=require('bluebird');var Mustache=require(_0x47a5('0x5'));var util=require(_0x47a5('0x6'));var path=require(_0x47a5('0x7'));var sox=require(_0x47a5('0x8'));var csv=require(_0x47a5('0x9'));var ejs=require('ejs');var fs=require('fs');var fs_extra=require(_0x47a5('0xa'));var _=require('lodash');var squel=require(_0x47a5('0xb'));var crypto=require(_0x47a5('0xc'));var jsforce=require('jsforce');var deskjs=require(_0x47a5('0xd'));var toCsv=require('to-csv');var querystring=require('querystring');var Papa=require('papaparse');var Redis=require(_0x47a5('0xe'));var authService=require(_0x47a5('0xf'));var qs=require('../../components/parsers/qs');var as=require(_0x47a5('0x10'));var hardwareService=require('../../config/license/hardware');var logger=require('../../config/logger')(_0x47a5('0x11'));var utils=require(_0x47a5('0x12'));var config=require(_0x47a5('0x13'));var licenseUtil=require(_0x47a5('0x14'));var db=require(_0x47a5('0x15'))['db'];function respondWithStatusCode(_0xd308b8,_0x1eae59){_0x1eae59=_0x1eae59||0xcc;return function(_0x5beb89){if(_0x5beb89){return _0xd308b8[_0x47a5('0x16')](_0x1eae59);}return _0xd308b8[_0x47a5('0x17')](_0x1eae59)[_0x47a5('0x18')]();};}function respondWithResult(_0x711793,_0x139f25){_0x139f25=_0x139f25||0xc8;return function(_0x620ee9){if(_0x620ee9){return _0x711793[_0x47a5('0x17')](_0x139f25)[_0x47a5('0x19')](_0x620ee9);}};}function respondWithFilteredResult(_0x4e99a8,_0x362359){return function(_0x11faf5){if(_0x11faf5){var _0x3b001e=typeof _0x362359[_0x47a5('0x1a')]===_0x47a5('0x1b')&&typeof _0x362359['limit']==='undefined';var _0x138bc0=_0x11faf5['count'];var _0x5247fd=_0x3b001e?0x0:_0x362359[_0x47a5('0x1a')];var _0xaf70a6=_0x3b001e?_0x11faf5[_0x47a5('0x1c')]:_0x362359[_0x47a5('0x1a')]+_0x362359[_0x47a5('0x1d')];var _0x12b98e;if(_0xaf70a6>=_0x138bc0){_0xaf70a6=_0x138bc0;_0x12b98e=0xc8;}else{_0x12b98e=0xce;}_0x4e99a8[_0x47a5('0x17')](_0x12b98e);return _0x4e99a8[_0x47a5('0x1e')](_0x47a5('0x1f'),_0x5247fd+'-'+_0xaf70a6+'/'+_0x138bc0)['json'](_0x11faf5);}return null;};}function patchUpdates(_0x1570bc){return function(_0xf160ba){try{jsonpatch['apply'](_0xf160ba,_0x1570bc,!![]);}catch(_0x2b0360){return BPromise[_0x47a5('0x20')](_0x2b0360);}return _0xf160ba[_0x47a5('0x21')]();};}function saveUpdates(_0x4c5910,_0xb8ae6c){return function(_0x2f142b){if(_0x2f142b){return _0x2f142b[_0x47a5('0x22')](_0x4c5910)[_0x47a5('0x23')](function(_0x5ef1b1){return _0x5ef1b1;});}return null;};}function removeEntity(_0xe2dea9,_0x385687){return function(_0x513981){if(_0x513981){return _0x513981[_0x47a5('0x24')]()[_0x47a5('0x23')](function(){_0xe2dea9[_0x47a5('0x17')](0xcc)[_0x47a5('0x18')]();});}};}function handleEntityNotFound(_0x3abd6a,_0x50bf17){return function(_0x53078a){if(!_0x53078a){_0x3abd6a[_0x47a5('0x16')](0x194);}return _0x53078a;};}function handleError(_0x5686db,_0x1ea9c8){_0x1ea9c8=_0x1ea9c8||0x1f4;return function(_0x5b6c4e){logger[_0x47a5('0x25')](_0x5b6c4e[_0x47a5('0x26')]);if(_0x5b6c4e[_0x47a5('0x27')]){delete _0x5b6c4e[_0x47a5('0x27')];}_0x5686db[_0x47a5('0x17')](_0x1ea9c8)[_0x47a5('0x28')](_0x5b6c4e);};}exports[_0x47a5('0x29')]=function(_0x136b14,_0x16631f){var _0x361bfa={},_0x1127f8={},_0x11a4fa={'count':0x0,'rows':[]};var _0x3ad507=_['map'](db[_0x47a5('0x2a')]['rawAttributes'],function(_0x2ef875){return{'name':_0x2ef875[_0x47a5('0x2b')],'type':_0x2ef875[_0x47a5('0x2c')]['key']};});_0x1127f8[_0x47a5('0x2d')]=_[_0x47a5('0x2e')](_0x3ad507,_0x47a5('0x27'));_0x1127f8[_0x47a5('0x2f')]=_['keys'](_0x136b14['query']);_0x1127f8[_0x47a5('0x30')]=_[_0x47a5('0x31')](_0x1127f8['model'],_0x1127f8['query']);_0x361bfa[_0x47a5('0x32')]=_[_0x47a5('0x31')](_0x1127f8['model'],qs[_0x47a5('0x33')](_0x136b14['query'][_0x47a5('0x33')]));_0x361bfa[_0x47a5('0x32')]=_0x361bfa['attributes']['length']?_0x361bfa[_0x47a5('0x32')]:_0x1127f8['model'];if(!_0x136b14[_0x47a5('0x2f')][_0x47a5('0x34')](_0x47a5('0x35'))){_0x361bfa['limit']=qs[_0x47a5('0x1d')](_0x136b14['query']['limit']);_0x361bfa[_0x47a5('0x1a')]=qs['offset'](_0x136b14[_0x47a5('0x2f')]['offset']);}_0x361bfa[_0x47a5('0x36')]=qs[_0x47a5('0x37')](_0x136b14[_0x47a5('0x2f')][_0x47a5('0x37')]);_0x361bfa[_0x47a5('0x38')]=qs[_0x47a5('0x30')](_[_0x47a5('0x39')](_0x136b14[_0x47a5('0x2f')],_0x1127f8[_0x47a5('0x30')]),_0x3ad507);if(_0x136b14['query'][_0x47a5('0x3a')]){_0x361bfa[_0x47a5('0x38')]=_['merge'](_0x361bfa[_0x47a5('0x38')],{'$or':_[_0x47a5('0x2e')](_0x3ad507,function(_0x1d4348){if(_0x1d4348['type']!==_0x47a5('0x3b')){var _0x10f660={};_0x10f660[_0x1d4348['name']]={'$like':'%'+_0x136b14[_0x47a5('0x2f')][_0x47a5('0x3a')]+'%'};return _0x10f660;}})});}_0x361bfa=_['merge']({},_0x361bfa,_0x136b14['options']);var _0x5ebd8c={'where':_0x361bfa[_0x47a5('0x38')]};return db['CmHopperFinal'][_0x47a5('0x1c')](_0x5ebd8c)[_0x47a5('0x23')](function(_0x301a85){_0x11a4fa[_0x47a5('0x1c')]=_0x301a85;if(_0x136b14[_0x47a5('0x2f')][_0x47a5('0x3c')]){_0x361bfa[_0x47a5('0x3d')]=[{'all':!![]}];}return db[_0x47a5('0x2a')][_0x47a5('0x3e')](_0x361bfa);})[_0x47a5('0x23')](function(_0x280500){_0x11a4fa[_0x47a5('0x3f')]=_0x280500;return _0x11a4fa;})[_0x47a5('0x23')](respondWithFilteredResult(_0x16631f,_0x361bfa))['catch'](handleError(_0x16631f,null));};exports[_0x47a5('0x40')]=function(_0x1c36fa,_0x331474){var _0x23bd8d={'raw':!![],'where':{'id':_0x1c36fa[_0x47a5('0x41')]['id']}},_0x586f4f={};_0x586f4f['model']=_['keys'](db['CmHopperFinal']['rawAttributes']);_0x586f4f[_0x47a5('0x2f')]=_['keys'](_0x1c36fa[_0x47a5('0x2f')]);_0x586f4f[_0x47a5('0x30')]=_[_0x47a5('0x31')](_0x586f4f['model'],_0x586f4f[_0x47a5('0x2f')]);_0x23bd8d[_0x47a5('0x32')]=_['intersection'](_0x586f4f['model'],qs[_0x47a5('0x33')](_0x1c36fa['query'][_0x47a5('0x33')]));_0x23bd8d[_0x47a5('0x32')]=_0x23bd8d[_0x47a5('0x32')][_0x47a5('0x42')]?_0x23bd8d[_0x47a5('0x32')]:_0x586f4f[_0x47a5('0x2d')];if(_0x1c36fa[_0x47a5('0x2f')][_0x47a5('0x3c')]){_0x23bd8d[_0x47a5('0x3d')]=[{'all':!![]}];}_0x23bd8d=_[_0x47a5('0x43')]({},_0x23bd8d,_0x1c36fa[_0x47a5('0x44')]);return db[_0x47a5('0x2a')][_0x47a5('0x45')](_0x23bd8d)[_0x47a5('0x23')](handleEntityNotFound(_0x331474,null))[_0x47a5('0x23')](respondWithResult(_0x331474,null))[_0x47a5('0x46')](handleError(_0x331474,null));};exports['describe']=function(_0x2d38de,_0x23bb04){return db['CmHopperFinal']['describe']()[_0x47a5('0x23')](respondWithResult(_0x23bb04,null))['catch'](handleError(_0x23bb04,null));};exports[_0x47a5('0x22')]=function(_0xd93e37,_0x54c35f){if(_0xd93e37['body'][_0x47a5('0x47')]){delete _0xd93e37['body'][_0x47a5('0x47')];}return db[_0x47a5('0x2a')][_0x47a5('0x45')]({'where':{'uniqueid':_0xd93e37[_0x47a5('0x41')]['id']}})[_0x47a5('0x23')](handleEntityNotFound(_0x54c35f,null))[_0x47a5('0x23')](saveUpdates(_0xd93e37[_0x47a5('0x48')],null))['then'](respondWithResult(_0x54c35f,null))['catch'](handleError(_0x54c35f,null));};exports[_0x47a5('0x49')]=function(_0x411230,_0x1163e3,_0x9ea93e){return db[_0x47a5('0x2a')][_0x47a5('0x3e')]({'raw':![],'where':{'VoiceQueueId':_0x411230[_0x47a5('0x41')]['id']},'attributes':[[db['sequelize']['fn'](_0x47a5('0x4a'),db[_0x47a5('0x4b')]['fn']('IF',db[_0x47a5('0x4b')]['literal'](_0x47a5('0x4c')))),'noSuchContacts'],[db[_0x47a5('0x4b')]['fn'](_0x47a5('0x4a'),db[_0x47a5('0x4b')]['fn']('IF',db[_0x47a5('0x4b')]['literal'](_0x47a5('0x4d')))),_0x47a5('0x4e')],[db[_0x47a5('0x4b')]['fn'](_0x47a5('0x4a'),db[_0x47a5('0x4b')]['fn']('IF',db[_0x47a5('0x4b')][_0x47a5('0x4f')]('`state`\x20=\x205,\x201,\x20null'))),_0x47a5('0x50')],[db[_0x47a5('0x4b')]['fn'](_0x47a5('0x4a'),db[_0x47a5('0x4b')]['fn']('IF',db[_0x47a5('0x4b')][_0x47a5('0x4f')]('`state`\x20=\x208,\x201,\x20null'))),_0x47a5('0x51')],[db[_0x47a5('0x4b')]['fn'](_0x47a5('0x4a'),db['sequelize']['fn']('IF',db[_0x47a5('0x4b')][_0x47a5('0x4f')](_0x47a5('0x52')))),'dropContacts'],[db['sequelize']['fn'](_0x47a5('0x4a'),db[_0x47a5('0x4b')]['fn']('IF',db['sequelize']['literal'](_0x47a5('0x53')))),'abandonedContacts'],[db[_0x47a5('0x4b')]['fn']('COUNT',db['sequelize']['fn']('IF',db[_0x47a5('0x4b')][_0x47a5('0x4f')]('`state`\x20=\x2022,\x201,\x20null'))),_0x47a5('0x54')],[db[_0x47a5('0x4b')]['fn']('COUNT',db['sequelize']['fn']('IF',db[_0x47a5('0x4b')][_0x47a5('0x4f')](_0x47a5('0x55')))),_0x47a5('0x56')]]})['then'](handleEntityNotFound(_0x1163e3,null))[_0x47a5('0x23')](respondWithResult(_0x1163e3,null))[_0x47a5('0x46')](handleError(_0x1163e3,null));};exports[_0x47a5('0x57')]=function(_0x5a33b8,_0x30ea7a,_0x4db625){return db[_0x47a5('0x2a')][_0x47a5('0x3e')]({'raw':![],'where':{'CampaignId':_0x5a33b8[_0x47a5('0x41')]['id']},'attributes':[[db[_0x47a5('0x4b')]['fn'](_0x47a5('0x4a'),db['sequelize']['fn']('IF',db[_0x47a5('0x4b')]['literal']('`state`\x20=\x200,\x201,\x20null'))),'noSuchContacts'],[db['sequelize']['fn'](_0x47a5('0x4a'),db[_0x47a5('0x4b')]['fn']('IF',db[_0x47a5('0x4b')]['literal']('`state`\x20=\x203,\x201,\x20null'))),_0x47a5('0x4e')],[db[_0x47a5('0x4b')]['fn'](_0x47a5('0x4a'),db[_0x47a5('0x4b')]['fn']('IF',db[_0x47a5('0x4b')]['literal'](_0x47a5('0x58')))),'busyContacts'],[db[_0x47a5('0x4b')]['fn'](_0x47a5('0x4a'),db['sequelize']['fn']('IF',db[_0x47a5('0x4b')][_0x47a5('0x4f')](_0x47a5('0x59')))),_0x47a5('0x51')],[db[_0x47a5('0x4b')]['fn'](_0x47a5('0x4a'),db[_0x47a5('0x4b')]['fn']('IF',db[_0x47a5('0x4b')]['literal'](_0x47a5('0x52')))),_0x47a5('0x5a')],[db[_0x47a5('0x4b')]['fn'](_0x47a5('0x4a'),db[_0x47a5('0x4b')]['fn']('IF',db['sequelize'][_0x47a5('0x4f')](_0x47a5('0x53')))),_0x47a5('0x5b')],[db[_0x47a5('0x4b')]['fn'](_0x47a5('0x4a'),db[_0x47a5('0x4b')]['fn']('IF',db[_0x47a5('0x4b')][_0x47a5('0x4f')](_0x47a5('0x5c')))),_0x47a5('0x54')],[db[_0x47a5('0x4b')]['fn'](_0x47a5('0x4a'),db[_0x47a5('0x4b')]['fn']('IF',db[_0x47a5('0x4b')][_0x47a5('0x4f')]('`state`\x20=\x2019,\x201,\x20null'))),_0x47a5('0x56')]]})[_0x47a5('0x23')](handleEntityNotFound(_0x30ea7a,null))[_0x47a5('0x23')](respondWithResult(_0x30ea7a,null))['catch'](handleError(_0x30ea7a,null));};exports[_0x47a5('0x5d')]=function(_0x2e46af,_0x36c67,_0x26f1ac){return db['VoiceQueue'][_0x47a5('0x45')]({'where':{'id':_0x2e46af['params']['id']}})[_0x47a5('0x23')](handleEntityNotFound(_0x36c67,null))['then'](function(_0x43f649){var _0x4cf7c5;if(_0x43f649){_0x4cf7c5=squel[_0x47a5('0x5e')]()[_0x47a5('0x5f')](_0x47a5('0x60'))['fromQuery'](['phone','scheduledAt',_0x47a5('0x61'),_0x47a5('0x62'),_0x47a5('0x63'),_0x47a5('0x64'),'updatedAt'],squel[_0x47a5('0x65')]()[_0x47a5('0x66')](_0x47a5('0x67'),_0x47a5('0x68'))[_0x47a5('0x66')](_0x47a5('0x69'),_0x47a5('0x6a'))[_0x47a5('0x66')](_0x47a5('0x6b'),_0x47a5('0x61'))[_0x47a5('0x66')](_0x47a5('0x6c'),'ListId')[_0x47a5('0x66')]('ANY_VALUE(VoiceQueueId)',_0x47a5('0x63'))[_0x47a5('0x66')](_0x47a5('0x69'),_0x47a5('0x64'))[_0x47a5('0x66')](_0x47a5('0x69'),_0x47a5('0x6d'))[_0x47a5('0x6e')](_0x47a5('0x6f'))[_0x47a5('0x38')](_0x47a5('0x70'),_0x2e46af[_0x47a5('0x41')]['id'][_0x47a5('0x71')]())[_0x47a5('0x38')](_0x47a5('0x72'),_0x2e46af['body']['state']['toString']())['where'](_0x47a5('0x73'))[_0x47a5('0x38')]('calleridnum\x20NOT\x20IN\x20(?)',squel[_0x47a5('0x65')]()[_0x47a5('0x66')](_0x47a5('0x68'))[_0x47a5('0x6e')](_0x47a5('0x60'))[_0x47a5('0x38')](_0x47a5('0x70'),_0x2e46af[_0x47a5('0x41')]['id'][_0x47a5('0x71')]()))[_0x47a5('0x38')](_0x47a5('0x74'),squel['select']()[_0x47a5('0x66')](_0x47a5('0x75'))[_0x47a5('0x6e')]('cm_hopper_final')[_0x47a5('0x38')](_0x47a5('0x70'),_0x2e46af[_0x47a5('0x41')]['id']['toString']())[_0x47a5('0x38')]('state\x20=\x204'))['group'](_0x47a5('0x61')))[_0x47a5('0x71')]();return db[_0x47a5('0x4b')][_0x47a5('0x2f')](_0x4cf7c5);}return[];})[_0x47a5('0x23')](respondWithResult(_0x36c67,null))[_0x47a5('0x46')](handleError(_0x36c67,null));};exports['moveContactsIvrCampaignHopperFinal']=function(_0x592322,_0x3e0dbd,_0x4f2361){return db[_0x47a5('0x76')][_0x47a5('0x45')]({'where':{'id':_0x592322[_0x47a5('0x41')]['id']}})[_0x47a5('0x23')](handleEntityNotFound(_0x3e0dbd,null))['then'](function(_0x3c66e3){var _0x550bde;if(_0x3c66e3){_0x550bde=squel['insert']()[_0x47a5('0x5f')](_0x47a5('0x60'))['fromQuery']([_0x47a5('0x68'),_0x47a5('0x6a'),_0x47a5('0x61'),'ListId',_0x47a5('0x77'),'createdAt',_0x47a5('0x6d')],squel[_0x47a5('0x65')]()[_0x47a5('0x66')]('ANY_VALUE(calleridnum)',_0x47a5('0x68'))[_0x47a5('0x66')](_0x47a5('0x69'),'scheduledAt')[_0x47a5('0x66')]('ANY_VALUE(ContactId)',_0x47a5('0x61'))['field'](_0x47a5('0x6c'),_0x47a5('0x62'))[_0x47a5('0x66')](_0x47a5('0x78'),'CampaignId')[_0x47a5('0x66')](_0x47a5('0x69'),_0x47a5('0x64'))[_0x47a5('0x66')](_0x47a5('0x69'),'updatedAt')['from'](_0x47a5('0x6f'))['where'](_0x47a5('0x79'),_0x592322[_0x47a5('0x41')]['id'][_0x47a5('0x71')]())['where'](_0x47a5('0x72'),_0x592322[_0x47a5('0x48')]['state'][_0x47a5('0x71')]())[_0x47a5('0x38')](_0x47a5('0x73'))[_0x47a5('0x38')]('calleridnum\x20NOT\x20IN\x20(?)',squel['select']()[_0x47a5('0x66')](_0x47a5('0x68'))['from'](_0x47a5('0x60'))[_0x47a5('0x38')]('CampaignId\x20=\x20?',_0x592322[_0x47a5('0x41')]['id'][_0x47a5('0x71')]()))[_0x47a5('0x38')]('calleridnum\x20NOT\x20IN\x20(?)',squel[_0x47a5('0x65')]()['field'](_0x47a5('0x75'))['from'](_0x47a5('0x6f'))[_0x47a5('0x38')]('CampaignId\x20=\x20?',_0x592322[_0x47a5('0x41')]['id']['toString']())[_0x47a5('0x38')](_0x47a5('0x7a')))[_0x47a5('0x7b')](_0x47a5('0x61')))['toString']();return db[_0x47a5('0x4b')]['query'](_0x550bde);}return[];})['then'](respondWithResult(_0x3e0dbd,null))[_0x47a5('0x46')](handleError(_0x3e0dbd,null));};exports[_0x47a5('0x7c')]=function(_0x352238,_0x96fb22,_0x380c8b){return db['CmHopper'][_0x47a5('0x7d')]({'where':{'VoiceQueueId':_0x352238[_0x47a5('0x48')][_0x47a5('0x63')],'CampaignId':_0x352238[_0x47a5('0x48')]['CampaignId'],'ContactId':_0x352238[_0x47a5('0x48')]['ContactId']}})[_0x47a5('0x23')](handleEntityNotFound(_0x96fb22,null))[_0x47a5('0x23')](function(_0x3f93f0){if(_0x3f93f0){return _0x3f93f0;}return null;})[_0x47a5('0x23')](respondWithResult(_0x96fb22,null))[_0x47a5('0x46')](handleError(_0x96fb22,null));};
\ No newline at end of file