Built motion from commit (unavailable).|2.5.6
[motion2.git] / server / components / export / xlsx.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 _0x3e76=['Setting','find','split','splitSizeXlsx','then','sequelize','query','format','QueryTypes','SELECT','num','length','push','%s\x20limit\x20%d\x20OFFSET\x20%d','dirname','existsSync','mkdirSync','join','binary','%s.%s','zip','info','Extraction\x20report\x20with\x20id\x20%d\x20in\x20%s\x20format\x20completed','xlsx','catch','inspect','Failed','util','path','lodash','json2xls','bluebird','zip-dir','../../mysqldb','../../config/logger','analytics','argv','savename','AnalyticExtractedReport','update','Start\x20extraction\x20report\x20with\x20id\x20%d\x20in\x20%s\x20format','XLSX'];(function(_0x79951f,_0x3188f6){var _0xd00e3a=function(_0x11c530){while(--_0x11c530){_0x79951f['push'](_0x79951f['shift']());}};_0xd00e3a(++_0x3188f6);}(_0x3e76,0x1e9));var _0x63e7=function(_0xbca1b1,_0x33f0ce){_0xbca1b1=_0xbca1b1-0x0;var _0x4e1686=_0x3e76[_0xbca1b1];return _0x4e1686;};'use strict';var util=require(_0x63e7('0x0'));var path=require(_0x63e7('0x1'));var _=require(_0x63e7('0x2'));var fs=require('fs');var json2xls=require(_0x63e7('0x3'));var BPromise=require(_0x63e7('0x4'));var zipdir=require(_0x63e7('0x5'));var rimraf=require('rimraf');var db=require(_0x63e7('0x6'))['db'];var dbH=require(_0x63e7('0x6'))['dbH'];var logger=require(_0x63e7('0x7'))(_0x63e7('0x8'));var EXTRACTED_REPORT_ID=Number(process[_0x63e7('0x9')][0x2]);var QUERY=process[_0x63e7('0x9')][0x3];var PATH=process['argv'][0x4];function analyticExtractedReport(_0x5ed06b,_0x96a0a){var _0x362aae={'status':_0x5ed06b};var _0x2ae748={'where':{'id':EXTRACTED_REPORT_ID}};if(_0x96a0a){_0x362aae[_0x63e7('0xa')]=_0x96a0a;}return db[_0x63e7('0xb')][_0x63e7('0xc')](_0x362aae,_0x2ae748);}function main(){var _0x5bacd6=0x1388;var _0x304c2f;logger['info'](util['format'](_0x63e7('0xd'),EXTRACTED_REPORT_ID,_0x63e7('0xe')));return db[_0x63e7('0xf')][_0x63e7('0x10')]({'where':{'id':0x1},'raw':!![],'attributes':['id',_0x63e7('0x11'),_0x63e7('0x12')]})[_0x63e7('0x13')](function(_0x36b500){if(_0x36b500){_0x304c2f=_0x36b500;_0x5bacd6=_0x304c2f['splitSizeXlsx']||0x1388;}})['then'](function(){return dbH[_0x63e7('0x14')][_0x63e7('0x15')](util[_0x63e7('0x16')]('SELECT\x20count(*)\x20as\x20num\x20FROM\x20(%s)\x20t',QUERY),{'type':dbH['sequelize'][_0x63e7('0x17')][_0x63e7('0x18')]});})[_0x63e7('0x13')](function(_0x513659){if(!_0x513659[0x0][_0x63e7('0x19')]){return analyticExtractedReport('Empty');}var _0x3ffcdd=[];var _0x413195=0x0;var _0x1c751a=!![];if(_0x304c2f[_0x63e7('0x11')]){if(_0x513659&&_0x513659[_0x63e7('0x1a')]){var _0x3c4655=_0x513659[0x0][_0x63e7('0x19')]%(_0x413195+_0x5bacd6);for(;_0x1c751a;_0x413195+=_0x5bacd6,_0x3c4655=_0x513659[0x0]['num']%(_0x413195+_0x5bacd6)){if(_0x3c4655==0x0||_0x3c4655==_0x513659[0x0]['num']){_0x1c751a=![];}_0x3ffcdd[_0x63e7('0x1b')](dbH[_0x63e7('0x14')][_0x63e7('0x15')](util[_0x63e7('0x16')](_0x63e7('0x1c'),QUERY,_0x5bacd6,_0x413195),{'type':dbH[_0x63e7('0x14')][_0x63e7('0x17')][_0x63e7('0x18')]}));}}}else{_0x3ffcdd[_0x63e7('0x1b')](dbH[_0x63e7('0x14')][_0x63e7('0x15')](QUERY,{'type':dbH[_0x63e7('0x14')][_0x63e7('0x17')][_0x63e7('0x18')]}));}var _0x103266=path[_0x63e7('0x1d')](PATH);var _0x2fda32=path['basename'](PATH,'.xlsx');var _0x253687=_0x304c2f[_0x63e7('0x11')]&&_0x3ffcdd[_0x63e7('0x1a')]>0x1;var _0x488fbc=[];if(!fs[_0x63e7('0x1e')](path['join'](_0x103266,_0x2fda32))&&_0x253687){fs[_0x63e7('0x1f')](path[_0x63e7('0x20')](_0x103266,_0x2fda32));}return BPromise['each'](_0x3ffcdd,function(_0x1febd5){_0x488fbc[_0x63e7('0x1b')](_0x1febd5);})[_0x63e7('0x13')](function(){for(var _0x328d60=0x0;_0x328d60<_0x488fbc[_0x63e7('0x1a')];_0x328d60+=0x1){var _0x13a951;var _0x28c1fe=_0x488fbc[_0x328d60];if(_0x253687){_0x13a951=path[_0x63e7('0x20')](_0x103266,_0x2fda32,util[_0x63e7('0x16')]('%s%d.%s',_0x2fda32,_0x328d60,'xlsx'));}else{_0x13a951=path[_0x63e7('0x20')](_0x103266,util[_0x63e7('0x16')]('%s.%s',_0x2fda32,'xlsx'));}fs['writeFileSync'](_0x13a951,json2xls(_0x28c1fe),_0x63e7('0x21'));}})['then'](function(){if(_0x253687){zipdir(path[_0x63e7('0x20')](_0x103266,_0x2fda32),{'saveTo':path['join'](_0x103266,util[_0x63e7('0x16')](_0x63e7('0x22'),_0x2fda32,_0x63e7('0x23')))},function(_0x45e3b1,_0xb7f72b){});rimraf(path['join'](_0x103266,_0x2fda32),function(){});}})[_0x63e7('0x13')](function(){logger[_0x63e7('0x24')](util['format'](_0x63e7('0x25'),EXTRACTED_REPORT_ID,_0x63e7('0xe')));return analyticExtractedReport('Completed',_0x253687?util[_0x63e7('0x16')]('%s.%s',_0x2fda32,_0x253687?'zip':_0x63e7('0x26')):null);});})[_0x63e7('0x27')](function(_0x2348f2){logger[_0x63e7('0x24')](util[_0x63e7('0x16')]('Error\x20during\x20extraction\x20report\x20with\x20id\x20%d\x20in\x20%s\x20format',EXTRACTED_REPORT_ID,_0x63e7('0xe')),util[_0x63e7('0x28')](_0x2348f2,{'showHidden':![],'depth':null}));return analyticExtractedReport(_0x63e7('0x29'));});}main();