Built motion from commit (unavailable).|2.4.19
[motion2.git] / server / api / analyticDefaultReport / analyticDefaultReport.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 _0x9642=['.calldate\x20BETWEEN\x20?\x20AND\x20?','endDate','.createdAt\x20BETWEEN\x20?\x20AND\x20?','info','../../components/export/','../../files/reports','savename','COUNT(*)','run','html-pdf','eml-format','request-promise','moment','bluebird','mustache','util','path','to-csv','lodash','squel','crypto','jsforce','desk.js','querystring','papaparse','ioredis','../../components/parsers/advancedSearch','../../config/license/hardware','../../config/logger','api','../../mysqldb','status','end','json','offset','limit','Content-Range','apply','reject','save','update','destroy','then','get','UserProfileResource','sendStatus','error','stack','name','send','index','map','fieldName','type','key','model','query','keys','filters','intersection','attributes','fields','hasOwnProperty','nolimit','sort','where','filter','merge','VIRTUAL','AnalyticDefaultReport','count','includeAll','include','findAll','rows','catch','show','params','rawAttributes','length','options','find','create','body','user','Unable\x20to\x20retrieve\x20the\x20current\x20user','role','Reports','UserProfileSection','userProfileId','Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s','preview','join','left_join','right_join','cross_join','SUM(%s)','COUNT(%s)','COUNT(DISTINCT\x20%s)','MAX(%s)','MIN(%s)','AVG(%s)','GROUP_CONCAT(%s)','GROUP_CONCAT(%s\x20ORDER\x20BY\x20%s\x20DESC)','SEC_TO_TIME(%s)','DATE(%s)','HOUR(%s)','ROUND(%s)','UNIX_TIMESTAMP(%s)','IS\x20NULL','IS\x20NOT\x20NULL','IS\x20EMPTY','IS\x20NOT\x20EMPTY','rules','operator','group','field','condition','value','getFields','Sequelize','Please\x20insert\x20at\x20least\x20one\x20field','AnalyticMetric','select','from','table','MetricId','metric','function','format','orderBy','DESC','joins','includes','foreignTable','foreignKey','%s.%s\x20=\x20%s.%s','parentKey','conditions','clone','debug','Limited\x20Query:','sequelize','toString','SELECT','GROUP_CONCAT(%s\x20ORDER\x20BY\x20%s\x20ASC)','ValidationErrorItem','keyBy','replace','groupBy','order','alias','parse','No\x20available\x20data','output','fullPath','randomstring','generate','csv','default','AnalyticExtractedReport'];(function(_0x58a984,_0xb993e8){var _0x25dd32=function(_0x9c9ef4){while(--_0x9c9ef4){_0x58a984['push'](_0x58a984['shift']());}};_0x25dd32(++_0xb993e8);}(_0x9642,0x14b));var _0x2964=function(_0x1964ce,_0x3bb1dc){_0x1964ce=_0x1964ce-0x0;var _0xc7902f=_0x9642[_0x1964ce];return _0xc7902f;};'use strict';var pdf=require(_0x2964('0x0'));var emlformat=require(_0x2964('0x1'));var rimraf=require('rimraf');var zipdir=require('zip-dir');var jsonpatch=require('fast-json-patch');var rp=require(_0x2964('0x2'));var moment=require(_0x2964('0x3'));var BPromise=require(_0x2964('0x4'));var Mustache=require(_0x2964('0x5'));var util=require(_0x2964('0x6'));var path=require(_0x2964('0x7'));var sox=require('sox');var csv=require(_0x2964('0x8'));var ejs=require('ejs');var fs=require('fs');var _=require(_0x2964('0x9'));var squel=require(_0x2964('0xa'));var crypto=require(_0x2964('0xb'));var jsforce=require(_0x2964('0xc'));var deskjs=require(_0x2964('0xd'));var toCsv=require(_0x2964('0x8'));var querystring=require(_0x2964('0xe'));var Papa=require(_0x2964('0xf'));var Redis=require(_0x2964('0x10'));var authService=require('../../components/auth/service');var qs=require('../../components/parsers/qs');var as=require(_0x2964('0x11'));var hardwareService=require(_0x2964('0x12'));var logger=require(_0x2964('0x13'))(_0x2964('0x14'));var utils=require('../../config/utils');var config=require('../../config/environment');var db=require(_0x2964('0x15'))['db'];function respondWithStatusCode(_0x3c5e1e,_0x24df7a){_0x24df7a=_0x24df7a||0xcc;return function(_0x47b2aa){if(_0x47b2aa){return _0x3c5e1e['sendStatus'](_0x24df7a);}return _0x3c5e1e[_0x2964('0x16')](_0x24df7a)[_0x2964('0x17')]();};}function respondWithResult(_0x5a8d11,_0x323ce9){_0x323ce9=_0x323ce9||0xc8;return function(_0x43d14b){if(_0x43d14b){return _0x5a8d11[_0x2964('0x16')](_0x323ce9)[_0x2964('0x18')](_0x43d14b);}};}function respondWithFilteredResult(_0x24f6c3,_0x384dbf){return function(_0x4aefdc){if(_0x4aefdc){var _0x2cd6c3=_0x4aefdc['count'],_0x4d8d82=_0x384dbf[_0x2964('0x19')],_0x536b96=_0x384dbf[_0x2964('0x19')]+_0x384dbf[_0x2964('0x1a')],_0x37e1bb;if(_0x536b96>=_0x2cd6c3){_0x536b96=_0x2cd6c3;_0x37e1bb=0xc8;}else{_0x37e1bb=0xce;}_0x24f6c3[_0x2964('0x16')](_0x37e1bb);return _0x24f6c3['set'](_0x2964('0x1b'),_0x4d8d82+'-'+_0x536b96+'/'+_0x2cd6c3)[_0x2964('0x18')](_0x4aefdc);}return null;};}function patchUpdates(_0x4ad454){return function(_0x5009f3){try{jsonpatch[_0x2964('0x1c')](_0x5009f3,_0x4ad454,!![]);}catch(_0x40c5ad){return BPromise[_0x2964('0x1d')](_0x40c5ad);}return _0x5009f3[_0x2964('0x1e')]();};}function saveUpdates(_0x3d252e,_0x5dda55){return function(_0x273323){if(_0x273323){return _0x273323[_0x2964('0x1f')](_0x3d252e)['then'](function(_0x278cee){return _0x278cee;});}return null;};}function removeEntity(_0x5569a9,_0x1c672d){return function(_0x106491){if(_0x106491){return _0x106491[_0x2964('0x20')]()[_0x2964('0x21')](function(){var _0x363e85=_0x106491[_0x2964('0x22')]({'plain':!![]});var _0x5af029='DefaultReports';return db[_0x2964('0x23')]['destroy']({'where':{'type':_0x5af029,'resourceId':_0x363e85['id']}})[_0x2964('0x21')](function(){return _0x106491;});})[_0x2964('0x21')](function(){_0x5569a9['status'](0xcc)['end']();});}};}function handleEntityNotFound(_0x48e46a,_0x4834fa){return function(_0x3fff49){if(!_0x3fff49){_0x48e46a[_0x2964('0x24')](0x194);}return _0x3fff49;};}function handleError(_0x1c0526,_0x3fccfa){_0x3fccfa=_0x3fccfa||0x1f4;return function(_0x293196){logger[_0x2964('0x25')](_0x293196[_0x2964('0x26')]);if(_0x293196[_0x2964('0x27')]){delete _0x293196[_0x2964('0x27')];}_0x1c0526[_0x2964('0x16')](_0x3fccfa)[_0x2964('0x28')](_0x293196);};}exports[_0x2964('0x29')]=function(_0x11fd19,_0x125eb1){var _0x19c8ef={},_0x36c949={},_0x13ade4={'count':0x0,'rows':[]};var _0x4fe5ea=_[_0x2964('0x2a')](db['AnalyticDefaultReport']['rawAttributes'],function(_0x35deb0){return{'name':_0x35deb0[_0x2964('0x2b')],'type':_0x35deb0[_0x2964('0x2c')][_0x2964('0x2d')]};});_0x36c949[_0x2964('0x2e')]=_['map'](_0x4fe5ea,_0x2964('0x27'));_0x36c949[_0x2964('0x2f')]=_[_0x2964('0x30')](_0x11fd19[_0x2964('0x2f')]);_0x36c949[_0x2964('0x31')]=_[_0x2964('0x32')](_0x36c949[_0x2964('0x2e')],_0x36c949[_0x2964('0x2f')]);_0x19c8ef[_0x2964('0x33')]=_[_0x2964('0x32')](_0x36c949[_0x2964('0x2e')],qs[_0x2964('0x34')](_0x11fd19[_0x2964('0x2f')][_0x2964('0x34')]));_0x19c8ef[_0x2964('0x33')]=_0x19c8ef[_0x2964('0x33')]['length']?_0x19c8ef[_0x2964('0x33')]:_0x36c949[_0x2964('0x2e')];if(!_0x11fd19['query'][_0x2964('0x35')](_0x2964('0x36'))){_0x19c8ef['limit']=qs[_0x2964('0x1a')](_0x11fd19[_0x2964('0x2f')]['limit']);_0x19c8ef['offset']=qs[_0x2964('0x19')](_0x11fd19[_0x2964('0x2f')][_0x2964('0x19')]);}_0x19c8ef['order']=qs['sort'](_0x11fd19[_0x2964('0x2f')][_0x2964('0x37')]);_0x19c8ef[_0x2964('0x38')]=qs[_0x2964('0x31')](_['pick'](_0x11fd19[_0x2964('0x2f')],_0x36c949[_0x2964('0x31')]));if(_0x11fd19[_0x2964('0x2f')][_0x2964('0x39')]){_0x19c8ef[_0x2964('0x38')]=_[_0x2964('0x3a')](_0x19c8ef[_0x2964('0x38')],{'$or':_[_0x2964('0x2a')](_0x4fe5ea,function(_0x23420e){if(_0x23420e[_0x2964('0x2c')]!==_0x2964('0x3b')){var _0x21f91f={};_0x21f91f[_0x23420e[_0x2964('0x27')]]={'$like':'%'+_0x11fd19['query'][_0x2964('0x39')]+'%'};return _0x21f91f;}})});}_0x19c8ef=_[_0x2964('0x3a')]({},_0x19c8ef,_0x11fd19['options']);var _0x396ee7={'where':_0x19c8ef['where']};return db[_0x2964('0x3c')][_0x2964('0x3d')](_0x396ee7)[_0x2964('0x21')](function(_0x39e99d){_0x13ade4[_0x2964('0x3d')]=_0x39e99d;if(_0x11fd19[_0x2964('0x2f')][_0x2964('0x3e')]){_0x19c8ef[_0x2964('0x3f')]=[{'all':!![]}];}return db[_0x2964('0x3c')][_0x2964('0x40')](_0x19c8ef);})['then'](function(_0x418cb6){_0x13ade4[_0x2964('0x41')]=_0x418cb6;return _0x13ade4;})[_0x2964('0x21')](respondWithFilteredResult(_0x125eb1,_0x19c8ef))[_0x2964('0x42')](handleError(_0x125eb1,null));};exports[_0x2964('0x43')]=function(_0x4887c5,_0x3b7eee){var _0x553473={'raw':!![],'where':{'id':_0x4887c5[_0x2964('0x44')]['id']}},_0x26dcd9={};_0x26dcd9[_0x2964('0x2e')]=_[_0x2964('0x30')](db[_0x2964('0x3c')][_0x2964('0x45')]);_0x26dcd9[_0x2964('0x2f')]=_['keys'](_0x4887c5['query']);_0x26dcd9[_0x2964('0x31')]=_[_0x2964('0x32')](_0x26dcd9[_0x2964('0x2e')],_0x26dcd9['query']);_0x553473['attributes']=_[_0x2964('0x32')](_0x26dcd9[_0x2964('0x2e')],qs['fields'](_0x4887c5[_0x2964('0x2f')]['fields']));_0x553473[_0x2964('0x33')]=_0x553473[_0x2964('0x33')][_0x2964('0x46')]?_0x553473[_0x2964('0x33')]:_0x26dcd9['model'];if(_0x4887c5[_0x2964('0x2f')][_0x2964('0x3e')]){_0x553473[_0x2964('0x3f')]=[{'all':!![]}];}_0x553473=_[_0x2964('0x3a')]({},_0x553473,_0x4887c5[_0x2964('0x47')]);return db[_0x2964('0x3c')][_0x2964('0x48')](_0x553473)[_0x2964('0x21')](handleEntityNotFound(_0x3b7eee,null))[_0x2964('0x21')](respondWithResult(_0x3b7eee,null))[_0x2964('0x42')](handleError(_0x3b7eee,null));};exports[_0x2964('0x49')]=function(_0x113f69,_0x1d4bea){return db[_0x2964('0x3c')][_0x2964('0x49')](_0x113f69[_0x2964('0x4a')],{})['then'](function(_0xba6e05){var _0x580efa=_0x113f69[_0x2964('0x4b')][_0x2964('0x22')]({'plain':!![]});if(!_0x580efa)throw new Error(_0x2964('0x4c'));if(_0x580efa[_0x2964('0x4d')]===_0x2964('0x4b')){var _0x495620=_0xba6e05[_0x2964('0x22')]({'plain':!![]});var _0x1c34c0=_0x2964('0x4e');return db[_0x2964('0x4f')]['find']({'where':{'name':_0x1c34c0,'userProfileId':_0x580efa[_0x2964('0x50')]},'raw':!![]})[_0x2964('0x21')](function(_0xdc993d){if(_0xdc993d&&_0xdc993d['autoAssociation']===0x0){return db[_0x2964('0x23')][_0x2964('0x49')]({'name':_0x495620[_0x2964('0x27')],'resourceId':_0x495620['id'],'type':'DefaultReports','sectionId':_0xdc993d['id']},{})['then'](function(){return _0xba6e05;});}else{return _0xba6e05;}})[_0x2964('0x42')](function(_0x62a9fa){logger['error'](_0x2964('0x51'),_0x62a9fa);throw _0x62a9fa;});}return _0xba6e05;})[_0x2964('0x21')](respondWithResult(_0x1d4bea,0xc9))[_0x2964('0x42')](handleError(_0x1d4bea,null));};exports[_0x2964('0x1f')]=function(_0x1ad71b,_0x202be3){if(_0x1ad71b['body']['id']){delete _0x1ad71b[_0x2964('0x4a')]['id'];}return db[_0x2964('0x3c')]['find']({'where':{'id':_0x1ad71b[_0x2964('0x44')]['id']}})[_0x2964('0x21')](handleEntityNotFound(_0x202be3,null))[_0x2964('0x21')](saveUpdates(_0x1ad71b[_0x2964('0x4a')],null))[_0x2964('0x21')](respondWithResult(_0x202be3,null))[_0x2964('0x42')](handleError(_0x202be3,null));};exports[_0x2964('0x20')]=function(_0xf07439,_0x41690c){return db[_0x2964('0x3c')][_0x2964('0x48')]({'where':{'id':_0xf07439[_0x2964('0x44')]['id']}})['then'](handleEntityNotFound(_0x41690c,null))[_0x2964('0x21')](removeEntity(_0x41690c,null))[_0x2964('0x42')](handleError(_0x41690c,null));};exports[_0x2964('0x52')]=function(_0x19f429,_0x118854){var _0x4b5922=0xa;var _0x145628=[_0x2964('0x53'),_0x2964('0x54'),_0x2964('0x55'),_0x2964('0x56')];var _0x362544={'SUM':_0x2964('0x57'),'COUNT':_0x2964('0x58'),'COUNT DISTINCT':_0x2964('0x59'),'MAX':_0x2964('0x5a'),'MIN':_0x2964('0x5b'),'AVG':_0x2964('0x5c'),'GROUP_CONCAT':_0x2964('0x5d'),'GROUP_CONCAT ASC':'GROUP_CONCAT(%s\x20ORDER\x20BY\x20%s\x20ASC)','GROUP_CONCAT DESC':_0x2964('0x5e')};var _0x5ab6a6={'SEC_TO_TIME':_0x2964('0x5f'),'DATE':_0x2964('0x60'),'HOUR':_0x2964('0x61'),'ROUND':_0x2964('0x62'),'UNIX_TIMESTAMP':_0x2964('0x63')};var _0xe62fa9=function(_0x39fd1d){return!_['includes']([_0x2964('0x64'),_0x2964('0x65'),_0x2964('0x66'),_0x2964('0x67')],_0x39fd1d);};var _0x5ca205=function(_0x29eab9){if(!_0x29eab9||!_0x29eab9[_0x2964('0x68')][_0x2964('0x46')]){return'';}for(var _0x48848b='(',_0x52e038=0x0;_0x52e038<_0x29eab9['rules']['length'];_0x52e038+=0x1){_0x52e038>0x0&&(_0x48848b+='\x20'+_0x29eab9[_0x2964('0x69')]+'\x20');_0x48848b+=_0x29eab9[_0x2964('0x68')][_0x52e038][_0x2964('0x6a')]?_0x5ca205(_0x29eab9[_0x2964('0x68')][_0x52e038][_0x2964('0x6a')]):_0x29eab9[_0x2964('0x68')][_0x52e038][_0x2964('0x6b')]+'\x20'+_0x29eab9['rules'][_0x52e038][_0x2964('0x6c')]+(_0xe62fa9(_0x29eab9['rules'][_0x52e038][_0x2964('0x6c')])?'\x20'+_0x29eab9[_0x2964('0x68')][_0x52e038][_0x2964('0x6d')]:'');}return _0x48848b+')';};var _0x226a15={'where':{'id':_0x19f429[_0x2964('0x44')]['id']}},_0x240332,_0x23087e,_0x208695,_0x11e5b5,_0x416451;_0x226a15=_['merge']({},_0x226a15,_0x19f429[_0x2964('0x47')]);return db['AnalyticDefaultReport'][_0x2964('0x48')](_0x226a15)[_0x2964('0x21')](function(_0x3dbabc){if(_0x3dbabc){_0x240332=_0x3dbabc;return _0x3dbabc[_0x2964('0x6e')]();}return null;})[_0x2964('0x21')](function(_0x5386b4){if(_0x5386b4){if(!_0x5386b4[_0x2964('0x46')]){throw new db[(_0x2964('0x6f'))]['ValidationErrorItem'](_0x2964('0x70'),0x193);}_0x23087e=_0x5386b4;return db[_0x2964('0x71')][_0x2964('0x40')]({'raw':!![]});}return null;})[_0x2964('0x21')](function(_0x412225){if(_0x412225){_0x208695=_['keyBy'](_0x412225,'id');var _0x1a1012;var _0x143c15=squel[_0x2964('0x72')]();_0x143c15[_0x2964('0x73')](_0x240332[_0x2964('0x74')]);for(var _0x47b9b6=0x0;_0x47b9b6<_0x23087e[_0x2964('0x46')];_0x47b9b6+=0x1){_0x1a1012=_0x23087e[_0x47b9b6]['MetricId']?_0x208695[_0x23087e[_0x47b9b6][_0x2964('0x75')]][_0x2964('0x76')]:_0x23087e[_0x47b9b6]['field'];_0x1a1012=_0x23087e[_0x47b9b6][_0x2964('0x77')]?_['replace'](_0x362544[_0x23087e[_0x47b9b6][_0x2964('0x77')]],'%s',_0x1a1012):_0x1a1012;_0x1a1012=_0x23087e[_0x47b9b6][_0x2964('0x78')]?_['replace'](_0x5ab6a6[_0x23087e[_0x47b9b6][_0x2964('0x78')]],'%s',_0x1a1012):_0x1a1012;if(_0x23087e[_0x47b9b6]['groupBy']){_0x143c15[_0x2964('0x6a')](_0x1a1012);}_0x23087e[_0x47b9b6][_0x2964('0x79')]&&_0x143c15['order'](_0x1a1012,_0x23087e[_0x47b9b6][_0x2964('0x79')]===_0x2964('0x7a')?![]:!![]);_0x143c15[_0x2964('0x6b')](_0x1a1012,_0x23087e[_0x47b9b6]['alias']||_0x1a1012);}if(_0x240332['joins']){_0x240332[_0x2964('0x7b')]=JSON['parse'](_0x240332[_0x2964('0x7b')]);for(var _0x4f770a=0x0;_0x4f770a<_0x240332[_0x2964('0x7b')][_0x2964('0x46')];_0x4f770a+=0x1){if(_0x240332['joins'][_0x4f770a][_0x2964('0x2c')]&&_[_0x2964('0x7c')](_0x145628,_0x240332['joins'][_0x4f770a]['type'])&&_0x240332[_0x2964('0x7b')][_0x4f770a]['parentKey']&&_0x240332[_0x2964('0x7b')][_0x4f770a][_0x2964('0x7d')]&&_0x240332[_0x2964('0x7b')][_0x4f770a][_0x2964('0x7e')]){_0x143c15[_0x240332[_0x2964('0x7b')][_0x4f770a][_0x2964('0x2c')]](_0x240332[_0x2964('0x7b')][_0x4f770a][_0x2964('0x7d')],null,util[_0x2964('0x78')](_0x2964('0x7f'),_0x240332[_0x2964('0x74')],_0x240332[_0x2964('0x7b')][_0x4f770a][_0x2964('0x80')],_0x240332[_0x2964('0x7b')][_0x4f770a]['foreignTable'],_0x240332[_0x2964('0x7b')][_0x4f770a][_0x2964('0x7e')]));}}}if(_0x240332[_0x2964('0x81')]){_0x240332[_0x2964('0x81')]=JSON['parse'](_0x240332[_0x2964('0x81')]);_0x143c15[_0x2964('0x38')](_0x5ca205(_0x240332['conditions'][_0x2964('0x6a')]));}_0x416451=_0x143c15[_0x2964('0x82')]();_0x143c15['limit'](_0x4b5922);_0x143c15['offset'](0x0);logger[_0x2964('0x83')](_0x2964('0x84'),_0x143c15['toString']());return db[_0x2964('0x85')][_0x2964('0x2f')](_0x143c15[_0x2964('0x86')](),{'type':db[_0x2964('0x85')]['QueryTypes'][_0x2964('0x87')]});}})['then'](respondWithResult(_0x118854,null))[_0x2964('0x42')](handleError(_0x118854,null));};function runReport(_0x2f78d8,_0x405616,_0x3858d2){var _0xca52ec=_0x405616[_0x2964('0x27')];var _0x41dc25=0xa;var _0x1b8d6e=[_0x2964('0x53'),_0x2964('0x54'),_0x2964('0x55'),_0x2964('0x56')];var _0x3964e3={'SUM':'SUM(%s)','COUNT':_0x2964('0x58'),'COUNT DISTINCT':_0x2964('0x59'),'MAX':_0x2964('0x5a'),'MIN':_0x2964('0x5b'),'AVG':'AVG(%s)','GROUP_CONCAT':_0x2964('0x5d'),'GROUP_CONCAT ASC':_0x2964('0x88'),'GROUP_CONCAT DESC':'GROUP_CONCAT(%s\x20ORDER\x20BY\x20%s\x20DESC)'};var _0x120925={'SEC_TO_TIME':_0x2964('0x5f'),'DATE':_0x2964('0x60'),'HOUR':_0x2964('0x61'),'ROUND':_0x2964('0x62'),'UNIX_TIMESTAMP':_0x2964('0x63')};var _0x58e001=function(_0x1dbae9){return!_[_0x2964('0x7c')]([_0x2964('0x64'),_0x2964('0x65'),_0x2964('0x66'),'IS\x20NOT\x20EMPTY'],_0x1dbae9);};var _0x1ea799=function(_0x398137){if(!_0x398137||!_0x398137[_0x2964('0x68')][_0x2964('0x46')]){return'';}for(var _0x5b78f4='(',_0x4b63a4=0x0;_0x4b63a4<_0x398137[_0x2964('0x68')][_0x2964('0x46')];_0x4b63a4+=0x1){_0x4b63a4>0x0&&(_0x5b78f4+='\x20'+_0x398137[_0x2964('0x69')]+'\x20');_0x5b78f4+=_0x398137[_0x2964('0x68')][_0x4b63a4]['group']?_0x1ea799(_0x398137[_0x2964('0x68')][_0x4b63a4][_0x2964('0x6a')]):_0x398137[_0x2964('0x68')][_0x4b63a4]['field']+'\x20'+_0x398137[_0x2964('0x68')][_0x4b63a4][_0x2964('0x6c')]+(_0x58e001(_0x398137['rules'][_0x4b63a4][_0x2964('0x6c')])?'\x20'+_0x398137['rules'][_0x4b63a4][_0x2964('0x6d')]:'');}return _0x5b78f4+')';};var _0x40b54e={'where':{'id':_0x2f78d8['id']}},_0x301490,_0x64863,_0x5f2470,_0x50ae80,_0x4d6962;_0x40b54e=_['merge']({},_0x40b54e,_0x3858d2);return db[_0x2964('0x3c')][_0x2964('0x48')](_0x40b54e)[_0x2964('0x21')](function(_0x3a997d){if(_0x3a997d){_0x301490=_0x3a997d;return _0x3a997d[_0x2964('0x6e')]();}return null;})[_0x2964('0x21')](function(_0x14bb38){if(_0x14bb38){if(!_0x14bb38[_0x2964('0x46')]){throw new db['Sequelize'][(_0x2964('0x89'))]('Please\x20insert\x20at\x20least\x20one\x20field',0x193);}_0x64863=_0x14bb38;return db[_0x2964('0x71')][_0x2964('0x40')]({'raw':!![]});}return null;})['then'](function(_0x5c0dd5){if(_0x5c0dd5){_0x5f2470=_[_0x2964('0x8a')](_0x5c0dd5,'id');var _0x312469;var _0x469ed4=squel[_0x2964('0x72')]();_0x469ed4[_0x2964('0x73')](_0x301490[_0x2964('0x74')]);for(var _0x43c95a=0x0;_0x43c95a<_0x64863['length'];_0x43c95a+=0x1){_0x312469=_0x64863[_0x43c95a][_0x2964('0x75')]?_0x5f2470[_0x64863[_0x43c95a][_0x2964('0x75')]][_0x2964('0x76')]:_0x64863[_0x43c95a][_0x2964('0x6b')];_0x312469=_0x64863[_0x43c95a][_0x2964('0x77')]?_['replace'](_0x3964e3[_0x64863[_0x43c95a]['function']],'%s',_0x312469):_0x312469;_0x312469=_0x64863[_0x43c95a]['format']?_[_0x2964('0x8b')](_0x120925[_0x64863[_0x43c95a]['format']],'%s',_0x312469):_0x312469;if(_0x64863[_0x43c95a][_0x2964('0x8c')]){_0x469ed4[_0x2964('0x6a')](_0x312469);}_0x64863[_0x43c95a][_0x2964('0x79')]&&_0x469ed4[_0x2964('0x8d')](_0x312469,_0x64863[_0x43c95a]['orderBy']===_0x2964('0x7a')?![]:!![]);_0x469ed4[_0x2964('0x6b')](_0x312469,_0x64863[_0x43c95a][_0x2964('0x8e')]||_0x312469);}if(_0x301490['joins']){_0x301490['joins']=JSON[_0x2964('0x8f')](_0x301490['joins']);for(var _0x4eb760=0x0;_0x4eb760<_0x301490[_0x2964('0x7b')]['length'];_0x4eb760+=0x1){if(_0x301490[_0x2964('0x7b')][_0x4eb760]['type']&&_[_0x2964('0x7c')](_0x1b8d6e,_0x301490[_0x2964('0x7b')][_0x4eb760][_0x2964('0x2c')])&&_0x301490['joins'][_0x4eb760][_0x2964('0x80')]&&_0x301490['joins'][_0x4eb760][_0x2964('0x7d')]&&_0x301490[_0x2964('0x7b')][_0x4eb760]['foreignKey']){_0x469ed4[_0x301490[_0x2964('0x7b')][_0x4eb760][_0x2964('0x2c')]](_0x301490[_0x2964('0x7b')][_0x4eb760]['foreignTable'],null,util[_0x2964('0x78')](_0x2964('0x7f'),_0x301490['table'],_0x301490[_0x2964('0x7b')][_0x4eb760][_0x2964('0x80')],_0x301490[_0x2964('0x7b')][_0x4eb760][_0x2964('0x7d')],_0x301490[_0x2964('0x7b')][_0x4eb760]['foreignKey']));}}}if(_0x301490[_0x2964('0x81')]){_0x301490[_0x2964('0x81')]=JSON['parse'](_0x301490[_0x2964('0x81')]);_0x469ed4[_0x2964('0x38')](_0x1ea799(_0x301490['conditions'][_0x2964('0x6a')]));}_0x4d6962=_0x469ed4[_0x2964('0x82')]();_0x469ed4[_0x2964('0x1a')](_0x41dc25);_0x469ed4[_0x2964('0x19')](0x0);logger[_0x2964('0x83')](_0x2964('0x84'),_0x469ed4[_0x2964('0x86')]());return db['sequelize']['query'](_0x469ed4[_0x2964('0x86')](),{'type':db['sequelize']['QueryTypes'][_0x2964('0x87')]});}})[_0x2964('0x21')](function(_0x54784e){if(!_0x54784e[_0x2964('0x46')]){throw new db['Sequelize'][(_0x2964('0x89'))](_0x2964('0x90'),0xcc);}if(_0x405616[_0x2964('0x91')]==='web'){return null;}var _0x4bb081=_[_0x2964('0x3a')](_0x405616,{'name':_0x405616[_0x2964('0x92')]||_0x405616[_0x2964('0x27')]||_0x301490['name'],'basename':_0xca52ec,'savename':util[_0x2964('0x78')]('%s-%s.%s',_0x405616['name']||_0x301490[_0x2964('0x27')],require(_0x2964('0x93'))[_0x2964('0x94')](0x4),_0x405616[_0x2964('0x91')]||_0x2964('0x95')),'reportId':_0x301490['id'],'reportType':_0x2964('0x96')});return db[_0x2964('0x97')][_0x2964('0x49')](_0x4bb081,{'raw':!![]});})['then'](function(_0x25f3db){if(_0x301490[_0x2964('0x74')]==='cdr'){_0x4d6962['where'](_0x301490[_0x2964('0x74')]+_0x2964('0x98'),_0x405616['startDate'],_0x405616[_0x2964('0x99')]);}else{_0x4d6962['where'](_0x301490[_0x2964('0x74')]+_0x2964('0x9a'),_0x405616['startDate'],_0x405616[_0x2964('0x99')]);}if(_0x25f3db){logger[_0x2964('0x9b')]('Run\x20Query:',_0x4d6962['toString']());require('child_process')['fork'](path['join'](__dirname,_0x2964('0x9c'),_0x25f3db['output']),[_0x25f3db['id'],_0x4d6962[_0x2964('0x86')](),path['join'](__dirname,_0x2964('0x9d'),_0x25f3db[_0x2964('0x9e')]),_0xca52ec]);return _0x25f3db;}else{var _0x1633a2=squel[_0x2964('0x72')]();_0x1633a2[_0x2964('0x73')]('('+_0x4d6962[_0x2964('0x86')]()+')','countTable');_0x1633a2['field'](_0x2964('0x9f'),_0x2964('0x3d'));_0x4d6962[_0x2964('0x1a')](_0x405616[_0x2964('0x1a')]||_0x41dc25);_0x4d6962[_0x2964('0x19')](_0x405616[_0x2964('0x19')]||0x0);return db[_0x2964('0x85')][_0x2964('0x2f')](_0x1633a2[_0x2964('0x86')](),{'type':db['sequelize']['QueryTypes'][_0x2964('0x87')]})['then'](function(_0x1abdb6){if(!_0x1abdb6[_0x2964('0x46')]){_0x50ae80=0x0;}else{_0x50ae80=_0x1abdb6[0x0][_0x2964('0x3d')]||0x0;}return db[_0x2964('0x85')]['query'](_0x4d6962[_0x2964('0x86')](),{'type':db['sequelize']['QueryTypes'][_0x2964('0x87')]});})[_0x2964('0x21')](function(_0x511c11){return{'rows':_0x511c11||[],'count':_0x50ae80};});}});}exports[_0x2964('0xa0')]=function(_0x537cc8,_0x4d213){return runReport(_0x537cc8[_0x2964('0x44')],_0x537cc8[_0x2964('0x2f')],_0x537cc8[_0x2964('0x47')])[_0x2964('0x21')](respondWithResult(_0x4d213,null))[_0x2964('0x42')](handleError(_0x4d213,null));};exports['runReport']=runReport;exports[_0x2964('0x2f')]=function(_0x54dedd,_0x1b0028){var _0x99ae5f=0xa;var _0x1d7cf4=[_0x2964('0x53'),_0x2964('0x54'),'right_join','cross_join'];var _0x35ae5b={'SUM':_0x2964('0x57'),'COUNT':_0x2964('0x58'),'COUNT DISTINCT':'COUNT(DISTINCT\x20%s)','MAX':_0x2964('0x5a'),'MIN':_0x2964('0x5b'),'AVG':_0x2964('0x5c'),'GROUP_CONCAT':_0x2964('0x5d'),'GROUP_CONCAT ASC':_0x2964('0x88'),'GROUP_CONCAT DESC':_0x2964('0x5e')};var _0x4636d8={'SEC_TO_TIME':'SEC_TO_TIME(%s)','DATE':_0x2964('0x60'),'HOUR':'HOUR(%s)','ROUND':_0x2964('0x62'),'UNIX_TIMESTAMP':_0x2964('0x63')};var _0x3d30be=function(_0xb21add){return!_[_0x2964('0x7c')]([_0x2964('0x64'),_0x2964('0x65'),_0x2964('0x66'),_0x2964('0x67')],_0xb21add);};var _0x197896=function(_0x4ee256){if(!_0x4ee256||!_0x4ee256['rules'][_0x2964('0x46')]){return'';}for(var _0x377ee0='(',_0x30f9d3=0x0;_0x30f9d3<_0x4ee256['rules'][_0x2964('0x46')];_0x30f9d3+=0x1){_0x30f9d3>0x0&&(_0x377ee0+='\x20'+_0x4ee256['operator']+'\x20');_0x377ee0+=_0x4ee256[_0x2964('0x68')][_0x30f9d3][_0x2964('0x6a')]?_0x197896(_0x4ee256[_0x2964('0x68')][_0x30f9d3][_0x2964('0x6a')]):_0x4ee256[_0x2964('0x68')][_0x30f9d3][_0x2964('0x6b')]+'\x20'+_0x4ee256['rules'][_0x30f9d3][_0x2964('0x6c')]+(_0x3d30be(_0x4ee256[_0x2964('0x68')][_0x30f9d3][_0x2964('0x6c')])?'\x20'+_0x4ee256[_0x2964('0x68')][_0x30f9d3][_0x2964('0x6d')]:'');}return _0x377ee0+')';};var _0x2e422a={'where':{'id':_0x54dedd[_0x2964('0x44')]['id']}},_0x55f8dd,_0x2e9ada,_0x53b9fb,_0x32b6a9,_0x4693e4;_0x2e422a=_['merge']({},_0x2e422a,_0x54dedd[_0x2964('0x47')]);return db['AnalyticDefaultReport']['find'](_0x2e422a)[_0x2964('0x21')](function(_0x4cdf49){if(_0x4cdf49){_0x55f8dd=_0x4cdf49;return _0x4cdf49[_0x2964('0x6e')]();}return null;})[_0x2964('0x21')](function(_0x49385e){if(_0x49385e){if(!_0x49385e[_0x2964('0x46')]){throw new db['Sequelize'][(_0x2964('0x89'))](_0x2964('0x70'),0x193);}_0x2e9ada=_0x49385e;return db['AnalyticMetric']['findAll']({'raw':!![]});}return null;})['then'](function(_0x2c3c0c){if(_0x2c3c0c){_0x53b9fb=_[_0x2964('0x8a')](_0x2c3c0c,'id');var _0x38698d;var _0x2013fa=squel[_0x2964('0x72')]();_0x2013fa['from'](_0x55f8dd[_0x2964('0x74')]);for(var _0x54f723=0x0;_0x54f723<_0x2e9ada[_0x2964('0x46')];_0x54f723+=0x1){_0x38698d=_0x2e9ada[_0x54f723][_0x2964('0x75')]?_0x53b9fb[_0x2e9ada[_0x54f723][_0x2964('0x75')]][_0x2964('0x76')]:_0x2e9ada[_0x54f723][_0x2964('0x6b')];_0x38698d=_0x2e9ada[_0x54f723]['function']?_['replace'](_0x35ae5b[_0x2e9ada[_0x54f723][_0x2964('0x77')]],'%s',_0x38698d):_0x38698d;_0x38698d=_0x2e9ada[_0x54f723][_0x2964('0x78')]?_[_0x2964('0x8b')](_0x4636d8[_0x2e9ada[_0x54f723][_0x2964('0x78')]],'%s',_0x38698d):_0x38698d;if(_0x2e9ada[_0x54f723][_0x2964('0x8c')]){_0x2013fa[_0x2964('0x6a')](_0x38698d);}_0x2e9ada[_0x54f723]['orderBy']&&_0x2013fa[_0x2964('0x8d')](_0x38698d,_0x2e9ada[_0x54f723][_0x2964('0x79')]===_0x2964('0x7a')?![]:!![]);_0x2013fa[_0x2964('0x6b')](_0x38698d,_0x2e9ada[_0x54f723]['alias']||_0x38698d);}if(_0x55f8dd['joins']){_0x55f8dd[_0x2964('0x7b')]=JSON['parse'](_0x55f8dd[_0x2964('0x7b')]);for(var _0x24e2c1=0x0;_0x24e2c1<_0x55f8dd[_0x2964('0x7b')][_0x2964('0x46')];_0x24e2c1+=0x1){if(_0x55f8dd[_0x2964('0x7b')][_0x24e2c1][_0x2964('0x2c')]&&_['includes'](_0x1d7cf4,_0x55f8dd[_0x2964('0x7b')][_0x24e2c1]['type'])&&_0x55f8dd[_0x2964('0x7b')][_0x24e2c1][_0x2964('0x80')]&&_0x55f8dd[_0x2964('0x7b')][_0x24e2c1][_0x2964('0x7d')]&&_0x55f8dd['joins'][_0x24e2c1][_0x2964('0x7e')]){_0x2013fa[_0x55f8dd[_0x2964('0x7b')][_0x24e2c1][_0x2964('0x2c')]](_0x55f8dd['joins'][_0x24e2c1][_0x2964('0x7d')],null,util['format'](_0x2964('0x7f'),_0x55f8dd['table'],_0x55f8dd[_0x2964('0x7b')][_0x24e2c1][_0x2964('0x80')],_0x55f8dd[_0x2964('0x7b')][_0x24e2c1][_0x2964('0x7d')],_0x55f8dd['joins'][_0x24e2c1]['foreignKey']));}}}if(_0x55f8dd[_0x2964('0x81')]){_0x55f8dd['conditions']=JSON['parse'](_0x55f8dd['conditions']);_0x2013fa[_0x2964('0x38')](_0x197896(_0x55f8dd['conditions'][_0x2964('0x6a')]));}_0x4693e4=_0x2013fa[_0x2964('0x82')]();_0x2013fa['limit'](_0x99ae5f);_0x2013fa['offset'](0x0);logger[_0x2964('0x83')](_0x2964('0x84'),_0x2013fa[_0x2964('0x86')]());return db['sequelize']['query'](_0x2013fa[_0x2964('0x86')](),{'type':db[_0x2964('0x85')]['QueryTypes'][_0x2964('0x87')]});}})[_0x2964('0x21')](function(){return{'sql':_0x4693e4[_0x2964('0x86')]()};})[_0x2964('0x21')](respondWithResult(_0x1b0028,null))['catch'](handleError(_0x1b0028,null));};