Built motion from commit 092f8824.|2.5.49
[motion2.git] / server / api / cmHopperFinal / cmHopperFinal.controller.js
index a2fdddc..8198e0e 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0x5309=['reject','save','update','then','destroy','error','stack','name','send','index','map','CmHopperFinal','rawAttributes','fieldName','model','query','keys','filters','attributes','fields','length','hasOwnProperty','order','sort','where','filter','merge','type','VIRTUAL','options','includeAll','include','findAll','rows','params','intersection','find','catch','describe','body','uniqueid','countContactsQueueCampaignHopperFinal','sequelize','literal','noSuchContacts','COUNT','`state`\x20=\x203,\x201,\x20null','noAnswerContacts','`state`\x20=\x205,\x201,\x20null','busyContacts','`state`\x20=\x208,\x201,\x20null','congestionContacts','dropContacts','`state`\x20=\x2011\x20,\x201,\x20null','abandonedContacts','`state`\x20=\x2022,\x201,\x20null','reCallContacts','countContactsIvrCampaignHopperFinal','`state`\x20=\x2010\x20,\x201,\x20null','`state`\x20=\x2019,\x201,\x20null','answeringMachine','moveContactsQueueCampaignHopperFinal','VoiceQueue','insert','into','fromQuery','phone','scheduledAt','ListId','VoiceQueueId','updatedAt','select','field','ANY_VALUE(calleridnum)','ANY_VALUE(ListId)','NOW()','from','cm_hopper_final','VoiceQueueId\x20=\x20?','toString','state\x20=\x20?','calleridnum\x20IS\x20NOT\x20NULL','calleridnum\x20NOT\x20IN\x20(?)','calleridnum','state\x20=\x204','ContactId','moveContactsIvrCampaignHopperFinal','Campaign','cm_hopper','CampaignId','ANY_VALUE(ContactId)','ANY_VALUE(CampaignId)','createdAt','CampaignId\x20=\x20?','state','group','checkContactHopper','eml-format','rimraf','fast-json-patch','request-promise','moment','mustache','to-csv','ejs','fs-extra','lodash','squel','crypto','jsforce','desk.js','papaparse','ioredis','../../components/parsers/advancedSearch','../../config/license/hardware','../../config/logger','api','../../config/environment','../../config/license/util','../../mysqldb','sendStatus','status','end','json','offset','limit','undefined','count','Content-Range','apply'];(function(_0x27cc19,_0x107641){var _0x2c9ded=function(_0x1f1f02){while(--_0x1f1f02){_0x27cc19['push'](_0x27cc19['shift']());}};_0x2c9ded(++_0x107641);}(_0x5309,0x165));var _0x9530=function(_0xaf25ae,_0x2001c1){_0xaf25ae=_0xaf25ae-0x0;var _0x49732d=_0x5309[_0xaf25ae];return _0x49732d;};'use strict';var emlformat=require(_0x9530('0x0'));var rimraf=require(_0x9530('0x1'));var zipdir=require('zip-dir');var jsonpatch=require(_0x9530('0x2'));var rp=require(_0x9530('0x3'));var moment=require(_0x9530('0x4'));var BPromise=require('bluebird');var Mustache=require(_0x9530('0x5'));var util=require('util');var path=require('path');var sox=require('sox');var csv=require(_0x9530('0x6'));var ejs=require(_0x9530('0x7'));var fs=require('fs');var fs_extra=require(_0x9530('0x8'));var _=require(_0x9530('0x9'));var squel=require(_0x9530('0xa'));var crypto=require(_0x9530('0xb'));var jsforce=require(_0x9530('0xc'));var deskjs=require(_0x9530('0xd'));var toCsv=require('to-csv');var querystring=require('querystring');var Papa=require(_0x9530('0xe'));var Redis=require(_0x9530('0xf'));var authService=require('../../components/auth/service');var qs=require('../../components/parsers/qs');var as=require(_0x9530('0x10'));var hardwareService=require(_0x9530('0x11'));var logger=require(_0x9530('0x12'))(_0x9530('0x13'));var utils=require('../../config/utils');var config=require(_0x9530('0x14'));var licenseUtil=require(_0x9530('0x15'));var db=require(_0x9530('0x16'))['db'];function respondWithStatusCode(_0xfabb74,_0x364fd9){_0x364fd9=_0x364fd9||0xcc;return function(_0x5ac2a5){if(_0x5ac2a5){return _0xfabb74[_0x9530('0x17')](_0x364fd9);}return _0xfabb74[_0x9530('0x18')](_0x364fd9)[_0x9530('0x19')]();};}function respondWithResult(_0x5c5cc8,_0x209f8c){_0x209f8c=_0x209f8c||0xc8;return function(_0x467a3d){if(_0x467a3d){return _0x5c5cc8[_0x9530('0x18')](_0x209f8c)[_0x9530('0x1a')](_0x467a3d);}};}function respondWithFilteredResult(_0x18a712,_0x36bda3){return function(_0x2a1b9c){if(_0x2a1b9c){var _0x27f6b8=typeof _0x36bda3[_0x9530('0x1b')]==='undefined'&&typeof _0x36bda3[_0x9530('0x1c')]===_0x9530('0x1d');var _0x1ca71a=_0x2a1b9c[_0x9530('0x1e')];var _0x42df25=_0x27f6b8?0x0:_0x36bda3['offset'];var _0x270375=_0x27f6b8?_0x2a1b9c[_0x9530('0x1e')]:_0x36bda3[_0x9530('0x1b')]+_0x36bda3['limit'];var _0x30b274;if(_0x270375>=_0x1ca71a){_0x270375=_0x1ca71a;_0x30b274=0xc8;}else{_0x30b274=0xce;}_0x18a712['status'](_0x30b274);return _0x18a712['set'](_0x9530('0x1f'),_0x42df25+'-'+_0x270375+'/'+_0x1ca71a)[_0x9530('0x1a')](_0x2a1b9c);}return null;};}function patchUpdates(_0x9f4484){return function(_0xe4db8){try{jsonpatch[_0x9530('0x20')](_0xe4db8,_0x9f4484,!![]);}catch(_0x43d47d){return BPromise[_0x9530('0x21')](_0x43d47d);}return _0xe4db8[_0x9530('0x22')]();};}function saveUpdates(_0x371e99,_0x475d98){return function(_0x242ec4){if(_0x242ec4){return _0x242ec4[_0x9530('0x23')](_0x371e99)[_0x9530('0x24')](function(_0x4cf58e){return _0x4cf58e;});}return null;};}function removeEntity(_0x4c98e0,_0x2e05d8){return function(_0xed9cfa){if(_0xed9cfa){return _0xed9cfa[_0x9530('0x25')]()[_0x9530('0x24')](function(){_0x4c98e0[_0x9530('0x18')](0xcc)[_0x9530('0x19')]();});}};}function handleEntityNotFound(_0x50349e,_0x4de891){return function(_0x184d6f){if(!_0x184d6f){_0x50349e['sendStatus'](0x194);}return _0x184d6f;};}function handleError(_0x4fa31b,_0x151296){_0x151296=_0x151296||0x1f4;return function(_0x688dbc){logger[_0x9530('0x26')](_0x688dbc[_0x9530('0x27')]);if(_0x688dbc['name']){delete _0x688dbc[_0x9530('0x28')];}_0x4fa31b[_0x9530('0x18')](_0x151296)[_0x9530('0x29')](_0x688dbc);};}exports[_0x9530('0x2a')]=function(_0x541f33,_0x4e4aa6){var _0x1a86a3={},_0x25d176={},_0x143e8b={'count':0x0,'rows':[]};var _0x1330ec=_[_0x9530('0x2b')](db[_0x9530('0x2c')][_0x9530('0x2d')],function(_0x5a20f2){return{'name':_0x5a20f2[_0x9530('0x2e')],'type':_0x5a20f2['type']['key']};});_0x25d176[_0x9530('0x2f')]=_[_0x9530('0x2b')](_0x1330ec,'name');_0x25d176[_0x9530('0x30')]=_[_0x9530('0x31')](_0x541f33[_0x9530('0x30')]);_0x25d176[_0x9530('0x32')]=_['intersection'](_0x25d176[_0x9530('0x2f')],_0x25d176[_0x9530('0x30')]);_0x1a86a3[_0x9530('0x33')]=_['intersection'](_0x25d176[_0x9530('0x2f')],qs[_0x9530('0x34')](_0x541f33['query']['fields']));_0x1a86a3[_0x9530('0x33')]=_0x1a86a3['attributes'][_0x9530('0x35')]?_0x1a86a3[_0x9530('0x33')]:_0x25d176[_0x9530('0x2f')];if(!_0x541f33[_0x9530('0x30')][_0x9530('0x36')]('nolimit')){_0x1a86a3['limit']=qs[_0x9530('0x1c')](_0x541f33[_0x9530('0x30')]['limit']);_0x1a86a3['offset']=qs[_0x9530('0x1b')](_0x541f33[_0x9530('0x30')][_0x9530('0x1b')]);}_0x1a86a3[_0x9530('0x37')]=qs[_0x9530('0x38')](_0x541f33['query'][_0x9530('0x38')]);_0x1a86a3[_0x9530('0x39')]=qs[_0x9530('0x32')](_['pick'](_0x541f33[_0x9530('0x30')],_0x25d176[_0x9530('0x32')]),_0x1330ec);if(_0x541f33[_0x9530('0x30')][_0x9530('0x3a')]){_0x1a86a3[_0x9530('0x39')]=_[_0x9530('0x3b')](_0x1a86a3[_0x9530('0x39')],{'$or':_[_0x9530('0x2b')](_0x1330ec,function(_0x3b5ad1){if(_0x3b5ad1[_0x9530('0x3c')]!==_0x9530('0x3d')){var _0x4e2c70={};_0x4e2c70[_0x3b5ad1[_0x9530('0x28')]]={'$like':'%'+_0x541f33[_0x9530('0x30')][_0x9530('0x3a')]+'%'};return _0x4e2c70;}})});}_0x1a86a3=_[_0x9530('0x3b')]({},_0x1a86a3,_0x541f33[_0x9530('0x3e')]);var _0x49c201={'where':_0x1a86a3[_0x9530('0x39')]};return db[_0x9530('0x2c')][_0x9530('0x1e')](_0x49c201)[_0x9530('0x24')](function(_0x527f99){_0x143e8b[_0x9530('0x1e')]=_0x527f99;if(_0x541f33[_0x9530('0x30')][_0x9530('0x3f')]){_0x1a86a3[_0x9530('0x40')]=[{'all':!![]}];}return db[_0x9530('0x2c')][_0x9530('0x41')](_0x1a86a3);})[_0x9530('0x24')](function(_0x2a30f3){_0x143e8b[_0x9530('0x42')]=_0x2a30f3;return _0x143e8b;})[_0x9530('0x24')](respondWithFilteredResult(_0x4e4aa6,_0x1a86a3))['catch'](handleError(_0x4e4aa6,null));};exports['show']=function(_0x592ba5,_0x472a14){var _0x2d60af={'raw':!![],'where':{'id':_0x592ba5[_0x9530('0x43')]['id']}},_0x5cbe7d={};_0x5cbe7d[_0x9530('0x2f')]=_[_0x9530('0x31')](db['CmHopperFinal'][_0x9530('0x2d')]);_0x5cbe7d[_0x9530('0x30')]=_[_0x9530('0x31')](_0x592ba5[_0x9530('0x30')]);_0x5cbe7d[_0x9530('0x32')]=_[_0x9530('0x44')](_0x5cbe7d[_0x9530('0x2f')],_0x5cbe7d[_0x9530('0x30')]);_0x2d60af[_0x9530('0x33')]=_['intersection'](_0x5cbe7d[_0x9530('0x2f')],qs['fields'](_0x592ba5['query'][_0x9530('0x34')]));_0x2d60af[_0x9530('0x33')]=_0x2d60af[_0x9530('0x33')][_0x9530('0x35')]?_0x2d60af[_0x9530('0x33')]:_0x5cbe7d[_0x9530('0x2f')];if(_0x592ba5[_0x9530('0x30')]['includeAll']){_0x2d60af[_0x9530('0x40')]=[{'all':!![]}];}_0x2d60af=_['merge']({},_0x2d60af,_0x592ba5[_0x9530('0x3e')]);return db[_0x9530('0x2c')][_0x9530('0x45')](_0x2d60af)[_0x9530('0x24')](handleEntityNotFound(_0x472a14,null))[_0x9530('0x24')](respondWithResult(_0x472a14,null))[_0x9530('0x46')](handleError(_0x472a14,null));};exports[_0x9530('0x47')]=function(_0x368655,_0x2347cc){return db['CmHopperFinal'][_0x9530('0x47')]()[_0x9530('0x24')](respondWithResult(_0x2347cc,null))[_0x9530('0x46')](handleError(_0x2347cc,null));};exports[_0x9530('0x23')]=function(_0x5cf336,_0x225332){if(_0x5cf336[_0x9530('0x48')][_0x9530('0x49')]){delete _0x5cf336[_0x9530('0x48')][_0x9530('0x49')];}return db['CmHopperFinal'][_0x9530('0x45')]({'where':{'uniqueid':_0x5cf336[_0x9530('0x43')]['id']}})['then'](handleEntityNotFound(_0x225332,null))['then'](saveUpdates(_0x5cf336[_0x9530('0x48')],null))[_0x9530('0x24')](respondWithResult(_0x225332,null))[_0x9530('0x46')](handleError(_0x225332,null));};exports[_0x9530('0x4a')]=function(_0x4f8bde,_0x1a07a4,_0xffb8b6){return db['CmHopperFinal'][_0x9530('0x41')]({'raw':![],'where':{'VoiceQueueId':_0x4f8bde['params']['id']},'attributes':[[db[_0x9530('0x4b')]['fn']('COUNT',db[_0x9530('0x4b')]['fn']('IF',db[_0x9530('0x4b')][_0x9530('0x4c')]('`state`\x20=\x200,\x201,\x20null'))),_0x9530('0x4d')],[db['sequelize']['fn'](_0x9530('0x4e'),db[_0x9530('0x4b')]['fn']('IF',db[_0x9530('0x4b')][_0x9530('0x4c')](_0x9530('0x4f')))),_0x9530('0x50')],[db['sequelize']['fn'](_0x9530('0x4e'),db[_0x9530('0x4b')]['fn']('IF',db['sequelize'][_0x9530('0x4c')](_0x9530('0x51')))),_0x9530('0x52')],[db['sequelize']['fn'](_0x9530('0x4e'),db[_0x9530('0x4b')]['fn']('IF',db[_0x9530('0x4b')][_0x9530('0x4c')](_0x9530('0x53')))),_0x9530('0x54')],[db['sequelize']['fn'](_0x9530('0x4e'),db['sequelize']['fn']('IF',db[_0x9530('0x4b')]['literal']('`state`\x20=\x2010\x20,\x201,\x20null'))),_0x9530('0x55')],[db[_0x9530('0x4b')]['fn']('COUNT',db[_0x9530('0x4b')]['fn']('IF',db[_0x9530('0x4b')][_0x9530('0x4c')](_0x9530('0x56')))),_0x9530('0x57')],[db[_0x9530('0x4b')]['fn'](_0x9530('0x4e'),db[_0x9530('0x4b')]['fn']('IF',db[_0x9530('0x4b')][_0x9530('0x4c')](_0x9530('0x58')))),_0x9530('0x59')],[db['sequelize']['fn']('COUNT',db[_0x9530('0x4b')]['fn']('IF',db[_0x9530('0x4b')][_0x9530('0x4c')]('`state`\x20=\x2019,\x201,\x20null'))),'answeringMachine']]})[_0x9530('0x24')](handleEntityNotFound(_0x1a07a4,null))[_0x9530('0x24')](respondWithResult(_0x1a07a4,null))['catch'](handleError(_0x1a07a4,null));};exports[_0x9530('0x5a')]=function(_0x3991fc,_0x2019f1,_0x16e092){return db[_0x9530('0x2c')]['findAll']({'raw':![],'where':{'CampaignId':_0x3991fc['params']['id']},'attributes':[[db['sequelize']['fn'](_0x9530('0x4e'),db[_0x9530('0x4b')]['fn']('IF',db['sequelize'][_0x9530('0x4c')]('`state`\x20=\x200,\x201,\x20null'))),'noSuchContacts'],[db[_0x9530('0x4b')]['fn'](_0x9530('0x4e'),db['sequelize']['fn']('IF',db[_0x9530('0x4b')][_0x9530('0x4c')](_0x9530('0x4f')))),_0x9530('0x50')],[db[_0x9530('0x4b')]['fn'](_0x9530('0x4e'),db[_0x9530('0x4b')]['fn']('IF',db['sequelize'][_0x9530('0x4c')]('`state`\x20=\x205,\x201,\x20null'))),'busyContacts'],[db[_0x9530('0x4b')]['fn'](_0x9530('0x4e'),db[_0x9530('0x4b')]['fn']('IF',db[_0x9530('0x4b')][_0x9530('0x4c')](_0x9530('0x53')))),_0x9530('0x54')],[db['sequelize']['fn'](_0x9530('0x4e'),db[_0x9530('0x4b')]['fn']('IF',db[_0x9530('0x4b')][_0x9530('0x4c')](_0x9530('0x5b')))),_0x9530('0x55')],[db['sequelize']['fn'](_0x9530('0x4e'),db['sequelize']['fn']('IF',db[_0x9530('0x4b')][_0x9530('0x4c')](_0x9530('0x56')))),_0x9530('0x57')],[db[_0x9530('0x4b')]['fn'](_0x9530('0x4e'),db[_0x9530('0x4b')]['fn']('IF',db[_0x9530('0x4b')][_0x9530('0x4c')](_0x9530('0x58')))),_0x9530('0x59')],[db[_0x9530('0x4b')]['fn'](_0x9530('0x4e'),db[_0x9530('0x4b')]['fn']('IF',db['sequelize'][_0x9530('0x4c')](_0x9530('0x5c')))),_0x9530('0x5d')]]})[_0x9530('0x24')](handleEntityNotFound(_0x2019f1,null))['then'](respondWithResult(_0x2019f1,null))[_0x9530('0x46')](handleError(_0x2019f1,null));};exports[_0x9530('0x5e')]=function(_0xb13fbd,_0x393a8d,_0x1876ae){return db[_0x9530('0x5f')][_0x9530('0x45')]({'where':{'id':_0xb13fbd[_0x9530('0x43')]['id']}})[_0x9530('0x24')](handleEntityNotFound(_0x393a8d,null))[_0x9530('0x24')](function(_0x22526f){var _0x235257;if(_0x22526f){_0x235257=squel[_0x9530('0x60')]()[_0x9530('0x61')]('cm_hopper')[_0x9530('0x62')]([_0x9530('0x63'),_0x9530('0x64'),'ContactId',_0x9530('0x65'),_0x9530('0x66'),'createdAt',_0x9530('0x67')],squel[_0x9530('0x68')]()[_0x9530('0x69')](_0x9530('0x6a'),_0x9530('0x63'))[_0x9530('0x69')]('NOW()',_0x9530('0x64'))['field']('ANY_VALUE(ContactId)','ContactId')[_0x9530('0x69')](_0x9530('0x6b'),_0x9530('0x65'))[_0x9530('0x69')]('ANY_VALUE(VoiceQueueId)',_0x9530('0x66'))[_0x9530('0x69')](_0x9530('0x6c'),'createdAt')[_0x9530('0x69')](_0x9530('0x6c'),_0x9530('0x67'))[_0x9530('0x6d')](_0x9530('0x6e'))[_0x9530('0x39')](_0x9530('0x6f'),_0xb13fbd['params']['id'][_0x9530('0x70')]())[_0x9530('0x39')](_0x9530('0x71'),_0xb13fbd[_0x9530('0x48')]['state'][_0x9530('0x70')]())[_0x9530('0x39')](_0x9530('0x72'))[_0x9530('0x39')]('calleridnum\x20NOT\x20IN\x20(?)',squel[_0x9530('0x68')]()[_0x9530('0x69')](_0x9530('0x63'))['from']('cm_hopper')['where'](_0x9530('0x6f'),_0xb13fbd['params']['id']['toString']()))[_0x9530('0x39')](_0x9530('0x73'),squel[_0x9530('0x68')]()[_0x9530('0x69')](_0x9530('0x74'))[_0x9530('0x6d')](_0x9530('0x6e'))['where']('VoiceQueueId\x20=\x20?',_0xb13fbd[_0x9530('0x43')]['id'][_0x9530('0x70')]())['where'](_0x9530('0x75')))['group'](_0x9530('0x76')))['toString']();return db[_0x9530('0x4b')]['query'](_0x235257);}return[];})['then'](respondWithResult(_0x393a8d,null))[_0x9530('0x46')](handleError(_0x393a8d,null));};exports[_0x9530('0x77')]=function(_0x4f255b,_0x6af464,_0x4ec7a2){return db[_0x9530('0x78')]['find']({'where':{'id':_0x4f255b['params']['id']}})[_0x9530('0x24')](handleEntityNotFound(_0x6af464,null))['then'](function(_0x318048){var _0x3e9ef2;if(_0x318048){_0x3e9ef2=squel[_0x9530('0x60')]()[_0x9530('0x61')](_0x9530('0x79'))['fromQuery']([_0x9530('0x63'),_0x9530('0x64'),'ContactId','ListId',_0x9530('0x7a'),'createdAt','updatedAt'],squel[_0x9530('0x68')]()['field'](_0x9530('0x6a'),_0x9530('0x63'))[_0x9530('0x69')](_0x9530('0x6c'),_0x9530('0x64'))[_0x9530('0x69')](_0x9530('0x7b'),_0x9530('0x76'))[_0x9530('0x69')](_0x9530('0x6b'),_0x9530('0x65'))[_0x9530('0x69')](_0x9530('0x7c'),_0x9530('0x7a'))['field'](_0x9530('0x6c'),_0x9530('0x7d'))[_0x9530('0x69')](_0x9530('0x6c'),'updatedAt')[_0x9530('0x6d')]('cm_hopper_final')['where'](_0x9530('0x7e'),_0x4f255b[_0x9530('0x43')]['id']['toString']())[_0x9530('0x39')](_0x9530('0x71'),_0x4f255b[_0x9530('0x48')][_0x9530('0x7f')][_0x9530('0x70')]())['where']('calleridnum\x20IS\x20NOT\x20NULL')['where']('calleridnum\x20NOT\x20IN\x20(?)',squel[_0x9530('0x68')]()[_0x9530('0x69')](_0x9530('0x63'))['from'](_0x9530('0x79'))[_0x9530('0x39')]('CampaignId\x20=\x20?',_0x4f255b[_0x9530('0x43')]['id'][_0x9530('0x70')]()))[_0x9530('0x39')](_0x9530('0x73'),squel[_0x9530('0x68')]()[_0x9530('0x69')]('calleridnum')[_0x9530('0x6d')](_0x9530('0x6e'))[_0x9530('0x39')]('CampaignId\x20=\x20?',_0x4f255b[_0x9530('0x43')]['id'][_0x9530('0x70')]())['where'](_0x9530('0x75')))[_0x9530('0x80')](_0x9530('0x76')))[_0x9530('0x70')]();return db[_0x9530('0x4b')][_0x9530('0x30')](_0x3e9ef2);}return[];})[_0x9530('0x24')](respondWithResult(_0x6af464,null))['catch'](handleError(_0x6af464,null));};exports[_0x9530('0x81')]=function(_0x59acfd,_0x49c6b8,_0x174ffe){return db['CmHopper']['findOne']({'where':{'VoiceQueueId':_0x59acfd[_0x9530('0x48')][_0x9530('0x66')],'CampaignId':_0x59acfd[_0x9530('0x48')][_0x9530('0x7a')],'ContactId':_0x59acfd['body'][_0x9530('0x76')]}})[_0x9530('0x24')](handleEntityNotFound(_0x49c6b8,null))[_0x9530('0x24')](function(_0xac4085){if(_0xac4085){return _0xac4085;}return null;})[_0x9530('0x24')](respondWithResult(_0x49c6b8,null))['catch'](handleError(_0x49c6b8,null));};
\ No newline at end of file
+var _0x5fab=['json','offset','undefined','count','limit','set','Content-Range','apply','reject','save','update','destroy','end','sendStatus','name','send','index','map','CmHopperFinal','rawAttributes','fieldName','type','key','model','query','keys','filters','attributes','length','hasOwnProperty','nolimit','order','sort','where','pick','VIRTUAL','filter','includeAll','include','findAll','then','rows','show','params','intersection','fields','options','find','catch','describe','body','countContactsQueueCampaignHopperFinal','COUNT','sequelize','`state`\x20=\x200,\x201,\x20null','noSuchContacts','literal','`state`\x20=\x203,\x201,\x20null','noAnswerContacts','`state`\x20=\x205,\x201,\x20null','busyContacts','`state`\x20=\x208,\x201,\x20null','congestionContacts','`state`\x20=\x2010\x20,\x201,\x20null','`state`\x20=\x2011\x20,\x201,\x20null','abandonedContacts','reCallContacts','`state`\x20=\x2019,\x201,\x20null','answeringMachine','countContactsIvrCampaignHopperFinal','dropContacts','`state`\x20=\x2022,\x201,\x20null','moveContactsQueueCampaignHopperFinal','into','cm_hopper','fromQuery','phone','scheduledAt','ContactId','VoiceQueueId','select','field','ANY_VALUE(ContactId)','ANY_VALUE(ListId)','ListId','ANY_VALUE(VoiceQueueId)','NOW()','updatedAt','from','cm_hopper_final','VoiceQueueId\x20=\x20?','toString','state\x20=\x20?','calleridnum\x20IS\x20NOT\x20NULL','calleridnum\x20NOT\x20IN\x20(?)','calleridnum','state\x20=\x204','group','Campaign','insert','CampaignId','createdAt','ANY_VALUE(CampaignId)','CampaignId\x20=\x20?','checkContactHopper','CmHopper','findOne','eml-format','rimraf','fast-json-patch','request-promise','moment','bluebird','mustache','util','path','sox','to-csv','ejs','squel','crypto','jsforce','querystring','papaparse','../../components/parsers/qs','../../components/parsers/advancedSearch','../../config/license/hardware','../../config/logger','api','../../config/utils','../../config/environment','../../config/license/util','../../mysqldb','status'];(function(_0x4be9e1,_0x15a743){var _0x55a89a=function(_0x4e28a0){while(--_0x4e28a0){_0x4be9e1['push'](_0x4be9e1['shift']());}};_0x55a89a(++_0x15a743);}(_0x5fab,0x177));var _0xb5fa=function(_0x4b8ab7,_0x37c8bd){_0x4b8ab7=_0x4b8ab7-0x0;var _0x3f6c00=_0x5fab[_0x4b8ab7];return _0x3f6c00;};'use strict';var emlformat=require(_0xb5fa('0x0'));var rimraf=require(_0xb5fa('0x1'));var zipdir=require('zip-dir');var jsonpatch=require(_0xb5fa('0x2'));var rp=require(_0xb5fa('0x3'));var moment=require(_0xb5fa('0x4'));var BPromise=require(_0xb5fa('0x5'));var Mustache=require(_0xb5fa('0x6'));var util=require(_0xb5fa('0x7'));var path=require(_0xb5fa('0x8'));var sox=require(_0xb5fa('0x9'));var csv=require(_0xb5fa('0xa'));var ejs=require(_0xb5fa('0xb'));var fs=require('fs');var fs_extra=require('fs-extra');var _=require('lodash');var squel=require(_0xb5fa('0xc'));var crypto=require(_0xb5fa('0xd'));var jsforce=require(_0xb5fa('0xe'));var deskjs=require('desk.js');var toCsv=require(_0xb5fa('0xa'));var querystring=require(_0xb5fa('0xf'));var Papa=require(_0xb5fa('0x10'));var Redis=require('ioredis');var authService=require('../../components/auth/service');var qs=require(_0xb5fa('0x11'));var as=require(_0xb5fa('0x12'));var hardwareService=require(_0xb5fa('0x13'));var logger=require(_0xb5fa('0x14'))(_0xb5fa('0x15'));var utils=require(_0xb5fa('0x16'));var config=require(_0xb5fa('0x17'));var licenseUtil=require(_0xb5fa('0x18'));var db=require(_0xb5fa('0x19'))['db'];function respondWithStatusCode(_0x4d3576,_0x2ad830){_0x2ad830=_0x2ad830||0xcc;return function(_0x3dad4d){if(_0x3dad4d){return _0x4d3576['sendStatus'](_0x2ad830);}return _0x4d3576[_0xb5fa('0x1a')](_0x2ad830)['end']();};}function respondWithResult(_0x265992,_0x3fc372){_0x3fc372=_0x3fc372||0xc8;return function(_0x40c914){if(_0x40c914){return _0x265992[_0xb5fa('0x1a')](_0x3fc372)[_0xb5fa('0x1b')](_0x40c914);}};}function respondWithFilteredResult(_0x5371cf,_0x567f31){return function(_0x38e964){if(_0x38e964){var _0x587043=typeof _0x567f31[_0xb5fa('0x1c')]===_0xb5fa('0x1d')&&typeof _0x567f31['limit']==='undefined';var _0x451a55=_0x38e964[_0xb5fa('0x1e')];var _0x32e9e5=_0x587043?0x0:_0x567f31[_0xb5fa('0x1c')];var _0x324ba5=_0x587043?_0x38e964[_0xb5fa('0x1e')]:_0x567f31[_0xb5fa('0x1c')]+_0x567f31[_0xb5fa('0x1f')];var _0xc14dc4;if(_0x324ba5>=_0x451a55){_0x324ba5=_0x451a55;_0xc14dc4=0xc8;}else{_0xc14dc4=0xce;}_0x5371cf[_0xb5fa('0x1a')](_0xc14dc4);return _0x5371cf[_0xb5fa('0x20')](_0xb5fa('0x21'),_0x32e9e5+'-'+_0x324ba5+'/'+_0x451a55)['json'](_0x38e964);}return null;};}function patchUpdates(_0x432bfa){return function(_0x519e20){try{jsonpatch[_0xb5fa('0x22')](_0x519e20,_0x432bfa,!![]);}catch(_0x4a6c04){return BPromise[_0xb5fa('0x23')](_0x4a6c04);}return _0x519e20[_0xb5fa('0x24')]();};}function saveUpdates(_0x4e05c0,_0x40dfdf){return function(_0x3a2ab9){if(_0x3a2ab9){return _0x3a2ab9[_0xb5fa('0x25')](_0x4e05c0)['then'](function(_0x32a85c){return _0x32a85c;});}return null;};}function removeEntity(_0xec108f,_0x444237){return function(_0x542348){if(_0x542348){return _0x542348[_0xb5fa('0x26')]()['then'](function(){_0xec108f[_0xb5fa('0x1a')](0xcc)[_0xb5fa('0x27')]();});}};}function handleEntityNotFound(_0x11053a,_0x543edf){return function(_0x2dbd22){if(!_0x2dbd22){_0x11053a[_0xb5fa('0x28')](0x194);}return _0x2dbd22;};}function handleError(_0x6a455c,_0x20d649){_0x20d649=_0x20d649||0x1f4;return function(_0x568870){logger['error'](_0x568870['stack']);if(_0x568870['name']){delete _0x568870[_0xb5fa('0x29')];}_0x6a455c[_0xb5fa('0x1a')](_0x20d649)[_0xb5fa('0x2a')](_0x568870);};}exports[_0xb5fa('0x2b')]=function(_0x534884,_0x3506a4){var _0x358549={},_0x353314={},_0x409af9={'count':0x0,'rows':[]};var _0x2a5690=_[_0xb5fa('0x2c')](db[_0xb5fa('0x2d')][_0xb5fa('0x2e')],function(_0x1f4380){return{'name':_0x1f4380[_0xb5fa('0x2f')],'type':_0x1f4380[_0xb5fa('0x30')][_0xb5fa('0x31')]};});_0x353314[_0xb5fa('0x32')]=_[_0xb5fa('0x2c')](_0x2a5690,_0xb5fa('0x29'));_0x353314[_0xb5fa('0x33')]=_[_0xb5fa('0x34')](_0x534884[_0xb5fa('0x33')]);_0x353314[_0xb5fa('0x35')]=_['intersection'](_0x353314[_0xb5fa('0x32')],_0x353314['query']);_0x358549['attributes']=_['intersection'](_0x353314[_0xb5fa('0x32')],qs['fields'](_0x534884[_0xb5fa('0x33')]['fields']));_0x358549['attributes']=_0x358549[_0xb5fa('0x36')][_0xb5fa('0x37')]?_0x358549['attributes']:_0x353314['model'];if(!_0x534884[_0xb5fa('0x33')][_0xb5fa('0x38')](_0xb5fa('0x39'))){_0x358549['limit']=qs[_0xb5fa('0x1f')](_0x534884[_0xb5fa('0x33')]['limit']);_0x358549[_0xb5fa('0x1c')]=qs[_0xb5fa('0x1c')](_0x534884[_0xb5fa('0x33')]['offset']);}_0x358549[_0xb5fa('0x3a')]=qs[_0xb5fa('0x3b')](_0x534884[_0xb5fa('0x33')]['sort']);_0x358549[_0xb5fa('0x3c')]=qs[_0xb5fa('0x35')](_[_0xb5fa('0x3d')](_0x534884[_0xb5fa('0x33')],_0x353314['filters']),_0x2a5690);if(_0x534884['query']['filter']){_0x358549['where']=_['merge'](_0x358549['where'],{'$or':_[_0xb5fa('0x2c')](_0x2a5690,function(_0x4c0a4d){if(_0x4c0a4d[_0xb5fa('0x30')]!==_0xb5fa('0x3e')){var _0x36db1a={};_0x36db1a[_0x4c0a4d[_0xb5fa('0x29')]]={'$like':'%'+_0x534884[_0xb5fa('0x33')][_0xb5fa('0x3f')]+'%'};return _0x36db1a;}})});}_0x358549=_['merge']({},_0x358549,_0x534884['options']);var _0x4c4bf0={'where':_0x358549[_0xb5fa('0x3c')]};return db['CmHopperFinal'][_0xb5fa('0x1e')](_0x4c4bf0)['then'](function(_0x58aa97){_0x409af9[_0xb5fa('0x1e')]=_0x58aa97;if(_0x534884[_0xb5fa('0x33')][_0xb5fa('0x40')]){_0x358549[_0xb5fa('0x41')]=[{'all':!![]}];}return db[_0xb5fa('0x2d')][_0xb5fa('0x42')](_0x358549);})[_0xb5fa('0x43')](function(_0x83df0b){_0x409af9[_0xb5fa('0x44')]=_0x83df0b;return _0x409af9;})[_0xb5fa('0x43')](respondWithFilteredResult(_0x3506a4,_0x358549))['catch'](handleError(_0x3506a4,null));};exports[_0xb5fa('0x45')]=function(_0x4bc9df,_0x233f90){var _0x39aac3={'raw':!![],'where':{'id':_0x4bc9df[_0xb5fa('0x46')]['id']}},_0x2c7c5f={};_0x2c7c5f[_0xb5fa('0x32')]=_[_0xb5fa('0x34')](db[_0xb5fa('0x2d')][_0xb5fa('0x2e')]);_0x2c7c5f['query']=_[_0xb5fa('0x34')](_0x4bc9df[_0xb5fa('0x33')]);_0x2c7c5f['filters']=_[_0xb5fa('0x47')](_0x2c7c5f['model'],_0x2c7c5f[_0xb5fa('0x33')]);_0x39aac3[_0xb5fa('0x36')]=_['intersection'](_0x2c7c5f['model'],qs[_0xb5fa('0x48')](_0x4bc9df[_0xb5fa('0x33')][_0xb5fa('0x48')]));_0x39aac3[_0xb5fa('0x36')]=_0x39aac3[_0xb5fa('0x36')][_0xb5fa('0x37')]?_0x39aac3[_0xb5fa('0x36')]:_0x2c7c5f[_0xb5fa('0x32')];if(_0x4bc9df['query'][_0xb5fa('0x40')]){_0x39aac3[_0xb5fa('0x41')]=[{'all':!![]}];}_0x39aac3=_['merge']({},_0x39aac3,_0x4bc9df[_0xb5fa('0x49')]);return db[_0xb5fa('0x2d')][_0xb5fa('0x4a')](_0x39aac3)[_0xb5fa('0x43')](handleEntityNotFound(_0x233f90,null))[_0xb5fa('0x43')](respondWithResult(_0x233f90,null))[_0xb5fa('0x4b')](handleError(_0x233f90,null));};exports[_0xb5fa('0x4c')]=function(_0x33eb2c,_0x20f5f5){return db[_0xb5fa('0x2d')][_0xb5fa('0x4c')]()[_0xb5fa('0x43')](respondWithResult(_0x20f5f5,null))[_0xb5fa('0x4b')](handleError(_0x20f5f5,null));};exports[_0xb5fa('0x25')]=function(_0x42a359,_0x3a39f2){if(_0x42a359['body']['uniqueid']){delete _0x42a359[_0xb5fa('0x4d')]['uniqueid'];}return db[_0xb5fa('0x2d')][_0xb5fa('0x4a')]({'where':{'uniqueid':_0x42a359['params']['id']}})[_0xb5fa('0x43')](handleEntityNotFound(_0x3a39f2,null))[_0xb5fa('0x43')](saveUpdates(_0x42a359[_0xb5fa('0x4d')],null))[_0xb5fa('0x43')](respondWithResult(_0x3a39f2,null))[_0xb5fa('0x4b')](handleError(_0x3a39f2,null));};exports[_0xb5fa('0x4e')]=function(_0x51d5f7,_0x27a651,_0x4fd5bf){return db[_0xb5fa('0x2d')][_0xb5fa('0x42')]({'raw':![],'where':{'VoiceQueueId':_0x51d5f7[_0xb5fa('0x46')]['id']},'attributes':[[db['sequelize']['fn'](_0xb5fa('0x4f'),db[_0xb5fa('0x50')]['fn']('IF',db['sequelize']['literal'](_0xb5fa('0x51')))),_0xb5fa('0x52')],[db[_0xb5fa('0x50')]['fn'](_0xb5fa('0x4f'),db[_0xb5fa('0x50')]['fn']('IF',db[_0xb5fa('0x50')][_0xb5fa('0x53')](_0xb5fa('0x54')))),_0xb5fa('0x55')],[db[_0xb5fa('0x50')]['fn'](_0xb5fa('0x4f'),db[_0xb5fa('0x50')]['fn']('IF',db[_0xb5fa('0x50')][_0xb5fa('0x53')](_0xb5fa('0x56')))),_0xb5fa('0x57')],[db[_0xb5fa('0x50')]['fn'](_0xb5fa('0x4f'),db['sequelize']['fn']('IF',db[_0xb5fa('0x50')][_0xb5fa('0x53')](_0xb5fa('0x58')))),_0xb5fa('0x59')],[db[_0xb5fa('0x50')]['fn'](_0xb5fa('0x4f'),db[_0xb5fa('0x50')]['fn']('IF',db[_0xb5fa('0x50')][_0xb5fa('0x53')](_0xb5fa('0x5a')))),'dropContacts'],[db['sequelize']['fn'](_0xb5fa('0x4f'),db[_0xb5fa('0x50')]['fn']('IF',db[_0xb5fa('0x50')]['literal'](_0xb5fa('0x5b')))),_0xb5fa('0x5c')],[db[_0xb5fa('0x50')]['fn'](_0xb5fa('0x4f'),db[_0xb5fa('0x50')]['fn']('IF',db[_0xb5fa('0x50')][_0xb5fa('0x53')]('`state`\x20=\x2022,\x201,\x20null'))),_0xb5fa('0x5d')],[db[_0xb5fa('0x50')]['fn']('COUNT',db[_0xb5fa('0x50')]['fn']('IF',db[_0xb5fa('0x50')]['literal'](_0xb5fa('0x5e')))),_0xb5fa('0x5f')]]})[_0xb5fa('0x43')](handleEntityNotFound(_0x27a651,null))[_0xb5fa('0x43')](respondWithResult(_0x27a651,null))[_0xb5fa('0x4b')](handleError(_0x27a651,null));};exports[_0xb5fa('0x60')]=function(_0x18cde9,_0x40d7d5,_0xd2ba4e){return db[_0xb5fa('0x2d')][_0xb5fa('0x42')]({'raw':![],'where':{'CampaignId':_0x18cde9[_0xb5fa('0x46')]['id']},'attributes':[[db[_0xb5fa('0x50')]['fn'](_0xb5fa('0x4f'),db[_0xb5fa('0x50')]['fn']('IF',db[_0xb5fa('0x50')][_0xb5fa('0x53')](_0xb5fa('0x51')))),_0xb5fa('0x52')],[db[_0xb5fa('0x50')]['fn'](_0xb5fa('0x4f'),db[_0xb5fa('0x50')]['fn']('IF',db['sequelize'][_0xb5fa('0x53')](_0xb5fa('0x54')))),_0xb5fa('0x55')],[db['sequelize']['fn'](_0xb5fa('0x4f'),db[_0xb5fa('0x50')]['fn']('IF',db['sequelize'][_0xb5fa('0x53')](_0xb5fa('0x56')))),_0xb5fa('0x57')],[db['sequelize']['fn']('COUNT',db[_0xb5fa('0x50')]['fn']('IF',db[_0xb5fa('0x50')][_0xb5fa('0x53')]('`state`\x20=\x208,\x201,\x20null'))),_0xb5fa('0x59')],[db[_0xb5fa('0x50')]['fn'](_0xb5fa('0x4f'),db[_0xb5fa('0x50')]['fn']('IF',db['sequelize']['literal']('`state`\x20=\x2010\x20,\x201,\x20null'))),_0xb5fa('0x61')],[db[_0xb5fa('0x50')]['fn'](_0xb5fa('0x4f'),db['sequelize']['fn']('IF',db[_0xb5fa('0x50')][_0xb5fa('0x53')](_0xb5fa('0x5b')))),_0xb5fa('0x5c')],[db[_0xb5fa('0x50')]['fn'](_0xb5fa('0x4f'),db[_0xb5fa('0x50')]['fn']('IF',db[_0xb5fa('0x50')][_0xb5fa('0x53')](_0xb5fa('0x62')))),_0xb5fa('0x5d')],[db[_0xb5fa('0x50')]['fn'](_0xb5fa('0x4f'),db[_0xb5fa('0x50')]['fn']('IF',db[_0xb5fa('0x50')]['literal'](_0xb5fa('0x5e')))),'answeringMachine']]})[_0xb5fa('0x43')](handleEntityNotFound(_0x40d7d5,null))[_0xb5fa('0x43')](respondWithResult(_0x40d7d5,null))[_0xb5fa('0x4b')](handleError(_0x40d7d5,null));};exports[_0xb5fa('0x63')]=function(_0x339dfb,_0x56e6b0,_0x1585cd){return db['VoiceQueue'][_0xb5fa('0x4a')]({'where':{'id':_0x339dfb[_0xb5fa('0x46')]['id']}})[_0xb5fa('0x43')](handleEntityNotFound(_0x56e6b0,null))[_0xb5fa('0x43')](function(_0x5e44d8){var _0x4d1117;if(_0x5e44d8){_0x4d1117=squel['insert']()[_0xb5fa('0x64')](_0xb5fa('0x65'))[_0xb5fa('0x66')]([_0xb5fa('0x67'),_0xb5fa('0x68'),_0xb5fa('0x69'),'ListId',_0xb5fa('0x6a'),'createdAt','updatedAt'],squel[_0xb5fa('0x6b')]()['field']('ANY_VALUE(calleridnum)','phone')[_0xb5fa('0x6c')]('NOW()',_0xb5fa('0x68'))[_0xb5fa('0x6c')](_0xb5fa('0x6d'),'ContactId')['field'](_0xb5fa('0x6e'),_0xb5fa('0x6f'))['field'](_0xb5fa('0x70'),_0xb5fa('0x6a'))[_0xb5fa('0x6c')](_0xb5fa('0x71'),'createdAt')[_0xb5fa('0x6c')](_0xb5fa('0x71'),_0xb5fa('0x72'))[_0xb5fa('0x73')](_0xb5fa('0x74'))[_0xb5fa('0x3c')](_0xb5fa('0x75'),_0x339dfb['params']['id'][_0xb5fa('0x76')]())['where'](_0xb5fa('0x77'),_0x339dfb[_0xb5fa('0x4d')]['state'][_0xb5fa('0x76')]())[_0xb5fa('0x3c')](_0xb5fa('0x78'))[_0xb5fa('0x3c')](_0xb5fa('0x79'),squel[_0xb5fa('0x6b')]()[_0xb5fa('0x6c')](_0xb5fa('0x67'))['from'](_0xb5fa('0x65'))[_0xb5fa('0x3c')](_0xb5fa('0x75'),_0x339dfb[_0xb5fa('0x46')]['id']['toString']()))['where']('calleridnum\x20NOT\x20IN\x20(?)',squel['select']()[_0xb5fa('0x6c')](_0xb5fa('0x7a'))[_0xb5fa('0x73')](_0xb5fa('0x74'))['where']('VoiceQueueId\x20=\x20?',_0x339dfb[_0xb5fa('0x46')]['id']['toString']())[_0xb5fa('0x3c')](_0xb5fa('0x7b')))[_0xb5fa('0x7c')](_0xb5fa('0x69')))['toString']();return db[_0xb5fa('0x50')]['query'](_0x4d1117);}return[];})[_0xb5fa('0x43')](respondWithResult(_0x56e6b0,null))[_0xb5fa('0x4b')](handleError(_0x56e6b0,null));};exports['moveContactsIvrCampaignHopperFinal']=function(_0x5e6852,_0x391412,_0x3150ac){return db[_0xb5fa('0x7d')][_0xb5fa('0x4a')]({'where':{'id':_0x5e6852[_0xb5fa('0x46')]['id']}})[_0xb5fa('0x43')](handleEntityNotFound(_0x391412,null))[_0xb5fa('0x43')](function(_0x25b278){var _0x1a0255;if(_0x25b278){_0x1a0255=squel[_0xb5fa('0x7e')]()[_0xb5fa('0x64')](_0xb5fa('0x65'))[_0xb5fa('0x66')](['phone','scheduledAt',_0xb5fa('0x69'),'ListId',_0xb5fa('0x7f'),_0xb5fa('0x80'),'updatedAt'],squel[_0xb5fa('0x6b')]()[_0xb5fa('0x6c')]('ANY_VALUE(calleridnum)',_0xb5fa('0x67'))[_0xb5fa('0x6c')]('NOW()',_0xb5fa('0x68'))[_0xb5fa('0x6c')](_0xb5fa('0x6d'),'ContactId')['field'](_0xb5fa('0x6e'),_0xb5fa('0x6f'))[_0xb5fa('0x6c')](_0xb5fa('0x81'),_0xb5fa('0x7f'))[_0xb5fa('0x6c')](_0xb5fa('0x71'),_0xb5fa('0x80'))[_0xb5fa('0x6c')](_0xb5fa('0x71'),'updatedAt')['from'](_0xb5fa('0x74'))[_0xb5fa('0x3c')](_0xb5fa('0x82'),_0x5e6852[_0xb5fa('0x46')]['id']['toString']())[_0xb5fa('0x3c')](_0xb5fa('0x77'),_0x5e6852[_0xb5fa('0x4d')]['state'][_0xb5fa('0x76')]())[_0xb5fa('0x3c')](_0xb5fa('0x78'))[_0xb5fa('0x3c')]('calleridnum\x20NOT\x20IN\x20(?)',squel[_0xb5fa('0x6b')]()[_0xb5fa('0x6c')](_0xb5fa('0x67'))[_0xb5fa('0x73')](_0xb5fa('0x65'))[_0xb5fa('0x3c')](_0xb5fa('0x82'),_0x5e6852[_0xb5fa('0x46')]['id'][_0xb5fa('0x76')]()))[_0xb5fa('0x3c')](_0xb5fa('0x79'),squel[_0xb5fa('0x6b')]()[_0xb5fa('0x6c')](_0xb5fa('0x7a'))[_0xb5fa('0x73')]('cm_hopper_final')[_0xb5fa('0x3c')](_0xb5fa('0x82'),_0x5e6852[_0xb5fa('0x46')]['id'][_0xb5fa('0x76')]())[_0xb5fa('0x3c')](_0xb5fa('0x7b')))[_0xb5fa('0x7c')](_0xb5fa('0x69')))['toString']();return db['sequelize'][_0xb5fa('0x33')](_0x1a0255);}return[];})['then'](respondWithResult(_0x391412,null))['catch'](handleError(_0x391412,null));};exports[_0xb5fa('0x83')]=function(_0x27dbe8,_0x2faf23,_0x4d607d){return db[_0xb5fa('0x84')][_0xb5fa('0x85')]({'where':{'VoiceQueueId':_0x27dbe8[_0xb5fa('0x4d')]['VoiceQueueId'],'CampaignId':_0x27dbe8[_0xb5fa('0x4d')][_0xb5fa('0x7f')],'ContactId':_0x27dbe8['body'][_0xb5fa('0x69')]}})[_0xb5fa('0x43')](handleEntityNotFound(_0x2faf23,null))[_0xb5fa('0x43')](function(_0xf15d5c){if(_0xf15d5c){return _0xf15d5c;}return null;})[_0xb5fa('0x43')](respondWithResult(_0x2faf23,null))[_0xb5fa('0x4b')](handleError(_0x2faf23,null));};
\ No newline at end of file