0859b50dff543190907b8480dacb5e30f50abffc
[motion2.git] / server / utils / client-side-logger.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 _0xe15a=['data','timestamp','error','api','auth','set','client-side-logger','use','logger','%s\x20%s\x20%s\x20%s\x20%sms\x20id=%s\x20name=%s\x20role=%s','isEmpty','\x20body=%s','format','method','headers','x-forwarded-for','connection','remoteAddress','url','responseTime','inspect','%s\x20%s\x20%s\x20%s\x20%sms\x20id=%s\x20name=%s\x20role=%s\x20device=%s','body','device','%s\x20%s\x20%s\x20%s\x20%sms\x20id=%s\x20name=%s\x20role=%s\x20device=%s\x20(id=%s\x20name=%s)','other','agent_id','agent_name','test','setupLoggers','fs-extra','lodash','express-winston','util','./loggers','./safe-template','safeTemplate','./mask-sensitive-data','join','/var','log','xcally','client','role','name','ensureDir','then','user','no-user'];(function(_0x4efd45,_0x10ac98){var _0x18594e=function(_0x2cf321){while(--_0x2cf321){_0x4efd45['push'](_0x4efd45['shift']());}};_0x18594e(++_0x10ac98);}(_0xe15a,0x80));var _0xae15=function(_0x36884e,_0x48008f){_0x36884e=_0x36884e-0x0;var _0x1cc367=_0xe15a[_0x36884e];return _0x1cc367;};var fs=require(_0xae15('0x0'));var _=require(_0xae15('0x1'));var ewinston=require(_0xae15('0x2'));var path=require('path');var util=require(_0xae15('0x3'));var fileLogger=require(_0xae15('0x4'))['fileLogger'];var safeTemplate=require(_0xae15('0x5'))[_0xae15('0x6')];var maskSensitiveData=require(_0xae15('0x7'))['maskSensitiveData'];function ClientSideLogger(){function _0x536abd(_0x40745e){var _0x545cca=path[_0xae15('0x8')](_0xae15('0x9'),_0xae15('0xa'),_0xae15('0xb'));var _0xd69f51=path[_0xae15('0x8')](_0xae15('0xc'),_0x40745e[_0xae15('0xd')]+'-'+_0x40745e[_0xae15('0xe')]);return fs[_0xae15('0xf')](path['join'](_0x545cca,_0xd69f51))[_0xae15('0x10')](function(){var _0x34b5e6=fileLogger(_0xae15('0xc'),path[_0xae15('0x8')](_0x545cca,_0xd69f51));return _0x34b5e6;})['catch'](function(_0x5983c9){throw _0x5983c9;});}this[_0xae15('0xa')]=function(_0x5b5a96,_0x3784ef,_0x55c911,_0x292179){return _0x536abd(_0x5b5a96[_0xae15('0x11')])[_0xae15('0x10')](function(_0x3ea41c){var _0x5b0f07=_0x3ea41c[_0x3784ef];return _0x5b0f07;})['then'](function(_0x5ac7dc){var _0x218cbd=_0x5b5a96[_0xae15('0x11')]?_0x5b5a96['user']['id']:_0xae15('0x12');var _0x172a88=_0x292179[_0xae15('0x13')];var _0x8be3f4=_0x292179[_0xae15('0x14')];var _0x500117=new Date(Number(_0x8be3f4));return _0x5ac7dc(_0x218cbd,_0x500117,_0x55c911,_0x172a88);})['catch'](function(_0x742ae4){fileLogger(_0xae15('0xc'))[_0xae15('0x15')](_0x742ae4);});};}function setupLoggers(_0x37025e){return new Promise(function(_0x47501a){var _0x45f05d=new ClientSideLogger();var _0x1f34ba=fileLogger(_0xae15('0x16'));var _0x30943f=fileLogger(_0xae15('0x17'));_0x37025e[_0xae15('0x18')](_0xae15('0x19'),_0x45f05d);_0x37025e[_0xae15('0x1a')](ewinston[_0xae15('0x1b')]({'winstonInstance':_0x1f34ba,'meta':![],'statusLevels':!![],'msg':function(_0x33a245,_0x274a04){var _0x36ea03=_0xae15('0x1c');if(!_[_0xae15('0x1d')](_0x33a245['body'])){_0x36ea03+=_0xae15('0x1e');var _0x430d7e=_0x33a245['body'];maskSensitiveData(_0x430d7e);}return safeTemplate(util[_0xae15('0x1f')](_0x36ea03,_0x33a245[_0xae15('0x20')],_0x33a245[_0xae15('0x21')][_0xae15('0x22')]?_0x33a245[_0xae15('0x21')][_0xae15('0x22')]:_0x33a245[_0xae15('0x23')][_0xae15('0x24')]||_0x33a245['ip'],_0x33a245[_0xae15('0x25')],_0x274a04['statusCode'],_0x274a04[_0xae15('0x26')],_0x33a245['user']?_0x33a245[_0xae15('0x11')]['id']:null,_0x33a245['user']?_0x33a245[_0xae15('0x11')][_0xae15('0xe')]:null,_0x33a245[_0xae15('0x11')]?_0x33a245[_0xae15('0x11')]['role']:null,_0x430d7e?util[_0xae15('0x27')](_0x430d7e,![],null):''));}}));_0x37025e['use'](ewinston[_0xae15('0x1b')]({'winstonInstance':_0x30943f,'meta':![],'statusLevels':!![],'msg':function(_0x1c2885,_0x373543){var _0x5de157=_0xae15('0x28');if(_0x1c2885[_0xae15('0x29')]&&_0x1c2885[_0xae15('0x29')][_0xae15('0x2a')]&&_0x1c2885['body']['agent_id']){_0x5de157=_0xae15('0x2b');}return util[_0xae15('0x1f')](_0x5de157,_0x1c2885[_0xae15('0x20')],_0x1c2885[_0xae15('0x21')][_0xae15('0x22')]?_0x1c2885[_0xae15('0x21')][_0xae15('0x22')]:_0x1c2885[_0xae15('0x23')][_0xae15('0x24')]||_0x1c2885['ip'],_0x1c2885[_0xae15('0x25')],_0x373543['statusCode'],_0x373543[_0xae15('0x26')],_0x1c2885[_0xae15('0x11')]?_0x1c2885[_0xae15('0x11')]['id']:null,_0x1c2885[_0xae15('0x11')]?_0x1c2885[_0xae15('0x11')][_0xae15('0xe')]:null,_0x1c2885['user']?_0x1c2885['user'][_0xae15('0xd')]:null,_0x1c2885[_0xae15('0x29')]&&_0x1c2885[_0xae15('0x29')][_0xae15('0x2a')]?_0x1c2885['body'][_0xae15('0x2a')]:_0xae15('0x2c'),_0x1c2885[_0xae15('0x29')]&&_0x1c2885[_0xae15('0x29')][_0xae15('0x2d')]?_0x1c2885['body'][_0xae15('0x2d')]:'',_0x1c2885[_0xae15('0x29')]&&_0x1c2885[_0xae15('0x29')][_0xae15('0x2e')]?_0x1c2885['body'][_0xae15('0x2e')]:'');},'ignoreRoute':function(_0x2092ba){var _0x581f5a=/\/api\/users\/[0-9]+\/(login|logout)/gi;return!_0x581f5a[_0xae15('0x2f')](_0x2092ba['url']);}}));return _0x47501a();});}exports[_0xae15('0x30')]=setupLoggers;