diff options
author | Olivier Blin <oblin@mandriva.org> | 2005-02-16 13:16:08 +0000 |
---|---|---|
committer | Olivier Blin <oblin@mandriva.org> | 2005-02-16 13:16:08 +0000 |
commit | b8a654270fe2f980ce0da3aa4eb5bad1f4d7243a (patch) | |
tree | bf6555a45f16ddbfc81e2ae8bad3d69685007a37 | |
parent | a3a4b90c2c4dcd0eff81e9c8983bbe742d1653a1 (diff) | |
download | drakx-b8a654270fe2f980ce0da3aa4eb5bad1f4d7243a.tar drakx-b8a654270fe2f980ce0da3aa4eb5bad1f4d7243a.tar.gz drakx-b8a654270fe2f980ce0da3aa4eb5bad1f4d7243a.tar.bz2 drakx-b8a654270fe2f980ce0da3aa4eb5bad1f4d7243a.tar.xz drakx-b8a654270fe2f980ce0da3aa4eb5bad1f4d7243a.zip |
allow to sort blacklist by date, attacker or attack type
-rw-r--r-- | perl-install/standalone/drakids | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/perl-install/standalone/drakids b/perl-install/standalone/drakids index 2eaa7c4da..6d81979e6 100644 --- a/perl-install/standalone/drakids +++ b/perl-install/standalone/drakids @@ -14,6 +14,7 @@ use Gtk2::SimpleList; use ugtk2 qw(:create :helpers :wrappers); my $blacklist = Gtk2::SimpleList->new(addr => 'hidden', + timestamp => 'hidden', N("Date") => 'text', N("Attacker") => 'text', N("Attack type") => 'text', @@ -22,6 +23,13 @@ my $blacklist = Gtk2::SimpleList->new(addr => 'hidden', N("Protocol") => 'text', ); $blacklist->get_selection->set_mode('multiple'); +$blacklist->set_headers_clickable(1); +for (0, 1, 2) { + $blacklist->get_column($_)->signal_connect('clicked', \&sort_by_column, $blacklist->get_model); + #- sort on timestamp if Date column is clicked + #- sort columns include hidden columns while list columns don't + $blacklist->get_column($_)->set_sort_column_id($_ == 0 ? 1 : $_ + 2); +} my $activefw = activefw->new(sub { my ($con, $msg) = @_; @@ -60,6 +68,13 @@ Gtk2->main; ugtk2::exit(0); +sub sort_by_column { + my ($column, $model) = @_; + my $col_id = $column->get_sort_column_id; + my ($old_id, $old_order) = $model->get_sort_column_id; + $model->set_sort_column_id($col_id, $old_id == $col_id && $old_order ne 'descending' ? 'ascending' : 'descending'); +} + sub handle_init { $activefw->find_daemon; init_blacklist(); @@ -80,6 +95,7 @@ sub handle_blacklist { my ($timestamp, $indev, $prefix, $sensor, $protocol, $addr, $port, $icmp_type) = @_; push @{$blacklist->{data}}, [ $addr, + $timestamp, activefw::format_date($timestamp), activefw::resolve_address(activefw::get_ip_address($addr)), $prefix eq 'SCAN' ? N("Port scanning") : |