Built motion from commit 753c950e.|2.5.42
[motion2.git] / server / api / mailQueue / mailQueue.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 _0x4be8=['offset','limit','count','Content-Range','apply','reject','save','update','then','destroy','MailQueues','UserProfileResource','error','stack','name','index','map','MailQueue','rawAttributes','fieldName','type','key','model','query','keys','filters','intersection','attributes','fields','length','sort','where','pick','filter','merge','VIRTUAL','includeAll','include','findAll','rows','show','params','find','catch','create','body','user','role','get','UserProfileSection','userProfileId','Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s','describe','findOne','order','MailQueueId','UserMailQueue','User','UserId','mailPause','updatedAt','format','%s/%s','SIP','createdAt','getTeams','Team','options','hasOwnProperty','nolimit','addTeams','Agents','voicePause','interface','sequelize','transaction','each','findOrCreate','forEach','emit','userMailQueue:save','removeTeams','select','field','tq.TeamId','from','team_has_mail_queues','join','user_has_teams','ut.TeamId\x20=\x20tq.TeamId','MailQueueId\x20=\x20?','clone','push','toString','QueryTypes','SELECT','TeamId','union','compact','value','ids','isEmpty','userMailQueue:remove','addAgents','removeAgents','isArray','getAgents','eml-format','rimraf','zip-dir','fast-json-patch','request-promise','moment','bluebird','path','sox','to-csv','ejs','fs-extra','lodash','crypto','jsforce','querystring','ioredis','../../components/auth/service','../../components/parsers/qs','../../components/parsers/advancedSearch','../../config/logger','api','../../config/utils','../../config/license/util','redis','defaults','localhost','register','status','end','json'];(function(_0x36cfe3,_0x2cca39){var _0x5c203f=function(_0x33486b){while(--_0x33486b){_0x36cfe3['push'](_0x36cfe3['shift']());}};_0x5c203f(++_0x2cca39);}(_0x4be8,0x17f));var _0x84be=function(_0x1573ea,_0x434f02){_0x1573ea=_0x1573ea-0x0;var _0x51c0e2=_0x4be8[_0x1573ea];return _0x51c0e2;};'use strict';var emlformat=require(_0x84be('0x0'));var rimraf=require(_0x84be('0x1'));var zipdir=require(_0x84be('0x2'));var jsonpatch=require(_0x84be('0x3'));var rp=require(_0x84be('0x4'));var moment=require(_0x84be('0x5'));var BPromise=require(_0x84be('0x6'));var Mustache=require('mustache');var util=require('util');var path=require(_0x84be('0x7'));var sox=require(_0x84be('0x8'));var csv=require(_0x84be('0x9'));var ejs=require(_0x84be('0xa'));var fs=require('fs');var fs_extra=require(_0x84be('0xb'));var _=require(_0x84be('0xc'));var squel=require('squel');var crypto=require(_0x84be('0xd'));var jsforce=require(_0x84be('0xe'));var deskjs=require('desk.js');var toCsv=require(_0x84be('0x9'));var querystring=require(_0x84be('0xf'));var Papa=require('papaparse');var Redis=require(_0x84be('0x10'));var authService=require(_0x84be('0x11'));var qs=require(_0x84be('0x12'));var as=require(_0x84be('0x13'));var hardwareService=require('../../config/license/hardware');var logger=require(_0x84be('0x14'))(_0x84be('0x15'));var utils=require(_0x84be('0x16'));var config=require('../../config/environment');var licenseUtil=require(_0x84be('0x17'));var db=require('../../mysqldb')['db'];config[_0x84be('0x18')]=_[_0x84be('0x19')](config[_0x84be('0x18')],{'host':_0x84be('0x1a'),'port':0x18eb});var socket=require('socket.io-emitter')(new Redis(config['redis']));require('./mailQueue.socket')[_0x84be('0x1b')](socket);function respondWithStatusCode(_0x3d84af,_0x22d557){_0x22d557=_0x22d557||0xcc;return function(_0x87aa41){if(_0x87aa41){return _0x3d84af['sendStatus'](_0x22d557);}return _0x3d84af[_0x84be('0x1c')](_0x22d557)[_0x84be('0x1d')]();};}function respondWithResult(_0x2e4d55,_0x982ebd){_0x982ebd=_0x982ebd||0xc8;return function(_0x3c965d){if(_0x3c965d){return _0x2e4d55[_0x84be('0x1c')](_0x982ebd)[_0x84be('0x1e')](_0x3c965d);}};}function respondWithFilteredResult(_0x546e08,_0x5d0916){return function(_0x1854c4){if(_0x1854c4){var _0x56abf7=typeof _0x5d0916[_0x84be('0x1f')]==='undefined'&&typeof _0x5d0916[_0x84be('0x20')]==='undefined';var _0x4292ef=_0x1854c4[_0x84be('0x21')];var _0x2f2ee0=_0x56abf7?0x0:_0x5d0916[_0x84be('0x1f')];var _0x139c13=_0x56abf7?_0x1854c4[_0x84be('0x21')]:_0x5d0916['offset']+_0x5d0916['limit'];var _0x457223;if(_0x139c13>=_0x4292ef){_0x139c13=_0x4292ef;_0x457223=0xc8;}else{_0x457223=0xce;}_0x546e08[_0x84be('0x1c')](_0x457223);return _0x546e08['set'](_0x84be('0x22'),_0x2f2ee0+'-'+_0x139c13+'/'+_0x4292ef)['json'](_0x1854c4);}return null;};}function patchUpdates(_0x4b19fa){return function(_0x6f7ce){try{jsonpatch[_0x84be('0x23')](_0x6f7ce,_0x4b19fa,!![]);}catch(_0x2915a5){return BPromise[_0x84be('0x24')](_0x2915a5);}return _0x6f7ce[_0x84be('0x25')]();};}function saveUpdates(_0x486a3c,_0x135f95){return function(_0x265ed6){if(_0x265ed6){return _0x265ed6[_0x84be('0x26')](_0x486a3c)[_0x84be('0x27')](function(_0x3f664e){return _0x3f664e;});}return null;};}function removeEntity(_0x252fe8,_0x5691fe){return function(_0x1c5e0f){if(_0x1c5e0f){return _0x1c5e0f[_0x84be('0x28')]()[_0x84be('0x27')](function(){var _0x588ecb=_0x1c5e0f['get']({'plain':!![]});var _0x3bfe2=_0x84be('0x29');return db[_0x84be('0x2a')]['destroy']({'where':{'type':_0x3bfe2,'resourceId':_0x588ecb['id']}})[_0x84be('0x27')](function(){return _0x1c5e0f;});})[_0x84be('0x27')](function(){_0x252fe8[_0x84be('0x1c')](0xcc)[_0x84be('0x1d')]();});}};}function handleEntityNotFound(_0x5329bb,_0x34db0e){return function(_0x209bc6){if(!_0x209bc6){_0x5329bb['sendStatus'](0x194);}return _0x209bc6;};}function handleError(_0x220f00,_0x4ef656){_0x4ef656=_0x4ef656||0x1f4;return function(_0x67943b){logger[_0x84be('0x2b')](_0x67943b[_0x84be('0x2c')]);if(_0x67943b['name']){delete _0x67943b[_0x84be('0x2d')];}_0x220f00[_0x84be('0x1c')](_0x4ef656)['send'](_0x67943b);};}exports[_0x84be('0x2e')]=function(_0x327f23,_0x55b691){var _0x1e7438={},_0x4233d3={},_0x63abfa={'count':0x0,'rows':[]};var _0x38a7a8=_[_0x84be('0x2f')](db[_0x84be('0x30')][_0x84be('0x31')],function(_0x37cc12){return{'name':_0x37cc12[_0x84be('0x32')],'type':_0x37cc12[_0x84be('0x33')][_0x84be('0x34')]};});_0x4233d3[_0x84be('0x35')]=_[_0x84be('0x2f')](_0x38a7a8,_0x84be('0x2d'));_0x4233d3[_0x84be('0x36')]=_[_0x84be('0x37')](_0x327f23[_0x84be('0x36')]);_0x4233d3[_0x84be('0x38')]=_[_0x84be('0x39')](_0x4233d3[_0x84be('0x35')],_0x4233d3[_0x84be('0x36')]);_0x1e7438[_0x84be('0x3a')]=_[_0x84be('0x39')](_0x4233d3[_0x84be('0x35')],qs[_0x84be('0x3b')](_0x327f23[_0x84be('0x36')]['fields']));_0x1e7438[_0x84be('0x3a')]=_0x1e7438[_0x84be('0x3a')][_0x84be('0x3c')]?_0x1e7438[_0x84be('0x3a')]:_0x4233d3['model'];if(!_0x327f23[_0x84be('0x36')]['hasOwnProperty']('nolimit')){_0x1e7438[_0x84be('0x20')]=qs[_0x84be('0x20')](_0x327f23[_0x84be('0x36')]['limit']);_0x1e7438[_0x84be('0x1f')]=qs[_0x84be('0x1f')](_0x327f23[_0x84be('0x36')]['offset']);}_0x1e7438['order']=qs[_0x84be('0x3d')](_0x327f23[_0x84be('0x36')][_0x84be('0x3d')]);_0x1e7438[_0x84be('0x3e')]=qs[_0x84be('0x38')](_[_0x84be('0x3f')](_0x327f23['query'],_0x4233d3[_0x84be('0x38')]),_0x38a7a8);if(_0x327f23['query'][_0x84be('0x40')]){_0x1e7438[_0x84be('0x3e')]=_[_0x84be('0x41')](_0x1e7438['where'],{'$or':_[_0x84be('0x2f')](_0x38a7a8,function(_0x4b7bb1){if(_0x4b7bb1['type']!==_0x84be('0x42')){var _0x4189c9={};_0x4189c9[_0x4b7bb1['name']]={'$like':'%'+_0x327f23[_0x84be('0x36')][_0x84be('0x40')]+'%'};return _0x4189c9;}})});}_0x1e7438=_[_0x84be('0x41')]({},_0x1e7438,_0x327f23['options']);var _0x5f3000={'where':_0x1e7438['where']};return db['MailQueue'][_0x84be('0x21')](_0x5f3000)[_0x84be('0x27')](function(_0x407b9d){_0x63abfa[_0x84be('0x21')]=_0x407b9d;if(_0x327f23['query'][_0x84be('0x43')]){_0x1e7438[_0x84be('0x44')]=[{'all':!![]}];}return db[_0x84be('0x30')][_0x84be('0x45')](_0x1e7438);})[_0x84be('0x27')](function(_0x2d3596){_0x63abfa[_0x84be('0x46')]=_0x2d3596;return _0x63abfa;})[_0x84be('0x27')](respondWithFilteredResult(_0x55b691,_0x1e7438))['catch'](handleError(_0x55b691,null));};exports[_0x84be('0x47')]=function(_0x11f028,_0x372bae){var _0x38bbac={'raw':!![],'where':{'id':_0x11f028[_0x84be('0x48')]['id']}},_0x291b83={};_0x291b83['model']=_[_0x84be('0x37')](db['MailQueue'][_0x84be('0x31')]);_0x291b83[_0x84be('0x36')]=_['keys'](_0x11f028[_0x84be('0x36')]);_0x291b83[_0x84be('0x38')]=_[_0x84be('0x39')](_0x291b83[_0x84be('0x35')],_0x291b83[_0x84be('0x36')]);_0x38bbac[_0x84be('0x3a')]=_[_0x84be('0x39')](_0x291b83[_0x84be('0x35')],qs['fields'](_0x11f028[_0x84be('0x36')]['fields']));_0x38bbac['attributes']=_0x38bbac[_0x84be('0x3a')]['length']?_0x38bbac['attributes']:_0x291b83[_0x84be('0x35')];if(_0x11f028['query']['includeAll']){_0x38bbac[_0x84be('0x44')]=[{'all':!![]}];}_0x38bbac=_[_0x84be('0x41')]({},_0x38bbac,_0x11f028['options']);return db[_0x84be('0x30')][_0x84be('0x49')](_0x38bbac)[_0x84be('0x27')](handleEntityNotFound(_0x372bae,null))['then'](respondWithResult(_0x372bae,null))[_0x84be('0x4a')](handleError(_0x372bae,null));};exports[_0x84be('0x4b')]=function(_0x2929c1,_0x2d4790){return db[_0x84be('0x30')][_0x84be('0x4b')](_0x2929c1[_0x84be('0x4c')],{})[_0x84be('0x27')](function(_0x380eca){var _0x17099b=_0x2929c1[_0x84be('0x4d')]['get']({'plain':!![]});if(!_0x17099b)throw new Error('Unable\x20to\x20retrieve\x20the\x20current\x20user');if(_0x17099b[_0x84be('0x4e')]===_0x84be('0x4d')){var _0x1678a8=_0x380eca[_0x84be('0x4f')]({'plain':!![]});var _0xcea41=_0x84be('0x29');return db[_0x84be('0x50')][_0x84be('0x49')]({'where':{'name':_0xcea41,'userProfileId':_0x17099b[_0x84be('0x51')]},'raw':!![]})[_0x84be('0x27')](function(_0x432f9c){if(_0x432f9c&&_0x432f9c['autoAssociation']===0x0){return db[_0x84be('0x2a')][_0x84be('0x4b')]({'name':_0x1678a8['name'],'resourceId':_0x1678a8['id'],'type':_0x432f9c[_0x84be('0x2d')],'sectionId':_0x432f9c['id']},{})[_0x84be('0x27')](function(){return _0x380eca;});}else{return _0x380eca;}})[_0x84be('0x4a')](function(_0x4e477a){logger[_0x84be('0x2b')](_0x84be('0x52'),_0x4e477a);throw _0x4e477a;});}return _0x380eca;})[_0x84be('0x27')](respondWithResult(_0x2d4790,0xc9))['catch'](handleError(_0x2d4790,null));};exports[_0x84be('0x26')]=function(_0x180e3c,_0x40d892){if(_0x180e3c[_0x84be('0x4c')]['id']){delete _0x180e3c[_0x84be('0x4c')]['id'];}return db[_0x84be('0x30')][_0x84be('0x49')]({'where':{'id':_0x180e3c[_0x84be('0x48')]['id']}})['then'](handleEntityNotFound(_0x40d892,null))[_0x84be('0x27')](saveUpdates(_0x180e3c[_0x84be('0x4c')],null))[_0x84be('0x27')](respondWithResult(_0x40d892,null))[_0x84be('0x4a')](handleError(_0x40d892,null));};exports[_0x84be('0x28')]=function(_0x4db266,_0x480b0b){return db['MailQueue'][_0x84be('0x49')]({'where':{'id':_0x4db266['params']['id']}})[_0x84be('0x27')](handleEntityNotFound(_0x480b0b,null))['then'](removeEntity(_0x480b0b,null))['catch'](handleError(_0x480b0b,null));};exports[_0x84be('0x53')]=function(_0x43b55c,_0x572064){return db[_0x84be('0x30')][_0x84be('0x53')]()[_0x84be('0x27')](respondWithResult(_0x572064,null))['catch'](handleError(_0x572064,null));};exports['getMembers']=function(_0x22f2a5,_0x48ddec,_0x3edfe8){var _0x2db5fe={'raw':!![],'where':{}},_0x337ede={},_0x3046ad;return db[_0x84be('0x30')][_0x84be('0x54')]({'where':{'id':_0x22f2a5[_0x84be('0x48')]['id']}})[_0x84be('0x27')](handleEntityNotFound(_0x48ddec,null))[_0x84be('0x27')](function(_0x39e648){if(_0x39e648){_0x3046ad=_0x39e648[_0x84be('0x4f')]({'plain':!![]});_0x337ede[_0x84be('0x35')]=_['keys'](db['UserMailQueue']['rawAttributes']);_0x337ede['query']=_[_0x84be('0x37')](_0x22f2a5[_0x84be('0x36')]);_0x337ede[_0x84be('0x38')]=_['intersection'](_0x337ede[_0x84be('0x35')],_0x337ede[_0x84be('0x36')]);_0x2db5fe[_0x84be('0x3a')]=_[_0x84be('0x39')](_0x337ede[_0x84be('0x35')],qs[_0x84be('0x3b')](_0x22f2a5[_0x84be('0x36')][_0x84be('0x3b')]));_0x2db5fe[_0x84be('0x3a')]=_0x2db5fe[_0x84be('0x3a')]['length']?_0x2db5fe[_0x84be('0x3a')]:_0x337ede['model'];if(!_0x22f2a5['query']['hasOwnProperty']('nolimit')){_0x2db5fe[_0x84be('0x20')]=qs[_0x84be('0x20')](_0x22f2a5[_0x84be('0x36')][_0x84be('0x20')]);_0x2db5fe[_0x84be('0x1f')]=qs[_0x84be('0x1f')](_0x22f2a5[_0x84be('0x36')]['offset']);}_0x2db5fe[_0x84be('0x55')]=qs[_0x84be('0x3d')](_0x22f2a5[_0x84be('0x36')]['sort']);_0x2db5fe[_0x84be('0x3e')]=qs['filters'](_[_0x84be('0x3f')](_0x22f2a5[_0x84be('0x36')],_0x337ede[_0x84be('0x38')]));_0x2db5fe['where'][_0x84be('0x56')]=_0x39e648['id'];if(_0x22f2a5[_0x84be('0x36')]['filter']){_0x2db5fe['where']=_[_0x84be('0x41')](_0x2db5fe['where'],{'$or':_[_0x84be('0x2f')](_0x2db5fe[_0x84be('0x3a')],function(_0x2d6d99){var _0x345cb7={};_0x345cb7[_0x2d6d99]={'$like':'%'+_0x22f2a5[_0x84be('0x36')][_0x84be('0x40')]+'%'};return _0x345cb7;})});}_0x2db5fe=_[_0x84be('0x41')]({},_0x2db5fe,_0x22f2a5['options']);return db[_0x84be('0x57')][_0x84be('0x45')](_0x2db5fe);}})[_0x84be('0x27')](function(_0x5d3e94){if(_0x5d3e94){return db[_0x84be('0x58')]['findAndCountAll']({'where':{'id':_[_0x84be('0x2f')](_0x5d3e94,_0x84be('0x59')),'role':'agent'},'attributes':['id',_0x84be('0x2d'),_0x84be('0x5a'),_0x84be('0x5b'),'createdAt']});}})[_0x84be('0x27')](function(_0x1a14b5){if(_0x1a14b5){return{'count':_0x1a14b5['count'],'rows':_['map'](_0x1a14b5[_0x84be('0x46')],function(_0x28357d){return{'membername':_0x28357d[_0x84be('0x2d')],'UserId':_0x28357d['id'],'queue_name':_0x3046ad[_0x84be('0x2d')],'MailQueueId':_0x3046ad['id'],'interface':util[_0x84be('0x5c')](_0x84be('0x5d'),_0x84be('0x5e'),_0x28357d[_0x84be('0x2d')]),'penalty':0x0,'paused':_0x28357d[_0x84be('0x5a')],'createdAt':_0x28357d[_0x84be('0x5f')],'updatedAt':_0x28357d[_0x84be('0x5b')]};})};}else{return{'count':0x0,'rows':[]};}})[_0x84be('0x27')](respondWithFilteredResult(_0x48ddec,_0x2db5fe))['catch'](handleError(_0x48ddec,null));};exports[_0x84be('0x60')]=function(_0xd3f518,_0x23c60c,_0x38c800){var _0x12149f={};var _0x6e6022={};var _0x1ad1c5;var _0x3e41dc;return db[_0x84be('0x30')][_0x84be('0x54')]({'where':{'id':_0xd3f518[_0x84be('0x48')]['id']}})[_0x84be('0x27')](handleEntityNotFound(_0x23c60c,null))[_0x84be('0x27')](function(_0x2085de){if(_0x2085de){_0x1ad1c5=_0x2085de;_0x6e6022[_0x84be('0x35')]=_[_0x84be('0x37')](db[_0x84be('0x61')][_0x84be('0x31')]);_0x6e6022[_0x84be('0x36')]=_['keys'](_0xd3f518[_0x84be('0x36')]);_0x6e6022[_0x84be('0x38')]=_[_0x84be('0x39')](_0x6e6022['model'],_0x6e6022[_0x84be('0x36')]);_0x12149f[_0x84be('0x3a')]=_[_0x84be('0x39')](_0x6e6022['model'],qs[_0x84be('0x3b')](_0xd3f518[_0x84be('0x36')]['fields']));_0x12149f[_0x84be('0x3a')]=_0x12149f[_0x84be('0x3a')]['length']?_0x12149f[_0x84be('0x3a')]:_0x6e6022[_0x84be('0x35')];_0x12149f[_0x84be('0x55')]=qs[_0x84be('0x3d')](_0xd3f518[_0x84be('0x36')][_0x84be('0x3d')]);_0x12149f[_0x84be('0x3e')]=qs[_0x84be('0x38')](_[_0x84be('0x3f')](_0xd3f518[_0x84be('0x36')],_0x6e6022[_0x84be('0x38')]));if(_0xd3f518[_0x84be('0x36')][_0x84be('0x40')]){_0x12149f[_0x84be('0x3e')]=_['merge'](_0x12149f[_0x84be('0x3e')],{'$or':_[_0x84be('0x2f')](_0x12149f[_0x84be('0x3a')],function(_0x57c7f0){var _0xab027={};_0xab027[_0x57c7f0]={'$like':'%'+_0xd3f518[_0x84be('0x36')]['filter']+'%'};return _0xab027;})});}_0x12149f=_[_0x84be('0x41')]({},_0x12149f,_0xd3f518[_0x84be('0x62')]);return _0x1ad1c5[_0x84be('0x60')](_0x12149f);}})['then'](function(_0x121d24){if(_0x121d24){_0x3e41dc=_0x121d24[_0x84be('0x3c')];if(!_0xd3f518[_0x84be('0x36')][_0x84be('0x63')](_0x84be('0x64'))){_0x12149f[_0x84be('0x20')]=qs[_0x84be('0x20')](_0xd3f518['query'][_0x84be('0x20')]);_0x12149f[_0x84be('0x1f')]=qs[_0x84be('0x1f')](_0xd3f518[_0x84be('0x36')][_0x84be('0x1f')]);}return _0x1ad1c5['getTeams'](_0x12149f);}})[_0x84be('0x27')](function(_0x473198){if(_0x473198){return _0x473198?{'count':_0x3e41dc,'rows':_0x473198}:null;}})[_0x84be('0x27')](respondWithResult(_0x23c60c,null))[_0x84be('0x4a')](handleError(_0x23c60c,null));};exports[_0x84be('0x65')]=function(_0x36fb49,_0x4e2e2c,_0x38cfcd){var _0x56c635=_0x36fb49[_0x84be('0x4c')]['ids'];return db[_0x84be('0x61')][_0x84be('0x45')]({'where':{'id':_0x56c635},'attributes':['id'],'include':[{'model':db[_0x84be('0x58')],'as':_0x84be('0x66'),'attributes':['id',_0x84be('0x2d'),'online',_0x84be('0x67'),_0x84be('0x68')],'raw':!![]}]})[_0x84be('0x27')](function(_0x1fdc59){if(_0x1fdc59){var _0x3e4c9e=_['flatMap'](_0x1fdc59,function(_0x23f210){var _0x42f675=_0x23f210['get']({'plain':!![]});return _0x42f675[_0x84be('0x66')];});return db[_0x84be('0x30')][_0x84be('0x49')]({'where':{'id':_0x36fb49[_0x84be('0x48')]['id']}})[_0x84be('0x27')](function(_0x23da53){return db[_0x84be('0x69')][_0x84be('0x6a')](function(_0x359a51){return _0x23da53[_0x84be('0x65')](_0x56c635,{'transaction':_0x359a51})['then'](function(){return BPromise[_0x84be('0x6b')](_0x3e4c9e,function(_0x28558e){return db[_0x84be('0x57')][_0x84be('0x6c')]({'where':{'UserId':_0x28558e['id'],'MailQueueId':_0x36fb49['params']['id']},'transaction':_0x359a51});});})[_0x84be('0x27')](function(){_0x3e4c9e[_0x84be('0x6d')](function(_0x58c04d){socket[_0x84be('0x6e')](_0x84be('0x6f'),{'UserId':_0x58c04d['id'],'MailQueueId':_0x23da53['id']});});});});});}})['then'](respondWithStatusCode(_0x4e2e2c,null))[_0x84be('0x4a')](handleError(_0x4e2e2c,null));};exports[_0x84be('0x70')]=function(_0x12b02e,_0x2651ae,_0x5d6f5c){return db[_0x84be('0x61')][_0x84be('0x45')]({'where':{'id':_0x12b02e['query']['ids']},'attributes':['id'],'include':[{'model':db[_0x84be('0x58')],'as':_0x84be('0x66'),'attributes':['id'],'raw':!![]}]})[_0x84be('0x27')](handleEntityNotFound(_0x2651ae,null))[_0x84be('0x27')](function(_0x4c1bf5){var _0x4ca686=_[_0x84be('0x2f')](_0x4c1bf5,'id');var _0x3f02c9=[];var _0x105bc5=[];var _0x1881f0=squel[_0x84be('0x71')]();_0x1881f0[_0x84be('0x72')](_0x84be('0x73'))[_0x84be('0x74')](_0x84be('0x75'),'tq')[_0x84be('0x76')](_0x84be('0x77'),'ut',_0x84be('0x78'))['where'](_0x84be('0x79'),_0x12b02e[_0x84be('0x48')]['id']);for(var _0x4796e7=0x0;_0x4796e7<_0x4c1bf5[_0x84be('0x3c')];_0x4796e7+=0x1){let _0x572813=_0x4c1bf5[_0x4796e7];for(var _0x22d5cd=0x0;_0x22d5cd<_0x572813[_0x84be('0x66')][_0x84be('0x3c')];_0x22d5cd+=0x1){let _0x974894=_0x572813['Agents'][_0x22d5cd];var _0x1631fa=_0x1881f0[_0x84be('0x7a')]();_0x1631fa[_0x84be('0x3e')]('ut.UserId\x20=\x20?',_0x974894['id']);_0x105bc5[_0x84be('0x7b')](db[_0x84be('0x69')][_0x84be('0x36')](_0x1631fa[_0x84be('0x7c')](),{'type':db[_0x84be('0x69')][_0x84be('0x7d')][_0x84be('0x7e')]})[_0x84be('0x27')](function(_0x2a1837){if(_0x2a1837[_0x84be('0x3c')]===0x1){return _0x974894['id'];}else{var _0x59245b=_['every'](_[_0x84be('0x2f')](_0x2a1837,_0x84be('0x7f')),function(_0x56656e){return _['includes'](_0x4ca686,_0x56656e);});if(_0x59245b){return _0x974894['id'];}}}));}}return BPromise['all'](_0x105bc5)['then'](function(_0x29ff7c){_0x3f02c9=_(_0x3f02c9)[_0x84be('0x80')](_0x29ff7c)[_0x84be('0x81')]()[_0x84be('0x82')]();return db[_0x84be('0x30')][_0x84be('0x49')]({'where':{'id':_0x12b02e['params']['id']}})[_0x84be('0x27')](function(_0x481cbe){return db['sequelize'][_0x84be('0x6a')](function(_0xfdf1a5){return _0x481cbe[_0x84be('0x70')](_0x12b02e[_0x84be('0x36')][_0x84be('0x83')],{'transaction':_0xfdf1a5})['then'](function(){if(!_[_0x84be('0x84')](_0x3f02c9)){return _0x481cbe['removeAgents'](_0x3f02c9,{'transaction':_0xfdf1a5});}})[_0x84be('0x27')](function(){_0x3f02c9[_0x84be('0x6d')](function(_0x3aff5a){socket[_0x84be('0x6e')](_0x84be('0x85'),{'UserId':_0x3aff5a,'MailQueueId':_0x481cbe['id']});});});});});});})[_0x84be('0x27')](respondWithStatusCode(_0x2651ae,null))[_0x84be('0x4a')](handleError(_0x2651ae,null));};exports[_0x84be('0x86')]=function(_0xd52f31,_0x2ac090,_0x50b25b){return db[_0x84be('0x30')]['find']({'where':{'id':_0xd52f31[_0x84be('0x48')]['id']}})[_0x84be('0x27')](handleEntityNotFound(_0x2ac090,null))[_0x84be('0x27')](function(_0xd94c26){if(_0xd94c26){return _0xd94c26[_0x84be('0x86')](_0xd52f31[_0x84be('0x4c')][_0x84be('0x83')],_['omit'](_0xd52f31[_0x84be('0x4c')],['ids','id'])||{})['spread'](function(_0x72b707){for(var _0x36b29f=0x0;_0x36b29f<_0xd52f31[_0x84be('0x4c')][_0x84be('0x83')][_0x84be('0x3c')];_0x36b29f+=0x1){socket[_0x84be('0x6e')](_0x84be('0x6f'),{'UserId':Number(_0xd52f31[_0x84be('0x4c')][_0x84be('0x83')][_0x36b29f]),'MailQueueId':Number(_0xd52f31['params']['id'])});}return _0x72b707;});}})[_0x84be('0x27')](respondWithResult(_0x2ac090,null))['catch'](handleError(_0x2ac090,null));};exports[_0x84be('0x87')]=function(_0x39f764,_0x1e7391,_0x56b9e6){return db[_0x84be('0x30')][_0x84be('0x49')]({'where':{'id':_0x39f764[_0x84be('0x48')]['id']}})[_0x84be('0x27')](handleEntityNotFound(_0x1e7391,null))[_0x84be('0x27')](function(_0xc312c4){if(_0xc312c4){return _0xc312c4[_0x84be('0x87')](_0x39f764[_0x84be('0x36')][_0x84be('0x83')])[_0x84be('0x27')](function(){if(_[_0x84be('0x88')](_0x39f764[_0x84be('0x36')][_0x84be('0x83')])){for(var _0x4b3576=0x0;_0x4b3576<_0x39f764[_0x84be('0x36')][_0x84be('0x83')][_0x84be('0x3c')];_0x4b3576+=0x1){socket[_0x84be('0x6e')](_0x84be('0x85'),{'UserId':Number(_0x39f764[_0x84be('0x36')][_0x84be('0x83')][_0x4b3576]),'MailQueueId':Number(_0x39f764[_0x84be('0x48')]['id'])});}}else{socket['emit'](_0x84be('0x85'),{'UserId':Number(_0x39f764['query'][_0x84be('0x83')]),'MailQueueId':Number(_0x39f764[_0x84be('0x48')]['id'])});}});}})[_0x84be('0x27')](respondWithStatusCode(_0x1e7391,null))[_0x84be('0x4a')](handleError(_0x1e7391,null));};exports[_0x84be('0x89')]=function(_0x3e08ed,_0x512324,_0x567b42){var _0x4eb12e={};var _0x403f66={};var _0x5328af;var _0xad6b3c;return db[_0x84be('0x30')][_0x84be('0x54')]({'where':{'id':_0x3e08ed[_0x84be('0x48')]['id']}})[_0x84be('0x27')](handleEntityNotFound(_0x512324,null))[_0x84be('0x27')](function(_0x167541){if(_0x167541){_0x5328af=_0x167541;_0x403f66[_0x84be('0x35')]=_[_0x84be('0x37')](db[_0x84be('0x58')][_0x84be('0x31')]);_0x403f66[_0x84be('0x36')]=_[_0x84be('0x37')](_0x3e08ed[_0x84be('0x36')]);_0x403f66[_0x84be('0x38')]=_[_0x84be('0x39')](_0x403f66[_0x84be('0x35')],_0x403f66[_0x84be('0x36')]);_0x4eb12e[_0x84be('0x3a')]=_[_0x84be('0x39')](_0x403f66[_0x84be('0x35')],qs[_0x84be('0x3b')](_0x3e08ed[_0x84be('0x36')][_0x84be('0x3b')]));_0x4eb12e[_0x84be('0x3a')]=_0x4eb12e['attributes'][_0x84be('0x3c')]?_0x4eb12e[_0x84be('0x3a')]:_0x403f66[_0x84be('0x35')];_0x4eb12e[_0x84be('0x55')]=qs['sort'](_0x3e08ed[_0x84be('0x36')]['sort']);_0x4eb12e[_0x84be('0x3e')]=qs[_0x84be('0x38')](_[_0x84be('0x3f')](_0x3e08ed[_0x84be('0x36')],_0x403f66[_0x84be('0x38')]));if(_0x3e08ed[_0x84be('0x36')][_0x84be('0x40')]){_0x4eb12e[_0x84be('0x3e')]=_['merge'](_0x4eb12e[_0x84be('0x3e')],{'$or':_[_0x84be('0x2f')](_0x4eb12e[_0x84be('0x3a')],function(_0x29183f){var _0x46bac0={};_0x46bac0[_0x29183f]={'$like':'%'+_0x3e08ed['query'][_0x84be('0x40')]+'%'};return _0x46bac0;})});}_0x4eb12e=_[_0x84be('0x41')]({},_0x4eb12e,_0x3e08ed['options']);return _0x5328af[_0x84be('0x89')](_0x4eb12e);}})[_0x84be('0x27')](function(_0x182082){if(_0x182082){_0xad6b3c=_0x182082['length'];if(!_0x3e08ed[_0x84be('0x36')][_0x84be('0x63')]('nolimit')){_0x4eb12e['limit']=qs[_0x84be('0x20')](_0x3e08ed[_0x84be('0x36')][_0x84be('0x20')]);_0x4eb12e['offset']=qs[_0x84be('0x1f')](_0x3e08ed[_0x84be('0x36')][_0x84be('0x1f')]);}return _0x5328af[_0x84be('0x89')](_0x4eb12e);}})['then'](function(_0x4bd21b){if(_0x4bd21b){return _0x4bd21b?{'count':_0xad6b3c,'rows':_0x4bd21b}:null;}})[_0x84be('0x27')](respondWithResult(_0x512324,null))[_0x84be('0x4a')](handleError(_0x512324,null));};