Built motion from commit 43538d75.|2.5.35
[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 _0x7095=['COUNT(*)','run','runReport','SEC_TO_TIME(%s)','IS\x20NULL','Limited\x20Query:','rimraf','zip-dir','fast-json-patch','request-promise','moment','bluebird','util','path','sox','to-csv','ejs','fs-extra','lodash','squel','jsforce','querystring','../../components/auth/service','../../components/parsers/advancedSearch','../../config/license/hardware','../../config/logger','api','../../config/utils','../../config/license/util','../../mysqldb','sendStatus','status','end','offset','undefined','set','Content-Range','apply','reject','save','update','then','destroy','get','UserProfileResource','stack','name','send','index','map','AnalyticCustomReport','fieldName','type','key','model','query','filters','attributes','fields','length','nolimit','limit','order','sort','pick','filter','where','VIRTUAL','merge','count','includeAll','include','findAll','show','params','keys','rawAttributes','intersection','options','find','catch','create','body','Unable\x20to\x20retrieve\x20the\x20current\x20user','role','user','Reports','UserProfileSection','userProfileId','autoAssociation','error','Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s','preview','right_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)','GROUP_CONCAT(%s\x20ORDER\x20BY\x20%s\x20DESC)','DATE(%s)','HOUR(%s)','ROUND(%s)','UNIX_TIMESTAMP(%s)','includes','IS\x20NOT\x20NULL','IS\x20EMPTY','rules','operator','group','condition','getFields','ValidationErrorItem','Please\x20insert\x20at\x20least\x20one\x20field','AnalyticMetric','keyBy','from','table','metric','field','function','replace','format','groupBy','orderBy','joins','parentKey','foreignTable','foreignKey','%s.%s\x20=\x20%s.%s','conditions','clone','debug','toString','sequelize','QueryTypes','SELECT','join','left_join','cross_join','IS\x20NOT\x20EMPTY','value','Sequelize','select','MetricId','DESC','alias','parse','output','%s-%s.%s','randomstring','generate','cdr','.calldate\x20BETWEEN\x20?\x20AND\x20?','endDate','.createdAt\x20BETWEEN\x20?\x20AND\x20?','startDate','info','Run\x20Query:','child_process','fork','../../components/export/','../../files/reports','savename','countTable'];(function(_0x397e5f,_0x454c8f){var _0x5302b8=function(_0x1a29ef){while(--_0x1a29ef){_0x397e5f['push'](_0x397e5f['shift']());}};_0x5302b8(++_0x454c8f);}(_0x7095,0xae));var _0x5709=function(_0x2adcaa,_0x261668){_0x2adcaa=_0x2adcaa-0x0;var _0x11101f=_0x7095[_0x2adcaa];return _0x11101f;};'use strict';var emlformat=require('eml-format');var rimraf=require(_0x5709('0x0'));var zipdir=require(_0x5709('0x1'));var jsonpatch=require(_0x5709('0x2'));var rp=require(_0x5709('0x3'));var moment=require(_0x5709('0x4'));var BPromise=require(_0x5709('0x5'));var Mustache=require('mustache');var util=require(_0x5709('0x6'));var path=require(_0x5709('0x7'));var sox=require(_0x5709('0x8'));var csv=require(_0x5709('0x9'));var ejs=require(_0x5709('0xa'));var fs=require('fs');var fs_extra=require(_0x5709('0xb'));var _=require(_0x5709('0xc'));var squel=require(_0x5709('0xd'));var crypto=require('crypto');var jsforce=require(_0x5709('0xe'));var deskjs=require('desk.js');var toCsv=require(_0x5709('0x9'));var querystring=require(_0x5709('0xf'));var Papa=require('papaparse');var Redis=require('ioredis');var authService=require(_0x5709('0x10'));var qs=require('../../components/parsers/qs');var as=require(_0x5709('0x11'));var hardwareService=require(_0x5709('0x12'));var logger=require(_0x5709('0x13'))(_0x5709('0x14'));var utils=require(_0x5709('0x15'));var config=require('../../config/environment');var licenseUtil=require(_0x5709('0x16'));var db=require(_0x5709('0x17'))['db'];var dbH=require(_0x5709('0x17'))['dbH'];function respondWithStatusCode(_0x5adec2,_0x15437f){_0x15437f=_0x15437f||0xcc;return function(_0x226b1f){if(_0x226b1f){return _0x5adec2[_0x5709('0x18')](_0x15437f);}return _0x5adec2[_0x5709('0x19')](_0x15437f)[_0x5709('0x1a')]();};}function respondWithResult(_0x47ced9,_0x28dd5e){_0x28dd5e=_0x28dd5e||0xc8;return function(_0x55f8ab){if(_0x55f8ab){return _0x47ced9[_0x5709('0x19')](_0x28dd5e)['json'](_0x55f8ab);}};}function respondWithFilteredResult(_0xea24cb,_0x5abb4f){return function(_0x442779){if(_0x442779){var _0xce0ab1=typeof _0x5abb4f[_0x5709('0x1b')]===_0x5709('0x1c')&&typeof _0x5abb4f['limit']===_0x5709('0x1c');var _0x41ad28=_0x442779['count'];var _0x4118eb=_0xce0ab1?0x0:_0x5abb4f['offset'];var _0x5a3bda=_0xce0ab1?_0x442779['count']:_0x5abb4f['offset']+_0x5abb4f['limit'];var _0x2acc9a;if(_0x5a3bda>=_0x41ad28){_0x5a3bda=_0x41ad28;_0x2acc9a=0xc8;}else{_0x2acc9a=0xce;}_0xea24cb['status'](_0x2acc9a);return _0xea24cb[_0x5709('0x1d')](_0x5709('0x1e'),_0x4118eb+'-'+_0x5a3bda+'/'+_0x41ad28)['json'](_0x442779);}return null;};}function patchUpdates(_0x140497){return function(_0x1474ad){try{jsonpatch[_0x5709('0x1f')](_0x1474ad,_0x140497,!![]);}catch(_0x55003b){return BPromise[_0x5709('0x20')](_0x55003b);}return _0x1474ad[_0x5709('0x21')]();};}function saveUpdates(_0x28e541,_0x340729){return function(_0x43178a){if(_0x43178a){return _0x43178a[_0x5709('0x22')](_0x28e541)[_0x5709('0x23')](function(_0x44daed){return _0x44daed;});}return null;};}function removeEntity(_0x4ceba9,_0x1b5c27){return function(_0x23b630){if(_0x23b630){return _0x23b630[_0x5709('0x24')]()[_0x5709('0x23')](function(){var _0x1cb95a=_0x23b630[_0x5709('0x25')]({'plain':!![]});var _0x37fa3b='CustomReports';return db[_0x5709('0x26')][_0x5709('0x24')]({'where':{'type':_0x37fa3b,'resourceId':_0x1cb95a['id']}})[_0x5709('0x23')](function(){return _0x23b630;});})[_0x5709('0x23')](function(){_0x4ceba9[_0x5709('0x19')](0xcc)[_0x5709('0x1a')]();});}};}function handleEntityNotFound(_0x2c6c72,_0x469cab){return function(_0x147949){if(!_0x147949){_0x2c6c72['sendStatus'](0x194);}return _0x147949;};}function handleError(_0x14d016,_0xcf18a){_0xcf18a=_0xcf18a||0x1f4;return function(_0x573896){logger['error'](_0x573896[_0x5709('0x27')]);if(_0x573896['name']){delete _0x573896[_0x5709('0x28')];}_0x14d016[_0x5709('0x19')](_0xcf18a)[_0x5709('0x29')](_0x573896);};}exports[_0x5709('0x2a')]=function(_0x140d34,_0x452cfe){var _0x3146a9={},_0x1e883b={},_0xe243f0={'count':0x0,'rows':[]};var _0x5701a7=_[_0x5709('0x2b')](db[_0x5709('0x2c')]['rawAttributes'],function(_0x127090){return{'name':_0x127090[_0x5709('0x2d')],'type':_0x127090[_0x5709('0x2e')][_0x5709('0x2f')]};});_0x1e883b[_0x5709('0x30')]=_[_0x5709('0x2b')](_0x5701a7,_0x5709('0x28'));_0x1e883b[_0x5709('0x31')]=_['keys'](_0x140d34['query']);_0x1e883b[_0x5709('0x32')]=_['intersection'](_0x1e883b[_0x5709('0x30')],_0x1e883b['query']);_0x3146a9[_0x5709('0x33')]=_['intersection'](_0x1e883b['model'],qs[_0x5709('0x34')](_0x140d34[_0x5709('0x31')][_0x5709('0x34')]));_0x3146a9['attributes']=_0x3146a9[_0x5709('0x33')][_0x5709('0x35')]?_0x3146a9[_0x5709('0x33')]:_0x1e883b[_0x5709('0x30')];if(!_0x140d34['query']['hasOwnProperty'](_0x5709('0x36'))){_0x3146a9['limit']=qs[_0x5709('0x37')](_0x140d34[_0x5709('0x31')]['limit']);_0x3146a9[_0x5709('0x1b')]=qs[_0x5709('0x1b')](_0x140d34[_0x5709('0x31')]['offset']);}_0x3146a9[_0x5709('0x38')]=qs[_0x5709('0x39')](_0x140d34[_0x5709('0x31')][_0x5709('0x39')]);_0x3146a9['where']=qs[_0x5709('0x32')](_[_0x5709('0x3a')](_0x140d34[_0x5709('0x31')],_0x1e883b[_0x5709('0x32')]),_0x5701a7);if(_0x140d34[_0x5709('0x31')][_0x5709('0x3b')]){_0x3146a9[_0x5709('0x3c')]=_['merge'](_0x3146a9[_0x5709('0x3c')],{'$or':_[_0x5709('0x2b')](_0x5701a7,function(_0x101187){if(_0x101187[_0x5709('0x2e')]!==_0x5709('0x3d')){var _0x22afaa={};_0x22afaa[_0x101187[_0x5709('0x28')]]={'$like':'%'+_0x140d34[_0x5709('0x31')][_0x5709('0x3b')]+'%'};return _0x22afaa;}})});}_0x3146a9=_[_0x5709('0x3e')]({},_0x3146a9,_0x140d34['options']);var _0x47af33={'where':_0x3146a9['where']};return db['AnalyticCustomReport']['count'](_0x47af33)[_0x5709('0x23')](function(_0x2ca9c4){_0xe243f0[_0x5709('0x3f')]=_0x2ca9c4;if(_0x140d34[_0x5709('0x31')][_0x5709('0x40')]){_0x3146a9[_0x5709('0x41')]=[{'all':!![]}];}return db[_0x5709('0x2c')][_0x5709('0x42')](_0x3146a9);})[_0x5709('0x23')](function(_0x1febbb){_0xe243f0['rows']=_0x1febbb;return _0xe243f0;})[_0x5709('0x23')](respondWithFilteredResult(_0x452cfe,_0x3146a9))['catch'](handleError(_0x452cfe,null));};exports[_0x5709('0x43')]=function(_0x369f3f,_0x227183){var _0x5437ff={'raw':![],'where':{'id':_0x369f3f[_0x5709('0x44')]['id']}},_0x506eaa={};_0x506eaa[_0x5709('0x30')]=_[_0x5709('0x45')](db['AnalyticCustomReport'][_0x5709('0x46')]);_0x506eaa['query']=_[_0x5709('0x45')](_0x369f3f[_0x5709('0x31')]);_0x506eaa[_0x5709('0x32')]=_[_0x5709('0x47')](_0x506eaa[_0x5709('0x30')],_0x506eaa[_0x5709('0x31')]);_0x5437ff[_0x5709('0x33')]=_['intersection'](_0x506eaa[_0x5709('0x30')],qs[_0x5709('0x34')](_0x369f3f[_0x5709('0x31')][_0x5709('0x34')]));_0x5437ff['attributes']=_0x5437ff[_0x5709('0x33')][_0x5709('0x35')]?_0x5437ff[_0x5709('0x33')]:_0x506eaa[_0x5709('0x30')];if(_0x369f3f[_0x5709('0x31')][_0x5709('0x40')]){_0x5437ff[_0x5709('0x41')]=[{'all':!![]}];}_0x5437ff=_['merge']({},_0x5437ff,_0x369f3f[_0x5709('0x48')]);return db[_0x5709('0x2c')][_0x5709('0x49')](_0x5437ff)[_0x5709('0x23')](handleEntityNotFound(_0x227183,null))['then'](respondWithResult(_0x227183,null))[_0x5709('0x4a')](handleError(_0x227183,null));};exports[_0x5709('0x4b')]=function(_0x1b716f,_0xa5643e){return db[_0x5709('0x2c')][_0x5709('0x4b')](_0x1b716f[_0x5709('0x4c')],{})[_0x5709('0x23')](function(_0x5653e1){var _0x213b31=_0x1b716f['user'][_0x5709('0x25')]({'plain':!![]});if(!_0x213b31)throw new Error(_0x5709('0x4d'));if(_0x213b31[_0x5709('0x4e')]===_0x5709('0x4f')){var _0x5c738a=_0x5653e1['get']({'plain':!![]});var _0x2f61fe=_0x5709('0x50');return db[_0x5709('0x51')]['find']({'where':{'name':_0x2f61fe,'userProfileId':_0x213b31[_0x5709('0x52')]},'raw':!![]})[_0x5709('0x23')](function(_0x47067a){if(_0x47067a&&_0x47067a[_0x5709('0x53')]===0x0){return db[_0x5709('0x26')][_0x5709('0x4b')]({'name':_0x5c738a[_0x5709('0x28')],'resourceId':_0x5c738a['id'],'type':'CustomReports','sectionId':_0x47067a['id']},{})[_0x5709('0x23')](function(){return _0x5653e1;});}else{return _0x5653e1;}})[_0x5709('0x4a')](function(_0x2e6149){logger[_0x5709('0x54')](_0x5709('0x55'),_0x2e6149);throw _0x2e6149;});}return _0x5653e1;})['then'](respondWithResult(_0xa5643e,0xc9))[_0x5709('0x4a')](handleError(_0xa5643e,null));};exports[_0x5709('0x22')]=function(_0x52ab31,_0x1d6d6a){if(_0x52ab31['body']['id']){delete _0x52ab31[_0x5709('0x4c')]['id'];}return db[_0x5709('0x2c')][_0x5709('0x49')]({'where':{'id':_0x52ab31[_0x5709('0x44')]['id']}})[_0x5709('0x23')](handleEntityNotFound(_0x1d6d6a,null))['then'](saveUpdates(_0x52ab31[_0x5709('0x4c')],null))['then'](respondWithResult(_0x1d6d6a,null))[_0x5709('0x4a')](handleError(_0x1d6d6a,null));};exports[_0x5709('0x24')]=function(_0x2d6cc3,_0x6caf98){return db[_0x5709('0x2c')]['find']({'where':{'id':_0x2d6cc3[_0x5709('0x44')]['id']}})[_0x5709('0x23')](handleEntityNotFound(_0x6caf98,null))[_0x5709('0x23')](removeEntity(_0x6caf98,null))[_0x5709('0x4a')](handleError(_0x6caf98,null));};exports[_0x5709('0x56')]=function(_0x51dce0,_0x5dd15d){var _0x216443=0xa;var _0x11c51a=['join','left_join',_0x5709('0x57'),'cross_join'];var _0xabc1cf={'SUM':_0x5709('0x58'),'COUNT':_0x5709('0x59'),'COUNT DISTINCT':_0x5709('0x5a'),'MAX':_0x5709('0x5b'),'MIN':_0x5709('0x5c'),'AVG':_0x5709('0x5d'),'GROUP_CONCAT':_0x5709('0x5e'),'GROUP_CONCAT ASC':_0x5709('0x5f'),'GROUP_CONCAT DESC':_0x5709('0x60')};var _0x2adfae={'SEC_TO_TIME':'SEC_TO_TIME(%s)','DATE':_0x5709('0x61'),'HOUR':_0x5709('0x62'),'ROUND':_0x5709('0x63'),'UNIX_TIMESTAMP':_0x5709('0x64')};var _0x30b429=function(_0x3b1c34){return!_[_0x5709('0x65')](['IS\x20NULL',_0x5709('0x66'),_0x5709('0x67'),'IS\x20NOT\x20EMPTY'],_0x3b1c34);};var _0x16467a=function(_0x251f82){if(!_0x251f82||!_0x251f82[_0x5709('0x68')][_0x5709('0x35')]){return'';}for(var _0x4427eb='(',_0xd6861e=0x0;_0xd6861e<_0x251f82[_0x5709('0x68')][_0x5709('0x35')];_0xd6861e+=0x1){_0xd6861e>0x0&&(_0x4427eb+='\x20'+_0x251f82[_0x5709('0x69')]+'\x20');_0x4427eb+=_0x251f82[_0x5709('0x68')][_0xd6861e]['group']?_0x16467a(_0x251f82[_0x5709('0x68')][_0xd6861e][_0x5709('0x6a')]):_0x251f82[_0x5709('0x68')][_0xd6861e]['field']+'\x20'+_0x251f82['rules'][_0xd6861e]['condition']+(_0x30b429(_0x251f82[_0x5709('0x68')][_0xd6861e][_0x5709('0x6b')])?'\x20'+_0x251f82[_0x5709('0x68')][_0xd6861e]['value']:'');}return _0x4427eb+')';};var _0x20fe0e={'where':{'id':_0x51dce0[_0x5709('0x44')]['id']}},_0x2043c7,_0x4c5480,_0x6c2e3c,_0x18d189,_0xa1a57c;_0x20fe0e=_[_0x5709('0x3e')]({},_0x20fe0e,_0x51dce0[_0x5709('0x48')]);return db[_0x5709('0x2c')][_0x5709('0x49')](_0x20fe0e)[_0x5709('0x23')](function(_0xe20a25){if(_0xe20a25){_0x2043c7=_0xe20a25;return _0xe20a25[_0x5709('0x6c')]();}return null;})[_0x5709('0x23')](function(_0x1472be){if(_0x1472be){if(!_0x1472be[_0x5709('0x35')]){throw new db['Sequelize'][(_0x5709('0x6d'))](_0x5709('0x6e'),0x193);}_0x4c5480=_0x1472be;return db[_0x5709('0x6f')][_0x5709('0x42')]({'raw':!![]});}return null;})[_0x5709('0x23')](function(_0x23947b){if(_0x23947b){_0x6c2e3c=_[_0x5709('0x70')](_0x23947b,'id');var _0x4f4db0;var _0x152055=squel['select']();_0x152055[_0x5709('0x71')](_0x2043c7[_0x5709('0x72')]);for(var _0x596a50=0x0;_0x596a50<_0x4c5480[_0x5709('0x35')];_0x596a50+=0x1){_0x4f4db0=_0x4c5480[_0x596a50]['MetricId']?_0x6c2e3c[_0x4c5480[_0x596a50]['MetricId']][_0x5709('0x73')]:_0x4c5480[_0x596a50][_0x5709('0x74')];_0x4f4db0=_0x4c5480[_0x596a50][_0x5709('0x75')]?_[_0x5709('0x76')](_0xabc1cf[_0x4c5480[_0x596a50][_0x5709('0x75')]],'%s',_0x4f4db0):_0x4f4db0;_0x4f4db0=_0x4c5480[_0x596a50][_0x5709('0x77')]?_[_0x5709('0x76')](_0x2adfae[_0x4c5480[_0x596a50][_0x5709('0x77')]],'%s',_0x4f4db0):_0x4f4db0;if(_0x4c5480[_0x596a50][_0x5709('0x78')]){_0x152055[_0x5709('0x6a')](_0x4f4db0);}_0x4c5480[_0x596a50][_0x5709('0x79')]&&_0x152055['order'](_0x4f4db0,_0x4c5480[_0x596a50][_0x5709('0x79')]==='DESC'?![]:!![]);_0x152055[_0x5709('0x74')](_0x4f4db0,_0x4c5480[_0x596a50]['alias']||_0x4f4db0);}if(_0x2043c7[_0x5709('0x7a')]){_0x2043c7['joins']=JSON['parse'](_0x2043c7['joins']);for(var _0x321e94=0x0;_0x321e94<_0x2043c7[_0x5709('0x7a')][_0x5709('0x35')];_0x321e94+=0x1){if(_0x2043c7[_0x5709('0x7a')][_0x321e94][_0x5709('0x2e')]&&_['includes'](_0x11c51a,_0x2043c7[_0x5709('0x7a')][_0x321e94][_0x5709('0x2e')])&&_0x2043c7['joins'][_0x321e94][_0x5709('0x7b')]&&_0x2043c7[_0x5709('0x7a')][_0x321e94][_0x5709('0x7c')]&&_0x2043c7[_0x5709('0x7a')][_0x321e94][_0x5709('0x7d')]){_0x152055[_0x2043c7[_0x5709('0x7a')][_0x321e94][_0x5709('0x2e')]](_0x2043c7[_0x5709('0x7a')][_0x321e94][_0x5709('0x7c')],null,util[_0x5709('0x77')](_0x5709('0x7e'),_0x2043c7[_0x5709('0x72')],_0x2043c7['joins'][_0x321e94][_0x5709('0x7b')],_0x2043c7['joins'][_0x321e94][_0x5709('0x7c')],_0x2043c7[_0x5709('0x7a')][_0x321e94][_0x5709('0x7d')]));}}}if(_0x2043c7[_0x5709('0x7f')]){_0x2043c7[_0x5709('0x7f')]=JSON['parse'](_0x2043c7[_0x5709('0x7f')]);_0x152055[_0x5709('0x3c')](_0x16467a(_0x2043c7['conditions'][_0x5709('0x6a')]));}_0xa1a57c=_0x152055[_0x5709('0x80')]();_0x152055['limit'](_0x216443);_0x152055[_0x5709('0x1b')](0x0);logger[_0x5709('0x81')]('Limited\x20Query:',_0x152055[_0x5709('0x82')]());return dbH['sequelize'][_0x5709('0x31')](_0x152055[_0x5709('0x82')](),{'type':dbH[_0x5709('0x83')][_0x5709('0x84')][_0x5709('0x85')]});}})[_0x5709('0x23')](respondWithResult(_0x5dd15d,null))['catch'](handleError(_0x5dd15d,null));};function runReport(_0x4b2c8a,_0x181d76,_0x59161b){var _0x2886a8=_0x181d76['name'];var _0x26a3b1=0xa;var _0x1548bd=[_0x5709('0x86'),_0x5709('0x87'),'right_join',_0x5709('0x88')];var _0xe75e80={'SUM':_0x5709('0x58'),'COUNT':_0x5709('0x59'),'COUNT DISTINCT':_0x5709('0x5a'),'MAX':'MAX(%s)','MIN':_0x5709('0x5c'),'AVG':_0x5709('0x5d'),'GROUP_CONCAT':'GROUP_CONCAT(%s)','GROUP_CONCAT ASC':_0x5709('0x5f'),'GROUP_CONCAT DESC':_0x5709('0x60')};var _0x4e5a05={'SEC_TO_TIME':'SEC_TO_TIME(%s)','DATE':_0x5709('0x61'),'HOUR':_0x5709('0x62'),'ROUND':_0x5709('0x63'),'UNIX_TIMESTAMP':'UNIX_TIMESTAMP(%s)'};var _0x2e9379=function(_0x56b8ca){return!_[_0x5709('0x65')](['IS\x20NULL','IS\x20NOT\x20NULL',_0x5709('0x67'),_0x5709('0x89')],_0x56b8ca);};var _0x46d659=function(_0x554257){if(!_0x554257||!_0x554257['rules'][_0x5709('0x35')]){return'';}for(var _0x24367a='(',_0xa2eab4=0x0;_0xa2eab4<_0x554257[_0x5709('0x68')][_0x5709('0x35')];_0xa2eab4+=0x1){_0xa2eab4>0x0&&(_0x24367a+='\x20'+_0x554257[_0x5709('0x69')]+'\x20');_0x24367a+=_0x554257[_0x5709('0x68')][_0xa2eab4][_0x5709('0x6a')]?_0x46d659(_0x554257[_0x5709('0x68')][_0xa2eab4][_0x5709('0x6a')]):_0x554257[_0x5709('0x68')][_0xa2eab4][_0x5709('0x74')]+'\x20'+_0x554257['rules'][_0xa2eab4][_0x5709('0x6b')]+(_0x2e9379(_0x554257['rules'][_0xa2eab4][_0x5709('0x6b')])?'\x20'+_0x554257[_0x5709('0x68')][_0xa2eab4][_0x5709('0x8a')]:'');}return _0x24367a+')';};var _0x301cf5={'where':{'id':_0x4b2c8a['id']}},_0xae405c,_0x121677,_0x5f27df,_0x226e00,_0x5346c2;_0x301cf5=_['merge']({},_0x301cf5,_0x59161b);return db['AnalyticCustomReport'][_0x5709('0x49')](_0x301cf5)[_0x5709('0x23')](function(_0x295a41){if(_0x295a41){_0xae405c=_0x295a41;return _0x295a41[_0x5709('0x6c')]();}return null;})[_0x5709('0x23')](function(_0x3a8ad3){if(_0x3a8ad3){if(!_0x3a8ad3['length']){throw new db[(_0x5709('0x8b'))]['ValidationErrorItem']('Please\x20insert\x20at\x20least\x20one\x20field',0x193);}_0x121677=_0x3a8ad3;return db[_0x5709('0x6f')]['findAll']({'raw':!![]});}return null;})['then'](function(_0x2e1814){if(_0x2e1814){_0x5f27df=_[_0x5709('0x70')](_0x2e1814,'id');var _0x4debb6;var _0x39cf32=squel[_0x5709('0x8c')]();_0x39cf32['from'](_0xae405c[_0x5709('0x72')]);for(var _0x4dcf9d=0x0;_0x4dcf9d<_0x121677['length'];_0x4dcf9d+=0x1){_0x4debb6=_0x121677[_0x4dcf9d][_0x5709('0x8d')]?_0x5f27df[_0x121677[_0x4dcf9d][_0x5709('0x8d')]][_0x5709('0x73')]:_0x121677[_0x4dcf9d]['field'];_0x4debb6=_0x121677[_0x4dcf9d][_0x5709('0x75')]?_['replace'](_0xe75e80[_0x121677[_0x4dcf9d][_0x5709('0x75')]],'%s',_0x4debb6):_0x4debb6;_0x4debb6=_0x121677[_0x4dcf9d][_0x5709('0x77')]?_[_0x5709('0x76')](_0x4e5a05[_0x121677[_0x4dcf9d][_0x5709('0x77')]],'%s',_0x4debb6):_0x4debb6;if(_0x121677[_0x4dcf9d][_0x5709('0x78')]){_0x39cf32[_0x5709('0x6a')](_0x4debb6);}_0x121677[_0x4dcf9d][_0x5709('0x79')]&&_0x39cf32[_0x5709('0x38')](_0x4debb6,_0x121677[_0x4dcf9d][_0x5709('0x79')]===_0x5709('0x8e')?![]:!![]);_0x39cf32['field'](_0x4debb6,_0x121677[_0x4dcf9d][_0x5709('0x8f')]||_0x4debb6);}if(_0xae405c[_0x5709('0x7a')]){_0xae405c[_0x5709('0x7a')]=JSON[_0x5709('0x90')](_0xae405c[_0x5709('0x7a')]);for(var _0x3a664d=0x0;_0x3a664d<_0xae405c[_0x5709('0x7a')][_0x5709('0x35')];_0x3a664d+=0x1){if(_0xae405c[_0x5709('0x7a')][_0x3a664d][_0x5709('0x2e')]&&_[_0x5709('0x65')](_0x1548bd,_0xae405c[_0x5709('0x7a')][_0x3a664d][_0x5709('0x2e')])&&_0xae405c['joins'][_0x3a664d][_0x5709('0x7b')]&&_0xae405c[_0x5709('0x7a')][_0x3a664d][_0x5709('0x7c')]&&_0xae405c['joins'][_0x3a664d]['foreignKey']){_0x39cf32[_0xae405c['joins'][_0x3a664d][_0x5709('0x2e')]](_0xae405c[_0x5709('0x7a')][_0x3a664d]['foreignTable'],null,util[_0x5709('0x77')]('%s.%s\x20=\x20%s.%s',_0xae405c['table'],_0xae405c['joins'][_0x3a664d][_0x5709('0x7b')],_0xae405c['joins'][_0x3a664d]['foreignTable'],_0xae405c[_0x5709('0x7a')][_0x3a664d][_0x5709('0x7d')]));}}}if(_0xae405c[_0x5709('0x7f')]){_0xae405c['conditions']=JSON[_0x5709('0x90')](_0xae405c['conditions']);_0x39cf32[_0x5709('0x3c')](_0x46d659(_0xae405c[_0x5709('0x7f')]['group']));}_0x5346c2=_0x39cf32[_0x5709('0x80')]();_0x39cf32[_0x5709('0x37')](_0x26a3b1);_0x39cf32[_0x5709('0x1b')](0x0);return;}})[_0x5709('0x23')](function(){if(_0x181d76[_0x5709('0x91')]==='web'){return null;}var _0x38f228=_[_0x5709('0x3e')](_0x181d76,{'name':_0x181d76['fullPath']||_0x181d76[_0x5709('0x28')]||_0xae405c[_0x5709('0x28')],'basename':_0x2886a8,'savename':util[_0x5709('0x77')](_0x5709('0x92'),_0x181d76[_0x5709('0x28')]||_0xae405c[_0x5709('0x28')],require(_0x5709('0x93'))[_0x5709('0x94')](0x4),_0x181d76[_0x5709('0x91')]||'csv'),'reportId':_0xae405c['id'],'reportType':'custom'});return db['AnalyticExtractedReport'][_0x5709('0x4b')](_0x38f228,{'raw':!![]});})[_0x5709('0x23')](function(_0x26da30){if(_0xae405c[_0x5709('0x72')]===_0x5709('0x95')){_0x5346c2[_0x5709('0x3c')](_0xae405c[_0x5709('0x72')]+_0x5709('0x96'),_0x181d76['startDate'],_0x181d76[_0x5709('0x97')]);}else{_0x5346c2[_0x5709('0x3c')](_0xae405c[_0x5709('0x72')]+_0x5709('0x98'),_0x181d76[_0x5709('0x99')],_0x181d76[_0x5709('0x97')]);}if(_0x26da30){logger[_0x5709('0x9a')](_0x5709('0x9b'),_0x5346c2[_0x5709('0x82')]());require(_0x5709('0x9c'))[_0x5709('0x9d')](path[_0x5709('0x86')](__dirname,_0x5709('0x9e'),_0x26da30[_0x5709('0x91')]),[_0x26da30['id'],_0x5346c2[_0x5709('0x82')](),path[_0x5709('0x86')](__dirname,_0x5709('0x9f'),_0x26da30[_0x5709('0xa0')]),_0x2886a8]);return _0x26da30;}else{var _0x2e229c=squel[_0x5709('0x8c')]();_0x2e229c[_0x5709('0x71')]('('+_0x5346c2['toString']()+')',_0x5709('0xa1'));_0x2e229c['field'](_0x5709('0xa2'),_0x5709('0x3f'));_0x5346c2['limit'](_0x181d76[_0x5709('0x37')]||_0x26a3b1);_0x5346c2[_0x5709('0x1b')](_0x181d76[_0x5709('0x1b')]||0x0);return dbH[_0x5709('0x83')][_0x5709('0x31')](_0x2e229c['toString'](),{'type':dbH[_0x5709('0x83')]['QueryTypes']['SELECT']})[_0x5709('0x23')](function(_0x405b75){if(!_0x405b75['length']){_0x226e00=0x0;}else{_0x226e00=_0x405b75[0x0][_0x5709('0x3f')]||0x0;}return dbH['sequelize'][_0x5709('0x31')](_0x5346c2[_0x5709('0x82')](),{'type':dbH[_0x5709('0x83')]['QueryTypes']['SELECT']});})[_0x5709('0x23')](function(_0x476185){return{'rows':_0x476185||[],'count':_0x226e00};});}});}exports[_0x5709('0xa3')]=function(_0x22d219,_0x4ecb40){return runReport(_0x22d219[_0x5709('0x44')],_0x22d219['query'],_0x22d219[_0x5709('0x48')])[_0x5709('0x23')](respondWithResult(_0x4ecb40,null))['catch'](handleError(_0x4ecb40,null));};exports[_0x5709('0xa4')]=runReport;exports[_0x5709('0x31')]=function(_0x368a9e,_0x1fee35){var _0x58b4a2=0xa;var _0x381dc8=[_0x5709('0x86'),_0x5709('0x87'),_0x5709('0x57'),_0x5709('0x88')];var _0x3fe805={'SUM':'SUM(%s)','COUNT':_0x5709('0x59'),'COUNT DISTINCT':_0x5709('0x5a'),'MAX':_0x5709('0x5b'),'MIN':_0x5709('0x5c'),'AVG':'AVG(%s)','GROUP_CONCAT':_0x5709('0x5e'),'GROUP_CONCAT ASC':_0x5709('0x5f'),'GROUP_CONCAT DESC':_0x5709('0x60')};var _0x4fdaf6={'SEC_TO_TIME':_0x5709('0xa5'),'DATE':_0x5709('0x61'),'HOUR':_0x5709('0x62'),'ROUND':'ROUND(%s)','UNIX_TIMESTAMP':_0x5709('0x64')};var _0x4845a1=function(_0x272939){return!_[_0x5709('0x65')]([_0x5709('0xa6'),'IS\x20NOT\x20NULL',_0x5709('0x67'),_0x5709('0x89')],_0x272939);};var _0x11cf5d=function(_0x2081fb){if(!_0x2081fb||!_0x2081fb['rules'][_0x5709('0x35')]){return'';}for(var _0x335d30='(',_0x27e0d4=0x0;_0x27e0d4<_0x2081fb[_0x5709('0x68')][_0x5709('0x35')];_0x27e0d4+=0x1){_0x27e0d4>0x0&&(_0x335d30+='\x20'+_0x2081fb[_0x5709('0x69')]+'\x20');_0x335d30+=_0x2081fb[_0x5709('0x68')][_0x27e0d4][_0x5709('0x6a')]?_0x11cf5d(_0x2081fb[_0x5709('0x68')][_0x27e0d4][_0x5709('0x6a')]):_0x2081fb[_0x5709('0x68')][_0x27e0d4][_0x5709('0x74')]+'\x20'+_0x2081fb['rules'][_0x27e0d4][_0x5709('0x6b')]+(_0x4845a1(_0x2081fb['rules'][_0x27e0d4]['condition'])?'\x20'+_0x2081fb[_0x5709('0x68')][_0x27e0d4][_0x5709('0x8a')]:'');}return _0x335d30+')';};var _0x5b76d9={'where':{'id':_0x368a9e[_0x5709('0x44')]['id']}},_0x2ed759,_0x36584c,_0x36b68a,_0x57cce0,_0x17f631;_0x5b76d9=_[_0x5709('0x3e')]({},_0x5b76d9,_0x368a9e['options']);return db[_0x5709('0x2c')][_0x5709('0x49')](_0x5b76d9)[_0x5709('0x23')](function(_0x1591d4){if(_0x1591d4){_0x2ed759=_0x1591d4;return _0x1591d4[_0x5709('0x6c')]();}return null;})[_0x5709('0x23')](function(_0x58e465){if(_0x58e465){if(!_0x58e465['length']){throw new db['Sequelize'][(_0x5709('0x6d'))]('Please\x20insert\x20at\x20least\x20one\x20field',0x193);}_0x36584c=_0x58e465;return db[_0x5709('0x6f')][_0x5709('0x42')]({'raw':!![]});}return null;})['then'](function(_0x4f2580){if(_0x4f2580){_0x36b68a=_[_0x5709('0x70')](_0x4f2580,'id');var _0x3d23e9;var _0x963ac5=squel[_0x5709('0x8c')]();_0x963ac5['from'](_0x2ed759['table']);for(var _0xad5113=0x0;_0xad5113<_0x36584c[_0x5709('0x35')];_0xad5113+=0x1){_0x3d23e9=_0x36584c[_0xad5113][_0x5709('0x8d')]?_0x36b68a[_0x36584c[_0xad5113][_0x5709('0x8d')]][_0x5709('0x73')]:_0x36584c[_0xad5113][_0x5709('0x74')];_0x3d23e9=_0x36584c[_0xad5113][_0x5709('0x75')]?_['replace'](_0x3fe805[_0x36584c[_0xad5113]['function']],'%s',_0x3d23e9):_0x3d23e9;_0x3d23e9=_0x36584c[_0xad5113][_0x5709('0x77')]?_[_0x5709('0x76')](_0x4fdaf6[_0x36584c[_0xad5113][_0x5709('0x77')]],'%s',_0x3d23e9):_0x3d23e9;if(_0x36584c[_0xad5113][_0x5709('0x78')]){_0x963ac5['group'](_0x3d23e9);}_0x36584c[_0xad5113][_0x5709('0x79')]&&_0x963ac5[_0x5709('0x38')](_0x3d23e9,_0x36584c[_0xad5113]['orderBy']===_0x5709('0x8e')?![]:!![]);_0x963ac5[_0x5709('0x74')](_0x3d23e9,_0x36584c[_0xad5113][_0x5709('0x8f')]||_0x3d23e9);}if(_0x2ed759[_0x5709('0x7a')]){_0x2ed759[_0x5709('0x7a')]=JSON[_0x5709('0x90')](_0x2ed759[_0x5709('0x7a')]);for(var _0x42f32a=0x0;_0x42f32a<_0x2ed759[_0x5709('0x7a')]['length'];_0x42f32a+=0x1){if(_0x2ed759['joins'][_0x42f32a]['type']&&_['includes'](_0x381dc8,_0x2ed759[_0x5709('0x7a')][_0x42f32a]['type'])&&_0x2ed759['joins'][_0x42f32a]['parentKey']&&_0x2ed759[_0x5709('0x7a')][_0x42f32a][_0x5709('0x7c')]&&_0x2ed759['joins'][_0x42f32a][_0x5709('0x7d')]){_0x963ac5[_0x2ed759['joins'][_0x42f32a][_0x5709('0x2e')]](_0x2ed759['joins'][_0x42f32a][_0x5709('0x7c')],null,util[_0x5709('0x77')](_0x5709('0x7e'),_0x2ed759['table'],_0x2ed759[_0x5709('0x7a')][_0x42f32a][_0x5709('0x7b')],_0x2ed759[_0x5709('0x7a')][_0x42f32a][_0x5709('0x7c')],_0x2ed759['joins'][_0x42f32a][_0x5709('0x7d')]));}}}if(_0x2ed759['conditions']){_0x2ed759[_0x5709('0x7f')]=JSON[_0x5709('0x90')](_0x2ed759['conditions']);_0x963ac5[_0x5709('0x3c')](_0x11cf5d(_0x2ed759[_0x5709('0x7f')]['group']));}_0x17f631=_0x963ac5['clone']();_0x963ac5['limit'](_0x58b4a2);_0x963ac5[_0x5709('0x1b')](0x0);logger[_0x5709('0x81')](_0x5709('0xa7'),_0x963ac5[_0x5709('0x82')]());return dbH[_0x5709('0x83')][_0x5709('0x31')](_0x963ac5['toString'](),{'type':dbH[_0x5709('0x83')][_0x5709('0x84')][_0x5709('0x85')]});}})['then'](function(){return{'sql':_0x17f631[_0x5709('0x82')]()};})[_0x5709('0x23')](respondWithResult(_0x1fee35,null))[_0x5709('0x4a')](handleError(_0x1fee35,null));};