Built motion from commit (unavailable).|2.5.8
[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 _0x43d6=['AnalyticExtractedReport','info','XLSX','Setting','find','splitSizeXlsx','then','sequelize','query','QueryTypes','SELECT','num','Empty','format','push','dirname','basename','.xlsx','split','length','existsSync','join','each','%s%d.%s','%s.%s','xlsx','writeFileSync','binary','Completed','zip','catch','inspect','util','path','lodash','json2xls','bluebird','zip-dir','../../mysqldb','dbH','../../config/logger','analytics','argv','savename'];(function(_0x57b54c,_0x54ce0d){var _0x59cc19=function(_0xa33bc6){while(--_0xa33bc6){_0x57b54c['push'](_0x57b54c['shift']());}};_0x59cc19(++_0x54ce0d);}(_0x43d6,0xfc));var _0x643d=function(_0x593d62,_0x3d52fe){_0x593d62=_0x593d62-0x0;var _0x47ee6b=_0x43d6[_0x593d62];return _0x47ee6b;};'use strict';var util=require(_0x643d('0x0'));var path=require(_0x643d('0x1'));var _=require(_0x643d('0x2'));var fs=require('fs');var json2xls=require(_0x643d('0x3'));var BPromise=require(_0x643d('0x4'));var zipdir=require(_0x643d('0x5'));var rimraf=require('rimraf');var db=require(_0x643d('0x6'))['db'];var dbH=require(_0x643d('0x6'))[_0x643d('0x7')];var logger=require(_0x643d('0x8'))(_0x643d('0x9'));var EXTRACTED_REPORT_ID=Number(process[_0x643d('0xa')][0x2]);var QUERY=process['argv'][0x3];var PATH=process[_0x643d('0xa')][0x4];function analyticExtractedReport(_0x26a8c1,_0x5b1feb){var _0x349e3e={'status':_0x26a8c1};var _0x1787da={'where':{'id':EXTRACTED_REPORT_ID}};if(_0x5b1feb){_0x349e3e[_0x643d('0xb')]=_0x5b1feb;}return db[_0x643d('0xc')]['update'](_0x349e3e,_0x1787da);}function main(){var _0x3f079c=0x1388;var _0x3334dc;logger[_0x643d('0xd')](util['format']('Start\x20extraction\x20report\x20with\x20id\x20%d\x20in\x20%s\x20format',EXTRACTED_REPORT_ID,_0x643d('0xe')));return db[_0x643d('0xf')][_0x643d('0x10')]({'where':{'id':0x1},'raw':!![],'attributes':['id','split',_0x643d('0x11')]})[_0x643d('0x12')](function(_0x5ba4ee){if(_0x5ba4ee){_0x3334dc=_0x5ba4ee;_0x3f079c=_0x3334dc[_0x643d('0x11')]||0x1388;}})['then'](function(){return dbH[_0x643d('0x13')][_0x643d('0x14')](util['format']('SELECT\x20count(*)\x20as\x20num\x20FROM\x20(%s)\x20t',QUERY),{'type':dbH[_0x643d('0x13')][_0x643d('0x15')][_0x643d('0x16')]});})['then'](function(_0x1fee1d){if(!_0x1fee1d[0x0][_0x643d('0x17')]){return analyticExtractedReport(_0x643d('0x18'));}var _0x4336d0=[];var _0x3ab47d=0x0;var _0x4bedf4=!![];if(_0x3334dc['split']){if(_0x1fee1d&&_0x1fee1d['length']){var _0x24b4c2=_0x1fee1d[0x0][_0x643d('0x17')]%(_0x3ab47d+_0x3f079c);for(;_0x4bedf4;_0x3ab47d+=_0x3f079c,_0x24b4c2=_0x1fee1d[0x0]['num']%(_0x3ab47d+_0x3f079c)){if(_0x24b4c2==0x0||_0x24b4c2==_0x1fee1d[0x0]['num']){_0x4bedf4=![];}_0x4336d0['push'](dbH[_0x643d('0x13')][_0x643d('0x14')](util[_0x643d('0x19')]('%s\x20limit\x20%d\x20OFFSET\x20%d',QUERY,_0x3f079c,_0x3ab47d),{'type':dbH[_0x643d('0x13')][_0x643d('0x15')][_0x643d('0x16')]}));}}}else{_0x4336d0[_0x643d('0x1a')](dbH[_0x643d('0x13')][_0x643d('0x14')](QUERY,{'type':dbH[_0x643d('0x13')][_0x643d('0x15')][_0x643d('0x16')]}));}var _0x94f683=path[_0x643d('0x1b')](PATH);var _0x942cb7=path[_0x643d('0x1c')](PATH,_0x643d('0x1d'));var _0x3306a7=_0x3334dc[_0x643d('0x1e')]&&_0x4336d0[_0x643d('0x1f')]>0x1;var _0x168930=[];if(!fs[_0x643d('0x20')](path['join'](_0x94f683,_0x942cb7))&&_0x3306a7){fs['mkdirSync'](path[_0x643d('0x21')](_0x94f683,_0x942cb7));}return BPromise[_0x643d('0x22')](_0x4336d0,function(_0x46b4ff){_0x168930[_0x643d('0x1a')](_0x46b4ff);})[_0x643d('0x12')](function(){for(var _0x5d52c8=0x0;_0x5d52c8<_0x168930[_0x643d('0x1f')];_0x5d52c8+=0x1){var _0x3eaada;var _0x40f62c=_0x168930[_0x5d52c8];if(_0x3306a7){_0x3eaada=path[_0x643d('0x21')](_0x94f683,_0x942cb7,util[_0x643d('0x19')](_0x643d('0x23'),_0x942cb7,_0x5d52c8,'xlsx'));}else{_0x3eaada=path[_0x643d('0x21')](_0x94f683,util[_0x643d('0x19')](_0x643d('0x24'),_0x942cb7,_0x643d('0x25')));}fs[_0x643d('0x26')](_0x3eaada,json2xls(_0x40f62c),_0x643d('0x27'));}})[_0x643d('0x12')](function(){if(_0x3306a7){zipdir(path[_0x643d('0x21')](_0x94f683,_0x942cb7),{'saveTo':path[_0x643d('0x21')](_0x94f683,util[_0x643d('0x19')](_0x643d('0x24'),_0x942cb7,'zip'))},function(_0x16ad24,_0x511e13){});rimraf(path[_0x643d('0x21')](_0x94f683,_0x942cb7),function(){});}})[_0x643d('0x12')](function(){logger[_0x643d('0xd')](util[_0x643d('0x19')]('Extraction\x20report\x20with\x20id\x20%d\x20in\x20%s\x20format\x20completed',EXTRACTED_REPORT_ID,'XLSX'));return analyticExtractedReport(_0x643d('0x28'),_0x3306a7?util[_0x643d('0x19')](_0x643d('0x24'),_0x942cb7,_0x3306a7?_0x643d('0x29'):_0x643d('0x25')):null);});})[_0x643d('0x2a')](function(_0x41284c){logger[_0x643d('0xd')](util[_0x643d('0x19')]('Error\x20during\x20extraction\x20report\x20with\x20id\x20%d\x20in\x20%s\x20format',EXTRACTED_REPORT_ID,_0x643d('0xe')),util[_0x643d('0x2b')](_0x41284c,{'showHidden':![],'depth':null}));return analyticExtractedReport('Failed');});}main();