d32f9f5288b2c5de96a8ba27c2885ef618627a3d
[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 _0x3ca4=['stack','name','send','index','map','CmList','rawAttributes','fieldName','type','model','query','filters','intersection','fields','attributes','length','hasOwnProperty','nolimit','order','sort','where','filter','merge','VIRTUAL','includeAll','include','findAll','rows','catch','show','params','keys','options','create','body','user','Lists','UserProfileSection','find','userProfileId','autoAssociation','Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s','describe','ListId','Disposition','getDispositions','findOne','pick','removeDispositions','ids','addContacts','tags','isArray','join','push','omit','success','errors','Malformed\x20request\x20syntax','CmCustomField','CustomFields','CmContact','concat','raw','getContacts','ContactItemType','OrderBy','alias','select','from','cm_contacts','c.ListId\x20=\x20?','distinct','c.cf_','customField_','field','item','cm_contact_has_items','ItemTypeId\x20=\x20?','CmContactId\x20=\x20c.id','additionalPhone_','description_additionalPhone_','toString','each','isEmpty','now','writeFileSync','format','/tmp/list_%d_%s.csv','setHeader','Content-disposition','Content-type','text/csv','download','addCustomField','sequelize','transaction','Sequelize','TEXT','number','INTEGER','switch','BOOLEAN','queryInterface','cf_%s','getCustomFields','findAndCountAll','getGlobalCustomFields','addAgents','spread','emit','removeAgents','userCmList:remove','getAgents','info','rimraf','zip-dir','fast-json-patch','bluebird','sox','to-csv','ejs','fs-extra','lodash','squel','crypto','jsforce','desk.js','ioredis','../../components/parsers/advancedSearch','../../config/logger','api','../../config/utils','defaults','redis','localhost','socket.io-emitter','./cmList.socket','register','sendStatus','status','offset','undefined','limit','count','set','json','save','update','then','get','UserProfileResource','destroy','end','error'];(function(_0x14add3,_0x13ce8d){var _0x4a174f=function(_0x2b3ed7){while(--_0x2b3ed7){_0x14add3['push'](_0x14add3['shift']());}};_0x4a174f(++_0x13ce8d);}(_0x3ca4,0x73));var _0x43ca=function(_0x5eb61e,_0x41b498){_0x5eb61e=_0x5eb61e-0x0;var _0x3e484c=_0x3ca4[_0x5eb61e];return _0x3e484c;};'use strict';var emlformat=require('eml-format');var rimraf=require(_0x43ca('0x0'));var zipdir=require(_0x43ca('0x1'));var jsonpatch=require(_0x43ca('0x2'));var rp=require('request-promise');var moment=require('moment');var BPromise=require(_0x43ca('0x3'));var Mustache=require('mustache');var util=require('util');var path=require('path');var sox=require(_0x43ca('0x4'));var csv=require(_0x43ca('0x5'));var ejs=require(_0x43ca('0x6'));var fs=require('fs');var fs_extra=require(_0x43ca('0x7'));var _=require(_0x43ca('0x8'));var squel=require(_0x43ca('0x9'));var crypto=require(_0x43ca('0xa'));var jsforce=require(_0x43ca('0xb'));var deskjs=require(_0x43ca('0xc'));var toCsv=require(_0x43ca('0x5'));var querystring=require('querystring');var Papa=require('papaparse');var Redis=require(_0x43ca('0xd'));var authService=require('../../components/auth/service');var qs=require('../../components/parsers/qs');var as=require(_0x43ca('0xe'));var hardwareService=require('../../config/license/hardware');var logger=require(_0x43ca('0xf'))(_0x43ca('0x10'));var utils=require(_0x43ca('0x11'));var config=require('../../config/environment');var licenseUtil=require('../../config/license/util');var db=require('../../mysqldb')['db'];var csv_results;config['redis']=_[_0x43ca('0x12')](config[_0x43ca('0x13')],{'host':_0x43ca('0x14'),'port':0x18eb});var socket=require(_0x43ca('0x15'))(new Redis(config[_0x43ca('0x13')]));require(_0x43ca('0x16'))[_0x43ca('0x17')](socket);function respondWithStatusCode(_0x5e484d,_0x5c07f2){_0x5c07f2=_0x5c07f2||0xcc;return function(_0x5b7847){if(_0x5b7847){return _0x5e484d[_0x43ca('0x18')](_0x5c07f2);}return _0x5e484d['status'](_0x5c07f2)['end']();};}function respondWithResult(_0x439351,_0x5b9495){_0x5b9495=_0x5b9495||0xc8;return function(_0x379306){if(_0x379306){return _0x439351[_0x43ca('0x19')](_0x5b9495)['json'](_0x379306);}};}function respondWithFilteredResult(_0x171a56,_0x2a7b66){return function(_0x34a32e){if(_0x34a32e){var _0x11c4e9=typeof _0x2a7b66[_0x43ca('0x1a')]===_0x43ca('0x1b')&&typeof _0x2a7b66[_0x43ca('0x1c')]===_0x43ca('0x1b');var _0x10500e=_0x34a32e['count'];var _0x33366c=_0x11c4e9?0x0:_0x2a7b66[_0x43ca('0x1a')];var _0xe30e50=_0x11c4e9?_0x34a32e[_0x43ca('0x1d')]:_0x2a7b66['offset']+_0x2a7b66['limit'];var _0x5afbde;if(_0xe30e50>=_0x10500e){_0xe30e50=_0x10500e;_0x5afbde=0xc8;}else{_0x5afbde=0xce;}_0x171a56['status'](_0x5afbde);return _0x171a56[_0x43ca('0x1e')]('Content-Range',_0x33366c+'-'+_0xe30e50+'/'+_0x10500e)[_0x43ca('0x1f')](_0x34a32e);}return null;};}function patchUpdates(_0x46bca8){return function(_0x305858){try{jsonpatch['apply'](_0x305858,_0x46bca8,!![]);}catch(_0x24ad5e){return BPromise['reject'](_0x24ad5e);}return _0x305858[_0x43ca('0x20')]();};}function saveUpdates(_0x17a870,_0x1491d3){return function(_0x5a6a12){if(_0x5a6a12){return _0x5a6a12[_0x43ca('0x21')](_0x17a870)['then'](function(_0x4d9222){return _0x4d9222;});}return null;};}function removeEntity(_0x46879d,_0x49914b){return function(_0x34ab34){if(_0x34ab34){return _0x34ab34['destroy']()[_0x43ca('0x22')](function(){var _0x542f93=_0x34ab34[_0x43ca('0x23')]({'plain':!![]});var _0x38f91d='Lists';return db[_0x43ca('0x24')][_0x43ca('0x25')]({'where':{'type':_0x38f91d,'resourceId':_0x542f93['id']}})[_0x43ca('0x22')](function(){return _0x34ab34;});})[_0x43ca('0x22')](function(){_0x46879d[_0x43ca('0x19')](0xcc)[_0x43ca('0x26')]();});}};}function handleEntityNotFound(_0x328489,_0x10c9ae){return function(_0xb618d4){if(!_0xb618d4){_0x328489['sendStatus'](0x194);}return _0xb618d4;};}function handleError(_0x5be0fe,_0x2d2576){_0x2d2576=_0x2d2576||0x1f4;return function(_0x591443){logger[_0x43ca('0x27')](_0x591443[_0x43ca('0x28')]);if(_0x591443[_0x43ca('0x29')]){delete _0x591443[_0x43ca('0x29')];}_0x5be0fe[_0x43ca('0x19')](_0x2d2576)[_0x43ca('0x2a')](_0x591443);};}exports[_0x43ca('0x2b')]=function(_0x5f3c9c,_0x4d8647){var _0x23f085={},_0x531c1d={},_0x3e866e={'count':0x0,'rows':[]};var _0x55731b=_[_0x43ca('0x2c')](db[_0x43ca('0x2d')][_0x43ca('0x2e')],function(_0x499582){return{'name':_0x499582[_0x43ca('0x2f')],'type':_0x499582[_0x43ca('0x30')]['key']};});_0x531c1d[_0x43ca('0x31')]=_[_0x43ca('0x2c')](_0x55731b,_0x43ca('0x29'));_0x531c1d[_0x43ca('0x32')]=_['keys'](_0x5f3c9c['query']);_0x531c1d[_0x43ca('0x33')]=_[_0x43ca('0x34')](_0x531c1d[_0x43ca('0x31')],_0x531c1d[_0x43ca('0x32')]);_0x23f085['attributes']=_[_0x43ca('0x34')](_0x531c1d[_0x43ca('0x31')],qs[_0x43ca('0x35')](_0x5f3c9c[_0x43ca('0x32')]['fields']));_0x23f085[_0x43ca('0x36')]=_0x23f085['attributes'][_0x43ca('0x37')]?_0x23f085[_0x43ca('0x36')]:_0x531c1d[_0x43ca('0x31')];if(!_0x5f3c9c[_0x43ca('0x32')][_0x43ca('0x38')](_0x43ca('0x39'))){_0x23f085[_0x43ca('0x1c')]=qs['limit'](_0x5f3c9c[_0x43ca('0x32')][_0x43ca('0x1c')]);_0x23f085['offset']=qs[_0x43ca('0x1a')](_0x5f3c9c[_0x43ca('0x32')][_0x43ca('0x1a')]);}_0x23f085[_0x43ca('0x3a')]=qs[_0x43ca('0x3b')](_0x5f3c9c[_0x43ca('0x32')][_0x43ca('0x3b')]);_0x23f085[_0x43ca('0x3c')]=qs[_0x43ca('0x33')](_['pick'](_0x5f3c9c[_0x43ca('0x32')],_0x531c1d[_0x43ca('0x33')]),_0x55731b);if(_0x5f3c9c[_0x43ca('0x32')][_0x43ca('0x3d')]){_0x23f085['where']=_[_0x43ca('0x3e')](_0x23f085[_0x43ca('0x3c')],{'$or':_[_0x43ca('0x2c')](_0x55731b,function(_0x3a75da){if(_0x3a75da[_0x43ca('0x30')]!==_0x43ca('0x3f')){var _0x36a0ae={};_0x36a0ae[_0x3a75da[_0x43ca('0x29')]]={'$like':'%'+_0x5f3c9c[_0x43ca('0x32')][_0x43ca('0x3d')]+'%'};return _0x36a0ae;}})});}_0x23f085=_[_0x43ca('0x3e')]({},_0x23f085,_0x5f3c9c['options']);var _0x4da442={'where':_0x23f085[_0x43ca('0x3c')]};return db[_0x43ca('0x2d')]['count'](_0x4da442)[_0x43ca('0x22')](function(_0x3f55f6){_0x3e866e[_0x43ca('0x1d')]=_0x3f55f6;if(_0x5f3c9c['query'][_0x43ca('0x40')]){_0x23f085[_0x43ca('0x41')]=[{'all':!![]}];}return db[_0x43ca('0x2d')][_0x43ca('0x42')](_0x23f085);})[_0x43ca('0x22')](function(_0x5340b5){_0x3e866e[_0x43ca('0x43')]=_0x5340b5;return _0x3e866e;})[_0x43ca('0x22')](respondWithFilteredResult(_0x4d8647,_0x23f085))[_0x43ca('0x44')](handleError(_0x4d8647,null));};exports[_0x43ca('0x45')]=function(_0xad5c57,_0x13a01f){var _0x33ceb8={'raw':![],'where':{'id':_0xad5c57[_0x43ca('0x46')]['id']}},_0x393715={};_0x393715[_0x43ca('0x31')]=_[_0x43ca('0x47')](db[_0x43ca('0x2d')]['rawAttributes']);_0x393715['query']=_[_0x43ca('0x47')](_0xad5c57[_0x43ca('0x32')]);_0x393715[_0x43ca('0x33')]=_[_0x43ca('0x34')](_0x393715[_0x43ca('0x31')],_0x393715[_0x43ca('0x32')]);_0x33ceb8[_0x43ca('0x36')]=_[_0x43ca('0x34')](_0x393715['model'],qs['fields'](_0xad5c57[_0x43ca('0x32')][_0x43ca('0x35')]));_0x33ceb8[_0x43ca('0x36')]=_0x33ceb8[_0x43ca('0x36')][_0x43ca('0x37')]?_0x33ceb8[_0x43ca('0x36')]:_0x393715[_0x43ca('0x31')];if(_0xad5c57[_0x43ca('0x32')][_0x43ca('0x40')]){_0x33ceb8[_0x43ca('0x41')]=[{'all':!![]}];}_0x33ceb8=_[_0x43ca('0x3e')]({},_0x33ceb8,_0xad5c57[_0x43ca('0x48')]);return db[_0x43ca('0x2d')]['find'](_0x33ceb8)[_0x43ca('0x22')](handleEntityNotFound(_0x13a01f,null))[_0x43ca('0x22')](respondWithResult(_0x13a01f,null))['catch'](handleError(_0x13a01f,null));};exports[_0x43ca('0x49')]=function(_0x5e0f99,_0x5df36b){return db['CmList'][_0x43ca('0x49')](_0x5e0f99[_0x43ca('0x4a')],{})[_0x43ca('0x22')](function(_0x399fe9){var _0x4d634c=_0x5e0f99['user'][_0x43ca('0x23')]({'plain':!![]});if(!_0x4d634c)throw new Error('Unable\x20to\x20retrieve\x20the\x20current\x20user');if(_0x4d634c['role']===_0x43ca('0x4b')){var _0x547f65=_0x399fe9[_0x43ca('0x23')]({'plain':!![]});var _0x59f2bd=_0x43ca('0x4c');return db[_0x43ca('0x4d')][_0x43ca('0x4e')]({'where':{'name':_0x59f2bd,'userProfileId':_0x4d634c[_0x43ca('0x4f')]},'raw':!![]})[_0x43ca('0x22')](function(_0x5e4bba){if(_0x5e4bba&&_0x5e4bba[_0x43ca('0x50')]===0x0){return db[_0x43ca('0x24')]['create']({'name':_0x547f65[_0x43ca('0x29')],'resourceId':_0x547f65['id'],'type':_0x5e4bba['name'],'sectionId':_0x5e4bba['id']},{})[_0x43ca('0x22')](function(){return _0x399fe9;});}else{return _0x399fe9;}})[_0x43ca('0x44')](function(_0x298062){logger[_0x43ca('0x27')](_0x43ca('0x51'),_0x298062);throw _0x298062;});}return _0x399fe9;})[_0x43ca('0x22')](respondWithResult(_0x5df36b,0xc9))[_0x43ca('0x44')](handleError(_0x5df36b,null));};exports['update']=function(_0x395eb6,_0x15635e){if(_0x395eb6[_0x43ca('0x4a')]['id']){delete _0x395eb6[_0x43ca('0x4a')]['id'];}return db['CmList']['find']({'where':{'id':_0x395eb6[_0x43ca('0x46')]['id']}})['then'](handleEntityNotFound(_0x15635e,null))['then'](saveUpdates(_0x395eb6[_0x43ca('0x4a')],null))[_0x43ca('0x22')](respondWithResult(_0x15635e,null))[_0x43ca('0x44')](handleError(_0x15635e,null));};exports[_0x43ca('0x25')]=function(_0x58eea0,_0x3bcc41){return db[_0x43ca('0x2d')]['find']({'where':{'id':_0x58eea0[_0x43ca('0x46')]['id']}})['then'](handleEntityNotFound(_0x3bcc41,null))[_0x43ca('0x22')](removeEntity(_0x3bcc41,null))[_0x43ca('0x44')](handleError(_0x3bcc41,null));};exports[_0x43ca('0x52')]=function(_0x7c1482,_0x35b084){return db['CmList']['describe']()[_0x43ca('0x22')](respondWithResult(_0x35b084,null))[_0x43ca('0x44')](handleError(_0x35b084,null));};exports['addDisposition']=function(_0x1d9a4e,_0x44dfba,_0x107caf){if(_0x1d9a4e['body']['id']){delete _0x1d9a4e[_0x43ca('0x4a')]['id'];}return db[_0x43ca('0x2d')][_0x43ca('0x4e')]({'where':{'id':_0x1d9a4e['params']['id']}})[_0x43ca('0x22')](handleEntityNotFound(_0x44dfba,null))[_0x43ca('0x22')](function(_0x2efe0a){if(_0x2efe0a){_0x1d9a4e[_0x43ca('0x4a')][_0x43ca('0x53')]=_0x2efe0a['id'];return db[_0x43ca('0x54')][_0x43ca('0x49')](_0x1d9a4e[_0x43ca('0x4a')]);}})[_0x43ca('0x22')](respondWithResult(_0x44dfba,null))['catch'](handleError(_0x44dfba,null));};exports[_0x43ca('0x55')]=function(_0x76feef,_0x22d755,_0x427c84){var _0x19dc7a={'raw':![],'where':{}};var _0x19b815={};var _0x2f3992={'count':0x0,'rows':[]};return db[_0x43ca('0x2d')][_0x43ca('0x56')]({'where':{'id':_0x76feef[_0x43ca('0x46')]['id']}})[_0x43ca('0x22')](handleEntityNotFound(_0x22d755,null))[_0x43ca('0x22')](function(_0x8f1c13){if(_0x8f1c13){_0x19b815[_0x43ca('0x31')]=_[_0x43ca('0x47')](db[_0x43ca('0x54')][_0x43ca('0x2e')]);_0x19b815['query']=_['keys'](_0x76feef[_0x43ca('0x32')]);_0x19b815[_0x43ca('0x33')]=_['intersection'](_0x19b815[_0x43ca('0x31')],_0x19b815['query']);_0x19dc7a[_0x43ca('0x36')]=_['intersection'](_0x19b815[_0x43ca('0x31')],qs[_0x43ca('0x35')](_0x76feef[_0x43ca('0x32')][_0x43ca('0x35')]));_0x19dc7a['attributes']=_0x19dc7a['attributes'][_0x43ca('0x37')]?_0x19dc7a[_0x43ca('0x36')]:_0x19b815[_0x43ca('0x31')];if(!_0x76feef[_0x43ca('0x32')][_0x43ca('0x38')](_0x43ca('0x39'))){_0x19dc7a['limit']=qs[_0x43ca('0x1c')](_0x76feef[_0x43ca('0x32')]['limit']);_0x19dc7a['offset']=qs[_0x43ca('0x1a')](_0x76feef[_0x43ca('0x32')][_0x43ca('0x1a')]);}_0x19dc7a['order']=qs[_0x43ca('0x3b')](_0x76feef[_0x43ca('0x32')][_0x43ca('0x3b')]);_0x19dc7a[_0x43ca('0x3c')]=qs[_0x43ca('0x33')](_[_0x43ca('0x57')](_0x76feef[_0x43ca('0x32')],_0x19b815[_0x43ca('0x33')]));_0x19dc7a['where'][_0x43ca('0x53')]=_0x8f1c13['id'];if(_0x76feef[_0x43ca('0x32')][_0x43ca('0x3d')]){_0x19dc7a[_0x43ca('0x3c')]=_[_0x43ca('0x3e')](_0x19dc7a[_0x43ca('0x3c')],{'$or':_['map'](_0x19dc7a[_0x43ca('0x36')],function(_0xe273f9){var _0xb48de8={};_0xb48de8[_0xe273f9]={'$like':'%'+_0x76feef[_0x43ca('0x32')][_0x43ca('0x3d')]+'%'};return _0xb48de8;})});}_0x19dc7a=_['merge']({},_0x19dc7a,_0x76feef[_0x43ca('0x48')]);return db[_0x43ca('0x54')]['count']({'where':_0x19dc7a[_0x43ca('0x3c')]})[_0x43ca('0x22')](function(_0x56567c){_0x2f3992[_0x43ca('0x1d')]=_0x56567c;if(_0x76feef[_0x43ca('0x32')][_0x43ca('0x40')]){_0x19dc7a['include']=[{'all':!![]}];}return db[_0x43ca('0x54')][_0x43ca('0x42')](_0x19dc7a);})[_0x43ca('0x22')](function(_0x3a5468){_0x2f3992[_0x43ca('0x43')]=_0x3a5468;return _0x2f3992;});}})['then'](respondWithFilteredResult(_0x22d755,_0x19dc7a))['catch'](handleError(_0x22d755,null));};exports[_0x43ca('0x58')]=function(_0x5a127a,_0x18a483,_0x24aecc){return db['CmList'][_0x43ca('0x4e')]({'where':{'id':_0x5a127a['params']['id']}})['then'](handleEntityNotFound(_0x18a483,null))['then'](function(_0x1f21ec){if(_0x1f21ec){return _0x1f21ec['removeDispositions'](_0x5a127a['query'][_0x43ca('0x59')]);}})['then'](respondWithStatusCode(_0x18a483,null))[_0x43ca('0x44')](handleError(_0x18a483,null));};exports[_0x43ca('0x5a')]=function(_0x30f104,_0x42788a,_0x555cd9){return db['CmList']['find']({'where':{'id':_0x30f104[_0x43ca('0x46')]['id']}})[_0x43ca('0x22')](handleEntityNotFound(_0x42788a,null))[_0x43ca('0x22')](function(_0x191312){if(_0x191312){var _0x4882f9=[];var _0x3729b1={'success':[],'errors':[]};return db['CmContact']['describe']()['then'](function(_0x1b2f96){if(_0x30f104[_0x43ca('0x4a')][_0x43ca('0x5b')]&&_[_0x43ca('0x5c')](_0x30f104[_0x43ca('0x4a')][_0x43ca('0x5b')])){if(_0x30f104[_0x43ca('0x4a')][_0x43ca('0x5b')]['length']){_0x30f104[_0x43ca('0x4a')][_0x43ca('0x5b')]=_0x30f104['body'][_0x43ca('0x5b')][_0x43ca('0x5d')](';')+';';}else{_0x30f104[_0x43ca('0x4a')][_0x43ca('0x5b')]=null;}}else{_0x30f104[_0x43ca('0x4a')][_0x43ca('0x5b')]=null;}if(_0x30f104['body']&&_[_0x43ca('0x5c')](_0x30f104[_0x43ca('0x4a')])){for(var _0x257899=0x0;_0x257899<_0x30f104[_0x43ca('0x4a')][_0x43ca('0x37')];_0x257899+=0x1){_0x30f104[_0x43ca('0x4a')][_0x257899]['ListId']=_0x30f104[_0x43ca('0x46')]['id'];_0x4882f9[_0x43ca('0x5e')](_0x30f104[_0x43ca('0x4a')][_0x257899]);}return BPromise['each'](_0x4882f9,function(_0x1c6e67){return db['CmContact'][_0x43ca('0x49')](_[_0x43ca('0x5f')](_0x1c6e67,[_0x43ca('0x59'),'id'])||{},{'fields':_[_0x43ca('0x47')](_0x1b2f96),'raw':!![]})[_0x43ca('0x22')](function(_0x974c37){_0x3729b1[_0x43ca('0x60')][_0x43ca('0x5e')](_0x974c37['dataValues']);})[_0x43ca('0x44')](function(_0x38acfa){_0x3729b1[_0x43ca('0x61')][_0x43ca('0x5e')]({'data':_0x1c6e67,'error':_0x38acfa['message']});});})[_0x43ca('0x22')](function(_0x635a4d){return _0x3729b1;})[_0x43ca('0x44')](function(_0x3874af){return _0x3874af;});}else{_0x42788a[_0x43ca('0x19')](0x190)['json']({'message':_0x43ca('0x62')});}});}})[_0x43ca('0x22')](respondWithResult(_0x42788a,null))[_0x43ca('0x44')](handleError(_0x42788a,null));};exports['getContacts']=function(_0x58e440,_0x10d4dd,_0x5a2f5b){var _0x3d1a47;return db[_0x43ca('0x2d')][_0x43ca('0x4e')]({'where':{'id':_0x58e440[_0x43ca('0x46')]['id']},'include':[{'model':db[_0x43ca('0x63')],'as':_0x43ca('0x64')}]})[_0x43ca('0x22')](handleEntityNotFound(_0x10d4dd,null))[_0x43ca('0x22')](function(_0x42703f){if(_0x42703f){_0x3d1a47=_0x42703f;return db[_0x43ca('0x65')]['rawAttributes'];}})[_0x43ca('0x22')](function(_0x5ac3a6){if(_0x5ac3a6){var _0xe22983={};var _0x69b66f={};_0x69b66f[_0x43ca('0x31')]=_[_0x43ca('0x66')](_[_0x43ca('0x47')](_0x5ac3a6),_[_0x43ca('0x2c')](_0x3d1a47[_0x43ca('0x64')],function(_0x4ddfa6){return util['format']('cf_%d',_0x4ddfa6['id']);}));_0x69b66f[_0x43ca('0x32')]=_['keys'](_0x58e440[_0x43ca('0x32')]);_0x69b66f['filters']=_[_0x43ca('0x34')](_0x69b66f['model'],_0x69b66f[_0x43ca('0x32')]);_0xe22983[_0x43ca('0x36')]=_[_0x43ca('0x34')](_0x69b66f[_0x43ca('0x31')],qs['fields'](_0x58e440[_0x43ca('0x32')][_0x43ca('0x35')]));_0xe22983[_0x43ca('0x36')]=_0xe22983[_0x43ca('0x36')][_0x43ca('0x37')]?_0xe22983[_0x43ca('0x36')]:_0x69b66f['model'];if(!_0x58e440[_0x43ca('0x32')][_0x43ca('0x38')](_0x43ca('0x39'))){_0xe22983['limit']=qs[_0x43ca('0x1c')](_0x58e440[_0x43ca('0x32')]['limit']);_0xe22983['offset']=qs[_0x43ca('0x1a')](_0x58e440[_0x43ca('0x32')][_0x43ca('0x1a')]);}_0xe22983[_0x43ca('0x3a')]=qs['sort'](_0x58e440[_0x43ca('0x32')]['sort']);_0xe22983[_0x43ca('0x3c')]=qs[_0x43ca('0x33')](_[_0x43ca('0x57')](_0x58e440[_0x43ca('0x32')],_0x69b66f[_0x43ca('0x33')]));_0xe22983[_0x43ca('0x67')]=!![];if(_0x58e440[_0x43ca('0x32')][_0x43ca('0x3d')]){_0xe22983[_0x43ca('0x3c')]=_[_0x43ca('0x3e')](_0xe22983['where'],{'$or':_['map'](_0xe22983['attributes'],function(_0x1a997a){var _0x47d2ab={};_0x47d2ab[_0x1a997a]={'$like':'%'+_0x58e440[_0x43ca('0x32')]['filter']+'%'};return _0x47d2ab;})});}_0xe22983=_[_0x43ca('0x3e')]({},_0xe22983,_0x58e440[_0x43ca('0x48')]);return _0x3d1a47[_0x43ca('0x68')](_0xe22983);}})[_0x43ca('0x22')](respondWithResult(_0x10d4dd,null))[_0x43ca('0x44')](handleError(_0x10d4dd,null));};exports['getContactsCsv']=function(_0x3612e1,_0x48ab5c,_0x2155ab){var _0x1969e7;var _0xb06fdb;var _0x1ed06a;var _0x481d2d=_0x3612e1[_0x43ca('0x46')]['id'];csv_results=[];return db[_0x43ca('0x69')][_0x43ca('0x42')]({'attributes':['id',_0x43ca('0x29')],'raw':!![],'order':[_0x43ca('0x6a')]})[_0x43ca('0x22')](function(_0x44715b){_0x1969e7=_0x44715b;var _0xec6afd=_[_0x43ca('0x47')](db[_0x43ca('0x65')][_0x43ca('0x2e')]);return db[_0x43ca('0x63')][_0x43ca('0x42')]({'raw':!![],'attributes':['id',_0x43ca('0x6b')]})[_0x43ca('0x22')](function(_0x4bf5c2){_0xb06fdb=_0x4bf5c2;var _0x341880=squel[_0x43ca('0x6c')]()[_0x43ca('0x35')](_0xec6afd)[_0x43ca('0x6d')](_0x43ca('0x6e'),'c')[_0x43ca('0x3c')](_0x43ca('0x6f'),_0x481d2d)[_0x43ca('0x3c')]('c.deletedAt\x20is\x20null')[_0x43ca('0x70')]();for(var _0x437494=0x0;_0x437494<_0xb06fdb['length'];_0x437494++){_0x341880['field'](_0x43ca('0x71')+_0xb06fdb[_0x437494]['id'],_0x43ca('0x72')+_0xb06fdb[_0x437494][_0x43ca('0x6b')]);}for(var _0x437494=0x0;_0x437494<_0x1969e7[_0x43ca('0x37')];_0x437494++){_0x341880[_0x43ca('0x73')](squel['select']()[_0x43ca('0x73')](_0x43ca('0x74'))['from'](_0x43ca('0x75'))[_0x43ca('0x3c')](_0x43ca('0x76'),_0x1969e7[_0x437494]['id'])[_0x43ca('0x3c')](_0x43ca('0x77')),_0x43ca('0x78')+_0x1969e7[_0x437494][_0x43ca('0x29')]);_0x341880[_0x43ca('0x73')](squel[_0x43ca('0x6c')]()[_0x43ca('0x73')]('description')[_0x43ca('0x6d')]('cm_contact_has_items')[_0x43ca('0x3c')](_0x43ca('0x76'),_0x1969e7[_0x437494]['id'])[_0x43ca('0x3c')](_0x43ca('0x77')),_0x43ca('0x79')+_0x1969e7[_0x437494]['name']);}var _0x1b6afe=[];_0x1b6afe[_0x43ca('0x5e')](_0x341880[_0x43ca('0x7a')]());BPromise[_0x43ca('0x7b')](_0x1b6afe,handleQuery)['then'](function(_0x1343e0){handleQuery(_0x341880['toString']());var _0x1532b5=csv_results[0x0];if(!_[_0x43ca('0x7c')](_0x1532b5)){var _0x17dea6=toCsv(_0x1532b5);var _0x27a5fe=Date[_0x43ca('0x7d')]();fs[_0x43ca('0x7e')](util[_0x43ca('0x7f')](_0x43ca('0x80'),_0x481d2d,_0x27a5fe),_0x17dea6);_0x48ab5c[_0x43ca('0x81')](_0x43ca('0x82'),'attachment;\x20filename='+util[_0x43ca('0x7f')]('list_%d_%s.csv',_0x481d2d,_0x27a5fe));_0x48ab5c[_0x43ca('0x81')](_0x43ca('0x83'),_0x43ca('0x84'));return _0x48ab5c[_0x43ca('0x85')](util['format']('/tmp/list_%d_%s.csv',_0x481d2d,_0x27a5fe));}else{return _0x48ab5c[_0x43ca('0x18')](0xcc);}});});});};exports[_0x43ca('0x86')]=function(_0x5116ff,_0x24b0a2,_0x207842){var _0x419672;delete _0x5116ff['body']['id'];return db[_0x43ca('0x2d')][_0x43ca('0x56')]({'where':{'id':_0x5116ff[_0x43ca('0x46')]['id']}})['then'](handleEntityNotFound(_0x24b0a2,null))[_0x43ca('0x22')](function(_0x2d07d2){if(_0x2d07d2){return db[_0x43ca('0x87')][_0x43ca('0x88')](function(_0x48062e){return db[_0x43ca('0x63')][_0x43ca('0x49')](_0x5116ff[_0x43ca('0x4a')],{'transaction':_0x48062e})['then'](function(_0x19ea16){_0x419672=_0x19ea16;return _0x2d07d2['addCustomFields'](_0x19ea16,{'transaction':_0x48062e});})[_0x43ca('0x22')](function(){var _0x159928={'type':db[_0x43ca('0x89')][_0x43ca('0x8a')],'transaction':_0x48062e};switch(_0x5116ff[_0x43ca('0x4a')][_0x43ca('0x30')]){case'text':_0x159928[_0x43ca('0x30')]=db['Sequelize'][_0x43ca('0x8a')];break;case _0x43ca('0x8b'):_0x159928[_0x43ca('0x30')]=db[_0x43ca('0x89')][_0x43ca('0x8c')];break;case _0x43ca('0x8d'):_0x159928[_0x43ca('0x30')]=db['Sequelize'][_0x43ca('0x8e')];_0x159928['defaultValue']=![];break;default:}return db['sequelize'][_0x43ca('0x8f')]['addColumn'](_0x43ca('0x6e'),util[_0x43ca('0x7f')](_0x43ca('0x90'),_0x419672['id']),_0x159928);})[_0x43ca('0x22')](function(){return _0x419672;});});}})[_0x43ca('0x22')](respondWithResult(_0x24b0a2,null))[_0x43ca('0x44')](handleError(_0x24b0a2,null));};exports[_0x43ca('0x91')]=function(_0x56d25e,_0x1a0a22,_0x3fe927){var _0x10f54b={};var _0x528fc7={};var _0x4b5eaf;var _0x39cdc4;return db[_0x43ca('0x2d')][_0x43ca('0x56')]({'where':{'id':_0x56d25e[_0x43ca('0x46')]['id']}})[_0x43ca('0x22')](handleEntityNotFound(_0x1a0a22,null))[_0x43ca('0x22')](function(_0xb458f4){if(_0xb458f4){_0x4b5eaf=_0xb458f4;_0x528fc7['model']=_['keys'](db[_0x43ca('0x63')]['rawAttributes']);_0x528fc7[_0x43ca('0x32')]=_[_0x43ca('0x47')](_0x56d25e['query']);_0x528fc7[_0x43ca('0x33')]=_['intersection'](_0x528fc7[_0x43ca('0x31')],_0x528fc7[_0x43ca('0x32')]);_0x10f54b[_0x43ca('0x36')]=_[_0x43ca('0x34')](_0x528fc7[_0x43ca('0x31')],qs['fields'](_0x56d25e[_0x43ca('0x32')][_0x43ca('0x35')]));_0x10f54b[_0x43ca('0x36')]=_0x10f54b['attributes'][_0x43ca('0x37')]?_0x10f54b[_0x43ca('0x36')]:_0x528fc7[_0x43ca('0x31')];_0x10f54b['order']=qs[_0x43ca('0x3b')](_0x56d25e[_0x43ca('0x32')][_0x43ca('0x3b')]);_0x10f54b[_0x43ca('0x3c')]=qs[_0x43ca('0x33')](_[_0x43ca('0x57')](_0x56d25e[_0x43ca('0x32')],_0x528fc7[_0x43ca('0x33')]));_0x10f54b[_0x43ca('0x3c')]=_['merge'](_0x10f54b[_0x43ca('0x3c')],{'$or':[{'ListId':_0xb458f4['id']},{'ListId':null}]});if(_0x56d25e[_0x43ca('0x32')][_0x43ca('0x3d')]){_0x10f54b[_0x43ca('0x3c')]=_['merge'](_0x10f54b[_0x43ca('0x3c')],{'$or':_[_0x43ca('0x2c')](_0x10f54b[_0x43ca('0x36')],function(_0x1ce391){var _0x13c17c={};_0x13c17c[_0x1ce391]={'$like':'%'+_0x56d25e[_0x43ca('0x32')][_0x43ca('0x3d')]+'%'};return _0x13c17c;})});}_0x10f54b=_['merge']({},_0x10f54b,_0x56d25e[_0x43ca('0x48')]);return db[_0x43ca('0x63')][_0x43ca('0x92')](_0x10f54b);}})[_0x43ca('0x22')](respondWithResult(_0x1a0a22,null))[_0x43ca('0x44')](handleError(_0x1a0a22,null));};exports[_0x43ca('0x93')]=function(_0x27f141,_0x49f49e){return db[_0x43ca('0x63')]['findAndCountAll']({'where':{'ListId':null}})[_0x43ca('0x22')](handleEntityNotFound(_0x49f49e,null))[_0x43ca('0x22')](function(_0x4fc182){return _0x4fc182;})[_0x43ca('0x22')](respondWithResult(_0x49f49e,null))['catch'](handleError(_0x49f49e,null));};exports[_0x43ca('0x94')]=function(_0x4c64a2,_0x2a0e75,_0x597bb4){return db[_0x43ca('0x2d')][_0x43ca('0x4e')]({'where':{'id':_0x4c64a2[_0x43ca('0x46')]['id']}})[_0x43ca('0x22')](handleEntityNotFound(_0x2a0e75,null))[_0x43ca('0x22')](function(_0x1b9715){if(_0x1b9715){return _0x1b9715[_0x43ca('0x94')](_0x4c64a2[_0x43ca('0x4a')][_0x43ca('0x59')],_[_0x43ca('0x5f')](_0x4c64a2[_0x43ca('0x4a')],[_0x43ca('0x59'),'id'])||{})[_0x43ca('0x95')](function(_0x524e69){for(var _0x576a88=0x0;_0x576a88<_0x4c64a2['body']['ids'][_0x43ca('0x37')];_0x576a88+=0x1){socket[_0x43ca('0x96')]('userCmList:save',{'UserId':Number(_0x4c64a2[_0x43ca('0x4a')][_0x43ca('0x59')][_0x576a88]),'CmListId':Number(_0x4c64a2[_0x43ca('0x46')]['id'])});}return _0x524e69;});}})[_0x43ca('0x22')](respondWithResult(_0x2a0e75,null))[_0x43ca('0x44')](handleError(_0x2a0e75,null));};exports[_0x43ca('0x97')]=function(_0x402cdb,_0x4820d9,_0x20d72a){return db['CmList'][_0x43ca('0x4e')]({'where':{'id':_0x402cdb[_0x43ca('0x46')]['id']}})[_0x43ca('0x22')](handleEntityNotFound(_0x4820d9,null))[_0x43ca('0x22')](function(_0x5a3353){if(_0x5a3353){return _0x5a3353[_0x43ca('0x97')](_0x402cdb['query'][_0x43ca('0x59')])['then'](function(){if(_[_0x43ca('0x5c')](_0x402cdb[_0x43ca('0x32')][_0x43ca('0x59')])){for(var _0x1609a1=0x0;_0x1609a1<_0x402cdb[_0x43ca('0x32')][_0x43ca('0x59')]['length'];_0x1609a1+=0x1){socket[_0x43ca('0x96')](_0x43ca('0x98'),{'UserId':Number(_0x402cdb['query'][_0x43ca('0x59')][_0x1609a1]),'CmListId':Number(_0x402cdb[_0x43ca('0x46')]['id'])});}}else{socket['emit'](_0x43ca('0x98'),{'UserId':Number(_0x402cdb[_0x43ca('0x32')]['ids']),'CmListId':Number(_0x402cdb['params']['id'])});}});}})[_0x43ca('0x22')](respondWithStatusCode(_0x4820d9,null))[_0x43ca('0x44')](handleError(_0x4820d9,null));};exports[_0x43ca('0x99')]=function(_0x55385c,_0x2d8c70,_0x3351ba){var _0x5afe81={};var _0x408b5e={};var _0x44877b;var _0x14b0be;return db[_0x43ca('0x2d')][_0x43ca('0x56')]({'where':{'id':_0x55385c['params']['id']}})['then'](handleEntityNotFound(_0x2d8c70,null))[_0x43ca('0x22')](function(_0x4e63d8){if(_0x4e63d8){_0x44877b=_0x4e63d8;_0x408b5e[_0x43ca('0x31')]=_['keys'](db['User'][_0x43ca('0x2e')]);_0x408b5e['query']=_['keys'](_0x55385c[_0x43ca('0x32')]);_0x408b5e[_0x43ca('0x33')]=_[_0x43ca('0x34')](_0x408b5e[_0x43ca('0x31')],_0x408b5e[_0x43ca('0x32')]);_0x5afe81[_0x43ca('0x36')]=_[_0x43ca('0x34')](_0x408b5e[_0x43ca('0x31')],qs['fields'](_0x55385c[_0x43ca('0x32')][_0x43ca('0x35')]));_0x5afe81[_0x43ca('0x36')]=_0x5afe81[_0x43ca('0x36')]['length']?_0x5afe81[_0x43ca('0x36')]:_0x408b5e['model'];_0x5afe81[_0x43ca('0x3a')]=qs['sort'](_0x55385c[_0x43ca('0x32')][_0x43ca('0x3b')]);_0x5afe81[_0x43ca('0x3c')]=qs['filters'](_[_0x43ca('0x57')](_0x55385c[_0x43ca('0x32')],_0x408b5e[_0x43ca('0x33')]));if(_0x55385c[_0x43ca('0x32')]['filter']){_0x5afe81['where']=_[_0x43ca('0x3e')](_0x5afe81['where'],{'$or':_[_0x43ca('0x2c')](_0x5afe81[_0x43ca('0x36')],function(_0x145f06){var _0x71b39c={};_0x71b39c[_0x145f06]={'$like':'%'+_0x55385c[_0x43ca('0x32')][_0x43ca('0x3d')]+'%'};return _0x71b39c;})});}_0x5afe81=_[_0x43ca('0x3e')]({},_0x5afe81,_0x55385c[_0x43ca('0x48')]);return _0x44877b[_0x43ca('0x99')](_0x5afe81);}})[_0x43ca('0x22')](function(_0x110d6e){if(_0x110d6e){_0x14b0be=_0x110d6e[_0x43ca('0x37')];if(!_0x55385c[_0x43ca('0x32')][_0x43ca('0x38')]('nolimit')){_0x5afe81[_0x43ca('0x1c')]=qs[_0x43ca('0x1c')](_0x55385c[_0x43ca('0x32')][_0x43ca('0x1c')]);_0x5afe81[_0x43ca('0x1a')]=qs[_0x43ca('0x1a')](_0x55385c[_0x43ca('0x32')]['offset']);}return _0x44877b[_0x43ca('0x99')](_0x5afe81);}})['then'](function(_0x41fd86){if(_0x41fd86){return _0x41fd86?{'count':_0x14b0be,'rows':_0x41fd86}:null;}})[_0x43ca('0x22')](respondWithResult(_0x2d8c70,null))[_0x43ca('0x44')](handleError(_0x2d8c70,null));};function handleQuery(_0x2249eb){logger[_0x43ca('0x9a')](_0x2249eb);return db[_0x43ca('0x87')][_0x43ca('0x32')](_0x2249eb)[_0x43ca('0x95')](function(_0x4e4794){csv_results[_0x43ca('0x5e')](_0x4e4794);})[_0x43ca('0x44')](function(_0x4c250d){logger[_0x43ca('0x27')](_0x4c250d['message']);});}