mirror of
https://github.com/pragma-/pbot.git
synced 2025-01-11 20:42:38 +01:00
Allow optionally using name instead of hostmask in adminset/adminunset/adminrem commands
This commit is contained in:
parent
e3eb698f27
commit
9376c65b24
@ -81,9 +81,11 @@ sub adminadd {
|
|||||||
|
|
||||||
if(not defined $name or not defined $channel or not defined $hostmask or not defined $level
|
if(not defined $name or not defined $channel or not defined $hostmask or not defined $level
|
||||||
or not defined $password) {
|
or not defined $password) {
|
||||||
return "/msg $nick Usage: adminadd name channel hostmask level password";
|
return "/msg $nick Usage: adminadd <name> <channel> <hostmask> <level> <password>";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$channel = '.*' if lc $channel eq 'global';
|
||||||
|
|
||||||
$self->{pbot}->{admins}->add_admin($name, $channel, $hostmask, $level, $password);
|
$self->{pbot}->{admins}->add_admin($name, $channel, $hostmask, $level, $password);
|
||||||
return "Admin added.";
|
return "Admin added.";
|
||||||
}
|
}
|
||||||
@ -95,7 +97,23 @@ sub adminrem {
|
|||||||
my ($channel, $hostmask) = split / /, $arguments, 2;
|
my ($channel, $hostmask) = split / /, $arguments, 2;
|
||||||
|
|
||||||
if(not defined $channel or not defined $hostmask) {
|
if(not defined $channel or not defined $hostmask) {
|
||||||
return "/msg $nick Usage: adminrem channel hostmask";
|
return "/msg $nick Usage: adminrem <channel> <hostmask/name>";
|
||||||
|
}
|
||||||
|
|
||||||
|
$channel = lc $channel;
|
||||||
|
$hostmask = lc $hostmask;
|
||||||
|
|
||||||
|
$channel = '.*' if $channel eq 'global';
|
||||||
|
|
||||||
|
if (exists $self->{pbot}->{admins}->{admins}->hash->{$channel}) {
|
||||||
|
if (not exists $self->{pbot}->{admins}->{admins}->hash->{$channel}->{$hostmask}) {
|
||||||
|
foreach my $mask (keys $self->{pbot}->{admins}->{admins}->hash->{$channel}) {
|
||||||
|
if ($self->{pbot}->{admins}->{admins}->hash->{$channel}->{$mask}->{name} eq $hostmask) {
|
||||||
|
$hostmask = $mask;
|
||||||
|
last;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if($self->{pbot}->{admins}->remove_admin($channel, $hostmask)) {
|
if($self->{pbot}->{admins}->remove_admin($channel, $hostmask)) {
|
||||||
@ -111,7 +129,23 @@ sub adminset {
|
|||||||
my ($channel, $hostmask, $key, $value) = split / /, $arguments, 4 if defined $arguments;
|
my ($channel, $hostmask, $key, $value) = split / /, $arguments, 4 if defined $arguments;
|
||||||
|
|
||||||
if(not defined $channel or not defined $hostmask) {
|
if(not defined $channel or not defined $hostmask) {
|
||||||
return "Usage: adminset <channel> <hostmask> <key> <value>";
|
return "Usage: adminset <channel> <hostmask/name> <key> <value>";
|
||||||
|
}
|
||||||
|
|
||||||
|
$channel = lc $channel;
|
||||||
|
$hostmask = lc $hostmask;
|
||||||
|
|
||||||
|
$channel = '.*' if $channel eq 'global';
|
||||||
|
|
||||||
|
if (exists $self->{pbot}->{admins}->{admins}->hash->{$channel}) {
|
||||||
|
if (not exists $self->{pbot}->{admins}->{admins}->hash->{$channel}->{$hostmask}) {
|
||||||
|
foreach my $mask (keys $self->{pbot}->{admins}->{admins}->hash->{$channel}) {
|
||||||
|
if ($self->{pbot}->{admins}->{admins}->hash->{$channel}->{$mask}->{name} eq $hostmask) {
|
||||||
|
$hostmask = $mask;
|
||||||
|
last;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return $self->{pbot}->{admins}->{admins}->set($channel, $hostmask, $key, $value);
|
return $self->{pbot}->{admins}->{admins}->set($channel, $hostmask, $key, $value);
|
||||||
@ -123,7 +157,23 @@ sub adminunset {
|
|||||||
my ($channel, $hostmask, $key) = split / /, $arguments, 3 if defined $arguments;
|
my ($channel, $hostmask, $key) = split / /, $arguments, 3 if defined $arguments;
|
||||||
|
|
||||||
if(not defined $channel or not defined $hostmask) {
|
if(not defined $channel or not defined $hostmask) {
|
||||||
return "Usage: adminunset <channel> <hostmask> <key>";
|
return "Usage: adminunset <channel> <hostmask/name> <key>";
|
||||||
|
}
|
||||||
|
|
||||||
|
$channel = lc $channel;
|
||||||
|
$hostmask = lc $hostmask;
|
||||||
|
|
||||||
|
$channel = '.*' if $channel eq 'global';
|
||||||
|
|
||||||
|
if (exists $self->{pbot}->{admins}->{admins}->hash->{$channel}) {
|
||||||
|
if (not exists $self->{pbot}->{admins}->{admins}->hash->{$channel}->{$hostmask}) {
|
||||||
|
foreach my $mask (keys $self->{pbot}->{admins}->{admins}->hash->{$channel}) {
|
||||||
|
if ($self->{pbot}->{admins}->{admins}->hash->{$channel}->{$mask}->{name} eq $hostmask) {
|
||||||
|
$hostmask = $mask;
|
||||||
|
last;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return $self->{pbot}->{admins}->{admins}->unset($channel, $hostmask, $key);
|
return $self->{pbot}->{admins}->{admins}->unset($channel, $hostmask, $key);
|
||||||
|
Loading…
Reference in New Issue
Block a user