b153b0e8bfad4022330722f3cc749494d9cc05b4
[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 _0x76c1=['queryInterface','addColumn','getCustomFields','findAndCountAll','addAgents','emit','userCmList:save','removeAgents','userCmList:remove','getAgents','User','info','message','eml-format','rimraf','zip-dir','fast-json-patch','request-promise','moment','util','path','sox','fs-extra','lodash','crypto','jsforce','desk.js','papaparse','ioredis','../../components/parsers/qs','../../components/parsers/advancedSearch','../../config/logger','api','../../config/utils','../../config/license/util','redis','defaults','localhost','./cmList.socket','register','status','end','json','undefined','limit','count','offset','set','Content-Range','apply','reject','save','update','then','destroy','Lists','UserProfileResource','sendStatus','error','stack','name','send','index','CmList','type','key','model','map','query','keys','filters','intersection','fields','attributes','hasOwnProperty','nolimit','order','sort','where','filter','merge','VIRTUAL','options','includeAll','findAll','rows','show','params','rawAttributes','include','find','catch','create','user','get','Unable\x20to\x20retrieve\x20the\x20current\x20user','role','UserProfileSection','userProfileId','Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s','body','describe','addDisposition','ListId','Disposition','getDispositions','findOne','length','pick','removeDispositions','ids','addContacts','CmContact','tags','join','isArray','omit','success','dataValues','push','Malformed\x20request\x20syntax','getContacts','CmCustomField','concat','CustomFields','format','cf_%d','getContactsCsv','ContactItemType','OrderBy','alias','select','from','cm_contacts','c.ListId\x20=\x20?','distinct','field','c.cf_','customField_','item','cm_contact_has_items','ItemTypeId\x20=\x20?','CmContactId\x20=\x20c.id','additionalPhone_','description','description_additionalPhone_','toString','each','isEmpty','/tmp/list_%d_%s.csv','setHeader','Content-disposition','attachment;\x20filename=','list_%d_%s.csv','Content-type','text/csv','download','sequelize','transaction','addCustomFields','Sequelize','TEXT','text','number','INTEGER','switch','BOOLEAN'];(function(_0x46e418,_0x5c4d24){var _0x5e1be5=function(_0x170bd4){while(--_0x170bd4){_0x46e418['push'](_0x46e418['shift']());}};_0x5e1be5(++_0x5c4d24);}(_0x76c1,0x15b));var _0x176c=function(_0x576d8a,_0x2d7bde){_0x576d8a=_0x576d8a-0x0;var _0x3dc3ef=_0x76c1[_0x576d8a];return _0x3dc3ef;};'use strict';var emlformat=require(_0x176c('0x0'));var rimraf=require(_0x176c('0x1'));var zipdir=require(_0x176c('0x2'));var jsonpatch=require(_0x176c('0x3'));var rp=require(_0x176c('0x4'));var moment=require(_0x176c('0x5'));var BPromise=require('bluebird');var Mustache=require('mustache');var util=require(_0x176c('0x6'));var path=require(_0x176c('0x7'));var sox=require(_0x176c('0x8'));var csv=require('to-csv');var ejs=require('ejs');var fs=require('fs');var fs_extra=require(_0x176c('0x9'));var _=require(_0x176c('0xa'));var squel=require('squel');var crypto=require(_0x176c('0xb'));var jsforce=require(_0x176c('0xc'));var deskjs=require(_0x176c('0xd'));var toCsv=require('to-csv');var querystring=require('querystring');var Papa=require(_0x176c('0xe'));var Redis=require(_0x176c('0xf'));var authService=require('../../components/auth/service');var qs=require(_0x176c('0x10'));var as=require(_0x176c('0x11'));var hardwareService=require('../../config/license/hardware');var logger=require(_0x176c('0x12'))(_0x176c('0x13'));var utils=require(_0x176c('0x14'));var config=require('../../config/environment');var licenseUtil=require(_0x176c('0x15'));var db=require('../../mysqldb')['db'];var csv_results;config[_0x176c('0x16')]=_[_0x176c('0x17')](config['redis'],{'host':_0x176c('0x18'),'port':0x18eb});var socket=require('socket.io-emitter')(new Redis(config[_0x176c('0x16')]));require(_0x176c('0x19'))[_0x176c('0x1a')](socket);function respondWithStatusCode(_0x701920,_0x5bf5ca){_0x5bf5ca=_0x5bf5ca||0xcc;return function(_0x1b9f08){if(_0x1b9f08){return _0x701920['sendStatus'](_0x5bf5ca);}return _0x701920[_0x176c('0x1b')](_0x5bf5ca)[_0x176c('0x1c')]();};}function respondWithResult(_0x27693f,_0x62000e){_0x62000e=_0x62000e||0xc8;return function(_0x2a7f32){if(_0x2a7f32){return _0x27693f[_0x176c('0x1b')](_0x62000e)[_0x176c('0x1d')](_0x2a7f32);}};}function respondWithFilteredResult(_0x4cbad3,_0x1ab71f){return function(_0x2b33c3){if(_0x2b33c3){var _0x4301fc=typeof _0x1ab71f['offset']===_0x176c('0x1e')&&typeof _0x1ab71f[_0x176c('0x1f')]==='undefined';var _0x5cd3c5=_0x2b33c3[_0x176c('0x20')];var _0x20f856=_0x4301fc?0x0:_0x1ab71f[_0x176c('0x21')];var _0x16b1c0=_0x4301fc?_0x2b33c3['count']:_0x1ab71f[_0x176c('0x21')]+_0x1ab71f[_0x176c('0x1f')];var _0xd9b48d;if(_0x16b1c0>=_0x5cd3c5){_0x16b1c0=_0x5cd3c5;_0xd9b48d=0xc8;}else{_0xd9b48d=0xce;}_0x4cbad3[_0x176c('0x1b')](_0xd9b48d);return _0x4cbad3[_0x176c('0x22')](_0x176c('0x23'),_0x20f856+'-'+_0x16b1c0+'/'+_0x5cd3c5)[_0x176c('0x1d')](_0x2b33c3);}return null;};}function patchUpdates(_0x1c83a0){return function(_0x2fee46){try{jsonpatch[_0x176c('0x24')](_0x2fee46,_0x1c83a0,!![]);}catch(_0x15e442){return BPromise[_0x176c('0x25')](_0x15e442);}return _0x2fee46[_0x176c('0x26')]();};}function saveUpdates(_0x2b8f1a,_0x54038f){return function(_0x2b8724){if(_0x2b8724){return _0x2b8724[_0x176c('0x27')](_0x2b8f1a)[_0x176c('0x28')](function(_0x1e9815){return _0x1e9815;});}return null;};}function removeEntity(_0x49e882,_0x5b8b92){return function(_0x5956b2){if(_0x5956b2){return _0x5956b2[_0x176c('0x29')]()[_0x176c('0x28')](function(){var _0x482bb8=_0x5956b2['get']({'plain':!![]});var _0x162f26=_0x176c('0x2a');return db[_0x176c('0x2b')][_0x176c('0x29')]({'where':{'type':_0x162f26,'resourceId':_0x482bb8['id']}})['then'](function(){return _0x5956b2;});})[_0x176c('0x28')](function(){_0x49e882[_0x176c('0x1b')](0xcc)['end']();});}};}function handleEntityNotFound(_0x16e3ee,_0x1132f5){return function(_0x51df1e){if(!_0x51df1e){_0x16e3ee[_0x176c('0x2c')](0x194);}return _0x51df1e;};}function handleError(_0x4eb170,_0x347512){_0x347512=_0x347512||0x1f4;return function(_0x362261){logger[_0x176c('0x2d')](_0x362261[_0x176c('0x2e')]);if(_0x362261[_0x176c('0x2f')]){delete _0x362261[_0x176c('0x2f')];}_0x4eb170[_0x176c('0x1b')](_0x347512)[_0x176c('0x30')](_0x362261);};}exports[_0x176c('0x31')]=function(_0x465052,_0x5e2fa3){var _0xecc3cb={},_0x1a547c={},_0x58b16d={'count':0x0,'rows':[]};var _0x357820=_['map'](db[_0x176c('0x32')]['rawAttributes'],function(_0x451231){return{'name':_0x451231['fieldName'],'type':_0x451231[_0x176c('0x33')][_0x176c('0x34')]};});_0x1a547c[_0x176c('0x35')]=_[_0x176c('0x36')](_0x357820,_0x176c('0x2f'));_0x1a547c[_0x176c('0x37')]=_[_0x176c('0x38')](_0x465052[_0x176c('0x37')]);_0x1a547c[_0x176c('0x39')]=_[_0x176c('0x3a')](_0x1a547c['model'],_0x1a547c['query']);_0xecc3cb['attributes']=_['intersection'](_0x1a547c['model'],qs[_0x176c('0x3b')](_0x465052[_0x176c('0x37')][_0x176c('0x3b')]));_0xecc3cb[_0x176c('0x3c')]=_0xecc3cb[_0x176c('0x3c')]['length']?_0xecc3cb[_0x176c('0x3c')]:_0x1a547c[_0x176c('0x35')];if(!_0x465052[_0x176c('0x37')][_0x176c('0x3d')](_0x176c('0x3e'))){_0xecc3cb['limit']=qs[_0x176c('0x1f')](_0x465052[_0x176c('0x37')][_0x176c('0x1f')]);_0xecc3cb[_0x176c('0x21')]=qs['offset'](_0x465052[_0x176c('0x37')][_0x176c('0x21')]);}_0xecc3cb[_0x176c('0x3f')]=qs[_0x176c('0x40')](_0x465052[_0x176c('0x37')][_0x176c('0x40')]);_0xecc3cb[_0x176c('0x41')]=qs[_0x176c('0x39')](_['pick'](_0x465052[_0x176c('0x37')],_0x1a547c['filters']),_0x357820);if(_0x465052[_0x176c('0x37')][_0x176c('0x42')]){_0xecc3cb[_0x176c('0x41')]=_[_0x176c('0x43')](_0xecc3cb[_0x176c('0x41')],{'$or':_[_0x176c('0x36')](_0x357820,function(_0x49c19f){if(_0x49c19f[_0x176c('0x33')]!==_0x176c('0x44')){var _0x5298b5={};_0x5298b5[_0x49c19f['name']]={'$like':'%'+_0x465052[_0x176c('0x37')][_0x176c('0x42')]+'%'};return _0x5298b5;}})});}_0xecc3cb=_[_0x176c('0x43')]({},_0xecc3cb,_0x465052[_0x176c('0x45')]);var _0xa9fca4={'where':_0xecc3cb['where']};return db[_0x176c('0x32')]['count'](_0xa9fca4)['then'](function(_0x26f489){_0x58b16d[_0x176c('0x20')]=_0x26f489;if(_0x465052[_0x176c('0x37')][_0x176c('0x46')]){_0xecc3cb['include']=[{'all':!![]}];}return db[_0x176c('0x32')][_0x176c('0x47')](_0xecc3cb);})['then'](function(_0x22698c){_0x58b16d[_0x176c('0x48')]=_0x22698c;return _0x58b16d;})[_0x176c('0x28')](respondWithFilteredResult(_0x5e2fa3,_0xecc3cb))['catch'](handleError(_0x5e2fa3,null));};exports[_0x176c('0x49')]=function(_0x28e385,_0x101a9f){var _0x5d966a={'raw':![],'where':{'id':_0x28e385[_0x176c('0x4a')]['id']}},_0x490086={};_0x490086[_0x176c('0x35')]=_[_0x176c('0x38')](db[_0x176c('0x32')][_0x176c('0x4b')]);_0x490086[_0x176c('0x37')]=_[_0x176c('0x38')](_0x28e385[_0x176c('0x37')]);_0x490086[_0x176c('0x39')]=_['intersection'](_0x490086[_0x176c('0x35')],_0x490086['query']);_0x5d966a[_0x176c('0x3c')]=_[_0x176c('0x3a')](_0x490086[_0x176c('0x35')],qs[_0x176c('0x3b')](_0x28e385[_0x176c('0x37')][_0x176c('0x3b')]));_0x5d966a[_0x176c('0x3c')]=_0x5d966a[_0x176c('0x3c')]['length']?_0x5d966a[_0x176c('0x3c')]:_0x490086[_0x176c('0x35')];if(_0x28e385[_0x176c('0x37')][_0x176c('0x46')]){_0x5d966a[_0x176c('0x4c')]=[{'all':!![]}];}_0x5d966a=_[_0x176c('0x43')]({},_0x5d966a,_0x28e385[_0x176c('0x45')]);return db[_0x176c('0x32')][_0x176c('0x4d')](_0x5d966a)['then'](handleEntityNotFound(_0x101a9f,null))['then'](respondWithResult(_0x101a9f,null))[_0x176c('0x4e')](handleError(_0x101a9f,null));};exports[_0x176c('0x4f')]=function(_0x21b909,_0x45e692){return db['CmList'][_0x176c('0x4f')](_0x21b909['body'],{})[_0x176c('0x28')](function(_0x41b690){var _0x24a518=_0x21b909[_0x176c('0x50')][_0x176c('0x51')]({'plain':!![]});if(!_0x24a518)throw new Error(_0x176c('0x52'));if(_0x24a518[_0x176c('0x53')]===_0x176c('0x50')){var _0x424533=_0x41b690[_0x176c('0x51')]({'plain':!![]});var _0x1992ab='Lists';return db[_0x176c('0x54')]['find']({'where':{'name':_0x1992ab,'userProfileId':_0x24a518[_0x176c('0x55')]},'raw':!![]})[_0x176c('0x28')](function(_0x52cc40){if(_0x52cc40&&_0x52cc40['autoAssociation']===0x0){return db[_0x176c('0x2b')]['create']({'name':_0x424533[_0x176c('0x2f')],'resourceId':_0x424533['id'],'type':_0x52cc40[_0x176c('0x2f')],'sectionId':_0x52cc40['id']},{})[_0x176c('0x28')](function(){return _0x41b690;});}else{return _0x41b690;}})[_0x176c('0x4e')](function(_0x2e489f){logger[_0x176c('0x2d')](_0x176c('0x56'),_0x2e489f);throw _0x2e489f;});}return _0x41b690;})[_0x176c('0x28')](respondWithResult(_0x45e692,0xc9))[_0x176c('0x4e')](handleError(_0x45e692,null));};exports['update']=function(_0xf1ab1d,_0x23eedf){if(_0xf1ab1d['body']['id']){delete _0xf1ab1d[_0x176c('0x57')]['id'];}return db[_0x176c('0x32')]['find']({'where':{'id':_0xf1ab1d['params']['id']}})[_0x176c('0x28')](handleEntityNotFound(_0x23eedf,null))[_0x176c('0x28')](saveUpdates(_0xf1ab1d[_0x176c('0x57')],null))[_0x176c('0x28')](respondWithResult(_0x23eedf,null))['catch'](handleError(_0x23eedf,null));};exports[_0x176c('0x29')]=function(_0x27d037,_0x217fda){return db['CmList']['find']({'where':{'id':_0x27d037['params']['id']}})['then'](handleEntityNotFound(_0x217fda,null))[_0x176c('0x28')](removeEntity(_0x217fda,null))[_0x176c('0x4e')](handleError(_0x217fda,null));};exports[_0x176c('0x58')]=function(_0x245032,_0x13b526){return db[_0x176c('0x32')]['describe']()['then'](respondWithResult(_0x13b526,null))['catch'](handleError(_0x13b526,null));};exports[_0x176c('0x59')]=function(_0x4b868b,_0x39a821,_0x24a2e7){if(_0x4b868b['body']['id']){delete _0x4b868b[_0x176c('0x57')]['id'];}return db[_0x176c('0x32')][_0x176c('0x4d')]({'where':{'id':_0x4b868b[_0x176c('0x4a')]['id']}})[_0x176c('0x28')](handleEntityNotFound(_0x39a821,null))[_0x176c('0x28')](function(_0x78fa08){if(_0x78fa08){_0x4b868b[_0x176c('0x57')][_0x176c('0x5a')]=_0x78fa08['id'];return db[_0x176c('0x5b')][_0x176c('0x4f')](_0x4b868b[_0x176c('0x57')]);}})[_0x176c('0x28')](respondWithResult(_0x39a821,null))[_0x176c('0x4e')](handleError(_0x39a821,null));};exports[_0x176c('0x5c')]=function(_0x2247bb,_0x26bd26,_0x165a45){var _0x44ec11={'raw':![],'where':{}};var _0x4df801={};var _0x1949e1={'count':0x0,'rows':[]};return db[_0x176c('0x32')][_0x176c('0x5d')]({'where':{'id':_0x2247bb[_0x176c('0x4a')]['id']}})[_0x176c('0x28')](handleEntityNotFound(_0x26bd26,null))[_0x176c('0x28')](function(_0x16bbe2){if(_0x16bbe2){_0x4df801[_0x176c('0x35')]=_[_0x176c('0x38')](db[_0x176c('0x5b')][_0x176c('0x4b')]);_0x4df801[_0x176c('0x37')]=_[_0x176c('0x38')](_0x2247bb[_0x176c('0x37')]);_0x4df801['filters']=_[_0x176c('0x3a')](_0x4df801[_0x176c('0x35')],_0x4df801[_0x176c('0x37')]);_0x44ec11['attributes']=_[_0x176c('0x3a')](_0x4df801['model'],qs[_0x176c('0x3b')](_0x2247bb[_0x176c('0x37')]['fields']));_0x44ec11[_0x176c('0x3c')]=_0x44ec11[_0x176c('0x3c')][_0x176c('0x5e')]?_0x44ec11[_0x176c('0x3c')]:_0x4df801[_0x176c('0x35')];if(!_0x2247bb[_0x176c('0x37')][_0x176c('0x3d')](_0x176c('0x3e'))){_0x44ec11[_0x176c('0x1f')]=qs['limit'](_0x2247bb[_0x176c('0x37')][_0x176c('0x1f')]);_0x44ec11[_0x176c('0x21')]=qs[_0x176c('0x21')](_0x2247bb[_0x176c('0x37')][_0x176c('0x21')]);}_0x44ec11['order']=qs[_0x176c('0x40')](_0x2247bb[_0x176c('0x37')][_0x176c('0x40')]);_0x44ec11['where']=qs['filters'](_[_0x176c('0x5f')](_0x2247bb[_0x176c('0x37')],_0x4df801[_0x176c('0x39')]));_0x44ec11[_0x176c('0x41')][_0x176c('0x5a')]=_0x16bbe2['id'];if(_0x2247bb[_0x176c('0x37')]['filter']){_0x44ec11[_0x176c('0x41')]=_[_0x176c('0x43')](_0x44ec11['where'],{'$or':_[_0x176c('0x36')](_0x44ec11[_0x176c('0x3c')],function(_0x455b8d){var _0xec1386={};_0xec1386[_0x455b8d]={'$like':'%'+_0x2247bb['query'][_0x176c('0x42')]+'%'};return _0xec1386;})});}_0x44ec11=_['merge']({},_0x44ec11,_0x2247bb['options']);return db[_0x176c('0x5b')][_0x176c('0x20')]({'where':_0x44ec11[_0x176c('0x41')]})[_0x176c('0x28')](function(_0x1a1194){_0x1949e1[_0x176c('0x20')]=_0x1a1194;if(_0x2247bb[_0x176c('0x37')][_0x176c('0x46')]){_0x44ec11[_0x176c('0x4c')]=[{'all':!![]}];}return db[_0x176c('0x5b')][_0x176c('0x47')](_0x44ec11);})['then'](function(_0x2783de){_0x1949e1[_0x176c('0x48')]=_0x2783de;return _0x1949e1;});}})[_0x176c('0x28')](respondWithFilteredResult(_0x26bd26,_0x44ec11))[_0x176c('0x4e')](handleError(_0x26bd26,null));};exports['removeDispositions']=function(_0x207206,_0x490cf8,_0x26594e){return db['CmList']['find']({'where':{'id':_0x207206[_0x176c('0x4a')]['id']}})['then'](handleEntityNotFound(_0x490cf8,null))[_0x176c('0x28')](function(_0x55bfd4){if(_0x55bfd4){return _0x55bfd4[_0x176c('0x60')](_0x207206[_0x176c('0x37')][_0x176c('0x61')]);}})[_0x176c('0x28')](respondWithStatusCode(_0x490cf8,null))[_0x176c('0x4e')](handleError(_0x490cf8,null));};exports[_0x176c('0x62')]=function(_0x115850,_0x6ef15c,_0x494375){return db['CmList'][_0x176c('0x4d')]({'where':{'id':_0x115850[_0x176c('0x4a')]['id']}})[_0x176c('0x28')](handleEntityNotFound(_0x6ef15c,null))['then'](function(_0x987f75){if(_0x987f75){var _0x32fdff=[];var _0x11c8e2={'success':[],'errors':[]};return db[_0x176c('0x63')][_0x176c('0x58')]()[_0x176c('0x28')](function(_0x2161de){if(_0x115850[_0x176c('0x57')]['tags']&&_['isArray'](_0x115850[_0x176c('0x57')][_0x176c('0x64')])){if(_0x115850[_0x176c('0x57')][_0x176c('0x64')][_0x176c('0x5e')]){_0x115850[_0x176c('0x57')][_0x176c('0x64')]=_0x115850[_0x176c('0x57')][_0x176c('0x64')][_0x176c('0x65')](';')+';';}else{_0x115850[_0x176c('0x57')][_0x176c('0x64')]=null;}}else{_0x115850['body'][_0x176c('0x64')]=null;}if(_0x115850[_0x176c('0x57')]&&_[_0x176c('0x66')](_0x115850[_0x176c('0x57')])){for(var _0x41ce6f=0x0;_0x41ce6f<_0x115850['body']['length'];_0x41ce6f+=0x1){_0x115850[_0x176c('0x57')][_0x41ce6f][_0x176c('0x5a')]=_0x115850[_0x176c('0x4a')]['id'];_0x32fdff['push'](_0x115850[_0x176c('0x57')][_0x41ce6f]);}return BPromise['each'](_0x32fdff,function(_0x2c3857){return db[_0x176c('0x63')][_0x176c('0x4f')](_[_0x176c('0x67')](_0x2c3857,[_0x176c('0x61'),'id'])||{},{'fields':_[_0x176c('0x38')](_0x2161de),'raw':!![]})[_0x176c('0x28')](function(_0x212194){_0x11c8e2[_0x176c('0x68')]['push'](_0x212194[_0x176c('0x69')]);})[_0x176c('0x4e')](function(_0x288050){_0x11c8e2['errors'][_0x176c('0x6a')]({'data':_0x2c3857,'error':_0x288050['message']});});})[_0x176c('0x28')](function(_0xc6779d){return _0x11c8e2;})[_0x176c('0x4e')](function(_0x1fea6a){return _0x1fea6a;});}else{_0x6ef15c[_0x176c('0x1b')](0x190)[_0x176c('0x1d')]({'message':_0x176c('0x6b')});}});}})[_0x176c('0x28')](respondWithResult(_0x6ef15c,null))['catch'](handleError(_0x6ef15c,null));};exports[_0x176c('0x6c')]=function(_0x18e0f7,_0x10f3d8,_0x1df7c7){var _0x22bb4b;return db['CmList'][_0x176c('0x4d')]({'where':{'id':_0x18e0f7[_0x176c('0x4a')]['id']},'include':[{'model':db[_0x176c('0x6d')],'as':'CustomFields'}]})[_0x176c('0x28')](handleEntityNotFound(_0x10f3d8,null))[_0x176c('0x28')](function(_0x5be476){if(_0x5be476){_0x22bb4b=_0x5be476;return db[_0x176c('0x63')][_0x176c('0x4b')];}})[_0x176c('0x28')](function(_0x4f76bf){if(_0x4f76bf){var _0x215ce8={};var _0x1b285e={};_0x1b285e['model']=_[_0x176c('0x6e')](_[_0x176c('0x38')](_0x4f76bf),_[_0x176c('0x36')](_0x22bb4b[_0x176c('0x6f')],function(_0x5b88a7){return util[_0x176c('0x70')](_0x176c('0x71'),_0x5b88a7['id']);}));_0x1b285e[_0x176c('0x37')]=_[_0x176c('0x38')](_0x18e0f7[_0x176c('0x37')]);_0x1b285e[_0x176c('0x39')]=_[_0x176c('0x3a')](_0x1b285e['model'],_0x1b285e[_0x176c('0x37')]);_0x215ce8[_0x176c('0x3c')]=_[_0x176c('0x3a')](_0x1b285e[_0x176c('0x35')],qs['fields'](_0x18e0f7[_0x176c('0x37')][_0x176c('0x3b')]));_0x215ce8[_0x176c('0x3c')]=_0x215ce8[_0x176c('0x3c')][_0x176c('0x5e')]?_0x215ce8['attributes']:_0x1b285e['model'];if(!_0x18e0f7['query'][_0x176c('0x3d')](_0x176c('0x3e'))){_0x215ce8[_0x176c('0x1f')]=qs[_0x176c('0x1f')](_0x18e0f7[_0x176c('0x37')][_0x176c('0x1f')]);_0x215ce8['offset']=qs[_0x176c('0x21')](_0x18e0f7[_0x176c('0x37')][_0x176c('0x21')]);}_0x215ce8[_0x176c('0x3f')]=qs[_0x176c('0x40')](_0x18e0f7[_0x176c('0x37')][_0x176c('0x40')]);_0x215ce8[_0x176c('0x41')]=qs[_0x176c('0x39')](_['pick'](_0x18e0f7[_0x176c('0x37')],_0x1b285e[_0x176c('0x39')]));_0x215ce8['raw']=!![];if(_0x18e0f7[_0x176c('0x37')][_0x176c('0x42')]){_0x215ce8['where']=_[_0x176c('0x43')](_0x215ce8[_0x176c('0x41')],{'$or':_[_0x176c('0x36')](_0x215ce8[_0x176c('0x3c')],function(_0x1942db){var _0x4e2cb5={};_0x4e2cb5[_0x1942db]={'$like':'%'+_0x18e0f7[_0x176c('0x37')][_0x176c('0x42')]+'%'};return _0x4e2cb5;})});}_0x215ce8=_[_0x176c('0x43')]({},_0x215ce8,_0x18e0f7['options']);return _0x22bb4b[_0x176c('0x6c')](_0x215ce8);}})[_0x176c('0x28')](respondWithResult(_0x10f3d8,null))[_0x176c('0x4e')](handleError(_0x10f3d8,null));};exports[_0x176c('0x72')]=function(_0x1010cb,_0x1e329c,_0x267c0b){var _0x335645;var _0x5b0f34;var _0x5a9db0;var _0x31ba97=_0x1010cb[_0x176c('0x4a')]['id'];csv_results=[];return db[_0x176c('0x73')][_0x176c('0x47')]({'attributes':['id','name'],'raw':!![],'order':[_0x176c('0x74')]})[_0x176c('0x28')](function(_0x35bfee){_0x335645=_0x35bfee;var _0x589e09=_[_0x176c('0x38')](db[_0x176c('0x63')]['rawAttributes']);return db[_0x176c('0x6d')][_0x176c('0x47')]({'raw':!![],'attributes':['id',_0x176c('0x75')]})['then'](function(_0x4d3bd1){_0x5b0f34=_0x4d3bd1;var _0x346144=squel[_0x176c('0x76')]()[_0x176c('0x3b')](_0x589e09)[_0x176c('0x77')](_0x176c('0x78'),'c')[_0x176c('0x41')](_0x176c('0x79'),_0x31ba97)['where']('c.deletedAt\x20is\x20null')[_0x176c('0x7a')]();for(var _0x249c5c=0x0;_0x249c5c<_0x5b0f34[_0x176c('0x5e')];_0x249c5c++){_0x346144[_0x176c('0x7b')](_0x176c('0x7c')+_0x5b0f34[_0x249c5c]['id'],_0x176c('0x7d')+_0x5b0f34[_0x249c5c][_0x176c('0x75')]);}for(var _0x249c5c=0x0;_0x249c5c<_0x335645[_0x176c('0x5e')];_0x249c5c++){_0x346144[_0x176c('0x7b')](squel[_0x176c('0x76')]()['field'](_0x176c('0x7e'))[_0x176c('0x77')](_0x176c('0x7f'))[_0x176c('0x41')](_0x176c('0x80'),_0x335645[_0x249c5c]['id'])[_0x176c('0x41')](_0x176c('0x81')),_0x176c('0x82')+_0x335645[_0x249c5c][_0x176c('0x2f')]);_0x346144[_0x176c('0x7b')](squel[_0x176c('0x76')]()[_0x176c('0x7b')](_0x176c('0x83'))[_0x176c('0x77')]('cm_contact_has_items')['where'](_0x176c('0x80'),_0x335645[_0x249c5c]['id'])[_0x176c('0x41')](_0x176c('0x81')),_0x176c('0x84')+_0x335645[_0x249c5c][_0x176c('0x2f')]);}var _0xca83cd=[];_0xca83cd[_0x176c('0x6a')](_0x346144[_0x176c('0x85')]());BPromise[_0x176c('0x86')](_0xca83cd,handleQuery)[_0x176c('0x28')](function(_0x5cf33c){handleQuery(_0x346144[_0x176c('0x85')]());var _0xbed520=csv_results[0x0];if(!_[_0x176c('0x87')](_0xbed520)){var _0x371d54=toCsv(_0xbed520);var _0x19f84f=Date['now']();fs['writeFileSync'](util[_0x176c('0x70')](_0x176c('0x88'),_0x31ba97,_0x19f84f),_0x371d54);_0x1e329c[_0x176c('0x89')](_0x176c('0x8a'),_0x176c('0x8b')+util['format'](_0x176c('0x8c'),_0x31ba97,_0x19f84f));_0x1e329c[_0x176c('0x89')](_0x176c('0x8d'),_0x176c('0x8e'));return _0x1e329c[_0x176c('0x8f')](util[_0x176c('0x70')](_0x176c('0x88'),_0x31ba97,_0x19f84f));}else{return _0x1e329c[_0x176c('0x2c')](0xcc);}});});});};exports['addCustomField']=function(_0x12059f,_0x3aedb9,_0x1abd59){var _0x1ad4a3;delete _0x12059f['body']['id'];return db[_0x176c('0x32')]['findOne']({'where':{'id':_0x12059f[_0x176c('0x4a')]['id']}})[_0x176c('0x28')](handleEntityNotFound(_0x3aedb9,null))[_0x176c('0x28')](function(_0x22418a){if(_0x22418a){return db[_0x176c('0x90')][_0x176c('0x91')](function(_0x5449bc){return db['CmCustomField'][_0x176c('0x4f')](_0x12059f[_0x176c('0x57')],{'transaction':_0x5449bc})['then'](function(_0x20a4c1){_0x1ad4a3=_0x20a4c1;return _0x22418a[_0x176c('0x92')](_0x20a4c1,{'transaction':_0x5449bc});})['then'](function(){var _0x45be4d={'type':db[_0x176c('0x93')][_0x176c('0x94')],'transaction':_0x5449bc};switch(_0x12059f['body'][_0x176c('0x33')]){case _0x176c('0x95'):_0x45be4d['type']=db['Sequelize'][_0x176c('0x94')];break;case _0x176c('0x96'):_0x45be4d[_0x176c('0x33')]=db['Sequelize'][_0x176c('0x97')];break;case _0x176c('0x98'):_0x45be4d[_0x176c('0x33')]=db[_0x176c('0x93')][_0x176c('0x99')];_0x45be4d['defaultValue']=![];break;default:}return db[_0x176c('0x90')][_0x176c('0x9a')][_0x176c('0x9b')](_0x176c('0x78'),util[_0x176c('0x70')]('cf_%s',_0x1ad4a3['id']),_0x45be4d);})['then'](function(){return _0x1ad4a3;});});}})[_0x176c('0x28')](respondWithResult(_0x3aedb9,null))[_0x176c('0x4e')](handleError(_0x3aedb9,null));};exports[_0x176c('0x9c')]=function(_0xedba98,_0x264717,_0x41c87b){var _0x47d429={};var _0x31eedd={};var _0x1ddaa0;var _0x547273;return db[_0x176c('0x32')][_0x176c('0x5d')]({'where':{'id':_0xedba98['params']['id']}})[_0x176c('0x28')](handleEntityNotFound(_0x264717,null))[_0x176c('0x28')](function(_0x1a2710){if(_0x1a2710){_0x1ddaa0=_0x1a2710;_0x31eedd[_0x176c('0x35')]=_['keys'](db[_0x176c('0x6d')][_0x176c('0x4b')]);_0x31eedd[_0x176c('0x37')]=_['keys'](_0xedba98['query']);_0x31eedd[_0x176c('0x39')]=_[_0x176c('0x3a')](_0x31eedd[_0x176c('0x35')],_0x31eedd[_0x176c('0x37')]);_0x47d429[_0x176c('0x3c')]=_[_0x176c('0x3a')](_0x31eedd[_0x176c('0x35')],qs[_0x176c('0x3b')](_0xedba98[_0x176c('0x37')][_0x176c('0x3b')]));_0x47d429['attributes']=_0x47d429[_0x176c('0x3c')]['length']?_0x47d429[_0x176c('0x3c')]:_0x31eedd[_0x176c('0x35')];_0x47d429[_0x176c('0x3f')]=qs['sort'](_0xedba98['query']['sort']);_0x47d429[_0x176c('0x41')]=qs[_0x176c('0x39')](_[_0x176c('0x5f')](_0xedba98[_0x176c('0x37')],_0x31eedd[_0x176c('0x39')]));_0x47d429['where']=_['merge'](_0x47d429[_0x176c('0x41')],{'$or':[{'ListId':_0x1a2710['id']},{'ListId':null}]});if(_0xedba98[_0x176c('0x37')]['filter']){_0x47d429['where']=_['merge'](_0x47d429[_0x176c('0x41')],{'$or':_[_0x176c('0x36')](_0x47d429['attributes'],function(_0x464d70){var _0x32e0a5={};_0x32e0a5[_0x464d70]={'$like':'%'+_0xedba98[_0x176c('0x37')][_0x176c('0x42')]+'%'};return _0x32e0a5;})});}_0x47d429=_[_0x176c('0x43')]({},_0x47d429,_0xedba98[_0x176c('0x45')]);return db[_0x176c('0x6d')][_0x176c('0x9d')](_0x47d429);}})[_0x176c('0x28')](respondWithResult(_0x264717,null))['catch'](handleError(_0x264717,null));};exports['getGlobalCustomFields']=function(_0x1359af,_0x3082df){return db[_0x176c('0x6d')]['findAndCountAll']({'where':{'ListId':null}})['then'](handleEntityNotFound(_0x3082df,null))[_0x176c('0x28')](function(_0x19b2cd){return _0x19b2cd;})[_0x176c('0x28')](respondWithResult(_0x3082df,null))[_0x176c('0x4e')](handleError(_0x3082df,null));};exports[_0x176c('0x9e')]=function(_0x5b5f29,_0x393ca2,_0x20c529){return db[_0x176c('0x32')][_0x176c('0x4d')]({'where':{'id':_0x5b5f29['params']['id']}})['then'](handleEntityNotFound(_0x393ca2,null))[_0x176c('0x28')](function(_0x297601){if(_0x297601){return _0x297601['addAgents'](_0x5b5f29[_0x176c('0x57')][_0x176c('0x61')],_[_0x176c('0x67')](_0x5b5f29[_0x176c('0x57')],[_0x176c('0x61'),'id'])||{})['spread'](function(_0x1e2423){for(var _0x1922b8=0x0;_0x1922b8<_0x5b5f29[_0x176c('0x57')][_0x176c('0x61')][_0x176c('0x5e')];_0x1922b8+=0x1){socket[_0x176c('0x9f')](_0x176c('0xa0'),{'UserId':Number(_0x5b5f29[_0x176c('0x57')][_0x176c('0x61')][_0x1922b8]),'CmListId':Number(_0x5b5f29[_0x176c('0x4a')]['id'])});}return _0x1e2423;});}})[_0x176c('0x28')](respondWithResult(_0x393ca2,null))[_0x176c('0x4e')](handleError(_0x393ca2,null));};exports[_0x176c('0xa1')]=function(_0xd9debd,_0xf1f0e6,_0x10a130){return db['CmList'][_0x176c('0x4d')]({'where':{'id':_0xd9debd[_0x176c('0x4a')]['id']}})[_0x176c('0x28')](handleEntityNotFound(_0xf1f0e6,null))['then'](function(_0x55faa8){if(_0x55faa8){return _0x55faa8[_0x176c('0xa1')](_0xd9debd[_0x176c('0x37')][_0x176c('0x61')])[_0x176c('0x28')](function(){if(_[_0x176c('0x66')](_0xd9debd[_0x176c('0x37')][_0x176c('0x61')])){for(var _0x46f16b=0x0;_0x46f16b<_0xd9debd[_0x176c('0x37')][_0x176c('0x61')][_0x176c('0x5e')];_0x46f16b+=0x1){socket[_0x176c('0x9f')](_0x176c('0xa2'),{'UserId':Number(_0xd9debd[_0x176c('0x37')]['ids'][_0x46f16b]),'CmListId':Number(_0xd9debd['params']['id'])});}}else{socket['emit'](_0x176c('0xa2'),{'UserId':Number(_0xd9debd[_0x176c('0x37')][_0x176c('0x61')]),'CmListId':Number(_0xd9debd['params']['id'])});}});}})[_0x176c('0x28')](respondWithStatusCode(_0xf1f0e6,null))['catch'](handleError(_0xf1f0e6,null));};exports[_0x176c('0xa3')]=function(_0x4ba669,_0x548280,_0x2fccb9){var _0x4beb5c={};var _0x279ecb={};var _0x32cc4f;var _0x2f7255;return db[_0x176c('0x32')][_0x176c('0x5d')]({'where':{'id':_0x4ba669['params']['id']}})['then'](handleEntityNotFound(_0x548280,null))['then'](function(_0x9f6abe){if(_0x9f6abe){_0x32cc4f=_0x9f6abe;_0x279ecb[_0x176c('0x35')]=_[_0x176c('0x38')](db[_0x176c('0xa4')][_0x176c('0x4b')]);_0x279ecb[_0x176c('0x37')]=_[_0x176c('0x38')](_0x4ba669['query']);_0x279ecb[_0x176c('0x39')]=_[_0x176c('0x3a')](_0x279ecb[_0x176c('0x35')],_0x279ecb[_0x176c('0x37')]);_0x4beb5c['attributes']=_[_0x176c('0x3a')](_0x279ecb[_0x176c('0x35')],qs[_0x176c('0x3b')](_0x4ba669[_0x176c('0x37')]['fields']));_0x4beb5c[_0x176c('0x3c')]=_0x4beb5c['attributes'][_0x176c('0x5e')]?_0x4beb5c[_0x176c('0x3c')]:_0x279ecb[_0x176c('0x35')];_0x4beb5c[_0x176c('0x3f')]=qs[_0x176c('0x40')](_0x4ba669[_0x176c('0x37')][_0x176c('0x40')]);_0x4beb5c['where']=qs[_0x176c('0x39')](_['pick'](_0x4ba669[_0x176c('0x37')],_0x279ecb['filters']));if(_0x4ba669[_0x176c('0x37')]['filter']){_0x4beb5c[_0x176c('0x41')]=_['merge'](_0x4beb5c[_0x176c('0x41')],{'$or':_['map'](_0x4beb5c[_0x176c('0x3c')],function(_0x2db8cc){var _0x360e92={};_0x360e92[_0x2db8cc]={'$like':'%'+_0x4ba669[_0x176c('0x37')][_0x176c('0x42')]+'%'};return _0x360e92;})});}_0x4beb5c=_['merge']({},_0x4beb5c,_0x4ba669[_0x176c('0x45')]);return _0x32cc4f['getAgents'](_0x4beb5c);}})['then'](function(_0xc2ab87){if(_0xc2ab87){_0x2f7255=_0xc2ab87[_0x176c('0x5e')];if(!_0x4ba669[_0x176c('0x37')][_0x176c('0x3d')](_0x176c('0x3e'))){_0x4beb5c[_0x176c('0x1f')]=qs[_0x176c('0x1f')](_0x4ba669['query'][_0x176c('0x1f')]);_0x4beb5c['offset']=qs[_0x176c('0x21')](_0x4ba669[_0x176c('0x37')][_0x176c('0x21')]);}return _0x32cc4f['getAgents'](_0x4beb5c);}})[_0x176c('0x28')](function(_0x316c1e){if(_0x316c1e){return _0x316c1e?{'count':_0x2f7255,'rows':_0x316c1e}:null;}})[_0x176c('0x28')](respondWithResult(_0x548280,null))[_0x176c('0x4e')](handleError(_0x548280,null));};function handleQuery(_0x4e71ec){logger[_0x176c('0xa5')](_0x4e71ec);return db[_0x176c('0x90')][_0x176c('0x37')](_0x4e71ec)['spread'](function(_0x2fae01){csv_results[_0x176c('0x6a')](_0x2fae01);})[_0x176c('0x4e')](function(_0x5d6fdd){logger[_0x176c('0x2d')](_0x5d6fdd[_0x176c('0xa6')]);});}