2017-03-07 18:01:13 -05:00
|
|
|
<?php
|
2017-11-16 20:23:18 -05:00
|
|
|
/** @license MIT
|
|
|
|
* Copyright 2017 J. King, Dustin Wilson et al.
|
|
|
|
* See LICENSE and AUTHORS files for details */
|
|
|
|
|
2017-03-07 18:01:13 -05:00
|
|
|
declare(strict_types=1);
|
2021-04-14 11:17:01 -04:00
|
|
|
|
2017-03-27 23:12:12 -05:00
|
|
|
namespace JKingWeb\Arsse\User\Internal;
|
2017-03-07 18:01:13 -05:00
|
|
|
|
2018-11-03 13:26:22 -04:00
|
|
|
use JKingWeb\Arsse\Arsse;
|
2020-11-15 16:24:26 -05:00
|
|
|
use JKingWeb\Arsse\User\ExceptionConflict;
|
2018-11-03 13:26:22 -04:00
|
|
|
|
2018-11-02 10:01:49 -04:00
|
|
|
class Driver implements \JKingWeb\Arsse\User\Driver {
|
2018-10-28 13:50:57 -04:00
|
|
|
public function __construct() {
|
|
|
|
}
|
2017-03-07 18:01:13 -05:00
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public static function driverName(): string {
|
2017-07-17 07:47:57 -04:00
|
|
|
return Arsse::$lang->msg("Driver.User.Internal.Name");
|
2017-03-07 18:01:13 -05:00
|
|
|
}
|
|
|
|
|
2018-10-28 13:50:57 -04:00
|
|
|
public function auth(string $user, string $password): bool {
|
|
|
|
try {
|
2018-11-04 12:06:30 -05:00
|
|
|
$hash = $this->userPasswordGet($user);
|
2019-03-24 14:42:23 -04:00
|
|
|
if (is_null($hash)) {
|
|
|
|
return false;
|
|
|
|
}
|
2020-11-15 16:24:26 -05:00
|
|
|
} catch (ExceptionConflict $e) {
|
2018-10-28 13:50:57 -04:00
|
|
|
return false;
|
2017-07-20 22:40:09 -04:00
|
|
|
}
|
2020-03-01 15:16:50 -05:00
|
|
|
if ($password === "" && $hash === "") {
|
2018-10-28 13:50:57 -04:00
|
|
|
return true;
|
2017-03-07 18:01:13 -05:00
|
|
|
}
|
2018-10-28 13:50:57 -04:00
|
|
|
return password_verify($password, $hash);
|
|
|
|
}
|
|
|
|
|
2020-01-20 13:34:03 -05:00
|
|
|
public function userAdd(string $user, string $password = null): ?string {
|
2018-11-02 11:52:55 -04:00
|
|
|
if (isset($password)) {
|
|
|
|
// only add the user if the password is not null; the user manager will retry with a generated password if null is returned
|
|
|
|
Arsse::$db->userAdd($user, $password);
|
|
|
|
}
|
|
|
|
return $password;
|
2017-03-07 18:01:13 -05:00
|
|
|
}
|
|
|
|
|
2020-12-25 17:47:36 -05:00
|
|
|
public function userRename(string $user, string $newName): bool {
|
|
|
|
// do nothing: the internal database is updated regardless of what the driver does (assuming it does not throw an exception)
|
|
|
|
// throw an exception if the user does not exist
|
|
|
|
if (!$this->userExists($user)) {
|
|
|
|
throw new ExceptionConflict("doesNotExist", ['action' => __FUNCTION__, 'user' => $user]);
|
|
|
|
} else {
|
|
|
|
return !($user === $newName);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-10-28 13:50:57 -04:00
|
|
|
public function userRemove(string $user): bool {
|
|
|
|
return Arsse::$db->userRemove($user);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function userList(): array {
|
|
|
|
return Arsse::$db->userList();
|
|
|
|
}
|
|
|
|
|
2020-11-09 18:14:03 -05:00
|
|
|
public function userPasswordSet(string $user, ?string $newPassword, string $oldPassword = null): ?string {
|
2018-11-02 11:52:55 -04:00
|
|
|
// do nothing: the internal database is updated regardless of what the driver does (assuming it does not throw an exception)
|
2020-12-25 17:47:36 -05:00
|
|
|
// throw an exception if the user does not exist
|
|
|
|
if (!$this->userExists($user)) {
|
|
|
|
throw new ExceptionConflict("doesNotExist", ['action' => __FUNCTION__, 'user' => $user]);
|
|
|
|
} else {
|
|
|
|
return $newPassword;
|
|
|
|
}
|
2018-10-28 13:50:57 -04:00
|
|
|
}
|
2018-11-04 12:06:30 -05:00
|
|
|
|
2019-03-24 14:42:23 -04:00
|
|
|
public function userPasswordUnset(string $user, string $oldPassword = null): bool {
|
|
|
|
// do nothing: the internal database is updated regardless of what the driver does (assuming it does not throw an exception)
|
|
|
|
// throw an exception if the user does not exist
|
|
|
|
if (!$this->userExists($user)) {
|
2020-12-25 17:47:36 -05:00
|
|
|
throw new ExceptionConflict("doesNotExist", ['action' => __FUNCTION__, 'user' => $user]);
|
2019-03-24 14:42:23 -04:00
|
|
|
} else {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-01-20 13:34:03 -05:00
|
|
|
protected function userPasswordGet(string $user): ?string {
|
2018-11-04 12:06:30 -05:00
|
|
|
return Arsse::$db->userPasswordGet($user);
|
|
|
|
}
|
2020-11-09 18:14:03 -05:00
|
|
|
|
|
|
|
protected function userExists(string $user): bool {
|
|
|
|
return Arsse::$db->userExists($user);
|
|
|
|
}
|
2020-11-10 17:09:59 -05:00
|
|
|
|
2020-12-05 22:13:48 -05:00
|
|
|
public function userPropertiesGet(string $user, bool $includeLarge = true): array {
|
2020-11-10 17:09:59 -05:00
|
|
|
// do nothing: the internal database will retrieve everything for us
|
|
|
|
if (!$this->userExists($user)) {
|
2020-12-25 17:47:36 -05:00
|
|
|
throw new ExceptionConflict("doesNotExist", ['action' => __FUNCTION__, 'user' => $user]);
|
2020-11-10 17:09:59 -05:00
|
|
|
} else {
|
|
|
|
return [];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function userPropertiesSet(string $user, array $data): array {
|
|
|
|
// do nothing: the internal database will set everything for us
|
|
|
|
if (!$this->userExists($user)) {
|
2020-12-25 17:47:36 -05:00
|
|
|
throw new ExceptionConflict("doesNotExist", ['action' => __FUNCTION__, 'user' => $user]);
|
2020-11-10 17:09:59 -05:00
|
|
|
} else {
|
|
|
|
return $data;
|
|
|
|
}
|
|
|
|
}
|
2017-08-29 10:50:31 -04:00
|
|
|
}
|