Built motion from commit 9d1906d1.|2.5.40
[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 _0x3843=['lodash','squel','crypto','jsforce','desk.js','querystring','papaparse','ioredis','../../components/auth/service','../../components/parsers/qs','../../config/logger','api','../../config/environment','../../config/license/util','../../mysqldb','dbH','status','json','offset','undefined','limit','count','set','Content-Range','apply','reject','save','update','destroy','then','get','CustomReports','end','sendStatus','error','stack','name','send','map','AnalyticCustomReport','rawAttributes','fieldName','type','model','query','keys','filters','intersection','attributes','length','hasOwnProperty','order','sort','where','pick','filter','merge','options','findAll','rows','catch','show','params','fields','create','body','user','Unable\x20to\x20retrieve\x20the\x20current\x20user','role','Reports','UserProfileSection','find','autoAssociation','UserProfileResource','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)','includes','IS\x20NOT\x20NULL','IS\x20NOT\x20EMPTY','rules','operator','group','condition','value','getFields','Sequelize','ValidationErrorItem','keyBy','select','table','MetricId','metric','function','replace','format','groupBy','orderBy','DESC','field','alias','joins','foreignTable','foreignKey','%s.%s\x20=\x20%s.%s','conditions','parse','clone','debug','Limited\x20Query:','toString','sequelize','QueryTypes','SELECT','GROUP_CONCAT(%s\x20ORDER\x20BY\x20%s\x20ASC)','IS\x20NULL','IS\x20EMPTY','AnalyticMetric','parentKey','output','web','fullPath','%s-%s.%s','randomstring','csv','custom','AnalyticExtractedReport','.calldate\x20BETWEEN\x20?\x20AND\x20?','startDate','endDate','.createdAt\x20BETWEEN\x20?\x20AND\x20?','info','Run\x20Query:','child_process','fork','../../components/export/','../../files/reports','savename','from','countTable','runReport','Please\x20insert\x20at\x20least\x20one\x20field','eml-format','rimraf','zip-dir','moment','mustache','path','to-csv','fs-extra'];(function(_0x5248f5,_0x39c5a0){var _0x460c5a=function(_0x50f77e){while(--_0x50f77e){_0x5248f5['push'](_0x5248f5['shift']());}};_0x460c5a(++_0x39c5a0);}(_0x3843,0x144));var _0x3384=function(_0x495854,_0x1b3c2a){_0x495854=_0x495854-0x0;var _0x567d26=_0x3843[_0x495854];return _0x567d26;};'use strict';var emlformat=require(_0x3384('0x0'));var rimraf=require(_0x3384('0x1'));var zipdir=require(_0x3384('0x2'));var jsonpatch=require('fast-json-patch');var rp=require('request-promise');var moment=require(_0x3384('0x3'));var BPromise=require('bluebird');var Mustache=require(_0x3384('0x4'));var util=require('util');var path=require(_0x3384('0x5'));var sox=require('sox');var csv=require(_0x3384('0x6'));var ejs=require('ejs');var fs=require('fs');var fs_extra=require(_0x3384('0x7'));var _=require(_0x3384('0x8'));var squel=require(_0x3384('0x9'));var crypto=require(_0x3384('0xa'));var jsforce=require(_0x3384('0xb'));var deskjs=require(_0x3384('0xc'));var toCsv=require(_0x3384('0x6'));var querystring=require(_0x3384('0xd'));var Papa=require(_0x3384('0xe'));var Redis=require(_0x3384('0xf'));var authService=require(_0x3384('0x10'));var qs=require(_0x3384('0x11'));var as=require('../../components/parsers/advancedSearch');var hardwareService=require('../../config/license/hardware');var logger=require(_0x3384('0x12'))(_0x3384('0x13'));var utils=require('../../config/utils');var config=require(_0x3384('0x14'));var licenseUtil=require(_0x3384('0x15'));var db=require(_0x3384('0x16'))['db'];var dbH=require(_0x3384('0x16'))[_0x3384('0x17')];function respondWithStatusCode(_0x5b62b5,_0x13da07){_0x13da07=_0x13da07||0xcc;return function(_0x1daa9d){if(_0x1daa9d){return _0x5b62b5['sendStatus'](_0x13da07);}return _0x5b62b5[_0x3384('0x18')](_0x13da07)['end']();};}function respondWithResult(_0x5e30b6,_0x22fec9){_0x22fec9=_0x22fec9||0xc8;return function(_0xb24503){if(_0xb24503){return _0x5e30b6[_0x3384('0x18')](_0x22fec9)[_0x3384('0x19')](_0xb24503);}};}function respondWithFilteredResult(_0x27efdb,_0x5d6c62){return function(_0x2fec76){if(_0x2fec76){var _0x550c74=typeof _0x5d6c62[_0x3384('0x1a')]===_0x3384('0x1b')&&typeof _0x5d6c62[_0x3384('0x1c')]==='undefined';var _0x53f2da=_0x2fec76['count'];var _0x4da375=_0x550c74?0x0:_0x5d6c62[_0x3384('0x1a')];var _0x480ef4=_0x550c74?_0x2fec76[_0x3384('0x1d')]:_0x5d6c62[_0x3384('0x1a')]+_0x5d6c62[_0x3384('0x1c')];var _0x1ada92;if(_0x480ef4>=_0x53f2da){_0x480ef4=_0x53f2da;_0x1ada92=0xc8;}else{_0x1ada92=0xce;}_0x27efdb[_0x3384('0x18')](_0x1ada92);return _0x27efdb[_0x3384('0x1e')](_0x3384('0x1f'),_0x4da375+'-'+_0x480ef4+'/'+_0x53f2da)[_0x3384('0x19')](_0x2fec76);}return null;};}function patchUpdates(_0x1d9556){return function(_0x4f14fa){try{jsonpatch[_0x3384('0x20')](_0x4f14fa,_0x1d9556,!![]);}catch(_0x15be34){return BPromise[_0x3384('0x21')](_0x15be34);}return _0x4f14fa[_0x3384('0x22')]();};}function saveUpdates(_0x163f55,_0x5eecdb){return function(_0x5def02){if(_0x5def02){return _0x5def02[_0x3384('0x23')](_0x163f55)['then'](function(_0x514f64){return _0x514f64;});}return null;};}function removeEntity(_0x2e1c53,_0x21fa1){return function(_0x360f44){if(_0x360f44){return _0x360f44[_0x3384('0x24')]()[_0x3384('0x25')](function(){var _0x424285=_0x360f44[_0x3384('0x26')]({'plain':!![]});var _0x4303cd=_0x3384('0x27');return db['UserProfileResource']['destroy']({'where':{'type':_0x4303cd,'resourceId':_0x424285['id']}})[_0x3384('0x25')](function(){return _0x360f44;});})[_0x3384('0x25')](function(){_0x2e1c53[_0x3384('0x18')](0xcc)[_0x3384('0x28')]();});}};}function handleEntityNotFound(_0x474f23,_0x261f13){return function(_0x1f27a7){if(!_0x1f27a7){_0x474f23[_0x3384('0x29')](0x194);}return _0x1f27a7;};}function handleError(_0x20a11b,_0x5d5ed4){_0x5d5ed4=_0x5d5ed4||0x1f4;return function(_0x392985){logger[_0x3384('0x2a')](_0x392985[_0x3384('0x2b')]);if(_0x392985[_0x3384('0x2c')]){delete _0x392985[_0x3384('0x2c')];}_0x20a11b['status'](_0x5d5ed4)[_0x3384('0x2d')](_0x392985);};}exports['index']=function(_0x36e183,_0x31957a){var _0x30e264={},_0x521887={},_0x51b110={'count':0x0,'rows':[]};var _0x2f4b91=_[_0x3384('0x2e')](db[_0x3384('0x2f')][_0x3384('0x30')],function(_0x96133c){return{'name':_0x96133c[_0x3384('0x31')],'type':_0x96133c[_0x3384('0x32')]['key']};});_0x521887[_0x3384('0x33')]=_[_0x3384('0x2e')](_0x2f4b91,_0x3384('0x2c'));_0x521887[_0x3384('0x34')]=_[_0x3384('0x35')](_0x36e183['query']);_0x521887[_0x3384('0x36')]=_[_0x3384('0x37')](_0x521887['model'],_0x521887['query']);_0x30e264[_0x3384('0x38')]=_[_0x3384('0x37')](_0x521887[_0x3384('0x33')],qs['fields'](_0x36e183[_0x3384('0x34')]['fields']));_0x30e264[_0x3384('0x38')]=_0x30e264[_0x3384('0x38')][_0x3384('0x39')]?_0x30e264[_0x3384('0x38')]:_0x521887[_0x3384('0x33')];if(!_0x36e183[_0x3384('0x34')][_0x3384('0x3a')]('nolimit')){_0x30e264[_0x3384('0x1c')]=qs[_0x3384('0x1c')](_0x36e183[_0x3384('0x34')]['limit']);_0x30e264[_0x3384('0x1a')]=qs[_0x3384('0x1a')](_0x36e183['query'][_0x3384('0x1a')]);}_0x30e264[_0x3384('0x3b')]=qs[_0x3384('0x3c')](_0x36e183[_0x3384('0x34')][_0x3384('0x3c')]);_0x30e264[_0x3384('0x3d')]=qs[_0x3384('0x36')](_[_0x3384('0x3e')](_0x36e183[_0x3384('0x34')],_0x521887['filters']),_0x2f4b91);if(_0x36e183['query'][_0x3384('0x3f')]){_0x30e264[_0x3384('0x3d')]=_[_0x3384('0x40')](_0x30e264['where'],{'$or':_[_0x3384('0x2e')](_0x2f4b91,function(_0x33d846){if(_0x33d846[_0x3384('0x32')]!=='VIRTUAL'){var _0x2dc6e6={};_0x2dc6e6[_0x33d846[_0x3384('0x2c')]]={'$like':'%'+_0x36e183[_0x3384('0x34')][_0x3384('0x3f')]+'%'};return _0x2dc6e6;}})});}_0x30e264=_[_0x3384('0x40')]({},_0x30e264,_0x36e183[_0x3384('0x41')]);var _0x24490d={'where':_0x30e264[_0x3384('0x3d')]};return db[_0x3384('0x2f')][_0x3384('0x1d')](_0x24490d)[_0x3384('0x25')](function(_0x50ed92){_0x51b110[_0x3384('0x1d')]=_0x50ed92;if(_0x36e183[_0x3384('0x34')]['includeAll']){_0x30e264['include']=[{'all':!![]}];}return db[_0x3384('0x2f')][_0x3384('0x42')](_0x30e264);})[_0x3384('0x25')](function(_0x595177){_0x51b110[_0x3384('0x43')]=_0x595177;return _0x51b110;})[_0x3384('0x25')](respondWithFilteredResult(_0x31957a,_0x30e264))[_0x3384('0x44')](handleError(_0x31957a,null));};exports[_0x3384('0x45')]=function(_0x3c2c45,_0x331c20){var _0x54e7d5={'raw':![],'where':{'id':_0x3c2c45[_0x3384('0x46')]['id']}},_0x283b1b={};_0x283b1b[_0x3384('0x33')]=_[_0x3384('0x35')](db[_0x3384('0x2f')][_0x3384('0x30')]);_0x283b1b['query']=_[_0x3384('0x35')](_0x3c2c45[_0x3384('0x34')]);_0x283b1b[_0x3384('0x36')]=_[_0x3384('0x37')](_0x283b1b[_0x3384('0x33')],_0x283b1b[_0x3384('0x34')]);_0x54e7d5['attributes']=_[_0x3384('0x37')](_0x283b1b[_0x3384('0x33')],qs[_0x3384('0x47')](_0x3c2c45[_0x3384('0x34')][_0x3384('0x47')]));_0x54e7d5[_0x3384('0x38')]=_0x54e7d5[_0x3384('0x38')][_0x3384('0x39')]?_0x54e7d5['attributes']:_0x283b1b[_0x3384('0x33')];if(_0x3c2c45[_0x3384('0x34')]['includeAll']){_0x54e7d5['include']=[{'all':!![]}];}_0x54e7d5=_[_0x3384('0x40')]({},_0x54e7d5,_0x3c2c45['options']);return db[_0x3384('0x2f')]['find'](_0x54e7d5)[_0x3384('0x25')](handleEntityNotFound(_0x331c20,null))[_0x3384('0x25')](respondWithResult(_0x331c20,null))['catch'](handleError(_0x331c20,null));};exports['create']=function(_0xbd5be7,_0x9b65d1){return db[_0x3384('0x2f')][_0x3384('0x48')](_0xbd5be7[_0x3384('0x49')],{})[_0x3384('0x25')](function(_0x3764fb){var _0x779eef=_0xbd5be7[_0x3384('0x4a')]['get']({'plain':!![]});if(!_0x779eef)throw new Error(_0x3384('0x4b'));if(_0x779eef[_0x3384('0x4c')]===_0x3384('0x4a')){var _0x3af6eb=_0x3764fb[_0x3384('0x26')]({'plain':!![]});var _0x4014e5=_0x3384('0x4d');return db[_0x3384('0x4e')][_0x3384('0x4f')]({'where':{'name':_0x4014e5,'userProfileId':_0x779eef['userProfileId']},'raw':!![]})[_0x3384('0x25')](function(_0x15d38b){if(_0x15d38b&&_0x15d38b[_0x3384('0x50')]===0x0){return db[_0x3384('0x51')]['create']({'name':_0x3af6eb[_0x3384('0x2c')],'resourceId':_0x3af6eb['id'],'type':_0x3384('0x27'),'sectionId':_0x15d38b['id']},{})[_0x3384('0x25')](function(){return _0x3764fb;});}else{return _0x3764fb;}})['catch'](function(_0x5d176c){logger['error'](_0x3384('0x52'),_0x5d176c);throw _0x5d176c;});}return _0x3764fb;})[_0x3384('0x25')](respondWithResult(_0x9b65d1,0xc9))[_0x3384('0x44')](handleError(_0x9b65d1,null));};exports[_0x3384('0x23')]=function(_0x63feb4,_0x39f8b0){if(_0x63feb4[_0x3384('0x49')]['id']){delete _0x63feb4[_0x3384('0x49')]['id'];}return db[_0x3384('0x2f')][_0x3384('0x4f')]({'where':{'id':_0x63feb4[_0x3384('0x46')]['id']}})[_0x3384('0x25')](handleEntityNotFound(_0x39f8b0,null))[_0x3384('0x25')](saveUpdates(_0x63feb4['body'],null))[_0x3384('0x25')](respondWithResult(_0x39f8b0,null))[_0x3384('0x44')](handleError(_0x39f8b0,null));};exports[_0x3384('0x24')]=function(_0x44f68f,_0x487796){return db[_0x3384('0x2f')][_0x3384('0x4f')]({'where':{'id':_0x44f68f[_0x3384('0x46')]['id']}})[_0x3384('0x25')](handleEntityNotFound(_0x487796,null))[_0x3384('0x25')](removeEntity(_0x487796,null))[_0x3384('0x44')](handleError(_0x487796,null));};exports[_0x3384('0x53')]=function(_0x37d952,_0x5ca690){var _0x430e53=0xa;var _0x1e895d=[_0x3384('0x54'),_0x3384('0x55'),_0x3384('0x56'),_0x3384('0x57')];var _0x449f37={'SUM':_0x3384('0x58'),'COUNT':_0x3384('0x59'),'COUNT DISTINCT':_0x3384('0x5a'),'MAX':_0x3384('0x5b'),'MIN':_0x3384('0x5c'),'AVG':_0x3384('0x5d'),'GROUP_CONCAT':_0x3384('0x5e'),'GROUP_CONCAT ASC':'GROUP_CONCAT(%s\x20ORDER\x20BY\x20%s\x20ASC)','GROUP_CONCAT DESC':_0x3384('0x5f')};var _0xdf6bdb={'SEC_TO_TIME':_0x3384('0x60'),'DATE':_0x3384('0x61'),'HOUR':_0x3384('0x62'),'ROUND':_0x3384('0x63'),'UNIX_TIMESTAMP':_0x3384('0x64')};var _0x452244=function(_0x1a275c){return!_[_0x3384('0x65')](['IS\x20NULL',_0x3384('0x66'),'IS\x20EMPTY',_0x3384('0x67')],_0x1a275c);};var _0x353a73=function(_0xc47792){if(!_0xc47792||!_0xc47792[_0x3384('0x68')]['length']){return'';}for(var _0x5baba9='(',_0x2115d8=0x0;_0x2115d8<_0xc47792[_0x3384('0x68')][_0x3384('0x39')];_0x2115d8+=0x1){_0x2115d8>0x0&&(_0x5baba9+='\x20'+_0xc47792[_0x3384('0x69')]+'\x20');_0x5baba9+=_0xc47792[_0x3384('0x68')][_0x2115d8][_0x3384('0x6a')]?_0x353a73(_0xc47792['rules'][_0x2115d8][_0x3384('0x6a')]):_0xc47792[_0x3384('0x68')][_0x2115d8]['field']+'\x20'+_0xc47792[_0x3384('0x68')][_0x2115d8]['condition']+(_0x452244(_0xc47792[_0x3384('0x68')][_0x2115d8][_0x3384('0x6b')])?'\x20'+_0xc47792[_0x3384('0x68')][_0x2115d8][_0x3384('0x6c')]:'');}return _0x5baba9+')';};var _0x3ae0a5={'where':{'id':_0x37d952['params']['id']}},_0x13d1d1,_0x38af1f,_0x4b7bfc,_0x34779b,_0x46bbbe;_0x3ae0a5=_[_0x3384('0x40')]({},_0x3ae0a5,_0x37d952['options']);return db[_0x3384('0x2f')][_0x3384('0x4f')](_0x3ae0a5)[_0x3384('0x25')](function(_0x3c0fad){if(_0x3c0fad){_0x13d1d1=_0x3c0fad;return _0x3c0fad[_0x3384('0x6d')]();}return null;})[_0x3384('0x25')](function(_0x40c634){if(_0x40c634){if(!_0x40c634[_0x3384('0x39')]){throw new db[(_0x3384('0x6e'))][(_0x3384('0x6f'))]('Please\x20insert\x20at\x20least\x20one\x20field',0x193);}_0x38af1f=_0x40c634;return db['AnalyticMetric'][_0x3384('0x42')]({'raw':!![]});}return null;})[_0x3384('0x25')](function(_0xe9cb8a){if(_0xe9cb8a){_0x4b7bfc=_[_0x3384('0x70')](_0xe9cb8a,'id');var _0x3c6d73;var _0x5c0f6e=squel[_0x3384('0x71')]();_0x5c0f6e['from'](_0x13d1d1[_0x3384('0x72')]);for(var _0x2fac45=0x0;_0x2fac45<_0x38af1f['length'];_0x2fac45+=0x1){_0x3c6d73=_0x38af1f[_0x2fac45][_0x3384('0x73')]?_0x4b7bfc[_0x38af1f[_0x2fac45][_0x3384('0x73')]][_0x3384('0x74')]:_0x38af1f[_0x2fac45]['field'];_0x3c6d73=_0x38af1f[_0x2fac45][_0x3384('0x75')]?_[_0x3384('0x76')](_0x449f37[_0x38af1f[_0x2fac45][_0x3384('0x75')]],'%s',_0x3c6d73):_0x3c6d73;_0x3c6d73=_0x38af1f[_0x2fac45][_0x3384('0x77')]?_[_0x3384('0x76')](_0xdf6bdb[_0x38af1f[_0x2fac45][_0x3384('0x77')]],'%s',_0x3c6d73):_0x3c6d73;if(_0x38af1f[_0x2fac45][_0x3384('0x78')]){_0x5c0f6e[_0x3384('0x6a')](_0x3c6d73);}_0x38af1f[_0x2fac45][_0x3384('0x79')]&&_0x5c0f6e['order'](_0x3c6d73,_0x38af1f[_0x2fac45]['orderBy']===_0x3384('0x7a')?![]:!![]);_0x5c0f6e[_0x3384('0x7b')](_0x3c6d73,_0x38af1f[_0x2fac45][_0x3384('0x7c')]||_0x3c6d73);}if(_0x13d1d1[_0x3384('0x7d')]){_0x13d1d1[_0x3384('0x7d')]=JSON['parse'](_0x13d1d1[_0x3384('0x7d')]);for(var _0x1f2ac7=0x0;_0x1f2ac7<_0x13d1d1[_0x3384('0x7d')][_0x3384('0x39')];_0x1f2ac7+=0x1){if(_0x13d1d1['joins'][_0x1f2ac7][_0x3384('0x32')]&&_['includes'](_0x1e895d,_0x13d1d1[_0x3384('0x7d')][_0x1f2ac7][_0x3384('0x32')])&&_0x13d1d1[_0x3384('0x7d')][_0x1f2ac7]['parentKey']&&_0x13d1d1[_0x3384('0x7d')][_0x1f2ac7][_0x3384('0x7e')]&&_0x13d1d1['joins'][_0x1f2ac7][_0x3384('0x7f')]){_0x5c0f6e[_0x13d1d1[_0x3384('0x7d')][_0x1f2ac7]['type']](_0x13d1d1['joins'][_0x1f2ac7]['foreignTable'],null,util[_0x3384('0x77')](_0x3384('0x80'),_0x13d1d1[_0x3384('0x72')],_0x13d1d1[_0x3384('0x7d')][_0x1f2ac7]['parentKey'],_0x13d1d1[_0x3384('0x7d')][_0x1f2ac7][_0x3384('0x7e')],_0x13d1d1[_0x3384('0x7d')][_0x1f2ac7][_0x3384('0x7f')]));}}}if(_0x13d1d1[_0x3384('0x81')]){_0x13d1d1[_0x3384('0x81')]=JSON[_0x3384('0x82')](_0x13d1d1['conditions']);_0x5c0f6e['where'](_0x353a73(_0x13d1d1[_0x3384('0x81')][_0x3384('0x6a')]));}_0x46bbbe=_0x5c0f6e[_0x3384('0x83')]();_0x5c0f6e[_0x3384('0x1c')](_0x430e53);_0x5c0f6e[_0x3384('0x1a')](0x0);logger[_0x3384('0x84')](_0x3384('0x85'),_0x5c0f6e[_0x3384('0x86')]());return dbH[_0x3384('0x87')][_0x3384('0x34')](_0x5c0f6e[_0x3384('0x86')](),{'type':dbH[_0x3384('0x87')][_0x3384('0x88')][_0x3384('0x89')]});}})[_0x3384('0x25')](respondWithResult(_0x5ca690,null))['catch'](handleError(_0x5ca690,null));};function runReport(_0xea9250,_0x2ecea7,_0x105908){var _0x1fc331=_0x2ecea7[_0x3384('0x2c')];var _0x5d0464=0xa;var _0x696479=[_0x3384('0x54'),'left_join',_0x3384('0x56'),'cross_join'];var _0x37d6f3={'SUM':_0x3384('0x58'),'COUNT':_0x3384('0x59'),'COUNT DISTINCT':'COUNT(DISTINCT\x20%s)','MAX':_0x3384('0x5b'),'MIN':'MIN(%s)','AVG':'AVG(%s)','GROUP_CONCAT':_0x3384('0x5e'),'GROUP_CONCAT ASC':_0x3384('0x8a'),'GROUP_CONCAT DESC':_0x3384('0x5f')};var _0x3e4035={'SEC_TO_TIME':_0x3384('0x60'),'DATE':'DATE(%s)','HOUR':_0x3384('0x62'),'ROUND':'ROUND(%s)','UNIX_TIMESTAMP':_0x3384('0x64')};var _0x25d31f=function(_0x680059){return!_[_0x3384('0x65')]([_0x3384('0x8b'),_0x3384('0x66'),_0x3384('0x8c'),_0x3384('0x67')],_0x680059);};var _0x2ffddc=function(_0x2fef6e){if(!_0x2fef6e||!_0x2fef6e[_0x3384('0x68')][_0x3384('0x39')]){return'';}for(var _0x43f1ec='(',_0x419958=0x0;_0x419958<_0x2fef6e[_0x3384('0x68')]['length'];_0x419958+=0x1){_0x419958>0x0&&(_0x43f1ec+='\x20'+_0x2fef6e['operator']+'\x20');_0x43f1ec+=_0x2fef6e[_0x3384('0x68')][_0x419958]['group']?_0x2ffddc(_0x2fef6e['rules'][_0x419958]['group']):_0x2fef6e[_0x3384('0x68')][_0x419958]['field']+'\x20'+_0x2fef6e[_0x3384('0x68')][_0x419958][_0x3384('0x6b')]+(_0x25d31f(_0x2fef6e[_0x3384('0x68')][_0x419958][_0x3384('0x6b')])?'\x20'+_0x2fef6e[_0x3384('0x68')][_0x419958][_0x3384('0x6c')]:'');}return _0x43f1ec+')';};var _0xb22017={'where':{'id':_0xea9250['id']}},_0xc9d270,_0x276a5c,_0x1090c5,_0x169f31,_0x1563f6;_0xb22017=_[_0x3384('0x40')]({},_0xb22017,_0x105908);return db[_0x3384('0x2f')][_0x3384('0x4f')](_0xb22017)['then'](function(_0x363407){if(_0x363407){_0xc9d270=_0x363407;return _0x363407[_0x3384('0x6d')]();}return null;})[_0x3384('0x25')](function(_0x3931ec){if(_0x3931ec){if(!_0x3931ec[_0x3384('0x39')]){throw new db[(_0x3384('0x6e'))][(_0x3384('0x6f'))]('Please\x20insert\x20at\x20least\x20one\x20field',0x193);}_0x276a5c=_0x3931ec;return db[_0x3384('0x8d')][_0x3384('0x42')]({'raw':!![]});}return null;})['then'](function(_0xfca560){if(_0xfca560){_0x1090c5=_[_0x3384('0x70')](_0xfca560,'id');var _0x1191da;var _0x23b768=squel[_0x3384('0x71')]();_0x23b768['from'](_0xc9d270[_0x3384('0x72')]);for(var _0x127267=0x0;_0x127267<_0x276a5c['length'];_0x127267+=0x1){_0x1191da=_0x276a5c[_0x127267]['MetricId']?_0x1090c5[_0x276a5c[_0x127267]['MetricId']][_0x3384('0x74')]:_0x276a5c[_0x127267][_0x3384('0x7b')];_0x1191da=_0x276a5c[_0x127267][_0x3384('0x75')]?_[_0x3384('0x76')](_0x37d6f3[_0x276a5c[_0x127267]['function']],'%s',_0x1191da):_0x1191da;_0x1191da=_0x276a5c[_0x127267][_0x3384('0x77')]?_[_0x3384('0x76')](_0x3e4035[_0x276a5c[_0x127267][_0x3384('0x77')]],'%s',_0x1191da):_0x1191da;if(_0x276a5c[_0x127267][_0x3384('0x78')]){_0x23b768[_0x3384('0x6a')](_0x1191da);}_0x276a5c[_0x127267][_0x3384('0x79')]&&_0x23b768['order'](_0x1191da,_0x276a5c[_0x127267]['orderBy']==='DESC'?![]:!![]);_0x23b768[_0x3384('0x7b')](_0x1191da,_0x276a5c[_0x127267][_0x3384('0x7c')]||_0x1191da);}if(_0xc9d270[_0x3384('0x7d')]){_0xc9d270[_0x3384('0x7d')]=JSON[_0x3384('0x82')](_0xc9d270[_0x3384('0x7d')]);for(var _0x189a66=0x0;_0x189a66<_0xc9d270[_0x3384('0x7d')][_0x3384('0x39')];_0x189a66+=0x1){if(_0xc9d270[_0x3384('0x7d')][_0x189a66]['type']&&_['includes'](_0x696479,_0xc9d270[_0x3384('0x7d')][_0x189a66][_0x3384('0x32')])&&_0xc9d270[_0x3384('0x7d')][_0x189a66]['parentKey']&&_0xc9d270[_0x3384('0x7d')][_0x189a66][_0x3384('0x7e')]&&_0xc9d270[_0x3384('0x7d')][_0x189a66][_0x3384('0x7f')]){_0x23b768[_0xc9d270['joins'][_0x189a66]['type']](_0xc9d270[_0x3384('0x7d')][_0x189a66][_0x3384('0x7e')],null,util[_0x3384('0x77')]('%s.%s\x20=\x20%s.%s',_0xc9d270['table'],_0xc9d270[_0x3384('0x7d')][_0x189a66][_0x3384('0x8e')],_0xc9d270[_0x3384('0x7d')][_0x189a66][_0x3384('0x7e')],_0xc9d270[_0x3384('0x7d')][_0x189a66][_0x3384('0x7f')]));}}}if(_0xc9d270[_0x3384('0x81')]){_0xc9d270[_0x3384('0x81')]=JSON['parse'](_0xc9d270[_0x3384('0x81')]);_0x23b768['where'](_0x2ffddc(_0xc9d270['conditions'][_0x3384('0x6a')]));}_0x1563f6=_0x23b768['clone']();_0x23b768['limit'](_0x5d0464);_0x23b768[_0x3384('0x1a')](0x0);return;}})[_0x3384('0x25')](function(){if(_0x2ecea7[_0x3384('0x8f')]===_0x3384('0x90')){return null;}var _0x2cf7dd=_[_0x3384('0x40')](_0x2ecea7,{'name':_0x2ecea7[_0x3384('0x91')]||_0x2ecea7[_0x3384('0x2c')]||_0xc9d270[_0x3384('0x2c')],'basename':_0x1fc331,'savename':util['format'](_0x3384('0x92'),_0x2ecea7[_0x3384('0x2c')]||_0xc9d270[_0x3384('0x2c')],require(_0x3384('0x93'))['generate'](0x4),_0x2ecea7['output']||_0x3384('0x94')),'reportId':_0xc9d270['id'],'reportType':_0x3384('0x95')});return db[_0x3384('0x96')][_0x3384('0x48')](_0x2cf7dd,{'raw':!![]});})[_0x3384('0x25')](function(_0xddf537){if(_0xc9d270[_0x3384('0x72')]==='cdr'){_0x1563f6[_0x3384('0x3d')](_0xc9d270[_0x3384('0x72')]+_0x3384('0x97'),_0x2ecea7[_0x3384('0x98')],_0x2ecea7[_0x3384('0x99')]);}else{_0x1563f6[_0x3384('0x3d')](_0xc9d270[_0x3384('0x72')]+_0x3384('0x9a'),_0x2ecea7['startDate'],_0x2ecea7[_0x3384('0x99')]);}if(_0xddf537){logger[_0x3384('0x9b')](_0x3384('0x9c'),_0x1563f6[_0x3384('0x86')]());require(_0x3384('0x9d'))[_0x3384('0x9e')](path[_0x3384('0x54')](__dirname,_0x3384('0x9f'),_0xddf537[_0x3384('0x8f')]),[_0xddf537['id'],_0x1563f6[_0x3384('0x86')](),path[_0x3384('0x54')](__dirname,_0x3384('0xa0'),_0xddf537[_0x3384('0xa1')]),_0x1fc331]);return _0xddf537;}else{var _0x2804b8=squel[_0x3384('0x71')]();_0x2804b8[_0x3384('0xa2')]('('+_0x1563f6[_0x3384('0x86')]()+')',_0x3384('0xa3'));_0x2804b8[_0x3384('0x7b')]('COUNT(*)',_0x3384('0x1d'));_0x1563f6[_0x3384('0x1c')](_0x2ecea7[_0x3384('0x1c')]||_0x5d0464);_0x1563f6[_0x3384('0x1a')](_0x2ecea7[_0x3384('0x1a')]||0x0);return dbH[_0x3384('0x87')]['query'](_0x2804b8[_0x3384('0x86')](),{'type':dbH[_0x3384('0x87')]['QueryTypes']['SELECT']})[_0x3384('0x25')](function(_0x35b099){if(!_0x35b099[_0x3384('0x39')]){_0x169f31=0x0;}else{_0x169f31=_0x35b099[0x0][_0x3384('0x1d')]||0x0;}return dbH['sequelize']['query'](_0x1563f6[_0x3384('0x86')](),{'type':dbH[_0x3384('0x87')]['QueryTypes'][_0x3384('0x89')]});})[_0x3384('0x25')](function(_0x46bac3){return{'rows':_0x46bac3||[],'count':_0x169f31};});}});}exports['run']=function(_0x5c7acb,_0x46babc){return runReport(_0x5c7acb[_0x3384('0x46')],_0x5c7acb[_0x3384('0x34')],_0x5c7acb[_0x3384('0x41')])[_0x3384('0x25')](respondWithResult(_0x46babc,null))[_0x3384('0x44')](handleError(_0x46babc,null));};exports[_0x3384('0xa4')]=runReport;exports['query']=function(_0x586ec2,_0x4b9381){var _0x300602=0xa;var _0x42d06c=['join',_0x3384('0x55'),_0x3384('0x56'),_0x3384('0x57')];var _0x17a91e={'SUM':'SUM(%s)','COUNT':_0x3384('0x59'),'COUNT DISTINCT':_0x3384('0x5a'),'MAX':_0x3384('0x5b'),'MIN':_0x3384('0x5c'),'AVG':_0x3384('0x5d'),'GROUP_CONCAT':_0x3384('0x5e'),'GROUP_CONCAT ASC':'GROUP_CONCAT(%s\x20ORDER\x20BY\x20%s\x20ASC)','GROUP_CONCAT DESC':_0x3384('0x5f')};var _0x155b34={'SEC_TO_TIME':_0x3384('0x60'),'DATE':_0x3384('0x61'),'HOUR':_0x3384('0x62'),'ROUND':_0x3384('0x63'),'UNIX_TIMESTAMP':_0x3384('0x64')};var _0x27272c=function(_0x3ed847){return!_[_0x3384('0x65')]([_0x3384('0x8b'),_0x3384('0x66'),_0x3384('0x8c'),_0x3384('0x67')],_0x3ed847);};var _0x1417ba=function(_0x5c283a){if(!_0x5c283a||!_0x5c283a[_0x3384('0x68')][_0x3384('0x39')]){return'';}for(var _0x1d911c='(',_0x81cd5=0x0;_0x81cd5<_0x5c283a[_0x3384('0x68')]['length'];_0x81cd5+=0x1){_0x81cd5>0x0&&(_0x1d911c+='\x20'+_0x5c283a[_0x3384('0x69')]+'\x20');_0x1d911c+=_0x5c283a['rules'][_0x81cd5][_0x3384('0x6a')]?_0x1417ba(_0x5c283a[_0x3384('0x68')][_0x81cd5]['group']):_0x5c283a[_0x3384('0x68')][_0x81cd5][_0x3384('0x7b')]+'\x20'+_0x5c283a[_0x3384('0x68')][_0x81cd5][_0x3384('0x6b')]+(_0x27272c(_0x5c283a[_0x3384('0x68')][_0x81cd5][_0x3384('0x6b')])?'\x20'+_0x5c283a[_0x3384('0x68')][_0x81cd5][_0x3384('0x6c')]:'');}return _0x1d911c+')';};var _0x57b7bd={'where':{'id':_0x586ec2[_0x3384('0x46')]['id']}},_0x58ddc8,_0x2d3957,_0x4bf9d6,_0x44dc97,_0x21d0dc;_0x57b7bd=_[_0x3384('0x40')]({},_0x57b7bd,_0x586ec2[_0x3384('0x41')]);return db[_0x3384('0x2f')][_0x3384('0x4f')](_0x57b7bd)['then'](function(_0xcfcb4f){if(_0xcfcb4f){_0x58ddc8=_0xcfcb4f;return _0xcfcb4f[_0x3384('0x6d')]();}return null;})[_0x3384('0x25')](function(_0x18f8eb){if(_0x18f8eb){if(!_0x18f8eb[_0x3384('0x39')]){throw new db[(_0x3384('0x6e'))][(_0x3384('0x6f'))](_0x3384('0xa5'),0x193);}_0x2d3957=_0x18f8eb;return db[_0x3384('0x8d')][_0x3384('0x42')]({'raw':!![]});}return null;})[_0x3384('0x25')](function(_0x81eee7){if(_0x81eee7){_0x4bf9d6=_['keyBy'](_0x81eee7,'id');var _0x288ccc;var _0x508727=squel[_0x3384('0x71')]();_0x508727['from'](_0x58ddc8[_0x3384('0x72')]);for(var _0x1e2372=0x0;_0x1e2372<_0x2d3957[_0x3384('0x39')];_0x1e2372+=0x1){_0x288ccc=_0x2d3957[_0x1e2372]['MetricId']?_0x4bf9d6[_0x2d3957[_0x1e2372]['MetricId']][_0x3384('0x74')]:_0x2d3957[_0x1e2372][_0x3384('0x7b')];_0x288ccc=_0x2d3957[_0x1e2372]['function']?_[_0x3384('0x76')](_0x17a91e[_0x2d3957[_0x1e2372][_0x3384('0x75')]],'%s',_0x288ccc):_0x288ccc;_0x288ccc=_0x2d3957[_0x1e2372]['format']?_[_0x3384('0x76')](_0x155b34[_0x2d3957[_0x1e2372][_0x3384('0x77')]],'%s',_0x288ccc):_0x288ccc;if(_0x2d3957[_0x1e2372][_0x3384('0x78')]){_0x508727[_0x3384('0x6a')](_0x288ccc);}_0x2d3957[_0x1e2372][_0x3384('0x79')]&&_0x508727[_0x3384('0x3b')](_0x288ccc,_0x2d3957[_0x1e2372][_0x3384('0x79')]===_0x3384('0x7a')?![]:!![]);_0x508727[_0x3384('0x7b')](_0x288ccc,_0x2d3957[_0x1e2372][_0x3384('0x7c')]||_0x288ccc);}if(_0x58ddc8['joins']){_0x58ddc8[_0x3384('0x7d')]=JSON['parse'](_0x58ddc8[_0x3384('0x7d')]);for(var _0x32b214=0x0;_0x32b214<_0x58ddc8[_0x3384('0x7d')][_0x3384('0x39')];_0x32b214+=0x1){if(_0x58ddc8['joins'][_0x32b214][_0x3384('0x32')]&&_[_0x3384('0x65')](_0x42d06c,_0x58ddc8[_0x3384('0x7d')][_0x32b214]['type'])&&_0x58ddc8[_0x3384('0x7d')][_0x32b214]['parentKey']&&_0x58ddc8[_0x3384('0x7d')][_0x32b214][_0x3384('0x7e')]&&_0x58ddc8['joins'][_0x32b214][_0x3384('0x7f')]){_0x508727[_0x58ddc8[_0x3384('0x7d')][_0x32b214][_0x3384('0x32')]](_0x58ddc8[_0x3384('0x7d')][_0x32b214][_0x3384('0x7e')],null,util[_0x3384('0x77')]('%s.%s\x20=\x20%s.%s',_0x58ddc8['table'],_0x58ddc8[_0x3384('0x7d')][_0x32b214]['parentKey'],_0x58ddc8[_0x3384('0x7d')][_0x32b214]['foreignTable'],_0x58ddc8[_0x3384('0x7d')][_0x32b214][_0x3384('0x7f')]));}}}if(_0x58ddc8['conditions']){_0x58ddc8[_0x3384('0x81')]=JSON[_0x3384('0x82')](_0x58ddc8[_0x3384('0x81')]);_0x508727[_0x3384('0x3d')](_0x1417ba(_0x58ddc8['conditions']['group']));}_0x21d0dc=_0x508727[_0x3384('0x83')]();_0x508727[_0x3384('0x1c')](_0x300602);_0x508727[_0x3384('0x1a')](0x0);logger['debug'](_0x3384('0x85'),_0x508727['toString']());return dbH[_0x3384('0x87')]['query'](_0x508727[_0x3384('0x86')](),{'type':dbH[_0x3384('0x87')]['QueryTypes'][_0x3384('0x89')]});}})['then'](function(){return{'sql':_0x21d0dc['toString']()};})[_0x3384('0x25')](respondWithResult(_0x4b9381,null))[_0x3384('0x44')](handleError(_0x4b9381,null));};