mirror of
https://code.mensbeam.com/MensBeam/Arsse.git
synced 2025-01-25 12:30:34 +00:00
e6feb8de8d
As the User class depends on the database and this has yet to be tested (though I'm fairly certain it works), the mock driver also acts as a mock of the required database functions, with both instances sharing a common storage structure. Later test series should separate the two.
116 lines
No EOL
3.9 KiB
PHP
116 lines
No EOL
3.9 KiB
PHP
<?php
|
|
declare(strict_types=1);
|
|
namespace JKingWeb\NewsSync\Test\User;
|
|
use JKingWeb\NewsSync\Lang, JKingWeb\NewsSync\User\Driver;
|
|
|
|
final class DriverInternalMock implements Driver {
|
|
|
|
public static $db = [];
|
|
protected $data;
|
|
protected $functions = [
|
|
"auth" => Driver::FUNC_INTERNAL,
|
|
"authorize" => Driver::FUNC_INTERNAL,
|
|
"userList" => Driver::FUNC_INTERNAL,
|
|
"userExists" => Driver::FUNC_INTERNAL,
|
|
"userAdd" => Driver::FUNC_INTERNAL,
|
|
"userRemove" => Driver::FUNC_INTERNAL,
|
|
"userPasswordSet" => Driver::FUNC_INTERNAL,
|
|
"userPropertiesGet" => Driver::FUNC_INTERNAL,
|
|
"userPropertiesSet" => Driver::FUNC_INTERNAL,
|
|
"userRightsGet" => Driver::FUNC_INTERNAL,
|
|
"userRightsSet" => Driver::FUNC_INTERNAL,
|
|
];
|
|
|
|
static public function create(\JKingWeb\NewsSync\RuntimeData $data): Driver {
|
|
return new static($data);
|
|
}
|
|
|
|
static public function driverName(): string {
|
|
return "Mock Internal Driver";
|
|
}
|
|
|
|
public function driverFunctions(string $function = null) {
|
|
if($function===null) return $this->functions;
|
|
if(array_key_exists($function, $this->functions)) {
|
|
return $this->functions[$function];
|
|
} else {
|
|
return Driver::FUNC_NOT_IMPLEMENTED;
|
|
}
|
|
}
|
|
|
|
public function __construct(\JKingWeb\NewsSync\RuntimeData $data) {
|
|
$this->data = $data;
|
|
}
|
|
|
|
function auth(string $user, string $password): bool {
|
|
if(!$this->userExists($user)) return false;
|
|
if(password_verify($password, static::$db[$user]['password'])) return true;
|
|
return false;
|
|
}
|
|
|
|
function authorize(string $affectedUser, string $action, int $newRightsLevel = 0): bool {
|
|
return true;
|
|
}
|
|
|
|
function userExists(string $user): bool {
|
|
return array_key_exists($user, static::$db);
|
|
}
|
|
|
|
function userAdd(string $user, string $password = null): bool {
|
|
if($this->userExists($user)) return false;
|
|
$u = [
|
|
'password' => $password ? password_hash($password, \PASSWORD_DEFAULT) : null,
|
|
'rights' => Driver::RIGHTS_NONE,
|
|
];
|
|
static::$db[$user] = $u;
|
|
return true;
|
|
}
|
|
|
|
function userRemove(string $user): bool {
|
|
if(!$this->userExists($user)) return false;
|
|
unset(static::$db[$user]);
|
|
return true;
|
|
}
|
|
|
|
function userList(string $domain = null): array {
|
|
$list = array_keys(static::$db);
|
|
if($domain===null) {
|
|
return $list;
|
|
} else {
|
|
$suffix = '@'.$domain;
|
|
$len = -1 * strlen($suffix);
|
|
return array_filter($list, function($user) use($suffix, $len) {
|
|
return substr_compare($user, $suffix, $len);
|
|
});
|
|
}
|
|
}
|
|
|
|
function userPasswordSet(string $user, string $newPassword, string $oldPassword): bool {
|
|
if(!$this->userExists($user)) return false;
|
|
if(!$this->auth($user, $oldPassword)) return false;
|
|
static::$db[$user]['password'] = password_hash($newPassword, \PASSWORD_DEFAULT);
|
|
return true;
|
|
}
|
|
|
|
function userPropertiesGet(string $user): array {
|
|
if(!$this->userExists($user)) return [];
|
|
return static::$db[$user];
|
|
}
|
|
|
|
function userPropertiesSet(string $user, array $properties): array {
|
|
if(!$this->userExists($user)) return [];
|
|
static::$db[$user] = array_merge(static::$db[$user], $properties);
|
|
return $this->userPropertiesGet($user);
|
|
}
|
|
|
|
function userRightsGet(string $user): int {
|
|
if(!$this->userExists($user)) return Driver::RIGHTS_NONE;
|
|
return static::$db[$user]['rights'];
|
|
}
|
|
|
|
function userRightsSet(string $user, int $level): bool {
|
|
if(!$this->userExists($user)) return false;
|
|
static::$db[$user]['rights'] = $level;
|
|
return true;
|
|
}
|
|
} |