f1aace4fd725361c486d053af303dfe671610688
[motion2.git] / server / api / analyticExtractedReport / analyticExtractedReport.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 _0x35bf=['savename','output','existsSync','join','root','server/files/reports','Sequelize','ValidationError','Report\x20not\x20found\x20or\x20empty','exists','format','%s.%s','toLowerCase','eml-format','rimraf','zip-dir','mustache','util','path','to-csv','fs-extra','lodash','squel','crypto','jsforce','desk.js','querystring','ioredis','../../components/auth/service','../../components/parsers/advancedSearch','../../config/logger','api','../../config/utils','../../config/environment','../../config/license/util','../../mysqldb','sendStatus','status','end','json','offset','undefined','count','set','Content-Range','reject','save','update','then','destroy','get','ExtractedReports','error','name','send','index','map','AnalyticExtractedReport','rawAttributes','fieldName','type','key','model','query','filters','intersection','attributes','fields','length','nolimit','limit','order','sort','where','pick','merge','VIRTUAL','filter','options','includeAll','include','findAll','rows','catch','show','params','find','body','user','Unable\x20to\x20retrieve\x20the\x20current\x20user','role','UserProfileSection','userProfileId','autoAssociation','UserProfileResource','create','Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s'];(function(_0x5d80de,_0x2cf15d){var _0x1c7556=function(_0x5bd806){while(--_0x5bd806){_0x5d80de['push'](_0x5d80de['shift']());}};_0x1c7556(++_0x2cf15d);}(_0x35bf,0x1f2));var _0xf35b=function(_0x3b2b32,_0x3eb088){_0x3b2b32=_0x3b2b32-0x0;var _0x21c9a0=_0x35bf[_0x3b2b32];return _0x21c9a0;};'use strict';var emlformat=require(_0xf35b('0x0'));var rimraf=require(_0xf35b('0x1'));var zipdir=require(_0xf35b('0x2'));var jsonpatch=require('fast-json-patch');var rp=require('request-promise');var moment=require('moment');var BPromise=require('bluebird');var Mustache=require(_0xf35b('0x3'));var util=require(_0xf35b('0x4'));var path=require(_0xf35b('0x5'));var sox=require('sox');var csv=require(_0xf35b('0x6'));var ejs=require('ejs');var fs=require('fs');var fs_extra=require(_0xf35b('0x7'));var _=require(_0xf35b('0x8'));var squel=require(_0xf35b('0x9'));var crypto=require(_0xf35b('0xa'));var jsforce=require(_0xf35b('0xb'));var deskjs=require(_0xf35b('0xc'));var toCsv=require(_0xf35b('0x6'));var querystring=require(_0xf35b('0xd'));var Papa=require('papaparse');var Redis=require(_0xf35b('0xe'));var authService=require(_0xf35b('0xf'));var qs=require('../../components/parsers/qs');var as=require(_0xf35b('0x10'));var hardwareService=require('../../config/license/hardware');var logger=require(_0xf35b('0x11'))(_0xf35b('0x12'));var utils=require(_0xf35b('0x13'));var config=require(_0xf35b('0x14'));var licenseUtil=require(_0xf35b('0x15'));var db=require(_0xf35b('0x16'))['db'];function respondWithStatusCode(_0x26aa79,_0x401da2){_0x401da2=_0x401da2||0xcc;return function(_0x51a646){if(_0x51a646){return _0x26aa79[_0xf35b('0x17')](_0x401da2);}return _0x26aa79[_0xf35b('0x18')](_0x401da2)[_0xf35b('0x19')]();};}function respondWithResult(_0x468477,_0x4d4730){_0x4d4730=_0x4d4730||0xc8;return function(_0x69e516){if(_0x69e516){return _0x468477['status'](_0x4d4730)[_0xf35b('0x1a')](_0x69e516);}};}function respondWithFilteredResult(_0x52d17d,_0x576a90){return function(_0x587b68){if(_0x587b68){var _0x2c7fad=typeof _0x576a90[_0xf35b('0x1b')]===_0xf35b('0x1c')&&typeof _0x576a90['limit']==='undefined';var _0x47a144=_0x587b68[_0xf35b('0x1d')];var _0x491ac3=_0x2c7fad?0x0:_0x576a90[_0xf35b('0x1b')];var _0x3b5c7a=_0x2c7fad?_0x587b68[_0xf35b('0x1d')]:_0x576a90[_0xf35b('0x1b')]+_0x576a90['limit'];var _0x36e2d0;if(_0x3b5c7a>=_0x47a144){_0x3b5c7a=_0x47a144;_0x36e2d0=0xc8;}else{_0x36e2d0=0xce;}_0x52d17d[_0xf35b('0x18')](_0x36e2d0);return _0x52d17d[_0xf35b('0x1e')](_0xf35b('0x1f'),_0x491ac3+'-'+_0x3b5c7a+'/'+_0x47a144)[_0xf35b('0x1a')](_0x587b68);}return null;};}function patchUpdates(_0x56ce2b){return function(_0x5d44aa){try{jsonpatch['apply'](_0x5d44aa,_0x56ce2b,!![]);}catch(_0x24f8bc){return BPromise[_0xf35b('0x20')](_0x24f8bc);}return _0x5d44aa[_0xf35b('0x21')]();};}function saveUpdates(_0x578e,_0x402802){return function(_0x3c1faf){if(_0x3c1faf){return _0x3c1faf[_0xf35b('0x22')](_0x578e)[_0xf35b('0x23')](function(_0x4cc16d){return _0x4cc16d;});}return null;};}function removeEntity(_0x53751b,_0x221016){return function(_0x4592e8){if(_0x4592e8){return _0x4592e8[_0xf35b('0x24')]()[_0xf35b('0x23')](function(){var _0x201379=_0x4592e8[_0xf35b('0x25')]({'plain':!![]});var _0x4939f4=_0xf35b('0x26');return db['UserProfileResource']['destroy']({'where':{'type':_0x4939f4,'resourceId':_0x201379['id']}})[_0xf35b('0x23')](function(){return _0x4592e8;});})[_0xf35b('0x23')](function(){_0x53751b[_0xf35b('0x18')](0xcc)[_0xf35b('0x19')]();});}};}function handleEntityNotFound(_0x4e2f92,_0x16213e){return function(_0x2a2426){if(!_0x2a2426){_0x4e2f92['sendStatus'](0x194);}return _0x2a2426;};}function handleError(_0x259b72,_0x32afbf){_0x32afbf=_0x32afbf||0x1f4;return function(_0x2084a6){logger[_0xf35b('0x27')](_0x2084a6['stack']);if(_0x2084a6[_0xf35b('0x28')]){delete _0x2084a6[_0xf35b('0x28')];}_0x259b72['status'](_0x32afbf)[_0xf35b('0x29')](_0x2084a6);};}exports[_0xf35b('0x2a')]=function(_0x5e5825,_0x24fad4){var _0x1092eb={},_0x2d421f={},_0x285d14={'count':0x0,'rows':[]};var _0x3053a3=_[_0xf35b('0x2b')](db[_0xf35b('0x2c')][_0xf35b('0x2d')],function(_0x441791){return{'name':_0x441791[_0xf35b('0x2e')],'type':_0x441791[_0xf35b('0x2f')][_0xf35b('0x30')]};});_0x2d421f[_0xf35b('0x31')]=_['map'](_0x3053a3,_0xf35b('0x28'));_0x2d421f[_0xf35b('0x32')]=_['keys'](_0x5e5825[_0xf35b('0x32')]);_0x2d421f[_0xf35b('0x33')]=_[_0xf35b('0x34')](_0x2d421f['model'],_0x2d421f[_0xf35b('0x32')]);_0x1092eb[_0xf35b('0x35')]=_['intersection'](_0x2d421f[_0xf35b('0x31')],qs[_0xf35b('0x36')](_0x5e5825[_0xf35b('0x32')][_0xf35b('0x36')]));_0x1092eb[_0xf35b('0x35')]=_0x1092eb[_0xf35b('0x35')][_0xf35b('0x37')]?_0x1092eb[_0xf35b('0x35')]:_0x2d421f[_0xf35b('0x31')];if(!_0x5e5825[_0xf35b('0x32')]['hasOwnProperty'](_0xf35b('0x38'))){_0x1092eb[_0xf35b('0x39')]=qs['limit'](_0x5e5825['query'][_0xf35b('0x39')]);_0x1092eb[_0xf35b('0x1b')]=qs['offset'](_0x5e5825[_0xf35b('0x32')][_0xf35b('0x1b')]);}_0x1092eb[_0xf35b('0x3a')]=qs[_0xf35b('0x3b')](_0x5e5825['query'][_0xf35b('0x3b')]);_0x1092eb[_0xf35b('0x3c')]=qs[_0xf35b('0x33')](_[_0xf35b('0x3d')](_0x5e5825[_0xf35b('0x32')],_0x2d421f[_0xf35b('0x33')]),_0x3053a3);if(_0x5e5825[_0xf35b('0x32')]['filter']){_0x1092eb['where']=_[_0xf35b('0x3e')](_0x1092eb[_0xf35b('0x3c')],{'$or':_[_0xf35b('0x2b')](_0x3053a3,function(_0x554e6a){if(_0x554e6a['type']!==_0xf35b('0x3f')){var _0x4923a9={};_0x4923a9[_0x554e6a[_0xf35b('0x28')]]={'$like':'%'+_0x5e5825[_0xf35b('0x32')][_0xf35b('0x40')]+'%'};return _0x4923a9;}})});}_0x1092eb=_[_0xf35b('0x3e')]({},_0x1092eb,_0x5e5825[_0xf35b('0x41')]);var _0x3d4578={'where':_0x1092eb[_0xf35b('0x3c')]};return db[_0xf35b('0x2c')][_0xf35b('0x1d')](_0x3d4578)[_0xf35b('0x23')](function(_0x3103b6){_0x285d14[_0xf35b('0x1d')]=_0x3103b6;if(_0x5e5825[_0xf35b('0x32')][_0xf35b('0x42')]){_0x1092eb[_0xf35b('0x43')]=[{'all':!![]}];}return db['AnalyticExtractedReport'][_0xf35b('0x44')](_0x1092eb);})[_0xf35b('0x23')](function(_0xcae3f3){_0x285d14[_0xf35b('0x45')]=_0xcae3f3;return _0x285d14;})['then'](respondWithFilteredResult(_0x24fad4,_0x1092eb))[_0xf35b('0x46')](handleError(_0x24fad4,null));};exports[_0xf35b('0x47')]=function(_0x2cad5f,_0x1de9be){var _0x5935e4={'raw':!![],'where':{'id':_0x2cad5f[_0xf35b('0x48')]['id']}},_0x47c843={};_0x47c843[_0xf35b('0x31')]=_['keys'](db['AnalyticExtractedReport'][_0xf35b('0x2d')]);_0x47c843['query']=_['keys'](_0x2cad5f[_0xf35b('0x32')]);_0x47c843['filters']=_['intersection'](_0x47c843['model'],_0x47c843['query']);_0x5935e4[_0xf35b('0x35')]=_[_0xf35b('0x34')](_0x47c843['model'],qs[_0xf35b('0x36')](_0x2cad5f[_0xf35b('0x32')][_0xf35b('0x36')]));_0x5935e4[_0xf35b('0x35')]=_0x5935e4['attributes'][_0xf35b('0x37')]?_0x5935e4[_0xf35b('0x35')]:_0x47c843[_0xf35b('0x31')];if(_0x2cad5f[_0xf35b('0x32')]['includeAll']){_0x5935e4[_0xf35b('0x43')]=[{'all':!![]}];}_0x5935e4=_[_0xf35b('0x3e')]({},_0x5935e4,_0x2cad5f[_0xf35b('0x41')]);return db['AnalyticExtractedReport'][_0xf35b('0x49')](_0x5935e4)['then'](handleEntityNotFound(_0x1de9be,null))[_0xf35b('0x23')](respondWithResult(_0x1de9be,null))[_0xf35b('0x46')](handleError(_0x1de9be,null));};exports['create']=function(_0x5ab16b,_0x3fba64){return db[_0xf35b('0x2c')]['create'](_0x5ab16b[_0xf35b('0x4a')],{})[_0xf35b('0x23')](function(_0x5f1425){var _0x49c899=_0x5ab16b[_0xf35b('0x4b')][_0xf35b('0x25')]({'plain':!![]});if(!_0x49c899)throw new Error(_0xf35b('0x4c'));if(_0x49c899[_0xf35b('0x4d')]===_0xf35b('0x4b')){var _0x35fb81=_0x5f1425[_0xf35b('0x25')]({'plain':!![]});var _0x17863c=_0xf35b('0x26');return db[_0xf35b('0x4e')]['find']({'where':{'name':_0x17863c,'userProfileId':_0x49c899[_0xf35b('0x4f')]},'raw':!![]})[_0xf35b('0x23')](function(_0x9b0de3){if(_0x9b0de3&&_0x9b0de3[_0xf35b('0x50')]===0x0){return db[_0xf35b('0x51')][_0xf35b('0x52')]({'name':_0x35fb81[_0xf35b('0x28')],'resourceId':_0x35fb81['id'],'type':_0x9b0de3[_0xf35b('0x28')],'sectionId':_0x9b0de3['id']},{})[_0xf35b('0x23')](function(){return _0x5f1425;});}else{return _0x5f1425;}})[_0xf35b('0x46')](function(_0x4e5469){logger['error'](_0xf35b('0x53'),_0x4e5469);throw _0x4e5469;});}return _0x5f1425;})['then'](respondWithResult(_0x3fba64,0xc9))[_0xf35b('0x46')](handleError(_0x3fba64,null));};exports['update']=function(_0x5280e0,_0x59c6f3){if(_0x5280e0['body']['id']){delete _0x5280e0[_0xf35b('0x4a')]['id'];}return db[_0xf35b('0x2c')][_0xf35b('0x49')]({'where':{'id':_0x5280e0[_0xf35b('0x48')]['id']}})['then'](handleEntityNotFound(_0x59c6f3,null))['then'](saveUpdates(_0x5280e0[_0xf35b('0x4a')],null))[_0xf35b('0x23')](respondWithResult(_0x59c6f3,null))[_0xf35b('0x46')](handleError(_0x59c6f3,null));};exports[_0xf35b('0x24')]=function(_0x397818,_0xffa9fb){return db[_0xf35b('0x2c')][_0xf35b('0x49')]({'where':{'id':_0x397818[_0xf35b('0x48')]['id']}})[_0xf35b('0x23')](handleEntityNotFound(_0xffa9fb,null))['then'](removeEntity(_0xffa9fb,null))['catch'](handleError(_0xffa9fb,null));};exports['download']=function(_0x10899e,_0x4a31c3,_0x2b3c04){return db[_0xf35b('0x2c')][_0xf35b('0x49')]({'where':{'id':_0x10899e[_0xf35b('0x48')]['id']},'attributes':['name','basename',_0xf35b('0x54'),_0xf35b('0x55')],'raw':!![]})[_0xf35b('0x23')](handleEntityNotFound(_0x4a31c3,null))[_0xf35b('0x23')](function(_0x336b70){if(_0x336b70){if(!fs[_0xf35b('0x56')](path[_0xf35b('0x57')](config[_0xf35b('0x58')],_0xf35b('0x59'),_0x336b70[_0xf35b('0x54')]))){throw new db[(_0xf35b('0x5a'))][(_0xf35b('0x5b'))](_0xf35b('0x5c'));}if(_0x10899e[_0xf35b('0x32')][_0xf35b('0x5d')]){return _0x4a31c3[_0xf35b('0x17')](0xc8);}return _0x4a31c3['download'](path[_0xf35b('0x57')](config['root'],_0xf35b('0x59'),_0x336b70[_0xf35b('0x54')]),util[_0xf35b('0x5e')](_0xf35b('0x5f'),_0x336b70['basename']||_0x336b70['name'],_0x336b70[_0xf35b('0x55')][_0xf35b('0x60')]()));}})[_0xf35b('0x46')](handleError(_0x4a31c3,null));};