mirror of
https://github.com/pragma-/pbot.git
synced 2025-01-26 20:14:34 +01:00
Make unban queue more robust; allow immediate unban/unmute too
This commit is contained in:
parent
3cd63f5161
commit
414b11f787
@ -60,7 +60,7 @@ sub initialize {
|
|||||||
$self->{pbot}->{timer}->register(sub { $self->check_opped_timeouts }, 10);
|
$self->{pbot}->{timer}->register(sub { $self->check_opped_timeouts }, 10);
|
||||||
$self->{pbot}->{timer}->register(sub { $self->check_unban_timeouts }, 10);
|
$self->{pbot}->{timer}->register(sub { $self->check_unban_timeouts }, 10);
|
||||||
$self->{pbot}->{timer}->register(sub { $self->check_unmute_timeouts }, 10);
|
$self->{pbot}->{timer}->register(sub { $self->check_unmute_timeouts }, 10);
|
||||||
$self->{pbot}->{timer}->register(sub { $self->check_unban_queue }, 10);
|
$self->{pbot}->{timer}->register(sub { $self->check_unban_queue }, 30);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub can_gain_ops {
|
sub can_gain_ops {
|
||||||
@ -128,7 +128,7 @@ sub ban_user {
|
|||||||
|
|
||||||
sub unban_user {
|
sub unban_user {
|
||||||
my $self = shift;
|
my $self = shift;
|
||||||
my ($mask, $channel) = @_;
|
my ($mask, $channel, $immediately) = @_;
|
||||||
|
|
||||||
my $bans;
|
my $bans;
|
||||||
|
|
||||||
@ -166,9 +166,15 @@ sub unban_user {
|
|||||||
next if $baninfo->{type} ne '+b';
|
next if $baninfo->{type} ne '+b';
|
||||||
next if exists $unbanned{$baninfo->{banmask}};
|
next if exists $unbanned{$baninfo->{banmask}};
|
||||||
$unbanned{$baninfo->{banmask}} = 1;
|
$unbanned{$baninfo->{banmask}} = 1;
|
||||||
|
|
||||||
|
if ($immediately) {
|
||||||
|
$self->add_op_command($channel, "mode $channel -b $baninfo->{banmask}");
|
||||||
|
$self->gain_ops($channel);
|
||||||
|
} else {
|
||||||
$self->add_to_unban_queue($channel, 'b', $baninfo->{banmask});
|
$self->add_to_unban_queue($channel, 'b', $baninfo->{banmask});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
sub ban_user_timed {
|
sub ban_user_timed {
|
||||||
my $self = shift;
|
my $self = shift;
|
||||||
@ -213,16 +219,23 @@ sub mute_user {
|
|||||||
|
|
||||||
sub unmute_user {
|
sub unmute_user {
|
||||||
my $self = shift;
|
my $self = shift;
|
||||||
my ($mask, $channel) = @_;
|
my ($mask, $channel, $immediately) = @_;
|
||||||
$mask = lc $mask;
|
$mask = lc $mask;
|
||||||
$channel = lc $channel;
|
$channel = lc $channel;
|
||||||
$self->{pbot}->{logger}->log("Unmuting $channel $mask\n");
|
$self->{pbot}->{logger}->log("Unmuting $channel $mask\n");
|
||||||
|
|
||||||
if ($self->{unmute_timeout}->find_index($channel, $mask)) {
|
if ($self->{unmute_timeout}->find_index($channel, $mask)) {
|
||||||
$self->{unmute_timeout}->hash->{$channel}->{$mask}{timeout} = gettimeofday + 7200; # try again in 2 hours if unmute doesn't immediately succeed
|
$self->{unmute_timeout}->hash->{$channel}->{$mask}{timeout} = gettimeofday + 7200; # try again in 2 hours if unmute doesn't immediately succeed
|
||||||
$self->{unmute_timeout}->save;
|
$self->{unmute_timeout}->save;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($immediately) {
|
||||||
|
$self->add_op_command($channel, "mode $channel -q $mask");
|
||||||
|
$self->gain_ops($channel);
|
||||||
|
} else {
|
||||||
$self->add_to_unban_queue($channel, 'q', $mask);
|
$self->add_to_unban_queue($channel, 'q', $mask);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
sub mute_user_timed {
|
sub mute_user_timed {
|
||||||
my $self = shift;
|
my $self = shift;
|
||||||
@ -296,48 +309,33 @@ sub check_unban_queue {
|
|||||||
|
|
||||||
foreach my $channel (keys %{$self->{unban_queue}}) {
|
foreach my $channel (keys %{$self->{unban_queue}}) {
|
||||||
my ($list, $count, $modes);
|
my ($list, $count, $modes);
|
||||||
|
|
||||||
foreach my $mode (keys %{$self->{unban_queue}->{$channel}}) {
|
|
||||||
$list = '';
|
$list = '';
|
||||||
$modes = '-';
|
$modes = '-';
|
||||||
$count = 0;
|
$count = 0;
|
||||||
|
|
||||||
|
foreach my $mode (keys %{$self->{unban_queue}->{$channel}}) {
|
||||||
while (@{$self->{unban_queue}->{$channel}->{$mode}}) {
|
while (@{$self->{unban_queue}->{$channel}->{$mode}}) {
|
||||||
my $target = pop @{$self->{unban_queue}->{$channel}->{$mode}};
|
my $target = pop @{$self->{unban_queue}->{$channel}->{$mode}};
|
||||||
|
|
||||||
my $rem = @{$self->{unban_queue}->{$channel}->{$mode}};
|
|
||||||
|
|
||||||
if ($mode eq 'b') {
|
|
||||||
$self->{pbot}->{logger}->log("Unbanning $target in $channel\n");
|
|
||||||
if ($self->has_ban_timeout($channel, $target)) {
|
|
||||||
$self->{unban_timeout}->hash->{$channel}->{$target}{timeout} = gettimeofday + 7200; # try again in 2 hours if unban doesn't immediately succeed
|
|
||||||
$self->{unban_timeout}->save;
|
|
||||||
}
|
|
||||||
} elsif ($mode eq 'q') {
|
|
||||||
$self->{pbot}->{logger}->log("Unmuting $target in $channel\n");
|
|
||||||
} else {
|
|
||||||
$self->{pbot}->{logger}->log("Unknown mode [$mode] in unban queue\n");
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
$list .= " $target";
|
$list .= " $target";
|
||||||
$modes .= $mode;
|
$modes .= $mode;
|
||||||
last if ++$count == 4; # FIXME: get value from ircd
|
last if ++$count >= $self->{pbot}->{ircd}->{MODES};
|
||||||
}
|
|
||||||
|
|
||||||
if ($count) {
|
|
||||||
$self->add_op_command($channel, "mode $channel $modes $list");
|
|
||||||
$self->gain_ops($channel);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (not @{$self->{unban_queue}->{$channel}->{$mode}}) {
|
if (not @{$self->{unban_queue}->{$channel}->{$mode}}) {
|
||||||
delete $self->{unban_queue}->{$channel}->{$mode};
|
delete $self->{unban_queue}->{$channel}->{$mode};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
last if $count == $self->{pbot}->{ircd}->{MODES};
|
||||||
}
|
}
|
||||||
|
|
||||||
if (not keys $self->{unban_queue}->{$channel}) {
|
if (not keys $self->{unban_queue}->{$channel}) {
|
||||||
delete $self->{unban_queue}->{$channel};
|
delete $self->{unban_queue}->{$channel};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($count) {
|
||||||
|
$self->add_op_command($channel, "mode $channel $modes $list");
|
||||||
|
$self->gain_ops($channel);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -351,6 +349,7 @@ sub check_unban_timeouts {
|
|||||||
foreach my $channel (keys %{ $self->{unban_timeout}->hash }) {
|
foreach my $channel (keys %{ $self->{unban_timeout}->hash }) {
|
||||||
foreach my $mask (keys %{ $self->{unban_timeout}->hash->{$channel} }) {
|
foreach my $mask (keys %{ $self->{unban_timeout}->hash->{$channel} }) {
|
||||||
if($self->{unban_timeout}->hash->{$channel}->{$mask}{timeout} < $now) {
|
if($self->{unban_timeout}->hash->{$channel}->{$mask}{timeout} < $now) {
|
||||||
|
$self->{unban_timeout}->hash->{$channel}->{$mask}{timeout} = $now + 7200;
|
||||||
$self->unban_user($mask, $channel);
|
$self->unban_user($mask, $channel);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -367,6 +366,7 @@ sub check_unmute_timeouts {
|
|||||||
foreach my $channel (keys %{ $self->{unmute_timeout}->hash }) {
|
foreach my $channel (keys %{ $self->{unmute_timeout}->hash }) {
|
||||||
foreach my $mask (keys %{ $self->{unmute_timeout}->hash->{$channel} }) {
|
foreach my $mask (keys %{ $self->{unmute_timeout}->hash->{$channel} }) {
|
||||||
if($self->{unmute_timeout}->hash->{$channel}->{$mask}{timeout} < $now) {
|
if($self->{unmute_timeout}->hash->{$channel}->{$mask}{timeout} < $now) {
|
||||||
|
$self->{unmute_timeout}->hash->{$channel}->{$mask}{timeout} = $now + 7200;
|
||||||
$self->unmute_user($mask, $channel);
|
$self->unmute_user($mask, $channel);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user