This repository has been archived on 2024-09-05. You can view files and clone it, but cannot push or open issues or pull requests.
shimmie2/core/userclass.php

138 lines
3.8 KiB
PHP
Raw Normal View History

2021-12-14 18:32:47 +00:00
<?php
declare(strict_types=1);
namespace Shimmie2;
2023-02-07 13:21:37 +00:00
use GQLA\Type;
use GQLA\Field;
2012-02-14 21:11:23 +00:00
2014-04-29 01:33:03 -04:00
/**
* Class UserClass
*/
2023-02-07 13:21:37 +00:00
#[Type(name: "UserClass")]
class UserClass
{
2024-01-20 19:52:18 +00:00
/** @var array<string, UserClass> */
public static array $known_classes = [];
2023-02-07 13:21:37 +00:00
#[Field]
public ?string $name = null;
public ?UserClass $parent = null;
/** @var array<string, bool> */
public array $abilities = [];
/**
* @param array<string, bool> $abilities
*/
2020-03-19 01:15:25 +03:00
public function __construct(string $name, string $parent = null, array $abilities = [])
{
$this->name = $name;
$this->abilities = $abilities;
if (!is_null($parent)) {
2024-01-20 19:52:18 +00:00
$this->parent = static::$known_classes[$parent];
}
2024-01-20 19:52:18 +00:00
static::$known_classes[$name] = $this;
}
/**
* @return string[]
*/
2023-02-15 22:26:34 +00:00
#[Field(type: "[Permission!]!")]
2023-02-07 13:21:37 +00:00
public function permissions(): array
{
$perms = [];
2024-01-20 01:03:01 +00:00
foreach ((new \ReflectionClass(Permissions::class))->getConstants() as $k => $v) {
2023-02-07 13:21:37 +00:00
if ($this->can($v)) {
$perms[] = $v;
}
}
return $perms;
}
/**
* Determine if this class of user can perform an action or has ability.
*/
public function can(string $ability): bool
{
if (array_key_exists($ability, $this->abilities)) {
2020-01-26 13:19:35 +00:00
return $this->abilities[$ability];
} elseif (!is_null($this->parent)) {
return $this->parent->can($ability);
} else {
$min_dist = 9999;
$min_ability = null;
2024-01-20 19:52:18 +00:00
foreach (UserClass::$known_classes['base']->abilities as $a => $cando) {
$v = levenshtein($ability, $a);
if ($v < $min_dist) {
$min_dist = $v;
$min_ability = $a;
}
}
2024-02-11 15:47:40 +00:00
throw new ServerError("Unknown ability '$ability'. Did the developer mean '$min_ability'?");
}
}
2012-02-14 21:11:23 +00:00
}
$_all_false = [];
2024-02-21 11:12:04 +00:00
$_all_true = [];
2024-01-20 01:03:01 +00:00
foreach ((new \ReflectionClass(Permissions::class))->getConstants() as $k => $v) {
2024-01-20 19:47:26 +00:00
assert(is_string($v));
$_all_false[$v] = false;
2024-02-21 11:12:04 +00:00
$_all_true[$v] = true;
}
2024-02-21 11:12:04 +00:00
// hellbanned is a snowflake, it isn't really a "permission" so much as
// "a special behaviour which applies to one particular user class"
$_all_true[Permissions::HELLBANNED] = false;
new UserClass("base", null, $_all_false);
2024-02-21 11:12:04 +00:00
new UserClass("admin", null, $_all_true);
2024-02-21 23:20:54 +00:00
unset($_all_true);
unset($_all_false);
2019-11-28 17:20:23 +00:00
// Ghost users can't do anything
new UserClass("ghost", "base", [
Permissions::READ_PM => true,
2019-11-28 17:20:23 +00:00
]);
// Anonymous users can't do anything by default, but
// the admin might grant them some permissions
new UserClass("anonymous", "base", [
Permissions::CREATE_USER => true,
]);
new UserClass("user", "base", [
2019-07-09 09:10:21 -05:00
Permissions::BIG_SEARCH => true,
Permissions::CREATE_IMAGE => true,
Permissions::CREATE_COMMENT => true,
Permissions::EDIT_IMAGE_TAG => true,
Permissions::EDIT_IMAGE_SOURCE => true,
Permissions::EDIT_IMAGE_TITLE => true,
Permissions::EDIT_IMAGE_RELATIONSHIPS => true,
Permissions::EDIT_IMAGE_ARTIST => true,
2019-07-09 09:10:21 -05:00
Permissions::CREATE_IMAGE_REPORT => true,
Permissions::EDIT_IMAGE_RATING => true,
Permissions::EDIT_FAVOURITES => true,
2023-02-24 05:32:23 +00:00
Permissions::CREATE_VOTE => true,
Permissions::SEND_PM => true,
Permissions::READ_PM => true,
2020-06-02 18:08:24 -05:00
Permissions::SET_PRIVATE_IMAGE => true,
2022-07-09 23:37:43 +01:00
Permissions::PERFORM_BULK_ACTIONS => true,
2020-06-21 19:17:58 -05:00
Permissions::BULK_DOWNLOAD => true,
2024-02-10 23:32:50 +00:00
Permissions::CHANGE_USER_SETTING => true,
Permissions::FORUM_CREATE => true,
2024-02-10 23:32:50 +00:00
Permissions::NOTES_CREATE => true,
Permissions::NOTES_EDIT => true,
Permissions::NOTES_REQUEST => true,
2024-02-10 23:32:50 +00:00
Permissions::POOLS_CREATE => true,
Permissions::POOLS_UPDATE => true,
]);
new UserClass("hellbanned", "user", [
Permissions::HELLBANNED => true,
]);
@include_once "data/config/user-classes.conf.php";