a11cbfcfa91f6f5b3687593c610db373b2c55849
[motion2.git] / server / components / export / csv.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 _0xc0ba=['num','Empty','length','forEach','%s\x20limit\x20%d\x20OFFSET\x20%d','push','dirname','basename','.csv','existsSync','join','mkdirSync','each','%s%d.%s','csv','%s.%s','writeFileSync','zip','zip\x20finished','Extraction\x20report\x20with\x20id\x20%d\x20in\x20%s\x20format\x20completed','Completed','catch','Error\x20during\x20extraction\x20report\x20with\x20id\x20%d\x20in\x20%s\x20format','Failed','finally','path','to-csv','bluebird','zip-dir','rimraf','../../mysqldb','dbH','../../config/logger','analytics','argv','AnalyticExtractedReport','info','format','Start\x20extraction\x20report\x20with\x20id\x20%d\x20in\x20%s\x20format','CSV','Setting','split','splitSizeCsv','then','sequelize','query','SELECT\x20count(*)\x20as\x20num\x20FROM\x20(%s)\x20t','QueryTypes','SELECT'];(function(_0x437fb1,_0x4acbf5){var _0x45ae49=function(_0x4fdf4d){while(--_0x4fdf4d){_0x437fb1['push'](_0x437fb1['shift']());}};_0x45ae49(++_0x4acbf5);}(_0xc0ba,0xac));var _0xac0b=function(_0x4f6f84,_0x31e197){_0x4f6f84=_0x4f6f84-0x0;var _0x20d989=_0xc0ba[_0x4f6f84];return _0x20d989;};'use strict';var util=require('util');var path=require(_0xac0b('0x0'));var _=require('lodash');var csv=require(_0xac0b('0x1'));var fs=require('fs');var BPromise=require(_0xac0b('0x2'));var zipdir=require(_0xac0b('0x3'));var rimraf=require(_0xac0b('0x4'));var db=require(_0xac0b('0x5'))['db'];var dbH=require(_0xac0b('0x5'))[_0xac0b('0x6')];var logger=require(_0xac0b('0x7'))(_0xac0b('0x8'));var EXTRACTED_REPORT_ID=Number(process[_0xac0b('0x9')][0x2]);var QUERY=process[_0xac0b('0x9')][0x3];var PATH=process[_0xac0b('0x9')][0x4];var EXIT_CODE=0x0;function analyticExtractedReport(_0x130c8b,_0x3191fd){var _0x5893c5={'status':_0x130c8b};var _0x428843={'where':{'id':EXTRACTED_REPORT_ID}};if(_0x3191fd){_0x5893c5['savename']=_0x3191fd;}return db[_0xac0b('0xa')]['update'](_0x5893c5,_0x428843);}function main(){var _0x1bc1a6=0x1388;var _0x2af2a8;logger[_0xac0b('0xb')](util[_0xac0b('0xc')](_0xac0b('0xd'),EXTRACTED_REPORT_ID,_0xac0b('0xe')));return db[_0xac0b('0xf')]['find']({'where':{'id':0x1},'raw':!![],'attributes':['id',_0xac0b('0x10'),_0xac0b('0x11')]})[_0xac0b('0x12')](function(_0x51930d){if(_0x51930d){_0x2af2a8=_0x51930d;_0x1bc1a6=_0x2af2a8[_0xac0b('0x11')]||0x1388;}})['then'](function(){return dbH[_0xac0b('0x13')][_0xac0b('0x14')](util[_0xac0b('0xc')](_0xac0b('0x15'),QUERY),{'type':dbH[_0xac0b('0x13')][_0xac0b('0x16')][_0xac0b('0x17')]});})['then'](function(_0x5ddf80){if(!_0x5ddf80[0x0][_0xac0b('0x18')]){return analyticExtractedReport(_0xac0b('0x19'));}var _0xbb895=[];var _0x93e9b0=0x0;if(_0x2af2a8[_0xac0b('0x10')]){if(_0x5ddf80&&_0x5ddf80[_0xac0b('0x1a')]){var _0x5f1e10=_['range'](_0x5ddf80[0x0][_0xac0b('0x18')]/_0x1bc1a6);var _0x3e5154=Number['isInteger'](_0x5ddf80[0x0][_0xac0b('0x18')]/_0x1bc1a6)?_0x5ddf80[0x0][_0xac0b('0x18')]%_0x1bc1a6:0x0;_0x5f1e10[_0xac0b('0x1b')](function(_0x359cf2){if(_0x359cf2>0x0){_0x93e9b0+=_0x1bc1a6;}_0xbb895['push'](dbH[_0xac0b('0x13')]['query'](util[_0xac0b('0xc')](_0xac0b('0x1c'),QUERY,_0x1bc1a6,_0x93e9b0),{'type':dbH[_0xac0b('0x13')]['QueryTypes'][_0xac0b('0x17')]}));});if(_0x3e5154>0x0){_0x93e9b0+=_0x1bc1a6;_0xbb895[_0xac0b('0x1d')](dbH['sequelize']['query'](util[_0xac0b('0xc')]('%s\x20limit\x20%d\x20OFFSET\x20%d',QUERY,_0x3e5154,_0x93e9b0),{'type':dbH[_0xac0b('0x13')][_0xac0b('0x16')][_0xac0b('0x17')]}));}}}else{_0xbb895[_0xac0b('0x1d')](dbH[_0xac0b('0x13')][_0xac0b('0x14')](QUERY,{'type':dbH[_0xac0b('0x13')][_0xac0b('0x16')][_0xac0b('0x17')]}));}var _0x51030b=path[_0xac0b('0x1e')](PATH);var _0x48dffa=path[_0xac0b('0x1f')](PATH,_0xac0b('0x20'));var _0x4d2e21=_0x2af2a8['split']&&_0xbb895[_0xac0b('0x1a')]>0x1;var _0x68db1d=[];if(!fs[_0xac0b('0x21')](path[_0xac0b('0x22')](_0x51030b,_0x48dffa))&&_0x4d2e21){fs[_0xac0b('0x23')](path[_0xac0b('0x22')](_0x51030b,_0x48dffa));}return BPromise[_0xac0b('0x24')](_0xbb895,function(_0x4432f2){_0x68db1d[_0xac0b('0x1d')](_0x4432f2);})[_0xac0b('0x12')](function(){for(var _0x3aee8b=0x0;_0x3aee8b<_0x68db1d['length'];_0x3aee8b+=0x1){var _0x26ff83;var _0x30c5a5=_0x68db1d[_0x3aee8b];if(_0x4d2e21){_0x26ff83=path[_0xac0b('0x22')](_0x51030b,_0x48dffa,util['format'](_0xac0b('0x25'),_0x48dffa,_0x3aee8b,_0xac0b('0x26')));}else{_0x26ff83=path[_0xac0b('0x22')](_0x51030b,util[_0xac0b('0xc')](_0xac0b('0x27'),_0x48dffa,'csv'));}fs[_0xac0b('0x28')](_0x26ff83,csv(_0x30c5a5));}})[_0xac0b('0x12')](function(){if(_0x4d2e21){return new Promise(function(_0x4dae2b){zipdir(path[_0xac0b('0x22')](_0x51030b,_0x48dffa),{'saveTo':path['join'](_0x51030b,util[_0xac0b('0xc')](_0xac0b('0x27'),_0x48dffa,_0xac0b('0x29')))},function(_0x3a6758,_0x347fd8){rimraf(path['join'](_0x51030b,_0x48dffa),function(){});_0x4dae2b(_0xac0b('0x2a'));});});}})[_0xac0b('0x12')](function(){logger[_0xac0b('0xb')](util[_0xac0b('0xc')](_0xac0b('0x2b'),EXTRACTED_REPORT_ID,_0xac0b('0xe')));return analyticExtractedReport(_0xac0b('0x2c'),_0x4d2e21?util[_0xac0b('0xc')](_0xac0b('0x27'),_0x48dffa,_0x4d2e21?_0xac0b('0x29'):_0xac0b('0x26')):null);});})[_0xac0b('0x2d')](function(_0x45c033){logger[_0xac0b('0xb')](util[_0xac0b('0xc')](_0xac0b('0x2e'),EXTRACTED_REPORT_ID,'CSV'),util['inspect'](_0x45c033,{'showHidden':![],'depth':null}));EXIT_CODE=0x1;return analyticExtractedReport(_0xac0b('0x2f'));})[_0xac0b('0x30')](function(){process['exit'](EXIT_CODE);});}main();