2c0795abc2bb97f9da35215fc4f9022d3e6de78a
[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 _0x5656=['%s%d.%s','csv','%s.%s','zip\x20finished','Completed','catch','Error\x20during\x20extraction\x20report\x20with\x20id\x20%d\x20in\x20%s\x20format','inspect','Failed','finally','exit','util','lodash','to-csv','bluebird','rimraf','../../mysqldb','../../config/logger','analytics','argv','AnalyticExtractedReport','update','info','format','CSV','Setting','find','then','sequelize','query','SELECT\x20count(*)\x20as\x20num\x20FROM\x20(%s)\x20t','QueryTypes','SELECT','num','Empty','length','isInteger','push','%s\x20limit\x20%d\x20OFFSET\x20%d','dirname','basename','.csv','split','existsSync','join','each'];(function(_0x8c43de,_0x90ff31){var _0xa6591b=function(_0x469716){while(--_0x469716){_0x8c43de['push'](_0x8c43de['shift']());}};_0xa6591b(++_0x90ff31);}(_0x5656,0x95));var _0x6565=function(_0x104506,_0x1677de){_0x104506=_0x104506-0x0;var _0xe969fe=_0x5656[_0x104506];return _0xe969fe;};'use strict';var util=require(_0x6565('0x0'));var path=require('path');var _=require(_0x6565('0x1'));var csv=require(_0x6565('0x2'));var fs=require('fs');var BPromise=require(_0x6565('0x3'));var zipdir=require('zip-dir');var rimraf=require(_0x6565('0x4'));var db=require(_0x6565('0x5'))['db'];var dbH=require(_0x6565('0x5'))['dbH'];var logger=require(_0x6565('0x6'))(_0x6565('0x7'));var EXTRACTED_REPORT_ID=Number(process['argv'][0x2]);var QUERY=process[_0x6565('0x8')][0x3];var PATH=process[_0x6565('0x8')][0x4];var EXIT_CODE=0x0;function analyticExtractedReport(_0x2fbdd8,_0x401c0b){var _0x32904f={'status':_0x2fbdd8};var _0x1b9d2a={'where':{'id':EXTRACTED_REPORT_ID}};if(_0x401c0b){_0x32904f['savename']=_0x401c0b;}return db[_0x6565('0x9')][_0x6565('0xa')](_0x32904f,_0x1b9d2a);}function main(){var _0x138d15=0x1388;var _0x5e744b;logger[_0x6565('0xb')](util[_0x6565('0xc')]('Start\x20extraction\x20report\x20with\x20id\x20%d\x20in\x20%s\x20format',EXTRACTED_REPORT_ID,_0x6565('0xd')));return db[_0x6565('0xe')][_0x6565('0xf')]({'where':{'id':0x1},'raw':!![],'attributes':['id','split','splitSizeCsv']})['then'](function(_0x1a2c98){if(_0x1a2c98){_0x5e744b=_0x1a2c98;_0x138d15=_0x5e744b['splitSizeCsv']||0x1388;}})[_0x6565('0x10')](function(){return dbH[_0x6565('0x11')][_0x6565('0x12')](util[_0x6565('0xc')](_0x6565('0x13'),QUERY),{'type':dbH[_0x6565('0x11')][_0x6565('0x14')][_0x6565('0x15')]});})['then'](function(_0x4a28f8){if(!_0x4a28f8[0x0][_0x6565('0x16')]){return analyticExtractedReport(_0x6565('0x17'));}var _0x53ddd2=[];var _0x13292d=0x0;if(_0x5e744b['split']){if(_0x4a28f8&&_0x4a28f8[_0x6565('0x18')]){var _0x3c0833=_['range'](_0x4a28f8[0x0][_0x6565('0x16')]/_0x138d15);var _0x2137d0=Number[_0x6565('0x19')](_0x4a28f8[0x0]['num']/_0x138d15)?_0x4a28f8[0x0][_0x6565('0x16')]%_0x138d15:0x0;_0x3c0833['forEach'](function(_0x2246e9){if(_0x2246e9>0x0){_0x13292d+=_0x138d15;}_0x53ddd2[_0x6565('0x1a')](dbH[_0x6565('0x11')][_0x6565('0x12')](util[_0x6565('0xc')](_0x6565('0x1b'),QUERY,_0x138d15,_0x13292d),{'type':dbH[_0x6565('0x11')][_0x6565('0x14')][_0x6565('0x15')]}));});if(_0x2137d0>0x0){_0x13292d+=_0x138d15;_0x53ddd2[_0x6565('0x1a')](dbH['sequelize'][_0x6565('0x12')](util[_0x6565('0xc')](_0x6565('0x1b'),QUERY,_0x2137d0,_0x13292d),{'type':dbH[_0x6565('0x11')][_0x6565('0x14')]['SELECT']}));}}}else{_0x53ddd2[_0x6565('0x1a')](dbH['sequelize'][_0x6565('0x12')](QUERY,{'type':dbH[_0x6565('0x11')][_0x6565('0x14')]['SELECT']}));}var _0x430891=path[_0x6565('0x1c')](PATH);var _0x1ce684=path[_0x6565('0x1d')](PATH,_0x6565('0x1e'));var _0x450ce4=_0x5e744b[_0x6565('0x1f')]&&_0x53ddd2['length']>0x1;var _0x6c3fd7=[];if(!fs[_0x6565('0x20')](path['join'](_0x430891,_0x1ce684))&&_0x450ce4){fs['mkdirSync'](path[_0x6565('0x21')](_0x430891,_0x1ce684));}return BPromise[_0x6565('0x22')](_0x53ddd2,function(_0x450ecf){_0x6c3fd7[_0x6565('0x1a')](_0x450ecf);})[_0x6565('0x10')](function(){for(var _0x1bc3be=0x0;_0x1bc3be<_0x6c3fd7[_0x6565('0x18')];_0x1bc3be+=0x1){var _0xe98e7c;var _0x2ae6e9=_0x6c3fd7[_0x1bc3be];if(_0x450ce4){_0xe98e7c=path[_0x6565('0x21')](_0x430891,_0x1ce684,util['format'](_0x6565('0x23'),_0x1ce684,_0x1bc3be,_0x6565('0x24')));}else{_0xe98e7c=path[_0x6565('0x21')](_0x430891,util['format'](_0x6565('0x25'),_0x1ce684,'csv'));}fs['writeFileSync'](_0xe98e7c,csv(_0x2ae6e9));}})[_0x6565('0x10')](function(){if(_0x450ce4){return new Promise(function(_0x4540b4){zipdir(path['join'](_0x430891,_0x1ce684),{'saveTo':path[_0x6565('0x21')](_0x430891,util['format'](_0x6565('0x25'),_0x1ce684,'zip'))},function(_0x260585,_0x51c364){rimraf(path['join'](_0x430891,_0x1ce684),function(){});_0x4540b4(_0x6565('0x26'));});});}})[_0x6565('0x10')](function(){logger['info'](util[_0x6565('0xc')]('Extraction\x20report\x20with\x20id\x20%d\x20in\x20%s\x20format\x20completed',EXTRACTED_REPORT_ID,_0x6565('0xd')));return analyticExtractedReport(_0x6565('0x27'),_0x450ce4?util[_0x6565('0xc')](_0x6565('0x25'),_0x1ce684,_0x450ce4?'zip':_0x6565('0x24')):null);});})[_0x6565('0x28')](function(_0x9b6dc1){logger[_0x6565('0xb')](util[_0x6565('0xc')](_0x6565('0x29'),EXTRACTED_REPORT_ID,'CSV'),util[_0x6565('0x2a')](_0x9b6dc1,{'showHidden':![],'depth':null}));EXIT_CODE=0x1;return analyticExtractedReport(_0x6565('0x2b'));})[_0x6565('0x2c')](function(){process[_0x6565('0x2d')](EXIT_CODE);});}main();