3
0
mirror of https://github.com/pragma-/pbot.git synced 2025-01-11 20:42:38 +01:00

Capabilities: cap command now supports "add" and "remove"

This commit is contained in:
Pragmatic Software 2020-02-03 18:52:21 -08:00
parent 9b86da6047
commit 58233293fb

View File

@ -53,17 +53,17 @@ sub has {
my ($self, $cap, $subcap, $depth) = @_; my ($self, $cap, $subcap, $depth) = @_;
my $cap_data = $self->{caps}->get_data($cap); my $cap_data = $self->{caps}->get_data($cap);
return 0 if not defined $cap_data; return 0 if not defined $cap_data;
return 1 if $cap eq $subcap; return 1 if $cap eq $subcap and $cap_data->{$subcap};
$depth //= 10; $depth //= 10;
if (--$depth <= 0) { if (--$depth <= 0) {
$self->{pbot}->{logger}->log("Max recursion reached for PBot::Capabilities->has()\n"); $self->{pbot}->{logger}->log("Max recursion reached for PBot::Capabilities->has($cap, $subcap)\n");
return 0; return 0;
} }
foreach my $c (keys %{$cap_data}) { foreach my $c (keys %{$cap_data}) {
next if $c eq '_name'; next if $c eq '_name';
return 1 if $c eq $subcap; return 1 if $c eq $subcap and $cap_data->{$c};
return 1 if $self->has($c, $subcap, $depth); return 1 if $self->has($c, $subcap, $depth);
} }
return 0; return 0;
@ -75,6 +75,7 @@ sub userhas {
return 1 if $user->{$cap}; return 1 if $user->{$cap};
foreach my $key (keys %{$user}) { foreach my $key (keys %{$user}) {
next if $key eq '_name'; next if $key eq '_name';
next if not $user->{$key};
return 1 if $self->has($key, $cap); return 1 if $self->has($key, $cap);
} }
return 0; return 0;
@ -110,16 +111,27 @@ sub add {
} }
sub remove { sub remove {
my ($self, $cap) = @_; my ($self, $cap, $subcap) = @_;
$cap = lc $cap; $cap = lc $cap;
if (not defined $subcap) {
foreach my $c (keys %{$self->{caps}->{hash}}) { foreach my $c (keys %{$self->{caps}->{hash}}) {
next if $c eq '_name'; next if $c eq '_name';
foreach my $sub_cap (keys %{$self->{caps}->{hash}->{$c}}) { foreach my $sub_cap (keys %{$self->{caps}->{hash}->{$c}}) {
delete $self->{caps}->{hash}->{$c}->{$sub_cap} if $sub_cap eq $cap; delete $self->{caps}->{hash}->{$c}->{$sub_cap} if $sub_cap eq $cap;
} }
delete $self->{caps}->{hash}->{$c} if $c eq $cap; if ($c eq $cap) {
delete $self->{caps}->{hash}->{$c};
} }
} }
} else {
$subcap = lc $subcap;
if (exists $self->{caps}->{hash}->{$cap}) {
delete $self->{caps}->{hash}->{$cap}->{$subcap};
}
}
$self->{caps}->save;
}
sub rebuild_botowner_capabilities { sub rebuild_botowner_capabilities {
my ($self) = @_; my ($self) = @_;
@ -214,9 +226,36 @@ sub capcmd {
} }
when ('add') { when ('add') {
my $cap = $self->{pbot}->{interpreter}->shift_arg($stuff->{arglist});
my $subcap = $self->{pbot}->{interpreter}->shift_arg($stuff->{arglist});
return "Usage: cap add <capability> [sub-capability]" if not defined $cap;
if (not defined $subcap) {
return "Capability $cap already exists. Did you mean to add a sub-capability to it? Usage: cap add <capability> [sub-capability]" if $self->exists($cap);
$self->add($cap);
return "Capability $cap added.";
} else {
return "You cannot add a capability to itself." if lc $cap eq lc $subcap;
return "No such capability $subcap." if not $self->exists($subcap);
$self->add($cap, $subcap);
return "Capability $subcap added to $cap.";
}
} }
when ('remove') { when ('remove') {
my $cap = $self->{pbot}->{interpreter}->shift_arg($stuff->{arglist});
my $subcap = $self->{pbot}->{interpreter}->shift_arg($stuff->{arglist});
return "Usage: cap remove <capability> [sub-capability]" if not defined $cap;
return "No such capability $cap." if not $self->exists($cap);
if (not defined $subcap) {
$self->remove($cap);
return "Capability $cap removed.";
} else {
return "Capability $cap does not have a $subcap sub-capability." if not $self->has($cap, $subcap);
$self->remove($cap, $subcap);
return "Capability $subcap removed from $cap.";
}
} }
default { default {