Built motion from commit (unavailable).|2.5.14
[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 _0x531d=['parse','clone','debug','Limited\x20Query:','sequelize','toString','SELECT','IS\x20NULL','operator','getFields','Sequelize','select','alias','%s.%s\x20=\x20%s.%s','QueryTypes','web','fullPath','%s-%s.%s','randomstring','generate','output','AnalyticExtractedReport','.calldate\x20BETWEEN\x20?\x20AND\x20?','startDate','endDate','info','child_process','fork','../../components/export/','../../files/reports','savename','countTable','COUNT(*)','GROUP_CONCAT(%s)','IS\x20EMPTY','html-pdf','eml-format','rimraf','zip-dir','fast-json-patch','request-promise','bluebird','mustache','util','sox','ejs','lodash','squel','crypto','jsforce','desk.js','querystring','papaparse','ioredis','../../components/parsers/qs','../../config/license/hardware','../../config/logger','api','../../config/environment','../../config/license/util','../../mysqldb','dbH','sendStatus','status','end','json','offset','limit','reject','save','update','then','CustomReports','destroy','error','stack','name','send','index','map','AnalyticCustomReport','rawAttributes','fieldName','key','model','query','keys','filters','intersection','attributes','fields','length','hasOwnProperty','nolimit','sort','where','pick','filter','merge','type','options','count','includeAll','include','findAll','rows','catch','show','find','create','user','get','role','Reports','UserProfileSection','autoAssociation','body','params','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\x20ORDER\x20BY\x20%s\x20ASC)','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','group','field','condition','value','ValidationErrorItem','Please\x20insert\x20at\x20least\x20one\x20field','AnalyticMetric','keyBy','from','table','MetricId','metric','function','replace','format','groupBy','orderBy','order','DESC','joins','foreignTable','parentKey','foreignKey','conditions'];(function(_0x2641f9,_0x26715f){var _0x585741=function(_0x2d1462){while(--_0x2d1462){_0x2641f9['push'](_0x2641f9['shift']());}};_0x585741(++_0x26715f);}(_0x531d,0x16b));var _0xd531=function(_0x2e3189,_0x3aefee){_0x2e3189=_0x2e3189-0x0;var _0x5d9ee2=_0x531d[_0x2e3189];return _0x5d9ee2;};'use strict';var pdf=require(_0xd531('0x0'));var emlformat=require(_0xd531('0x1'));var rimraf=require(_0xd531('0x2'));var zipdir=require(_0xd531('0x3'));var jsonpatch=require(_0xd531('0x4'));var rp=require(_0xd531('0x5'));var moment=require('moment');var BPromise=require(_0xd531('0x6'));var Mustache=require(_0xd531('0x7'));var util=require(_0xd531('0x8'));var path=require('path');var sox=require(_0xd531('0x9'));var csv=require('to-csv');var ejs=require(_0xd531('0xa'));var fs=require('fs');var _=require(_0xd531('0xb'));var squel=require(_0xd531('0xc'));var crypto=require(_0xd531('0xd'));var jsforce=require(_0xd531('0xe'));var deskjs=require(_0xd531('0xf'));var toCsv=require('to-csv');var querystring=require(_0xd531('0x10'));var Papa=require(_0xd531('0x11'));var Redis=require(_0xd531('0x12'));var authService=require('../../components/auth/service');var qs=require(_0xd531('0x13'));var as=require('../../components/parsers/advancedSearch');var hardwareService=require(_0xd531('0x14'));var logger=require(_0xd531('0x15'))(_0xd531('0x16'));var utils=require('../../config/utils');var config=require(_0xd531('0x17'));var licenseUtil=require(_0xd531('0x18'));var db=require(_0xd531('0x19'))['db'];var dbH=require('../../mysqldb')[_0xd531('0x1a')];function respondWithStatusCode(_0x4df361,_0x6c5d8a){_0x6c5d8a=_0x6c5d8a||0xcc;return function(_0x153941){if(_0x153941){return _0x4df361[_0xd531('0x1b')](_0x6c5d8a);}return _0x4df361[_0xd531('0x1c')](_0x6c5d8a)[_0xd531('0x1d')]();};}function respondWithResult(_0x40a38f,_0x9546b1){_0x9546b1=_0x9546b1||0xc8;return function(_0x465953){if(_0x465953){return _0x40a38f[_0xd531('0x1c')](_0x9546b1)[_0xd531('0x1e')](_0x465953);}};}function respondWithFilteredResult(_0x87db87,_0x3248d0){return function(_0x2df22b){if(_0x2df22b){var _0xd35948=_0x2df22b['count'],_0x564e27=_0x3248d0[_0xd531('0x1f')],_0x47fc8d=_0x3248d0[_0xd531('0x1f')]+_0x3248d0[_0xd531('0x20')],_0x5735ca;if(_0x47fc8d>=_0xd35948){_0x47fc8d=_0xd35948;_0x5735ca=0xc8;}else{_0x5735ca=0xce;}_0x87db87[_0xd531('0x1c')](_0x5735ca);return _0x87db87['set']('Content-Range',_0x564e27+'-'+_0x47fc8d+'/'+_0xd35948)[_0xd531('0x1e')](_0x2df22b);}return null;};}function patchUpdates(_0x19ae54){return function(_0x1640eb){try{jsonpatch['apply'](_0x1640eb,_0x19ae54,!![]);}catch(_0x4f0602){return BPromise[_0xd531('0x21')](_0x4f0602);}return _0x1640eb[_0xd531('0x22')]();};}function saveUpdates(_0x3992e7,_0x357f29){return function(_0x4a07fa){if(_0x4a07fa){return _0x4a07fa[_0xd531('0x23')](_0x3992e7)[_0xd531('0x24')](function(_0x236b96){return _0x236b96;});}return null;};}function removeEntity(_0x213411,_0x146521){return function(_0x35eeca){if(_0x35eeca){return _0x35eeca['destroy']()[_0xd531('0x24')](function(){var _0x594022=_0x35eeca['get']({'plain':!![]});var _0x384df1=_0xd531('0x25');return db['UserProfileResource'][_0xd531('0x26')]({'where':{'type':_0x384df1,'resourceId':_0x594022['id']}})[_0xd531('0x24')](function(){return _0x35eeca;});})[_0xd531('0x24')](function(){_0x213411[_0xd531('0x1c')](0xcc)[_0xd531('0x1d')]();});}};}function handleEntityNotFound(_0x20fd88,_0x222772){return function(_0x2350dc){if(!_0x2350dc){_0x20fd88[_0xd531('0x1b')](0x194);}return _0x2350dc;};}function handleError(_0x4b74ac,_0x5d3786){_0x5d3786=_0x5d3786||0x1f4;return function(_0x4fa229){logger[_0xd531('0x27')](_0x4fa229[_0xd531('0x28')]);if(_0x4fa229[_0xd531('0x29')]){delete _0x4fa229['name'];}_0x4b74ac[_0xd531('0x1c')](_0x5d3786)[_0xd531('0x2a')](_0x4fa229);};}exports[_0xd531('0x2b')]=function(_0x518232,_0x143a60){var _0x5d7785={},_0x59a0bb={},_0x52b992={'count':0x0,'rows':[]};var _0x35356a=_[_0xd531('0x2c')](db[_0xd531('0x2d')][_0xd531('0x2e')],function(_0x4d0e20){return{'name':_0x4d0e20[_0xd531('0x2f')],'type':_0x4d0e20['type'][_0xd531('0x30')]};});_0x59a0bb[_0xd531('0x31')]=_['map'](_0x35356a,_0xd531('0x29'));_0x59a0bb[_0xd531('0x32')]=_[_0xd531('0x33')](_0x518232[_0xd531('0x32')]);_0x59a0bb[_0xd531('0x34')]=_[_0xd531('0x35')](_0x59a0bb[_0xd531('0x31')],_0x59a0bb[_0xd531('0x32')]);_0x5d7785[_0xd531('0x36')]=_[_0xd531('0x35')](_0x59a0bb[_0xd531('0x31')],qs['fields'](_0x518232[_0xd531('0x32')][_0xd531('0x37')]));_0x5d7785[_0xd531('0x36')]=_0x5d7785['attributes'][_0xd531('0x38')]?_0x5d7785[_0xd531('0x36')]:_0x59a0bb['model'];if(!_0x518232[_0xd531('0x32')][_0xd531('0x39')](_0xd531('0x3a'))){_0x5d7785[_0xd531('0x20')]=qs[_0xd531('0x20')](_0x518232[_0xd531('0x32')][_0xd531('0x20')]);_0x5d7785[_0xd531('0x1f')]=qs[_0xd531('0x1f')](_0x518232[_0xd531('0x32')][_0xd531('0x1f')]);}_0x5d7785['order']=qs[_0xd531('0x3b')](_0x518232['query']['sort']);_0x5d7785[_0xd531('0x3c')]=qs[_0xd531('0x34')](_[_0xd531('0x3d')](_0x518232['query'],_0x59a0bb[_0xd531('0x34')]),_0x35356a);if(_0x518232[_0xd531('0x32')][_0xd531('0x3e')]){_0x5d7785[_0xd531('0x3c')]=_[_0xd531('0x3f')](_0x5d7785['where'],{'$or':_[_0xd531('0x2c')](_0x35356a,function(_0x2943bd){if(_0x2943bd[_0xd531('0x40')]!=='VIRTUAL'){var _0x44bc28={};_0x44bc28[_0x2943bd[_0xd531('0x29')]]={'$like':'%'+_0x518232[_0xd531('0x32')]['filter']+'%'};return _0x44bc28;}})});}_0x5d7785=_[_0xd531('0x3f')]({},_0x5d7785,_0x518232[_0xd531('0x41')]);var _0x55fc50={'where':_0x5d7785[_0xd531('0x3c')]};return db[_0xd531('0x2d')][_0xd531('0x42')](_0x55fc50)['then'](function(_0x2b6390){_0x52b992[_0xd531('0x42')]=_0x2b6390;if(_0x518232[_0xd531('0x32')][_0xd531('0x43')]){_0x5d7785[_0xd531('0x44')]=[{'all':!![]}];}return db[_0xd531('0x2d')][_0xd531('0x45')](_0x5d7785);})[_0xd531('0x24')](function(_0x26b62f){_0x52b992[_0xd531('0x46')]=_0x26b62f;return _0x52b992;})[_0xd531('0x24')](respondWithFilteredResult(_0x143a60,_0x5d7785))[_0xd531('0x47')](handleError(_0x143a60,null));};exports[_0xd531('0x48')]=function(_0x4a10c4,_0xc84e71){var _0x539637={'raw':![],'where':{'id':_0x4a10c4['params']['id']}},_0x144f98={};_0x144f98[_0xd531('0x31')]=_[_0xd531('0x33')](db[_0xd531('0x2d')][_0xd531('0x2e')]);_0x144f98[_0xd531('0x32')]=_[_0xd531('0x33')](_0x4a10c4['query']);_0x144f98[_0xd531('0x34')]=_[_0xd531('0x35')](_0x144f98['model'],_0x144f98[_0xd531('0x32')]);_0x539637['attributes']=_[_0xd531('0x35')](_0x144f98['model'],qs[_0xd531('0x37')](_0x4a10c4['query'][_0xd531('0x37')]));_0x539637[_0xd531('0x36')]=_0x539637[_0xd531('0x36')][_0xd531('0x38')]?_0x539637[_0xd531('0x36')]:_0x144f98['model'];if(_0x4a10c4[_0xd531('0x32')][_0xd531('0x43')]){_0x539637[_0xd531('0x44')]=[{'all':!![]}];}_0x539637=_[_0xd531('0x3f')]({},_0x539637,_0x4a10c4[_0xd531('0x41')]);return db[_0xd531('0x2d')][_0xd531('0x49')](_0x539637)[_0xd531('0x24')](handleEntityNotFound(_0xc84e71,null))[_0xd531('0x24')](respondWithResult(_0xc84e71,null))[_0xd531('0x47')](handleError(_0xc84e71,null));};exports[_0xd531('0x4a')]=function(_0x56df5b,_0x131045){return db[_0xd531('0x2d')]['create'](_0x56df5b['body'],{})[_0xd531('0x24')](function(_0x265d86){var _0xf5b819=_0x56df5b[_0xd531('0x4b')][_0xd531('0x4c')]({'plain':!![]});if(!_0xf5b819)throw new Error('Unable\x20to\x20retrieve\x20the\x20current\x20user');if(_0xf5b819[_0xd531('0x4d')]===_0xd531('0x4b')){var _0x443cae=_0x265d86[_0xd531('0x4c')]({'plain':!![]});var _0x2dbc1f=_0xd531('0x4e');return db[_0xd531('0x4f')][_0xd531('0x49')]({'where':{'name':_0x2dbc1f,'userProfileId':_0xf5b819['userProfileId']},'raw':!![]})[_0xd531('0x24')](function(_0x914131){if(_0x914131&&_0x914131[_0xd531('0x50')]===0x0){return db['UserProfileResource'][_0xd531('0x4a')]({'name':_0x443cae[_0xd531('0x29')],'resourceId':_0x443cae['id'],'type':'CustomReports','sectionId':_0x914131['id']},{})[_0xd531('0x24')](function(){return _0x265d86;});}else{return _0x265d86;}})[_0xd531('0x47')](function(_0x379c95){logger[_0xd531('0x27')]('Unable\x20to\x20associate\x20the\x20resource\x20to\x20the\x20User\x20Profile:\x20%s',_0x379c95);throw _0x379c95;});}return _0x265d86;})[_0xd531('0x24')](respondWithResult(_0x131045,0xc9))[_0xd531('0x47')](handleError(_0x131045,null));};exports[_0xd531('0x23')]=function(_0x147bbe,_0x5cddd7){if(_0x147bbe[_0xd531('0x51')]['id']){delete _0x147bbe[_0xd531('0x51')]['id'];}return db[_0xd531('0x2d')][_0xd531('0x49')]({'where':{'id':_0x147bbe[_0xd531('0x52')]['id']}})[_0xd531('0x24')](handleEntityNotFound(_0x5cddd7,null))[_0xd531('0x24')](saveUpdates(_0x147bbe['body'],null))[_0xd531('0x24')](respondWithResult(_0x5cddd7,null))[_0xd531('0x47')](handleError(_0x5cddd7,null));};exports[_0xd531('0x26')]=function(_0x298f28,_0x57cadd){return db[_0xd531('0x2d')][_0xd531('0x49')]({'where':{'id':_0x298f28[_0xd531('0x52')]['id']}})[_0xd531('0x24')](handleEntityNotFound(_0x57cadd,null))[_0xd531('0x24')](removeEntity(_0x57cadd,null))[_0xd531('0x47')](handleError(_0x57cadd,null));};exports[_0xd531('0x53')]=function(_0x5d43fb,_0x5823e9){var _0x47cc8f=0xa;var _0x3f6231=[_0xd531('0x54'),_0xd531('0x55'),_0xd531('0x56'),_0xd531('0x57')];var _0x5c6650={'SUM':_0xd531('0x58'),'COUNT':_0xd531('0x59'),'COUNT DISTINCT':_0xd531('0x5a'),'MAX':_0xd531('0x5b'),'MIN':_0xd531('0x5c'),'AVG':_0xd531('0x5d'),'GROUP_CONCAT':'GROUP_CONCAT(%s)','GROUP_CONCAT ASC':_0xd531('0x5e'),'GROUP_CONCAT DESC':_0xd531('0x5f')};var _0x3c3887={'SEC_TO_TIME':_0xd531('0x60'),'DATE':_0xd531('0x61'),'HOUR':_0xd531('0x62'),'ROUND':_0xd531('0x63'),'UNIX_TIMESTAMP':_0xd531('0x64')};var _0x30bcee=function(_0x58c388){return!_[_0xd531('0x65')](['IS\x20NULL',_0xd531('0x66'),'IS\x20EMPTY',_0xd531('0x67')],_0x58c388);};var _0x166fbc=function(_0x277124){if(!_0x277124||!_0x277124[_0xd531('0x68')][_0xd531('0x38')]){return'';}for(var _0x5eacd6='(',_0x5370d6=0x0;_0x5370d6<_0x277124[_0xd531('0x68')][_0xd531('0x38')];_0x5370d6+=0x1){_0x5370d6>0x0&&(_0x5eacd6+='\x20'+_0x277124['operator']+'\x20');_0x5eacd6+=_0x277124[_0xd531('0x68')][_0x5370d6][_0xd531('0x69')]?_0x166fbc(_0x277124[_0xd531('0x68')][_0x5370d6]['group']):_0x277124[_0xd531('0x68')][_0x5370d6][_0xd531('0x6a')]+'\x20'+_0x277124['rules'][_0x5370d6][_0xd531('0x6b')]+(_0x30bcee(_0x277124[_0xd531('0x68')][_0x5370d6][_0xd531('0x6b')])?'\x20'+_0x277124['rules'][_0x5370d6][_0xd531('0x6c')]:'');}return _0x5eacd6+')';};var _0x1d99b2={'where':{'id':_0x5d43fb[_0xd531('0x52')]['id']}},_0x612324,_0x38c78c,_0x2a0414,_0x14b8ed,_0x23abff;_0x1d99b2=_[_0xd531('0x3f')]({},_0x1d99b2,_0x5d43fb[_0xd531('0x41')]);return db['AnalyticCustomReport'][_0xd531('0x49')](_0x1d99b2)[_0xd531('0x24')](function(_0x256707){if(_0x256707){_0x612324=_0x256707;return _0x256707['getFields']();}return null;})[_0xd531('0x24')](function(_0xa2cfb3){if(_0xa2cfb3){if(!_0xa2cfb3[_0xd531('0x38')]){throw new db['Sequelize'][(_0xd531('0x6d'))](_0xd531('0x6e'),0x193);}_0x38c78c=_0xa2cfb3;return db[_0xd531('0x6f')][_0xd531('0x45')]({'raw':!![]});}return null;})[_0xd531('0x24')](function(_0x1694aa){if(_0x1694aa){_0x2a0414=_[_0xd531('0x70')](_0x1694aa,'id');var _0xeb4f95;var _0x2ec160=squel['select']();_0x2ec160[_0xd531('0x71')](_0x612324[_0xd531('0x72')]);for(var _0x102527=0x0;_0x102527<_0x38c78c[_0xd531('0x38')];_0x102527+=0x1){_0xeb4f95=_0x38c78c[_0x102527][_0xd531('0x73')]?_0x2a0414[_0x38c78c[_0x102527][_0xd531('0x73')]][_0xd531('0x74')]:_0x38c78c[_0x102527][_0xd531('0x6a')];_0xeb4f95=_0x38c78c[_0x102527][_0xd531('0x75')]?_[_0xd531('0x76')](_0x5c6650[_0x38c78c[_0x102527]['function']],'%s',_0xeb4f95):_0xeb4f95;_0xeb4f95=_0x38c78c[_0x102527][_0xd531('0x77')]?_[_0xd531('0x76')](_0x3c3887[_0x38c78c[_0x102527]['format']],'%s',_0xeb4f95):_0xeb4f95;if(_0x38c78c[_0x102527][_0xd531('0x78')]){_0x2ec160[_0xd531('0x69')](_0xeb4f95);}_0x38c78c[_0x102527][_0xd531('0x79')]&&_0x2ec160[_0xd531('0x7a')](_0xeb4f95,_0x38c78c[_0x102527][_0xd531('0x79')]===_0xd531('0x7b')?![]:!![]);_0x2ec160[_0xd531('0x6a')](_0xeb4f95,_0x38c78c[_0x102527]['alias']||_0xeb4f95);}if(_0x612324['joins']){_0x612324[_0xd531('0x7c')]=JSON['parse'](_0x612324[_0xd531('0x7c')]);for(var _0x4f44e9=0x0;_0x4f44e9<_0x612324[_0xd531('0x7c')]['length'];_0x4f44e9+=0x1){if(_0x612324[_0xd531('0x7c')][_0x4f44e9][_0xd531('0x40')]&&_[_0xd531('0x65')](_0x3f6231,_0x612324[_0xd531('0x7c')][_0x4f44e9]['type'])&&_0x612324[_0xd531('0x7c')][_0x4f44e9]['parentKey']&&_0x612324[_0xd531('0x7c')][_0x4f44e9][_0xd531('0x7d')]&&_0x612324[_0xd531('0x7c')][_0x4f44e9]['foreignKey']){_0x2ec160[_0x612324[_0xd531('0x7c')][_0x4f44e9][_0xd531('0x40')]](_0x612324['joins'][_0x4f44e9][_0xd531('0x7d')],null,util[_0xd531('0x77')]('%s.%s\x20=\x20%s.%s',_0x612324['table'],_0x612324[_0xd531('0x7c')][_0x4f44e9][_0xd531('0x7e')],_0x612324[_0xd531('0x7c')][_0x4f44e9][_0xd531('0x7d')],_0x612324[_0xd531('0x7c')][_0x4f44e9][_0xd531('0x7f')]));}}}if(_0x612324[_0xd531('0x80')]){_0x612324['conditions']=JSON[_0xd531('0x81')](_0x612324[_0xd531('0x80')]);_0x2ec160['where'](_0x166fbc(_0x612324['conditions'][_0xd531('0x69')]));}_0x23abff=_0x2ec160[_0xd531('0x82')]();_0x2ec160['limit'](_0x47cc8f);_0x2ec160[_0xd531('0x1f')](0x0);logger[_0xd531('0x83')](_0xd531('0x84'),_0x2ec160['toString']());return db[_0xd531('0x85')]['query'](_0x2ec160[_0xd531('0x86')](),{'type':db[_0xd531('0x85')]['QueryTypes'][_0xd531('0x87')]});}})[_0xd531('0x24')](respondWithResult(_0x5823e9,null))[_0xd531('0x47')](handleError(_0x5823e9,null));};function runReport(_0x450100,_0x1a76d8,_0x20060b){var _0x9a33cd=_0x1a76d8['name'];var _0x390f60=0xa;var _0x4e6caa=[_0xd531('0x54'),_0xd531('0x55'),_0xd531('0x56'),_0xd531('0x57')];var _0xa8d8ba={'SUM':_0xd531('0x58'),'COUNT':_0xd531('0x59'),'COUNT DISTINCT':_0xd531('0x5a'),'MAX':_0xd531('0x5b'),'MIN':_0xd531('0x5c'),'AVG':'AVG(%s)','GROUP_CONCAT':'GROUP_CONCAT(%s)','GROUP_CONCAT ASC':_0xd531('0x5e'),'GROUP_CONCAT DESC':_0xd531('0x5f')};var _0x11f027={'SEC_TO_TIME':_0xd531('0x60'),'DATE':_0xd531('0x61'),'HOUR':_0xd531('0x62'),'ROUND':_0xd531('0x63'),'UNIX_TIMESTAMP':_0xd531('0x64')};var _0x362492=function(_0x191c64){return!_[_0xd531('0x65')]([_0xd531('0x88'),'IS\x20NOT\x20NULL','IS\x20EMPTY',_0xd531('0x67')],_0x191c64);};var _0x311d5e=function(_0x1aecfc){if(!_0x1aecfc||!_0x1aecfc[_0xd531('0x68')][_0xd531('0x38')]){return'';}for(var _0x5f23be='(',_0x3450d7=0x0;_0x3450d7<_0x1aecfc['rules']['length'];_0x3450d7+=0x1){_0x3450d7>0x0&&(_0x5f23be+='\x20'+_0x1aecfc[_0xd531('0x89')]+'\x20');_0x5f23be+=_0x1aecfc[_0xd531('0x68')][_0x3450d7][_0xd531('0x69')]?_0x311d5e(_0x1aecfc[_0xd531('0x68')][_0x3450d7][_0xd531('0x69')]):_0x1aecfc['rules'][_0x3450d7][_0xd531('0x6a')]+'\x20'+_0x1aecfc[_0xd531('0x68')][_0x3450d7][_0xd531('0x6b')]+(_0x362492(_0x1aecfc['rules'][_0x3450d7]['condition'])?'\x20'+_0x1aecfc['rules'][_0x3450d7]['value']:'');}return _0x5f23be+')';};var _0x21b6ea={'where':{'id':_0x450100['id']}},_0x5f0880,_0x503e92,_0x1b0b32,_0x210c3c,_0x1abb74;_0x21b6ea=_[_0xd531('0x3f')]({},_0x21b6ea,_0x20060b);return db[_0xd531('0x2d')]['find'](_0x21b6ea)[_0xd531('0x24')](function(_0x4a55a6){if(_0x4a55a6){_0x5f0880=_0x4a55a6;return _0x4a55a6[_0xd531('0x8a')]();}return null;})['then'](function(_0x3d1ed9){if(_0x3d1ed9){if(!_0x3d1ed9[_0xd531('0x38')]){throw new db[(_0xd531('0x8b'))][(_0xd531('0x6d'))](_0xd531('0x6e'),0x193);}_0x503e92=_0x3d1ed9;return db[_0xd531('0x6f')][_0xd531('0x45')]({'raw':!![]});}return null;})[_0xd531('0x24')](function(_0xb6cabf){if(_0xb6cabf){_0x1b0b32=_[_0xd531('0x70')](_0xb6cabf,'id');var _0x38e755;var _0x3826d5=squel[_0xd531('0x8c')]();_0x3826d5[_0xd531('0x71')](_0x5f0880[_0xd531('0x72')]);for(var _0xf5c49a=0x0;_0xf5c49a<_0x503e92[_0xd531('0x38')];_0xf5c49a+=0x1){_0x38e755=_0x503e92[_0xf5c49a][_0xd531('0x73')]?_0x1b0b32[_0x503e92[_0xf5c49a][_0xd531('0x73')]]['metric']:_0x503e92[_0xf5c49a][_0xd531('0x6a')];_0x38e755=_0x503e92[_0xf5c49a][_0xd531('0x75')]?_[_0xd531('0x76')](_0xa8d8ba[_0x503e92[_0xf5c49a][_0xd531('0x75')]],'%s',_0x38e755):_0x38e755;_0x38e755=_0x503e92[_0xf5c49a][_0xd531('0x77')]?_['replace'](_0x11f027[_0x503e92[_0xf5c49a]['format']],'%s',_0x38e755):_0x38e755;if(_0x503e92[_0xf5c49a]['groupBy']){_0x3826d5[_0xd531('0x69')](_0x38e755);}_0x503e92[_0xf5c49a]['orderBy']&&_0x3826d5[_0xd531('0x7a')](_0x38e755,_0x503e92[_0xf5c49a]['orderBy']===_0xd531('0x7b')?![]:!![]);_0x3826d5[_0xd531('0x6a')](_0x38e755,_0x503e92[_0xf5c49a][_0xd531('0x8d')]||_0x38e755);}if(_0x5f0880[_0xd531('0x7c')]){_0x5f0880[_0xd531('0x7c')]=JSON[_0xd531('0x81')](_0x5f0880[_0xd531('0x7c')]);for(var _0x4bf17a=0x0;_0x4bf17a<_0x5f0880[_0xd531('0x7c')][_0xd531('0x38')];_0x4bf17a+=0x1){if(_0x5f0880['joins'][_0x4bf17a]['type']&&_[_0xd531('0x65')](_0x4e6caa,_0x5f0880[_0xd531('0x7c')][_0x4bf17a][_0xd531('0x40')])&&_0x5f0880[_0xd531('0x7c')][_0x4bf17a][_0xd531('0x7e')]&&_0x5f0880[_0xd531('0x7c')][_0x4bf17a][_0xd531('0x7d')]&&_0x5f0880[_0xd531('0x7c')][_0x4bf17a][_0xd531('0x7f')]){_0x3826d5[_0x5f0880[_0xd531('0x7c')][_0x4bf17a][_0xd531('0x40')]](_0x5f0880['joins'][_0x4bf17a][_0xd531('0x7d')],null,util[_0xd531('0x77')](_0xd531('0x8e'),_0x5f0880[_0xd531('0x72')],_0x5f0880['joins'][_0x4bf17a][_0xd531('0x7e')],_0x5f0880[_0xd531('0x7c')][_0x4bf17a][_0xd531('0x7d')],_0x5f0880[_0xd531('0x7c')][_0x4bf17a][_0xd531('0x7f')]));}}}if(_0x5f0880[_0xd531('0x80')]){_0x5f0880['conditions']=JSON[_0xd531('0x81')](_0x5f0880[_0xd531('0x80')]);_0x3826d5[_0xd531('0x3c')](_0x311d5e(_0x5f0880[_0xd531('0x80')][_0xd531('0x69')]));}_0x1abb74=_0x3826d5['clone']();_0x3826d5[_0xd531('0x20')](_0x390f60);_0x3826d5[_0xd531('0x1f')](0x0);logger[_0xd531('0x83')](_0xd531('0x84'),_0x3826d5[_0xd531('0x86')]());return db[_0xd531('0x85')][_0xd531('0x32')](_0x3826d5[_0xd531('0x86')](),{'type':db[_0xd531('0x85')][_0xd531('0x8f')][_0xd531('0x87')]});}})[_0xd531('0x24')](function(_0x70fe06){if(!_0x70fe06[_0xd531('0x38')]){throw new db[(_0xd531('0x8b'))]['ValidationErrorItem']('No\x20available\x20data',0xcc);}if(_0x1a76d8['output']===_0xd531('0x90')){return null;}var _0x41710b=_[_0xd531('0x3f')](_0x1a76d8,{'name':_0x1a76d8[_0xd531('0x91')]||_0x1a76d8[_0xd531('0x29')]||_0x5f0880[_0xd531('0x29')],'basename':_0x9a33cd,'savename':util['format'](_0xd531('0x92'),_0x1a76d8[_0xd531('0x29')]||_0x5f0880[_0xd531('0x29')],require(_0xd531('0x93'))[_0xd531('0x94')](0x4),_0x1a76d8[_0xd531('0x95')]||'csv'),'reportId':_0x5f0880['id'],'reportType':'custom'});return db[_0xd531('0x96')]['create'](_0x41710b,{'raw':!![]});})[_0xd531('0x24')](function(_0x38f4cc){if(_0x5f0880[_0xd531('0x72')]==='cdr'){_0x1abb74[_0xd531('0x3c')](_0x5f0880[_0xd531('0x72')]+_0xd531('0x97'),_0x1a76d8[_0xd531('0x98')],_0x1a76d8[_0xd531('0x99')]);}else{_0x1abb74[_0xd531('0x3c')](_0x5f0880[_0xd531('0x72')]+'.createdAt\x20BETWEEN\x20?\x20AND\x20?',_0x1a76d8[_0xd531('0x98')],_0x1a76d8[_0xd531('0x99')]);}if(_0x38f4cc){logger[_0xd531('0x9a')]('Run\x20Query:',_0x1abb74[_0xd531('0x86')]());require(_0xd531('0x9b'))[_0xd531('0x9c')](path[_0xd531('0x54')](__dirname,_0xd531('0x9d'),_0x38f4cc[_0xd531('0x95')]),[_0x38f4cc['id'],_0x1abb74[_0xd531('0x86')](),path[_0xd531('0x54')](__dirname,_0xd531('0x9e'),_0x38f4cc[_0xd531('0x9f')]),_0x9a33cd]);return _0x38f4cc;}else{var _0x792fc=squel['select']();_0x792fc['from']('('+_0x1abb74['toString']()+')',_0xd531('0xa0'));_0x792fc[_0xd531('0x6a')](_0xd531('0xa1'),_0xd531('0x42'));_0x1abb74[_0xd531('0x20')](_0x1a76d8[_0xd531('0x20')]||_0x390f60);_0x1abb74[_0xd531('0x1f')](_0x1a76d8['offset']||0x0);return dbH[_0xd531('0x85')][_0xd531('0x32')](_0x792fc[_0xd531('0x86')](),{'type':dbH[_0xd531('0x85')][_0xd531('0x8f')][_0xd531('0x87')]})[_0xd531('0x24')](function(_0x501124){if(!_0x501124['length']){_0x210c3c=0x0;}else{_0x210c3c=_0x501124[0x0][_0xd531('0x42')]||0x0;}return dbH[_0xd531('0x85')][_0xd531('0x32')](_0x1abb74[_0xd531('0x86')](),{'type':dbH[_0xd531('0x85')]['QueryTypes'][_0xd531('0x87')]});})[_0xd531('0x24')](function(_0x45bdb9){return{'rows':_0x45bdb9||[],'count':_0x210c3c};});}});}exports['run']=function(_0x3aad8f,_0x30a8db){return runReport(_0x3aad8f[_0xd531('0x52')],_0x3aad8f['query'],_0x3aad8f[_0xd531('0x41')])[_0xd531('0x24')](respondWithResult(_0x30a8db,null))[_0xd531('0x47')](handleError(_0x30a8db,null));};exports['runReport']=runReport;exports[_0xd531('0x32')]=function(_0x2196fc,_0x3be835){var _0x71e1fb=0xa;var _0x28d569=['join',_0xd531('0x55'),_0xd531('0x56'),_0xd531('0x57')];var _0x2285f3={'SUM':'SUM(%s)','COUNT':_0xd531('0x59'),'COUNT DISTINCT':'COUNT(DISTINCT\x20%s)','MAX':_0xd531('0x5b'),'MIN':_0xd531('0x5c'),'AVG':_0xd531('0x5d'),'GROUP_CONCAT':_0xd531('0xa2'),'GROUP_CONCAT ASC':_0xd531('0x5e'),'GROUP_CONCAT DESC':_0xd531('0x5f')};var _0x5a47fc={'SEC_TO_TIME':'SEC_TO_TIME(%s)','DATE':'DATE(%s)','HOUR':'HOUR(%s)','ROUND':'ROUND(%s)','UNIX_TIMESTAMP':'UNIX_TIMESTAMP(%s)'};var _0x16611a=function(_0x31cdc4){return!_['includes']([_0xd531('0x88'),'IS\x20NOT\x20NULL',_0xd531('0xa3'),_0xd531('0x67')],_0x31cdc4);};var _0x281955=function(_0x1c425e){if(!_0x1c425e||!_0x1c425e['rules']['length']){return'';}for(var _0x292c2b='(',_0x1edfa0=0x0;_0x1edfa0<_0x1c425e[_0xd531('0x68')][_0xd531('0x38')];_0x1edfa0+=0x1){_0x1edfa0>0x0&&(_0x292c2b+='\x20'+_0x1c425e[_0xd531('0x89')]+'\x20');_0x292c2b+=_0x1c425e[_0xd531('0x68')][_0x1edfa0][_0xd531('0x69')]?_0x281955(_0x1c425e[_0xd531('0x68')][_0x1edfa0][_0xd531('0x69')]):_0x1c425e[_0xd531('0x68')][_0x1edfa0][_0xd531('0x6a')]+'\x20'+_0x1c425e[_0xd531('0x68')][_0x1edfa0][_0xd531('0x6b')]+(_0x16611a(_0x1c425e['rules'][_0x1edfa0][_0xd531('0x6b')])?'\x20'+_0x1c425e[_0xd531('0x68')][_0x1edfa0][_0xd531('0x6c')]:'');}return _0x292c2b+')';};var _0x32ef8b={'where':{'id':_0x2196fc['params']['id']}},_0x48ad17,_0xe89e62,_0x2027ed,_0x4d5737,_0x444c81;_0x32ef8b=_[_0xd531('0x3f')]({},_0x32ef8b,_0x2196fc['options']);return db[_0xd531('0x2d')]['find'](_0x32ef8b)['then'](function(_0x3958f1){if(_0x3958f1){_0x48ad17=_0x3958f1;return _0x3958f1['getFields']();}return null;})[_0xd531('0x24')](function(_0x5afbf4){if(_0x5afbf4){if(!_0x5afbf4[_0xd531('0x38')]){throw new db[(_0xd531('0x8b'))][(_0xd531('0x6d'))](_0xd531('0x6e'),0x193);}_0xe89e62=_0x5afbf4;return db[_0xd531('0x6f')][_0xd531('0x45')]({'raw':!![]});}return null;})[_0xd531('0x24')](function(_0x19c756){if(_0x19c756){_0x2027ed=_[_0xd531('0x70')](_0x19c756,'id');var _0x392edc;var _0x271987=squel[_0xd531('0x8c')]();_0x271987[_0xd531('0x71')](_0x48ad17[_0xd531('0x72')]);for(var _0x13b34a=0x0;_0x13b34a<_0xe89e62[_0xd531('0x38')];_0x13b34a+=0x1){_0x392edc=_0xe89e62[_0x13b34a][_0xd531('0x73')]?_0x2027ed[_0xe89e62[_0x13b34a][_0xd531('0x73')]][_0xd531('0x74')]:_0xe89e62[_0x13b34a]['field'];_0x392edc=_0xe89e62[_0x13b34a]['function']?_[_0xd531('0x76')](_0x2285f3[_0xe89e62[_0x13b34a]['function']],'%s',_0x392edc):_0x392edc;_0x392edc=_0xe89e62[_0x13b34a]['format']?_[_0xd531('0x76')](_0x5a47fc[_0xe89e62[_0x13b34a][_0xd531('0x77')]],'%s',_0x392edc):_0x392edc;if(_0xe89e62[_0x13b34a][_0xd531('0x78')]){_0x271987['group'](_0x392edc);}_0xe89e62[_0x13b34a]['orderBy']&&_0x271987['order'](_0x392edc,_0xe89e62[_0x13b34a][_0xd531('0x79')]===_0xd531('0x7b')?![]:!![]);_0x271987[_0xd531('0x6a')](_0x392edc,_0xe89e62[_0x13b34a][_0xd531('0x8d')]||_0x392edc);}if(_0x48ad17['joins']){_0x48ad17[_0xd531('0x7c')]=JSON[_0xd531('0x81')](_0x48ad17[_0xd531('0x7c')]);for(var _0x44af85=0x0;_0x44af85<_0x48ad17[_0xd531('0x7c')][_0xd531('0x38')];_0x44af85+=0x1){if(_0x48ad17[_0xd531('0x7c')][_0x44af85][_0xd531('0x40')]&&_['includes'](_0x28d569,_0x48ad17[_0xd531('0x7c')][_0x44af85][_0xd531('0x40')])&&_0x48ad17['joins'][_0x44af85][_0xd531('0x7e')]&&_0x48ad17[_0xd531('0x7c')][_0x44af85][_0xd531('0x7d')]&&_0x48ad17['joins'][_0x44af85]['foreignKey']){_0x271987[_0x48ad17['joins'][_0x44af85][_0xd531('0x40')]](_0x48ad17[_0xd531('0x7c')][_0x44af85][_0xd531('0x7d')],null,util[_0xd531('0x77')](_0xd531('0x8e'),_0x48ad17['table'],_0x48ad17[_0xd531('0x7c')][_0x44af85][_0xd531('0x7e')],_0x48ad17[_0xd531('0x7c')][_0x44af85]['foreignTable'],_0x48ad17['joins'][_0x44af85][_0xd531('0x7f')]));}}}if(_0x48ad17['conditions']){_0x48ad17[_0xd531('0x80')]=JSON[_0xd531('0x81')](_0x48ad17[_0xd531('0x80')]);_0x271987[_0xd531('0x3c')](_0x281955(_0x48ad17[_0xd531('0x80')][_0xd531('0x69')]));}_0x444c81=_0x271987[_0xd531('0x82')]();_0x271987[_0xd531('0x20')](_0x71e1fb);_0x271987['offset'](0x0);logger[_0xd531('0x83')]('Limited\x20Query:',_0x271987[_0xd531('0x86')]());return db[_0xd531('0x85')][_0xd531('0x32')](_0x271987[_0xd531('0x86')](),{'type':db[_0xd531('0x85')][_0xd531('0x8f')][_0xd531('0x87')]});}})['then'](function(){return{'sql':_0x444c81[_0xd531('0x86')]()};})['then'](respondWithResult(_0x3be835,null))[_0xd531('0x47')](handleError(_0x3be835,null));};