70bb4f9bf38177871872a591131852704f064b77
[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 _0x36d8=['cf_%s','getCustomFields','findOne','order','getGlobalCustomFields','findAndCountAll','addAgents','spread','emit','userCmList:save','removeAgents','userCmList:remove','getAgents','eml-format','rimraf','zip-dir','request-promise','bluebird','mustache','util','path','sox','to-csv','ejs','fs-extra','crypto','jsforce','desk.js','querystring','papaparse','ioredis','../../components/auth/service','../../components/parsers/qs','api','../../config/utils','../../config/environment','../../config/license/util','../../mysqldb','redis','defaults','localhost','socket.io-emitter','register','sendStatus','status','json','offset','limit','undefined','count','set','Content-Range','apply','reject','save','update','destroy','then','Lists','end','error','stack','name','send','index','map','CmList','rawAttributes','fieldName','key','model','query','keys','filters','attributes','intersection','fields','length','hasOwnProperty','nolimit','sort','where','pick','filter','merge','type','VIRTUAL','options','include','rows','show','find','catch','create','user','get','Unable\x20to\x20retrieve\x20the\x20current\x20user','UserProfileSection','UserProfileResource','Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s','body','params','describe','addDisposition','Disposition','includeAll','findAll','removeDispositions','ids','tags','isArray','join','ListId','push','each','omit','success','dataValues','message','Malformed\x20request\x20syntax','getContacts','CustomFields','CmContact','concat','format','cf_%d','getContactsCsv','ContactItemType','CmCustomField','alias','from','cm_contacts','c.ListId\x20=\x20?','distinct','customField_','field','select','item','ItemTypeId\x20=\x20?','additionalPhone_','description','cm_contact_has_items','CmContactId\x20=\x20c.id','toString','isEmpty','now','writeFileSync','setHeader','attachment;\x20filename=','Content-type','text/csv','download','/tmp/list_%d_%s.csv','addCustomFields','Sequelize','text','TEXT','number','INTEGER','switch','defaultValue','sequelize','queryInterface','addColumn'];(function(_0x1dce59,_0x54a0e5){var _0x47f187=function(_0x39d510){while(--_0x39d510){_0x1dce59['push'](_0x1dce59['shift']());}};_0x47f187(++_0x54a0e5);}(_0x36d8,0xb1));var _0x836d=function(_0x10ca12,_0x34b81e){_0x10ca12=_0x10ca12-0x0;var _0x19607f=_0x36d8[_0x10ca12];return _0x19607f;};'use strict';var emlformat=require(_0x836d('0x0'));var rimraf=require(_0x836d('0x1'));var zipdir=require(_0x836d('0x2'));var jsonpatch=require('fast-json-patch');var rp=require(_0x836d('0x3'));var moment=require('moment');var BPromise=require(_0x836d('0x4'));var Mustache=require(_0x836d('0x5'));var util=require(_0x836d('0x6'));var path=require(_0x836d('0x7'));var sox=require(_0x836d('0x8'));var csv=require(_0x836d('0x9'));var ejs=require(_0x836d('0xa'));var fs=require('fs');var fs_extra=require(_0x836d('0xb'));var _=require('lodash');var squel=require('squel');var crypto=require(_0x836d('0xc'));var jsforce=require(_0x836d('0xd'));var deskjs=require(_0x836d('0xe'));var toCsv=require(_0x836d('0x9'));var querystring=require(_0x836d('0xf'));var Papa=require(_0x836d('0x10'));var Redis=require(_0x836d('0x11'));var authService=require(_0x836d('0x12'));var qs=require(_0x836d('0x13'));var as=require('../../components/parsers/advancedSearch');var hardwareService=require('../../config/license/hardware');var logger=require('../../config/logger')(_0x836d('0x14'));var utils=require(_0x836d('0x15'));var config=require(_0x836d('0x16'));var licenseUtil=require(_0x836d('0x17'));var db=require(_0x836d('0x18'))['db'];var csv_results;config[_0x836d('0x19')]=_[_0x836d('0x1a')](config[_0x836d('0x19')],{'host':_0x836d('0x1b'),'port':0x18eb});var socket=require(_0x836d('0x1c'))(new Redis(config[_0x836d('0x19')]));require('./cmList.socket')[_0x836d('0x1d')](socket);function respondWithStatusCode(_0xed77a6,_0x442041){_0x442041=_0x442041||0xcc;return function(_0x545085){if(_0x545085){return _0xed77a6[_0x836d('0x1e')](_0x442041);}return _0xed77a6[_0x836d('0x1f')](_0x442041)['end']();};}function respondWithResult(_0x1d3bf2,_0xc7c820){_0xc7c820=_0xc7c820||0xc8;return function(_0x279373){if(_0x279373){return _0x1d3bf2[_0x836d('0x1f')](_0xc7c820)[_0x836d('0x20')](_0x279373);}};}function respondWithFilteredResult(_0x5f02de,_0x2ad998){return function(_0x1a2490){if(_0x1a2490){var _0x1949e8=typeof _0x2ad998[_0x836d('0x21')]==='undefined'&&typeof _0x2ad998[_0x836d('0x22')]===_0x836d('0x23');var _0x27c87a=_0x1a2490[_0x836d('0x24')];var _0x15cc1d=_0x1949e8?0x0:_0x2ad998['offset'];var _0x5cce4f=_0x1949e8?_0x1a2490['count']:_0x2ad998[_0x836d('0x21')]+_0x2ad998[_0x836d('0x22')];var _0x4c5797;if(_0x5cce4f>=_0x27c87a){_0x5cce4f=_0x27c87a;_0x4c5797=0xc8;}else{_0x4c5797=0xce;}_0x5f02de[_0x836d('0x1f')](_0x4c5797);return _0x5f02de[_0x836d('0x25')](_0x836d('0x26'),_0x15cc1d+'-'+_0x5cce4f+'/'+_0x27c87a)['json'](_0x1a2490);}return null;};}function patchUpdates(_0x3ae8ec){return function(_0x22bea0){try{jsonpatch[_0x836d('0x27')](_0x22bea0,_0x3ae8ec,!![]);}catch(_0x636eed){return BPromise[_0x836d('0x28')](_0x636eed);}return _0x22bea0[_0x836d('0x29')]();};}function saveUpdates(_0x204717,_0x3f6fe8){return function(_0x1a9824){if(_0x1a9824){return _0x1a9824[_0x836d('0x2a')](_0x204717)['then'](function(_0x5392de){return _0x5392de;});}return null;};}function removeEntity(_0x3e74a1,_0x8dabec){return function(_0xe6ecef){if(_0xe6ecef){return _0xe6ecef[_0x836d('0x2b')]()[_0x836d('0x2c')](function(){var _0x45538f=_0xe6ecef['get']({'plain':!![]});var _0x39ee57=_0x836d('0x2d');return db['UserProfileResource'][_0x836d('0x2b')]({'where':{'type':_0x39ee57,'resourceId':_0x45538f['id']}})[_0x836d('0x2c')](function(){return _0xe6ecef;});})[_0x836d('0x2c')](function(){_0x3e74a1[_0x836d('0x1f')](0xcc)[_0x836d('0x2e')]();});}};}function handleEntityNotFound(_0x4b7be9,_0x152b3f){return function(_0x25b119){if(!_0x25b119){_0x4b7be9[_0x836d('0x1e')](0x194);}return _0x25b119;};}function handleError(_0x255cfd,_0x11320b){_0x11320b=_0x11320b||0x1f4;return function(_0x32e615){logger[_0x836d('0x2f')](_0x32e615[_0x836d('0x30')]);if(_0x32e615[_0x836d('0x31')]){delete _0x32e615[_0x836d('0x31')];}_0x255cfd['status'](_0x11320b)[_0x836d('0x32')](_0x32e615);};}exports[_0x836d('0x33')]=function(_0x4a8c29,_0x1d6cee){var _0x1e1cef={},_0x150a09={},_0x33887b={'count':0x0,'rows':[]};var _0x135243=_[_0x836d('0x34')](db[_0x836d('0x35')][_0x836d('0x36')],function(_0x20e94c){return{'name':_0x20e94c[_0x836d('0x37')],'type':_0x20e94c['type'][_0x836d('0x38')]};});_0x150a09[_0x836d('0x39')]=_[_0x836d('0x34')](_0x135243,_0x836d('0x31'));_0x150a09[_0x836d('0x3a')]=_[_0x836d('0x3b')](_0x4a8c29['query']);_0x150a09[_0x836d('0x3c')]=_['intersection'](_0x150a09[_0x836d('0x39')],_0x150a09[_0x836d('0x3a')]);_0x1e1cef[_0x836d('0x3d')]=_[_0x836d('0x3e')](_0x150a09[_0x836d('0x39')],qs[_0x836d('0x3f')](_0x4a8c29[_0x836d('0x3a')]['fields']));_0x1e1cef['attributes']=_0x1e1cef[_0x836d('0x3d')][_0x836d('0x40')]?_0x1e1cef[_0x836d('0x3d')]:_0x150a09[_0x836d('0x39')];if(!_0x4a8c29[_0x836d('0x3a')][_0x836d('0x41')](_0x836d('0x42'))){_0x1e1cef[_0x836d('0x22')]=qs['limit'](_0x4a8c29['query'][_0x836d('0x22')]);_0x1e1cef[_0x836d('0x21')]=qs[_0x836d('0x21')](_0x4a8c29[_0x836d('0x3a')][_0x836d('0x21')]);}_0x1e1cef['order']=qs['sort'](_0x4a8c29['query'][_0x836d('0x43')]);_0x1e1cef[_0x836d('0x44')]=qs[_0x836d('0x3c')](_[_0x836d('0x45')](_0x4a8c29[_0x836d('0x3a')],_0x150a09[_0x836d('0x3c')]),_0x135243);if(_0x4a8c29[_0x836d('0x3a')][_0x836d('0x46')]){_0x1e1cef[_0x836d('0x44')]=_[_0x836d('0x47')](_0x1e1cef['where'],{'$or':_['map'](_0x135243,function(_0x4b498b){if(_0x4b498b[_0x836d('0x48')]!==_0x836d('0x49')){var _0x4b696d={};_0x4b696d[_0x4b498b[_0x836d('0x31')]]={'$like':'%'+_0x4a8c29[_0x836d('0x3a')]['filter']+'%'};return _0x4b696d;}})});}_0x1e1cef=_['merge']({},_0x1e1cef,_0x4a8c29[_0x836d('0x4a')]);var _0x317f4c={'where':_0x1e1cef[_0x836d('0x44')]};return db[_0x836d('0x35')]['count'](_0x317f4c)['then'](function(_0x4e599d){_0x33887b[_0x836d('0x24')]=_0x4e599d;if(_0x4a8c29[_0x836d('0x3a')]['includeAll']){_0x1e1cef[_0x836d('0x4b')]=[{'all':!![]}];}return db[_0x836d('0x35')]['findAll'](_0x1e1cef);})[_0x836d('0x2c')](function(_0x37584e){_0x33887b[_0x836d('0x4c')]=_0x37584e;return _0x33887b;})[_0x836d('0x2c')](respondWithFilteredResult(_0x1d6cee,_0x1e1cef))['catch'](handleError(_0x1d6cee,null));};exports[_0x836d('0x4d')]=function(_0x5f094e,_0x4e460f){var _0x35ba7e={'raw':![],'where':{'id':_0x5f094e['params']['id']}},_0x45f113={};_0x45f113[_0x836d('0x39')]=_['keys'](db[_0x836d('0x35')]['rawAttributes']);_0x45f113['query']=_[_0x836d('0x3b')](_0x5f094e[_0x836d('0x3a')]);_0x45f113[_0x836d('0x3c')]=_[_0x836d('0x3e')](_0x45f113['model'],_0x45f113[_0x836d('0x3a')]);_0x35ba7e[_0x836d('0x3d')]=_[_0x836d('0x3e')](_0x45f113[_0x836d('0x39')],qs['fields'](_0x5f094e[_0x836d('0x3a')][_0x836d('0x3f')]));_0x35ba7e[_0x836d('0x3d')]=_0x35ba7e[_0x836d('0x3d')][_0x836d('0x40')]?_0x35ba7e[_0x836d('0x3d')]:_0x45f113[_0x836d('0x39')];if(_0x5f094e[_0x836d('0x3a')]['includeAll']){_0x35ba7e['include']=[{'all':!![]}];}_0x35ba7e=_[_0x836d('0x47')]({},_0x35ba7e,_0x5f094e[_0x836d('0x4a')]);return db[_0x836d('0x35')][_0x836d('0x4e')](_0x35ba7e)['then'](handleEntityNotFound(_0x4e460f,null))[_0x836d('0x2c')](respondWithResult(_0x4e460f,null))[_0x836d('0x4f')](handleError(_0x4e460f,null));};exports[_0x836d('0x50')]=function(_0x48e60d,_0x422414){return db[_0x836d('0x35')][_0x836d('0x50')](_0x48e60d['body'],{})[_0x836d('0x2c')](function(_0x5eea7e){var _0x1a132e=_0x48e60d[_0x836d('0x51')][_0x836d('0x52')]({'plain':!![]});if(!_0x1a132e)throw new Error(_0x836d('0x53'));if(_0x1a132e['role']===_0x836d('0x51')){var _0x2be09c=_0x5eea7e[_0x836d('0x52')]({'plain':!![]});var _0x5e9e3b=_0x836d('0x2d');return db[_0x836d('0x54')][_0x836d('0x4e')]({'where':{'name':_0x5e9e3b,'userProfileId':_0x1a132e['userProfileId']},'raw':!![]})[_0x836d('0x2c')](function(_0x4fff8b){if(_0x4fff8b&&_0x4fff8b['autoAssociation']===0x0){return db[_0x836d('0x55')][_0x836d('0x50')]({'name':_0x2be09c[_0x836d('0x31')],'resourceId':_0x2be09c['id'],'type':_0x4fff8b[_0x836d('0x31')],'sectionId':_0x4fff8b['id']},{})['then'](function(){return _0x5eea7e;});}else{return _0x5eea7e;}})[_0x836d('0x4f')](function(_0x38fc52){logger[_0x836d('0x2f')](_0x836d('0x56'),_0x38fc52);throw _0x38fc52;});}return _0x5eea7e;})[_0x836d('0x2c')](respondWithResult(_0x422414,0xc9))['catch'](handleError(_0x422414,null));};exports[_0x836d('0x2a')]=function(_0x4bbd95,_0x1b9a08){if(_0x4bbd95[_0x836d('0x57')]['id']){delete _0x4bbd95['body']['id'];}return db[_0x836d('0x35')][_0x836d('0x4e')]({'where':{'id':_0x4bbd95[_0x836d('0x58')]['id']}})[_0x836d('0x2c')](handleEntityNotFound(_0x1b9a08,null))[_0x836d('0x2c')](saveUpdates(_0x4bbd95[_0x836d('0x57')],null))[_0x836d('0x2c')](respondWithResult(_0x1b9a08,null))[_0x836d('0x4f')](handleError(_0x1b9a08,null));};exports[_0x836d('0x2b')]=function(_0x32feb1,_0x460386){return db[_0x836d('0x35')][_0x836d('0x4e')]({'where':{'id':_0x32feb1[_0x836d('0x58')]['id']}})[_0x836d('0x2c')](handleEntityNotFound(_0x460386,null))['then'](removeEntity(_0x460386,null))[_0x836d('0x4f')](handleError(_0x460386,null));};exports[_0x836d('0x59')]=function(_0x44195c,_0x5d2a5f){return db['CmList'][_0x836d('0x59')]()['then'](respondWithResult(_0x5d2a5f,null))[_0x836d('0x4f')](handleError(_0x5d2a5f,null));};exports[_0x836d('0x5a')]=function(_0x36ccb5,_0x34120e,_0x546899){if(_0x36ccb5[_0x836d('0x57')]['id']){delete _0x36ccb5[_0x836d('0x57')]['id'];}return db[_0x836d('0x35')][_0x836d('0x4e')]({'where':{'id':_0x36ccb5[_0x836d('0x58')]['id']}})[_0x836d('0x2c')](handleEntityNotFound(_0x34120e,null))[_0x836d('0x2c')](function(_0x147aec){if(_0x147aec){_0x36ccb5[_0x836d('0x57')]['ListId']=_0x147aec['id'];return db['Disposition'][_0x836d('0x50')](_0x36ccb5[_0x836d('0x57')]);}})[_0x836d('0x2c')](respondWithResult(_0x34120e,null))['catch'](handleError(_0x34120e,null));};exports['getDispositions']=function(_0x132f15,_0xdd76b8,_0x455c73){var _0x413829={'raw':![],'where':{}};var _0x25dba8={};var _0x16e4d1={'count':0x0,'rows':[]};return db[_0x836d('0x35')]['findOne']({'where':{'id':_0x132f15[_0x836d('0x58')]['id']}})['then'](handleEntityNotFound(_0xdd76b8,null))[_0x836d('0x2c')](function(_0xb0cf08){if(_0xb0cf08){_0x25dba8[_0x836d('0x39')]=_[_0x836d('0x3b')](db[_0x836d('0x5b')][_0x836d('0x36')]);_0x25dba8[_0x836d('0x3a')]=_['keys'](_0x132f15[_0x836d('0x3a')]);_0x25dba8[_0x836d('0x3c')]=_[_0x836d('0x3e')](_0x25dba8[_0x836d('0x39')],_0x25dba8[_0x836d('0x3a')]);_0x413829[_0x836d('0x3d')]=_[_0x836d('0x3e')](_0x25dba8[_0x836d('0x39')],qs[_0x836d('0x3f')](_0x132f15[_0x836d('0x3a')][_0x836d('0x3f')]));_0x413829[_0x836d('0x3d')]=_0x413829[_0x836d('0x3d')][_0x836d('0x40')]?_0x413829[_0x836d('0x3d')]:_0x25dba8['model'];if(!_0x132f15[_0x836d('0x3a')][_0x836d('0x41')](_0x836d('0x42'))){_0x413829['limit']=qs[_0x836d('0x22')](_0x132f15[_0x836d('0x3a')][_0x836d('0x22')]);_0x413829[_0x836d('0x21')]=qs[_0x836d('0x21')](_0x132f15[_0x836d('0x3a')][_0x836d('0x21')]);}_0x413829['order']=qs[_0x836d('0x43')](_0x132f15[_0x836d('0x3a')][_0x836d('0x43')]);_0x413829['where']=qs[_0x836d('0x3c')](_['pick'](_0x132f15[_0x836d('0x3a')],_0x25dba8['filters']));_0x413829['where']['ListId']=_0xb0cf08['id'];if(_0x132f15[_0x836d('0x3a')][_0x836d('0x46')]){_0x413829['where']=_[_0x836d('0x47')](_0x413829['where'],{'$or':_[_0x836d('0x34')](_0x413829[_0x836d('0x3d')],function(_0x5241cb){var _0x10a97c={};_0x10a97c[_0x5241cb]={'$like':'%'+_0x132f15['query']['filter']+'%'};return _0x10a97c;})});}_0x413829=_[_0x836d('0x47')]({},_0x413829,_0x132f15[_0x836d('0x4a')]);return db['Disposition'][_0x836d('0x24')]({'where':_0x413829['where']})['then'](function(_0x20da17){_0x16e4d1[_0x836d('0x24')]=_0x20da17;if(_0x132f15['query'][_0x836d('0x5c')]){_0x413829[_0x836d('0x4b')]=[{'all':!![]}];}return db[_0x836d('0x5b')][_0x836d('0x5d')](_0x413829);})[_0x836d('0x2c')](function(_0x3057fa){_0x16e4d1[_0x836d('0x4c')]=_0x3057fa;return _0x16e4d1;});}})[_0x836d('0x2c')](respondWithFilteredResult(_0xdd76b8,_0x413829))[_0x836d('0x4f')](handleError(_0xdd76b8,null));};exports[_0x836d('0x5e')]=function(_0x4c9942,_0x438dab,_0x4a3215){return db[_0x836d('0x35')][_0x836d('0x4e')]({'where':{'id':_0x4c9942['params']['id']}})[_0x836d('0x2c')](handleEntityNotFound(_0x438dab,null))[_0x836d('0x2c')](function(_0x473706){if(_0x473706){return _0x473706['removeDispositions'](_0x4c9942[_0x836d('0x3a')][_0x836d('0x5f')]);}})['then'](respondWithStatusCode(_0x438dab,null))[_0x836d('0x4f')](handleError(_0x438dab,null));};exports['addContacts']=function(_0x57cab4,_0x4e165b,_0x2e2547){return db[_0x836d('0x35')][_0x836d('0x4e')]({'where':{'id':_0x57cab4[_0x836d('0x58')]['id']}})['then'](handleEntityNotFound(_0x4e165b,null))[_0x836d('0x2c')](function(_0x43e6be){if(_0x43e6be){var _0x566d72=[];var _0x4578f7={'success':[],'errors':[]};return db['CmContact']['describe']()[_0x836d('0x2c')](function(_0x385c09){if(_0x57cab4[_0x836d('0x57')][_0x836d('0x60')]&&_[_0x836d('0x61')](_0x57cab4[_0x836d('0x57')][_0x836d('0x60')])){if(_0x57cab4[_0x836d('0x57')]['tags']['length']){_0x57cab4[_0x836d('0x57')][_0x836d('0x60')]=_0x57cab4[_0x836d('0x57')][_0x836d('0x60')][_0x836d('0x62')](';')+';';}else{_0x57cab4['body'][_0x836d('0x60')]=null;}}else{_0x57cab4['body'][_0x836d('0x60')]=null;}if(_0x57cab4[_0x836d('0x57')]&&_[_0x836d('0x61')](_0x57cab4[_0x836d('0x57')])){for(var _0x1129e7=0x0;_0x1129e7<_0x57cab4[_0x836d('0x57')]['length'];_0x1129e7+=0x1){_0x57cab4[_0x836d('0x57')][_0x1129e7][_0x836d('0x63')]=_0x57cab4[_0x836d('0x58')]['id'];_0x566d72[_0x836d('0x64')](_0x57cab4['body'][_0x1129e7]);}return BPromise[_0x836d('0x65')](_0x566d72,function(_0x218556){return db['CmContact'][_0x836d('0x50')](_[_0x836d('0x66')](_0x218556,[_0x836d('0x5f'),'id'])||{},{'fields':_[_0x836d('0x3b')](_0x385c09),'raw':!![]})[_0x836d('0x2c')](function(_0x16a7d0){_0x4578f7[_0x836d('0x67')][_0x836d('0x64')](_0x16a7d0[_0x836d('0x68')]);})[_0x836d('0x4f')](function(_0x738868){_0x4578f7['errors']['push']({'data':_0x218556,'error':_0x738868[_0x836d('0x69')]});});})[_0x836d('0x2c')](function(_0x4a2682){return _0x4578f7;})[_0x836d('0x4f')](function(_0x4835b0){return _0x4835b0;});}else{_0x4e165b[_0x836d('0x1f')](0x190)[_0x836d('0x20')]({'message':_0x836d('0x6a')});}});}})[_0x836d('0x2c')](respondWithResult(_0x4e165b,null))['catch'](handleError(_0x4e165b,null));};exports[_0x836d('0x6b')]=function(_0xf0c40d,_0x2d56ed,_0x14a317){var _0x415fa8;return db['CmList'][_0x836d('0x4e')]({'where':{'id':_0xf0c40d[_0x836d('0x58')]['id']},'include':[{'model':db['CmCustomField'],'as':_0x836d('0x6c')}]})[_0x836d('0x2c')](handleEntityNotFound(_0x2d56ed,null))[_0x836d('0x2c')](function(_0x4b4e2e){if(_0x4b4e2e){_0x415fa8=_0x4b4e2e;return db[_0x836d('0x6d')][_0x836d('0x36')];}})[_0x836d('0x2c')](function(_0x309d1d){if(_0x309d1d){var _0x5c0cb1={};var _0x335e6c={};_0x335e6c['model']=_[_0x836d('0x6e')](_[_0x836d('0x3b')](_0x309d1d),_[_0x836d('0x34')](_0x415fa8[_0x836d('0x6c')],function(_0x2595d4){return util[_0x836d('0x6f')](_0x836d('0x70'),_0x2595d4['id']);}));_0x335e6c[_0x836d('0x3a')]=_[_0x836d('0x3b')](_0xf0c40d['query']);_0x335e6c[_0x836d('0x3c')]=_['intersection'](_0x335e6c[_0x836d('0x39')],_0x335e6c[_0x836d('0x3a')]);_0x5c0cb1[_0x836d('0x3d')]=_[_0x836d('0x3e')](_0x335e6c[_0x836d('0x39')],qs[_0x836d('0x3f')](_0xf0c40d['query'][_0x836d('0x3f')]));_0x5c0cb1[_0x836d('0x3d')]=_0x5c0cb1[_0x836d('0x3d')][_0x836d('0x40')]?_0x5c0cb1[_0x836d('0x3d')]:_0x335e6c[_0x836d('0x39')];if(!_0xf0c40d[_0x836d('0x3a')]['hasOwnProperty']('nolimit')){_0x5c0cb1['limit']=qs[_0x836d('0x22')](_0xf0c40d[_0x836d('0x3a')]['limit']);_0x5c0cb1[_0x836d('0x21')]=qs[_0x836d('0x21')](_0xf0c40d['query']['offset']);}_0x5c0cb1['order']=qs[_0x836d('0x43')](_0xf0c40d[_0x836d('0x3a')][_0x836d('0x43')]);_0x5c0cb1[_0x836d('0x44')]=qs['filters'](_[_0x836d('0x45')](_0xf0c40d[_0x836d('0x3a')],_0x335e6c[_0x836d('0x3c')]));_0x5c0cb1['raw']=!![];if(_0xf0c40d['query']['filter']){_0x5c0cb1[_0x836d('0x44')]=_['merge'](_0x5c0cb1[_0x836d('0x44')],{'$or':_[_0x836d('0x34')](_0x5c0cb1[_0x836d('0x3d')],function(_0x101dae){var _0x5e077a={};_0x5e077a[_0x101dae]={'$like':'%'+_0xf0c40d[_0x836d('0x3a')]['filter']+'%'};return _0x5e077a;})});}_0x5c0cb1=_['merge']({},_0x5c0cb1,_0xf0c40d[_0x836d('0x4a')]);return _0x415fa8[_0x836d('0x6b')](_0x5c0cb1);}})['then'](respondWithResult(_0x2d56ed,null))[_0x836d('0x4f')](handleError(_0x2d56ed,null));};exports[_0x836d('0x71')]=function(_0x289342,_0xbd3054,_0x581e1b){var _0x489a46;var _0x2ed4e6;var _0x1ec88a;var _0x2f6efd=_0x289342['params']['id'];csv_results=[];return db[_0x836d('0x72')][_0x836d('0x5d')]({'attributes':['id',_0x836d('0x31')],'raw':!![],'order':['OrderBy']})[_0x836d('0x2c')](function(_0x2d9727){_0x489a46=_0x2d9727;var _0xf7d292=_['keys'](db['CmContact'][_0x836d('0x36')]);return db[_0x836d('0x73')][_0x836d('0x5d')]({'raw':!![],'attributes':['id',_0x836d('0x74')]})[_0x836d('0x2c')](function(_0x47d112){_0x2ed4e6=_0x47d112;var _0x2bb083=squel['select']()[_0x836d('0x3f')](_0xf7d292)[_0x836d('0x75')](_0x836d('0x76'),'c')[_0x836d('0x44')](_0x836d('0x77'),_0x2f6efd)[_0x836d('0x44')]('c.deletedAt\x20is\x20null')[_0x836d('0x78')]();for(var _0x3dd570=0x0;_0x3dd570<_0x2ed4e6[_0x836d('0x40')];_0x3dd570++){_0x2bb083['field']('c.cf_'+_0x2ed4e6[_0x3dd570]['id'],_0x836d('0x79')+_0x2ed4e6[_0x3dd570][_0x836d('0x74')]);}for(var _0x3dd570=0x0;_0x3dd570<_0x489a46[_0x836d('0x40')];_0x3dd570++){_0x2bb083[_0x836d('0x7a')](squel[_0x836d('0x7b')]()[_0x836d('0x7a')](_0x836d('0x7c'))[_0x836d('0x75')]('cm_contact_has_items')['where'](_0x836d('0x7d'),_0x489a46[_0x3dd570]['id'])['where']('CmContactId\x20=\x20c.id'),_0x836d('0x7e')+_0x489a46[_0x3dd570][_0x836d('0x31')]);_0x2bb083[_0x836d('0x7a')](squel[_0x836d('0x7b')]()[_0x836d('0x7a')](_0x836d('0x7f'))['from'](_0x836d('0x80'))[_0x836d('0x44')](_0x836d('0x7d'),_0x489a46[_0x3dd570]['id'])[_0x836d('0x44')](_0x836d('0x81')),'description_additionalPhone_'+_0x489a46[_0x3dd570][_0x836d('0x31')]);}var _0x54bc3b=[];_0x54bc3b[_0x836d('0x64')](_0x2bb083['toString']());BPromise[_0x836d('0x65')](_0x54bc3b,handleQuery)['then'](function(_0x2f24a0){handleQuery(_0x2bb083[_0x836d('0x82')]());var _0x3969e4=csv_results[0x0];if(!_[_0x836d('0x83')](_0x3969e4)){var _0xcfcd30=toCsv(_0x3969e4);var _0x55edee=Date[_0x836d('0x84')]();fs[_0x836d('0x85')](util[_0x836d('0x6f')]('/tmp/list_%d_%s.csv',_0x2f6efd,_0x55edee),_0xcfcd30);_0xbd3054[_0x836d('0x86')]('Content-disposition',_0x836d('0x87')+util['format']('list_%d_%s.csv',_0x2f6efd,_0x55edee));_0xbd3054[_0x836d('0x86')](_0x836d('0x88'),_0x836d('0x89'));return _0xbd3054[_0x836d('0x8a')](util[_0x836d('0x6f')](_0x836d('0x8b'),_0x2f6efd,_0x55edee));}else{return _0xbd3054['sendStatus'](0xcc);}});});});};exports['addCustomField']=function(_0x15b8a3,_0x4f51cc,_0x3792d8){var _0x24fd63;delete _0x15b8a3[_0x836d('0x57')]['id'];return db['CmList']['findOne']({'where':{'id':_0x15b8a3['params']['id']}})[_0x836d('0x2c')](handleEntityNotFound(_0x4f51cc,null))[_0x836d('0x2c')](function(_0x274a36){if(_0x274a36){return db['sequelize']['transaction'](function(_0x46f32d){return db['CmCustomField'][_0x836d('0x50')](_0x15b8a3[_0x836d('0x57')],{'transaction':_0x46f32d})['then'](function(_0x19595b){_0x24fd63=_0x19595b;return _0x274a36[_0x836d('0x8c')](_0x19595b,{'transaction':_0x46f32d});})['then'](function(){var _0x1ea7b3={'type':db[_0x836d('0x8d')]['TEXT'],'transaction':_0x46f32d};switch(_0x15b8a3[_0x836d('0x57')]['type']){case _0x836d('0x8e'):_0x1ea7b3[_0x836d('0x48')]=db['Sequelize'][_0x836d('0x8f')];break;case _0x836d('0x90'):_0x1ea7b3[_0x836d('0x48')]=db['Sequelize'][_0x836d('0x91')];break;case _0x836d('0x92'):_0x1ea7b3[_0x836d('0x48')]=db[_0x836d('0x8d')]['BOOLEAN'];_0x1ea7b3[_0x836d('0x93')]=![];break;default:}return db[_0x836d('0x94')][_0x836d('0x95')][_0x836d('0x96')](_0x836d('0x76'),util[_0x836d('0x6f')](_0x836d('0x97'),_0x24fd63['id']),_0x1ea7b3);})['then'](function(){return _0x24fd63;});});}})['then'](respondWithResult(_0x4f51cc,null))['catch'](handleError(_0x4f51cc,null));};exports[_0x836d('0x98')]=function(_0x4ecabc,_0x23adc4,_0x49732b){var _0x546bcf={};var _0x49fe89={};var _0x28f4a8;var _0x5db953;return db['CmList'][_0x836d('0x99')]({'where':{'id':_0x4ecabc[_0x836d('0x58')]['id']}})[_0x836d('0x2c')](handleEntityNotFound(_0x23adc4,null))[_0x836d('0x2c')](function(_0x58d239){if(_0x58d239){_0x28f4a8=_0x58d239;_0x49fe89['model']=_['keys'](db[_0x836d('0x73')][_0x836d('0x36')]);_0x49fe89[_0x836d('0x3a')]=_[_0x836d('0x3b')](_0x4ecabc[_0x836d('0x3a')]);_0x49fe89[_0x836d('0x3c')]=_[_0x836d('0x3e')](_0x49fe89['model'],_0x49fe89[_0x836d('0x3a')]);_0x546bcf[_0x836d('0x3d')]=_[_0x836d('0x3e')](_0x49fe89[_0x836d('0x39')],qs['fields'](_0x4ecabc['query'][_0x836d('0x3f')]));_0x546bcf[_0x836d('0x3d')]=_0x546bcf['attributes'][_0x836d('0x40')]?_0x546bcf[_0x836d('0x3d')]:_0x49fe89[_0x836d('0x39')];_0x546bcf[_0x836d('0x9a')]=qs[_0x836d('0x43')](_0x4ecabc[_0x836d('0x3a')][_0x836d('0x43')]);_0x546bcf[_0x836d('0x44')]=qs[_0x836d('0x3c')](_[_0x836d('0x45')](_0x4ecabc[_0x836d('0x3a')],_0x49fe89[_0x836d('0x3c')]));_0x546bcf[_0x836d('0x44')]=_[_0x836d('0x47')](_0x546bcf[_0x836d('0x44')],{'$or':[{'ListId':_0x58d239['id']},{'ListId':null}]});if(_0x4ecabc[_0x836d('0x3a')][_0x836d('0x46')]){_0x546bcf[_0x836d('0x44')]=_[_0x836d('0x47')](_0x546bcf[_0x836d('0x44')],{'$or':_[_0x836d('0x34')](_0x546bcf[_0x836d('0x3d')],function(_0x3bf08a){var _0x2e599e={};_0x2e599e[_0x3bf08a]={'$like':'%'+_0x4ecabc['query'][_0x836d('0x46')]+'%'};return _0x2e599e;})});}_0x546bcf=_[_0x836d('0x47')]({},_0x546bcf,_0x4ecabc[_0x836d('0x4a')]);return db[_0x836d('0x73')]['findAndCountAll'](_0x546bcf);}})[_0x836d('0x2c')](respondWithResult(_0x23adc4,null))[_0x836d('0x4f')](handleError(_0x23adc4,null));};exports[_0x836d('0x9b')]=function(_0xc1a134,_0x370e77){return db[_0x836d('0x73')][_0x836d('0x9c')]({'where':{'ListId':null}})[_0x836d('0x2c')](handleEntityNotFound(_0x370e77,null))[_0x836d('0x2c')](function(_0x1b0ae1){return _0x1b0ae1;})[_0x836d('0x2c')](respondWithResult(_0x370e77,null))[_0x836d('0x4f')](handleError(_0x370e77,null));};exports[_0x836d('0x9d')]=function(_0x2c4fd0,_0x34f586,_0x26afca){return db[_0x836d('0x35')][_0x836d('0x4e')]({'where':{'id':_0x2c4fd0[_0x836d('0x58')]['id']}})[_0x836d('0x2c')](handleEntityNotFound(_0x34f586,null))[_0x836d('0x2c')](function(_0x239e5a){if(_0x239e5a){return _0x239e5a['addAgents'](_0x2c4fd0[_0x836d('0x57')]['ids'],_[_0x836d('0x66')](_0x2c4fd0[_0x836d('0x57')],['ids','id'])||{})[_0x836d('0x9e')](function(_0x20af85){for(var _0x2476a9=0x0;_0x2476a9<_0x2c4fd0[_0x836d('0x57')]['ids'][_0x836d('0x40')];_0x2476a9+=0x1){socket[_0x836d('0x9f')](_0x836d('0xa0'),{'UserId':Number(_0x2c4fd0[_0x836d('0x57')][_0x836d('0x5f')][_0x2476a9]),'CmListId':Number(_0x2c4fd0[_0x836d('0x58')]['id'])});}return _0x20af85;});}})['then'](respondWithResult(_0x34f586,null))[_0x836d('0x4f')](handleError(_0x34f586,null));};exports[_0x836d('0xa1')]=function(_0x210583,_0x1c8a14,_0x209d72){return db[_0x836d('0x35')][_0x836d('0x4e')]({'where':{'id':_0x210583[_0x836d('0x58')]['id']}})[_0x836d('0x2c')](handleEntityNotFound(_0x1c8a14,null))[_0x836d('0x2c')](function(_0x14aef6){if(_0x14aef6){return _0x14aef6['removeAgents'](_0x210583['query'][_0x836d('0x5f')])[_0x836d('0x2c')](function(){if(_[_0x836d('0x61')](_0x210583[_0x836d('0x3a')][_0x836d('0x5f')])){for(var _0x5273a5=0x0;_0x5273a5<_0x210583[_0x836d('0x3a')][_0x836d('0x5f')]['length'];_0x5273a5+=0x1){socket[_0x836d('0x9f')](_0x836d('0xa2'),{'UserId':Number(_0x210583[_0x836d('0x3a')][_0x836d('0x5f')][_0x5273a5]),'CmListId':Number(_0x210583[_0x836d('0x58')]['id'])});}}else{socket['emit'](_0x836d('0xa2'),{'UserId':Number(_0x210583['query'][_0x836d('0x5f')]),'CmListId':Number(_0x210583[_0x836d('0x58')]['id'])});}});}})[_0x836d('0x2c')](respondWithStatusCode(_0x1c8a14,null))[_0x836d('0x4f')](handleError(_0x1c8a14,null));};exports[_0x836d('0xa3')]=function(_0xa3d55d,_0x504dc9,_0x1eed36){var _0x37a62b={};var _0x1985ed={};var _0x301d5d;var _0x4e69c6;return db[_0x836d('0x35')][_0x836d('0x99')]({'where':{'id':_0xa3d55d[_0x836d('0x58')]['id']}})[_0x836d('0x2c')](handleEntityNotFound(_0x504dc9,null))[_0x836d('0x2c')](function(_0x4dc2e1){if(_0x4dc2e1){_0x301d5d=_0x4dc2e1;_0x1985ed[_0x836d('0x39')]=_[_0x836d('0x3b')](db['User'][_0x836d('0x36')]);_0x1985ed['query']=_[_0x836d('0x3b')](_0xa3d55d[_0x836d('0x3a')]);_0x1985ed['filters']=_[_0x836d('0x3e')](_0x1985ed[_0x836d('0x39')],_0x1985ed[_0x836d('0x3a')]);_0x37a62b[_0x836d('0x3d')]=_[_0x836d('0x3e')](_0x1985ed[_0x836d('0x39')],qs[_0x836d('0x3f')](_0xa3d55d[_0x836d('0x3a')][_0x836d('0x3f')]));_0x37a62b[_0x836d('0x3d')]=_0x37a62b[_0x836d('0x3d')][_0x836d('0x40')]?_0x37a62b['attributes']:_0x1985ed[_0x836d('0x39')];_0x37a62b[_0x836d('0x9a')]=qs[_0x836d('0x43')](_0xa3d55d[_0x836d('0x3a')][_0x836d('0x43')]);_0x37a62b['where']=qs[_0x836d('0x3c')](_['pick'](_0xa3d55d['query'],_0x1985ed['filters']));if(_0xa3d55d[_0x836d('0x3a')][_0x836d('0x46')]){_0x37a62b['where']=_[_0x836d('0x47')](_0x37a62b[_0x836d('0x44')],{'$or':_[_0x836d('0x34')](_0x37a62b[_0x836d('0x3d')],function(_0x2a7d44){var _0x4aec3b={};_0x4aec3b[_0x2a7d44]={'$like':'%'+_0xa3d55d[_0x836d('0x3a')][_0x836d('0x46')]+'%'};return _0x4aec3b;})});}_0x37a62b=_[_0x836d('0x47')]({},_0x37a62b,_0xa3d55d['options']);return _0x301d5d['getAgents'](_0x37a62b);}})[_0x836d('0x2c')](function(_0xc46e9a){if(_0xc46e9a){_0x4e69c6=_0xc46e9a[_0x836d('0x40')];if(!_0xa3d55d[_0x836d('0x3a')][_0x836d('0x41')]('nolimit')){_0x37a62b[_0x836d('0x22')]=qs[_0x836d('0x22')](_0xa3d55d[_0x836d('0x3a')]['limit']);_0x37a62b[_0x836d('0x21')]=qs[_0x836d('0x21')](_0xa3d55d[_0x836d('0x3a')][_0x836d('0x21')]);}return _0x301d5d[_0x836d('0xa3')](_0x37a62b);}})['then'](function(_0x5521e6){if(_0x5521e6){return _0x5521e6?{'count':_0x4e69c6,'rows':_0x5521e6}:null;}})['then'](respondWithResult(_0x504dc9,null))[_0x836d('0x4f')](handleError(_0x504dc9,null));};function handleQuery(_0x32fb14){logger['info'](_0x32fb14);return db['sequelize'][_0x836d('0x3a')](_0x32fb14)['spread'](function(_0x565ddd){csv_results[_0x836d('0x64')](_0x565ddd);})['catch'](function(_0x40a136){logger[_0x836d('0x2f')](_0x40a136['message']);});}