Built motion from commit (unavailable).|2.5.10
[motion2.git] / server / api / analyticCustomReport / analyticCustomReport.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 _0xdaae=['status','count','limit','Content-Range','json','apply','reject','then','destroy','get','CustomReports','UserProfileResource','end','error','stack','name','send','index','map','AnalyticCustomReport','rawAttributes','type','query','keys','filters','intersection','model','attributes','fields','hasOwnProperty','nolimit','offset','order','sort','filter','where','merge','VIRTUAL','options','includeAll','include','rows','catch','find','create','body','user','role','Reports','UserProfileSection','userProfileId','autoAssociation','update','preview','join','SUM(%s)','COUNT(%s)','MAX(%s)','AVG(%s)','GROUP_CONCAT(%s)','GROUP_CONCAT(%s\x20ORDER\x20BY\x20%s\x20ASC)','GROUP_CONCAT(%s\x20ORDER\x20BY\x20%s\x20DESC)','SEC_TO_TIME(%s)','ROUND(%s)','UNIX_TIMESTAMP(%s)','includes','IS\x20NULL','IS\x20NOT\x20NULL','IS\x20EMPTY','IS\x20NOT\x20EMPTY','rules','operator','group','field','condition','value','getFields','Sequelize','ValidationErrorItem','Please\x20insert\x20at\x20least\x20one\x20field','AnalyticMetric','keyBy','select','from','table','MetricId','function','replace','format','orderBy','DESC','alias','joins','parse','parentKey','foreignTable','foreignKey','%s.%s\x20=\x20%s.%s','conditions','clone','debug','Limited\x20Query:','toString','sequelize','SELECT','left_join','right_join','cross_join','COUNT(DISTINCT\x20%s)','MIN(%s)','DATE(%s)','length','metric','groupBy','No\x20available\x20data','output','web','fullPath','generate','csv','custom','AnalyticExtractedReport','.calldate\x20BETWEEN\x20?\x20AND\x20?','endDate','info','fork','countTable','COUNT(*)','QueryTypes','run','params','runReport','findAll','html-pdf','eml-format','rimraf','zip-dir','moment','bluebird','mustache','util','path','to-csv','ejs','lodash','squel','crypto','jsforce','desk.js','papaparse','../../components/auth/service','../../components/parsers/qs','../../config/logger','api','../../config/utils','../../config/license/util','../../mysqldb','sendStatus'];(function(_0x2a56ad,_0x2b94bf){var _0x425175=function(_0x342f20){while(--_0x342f20){_0x2a56ad['push'](_0x2a56ad['shift']());}};_0x425175(++_0x2b94bf);}(_0xdaae,0x1c1));var _0xedaa=function(_0x15adc6,_0xbc8322){_0x15adc6=_0x15adc6-0x0;var _0x3bb841=_0xdaae[_0x15adc6];return _0x3bb841;};'use strict';var pdf=require(_0xedaa('0x0'));var emlformat=require(_0xedaa('0x1'));var rimraf=require(_0xedaa('0x2'));var zipdir=require(_0xedaa('0x3'));var jsonpatch=require('fast-json-patch');var rp=require('request-promise');var moment=require(_0xedaa('0x4'));var BPromise=require(_0xedaa('0x5'));var Mustache=require(_0xedaa('0x6'));var util=require(_0xedaa('0x7'));var path=require(_0xedaa('0x8'));var sox=require('sox');var csv=require(_0xedaa('0x9'));var ejs=require(_0xedaa('0xa'));var fs=require('fs');var _=require(_0xedaa('0xb'));var squel=require(_0xedaa('0xc'));var crypto=require(_0xedaa('0xd'));var jsforce=require(_0xedaa('0xe'));var deskjs=require(_0xedaa('0xf'));var toCsv=require(_0xedaa('0x9'));var querystring=require('querystring');var Papa=require(_0xedaa('0x10'));var Redis=require('ioredis');var authService=require(_0xedaa('0x11'));var qs=require(_0xedaa('0x12'));var as=require('../../components/parsers/advancedSearch');var hardwareService=require('../../config/license/hardware');var logger=require(_0xedaa('0x13'))(_0xedaa('0x14'));var utils=require(_0xedaa('0x15'));var config=require('../../config/environment');var licenseUtil=require(_0xedaa('0x16'));var db=require(_0xedaa('0x17'))['db'];var dbH=require('../../mysqldb')['dbH'];function respondWithStatusCode(_0x42ceb0,_0x46beaf){_0x46beaf=_0x46beaf||0xcc;return function(_0x1fc5d0){if(_0x1fc5d0){return _0x42ceb0[_0xedaa('0x18')](_0x46beaf);}return _0x42ceb0[_0xedaa('0x19')](_0x46beaf)['end']();};}function respondWithResult(_0x41d115,_0x1dd096){_0x1dd096=_0x1dd096||0xc8;return function(_0x6c99fa){if(_0x6c99fa){return _0x41d115['status'](_0x1dd096)['json'](_0x6c99fa);}};}function respondWithFilteredResult(_0x1017de,_0x597092){return function(_0x454be3){if(_0x454be3){var _0x18f340=_0x454be3[_0xedaa('0x1a')],_0x8cf030=_0x597092['offset'],_0x2dea2c=_0x597092['offset']+_0x597092[_0xedaa('0x1b')],_0x5bf518;if(_0x2dea2c>=_0x18f340){_0x2dea2c=_0x18f340;_0x5bf518=0xc8;}else{_0x5bf518=0xce;}_0x1017de[_0xedaa('0x19')](_0x5bf518);return _0x1017de['set'](_0xedaa('0x1c'),_0x8cf030+'-'+_0x2dea2c+'/'+_0x18f340)[_0xedaa('0x1d')](_0x454be3);}return null;};}function patchUpdates(_0x25af96){return function(_0x454e5a){try{jsonpatch[_0xedaa('0x1e')](_0x454e5a,_0x25af96,!![]);}catch(_0x29b0f2){return BPromise[_0xedaa('0x1f')](_0x29b0f2);}return _0x454e5a['save']();};}function saveUpdates(_0x25237e,_0x5b3338){return function(_0x4ccb4b){if(_0x4ccb4b){return _0x4ccb4b['update'](_0x25237e)[_0xedaa('0x20')](function(_0x5b9ebe){return _0x5b9ebe;});}return null;};}function removeEntity(_0x3afa02,_0x39c6c9){return function(_0x59cbe9){if(_0x59cbe9){return _0x59cbe9[_0xedaa('0x21')]()[_0xedaa('0x20')](function(){var _0x34892b=_0x59cbe9[_0xedaa('0x22')]({'plain':!![]});var _0x52f7f7=_0xedaa('0x23');return db[_0xedaa('0x24')]['destroy']({'where':{'type':_0x52f7f7,'resourceId':_0x34892b['id']}})[_0xedaa('0x20')](function(){return _0x59cbe9;});})['then'](function(){_0x3afa02['status'](0xcc)[_0xedaa('0x25')]();});}};}function handleEntityNotFound(_0x3fd21f,_0x4f44f0){return function(_0x22bc20){if(!_0x22bc20){_0x3fd21f[_0xedaa('0x18')](0x194);}return _0x22bc20;};}function handleError(_0x1e920e,_0x3bc1ad){_0x3bc1ad=_0x3bc1ad||0x1f4;return function(_0x2ad383){logger[_0xedaa('0x26')](_0x2ad383[_0xedaa('0x27')]);if(_0x2ad383[_0xedaa('0x28')]){delete _0x2ad383[_0xedaa('0x28')];}_0x1e920e[_0xedaa('0x19')](_0x3bc1ad)[_0xedaa('0x29')](_0x2ad383);};}exports[_0xedaa('0x2a')]=function(_0x1e9609,_0x14e99c){var _0x5408bf={},_0x1c88f5={},_0x437ad2={'count':0x0,'rows':[]};var _0x28ee0a=_[_0xedaa('0x2b')](db[_0xedaa('0x2c')][_0xedaa('0x2d')],function(_0x95f21c){return{'name':_0x95f21c['fieldName'],'type':_0x95f21c[_0xedaa('0x2e')]['key']};});_0x1c88f5['model']=_[_0xedaa('0x2b')](_0x28ee0a,_0xedaa('0x28'));_0x1c88f5[_0xedaa('0x2f')]=_[_0xedaa('0x30')](_0x1e9609[_0xedaa('0x2f')]);_0x1c88f5[_0xedaa('0x31')]=_[_0xedaa('0x32')](_0x1c88f5[_0xedaa('0x33')],_0x1c88f5[_0xedaa('0x2f')]);_0x5408bf[_0xedaa('0x34')]=_[_0xedaa('0x32')](_0x1c88f5[_0xedaa('0x33')],qs[_0xedaa('0x35')](_0x1e9609[_0xedaa('0x2f')]['fields']));_0x5408bf[_0xedaa('0x34')]=_0x5408bf[_0xedaa('0x34')]['length']?_0x5408bf[_0xedaa('0x34')]:_0x1c88f5['model'];if(!_0x1e9609[_0xedaa('0x2f')][_0xedaa('0x36')](_0xedaa('0x37'))){_0x5408bf['limit']=qs[_0xedaa('0x1b')](_0x1e9609[_0xedaa('0x2f')][_0xedaa('0x1b')]);_0x5408bf['offset']=qs[_0xedaa('0x38')](_0x1e9609[_0xedaa('0x2f')]['offset']);}_0x5408bf[_0xedaa('0x39')]=qs[_0xedaa('0x3a')](_0x1e9609[_0xedaa('0x2f')][_0xedaa('0x3a')]);_0x5408bf['where']=qs[_0xedaa('0x31')](_['pick'](_0x1e9609[_0xedaa('0x2f')],_0x1c88f5[_0xedaa('0x31')]),_0x28ee0a);if(_0x1e9609[_0xedaa('0x2f')][_0xedaa('0x3b')]){_0x5408bf[_0xedaa('0x3c')]=_[_0xedaa('0x3d')](_0x5408bf[_0xedaa('0x3c')],{'$or':_['map'](_0x28ee0a,function(_0x1a0123){if(_0x1a0123['type']!==_0xedaa('0x3e')){var _0x2b1b13={};_0x2b1b13[_0x1a0123[_0xedaa('0x28')]]={'$like':'%'+_0x1e9609[_0xedaa('0x2f')]['filter']+'%'};return _0x2b1b13;}})});}_0x5408bf=_[_0xedaa('0x3d')]({},_0x5408bf,_0x1e9609[_0xedaa('0x3f')]);var _0x4d4c30={'where':_0x5408bf['where']};return db[_0xedaa('0x2c')]['count'](_0x4d4c30)[_0xedaa('0x20')](function(_0xbc8cb1){_0x437ad2['count']=_0xbc8cb1;if(_0x1e9609[_0xedaa('0x2f')][_0xedaa('0x40')]){_0x5408bf[_0xedaa('0x41')]=[{'all':!![]}];}return db[_0xedaa('0x2c')]['findAll'](_0x5408bf);})[_0xedaa('0x20')](function(_0x407002){_0x437ad2[_0xedaa('0x42')]=_0x407002;return _0x437ad2;})['then'](respondWithFilteredResult(_0x14e99c,_0x5408bf))[_0xedaa('0x43')](handleError(_0x14e99c,null));};exports['show']=function(_0x31d0ac,_0x2092dc){var _0x1a90db={'raw':![],'where':{'id':_0x31d0ac['params']['id']}},_0x43d3a3={};_0x43d3a3[_0xedaa('0x33')]=_['keys'](db[_0xedaa('0x2c')][_0xedaa('0x2d')]);_0x43d3a3[_0xedaa('0x2f')]=_[_0xedaa('0x30')](_0x31d0ac[_0xedaa('0x2f')]);_0x43d3a3[_0xedaa('0x31')]=_[_0xedaa('0x32')](_0x43d3a3[_0xedaa('0x33')],_0x43d3a3[_0xedaa('0x2f')]);_0x1a90db[_0xedaa('0x34')]=_['intersection'](_0x43d3a3[_0xedaa('0x33')],qs[_0xedaa('0x35')](_0x31d0ac['query'][_0xedaa('0x35')]));_0x1a90db[_0xedaa('0x34')]=_0x1a90db[_0xedaa('0x34')]['length']?_0x1a90db[_0xedaa('0x34')]:_0x43d3a3['model'];if(_0x31d0ac['query']['includeAll']){_0x1a90db[_0xedaa('0x41')]=[{'all':!![]}];}_0x1a90db=_[_0xedaa('0x3d')]({},_0x1a90db,_0x31d0ac[_0xedaa('0x3f')]);return db[_0xedaa('0x2c')][_0xedaa('0x44')](_0x1a90db)['then'](handleEntityNotFound(_0x2092dc,null))[_0xedaa('0x20')](respondWithResult(_0x2092dc,null))[_0xedaa('0x43')](handleError(_0x2092dc,null));};exports['create']=function(_0x1929c7,_0x1ae28d){return db[_0xedaa('0x2c')][_0xedaa('0x45')](_0x1929c7[_0xedaa('0x46')],{})[_0xedaa('0x20')](function(_0x58bccf){var _0x50dbcf=_0x1929c7[_0xedaa('0x47')][_0xedaa('0x22')]({'plain':!![]});if(!_0x50dbcf)throw new Error('Unable\x20to\x20retrieve\x20the\x20current\x20user');if(_0x50dbcf[_0xedaa('0x48')]===_0xedaa('0x47')){var _0x29067f=_0x58bccf[_0xedaa('0x22')]({'plain':!![]});var _0x5bebbc=_0xedaa('0x49');return db[_0xedaa('0x4a')][_0xedaa('0x44')]({'where':{'name':_0x5bebbc,'userProfileId':_0x50dbcf[_0xedaa('0x4b')]},'raw':!![]})[_0xedaa('0x20')](function(_0x43bfc3){if(_0x43bfc3&&_0x43bfc3[_0xedaa('0x4c')]===0x0){return db[_0xedaa('0x24')][_0xedaa('0x45')]({'name':_0x29067f['name'],'resourceId':_0x29067f['id'],'type':_0xedaa('0x23'),'sectionId':_0x43bfc3['id']},{})[_0xedaa('0x20')](function(){return _0x58bccf;});}else{return _0x58bccf;}})[_0xedaa('0x43')](function(_0x4ef492){logger[_0xedaa('0x26')]('Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s',_0x4ef492);throw _0x4ef492;});}return _0x58bccf;})[_0xedaa('0x20')](respondWithResult(_0x1ae28d,0xc9))[_0xedaa('0x43')](handleError(_0x1ae28d,null));};exports[_0xedaa('0x4d')]=function(_0x540140,_0x217a48){if(_0x540140['body']['id']){delete _0x540140['body']['id'];}return db[_0xedaa('0x2c')][_0xedaa('0x44')]({'where':{'id':_0x540140['params']['id']}})['then'](handleEntityNotFound(_0x217a48,null))['then'](saveUpdates(_0x540140[_0xedaa('0x46')],null))[_0xedaa('0x20')](respondWithResult(_0x217a48,null))[_0xedaa('0x43')](handleError(_0x217a48,null));};exports['destroy']=function(_0x3cb762,_0x212e83){return db[_0xedaa('0x2c')][_0xedaa('0x44')]({'where':{'id':_0x3cb762['params']['id']}})[_0xedaa('0x20')](handleEntityNotFound(_0x212e83,null))['then'](removeEntity(_0x212e83,null))[_0xedaa('0x43')](handleError(_0x212e83,null));};exports[_0xedaa('0x4e')]=function(_0x4e053e,_0x7a08c1){var _0x29fd60=0xa;var _0x47267a=[_0xedaa('0x4f'),'left_join','right_join','cross_join'];var _0x2d55b7={'SUM':_0xedaa('0x50'),'COUNT':_0xedaa('0x51'),'COUNT DISTINCT':'COUNT(DISTINCT\x20%s)','MAX':_0xedaa('0x52'),'MIN':'MIN(%s)','AVG':_0xedaa('0x53'),'GROUP_CONCAT':_0xedaa('0x54'),'GROUP_CONCAT ASC':_0xedaa('0x55'),'GROUP_CONCAT DESC':_0xedaa('0x56')};var _0x2dcc0f={'SEC_TO_TIME':_0xedaa('0x57'),'DATE':'DATE(%s)','HOUR':'HOUR(%s)','ROUND':_0xedaa('0x58'),'UNIX_TIMESTAMP':_0xedaa('0x59')};var _0x181627=function(_0x5c512d){return!_[_0xedaa('0x5a')]([_0xedaa('0x5b'),_0xedaa('0x5c'),_0xedaa('0x5d'),_0xedaa('0x5e')],_0x5c512d);};var _0x1cf73a=function(_0x2b7909){if(!_0x2b7909||!_0x2b7909[_0xedaa('0x5f')]['length']){return'';}for(var _0xf3b1a4='(',_0xa22bd6=0x0;_0xa22bd6<_0x2b7909[_0xedaa('0x5f')]['length'];_0xa22bd6+=0x1){_0xa22bd6>0x0&&(_0xf3b1a4+='\x20'+_0x2b7909[_0xedaa('0x60')]+'\x20');_0xf3b1a4+=_0x2b7909[_0xedaa('0x5f')][_0xa22bd6][_0xedaa('0x61')]?_0x1cf73a(_0x2b7909[_0xedaa('0x5f')][_0xa22bd6][_0xedaa('0x61')]):_0x2b7909['rules'][_0xa22bd6][_0xedaa('0x62')]+'\x20'+_0x2b7909[_0xedaa('0x5f')][_0xa22bd6][_0xedaa('0x63')]+(_0x181627(_0x2b7909[_0xedaa('0x5f')][_0xa22bd6][_0xedaa('0x63')])?'\x20'+_0x2b7909[_0xedaa('0x5f')][_0xa22bd6][_0xedaa('0x64')]:'');}return _0xf3b1a4+')';};var _0x4588bb={'where':{'id':_0x4e053e['params']['id']}},_0x33642b,_0x23cf4c,_0x2bc87c,_0x43325f,_0x510a0a;_0x4588bb=_[_0xedaa('0x3d')]({},_0x4588bb,_0x4e053e[_0xedaa('0x3f')]);return db['AnalyticCustomReport']['find'](_0x4588bb)[_0xedaa('0x20')](function(_0x81f5fd){if(_0x81f5fd){_0x33642b=_0x81f5fd;return _0x81f5fd[_0xedaa('0x65')]();}return null;})[_0xedaa('0x20')](function(_0x395221){if(_0x395221){if(!_0x395221['length']){throw new db[(_0xedaa('0x66'))][(_0xedaa('0x67'))](_0xedaa('0x68'),0x193);}_0x23cf4c=_0x395221;return db[_0xedaa('0x69')]['findAll']({'raw':!![]});}return null;})[_0xedaa('0x20')](function(_0x4f69c4){if(_0x4f69c4){_0x2bc87c=_[_0xedaa('0x6a')](_0x4f69c4,'id');var _0x3600cd;var _0x2a3d78=squel[_0xedaa('0x6b')]();_0x2a3d78[_0xedaa('0x6c')](_0x33642b[_0xedaa('0x6d')]);for(var _0x319c55=0x0;_0x319c55<_0x23cf4c['length'];_0x319c55+=0x1){_0x3600cd=_0x23cf4c[_0x319c55][_0xedaa('0x6e')]?_0x2bc87c[_0x23cf4c[_0x319c55][_0xedaa('0x6e')]]['metric']:_0x23cf4c[_0x319c55]['field'];_0x3600cd=_0x23cf4c[_0x319c55][_0xedaa('0x6f')]?_[_0xedaa('0x70')](_0x2d55b7[_0x23cf4c[_0x319c55]['function']],'%s',_0x3600cd):_0x3600cd;_0x3600cd=_0x23cf4c[_0x319c55][_0xedaa('0x71')]?_[_0xedaa('0x70')](_0x2dcc0f[_0x23cf4c[_0x319c55][_0xedaa('0x71')]],'%s',_0x3600cd):_0x3600cd;if(_0x23cf4c[_0x319c55]['groupBy']){_0x2a3d78['group'](_0x3600cd);}_0x23cf4c[_0x319c55][_0xedaa('0x72')]&&_0x2a3d78['order'](_0x3600cd,_0x23cf4c[_0x319c55][_0xedaa('0x72')]===_0xedaa('0x73')?![]:!![]);_0x2a3d78[_0xedaa('0x62')](_0x3600cd,_0x23cf4c[_0x319c55][_0xedaa('0x74')]||_0x3600cd);}if(_0x33642b[_0xedaa('0x75')]){_0x33642b[_0xedaa('0x75')]=JSON[_0xedaa('0x76')](_0x33642b['joins']);for(var _0x36e893=0x0;_0x36e893<_0x33642b[_0xedaa('0x75')]['length'];_0x36e893+=0x1){if(_0x33642b[_0xedaa('0x75')][_0x36e893]['type']&&_[_0xedaa('0x5a')](_0x47267a,_0x33642b['joins'][_0x36e893][_0xedaa('0x2e')])&&_0x33642b[_0xedaa('0x75')][_0x36e893][_0xedaa('0x77')]&&_0x33642b[_0xedaa('0x75')][_0x36e893][_0xedaa('0x78')]&&_0x33642b[_0xedaa('0x75')][_0x36e893][_0xedaa('0x79')]){_0x2a3d78[_0x33642b[_0xedaa('0x75')][_0x36e893][_0xedaa('0x2e')]](_0x33642b[_0xedaa('0x75')][_0x36e893][_0xedaa('0x78')],null,util[_0xedaa('0x71')](_0xedaa('0x7a'),_0x33642b['table'],_0x33642b[_0xedaa('0x75')][_0x36e893][_0xedaa('0x77')],_0x33642b[_0xedaa('0x75')][_0x36e893]['foreignTable'],_0x33642b[_0xedaa('0x75')][_0x36e893]['foreignKey']));}}}if(_0x33642b[_0xedaa('0x7b')]){_0x33642b['conditions']=JSON['parse'](_0x33642b['conditions']);_0x2a3d78['where'](_0x1cf73a(_0x33642b[_0xedaa('0x7b')][_0xedaa('0x61')]));}_0x510a0a=_0x2a3d78[_0xedaa('0x7c')]();_0x2a3d78['limit'](_0x29fd60);_0x2a3d78[_0xedaa('0x38')](0x0);logger[_0xedaa('0x7d')](_0xedaa('0x7e'),_0x2a3d78['toString']());return db['sequelize']['query'](_0x2a3d78[_0xedaa('0x7f')](),{'type':db[_0xedaa('0x80')]['QueryTypes'][_0xedaa('0x81')]});}})[_0xedaa('0x20')](respondWithResult(_0x7a08c1,null))[_0xedaa('0x43')](handleError(_0x7a08c1,null));};function runReport(_0x3c0185,_0x12cf17,_0x330b5a){var _0x37d1a4=_0x12cf17[_0xedaa('0x28')];var _0xf8a1dd=0xa;var _0x9e78ba=[_0xedaa('0x4f'),_0xedaa('0x82'),_0xedaa('0x83'),_0xedaa('0x84')];var _0x220910={'SUM':'SUM(%s)','COUNT':_0xedaa('0x51'),'COUNT DISTINCT':_0xedaa('0x85'),'MAX':_0xedaa('0x52'),'MIN':_0xedaa('0x86'),'AVG':_0xedaa('0x53'),'GROUP_CONCAT':_0xedaa('0x54'),'GROUP_CONCAT ASC':_0xedaa('0x55'),'GROUP_CONCAT DESC':_0xedaa('0x56')};var _0x5a7ccc={'SEC_TO_TIME':_0xedaa('0x57'),'DATE':_0xedaa('0x87'),'HOUR':'HOUR(%s)','ROUND':_0xedaa('0x58'),'UNIX_TIMESTAMP':_0xedaa('0x59')};var _0x5c4ff7=function(_0x2c6a21){return!_[_0xedaa('0x5a')]([_0xedaa('0x5b'),_0xedaa('0x5c'),_0xedaa('0x5d'),_0xedaa('0x5e')],_0x2c6a21);};var _0x203446=function(_0x117d48){if(!_0x117d48||!_0x117d48['rules']['length']){return'';}for(var _0x22a2eb='(',_0x188ff1=0x0;_0x188ff1<_0x117d48['rules'][_0xedaa('0x88')];_0x188ff1+=0x1){_0x188ff1>0x0&&(_0x22a2eb+='\x20'+_0x117d48[_0xedaa('0x60')]+'\x20');_0x22a2eb+=_0x117d48[_0xedaa('0x5f')][_0x188ff1][_0xedaa('0x61')]?_0x203446(_0x117d48[_0xedaa('0x5f')][_0x188ff1][_0xedaa('0x61')]):_0x117d48[_0xedaa('0x5f')][_0x188ff1][_0xedaa('0x62')]+'\x20'+_0x117d48[_0xedaa('0x5f')][_0x188ff1]['condition']+(_0x5c4ff7(_0x117d48[_0xedaa('0x5f')][_0x188ff1][_0xedaa('0x63')])?'\x20'+_0x117d48[_0xedaa('0x5f')][_0x188ff1][_0xedaa('0x64')]:'');}return _0x22a2eb+')';};var _0x3c7e38={'where':{'id':_0x3c0185['id']}},_0x1c750a,_0x28fe11,_0x35922e,_0x42d57d,_0x2a613e;_0x3c7e38=_[_0xedaa('0x3d')]({},_0x3c7e38,_0x330b5a);return db['AnalyticCustomReport'][_0xedaa('0x44')](_0x3c7e38)[_0xedaa('0x20')](function(_0x35c040){if(_0x35c040){_0x1c750a=_0x35c040;return _0x35c040[_0xedaa('0x65')]();}return null;})[_0xedaa('0x20')](function(_0x233ee2){if(_0x233ee2){if(!_0x233ee2[_0xedaa('0x88')]){throw new db[(_0xedaa('0x66'))][(_0xedaa('0x67'))](_0xedaa('0x68'),0x193);}_0x28fe11=_0x233ee2;return db['AnalyticMetric']['findAll']({'raw':!![]});}return null;})[_0xedaa('0x20')](function(_0x1197ff){if(_0x1197ff){_0x35922e=_[_0xedaa('0x6a')](_0x1197ff,'id');var _0x1b60f1;var _0x2bf516=squel['select']();_0x2bf516['from'](_0x1c750a[_0xedaa('0x6d')]);for(var _0x5cdd3b=0x0;_0x5cdd3b<_0x28fe11[_0xedaa('0x88')];_0x5cdd3b+=0x1){_0x1b60f1=_0x28fe11[_0x5cdd3b][_0xedaa('0x6e')]?_0x35922e[_0x28fe11[_0x5cdd3b][_0xedaa('0x6e')]][_0xedaa('0x89')]:_0x28fe11[_0x5cdd3b][_0xedaa('0x62')];_0x1b60f1=_0x28fe11[_0x5cdd3b]['function']?_[_0xedaa('0x70')](_0x220910[_0x28fe11[_0x5cdd3b][_0xedaa('0x6f')]],'%s',_0x1b60f1):_0x1b60f1;_0x1b60f1=_0x28fe11[_0x5cdd3b][_0xedaa('0x71')]?_['replace'](_0x5a7ccc[_0x28fe11[_0x5cdd3b][_0xedaa('0x71')]],'%s',_0x1b60f1):_0x1b60f1;if(_0x28fe11[_0x5cdd3b][_0xedaa('0x8a')]){_0x2bf516[_0xedaa('0x61')](_0x1b60f1);}_0x28fe11[_0x5cdd3b][_0xedaa('0x72')]&&_0x2bf516['order'](_0x1b60f1,_0x28fe11[_0x5cdd3b][_0xedaa('0x72')]===_0xedaa('0x73')?![]:!![]);_0x2bf516[_0xedaa('0x62')](_0x1b60f1,_0x28fe11[_0x5cdd3b][_0xedaa('0x74')]||_0x1b60f1);}if(_0x1c750a['joins']){_0x1c750a[_0xedaa('0x75')]=JSON[_0xedaa('0x76')](_0x1c750a['joins']);for(var _0x3bb784=0x0;_0x3bb784<_0x1c750a[_0xedaa('0x75')][_0xedaa('0x88')];_0x3bb784+=0x1){if(_0x1c750a['joins'][_0x3bb784][_0xedaa('0x2e')]&&_['includes'](_0x9e78ba,_0x1c750a['joins'][_0x3bb784]['type'])&&_0x1c750a[_0xedaa('0x75')][_0x3bb784][_0xedaa('0x77')]&&_0x1c750a[_0xedaa('0x75')][_0x3bb784][_0xedaa('0x78')]&&_0x1c750a[_0xedaa('0x75')][_0x3bb784]['foreignKey']){_0x2bf516[_0x1c750a[_0xedaa('0x75')][_0x3bb784][_0xedaa('0x2e')]](_0x1c750a[_0xedaa('0x75')][_0x3bb784]['foreignTable'],null,util[_0xedaa('0x71')](_0xedaa('0x7a'),_0x1c750a[_0xedaa('0x6d')],_0x1c750a[_0xedaa('0x75')][_0x3bb784][_0xedaa('0x77')],_0x1c750a[_0xedaa('0x75')][_0x3bb784][_0xedaa('0x78')],_0x1c750a[_0xedaa('0x75')][_0x3bb784][_0xedaa('0x79')]));}}}if(_0x1c750a['conditions']){_0x1c750a[_0xedaa('0x7b')]=JSON[_0xedaa('0x76')](_0x1c750a[_0xedaa('0x7b')]);_0x2bf516['where'](_0x203446(_0x1c750a[_0xedaa('0x7b')][_0xedaa('0x61')]));}_0x2a613e=_0x2bf516[_0xedaa('0x7c')]();_0x2bf516['limit'](_0xf8a1dd);_0x2bf516[_0xedaa('0x38')](0x0);logger['debug'](_0xedaa('0x7e'),_0x2bf516[_0xedaa('0x7f')]());return db['sequelize']['query'](_0x2bf516['toString'](),{'type':db[_0xedaa('0x80')]['QueryTypes'][_0xedaa('0x81')]});}})[_0xedaa('0x20')](function(_0x5e6fd9){if(!_0x5e6fd9[_0xedaa('0x88')]){throw new db[(_0xedaa('0x66'))][(_0xedaa('0x67'))](_0xedaa('0x8b'),0xcc);}if(_0x12cf17[_0xedaa('0x8c')]===_0xedaa('0x8d')){return null;}var _0x170587=_[_0xedaa('0x3d')](_0x12cf17,{'name':_0x12cf17[_0xedaa('0x8e')]||_0x12cf17['name']||_0x1c750a[_0xedaa('0x28')],'basename':_0x37d1a4,'savename':util[_0xedaa('0x71')]('%s-%s.%s',_0x12cf17[_0xedaa('0x28')]||_0x1c750a[_0xedaa('0x28')],require('randomstring')[_0xedaa('0x8f')](0x4),_0x12cf17[_0xedaa('0x8c')]||_0xedaa('0x90')),'reportId':_0x1c750a['id'],'reportType':_0xedaa('0x91')});return db[_0xedaa('0x92')]['create'](_0x170587,{'raw':!![]});})['then'](function(_0x3ae9f1){if(_0x1c750a[_0xedaa('0x6d')]==='cdr'){_0x2a613e[_0xedaa('0x3c')](_0x1c750a[_0xedaa('0x6d')]+_0xedaa('0x93'),_0x12cf17['startDate'],_0x12cf17[_0xedaa('0x94')]);}else{_0x2a613e[_0xedaa('0x3c')](_0x1c750a[_0xedaa('0x6d')]+'.createdAt\x20BETWEEN\x20?\x20AND\x20?',_0x12cf17['startDate'],_0x12cf17[_0xedaa('0x94')]);}if(_0x3ae9f1){logger[_0xedaa('0x95')]('Run\x20Query:',_0x2a613e[_0xedaa('0x7f')]());require('child_process')[_0xedaa('0x96')](path[_0xedaa('0x4f')](__dirname,'../../components/export/',_0x3ae9f1['output']),[_0x3ae9f1['id'],_0x2a613e[_0xedaa('0x7f')](),path['join'](__dirname,'../../files/reports',_0x3ae9f1['savename']),_0x37d1a4]);return _0x3ae9f1;}else{var _0x5b15e1=squel['select']();_0x5b15e1[_0xedaa('0x6c')]('('+_0x2a613e[_0xedaa('0x7f')]()+')',_0xedaa('0x97'));_0x5b15e1[_0xedaa('0x62')](_0xedaa('0x98'),'count');_0x2a613e[_0xedaa('0x1b')](_0x12cf17[_0xedaa('0x1b')]||_0xf8a1dd);_0x2a613e['offset'](_0x12cf17['offset']||0x0);return dbH[_0xedaa('0x80')][_0xedaa('0x2f')](_0x5b15e1['toString'](),{'type':dbH[_0xedaa('0x80')][_0xedaa('0x99')][_0xedaa('0x81')]})[_0xedaa('0x20')](function(_0x30d98d){if(!_0x30d98d[_0xedaa('0x88')]){_0x42d57d=0x0;}else{_0x42d57d=_0x30d98d[0x0][_0xedaa('0x1a')]||0x0;}return dbH[_0xedaa('0x80')][_0xedaa('0x2f')](_0x2a613e[_0xedaa('0x7f')](),{'type':dbH['sequelize'][_0xedaa('0x99')]['SELECT']});})[_0xedaa('0x20')](function(_0x14ae39){return{'rows':_0x14ae39||[],'count':_0x42d57d};});}});}exports[_0xedaa('0x9a')]=function(_0x2febd8,_0x5e69d2){return runReport(_0x2febd8[_0xedaa('0x9b')],_0x2febd8[_0xedaa('0x2f')],_0x2febd8[_0xedaa('0x3f')])[_0xedaa('0x20')](respondWithResult(_0x5e69d2,null))[_0xedaa('0x43')](handleError(_0x5e69d2,null));};exports[_0xedaa('0x9c')]=runReport;exports[_0xedaa('0x2f')]=function(_0x394f47,_0xbc280b){var _0x1f5cc3=0xa;var _0x216f6c=[_0xedaa('0x4f'),'left_join','right_join',_0xedaa('0x84')];var _0x22f0b3={'SUM':'SUM(%s)','COUNT':_0xedaa('0x51'),'COUNT DISTINCT':'COUNT(DISTINCT\x20%s)','MAX':_0xedaa('0x52'),'MIN':_0xedaa('0x86'),'AVG':_0xedaa('0x53'),'GROUP_CONCAT':_0xedaa('0x54'),'GROUP_CONCAT ASC':_0xedaa('0x55'),'GROUP_CONCAT DESC':_0xedaa('0x56')};var _0x35d3fd={'SEC_TO_TIME':'SEC_TO_TIME(%s)','DATE':_0xedaa('0x87'),'HOUR':'HOUR(%s)','ROUND':'ROUND(%s)','UNIX_TIMESTAMP':_0xedaa('0x59')};var _0xf10f9=function(_0xde5d8d){return!_[_0xedaa('0x5a')]([_0xedaa('0x5b'),'IS\x20NOT\x20NULL',_0xedaa('0x5d'),_0xedaa('0x5e')],_0xde5d8d);};var _0x4a15cb=function(_0x119809){if(!_0x119809||!_0x119809[_0xedaa('0x5f')][_0xedaa('0x88')]){return'';}for(var _0x236bf9='(',_0x195098=0x0;_0x195098<_0x119809[_0xedaa('0x5f')][_0xedaa('0x88')];_0x195098+=0x1){_0x195098>0x0&&(_0x236bf9+='\x20'+_0x119809['operator']+'\x20');_0x236bf9+=_0x119809[_0xedaa('0x5f')][_0x195098][_0xedaa('0x61')]?_0x4a15cb(_0x119809[_0xedaa('0x5f')][_0x195098][_0xedaa('0x61')]):_0x119809[_0xedaa('0x5f')][_0x195098]['field']+'\x20'+_0x119809['rules'][_0x195098][_0xedaa('0x63')]+(_0xf10f9(_0x119809[_0xedaa('0x5f')][_0x195098][_0xedaa('0x63')])?'\x20'+_0x119809[_0xedaa('0x5f')][_0x195098][_0xedaa('0x64')]:'');}return _0x236bf9+')';};var _0x3f3174={'where':{'id':_0x394f47[_0xedaa('0x9b')]['id']}},_0x364e54,_0x1d43fb,_0x2354b3,_0x197fd8,_0x26d43f;_0x3f3174=_[_0xedaa('0x3d')]({},_0x3f3174,_0x394f47['options']);return db[_0xedaa('0x2c')]['find'](_0x3f3174)[_0xedaa('0x20')](function(_0x5c43e3){if(_0x5c43e3){_0x364e54=_0x5c43e3;return _0x5c43e3[_0xedaa('0x65')]();}return null;})['then'](function(_0x563720){if(_0x563720){if(!_0x563720['length']){throw new db[(_0xedaa('0x66'))][(_0xedaa('0x67'))]('Please\x20insert\x20at\x20least\x20one\x20field',0x193);}_0x1d43fb=_0x563720;return db[_0xedaa('0x69')][_0xedaa('0x9d')]({'raw':!![]});}return null;})[_0xedaa('0x20')](function(_0x36699c){if(_0x36699c){_0x2354b3=_[_0xedaa('0x6a')](_0x36699c,'id');var _0x3b913c;var _0x190bce=squel['select']();_0x190bce['from'](_0x364e54[_0xedaa('0x6d')]);for(var _0x474fa2=0x0;_0x474fa2<_0x1d43fb[_0xedaa('0x88')];_0x474fa2+=0x1){_0x3b913c=_0x1d43fb[_0x474fa2][_0xedaa('0x6e')]?_0x2354b3[_0x1d43fb[_0x474fa2][_0xedaa('0x6e')]][_0xedaa('0x89')]:_0x1d43fb[_0x474fa2][_0xedaa('0x62')];_0x3b913c=_0x1d43fb[_0x474fa2][_0xedaa('0x6f')]?_[_0xedaa('0x70')](_0x22f0b3[_0x1d43fb[_0x474fa2][_0xedaa('0x6f')]],'%s',_0x3b913c):_0x3b913c;_0x3b913c=_0x1d43fb[_0x474fa2][_0xedaa('0x71')]?_[_0xedaa('0x70')](_0x35d3fd[_0x1d43fb[_0x474fa2][_0xedaa('0x71')]],'%s',_0x3b913c):_0x3b913c;if(_0x1d43fb[_0x474fa2][_0xedaa('0x8a')]){_0x190bce[_0xedaa('0x61')](_0x3b913c);}_0x1d43fb[_0x474fa2][_0xedaa('0x72')]&&_0x190bce[_0xedaa('0x39')](_0x3b913c,_0x1d43fb[_0x474fa2]['orderBy']===_0xedaa('0x73')?![]:!![]);_0x190bce[_0xedaa('0x62')](_0x3b913c,_0x1d43fb[_0x474fa2][_0xedaa('0x74')]||_0x3b913c);}if(_0x364e54[_0xedaa('0x75')]){_0x364e54[_0xedaa('0x75')]=JSON[_0xedaa('0x76')](_0x364e54[_0xedaa('0x75')]);for(var _0x53232a=0x0;_0x53232a<_0x364e54[_0xedaa('0x75')][_0xedaa('0x88')];_0x53232a+=0x1){if(_0x364e54[_0xedaa('0x75')][_0x53232a][_0xedaa('0x2e')]&&_[_0xedaa('0x5a')](_0x216f6c,_0x364e54['joins'][_0x53232a][_0xedaa('0x2e')])&&_0x364e54['joins'][_0x53232a][_0xedaa('0x77')]&&_0x364e54['joins'][_0x53232a]['foreignTable']&&_0x364e54['joins'][_0x53232a][_0xedaa('0x79')]){_0x190bce[_0x364e54['joins'][_0x53232a][_0xedaa('0x2e')]](_0x364e54[_0xedaa('0x75')][_0x53232a][_0xedaa('0x78')],null,util[_0xedaa('0x71')](_0xedaa('0x7a'),_0x364e54[_0xedaa('0x6d')],_0x364e54[_0xedaa('0x75')][_0x53232a][_0xedaa('0x77')],_0x364e54[_0xedaa('0x75')][_0x53232a][_0xedaa('0x78')],_0x364e54[_0xedaa('0x75')][_0x53232a][_0xedaa('0x79')]));}}}if(_0x364e54[_0xedaa('0x7b')]){_0x364e54['conditions']=JSON[_0xedaa('0x76')](_0x364e54[_0xedaa('0x7b')]);_0x190bce[_0xedaa('0x3c')](_0x4a15cb(_0x364e54[_0xedaa('0x7b')]['group']));}_0x26d43f=_0x190bce[_0xedaa('0x7c')]();_0x190bce['limit'](_0x1f5cc3);_0x190bce[_0xedaa('0x38')](0x0);logger[_0xedaa('0x7d')]('Limited\x20Query:',_0x190bce['toString']());return db[_0xedaa('0x80')][_0xedaa('0x2f')](_0x190bce['toString'](),{'type':db[_0xedaa('0x80')][_0xedaa('0x99')][_0xedaa('0x81')]});}})[_0xedaa('0x20')](function(){return{'sql':_0x26d43f[_0xedaa('0x7f')]()};})[_0xedaa('0x20')](respondWithResult(_0xbc280b,null))[_0xedaa('0x43')](handleError(_0xbc280b,null));};