8028225b391fb1e1e07e9ca175a0d7f7b13185d6
[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 _0xc327=['CmList','fieldName','type','key','model','query','filters','intersection','attributes','length','hasOwnProperty','nolimit','sort','pick','where','merge','VIRTUAL','filter','includeAll','findAll','rows','catch','show','params','keys','rawAttributes','fields','include','options','create','Unable\x20to\x20retrieve\x20the\x20current\x20user','role','user','UserProfileSection','find','userProfileId','autoAssociation','error','Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s','body','destroy','describe','addDisposition','ListId','Disposition','getDispositions','order','removeDispositions','ids','addContacts','CmContact','tags','isArray','each','omit','success','dataValues','push','message','Malformed\x20request\x20syntax','getContacts','CmCustomField','CustomFields','ContactItemType','OrderBy','alias','select','from','cm_contacts','c.ListId\x20=\x20?','c.deletedAt\x20is\x20null','distinct','field','c.cf_','customField_','item','cm_contact_has_items','ItemTypeId\x20=\x20?','CmContactId\x20=\x20c.id','additionalPhone_','description','toString','isEmpty','now','writeFileSync','format','/tmp/list_%d_%s.csv','setHeader','Content-disposition','attachment;\x20filename=','list_%d_%s.csv','text/csv','download','addCustomField','findOne','addCustomFields','Sequelize','text','TEXT','number','INTEGER','switch','BOOLEAN','defaultValue','sequelize','queryInterface','addColumn','getCustomFields','getGlobalCustomFields','findAndCountAll','addAgents','spread','emit','userCmList:save','removeAgents','userCmList:remove','getAgents','User','info','rimraf','fast-json-patch','moment','bluebird','mustache','path','sox','to-csv','ejs','fs-extra','lodash','squel','desk.js','querystring','papaparse','ioredis','../../components/parsers/qs','../../config/logger','api','../../config/utils','../../config/license/util','../../mysqldb','redis','defaults','socket.io-emitter','register','sendStatus','status','end','offset','undefined','count','limit','set','Content-Range','json','apply','reject','save','update','then','get','Lists','UserProfileResource','stack','name','send','index','map'];(function(_0x2309da,_0x136002){var _0x792c1c=function(_0x5c4dd3){while(--_0x5c4dd3){_0x2309da['push'](_0x2309da['shift']());}};_0x792c1c(++_0x136002);}(_0xc327,0x1c7));var _0x7c32=function(_0x297fd3,_0x115406){_0x297fd3=_0x297fd3-0x0;var _0x2af381=_0xc327[_0x297fd3];return _0x2af381;};'use strict';var emlformat=require('eml-format');var rimraf=require(_0x7c32('0x0'));var zipdir=require('zip-dir');var jsonpatch=require(_0x7c32('0x1'));var rp=require('request-promise');var moment=require(_0x7c32('0x2'));var BPromise=require(_0x7c32('0x3'));var Mustache=require(_0x7c32('0x4'));var util=require('util');var path=require(_0x7c32('0x5'));var sox=require(_0x7c32('0x6'));var csv=require(_0x7c32('0x7'));var ejs=require(_0x7c32('0x8'));var fs=require('fs');var fs_extra=require(_0x7c32('0x9'));var _=require(_0x7c32('0xa'));var squel=require(_0x7c32('0xb'));var crypto=require('crypto');var jsforce=require('jsforce');var deskjs=require(_0x7c32('0xc'));var toCsv=require(_0x7c32('0x7'));var querystring=require(_0x7c32('0xd'));var Papa=require(_0x7c32('0xe'));var Redis=require(_0x7c32('0xf'));var authService=require('../../components/auth/service');var qs=require(_0x7c32('0x10'));var as=require('../../components/parsers/advancedSearch');var hardwareService=require('../../config/license/hardware');var logger=require(_0x7c32('0x11'))(_0x7c32('0x12'));var utils=require(_0x7c32('0x13'));var config=require('../../config/environment');var licenseUtil=require(_0x7c32('0x14'));var db=require(_0x7c32('0x15'))['db'];var csv_results;config[_0x7c32('0x16')]=_[_0x7c32('0x17')](config[_0x7c32('0x16')],{'host':'localhost','port':0x18eb});var socket=require(_0x7c32('0x18'))(new Redis(config[_0x7c32('0x16')]));require('./cmList.socket')[_0x7c32('0x19')](socket);function respondWithStatusCode(_0x138ae2,_0x472bfd){_0x472bfd=_0x472bfd||0xcc;return function(_0x3d5acc){if(_0x3d5acc){return _0x138ae2[_0x7c32('0x1a')](_0x472bfd);}return _0x138ae2[_0x7c32('0x1b')](_0x472bfd)[_0x7c32('0x1c')]();};}function respondWithResult(_0x5866d5,_0x1e5d9){_0x1e5d9=_0x1e5d9||0xc8;return function(_0x324b4d){if(_0x324b4d){return _0x5866d5[_0x7c32('0x1b')](_0x1e5d9)['json'](_0x324b4d);}};}function respondWithFilteredResult(_0x33a282,_0x28560f){return function(_0x4cdb70){if(_0x4cdb70){var _0x515ba0=typeof _0x28560f[_0x7c32('0x1d')]===_0x7c32('0x1e')&&typeof _0x28560f['limit']==='undefined';var _0x25d63a=_0x4cdb70['count'];var _0x55a2bb=_0x515ba0?0x0:_0x28560f[_0x7c32('0x1d')];var _0x342461=_0x515ba0?_0x4cdb70[_0x7c32('0x1f')]:_0x28560f['offset']+_0x28560f[_0x7c32('0x20')];var _0x6c68cb;if(_0x342461>=_0x25d63a){_0x342461=_0x25d63a;_0x6c68cb=0xc8;}else{_0x6c68cb=0xce;}_0x33a282[_0x7c32('0x1b')](_0x6c68cb);return _0x33a282[_0x7c32('0x21')](_0x7c32('0x22'),_0x55a2bb+'-'+_0x342461+'/'+_0x25d63a)[_0x7c32('0x23')](_0x4cdb70);}return null;};}function patchUpdates(_0x2383d0){return function(_0x4c7c19){try{jsonpatch[_0x7c32('0x24')](_0x4c7c19,_0x2383d0,!![]);}catch(_0xba50cd){return BPromise[_0x7c32('0x25')](_0xba50cd);}return _0x4c7c19[_0x7c32('0x26')]();};}function saveUpdates(_0x515ed4,_0x1058ce){return function(_0x2db403){if(_0x2db403){return _0x2db403[_0x7c32('0x27')](_0x515ed4)[_0x7c32('0x28')](function(_0x4e1e24){return _0x4e1e24;});}return null;};}function removeEntity(_0x1dd551,_0x18e623){return function(_0x1afed5){if(_0x1afed5){return _0x1afed5['destroy']()[_0x7c32('0x28')](function(){var _0x197f55=_0x1afed5[_0x7c32('0x29')]({'plain':!![]});var _0xae0ce4=_0x7c32('0x2a');return db[_0x7c32('0x2b')]['destroy']({'where':{'type':_0xae0ce4,'resourceId':_0x197f55['id']}})['then'](function(){return _0x1afed5;});})[_0x7c32('0x28')](function(){_0x1dd551[_0x7c32('0x1b')](0xcc)[_0x7c32('0x1c')]();});}};}function handleEntityNotFound(_0x35eafb,_0x20ffe6){return function(_0x238edc){if(!_0x238edc){_0x35eafb[_0x7c32('0x1a')](0x194);}return _0x238edc;};}function handleError(_0x295c88,_0x52b1df){_0x52b1df=_0x52b1df||0x1f4;return function(_0x2e8f1b){logger['error'](_0x2e8f1b[_0x7c32('0x2c')]);if(_0x2e8f1b[_0x7c32('0x2d')]){delete _0x2e8f1b[_0x7c32('0x2d')];}_0x295c88[_0x7c32('0x1b')](_0x52b1df)[_0x7c32('0x2e')](_0x2e8f1b);};}exports[_0x7c32('0x2f')]=function(_0x335007,_0x5350cc){var _0x258ace={},_0x3e530a={},_0x52a7b2={'count':0x0,'rows':[]};var _0x5652f8=_[_0x7c32('0x30')](db[_0x7c32('0x31')]['rawAttributes'],function(_0x53916c){return{'name':_0x53916c[_0x7c32('0x32')],'type':_0x53916c[_0x7c32('0x33')][_0x7c32('0x34')]};});_0x3e530a[_0x7c32('0x35')]=_[_0x7c32('0x30')](_0x5652f8,_0x7c32('0x2d'));_0x3e530a[_0x7c32('0x36')]=_['keys'](_0x335007[_0x7c32('0x36')]);_0x3e530a[_0x7c32('0x37')]=_['intersection'](_0x3e530a['model'],_0x3e530a[_0x7c32('0x36')]);_0x258ace['attributes']=_[_0x7c32('0x38')](_0x3e530a[_0x7c32('0x35')],qs['fields'](_0x335007[_0x7c32('0x36')]['fields']));_0x258ace[_0x7c32('0x39')]=_0x258ace[_0x7c32('0x39')][_0x7c32('0x3a')]?_0x258ace[_0x7c32('0x39')]:_0x3e530a[_0x7c32('0x35')];if(!_0x335007[_0x7c32('0x36')][_0x7c32('0x3b')](_0x7c32('0x3c'))){_0x258ace['limit']=qs[_0x7c32('0x20')](_0x335007[_0x7c32('0x36')][_0x7c32('0x20')]);_0x258ace[_0x7c32('0x1d')]=qs[_0x7c32('0x1d')](_0x335007['query']['offset']);}_0x258ace['order']=qs[_0x7c32('0x3d')](_0x335007['query']['sort']);_0x258ace['where']=qs[_0x7c32('0x37')](_[_0x7c32('0x3e')](_0x335007[_0x7c32('0x36')],_0x3e530a['filters']),_0x5652f8);if(_0x335007[_0x7c32('0x36')]['filter']){_0x258ace[_0x7c32('0x3f')]=_[_0x7c32('0x40')](_0x258ace[_0x7c32('0x3f')],{'$or':_[_0x7c32('0x30')](_0x5652f8,function(_0x55baf2){if(_0x55baf2[_0x7c32('0x33')]!==_0x7c32('0x41')){var _0x7799a3={};_0x7799a3[_0x55baf2[_0x7c32('0x2d')]]={'$like':'%'+_0x335007[_0x7c32('0x36')][_0x7c32('0x42')]+'%'};return _0x7799a3;}})});}_0x258ace=_[_0x7c32('0x40')]({},_0x258ace,_0x335007['options']);var _0x1eaea4={'where':_0x258ace[_0x7c32('0x3f')]};return db[_0x7c32('0x31')]['count'](_0x1eaea4)['then'](function(_0xc785e8){_0x52a7b2[_0x7c32('0x1f')]=_0xc785e8;if(_0x335007[_0x7c32('0x36')][_0x7c32('0x43')]){_0x258ace['include']=[{'all':!![]}];}return db['CmList'][_0x7c32('0x44')](_0x258ace);})[_0x7c32('0x28')](function(_0x427059){_0x52a7b2[_0x7c32('0x45')]=_0x427059;return _0x52a7b2;})['then'](respondWithFilteredResult(_0x5350cc,_0x258ace))[_0x7c32('0x46')](handleError(_0x5350cc,null));};exports[_0x7c32('0x47')]=function(_0x3ac823,_0x2eb9b8){var _0x502a57={'raw':![],'where':{'id':_0x3ac823[_0x7c32('0x48')]['id']}},_0x2338dd={};_0x2338dd[_0x7c32('0x35')]=_[_0x7c32('0x49')](db[_0x7c32('0x31')][_0x7c32('0x4a')]);_0x2338dd[_0x7c32('0x36')]=_[_0x7c32('0x49')](_0x3ac823[_0x7c32('0x36')]);_0x2338dd[_0x7c32('0x37')]=_[_0x7c32('0x38')](_0x2338dd['model'],_0x2338dd[_0x7c32('0x36')]);_0x502a57[_0x7c32('0x39')]=_['intersection'](_0x2338dd[_0x7c32('0x35')],qs[_0x7c32('0x4b')](_0x3ac823[_0x7c32('0x36')][_0x7c32('0x4b')]));_0x502a57[_0x7c32('0x39')]=_0x502a57['attributes']['length']?_0x502a57[_0x7c32('0x39')]:_0x2338dd['model'];if(_0x3ac823[_0x7c32('0x36')][_0x7c32('0x43')]){_0x502a57[_0x7c32('0x4c')]=[{'all':!![]}];}_0x502a57=_[_0x7c32('0x40')]({},_0x502a57,_0x3ac823[_0x7c32('0x4d')]);return db['CmList']['find'](_0x502a57)[_0x7c32('0x28')](handleEntityNotFound(_0x2eb9b8,null))[_0x7c32('0x28')](respondWithResult(_0x2eb9b8,null))[_0x7c32('0x46')](handleError(_0x2eb9b8,null));};exports[_0x7c32('0x4e')]=function(_0x145929,_0x520588){return db[_0x7c32('0x31')]['create'](_0x145929['body'],{})[_0x7c32('0x28')](function(_0x194871){var _0x24409f=_0x145929['user'][_0x7c32('0x29')]({'plain':!![]});if(!_0x24409f)throw new Error(_0x7c32('0x4f'));if(_0x24409f[_0x7c32('0x50')]===_0x7c32('0x51')){var _0x67ea2c=_0x194871[_0x7c32('0x29')]({'plain':!![]});var _0x56c55f=_0x7c32('0x2a');return db[_0x7c32('0x52')][_0x7c32('0x53')]({'where':{'name':_0x56c55f,'userProfileId':_0x24409f[_0x7c32('0x54')]},'raw':!![]})[_0x7c32('0x28')](function(_0x335c1f){if(_0x335c1f&&_0x335c1f[_0x7c32('0x55')]===0x0){return db[_0x7c32('0x2b')][_0x7c32('0x4e')]({'name':_0x67ea2c['name'],'resourceId':_0x67ea2c['id'],'type':_0x335c1f[_0x7c32('0x2d')],'sectionId':_0x335c1f['id']},{})[_0x7c32('0x28')](function(){return _0x194871;});}else{return _0x194871;}})[_0x7c32('0x46')](function(_0x261a08){logger[_0x7c32('0x56')](_0x7c32('0x57'),_0x261a08);throw _0x261a08;});}return _0x194871;})['then'](respondWithResult(_0x520588,0xc9))['catch'](handleError(_0x520588,null));};exports[_0x7c32('0x27')]=function(_0x17da97,_0x553f09){if(_0x17da97['body']['id']){delete _0x17da97[_0x7c32('0x58')]['id'];}return db[_0x7c32('0x31')][_0x7c32('0x53')]({'where':{'id':_0x17da97[_0x7c32('0x48')]['id']}})[_0x7c32('0x28')](handleEntityNotFound(_0x553f09,null))[_0x7c32('0x28')](saveUpdates(_0x17da97[_0x7c32('0x58')],null))[_0x7c32('0x28')](respondWithResult(_0x553f09,null))[_0x7c32('0x46')](handleError(_0x553f09,null));};exports[_0x7c32('0x59')]=function(_0x1b7dc3,_0x12213a){return db[_0x7c32('0x31')]['find']({'where':{'id':_0x1b7dc3['params']['id']}})[_0x7c32('0x28')](handleEntityNotFound(_0x12213a,null))[_0x7c32('0x28')](removeEntity(_0x12213a,null))[_0x7c32('0x46')](handleError(_0x12213a,null));};exports[_0x7c32('0x5a')]=function(_0x385c57,_0xfd6fb3){return db[_0x7c32('0x31')][_0x7c32('0x5a')]()[_0x7c32('0x28')](respondWithResult(_0xfd6fb3,null))['catch'](handleError(_0xfd6fb3,null));};exports[_0x7c32('0x5b')]=function(_0x57a8f6,_0x572711,_0x577c2a){if(_0x57a8f6['body']['id']){delete _0x57a8f6[_0x7c32('0x58')]['id'];}return db[_0x7c32('0x31')][_0x7c32('0x53')]({'where':{'id':_0x57a8f6[_0x7c32('0x48')]['id']}})['then'](handleEntityNotFound(_0x572711,null))[_0x7c32('0x28')](function(_0x17c048){if(_0x17c048){_0x57a8f6[_0x7c32('0x58')][_0x7c32('0x5c')]=_0x17c048['id'];return db[_0x7c32('0x5d')]['create'](_0x57a8f6['body']);}})[_0x7c32('0x28')](respondWithResult(_0x572711,null))[_0x7c32('0x46')](handleError(_0x572711,null));};exports[_0x7c32('0x5e')]=function(_0x3fcff0,_0x302f9c,_0x483a9e){var _0x1b5ed3={'raw':![],'where':{}};var _0x835d32={};var _0x19eec8={'count':0x0,'rows':[]};return db[_0x7c32('0x31')]['findOne']({'where':{'id':_0x3fcff0[_0x7c32('0x48')]['id']}})[_0x7c32('0x28')](handleEntityNotFound(_0x302f9c,null))['then'](function(_0x271994){if(_0x271994){_0x835d32[_0x7c32('0x35')]=_[_0x7c32('0x49')](db[_0x7c32('0x5d')][_0x7c32('0x4a')]);_0x835d32[_0x7c32('0x36')]=_[_0x7c32('0x49')](_0x3fcff0[_0x7c32('0x36')]);_0x835d32[_0x7c32('0x37')]=_[_0x7c32('0x38')](_0x835d32[_0x7c32('0x35')],_0x835d32[_0x7c32('0x36')]);_0x1b5ed3[_0x7c32('0x39')]=_['intersection'](_0x835d32['model'],qs['fields'](_0x3fcff0[_0x7c32('0x36')]['fields']));_0x1b5ed3[_0x7c32('0x39')]=_0x1b5ed3[_0x7c32('0x39')]['length']?_0x1b5ed3[_0x7c32('0x39')]:_0x835d32['model'];if(!_0x3fcff0[_0x7c32('0x36')][_0x7c32('0x3b')](_0x7c32('0x3c'))){_0x1b5ed3[_0x7c32('0x20')]=qs['limit'](_0x3fcff0['query'][_0x7c32('0x20')]);_0x1b5ed3[_0x7c32('0x1d')]=qs[_0x7c32('0x1d')](_0x3fcff0[_0x7c32('0x36')]['offset']);}_0x1b5ed3[_0x7c32('0x5f')]=qs[_0x7c32('0x3d')](_0x3fcff0[_0x7c32('0x36')][_0x7c32('0x3d')]);_0x1b5ed3[_0x7c32('0x3f')]=qs[_0x7c32('0x37')](_['pick'](_0x3fcff0['query'],_0x835d32[_0x7c32('0x37')]));_0x1b5ed3['where'][_0x7c32('0x5c')]=_0x271994['id'];if(_0x3fcff0[_0x7c32('0x36')][_0x7c32('0x42')]){_0x1b5ed3['where']=_[_0x7c32('0x40')](_0x1b5ed3[_0x7c32('0x3f')],{'$or':_[_0x7c32('0x30')](_0x1b5ed3[_0x7c32('0x39')],function(_0xb4bafd){var _0x272d1b={};_0x272d1b[_0xb4bafd]={'$like':'%'+_0x3fcff0['query'][_0x7c32('0x42')]+'%'};return _0x272d1b;})});}_0x1b5ed3=_['merge']({},_0x1b5ed3,_0x3fcff0['options']);return db[_0x7c32('0x5d')][_0x7c32('0x1f')]({'where':_0x1b5ed3[_0x7c32('0x3f')]})[_0x7c32('0x28')](function(_0x115097){_0x19eec8['count']=_0x115097;if(_0x3fcff0[_0x7c32('0x36')][_0x7c32('0x43')]){_0x1b5ed3[_0x7c32('0x4c')]=[{'all':!![]}];}return db['Disposition'][_0x7c32('0x44')](_0x1b5ed3);})[_0x7c32('0x28')](function(_0x1e94cd){_0x19eec8[_0x7c32('0x45')]=_0x1e94cd;return _0x19eec8;});}})[_0x7c32('0x28')](respondWithFilteredResult(_0x302f9c,_0x1b5ed3))[_0x7c32('0x46')](handleError(_0x302f9c,null));};exports['removeDispositions']=function(_0x4a2e7f,_0x74f5b4,_0xc293ee){return db['CmList']['find']({'where':{'id':_0x4a2e7f[_0x7c32('0x48')]['id']}})['then'](handleEntityNotFound(_0x74f5b4,null))['then'](function(_0x425a8e){if(_0x425a8e){return _0x425a8e[_0x7c32('0x60')](_0x4a2e7f[_0x7c32('0x36')][_0x7c32('0x61')]);}})[_0x7c32('0x28')](respondWithStatusCode(_0x74f5b4,null))[_0x7c32('0x46')](handleError(_0x74f5b4,null));};exports[_0x7c32('0x62')]=function(_0x337a1c,_0xab3ae8,_0x4a0a63){return db[_0x7c32('0x31')][_0x7c32('0x53')]({'where':{'id':_0x337a1c[_0x7c32('0x48')]['id']}})[_0x7c32('0x28')](handleEntityNotFound(_0xab3ae8,null))[_0x7c32('0x28')](function(_0x1dfd21){if(_0x1dfd21){var _0x2e10df=[];var _0x166f55={'success':[],'errors':[]};return db[_0x7c32('0x63')][_0x7c32('0x5a')]()[_0x7c32('0x28')](function(_0x3ef940){if(_0x337a1c[_0x7c32('0x58')][_0x7c32('0x64')]&&_[_0x7c32('0x65')](_0x337a1c[_0x7c32('0x58')]['tags'])){if(_0x337a1c[_0x7c32('0x58')]['tags'][_0x7c32('0x3a')]){_0x337a1c['body'][_0x7c32('0x64')]=_0x337a1c['body'][_0x7c32('0x64')]['join'](';')+';';}else{_0x337a1c['body'][_0x7c32('0x64')]=null;}}else{_0x337a1c[_0x7c32('0x58')][_0x7c32('0x64')]=null;}if(_0x337a1c[_0x7c32('0x58')]&&_[_0x7c32('0x65')](_0x337a1c[_0x7c32('0x58')])){for(var _0xbbd7ea=0x0;_0xbbd7ea<_0x337a1c['body']['length'];_0xbbd7ea+=0x1){_0x337a1c[_0x7c32('0x58')][_0xbbd7ea][_0x7c32('0x5c')]=_0x337a1c[_0x7c32('0x48')]['id'];_0x2e10df['push'](_0x337a1c[_0x7c32('0x58')][_0xbbd7ea]);}return BPromise[_0x7c32('0x66')](_0x2e10df,function(_0x219d94){return db[_0x7c32('0x63')][_0x7c32('0x4e')](_[_0x7c32('0x67')](_0x219d94,[_0x7c32('0x61'),'id'])||{},{'fields':_[_0x7c32('0x49')](_0x3ef940),'raw':!![]})[_0x7c32('0x28')](function(_0x2af2f0){_0x166f55[_0x7c32('0x68')]['push'](_0x2af2f0[_0x7c32('0x69')]);})[_0x7c32('0x46')](function(_0x51cfa5){_0x166f55['errors'][_0x7c32('0x6a')]({'data':_0x219d94,'error':_0x51cfa5[_0x7c32('0x6b')]});});})[_0x7c32('0x28')](function(_0xc98bbe){return _0x166f55;})['catch'](function(_0xda4d5c){return _0xda4d5c;});}else{_0xab3ae8[_0x7c32('0x1b')](0x190)[_0x7c32('0x23')]({'message':_0x7c32('0x6c')});}});}})[_0x7c32('0x28')](respondWithResult(_0xab3ae8,null))[_0x7c32('0x46')](handleError(_0xab3ae8,null));};exports[_0x7c32('0x6d')]=function(_0x3c8bae,_0x2871f9,_0x326ccc){var _0x5d90dd;return db[_0x7c32('0x31')][_0x7c32('0x53')]({'where':{'id':_0x3c8bae[_0x7c32('0x48')]['id']},'include':[{'model':db[_0x7c32('0x6e')],'as':_0x7c32('0x6f')}]})[_0x7c32('0x28')](handleEntityNotFound(_0x2871f9,null))[_0x7c32('0x28')](function(_0x56b320){if(_0x56b320){_0x5d90dd=_0x56b320;return db[_0x7c32('0x63')][_0x7c32('0x4a')];}})['then'](function(_0x2a0a06){if(_0x2a0a06){var _0x44a143={};var _0x794e91={};_0x794e91[_0x7c32('0x35')]=_['concat'](_[_0x7c32('0x49')](_0x2a0a06),_[_0x7c32('0x30')](_0x5d90dd[_0x7c32('0x6f')],function(_0x5b1f60){return util['format']('cf_%d',_0x5b1f60['id']);}));_0x794e91[_0x7c32('0x36')]=_[_0x7c32('0x49')](_0x3c8bae[_0x7c32('0x36')]);_0x794e91[_0x7c32('0x37')]=_['intersection'](_0x794e91[_0x7c32('0x35')],_0x794e91[_0x7c32('0x36')]);_0x44a143[_0x7c32('0x39')]=_[_0x7c32('0x38')](_0x794e91['model'],qs[_0x7c32('0x4b')](_0x3c8bae['query'][_0x7c32('0x4b')]));_0x44a143['attributes']=_0x44a143[_0x7c32('0x39')][_0x7c32('0x3a')]?_0x44a143[_0x7c32('0x39')]:_0x794e91[_0x7c32('0x35')];if(!_0x3c8bae[_0x7c32('0x36')][_0x7c32('0x3b')](_0x7c32('0x3c'))){_0x44a143[_0x7c32('0x20')]=qs['limit'](_0x3c8bae[_0x7c32('0x36')][_0x7c32('0x20')]);_0x44a143[_0x7c32('0x1d')]=qs[_0x7c32('0x1d')](_0x3c8bae['query'][_0x7c32('0x1d')]);}_0x44a143[_0x7c32('0x5f')]=qs[_0x7c32('0x3d')](_0x3c8bae['query'][_0x7c32('0x3d')]);_0x44a143[_0x7c32('0x3f')]=qs[_0x7c32('0x37')](_[_0x7c32('0x3e')](_0x3c8bae['query'],_0x794e91['filters']));_0x44a143['raw']=!![];if(_0x3c8bae[_0x7c32('0x36')][_0x7c32('0x42')]){_0x44a143[_0x7c32('0x3f')]=_[_0x7c32('0x40')](_0x44a143[_0x7c32('0x3f')],{'$or':_['map'](_0x44a143['attributes'],function(_0x3ea8d3){var _0x393e5b={};_0x393e5b[_0x3ea8d3]={'$like':'%'+_0x3c8bae[_0x7c32('0x36')][_0x7c32('0x42')]+'%'};return _0x393e5b;})});}_0x44a143=_[_0x7c32('0x40')]({},_0x44a143,_0x3c8bae[_0x7c32('0x4d')]);return _0x5d90dd[_0x7c32('0x6d')](_0x44a143);}})[_0x7c32('0x28')](respondWithResult(_0x2871f9,null))['catch'](handleError(_0x2871f9,null));};exports['getContactsCsv']=function(_0x1da29e,_0x17f229,_0x1a5b8f){var _0x1394dd;var _0x6b32ee;var _0xd1eccd;var _0x2ac07b=_0x1da29e[_0x7c32('0x48')]['id'];csv_results=[];return db[_0x7c32('0x70')]['findAll']({'attributes':['id','name'],'raw':!![],'order':[_0x7c32('0x71')]})[_0x7c32('0x28')](function(_0x4355d0){_0x1394dd=_0x4355d0;var _0x3baf7a=_['keys'](db[_0x7c32('0x63')][_0x7c32('0x4a')]);return db[_0x7c32('0x6e')]['findAll']({'raw':!![],'attributes':['id',_0x7c32('0x72')]})[_0x7c32('0x28')](function(_0x4118de){_0x6b32ee=_0x4118de;var _0x52f5f1=squel[_0x7c32('0x73')]()[_0x7c32('0x4b')](_0x3baf7a)[_0x7c32('0x74')](_0x7c32('0x75'),'c')['where'](_0x7c32('0x76'),_0x2ac07b)[_0x7c32('0x3f')](_0x7c32('0x77'))[_0x7c32('0x78')]();for(var _0x37d55a=0x0;_0x37d55a<_0x6b32ee['length'];_0x37d55a++){_0x52f5f1[_0x7c32('0x79')](_0x7c32('0x7a')+_0x6b32ee[_0x37d55a]['id'],_0x7c32('0x7b')+_0x6b32ee[_0x37d55a][_0x7c32('0x72')]);}for(var _0x37d55a=0x0;_0x37d55a<_0x1394dd[_0x7c32('0x3a')];_0x37d55a++){_0x52f5f1[_0x7c32('0x79')](squel[_0x7c32('0x73')]()['field'](_0x7c32('0x7c'))[_0x7c32('0x74')](_0x7c32('0x7d'))[_0x7c32('0x3f')](_0x7c32('0x7e'),_0x1394dd[_0x37d55a]['id'])['where'](_0x7c32('0x7f')),_0x7c32('0x80')+_0x1394dd[_0x37d55a][_0x7c32('0x2d')]);_0x52f5f1['field'](squel['select']()[_0x7c32('0x79')](_0x7c32('0x81'))[_0x7c32('0x74')]('cm_contact_has_items')[_0x7c32('0x3f')](_0x7c32('0x7e'),_0x1394dd[_0x37d55a]['id'])[_0x7c32('0x3f')](_0x7c32('0x7f')),'description_additionalPhone_'+_0x1394dd[_0x37d55a][_0x7c32('0x2d')]);}var _0x4c57b2=[];_0x4c57b2[_0x7c32('0x6a')](_0x52f5f1[_0x7c32('0x82')]());BPromise[_0x7c32('0x66')](_0x4c57b2,handleQuery)['then'](function(_0x135770){handleQuery(_0x52f5f1[_0x7c32('0x82')]());var _0x4980f3=csv_results[0x0];if(!_[_0x7c32('0x83')](_0x4980f3)){var _0x8891fe=toCsv(_0x4980f3);var _0x3c106b=Date[_0x7c32('0x84')]();fs[_0x7c32('0x85')](util[_0x7c32('0x86')](_0x7c32('0x87'),_0x2ac07b,_0x3c106b),_0x8891fe);_0x17f229[_0x7c32('0x88')](_0x7c32('0x89'),_0x7c32('0x8a')+util[_0x7c32('0x86')](_0x7c32('0x8b'),_0x2ac07b,_0x3c106b));_0x17f229[_0x7c32('0x88')]('Content-type',_0x7c32('0x8c'));return _0x17f229[_0x7c32('0x8d')](util[_0x7c32('0x86')](_0x7c32('0x87'),_0x2ac07b,_0x3c106b));}else{return _0x17f229[_0x7c32('0x1a')](0xcc);}});});});};exports[_0x7c32('0x8e')]=function(_0x21de30,_0x4d21e7,_0x35addf){var _0xcad400;delete _0x21de30['body']['id'];return db[_0x7c32('0x31')][_0x7c32('0x8f')]({'where':{'id':_0x21de30[_0x7c32('0x48')]['id']}})[_0x7c32('0x28')](handleEntityNotFound(_0x4d21e7,null))[_0x7c32('0x28')](function(_0x2a954d){if(_0x2a954d){return db['sequelize']['transaction'](function(_0x3a765c){return db[_0x7c32('0x6e')][_0x7c32('0x4e')](_0x21de30[_0x7c32('0x58')],{'transaction':_0x3a765c})['then'](function(_0xf2301e){_0xcad400=_0xf2301e;return _0x2a954d[_0x7c32('0x90')](_0xf2301e,{'transaction':_0x3a765c});})[_0x7c32('0x28')](function(){var _0x43e4fc={'type':db[_0x7c32('0x91')]['TEXT'],'transaction':_0x3a765c};switch(_0x21de30[_0x7c32('0x58')][_0x7c32('0x33')]){case _0x7c32('0x92'):_0x43e4fc[_0x7c32('0x33')]=db['Sequelize'][_0x7c32('0x93')];break;case _0x7c32('0x94'):_0x43e4fc[_0x7c32('0x33')]=db[_0x7c32('0x91')][_0x7c32('0x95')];break;case _0x7c32('0x96'):_0x43e4fc[_0x7c32('0x33')]=db[_0x7c32('0x91')][_0x7c32('0x97')];_0x43e4fc[_0x7c32('0x98')]=![];break;default:}return db[_0x7c32('0x99')][_0x7c32('0x9a')][_0x7c32('0x9b')](_0x7c32('0x75'),util[_0x7c32('0x86')]('cf_%s',_0xcad400['id']),_0x43e4fc);})[_0x7c32('0x28')](function(){return _0xcad400;});});}})[_0x7c32('0x28')](respondWithResult(_0x4d21e7,null))[_0x7c32('0x46')](handleError(_0x4d21e7,null));};exports[_0x7c32('0x9c')]=function(_0x486e76,_0x48309d,_0x1783ec){var _0x26f246={};var _0x33b188={};var _0x35ac70;var _0x1796c9;return db[_0x7c32('0x31')][_0x7c32('0x8f')]({'where':{'id':_0x486e76['params']['id']}})[_0x7c32('0x28')](handleEntityNotFound(_0x48309d,null))[_0x7c32('0x28')](function(_0x2fdb2d){if(_0x2fdb2d){_0x35ac70=_0x2fdb2d;_0x33b188[_0x7c32('0x35')]=_[_0x7c32('0x49')](db['CmCustomField'][_0x7c32('0x4a')]);_0x33b188[_0x7c32('0x36')]=_[_0x7c32('0x49')](_0x486e76['query']);_0x33b188[_0x7c32('0x37')]=_['intersection'](_0x33b188[_0x7c32('0x35')],_0x33b188[_0x7c32('0x36')]);_0x26f246[_0x7c32('0x39')]=_[_0x7c32('0x38')](_0x33b188[_0x7c32('0x35')],qs[_0x7c32('0x4b')](_0x486e76['query'][_0x7c32('0x4b')]));_0x26f246['attributes']=_0x26f246[_0x7c32('0x39')][_0x7c32('0x3a')]?_0x26f246[_0x7c32('0x39')]:_0x33b188[_0x7c32('0x35')];_0x26f246[_0x7c32('0x5f')]=qs[_0x7c32('0x3d')](_0x486e76[_0x7c32('0x36')][_0x7c32('0x3d')]);_0x26f246['where']=qs['filters'](_[_0x7c32('0x3e')](_0x486e76[_0x7c32('0x36')],_0x33b188[_0x7c32('0x37')]));_0x26f246[_0x7c32('0x3f')]=_[_0x7c32('0x40')](_0x26f246[_0x7c32('0x3f')],{'$or':[{'ListId':_0x2fdb2d['id']},{'ListId':null}]});if(_0x486e76[_0x7c32('0x36')][_0x7c32('0x42')]){_0x26f246[_0x7c32('0x3f')]=_[_0x7c32('0x40')](_0x26f246[_0x7c32('0x3f')],{'$or':_[_0x7c32('0x30')](_0x26f246[_0x7c32('0x39')],function(_0x5a0aa6){var _0x5cd953={};_0x5cd953[_0x5a0aa6]={'$like':'%'+_0x486e76[_0x7c32('0x36')][_0x7c32('0x42')]+'%'};return _0x5cd953;})});}_0x26f246=_['merge']({},_0x26f246,_0x486e76[_0x7c32('0x4d')]);return db[_0x7c32('0x6e')]['findAndCountAll'](_0x26f246);}})[_0x7c32('0x28')](respondWithResult(_0x48309d,null))[_0x7c32('0x46')](handleError(_0x48309d,null));};exports[_0x7c32('0x9d')]=function(_0x3efb8a,_0x4581a3){return db[_0x7c32('0x6e')][_0x7c32('0x9e')]({'where':{'ListId':null}})[_0x7c32('0x28')](handleEntityNotFound(_0x4581a3,null))[_0x7c32('0x28')](function(_0x4f6d9e){return _0x4f6d9e;})[_0x7c32('0x28')](respondWithResult(_0x4581a3,null))['catch'](handleError(_0x4581a3,null));};exports[_0x7c32('0x9f')]=function(_0x5149a5,_0x16ab6f,_0x5ef535){return db[_0x7c32('0x31')][_0x7c32('0x53')]({'where':{'id':_0x5149a5[_0x7c32('0x48')]['id']}})[_0x7c32('0x28')](handleEntityNotFound(_0x16ab6f,null))[_0x7c32('0x28')](function(_0x5789ec){if(_0x5789ec){return _0x5789ec[_0x7c32('0x9f')](_0x5149a5['body']['ids'],_['omit'](_0x5149a5[_0x7c32('0x58')],[_0x7c32('0x61'),'id'])||{})[_0x7c32('0xa0')](function(_0x1682d5){for(var _0x4a6d69=0x0;_0x4a6d69<_0x5149a5[_0x7c32('0x58')][_0x7c32('0x61')][_0x7c32('0x3a')];_0x4a6d69+=0x1){socket[_0x7c32('0xa1')](_0x7c32('0xa2'),{'UserId':Number(_0x5149a5[_0x7c32('0x58')][_0x7c32('0x61')][_0x4a6d69]),'CmListId':Number(_0x5149a5[_0x7c32('0x48')]['id'])});}return _0x1682d5;});}})[_0x7c32('0x28')](respondWithResult(_0x16ab6f,null))[_0x7c32('0x46')](handleError(_0x16ab6f,null));};exports[_0x7c32('0xa3')]=function(_0x35eedd,_0x563dd3,_0x2a3949){return db[_0x7c32('0x31')][_0x7c32('0x53')]({'where':{'id':_0x35eedd['params']['id']}})[_0x7c32('0x28')](handleEntityNotFound(_0x563dd3,null))['then'](function(_0xbdf8d6){if(_0xbdf8d6){return _0xbdf8d6['removeAgents'](_0x35eedd[_0x7c32('0x36')]['ids'])[_0x7c32('0x28')](function(){if(_[_0x7c32('0x65')](_0x35eedd[_0x7c32('0x36')][_0x7c32('0x61')])){for(var _0x3a28c8=0x0;_0x3a28c8<_0x35eedd[_0x7c32('0x36')][_0x7c32('0x61')][_0x7c32('0x3a')];_0x3a28c8+=0x1){socket[_0x7c32('0xa1')](_0x7c32('0xa4'),{'UserId':Number(_0x35eedd['query']['ids'][_0x3a28c8]),'CmListId':Number(_0x35eedd[_0x7c32('0x48')]['id'])});}}else{socket[_0x7c32('0xa1')]('userCmList:remove',{'UserId':Number(_0x35eedd[_0x7c32('0x36')][_0x7c32('0x61')]),'CmListId':Number(_0x35eedd['params']['id'])});}});}})[_0x7c32('0x28')](respondWithStatusCode(_0x563dd3,null))['catch'](handleError(_0x563dd3,null));};exports[_0x7c32('0xa5')]=function(_0x37baa3,_0x1b918,_0x4630f1){var _0x298cc5={};var _0x544c9b={};var _0x952baa;var _0x42c059;return db[_0x7c32('0x31')][_0x7c32('0x8f')]({'where':{'id':_0x37baa3[_0x7c32('0x48')]['id']}})[_0x7c32('0x28')](handleEntityNotFound(_0x1b918,null))[_0x7c32('0x28')](function(_0x3c0c61){if(_0x3c0c61){_0x952baa=_0x3c0c61;_0x544c9b[_0x7c32('0x35')]=_[_0x7c32('0x49')](db[_0x7c32('0xa6')][_0x7c32('0x4a')]);_0x544c9b[_0x7c32('0x36')]=_[_0x7c32('0x49')](_0x37baa3[_0x7c32('0x36')]);_0x544c9b[_0x7c32('0x37')]=_[_0x7c32('0x38')](_0x544c9b[_0x7c32('0x35')],_0x544c9b[_0x7c32('0x36')]);_0x298cc5['attributes']=_[_0x7c32('0x38')](_0x544c9b['model'],qs[_0x7c32('0x4b')](_0x37baa3[_0x7c32('0x36')]['fields']));_0x298cc5[_0x7c32('0x39')]=_0x298cc5[_0x7c32('0x39')][_0x7c32('0x3a')]?_0x298cc5['attributes']:_0x544c9b[_0x7c32('0x35')];_0x298cc5[_0x7c32('0x5f')]=qs[_0x7c32('0x3d')](_0x37baa3[_0x7c32('0x36')][_0x7c32('0x3d')]);_0x298cc5[_0x7c32('0x3f')]=qs[_0x7c32('0x37')](_['pick'](_0x37baa3['query'],_0x544c9b[_0x7c32('0x37')]));if(_0x37baa3['query']['filter']){_0x298cc5[_0x7c32('0x3f')]=_[_0x7c32('0x40')](_0x298cc5[_0x7c32('0x3f')],{'$or':_[_0x7c32('0x30')](_0x298cc5[_0x7c32('0x39')],function(_0x5adeb4){var _0x3d09f7={};_0x3d09f7[_0x5adeb4]={'$like':'%'+_0x37baa3[_0x7c32('0x36')][_0x7c32('0x42')]+'%'};return _0x3d09f7;})});}_0x298cc5=_[_0x7c32('0x40')]({},_0x298cc5,_0x37baa3[_0x7c32('0x4d')]);return _0x952baa[_0x7c32('0xa5')](_0x298cc5);}})['then'](function(_0x4e1c37){if(_0x4e1c37){_0x42c059=_0x4e1c37[_0x7c32('0x3a')];if(!_0x37baa3['query'][_0x7c32('0x3b')](_0x7c32('0x3c'))){_0x298cc5[_0x7c32('0x20')]=qs['limit'](_0x37baa3[_0x7c32('0x36')][_0x7c32('0x20')]);_0x298cc5[_0x7c32('0x1d')]=qs[_0x7c32('0x1d')](_0x37baa3['query']['offset']);}return _0x952baa['getAgents'](_0x298cc5);}})[_0x7c32('0x28')](function(_0x5853d5){if(_0x5853d5){return _0x5853d5?{'count':_0x42c059,'rows':_0x5853d5}:null;}})[_0x7c32('0x28')](respondWithResult(_0x1b918,null))[_0x7c32('0x46')](handleError(_0x1b918,null));};function handleQuery(_0x16ea3e){logger[_0x7c32('0xa7')](_0x16ea3e);return db[_0x7c32('0x99')][_0x7c32('0x36')](_0x16ea3e)[_0x7c32('0xa0')](function(_0x230bf1){csv_results[_0x7c32('0x6a')](_0x230bf1);})['catch'](function(_0x3a6ed0){logger[_0x7c32('0x56')](_0x3a6ed0[_0x7c32('0x6b')]);});}