Built motion from commit (unavailable).|2.5.5
[motion2.git] / server / api / cmHopperFinal / cmHopperFinal.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 _0x041c=['cm_hopper','fromQuery','phone','ContactId','ListId','VoiceQueueId','createdAt','updatedAt','select','field','ANY_VALUE(calleridnum)','NOW()','scheduledAt','ANY_VALUE(ListId)','from','toString','state\x20=\x20?','calleridnum\x20IS\x20NOT\x20NULL','calleridnum\x20NOT\x20IN\x20(?)','calleridnum','cm_hopper_final','VoiceQueueId\x20=\x20?','group','moveContactsIvrCampaignHopperFinal','Campaign','ANY_VALUE(CampaignId)','CampaignId','CampaignId\x20=\x20?','state','state\x20=\x204','checkContactHopper','CmHopper','findOne','html-pdf','eml-format','rimraf','zip-dir','fast-json-patch','request-promise','moment','mustache','util','path','sox','to-csv','ejs','crypto','jsforce','desk.js','querystring','papaparse','ioredis','../../components/auth/service','../../components/parsers/qs','../../config/license/hardware','../../config/logger','api','../../config/utils','../../config/license/util','../../mysqldb','status','end','count','offset','limit','Content-Range','update','destroy','then','sendStatus','stack','name','send','map','CmHopperFinal','fieldName','type','key','query','keys','filters','intersection','model','attributes','length','hasOwnProperty','nolimit','order','where','filter','merge','VIRTUAL','options','includeAll','include','findAll','rows','show','params','rawAttributes','fields','find','catch','describe','body','uniqueid','sequelize','COUNT','`state`\x20=\x200,\x201,\x20null','noSuchContacts','noAnswerContacts','literal','`state`\x20=\x208,\x201,\x20null','dropContacts','abandonedContacts','`state`\x20=\x2022,\x201,\x20null','reCallContacts','`state`\x20=\x2019,\x201,\x20null','countContactsIvrCampaignHopperFinal','`state`\x20=\x203,\x201,\x20null','busyContacts','congestionContacts','`state`\x20=\x2010\x20,\x201,\x20null','`state`\x20=\x2011\x20,\x201,\x20null','moveContactsQueueCampaignHopperFinal','VoiceQueue','insert','into'];(function(_0x41ef28,_0x3789d5){var _0x378eb5=function(_0x297dd7){while(--_0x297dd7){_0x41ef28['push'](_0x41ef28['shift']());}};_0x378eb5(++_0x3789d5);}(_0x041c,0xa1));var _0xc041=function(_0x3783b5,_0x10210d){_0x3783b5=_0x3783b5-0x0;var _0x399b75=_0x041c[_0x3783b5];return _0x399b75;};'use strict';var pdf=require(_0xc041('0x0'));var emlformat=require(_0xc041('0x1'));var rimraf=require(_0xc041('0x2'));var zipdir=require(_0xc041('0x3'));var jsonpatch=require(_0xc041('0x4'));var rp=require(_0xc041('0x5'));var moment=require(_0xc041('0x6'));var BPromise=require('bluebird');var Mustache=require(_0xc041('0x7'));var util=require(_0xc041('0x8'));var path=require(_0xc041('0x9'));var sox=require(_0xc041('0xa'));var csv=require(_0xc041('0xb'));var ejs=require(_0xc041('0xc'));var fs=require('fs');var _=require('lodash');var squel=require('squel');var crypto=require(_0xc041('0xd'));var jsforce=require(_0xc041('0xe'));var deskjs=require(_0xc041('0xf'));var toCsv=require('to-csv');var querystring=require(_0xc041('0x10'));var Papa=require(_0xc041('0x11'));var Redis=require(_0xc041('0x12'));var authService=require(_0xc041('0x13'));var qs=require(_0xc041('0x14'));var as=require('../../components/parsers/advancedSearch');var hardwareService=require(_0xc041('0x15'));var logger=require(_0xc041('0x16'))(_0xc041('0x17'));var utils=require(_0xc041('0x18'));var config=require('../../config/environment');var licenseUtil=require(_0xc041('0x19'));var db=require(_0xc041('0x1a'))['db'];function respondWithStatusCode(_0x5b7bc7,_0x272ee4){_0x272ee4=_0x272ee4||0xcc;return function(_0xea9318){if(_0xea9318){return _0x5b7bc7['sendStatus'](_0x272ee4);}return _0x5b7bc7[_0xc041('0x1b')](_0x272ee4)[_0xc041('0x1c')]();};}function respondWithResult(_0x2798bd,_0x50d14b){_0x50d14b=_0x50d14b||0xc8;return function(_0x1addab){if(_0x1addab){return _0x2798bd[_0xc041('0x1b')](_0x50d14b)['json'](_0x1addab);}};}function respondWithFilteredResult(_0x46a640,_0xd3dda0){return function(_0x4ded63){if(_0x4ded63){var _0x1a914d=_0x4ded63[_0xc041('0x1d')],_0x27707e=_0xd3dda0[_0xc041('0x1e')],_0x9fca52=_0xd3dda0[_0xc041('0x1e')]+_0xd3dda0[_0xc041('0x1f')],_0x59f021;if(_0x9fca52>=_0x1a914d){_0x9fca52=_0x1a914d;_0x59f021=0xc8;}else{_0x59f021=0xce;}_0x46a640[_0xc041('0x1b')](_0x59f021);return _0x46a640['set'](_0xc041('0x20'),_0x27707e+'-'+_0x9fca52+'/'+_0x1a914d)['json'](_0x4ded63);}return null;};}function patchUpdates(_0x12937f){return function(_0x449bcb){try{jsonpatch['apply'](_0x449bcb,_0x12937f,!![]);}catch(_0x58d68b){return BPromise['reject'](_0x58d68b);}return _0x449bcb['save']();};}function saveUpdates(_0x894b0c,_0xbcc606){return function(_0x28efeb){if(_0x28efeb){return _0x28efeb[_0xc041('0x21')](_0x894b0c)['then'](function(_0x5b9067){return _0x5b9067;});}return null;};}function removeEntity(_0x10a7b3,_0x328911){return function(_0x140f61){if(_0x140f61){return _0x140f61[_0xc041('0x22')]()[_0xc041('0x23')](function(){_0x10a7b3[_0xc041('0x1b')](0xcc)[_0xc041('0x1c')]();});}};}function handleEntityNotFound(_0x46f6bb,_0xaaff56){return function(_0x10494e){if(!_0x10494e){_0x46f6bb[_0xc041('0x24')](0x194);}return _0x10494e;};}function handleError(_0x53768b,_0xc3a29){_0xc3a29=_0xc3a29||0x1f4;return function(_0x2aeb7c){logger['error'](_0x2aeb7c[_0xc041('0x25')]);if(_0x2aeb7c[_0xc041('0x26')]){delete _0x2aeb7c[_0xc041('0x26')];}_0x53768b['status'](_0xc3a29)[_0xc041('0x27')](_0x2aeb7c);};}exports['index']=function(_0x23221c,_0x256b9f){var _0x42a452={},_0xa80bfe={},_0x3989d8={'count':0x0,'rows':[]};var _0x3099b8=_[_0xc041('0x28')](db[_0xc041('0x29')]['rawAttributes'],function(_0x589b8a){return{'name':_0x589b8a[_0xc041('0x2a')],'type':_0x589b8a[_0xc041('0x2b')][_0xc041('0x2c')]};});_0xa80bfe['model']=_[_0xc041('0x28')](_0x3099b8,'name');_0xa80bfe[_0xc041('0x2d')]=_[_0xc041('0x2e')](_0x23221c['query']);_0xa80bfe[_0xc041('0x2f')]=_[_0xc041('0x30')](_0xa80bfe[_0xc041('0x31')],_0xa80bfe['query']);_0x42a452[_0xc041('0x32')]=_[_0xc041('0x30')](_0xa80bfe[_0xc041('0x31')],qs['fields'](_0x23221c['query']['fields']));_0x42a452[_0xc041('0x32')]=_0x42a452[_0xc041('0x32')][_0xc041('0x33')]?_0x42a452[_0xc041('0x32')]:_0xa80bfe[_0xc041('0x31')];if(!_0x23221c[_0xc041('0x2d')][_0xc041('0x34')](_0xc041('0x35'))){_0x42a452[_0xc041('0x1f')]=qs['limit'](_0x23221c[_0xc041('0x2d')]['limit']);_0x42a452[_0xc041('0x1e')]=qs['offset'](_0x23221c[_0xc041('0x2d')]['offset']);}_0x42a452[_0xc041('0x36')]=qs['sort'](_0x23221c[_0xc041('0x2d')]['sort']);_0x42a452[_0xc041('0x37')]=qs['filters'](_['pick'](_0x23221c[_0xc041('0x2d')],_0xa80bfe[_0xc041('0x2f')]),_0x3099b8);if(_0x23221c['query'][_0xc041('0x38')]){_0x42a452['where']=_[_0xc041('0x39')](_0x42a452[_0xc041('0x37')],{'$or':_['map'](_0x3099b8,function(_0x1fff15){if(_0x1fff15['type']!==_0xc041('0x3a')){var _0x56270e={};_0x56270e[_0x1fff15[_0xc041('0x26')]]={'$like':'%'+_0x23221c[_0xc041('0x2d')]['filter']+'%'};return _0x56270e;}})});}_0x42a452=_['merge']({},_0x42a452,_0x23221c[_0xc041('0x3b')]);var _0x20feaa={'where':_0x42a452[_0xc041('0x37')]};return db[_0xc041('0x29')][_0xc041('0x1d')](_0x20feaa)[_0xc041('0x23')](function(_0x3f2ad8){_0x3989d8[_0xc041('0x1d')]=_0x3f2ad8;if(_0x23221c[_0xc041('0x2d')][_0xc041('0x3c')]){_0x42a452[_0xc041('0x3d')]=[{'all':!![]}];}return db[_0xc041('0x29')][_0xc041('0x3e')](_0x42a452);})[_0xc041('0x23')](function(_0x1a8c41){_0x3989d8[_0xc041('0x3f')]=_0x1a8c41;return _0x3989d8;})['then'](respondWithFilteredResult(_0x256b9f,_0x42a452))['catch'](handleError(_0x256b9f,null));};exports[_0xc041('0x40')]=function(_0x1a4288,_0x19b2b3){var _0x5cc1ed={'raw':!![],'where':{'id':_0x1a4288[_0xc041('0x41')]['id']}},_0x4611ec={};_0x4611ec[_0xc041('0x31')]=_[_0xc041('0x2e')](db['CmHopperFinal'][_0xc041('0x42')]);_0x4611ec[_0xc041('0x2d')]=_[_0xc041('0x2e')](_0x1a4288[_0xc041('0x2d')]);_0x4611ec[_0xc041('0x2f')]=_['intersection'](_0x4611ec['model'],_0x4611ec[_0xc041('0x2d')]);_0x5cc1ed[_0xc041('0x32')]=_[_0xc041('0x30')](_0x4611ec[_0xc041('0x31')],qs[_0xc041('0x43')](_0x1a4288[_0xc041('0x2d')]['fields']));_0x5cc1ed['attributes']=_0x5cc1ed[_0xc041('0x32')][_0xc041('0x33')]?_0x5cc1ed[_0xc041('0x32')]:_0x4611ec[_0xc041('0x31')];if(_0x1a4288['query'][_0xc041('0x3c')]){_0x5cc1ed[_0xc041('0x3d')]=[{'all':!![]}];}_0x5cc1ed=_['merge']({},_0x5cc1ed,_0x1a4288[_0xc041('0x3b')]);return db[_0xc041('0x29')][_0xc041('0x44')](_0x5cc1ed)[_0xc041('0x23')](handleEntityNotFound(_0x19b2b3,null))[_0xc041('0x23')](respondWithResult(_0x19b2b3,null))[_0xc041('0x45')](handleError(_0x19b2b3,null));};exports[_0xc041('0x46')]=function(_0x619f18,_0x885542){return db[_0xc041('0x29')][_0xc041('0x46')]()['then'](respondWithResult(_0x885542,null))[_0xc041('0x45')](handleError(_0x885542,null));};exports[_0xc041('0x21')]=function(_0x2708eb,_0x5334f2){if(_0x2708eb[_0xc041('0x47')]['uniqueid']){delete _0x2708eb[_0xc041('0x47')][_0xc041('0x48')];}return db['CmHopperFinal'][_0xc041('0x44')]({'where':{'uniqueid':_0x2708eb[_0xc041('0x41')]['id']}})[_0xc041('0x23')](handleEntityNotFound(_0x5334f2,null))[_0xc041('0x23')](saveUpdates(_0x2708eb['body'],null))[_0xc041('0x23')](respondWithResult(_0x5334f2,null))[_0xc041('0x45')](handleError(_0x5334f2,null));};exports['countContactsQueueCampaignHopperFinal']=function(_0x4017be,_0x5abf91,_0x5bbd85){return db[_0xc041('0x29')][_0xc041('0x3e')]({'raw':![],'where':{'VoiceQueueId':_0x4017be['params']['id']},'attributes':[[db[_0xc041('0x49')]['fn'](_0xc041('0x4a'),db[_0xc041('0x49')]['fn']('IF',db[_0xc041('0x49')]['literal'](_0xc041('0x4b')))),_0xc041('0x4c')],[db[_0xc041('0x49')]['fn'](_0xc041('0x4a'),db[_0xc041('0x49')]['fn']('IF',db[_0xc041('0x49')]['literal']('`state`\x20=\x203,\x201,\x20null'))),_0xc041('0x4d')],[db[_0xc041('0x49')]['fn'](_0xc041('0x4a'),db['sequelize']['fn']('IF',db[_0xc041('0x49')][_0xc041('0x4e')]('`state`\x20=\x205,\x201,\x20null'))),'busyContacts'],[db[_0xc041('0x49')]['fn'](_0xc041('0x4a'),db['sequelize']['fn']('IF',db['sequelize']['literal'](_0xc041('0x4f')))),'congestionContacts'],[db[_0xc041('0x49')]['fn'](_0xc041('0x4a'),db['sequelize']['fn']('IF',db['sequelize'][_0xc041('0x4e')]('`state`\x20=\x2010\x20,\x201,\x20null'))),_0xc041('0x50')],[db['sequelize']['fn'](_0xc041('0x4a'),db[_0xc041('0x49')]['fn']('IF',db[_0xc041('0x49')][_0xc041('0x4e')]('`state`\x20=\x2011\x20,\x201,\x20null'))),_0xc041('0x51')],[db['sequelize']['fn'](_0xc041('0x4a'),db['sequelize']['fn']('IF',db[_0xc041('0x49')][_0xc041('0x4e')](_0xc041('0x52')))),_0xc041('0x53')],[db[_0xc041('0x49')]['fn']('COUNT',db[_0xc041('0x49')]['fn']('IF',db[_0xc041('0x49')][_0xc041('0x4e')](_0xc041('0x54')))),'answeringMachine']]})['then'](handleEntityNotFound(_0x5abf91,null))[_0xc041('0x23')](respondWithResult(_0x5abf91,null))[_0xc041('0x45')](handleError(_0x5abf91,null));};exports[_0xc041('0x55')]=function(_0x511367,_0x43c2ff,_0x4de077){return db[_0xc041('0x29')][_0xc041('0x3e')]({'raw':![],'where':{'CampaignId':_0x511367['params']['id']},'attributes':[[db[_0xc041('0x49')]['fn']('COUNT',db[_0xc041('0x49')]['fn']('IF',db[_0xc041('0x49')]['literal']('`state`\x20=\x200,\x201,\x20null'))),_0xc041('0x4c')],[db[_0xc041('0x49')]['fn'](_0xc041('0x4a'),db[_0xc041('0x49')]['fn']('IF',db[_0xc041('0x49')][_0xc041('0x4e')](_0xc041('0x56')))),_0xc041('0x4d')],[db[_0xc041('0x49')]['fn'](_0xc041('0x4a'),db[_0xc041('0x49')]['fn']('IF',db[_0xc041('0x49')][_0xc041('0x4e')]('`state`\x20=\x205,\x201,\x20null'))),_0xc041('0x57')],[db[_0xc041('0x49')]['fn'](_0xc041('0x4a'),db[_0xc041('0x49')]['fn']('IF',db['sequelize'][_0xc041('0x4e')]('`state`\x20=\x208,\x201,\x20null'))),_0xc041('0x58')],[db['sequelize']['fn'](_0xc041('0x4a'),db['sequelize']['fn']('IF',db[_0xc041('0x49')][_0xc041('0x4e')](_0xc041('0x59')))),'dropContacts'],[db[_0xc041('0x49')]['fn'](_0xc041('0x4a'),db[_0xc041('0x49')]['fn']('IF',db[_0xc041('0x49')]['literal'](_0xc041('0x5a')))),'abandonedContacts'],[db[_0xc041('0x49')]['fn'](_0xc041('0x4a'),db[_0xc041('0x49')]['fn']('IF',db[_0xc041('0x49')][_0xc041('0x4e')](_0xc041('0x52')))),'reCallContacts'],[db[_0xc041('0x49')]['fn'](_0xc041('0x4a'),db[_0xc041('0x49')]['fn']('IF',db['sequelize']['literal'](_0xc041('0x54')))),'answeringMachine']]})[_0xc041('0x23')](handleEntityNotFound(_0x43c2ff,null))[_0xc041('0x23')](respondWithResult(_0x43c2ff,null))[_0xc041('0x45')](handleError(_0x43c2ff,null));};exports[_0xc041('0x5b')]=function(_0x7fe019,_0x46fa52,_0x3dccf7){return db[_0xc041('0x5c')][_0xc041('0x44')]({'where':{'id':_0x7fe019['params']['id']}})[_0xc041('0x23')](handleEntityNotFound(_0x46fa52,null))['then'](function(_0x20e58c){var _0x5316e8;if(_0x20e58c){_0x5316e8=squel[_0xc041('0x5d')]()[_0xc041('0x5e')](_0xc041('0x5f'))[_0xc041('0x60')]([_0xc041('0x61'),'scheduledAt',_0xc041('0x62'),_0xc041('0x63'),_0xc041('0x64'),_0xc041('0x65'),_0xc041('0x66')],squel[_0xc041('0x67')]()[_0xc041('0x68')](_0xc041('0x69'),_0xc041('0x61'))[_0xc041('0x68')](_0xc041('0x6a'),_0xc041('0x6b'))[_0xc041('0x68')]('ANY_VALUE(ContactId)',_0xc041('0x62'))[_0xc041('0x68')](_0xc041('0x6c'),_0xc041('0x63'))['field']('ANY_VALUE(VoiceQueueId)',_0xc041('0x64'))[_0xc041('0x68')](_0xc041('0x6a'),_0xc041('0x65'))[_0xc041('0x68')]('NOW()',_0xc041('0x66'))[_0xc041('0x6d')]('cm_hopper_final')[_0xc041('0x37')]('VoiceQueueId\x20=\x20?',_0x7fe019[_0xc041('0x41')]['id'][_0xc041('0x6e')]())[_0xc041('0x37')](_0xc041('0x6f'),_0x7fe019[_0xc041('0x47')]['state'][_0xc041('0x6e')]())[_0xc041('0x37')](_0xc041('0x70'))['where']('calleridnum\x20NOT\x20IN\x20(?)',squel[_0xc041('0x67')]()['field'](_0xc041('0x61'))['from'](_0xc041('0x5f'))[_0xc041('0x37')]('VoiceQueueId\x20=\x20?',_0x7fe019[_0xc041('0x41')]['id'][_0xc041('0x6e')]()))[_0xc041('0x37')](_0xc041('0x71'),squel[_0xc041('0x67')]()[_0xc041('0x68')](_0xc041('0x72'))['from'](_0xc041('0x73'))[_0xc041('0x37')](_0xc041('0x74'),_0x7fe019[_0xc041('0x41')]['id'][_0xc041('0x6e')]())[_0xc041('0x37')]('state\x20=\x204'))[_0xc041('0x75')](_0xc041('0x62')))[_0xc041('0x6e')]();return db[_0xc041('0x49')][_0xc041('0x2d')](_0x5316e8);}return[];})[_0xc041('0x23')](respondWithResult(_0x46fa52,null))['catch'](handleError(_0x46fa52,null));};exports[_0xc041('0x76')]=function(_0x59b672,_0x291b36,_0x1a8983){return db[_0xc041('0x77')][_0xc041('0x44')]({'where':{'id':_0x59b672[_0xc041('0x41')]['id']}})[_0xc041('0x23')](handleEntityNotFound(_0x291b36,null))['then'](function(_0x5a3edd){var _0x5d3b8e;if(_0x5a3edd){_0x5d3b8e=squel[_0xc041('0x5d')]()[_0xc041('0x5e')](_0xc041('0x5f'))['fromQuery']([_0xc041('0x61'),_0xc041('0x6b'),_0xc041('0x62'),_0xc041('0x63'),'CampaignId',_0xc041('0x65'),_0xc041('0x66')],squel[_0xc041('0x67')]()[_0xc041('0x68')](_0xc041('0x69'),_0xc041('0x61'))[_0xc041('0x68')](_0xc041('0x6a'),_0xc041('0x6b'))[_0xc041('0x68')]('ANY_VALUE(ContactId)',_0xc041('0x62'))[_0xc041('0x68')](_0xc041('0x6c'),'ListId')[_0xc041('0x68')](_0xc041('0x78'),_0xc041('0x79'))[_0xc041('0x68')](_0xc041('0x6a'),_0xc041('0x65'))[_0xc041('0x68')](_0xc041('0x6a'),_0xc041('0x66'))[_0xc041('0x6d')](_0xc041('0x73'))[_0xc041('0x37')](_0xc041('0x7a'),_0x59b672[_0xc041('0x41')]['id'][_0xc041('0x6e')]())[_0xc041('0x37')](_0xc041('0x6f'),_0x59b672[_0xc041('0x47')][_0xc041('0x7b')]['toString']())[_0xc041('0x37')](_0xc041('0x70'))[_0xc041('0x37')](_0xc041('0x71'),squel['select']()[_0xc041('0x68')](_0xc041('0x61'))['from'](_0xc041('0x5f'))[_0xc041('0x37')]('CampaignId\x20=\x20?',_0x59b672[_0xc041('0x41')]['id'][_0xc041('0x6e')]()))[_0xc041('0x37')](_0xc041('0x71'),squel[_0xc041('0x67')]()[_0xc041('0x68')](_0xc041('0x72'))['from'](_0xc041('0x73'))[_0xc041('0x37')](_0xc041('0x7a'),_0x59b672[_0xc041('0x41')]['id'][_0xc041('0x6e')]())[_0xc041('0x37')](_0xc041('0x7c')))[_0xc041('0x75')](_0xc041('0x62')))[_0xc041('0x6e')]();return db[_0xc041('0x49')][_0xc041('0x2d')](_0x5d3b8e);}return[];})[_0xc041('0x23')](respondWithResult(_0x291b36,null))[_0xc041('0x45')](handleError(_0x291b36,null));};exports[_0xc041('0x7d')]=function(_0x25a77c,_0x56dd06,_0x3641c1){return db[_0xc041('0x7e')][_0xc041('0x7f')]({'where':{'VoiceQueueId':_0x25a77c[_0xc041('0x47')][_0xc041('0x64')],'CampaignId':_0x25a77c[_0xc041('0x47')][_0xc041('0x79')],'ContactId':_0x25a77c[_0xc041('0x47')][_0xc041('0x62')]}})[_0xc041('0x23')](handleEntityNotFound(_0x56dd06,null))['then'](function(_0x5d8fa6){if(_0x5d8fa6){return _0x5d8fa6;}return null;})[_0xc041('0x23')](respondWithResult(_0x56dd06,null))[_0xc041('0x45')](handleError(_0x56dd06,null));};