2011-06-19 21:57:34 +03:00
/*
2018-06-06 16:48:17 +03:00
* Bittorrent Client using Qt and libtorrent .
2011-06-19 21:57:34 +03:00
* Copyright ( C ) 2011 Christophe Dumez
*
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation ; either version 2
* of the License , or ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write to the Free Software
* Foundation , Inc . , 51 Franklin Street , Fifth Floor , Boston , MA 02110 - 1301 , USA .
*
* In addition , as a special exception , the copyright holders give permission to
* link this program with the OpenSSL project ' s " OpenSSL " library ( or with
* modified versions of it that use the same license as the " OpenSSL " library ) ,
* and distribute the linked executables . You must obey the GNU General Public
* License in all respects for all of the code used other than " OpenSSL " . If you
* modify file ( s ) , you may extend this exception to your version of the file ( s ) ,
* but you are not obligated to do so . If you do not wish to do so , delete this
* exception statement from your version .
*/
2018-06-14 12:54:23 +03:00
# include "executionlogwidget.h"
2018-06-06 16:48:17 +03:00
2015-01-06 01:25:56 +02:00
# include <QColor>
2018-06-06 16:48:17 +03:00
# include <QDateTime>
2015-01-06 01:25:56 +02:00
# include <QPalette>
2018-06-06 16:48:17 +03:00
2018-11-18 20:40:37 +02:00
# include "base/global.h"
2015-04-19 18:17:47 +03:00
# include "guiiconprovider.h"
2011-09-24 15:39:27 +03:00
# include "loglistwidget.h"
2018-06-14 12:54:23 +03:00
# include "ui_executionlogwidget.h"
2010-12-20 18:07:36 +00:00
2018-06-14 12:54:23 +03:00
ExecutionLogWidget : : ExecutionLogWidget ( QWidget * parent , const Log : : MsgTypes & types )
2015-01-06 01:48:24 +02:00
: QWidget ( parent )
2018-06-14 12:54:23 +03:00
, m_ui ( new Ui : : ExecutionLogWidget )
2018-07-21 17:16:28 +08:00
, m_msgList ( new LogListWidget ( MAX_LOG_MESSAGES , Log : : MsgTypes ( types ) ) )
2015-01-06 01:48:24 +02:00
, m_peerList ( new LogListWidget ( MAX_LOG_MESSAGES ) )
2010-12-20 18:07:36 +00:00
{
2018-06-06 16:48:17 +03:00
m_ui - > setupUi ( this ) ;
2011-09-24 15:39:27 +03:00
2017-06-12 22:47:28 +03:00
# ifndef Q_OS_MAC
2018-06-06 16:48:17 +03:00
m_ui - > tabConsole - > setTabIcon ( 0 , GuiIconProvider : : instance ( ) - > getIcon ( " view-calendar-journal " ) ) ;
m_ui - > tabConsole - > setTabIcon ( 1 , GuiIconProvider : : instance ( ) - > getIcon ( " view-filter " ) ) ;
2017-06-12 22:47:28 +03:00
# endif
2018-06-06 16:48:17 +03:00
m_ui - > tabGeneral - > layout ( ) - > addWidget ( m_msgList ) ;
m_ui - > tabBan - > layout ( ) - > addWidget ( m_peerList ) ;
2011-09-24 15:39:27 +03:00
2018-06-06 16:48:17 +03:00
const Logger * const logger = Logger : : instance ( ) ;
2018-11-27 22:15:04 +02:00
for ( const Log : : Msg & msg : asConst ( logger - > getMessages ( ) ) )
2015-01-06 01:48:24 +02:00
addLogMessage ( msg ) ;
2018-11-27 22:15:04 +02:00
for ( const Log : : Peer & peer : asConst ( logger - > getPeers ( ) ) )
2015-01-06 01:48:24 +02:00
addPeerMessage ( peer ) ;
2018-06-14 12:54:23 +03:00
connect ( logger , & Logger : : newLogMessage , this , & ExecutionLogWidget : : addLogMessage ) ;
connect ( logger , & Logger : : newLogPeer , this , & ExecutionLogWidget : : addPeerMessage ) ;
2010-12-20 18:07:36 +00:00
}
2018-06-14 12:54:23 +03:00
ExecutionLogWidget : : ~ ExecutionLogWidget ( )
2010-12-20 18:07:36 +00:00
{
2015-01-06 01:48:24 +02:00
delete m_msgList ;
delete m_peerList ;
2018-06-06 16:48:17 +03:00
delete m_ui ;
2010-12-20 18:07:36 +00:00
}
2018-06-14 12:54:23 +03:00
void ExecutionLogWidget : : showMsgTypes ( const Log : : MsgTypes & types )
2016-01-24 21:38:45 +02:00
{
m_msgList - > showMsgTypes ( types ) ;
}
2018-06-14 12:54:23 +03:00
void ExecutionLogWidget : : addLogMessage ( const Log : : Msg & msg )
2010-12-20 18:07:36 +00:00
{
2015-01-06 01:48:24 +02:00
QString text ;
QDateTime time = QDateTime : : fromMSecsSinceEpoch ( msg . timestamp ) ;
QColor color ;
2015-01-06 01:25:56 +02:00
2015-01-06 01:48:24 +02:00
switch ( msg . type ) {
case Log : : INFO :
color . setNamedColor ( " blue " ) ;
break ;
case Log : : WARNING :
color . setNamedColor ( " orange " ) ;
break ;
case Log : : CRITICAL :
color . setNamedColor ( " red " ) ;
break ;
default :
color = QApplication : : palette ( ) . color ( QPalette : : WindowText ) ;
}
2015-01-06 01:25:56 +02:00
2015-02-08 14:43:14 +01:00
text = " <font color='grey'> " + time . toString ( Qt : : SystemLocaleShortDate ) + " </font> - <font color=' " + color . name ( ) + " '> " + msg . message + " </font> " ;
2016-01-24 21:38:45 +02:00
m_msgList - > appendLine ( text , msg . type ) ;
2010-12-20 18:07:36 +00:00
}
2018-06-14 12:54:23 +03:00
void ExecutionLogWidget : : addPeerMessage ( const Log : : Peer & peer )
2010-12-20 18:07:36 +00:00
{
2015-01-06 01:48:24 +02:00
QString text ;
QDateTime time = QDateTime : : fromMSecsSinceEpoch ( peer . timestamp ) ;
2015-01-06 01:25:56 +02:00
2015-01-06 01:48:24 +02:00
if ( peer . blocked )
2018-03-06 23:49:12 +08:00
text = " <font color='grey'> " + time . toString ( Qt : : SystemLocaleShortDate ) + " </font> - "
+ tr ( " <font color='red'>%1</font> was blocked %2 " , " x.y.z.w was blocked " ) . arg ( peer . ip , peer . reason ) ;
2015-01-06 01:48:24 +02:00
else
2015-02-08 14:43:14 +01:00
text = " <font color='grey'> " + time . toString ( Qt : : SystemLocaleShortDate ) + " </font> - " + tr ( " <font color='red'>%1</font> was banned " , " x.y.z.w was banned " ) . arg ( peer . ip ) ;
2015-01-06 01:25:56 +02:00
2016-01-24 21:38:45 +02:00
m_peerList - > appendLine ( text , Log : : NORMAL ) ;
2010-12-20 18:07:36 +00:00
}