Built motion from commit 4ca75f1b.|2.6.28
[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 _0x8b98=['User','getAgents','info','sequelize','spread','eml-format','rimraf','zip-dir','fast-json-patch','moment','bluebird','mustache','util','path','to-csv','ejs','fs-extra','lodash','squel','crypto','desk.js','querystring','papaparse','ioredis','../../components/parsers/advancedSearch','../../config/license/hardware','api','../../config/utils','../../config/environment','../../config/license/util','redis','defaults','socket.io-emitter','./cmList.socket','register','sendStatus','end','status','json','offset','undefined','limit','count','set','Content-Range','apply','reject','save','then','Lists','destroy','name','send','index','map','CmList','rawAttributes','fieldName','type','query','keys','filters','intersection','model','fields','attributes','length','hasOwnProperty','nolimit','order','sort','where','pick','filter','options','includeAll','include','findAll','rows','catch','params','merge','find','create','body','user','get','Unable\x20to\x20retrieve\x20the\x20current\x20user','UserProfileSection','userProfileId','autoAssociation','UserProfileResource','error','update','describe','addDisposition','ListId','findOne','Disposition','removeDispositions','ids','CmContact','tags','isArray','join','push','each','success','errors','message','Malformed\x20request\x20syntax','getContacts','CmCustomField','CustomFields','cf_%d','raw','getContactsCsv','ContactItemType','OrderBy','alias','select','from','cm_contacts','c.ListId\x20=\x20?','c.deletedAt\x20is\x20null','distinct','field','customField_','item','cm_contact_has_items','ItemTypeId\x20=\x20?','CmContactId\x20=\x20c.id','description','isEmpty','format','setHeader','Content-disposition','attachment;\x20filename=','list_%d_%s.csv','Content-type','download','addCustomField','addCustomFields','Sequelize','TEXT','text','number','INTEGER','BOOLEAN','queryInterface','addColumn','findAndCountAll','getGlobalCustomFields','addAgents','omit','removeAgents','emit'];(function(_0x299e5b,_0x1ca8c2){var _0xfd6c31=function(_0xaf4a74){while(--_0xaf4a74){_0x299e5b['push'](_0x299e5b['shift']());}};_0xfd6c31(++_0x1ca8c2);}(_0x8b98,0x1dc));var _0x88b9=function(_0x297fd3,_0x115406){_0x297fd3=_0x297fd3-0x0;var _0x2af381=_0x8b98[_0x297fd3];return _0x2af381;};'use strict';var emlformat=require(_0x88b9('0x0'));var rimraf=require(_0x88b9('0x1'));var zipdir=require(_0x88b9('0x2'));var jsonpatch=require(_0x88b9('0x3'));var rp=require('request-promise');var moment=require(_0x88b9('0x4'));var BPromise=require(_0x88b9('0x5'));var Mustache=require(_0x88b9('0x6'));var util=require(_0x88b9('0x7'));var path=require(_0x88b9('0x8'));var sox=require('sox');var csv=require(_0x88b9('0x9'));var ejs=require(_0x88b9('0xa'));var fs=require('fs');var fs_extra=require(_0x88b9('0xb'));var _=require(_0x88b9('0xc'));var squel=require(_0x88b9('0xd'));var crypto=require(_0x88b9('0xe'));var jsforce=require('jsforce');var deskjs=require(_0x88b9('0xf'));var toCsv=require(_0x88b9('0x9'));var querystring=require(_0x88b9('0x10'));var Papa=require(_0x88b9('0x11'));var Redis=require(_0x88b9('0x12'));var authService=require('../../components/auth/service');var qs=require('../../components/parsers/qs');var as=require(_0x88b9('0x13'));var hardwareService=require(_0x88b9('0x14'));var logger=require('../../config/logger')(_0x88b9('0x15'));var utils=require(_0x88b9('0x16'));var config=require(_0x88b9('0x17'));var licenseUtil=require(_0x88b9('0x18'));var db=require('../../mysqldb')['db'];var csv_results;config[_0x88b9('0x19')]=_[_0x88b9('0x1a')](config['redis'],{'host':'localhost','port':0x18eb});var socket=require(_0x88b9('0x1b'))(new Redis(config[_0x88b9('0x19')]));require(_0x88b9('0x1c'))[_0x88b9('0x1d')](socket);function respondWithStatusCode(_0x1be208,_0x477457){_0x477457=_0x477457||0xcc;return function(_0x10bacb){if(_0x10bacb){return _0x1be208[_0x88b9('0x1e')](_0x477457);}return _0x1be208['status'](_0x477457)[_0x88b9('0x1f')]();};}function respondWithResult(_0x54bde5,_0x67395d){_0x67395d=_0x67395d||0xc8;return function(_0x435eee){if(_0x435eee){return _0x54bde5[_0x88b9('0x20')](_0x67395d)[_0x88b9('0x21')](_0x435eee);}};}function respondWithFilteredResult(_0x1456d7,_0x3513a7){return function(_0x3fd52a){if(_0x3fd52a){var _0xae9295=typeof _0x3513a7[_0x88b9('0x22')]===_0x88b9('0x23')&&typeof _0x3513a7[_0x88b9('0x24')]==='undefined';var _0x1f6c0d=_0x3fd52a[_0x88b9('0x25')];var _0xfb9924=_0xae9295?0x0:_0x3513a7[_0x88b9('0x22')];var _0x1d3caa=_0xae9295?_0x3fd52a[_0x88b9('0x25')]:_0x3513a7[_0x88b9('0x22')]+_0x3513a7['limit'];var _0x19cf33;if(_0x1d3caa>=_0x1f6c0d){_0x1d3caa=_0x1f6c0d;_0x19cf33=0xc8;}else{_0x19cf33=0xce;}_0x1456d7[_0x88b9('0x20')](_0x19cf33);return _0x1456d7[_0x88b9('0x26')](_0x88b9('0x27'),_0xfb9924+'-'+_0x1d3caa+'/'+_0x1f6c0d)[_0x88b9('0x21')](_0x3fd52a);}return null;};}function patchUpdates(_0x17fa1a){return function(_0x39f4df){try{jsonpatch[_0x88b9('0x28')](_0x39f4df,_0x17fa1a,!![]);}catch(_0x2ab273){return BPromise[_0x88b9('0x29')](_0x2ab273);}return _0x39f4df[_0x88b9('0x2a')]();};}function saveUpdates(_0x1a59f6,_0x441376){return function(_0x30fa5e){if(_0x30fa5e){return _0x30fa5e['update'](_0x1a59f6)[_0x88b9('0x2b')](function(_0x3497db){return _0x3497db;});}return null;};}function removeEntity(_0x32e2e5,_0x380465){return function(_0xb46a96){if(_0xb46a96){return _0xb46a96['destroy']()[_0x88b9('0x2b')](function(){var _0x5e8ef0=_0xb46a96['get']({'plain':!![]});var _0x1a4eba=_0x88b9('0x2c');return db['UserProfileResource'][_0x88b9('0x2d')]({'where':{'type':_0x1a4eba,'resourceId':_0x5e8ef0['id']}})[_0x88b9('0x2b')](function(){return _0xb46a96;});})[_0x88b9('0x2b')](function(){_0x32e2e5['status'](0xcc)['end']();});}};}function handleEntityNotFound(_0x541473,_0x53845a){return function(_0x504e9b){if(!_0x504e9b){_0x541473['sendStatus'](0x194);}return _0x504e9b;};}function handleError(_0x24b687,_0xfd6761){_0xfd6761=_0xfd6761||0x1f4;return function(_0x5a0b3a){logger['error'](_0x5a0b3a['stack']);if(_0x5a0b3a[_0x88b9('0x2e')]){delete _0x5a0b3a[_0x88b9('0x2e')];}_0x24b687[_0x88b9('0x20')](_0xfd6761)[_0x88b9('0x2f')](_0x5a0b3a);};}exports[_0x88b9('0x30')]=function(_0x44417c,_0x41fa8b){var _0x22714c={},_0x411872={},_0x4e5b88={'count':0x0,'rows':[]};var _0x19e766=_[_0x88b9('0x31')](db[_0x88b9('0x32')][_0x88b9('0x33')],function(_0x560b86){return{'name':_0x560b86[_0x88b9('0x34')],'type':_0x560b86[_0x88b9('0x35')]['key']};});_0x411872['model']=_[_0x88b9('0x31')](_0x19e766,_0x88b9('0x2e'));_0x411872[_0x88b9('0x36')]=_[_0x88b9('0x37')](_0x44417c[_0x88b9('0x36')]);_0x411872[_0x88b9('0x38')]=_[_0x88b9('0x39')](_0x411872[_0x88b9('0x3a')],_0x411872[_0x88b9('0x36')]);_0x22714c['attributes']=_[_0x88b9('0x39')](_0x411872['model'],qs[_0x88b9('0x3b')](_0x44417c[_0x88b9('0x36')]['fields']));_0x22714c[_0x88b9('0x3c')]=_0x22714c[_0x88b9('0x3c')][_0x88b9('0x3d')]?_0x22714c[_0x88b9('0x3c')]:_0x411872[_0x88b9('0x3a')];if(!_0x44417c['query'][_0x88b9('0x3e')](_0x88b9('0x3f'))){_0x22714c[_0x88b9('0x24')]=qs[_0x88b9('0x24')](_0x44417c['query']['limit']);_0x22714c[_0x88b9('0x22')]=qs[_0x88b9('0x22')](_0x44417c['query'][_0x88b9('0x22')]);}_0x22714c[_0x88b9('0x40')]=qs[_0x88b9('0x41')](_0x44417c[_0x88b9('0x36')][_0x88b9('0x41')]);_0x22714c[_0x88b9('0x42')]=qs['filters'](_[_0x88b9('0x43')](_0x44417c['query'],_0x411872[_0x88b9('0x38')]),_0x19e766);if(_0x44417c[_0x88b9('0x36')][_0x88b9('0x44')]){_0x22714c['where']=_['merge'](_0x22714c[_0x88b9('0x42')],{'$or':_['map'](_0x19e766,function(_0x38683c){if(_0x38683c['type']!=='VIRTUAL'){var _0x29e226={};_0x29e226[_0x38683c[_0x88b9('0x2e')]]={'$like':'%'+_0x44417c[_0x88b9('0x36')][_0x88b9('0x44')]+'%'};return _0x29e226;}})});}_0x22714c=_['merge']({},_0x22714c,_0x44417c[_0x88b9('0x45')]);var _0x49fb6d={'where':_0x22714c[_0x88b9('0x42')]};return db[_0x88b9('0x32')]['count'](_0x49fb6d)[_0x88b9('0x2b')](function(_0x23d3b5){_0x4e5b88['count']=_0x23d3b5;if(_0x44417c[_0x88b9('0x36')][_0x88b9('0x46')]){_0x22714c[_0x88b9('0x47')]=[{'all':!![]}];}return db['CmList'][_0x88b9('0x48')](_0x22714c);})[_0x88b9('0x2b')](function(_0x27f9f6){_0x4e5b88[_0x88b9('0x49')]=_0x27f9f6;return _0x4e5b88;})[_0x88b9('0x2b')](respondWithFilteredResult(_0x41fa8b,_0x22714c))[_0x88b9('0x4a')](handleError(_0x41fa8b,null));};exports['show']=function(_0x5a12ec,_0x1c6019){var _0x217cd0={'raw':![],'where':{'id':_0x5a12ec[_0x88b9('0x4b')]['id']}},_0x57c0f6={};_0x57c0f6[_0x88b9('0x3a')]=_[_0x88b9('0x37')](db['CmList'][_0x88b9('0x33')]);_0x57c0f6[_0x88b9('0x36')]=_[_0x88b9('0x37')](_0x5a12ec[_0x88b9('0x36')]);_0x57c0f6[_0x88b9('0x38')]=_[_0x88b9('0x39')](_0x57c0f6[_0x88b9('0x3a')],_0x57c0f6[_0x88b9('0x36')]);_0x217cd0[_0x88b9('0x3c')]=_['intersection'](_0x57c0f6[_0x88b9('0x3a')],qs[_0x88b9('0x3b')](_0x5a12ec[_0x88b9('0x36')][_0x88b9('0x3b')]));_0x217cd0[_0x88b9('0x3c')]=_0x217cd0[_0x88b9('0x3c')]['length']?_0x217cd0[_0x88b9('0x3c')]:_0x57c0f6[_0x88b9('0x3a')];if(_0x5a12ec['query']['includeAll']){_0x217cd0[_0x88b9('0x47')]=[{'all':!![]}];}_0x217cd0=_[_0x88b9('0x4c')]({},_0x217cd0,_0x5a12ec[_0x88b9('0x45')]);return db[_0x88b9('0x32')][_0x88b9('0x4d')](_0x217cd0)[_0x88b9('0x2b')](handleEntityNotFound(_0x1c6019,null))[_0x88b9('0x2b')](respondWithResult(_0x1c6019,null))[_0x88b9('0x4a')](handleError(_0x1c6019,null));};exports[_0x88b9('0x4e')]=function(_0x489ff1,_0x1679eb){return db[_0x88b9('0x32')][_0x88b9('0x4e')](_0x489ff1[_0x88b9('0x4f')],{})[_0x88b9('0x2b')](function(_0x176e93){var _0x9e32b8=_0x489ff1[_0x88b9('0x50')][_0x88b9('0x51')]({'plain':!![]});if(!_0x9e32b8)throw new Error(_0x88b9('0x52'));if(_0x9e32b8['role']==='user'){var _0x192b9e=_0x176e93[_0x88b9('0x51')]({'plain':!![]});var _0x42a016=_0x88b9('0x2c');return db[_0x88b9('0x53')][_0x88b9('0x4d')]({'where':{'name':_0x42a016,'userProfileId':_0x9e32b8[_0x88b9('0x54')]},'raw':!![]})[_0x88b9('0x2b')](function(_0x12ebbe){if(_0x12ebbe&&_0x12ebbe[_0x88b9('0x55')]===0x0){return db[_0x88b9('0x56')][_0x88b9('0x4e')]({'name':_0x192b9e['name'],'resourceId':_0x192b9e['id'],'type':_0x12ebbe[_0x88b9('0x2e')],'sectionId':_0x12ebbe['id']},{})[_0x88b9('0x2b')](function(){return _0x176e93;});}else{return _0x176e93;}})[_0x88b9('0x4a')](function(_0x209168){logger[_0x88b9('0x57')]('Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s',_0x209168);throw _0x209168;});}return _0x176e93;})[_0x88b9('0x2b')](respondWithResult(_0x1679eb,0xc9))[_0x88b9('0x4a')](handleError(_0x1679eb,null));};exports[_0x88b9('0x58')]=function(_0x303459,_0x2dff3d){if(_0x303459['body']['id']){delete _0x303459[_0x88b9('0x4f')]['id'];}return db[_0x88b9('0x32')][_0x88b9('0x4d')]({'where':{'id':_0x303459['params']['id']}})[_0x88b9('0x2b')](handleEntityNotFound(_0x2dff3d,null))[_0x88b9('0x2b')](saveUpdates(_0x303459[_0x88b9('0x4f')],null))[_0x88b9('0x2b')](respondWithResult(_0x2dff3d,null))[_0x88b9('0x4a')](handleError(_0x2dff3d,null));};exports['destroy']=function(_0x28ce9e,_0x1d48c4){return db[_0x88b9('0x32')]['find']({'where':{'id':_0x28ce9e[_0x88b9('0x4b')]['id']}})[_0x88b9('0x2b')](handleEntityNotFound(_0x1d48c4,null))[_0x88b9('0x2b')](removeEntity(_0x1d48c4,null))[_0x88b9('0x4a')](handleError(_0x1d48c4,null));};exports['describe']=function(_0x3a5016,_0xf0cdec){return db[_0x88b9('0x32')][_0x88b9('0x59')]()[_0x88b9('0x2b')](respondWithResult(_0xf0cdec,null))[_0x88b9('0x4a')](handleError(_0xf0cdec,null));};exports[_0x88b9('0x5a')]=function(_0x1e45ed,_0xc8f8fc,_0x2dad8a){if(_0x1e45ed[_0x88b9('0x4f')]['id']){delete _0x1e45ed[_0x88b9('0x4f')]['id'];}return db[_0x88b9('0x32')][_0x88b9('0x4d')]({'where':{'id':_0x1e45ed[_0x88b9('0x4b')]['id']}})[_0x88b9('0x2b')](handleEntityNotFound(_0xc8f8fc,null))['then'](function(_0x39ca91){if(_0x39ca91){_0x1e45ed[_0x88b9('0x4f')][_0x88b9('0x5b')]=_0x39ca91['id'];return db['Disposition'][_0x88b9('0x4e')](_0x1e45ed['body']);}})[_0x88b9('0x2b')](respondWithResult(_0xc8f8fc,null))[_0x88b9('0x4a')](handleError(_0xc8f8fc,null));};exports['getDispositions']=function(_0x16a196,_0x47e308,_0x5e872c){var _0x55e50b={'raw':![],'where':{}};var _0x260e85={};var _0x5ec669={'count':0x0,'rows':[]};return db[_0x88b9('0x32')][_0x88b9('0x5c')]({'where':{'id':_0x16a196[_0x88b9('0x4b')]['id']}})['then'](handleEntityNotFound(_0x47e308,null))['then'](function(_0x5a2bd8){if(_0x5a2bd8){_0x260e85[_0x88b9('0x3a')]=_[_0x88b9('0x37')](db[_0x88b9('0x5d')][_0x88b9('0x33')]);_0x260e85['query']=_['keys'](_0x16a196['query']);_0x260e85['filters']=_[_0x88b9('0x39')](_0x260e85[_0x88b9('0x3a')],_0x260e85[_0x88b9('0x36')]);_0x55e50b[_0x88b9('0x3c')]=_[_0x88b9('0x39')](_0x260e85['model'],qs[_0x88b9('0x3b')](_0x16a196[_0x88b9('0x36')]['fields']));_0x55e50b['attributes']=_0x55e50b[_0x88b9('0x3c')]['length']?_0x55e50b[_0x88b9('0x3c')]:_0x260e85[_0x88b9('0x3a')];if(!_0x16a196[_0x88b9('0x36')][_0x88b9('0x3e')](_0x88b9('0x3f'))){_0x55e50b[_0x88b9('0x24')]=qs[_0x88b9('0x24')](_0x16a196[_0x88b9('0x36')][_0x88b9('0x24')]);_0x55e50b[_0x88b9('0x22')]=qs[_0x88b9('0x22')](_0x16a196[_0x88b9('0x36')][_0x88b9('0x22')]);}_0x55e50b['order']=qs[_0x88b9('0x41')](_0x16a196[_0x88b9('0x36')]['sort']);_0x55e50b[_0x88b9('0x42')]=qs[_0x88b9('0x38')](_[_0x88b9('0x43')](_0x16a196[_0x88b9('0x36')],_0x260e85[_0x88b9('0x38')]));_0x55e50b[_0x88b9('0x42')]['ListId']=_0x5a2bd8['id'];if(_0x16a196[_0x88b9('0x36')]['filter']){_0x55e50b[_0x88b9('0x42')]=_['merge'](_0x55e50b[_0x88b9('0x42')],{'$or':_['map'](_0x55e50b['attributes'],function(_0x2d2565){var _0x15ec4e={};_0x15ec4e[_0x2d2565]={'$like':'%'+_0x16a196[_0x88b9('0x36')]['filter']+'%'};return _0x15ec4e;})});}_0x55e50b=_[_0x88b9('0x4c')]({},_0x55e50b,_0x16a196[_0x88b9('0x45')]);return db[_0x88b9('0x5d')][_0x88b9('0x25')]({'where':_0x55e50b['where']})['then'](function(_0x51e399){_0x5ec669[_0x88b9('0x25')]=_0x51e399;if(_0x16a196['query']['includeAll']){_0x55e50b[_0x88b9('0x47')]=[{'all':!![]}];}return db[_0x88b9('0x5d')][_0x88b9('0x48')](_0x55e50b);})[_0x88b9('0x2b')](function(_0x4eb169){_0x5ec669[_0x88b9('0x49')]=_0x4eb169;return _0x5ec669;});}})[_0x88b9('0x2b')](respondWithFilteredResult(_0x47e308,_0x55e50b))[_0x88b9('0x4a')](handleError(_0x47e308,null));};exports[_0x88b9('0x5e')]=function(_0x4305c6,_0x7d1085,_0x399cdd){return db[_0x88b9('0x32')]['find']({'where':{'id':_0x4305c6[_0x88b9('0x4b')]['id']}})[_0x88b9('0x2b')](handleEntityNotFound(_0x7d1085,null))[_0x88b9('0x2b')](function(_0x5c344f){if(_0x5c344f){return _0x5c344f[_0x88b9('0x5e')](_0x4305c6[_0x88b9('0x36')][_0x88b9('0x5f')]);}})[_0x88b9('0x2b')](respondWithStatusCode(_0x7d1085,null))[_0x88b9('0x4a')](handleError(_0x7d1085,null));};exports['addContacts']=function(_0x3da3c3,_0x62ce1e,_0x3a12d8){return db[_0x88b9('0x32')][_0x88b9('0x4d')]({'where':{'id':_0x3da3c3[_0x88b9('0x4b')]['id']}})[_0x88b9('0x2b')](handleEntityNotFound(_0x62ce1e,null))[_0x88b9('0x2b')](function(_0x5538bd){if(_0x5538bd){var _0x501e45=[];var _0x74c526={'success':[],'errors':[]};return db[_0x88b9('0x60')][_0x88b9('0x59')]()[_0x88b9('0x2b')](function(_0x26488d){if(_0x3da3c3[_0x88b9('0x4f')][_0x88b9('0x61')]&&_[_0x88b9('0x62')](_0x3da3c3[_0x88b9('0x4f')][_0x88b9('0x61')])){if(_0x3da3c3['body'][_0x88b9('0x61')][_0x88b9('0x3d')]){_0x3da3c3[_0x88b9('0x4f')]['tags']=_0x3da3c3[_0x88b9('0x4f')]['tags'][_0x88b9('0x63')](';')+';';}else{_0x3da3c3[_0x88b9('0x4f')][_0x88b9('0x61')]=null;}}else{_0x3da3c3['body'][_0x88b9('0x61')]=null;}if(_0x3da3c3[_0x88b9('0x4f')]&&_[_0x88b9('0x62')](_0x3da3c3[_0x88b9('0x4f')])){for(var _0x5e6553=0x0;_0x5e6553<_0x3da3c3[_0x88b9('0x4f')][_0x88b9('0x3d')];_0x5e6553+=0x1){_0x3da3c3['body'][_0x5e6553][_0x88b9('0x5b')]=_0x3da3c3[_0x88b9('0x4b')]['id'];_0x501e45[_0x88b9('0x64')](_0x3da3c3[_0x88b9('0x4f')][_0x5e6553]);}return BPromise[_0x88b9('0x65')](_0x501e45,function(_0x5c7ff0){return db[_0x88b9('0x60')][_0x88b9('0x4e')](_['omit'](_0x5c7ff0,['ids','id'])||{},{'fields':_['keys'](_0x26488d),'raw':!![]})[_0x88b9('0x2b')](function(_0x1294e8){_0x74c526[_0x88b9('0x66')][_0x88b9('0x64')](_0x1294e8['dataValues']);})[_0x88b9('0x4a')](function(_0x5f3f59){_0x74c526[_0x88b9('0x67')][_0x88b9('0x64')]({'data':_0x5c7ff0,'error':_0x5f3f59[_0x88b9('0x68')]});});})['then'](function(_0x405d2a){return _0x74c526;})[_0x88b9('0x4a')](function(_0x5218b2){return _0x5218b2;});}else{_0x62ce1e[_0x88b9('0x20')](0x190)[_0x88b9('0x21')]({'message':_0x88b9('0x69')});}});}})[_0x88b9('0x2b')](respondWithResult(_0x62ce1e,null))[_0x88b9('0x4a')](handleError(_0x62ce1e,null));};exports[_0x88b9('0x6a')]=function(_0x5efb5a,_0x2a116a,_0x2b5a97){var _0x3752ea;return db[_0x88b9('0x32')]['find']({'where':{'id':_0x5efb5a[_0x88b9('0x4b')]['id']},'include':[{'model':db[_0x88b9('0x6b')],'as':_0x88b9('0x6c')}]})[_0x88b9('0x2b')](handleEntityNotFound(_0x2a116a,null))[_0x88b9('0x2b')](function(_0x420a4f){if(_0x420a4f){_0x3752ea=_0x420a4f;return db[_0x88b9('0x60')][_0x88b9('0x33')];}})['then'](function(_0x58a818){if(_0x58a818){var _0x558733={};var _0x29147b={};_0x29147b[_0x88b9('0x3a')]=_['concat'](_['keys'](_0x58a818),_[_0x88b9('0x31')](_0x3752ea['CustomFields'],function(_0x2ef4bb){return util['format'](_0x88b9('0x6d'),_0x2ef4bb['id']);}));_0x29147b[_0x88b9('0x36')]=_[_0x88b9('0x37')](_0x5efb5a[_0x88b9('0x36')]);_0x29147b['filters']=_[_0x88b9('0x39')](_0x29147b['model'],_0x29147b[_0x88b9('0x36')]);_0x558733[_0x88b9('0x3c')]=_[_0x88b9('0x39')](_0x29147b[_0x88b9('0x3a')],qs[_0x88b9('0x3b')](_0x5efb5a['query'][_0x88b9('0x3b')]));_0x558733['attributes']=_0x558733[_0x88b9('0x3c')][_0x88b9('0x3d')]?_0x558733[_0x88b9('0x3c')]:_0x29147b[_0x88b9('0x3a')];if(!_0x5efb5a[_0x88b9('0x36')][_0x88b9('0x3e')](_0x88b9('0x3f'))){_0x558733[_0x88b9('0x24')]=qs[_0x88b9('0x24')](_0x5efb5a[_0x88b9('0x36')][_0x88b9('0x24')]);_0x558733[_0x88b9('0x22')]=qs[_0x88b9('0x22')](_0x5efb5a[_0x88b9('0x36')]['offset']);}_0x558733[_0x88b9('0x40')]=qs[_0x88b9('0x41')](_0x5efb5a['query'][_0x88b9('0x41')]);_0x558733[_0x88b9('0x42')]=qs[_0x88b9('0x38')](_[_0x88b9('0x43')](_0x5efb5a[_0x88b9('0x36')],_0x29147b[_0x88b9('0x38')]));_0x558733[_0x88b9('0x6e')]=!![];if(_0x5efb5a[_0x88b9('0x36')][_0x88b9('0x44')]){_0x558733[_0x88b9('0x42')]=_[_0x88b9('0x4c')](_0x558733[_0x88b9('0x42')],{'$or':_[_0x88b9('0x31')](_0x558733[_0x88b9('0x3c')],function(_0x29f401){var _0x3e99e6={};_0x3e99e6[_0x29f401]={'$like':'%'+_0x5efb5a[_0x88b9('0x36')][_0x88b9('0x44')]+'%'};return _0x3e99e6;})});}_0x558733=_[_0x88b9('0x4c')]({},_0x558733,_0x5efb5a['options']);return _0x3752ea['getContacts'](_0x558733);}})[_0x88b9('0x2b')](respondWithResult(_0x2a116a,null))['catch'](handleError(_0x2a116a,null));};exports[_0x88b9('0x6f')]=function(_0x398216,_0x94ea90,_0x83793a){var _0x5c55fe;var _0x25392;var _0x458cdc;var _0x2cf0b0=_0x398216['params']['id'];csv_results=[];return db[_0x88b9('0x70')][_0x88b9('0x48')]({'attributes':['id',_0x88b9('0x2e')],'raw':!![],'order':[_0x88b9('0x71')]})[_0x88b9('0x2b')](function(_0x38e0d2){_0x5c55fe=_0x38e0d2;var _0xaaa092=_[_0x88b9('0x37')](db[_0x88b9('0x60')]['rawAttributes']);return db[_0x88b9('0x6b')][_0x88b9('0x48')]({'raw':!![],'attributes':['id',_0x88b9('0x72')]})[_0x88b9('0x2b')](function(_0x197226){_0x25392=_0x197226;var _0x45e012=squel[_0x88b9('0x73')]()['fields'](_0xaaa092)[_0x88b9('0x74')](_0x88b9('0x75'),'c')[_0x88b9('0x42')](_0x88b9('0x76'),_0x2cf0b0)[_0x88b9('0x42')](_0x88b9('0x77'))[_0x88b9('0x78')]();for(var _0x47f658=0x0;_0x47f658<_0x25392[_0x88b9('0x3d')];_0x47f658++){_0x45e012[_0x88b9('0x79')]('c.cf_'+_0x25392[_0x47f658]['id'],_0x88b9('0x7a')+_0x25392[_0x47f658][_0x88b9('0x72')]);}for(var _0x47f658=0x0;_0x47f658<_0x5c55fe[_0x88b9('0x3d')];_0x47f658++){_0x45e012[_0x88b9('0x79')](squel[_0x88b9('0x73')]()[_0x88b9('0x79')](_0x88b9('0x7b'))[_0x88b9('0x74')](_0x88b9('0x7c'))[_0x88b9('0x42')](_0x88b9('0x7d'),_0x5c55fe[_0x47f658]['id'])['where'](_0x88b9('0x7e')),'additionalPhone_'+_0x5c55fe[_0x47f658][_0x88b9('0x2e')]);_0x45e012[_0x88b9('0x79')](squel[_0x88b9('0x73')]()[_0x88b9('0x79')](_0x88b9('0x7f'))['from'](_0x88b9('0x7c'))[_0x88b9('0x42')](_0x88b9('0x7d'),_0x5c55fe[_0x47f658]['id'])[_0x88b9('0x42')](_0x88b9('0x7e')),'description_additionalPhone_'+_0x5c55fe[_0x47f658][_0x88b9('0x2e')]);}var _0xe4628b=[];_0xe4628b[_0x88b9('0x64')](_0x45e012['toString']());BPromise[_0x88b9('0x65')](_0xe4628b,handleQuery)[_0x88b9('0x2b')](function(_0x3d5a3b){handleQuery(_0x45e012['toString']());var _0x2a9080=csv_results[0x0];if(!_[_0x88b9('0x80')](_0x2a9080)){var _0x1be5ef=toCsv(_0x2a9080);var _0x132d30=Date['now']();fs['writeFileSync'](util[_0x88b9('0x81')]('/tmp/list_%d_%s.csv',_0x2cf0b0,_0x132d30),_0x1be5ef);_0x94ea90[_0x88b9('0x82')](_0x88b9('0x83'),_0x88b9('0x84')+util[_0x88b9('0x81')](_0x88b9('0x85'),_0x2cf0b0,_0x132d30));_0x94ea90[_0x88b9('0x82')](_0x88b9('0x86'),'text/csv');return _0x94ea90[_0x88b9('0x87')](util[_0x88b9('0x81')]('/tmp/list_%d_%s.csv',_0x2cf0b0,_0x132d30));}else{return _0x94ea90['sendStatus'](0xcc);}});});});};exports[_0x88b9('0x88')]=function(_0x562ddf,_0x226792,_0x2189b8){var _0x5c7bba;delete _0x562ddf[_0x88b9('0x4f')]['id'];return db[_0x88b9('0x32')]['findOne']({'where':{'id':_0x562ddf[_0x88b9('0x4b')]['id']}})[_0x88b9('0x2b')](handleEntityNotFound(_0x226792,null))[_0x88b9('0x2b')](function(_0x5369f0){if(_0x5369f0){return db['sequelize']['transaction'](function(_0x46bbe2){return db[_0x88b9('0x6b')][_0x88b9('0x4e')](_0x562ddf['body'],{'transaction':_0x46bbe2})[_0x88b9('0x2b')](function(_0x43e558){_0x5c7bba=_0x43e558;return _0x5369f0[_0x88b9('0x89')](_0x43e558,{'transaction':_0x46bbe2});})[_0x88b9('0x2b')](function(){var _0x2fb13b={'type':db[_0x88b9('0x8a')][_0x88b9('0x8b')],'transaction':_0x46bbe2};switch(_0x562ddf[_0x88b9('0x4f')]['type']){case _0x88b9('0x8c'):_0x2fb13b['type']=db[_0x88b9('0x8a')]['TEXT'];break;case _0x88b9('0x8d'):_0x2fb13b[_0x88b9('0x35')]=db[_0x88b9('0x8a')][_0x88b9('0x8e')];break;case'switch':_0x2fb13b[_0x88b9('0x35')]=db[_0x88b9('0x8a')][_0x88b9('0x8f')];_0x2fb13b['defaultValue']=![];break;default:}return db['sequelize'][_0x88b9('0x90')][_0x88b9('0x91')](_0x88b9('0x75'),util['format']('cf_%s',_0x5c7bba['id']),_0x2fb13b);})['then'](function(){return _0x5c7bba;});});}})[_0x88b9('0x2b')](respondWithResult(_0x226792,null))[_0x88b9('0x4a')](handleError(_0x226792,null));};exports['getCustomFields']=function(_0x1ff684,_0x269efb,_0x11d5af){var _0x5849ab={};var _0x234902={};var _0xd38ad9;var _0x2c858d;return db[_0x88b9('0x32')][_0x88b9('0x5c')]({'where':{'id':_0x1ff684[_0x88b9('0x4b')]['id']}})[_0x88b9('0x2b')](handleEntityNotFound(_0x269efb,null))[_0x88b9('0x2b')](function(_0x4e9d6c){if(_0x4e9d6c){_0xd38ad9=_0x4e9d6c;_0x234902[_0x88b9('0x3a')]=_[_0x88b9('0x37')](db[_0x88b9('0x6b')][_0x88b9('0x33')]);_0x234902[_0x88b9('0x36')]=_['keys'](_0x1ff684[_0x88b9('0x36')]);_0x234902[_0x88b9('0x38')]=_[_0x88b9('0x39')](_0x234902[_0x88b9('0x3a')],_0x234902[_0x88b9('0x36')]);_0x5849ab[_0x88b9('0x3c')]=_['intersection'](_0x234902[_0x88b9('0x3a')],qs[_0x88b9('0x3b')](_0x1ff684[_0x88b9('0x36')][_0x88b9('0x3b')]));_0x5849ab[_0x88b9('0x3c')]=_0x5849ab[_0x88b9('0x3c')]['length']?_0x5849ab[_0x88b9('0x3c')]:_0x234902[_0x88b9('0x3a')];_0x5849ab[_0x88b9('0x40')]=qs[_0x88b9('0x41')](_0x1ff684[_0x88b9('0x36')][_0x88b9('0x41')]);_0x5849ab[_0x88b9('0x42')]=qs[_0x88b9('0x38')](_[_0x88b9('0x43')](_0x1ff684[_0x88b9('0x36')],_0x234902[_0x88b9('0x38')]));_0x5849ab[_0x88b9('0x42')]=_[_0x88b9('0x4c')](_0x5849ab[_0x88b9('0x42')],{'$or':[{'ListId':_0x4e9d6c['id']},{'ListId':null}]});if(_0x1ff684['query'][_0x88b9('0x44')]){_0x5849ab[_0x88b9('0x42')]=_[_0x88b9('0x4c')](_0x5849ab[_0x88b9('0x42')],{'$or':_['map'](_0x5849ab['attributes'],function(_0x30bd30){var _0x18d694={};_0x18d694[_0x30bd30]={'$like':'%'+_0x1ff684[_0x88b9('0x36')]['filter']+'%'};return _0x18d694;})});}_0x5849ab=_[_0x88b9('0x4c')]({},_0x5849ab,_0x1ff684[_0x88b9('0x45')]);return db['CmCustomField'][_0x88b9('0x92')](_0x5849ab);}})['then'](respondWithResult(_0x269efb,null))[_0x88b9('0x4a')](handleError(_0x269efb,null));};exports[_0x88b9('0x93')]=function(_0x336372,_0x24382c){return db[_0x88b9('0x6b')][_0x88b9('0x92')]({'where':{'ListId':null}})['then'](handleEntityNotFound(_0x24382c,null))[_0x88b9('0x2b')](function(_0x2c6d3c){return _0x2c6d3c;})[_0x88b9('0x2b')](respondWithResult(_0x24382c,null))[_0x88b9('0x4a')](handleError(_0x24382c,null));};exports[_0x88b9('0x94')]=function(_0x476d90,_0x2f2105,_0x15776c){return db[_0x88b9('0x32')][_0x88b9('0x4d')]({'where':{'id':_0x476d90[_0x88b9('0x4b')]['id']}})[_0x88b9('0x2b')](handleEntityNotFound(_0x2f2105,null))[_0x88b9('0x2b')](function(_0x50d7a7){if(_0x50d7a7){return _0x50d7a7[_0x88b9('0x94')](_0x476d90[_0x88b9('0x4f')][_0x88b9('0x5f')],_[_0x88b9('0x95')](_0x476d90[_0x88b9('0x4f')],[_0x88b9('0x5f'),'id'])||{})['spread'](function(_0x5e6eb7){for(var _0x455e40=0x0;_0x455e40<_0x476d90['body'][_0x88b9('0x5f')][_0x88b9('0x3d')];_0x455e40+=0x1){socket['emit']('userCmList:save',{'UserId':Number(_0x476d90[_0x88b9('0x4f')][_0x88b9('0x5f')][_0x455e40]),'CmListId':Number(_0x476d90['params']['id'])});}return _0x5e6eb7;});}})['then'](respondWithResult(_0x2f2105,null))[_0x88b9('0x4a')](handleError(_0x2f2105,null));};exports[_0x88b9('0x96')]=function(_0x2bafdf,_0x3c7f8b,_0xe6caa){return db[_0x88b9('0x32')][_0x88b9('0x4d')]({'where':{'id':_0x2bafdf['params']['id']}})[_0x88b9('0x2b')](handleEntityNotFound(_0x3c7f8b,null))[_0x88b9('0x2b')](function(_0x5ec277){if(_0x5ec277){return _0x5ec277['removeAgents'](_0x2bafdf[_0x88b9('0x36')][_0x88b9('0x5f')])['then'](function(){if(_['isArray'](_0x2bafdf[_0x88b9('0x36')][_0x88b9('0x5f')])){for(var _0x8e7e16=0x0;_0x8e7e16<_0x2bafdf[_0x88b9('0x36')][_0x88b9('0x5f')][_0x88b9('0x3d')];_0x8e7e16+=0x1){socket['emit']('userCmList:remove',{'UserId':Number(_0x2bafdf[_0x88b9('0x36')]['ids'][_0x8e7e16]),'CmListId':Number(_0x2bafdf[_0x88b9('0x4b')]['id'])});}}else{socket[_0x88b9('0x97')]('userCmList:remove',{'UserId':Number(_0x2bafdf[_0x88b9('0x36')][_0x88b9('0x5f')]),'CmListId':Number(_0x2bafdf[_0x88b9('0x4b')]['id'])});}});}})[_0x88b9('0x2b')](respondWithStatusCode(_0x3c7f8b,null))[_0x88b9('0x4a')](handleError(_0x3c7f8b,null));};exports['getAgents']=function(_0x539848,_0x21f772,_0x297278){var _0x97312f={};var _0x521ac5={};var _0x15fb3b;var _0x3416bf;return db[_0x88b9('0x32')][_0x88b9('0x5c')]({'where':{'id':_0x539848['params']['id']}})[_0x88b9('0x2b')](handleEntityNotFound(_0x21f772,null))[_0x88b9('0x2b')](function(_0x11c0b0){if(_0x11c0b0){_0x15fb3b=_0x11c0b0;_0x521ac5[_0x88b9('0x3a')]=_[_0x88b9('0x37')](db[_0x88b9('0x98')][_0x88b9('0x33')]);_0x521ac5[_0x88b9('0x36')]=_[_0x88b9('0x37')](_0x539848[_0x88b9('0x36')]);_0x521ac5[_0x88b9('0x38')]=_[_0x88b9('0x39')](_0x521ac5[_0x88b9('0x3a')],_0x521ac5[_0x88b9('0x36')]);_0x97312f[_0x88b9('0x3c')]=_[_0x88b9('0x39')](_0x521ac5[_0x88b9('0x3a')],qs[_0x88b9('0x3b')](_0x539848['query'][_0x88b9('0x3b')]));_0x97312f[_0x88b9('0x3c')]=_0x97312f[_0x88b9('0x3c')][_0x88b9('0x3d')]?_0x97312f[_0x88b9('0x3c')]:_0x521ac5[_0x88b9('0x3a')];_0x97312f[_0x88b9('0x40')]=qs[_0x88b9('0x41')](_0x539848[_0x88b9('0x36')][_0x88b9('0x41')]);_0x97312f[_0x88b9('0x42')]=qs[_0x88b9('0x38')](_[_0x88b9('0x43')](_0x539848[_0x88b9('0x36')],_0x521ac5['filters']));if(_0x539848[_0x88b9('0x36')][_0x88b9('0x44')]){_0x97312f[_0x88b9('0x42')]=_['merge'](_0x97312f[_0x88b9('0x42')],{'$or':_[_0x88b9('0x31')](_0x97312f[_0x88b9('0x3c')],function(_0xd286c6){var _0x4a7ff8={};_0x4a7ff8[_0xd286c6]={'$like':'%'+_0x539848[_0x88b9('0x36')][_0x88b9('0x44')]+'%'};return _0x4a7ff8;})});}_0x97312f=_[_0x88b9('0x4c')]({},_0x97312f,_0x539848[_0x88b9('0x45')]);return _0x15fb3b[_0x88b9('0x99')](_0x97312f);}})[_0x88b9('0x2b')](function(_0x46d7db){if(_0x46d7db){_0x3416bf=_0x46d7db[_0x88b9('0x3d')];if(!_0x539848['query'][_0x88b9('0x3e')](_0x88b9('0x3f'))){_0x97312f[_0x88b9('0x24')]=qs['limit'](_0x539848[_0x88b9('0x36')]['limit']);_0x97312f[_0x88b9('0x22')]=qs[_0x88b9('0x22')](_0x539848[_0x88b9('0x36')][_0x88b9('0x22')]);}return _0x15fb3b[_0x88b9('0x99')](_0x97312f);}})[_0x88b9('0x2b')](function(_0x19e57e){if(_0x19e57e){return _0x19e57e?{'count':_0x3416bf,'rows':_0x19e57e}:null;}})['then'](respondWithResult(_0x21f772,null))[_0x88b9('0x4a')](handleError(_0x21f772,null));};function handleQuery(_0x5ce118){logger[_0x88b9('0x9a')](_0x5ce118);return db[_0x88b9('0x9b')]['query'](_0x5ce118)[_0x88b9('0x9c')](function(_0x148711){csv_results[_0x88b9('0x64')](_0x148711);})[_0x88b9('0x4a')](function(_0x3e848a){logger[_0x88b9('0x57')](_0x3e848a[_0x88b9('0x68')]);});}