summaryrefslogtreecommitdiffstats
path: root/src/activityviewer.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/activityviewer.cpp')
-rw-r--r--src/activityviewer.cpp297
1 files changed, 297 insertions, 0 deletions
diff --git a/src/activityviewer.cpp b/src/activityviewer.cpp
new file mode 100644
index 0000000..849c0ad
--- /dev/null
+++ b/src/activityviewer.cpp
@@ -0,0 +1,297 @@
+/*
+ * Copyright (C) 2004 Robert Hogan <robert at roberthogan dot net>
+ */
+#include <config.h>
+
+
+#include "activityviewer.h"
+#include "dbviewer.h"
+#include "klamav.h"
+#include "klamavconfig.h"
+#include "collectiondb.h"
+
+
+#include <klocale.h>
+#include <kiconloader.h>
+#include <kmenubar.h>
+#include <kstatusbar.h>
+#include <kkeydialog.h>
+#include <kio/netaccess.h>
+#include <kfiledialog.h>
+#include <kdebug.h>
+#include <klistviewsearchline.h>
+#include <ktoolbarbutton.h> //ctor
+
+
+#include <kbuttonbox.h>
+#include <kurlrequester.h>
+#include <kurlcompletion.h>
+#include <kcombobox.h>
+#include <qlayout.h>
+#include <kmessagebox.h>
+#include <kstandarddirs.h>
+#include <qtoolbutton.h>
+
+const char *log_type[] = {
+ "All Types",
+ "Launch",
+ "Shutdown",
+ "Manual Scan",
+ "Error Found",
+ "Virus Found",
+ "Auto-Scan",
+ "Updates",
+ "Quarantine",
+ 0
+};
+
+const char *log_days[] = {
+ "Last 1 Day",
+ "Last 2 Days",
+ "Last 7 Days",
+ "Last 14 Days",
+ "Last 31 Days",
+ "Last 62 Days",
+ "Last 365 Days",
+ 0
+};
+
+
+Activityviewer::Activityviewer(QWidget *parent, const char *name)
+ : QWidget(parent, name)
+{
+
+ //Create GUI
+
+ QVBoxLayout *vbox = new QVBoxLayout(this, KDialog::marginHint(),
+ KDialog::spacingHint(), "vbox");
+
+ QWidget* privateLayoutWidget2 = new QWidget( this, "dblayout" );
+
+ QGridLayout *layout = new QGridLayout(privateLayoutWidget2, 2, 6, 10, 4);
+
+ QLabel *combo_label = new QLabel(i18n("Display Event Type:"), privateLayoutWidget2);
+ //combo_label->setFixedSize(combo_label->sizeHint());
+ layout->addWidget(combo_label,0,0);
+ combo_label->adjustSize();
+
+ check_combo = new QComboBox(false, privateLayoutWidget2);
+ check_combo->insertStrList(log_type);
+ check_combo->adjustSize();
+ //check_combo->setFixedSize(check_combo->size());
+ layout->addWidget(check_combo,0,1);
+
+ QLabel *days_label = new QLabel(i18n(" from the "), privateLayoutWidget2);
+ //combo_label->setFixedSize(combo_label->sizeHint());
+ layout->addWidget(days_label,0,2);
+ days_label->adjustSize();
+
+ days_combo = new QComboBox(false, privateLayoutWidget2);
+ days_combo->insertStrList(log_days);
+ days_combo->adjustSize();
+ //check_combo->setFixedSize(check_combo->size());
+ layout->addWidget(days_combo,0,3);
+
+
+
+ QToolButton* options = new QToolButton( privateLayoutWidget2,"play" );
+ options->setIconSet( SmallIconSet( "configure" ) );
+ options->setTextLabel("Options");
+ options->setTextPosition(QToolButton::Right);
+ options->setUsesTextLabel(true);
+ options->adjustSize();
+ layout->addWidget(options,0,6);
+
+ vbox->addWidget(privateLayoutWidget2);
+ connect( options, SIGNAL(clicked()), SLOT(slotOptions()) );
+
+
+
+ QGroupBox *group2 = new QGroupBox(i18n("Activity"), this);
+ vbox->addWidget(group2);
+
+ QGridLayout *layout2 = new QGridLayout( group2, 1, 1, KDialog::spacingHint(), KDialog::spacingHint(), "layout2");
+ layout2->addRowSpacing(0, group2->fontMetrics().height());
+ layout2->addRowSpacing(1, group2->fontMetrics().height());
+ //layout2->setColStretch(0, 1);
+ //layout2->setColStretch(1, 1);
+
+ QWidget *hlp2 = new QWidget( group2 );
+ layout2->addMultiCellWidget(hlp2, 1,1, 0,0);
+ QVBoxLayout *dir_layout2 = new QVBoxLayout(hlp2, KDialog::spacingHint() );
+
+
+
+ KToolBarButton *button;
+ KToolBar* searchToolBar = new KToolBar( hlp2 );
+ searchToolBar->setMovingEnabled(false);
+ searchToolBar->setFlat(true);
+ searchToolBar->setIconSize( 16 );
+ searchToolBar->setEnableContextMenu( false );
+
+ button = new KToolBarButton( "locationbar_erase", 0, searchToolBar );
+ /*QLabel *filter_label =*/ new QLabel( i18n("Search:") + " ", searchToolBar );
+
+
+ currentbox = new KListView(hlp2);
+ currentbox->setShowSortIndicator(true);
+
+ QFontMetrics rb_fm(currentbox->fontMetrics());
+ //currentbox->setMinimumSize(rb_fm.width("0")*55,
+ // rb_fm.lineSpacing()*15);
+ ////kdDebug() << ((currentbox->width())/3) << endl;
+ currentbox->addColumn( "Date",0);
+ currentbox->addColumn( "Type",0);
+ currentbox->addColumn( "Event",0);
+ currentbox->addColumn( "File",0);
+ currentbox->setResizeMode(QListView::AllColumns);
+ currentbox->setSelectionMode( QListView::Extended );
+ currentbox->setAllColumnsShowFocus(true);
+
+// qmenu = new QPopupMenu( currentbox );
+
+// connect(currentbox, SIGNAL( contextMenuRequested( QListViewItem *, const QPoint& , int ) ),
+// this, SLOT( slotRMB( QListViewItem *, const QPoint &, int ) ) );
+
+ kLineEdit1 = new KListViewSearchLine( (QWidget *)searchToolBar, currentbox,"klinedit1");
+/* QValueList<int> columns;
+ columns.append(0);
+ columns.append(1);
+ columns.append(2);*/
+/* kLineEdit1->setSearchColumns();*/
+ //kLineEdit1->setMaxLength(2);
+ connect(button, SIGNAL( clicked() ),
+ kLineEdit1, SLOT(clear()) );
+ connect(check_combo, SIGNAL( activated(const QString &) ),
+ this, SLOT(allActivityOfType(const QString &) ));
+ connect(days_combo, SIGNAL( activated(const QString &) ),
+ this, SLOT(allActivityOfDate(const QString &) ));
+
+
+ searchToolBar->setStretchableWidget( kLineEdit1 );
+
+ dir_layout2->addWidget( searchToolBar,0,0);
+
+ dir_layout2->addWidget(currentbox,1,0);
+
+ //layout->addMultiCellWidget(currentbox);
+
+ CollectionDB::instance()->expireActivity( QString("%1").arg(KlamavConfig::expireDays()) );
+
+ allActivityOfDate(days_combo->currentText());
+
+
+}
+
+void Activityviewer::populateActivity()
+{
+
+ currentbox->clear();
+
+ if (!(activity.isEmpty())){
+
+ int i=0;
+ QString eventdate;
+ QString eventtype;
+ QString event;
+ QString file;
+ for (QStringList::Iterator it = activity.begin(); it != activity.end(); it++ ){
+ ////kdDebug() << *it << endl;
+ if (i==0){
+ eventdate = *it;
+ i++;
+ }else if (i==1){
+ eventtype = *it;
+ i++;
+ }else if (i==2){
+ event = *it;
+ i++;
+ }else if (i==3){
+ file = *it;
+ i=0;
+ new EventListItem( currentbox, eventdate, eventtype,event, file);
+ }
+ }
+ }
+}
+
+void Activityviewer::allActivity()
+{
+
+ activity = CollectionDB::instance()->allActivity();
+
+ populateActivity();
+}
+
+void Activityviewer::allActivityOfType(const QString &type)
+{
+
+
+ QString days = days_combo->currentText().remove("Last ").remove(" Days").remove(" Day");
+
+ activity = CollectionDB::instance()->allActivityOfType(type,days);
+
+ populateActivity();
+}
+
+void Activityviewer::allActivityOfDate(const QString &days)
+{
+ QString stripdays = days;
+ stripdays = stripdays.remove("Last ").remove(" Days").remove(" Day");
+ QString type = check_combo->currentText();
+
+ activity = CollectionDB::instance()->allActivityOfType(type,stripdays);
+
+ populateActivity();
+}
+
+void Activityviewer::insertItem(const QString &date, const QString &type, const QString &event, const QString &file)
+{
+
+ if ((check_combo->currentText() == type) || (check_combo->currentText() == "All Types"))
+ new EventListItem( currentbox, date, type, event, file);
+
+}
+
+void Activityviewer::slotOptions(){
+
+
+ kmain->slotConfigKlamav( "Event Logging" );
+
+}
+
+
+Activityviewer::~Activityviewer()
+{
+}
+
+EventListItem::EventListItem( KListView *parent, QString label1, QString label2 , QString label3, QString label4)
+ : KListViewItem( parent, label1, label2 , label3, label4 )
+{
+}
+
+EventListItem::~EventListItem()
+{
+}
+
+
+// paint ze peons
+void EventListItem::paintCell ( QPainter * p, const QColorGroup & cg, int column, int width, int align )
+{
+ QColorGroup cg2(cg);
+
+
+ if (( this->text(1).contains( "Virus")) || ( this->text(1).contains( "Error")))
+ cg2.setColor(QColorGroup::Text, Qt::red);
+ else if ( this->text(1) == "Updates")
+ cg2.setColor(QColorGroup::Text, Qt::blue);
+ else if ( this->text(1) == "Quarantine")
+ cg2.setColor(QColorGroup::Text, Qt::green);
+
+ KListViewItem::paintCell( p, cg2, column, width, align );
+
+}
+
+
+
+#include "activityviewer.moc"