Built motion from commit 87cd5f02.|2.5.48
[motion2.git] / server / utils / loggers.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 _0x0b42=['gray','bold\x20magenta','bold\x20blue','addColors','format','%s-%s.log','message','replace','{{{','}}}','YYYY-MM-DD\x20HH:mm:ss','toUpperCase','meta','keys','length','stringify','[%s]\x20[%s]\x20%s\x20-\x20%s\x20%s','level','Logger','transports','Console','warn','File','%s-%s','error','consoleLogger','fileLogger','path','util','moment','winston','../config/environment','debugLevel','toLowerCase','info','redBG\x20white','red','bold\x20yellow','white','bold\x20white','bold\x20green'];(function(_0x20fdc1,_0xde1296){var _0x25397c=function(_0x814b51){while(--_0x814b51){_0x20fdc1['push'](_0x20fdc1['shift']());}};_0x25397c(++_0xde1296);}(_0x0b42,0x1de));var _0x20b4=function(_0x71b971,_0x5a0efe){_0x71b971=_0x71b971-0x0;var _0x3f6769=_0x0b42[_0x71b971];return _0x3f6769;};'use strict';var path=require(_0x20b4('0x0'));var util=require(_0x20b4('0x1'));var moment=require(_0x20b4('0x2'));var winston=require(_0x20b4('0x3'));var config=require(_0x20b4('0x4'));var debugLevel=config['debugLevel']?config[_0x20b4('0x5')][_0x20b4('0x6')]():_0x20b4('0x7');var XC_LOG_LEVELS={'fatal':0x0,'error':0x0,'warn':0x1,'info':0x2,'print':0x2,'success':0x2,'http':0x3,'verbose':0x4,'debug':0x5,'silly':0x6};var XC_LOG_COLORS={'fatal':_0x20b4('0x8'),'error':_0x20b4('0x9'),'warn':_0x20b4('0xa'),'info':_0x20b4('0xb'),'print':_0x20b4('0xc'),'success':_0x20b4('0xd'),'http':_0x20b4('0xe'),'verbose':_0x20b4('0xf'),'debug':_0x20b4('0x10'),'silly':'bold\x20cyan'};winston[_0x20b4('0x11')](XC_LOG_COLORS);function getLogFileName(_0xbea2e3,_0x337e31,_0x35f58b){var _0x41410d=_0xbea2e3||'/var/log/xcally';return path['join'](_0x41410d,util[_0x20b4('0x12')](_0x20b4('0x13'),_0x337e31,_0x35f58b));}function formatter(_0x5b9a41,_0x383782){_0x383782[_0x20b4('0x14')]=_0x383782[_0x20b4('0x14')][_0x20b4('0x15')](/@@{/g,_0x20b4('0x16'))[_0x20b4('0x15')](/}@@/g,_0x20b4('0x17'))[_0x20b4('0x15')](/@{/g,'{{')[_0x20b4('0x15')](/}@/g,'}}');return util[_0x20b4('0x12')]('[%s]\x20[%s]\x20%s\x20-\x20%s',moment()[_0x20b4('0x12')](_0x20b4('0x18')),_0x383782['level'][_0x20b4('0x19')](),_0x5b9a41,_0x383782[_0x20b4('0x14')]);}function fileFormat(_0x27365d,_0x65d75c){_0x65d75c['message']=_0x65d75c[_0x20b4('0x14')][_0x20b4('0x15')](/@@{/g,_0x20b4('0x16'))[_0x20b4('0x15')](/}@@/g,'}}}')[_0x20b4('0x15')](/@{/g,'{{')[_0x20b4('0x15')](/}@/g,'}}');var _0x39cf28=_0x65d75c[_0x20b4('0x1a')]&&Object[_0x20b4('0x1b')](_0x65d75c[_0x20b4('0x1a')])[_0x20b4('0x1c')]?'\x0a\x09'+JSON[_0x20b4('0x1d')](_0x65d75c[_0x20b4('0x1a')]):'';return util[_0x20b4('0x12')](_0x20b4('0x1e'),moment()[_0x20b4('0x12')](_0x20b4('0x18')),_0x65d75c[_0x20b4('0x1f')][_0x20b4('0x19')](),_0x27365d,_0x65d75c['message'],_0x39cf28);}function consoleLogger(){var _0x58571c=new winston[(_0x20b4('0x20'))]({'levels':XC_LOG_LEVELS,'transports':[new winston[(_0x20b4('0x21'))][(_0x20b4('0x22'))]({'level':_0x20b4('0x23'),'json':![],'formatter':function(_0x4d1102){return formatter('',_0x4d1102);}})]});return _0x58571c;}function fileLogger(_0x1a5b1c,_0x38446c){var _0x5754e1=new winston[(_0x20b4('0x20'))]({'levels':XC_LOG_LEVELS,'transports':[new winston[(_0x20b4('0x21'))][(_0x20b4('0x24'))]({'name':util[_0x20b4('0x12')](_0x20b4('0x25'),_0x1a5b1c,'error'),'filename':getLogFileName(_0x38446c,_0x1a5b1c,_0x20b4('0x26')),'level':_0x20b4('0x26'),'json':![],'maxsize':0xa00000,'maxFiles':0xa,'tailable':!![],'formatter':function(_0x396b50){return fileFormat(_0x1a5b1c,_0x396b50);}}),new winston['transports'][(_0x20b4('0x24'))]({'name':util[_0x20b4('0x12')](_0x20b4('0x25'),_0x1a5b1c,debugLevel),'filename':getLogFileName(_0x38446c,_0x1a5b1c,debugLevel),'level':debugLevel,'json':![],'maxsize':0xa00000,'maxFiles':0xa,'tailable':!![],'formatter':function(_0x495367){return fileFormat(_0x1a5b1c,_0x495367);}}),new winston['transports']['Console']({'level':_0x20b4('0x23'),'json':![],'formatter':function(_0x56243b){return fileFormat(_0x1a5b1c,_0x56243b);}})]});return _0x5754e1;}exports[_0x20b4('0x27')]=consoleLogger;exports[_0x20b4('0x28')]=fileLogger;