24a2b90675e709c70f6cc0141610d2c20e5b5c21
[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 _0x6383=['../../mysqldb','redis','defaults','socket.io-emitter','register','end','status','json','offset','undefined','count','Content-Range','apply','reject','save','update','then','get','UserProfileResource','error','stack','name','map','type','key','query','keys','filters','model','attributes','intersection','fields','hasOwnProperty','nolimit','limit','order','sort','filter','where','merge','VIRTUAL','options','CmList','include','rows','show','params','rawAttributes','length','includeAll','catch','create','body','user','Unable\x20to\x20retrieve\x20the\x20current\x20user','role','find','userProfileId','autoAssociation','destroy','describe','addDisposition','ListId','getDispositions','Disposition','pick','findAll','removeDispositions','ids','addContacts','CmContact','tags','isArray','push','success','dataValues','errors','Malformed\x20request\x20syntax','getContacts','CmCustomField','CustomFields','concat','format','cf_%d','raw','getContactsCsv','ContactItemType','alias','select','from','cm_contacts','c.ListId\x20=\x20?','distinct','c.cf_','customField_','field','item','cm_contact_has_items','CmContactId\x20=\x20c.id','additionalPhone_','description','description_additionalPhone_','toString','now','writeFileSync','/tmp/list_%d_%s.csv','setHeader','Content-disposition','attachment;\x20filename=','list_%d_%s.csv','Content-type','addCustomField','findOne','sequelize','transaction','addCustomFields','Sequelize','TEXT','text','INTEGER','switch','BOOLEAN','queryInterface','addColumn','findAndCountAll','addAgents','omit','spread','emit','userCmList:save','removeAgents','userCmList:remove','getAgents','User','message','eml-format','rimraf','zip-dir','fast-json-patch','request-promise','moment','bluebird','mustache','util','path','to-csv','ejs','fs-extra','lodash','jsforce','desk.js','../../components/parsers/qs','../../components/parsers/advancedSearch','../../config/license/hardware','api','../../config/environment','../../config/license/util'];(function(_0x49bacf,_0x423e98){var _0x4c2361=function(_0x59ee45){while(--_0x59ee45){_0x49bacf['push'](_0x49bacf['shift']());}};_0x4c2361(++_0x423e98);}(_0x6383,0x124));var _0x3638=function(_0xb68b6b,_0x4d96b9){_0xb68b6b=_0xb68b6b-0x0;var _0x4ba4b2=_0x6383[_0xb68b6b];return _0x4ba4b2;};'use strict';var emlformat=require(_0x3638('0x0'));var rimraf=require(_0x3638('0x1'));var zipdir=require(_0x3638('0x2'));var jsonpatch=require(_0x3638('0x3'));var rp=require(_0x3638('0x4'));var moment=require(_0x3638('0x5'));var BPromise=require(_0x3638('0x6'));var Mustache=require(_0x3638('0x7'));var util=require(_0x3638('0x8'));var path=require(_0x3638('0x9'));var sox=require('sox');var csv=require(_0x3638('0xa'));var ejs=require(_0x3638('0xb'));var fs=require('fs');var fs_extra=require(_0x3638('0xc'));var _=require(_0x3638('0xd'));var squel=require('squel');var crypto=require('crypto');var jsforce=require(_0x3638('0xe'));var deskjs=require(_0x3638('0xf'));var toCsv=require(_0x3638('0xa'));var querystring=require('querystring');var Papa=require('papaparse');var Redis=require('ioredis');var authService=require('../../components/auth/service');var qs=require(_0x3638('0x10'));var as=require(_0x3638('0x11'));var hardwareService=require(_0x3638('0x12'));var logger=require('../../config/logger')(_0x3638('0x13'));var utils=require('../../config/utils');var config=require(_0x3638('0x14'));var licenseUtil=require(_0x3638('0x15'));var db=require(_0x3638('0x16'))['db'];var csv_results;config[_0x3638('0x17')]=_[_0x3638('0x18')](config[_0x3638('0x17')],{'host':'localhost','port':0x18eb});var socket=require(_0x3638('0x19'))(new Redis(config[_0x3638('0x17')]));require('./cmList.socket')[_0x3638('0x1a')](socket);function respondWithStatusCode(_0x293e4f,_0x237fc1){_0x237fc1=_0x237fc1||0xcc;return function(_0x1367ca){if(_0x1367ca){return _0x293e4f['sendStatus'](_0x237fc1);}return _0x293e4f['status'](_0x237fc1)[_0x3638('0x1b')]();};}function respondWithResult(_0x757315,_0x4e1865){_0x4e1865=_0x4e1865||0xc8;return function(_0x150a3d){if(_0x150a3d){return _0x757315[_0x3638('0x1c')](_0x4e1865)[_0x3638('0x1d')](_0x150a3d);}};}function respondWithFilteredResult(_0x34f48e,_0x22baac){return function(_0x3b0186){if(_0x3b0186){var _0x4e29ad=typeof _0x22baac[_0x3638('0x1e')]==='undefined'&&typeof _0x22baac['limit']===_0x3638('0x1f');var _0x49315e=_0x3b0186[_0x3638('0x20')];var _0x19fa40=_0x4e29ad?0x0:_0x22baac['offset'];var _0x545087=_0x4e29ad?_0x3b0186[_0x3638('0x20')]:_0x22baac[_0x3638('0x1e')]+_0x22baac['limit'];var _0x3ea561;if(_0x545087>=_0x49315e){_0x545087=_0x49315e;_0x3ea561=0xc8;}else{_0x3ea561=0xce;}_0x34f48e['status'](_0x3ea561);return _0x34f48e['set'](_0x3638('0x21'),_0x19fa40+'-'+_0x545087+'/'+_0x49315e)['json'](_0x3b0186);}return null;};}function patchUpdates(_0x26c179){return function(_0x50dc9c){try{jsonpatch[_0x3638('0x22')](_0x50dc9c,_0x26c179,!![]);}catch(_0x1019c5){return BPromise[_0x3638('0x23')](_0x1019c5);}return _0x50dc9c[_0x3638('0x24')]();};}function saveUpdates(_0x4e2e7f,_0x489fc3){return function(_0x4cf41a){if(_0x4cf41a){return _0x4cf41a[_0x3638('0x25')](_0x4e2e7f)['then'](function(_0x386643){return _0x386643;});}return null;};}function removeEntity(_0x6f5db1,_0x445f50){return function(_0x37e3c5){if(_0x37e3c5){return _0x37e3c5['destroy']()[_0x3638('0x26')](function(){var _0x3d8dc9=_0x37e3c5[_0x3638('0x27')]({'plain':!![]});var _0x27766b='Lists';return db[_0x3638('0x28')]['destroy']({'where':{'type':_0x27766b,'resourceId':_0x3d8dc9['id']}})['then'](function(){return _0x37e3c5;});})[_0x3638('0x26')](function(){_0x6f5db1[_0x3638('0x1c')](0xcc)[_0x3638('0x1b')]();});}};}function handleEntityNotFound(_0x129d99,_0x3f9634){return function(_0xd4ea76){if(!_0xd4ea76){_0x129d99['sendStatus'](0x194);}return _0xd4ea76;};}function handleError(_0xd163a0,_0x24ded6){_0x24ded6=_0x24ded6||0x1f4;return function(_0x429977){logger[_0x3638('0x29')](_0x429977[_0x3638('0x2a')]);if(_0x429977[_0x3638('0x2b')]){delete _0x429977[_0x3638('0x2b')];}_0xd163a0[_0x3638('0x1c')](_0x24ded6)['send'](_0x429977);};}exports['index']=function(_0x405062,_0x354304){var _0x571f84={},_0x3e217a={},_0x3edc34={'count':0x0,'rows':[]};var _0x3ea384=_[_0x3638('0x2c')](db['CmList']['rawAttributes'],function(_0x1f05d8){return{'name':_0x1f05d8['fieldName'],'type':_0x1f05d8[_0x3638('0x2d')][_0x3638('0x2e')]};});_0x3e217a['model']=_[_0x3638('0x2c')](_0x3ea384,_0x3638('0x2b'));_0x3e217a[_0x3638('0x2f')]=_[_0x3638('0x30')](_0x405062['query']);_0x3e217a[_0x3638('0x31')]=_['intersection'](_0x3e217a[_0x3638('0x32')],_0x3e217a['query']);_0x571f84[_0x3638('0x33')]=_[_0x3638('0x34')](_0x3e217a['model'],qs[_0x3638('0x35')](_0x405062['query'][_0x3638('0x35')]));_0x571f84[_0x3638('0x33')]=_0x571f84[_0x3638('0x33')]['length']?_0x571f84[_0x3638('0x33')]:_0x3e217a[_0x3638('0x32')];if(!_0x405062[_0x3638('0x2f')][_0x3638('0x36')](_0x3638('0x37'))){_0x571f84[_0x3638('0x38')]=qs[_0x3638('0x38')](_0x405062[_0x3638('0x2f')][_0x3638('0x38')]);_0x571f84[_0x3638('0x1e')]=qs[_0x3638('0x1e')](_0x405062[_0x3638('0x2f')][_0x3638('0x1e')]);}_0x571f84[_0x3638('0x39')]=qs[_0x3638('0x3a')](_0x405062[_0x3638('0x2f')][_0x3638('0x3a')]);_0x571f84['where']=qs[_0x3638('0x31')](_['pick'](_0x405062[_0x3638('0x2f')],_0x3e217a[_0x3638('0x31')]),_0x3ea384);if(_0x405062[_0x3638('0x2f')][_0x3638('0x3b')]){_0x571f84[_0x3638('0x3c')]=_[_0x3638('0x3d')](_0x571f84[_0x3638('0x3c')],{'$or':_[_0x3638('0x2c')](_0x3ea384,function(_0x5cf40e){if(_0x5cf40e[_0x3638('0x2d')]!==_0x3638('0x3e')){var _0x39f832={};_0x39f832[_0x5cf40e[_0x3638('0x2b')]]={'$like':'%'+_0x405062[_0x3638('0x2f')][_0x3638('0x3b')]+'%'};return _0x39f832;}})});}_0x571f84=_[_0x3638('0x3d')]({},_0x571f84,_0x405062[_0x3638('0x3f')]);var _0x50ba22={'where':_0x571f84[_0x3638('0x3c')]};return db[_0x3638('0x40')][_0x3638('0x20')](_0x50ba22)['then'](function(_0xa3b503){_0x3edc34[_0x3638('0x20')]=_0xa3b503;if(_0x405062['query']['includeAll']){_0x571f84[_0x3638('0x41')]=[{'all':!![]}];}return db[_0x3638('0x40')]['findAll'](_0x571f84);})[_0x3638('0x26')](function(_0x4b329a){_0x3edc34[_0x3638('0x42')]=_0x4b329a;return _0x3edc34;})[_0x3638('0x26')](respondWithFilteredResult(_0x354304,_0x571f84))['catch'](handleError(_0x354304,null));};exports[_0x3638('0x43')]=function(_0x57f3cd,_0x88ecd9){var _0x26f587={'raw':![],'where':{'id':_0x57f3cd[_0x3638('0x44')]['id']}},_0x4e0095={};_0x4e0095['model']=_[_0x3638('0x30')](db[_0x3638('0x40')][_0x3638('0x45')]);_0x4e0095[_0x3638('0x2f')]=_['keys'](_0x57f3cd['query']);_0x4e0095[_0x3638('0x31')]=_[_0x3638('0x34')](_0x4e0095['model'],_0x4e0095[_0x3638('0x2f')]);_0x26f587[_0x3638('0x33')]=_[_0x3638('0x34')](_0x4e0095[_0x3638('0x32')],qs[_0x3638('0x35')](_0x57f3cd[_0x3638('0x2f')][_0x3638('0x35')]));_0x26f587[_0x3638('0x33')]=_0x26f587['attributes'][_0x3638('0x46')]?_0x26f587[_0x3638('0x33')]:_0x4e0095[_0x3638('0x32')];if(_0x57f3cd[_0x3638('0x2f')][_0x3638('0x47')]){_0x26f587['include']=[{'all':!![]}];}_0x26f587=_[_0x3638('0x3d')]({},_0x26f587,_0x57f3cd[_0x3638('0x3f')]);return db[_0x3638('0x40')]['find'](_0x26f587)[_0x3638('0x26')](handleEntityNotFound(_0x88ecd9,null))[_0x3638('0x26')](respondWithResult(_0x88ecd9,null))[_0x3638('0x48')](handleError(_0x88ecd9,null));};exports[_0x3638('0x49')]=function(_0x57cee9,_0x3fd014){return db[_0x3638('0x40')][_0x3638('0x49')](_0x57cee9[_0x3638('0x4a')],{})[_0x3638('0x26')](function(_0x3f05f0){var _0x598df7=_0x57cee9[_0x3638('0x4b')][_0x3638('0x27')]({'plain':!![]});if(!_0x598df7)throw new Error(_0x3638('0x4c'));if(_0x598df7[_0x3638('0x4d')]===_0x3638('0x4b')){var _0x5c5a2d=_0x3f05f0[_0x3638('0x27')]({'plain':!![]});var _0xe65c6d='Lists';return db['UserProfileSection'][_0x3638('0x4e')]({'where':{'name':_0xe65c6d,'userProfileId':_0x598df7[_0x3638('0x4f')]},'raw':!![]})[_0x3638('0x26')](function(_0x54a263){if(_0x54a263&&_0x54a263[_0x3638('0x50')]===0x0){return db[_0x3638('0x28')][_0x3638('0x49')]({'name':_0x5c5a2d[_0x3638('0x2b')],'resourceId':_0x5c5a2d['id'],'type':_0x54a263[_0x3638('0x2b')],'sectionId':_0x54a263['id']},{})[_0x3638('0x26')](function(){return _0x3f05f0;});}else{return _0x3f05f0;}})['catch'](function(_0x171d7f){logger[_0x3638('0x29')]('Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s',_0x171d7f);throw _0x171d7f;});}return _0x3f05f0;})['then'](respondWithResult(_0x3fd014,0xc9))[_0x3638('0x48')](handleError(_0x3fd014,null));};exports[_0x3638('0x25')]=function(_0x24ce96,_0x485249){if(_0x24ce96[_0x3638('0x4a')]['id']){delete _0x24ce96[_0x3638('0x4a')]['id'];}return db[_0x3638('0x40')][_0x3638('0x4e')]({'where':{'id':_0x24ce96[_0x3638('0x44')]['id']}})[_0x3638('0x26')](handleEntityNotFound(_0x485249,null))[_0x3638('0x26')](saveUpdates(_0x24ce96[_0x3638('0x4a')],null))[_0x3638('0x26')](respondWithResult(_0x485249,null))[_0x3638('0x48')](handleError(_0x485249,null));};exports[_0x3638('0x51')]=function(_0x3213a1,_0x16df21){return db[_0x3638('0x40')][_0x3638('0x4e')]({'where':{'id':_0x3213a1[_0x3638('0x44')]['id']}})[_0x3638('0x26')](handleEntityNotFound(_0x16df21,null))[_0x3638('0x26')](removeEntity(_0x16df21,null))[_0x3638('0x48')](handleError(_0x16df21,null));};exports[_0x3638('0x52')]=function(_0x18b7de,_0x32cc45){return db['CmList'][_0x3638('0x52')]()['then'](respondWithResult(_0x32cc45,null))['catch'](handleError(_0x32cc45,null));};exports[_0x3638('0x53')]=function(_0x117af3,_0x195f5c,_0x5e0bdb){if(_0x117af3[_0x3638('0x4a')]['id']){delete _0x117af3[_0x3638('0x4a')]['id'];}return db[_0x3638('0x40')][_0x3638('0x4e')]({'where':{'id':_0x117af3['params']['id']}})['then'](handleEntityNotFound(_0x195f5c,null))[_0x3638('0x26')](function(_0x58b46e){if(_0x58b46e){_0x117af3[_0x3638('0x4a')][_0x3638('0x54')]=_0x58b46e['id'];return db['Disposition'][_0x3638('0x49')](_0x117af3['body']);}})[_0x3638('0x26')](respondWithResult(_0x195f5c,null))[_0x3638('0x48')](handleError(_0x195f5c,null));};exports[_0x3638('0x55')]=function(_0x545fcc,_0x26dbcd,_0x311bbf){var _0xba4dd4={'raw':![],'where':{}};var _0x1354fe={};var _0x18637a={'count':0x0,'rows':[]};return db[_0x3638('0x40')]['findOne']({'where':{'id':_0x545fcc[_0x3638('0x44')]['id']}})['then'](handleEntityNotFound(_0x26dbcd,null))[_0x3638('0x26')](function(_0x3821b4){if(_0x3821b4){_0x1354fe[_0x3638('0x32')]=_[_0x3638('0x30')](db[_0x3638('0x56')][_0x3638('0x45')]);_0x1354fe['query']=_[_0x3638('0x30')](_0x545fcc[_0x3638('0x2f')]);_0x1354fe[_0x3638('0x31')]=_['intersection'](_0x1354fe[_0x3638('0x32')],_0x1354fe[_0x3638('0x2f')]);_0xba4dd4[_0x3638('0x33')]=_[_0x3638('0x34')](_0x1354fe[_0x3638('0x32')],qs[_0x3638('0x35')](_0x545fcc[_0x3638('0x2f')][_0x3638('0x35')]));_0xba4dd4[_0x3638('0x33')]=_0xba4dd4[_0x3638('0x33')][_0x3638('0x46')]?_0xba4dd4[_0x3638('0x33')]:_0x1354fe['model'];if(!_0x545fcc[_0x3638('0x2f')][_0x3638('0x36')](_0x3638('0x37'))){_0xba4dd4['limit']=qs[_0x3638('0x38')](_0x545fcc[_0x3638('0x2f')]['limit']);_0xba4dd4['offset']=qs[_0x3638('0x1e')](_0x545fcc[_0x3638('0x2f')]['offset']);}_0xba4dd4[_0x3638('0x39')]=qs[_0x3638('0x3a')](_0x545fcc[_0x3638('0x2f')][_0x3638('0x3a')]);_0xba4dd4[_0x3638('0x3c')]=qs[_0x3638('0x31')](_[_0x3638('0x57')](_0x545fcc[_0x3638('0x2f')],_0x1354fe[_0x3638('0x31')]));_0xba4dd4[_0x3638('0x3c')]['ListId']=_0x3821b4['id'];if(_0x545fcc[_0x3638('0x2f')]['filter']){_0xba4dd4['where']=_[_0x3638('0x3d')](_0xba4dd4[_0x3638('0x3c')],{'$or':_[_0x3638('0x2c')](_0xba4dd4[_0x3638('0x33')],function(_0x317529){var _0x2ae60c={};_0x2ae60c[_0x317529]={'$like':'%'+_0x545fcc['query']['filter']+'%'};return _0x2ae60c;})});}_0xba4dd4=_[_0x3638('0x3d')]({},_0xba4dd4,_0x545fcc[_0x3638('0x3f')]);return db['Disposition'][_0x3638('0x20')]({'where':_0xba4dd4[_0x3638('0x3c')]})[_0x3638('0x26')](function(_0x4013a7){_0x18637a[_0x3638('0x20')]=_0x4013a7;if(_0x545fcc[_0x3638('0x2f')][_0x3638('0x47')]){_0xba4dd4[_0x3638('0x41')]=[{'all':!![]}];}return db['Disposition'][_0x3638('0x58')](_0xba4dd4);})[_0x3638('0x26')](function(_0x2e6df4){_0x18637a[_0x3638('0x42')]=_0x2e6df4;return _0x18637a;});}})['then'](respondWithFilteredResult(_0x26dbcd,_0xba4dd4))[_0x3638('0x48')](handleError(_0x26dbcd,null));};exports['removeDispositions']=function(_0x5464bb,_0x4d347b,_0x200514){return db[_0x3638('0x40')][_0x3638('0x4e')]({'where':{'id':_0x5464bb['params']['id']}})[_0x3638('0x26')](handleEntityNotFound(_0x4d347b,null))[_0x3638('0x26')](function(_0x2dd347){if(_0x2dd347){return _0x2dd347[_0x3638('0x59')](_0x5464bb[_0x3638('0x2f')][_0x3638('0x5a')]);}})['then'](respondWithStatusCode(_0x4d347b,null))[_0x3638('0x48')](handleError(_0x4d347b,null));};exports[_0x3638('0x5b')]=function(_0x2c17a8,_0x20d127,_0x3ae79f){return db[_0x3638('0x40')][_0x3638('0x4e')]({'where':{'id':_0x2c17a8[_0x3638('0x44')]['id']}})[_0x3638('0x26')](handleEntityNotFound(_0x20d127,null))[_0x3638('0x26')](function(_0x2240c1){if(_0x2240c1){var _0x47b4b1=[];var _0x58c55f={'success':[],'errors':[]};return db[_0x3638('0x5c')][_0x3638('0x52')]()[_0x3638('0x26')](function(_0x4f22c3){if(_0x2c17a8['body'][_0x3638('0x5d')]&&_[_0x3638('0x5e')](_0x2c17a8[_0x3638('0x4a')][_0x3638('0x5d')])){if(_0x2c17a8[_0x3638('0x4a')][_0x3638('0x5d')]['length']){_0x2c17a8['body']['tags']=_0x2c17a8[_0x3638('0x4a')][_0x3638('0x5d')]['join'](';')+';';}else{_0x2c17a8[_0x3638('0x4a')][_0x3638('0x5d')]=null;}}else{_0x2c17a8['body'][_0x3638('0x5d')]=null;}if(_0x2c17a8['body']&&_[_0x3638('0x5e')](_0x2c17a8[_0x3638('0x4a')])){for(var _0x6dcfd8=0x0;_0x6dcfd8<_0x2c17a8[_0x3638('0x4a')]['length'];_0x6dcfd8+=0x1){_0x2c17a8[_0x3638('0x4a')][_0x6dcfd8]['ListId']=_0x2c17a8['params']['id'];_0x47b4b1[_0x3638('0x5f')](_0x2c17a8[_0x3638('0x4a')][_0x6dcfd8]);}return BPromise['each'](_0x47b4b1,function(_0x471016){return db[_0x3638('0x5c')][_0x3638('0x49')](_['omit'](_0x471016,['ids','id'])||{},{'fields':_[_0x3638('0x30')](_0x4f22c3),'raw':!![]})[_0x3638('0x26')](function(_0x4d868d){_0x58c55f[_0x3638('0x60')][_0x3638('0x5f')](_0x4d868d[_0x3638('0x61')]);})[_0x3638('0x48')](function(_0x168b22){_0x58c55f[_0x3638('0x62')][_0x3638('0x5f')]({'data':_0x471016,'error':_0x168b22['message']});});})['then'](function(_0x3b3c8d){return _0x58c55f;})[_0x3638('0x48')](function(_0x4c7d44){return _0x4c7d44;});}else{_0x20d127[_0x3638('0x1c')](0x190)[_0x3638('0x1d')]({'message':_0x3638('0x63')});}});}})['then'](respondWithResult(_0x20d127,null))[_0x3638('0x48')](handleError(_0x20d127,null));};exports[_0x3638('0x64')]=function(_0x4a7e13,_0x1735cb,_0x27c7a6){var _0x2a5080;return db[_0x3638('0x40')][_0x3638('0x4e')]({'where':{'id':_0x4a7e13[_0x3638('0x44')]['id']},'include':[{'model':db[_0x3638('0x65')],'as':_0x3638('0x66')}]})['then'](handleEntityNotFound(_0x1735cb,null))[_0x3638('0x26')](function(_0x454e33){if(_0x454e33){_0x2a5080=_0x454e33;return db[_0x3638('0x5c')]['rawAttributes'];}})[_0x3638('0x26')](function(_0x3f67cd){if(_0x3f67cd){var _0x27c754={};var _0x2fe5dd={};_0x2fe5dd[_0x3638('0x32')]=_[_0x3638('0x67')](_['keys'](_0x3f67cd),_[_0x3638('0x2c')](_0x2a5080[_0x3638('0x66')],function(_0x273a76){return util[_0x3638('0x68')](_0x3638('0x69'),_0x273a76['id']);}));_0x2fe5dd[_0x3638('0x2f')]=_[_0x3638('0x30')](_0x4a7e13[_0x3638('0x2f')]);_0x2fe5dd['filters']=_['intersection'](_0x2fe5dd['model'],_0x2fe5dd['query']);_0x27c754[_0x3638('0x33')]=_['intersection'](_0x2fe5dd[_0x3638('0x32')],qs['fields'](_0x4a7e13[_0x3638('0x2f')][_0x3638('0x35')]));_0x27c754['attributes']=_0x27c754[_0x3638('0x33')]['length']?_0x27c754['attributes']:_0x2fe5dd[_0x3638('0x32')];if(!_0x4a7e13['query'][_0x3638('0x36')](_0x3638('0x37'))){_0x27c754[_0x3638('0x38')]=qs[_0x3638('0x38')](_0x4a7e13[_0x3638('0x2f')][_0x3638('0x38')]);_0x27c754[_0x3638('0x1e')]=qs[_0x3638('0x1e')](_0x4a7e13[_0x3638('0x2f')][_0x3638('0x1e')]);}_0x27c754[_0x3638('0x39')]=qs[_0x3638('0x3a')](_0x4a7e13[_0x3638('0x2f')][_0x3638('0x3a')]);_0x27c754['where']=qs['filters'](_[_0x3638('0x57')](_0x4a7e13[_0x3638('0x2f')],_0x2fe5dd['filters']));_0x27c754[_0x3638('0x6a')]=!![];if(_0x4a7e13['query'][_0x3638('0x3b')]){_0x27c754[_0x3638('0x3c')]=_[_0x3638('0x3d')](_0x27c754[_0x3638('0x3c')],{'$or':_[_0x3638('0x2c')](_0x27c754['attributes'],function(_0x246f6e){var _0x8a06a6={};_0x8a06a6[_0x246f6e]={'$like':'%'+_0x4a7e13[_0x3638('0x2f')]['filter']+'%'};return _0x8a06a6;})});}_0x27c754=_[_0x3638('0x3d')]({},_0x27c754,_0x4a7e13[_0x3638('0x3f')]);return _0x2a5080[_0x3638('0x64')](_0x27c754);}})[_0x3638('0x26')](respondWithResult(_0x1735cb,null))['catch'](handleError(_0x1735cb,null));};exports[_0x3638('0x6b')]=function(_0x1736a9,_0x3d9504,_0x408562){var _0x55bbb4;var _0x12425f;var _0x50633a;var _0x257ee2=_0x1736a9[_0x3638('0x44')]['id'];csv_results=[];return db[_0x3638('0x6c')]['findAll']({'attributes':['id','name'],'raw':!![],'order':['OrderBy']})[_0x3638('0x26')](function(_0x119dac){_0x55bbb4=_0x119dac;var _0x85ccad=_[_0x3638('0x30')](db[_0x3638('0x5c')]['rawAttributes']);return db[_0x3638('0x65')][_0x3638('0x58')]({'raw':!![],'attributes':['id',_0x3638('0x6d')]})[_0x3638('0x26')](function(_0x5851af){_0x12425f=_0x5851af;var _0x5336c5=squel[_0x3638('0x6e')]()['fields'](_0x85ccad)[_0x3638('0x6f')](_0x3638('0x70'),'c')[_0x3638('0x3c')](_0x3638('0x71'),_0x257ee2)[_0x3638('0x3c')]('c.deletedAt\x20is\x20null')[_0x3638('0x72')]();for(var _0x1099ec=0x0;_0x1099ec<_0x12425f[_0x3638('0x46')];_0x1099ec++){_0x5336c5['field'](_0x3638('0x73')+_0x12425f[_0x1099ec]['id'],_0x3638('0x74')+_0x12425f[_0x1099ec]['alias']);}for(var _0x1099ec=0x0;_0x1099ec<_0x55bbb4[_0x3638('0x46')];_0x1099ec++){_0x5336c5[_0x3638('0x75')](squel[_0x3638('0x6e')]()['field'](_0x3638('0x76'))['from'](_0x3638('0x77'))[_0x3638('0x3c')]('ItemTypeId\x20=\x20?',_0x55bbb4[_0x1099ec]['id'])['where'](_0x3638('0x78')),_0x3638('0x79')+_0x55bbb4[_0x1099ec][_0x3638('0x2b')]);_0x5336c5[_0x3638('0x75')](squel['select']()['field'](_0x3638('0x7a'))[_0x3638('0x6f')](_0x3638('0x77'))[_0x3638('0x3c')]('ItemTypeId\x20=\x20?',_0x55bbb4[_0x1099ec]['id'])[_0x3638('0x3c')](_0x3638('0x78')),_0x3638('0x7b')+_0x55bbb4[_0x1099ec][_0x3638('0x2b')]);}var _0x42d07a=[];_0x42d07a['push'](_0x5336c5[_0x3638('0x7c')]());BPromise['each'](_0x42d07a,handleQuery)[_0x3638('0x26')](function(_0x25c677){handleQuery(_0x5336c5[_0x3638('0x7c')]());var _0x5272e1=csv_results[0x0];if(!_['isEmpty'](_0x5272e1)){var _0x48e2ce=toCsv(_0x5272e1);var _0x175cc6=Date[_0x3638('0x7d')]();fs[_0x3638('0x7e')](util[_0x3638('0x68')](_0x3638('0x7f'),_0x257ee2,_0x175cc6),_0x48e2ce);_0x3d9504[_0x3638('0x80')](_0x3638('0x81'),_0x3638('0x82')+util['format'](_0x3638('0x83'),_0x257ee2,_0x175cc6));_0x3d9504[_0x3638('0x80')](_0x3638('0x84'),'text/csv');return _0x3d9504['download'](util[_0x3638('0x68')](_0x3638('0x7f'),_0x257ee2,_0x175cc6));}else{return _0x3d9504['sendStatus'](0xcc);}});});});};exports[_0x3638('0x85')]=function(_0x39b685,_0x2d31ab,_0x80984d){var _0x45b4c6;delete _0x39b685['body']['id'];return db[_0x3638('0x40')][_0x3638('0x86')]({'where':{'id':_0x39b685[_0x3638('0x44')]['id']}})['then'](handleEntityNotFound(_0x2d31ab,null))['then'](function(_0x1cd920){if(_0x1cd920){return db[_0x3638('0x87')][_0x3638('0x88')](function(_0x194db6){return db[_0x3638('0x65')][_0x3638('0x49')](_0x39b685[_0x3638('0x4a')],{'transaction':_0x194db6})['then'](function(_0x2e0486){_0x45b4c6=_0x2e0486;return _0x1cd920[_0x3638('0x89')](_0x2e0486,{'transaction':_0x194db6});})[_0x3638('0x26')](function(){var _0x42448c={'type':db[_0x3638('0x8a')][_0x3638('0x8b')],'transaction':_0x194db6};switch(_0x39b685[_0x3638('0x4a')][_0x3638('0x2d')]){case _0x3638('0x8c'):_0x42448c['type']=db['Sequelize'][_0x3638('0x8b')];break;case'number':_0x42448c[_0x3638('0x2d')]=db[_0x3638('0x8a')][_0x3638('0x8d')];break;case _0x3638('0x8e'):_0x42448c[_0x3638('0x2d')]=db[_0x3638('0x8a')][_0x3638('0x8f')];_0x42448c['defaultValue']=![];break;default:}return db[_0x3638('0x87')][_0x3638('0x90')][_0x3638('0x91')](_0x3638('0x70'),util[_0x3638('0x68')]('cf_%s',_0x45b4c6['id']),_0x42448c);})[_0x3638('0x26')](function(){return _0x45b4c6;});});}})['then'](respondWithResult(_0x2d31ab,null))[_0x3638('0x48')](handleError(_0x2d31ab,null));};exports['getCustomFields']=function(_0x739846,_0x4ec45b,_0x22edf9){var _0x2322e7={};var _0x36d883={};var _0x1b34f3;var _0x4e899e;return db[_0x3638('0x40')][_0x3638('0x86')]({'where':{'id':_0x739846[_0x3638('0x44')]['id']}})['then'](handleEntityNotFound(_0x4ec45b,null))[_0x3638('0x26')](function(_0x4ea425){if(_0x4ea425){_0x1b34f3=_0x4ea425;_0x36d883[_0x3638('0x32')]=_[_0x3638('0x30')](db[_0x3638('0x65')]['rawAttributes']);_0x36d883[_0x3638('0x2f')]=_[_0x3638('0x30')](_0x739846[_0x3638('0x2f')]);_0x36d883[_0x3638('0x31')]=_[_0x3638('0x34')](_0x36d883[_0x3638('0x32')],_0x36d883[_0x3638('0x2f')]);_0x2322e7[_0x3638('0x33')]=_[_0x3638('0x34')](_0x36d883[_0x3638('0x32')],qs[_0x3638('0x35')](_0x739846[_0x3638('0x2f')][_0x3638('0x35')]));_0x2322e7[_0x3638('0x33')]=_0x2322e7[_0x3638('0x33')][_0x3638('0x46')]?_0x2322e7[_0x3638('0x33')]:_0x36d883['model'];_0x2322e7[_0x3638('0x39')]=qs[_0x3638('0x3a')](_0x739846['query'][_0x3638('0x3a')]);_0x2322e7['where']=qs[_0x3638('0x31')](_[_0x3638('0x57')](_0x739846[_0x3638('0x2f')],_0x36d883['filters']));_0x2322e7[_0x3638('0x3c')]=_[_0x3638('0x3d')](_0x2322e7['where'],{'$or':[{'ListId':_0x4ea425['id']},{'ListId':null}]});if(_0x739846[_0x3638('0x2f')][_0x3638('0x3b')]){_0x2322e7['where']=_[_0x3638('0x3d')](_0x2322e7[_0x3638('0x3c')],{'$or':_['map'](_0x2322e7[_0x3638('0x33')],function(_0x20c523){var _0x538d4c={};_0x538d4c[_0x20c523]={'$like':'%'+_0x739846[_0x3638('0x2f')][_0x3638('0x3b')]+'%'};return _0x538d4c;})});}_0x2322e7=_[_0x3638('0x3d')]({},_0x2322e7,_0x739846[_0x3638('0x3f')]);return db[_0x3638('0x65')][_0x3638('0x92')](_0x2322e7);}})['then'](respondWithResult(_0x4ec45b,null))[_0x3638('0x48')](handleError(_0x4ec45b,null));};exports['getGlobalCustomFields']=function(_0x2557b1,_0x1bc834){return db[_0x3638('0x65')][_0x3638('0x92')]({'where':{'ListId':null}})['then'](handleEntityNotFound(_0x1bc834,null))[_0x3638('0x26')](function(_0xb1a8dd){return _0xb1a8dd;})['then'](respondWithResult(_0x1bc834,null))[_0x3638('0x48')](handleError(_0x1bc834,null));};exports[_0x3638('0x93')]=function(_0x38fc26,_0x429ea2,_0x1418df){return db[_0x3638('0x40')][_0x3638('0x4e')]({'where':{'id':_0x38fc26['params']['id']}})[_0x3638('0x26')](handleEntityNotFound(_0x429ea2,null))[_0x3638('0x26')](function(_0x2053d4){if(_0x2053d4){return _0x2053d4[_0x3638('0x93')](_0x38fc26[_0x3638('0x4a')][_0x3638('0x5a')],_[_0x3638('0x94')](_0x38fc26['body'],[_0x3638('0x5a'),'id'])||{})[_0x3638('0x95')](function(_0x1c90f6){for(var _0x5b9675=0x0;_0x5b9675<_0x38fc26[_0x3638('0x4a')][_0x3638('0x5a')]['length'];_0x5b9675+=0x1){socket[_0x3638('0x96')](_0x3638('0x97'),{'UserId':Number(_0x38fc26[_0x3638('0x4a')][_0x3638('0x5a')][_0x5b9675]),'CmListId':Number(_0x38fc26[_0x3638('0x44')]['id'])});}return _0x1c90f6;});}})[_0x3638('0x26')](respondWithResult(_0x429ea2,null))['catch'](handleError(_0x429ea2,null));};exports[_0x3638('0x98')]=function(_0x20f030,_0x197848,_0x3c9bfd){return db[_0x3638('0x40')]['find']({'where':{'id':_0x20f030[_0x3638('0x44')]['id']}})['then'](handleEntityNotFound(_0x197848,null))[_0x3638('0x26')](function(_0x173ad2){if(_0x173ad2){return _0x173ad2[_0x3638('0x98')](_0x20f030[_0x3638('0x2f')]['ids'])['then'](function(){if(_[_0x3638('0x5e')](_0x20f030[_0x3638('0x2f')][_0x3638('0x5a')])){for(var _0x26b247=0x0;_0x26b247<_0x20f030[_0x3638('0x2f')][_0x3638('0x5a')][_0x3638('0x46')];_0x26b247+=0x1){socket[_0x3638('0x96')](_0x3638('0x99'),{'UserId':Number(_0x20f030['query'][_0x3638('0x5a')][_0x26b247]),'CmListId':Number(_0x20f030[_0x3638('0x44')]['id'])});}}else{socket[_0x3638('0x96')]('userCmList:remove',{'UserId':Number(_0x20f030[_0x3638('0x2f')][_0x3638('0x5a')]),'CmListId':Number(_0x20f030['params']['id'])});}});}})['then'](respondWithStatusCode(_0x197848,null))[_0x3638('0x48')](handleError(_0x197848,null));};exports[_0x3638('0x9a')]=function(_0x4b0c89,_0x1c49e7,_0xc35dc9){var _0x43194e={};var _0x23319c={};var _0x3b276c;var _0x5f0551;return db[_0x3638('0x40')][_0x3638('0x86')]({'where':{'id':_0x4b0c89[_0x3638('0x44')]['id']}})[_0x3638('0x26')](handleEntityNotFound(_0x1c49e7,null))[_0x3638('0x26')](function(_0x910ab0){if(_0x910ab0){_0x3b276c=_0x910ab0;_0x23319c[_0x3638('0x32')]=_['keys'](db[_0x3638('0x9b')][_0x3638('0x45')]);_0x23319c[_0x3638('0x2f')]=_['keys'](_0x4b0c89[_0x3638('0x2f')]);_0x23319c[_0x3638('0x31')]=_['intersection'](_0x23319c['model'],_0x23319c[_0x3638('0x2f')]);_0x43194e[_0x3638('0x33')]=_[_0x3638('0x34')](_0x23319c[_0x3638('0x32')],qs[_0x3638('0x35')](_0x4b0c89[_0x3638('0x2f')]['fields']));_0x43194e[_0x3638('0x33')]=_0x43194e[_0x3638('0x33')][_0x3638('0x46')]?_0x43194e['attributes']:_0x23319c[_0x3638('0x32')];_0x43194e[_0x3638('0x39')]=qs[_0x3638('0x3a')](_0x4b0c89[_0x3638('0x2f')][_0x3638('0x3a')]);_0x43194e['where']=qs[_0x3638('0x31')](_[_0x3638('0x57')](_0x4b0c89['query'],_0x23319c['filters']));if(_0x4b0c89[_0x3638('0x2f')]['filter']){_0x43194e[_0x3638('0x3c')]=_[_0x3638('0x3d')](_0x43194e[_0x3638('0x3c')],{'$or':_[_0x3638('0x2c')](_0x43194e[_0x3638('0x33')],function(_0x25902c){var _0x568370={};_0x568370[_0x25902c]={'$like':'%'+_0x4b0c89['query'][_0x3638('0x3b')]+'%'};return _0x568370;})});}_0x43194e=_[_0x3638('0x3d')]({},_0x43194e,_0x4b0c89['options']);return _0x3b276c['getAgents'](_0x43194e);}})[_0x3638('0x26')](function(_0x28c1ba){if(_0x28c1ba){_0x5f0551=_0x28c1ba[_0x3638('0x46')];if(!_0x4b0c89[_0x3638('0x2f')][_0x3638('0x36')]('nolimit')){_0x43194e['limit']=qs[_0x3638('0x38')](_0x4b0c89[_0x3638('0x2f')][_0x3638('0x38')]);_0x43194e[_0x3638('0x1e')]=qs['offset'](_0x4b0c89[_0x3638('0x2f')][_0x3638('0x1e')]);}return _0x3b276c[_0x3638('0x9a')](_0x43194e);}})[_0x3638('0x26')](function(_0x46445d){if(_0x46445d){return _0x46445d?{'count':_0x5f0551,'rows':_0x46445d}:null;}})[_0x3638('0x26')](respondWithResult(_0x1c49e7,null))['catch'](handleError(_0x1c49e7,null));};function handleQuery(_0x29504d){logger['info'](_0x29504d);return db[_0x3638('0x87')][_0x3638('0x2f')](_0x29504d)['spread'](function(_0x449785){csv_results[_0x3638('0x5f')](_0x449785);})[_0x3638('0x48')](function(_0x3cfb0){logger[_0x3638('0x29')](_0x3cfb0[_0x3638('0x9c')]);});}