aa0e8b1a8e26f1f41c4b901537fb84001b0f04ef
[motion2.git] / server / api / cmList / cmList.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 _0x99ce=['apply','reject','save','update','then','destroy','Lists','UserProfileResource','error','name','index','map','CmList','rawAttributes','fieldName','type','model','keys','query','filters','attributes','intersection','fields','hasOwnProperty','order','sort','where','pick','filter','merge','VIRTUAL','includeAll','include','findAll','rows','catch','show','params','options','find','create','user','get','role','userProfileId','autoAssociation','body','describe','ListId','Disposition','findOne','nolimit','removeDispositions','isArray','tags','length','push','each','CmContact','omit','ids','success','errors','message','Malformed\x20request\x20syntax','getContacts','CustomFields','format','cf_%d','raw','ContactItemType','OrderBy','CmCustomField','alias','select','from','c.ListId\x20=\x20?','c.deletedAt\x20is\x20null','distinct','c.cf_','customField_','field','item','cm_contact_has_items','ItemTypeId\x20=\x20?','CmContactId\x20=\x20c.id','additionalPhone_','description','description_additionalPhone_','toString','isEmpty','now','writeFileSync','/tmp/list_%d_%s.csv','setHeader','Content-disposition','attachment;\x20filename=','list_%d_%s.csv','Content-type','text/csv','download','transaction','addCustomFields','Sequelize','TEXT','text','number','INTEGER','sequelize','queryInterface','cm_contacts','getCustomFields','findAndCountAll','getGlobalCustomFields','addAgents','spread','emit','userCmList:save','removeAgents','userCmList:remove','getAgents','User','eml-format','rimraf','fast-json-patch','request-promise','moment','bluebird','util','path','sox','to-csv','ejs','lodash','squel','crypto','jsforce','desk.js','querystring','papaparse','ioredis','../../components/auth/service','../../components/parsers/qs','../../config/license/hardware','../../config/logger','api','../../config/utils','../../config/environment','../../config/license/util','redis','defaults','./cmList.socket','register','sendStatus','status','end','json','offset','undefined','limit','count','set'];(function(_0x2f33bf,_0x3c8aa5){var _0x3f44eb=function(_0x59fc04){while(--_0x59fc04){_0x2f33bf['push'](_0x2f33bf['shift']());}};_0x3f44eb(++_0x3c8aa5);}(_0x99ce,0x11c));var _0xe99c=function(_0x39a7bb,_0x3616b6){_0x39a7bb=_0x39a7bb-0x0;var _0x2e1027=_0x99ce[_0x39a7bb];return _0x2e1027;};'use strict';var emlformat=require(_0xe99c('0x0'));var rimraf=require(_0xe99c('0x1'));var zipdir=require('zip-dir');var jsonpatch=require(_0xe99c('0x2'));var rp=require(_0xe99c('0x3'));var moment=require(_0xe99c('0x4'));var BPromise=require(_0xe99c('0x5'));var Mustache=require('mustache');var util=require(_0xe99c('0x6'));var path=require(_0xe99c('0x7'));var sox=require(_0xe99c('0x8'));var csv=require(_0xe99c('0x9'));var ejs=require(_0xe99c('0xa'));var fs=require('fs');var fs_extra=require('fs-extra');var _=require(_0xe99c('0xb'));var squel=require(_0xe99c('0xc'));var crypto=require(_0xe99c('0xd'));var jsforce=require(_0xe99c('0xe'));var deskjs=require(_0xe99c('0xf'));var toCsv=require('to-csv');var querystring=require(_0xe99c('0x10'));var Papa=require(_0xe99c('0x11'));var Redis=require(_0xe99c('0x12'));var authService=require(_0xe99c('0x13'));var qs=require(_0xe99c('0x14'));var as=require('../../components/parsers/advancedSearch');var hardwareService=require(_0xe99c('0x15'));var logger=require(_0xe99c('0x16'))(_0xe99c('0x17'));var utils=require(_0xe99c('0x18'));var config=require(_0xe99c('0x19'));var licenseUtil=require(_0xe99c('0x1a'));var db=require('../../mysqldb')['db'];var csv_results;config[_0xe99c('0x1b')]=_[_0xe99c('0x1c')](config['redis'],{'host':'localhost','port':0x18eb});var socket=require('socket.io-emitter')(new Redis(config[_0xe99c('0x1b')]));require(_0xe99c('0x1d'))[_0xe99c('0x1e')](socket);function respondWithStatusCode(_0x29282c,_0x3d803a){_0x3d803a=_0x3d803a||0xcc;return function(_0x20d2f6){if(_0x20d2f6){return _0x29282c[_0xe99c('0x1f')](_0x3d803a);}return _0x29282c[_0xe99c('0x20')](_0x3d803a)[_0xe99c('0x21')]();};}function respondWithResult(_0x45a85e,_0x14366f){_0x14366f=_0x14366f||0xc8;return function(_0x52ac95){if(_0x52ac95){return _0x45a85e[_0xe99c('0x20')](_0x14366f)[_0xe99c('0x22')](_0x52ac95);}};}function respondWithFilteredResult(_0x54d582,_0x5ce2cb){return function(_0x488dd6){if(_0x488dd6){var _0x571ea5=typeof _0x5ce2cb[_0xe99c('0x23')]===_0xe99c('0x24')&&typeof _0x5ce2cb[_0xe99c('0x25')]===_0xe99c('0x24');var _0x2a3a27=_0x488dd6[_0xe99c('0x26')];var _0x3e273e=_0x571ea5?0x0:_0x5ce2cb['offset'];var _0x570368=_0x571ea5?_0x488dd6[_0xe99c('0x26')]:_0x5ce2cb['offset']+_0x5ce2cb['limit'];var _0x38173e;if(_0x570368>=_0x2a3a27){_0x570368=_0x2a3a27;_0x38173e=0xc8;}else{_0x38173e=0xce;}_0x54d582[_0xe99c('0x20')](_0x38173e);return _0x54d582[_0xe99c('0x27')]('Content-Range',_0x3e273e+'-'+_0x570368+'/'+_0x2a3a27)['json'](_0x488dd6);}return null;};}function patchUpdates(_0x145d4c){return function(_0x1d659f){try{jsonpatch[_0xe99c('0x28')](_0x1d659f,_0x145d4c,!![]);}catch(_0x56374c){return BPromise[_0xe99c('0x29')](_0x56374c);}return _0x1d659f[_0xe99c('0x2a')]();};}function saveUpdates(_0x4b285e,_0x51bb7b){return function(_0x231126){if(_0x231126){return _0x231126[_0xe99c('0x2b')](_0x4b285e)[_0xe99c('0x2c')](function(_0x106652){return _0x106652;});}return null;};}function removeEntity(_0xe0535,_0x31d206){return function(_0x54f392){if(_0x54f392){return _0x54f392[_0xe99c('0x2d')]()[_0xe99c('0x2c')](function(){var _0x2e204f=_0x54f392['get']({'plain':!![]});var _0x390a46=_0xe99c('0x2e');return db[_0xe99c('0x2f')][_0xe99c('0x2d')]({'where':{'type':_0x390a46,'resourceId':_0x2e204f['id']}})[_0xe99c('0x2c')](function(){return _0x54f392;});})[_0xe99c('0x2c')](function(){_0xe0535[_0xe99c('0x20')](0xcc)['end']();});}};}function handleEntityNotFound(_0x48276e,_0x116171){return function(_0x3e3338){if(!_0x3e3338){_0x48276e['sendStatus'](0x194);}return _0x3e3338;};}function handleError(_0x107b33,_0x46edc9){_0x46edc9=_0x46edc9||0x1f4;return function(_0x146b22){logger[_0xe99c('0x30')](_0x146b22['stack']);if(_0x146b22[_0xe99c('0x31')]){delete _0x146b22[_0xe99c('0x31')];}_0x107b33[_0xe99c('0x20')](_0x46edc9)['send'](_0x146b22);};}exports[_0xe99c('0x32')]=function(_0xa1a581,_0x583d57){var _0x36ef70={},_0x25afa6={},_0x17787a={'count':0x0,'rows':[]};var _0x35fc11=_[_0xe99c('0x33')](db[_0xe99c('0x34')][_0xe99c('0x35')],function(_0x421914){return{'name':_0x421914[_0xe99c('0x36')],'type':_0x421914[_0xe99c('0x37')]['key']};});_0x25afa6[_0xe99c('0x38')]=_['map'](_0x35fc11,_0xe99c('0x31'));_0x25afa6['query']=_[_0xe99c('0x39')](_0xa1a581[_0xe99c('0x3a')]);_0x25afa6[_0xe99c('0x3b')]=_['intersection'](_0x25afa6[_0xe99c('0x38')],_0x25afa6[_0xe99c('0x3a')]);_0x36ef70[_0xe99c('0x3c')]=_[_0xe99c('0x3d')](_0x25afa6['model'],qs[_0xe99c('0x3e')](_0xa1a581[_0xe99c('0x3a')][_0xe99c('0x3e')]));_0x36ef70[_0xe99c('0x3c')]=_0x36ef70[_0xe99c('0x3c')]['length']?_0x36ef70['attributes']:_0x25afa6[_0xe99c('0x38')];if(!_0xa1a581['query'][_0xe99c('0x3f')]('nolimit')){_0x36ef70[_0xe99c('0x25')]=qs[_0xe99c('0x25')](_0xa1a581[_0xe99c('0x3a')][_0xe99c('0x25')]);_0x36ef70[_0xe99c('0x23')]=qs[_0xe99c('0x23')](_0xa1a581[_0xe99c('0x3a')]['offset']);}_0x36ef70[_0xe99c('0x40')]=qs[_0xe99c('0x41')](_0xa1a581[_0xe99c('0x3a')][_0xe99c('0x41')]);_0x36ef70[_0xe99c('0x42')]=qs['filters'](_[_0xe99c('0x43')](_0xa1a581[_0xe99c('0x3a')],_0x25afa6[_0xe99c('0x3b')]),_0x35fc11);if(_0xa1a581[_0xe99c('0x3a')][_0xe99c('0x44')]){_0x36ef70[_0xe99c('0x42')]=_[_0xe99c('0x45')](_0x36ef70[_0xe99c('0x42')],{'$or':_[_0xe99c('0x33')](_0x35fc11,function(_0x29b4bf){if(_0x29b4bf['type']!==_0xe99c('0x46')){var _0x41a8ca={};_0x41a8ca[_0x29b4bf[_0xe99c('0x31')]]={'$like':'%'+_0xa1a581[_0xe99c('0x3a')][_0xe99c('0x44')]+'%'};return _0x41a8ca;}})});}_0x36ef70=_[_0xe99c('0x45')]({},_0x36ef70,_0xa1a581['options']);var _0xc4d35e={'where':_0x36ef70['where']};return db[_0xe99c('0x34')][_0xe99c('0x26')](_0xc4d35e)[_0xe99c('0x2c')](function(_0x27e1d0){_0x17787a[_0xe99c('0x26')]=_0x27e1d0;if(_0xa1a581['query'][_0xe99c('0x47')]){_0x36ef70[_0xe99c('0x48')]=[{'all':!![]}];}return db[_0xe99c('0x34')][_0xe99c('0x49')](_0x36ef70);})['then'](function(_0x1daa14){_0x17787a[_0xe99c('0x4a')]=_0x1daa14;return _0x17787a;})['then'](respondWithFilteredResult(_0x583d57,_0x36ef70))[_0xe99c('0x4b')](handleError(_0x583d57,null));};exports[_0xe99c('0x4c')]=function(_0x105558,_0x49f058){var _0xecab41={'raw':![],'where':{'id':_0x105558[_0xe99c('0x4d')]['id']}},_0x3d2c90={};_0x3d2c90[_0xe99c('0x38')]=_[_0xe99c('0x39')](db[_0xe99c('0x34')]['rawAttributes']);_0x3d2c90[_0xe99c('0x3a')]=_[_0xe99c('0x39')](_0x105558[_0xe99c('0x3a')]);_0x3d2c90[_0xe99c('0x3b')]=_[_0xe99c('0x3d')](_0x3d2c90['model'],_0x3d2c90['query']);_0xecab41[_0xe99c('0x3c')]=_[_0xe99c('0x3d')](_0x3d2c90[_0xe99c('0x38')],qs[_0xe99c('0x3e')](_0x105558[_0xe99c('0x3a')]['fields']));_0xecab41[_0xe99c('0x3c')]=_0xecab41[_0xe99c('0x3c')]['length']?_0xecab41[_0xe99c('0x3c')]:_0x3d2c90['model'];if(_0x105558['query'][_0xe99c('0x47')]){_0xecab41[_0xe99c('0x48')]=[{'all':!![]}];}_0xecab41=_[_0xe99c('0x45')]({},_0xecab41,_0x105558[_0xe99c('0x4e')]);return db[_0xe99c('0x34')][_0xe99c('0x4f')](_0xecab41)['then'](handleEntityNotFound(_0x49f058,null))['then'](respondWithResult(_0x49f058,null))[_0xe99c('0x4b')](handleError(_0x49f058,null));};exports[_0xe99c('0x50')]=function(_0x2f038c,_0x5dc700){return db[_0xe99c('0x34')][_0xe99c('0x50')](_0x2f038c['body'],{})[_0xe99c('0x2c')](function(_0x5892ac){var _0x4a4d45=_0x2f038c[_0xe99c('0x51')][_0xe99c('0x52')]({'plain':!![]});if(!_0x4a4d45)throw new Error('Unable\x20to\x20retrieve\x20the\x20current\x20user');if(_0x4a4d45[_0xe99c('0x53')]===_0xe99c('0x51')){var _0x29e420=_0x5892ac[_0xe99c('0x52')]({'plain':!![]});var _0xfac807='Lists';return db['UserProfileSection'][_0xe99c('0x4f')]({'where':{'name':_0xfac807,'userProfileId':_0x4a4d45[_0xe99c('0x54')]},'raw':!![]})['then'](function(_0x245e4e){if(_0x245e4e&&_0x245e4e[_0xe99c('0x55')]===0x0){return db[_0xe99c('0x2f')]['create']({'name':_0x29e420['name'],'resourceId':_0x29e420['id'],'type':_0x245e4e['name'],'sectionId':_0x245e4e['id']},{})[_0xe99c('0x2c')](function(){return _0x5892ac;});}else{return _0x5892ac;}})[_0xe99c('0x4b')](function(_0xdcb420){logger[_0xe99c('0x30')]('Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s',_0xdcb420);throw _0xdcb420;});}return _0x5892ac;})[_0xe99c('0x2c')](respondWithResult(_0x5dc700,0xc9))[_0xe99c('0x4b')](handleError(_0x5dc700,null));};exports[_0xe99c('0x2b')]=function(_0xb2b880,_0x412424){if(_0xb2b880[_0xe99c('0x56')]['id']){delete _0xb2b880[_0xe99c('0x56')]['id'];}return db[_0xe99c('0x34')][_0xe99c('0x4f')]({'where':{'id':_0xb2b880['params']['id']}})[_0xe99c('0x2c')](handleEntityNotFound(_0x412424,null))['then'](saveUpdates(_0xb2b880['body'],null))[_0xe99c('0x2c')](respondWithResult(_0x412424,null))[_0xe99c('0x4b')](handleError(_0x412424,null));};exports['destroy']=function(_0x261a79,_0x4215df){return db[_0xe99c('0x34')][_0xe99c('0x4f')]({'where':{'id':_0x261a79[_0xe99c('0x4d')]['id']}})[_0xe99c('0x2c')](handleEntityNotFound(_0x4215df,null))['then'](removeEntity(_0x4215df,null))['catch'](handleError(_0x4215df,null));};exports[_0xe99c('0x57')]=function(_0x15105c,_0x2ef2c3){return db['CmList']['describe']()[_0xe99c('0x2c')](respondWithResult(_0x2ef2c3,null))['catch'](handleError(_0x2ef2c3,null));};exports['addDisposition']=function(_0x1a6754,_0x32c340,_0x20ddda){if(_0x1a6754[_0xe99c('0x56')]['id']){delete _0x1a6754[_0xe99c('0x56')]['id'];}return db[_0xe99c('0x34')]['find']({'where':{'id':_0x1a6754[_0xe99c('0x4d')]['id']}})[_0xe99c('0x2c')](handleEntityNotFound(_0x32c340,null))['then'](function(_0x286aef){if(_0x286aef){_0x1a6754[_0xe99c('0x56')][_0xe99c('0x58')]=_0x286aef['id'];return db[_0xe99c('0x59')][_0xe99c('0x50')](_0x1a6754[_0xe99c('0x56')]);}})['then'](respondWithResult(_0x32c340,null))[_0xe99c('0x4b')](handleError(_0x32c340,null));};exports['getDispositions']=function(_0x4731cb,_0x12aceb,_0x1f7eaf){var _0x162540={'raw':![],'where':{}};var _0xc6e5f1={};var _0x5a3f30={'count':0x0,'rows':[]};return db[_0xe99c('0x34')][_0xe99c('0x5a')]({'where':{'id':_0x4731cb[_0xe99c('0x4d')]['id']}})[_0xe99c('0x2c')](handleEntityNotFound(_0x12aceb,null))[_0xe99c('0x2c')](function(_0x54a52e){if(_0x54a52e){_0xc6e5f1[_0xe99c('0x38')]=_[_0xe99c('0x39')](db[_0xe99c('0x59')][_0xe99c('0x35')]);_0xc6e5f1[_0xe99c('0x3a')]=_['keys'](_0x4731cb[_0xe99c('0x3a')]);_0xc6e5f1[_0xe99c('0x3b')]=_[_0xe99c('0x3d')](_0xc6e5f1['model'],_0xc6e5f1[_0xe99c('0x3a')]);_0x162540['attributes']=_['intersection'](_0xc6e5f1[_0xe99c('0x38')],qs[_0xe99c('0x3e')](_0x4731cb['query'][_0xe99c('0x3e')]));_0x162540[_0xe99c('0x3c')]=_0x162540[_0xe99c('0x3c')]['length']?_0x162540[_0xe99c('0x3c')]:_0xc6e5f1[_0xe99c('0x38')];if(!_0x4731cb['query'][_0xe99c('0x3f')](_0xe99c('0x5b'))){_0x162540[_0xe99c('0x25')]=qs['limit'](_0x4731cb[_0xe99c('0x3a')]['limit']);_0x162540[_0xe99c('0x23')]=qs[_0xe99c('0x23')](_0x4731cb[_0xe99c('0x3a')][_0xe99c('0x23')]);}_0x162540[_0xe99c('0x40')]=qs[_0xe99c('0x41')](_0x4731cb['query'][_0xe99c('0x41')]);_0x162540['where']=qs[_0xe99c('0x3b')](_[_0xe99c('0x43')](_0x4731cb['query'],_0xc6e5f1['filters']));_0x162540['where'][_0xe99c('0x58')]=_0x54a52e['id'];if(_0x4731cb[_0xe99c('0x3a')][_0xe99c('0x44')]){_0x162540['where']=_[_0xe99c('0x45')](_0x162540[_0xe99c('0x42')],{'$or':_[_0xe99c('0x33')](_0x162540[_0xe99c('0x3c')],function(_0x2d44bc){var _0x1a7159={};_0x1a7159[_0x2d44bc]={'$like':'%'+_0x4731cb[_0xe99c('0x3a')][_0xe99c('0x44')]+'%'};return _0x1a7159;})});}_0x162540=_['merge']({},_0x162540,_0x4731cb[_0xe99c('0x4e')]);return db[_0xe99c('0x59')]['count']({'where':_0x162540['where']})['then'](function(_0x184877){_0x5a3f30[_0xe99c('0x26')]=_0x184877;if(_0x4731cb[_0xe99c('0x3a')][_0xe99c('0x47')]){_0x162540[_0xe99c('0x48')]=[{'all':!![]}];}return db[_0xe99c('0x59')][_0xe99c('0x49')](_0x162540);})['then'](function(_0xe43d8e){_0x5a3f30['rows']=_0xe43d8e;return _0x5a3f30;});}})[_0xe99c('0x2c')](respondWithFilteredResult(_0x12aceb,_0x162540))['catch'](handleError(_0x12aceb,null));};exports[_0xe99c('0x5c')]=function(_0x56c08a,_0x2e3945,_0x37ad4b){return db[_0xe99c('0x34')]['find']({'where':{'id':_0x56c08a[_0xe99c('0x4d')]['id']}})[_0xe99c('0x2c')](handleEntityNotFound(_0x2e3945,null))[_0xe99c('0x2c')](function(_0x4bd15f){if(_0x4bd15f){return _0x4bd15f['removeDispositions'](_0x56c08a[_0xe99c('0x3a')]['ids']);}})[_0xe99c('0x2c')](respondWithStatusCode(_0x2e3945,null))[_0xe99c('0x4b')](handleError(_0x2e3945,null));};exports['addContacts']=function(_0x5117a1,_0x506ed1,_0x33f50d){return db[_0xe99c('0x34')]['find']({'where':{'id':_0x5117a1[_0xe99c('0x4d')]['id']}})[_0xe99c('0x2c')](handleEntityNotFound(_0x506ed1,null))[_0xe99c('0x2c')](function(_0x39289f){if(_0x39289f){var _0x4dd288=[];var _0x4fb377={'success':[],'errors':[]};return db['CmContact'][_0xe99c('0x57')]()['then'](function(_0x5ba818){if(_0x5117a1[_0xe99c('0x56')]['tags']&&_[_0xe99c('0x5d')](_0x5117a1[_0xe99c('0x56')]['tags'])){if(_0x5117a1[_0xe99c('0x56')][_0xe99c('0x5e')][_0xe99c('0x5f')]){_0x5117a1[_0xe99c('0x56')][_0xe99c('0x5e')]=_0x5117a1[_0xe99c('0x56')][_0xe99c('0x5e')]['join'](';')+';';}else{_0x5117a1[_0xe99c('0x56')][_0xe99c('0x5e')]=null;}}else{_0x5117a1[_0xe99c('0x56')]['tags']=null;}if(_0x5117a1[_0xe99c('0x56')]&&_['isArray'](_0x5117a1[_0xe99c('0x56')])){for(var _0x56314f=0x0;_0x56314f<_0x5117a1[_0xe99c('0x56')][_0xe99c('0x5f')];_0x56314f+=0x1){_0x5117a1['body'][_0x56314f][_0xe99c('0x58')]=_0x5117a1[_0xe99c('0x4d')]['id'];_0x4dd288[_0xe99c('0x60')](_0x5117a1[_0xe99c('0x56')][_0x56314f]);}return BPromise[_0xe99c('0x61')](_0x4dd288,function(_0x114385){return db[_0xe99c('0x62')][_0xe99c('0x50')](_[_0xe99c('0x63')](_0x114385,[_0xe99c('0x64'),'id'])||{},{'fields':_[_0xe99c('0x39')](_0x5ba818),'raw':!![]})[_0xe99c('0x2c')](function(_0x288644){_0x4fb377[_0xe99c('0x65')]['push'](_0x288644['dataValues']);})[_0xe99c('0x4b')](function(_0x515eaf){_0x4fb377[_0xe99c('0x66')][_0xe99c('0x60')]({'data':_0x114385,'error':_0x515eaf[_0xe99c('0x67')]});});})[_0xe99c('0x2c')](function(_0x3f47d5){return _0x4fb377;})[_0xe99c('0x4b')](function(_0xe8da2a){return _0xe8da2a;});}else{_0x506ed1[_0xe99c('0x20')](0x190)['json']({'message':_0xe99c('0x68')});}});}})[_0xe99c('0x2c')](respondWithResult(_0x506ed1,null))['catch'](handleError(_0x506ed1,null));};exports[_0xe99c('0x69')]=function(_0x3c949f,_0x3d610c,_0x456368){var _0x3b2d62;return db[_0xe99c('0x34')][_0xe99c('0x4f')]({'where':{'id':_0x3c949f[_0xe99c('0x4d')]['id']},'include':[{'model':db['CmCustomField'],'as':_0xe99c('0x6a')}]})[_0xe99c('0x2c')](handleEntityNotFound(_0x3d610c,null))[_0xe99c('0x2c')](function(_0x345060){if(_0x345060){_0x3b2d62=_0x345060;return db[_0xe99c('0x62')][_0xe99c('0x35')];}})[_0xe99c('0x2c')](function(_0x5e389b){if(_0x5e389b){var _0x4953f9={};var _0x403cc4={};_0x403cc4['model']=_['concat'](_[_0xe99c('0x39')](_0x5e389b),_['map'](_0x3b2d62[_0xe99c('0x6a')],function(_0x16594a){return util[_0xe99c('0x6b')](_0xe99c('0x6c'),_0x16594a['id']);}));_0x403cc4['query']=_[_0xe99c('0x39')](_0x3c949f['query']);_0x403cc4[_0xe99c('0x3b')]=_[_0xe99c('0x3d')](_0x403cc4['model'],_0x403cc4[_0xe99c('0x3a')]);_0x4953f9[_0xe99c('0x3c')]=_[_0xe99c('0x3d')](_0x403cc4[_0xe99c('0x38')],qs[_0xe99c('0x3e')](_0x3c949f[_0xe99c('0x3a')][_0xe99c('0x3e')]));_0x4953f9[_0xe99c('0x3c')]=_0x4953f9[_0xe99c('0x3c')][_0xe99c('0x5f')]?_0x4953f9[_0xe99c('0x3c')]:_0x403cc4[_0xe99c('0x38')];if(!_0x3c949f['query'][_0xe99c('0x3f')](_0xe99c('0x5b'))){_0x4953f9['limit']=qs['limit'](_0x3c949f['query']['limit']);_0x4953f9[_0xe99c('0x23')]=qs[_0xe99c('0x23')](_0x3c949f['query'][_0xe99c('0x23')]);}_0x4953f9[_0xe99c('0x40')]=qs[_0xe99c('0x41')](_0x3c949f[_0xe99c('0x3a')][_0xe99c('0x41')]);_0x4953f9[_0xe99c('0x42')]=qs[_0xe99c('0x3b')](_[_0xe99c('0x43')](_0x3c949f['query'],_0x403cc4['filters']));_0x4953f9[_0xe99c('0x6d')]=!![];if(_0x3c949f[_0xe99c('0x3a')][_0xe99c('0x44')]){_0x4953f9['where']=_[_0xe99c('0x45')](_0x4953f9['where'],{'$or':_[_0xe99c('0x33')](_0x4953f9[_0xe99c('0x3c')],function(_0x2c53d0){var _0x5a9f24={};_0x5a9f24[_0x2c53d0]={'$like':'%'+_0x3c949f[_0xe99c('0x3a')][_0xe99c('0x44')]+'%'};return _0x5a9f24;})});}_0x4953f9=_[_0xe99c('0x45')]({},_0x4953f9,_0x3c949f[_0xe99c('0x4e')]);return _0x3b2d62[_0xe99c('0x69')](_0x4953f9);}})[_0xe99c('0x2c')](respondWithResult(_0x3d610c,null))[_0xe99c('0x4b')](handleError(_0x3d610c,null));};exports['getContactsCsv']=function(_0x40d2a7,_0x45a895,_0x33beb0){var _0x5c062a;var _0x58bd45;var _0x1ebd2f;var _0x97755e=_0x40d2a7[_0xe99c('0x4d')]['id'];csv_results=[];return db[_0xe99c('0x6e')][_0xe99c('0x49')]({'attributes':['id',_0xe99c('0x31')],'raw':!![],'order':[_0xe99c('0x6f')]})['then'](function(_0xd2a8f6){_0x5c062a=_0xd2a8f6;var _0x2630c7=_[_0xe99c('0x39')](db['CmContact'][_0xe99c('0x35')]);return db[_0xe99c('0x70')][_0xe99c('0x49')]({'raw':!![],'attributes':['id',_0xe99c('0x71')]})['then'](function(_0x20fc84){_0x58bd45=_0x20fc84;var _0x22566f=squel[_0xe99c('0x72')]()[_0xe99c('0x3e')](_0x2630c7)[_0xe99c('0x73')]('cm_contacts','c')[_0xe99c('0x42')](_0xe99c('0x74'),_0x97755e)[_0xe99c('0x42')](_0xe99c('0x75'))[_0xe99c('0x76')]();for(var _0x1e7d7a=0x0;_0x1e7d7a<_0x58bd45[_0xe99c('0x5f')];_0x1e7d7a++){_0x22566f['field'](_0xe99c('0x77')+_0x58bd45[_0x1e7d7a]['id'],_0xe99c('0x78')+_0x58bd45[_0x1e7d7a]['alias']);}for(var _0x1e7d7a=0x0;_0x1e7d7a<_0x5c062a['length'];_0x1e7d7a++){_0x22566f[_0xe99c('0x79')](squel[_0xe99c('0x72')]()[_0xe99c('0x79')](_0xe99c('0x7a'))[_0xe99c('0x73')](_0xe99c('0x7b'))[_0xe99c('0x42')](_0xe99c('0x7c'),_0x5c062a[_0x1e7d7a]['id'])['where'](_0xe99c('0x7d')),_0xe99c('0x7e')+_0x5c062a[_0x1e7d7a]['name']);_0x22566f['field'](squel[_0xe99c('0x72')]()[_0xe99c('0x79')](_0xe99c('0x7f'))[_0xe99c('0x73')](_0xe99c('0x7b'))[_0xe99c('0x42')](_0xe99c('0x7c'),_0x5c062a[_0x1e7d7a]['id'])[_0xe99c('0x42')]('CmContactId\x20=\x20c.id'),_0xe99c('0x80')+_0x5c062a[_0x1e7d7a][_0xe99c('0x31')]);}var _0x3aae53=[];_0x3aae53[_0xe99c('0x60')](_0x22566f[_0xe99c('0x81')]());BPromise[_0xe99c('0x61')](_0x3aae53,handleQuery)[_0xe99c('0x2c')](function(_0x35335e){handleQuery(_0x22566f[_0xe99c('0x81')]());var _0x452eb1=csv_results[0x0];if(!_[_0xe99c('0x82')](_0x452eb1)){var _0x554d1e=toCsv(_0x452eb1);var _0x345365=Date[_0xe99c('0x83')]();fs[_0xe99c('0x84')](util[_0xe99c('0x6b')](_0xe99c('0x85'),_0x97755e,_0x345365),_0x554d1e);_0x45a895[_0xe99c('0x86')](_0xe99c('0x87'),_0xe99c('0x88')+util['format'](_0xe99c('0x89'),_0x97755e,_0x345365));_0x45a895[_0xe99c('0x86')](_0xe99c('0x8a'),_0xe99c('0x8b'));return _0x45a895[_0xe99c('0x8c')](util[_0xe99c('0x6b')](_0xe99c('0x85'),_0x97755e,_0x345365));}else{return _0x45a895[_0xe99c('0x1f')](0xcc);}});});});};exports['addCustomField']=function(_0x2e02a0,_0x2430e0,_0x46817c){var _0x138594;delete _0x2e02a0['body']['id'];return db[_0xe99c('0x34')][_0xe99c('0x5a')]({'where':{'id':_0x2e02a0[_0xe99c('0x4d')]['id']}})[_0xe99c('0x2c')](handleEntityNotFound(_0x2430e0,null))[_0xe99c('0x2c')](function(_0x2e0aa9){if(_0x2e0aa9){return db['sequelize'][_0xe99c('0x8d')](function(_0x4b7a0d){return db[_0xe99c('0x70')]['create'](_0x2e02a0[_0xe99c('0x56')],{'transaction':_0x4b7a0d})[_0xe99c('0x2c')](function(_0x42a524){_0x138594=_0x42a524;return _0x2e0aa9[_0xe99c('0x8e')](_0x42a524,{'transaction':_0x4b7a0d});})['then'](function(){var _0x4f4c1b={'type':db[_0xe99c('0x8f')][_0xe99c('0x90')],'transaction':_0x4b7a0d};switch(_0x2e02a0[_0xe99c('0x56')]['type']){case _0xe99c('0x91'):_0x4f4c1b['type']=db[_0xe99c('0x8f')]['TEXT'];break;case _0xe99c('0x92'):_0x4f4c1b[_0xe99c('0x37')]=db[_0xe99c('0x8f')][_0xe99c('0x93')];break;case'switch':_0x4f4c1b[_0xe99c('0x37')]=db[_0xe99c('0x8f')]['BOOLEAN'];_0x4f4c1b['defaultValue']=![];break;default:}return db[_0xe99c('0x94')][_0xe99c('0x95')]['addColumn'](_0xe99c('0x96'),util[_0xe99c('0x6b')]('cf_%s',_0x138594['id']),_0x4f4c1b);})[_0xe99c('0x2c')](function(){return _0x138594;});});}})[_0xe99c('0x2c')](respondWithResult(_0x2430e0,null))['catch'](handleError(_0x2430e0,null));};exports[_0xe99c('0x97')]=function(_0x1dd70b,_0x2c1a3d,_0x13e8f3){var _0x293ec5={};var _0x325c0d={};var _0x1f9693;var _0x2b1f50;return db['CmList']['findOne']({'where':{'id':_0x1dd70b[_0xe99c('0x4d')]['id']}})[_0xe99c('0x2c')](handleEntityNotFound(_0x2c1a3d,null))[_0xe99c('0x2c')](function(_0x2547e5){if(_0x2547e5){_0x1f9693=_0x2547e5;_0x325c0d[_0xe99c('0x38')]=_[_0xe99c('0x39')](db['CmCustomField']['rawAttributes']);_0x325c0d[_0xe99c('0x3a')]=_[_0xe99c('0x39')](_0x1dd70b[_0xe99c('0x3a')]);_0x325c0d['filters']=_[_0xe99c('0x3d')](_0x325c0d[_0xe99c('0x38')],_0x325c0d[_0xe99c('0x3a')]);_0x293ec5[_0xe99c('0x3c')]=_[_0xe99c('0x3d')](_0x325c0d[_0xe99c('0x38')],qs[_0xe99c('0x3e')](_0x1dd70b[_0xe99c('0x3a')][_0xe99c('0x3e')]));_0x293ec5[_0xe99c('0x3c')]=_0x293ec5[_0xe99c('0x3c')][_0xe99c('0x5f')]?_0x293ec5[_0xe99c('0x3c')]:_0x325c0d[_0xe99c('0x38')];_0x293ec5[_0xe99c('0x40')]=qs[_0xe99c('0x41')](_0x1dd70b[_0xe99c('0x3a')][_0xe99c('0x41')]);_0x293ec5['where']=qs[_0xe99c('0x3b')](_[_0xe99c('0x43')](_0x1dd70b['query'],_0x325c0d[_0xe99c('0x3b')]));_0x293ec5[_0xe99c('0x42')]=_[_0xe99c('0x45')](_0x293ec5[_0xe99c('0x42')],{'$or':[{'ListId':_0x2547e5['id']},{'ListId':null}]});if(_0x1dd70b[_0xe99c('0x3a')][_0xe99c('0x44')]){_0x293ec5[_0xe99c('0x42')]=_['merge'](_0x293ec5[_0xe99c('0x42')],{'$or':_[_0xe99c('0x33')](_0x293ec5[_0xe99c('0x3c')],function(_0x4fb6cc){var _0x1e6015={};_0x1e6015[_0x4fb6cc]={'$like':'%'+_0x1dd70b['query'][_0xe99c('0x44')]+'%'};return _0x1e6015;})});}_0x293ec5=_[_0xe99c('0x45')]({},_0x293ec5,_0x1dd70b[_0xe99c('0x4e')]);return db['CmCustomField'][_0xe99c('0x98')](_0x293ec5);}})[_0xe99c('0x2c')](respondWithResult(_0x2c1a3d,null))[_0xe99c('0x4b')](handleError(_0x2c1a3d,null));};exports[_0xe99c('0x99')]=function(_0x142df3,_0x22b470){return db[_0xe99c('0x70')][_0xe99c('0x98')]({'where':{'ListId':null}})['then'](handleEntityNotFound(_0x22b470,null))[_0xe99c('0x2c')](function(_0xec95f6){return _0xec95f6;})[_0xe99c('0x2c')](respondWithResult(_0x22b470,null))[_0xe99c('0x4b')](handleError(_0x22b470,null));};exports[_0xe99c('0x9a')]=function(_0x29b1a7,_0x3e1827,_0x39dc18){return db[_0xe99c('0x34')]['find']({'where':{'id':_0x29b1a7[_0xe99c('0x4d')]['id']}})['then'](handleEntityNotFound(_0x3e1827,null))[_0xe99c('0x2c')](function(_0x491b6b){if(_0x491b6b){return _0x491b6b[_0xe99c('0x9a')](_0x29b1a7['body'][_0xe99c('0x64')],_[_0xe99c('0x63')](_0x29b1a7['body'],[_0xe99c('0x64'),'id'])||{})[_0xe99c('0x9b')](function(_0x229273){for(var _0x4c38d7=0x0;_0x4c38d7<_0x29b1a7[_0xe99c('0x56')]['ids'][_0xe99c('0x5f')];_0x4c38d7+=0x1){socket[_0xe99c('0x9c')](_0xe99c('0x9d'),{'UserId':Number(_0x29b1a7['body']['ids'][_0x4c38d7]),'CmListId':Number(_0x29b1a7[_0xe99c('0x4d')]['id'])});}return _0x229273;});}})[_0xe99c('0x2c')](respondWithResult(_0x3e1827,null))[_0xe99c('0x4b')](handleError(_0x3e1827,null));};exports[_0xe99c('0x9e')]=function(_0x346a6d,_0x5649c6,_0x3ec77c){return db[_0xe99c('0x34')]['find']({'where':{'id':_0x346a6d[_0xe99c('0x4d')]['id']}})[_0xe99c('0x2c')](handleEntityNotFound(_0x5649c6,null))[_0xe99c('0x2c')](function(_0x2564c3){if(_0x2564c3){return _0x2564c3[_0xe99c('0x9e')](_0x346a6d[_0xe99c('0x3a')][_0xe99c('0x64')])[_0xe99c('0x2c')](function(){if(_[_0xe99c('0x5d')](_0x346a6d[_0xe99c('0x3a')]['ids'])){for(var _0x513078=0x0;_0x513078<_0x346a6d[_0xe99c('0x3a')][_0xe99c('0x64')]['length'];_0x513078+=0x1){socket[_0xe99c('0x9c')](_0xe99c('0x9f'),{'UserId':Number(_0x346a6d[_0xe99c('0x3a')]['ids'][_0x513078]),'CmListId':Number(_0x346a6d['params']['id'])});}}else{socket['emit'](_0xe99c('0x9f'),{'UserId':Number(_0x346a6d['query'][_0xe99c('0x64')]),'CmListId':Number(_0x346a6d[_0xe99c('0x4d')]['id'])});}});}})['then'](respondWithStatusCode(_0x5649c6,null))[_0xe99c('0x4b')](handleError(_0x5649c6,null));};exports[_0xe99c('0xa0')]=function(_0x5fb294,_0x22ae7a,_0xf0daa3){var _0x4aaf63={};var _0x2a67a2={};var _0x477486;var _0x2162ff;return db[_0xe99c('0x34')][_0xe99c('0x5a')]({'where':{'id':_0x5fb294[_0xe99c('0x4d')]['id']}})[_0xe99c('0x2c')](handleEntityNotFound(_0x22ae7a,null))[_0xe99c('0x2c')](function(_0x3e2298){if(_0x3e2298){_0x477486=_0x3e2298;_0x2a67a2[_0xe99c('0x38')]=_[_0xe99c('0x39')](db[_0xe99c('0xa1')][_0xe99c('0x35')]);_0x2a67a2[_0xe99c('0x3a')]=_[_0xe99c('0x39')](_0x5fb294['query']);_0x2a67a2[_0xe99c('0x3b')]=_[_0xe99c('0x3d')](_0x2a67a2[_0xe99c('0x38')],_0x2a67a2['query']);_0x4aaf63['attributes']=_[_0xe99c('0x3d')](_0x2a67a2['model'],qs[_0xe99c('0x3e')](_0x5fb294[_0xe99c('0x3a')][_0xe99c('0x3e')]));_0x4aaf63[_0xe99c('0x3c')]=_0x4aaf63[_0xe99c('0x3c')][_0xe99c('0x5f')]?_0x4aaf63['attributes']:_0x2a67a2[_0xe99c('0x38')];_0x4aaf63[_0xe99c('0x40')]=qs[_0xe99c('0x41')](_0x5fb294[_0xe99c('0x3a')][_0xe99c('0x41')]);_0x4aaf63[_0xe99c('0x42')]=qs['filters'](_[_0xe99c('0x43')](_0x5fb294[_0xe99c('0x3a')],_0x2a67a2['filters']));if(_0x5fb294['query'][_0xe99c('0x44')]){_0x4aaf63['where']=_['merge'](_0x4aaf63[_0xe99c('0x42')],{'$or':_[_0xe99c('0x33')](_0x4aaf63[_0xe99c('0x3c')],function(_0x20add9){var _0x3b187b={};_0x3b187b[_0x20add9]={'$like':'%'+_0x5fb294[_0xe99c('0x3a')]['filter']+'%'};return _0x3b187b;})});}_0x4aaf63=_['merge']({},_0x4aaf63,_0x5fb294[_0xe99c('0x4e')]);return _0x477486[_0xe99c('0xa0')](_0x4aaf63);}})['then'](function(_0x29ee5c){if(_0x29ee5c){_0x2162ff=_0x29ee5c[_0xe99c('0x5f')];if(!_0x5fb294[_0xe99c('0x3a')][_0xe99c('0x3f')](_0xe99c('0x5b'))){_0x4aaf63[_0xe99c('0x25')]=qs[_0xe99c('0x25')](_0x5fb294[_0xe99c('0x3a')]['limit']);_0x4aaf63[_0xe99c('0x23')]=qs[_0xe99c('0x23')](_0x5fb294[_0xe99c('0x3a')][_0xe99c('0x23')]);}return _0x477486['getAgents'](_0x4aaf63);}})['then'](function(_0x4aae43){if(_0x4aae43){return _0x4aae43?{'count':_0x2162ff,'rows':_0x4aae43}:null;}})[_0xe99c('0x2c')](respondWithResult(_0x22ae7a,null))[_0xe99c('0x4b')](handleError(_0x22ae7a,null));};function handleQuery(_0x1ea6d7){logger['info'](_0x1ea6d7);return db[_0xe99c('0x94')][_0xe99c('0x3a')](_0x1ea6d7)['spread'](function(_0x67568){csv_results['push'](_0x67568);})[_0xe99c('0x4b')](function(_0x40cbf6){logger[_0xe99c('0x30')](_0x40cbf6[_0xe99c('0x67')]);});}