mirror of
https://github.com/pragma-/pbot.git
synced 2025-01-12 04:52:37 +01:00
Add "forever" as valid parsedate option
`ban` command will not save ban to unban-timeouts if "forever" is used.
This commit is contained in:
parent
3be6755a61
commit
b5c10b73d9
@ -65,10 +65,16 @@ sub ban_user {
|
|||||||
}
|
}
|
||||||
|
|
||||||
my $botnick = $self->{pbot}->{registry}->get_value('irc', 'botnick');
|
my $botnick = $self->{pbot}->{registry}->get_value('irc', 'botnick');
|
||||||
return "" if $target =~ /\Q$botnick\E/i;
|
return "I don't think so." if $target =~ /^\Q$botnick\E!/i;
|
||||||
|
|
||||||
$self->{pbot}->{chanops}->ban_user_timed($target, $channel, $length);
|
$self->{pbot}->{chanops}->ban_user_timed($target, $channel, $length);
|
||||||
|
|
||||||
|
if ($length > 0) {
|
||||||
$length = duration($length);
|
$length = duration($length);
|
||||||
|
} else {
|
||||||
|
$length = 'all eternity';
|
||||||
|
}
|
||||||
|
|
||||||
return "/msg $nick $target banned in $channel for $length";
|
return "/msg $nick $target banned in $channel for $length";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -116,11 +116,13 @@ sub ban_user_timed {
|
|||||||
my $self = shift;
|
my $self = shift;
|
||||||
my ($mask, $channel, $length) = @_;
|
my ($mask, $channel, $length) = @_;
|
||||||
|
|
||||||
$mask .= '!*@*' if $mask !~ m/[!@]/;
|
$mask .= '!*@*' if $mask !~ m/[\$!@]/;
|
||||||
$self->ban_user($mask, $channel);
|
$self->ban_user($mask, $channel);
|
||||||
|
if ($length > 0) {
|
||||||
$self->{unban_timeout}->hash->{$channel}->{$mask}{timeout} = gettimeofday + $length;
|
$self->{unban_timeout}->hash->{$channel}->{$mask}{timeout} = gettimeofday + $length;
|
||||||
$self->{unban_timeout}->save;
|
$self->{unban_timeout}->save;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
sub join_channel {
|
sub join_channel {
|
||||||
my ($self, $channel) = @_;
|
my ($self, $channel) = @_;
|
||||||
|
@ -20,7 +20,9 @@ sub parsedate {
|
|||||||
|
|
||||||
my $seconds = 0;
|
my $seconds = 0;
|
||||||
foreach my $input (@inputs) {
|
foreach my $input (@inputs) {
|
||||||
|
return -1 if $input =~ m/forever/i;
|
||||||
$input .= ' seconds' if $input =~ m/^\d+$/;
|
$input .= ' seconds' if $input =~ m/^\d+$/;
|
||||||
|
|
||||||
my $parse = Time::ParseDate::parsedate($input, NOW => $now);
|
my $parse = Time::ParseDate::parsedate($input, NOW => $now);
|
||||||
|
|
||||||
if (not defined $parse) {
|
if (not defined $parse) {
|
||||||
@ -30,7 +32,7 @@ sub parsedate {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return ($seconds, undef);
|
return $seconds;
|
||||||
}
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
Loading…
Reference in New Issue
Block a user