Built motion from commit 9d0783e6.|2.6.13
[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 _0xf60a=['name','send','index','map','MailQueue','type','model','query','keys','intersection','attributes','fields','length','hasOwnProperty','order','sort','where','filters','filter','merge','VIRTUAL','includeAll','include','findAll','catch','show','rawAttributes','options','find','create','body','role','user','UserProfileSection','error','params','describe','pick','MailQueueId','UserMailQueue','User','findAndCountAll','UserId','agent','mailPause','updatedAt','createdAt','rows','%s/%s','SIP','getTeams','Team','ids','Agents','online','interface','flatMap','sequelize','transaction','addTeams','findOrCreate','forEach','userMailQueue:save','removeTeams','select','tq.TeamId','team_has_mail_queues','join','user_has_teams','ut.TeamId\x20=\x20tq.TeamId','clone','push','toString','QueryTypes','every','TeamId','includes','union','compact','value','isEmpty','removeAgents','emit','userMailQueue:remove','addAgents','omit','spread','isArray','getAgents','nolimit','rimraf','zip-dir','fast-json-patch','request-promise','bluebird','util','to-csv','ejs','fs-extra','lodash','squel','crypto','jsforce','papaparse','ioredis','../../components/parsers/qs','api','../../config/utils','../../config/environment','../../config/license/util','../../mysqldb','redis','defaults','localhost','socket.io-emitter','./mailQueue.socket','register','sendStatus','status','end','json','offset','undefined','count','limit','set','save','update','then','destroy','get','MailQueues','UserProfileResource','stack'];(function(_0x27cddc,_0x57780a){var _0x2aa574=function(_0x42cd6a){while(--_0x42cd6a){_0x27cddc['push'](_0x27cddc['shift']());}};_0x2aa574(++_0x57780a);}(_0xf60a,0x166));var _0xaf60=function(_0x26d1f4,_0x2142b7){_0x26d1f4=_0x26d1f4-0x0;var _0x4bc350=_0xf60a[_0x26d1f4];return _0x4bc350;};'use strict';var emlformat=require('eml-format');var rimraf=require(_0xaf60('0x0'));var zipdir=require(_0xaf60('0x1'));var jsonpatch=require(_0xaf60('0x2'));var rp=require(_0xaf60('0x3'));var moment=require('moment');var BPromise=require(_0xaf60('0x4'));var Mustache=require('mustache');var util=require(_0xaf60('0x5'));var path=require('path');var sox=require('sox');var csv=require(_0xaf60('0x6'));var ejs=require(_0xaf60('0x7'));var fs=require('fs');var fs_extra=require(_0xaf60('0x8'));var _=require(_0xaf60('0x9'));var squel=require(_0xaf60('0xa'));var crypto=require(_0xaf60('0xb'));var jsforce=require(_0xaf60('0xc'));var deskjs=require('desk.js');var toCsv=require(_0xaf60('0x6'));var querystring=require('querystring');var Papa=require(_0xaf60('0xd'));var Redis=require(_0xaf60('0xe'));var authService=require('../../components/auth/service');var qs=require(_0xaf60('0xf'));var as=require('../../components/parsers/advancedSearch');var hardwareService=require('../../config/license/hardware');var logger=require('../../config/logger')(_0xaf60('0x10'));var utils=require(_0xaf60('0x11'));var config=require(_0xaf60('0x12'));var licenseUtil=require(_0xaf60('0x13'));var db=require(_0xaf60('0x14'))['db'];config[_0xaf60('0x15')]=_[_0xaf60('0x16')](config[_0xaf60('0x15')],{'host':_0xaf60('0x17'),'port':0x18eb});var socket=require(_0xaf60('0x18'))(new Redis(config['redis']));require(_0xaf60('0x19'))[_0xaf60('0x1a')](socket);function respondWithStatusCode(_0x969b08,_0x5505e2){_0x5505e2=_0x5505e2||0xcc;return function(_0x5821f1){if(_0x5821f1){return _0x969b08[_0xaf60('0x1b')](_0x5505e2);}return _0x969b08[_0xaf60('0x1c')](_0x5505e2)[_0xaf60('0x1d')]();};}function respondWithResult(_0x38b582,_0x11de60){_0x11de60=_0x11de60||0xc8;return function(_0x26ea22){if(_0x26ea22){return _0x38b582[_0xaf60('0x1c')](_0x11de60)[_0xaf60('0x1e')](_0x26ea22);}};}function respondWithFilteredResult(_0x168be0,_0x28aff9){return function(_0x31a34f){if(_0x31a34f){var _0x55fe26=typeof _0x28aff9[_0xaf60('0x1f')]===_0xaf60('0x20')&&typeof _0x28aff9['limit']===_0xaf60('0x20');var _0x2d555b=_0x31a34f[_0xaf60('0x21')];var _0x25d8c4=_0x55fe26?0x0:_0x28aff9[_0xaf60('0x1f')];var _0x50f660=_0x55fe26?_0x31a34f[_0xaf60('0x21')]:_0x28aff9[_0xaf60('0x1f')]+_0x28aff9[_0xaf60('0x22')];var _0x536236;if(_0x50f660>=_0x2d555b){_0x50f660=_0x2d555b;_0x536236=0xc8;}else{_0x536236=0xce;}_0x168be0[_0xaf60('0x1c')](_0x536236);return _0x168be0[_0xaf60('0x23')]('Content-Range',_0x25d8c4+'-'+_0x50f660+'/'+_0x2d555b)['json'](_0x31a34f);}return null;};}function patchUpdates(_0x49ab65){return function(_0x5acf11){try{jsonpatch['apply'](_0x5acf11,_0x49ab65,!![]);}catch(_0x44b1f6){return BPromise['reject'](_0x44b1f6);}return _0x5acf11[_0xaf60('0x24')]();};}function saveUpdates(_0x598878,_0x215abe){return function(_0x2b048e){if(_0x2b048e){return _0x2b048e[_0xaf60('0x25')](_0x598878)[_0xaf60('0x26')](function(_0x168990){return _0x168990;});}return null;};}function removeEntity(_0x5797e0,_0x292469){return function(_0x39968a){if(_0x39968a){return _0x39968a[_0xaf60('0x27')]()['then'](function(){var _0x2cbdbd=_0x39968a[_0xaf60('0x28')]({'plain':!![]});var _0x2975a0=_0xaf60('0x29');return db[_0xaf60('0x2a')][_0xaf60('0x27')]({'where':{'type':_0x2975a0,'resourceId':_0x2cbdbd['id']}})[_0xaf60('0x26')](function(){return _0x39968a;});})[_0xaf60('0x26')](function(){_0x5797e0[_0xaf60('0x1c')](0xcc)['end']();});}};}function handleEntityNotFound(_0x59960a,_0x345e96){return function(_0x5a8db0){if(!_0x5a8db0){_0x59960a[_0xaf60('0x1b')](0x194);}return _0x5a8db0;};}function handleError(_0x57b5d6,_0x1a4698){_0x1a4698=_0x1a4698||0x1f4;return function(_0x2a404a){logger['error'](_0x2a404a[_0xaf60('0x2b')]);if(_0x2a404a[_0xaf60('0x2c')]){delete _0x2a404a[_0xaf60('0x2c')];}_0x57b5d6[_0xaf60('0x1c')](_0x1a4698)[_0xaf60('0x2d')](_0x2a404a);};}exports[_0xaf60('0x2e')]=function(_0x415476,_0x3e418c){var _0x4d91a1={},_0x4aba0d={},_0x4dea58={'count':0x0,'rows':[]};var _0x464b6f=_[_0xaf60('0x2f')](db[_0xaf60('0x30')]['rawAttributes'],function(_0x37603f){return{'name':_0x37603f['fieldName'],'type':_0x37603f[_0xaf60('0x31')]['key']};});_0x4aba0d[_0xaf60('0x32')]=_[_0xaf60('0x2f')](_0x464b6f,_0xaf60('0x2c'));_0x4aba0d[_0xaf60('0x33')]=_[_0xaf60('0x34')](_0x415476[_0xaf60('0x33')]);_0x4aba0d['filters']=_[_0xaf60('0x35')](_0x4aba0d[_0xaf60('0x32')],_0x4aba0d[_0xaf60('0x33')]);_0x4d91a1[_0xaf60('0x36')]=_[_0xaf60('0x35')](_0x4aba0d[_0xaf60('0x32')],qs[_0xaf60('0x37')](_0x415476[_0xaf60('0x33')][_0xaf60('0x37')]));_0x4d91a1[_0xaf60('0x36')]=_0x4d91a1[_0xaf60('0x36')][_0xaf60('0x38')]?_0x4d91a1[_0xaf60('0x36')]:_0x4aba0d[_0xaf60('0x32')];if(!_0x415476[_0xaf60('0x33')][_0xaf60('0x39')]('nolimit')){_0x4d91a1['limit']=qs[_0xaf60('0x22')](_0x415476[_0xaf60('0x33')]['limit']);_0x4d91a1[_0xaf60('0x1f')]=qs[_0xaf60('0x1f')](_0x415476[_0xaf60('0x33')][_0xaf60('0x1f')]);}_0x4d91a1[_0xaf60('0x3a')]=qs[_0xaf60('0x3b')](_0x415476[_0xaf60('0x33')][_0xaf60('0x3b')]);_0x4d91a1[_0xaf60('0x3c')]=qs[_0xaf60('0x3d')](_['pick'](_0x415476[_0xaf60('0x33')],_0x4aba0d[_0xaf60('0x3d')]),_0x464b6f);if(_0x415476[_0xaf60('0x33')][_0xaf60('0x3e')]){_0x4d91a1[_0xaf60('0x3c')]=_[_0xaf60('0x3f')](_0x4d91a1[_0xaf60('0x3c')],{'$or':_[_0xaf60('0x2f')](_0x464b6f,function(_0xe4eb46){if(_0xe4eb46[_0xaf60('0x31')]!==_0xaf60('0x40')){var _0x258ad9={};_0x258ad9[_0xe4eb46[_0xaf60('0x2c')]]={'$like':'%'+_0x415476['query'][_0xaf60('0x3e')]+'%'};return _0x258ad9;}})});}_0x4d91a1=_[_0xaf60('0x3f')]({},_0x4d91a1,_0x415476['options']);var _0x5ebb6d={'where':_0x4d91a1['where']};return db[_0xaf60('0x30')]['count'](_0x5ebb6d)[_0xaf60('0x26')](function(_0x22d34a){_0x4dea58['count']=_0x22d34a;if(_0x415476['query'][_0xaf60('0x41')]){_0x4d91a1[_0xaf60('0x42')]=[{'all':!![]}];}return db[_0xaf60('0x30')][_0xaf60('0x43')](_0x4d91a1);})[_0xaf60('0x26')](function(_0x488c32){_0x4dea58['rows']=_0x488c32;return _0x4dea58;})[_0xaf60('0x26')](respondWithFilteredResult(_0x3e418c,_0x4d91a1))[_0xaf60('0x44')](handleError(_0x3e418c,null));};exports[_0xaf60('0x45')]=function(_0x1bdf2b,_0xfbfeb){var _0x4fa6b2={'raw':!![],'where':{'id':_0x1bdf2b['params']['id']}},_0x2db568={};_0x2db568['model']=_[_0xaf60('0x34')](db[_0xaf60('0x30')][_0xaf60('0x46')]);_0x2db568[_0xaf60('0x33')]=_['keys'](_0x1bdf2b[_0xaf60('0x33')]);_0x2db568[_0xaf60('0x3d')]=_[_0xaf60('0x35')](_0x2db568[_0xaf60('0x32')],_0x2db568[_0xaf60('0x33')]);_0x4fa6b2[_0xaf60('0x36')]=_[_0xaf60('0x35')](_0x2db568[_0xaf60('0x32')],qs[_0xaf60('0x37')](_0x1bdf2b[_0xaf60('0x33')][_0xaf60('0x37')]));_0x4fa6b2[_0xaf60('0x36')]=_0x4fa6b2[_0xaf60('0x36')][_0xaf60('0x38')]?_0x4fa6b2[_0xaf60('0x36')]:_0x2db568[_0xaf60('0x32')];if(_0x1bdf2b[_0xaf60('0x33')]['includeAll']){_0x4fa6b2['include']=[{'all':!![]}];}_0x4fa6b2=_[_0xaf60('0x3f')]({},_0x4fa6b2,_0x1bdf2b[_0xaf60('0x47')]);return db[_0xaf60('0x30')][_0xaf60('0x48')](_0x4fa6b2)['then'](handleEntityNotFound(_0xfbfeb,null))['then'](respondWithResult(_0xfbfeb,null))[_0xaf60('0x44')](handleError(_0xfbfeb,null));};exports[_0xaf60('0x49')]=function(_0xea3ec0,_0x160c41){return db[_0xaf60('0x30')][_0xaf60('0x49')](_0xea3ec0[_0xaf60('0x4a')],{})[_0xaf60('0x26')](function(_0x538603){var _0x2b09ba=_0xea3ec0['user'][_0xaf60('0x28')]({'plain':!![]});if(!_0x2b09ba)throw new Error('Unable\x20to\x20retrieve\x20the\x20current\x20user');if(_0x2b09ba[_0xaf60('0x4b')]===_0xaf60('0x4c')){var _0x54c534=_0x538603['get']({'plain':!![]});var _0x26507e=_0xaf60('0x29');return db[_0xaf60('0x4d')]['find']({'where':{'name':_0x26507e,'userProfileId':_0x2b09ba['userProfileId']},'raw':!![]})['then'](function(_0x701bfe){if(_0x701bfe&&_0x701bfe['autoAssociation']===0x0){return db['UserProfileResource'][_0xaf60('0x49')]({'name':_0x54c534[_0xaf60('0x2c')],'resourceId':_0x54c534['id'],'type':_0x701bfe['name'],'sectionId':_0x701bfe['id']},{})['then'](function(){return _0x538603;});}else{return _0x538603;}})['catch'](function(_0x5be6fc){logger[_0xaf60('0x4e')]('Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s',_0x5be6fc);throw _0x5be6fc;});}return _0x538603;})['then'](respondWithResult(_0x160c41,0xc9))['catch'](handleError(_0x160c41,null));};exports[_0xaf60('0x25')]=function(_0x95380d,_0x311f49){if(_0x95380d[_0xaf60('0x4a')]['id']){delete _0x95380d['body']['id'];}return db['MailQueue'][_0xaf60('0x48')]({'where':{'id':_0x95380d[_0xaf60('0x4f')]['id']}})[_0xaf60('0x26')](handleEntityNotFound(_0x311f49,null))[_0xaf60('0x26')](saveUpdates(_0x95380d[_0xaf60('0x4a')],null))[_0xaf60('0x26')](respondWithResult(_0x311f49,null))[_0xaf60('0x44')](handleError(_0x311f49,null));};exports[_0xaf60('0x27')]=function(_0x591202,_0x138e38){return db[_0xaf60('0x30')][_0xaf60('0x48')]({'where':{'id':_0x591202[_0xaf60('0x4f')]['id']}})['then'](handleEntityNotFound(_0x138e38,null))[_0xaf60('0x26')](removeEntity(_0x138e38,null))[_0xaf60('0x44')](handleError(_0x138e38,null));};exports['describe']=function(_0x1defa1,_0x5b3808){return db[_0xaf60('0x30')][_0xaf60('0x50')]()['then'](respondWithResult(_0x5b3808,null))[_0xaf60('0x44')](handleError(_0x5b3808,null));};exports['getMembers']=function(_0x1c3df3,_0x551a8f,_0x557de0){var _0x347de1={'raw':!![],'where':{}},_0x4071de={},_0x2557e4;return db['MailQueue']['findOne']({'where':{'id':_0x1c3df3[_0xaf60('0x4f')]['id']}})['then'](handleEntityNotFound(_0x551a8f,null))[_0xaf60('0x26')](function(_0x2896c4){if(_0x2896c4){_0x2557e4=_0x2896c4[_0xaf60('0x28')]({'plain':!![]});_0x4071de[_0xaf60('0x32')]=_[_0xaf60('0x34')](db['UserMailQueue'][_0xaf60('0x46')]);_0x4071de[_0xaf60('0x33')]=_[_0xaf60('0x34')](_0x1c3df3[_0xaf60('0x33')]);_0x4071de[_0xaf60('0x3d')]=_[_0xaf60('0x35')](_0x4071de[_0xaf60('0x32')],_0x4071de[_0xaf60('0x33')]);_0x347de1[_0xaf60('0x36')]=_[_0xaf60('0x35')](_0x4071de['model'],qs[_0xaf60('0x37')](_0x1c3df3['query']['fields']));_0x347de1[_0xaf60('0x36')]=_0x347de1[_0xaf60('0x36')]['length']?_0x347de1[_0xaf60('0x36')]:_0x4071de[_0xaf60('0x32')];if(!_0x1c3df3[_0xaf60('0x33')]['hasOwnProperty']('nolimit')){_0x347de1[_0xaf60('0x22')]=qs['limit'](_0x1c3df3[_0xaf60('0x33')][_0xaf60('0x22')]);_0x347de1[_0xaf60('0x1f')]=qs[_0xaf60('0x1f')](_0x1c3df3['query']['offset']);}_0x347de1[_0xaf60('0x3a')]=qs[_0xaf60('0x3b')](_0x1c3df3['query'][_0xaf60('0x3b')]);_0x347de1[_0xaf60('0x3c')]=qs[_0xaf60('0x3d')](_[_0xaf60('0x51')](_0x1c3df3[_0xaf60('0x33')],_0x4071de[_0xaf60('0x3d')]));_0x347de1['where'][_0xaf60('0x52')]=_0x2896c4['id'];if(_0x1c3df3[_0xaf60('0x33')][_0xaf60('0x3e')]){_0x347de1['where']=_[_0xaf60('0x3f')](_0x347de1[_0xaf60('0x3c')],{'$or':_[_0xaf60('0x2f')](_0x347de1[_0xaf60('0x36')],function(_0x42a427){var _0x24637e={};_0x24637e[_0x42a427]={'$like':'%'+_0x1c3df3[_0xaf60('0x33')][_0xaf60('0x3e')]+'%'};return _0x24637e;})});}_0x347de1=_[_0xaf60('0x3f')]({},_0x347de1,_0x1c3df3[_0xaf60('0x47')]);return db[_0xaf60('0x53')][_0xaf60('0x43')](_0x347de1);}})[_0xaf60('0x26')](function(_0x2100b0){if(_0x2100b0){return db[_0xaf60('0x54')][_0xaf60('0x55')]({'where':{'id':_[_0xaf60('0x2f')](_0x2100b0,_0xaf60('0x56')),'role':_0xaf60('0x57')},'attributes':['id',_0xaf60('0x2c'),_0xaf60('0x58'),_0xaf60('0x59'),_0xaf60('0x5a')]});}})[_0xaf60('0x26')](function(_0x760be1){if(_0x760be1){return{'count':_0x760be1['count'],'rows':_[_0xaf60('0x2f')](_0x760be1[_0xaf60('0x5b')],function(_0x58bb0d){return{'membername':_0x58bb0d[_0xaf60('0x2c')],'UserId':_0x58bb0d['id'],'queue_name':_0x2557e4[_0xaf60('0x2c')],'MailQueueId':_0x2557e4['id'],'interface':util['format'](_0xaf60('0x5c'),_0xaf60('0x5d'),_0x58bb0d[_0xaf60('0x2c')]),'penalty':0x0,'paused':_0x58bb0d[_0xaf60('0x58')],'createdAt':_0x58bb0d[_0xaf60('0x5a')],'updatedAt':_0x58bb0d[_0xaf60('0x59')]};})};}else{return{'count':0x0,'rows':[]};}})[_0xaf60('0x26')](respondWithFilteredResult(_0x551a8f,_0x347de1))['catch'](handleError(_0x551a8f,null));};exports[_0xaf60('0x5e')]=function(_0x8ec3bf,_0x16d89a,_0xf00280){var _0x27244c={};var _0x58f9f9={};var _0x291228;var _0x401a84;return db[_0xaf60('0x30')]['findOne']({'where':{'id':_0x8ec3bf['params']['id']}})[_0xaf60('0x26')](handleEntityNotFound(_0x16d89a,null))['then'](function(_0x4d5bc1){if(_0x4d5bc1){_0x291228=_0x4d5bc1;_0x58f9f9[_0xaf60('0x32')]=_[_0xaf60('0x34')](db[_0xaf60('0x5f')][_0xaf60('0x46')]);_0x58f9f9[_0xaf60('0x33')]=_['keys'](_0x8ec3bf[_0xaf60('0x33')]);_0x58f9f9[_0xaf60('0x3d')]=_[_0xaf60('0x35')](_0x58f9f9[_0xaf60('0x32')],_0x58f9f9[_0xaf60('0x33')]);_0x27244c[_0xaf60('0x36')]=_['intersection'](_0x58f9f9[_0xaf60('0x32')],qs[_0xaf60('0x37')](_0x8ec3bf[_0xaf60('0x33')]['fields']));_0x27244c[_0xaf60('0x36')]=_0x27244c['attributes']['length']?_0x27244c['attributes']:_0x58f9f9[_0xaf60('0x32')];_0x27244c[_0xaf60('0x3a')]=qs[_0xaf60('0x3b')](_0x8ec3bf[_0xaf60('0x33')][_0xaf60('0x3b')]);_0x27244c[_0xaf60('0x3c')]=qs['filters'](_[_0xaf60('0x51')](_0x8ec3bf[_0xaf60('0x33')],_0x58f9f9['filters']));if(_0x8ec3bf['query'][_0xaf60('0x3e')]){_0x27244c[_0xaf60('0x3c')]=_[_0xaf60('0x3f')](_0x27244c['where'],{'$or':_[_0xaf60('0x2f')](_0x27244c[_0xaf60('0x36')],function(_0x415d72){var _0x252294={};_0x252294[_0x415d72]={'$like':'%'+_0x8ec3bf[_0xaf60('0x33')][_0xaf60('0x3e')]+'%'};return _0x252294;})});}_0x27244c=_[_0xaf60('0x3f')]({},_0x27244c,_0x8ec3bf[_0xaf60('0x47')]);return _0x291228[_0xaf60('0x5e')](_0x27244c);}})[_0xaf60('0x26')](function(_0xb23d24){if(_0xb23d24){_0x401a84=_0xb23d24['length'];if(!_0x8ec3bf[_0xaf60('0x33')][_0xaf60('0x39')]('nolimit')){_0x27244c[_0xaf60('0x22')]=qs[_0xaf60('0x22')](_0x8ec3bf[_0xaf60('0x33')][_0xaf60('0x22')]);_0x27244c['offset']=qs['offset'](_0x8ec3bf[_0xaf60('0x33')][_0xaf60('0x1f')]);}return _0x291228[_0xaf60('0x5e')](_0x27244c);}})[_0xaf60('0x26')](function(_0x53e9fe){if(_0x53e9fe){return _0x53e9fe?{'count':_0x401a84,'rows':_0x53e9fe}:null;}})['then'](respondWithResult(_0x16d89a,null))[_0xaf60('0x44')](handleError(_0x16d89a,null));};exports['addTeams']=function(_0x502fcd,_0x1e205f,_0x3f53f9){var _0x367c86=_0x502fcd[_0xaf60('0x4a')][_0xaf60('0x60')];return db[_0xaf60('0x5f')][_0xaf60('0x43')]({'where':{'id':_0x367c86},'attributes':['id'],'include':[{'model':db[_0xaf60('0x54')],'as':_0xaf60('0x61'),'attributes':['id',_0xaf60('0x2c'),_0xaf60('0x62'),'voicePause',_0xaf60('0x63')],'raw':!![]}]})['then'](function(_0x394306){if(_0x394306){var _0x36efbd=_[_0xaf60('0x64')](_0x394306,function(_0x5791a4){var _0x454ec6=_0x5791a4['get']({'plain':!![]});return _0x454ec6['Agents'];});return db['MailQueue']['find']({'where':{'id':_0x502fcd[_0xaf60('0x4f')]['id']}})[_0xaf60('0x26')](function(_0x153bd0){return db[_0xaf60('0x65')][_0xaf60('0x66')](function(_0x987282){return _0x153bd0[_0xaf60('0x67')](_0x367c86,{'transaction':_0x987282})[_0xaf60('0x26')](function(){return BPromise['each'](_0x36efbd,function(_0xa0b787){return db[_0xaf60('0x53')][_0xaf60('0x68')]({'where':{'UserId':_0xa0b787['id'],'MailQueueId':_0x502fcd[_0xaf60('0x4f')]['id']},'transaction':_0x987282});});})[_0xaf60('0x26')](function(){_0x36efbd[_0xaf60('0x69')](function(_0x2dba65){socket['emit'](_0xaf60('0x6a'),{'UserId':_0x2dba65['id'],'MailQueueId':_0x153bd0['id']});});});});});}})['then'](respondWithStatusCode(_0x1e205f,null))[_0xaf60('0x44')](handleError(_0x1e205f,null));};exports[_0xaf60('0x6b')]=function(_0x24deab,_0x4f7ce3,_0x1887b6){return db[_0xaf60('0x5f')][_0xaf60('0x43')]({'where':{'id':_0x24deab[_0xaf60('0x33')][_0xaf60('0x60')]},'attributes':['id'],'include':[{'model':db[_0xaf60('0x54')],'as':_0xaf60('0x61'),'attributes':['id'],'raw':!![]}]})[_0xaf60('0x26')](handleEntityNotFound(_0x4f7ce3,null))[_0xaf60('0x26')](function(_0x55b170){var _0x45817d=_['map'](_0x55b170,'id');var _0x1c7206=[];var _0x39b2ec=[];var _0x560daa=squel[_0xaf60('0x6c')]();_0x560daa['field'](_0xaf60('0x6d'))['from'](_0xaf60('0x6e'),'tq')[_0xaf60('0x6f')](_0xaf60('0x70'),'ut',_0xaf60('0x71'))[_0xaf60('0x3c')]('MailQueueId\x20=\x20?',_0x24deab[_0xaf60('0x4f')]['id']);for(var _0x466cde=0x0;_0x466cde<_0x55b170['length'];_0x466cde+=0x1){let _0x2364db=_0x55b170[_0x466cde];for(var _0x2156be=0x0;_0x2156be<_0x2364db[_0xaf60('0x61')][_0xaf60('0x38')];_0x2156be+=0x1){let _0xa9a617=_0x2364db[_0xaf60('0x61')][_0x2156be];var _0x5c7b4f=_0x560daa[_0xaf60('0x72')]();_0x5c7b4f[_0xaf60('0x3c')]('ut.UserId\x20=\x20?',_0xa9a617['id']);_0x39b2ec[_0xaf60('0x73')](db[_0xaf60('0x65')][_0xaf60('0x33')](_0x5c7b4f[_0xaf60('0x74')](),{'type':db[_0xaf60('0x65')][_0xaf60('0x75')]['SELECT']})['then'](function(_0x3892d6){if(_0x3892d6[_0xaf60('0x38')]===0x1){return _0xa9a617['id'];}else{var _0x3eb345=_[_0xaf60('0x76')](_['map'](_0x3892d6,_0xaf60('0x77')),function(_0x11dc65){return _[_0xaf60('0x78')](_0x45817d,_0x11dc65);});if(_0x3eb345){return _0xa9a617['id'];}}}));}}return BPromise['all'](_0x39b2ec)[_0xaf60('0x26')](function(_0x5e1fc0){_0x1c7206=_(_0x1c7206)[_0xaf60('0x79')](_0x5e1fc0)[_0xaf60('0x7a')]()[_0xaf60('0x7b')]();return db['MailQueue']['find']({'where':{'id':_0x24deab['params']['id']}})[_0xaf60('0x26')](function(_0x358a19){return db[_0xaf60('0x65')][_0xaf60('0x66')](function(_0x396825){return _0x358a19[_0xaf60('0x6b')](_0x24deab['query']['ids'],{'transaction':_0x396825})[_0xaf60('0x26')](function(){if(!_[_0xaf60('0x7c')](_0x1c7206)){return _0x358a19[_0xaf60('0x7d')](_0x1c7206,{'transaction':_0x396825});}})[_0xaf60('0x26')](function(){_0x1c7206[_0xaf60('0x69')](function(_0x15dba3){socket[_0xaf60('0x7e')](_0xaf60('0x7f'),{'UserId':_0x15dba3,'MailQueueId':_0x358a19['id']});});});});});});})[_0xaf60('0x26')](respondWithStatusCode(_0x4f7ce3,null))['catch'](handleError(_0x4f7ce3,null));};exports[_0xaf60('0x80')]=function(_0x7da04d,_0x151dd0,_0x52ff63){return db[_0xaf60('0x30')]['find']({'where':{'id':_0x7da04d[_0xaf60('0x4f')]['id']}})[_0xaf60('0x26')](handleEntityNotFound(_0x151dd0,null))[_0xaf60('0x26')](function(_0x492403){if(_0x492403){return _0x492403[_0xaf60('0x80')](_0x7da04d['body']['ids'],_[_0xaf60('0x81')](_0x7da04d[_0xaf60('0x4a')],[_0xaf60('0x60'),'id'])||{})[_0xaf60('0x82')](function(_0x39ed38){for(var _0x13b43c=0x0;_0x13b43c<_0x7da04d[_0xaf60('0x4a')][_0xaf60('0x60')][_0xaf60('0x38')];_0x13b43c+=0x1){socket[_0xaf60('0x7e')](_0xaf60('0x6a'),{'UserId':Number(_0x7da04d[_0xaf60('0x4a')][_0xaf60('0x60')][_0x13b43c]),'MailQueueId':Number(_0x7da04d['params']['id'])});}return _0x39ed38;});}})['then'](respondWithResult(_0x151dd0,null))['catch'](handleError(_0x151dd0,null));};exports['removeAgents']=function(_0x4f3915,_0x5431ad,_0x2102c7){return db[_0xaf60('0x30')]['find']({'where':{'id':_0x4f3915[_0xaf60('0x4f')]['id']}})['then'](handleEntityNotFound(_0x5431ad,null))[_0xaf60('0x26')](function(_0x43bdf0){if(_0x43bdf0){return _0x43bdf0[_0xaf60('0x7d')](_0x4f3915[_0xaf60('0x33')][_0xaf60('0x60')])[_0xaf60('0x26')](function(){if(_[_0xaf60('0x83')](_0x4f3915['query'][_0xaf60('0x60')])){for(var _0x50ce11=0x0;_0x50ce11<_0x4f3915[_0xaf60('0x33')][_0xaf60('0x60')][_0xaf60('0x38')];_0x50ce11+=0x1){socket[_0xaf60('0x7e')](_0xaf60('0x7f'),{'UserId':Number(_0x4f3915[_0xaf60('0x33')][_0xaf60('0x60')][_0x50ce11]),'MailQueueId':Number(_0x4f3915[_0xaf60('0x4f')]['id'])});}}else{socket[_0xaf60('0x7e')]('userMailQueue:remove',{'UserId':Number(_0x4f3915[_0xaf60('0x33')][_0xaf60('0x60')]),'MailQueueId':Number(_0x4f3915[_0xaf60('0x4f')]['id'])});}});}})['then'](respondWithStatusCode(_0x5431ad,null))[_0xaf60('0x44')](handleError(_0x5431ad,null));};exports['getAgents']=function(_0x5aefe3,_0x50c100,_0xf49c95){var _0x2d271b={};var _0xcd85cd={};var _0x485780;var _0x292426;return db['MailQueue']['findOne']({'where':{'id':_0x5aefe3[_0xaf60('0x4f')]['id']}})[_0xaf60('0x26')](handleEntityNotFound(_0x50c100,null))[_0xaf60('0x26')](function(_0x54e39b){if(_0x54e39b){_0x485780=_0x54e39b;_0xcd85cd[_0xaf60('0x32')]=_['keys'](db[_0xaf60('0x54')][_0xaf60('0x46')]);_0xcd85cd[_0xaf60('0x33')]=_[_0xaf60('0x34')](_0x5aefe3[_0xaf60('0x33')]);_0xcd85cd[_0xaf60('0x3d')]=_[_0xaf60('0x35')](_0xcd85cd[_0xaf60('0x32')],_0xcd85cd['query']);_0x2d271b[_0xaf60('0x36')]=_[_0xaf60('0x35')](_0xcd85cd[_0xaf60('0x32')],qs[_0xaf60('0x37')](_0x5aefe3[_0xaf60('0x33')][_0xaf60('0x37')]));_0x2d271b[_0xaf60('0x36')]=_0x2d271b[_0xaf60('0x36')]['length']?_0x2d271b[_0xaf60('0x36')]:_0xcd85cd[_0xaf60('0x32')];_0x2d271b[_0xaf60('0x3a')]=qs[_0xaf60('0x3b')](_0x5aefe3[_0xaf60('0x33')][_0xaf60('0x3b')]);_0x2d271b[_0xaf60('0x3c')]=qs[_0xaf60('0x3d')](_['pick'](_0x5aefe3[_0xaf60('0x33')],_0xcd85cd[_0xaf60('0x3d')]));if(_0x5aefe3[_0xaf60('0x33')][_0xaf60('0x3e')]){_0x2d271b[_0xaf60('0x3c')]=_[_0xaf60('0x3f')](_0x2d271b[_0xaf60('0x3c')],{'$or':_[_0xaf60('0x2f')](_0x2d271b[_0xaf60('0x36')],function(_0x511b9f){var _0xca76ba={};_0xca76ba[_0x511b9f]={'$like':'%'+_0x5aefe3['query'][_0xaf60('0x3e')]+'%'};return _0xca76ba;})});}_0x2d271b=_[_0xaf60('0x3f')]({},_0x2d271b,_0x5aefe3[_0xaf60('0x47')]);return _0x485780[_0xaf60('0x84')](_0x2d271b);}})[_0xaf60('0x26')](function(_0x5c5a1e){if(_0x5c5a1e){_0x292426=_0x5c5a1e[_0xaf60('0x38')];if(!_0x5aefe3[_0xaf60('0x33')]['hasOwnProperty'](_0xaf60('0x85'))){_0x2d271b[_0xaf60('0x22')]=qs[_0xaf60('0x22')](_0x5aefe3[_0xaf60('0x33')][_0xaf60('0x22')]);_0x2d271b['offset']=qs[_0xaf60('0x1f')](_0x5aefe3['query'][_0xaf60('0x1f')]);}return _0x485780[_0xaf60('0x84')](_0x2d271b);}})[_0xaf60('0x26')](function(_0x53378c){if(_0x53378c){return _0x53378c?{'count':_0x292426,'rows':_0x53378c}:null;}})[_0xaf60('0x26')](respondWithResult(_0x50c100,null))['catch'](handleError(_0x50c100,null));};