Built motion from commit 994c64e1.|2.6.1
[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 _0x671e=['Please\x20insert\x20at\x20least\x20one\x20field','findAll','select','from','table','MetricId','metric','function','groupBy','orderBy','DESC','field','alias','joins','parse','parentKey','foreignTable','foreignKey','%s.%s\x20=\x20%s.%s','conditions','clone','debug','toString','sequelize','QueryTypes','SELECT','right_join','getFields','AnalyticMetric','replace','format','order','output','web','fullPath','generate','AnalyticExtractedReport','cdr','.calldate\x20BETWEEN\x20?\x20AND\x20?','endDate','Run\x20Query:','fork','../../components/export/','../../files/reports','savename','countTable','COUNT(*)','runReport','GROUP_CONCAT(%s\x20ORDER\x20BY\x20%s\x20DESC)','keyBy','Limited\x20Query:','eml-format','rimraf','zip-dir','request-promise','moment','mustache','util','path','to-csv','ejs','lodash','squel','crypto','jsforce','querystring','papaparse','ioredis','../../components/parsers/advancedSearch','../../config/license/hardware','../../config/logger','../../config/utils','../../config/environment','../../config/license/util','../../mysqldb','dbH','status','offset','limit','undefined','count','set','json','apply','save','update','then','get','CustomReports','UserProfileResource','destroy','end','sendStatus','error','stack','name','index','AnalyticCustomReport','fieldName','type','model','map','query','intersection','fields','attributes','length','hasOwnProperty','nolimit','sort','filters','pick','merge','VIRTUAL','filter','options','where','include','rows','catch','show','params','rawAttributes','includeAll','create','body','user','Unable\x20to\x20retrieve\x20the\x20current\x20user','role','Reports','UserProfileSection','userProfileId','Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s','find','preview','join','left_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\x20ASC)','SEC_TO_TIME(%s)','DATE(%s)','HOUR(%s)','ROUND(%s)','UNIX_TIMESTAMP(%s)','includes','IS\x20NULL','IS\x20NOT\x20NULL','IS\x20EMPTY','IS\x20NOT\x20EMPTY','rules','operator','group','condition','value','Sequelize','ValidationErrorItem'];(function(_0x2bfd60,_0x46342b){var _0x3f6f9f=function(_0xf9ef08){while(--_0xf9ef08){_0x2bfd60['push'](_0x2bfd60['shift']());}};_0x3f6f9f(++_0x46342b);}(_0x671e,0xd6));var _0xe671=function(_0x1e11e9,_0x42df78){_0x1e11e9=_0x1e11e9-0x0;var _0x3e10b8=_0x671e[_0x1e11e9];return _0x3e10b8;};'use strict';var emlformat=require(_0xe671('0x0'));var rimraf=require(_0xe671('0x1'));var zipdir=require(_0xe671('0x2'));var jsonpatch=require('fast-json-patch');var rp=require(_0xe671('0x3'));var moment=require(_0xe671('0x4'));var BPromise=require('bluebird');var Mustache=require(_0xe671('0x5'));var util=require(_0xe671('0x6'));var path=require(_0xe671('0x7'));var sox=require('sox');var csv=require(_0xe671('0x8'));var ejs=require(_0xe671('0x9'));var fs=require('fs');var fs_extra=require('fs-extra');var _=require(_0xe671('0xa'));var squel=require(_0xe671('0xb'));var crypto=require(_0xe671('0xc'));var jsforce=require(_0xe671('0xd'));var deskjs=require('desk.js');var toCsv=require(_0xe671('0x8'));var querystring=require(_0xe671('0xe'));var Papa=require(_0xe671('0xf'));var Redis=require(_0xe671('0x10'));var authService=require('../../components/auth/service');var qs=require('../../components/parsers/qs');var as=require(_0xe671('0x11'));var hardwareService=require(_0xe671('0x12'));var logger=require(_0xe671('0x13'))('api');var utils=require(_0xe671('0x14'));var config=require(_0xe671('0x15'));var licenseUtil=require(_0xe671('0x16'));var db=require(_0xe671('0x17'))['db'];var dbH=require('../../mysqldb')[_0xe671('0x18')];function respondWithStatusCode(_0x4f8054,_0x1f2f78){_0x1f2f78=_0x1f2f78||0xcc;return function(_0x52757d){if(_0x52757d){return _0x4f8054['sendStatus'](_0x1f2f78);}return _0x4f8054['status'](_0x1f2f78)['end']();};}function respondWithResult(_0xcf6e92,_0x838c9a){_0x838c9a=_0x838c9a||0xc8;return function(_0x2e59f3){if(_0x2e59f3){return _0xcf6e92[_0xe671('0x19')](_0x838c9a)['json'](_0x2e59f3);}};}function respondWithFilteredResult(_0x19d49c,_0x6aea49){return function(_0x297452){if(_0x297452){var _0x29cae4=typeof _0x6aea49[_0xe671('0x1a')]==='undefined'&&typeof _0x6aea49[_0xe671('0x1b')]===_0xe671('0x1c');var _0x3ef34b=_0x297452[_0xe671('0x1d')];var _0xf28a70=_0x29cae4?0x0:_0x6aea49[_0xe671('0x1a')];var _0x1a94be=_0x29cae4?_0x297452[_0xe671('0x1d')]:_0x6aea49['offset']+_0x6aea49[_0xe671('0x1b')];var _0x32484a;if(_0x1a94be>=_0x3ef34b){_0x1a94be=_0x3ef34b;_0x32484a=0xc8;}else{_0x32484a=0xce;}_0x19d49c[_0xe671('0x19')](_0x32484a);return _0x19d49c[_0xe671('0x1e')]('Content-Range',_0xf28a70+'-'+_0x1a94be+'/'+_0x3ef34b)[_0xe671('0x1f')](_0x297452);}return null;};}function patchUpdates(_0x5d5672){return function(_0x1acc81){try{jsonpatch[_0xe671('0x20')](_0x1acc81,_0x5d5672,!![]);}catch(_0x59c49c){return BPromise['reject'](_0x59c49c);}return _0x1acc81[_0xe671('0x21')]();};}function saveUpdates(_0x23f1db,_0x4a9230){return function(_0x4b0b2a){if(_0x4b0b2a){return _0x4b0b2a[_0xe671('0x22')](_0x23f1db)['then'](function(_0x1479e9){return _0x1479e9;});}return null;};}function removeEntity(_0x511ff5,_0x285471){return function(_0x3cf8e1){if(_0x3cf8e1){return _0x3cf8e1['destroy']()[_0xe671('0x23')](function(){var _0x15e433=_0x3cf8e1[_0xe671('0x24')]({'plain':!![]});var _0x5bfaf8=_0xe671('0x25');return db[_0xe671('0x26')][_0xe671('0x27')]({'where':{'type':_0x5bfaf8,'resourceId':_0x15e433['id']}})['then'](function(){return _0x3cf8e1;});})[_0xe671('0x23')](function(){_0x511ff5[_0xe671('0x19')](0xcc)[_0xe671('0x28')]();});}};}function handleEntityNotFound(_0x559872,_0x1e1d55){return function(_0x6daba5){if(!_0x6daba5){_0x559872[_0xe671('0x29')](0x194);}return _0x6daba5;};}function handleError(_0x385f4f,_0x53dc22){_0x53dc22=_0x53dc22||0x1f4;return function(_0x1a20aa){logger[_0xe671('0x2a')](_0x1a20aa[_0xe671('0x2b')]);if(_0x1a20aa['name']){delete _0x1a20aa[_0xe671('0x2c')];}_0x385f4f[_0xe671('0x19')](_0x53dc22)['send'](_0x1a20aa);};}exports[_0xe671('0x2d')]=function(_0x3e319a,_0x18e95b){var _0x28f014={},_0x3c6ac5={},_0x1c045f={'count':0x0,'rows':[]};var _0x2cb1fc=_['map'](db[_0xe671('0x2e')]['rawAttributes'],function(_0x9e59e3){return{'name':_0x9e59e3[_0xe671('0x2f')],'type':_0x9e59e3[_0xe671('0x30')]['key']};});_0x3c6ac5[_0xe671('0x31')]=_[_0xe671('0x32')](_0x2cb1fc,'name');_0x3c6ac5['query']=_['keys'](_0x3e319a[_0xe671('0x33')]);_0x3c6ac5['filters']=_[_0xe671('0x34')](_0x3c6ac5[_0xe671('0x31')],_0x3c6ac5['query']);_0x28f014['attributes']=_[_0xe671('0x34')](_0x3c6ac5[_0xe671('0x31')],qs[_0xe671('0x35')](_0x3e319a[_0xe671('0x33')]['fields']));_0x28f014[_0xe671('0x36')]=_0x28f014[_0xe671('0x36')][_0xe671('0x37')]?_0x28f014[_0xe671('0x36')]:_0x3c6ac5['model'];if(!_0x3e319a['query'][_0xe671('0x38')](_0xe671('0x39'))){_0x28f014[_0xe671('0x1b')]=qs[_0xe671('0x1b')](_0x3e319a[_0xe671('0x33')][_0xe671('0x1b')]);_0x28f014[_0xe671('0x1a')]=qs[_0xe671('0x1a')](_0x3e319a[_0xe671('0x33')][_0xe671('0x1a')]);}_0x28f014['order']=qs[_0xe671('0x3a')](_0x3e319a[_0xe671('0x33')][_0xe671('0x3a')]);_0x28f014['where']=qs[_0xe671('0x3b')](_[_0xe671('0x3c')](_0x3e319a[_0xe671('0x33')],_0x3c6ac5['filters']),_0x2cb1fc);if(_0x3e319a['query']['filter']){_0x28f014['where']=_[_0xe671('0x3d')](_0x28f014['where'],{'$or':_[_0xe671('0x32')](_0x2cb1fc,function(_0x313f79){if(_0x313f79[_0xe671('0x30')]!==_0xe671('0x3e')){var _0x2bcc39={};_0x2bcc39[_0x313f79['name']]={'$like':'%'+_0x3e319a[_0xe671('0x33')][_0xe671('0x3f')]+'%'};return _0x2bcc39;}})});}_0x28f014=_[_0xe671('0x3d')]({},_0x28f014,_0x3e319a[_0xe671('0x40')]);var _0x23bb9d={'where':_0x28f014[_0xe671('0x41')]};return db[_0xe671('0x2e')][_0xe671('0x1d')](_0x23bb9d)[_0xe671('0x23')](function(_0x226a42){_0x1c045f['count']=_0x226a42;if(_0x3e319a[_0xe671('0x33')]['includeAll']){_0x28f014[_0xe671('0x42')]=[{'all':!![]}];}return db[_0xe671('0x2e')]['findAll'](_0x28f014);})['then'](function(_0x4626ec){_0x1c045f[_0xe671('0x43')]=_0x4626ec;return _0x1c045f;})[_0xe671('0x23')](respondWithFilteredResult(_0x18e95b,_0x28f014))[_0xe671('0x44')](handleError(_0x18e95b,null));};exports[_0xe671('0x45')]=function(_0x8a4e28,_0x354b72){var _0x4eb647={'raw':![],'where':{'id':_0x8a4e28[_0xe671('0x46')]['id']}},_0x2ce22a={};_0x2ce22a[_0xe671('0x31')]=_['keys'](db['AnalyticCustomReport'][_0xe671('0x47')]);_0x2ce22a[_0xe671('0x33')]=_['keys'](_0x8a4e28[_0xe671('0x33')]);_0x2ce22a['filters']=_[_0xe671('0x34')](_0x2ce22a[_0xe671('0x31')],_0x2ce22a[_0xe671('0x33')]);_0x4eb647[_0xe671('0x36')]=_['intersection'](_0x2ce22a[_0xe671('0x31')],qs[_0xe671('0x35')](_0x8a4e28['query']['fields']));_0x4eb647['attributes']=_0x4eb647[_0xe671('0x36')][_0xe671('0x37')]?_0x4eb647['attributes']:_0x2ce22a[_0xe671('0x31')];if(_0x8a4e28[_0xe671('0x33')][_0xe671('0x48')]){_0x4eb647['include']=[{'all':!![]}];}_0x4eb647=_[_0xe671('0x3d')]({},_0x4eb647,_0x8a4e28['options']);return db[_0xe671('0x2e')]['find'](_0x4eb647)[_0xe671('0x23')](handleEntityNotFound(_0x354b72,null))[_0xe671('0x23')](respondWithResult(_0x354b72,null))[_0xe671('0x44')](handleError(_0x354b72,null));};exports['create']=function(_0x49b429,_0x1bc418){return db[_0xe671('0x2e')][_0xe671('0x49')](_0x49b429[_0xe671('0x4a')],{})[_0xe671('0x23')](function(_0x218ef3){var _0x293529=_0x49b429[_0xe671('0x4b')]['get']({'plain':!![]});if(!_0x293529)throw new Error(_0xe671('0x4c'));if(_0x293529[_0xe671('0x4d')]===_0xe671('0x4b')){var _0x3b0afc=_0x218ef3['get']({'plain':!![]});var _0x4ce59a=_0xe671('0x4e');return db[_0xe671('0x4f')]['find']({'where':{'name':_0x4ce59a,'userProfileId':_0x293529[_0xe671('0x50')]},'raw':!![]})[_0xe671('0x23')](function(_0x532525){if(_0x532525&&_0x532525['autoAssociation']===0x0){return db[_0xe671('0x26')][_0xe671('0x49')]({'name':_0x3b0afc[_0xe671('0x2c')],'resourceId':_0x3b0afc['id'],'type':_0xe671('0x25'),'sectionId':_0x532525['id']},{})['then'](function(){return _0x218ef3;});}else{return _0x218ef3;}})['catch'](function(_0x432640){logger[_0xe671('0x2a')](_0xe671('0x51'),_0x432640);throw _0x432640;});}return _0x218ef3;})[_0xe671('0x23')](respondWithResult(_0x1bc418,0xc9))[_0xe671('0x44')](handleError(_0x1bc418,null));};exports[_0xe671('0x22')]=function(_0xfebefe,_0x18bcbc){if(_0xfebefe[_0xe671('0x4a')]['id']){delete _0xfebefe[_0xe671('0x4a')]['id'];}return db[_0xe671('0x2e')][_0xe671('0x52')]({'where':{'id':_0xfebefe[_0xe671('0x46')]['id']}})[_0xe671('0x23')](handleEntityNotFound(_0x18bcbc,null))[_0xe671('0x23')](saveUpdates(_0xfebefe['body'],null))['then'](respondWithResult(_0x18bcbc,null))[_0xe671('0x44')](handleError(_0x18bcbc,null));};exports[_0xe671('0x27')]=function(_0x63212f,_0x2c0c46){return db[_0xe671('0x2e')]['find']({'where':{'id':_0x63212f['params']['id']}})['then'](handleEntityNotFound(_0x2c0c46,null))[_0xe671('0x23')](removeEntity(_0x2c0c46,null))['catch'](handleError(_0x2c0c46,null));};exports[_0xe671('0x53')]=function(_0x30453c,_0x3fae41){var _0x2e7f44=0xa;var _0x924de5=[_0xe671('0x54'),_0xe671('0x55'),'right_join',_0xe671('0x56')];var _0x5a2ac2={'SUM':_0xe671('0x57'),'COUNT':_0xe671('0x58'),'COUNT DISTINCT':_0xe671('0x59'),'MAX':_0xe671('0x5a'),'MIN':_0xe671('0x5b'),'AVG':_0xe671('0x5c'),'GROUP_CONCAT':_0xe671('0x5d'),'GROUP_CONCAT ASC':_0xe671('0x5e'),'GROUP_CONCAT DESC':'GROUP_CONCAT(%s\x20ORDER\x20BY\x20%s\x20DESC)'};var _0x25a18c={'SEC_TO_TIME':_0xe671('0x5f'),'DATE':_0xe671('0x60'),'HOUR':_0xe671('0x61'),'ROUND':_0xe671('0x62'),'UNIX_TIMESTAMP':_0xe671('0x63')};var _0x1b2fca=function(_0x12f1ca){return!_[_0xe671('0x64')]([_0xe671('0x65'),_0xe671('0x66'),_0xe671('0x67'),_0xe671('0x68')],_0x12f1ca);};var _0xbfd56f=function(_0x68e5e7){if(!_0x68e5e7||!_0x68e5e7[_0xe671('0x69')][_0xe671('0x37')]){return'';}for(var _0x5cca13='(',_0x589f10=0x0;_0x589f10<_0x68e5e7['rules'][_0xe671('0x37')];_0x589f10+=0x1){_0x589f10>0x0&&(_0x5cca13+='\x20'+_0x68e5e7[_0xe671('0x6a')]+'\x20');_0x5cca13+=_0x68e5e7['rules'][_0x589f10][_0xe671('0x6b')]?_0xbfd56f(_0x68e5e7[_0xe671('0x69')][_0x589f10]['group']):_0x68e5e7['rules'][_0x589f10]['field']+'\x20'+_0x68e5e7[_0xe671('0x69')][_0x589f10][_0xe671('0x6c')]+(_0x1b2fca(_0x68e5e7['rules'][_0x589f10][_0xe671('0x6c')])?'\x20'+_0x68e5e7[_0xe671('0x69')][_0x589f10][_0xe671('0x6d')]:'');}return _0x5cca13+')';};var _0x429eff={'where':{'id':_0x30453c[_0xe671('0x46')]['id']}},_0x334fef,_0x4e1e2c,_0x3943b8,_0x2023f2,_0x52f7b5;_0x429eff=_[_0xe671('0x3d')]({},_0x429eff,_0x30453c[_0xe671('0x40')]);return db[_0xe671('0x2e')][_0xe671('0x52')](_0x429eff)[_0xe671('0x23')](function(_0xc81e18){if(_0xc81e18){_0x334fef=_0xc81e18;return _0xc81e18['getFields']();}return null;})[_0xe671('0x23')](function(_0x3c623c){if(_0x3c623c){if(!_0x3c623c[_0xe671('0x37')]){throw new db[(_0xe671('0x6e'))][(_0xe671('0x6f'))](_0xe671('0x70'),0x193);}_0x4e1e2c=_0x3c623c;return db['AnalyticMetric'][_0xe671('0x71')]({'raw':!![]});}return null;})[_0xe671('0x23')](function(_0x2e6ce1){if(_0x2e6ce1){_0x3943b8=_['keyBy'](_0x2e6ce1,'id');var _0x544866;var _0x72bf00=squel[_0xe671('0x72')]();_0x72bf00[_0xe671('0x73')](_0x334fef[_0xe671('0x74')]);for(var _0x35b39e=0x0;_0x35b39e<_0x4e1e2c[_0xe671('0x37')];_0x35b39e+=0x1){_0x544866=_0x4e1e2c[_0x35b39e][_0xe671('0x75')]?_0x3943b8[_0x4e1e2c[_0x35b39e][_0xe671('0x75')]][_0xe671('0x76')]:_0x4e1e2c[_0x35b39e]['field'];_0x544866=_0x4e1e2c[_0x35b39e][_0xe671('0x77')]?_['replace'](_0x5a2ac2[_0x4e1e2c[_0x35b39e][_0xe671('0x77')]],'%s',_0x544866):_0x544866;_0x544866=_0x4e1e2c[_0x35b39e]['format']?_['replace'](_0x25a18c[_0x4e1e2c[_0x35b39e]['format']],'%s',_0x544866):_0x544866;if(_0x4e1e2c[_0x35b39e][_0xe671('0x78')]){_0x72bf00[_0xe671('0x6b')](_0x544866);}_0x4e1e2c[_0x35b39e]['orderBy']&&_0x72bf00['order'](_0x544866,_0x4e1e2c[_0x35b39e][_0xe671('0x79')]===_0xe671('0x7a')?![]:!![]);_0x72bf00[_0xe671('0x7b')](_0x544866,_0x4e1e2c[_0x35b39e][_0xe671('0x7c')]||_0x544866);}if(_0x334fef[_0xe671('0x7d')]){_0x334fef[_0xe671('0x7d')]=JSON[_0xe671('0x7e')](_0x334fef[_0xe671('0x7d')]);for(var _0x232240=0x0;_0x232240<_0x334fef[_0xe671('0x7d')]['length'];_0x232240+=0x1){if(_0x334fef[_0xe671('0x7d')][_0x232240]['type']&&_['includes'](_0x924de5,_0x334fef[_0xe671('0x7d')][_0x232240][_0xe671('0x30')])&&_0x334fef[_0xe671('0x7d')][_0x232240][_0xe671('0x7f')]&&_0x334fef[_0xe671('0x7d')][_0x232240][_0xe671('0x80')]&&_0x334fef[_0xe671('0x7d')][_0x232240][_0xe671('0x81')]){_0x72bf00[_0x334fef[_0xe671('0x7d')][_0x232240][_0xe671('0x30')]](_0x334fef[_0xe671('0x7d')][_0x232240][_0xe671('0x80')],null,util['format'](_0xe671('0x82'),_0x334fef[_0xe671('0x74')],_0x334fef[_0xe671('0x7d')][_0x232240][_0xe671('0x7f')],_0x334fef[_0xe671('0x7d')][_0x232240][_0xe671('0x80')],_0x334fef[_0xe671('0x7d')][_0x232240]['foreignKey']));}}}if(_0x334fef['conditions']){_0x334fef[_0xe671('0x83')]=JSON['parse'](_0x334fef[_0xe671('0x83')]);_0x72bf00[_0xe671('0x41')](_0xbfd56f(_0x334fef['conditions'][_0xe671('0x6b')]));}_0x52f7b5=_0x72bf00[_0xe671('0x84')]();_0x72bf00[_0xe671('0x1b')](_0x2e7f44);_0x72bf00[_0xe671('0x1a')](0x0);logger[_0xe671('0x85')]('Limited\x20Query:',_0x72bf00[_0xe671('0x86')]());return dbH[_0xe671('0x87')][_0xe671('0x33')](_0x72bf00[_0xe671('0x86')](),{'type':dbH[_0xe671('0x87')][_0xe671('0x88')][_0xe671('0x89')]});}})['then'](respondWithResult(_0x3fae41,null))['catch'](handleError(_0x3fae41,null));};function runReport(_0x82b5aa,_0x4bf993,_0x3d5404){var _0x2adeae=_0x4bf993['name'];var _0x52005c=0xa;var _0x4a4642=['join','left_join',_0xe671('0x8a'),_0xe671('0x56')];var _0x538f84={'SUM':'SUM(%s)','COUNT':_0xe671('0x58'),'COUNT DISTINCT':_0xe671('0x59'),'MAX':'MAX(%s)','MIN':_0xe671('0x5b'),'AVG':_0xe671('0x5c'),'GROUP_CONCAT':'GROUP_CONCAT(%s)','GROUP_CONCAT ASC':_0xe671('0x5e'),'GROUP_CONCAT DESC':'GROUP_CONCAT(%s\x20ORDER\x20BY\x20%s\x20DESC)'};var _0x1dcd87={'SEC_TO_TIME':'SEC_TO_TIME(%s)','DATE':_0xe671('0x60'),'HOUR':_0xe671('0x61'),'ROUND':_0xe671('0x62'),'UNIX_TIMESTAMP':'UNIX_TIMESTAMP(%s)'};var _0x34e0cf=function(_0x209536){return!_[_0xe671('0x64')]([_0xe671('0x65'),_0xe671('0x66'),'IS\x20EMPTY','IS\x20NOT\x20EMPTY'],_0x209536);};var _0x4c1a7f=function(_0x312cd6){if(!_0x312cd6||!_0x312cd6['rules']['length']){return'';}for(var _0x1e5481='(',_0x51d77a=0x0;_0x51d77a<_0x312cd6[_0xe671('0x69')][_0xe671('0x37')];_0x51d77a+=0x1){_0x51d77a>0x0&&(_0x1e5481+='\x20'+_0x312cd6[_0xe671('0x6a')]+'\x20');_0x1e5481+=_0x312cd6['rules'][_0x51d77a][_0xe671('0x6b')]?_0x4c1a7f(_0x312cd6[_0xe671('0x69')][_0x51d77a][_0xe671('0x6b')]):_0x312cd6[_0xe671('0x69')][_0x51d77a][_0xe671('0x7b')]+'\x20'+_0x312cd6[_0xe671('0x69')][_0x51d77a][_0xe671('0x6c')]+(_0x34e0cf(_0x312cd6[_0xe671('0x69')][_0x51d77a]['condition'])?'\x20'+_0x312cd6[_0xe671('0x69')][_0x51d77a][_0xe671('0x6d')]:'');}return _0x1e5481+')';};var _0x2bcd94={'where':{'id':_0x82b5aa['id']}},_0x370399,_0x6c3e16,_0x16f673,_0xec66d6,_0x485aef;_0x2bcd94=_[_0xe671('0x3d')]({},_0x2bcd94,_0x3d5404);return db[_0xe671('0x2e')][_0xe671('0x52')](_0x2bcd94)[_0xe671('0x23')](function(_0x37a926){if(_0x37a926){_0x370399=_0x37a926;return _0x37a926[_0xe671('0x8b')]();}return null;})[_0xe671('0x23')](function(_0x5117eb){if(_0x5117eb){if(!_0x5117eb[_0xe671('0x37')]){throw new db[(_0xe671('0x6e'))][(_0xe671('0x6f'))]('Please\x20insert\x20at\x20least\x20one\x20field',0x193);}_0x6c3e16=_0x5117eb;return db[_0xe671('0x8c')]['findAll']({'raw':!![]});}return null;})[_0xe671('0x23')](function(_0x5499eb){if(_0x5499eb){_0x16f673=_['keyBy'](_0x5499eb,'id');var _0x4d212c;var _0x2a55c8=squel[_0xe671('0x72')]();_0x2a55c8[_0xe671('0x73')](_0x370399[_0xe671('0x74')]);for(var _0x537df5=0x0;_0x537df5<_0x6c3e16['length'];_0x537df5+=0x1){_0x4d212c=_0x6c3e16[_0x537df5][_0xe671('0x75')]?_0x16f673[_0x6c3e16[_0x537df5][_0xe671('0x75')]][_0xe671('0x76')]:_0x6c3e16[_0x537df5][_0xe671('0x7b')];_0x4d212c=_0x6c3e16[_0x537df5][_0xe671('0x77')]?_[_0xe671('0x8d')](_0x538f84[_0x6c3e16[_0x537df5][_0xe671('0x77')]],'%s',_0x4d212c):_0x4d212c;_0x4d212c=_0x6c3e16[_0x537df5][_0xe671('0x8e')]?_['replace'](_0x1dcd87[_0x6c3e16[_0x537df5]['format']],'%s',_0x4d212c):_0x4d212c;if(_0x6c3e16[_0x537df5][_0xe671('0x78')]){_0x2a55c8['group'](_0x4d212c);}_0x6c3e16[_0x537df5]['orderBy']&&_0x2a55c8[_0xe671('0x8f')](_0x4d212c,_0x6c3e16[_0x537df5][_0xe671('0x79')]===_0xe671('0x7a')?![]:!![]);_0x2a55c8[_0xe671('0x7b')](_0x4d212c,_0x6c3e16[_0x537df5][_0xe671('0x7c')]||_0x4d212c);}if(_0x370399[_0xe671('0x7d')]){_0x370399[_0xe671('0x7d')]=JSON[_0xe671('0x7e')](_0x370399[_0xe671('0x7d')]);for(var _0x21db9b=0x0;_0x21db9b<_0x370399['joins'][_0xe671('0x37')];_0x21db9b+=0x1){if(_0x370399[_0xe671('0x7d')][_0x21db9b]['type']&&_['includes'](_0x4a4642,_0x370399['joins'][_0x21db9b][_0xe671('0x30')])&&_0x370399[_0xe671('0x7d')][_0x21db9b][_0xe671('0x7f')]&&_0x370399['joins'][_0x21db9b][_0xe671('0x80')]&&_0x370399['joins'][_0x21db9b]['foreignKey']){_0x2a55c8[_0x370399[_0xe671('0x7d')][_0x21db9b][_0xe671('0x30')]](_0x370399['joins'][_0x21db9b][_0xe671('0x80')],null,util[_0xe671('0x8e')](_0xe671('0x82'),_0x370399['table'],_0x370399[_0xe671('0x7d')][_0x21db9b][_0xe671('0x7f')],_0x370399[_0xe671('0x7d')][_0x21db9b]['foreignTable'],_0x370399[_0xe671('0x7d')][_0x21db9b][_0xe671('0x81')]));}}}if(_0x370399[_0xe671('0x83')]){_0x370399[_0xe671('0x83')]=JSON['parse'](_0x370399['conditions']);_0x2a55c8[_0xe671('0x41')](_0x4c1a7f(_0x370399['conditions'][_0xe671('0x6b')]));}_0x485aef=_0x2a55c8['clone']();_0x2a55c8[_0xe671('0x1b')](_0x52005c);_0x2a55c8['offset'](0x0);return;}})[_0xe671('0x23')](function(){if(_0x4bf993[_0xe671('0x90')]===_0xe671('0x91')){return null;}var _0x43c454=_[_0xe671('0x3d')](_0x4bf993,{'name':_0x4bf993[_0xe671('0x92')]||_0x4bf993['name']||_0x370399['name'],'basename':_0x2adeae,'savename':util[_0xe671('0x8e')]('%s-%s.%s',_0x4bf993[_0xe671('0x2c')]||_0x370399['name'],require('randomstring')[_0xe671('0x93')](0x4),_0x4bf993[_0xe671('0x90')]||'csv'),'reportId':_0x370399['id'],'reportType':'custom'});return db[_0xe671('0x94')][_0xe671('0x49')](_0x43c454,{'raw':!![]});})[_0xe671('0x23')](function(_0x57ffbf){if(_0x370399[_0xe671('0x74')]===_0xe671('0x95')){_0x485aef[_0xe671('0x41')](_0x370399[_0xe671('0x74')]+_0xe671('0x96'),_0x4bf993['startDate'],_0x4bf993[_0xe671('0x97')]);}else{_0x485aef[_0xe671('0x41')](_0x370399[_0xe671('0x74')]+'.createdAt\x20BETWEEN\x20?\x20AND\x20?',_0x4bf993['startDate'],_0x4bf993['endDate']);}if(_0x57ffbf){logger['info'](_0xe671('0x98'),_0x485aef[_0xe671('0x86')]());require('child_process')[_0xe671('0x99')](path[_0xe671('0x54')](__dirname,_0xe671('0x9a'),_0x57ffbf[_0xe671('0x90')]),[_0x57ffbf['id'],_0x485aef[_0xe671('0x86')](),path[_0xe671('0x54')](__dirname,_0xe671('0x9b'),_0x57ffbf[_0xe671('0x9c')]),_0x2adeae]);return _0x57ffbf;}else{var _0x18c7fd=squel[_0xe671('0x72')]();_0x18c7fd[_0xe671('0x73')]('('+_0x485aef['toString']()+')',_0xe671('0x9d'));_0x18c7fd[_0xe671('0x7b')](_0xe671('0x9e'),_0xe671('0x1d'));_0x485aef[_0xe671('0x1b')](_0x4bf993[_0xe671('0x1b')]||_0x52005c);_0x485aef['offset'](_0x4bf993['offset']||0x0);return dbH[_0xe671('0x87')][_0xe671('0x33')](_0x18c7fd[_0xe671('0x86')](),{'type':dbH[_0xe671('0x87')][_0xe671('0x88')]['SELECT']})[_0xe671('0x23')](function(_0x470c0a){if(!_0x470c0a[_0xe671('0x37')]){_0xec66d6=0x0;}else{_0xec66d6=_0x470c0a[0x0][_0xe671('0x1d')]||0x0;}return dbH[_0xe671('0x87')][_0xe671('0x33')](_0x485aef['toString'](),{'type':dbH[_0xe671('0x87')]['QueryTypes'][_0xe671('0x89')]});})['then'](function(_0x545446){return{'rows':_0x545446||[],'count':_0xec66d6};});}});}exports['run']=function(_0x130b56,_0x455bb2){return runReport(_0x130b56[_0xe671('0x46')],_0x130b56['query'],_0x130b56[_0xe671('0x40')])['then'](respondWithResult(_0x455bb2,null))['catch'](handleError(_0x455bb2,null));};exports[_0xe671('0x9f')]=runReport;exports[_0xe671('0x33')]=function(_0x5f23d4,_0x5e5a24){var _0x3d5b14=0xa;var _0x156a7e=[_0xe671('0x54'),_0xe671('0x55'),_0xe671('0x8a'),'cross_join'];var _0x27824f={'SUM':'SUM(%s)','COUNT':_0xe671('0x58'),'COUNT DISTINCT':'COUNT(DISTINCT\x20%s)','MAX':_0xe671('0x5a'),'MIN':'MIN(%s)','AVG':_0xe671('0x5c'),'GROUP_CONCAT':_0xe671('0x5d'),'GROUP_CONCAT ASC':_0xe671('0x5e'),'GROUP_CONCAT DESC':_0xe671('0xa0')};var _0x546a2a={'SEC_TO_TIME':_0xe671('0x5f'),'DATE':_0xe671('0x60'),'HOUR':_0xe671('0x61'),'ROUND':_0xe671('0x62'),'UNIX_TIMESTAMP':'UNIX_TIMESTAMP(%s)'};var _0xbc8e4a=function(_0x2b559e){return!_[_0xe671('0x64')]([_0xe671('0x65'),_0xe671('0x66'),'IS\x20EMPTY',_0xe671('0x68')],_0x2b559e);};var _0xd205e0=function(_0x5f124e){if(!_0x5f124e||!_0x5f124e[_0xe671('0x69')][_0xe671('0x37')]){return'';}for(var _0xe6b01f='(',_0x4feda3=0x0;_0x4feda3<_0x5f124e[_0xe671('0x69')][_0xe671('0x37')];_0x4feda3+=0x1){_0x4feda3>0x0&&(_0xe6b01f+='\x20'+_0x5f124e[_0xe671('0x6a')]+'\x20');_0xe6b01f+=_0x5f124e['rules'][_0x4feda3]['group']?_0xd205e0(_0x5f124e[_0xe671('0x69')][_0x4feda3][_0xe671('0x6b')]):_0x5f124e['rules'][_0x4feda3][_0xe671('0x7b')]+'\x20'+_0x5f124e['rules'][_0x4feda3][_0xe671('0x6c')]+(_0xbc8e4a(_0x5f124e[_0xe671('0x69')][_0x4feda3]['condition'])?'\x20'+_0x5f124e['rules'][_0x4feda3][_0xe671('0x6d')]:'');}return _0xe6b01f+')';};var _0x21d7fe={'where':{'id':_0x5f23d4['params']['id']}},_0x146658,_0x4ef916,_0x47fffb,_0x212769,_0x305afd;_0x21d7fe=_[_0xe671('0x3d')]({},_0x21d7fe,_0x5f23d4[_0xe671('0x40')]);return db[_0xe671('0x2e')][_0xe671('0x52')](_0x21d7fe)[_0xe671('0x23')](function(_0x5e8728){if(_0x5e8728){_0x146658=_0x5e8728;return _0x5e8728[_0xe671('0x8b')]();}return null;})[_0xe671('0x23')](function(_0x13f2cc){if(_0x13f2cc){if(!_0x13f2cc[_0xe671('0x37')]){throw new db[(_0xe671('0x6e'))][(_0xe671('0x6f'))](_0xe671('0x70'),0x193);}_0x4ef916=_0x13f2cc;return db[_0xe671('0x8c')]['findAll']({'raw':!![]});}return null;})[_0xe671('0x23')](function(_0x191589){if(_0x191589){_0x47fffb=_[_0xe671('0xa1')](_0x191589,'id');var _0x25a48d;var _0x3398e6=squel[_0xe671('0x72')]();_0x3398e6[_0xe671('0x73')](_0x146658['table']);for(var _0x18757f=0x0;_0x18757f<_0x4ef916[_0xe671('0x37')];_0x18757f+=0x1){_0x25a48d=_0x4ef916[_0x18757f][_0xe671('0x75')]?_0x47fffb[_0x4ef916[_0x18757f][_0xe671('0x75')]][_0xe671('0x76')]:_0x4ef916[_0x18757f]['field'];_0x25a48d=_0x4ef916[_0x18757f][_0xe671('0x77')]?_[_0xe671('0x8d')](_0x27824f[_0x4ef916[_0x18757f][_0xe671('0x77')]],'%s',_0x25a48d):_0x25a48d;_0x25a48d=_0x4ef916[_0x18757f][_0xe671('0x8e')]?_[_0xe671('0x8d')](_0x546a2a[_0x4ef916[_0x18757f][_0xe671('0x8e')]],'%s',_0x25a48d):_0x25a48d;if(_0x4ef916[_0x18757f][_0xe671('0x78')]){_0x3398e6[_0xe671('0x6b')](_0x25a48d);}_0x4ef916[_0x18757f][_0xe671('0x79')]&&_0x3398e6['order'](_0x25a48d,_0x4ef916[_0x18757f][_0xe671('0x79')]==='DESC'?![]:!![]);_0x3398e6[_0xe671('0x7b')](_0x25a48d,_0x4ef916[_0x18757f][_0xe671('0x7c')]||_0x25a48d);}if(_0x146658[_0xe671('0x7d')]){_0x146658[_0xe671('0x7d')]=JSON[_0xe671('0x7e')](_0x146658[_0xe671('0x7d')]);for(var _0x150f0e=0x0;_0x150f0e<_0x146658[_0xe671('0x7d')][_0xe671('0x37')];_0x150f0e+=0x1){if(_0x146658[_0xe671('0x7d')][_0x150f0e][_0xe671('0x30')]&&_[_0xe671('0x64')](_0x156a7e,_0x146658[_0xe671('0x7d')][_0x150f0e][_0xe671('0x30')])&&_0x146658[_0xe671('0x7d')][_0x150f0e][_0xe671('0x7f')]&&_0x146658[_0xe671('0x7d')][_0x150f0e][_0xe671('0x80')]&&_0x146658['joins'][_0x150f0e]['foreignKey']){_0x3398e6[_0x146658[_0xe671('0x7d')][_0x150f0e][_0xe671('0x30')]](_0x146658['joins'][_0x150f0e][_0xe671('0x80')],null,util[_0xe671('0x8e')](_0xe671('0x82'),_0x146658[_0xe671('0x74')],_0x146658[_0xe671('0x7d')][_0x150f0e]['parentKey'],_0x146658[_0xe671('0x7d')][_0x150f0e][_0xe671('0x80')],_0x146658[_0xe671('0x7d')][_0x150f0e]['foreignKey']));}}}if(_0x146658[_0xe671('0x83')]){_0x146658[_0xe671('0x83')]=JSON[_0xe671('0x7e')](_0x146658[_0xe671('0x83')]);_0x3398e6[_0xe671('0x41')](_0xd205e0(_0x146658[_0xe671('0x83')][_0xe671('0x6b')]));}_0x305afd=_0x3398e6[_0xe671('0x84')]();_0x3398e6[_0xe671('0x1b')](_0x3d5b14);_0x3398e6[_0xe671('0x1a')](0x0);logger[_0xe671('0x85')](_0xe671('0xa2'),_0x3398e6['toString']());return dbH[_0xe671('0x87')]['query'](_0x3398e6[_0xe671('0x86')](),{'type':dbH[_0xe671('0x87')]['QueryTypes'][_0xe671('0x89')]});}})['then'](function(){return{'sql':_0x305afd[_0xe671('0x86')]()};})['then'](respondWithResult(_0x5e5a24,null))['catch'](handleError(_0x5e5a24,null));};