d0eb5f48edbf2054fb9ebe6635ccdaf632048eac
[motion2.git] / server / api / smsQueue / smsQueue.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 _0x0e2a=['user','get','Unable\x20to\x20retrieve\x20the\x20current\x20user','userProfileId','autoAssociation','create','error','describe','getMembers','findOne','UserSmsQueue','SmsQueueId','findAndCountAll','UserId','agent','smsPause','updatedAt','createdAt','format','SIP','Team','addTeams','ids','User','Agents','online','voicePause','interface','flatMap','each','findOrCreate','forEach','emit','removeTeams','select','tq.TeamId','from','team_has_sms_queues','join','user_has_teams','ut.TeamId\x20=\x20tq.TeamId','SmsQueueId\x20=\x20?','clone','ut.UserId\x20=\x20?','push','sequelize','toString','QueryTypes','every','TeamId','includes','all','union','compact','transaction','userSmsQueue:remove','addAgents','omit','spread','removeAgents','isArray','getAgents','rimraf','zip-dir','fast-json-patch','request-promise','bluebird','path','sox','to-csv','ejs','lodash','desk.js','querystring','papaparse','ioredis','../../components/auth/service','../../components/parsers/advancedSearch','../../config/license/hardware','../../config/logger','../../config/utils','../../config/environment','../../config/license/util','../../mysqldb','redis','defaults','localhost','socket.io-emitter','./smsQueue.socket','register','status','end','json','offset','undefined','count','Content-Range','apply','reject','save','update','then','SmsQueues','destroy','sendStatus','name','index','map','SmsQueue','key','model','query','keys','filters','intersection','attributes','fields','length','hasOwnProperty','nolimit','limit','order','sort','pick','filter','where','merge','type','options','include','findAll','rows','catch','show','params','rawAttributes','includeAll','find','body'];(function(_0x2e7b19,_0x10eaa2){var _0x137bd2=function(_0x2d67ff){while(--_0x2d67ff){_0x2e7b19['push'](_0x2e7b19['shift']());}};_0x137bd2(++_0x10eaa2);}(_0x0e2a,0x154));var _0xa0e2=function(_0x10f6e8,_0x351db6){_0x10f6e8=_0x10f6e8-0x0;var _0x35bb3c=_0x0e2a[_0x10f6e8];return _0x35bb3c;};'use strict';var emlformat=require('eml-format');var rimraf=require(_0xa0e2('0x0'));var zipdir=require(_0xa0e2('0x1'));var jsonpatch=require(_0xa0e2('0x2'));var rp=require(_0xa0e2('0x3'));var moment=require('moment');var BPromise=require(_0xa0e2('0x4'));var Mustache=require('mustache');var util=require('util');var path=require(_0xa0e2('0x5'));var sox=require(_0xa0e2('0x6'));var csv=require(_0xa0e2('0x7'));var ejs=require(_0xa0e2('0x8'));var fs=require('fs');var fs_extra=require('fs-extra');var _=require(_0xa0e2('0x9'));var squel=require('squel');var crypto=require('crypto');var jsforce=require('jsforce');var deskjs=require(_0xa0e2('0xa'));var toCsv=require(_0xa0e2('0x7'));var querystring=require(_0xa0e2('0xb'));var Papa=require(_0xa0e2('0xc'));var Redis=require(_0xa0e2('0xd'));var authService=require(_0xa0e2('0xe'));var qs=require('../../components/parsers/qs');var as=require(_0xa0e2('0xf'));var hardwareService=require(_0xa0e2('0x10'));var logger=require(_0xa0e2('0x11'))('api');var utils=require(_0xa0e2('0x12'));var config=require(_0xa0e2('0x13'));var licenseUtil=require(_0xa0e2('0x14'));var db=require(_0xa0e2('0x15'))['db'];config[_0xa0e2('0x16')]=_[_0xa0e2('0x17')](config[_0xa0e2('0x16')],{'host':_0xa0e2('0x18'),'port':0x18eb});var socket=require(_0xa0e2('0x19'))(new Redis(config['redis']));require(_0xa0e2('0x1a'))[_0xa0e2('0x1b')](socket);function respondWithStatusCode(_0x1bc648,_0x45736e){_0x45736e=_0x45736e||0xcc;return function(_0x34576f){if(_0x34576f){return _0x1bc648['sendStatus'](_0x45736e);}return _0x1bc648[_0xa0e2('0x1c')](_0x45736e)[_0xa0e2('0x1d')]();};}function respondWithResult(_0x12c3b2,_0x48f8c2){_0x48f8c2=_0x48f8c2||0xc8;return function(_0x4a861a){if(_0x4a861a){return _0x12c3b2['status'](_0x48f8c2)[_0xa0e2('0x1e')](_0x4a861a);}};}function respondWithFilteredResult(_0x124da1,_0x1631a3){return function(_0x221b70){if(_0x221b70){var _0x42aba5=typeof _0x1631a3[_0xa0e2('0x1f')]===_0xa0e2('0x20')&&typeof _0x1631a3['limit']===_0xa0e2('0x20');var _0x2180f2=_0x221b70[_0xa0e2('0x21')];var _0xfc3e2a=_0x42aba5?0x0:_0x1631a3[_0xa0e2('0x1f')];var _0x59f341=_0x42aba5?_0x221b70[_0xa0e2('0x21')]:_0x1631a3['offset']+_0x1631a3['limit'];var _0x2b1af2;if(_0x59f341>=_0x2180f2){_0x59f341=_0x2180f2;_0x2b1af2=0xc8;}else{_0x2b1af2=0xce;}_0x124da1[_0xa0e2('0x1c')](_0x2b1af2);return _0x124da1['set'](_0xa0e2('0x22'),_0xfc3e2a+'-'+_0x59f341+'/'+_0x2180f2)[_0xa0e2('0x1e')](_0x221b70);}return null;};}function patchUpdates(_0x196fe8){return function(_0x971683){try{jsonpatch[_0xa0e2('0x23')](_0x971683,_0x196fe8,!![]);}catch(_0x2a9a43){return BPromise[_0xa0e2('0x24')](_0x2a9a43);}return _0x971683[_0xa0e2('0x25')]();};}function saveUpdates(_0x18ff62,_0x1d5820){return function(_0x294fca){if(_0x294fca){return _0x294fca[_0xa0e2('0x26')](_0x18ff62)[_0xa0e2('0x27')](function(_0x241d9e){return _0x241d9e;});}return null;};}function removeEntity(_0x25c1b2,_0x247511){return function(_0x2a0186){if(_0x2a0186){return _0x2a0186['destroy']()['then'](function(){var _0x1d25ed=_0x2a0186['get']({'plain':!![]});var _0x2a2e84=_0xa0e2('0x28');return db['UserProfileResource'][_0xa0e2('0x29')]({'where':{'type':_0x2a2e84,'resourceId':_0x1d25ed['id']}})[_0xa0e2('0x27')](function(){return _0x2a0186;});})[_0xa0e2('0x27')](function(){_0x25c1b2[_0xa0e2('0x1c')](0xcc)[_0xa0e2('0x1d')]();});}};}function handleEntityNotFound(_0x3547d3,_0x4455b9){return function(_0x571379){if(!_0x571379){_0x3547d3[_0xa0e2('0x2a')](0x194);}return _0x571379;};}function handleError(_0x1a9c3a,_0x45ffe7){_0x45ffe7=_0x45ffe7||0x1f4;return function(_0x3f742b){logger['error'](_0x3f742b['stack']);if(_0x3f742b[_0xa0e2('0x2b')]){delete _0x3f742b[_0xa0e2('0x2b')];}_0x1a9c3a[_0xa0e2('0x1c')](_0x45ffe7)['send'](_0x3f742b);};}exports[_0xa0e2('0x2c')]=function(_0x1416ba,_0x2e69a6){var _0x54c15c={},_0x282691={},_0x174d92={'count':0x0,'rows':[]};var _0x110813=_[_0xa0e2('0x2d')](db[_0xa0e2('0x2e')]['rawAttributes'],function(_0x9ac959){return{'name':_0x9ac959['fieldName'],'type':_0x9ac959['type'][_0xa0e2('0x2f')]};});_0x282691[_0xa0e2('0x30')]=_['map'](_0x110813,_0xa0e2('0x2b'));_0x282691[_0xa0e2('0x31')]=_[_0xa0e2('0x32')](_0x1416ba[_0xa0e2('0x31')]);_0x282691[_0xa0e2('0x33')]=_[_0xa0e2('0x34')](_0x282691[_0xa0e2('0x30')],_0x282691[_0xa0e2('0x31')]);_0x54c15c[_0xa0e2('0x35')]=_['intersection'](_0x282691[_0xa0e2('0x30')],qs[_0xa0e2('0x36')](_0x1416ba[_0xa0e2('0x31')][_0xa0e2('0x36')]));_0x54c15c[_0xa0e2('0x35')]=_0x54c15c[_0xa0e2('0x35')][_0xa0e2('0x37')]?_0x54c15c[_0xa0e2('0x35')]:_0x282691[_0xa0e2('0x30')];if(!_0x1416ba['query'][_0xa0e2('0x38')](_0xa0e2('0x39'))){_0x54c15c[_0xa0e2('0x3a')]=qs['limit'](_0x1416ba[_0xa0e2('0x31')][_0xa0e2('0x3a')]);_0x54c15c[_0xa0e2('0x1f')]=qs[_0xa0e2('0x1f')](_0x1416ba[_0xa0e2('0x31')][_0xa0e2('0x1f')]);}_0x54c15c[_0xa0e2('0x3b')]=qs[_0xa0e2('0x3c')](_0x1416ba[_0xa0e2('0x31')][_0xa0e2('0x3c')]);_0x54c15c['where']=qs[_0xa0e2('0x33')](_[_0xa0e2('0x3d')](_0x1416ba[_0xa0e2('0x31')],_0x282691[_0xa0e2('0x33')]),_0x110813);if(_0x1416ba['query'][_0xa0e2('0x3e')]){_0x54c15c[_0xa0e2('0x3f')]=_[_0xa0e2('0x40')](_0x54c15c[_0xa0e2('0x3f')],{'$or':_[_0xa0e2('0x2d')](_0x110813,function(_0x2b5ce0){if(_0x2b5ce0[_0xa0e2('0x41')]!=='VIRTUAL'){var _0x525622={};_0x525622[_0x2b5ce0[_0xa0e2('0x2b')]]={'$like':'%'+_0x1416ba[_0xa0e2('0x31')][_0xa0e2('0x3e')]+'%'};return _0x525622;}})});}_0x54c15c=_['merge']({},_0x54c15c,_0x1416ba[_0xa0e2('0x42')]);var _0x32b980={'where':_0x54c15c[_0xa0e2('0x3f')]};return db[_0xa0e2('0x2e')]['count'](_0x32b980)[_0xa0e2('0x27')](function(_0x1a3597){_0x174d92['count']=_0x1a3597;if(_0x1416ba['query']['includeAll']){_0x54c15c[_0xa0e2('0x43')]=[{'all':!![]}];}return db[_0xa0e2('0x2e')][_0xa0e2('0x44')](_0x54c15c);})[_0xa0e2('0x27')](function(_0x2819a0){_0x174d92[_0xa0e2('0x45')]=_0x2819a0;return _0x174d92;})[_0xa0e2('0x27')](respondWithFilteredResult(_0x2e69a6,_0x54c15c))[_0xa0e2('0x46')](handleError(_0x2e69a6,null));};exports[_0xa0e2('0x47')]=function(_0x162875,_0x28d8af){var _0x204d12={'raw':!![],'where':{'id':_0x162875[_0xa0e2('0x48')]['id']}},_0x5b7f50={};_0x5b7f50['model']=_['keys'](db[_0xa0e2('0x2e')][_0xa0e2('0x49')]);_0x5b7f50[_0xa0e2('0x31')]=_[_0xa0e2('0x32')](_0x162875[_0xa0e2('0x31')]);_0x5b7f50[_0xa0e2('0x33')]=_[_0xa0e2('0x34')](_0x5b7f50['model'],_0x5b7f50['query']);_0x204d12[_0xa0e2('0x35')]=_['intersection'](_0x5b7f50[_0xa0e2('0x30')],qs[_0xa0e2('0x36')](_0x162875['query'][_0xa0e2('0x36')]));_0x204d12[_0xa0e2('0x35')]=_0x204d12[_0xa0e2('0x35')][_0xa0e2('0x37')]?_0x204d12['attributes']:_0x5b7f50[_0xa0e2('0x30')];if(_0x162875['query'][_0xa0e2('0x4a')]){_0x204d12[_0xa0e2('0x43')]=[{'all':!![]}];}_0x204d12=_[_0xa0e2('0x40')]({},_0x204d12,_0x162875['options']);return db['SmsQueue'][_0xa0e2('0x4b')](_0x204d12)[_0xa0e2('0x27')](handleEntityNotFound(_0x28d8af,null))[_0xa0e2('0x27')](respondWithResult(_0x28d8af,null))[_0xa0e2('0x46')](handleError(_0x28d8af,null));};exports['create']=function(_0x1ad821,_0x2e8dd8){return db[_0xa0e2('0x2e')]['create'](_0x1ad821[_0xa0e2('0x4c')],{})[_0xa0e2('0x27')](function(_0x236d4e){var _0x3b7e4a=_0x1ad821[_0xa0e2('0x4d')][_0xa0e2('0x4e')]({'plain':!![]});if(!_0x3b7e4a)throw new Error(_0xa0e2('0x4f'));if(_0x3b7e4a['role']==='user'){var _0x425162=_0x236d4e[_0xa0e2('0x4e')]({'plain':!![]});var _0x214156='SmsQueues';return db['UserProfileSection'][_0xa0e2('0x4b')]({'where':{'name':_0x214156,'userProfileId':_0x3b7e4a[_0xa0e2('0x50')]},'raw':!![]})[_0xa0e2('0x27')](function(_0xa13008){if(_0xa13008&&_0xa13008[_0xa0e2('0x51')]===0x0){return db['UserProfileResource'][_0xa0e2('0x52')]({'name':_0x425162[_0xa0e2('0x2b')],'resourceId':_0x425162['id'],'type':_0xa13008[_0xa0e2('0x2b')],'sectionId':_0xa13008['id']},{})['then'](function(){return _0x236d4e;});}else{return _0x236d4e;}})[_0xa0e2('0x46')](function(_0x1b6e19){logger[_0xa0e2('0x53')]('Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s',_0x1b6e19);throw _0x1b6e19;});}return _0x236d4e;})[_0xa0e2('0x27')](respondWithResult(_0x2e8dd8,0xc9))[_0xa0e2('0x46')](handleError(_0x2e8dd8,null));};exports[_0xa0e2('0x26')]=function(_0x5058c6,_0x3e01cb){if(_0x5058c6['body']['id']){delete _0x5058c6[_0xa0e2('0x4c')]['id'];}return db[_0xa0e2('0x2e')][_0xa0e2('0x4b')]({'where':{'id':_0x5058c6[_0xa0e2('0x48')]['id']}})['then'](handleEntityNotFound(_0x3e01cb,null))['then'](saveUpdates(_0x5058c6[_0xa0e2('0x4c')],null))[_0xa0e2('0x27')](respondWithResult(_0x3e01cb,null))[_0xa0e2('0x46')](handleError(_0x3e01cb,null));};exports[_0xa0e2('0x29')]=function(_0x3f2fa5,_0x5d2a03){return db['SmsQueue'][_0xa0e2('0x4b')]({'where':{'id':_0x3f2fa5[_0xa0e2('0x48')]['id']}})[_0xa0e2('0x27')](handleEntityNotFound(_0x5d2a03,null))[_0xa0e2('0x27')](removeEntity(_0x5d2a03,null))[_0xa0e2('0x46')](handleError(_0x5d2a03,null));};exports[_0xa0e2('0x54')]=function(_0x468e73,_0x30b0ac){return db[_0xa0e2('0x2e')][_0xa0e2('0x54')]()['then'](respondWithResult(_0x30b0ac,null))[_0xa0e2('0x46')](handleError(_0x30b0ac,null));};exports[_0xa0e2('0x55')]=function(_0x16441f,_0x41ecac,_0x3e4db5){var _0x542bc9={'raw':!![],'where':{}},_0x97c4d8={},_0x2d53ef;return db[_0xa0e2('0x2e')][_0xa0e2('0x56')]({'where':{'id':_0x16441f[_0xa0e2('0x48')]['id']}})[_0xa0e2('0x27')](handleEntityNotFound(_0x41ecac,null))['then'](function(_0x2a1a76){if(_0x2a1a76){_0x2d53ef=_0x2a1a76[_0xa0e2('0x4e')]({'plain':!![]});_0x97c4d8[_0xa0e2('0x30')]=_[_0xa0e2('0x32')](db[_0xa0e2('0x57')]['rawAttributes']);_0x97c4d8[_0xa0e2('0x31')]=_[_0xa0e2('0x32')](_0x16441f[_0xa0e2('0x31')]);_0x97c4d8[_0xa0e2('0x33')]=_[_0xa0e2('0x34')](_0x97c4d8[_0xa0e2('0x30')],_0x97c4d8[_0xa0e2('0x31')]);_0x542bc9['attributes']=_['intersection'](_0x97c4d8[_0xa0e2('0x30')],qs[_0xa0e2('0x36')](_0x16441f['query'][_0xa0e2('0x36')]));_0x542bc9[_0xa0e2('0x35')]=_0x542bc9[_0xa0e2('0x35')][_0xa0e2('0x37')]?_0x542bc9[_0xa0e2('0x35')]:_0x97c4d8[_0xa0e2('0x30')];if(!_0x16441f[_0xa0e2('0x31')]['hasOwnProperty']('nolimit')){_0x542bc9['limit']=qs[_0xa0e2('0x3a')](_0x16441f['query']['limit']);_0x542bc9['offset']=qs['offset'](_0x16441f['query'][_0xa0e2('0x1f')]);}_0x542bc9['order']=qs[_0xa0e2('0x3c')](_0x16441f['query']['sort']);_0x542bc9[_0xa0e2('0x3f')]=qs[_0xa0e2('0x33')](_[_0xa0e2('0x3d')](_0x16441f[_0xa0e2('0x31')],_0x97c4d8['filters']));_0x542bc9['where'][_0xa0e2('0x58')]=_0x2a1a76['id'];if(_0x16441f[_0xa0e2('0x31')][_0xa0e2('0x3e')]){_0x542bc9[_0xa0e2('0x3f')]=_['merge'](_0x542bc9[_0xa0e2('0x3f')],{'$or':_[_0xa0e2('0x2d')](_0x542bc9[_0xa0e2('0x35')],function(_0x28cb61){var _0x5bd830={};_0x5bd830[_0x28cb61]={'$like':'%'+_0x16441f[_0xa0e2('0x31')][_0xa0e2('0x3e')]+'%'};return _0x5bd830;})});}_0x542bc9=_['merge']({},_0x542bc9,_0x16441f[_0xa0e2('0x42')]);return db['UserSmsQueue'][_0xa0e2('0x44')](_0x542bc9);}})[_0xa0e2('0x27')](function(_0x306360){if(_0x306360){return db['User'][_0xa0e2('0x59')]({'where':{'id':_['map'](_0x306360,_0xa0e2('0x5a')),'role':_0xa0e2('0x5b')},'attributes':['id',_0xa0e2('0x2b'),_0xa0e2('0x5c'),_0xa0e2('0x5d'),_0xa0e2('0x5e')]});}})[_0xa0e2('0x27')](function(_0x2922e1){if(_0x2922e1){return{'count':_0x2922e1[_0xa0e2('0x21')],'rows':_['map'](_0x2922e1[_0xa0e2('0x45')],function(_0x3005a2){return{'membername':_0x3005a2[_0xa0e2('0x2b')],'UserId':_0x3005a2['id'],'queue_name':_0x2d53ef[_0xa0e2('0x2b')],'SmsQueueId':_0x2d53ef['id'],'interface':util[_0xa0e2('0x5f')]('%s/%s',_0xa0e2('0x60'),_0x3005a2[_0xa0e2('0x2b')]),'penalty':0x0,'paused':_0x3005a2[_0xa0e2('0x5c')],'createdAt':_0x3005a2[_0xa0e2('0x5e')],'updatedAt':_0x3005a2[_0xa0e2('0x5d')]};})};}else{return{'count':0x0,'rows':[]};}})[_0xa0e2('0x27')](respondWithFilteredResult(_0x41ecac,_0x542bc9))['catch'](handleError(_0x41ecac,null));};exports['getTeams']=function(_0x12b3ce,_0x193a50,_0x8d7d37){var _0x2f0044={};var _0x3c725d={};var _0x4f82fa;var _0xf7c3ef;return db[_0xa0e2('0x2e')][_0xa0e2('0x56')]({'where':{'id':_0x12b3ce[_0xa0e2('0x48')]['id']}})[_0xa0e2('0x27')](handleEntityNotFound(_0x193a50,null))['then'](function(_0x4efcee){if(_0x4efcee){_0x4f82fa=_0x4efcee;_0x3c725d[_0xa0e2('0x30')]=_[_0xa0e2('0x32')](db[_0xa0e2('0x61')]['rawAttributes']);_0x3c725d[_0xa0e2('0x31')]=_['keys'](_0x12b3ce[_0xa0e2('0x31')]);_0x3c725d['filters']=_[_0xa0e2('0x34')](_0x3c725d[_0xa0e2('0x30')],_0x3c725d['query']);_0x2f0044['attributes']=_['intersection'](_0x3c725d[_0xa0e2('0x30')],qs[_0xa0e2('0x36')](_0x12b3ce['query'][_0xa0e2('0x36')]));_0x2f0044['attributes']=_0x2f0044[_0xa0e2('0x35')][_0xa0e2('0x37')]?_0x2f0044[_0xa0e2('0x35')]:_0x3c725d[_0xa0e2('0x30')];_0x2f0044[_0xa0e2('0x3b')]=qs[_0xa0e2('0x3c')](_0x12b3ce[_0xa0e2('0x31')][_0xa0e2('0x3c')]);_0x2f0044[_0xa0e2('0x3f')]=qs[_0xa0e2('0x33')](_[_0xa0e2('0x3d')](_0x12b3ce[_0xa0e2('0x31')],_0x3c725d[_0xa0e2('0x33')]));if(_0x12b3ce['query'][_0xa0e2('0x3e')]){_0x2f0044[_0xa0e2('0x3f')]=_[_0xa0e2('0x40')](_0x2f0044[_0xa0e2('0x3f')],{'$or':_['map'](_0x2f0044[_0xa0e2('0x35')],function(_0x3f9fe2){var _0x10389b={};_0x10389b[_0x3f9fe2]={'$like':'%'+_0x12b3ce['query'][_0xa0e2('0x3e')]+'%'};return _0x10389b;})});}_0x2f0044=_[_0xa0e2('0x40')]({},_0x2f0044,_0x12b3ce['options']);return _0x4f82fa['getTeams'](_0x2f0044);}})[_0xa0e2('0x27')](function(_0x29904e){if(_0x29904e){_0xf7c3ef=_0x29904e[_0xa0e2('0x37')];if(!_0x12b3ce['query'][_0xa0e2('0x38')](_0xa0e2('0x39'))){_0x2f0044[_0xa0e2('0x3a')]=qs['limit'](_0x12b3ce[_0xa0e2('0x31')][_0xa0e2('0x3a')]);_0x2f0044['offset']=qs[_0xa0e2('0x1f')](_0x12b3ce['query'][_0xa0e2('0x1f')]);}return _0x4f82fa['getTeams'](_0x2f0044);}})[_0xa0e2('0x27')](function(_0x23d43d){if(_0x23d43d){return _0x23d43d?{'count':_0xf7c3ef,'rows':_0x23d43d}:null;}})[_0xa0e2('0x27')](respondWithResult(_0x193a50,null))[_0xa0e2('0x46')](handleError(_0x193a50,null));};exports[_0xa0e2('0x62')]=function(_0x18129d,_0x1dfcfb,_0x466364){var _0x481757=_0x18129d[_0xa0e2('0x4c')][_0xa0e2('0x63')];return db[_0xa0e2('0x61')][_0xa0e2('0x44')]({'where':{'id':_0x481757},'attributes':['id'],'include':[{'model':db[_0xa0e2('0x64')],'as':_0xa0e2('0x65'),'attributes':['id',_0xa0e2('0x2b'),_0xa0e2('0x66'),_0xa0e2('0x67'),_0xa0e2('0x68')],'raw':!![]}]})[_0xa0e2('0x27')](function(_0x762be8){if(_0x762be8){var _0x427346=_[_0xa0e2('0x69')](_0x762be8,function(_0x9a47ea){var _0x56d57b=_0x9a47ea['get']({'plain':!![]});return _0x56d57b[_0xa0e2('0x65')];});return db[_0xa0e2('0x2e')][_0xa0e2('0x4b')]({'where':{'id':_0x18129d[_0xa0e2('0x48')]['id']}})[_0xa0e2('0x27')](function(_0x4dc6d4){return db['sequelize']['transaction'](function(_0x275f46){return _0x4dc6d4[_0xa0e2('0x62')](_0x481757,{'transaction':_0x275f46})['then'](function(){return BPromise[_0xa0e2('0x6a')](_0x427346,function(_0x32a75d){return db['UserSmsQueue'][_0xa0e2('0x6b')]({'where':{'UserId':_0x32a75d['id'],'SmsQueueId':_0x18129d[_0xa0e2('0x48')]['id']},'transaction':_0x275f46});});})[_0xa0e2('0x27')](function(){_0x427346[_0xa0e2('0x6c')](function(_0x197153){socket[_0xa0e2('0x6d')]('userSmsQueue:save',{'UserId':_0x197153['id'],'SmsQueueId':_0x4dc6d4['id']});});});});});}})[_0xa0e2('0x27')](respondWithStatusCode(_0x1dfcfb,null))[_0xa0e2('0x46')](handleError(_0x1dfcfb,null));};exports[_0xa0e2('0x6e')]=function(_0x5d15f1,_0x391b19,_0x3ba2eb){return db['Team'][_0xa0e2('0x44')]({'where':{'id':_0x5d15f1[_0xa0e2('0x31')]['ids']},'attributes':['id'],'include':[{'model':db[_0xa0e2('0x64')],'as':_0xa0e2('0x65'),'attributes':['id'],'raw':!![]}]})[_0xa0e2('0x27')](handleEntityNotFound(_0x391b19,null))['then'](function(_0x5b5c5e){var _0x3b2dd8=_[_0xa0e2('0x2d')](_0x5b5c5e,'id');var _0x3381da=[];var _0x554936=[];var _0x451fd4=squel[_0xa0e2('0x6f')]();_0x451fd4['field'](_0xa0e2('0x70'))[_0xa0e2('0x71')](_0xa0e2('0x72'),'tq')[_0xa0e2('0x73')](_0xa0e2('0x74'),'ut',_0xa0e2('0x75'))[_0xa0e2('0x3f')](_0xa0e2('0x76'),_0x5d15f1[_0xa0e2('0x48')]['id']);for(var _0x53b146=0x0;_0x53b146<_0x5b5c5e[_0xa0e2('0x37')];_0x53b146+=0x1){let _0x25c9b3=_0x5b5c5e[_0x53b146];for(var _0x294527=0x0;_0x294527<_0x25c9b3[_0xa0e2('0x65')][_0xa0e2('0x37')];_0x294527+=0x1){let _0x2d3368=_0x25c9b3['Agents'][_0x294527];var _0x280cd5=_0x451fd4[_0xa0e2('0x77')]();_0x280cd5[_0xa0e2('0x3f')](_0xa0e2('0x78'),_0x2d3368['id']);_0x554936[_0xa0e2('0x79')](db[_0xa0e2('0x7a')][_0xa0e2('0x31')](_0x280cd5[_0xa0e2('0x7b')](),{'type':db[_0xa0e2('0x7a')][_0xa0e2('0x7c')]['SELECT']})[_0xa0e2('0x27')](function(_0x251a35){if(_0x251a35['length']===0x1){return _0x2d3368['id'];}else{var _0xec1a96=_[_0xa0e2('0x7d')](_['map'](_0x251a35,_0xa0e2('0x7e')),function(_0x7e3a25){return _[_0xa0e2('0x7f')](_0x3b2dd8,_0x7e3a25);});if(_0xec1a96){return _0x2d3368['id'];}}}));}}return BPromise[_0xa0e2('0x80')](_0x554936)['then'](function(_0x494d18){_0x3381da=_(_0x3381da)[_0xa0e2('0x81')](_0x494d18)[_0xa0e2('0x82')]()['value']();return db[_0xa0e2('0x2e')][_0xa0e2('0x4b')]({'where':{'id':_0x5d15f1[_0xa0e2('0x48')]['id']}})[_0xa0e2('0x27')](function(_0x297e86){return db[_0xa0e2('0x7a')][_0xa0e2('0x83')](function(_0x29c20c){return _0x297e86[_0xa0e2('0x6e')](_0x5d15f1['query']['ids'],{'transaction':_0x29c20c})[_0xa0e2('0x27')](function(){if(!_['isEmpty'](_0x3381da)){return _0x297e86['removeAgents'](_0x3381da,{'transaction':_0x29c20c});}})[_0xa0e2('0x27')](function(){_0x3381da[_0xa0e2('0x6c')](function(_0x4793e1){socket[_0xa0e2('0x6d')](_0xa0e2('0x84'),{'UserId':_0x4793e1,'SmsQueueId':_0x297e86['id']});});});});});});})['then'](respondWithStatusCode(_0x391b19,null))[_0xa0e2('0x46')](handleError(_0x391b19,null));};exports[_0xa0e2('0x85')]=function(_0x395da6,_0x3ba46b,_0x35f366){return db[_0xa0e2('0x2e')][_0xa0e2('0x4b')]({'where':{'id':_0x395da6[_0xa0e2('0x48')]['id']}})['then'](handleEntityNotFound(_0x3ba46b,null))[_0xa0e2('0x27')](function(_0x175e68){if(_0x175e68){return _0x175e68[_0xa0e2('0x85')](_0x395da6[_0xa0e2('0x4c')][_0xa0e2('0x63')],_[_0xa0e2('0x86')](_0x395da6['body'],[_0xa0e2('0x63'),'id'])||{})[_0xa0e2('0x87')](function(_0x56ba65){for(var _0x4db872=0x0;_0x4db872<_0x395da6['body'][_0xa0e2('0x63')]['length'];_0x4db872+=0x1){socket['emit']('userSmsQueue:save',{'UserId':Number(_0x395da6['body']['ids'][_0x4db872]),'SmsQueueId':Number(_0x395da6[_0xa0e2('0x48')]['id'])});}return _0x56ba65;});}})[_0xa0e2('0x27')](respondWithResult(_0x3ba46b,null))[_0xa0e2('0x46')](handleError(_0x3ba46b,null));};exports[_0xa0e2('0x88')]=function(_0x5500d4,_0x1cb894,_0x486e92){return db[_0xa0e2('0x2e')][_0xa0e2('0x4b')]({'where':{'id':_0x5500d4[_0xa0e2('0x48')]['id']}})[_0xa0e2('0x27')](handleEntityNotFound(_0x1cb894,null))[_0xa0e2('0x27')](function(_0x397ce2){if(_0x397ce2){return _0x397ce2[_0xa0e2('0x88')](_0x5500d4[_0xa0e2('0x31')][_0xa0e2('0x63')])['then'](function(){if(_[_0xa0e2('0x89')](_0x5500d4['query'][_0xa0e2('0x63')])){for(var _0x342dfc=0x0;_0x342dfc<_0x5500d4['query'][_0xa0e2('0x63')][_0xa0e2('0x37')];_0x342dfc+=0x1){socket['emit'](_0xa0e2('0x84'),{'UserId':Number(_0x5500d4[_0xa0e2('0x31')][_0xa0e2('0x63')][_0x342dfc]),'SmsQueueId':Number(_0x5500d4['params']['id'])});}}else{socket['emit']('userSmsQueue:remove',{'UserId':Number(_0x5500d4['query'][_0xa0e2('0x63')]),'SmsQueueId':Number(_0x5500d4['params']['id'])});}});}})['then'](respondWithStatusCode(_0x1cb894,null))['catch'](handleError(_0x1cb894,null));};exports['getAgents']=function(_0x3e8b55,_0x4ed46b,_0xde9e00){var _0x193704={};var _0x46bedd={};var _0x4c8e8c;var _0x10b892;return db[_0xa0e2('0x2e')][_0xa0e2('0x56')]({'where':{'id':_0x3e8b55[_0xa0e2('0x48')]['id']}})[_0xa0e2('0x27')](handleEntityNotFound(_0x4ed46b,null))['then'](function(_0x2e9114){if(_0x2e9114){_0x4c8e8c=_0x2e9114;_0x46bedd[_0xa0e2('0x30')]=_['keys'](db[_0xa0e2('0x64')][_0xa0e2('0x49')]);_0x46bedd[_0xa0e2('0x31')]=_[_0xa0e2('0x32')](_0x3e8b55[_0xa0e2('0x31')]);_0x46bedd[_0xa0e2('0x33')]=_['intersection'](_0x46bedd[_0xa0e2('0x30')],_0x46bedd['query']);_0x193704['attributes']=_[_0xa0e2('0x34')](_0x46bedd[_0xa0e2('0x30')],qs[_0xa0e2('0x36')](_0x3e8b55[_0xa0e2('0x31')][_0xa0e2('0x36')]));_0x193704[_0xa0e2('0x35')]=_0x193704[_0xa0e2('0x35')][_0xa0e2('0x37')]?_0x193704[_0xa0e2('0x35')]:_0x46bedd['model'];_0x193704[_0xa0e2('0x3b')]=qs[_0xa0e2('0x3c')](_0x3e8b55['query']['sort']);_0x193704[_0xa0e2('0x3f')]=qs['filters'](_[_0xa0e2('0x3d')](_0x3e8b55['query'],_0x46bedd[_0xa0e2('0x33')]));if(_0x3e8b55[_0xa0e2('0x31')]['filter']){_0x193704[_0xa0e2('0x3f')]=_[_0xa0e2('0x40')](_0x193704[_0xa0e2('0x3f')],{'$or':_['map'](_0x193704[_0xa0e2('0x35')],function(_0x4d311f){var _0x2dac46={};_0x2dac46[_0x4d311f]={'$like':'%'+_0x3e8b55[_0xa0e2('0x31')][_0xa0e2('0x3e')]+'%'};return _0x2dac46;})});}_0x193704=_[_0xa0e2('0x40')]({},_0x193704,_0x3e8b55[_0xa0e2('0x42')]);return _0x4c8e8c['getAgents'](_0x193704);}})[_0xa0e2('0x27')](function(_0x14bcc1){if(_0x14bcc1){_0x10b892=_0x14bcc1[_0xa0e2('0x37')];if(!_0x3e8b55['query'][_0xa0e2('0x38')](_0xa0e2('0x39'))){_0x193704[_0xa0e2('0x3a')]=qs[_0xa0e2('0x3a')](_0x3e8b55[_0xa0e2('0x31')][_0xa0e2('0x3a')]);_0x193704[_0xa0e2('0x1f')]=qs[_0xa0e2('0x1f')](_0x3e8b55[_0xa0e2('0x31')][_0xa0e2('0x1f')]);}return _0x4c8e8c[_0xa0e2('0x8a')](_0x193704);}})[_0xa0e2('0x27')](function(_0x13e10f){if(_0x13e10f){return _0x13e10f?{'count':_0x10b892,'rows':_0x13e10f}:null;}})[_0xa0e2('0x27')](respondWithResult(_0x4ed46b,null))[_0xa0e2('0x46')](handleError(_0x4ed46b,null));};