Built motion from commit c0cdc9d8.|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 _0x012a=['findOne','findAll','removeDispositions','ids','tags','join','isArray','ListId','each','CmContact','omit','success','push','dataValues','errors','Malformed\x20request\x20syntax','getContacts','CmCustomField','CustomFields','concat','format','cf_%d','raw','getContactsCsv','ContactItemType','OrderBy','from','cm_contacts','c.ListId\x20=\x20?','c.deletedAt\x20is\x20null','field','c.cf_','customField_','alias','select','item','cm_contact_has_items','ItemTypeId\x20=\x20?','additionalPhone_','description','CmContactId\x20=\x20c.id','toString','isEmpty','/tmp/list_%d_%s.csv','setHeader','Content-disposition','attachment;\x20filename=','Content-type','text/csv','addCustomField','transaction','addCustomFields','Sequelize','TEXT','INTEGER','switch','BOOLEAN','defaultValue','sequelize','queryInterface','addColumn','getCustomFields','findAndCountAll','getGlobalCustomFields','addAgents','emit','userCmList:save','removeAgents','userCmList:remove','getAgents','User','info','eml-format','rimraf','zip-dir','moment','bluebird','mustache','util','path','to-csv','ejs','fs-extra','lodash','squel','crypto','desk.js','querystring','papaparse','ioredis','../../components/auth/service','../../components/parsers/qs','../../components/parsers/advancedSearch','../../config/logger','api','../../config/utils','../../config/environment','../../mysqldb','defaults','socket.io-emitter','redis','./cmList.socket','register','status','end','json','offset','undefined','limit','count','set','Content-Range','save','destroy','UserProfileResource','then','sendStatus','error','name','index','CmList','rawAttributes','fieldName','key','model','map','keys','query','filters','attributes','intersection','fields','hasOwnProperty','nolimit','order','sort','where','pick','filter','merge','type','VIRTUAL','includeAll','include','rows','catch','show','params','length','options','find','create','body','user','Unable\x20to\x20retrieve\x20the\x20current\x20user','role','get','Lists','userProfileId','autoAssociation','Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s','describe','addDisposition','Disposition'];(function(_0x5c752c,_0x19f6fb){var _0x31e85b=function(_0x43f4c9){while(--_0x43f4c9){_0x5c752c['push'](_0x5c752c['shift']());}};_0x31e85b(++_0x19f6fb);}(_0x012a,0xec));var _0xa012=function(_0x4e0eb6,_0x330aa6){_0x4e0eb6=_0x4e0eb6-0x0;var _0x575ae9=_0x012a[_0x4e0eb6];return _0x575ae9;};'use strict';var emlformat=require(_0xa012('0x0'));var rimraf=require(_0xa012('0x1'));var zipdir=require(_0xa012('0x2'));var jsonpatch=require('fast-json-patch');var rp=require('request-promise');var moment=require(_0xa012('0x3'));var BPromise=require(_0xa012('0x4'));var Mustache=require(_0xa012('0x5'));var util=require(_0xa012('0x6'));var path=require(_0xa012('0x7'));var sox=require('sox');var csv=require(_0xa012('0x8'));var ejs=require(_0xa012('0x9'));var fs=require('fs');var fs_extra=require(_0xa012('0xa'));var _=require(_0xa012('0xb'));var squel=require(_0xa012('0xc'));var crypto=require(_0xa012('0xd'));var jsforce=require('jsforce');var deskjs=require(_0xa012('0xe'));var toCsv=require(_0xa012('0x8'));var querystring=require(_0xa012('0xf'));var Papa=require(_0xa012('0x10'));var Redis=require(_0xa012('0x11'));var authService=require(_0xa012('0x12'));var qs=require(_0xa012('0x13'));var as=require(_0xa012('0x14'));var hardwareService=require('../../config/license/hardware');var logger=require(_0xa012('0x15'))(_0xa012('0x16'));var utils=require(_0xa012('0x17'));var config=require(_0xa012('0x18'));var licenseUtil=require('../../config/license/util');var db=require(_0xa012('0x19'))['db'];var csv_results;config['redis']=_[_0xa012('0x1a')](config['redis'],{'host':'localhost','port':0x18eb});var socket=require(_0xa012('0x1b'))(new Redis(config[_0xa012('0x1c')]));require(_0xa012('0x1d'))[_0xa012('0x1e')](socket);function respondWithStatusCode(_0xf69eae,_0x2cbdc8){_0x2cbdc8=_0x2cbdc8||0xcc;return function(_0x1b6e3b){if(_0x1b6e3b){return _0xf69eae['sendStatus'](_0x2cbdc8);}return _0xf69eae[_0xa012('0x1f')](_0x2cbdc8)[_0xa012('0x20')]();};}function respondWithResult(_0xbe58ad,_0x3ad62b){_0x3ad62b=_0x3ad62b||0xc8;return function(_0x49e8b0){if(_0x49e8b0){return _0xbe58ad[_0xa012('0x1f')](_0x3ad62b)[_0xa012('0x21')](_0x49e8b0);}};}function respondWithFilteredResult(_0x528ccf,_0x1ead9c){return function(_0x596f6f){if(_0x596f6f){var _0x5165ef=typeof _0x1ead9c[_0xa012('0x22')]===_0xa012('0x23')&&typeof _0x1ead9c[_0xa012('0x24')]===_0xa012('0x23');var _0x4d174a=_0x596f6f[_0xa012('0x25')];var _0x576241=_0x5165ef?0x0:_0x1ead9c[_0xa012('0x22')];var _0x5d261c=_0x5165ef?_0x596f6f['count']:_0x1ead9c[_0xa012('0x22')]+_0x1ead9c[_0xa012('0x24')];var _0x4ee93f;if(_0x5d261c>=_0x4d174a){_0x5d261c=_0x4d174a;_0x4ee93f=0xc8;}else{_0x4ee93f=0xce;}_0x528ccf[_0xa012('0x1f')](_0x4ee93f);return _0x528ccf[_0xa012('0x26')](_0xa012('0x27'),_0x576241+'-'+_0x5d261c+'/'+_0x4d174a)['json'](_0x596f6f);}return null;};}function patchUpdates(_0x2a0096){return function(_0x3d4806){try{jsonpatch['apply'](_0x3d4806,_0x2a0096,!![]);}catch(_0x4c0cb2){return BPromise['reject'](_0x4c0cb2);}return _0x3d4806[_0xa012('0x28')]();};}function saveUpdates(_0x414687,_0x8db466){return function(_0x3df8af){if(_0x3df8af){return _0x3df8af['update'](_0x414687)['then'](function(_0x2d6b62){return _0x2d6b62;});}return null;};}function removeEntity(_0x584ada,_0x34260e){return function(_0x139499){if(_0x139499){return _0x139499[_0xa012('0x29')]()['then'](function(){var _0x5b76e5=_0x139499['get']({'plain':!![]});var _0x1c418c='Lists';return db[_0xa012('0x2a')][_0xa012('0x29')]({'where':{'type':_0x1c418c,'resourceId':_0x5b76e5['id']}})[_0xa012('0x2b')](function(){return _0x139499;});})[_0xa012('0x2b')](function(){_0x584ada[_0xa012('0x1f')](0xcc)['end']();});}};}function handleEntityNotFound(_0x297971,_0x582f6d){return function(_0x58aae8){if(!_0x58aae8){_0x297971[_0xa012('0x2c')](0x194);}return _0x58aae8;};}function handleError(_0x1b30a2,_0x4f7779){_0x4f7779=_0x4f7779||0x1f4;return function(_0x7f4789){logger[_0xa012('0x2d')](_0x7f4789['stack']);if(_0x7f4789[_0xa012('0x2e')]){delete _0x7f4789['name'];}_0x1b30a2[_0xa012('0x1f')](_0x4f7779)['send'](_0x7f4789);};}exports[_0xa012('0x2f')]=function(_0x50923a,_0x27ebfb){var _0xc10475={},_0x17b9a5={},_0x16f720={'count':0x0,'rows':[]};var _0xd5a4b9=_['map'](db[_0xa012('0x30')][_0xa012('0x31')],function(_0x59d96a){return{'name':_0x59d96a[_0xa012('0x32')],'type':_0x59d96a['type'][_0xa012('0x33')]};});_0x17b9a5[_0xa012('0x34')]=_[_0xa012('0x35')](_0xd5a4b9,_0xa012('0x2e'));_0x17b9a5['query']=_[_0xa012('0x36')](_0x50923a[_0xa012('0x37')]);_0x17b9a5[_0xa012('0x38')]=_['intersection'](_0x17b9a5[_0xa012('0x34')],_0x17b9a5[_0xa012('0x37')]);_0xc10475[_0xa012('0x39')]=_[_0xa012('0x3a')](_0x17b9a5['model'],qs[_0xa012('0x3b')](_0x50923a[_0xa012('0x37')][_0xa012('0x3b')]));_0xc10475[_0xa012('0x39')]=_0xc10475[_0xa012('0x39')]['length']?_0xc10475[_0xa012('0x39')]:_0x17b9a5['model'];if(!_0x50923a['query'][_0xa012('0x3c')](_0xa012('0x3d'))){_0xc10475[_0xa012('0x24')]=qs[_0xa012('0x24')](_0x50923a[_0xa012('0x37')][_0xa012('0x24')]);_0xc10475['offset']=qs[_0xa012('0x22')](_0x50923a[_0xa012('0x37')]['offset']);}_0xc10475[_0xa012('0x3e')]=qs[_0xa012('0x3f')](_0x50923a[_0xa012('0x37')][_0xa012('0x3f')]);_0xc10475[_0xa012('0x40')]=qs[_0xa012('0x38')](_[_0xa012('0x41')](_0x50923a[_0xa012('0x37')],_0x17b9a5[_0xa012('0x38')]),_0xd5a4b9);if(_0x50923a[_0xa012('0x37')][_0xa012('0x42')]){_0xc10475[_0xa012('0x40')]=_[_0xa012('0x43')](_0xc10475[_0xa012('0x40')],{'$or':_[_0xa012('0x35')](_0xd5a4b9,function(_0x1d5c0b){if(_0x1d5c0b[_0xa012('0x44')]!==_0xa012('0x45')){var _0x3bc1cf={};_0x3bc1cf[_0x1d5c0b[_0xa012('0x2e')]]={'$like':'%'+_0x50923a[_0xa012('0x37')]['filter']+'%'};return _0x3bc1cf;}})});}_0xc10475=_[_0xa012('0x43')]({},_0xc10475,_0x50923a['options']);var _0x2f0412={'where':_0xc10475[_0xa012('0x40')]};return db[_0xa012('0x30')][_0xa012('0x25')](_0x2f0412)[_0xa012('0x2b')](function(_0x12c020){_0x16f720[_0xa012('0x25')]=_0x12c020;if(_0x50923a[_0xa012('0x37')][_0xa012('0x46')]){_0xc10475[_0xa012('0x47')]=[{'all':!![]}];}return db[_0xa012('0x30')]['findAll'](_0xc10475);})[_0xa012('0x2b')](function(_0x200e43){_0x16f720[_0xa012('0x48')]=_0x200e43;return _0x16f720;})[_0xa012('0x2b')](respondWithFilteredResult(_0x27ebfb,_0xc10475))[_0xa012('0x49')](handleError(_0x27ebfb,null));};exports[_0xa012('0x4a')]=function(_0x28eae6,_0x5d51cf){var _0x233a60={'raw':![],'where':{'id':_0x28eae6[_0xa012('0x4b')]['id']}},_0x5bf288={};_0x5bf288['model']=_['keys'](db['CmList'][_0xa012('0x31')]);_0x5bf288[_0xa012('0x37')]=_['keys'](_0x28eae6['query']);_0x5bf288[_0xa012('0x38')]=_[_0xa012('0x3a')](_0x5bf288[_0xa012('0x34')],_0x5bf288[_0xa012('0x37')]);_0x233a60[_0xa012('0x39')]=_[_0xa012('0x3a')](_0x5bf288['model'],qs['fields'](_0x28eae6[_0xa012('0x37')][_0xa012('0x3b')]));_0x233a60['attributes']=_0x233a60[_0xa012('0x39')][_0xa012('0x4c')]?_0x233a60[_0xa012('0x39')]:_0x5bf288[_0xa012('0x34')];if(_0x28eae6['query'][_0xa012('0x46')]){_0x233a60[_0xa012('0x47')]=[{'all':!![]}];}_0x233a60=_['merge']({},_0x233a60,_0x28eae6[_0xa012('0x4d')]);return db[_0xa012('0x30')][_0xa012('0x4e')](_0x233a60)[_0xa012('0x2b')](handleEntityNotFound(_0x5d51cf,null))[_0xa012('0x2b')](respondWithResult(_0x5d51cf,null))[_0xa012('0x49')](handleError(_0x5d51cf,null));};exports[_0xa012('0x4f')]=function(_0x14f525,_0x5427f3){return db[_0xa012('0x30')][_0xa012('0x4f')](_0x14f525[_0xa012('0x50')],{})['then'](function(_0x14735a){var _0x289e20=_0x14f525[_0xa012('0x51')]['get']({'plain':!![]});if(!_0x289e20)throw new Error(_0xa012('0x52'));if(_0x289e20[_0xa012('0x53')]===_0xa012('0x51')){var _0x883537=_0x14735a[_0xa012('0x54')]({'plain':!![]});var _0x5569ed=_0xa012('0x55');return db['UserProfileSection'][_0xa012('0x4e')]({'where':{'name':_0x5569ed,'userProfileId':_0x289e20[_0xa012('0x56')]},'raw':!![]})['then'](function(_0x34e000){if(_0x34e000&&_0x34e000[_0xa012('0x57')]===0x0){return db[_0xa012('0x2a')][_0xa012('0x4f')]({'name':_0x883537[_0xa012('0x2e')],'resourceId':_0x883537['id'],'type':_0x34e000[_0xa012('0x2e')],'sectionId':_0x34e000['id']},{})[_0xa012('0x2b')](function(){return _0x14735a;});}else{return _0x14735a;}})[_0xa012('0x49')](function(_0x12b2f7){logger[_0xa012('0x2d')](_0xa012('0x58'),_0x12b2f7);throw _0x12b2f7;});}return _0x14735a;})[_0xa012('0x2b')](respondWithResult(_0x5427f3,0xc9))[_0xa012('0x49')](handleError(_0x5427f3,null));};exports['update']=function(_0x14b757,_0x3ae13f){if(_0x14b757['body']['id']){delete _0x14b757['body']['id'];}return db[_0xa012('0x30')][_0xa012('0x4e')]({'where':{'id':_0x14b757[_0xa012('0x4b')]['id']}})[_0xa012('0x2b')](handleEntityNotFound(_0x3ae13f,null))['then'](saveUpdates(_0x14b757[_0xa012('0x50')],null))[_0xa012('0x2b')](respondWithResult(_0x3ae13f,null))[_0xa012('0x49')](handleError(_0x3ae13f,null));};exports['destroy']=function(_0xccf483,_0x47e964){return db[_0xa012('0x30')][_0xa012('0x4e')]({'where':{'id':_0xccf483[_0xa012('0x4b')]['id']}})['then'](handleEntityNotFound(_0x47e964,null))[_0xa012('0x2b')](removeEntity(_0x47e964,null))[_0xa012('0x49')](handleError(_0x47e964,null));};exports[_0xa012('0x59')]=function(_0x591f7d,_0x201c6e){return db[_0xa012('0x30')]['describe']()[_0xa012('0x2b')](respondWithResult(_0x201c6e,null))[_0xa012('0x49')](handleError(_0x201c6e,null));};exports[_0xa012('0x5a')]=function(_0x211a1d,_0x31ff59,_0x563c49){if(_0x211a1d['body']['id']){delete _0x211a1d[_0xa012('0x50')]['id'];}return db[_0xa012('0x30')]['find']({'where':{'id':_0x211a1d[_0xa012('0x4b')]['id']}})[_0xa012('0x2b')](handleEntityNotFound(_0x31ff59,null))['then'](function(_0x34c643){if(_0x34c643){_0x211a1d[_0xa012('0x50')]['ListId']=_0x34c643['id'];return db[_0xa012('0x5b')][_0xa012('0x4f')](_0x211a1d[_0xa012('0x50')]);}})[_0xa012('0x2b')](respondWithResult(_0x31ff59,null))[_0xa012('0x49')](handleError(_0x31ff59,null));};exports['getDispositions']=function(_0x4579ae,_0x58f937,_0x509941){var _0x598421={'raw':![],'where':{}};var _0x4f28e6={};var _0x300a6a={'count':0x0,'rows':[]};return db[_0xa012('0x30')][_0xa012('0x5c')]({'where':{'id':_0x4579ae[_0xa012('0x4b')]['id']}})[_0xa012('0x2b')](handleEntityNotFound(_0x58f937,null))['then'](function(_0x2095cc){if(_0x2095cc){_0x4f28e6['model']=_[_0xa012('0x36')](db[_0xa012('0x5b')][_0xa012('0x31')]);_0x4f28e6[_0xa012('0x37')]=_[_0xa012('0x36')](_0x4579ae['query']);_0x4f28e6[_0xa012('0x38')]=_[_0xa012('0x3a')](_0x4f28e6[_0xa012('0x34')],_0x4f28e6[_0xa012('0x37')]);_0x598421['attributes']=_[_0xa012('0x3a')](_0x4f28e6[_0xa012('0x34')],qs['fields'](_0x4579ae[_0xa012('0x37')][_0xa012('0x3b')]));_0x598421['attributes']=_0x598421['attributes']['length']?_0x598421[_0xa012('0x39')]:_0x4f28e6['model'];if(!_0x4579ae[_0xa012('0x37')][_0xa012('0x3c')]('nolimit')){_0x598421['limit']=qs[_0xa012('0x24')](_0x4579ae[_0xa012('0x37')][_0xa012('0x24')]);_0x598421[_0xa012('0x22')]=qs[_0xa012('0x22')](_0x4579ae[_0xa012('0x37')]['offset']);}_0x598421[_0xa012('0x3e')]=qs['sort'](_0x4579ae[_0xa012('0x37')][_0xa012('0x3f')]);_0x598421['where']=qs[_0xa012('0x38')](_[_0xa012('0x41')](_0x4579ae[_0xa012('0x37')],_0x4f28e6[_0xa012('0x38')]));_0x598421['where']['ListId']=_0x2095cc['id'];if(_0x4579ae[_0xa012('0x37')][_0xa012('0x42')]){_0x598421[_0xa012('0x40')]=_[_0xa012('0x43')](_0x598421['where'],{'$or':_['map'](_0x598421[_0xa012('0x39')],function(_0x457d3d){var _0x3e052d={};_0x3e052d[_0x457d3d]={'$like':'%'+_0x4579ae['query']['filter']+'%'};return _0x3e052d;})});}_0x598421=_[_0xa012('0x43')]({},_0x598421,_0x4579ae[_0xa012('0x4d')]);return db[_0xa012('0x5b')][_0xa012('0x25')]({'where':_0x598421[_0xa012('0x40')]})[_0xa012('0x2b')](function(_0x41a9dd){_0x300a6a['count']=_0x41a9dd;if(_0x4579ae['query'][_0xa012('0x46')]){_0x598421['include']=[{'all':!![]}];}return db[_0xa012('0x5b')][_0xa012('0x5d')](_0x598421);})[_0xa012('0x2b')](function(_0x47854d){_0x300a6a[_0xa012('0x48')]=_0x47854d;return _0x300a6a;});}})['then'](respondWithFilteredResult(_0x58f937,_0x598421))[_0xa012('0x49')](handleError(_0x58f937,null));};exports[_0xa012('0x5e')]=function(_0xd28f4e,_0x1ae0f1,_0x2eb9db){return db[_0xa012('0x30')][_0xa012('0x4e')]({'where':{'id':_0xd28f4e['params']['id']}})[_0xa012('0x2b')](handleEntityNotFound(_0x1ae0f1,null))[_0xa012('0x2b')](function(_0x25aeba){if(_0x25aeba){return _0x25aeba['removeDispositions'](_0xd28f4e[_0xa012('0x37')][_0xa012('0x5f')]);}})['then'](respondWithStatusCode(_0x1ae0f1,null))['catch'](handleError(_0x1ae0f1,null));};exports['addContacts']=function(_0x228d16,_0x5f1780,_0x29fe8b){return db[_0xa012('0x30')]['find']({'where':{'id':_0x228d16[_0xa012('0x4b')]['id']}})['then'](handleEntityNotFound(_0x5f1780,null))['then'](function(_0x3a3b14){if(_0x3a3b14){var _0x1bf363=[];var _0x453f46={'success':[],'errors':[]};return db['CmContact']['describe']()[_0xa012('0x2b')](function(_0x37b0da){if(_0x228d16[_0xa012('0x50')][_0xa012('0x60')]&&_['isArray'](_0x228d16[_0xa012('0x50')][_0xa012('0x60')])){if(_0x228d16[_0xa012('0x50')][_0xa012('0x60')][_0xa012('0x4c')]){_0x228d16[_0xa012('0x50')]['tags']=_0x228d16['body'][_0xa012('0x60')][_0xa012('0x61')](';')+';';}else{_0x228d16[_0xa012('0x50')][_0xa012('0x60')]=null;}}else{_0x228d16['body'][_0xa012('0x60')]=null;}if(_0x228d16['body']&&_[_0xa012('0x62')](_0x228d16[_0xa012('0x50')])){for(var _0x21a0eb=0x0;_0x21a0eb<_0x228d16[_0xa012('0x50')]['length'];_0x21a0eb+=0x1){_0x228d16[_0xa012('0x50')][_0x21a0eb][_0xa012('0x63')]=_0x228d16[_0xa012('0x4b')]['id'];_0x1bf363['push'](_0x228d16[_0xa012('0x50')][_0x21a0eb]);}return BPromise[_0xa012('0x64')](_0x1bf363,function(_0x341ec2){return db[_0xa012('0x65')][_0xa012('0x4f')](_[_0xa012('0x66')](_0x341ec2,['ids','id'])||{},{'fields':_['keys'](_0x37b0da),'raw':!![]})[_0xa012('0x2b')](function(_0x4b383a){_0x453f46[_0xa012('0x67')][_0xa012('0x68')](_0x4b383a[_0xa012('0x69')]);})[_0xa012('0x49')](function(_0x4be20e){_0x453f46[_0xa012('0x6a')][_0xa012('0x68')]({'data':_0x341ec2,'error':_0x4be20e['message']});});})[_0xa012('0x2b')](function(_0x41263e){return _0x453f46;})['catch'](function(_0x486de5){return _0x486de5;});}else{_0x5f1780[_0xa012('0x1f')](0x190)[_0xa012('0x21')]({'message':_0xa012('0x6b')});}});}})[_0xa012('0x2b')](respondWithResult(_0x5f1780,null))[_0xa012('0x49')](handleError(_0x5f1780,null));};exports[_0xa012('0x6c')]=function(_0x89f6ed,_0x3fcc5e,_0x56da89){var _0xa244cf;return db['CmList'][_0xa012('0x4e')]({'where':{'id':_0x89f6ed[_0xa012('0x4b')]['id']},'include':[{'model':db[_0xa012('0x6d')],'as':_0xa012('0x6e')}]})[_0xa012('0x2b')](handleEntityNotFound(_0x3fcc5e,null))[_0xa012('0x2b')](function(_0xdbbdf4){if(_0xdbbdf4){_0xa244cf=_0xdbbdf4;return db[_0xa012('0x65')]['rawAttributes'];}})[_0xa012('0x2b')](function(_0x420f7e){if(_0x420f7e){var _0x493fbb={};var _0x48dda7={};_0x48dda7[_0xa012('0x34')]=_[_0xa012('0x6f')](_['keys'](_0x420f7e),_[_0xa012('0x35')](_0xa244cf[_0xa012('0x6e')],function(_0x56378a){return util[_0xa012('0x70')](_0xa012('0x71'),_0x56378a['id']);}));_0x48dda7[_0xa012('0x37')]=_[_0xa012('0x36')](_0x89f6ed[_0xa012('0x37')]);_0x48dda7[_0xa012('0x38')]=_['intersection'](_0x48dda7['model'],_0x48dda7[_0xa012('0x37')]);_0x493fbb[_0xa012('0x39')]=_[_0xa012('0x3a')](_0x48dda7['model'],qs[_0xa012('0x3b')](_0x89f6ed['query'][_0xa012('0x3b')]));_0x493fbb[_0xa012('0x39')]=_0x493fbb['attributes']['length']?_0x493fbb[_0xa012('0x39')]:_0x48dda7[_0xa012('0x34')];if(!_0x89f6ed[_0xa012('0x37')][_0xa012('0x3c')]('nolimit')){_0x493fbb[_0xa012('0x24')]=qs['limit'](_0x89f6ed[_0xa012('0x37')][_0xa012('0x24')]);_0x493fbb['offset']=qs[_0xa012('0x22')](_0x89f6ed[_0xa012('0x37')][_0xa012('0x22')]);}_0x493fbb[_0xa012('0x3e')]=qs[_0xa012('0x3f')](_0x89f6ed[_0xa012('0x37')][_0xa012('0x3f')]);_0x493fbb[_0xa012('0x40')]=qs[_0xa012('0x38')](_['pick'](_0x89f6ed[_0xa012('0x37')],_0x48dda7[_0xa012('0x38')]));_0x493fbb[_0xa012('0x72')]=!![];if(_0x89f6ed[_0xa012('0x37')][_0xa012('0x42')]){_0x493fbb[_0xa012('0x40')]=_[_0xa012('0x43')](_0x493fbb[_0xa012('0x40')],{'$or':_[_0xa012('0x35')](_0x493fbb['attributes'],function(_0x36ed92){var _0x3312d1={};_0x3312d1[_0x36ed92]={'$like':'%'+_0x89f6ed['query']['filter']+'%'};return _0x3312d1;})});}_0x493fbb=_[_0xa012('0x43')]({},_0x493fbb,_0x89f6ed[_0xa012('0x4d')]);return _0xa244cf[_0xa012('0x6c')](_0x493fbb);}})[_0xa012('0x2b')](respondWithResult(_0x3fcc5e,null))['catch'](handleError(_0x3fcc5e,null));};exports[_0xa012('0x73')]=function(_0x3696b9,_0x4fc6b2,_0x7e6e0d){var _0x8ba5bf;var _0x354156;var _0x45a1d6;var _0x11c2fc=_0x3696b9[_0xa012('0x4b')]['id'];csv_results=[];return db[_0xa012('0x74')][_0xa012('0x5d')]({'attributes':['id',_0xa012('0x2e')],'raw':!![],'order':[_0xa012('0x75')]})[_0xa012('0x2b')](function(_0x442d0d){_0x8ba5bf=_0x442d0d;var _0x128be2=_[_0xa012('0x36')](db[_0xa012('0x65')][_0xa012('0x31')]);return db[_0xa012('0x6d')]['findAll']({'raw':!![],'attributes':['id','alias']})[_0xa012('0x2b')](function(_0x1cf247){_0x354156=_0x1cf247;var _0xe5e137=squel['select']()[_0xa012('0x3b')](_0x128be2)[_0xa012('0x76')](_0xa012('0x77'),'c')[_0xa012('0x40')](_0xa012('0x78'),_0x11c2fc)['where'](_0xa012('0x79'))['distinct']();for(var _0x1f1479=0x0;_0x1f1479<_0x354156['length'];_0x1f1479++){_0xe5e137[_0xa012('0x7a')](_0xa012('0x7b')+_0x354156[_0x1f1479]['id'],_0xa012('0x7c')+_0x354156[_0x1f1479][_0xa012('0x7d')]);}for(var _0x1f1479=0x0;_0x1f1479<_0x8ba5bf['length'];_0x1f1479++){_0xe5e137[_0xa012('0x7a')](squel[_0xa012('0x7e')]()[_0xa012('0x7a')](_0xa012('0x7f'))[_0xa012('0x76')](_0xa012('0x80'))[_0xa012('0x40')](_0xa012('0x81'),_0x8ba5bf[_0x1f1479]['id'])[_0xa012('0x40')]('CmContactId\x20=\x20c.id'),_0xa012('0x82')+_0x8ba5bf[_0x1f1479][_0xa012('0x2e')]);_0xe5e137[_0xa012('0x7a')](squel[_0xa012('0x7e')]()['field'](_0xa012('0x83'))[_0xa012('0x76')](_0xa012('0x80'))[_0xa012('0x40')](_0xa012('0x81'),_0x8ba5bf[_0x1f1479]['id'])['where'](_0xa012('0x84')),'description_additionalPhone_'+_0x8ba5bf[_0x1f1479][_0xa012('0x2e')]);}var _0x41db0b=[];_0x41db0b[_0xa012('0x68')](_0xe5e137['toString']());BPromise[_0xa012('0x64')](_0x41db0b,handleQuery)[_0xa012('0x2b')](function(_0x5e6ad5){handleQuery(_0xe5e137[_0xa012('0x85')]());var _0x1e1f09=csv_results[0x0];if(!_[_0xa012('0x86')](_0x1e1f09)){var _0xe85bd1=toCsv(_0x1e1f09);var _0x3a9a0f=Date['now']();fs['writeFileSync'](util[_0xa012('0x70')](_0xa012('0x87'),_0x11c2fc,_0x3a9a0f),_0xe85bd1);_0x4fc6b2[_0xa012('0x88')](_0xa012('0x89'),_0xa012('0x8a')+util[_0xa012('0x70')]('list_%d_%s.csv',_0x11c2fc,_0x3a9a0f));_0x4fc6b2['setHeader'](_0xa012('0x8b'),_0xa012('0x8c'));return _0x4fc6b2['download'](util[_0xa012('0x70')](_0xa012('0x87'),_0x11c2fc,_0x3a9a0f));}else{return _0x4fc6b2['sendStatus'](0xcc);}});});});};exports[_0xa012('0x8d')]=function(_0x102573,_0x2633a2,_0xee86a0){var _0x3357d9;delete _0x102573[_0xa012('0x50')]['id'];return db[_0xa012('0x30')]['findOne']({'where':{'id':_0x102573['params']['id']}})['then'](handleEntityNotFound(_0x2633a2,null))[_0xa012('0x2b')](function(_0x2d9102){if(_0x2d9102){return db['sequelize'][_0xa012('0x8e')](function(_0x3c88d0){return db[_0xa012('0x6d')][_0xa012('0x4f')](_0x102573[_0xa012('0x50')],{'transaction':_0x3c88d0})[_0xa012('0x2b')](function(_0x216e2b){_0x3357d9=_0x216e2b;return _0x2d9102[_0xa012('0x8f')](_0x216e2b,{'transaction':_0x3c88d0});})[_0xa012('0x2b')](function(){var _0x201c19={'type':db[_0xa012('0x90')]['TEXT'],'transaction':_0x3c88d0};switch(_0x102573['body'][_0xa012('0x44')]){case'text':_0x201c19[_0xa012('0x44')]=db[_0xa012('0x90')][_0xa012('0x91')];break;case'number':_0x201c19[_0xa012('0x44')]=db[_0xa012('0x90')][_0xa012('0x92')];break;case _0xa012('0x93'):_0x201c19[_0xa012('0x44')]=db[_0xa012('0x90')][_0xa012('0x94')];_0x201c19[_0xa012('0x95')]=![];break;default:}return db[_0xa012('0x96')][_0xa012('0x97')][_0xa012('0x98')]('cm_contacts',util['format']('cf_%s',_0x3357d9['id']),_0x201c19);})[_0xa012('0x2b')](function(){return _0x3357d9;});});}})['then'](respondWithResult(_0x2633a2,null))[_0xa012('0x49')](handleError(_0x2633a2,null));};exports[_0xa012('0x99')]=function(_0x50838d,_0x224f4c,_0x29d7c7){var _0x15a4be={};var _0x6cf527={};var _0x122d08;var _0x2c4d87;return db[_0xa012('0x30')][_0xa012('0x5c')]({'where':{'id':_0x50838d[_0xa012('0x4b')]['id']}})[_0xa012('0x2b')](handleEntityNotFound(_0x224f4c,null))[_0xa012('0x2b')](function(_0x5976d5){if(_0x5976d5){_0x122d08=_0x5976d5;_0x6cf527[_0xa012('0x34')]=_[_0xa012('0x36')](db[_0xa012('0x6d')][_0xa012('0x31')]);_0x6cf527['query']=_[_0xa012('0x36')](_0x50838d[_0xa012('0x37')]);_0x6cf527[_0xa012('0x38')]=_['intersection'](_0x6cf527[_0xa012('0x34')],_0x6cf527[_0xa012('0x37')]);_0x15a4be[_0xa012('0x39')]=_[_0xa012('0x3a')](_0x6cf527['model'],qs[_0xa012('0x3b')](_0x50838d[_0xa012('0x37')]['fields']));_0x15a4be[_0xa012('0x39')]=_0x15a4be[_0xa012('0x39')][_0xa012('0x4c')]?_0x15a4be['attributes']:_0x6cf527['model'];_0x15a4be['order']=qs['sort'](_0x50838d[_0xa012('0x37')][_0xa012('0x3f')]);_0x15a4be[_0xa012('0x40')]=qs['filters'](_['pick'](_0x50838d['query'],_0x6cf527[_0xa012('0x38')]));_0x15a4be[_0xa012('0x40')]=_['merge'](_0x15a4be[_0xa012('0x40')],{'$or':[{'ListId':_0x5976d5['id']},{'ListId':null}]});if(_0x50838d[_0xa012('0x37')][_0xa012('0x42')]){_0x15a4be['where']=_[_0xa012('0x43')](_0x15a4be['where'],{'$or':_[_0xa012('0x35')](_0x15a4be[_0xa012('0x39')],function(_0x3b33e4){var _0x30d38b={};_0x30d38b[_0x3b33e4]={'$like':'%'+_0x50838d[_0xa012('0x37')][_0xa012('0x42')]+'%'};return _0x30d38b;})});}_0x15a4be=_[_0xa012('0x43')]({},_0x15a4be,_0x50838d[_0xa012('0x4d')]);return db[_0xa012('0x6d')][_0xa012('0x9a')](_0x15a4be);}})[_0xa012('0x2b')](respondWithResult(_0x224f4c,null))[_0xa012('0x49')](handleError(_0x224f4c,null));};exports[_0xa012('0x9b')]=function(_0x21aa28,_0xc1572c){return db[_0xa012('0x6d')]['findAndCountAll']({'where':{'ListId':null}})[_0xa012('0x2b')](handleEntityNotFound(_0xc1572c,null))['then'](function(_0x5615a5){return _0x5615a5;})['then'](respondWithResult(_0xc1572c,null))[_0xa012('0x49')](handleError(_0xc1572c,null));};exports[_0xa012('0x9c')]=function(_0x157148,_0x4d0050,_0x1c4713){return db[_0xa012('0x30')]['find']({'where':{'id':_0x157148[_0xa012('0x4b')]['id']}})[_0xa012('0x2b')](handleEntityNotFound(_0x4d0050,null))[_0xa012('0x2b')](function(_0x393cbf){if(_0x393cbf){return _0x393cbf[_0xa012('0x9c')](_0x157148[_0xa012('0x50')][_0xa012('0x5f')],_['omit'](_0x157148[_0xa012('0x50')],[_0xa012('0x5f'),'id'])||{})['spread'](function(_0x5a89bc){for(var _0x40f6cd=0x0;_0x40f6cd<_0x157148[_0xa012('0x50')][_0xa012('0x5f')][_0xa012('0x4c')];_0x40f6cd+=0x1){socket[_0xa012('0x9d')](_0xa012('0x9e'),{'UserId':Number(_0x157148[_0xa012('0x50')]['ids'][_0x40f6cd]),'CmListId':Number(_0x157148[_0xa012('0x4b')]['id'])});}return _0x5a89bc;});}})['then'](respondWithResult(_0x4d0050,null))[_0xa012('0x49')](handleError(_0x4d0050,null));};exports[_0xa012('0x9f')]=function(_0x43869d,_0x4051b2,_0x58ac51){return db[_0xa012('0x30')][_0xa012('0x4e')]({'where':{'id':_0x43869d[_0xa012('0x4b')]['id']}})[_0xa012('0x2b')](handleEntityNotFound(_0x4051b2,null))[_0xa012('0x2b')](function(_0x423968){if(_0x423968){return _0x423968[_0xa012('0x9f')](_0x43869d['query'][_0xa012('0x5f')])[_0xa012('0x2b')](function(){if(_[_0xa012('0x62')](_0x43869d[_0xa012('0x37')][_0xa012('0x5f')])){for(var _0x2ff584=0x0;_0x2ff584<_0x43869d[_0xa012('0x37')][_0xa012('0x5f')][_0xa012('0x4c')];_0x2ff584+=0x1){socket['emit'](_0xa012('0xa0'),{'UserId':Number(_0x43869d[_0xa012('0x37')][_0xa012('0x5f')][_0x2ff584]),'CmListId':Number(_0x43869d['params']['id'])});}}else{socket[_0xa012('0x9d')](_0xa012('0xa0'),{'UserId':Number(_0x43869d['query'][_0xa012('0x5f')]),'CmListId':Number(_0x43869d['params']['id'])});}});}})[_0xa012('0x2b')](respondWithStatusCode(_0x4051b2,null))[_0xa012('0x49')](handleError(_0x4051b2,null));};exports[_0xa012('0xa1')]=function(_0x78d51c,_0x332f53,_0x41b85a){var _0x486be4={};var _0x5b30be={};var _0x5ff8fd;var _0x5772a6;return db[_0xa012('0x30')]['findOne']({'where':{'id':_0x78d51c[_0xa012('0x4b')]['id']}})[_0xa012('0x2b')](handleEntityNotFound(_0x332f53,null))['then'](function(_0x3ff002){if(_0x3ff002){_0x5ff8fd=_0x3ff002;_0x5b30be['model']=_[_0xa012('0x36')](db[_0xa012('0xa2')][_0xa012('0x31')]);_0x5b30be[_0xa012('0x37')]=_['keys'](_0x78d51c[_0xa012('0x37')]);_0x5b30be[_0xa012('0x38')]=_[_0xa012('0x3a')](_0x5b30be[_0xa012('0x34')],_0x5b30be[_0xa012('0x37')]);_0x486be4[_0xa012('0x39')]=_[_0xa012('0x3a')](_0x5b30be[_0xa012('0x34')],qs[_0xa012('0x3b')](_0x78d51c['query'][_0xa012('0x3b')]));_0x486be4[_0xa012('0x39')]=_0x486be4[_0xa012('0x39')][_0xa012('0x4c')]?_0x486be4['attributes']:_0x5b30be[_0xa012('0x34')];_0x486be4[_0xa012('0x3e')]=qs['sort'](_0x78d51c[_0xa012('0x37')][_0xa012('0x3f')]);_0x486be4['where']=qs[_0xa012('0x38')](_[_0xa012('0x41')](_0x78d51c['query'],_0x5b30be['filters']));if(_0x78d51c['query']['filter']){_0x486be4[_0xa012('0x40')]=_[_0xa012('0x43')](_0x486be4[_0xa012('0x40')],{'$or':_[_0xa012('0x35')](_0x486be4['attributes'],function(_0x33a380){var _0x95f12f={};_0x95f12f[_0x33a380]={'$like':'%'+_0x78d51c['query']['filter']+'%'};return _0x95f12f;})});}_0x486be4=_[_0xa012('0x43')]({},_0x486be4,_0x78d51c[_0xa012('0x4d')]);return _0x5ff8fd[_0xa012('0xa1')](_0x486be4);}})[_0xa012('0x2b')](function(_0x277ef8){if(_0x277ef8){_0x5772a6=_0x277ef8[_0xa012('0x4c')];if(!_0x78d51c[_0xa012('0x37')]['hasOwnProperty'](_0xa012('0x3d'))){_0x486be4['limit']=qs[_0xa012('0x24')](_0x78d51c['query'][_0xa012('0x24')]);_0x486be4['offset']=qs['offset'](_0x78d51c[_0xa012('0x37')][_0xa012('0x22')]);}return _0x5ff8fd[_0xa012('0xa1')](_0x486be4);}})[_0xa012('0x2b')](function(_0x482ed7){if(_0x482ed7){return _0x482ed7?{'count':_0x5772a6,'rows':_0x482ed7}:null;}})[_0xa012('0x2b')](respondWithResult(_0x332f53,null))[_0xa012('0x49')](handleError(_0x332f53,null));};function handleQuery(_0xffefc3){logger[_0xa012('0xa3')](_0xffefc3);return db['sequelize'][_0xa012('0x37')](_0xffefc3)['spread'](function(_0xe815fa){csv_results['push'](_0xe815fa);})[_0xa012('0x49')](function(_0x118f89){logger[_0xa012('0x2d')](_0x118f89['message']);});}