a17e568cbc05fb8340414990e7f0ed9d01973867
[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 _0x7d27=['removeAgents','userCmList:remove','User','getAgents','eml-format','rimraf','zip-dir','fast-json-patch','request-promise','moment','bluebird','mustache','util','path','sox','to-csv','ejs','lodash','squel','crypto','jsforce','desk.js','querystring','papaparse','ioredis','../../components/parsers/advancedSearch','../../config/license/hardware','../../config/logger','api','../../config/utils','../../mysqldb','redis','defaults','socket.io-emitter','./cmList.socket','register','status','end','offset','undefined','limit','count','set','Content-Range','apply','reject','update','then','Lists','UserProfileResource','destroy','sendStatus','error','name','send','index','CmList','rawAttributes','type','model','keys','query','filters','intersection','fields','attributes','length','hasOwnProperty','nolimit','order','sort','where','filter','merge','VIRTUAL','includeAll','include','catch','params','options','find','create','body','user','get','Unable\x20to\x20retrieve\x20the\x20current\x20user','role','userProfileId','autoAssociation','Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s','describe','addDisposition','Disposition','getDispositions','findOne','ListId','map','findAll','removeDispositions','ids','addContacts','CmContact','tags','isArray','join','each','omit','success','push','dataValues','errors','message','json','Malformed\x20request\x20syntax','getContacts','CmCustomField','concat','CustomFields','pick','ContactItemType','OrderBy','alias','cm_contacts','c.deletedAt\x20is\x20null','field','c.cf_','customField_','select','item','from','cm_contact_has_items','CmContactId\x20=\x20c.id','ItemTypeId\x20=\x20?','toString','writeFileSync','/tmp/list_%d_%s.csv','setHeader','attachment;\x20filename=','list_%d_%s.csv','text/csv','download','transaction','addCustomFields','Sequelize','TEXT','text','number','INTEGER','switch','BOOLEAN','sequelize','queryInterface','addColumn','format','findAndCountAll','getGlobalCustomFields','addAgents','spread','emit','userCmList:save'];(function(_0x46c419,_0x1d1d03){var _0x4e9583=function(_0x1cf988){while(--_0x1cf988){_0x46c419['push'](_0x46c419['shift']());}};_0x4e9583(++_0x1d1d03);}(_0x7d27,0x1e4));var _0x77d2=function(_0x50b293,_0x2186e3){_0x50b293=_0x50b293-0x0;var _0x36c290=_0x7d27[_0x50b293];return _0x36c290;};'use strict';var emlformat=require(_0x77d2('0x0'));var rimraf=require(_0x77d2('0x1'));var zipdir=require(_0x77d2('0x2'));var jsonpatch=require(_0x77d2('0x3'));var rp=require(_0x77d2('0x4'));var moment=require(_0x77d2('0x5'));var BPromise=require(_0x77d2('0x6'));var Mustache=require(_0x77d2('0x7'));var util=require(_0x77d2('0x8'));var path=require(_0x77d2('0x9'));var sox=require(_0x77d2('0xa'));var csv=require(_0x77d2('0xb'));var ejs=require(_0x77d2('0xc'));var fs=require('fs');var fs_extra=require('fs-extra');var _=require(_0x77d2('0xd'));var squel=require(_0x77d2('0xe'));var crypto=require(_0x77d2('0xf'));var jsforce=require(_0x77d2('0x10'));var deskjs=require(_0x77d2('0x11'));var toCsv=require(_0x77d2('0xb'));var querystring=require(_0x77d2('0x12'));var Papa=require(_0x77d2('0x13'));var Redis=require(_0x77d2('0x14'));var authService=require('../../components/auth/service');var qs=require('../../components/parsers/qs');var as=require(_0x77d2('0x15'));var hardwareService=require(_0x77d2('0x16'));var logger=require(_0x77d2('0x17'))(_0x77d2('0x18'));var utils=require(_0x77d2('0x19'));var config=require('../../config/environment');var licenseUtil=require('../../config/license/util');var db=require(_0x77d2('0x1a'))['db'];var csv_results;config[_0x77d2('0x1b')]=_[_0x77d2('0x1c')](config[_0x77d2('0x1b')],{'host':'localhost','port':0x18eb});var socket=require(_0x77d2('0x1d'))(new Redis(config['redis']));require(_0x77d2('0x1e'))[_0x77d2('0x1f')](socket);function respondWithStatusCode(_0x8fadac,_0x5bfa17){_0x5bfa17=_0x5bfa17||0xcc;return function(_0x257a03){if(_0x257a03){return _0x8fadac['sendStatus'](_0x5bfa17);}return _0x8fadac[_0x77d2('0x20')](_0x5bfa17)[_0x77d2('0x21')]();};}function respondWithResult(_0x1b1241,_0x3649e5){_0x3649e5=_0x3649e5||0xc8;return function(_0x9ab9bb){if(_0x9ab9bb){return _0x1b1241[_0x77d2('0x20')](_0x3649e5)['json'](_0x9ab9bb);}};}function respondWithFilteredResult(_0x2b2cea,_0x59303c){return function(_0x26f1b4){if(_0x26f1b4){var _0x5c15a4=typeof _0x59303c[_0x77d2('0x22')]===_0x77d2('0x23')&&typeof _0x59303c[_0x77d2('0x24')]==='undefined';var _0x432f2d=_0x26f1b4[_0x77d2('0x25')];var _0x12a389=_0x5c15a4?0x0:_0x59303c[_0x77d2('0x22')];var _0x336d07=_0x5c15a4?_0x26f1b4[_0x77d2('0x25')]:_0x59303c[_0x77d2('0x22')]+_0x59303c[_0x77d2('0x24')];var _0x152c81;if(_0x336d07>=_0x432f2d){_0x336d07=_0x432f2d;_0x152c81=0xc8;}else{_0x152c81=0xce;}_0x2b2cea['status'](_0x152c81);return _0x2b2cea[_0x77d2('0x26')](_0x77d2('0x27'),_0x12a389+'-'+_0x336d07+'/'+_0x432f2d)['json'](_0x26f1b4);}return null;};}function patchUpdates(_0x442a86){return function(_0x4b9ce6){try{jsonpatch[_0x77d2('0x28')](_0x4b9ce6,_0x442a86,!![]);}catch(_0x5848cf){return BPromise[_0x77d2('0x29')](_0x5848cf);}return _0x4b9ce6['save']();};}function saveUpdates(_0x3cb3a5,_0x28d8c6){return function(_0x274138){if(_0x274138){return _0x274138[_0x77d2('0x2a')](_0x3cb3a5)[_0x77d2('0x2b')](function(_0x100ef2){return _0x100ef2;});}return null;};}function removeEntity(_0x34abaf,_0x5b6de2){return function(_0x466c29){if(_0x466c29){return _0x466c29['destroy']()[_0x77d2('0x2b')](function(){var _0x5e2187=_0x466c29['get']({'plain':!![]});var _0x232078=_0x77d2('0x2c');return db[_0x77d2('0x2d')][_0x77d2('0x2e')]({'where':{'type':_0x232078,'resourceId':_0x5e2187['id']}})[_0x77d2('0x2b')](function(){return _0x466c29;});})[_0x77d2('0x2b')](function(){_0x34abaf[_0x77d2('0x20')](0xcc)['end']();});}};}function handleEntityNotFound(_0x350cb3,_0x2bd6e1){return function(_0x1deefb){if(!_0x1deefb){_0x350cb3[_0x77d2('0x2f')](0x194);}return _0x1deefb;};}function handleError(_0x2ccbbb,_0x43027c){_0x43027c=_0x43027c||0x1f4;return function(_0x4d5d90){logger[_0x77d2('0x30')](_0x4d5d90['stack']);if(_0x4d5d90[_0x77d2('0x31')]){delete _0x4d5d90['name'];}_0x2ccbbb[_0x77d2('0x20')](_0x43027c)[_0x77d2('0x32')](_0x4d5d90);};}exports[_0x77d2('0x33')]=function(_0x318a62,_0x30b94a){var _0x324ef4={},_0x4cf71a={},_0x33d09e={'count':0x0,'rows':[]};var _0x99b7ce=_['map'](db[_0x77d2('0x34')][_0x77d2('0x35')],function(_0x45e960){return{'name':_0x45e960['fieldName'],'type':_0x45e960[_0x77d2('0x36')]['key']};});_0x4cf71a[_0x77d2('0x37')]=_['map'](_0x99b7ce,_0x77d2('0x31'));_0x4cf71a['query']=_[_0x77d2('0x38')](_0x318a62[_0x77d2('0x39')]);_0x4cf71a[_0x77d2('0x3a')]=_[_0x77d2('0x3b')](_0x4cf71a[_0x77d2('0x37')],_0x4cf71a[_0x77d2('0x39')]);_0x324ef4['attributes']=_['intersection'](_0x4cf71a['model'],qs['fields'](_0x318a62[_0x77d2('0x39')][_0x77d2('0x3c')]));_0x324ef4['attributes']=_0x324ef4[_0x77d2('0x3d')][_0x77d2('0x3e')]?_0x324ef4[_0x77d2('0x3d')]:_0x4cf71a['model'];if(!_0x318a62['query'][_0x77d2('0x3f')](_0x77d2('0x40'))){_0x324ef4['limit']=qs['limit'](_0x318a62[_0x77d2('0x39')]['limit']);_0x324ef4[_0x77d2('0x22')]=qs['offset'](_0x318a62[_0x77d2('0x39')][_0x77d2('0x22')]);}_0x324ef4[_0x77d2('0x41')]=qs[_0x77d2('0x42')](_0x318a62[_0x77d2('0x39')][_0x77d2('0x42')]);_0x324ef4[_0x77d2('0x43')]=qs[_0x77d2('0x3a')](_['pick'](_0x318a62[_0x77d2('0x39')],_0x4cf71a['filters']),_0x99b7ce);if(_0x318a62[_0x77d2('0x39')][_0x77d2('0x44')]){_0x324ef4[_0x77d2('0x43')]=_[_0x77d2('0x45')](_0x324ef4[_0x77d2('0x43')],{'$or':_['map'](_0x99b7ce,function(_0x120903){if(_0x120903[_0x77d2('0x36')]!==_0x77d2('0x46')){var _0x25b77d={};_0x25b77d[_0x120903[_0x77d2('0x31')]]={'$like':'%'+_0x318a62[_0x77d2('0x39')][_0x77d2('0x44')]+'%'};return _0x25b77d;}})});}_0x324ef4=_['merge']({},_0x324ef4,_0x318a62['options']);var _0x257e1c={'where':_0x324ef4[_0x77d2('0x43')]};return db[_0x77d2('0x34')][_0x77d2('0x25')](_0x257e1c)[_0x77d2('0x2b')](function(_0x1f2e41){_0x33d09e[_0x77d2('0x25')]=_0x1f2e41;if(_0x318a62['query'][_0x77d2('0x47')]){_0x324ef4[_0x77d2('0x48')]=[{'all':!![]}];}return db[_0x77d2('0x34')]['findAll'](_0x324ef4);})[_0x77d2('0x2b')](function(_0x4964d6){_0x33d09e['rows']=_0x4964d6;return _0x33d09e;})[_0x77d2('0x2b')](respondWithFilteredResult(_0x30b94a,_0x324ef4))[_0x77d2('0x49')](handleError(_0x30b94a,null));};exports['show']=function(_0xf9672a,_0x489fc6){var _0x3d5dbb={'raw':![],'where':{'id':_0xf9672a[_0x77d2('0x4a')]['id']}},_0x3b76c7={};_0x3b76c7[_0x77d2('0x37')]=_[_0x77d2('0x38')](db[_0x77d2('0x34')]['rawAttributes']);_0x3b76c7[_0x77d2('0x39')]=_[_0x77d2('0x38')](_0xf9672a[_0x77d2('0x39')]);_0x3b76c7[_0x77d2('0x3a')]=_[_0x77d2('0x3b')](_0x3b76c7[_0x77d2('0x37')],_0x3b76c7[_0x77d2('0x39')]);_0x3d5dbb[_0x77d2('0x3d')]=_[_0x77d2('0x3b')](_0x3b76c7[_0x77d2('0x37')],qs['fields'](_0xf9672a['query'][_0x77d2('0x3c')]));_0x3d5dbb[_0x77d2('0x3d')]=_0x3d5dbb[_0x77d2('0x3d')][_0x77d2('0x3e')]?_0x3d5dbb[_0x77d2('0x3d')]:_0x3b76c7[_0x77d2('0x37')];if(_0xf9672a[_0x77d2('0x39')][_0x77d2('0x47')]){_0x3d5dbb['include']=[{'all':!![]}];}_0x3d5dbb=_[_0x77d2('0x45')]({},_0x3d5dbb,_0xf9672a[_0x77d2('0x4b')]);return db['CmList'][_0x77d2('0x4c')](_0x3d5dbb)['then'](handleEntityNotFound(_0x489fc6,null))[_0x77d2('0x2b')](respondWithResult(_0x489fc6,null))[_0x77d2('0x49')](handleError(_0x489fc6,null));};exports[_0x77d2('0x4d')]=function(_0x1df6c0,_0x41b78a){return db[_0x77d2('0x34')][_0x77d2('0x4d')](_0x1df6c0[_0x77d2('0x4e')],{})[_0x77d2('0x2b')](function(_0x443313){var _0x48657e=_0x1df6c0[_0x77d2('0x4f')][_0x77d2('0x50')]({'plain':!![]});if(!_0x48657e)throw new Error(_0x77d2('0x51'));if(_0x48657e[_0x77d2('0x52')]===_0x77d2('0x4f')){var _0x2a55b0=_0x443313[_0x77d2('0x50')]({'plain':!![]});var _0x364faa=_0x77d2('0x2c');return db['UserProfileSection'][_0x77d2('0x4c')]({'where':{'name':_0x364faa,'userProfileId':_0x48657e[_0x77d2('0x53')]},'raw':!![]})['then'](function(_0x196f43){if(_0x196f43&&_0x196f43[_0x77d2('0x54')]===0x0){return db[_0x77d2('0x2d')][_0x77d2('0x4d')]({'name':_0x2a55b0[_0x77d2('0x31')],'resourceId':_0x2a55b0['id'],'type':_0x196f43[_0x77d2('0x31')],'sectionId':_0x196f43['id']},{})['then'](function(){return _0x443313;});}else{return _0x443313;}})[_0x77d2('0x49')](function(_0x5670cd){logger[_0x77d2('0x30')](_0x77d2('0x55'),_0x5670cd);throw _0x5670cd;});}return _0x443313;})[_0x77d2('0x2b')](respondWithResult(_0x41b78a,0xc9))[_0x77d2('0x49')](handleError(_0x41b78a,null));};exports[_0x77d2('0x2a')]=function(_0x21332b,_0x3ec519){if(_0x21332b[_0x77d2('0x4e')]['id']){delete _0x21332b['body']['id'];}return db[_0x77d2('0x34')][_0x77d2('0x4c')]({'where':{'id':_0x21332b[_0x77d2('0x4a')]['id']}})[_0x77d2('0x2b')](handleEntityNotFound(_0x3ec519,null))[_0x77d2('0x2b')](saveUpdates(_0x21332b[_0x77d2('0x4e')],null))[_0x77d2('0x2b')](respondWithResult(_0x3ec519,null))['catch'](handleError(_0x3ec519,null));};exports[_0x77d2('0x2e')]=function(_0x1f3035,_0x5474f1){return db[_0x77d2('0x34')][_0x77d2('0x4c')]({'where':{'id':_0x1f3035[_0x77d2('0x4a')]['id']}})[_0x77d2('0x2b')](handleEntityNotFound(_0x5474f1,null))[_0x77d2('0x2b')](removeEntity(_0x5474f1,null))[_0x77d2('0x49')](handleError(_0x5474f1,null));};exports[_0x77d2('0x56')]=function(_0x1e7ba2,_0xed85a6){return db['CmList'][_0x77d2('0x56')]()['then'](respondWithResult(_0xed85a6,null))[_0x77d2('0x49')](handleError(_0xed85a6,null));};exports[_0x77d2('0x57')]=function(_0x24ca39,_0x4f164e,_0x54e072){if(_0x24ca39[_0x77d2('0x4e')]['id']){delete _0x24ca39['body']['id'];}return db[_0x77d2('0x34')]['find']({'where':{'id':_0x24ca39[_0x77d2('0x4a')]['id']}})[_0x77d2('0x2b')](handleEntityNotFound(_0x4f164e,null))['then'](function(_0x47bf49){if(_0x47bf49){_0x24ca39[_0x77d2('0x4e')]['ListId']=_0x47bf49['id'];return db[_0x77d2('0x58')]['create'](_0x24ca39[_0x77d2('0x4e')]);}})['then'](respondWithResult(_0x4f164e,null))[_0x77d2('0x49')](handleError(_0x4f164e,null));};exports[_0x77d2('0x59')]=function(_0x2f5ee9,_0x142b88,_0x469381){var _0x537304={'raw':![],'where':{}};var _0x2d3f00={};var _0x4ada53={'count':0x0,'rows':[]};return db[_0x77d2('0x34')][_0x77d2('0x5a')]({'where':{'id':_0x2f5ee9[_0x77d2('0x4a')]['id']}})[_0x77d2('0x2b')](handleEntityNotFound(_0x142b88,null))['then'](function(_0x38ad5a){if(_0x38ad5a){_0x2d3f00[_0x77d2('0x37')]=_[_0x77d2('0x38')](db[_0x77d2('0x58')]['rawAttributes']);_0x2d3f00['query']=_['keys'](_0x2f5ee9[_0x77d2('0x39')]);_0x2d3f00[_0x77d2('0x3a')]=_['intersection'](_0x2d3f00[_0x77d2('0x37')],_0x2d3f00[_0x77d2('0x39')]);_0x537304[_0x77d2('0x3d')]=_[_0x77d2('0x3b')](_0x2d3f00[_0x77d2('0x37')],qs['fields'](_0x2f5ee9['query'][_0x77d2('0x3c')]));_0x537304[_0x77d2('0x3d')]=_0x537304[_0x77d2('0x3d')][_0x77d2('0x3e')]?_0x537304['attributes']:_0x2d3f00[_0x77d2('0x37')];if(!_0x2f5ee9[_0x77d2('0x39')]['hasOwnProperty'](_0x77d2('0x40'))){_0x537304[_0x77d2('0x24')]=qs[_0x77d2('0x24')](_0x2f5ee9[_0x77d2('0x39')]['limit']);_0x537304[_0x77d2('0x22')]=qs[_0x77d2('0x22')](_0x2f5ee9[_0x77d2('0x39')][_0x77d2('0x22')]);}_0x537304['order']=qs[_0x77d2('0x42')](_0x2f5ee9[_0x77d2('0x39')]['sort']);_0x537304[_0x77d2('0x43')]=qs[_0x77d2('0x3a')](_['pick'](_0x2f5ee9[_0x77d2('0x39')],_0x2d3f00[_0x77d2('0x3a')]));_0x537304[_0x77d2('0x43')][_0x77d2('0x5b')]=_0x38ad5a['id'];if(_0x2f5ee9[_0x77d2('0x39')][_0x77d2('0x44')]){_0x537304[_0x77d2('0x43')]=_[_0x77d2('0x45')](_0x537304[_0x77d2('0x43')],{'$or':_[_0x77d2('0x5c')](_0x537304['attributes'],function(_0x73cc5e){var _0x344267={};_0x344267[_0x73cc5e]={'$like':'%'+_0x2f5ee9[_0x77d2('0x39')]['filter']+'%'};return _0x344267;})});}_0x537304=_[_0x77d2('0x45')]({},_0x537304,_0x2f5ee9[_0x77d2('0x4b')]);return db['Disposition'][_0x77d2('0x25')]({'where':_0x537304[_0x77d2('0x43')]})['then'](function(_0x153208){_0x4ada53['count']=_0x153208;if(_0x2f5ee9[_0x77d2('0x39')][_0x77d2('0x47')]){_0x537304['include']=[{'all':!![]}];}return db['Disposition'][_0x77d2('0x5d')](_0x537304);})[_0x77d2('0x2b')](function(_0x465433){_0x4ada53['rows']=_0x465433;return _0x4ada53;});}})[_0x77d2('0x2b')](respondWithFilteredResult(_0x142b88,_0x537304))[_0x77d2('0x49')](handleError(_0x142b88,null));};exports[_0x77d2('0x5e')]=function(_0x4b3b2,_0x56ea4c,_0x3f1bac){return db['CmList'][_0x77d2('0x4c')]({'where':{'id':_0x4b3b2[_0x77d2('0x4a')]['id']}})[_0x77d2('0x2b')](handleEntityNotFound(_0x56ea4c,null))[_0x77d2('0x2b')](function(_0x3d543e){if(_0x3d543e){return _0x3d543e[_0x77d2('0x5e')](_0x4b3b2[_0x77d2('0x39')][_0x77d2('0x5f')]);}})['then'](respondWithStatusCode(_0x56ea4c,null))[_0x77d2('0x49')](handleError(_0x56ea4c,null));};exports[_0x77d2('0x60')]=function(_0x98b505,_0x59ed04,_0x513235){return db[_0x77d2('0x34')]['find']({'where':{'id':_0x98b505[_0x77d2('0x4a')]['id']}})['then'](handleEntityNotFound(_0x59ed04,null))[_0x77d2('0x2b')](function(_0x1ffc66){if(_0x1ffc66){var _0x27e17e=[];var _0x321edf={'success':[],'errors':[]};return db[_0x77d2('0x61')][_0x77d2('0x56')]()['then'](function(_0x58df07){if(_0x98b505['body'][_0x77d2('0x62')]&&_[_0x77d2('0x63')](_0x98b505[_0x77d2('0x4e')][_0x77d2('0x62')])){if(_0x98b505['body'][_0x77d2('0x62')]['length']){_0x98b505[_0x77d2('0x4e')]['tags']=_0x98b505['body'][_0x77d2('0x62')][_0x77d2('0x64')](';')+';';}else{_0x98b505[_0x77d2('0x4e')][_0x77d2('0x62')]=null;}}else{_0x98b505[_0x77d2('0x4e')][_0x77d2('0x62')]=null;}if(_0x98b505['body']&&_[_0x77d2('0x63')](_0x98b505[_0x77d2('0x4e')])){for(var _0x43a718=0x0;_0x43a718<_0x98b505[_0x77d2('0x4e')]['length'];_0x43a718+=0x1){_0x98b505[_0x77d2('0x4e')][_0x43a718][_0x77d2('0x5b')]=_0x98b505[_0x77d2('0x4a')]['id'];_0x27e17e['push'](_0x98b505[_0x77d2('0x4e')][_0x43a718]);}return BPromise[_0x77d2('0x65')](_0x27e17e,function(_0x3658f3){return db[_0x77d2('0x61')]['create'](_[_0x77d2('0x66')](_0x3658f3,[_0x77d2('0x5f'),'id'])||{},{'fields':_[_0x77d2('0x38')](_0x58df07),'raw':!![]})['then'](function(_0x3d6da4){_0x321edf[_0x77d2('0x67')][_0x77d2('0x68')](_0x3d6da4[_0x77d2('0x69')]);})[_0x77d2('0x49')](function(_0x987f4d){_0x321edf[_0x77d2('0x6a')][_0x77d2('0x68')]({'data':_0x3658f3,'error':_0x987f4d[_0x77d2('0x6b')]});});})['then'](function(_0x21fef2){return _0x321edf;})['catch'](function(_0x1a435f){return _0x1a435f;});}else{_0x59ed04['status'](0x190)[_0x77d2('0x6c')]({'message':_0x77d2('0x6d')});}});}})['then'](respondWithResult(_0x59ed04,null))[_0x77d2('0x49')](handleError(_0x59ed04,null));};exports[_0x77d2('0x6e')]=function(_0x494c2d,_0x1c4ac0,_0x35376f){var _0x333ffd;return db['CmList'][_0x77d2('0x4c')]({'where':{'id':_0x494c2d[_0x77d2('0x4a')]['id']},'include':[{'model':db[_0x77d2('0x6f')],'as':'CustomFields'}]})[_0x77d2('0x2b')](handleEntityNotFound(_0x1c4ac0,null))['then'](function(_0x3f0e0d){if(_0x3f0e0d){_0x333ffd=_0x3f0e0d;return db[_0x77d2('0x61')]['rawAttributes'];}})[_0x77d2('0x2b')](function(_0x41ca27){if(_0x41ca27){var _0x58d025={};var _0x1759ce={};_0x1759ce['model']=_[_0x77d2('0x70')](_[_0x77d2('0x38')](_0x41ca27),_[_0x77d2('0x5c')](_0x333ffd[_0x77d2('0x71')],function(_0x4b2948){return util['format']('cf_%d',_0x4b2948['id']);}));_0x1759ce[_0x77d2('0x39')]=_[_0x77d2('0x38')](_0x494c2d[_0x77d2('0x39')]);_0x1759ce['filters']=_[_0x77d2('0x3b')](_0x1759ce[_0x77d2('0x37')],_0x1759ce[_0x77d2('0x39')]);_0x58d025['attributes']=_['intersection'](_0x1759ce[_0x77d2('0x37')],qs['fields'](_0x494c2d[_0x77d2('0x39')]['fields']));_0x58d025[_0x77d2('0x3d')]=_0x58d025[_0x77d2('0x3d')][_0x77d2('0x3e')]?_0x58d025[_0x77d2('0x3d')]:_0x1759ce[_0x77d2('0x37')];if(!_0x494c2d[_0x77d2('0x39')][_0x77d2('0x3f')](_0x77d2('0x40'))){_0x58d025[_0x77d2('0x24')]=qs[_0x77d2('0x24')](_0x494c2d[_0x77d2('0x39')][_0x77d2('0x24')]);_0x58d025[_0x77d2('0x22')]=qs[_0x77d2('0x22')](_0x494c2d[_0x77d2('0x39')][_0x77d2('0x22')]);}_0x58d025[_0x77d2('0x41')]=qs[_0x77d2('0x42')](_0x494c2d[_0x77d2('0x39')]['sort']);_0x58d025[_0x77d2('0x43')]=qs[_0x77d2('0x3a')](_[_0x77d2('0x72')](_0x494c2d['query'],_0x1759ce[_0x77d2('0x3a')]));_0x58d025['raw']=!![];if(_0x494c2d[_0x77d2('0x39')][_0x77d2('0x44')]){_0x58d025[_0x77d2('0x43')]=_[_0x77d2('0x45')](_0x58d025[_0x77d2('0x43')],{'$or':_['map'](_0x58d025[_0x77d2('0x3d')],function(_0x595285){var _0x10eab3={};_0x10eab3[_0x595285]={'$like':'%'+_0x494c2d[_0x77d2('0x39')][_0x77d2('0x44')]+'%'};return _0x10eab3;})});}_0x58d025=_[_0x77d2('0x45')]({},_0x58d025,_0x494c2d[_0x77d2('0x4b')]);return _0x333ffd['getContacts'](_0x58d025);}})[_0x77d2('0x2b')](respondWithResult(_0x1c4ac0,null))[_0x77d2('0x49')](handleError(_0x1c4ac0,null));};exports['getContactsCsv']=function(_0x24bb0d,_0x588fa1,_0xfc024d){var _0x458ec3;var _0x50fff5;var _0xe25124;var _0x28bb22=_0x24bb0d[_0x77d2('0x4a')]['id'];csv_results=[];return db[_0x77d2('0x73')][_0x77d2('0x5d')]({'attributes':['id',_0x77d2('0x31')],'raw':!![],'order':[_0x77d2('0x74')]})[_0x77d2('0x2b')](function(_0x1690cb){_0x458ec3=_0x1690cb;var _0x270ec5=_['keys'](db[_0x77d2('0x61')][_0x77d2('0x35')]);return db[_0x77d2('0x6f')][_0x77d2('0x5d')]({'raw':!![],'attributes':['id',_0x77d2('0x75')]})[_0x77d2('0x2b')](function(_0x4f1f2d){_0x50fff5=_0x4f1f2d;var _0x4bc856=squel['select']()[_0x77d2('0x3c')](_0x270ec5)['from'](_0x77d2('0x76'),'c')[_0x77d2('0x43')]('c.ListId\x20=\x20?',_0x28bb22)['where'](_0x77d2('0x77'))['distinct']();for(var _0x446dbd=0x0;_0x446dbd<_0x50fff5[_0x77d2('0x3e')];_0x446dbd++){_0x4bc856[_0x77d2('0x78')](_0x77d2('0x79')+_0x50fff5[_0x446dbd]['id'],_0x77d2('0x7a')+_0x50fff5[_0x446dbd][_0x77d2('0x75')]);}for(var _0x446dbd=0x0;_0x446dbd<_0x458ec3[_0x77d2('0x3e')];_0x446dbd++){_0x4bc856[_0x77d2('0x78')](squel[_0x77d2('0x7b')]()[_0x77d2('0x78')](_0x77d2('0x7c'))[_0x77d2('0x7d')](_0x77d2('0x7e'))[_0x77d2('0x43')]('ItemTypeId\x20=\x20?',_0x458ec3[_0x446dbd]['id'])[_0x77d2('0x43')](_0x77d2('0x7f')),'additionalPhone_'+_0x458ec3[_0x446dbd][_0x77d2('0x31')]);_0x4bc856[_0x77d2('0x78')](squel[_0x77d2('0x7b')]()['field']('description')[_0x77d2('0x7d')](_0x77d2('0x7e'))[_0x77d2('0x43')](_0x77d2('0x80'),_0x458ec3[_0x446dbd]['id'])[_0x77d2('0x43')](_0x77d2('0x7f')),'description_additionalPhone_'+_0x458ec3[_0x446dbd][_0x77d2('0x31')]);}var _0x666523=[];_0x666523[_0x77d2('0x68')](_0x4bc856['toString']());BPromise[_0x77d2('0x65')](_0x666523,handleQuery)[_0x77d2('0x2b')](function(_0x235747){handleQuery(_0x4bc856[_0x77d2('0x81')]());var _0xa9b890=csv_results[0x0];if(!_['isEmpty'](_0xa9b890)){var _0x56dd10=toCsv(_0xa9b890);var _0x186373=Date['now']();fs[_0x77d2('0x82')](util['format'](_0x77d2('0x83'),_0x28bb22,_0x186373),_0x56dd10);_0x588fa1[_0x77d2('0x84')]('Content-disposition',_0x77d2('0x85')+util['format'](_0x77d2('0x86'),_0x28bb22,_0x186373));_0x588fa1[_0x77d2('0x84')]('Content-type',_0x77d2('0x87'));return _0x588fa1[_0x77d2('0x88')](util['format']('/tmp/list_%d_%s.csv',_0x28bb22,_0x186373));}else{return _0x588fa1[_0x77d2('0x2f')](0xcc);}});});});};exports['addCustomField']=function(_0x234d67,_0x5f113b,_0x15d857){var _0x2358bf;delete _0x234d67[_0x77d2('0x4e')]['id'];return db[_0x77d2('0x34')][_0x77d2('0x5a')]({'where':{'id':_0x234d67[_0x77d2('0x4a')]['id']}})['then'](handleEntityNotFound(_0x5f113b,null))['then'](function(_0x3b1f5b){if(_0x3b1f5b){return db['sequelize'][_0x77d2('0x89')](function(_0xd8dad2){return db['CmCustomField'][_0x77d2('0x4d')](_0x234d67[_0x77d2('0x4e')],{'transaction':_0xd8dad2})[_0x77d2('0x2b')](function(_0x29997f){_0x2358bf=_0x29997f;return _0x3b1f5b[_0x77d2('0x8a')](_0x29997f,{'transaction':_0xd8dad2});})[_0x77d2('0x2b')](function(){var _0x1ff321={'type':db[_0x77d2('0x8b')][_0x77d2('0x8c')],'transaction':_0xd8dad2};switch(_0x234d67[_0x77d2('0x4e')][_0x77d2('0x36')]){case _0x77d2('0x8d'):_0x1ff321[_0x77d2('0x36')]=db['Sequelize']['TEXT'];break;case _0x77d2('0x8e'):_0x1ff321[_0x77d2('0x36')]=db[_0x77d2('0x8b')][_0x77d2('0x8f')];break;case _0x77d2('0x90'):_0x1ff321[_0x77d2('0x36')]=db[_0x77d2('0x8b')][_0x77d2('0x91')];_0x1ff321['defaultValue']=![];break;default:}return db[_0x77d2('0x92')][_0x77d2('0x93')][_0x77d2('0x94')](_0x77d2('0x76'),util[_0x77d2('0x95')]('cf_%s',_0x2358bf['id']),_0x1ff321);})['then'](function(){return _0x2358bf;});});}})[_0x77d2('0x2b')](respondWithResult(_0x5f113b,null))['catch'](handleError(_0x5f113b,null));};exports['getCustomFields']=function(_0xc5f889,_0x46891d,_0x2218e0){var _0x61f051={};var _0x56a88c={};var _0x46c423;var _0x445e52;return db['CmList']['findOne']({'where':{'id':_0xc5f889[_0x77d2('0x4a')]['id']}})[_0x77d2('0x2b')](handleEntityNotFound(_0x46891d,null))[_0x77d2('0x2b')](function(_0x5242c3){if(_0x5242c3){_0x46c423=_0x5242c3;_0x56a88c['model']=_[_0x77d2('0x38')](db[_0x77d2('0x6f')][_0x77d2('0x35')]);_0x56a88c['query']=_['keys'](_0xc5f889[_0x77d2('0x39')]);_0x56a88c[_0x77d2('0x3a')]=_['intersection'](_0x56a88c[_0x77d2('0x37')],_0x56a88c[_0x77d2('0x39')]);_0x61f051[_0x77d2('0x3d')]=_[_0x77d2('0x3b')](_0x56a88c[_0x77d2('0x37')],qs['fields'](_0xc5f889[_0x77d2('0x39')][_0x77d2('0x3c')]));_0x61f051['attributes']=_0x61f051[_0x77d2('0x3d')][_0x77d2('0x3e')]?_0x61f051[_0x77d2('0x3d')]:_0x56a88c[_0x77d2('0x37')];_0x61f051['order']=qs[_0x77d2('0x42')](_0xc5f889['query'][_0x77d2('0x42')]);_0x61f051[_0x77d2('0x43')]=qs[_0x77d2('0x3a')](_[_0x77d2('0x72')](_0xc5f889[_0x77d2('0x39')],_0x56a88c[_0x77d2('0x3a')]));_0x61f051[_0x77d2('0x43')]=_[_0x77d2('0x45')](_0x61f051[_0x77d2('0x43')],{'$or':[{'ListId':_0x5242c3['id']},{'ListId':null}]});if(_0xc5f889['query']['filter']){_0x61f051[_0x77d2('0x43')]=_[_0x77d2('0x45')](_0x61f051[_0x77d2('0x43')],{'$or':_[_0x77d2('0x5c')](_0x61f051['attributes'],function(_0x42064b){var _0x16c500={};_0x16c500[_0x42064b]={'$like':'%'+_0xc5f889[_0x77d2('0x39')]['filter']+'%'};return _0x16c500;})});}_0x61f051=_[_0x77d2('0x45')]({},_0x61f051,_0xc5f889[_0x77d2('0x4b')]);return db[_0x77d2('0x6f')][_0x77d2('0x96')](_0x61f051);}})[_0x77d2('0x2b')](respondWithResult(_0x46891d,null))[_0x77d2('0x49')](handleError(_0x46891d,null));};exports[_0x77d2('0x97')]=function(_0x283870,_0x32c032){return db['CmCustomField'][_0x77d2('0x96')]({'where':{'ListId':null}})[_0x77d2('0x2b')](handleEntityNotFound(_0x32c032,null))[_0x77d2('0x2b')](function(_0x749b41){return _0x749b41;})[_0x77d2('0x2b')](respondWithResult(_0x32c032,null))[_0x77d2('0x49')](handleError(_0x32c032,null));};exports['addAgents']=function(_0x4a073f,_0xefaf04,_0x3df4f3){return db[_0x77d2('0x34')][_0x77d2('0x4c')]({'where':{'id':_0x4a073f[_0x77d2('0x4a')]['id']}})[_0x77d2('0x2b')](handleEntityNotFound(_0xefaf04,null))[_0x77d2('0x2b')](function(_0x19082b){if(_0x19082b){return _0x19082b[_0x77d2('0x98')](_0x4a073f[_0x77d2('0x4e')][_0x77d2('0x5f')],_['omit'](_0x4a073f['body'],[_0x77d2('0x5f'),'id'])||{})[_0x77d2('0x99')](function(_0x5ddb1e){for(var _0x3a94e2=0x0;_0x3a94e2<_0x4a073f[_0x77d2('0x4e')][_0x77d2('0x5f')]['length'];_0x3a94e2+=0x1){socket[_0x77d2('0x9a')](_0x77d2('0x9b'),{'UserId':Number(_0x4a073f[_0x77d2('0x4e')][_0x77d2('0x5f')][_0x3a94e2]),'CmListId':Number(_0x4a073f[_0x77d2('0x4a')]['id'])});}return _0x5ddb1e;});}})[_0x77d2('0x2b')](respondWithResult(_0xefaf04,null))['catch'](handleError(_0xefaf04,null));};exports[_0x77d2('0x9c')]=function(_0x3ee9d1,_0x58afd7,_0x17f101){return db['CmList']['find']({'where':{'id':_0x3ee9d1[_0x77d2('0x4a')]['id']}})[_0x77d2('0x2b')](handleEntityNotFound(_0x58afd7,null))[_0x77d2('0x2b')](function(_0xf46bfd){if(_0xf46bfd){return _0xf46bfd[_0x77d2('0x9c')](_0x3ee9d1[_0x77d2('0x39')][_0x77d2('0x5f')])[_0x77d2('0x2b')](function(){if(_[_0x77d2('0x63')](_0x3ee9d1[_0x77d2('0x39')][_0x77d2('0x5f')])){for(var _0x2a1115=0x0;_0x2a1115<_0x3ee9d1['query'][_0x77d2('0x5f')][_0x77d2('0x3e')];_0x2a1115+=0x1){socket[_0x77d2('0x9a')](_0x77d2('0x9d'),{'UserId':Number(_0x3ee9d1[_0x77d2('0x39')][_0x77d2('0x5f')][_0x2a1115]),'CmListId':Number(_0x3ee9d1[_0x77d2('0x4a')]['id'])});}}else{socket[_0x77d2('0x9a')]('userCmList:remove',{'UserId':Number(_0x3ee9d1[_0x77d2('0x39')][_0x77d2('0x5f')]),'CmListId':Number(_0x3ee9d1[_0x77d2('0x4a')]['id'])});}});}})[_0x77d2('0x2b')](respondWithStatusCode(_0x58afd7,null))['catch'](handleError(_0x58afd7,null));};exports['getAgents']=function(_0x82724b,_0x23685a,_0x3de586){var _0x208e14={};var _0x493a0f={};var _0x4c444b;var _0x1bfc8f;return db[_0x77d2('0x34')][_0x77d2('0x5a')]({'where':{'id':_0x82724b[_0x77d2('0x4a')]['id']}})[_0x77d2('0x2b')](handleEntityNotFound(_0x23685a,null))[_0x77d2('0x2b')](function(_0x37c339){if(_0x37c339){_0x4c444b=_0x37c339;_0x493a0f['model']=_['keys'](db[_0x77d2('0x9e')]['rawAttributes']);_0x493a0f[_0x77d2('0x39')]=_['keys'](_0x82724b[_0x77d2('0x39')]);_0x493a0f[_0x77d2('0x3a')]=_[_0x77d2('0x3b')](_0x493a0f[_0x77d2('0x37')],_0x493a0f[_0x77d2('0x39')]);_0x208e14[_0x77d2('0x3d')]=_[_0x77d2('0x3b')](_0x493a0f[_0x77d2('0x37')],qs[_0x77d2('0x3c')](_0x82724b[_0x77d2('0x39')]['fields']));_0x208e14[_0x77d2('0x3d')]=_0x208e14[_0x77d2('0x3d')][_0x77d2('0x3e')]?_0x208e14[_0x77d2('0x3d')]:_0x493a0f[_0x77d2('0x37')];_0x208e14['order']=qs[_0x77d2('0x42')](_0x82724b[_0x77d2('0x39')][_0x77d2('0x42')]);_0x208e14[_0x77d2('0x43')]=qs[_0x77d2('0x3a')](_['pick'](_0x82724b[_0x77d2('0x39')],_0x493a0f['filters']));if(_0x82724b[_0x77d2('0x39')][_0x77d2('0x44')]){_0x208e14[_0x77d2('0x43')]=_[_0x77d2('0x45')](_0x208e14[_0x77d2('0x43')],{'$or':_[_0x77d2('0x5c')](_0x208e14[_0x77d2('0x3d')],function(_0x36d46b){var _0x2a4fbd={};_0x2a4fbd[_0x36d46b]={'$like':'%'+_0x82724b[_0x77d2('0x39')][_0x77d2('0x44')]+'%'};return _0x2a4fbd;})});}_0x208e14=_[_0x77d2('0x45')]({},_0x208e14,_0x82724b['options']);return _0x4c444b[_0x77d2('0x9f')](_0x208e14);}})['then'](function(_0x3e080c){if(_0x3e080c){_0x1bfc8f=_0x3e080c[_0x77d2('0x3e')];if(!_0x82724b[_0x77d2('0x39')][_0x77d2('0x3f')](_0x77d2('0x40'))){_0x208e14[_0x77d2('0x24')]=qs['limit'](_0x82724b[_0x77d2('0x39')][_0x77d2('0x24')]);_0x208e14[_0x77d2('0x22')]=qs[_0x77d2('0x22')](_0x82724b[_0x77d2('0x39')]['offset']);}return _0x4c444b['getAgents'](_0x208e14);}})['then'](function(_0x14fc7f){if(_0x14fc7f){return _0x14fc7f?{'count':_0x1bfc8f,'rows':_0x14fc7f}:null;}})[_0x77d2('0x2b')](respondWithResult(_0x23685a,null))[_0x77d2('0x49')](handleError(_0x23685a,null));};function handleQuery(_0x4b2ce8){logger['info'](_0x4b2ce8);return db[_0x77d2('0x92')][_0x77d2('0x39')](_0x4b2ce8)[_0x77d2('0x99')](function(_0x28f51b){csv_results[_0x77d2('0x68')](_0x28f51b);})['catch'](function(_0x55b132){logger[_0x77d2('0x30')](_0x55b132[_0x77d2('0x6b')]);});}