forked from GNUsocial/gnu-social
[ENTITY][Actor] Add helper function for checking if the current actor can admin another
This commit is contained in:
parent
63679426b6
commit
80ebd6fb7b
@ -261,6 +261,7 @@ class Actor extends Entity
|
|||||||
'subscriber' => "subscriber-{$actor_id}",
|
'subscriber' => "subscriber-{$actor_id}",
|
||||||
'subscribed' => "subscribed-{$actor_id}",
|
'subscribed' => "subscribed-{$actor_id}",
|
||||||
'relative-nickname' => "actor-{$actor_id}-relative-nickname-{$other}", // $other is $nickname
|
'relative-nickname' => "actor-{$actor_id}-relative-nickname-{$other}", // $other is $nickname
|
||||||
|
'can-admin' => "actor-{$actor_id}-can-admin-{$other}", // $other is an actor id
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -595,6 +596,29 @@ class Actor extends Entity
|
|||||||
return true; // TODO
|
return true; // TODO
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check whether $this has permission for performing actions on behalf of $other
|
||||||
|
*/
|
||||||
|
public function canAdmin(self $other): bool
|
||||||
|
{
|
||||||
|
switch ($other->getType()) {
|
||||||
|
case self::GROUP:
|
||||||
|
return Cache::get(
|
||||||
|
self::cacheKeys($this->getId(), $other->getId())['can-admin'],
|
||||||
|
function () use ($other) {
|
||||||
|
try {
|
||||||
|
return DB::findOneBy('group_member', ['group_id' => $other->getId(), 'actor_id' => $this->getId()])->getIsAdmin();
|
||||||
|
} catch (NotFoundException) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static function schemaDef(): array
|
public static function schemaDef(): array
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
|
Loading…
Reference in New Issue
Block a user