2017-02-26 12:09:44 -05:00
|
|
|
<?php
|
|
|
|
declare(strict_types=1);
|
2017-03-27 23:12:12 -05:00
|
|
|
namespace JKingWeb\Arsse\Test\User;
|
2017-08-29 10:50:31 -04:00
|
|
|
|
2017-07-17 07:47:57 -04:00
|
|
|
use JKingWeb\Arsse\Arsse;
|
2017-03-27 23:12:12 -05:00
|
|
|
use JKingWeb\Arsse\User\Driver;
|
|
|
|
use JKingWeb\Arsse\User\Exception;
|
|
|
|
use JKingWeb\Arsse\User\ExceptionAuthz;
|
2017-02-26 12:09:44 -05:00
|
|
|
use PasswordGenerator\Generator as PassGen;
|
|
|
|
|
|
|
|
class Database extends DriverSkeleton {
|
2017-02-27 11:44:20 -05:00
|
|
|
public $db = [];
|
|
|
|
|
2017-03-28 18:50:00 -04:00
|
|
|
public function __construct() {
|
2017-02-26 22:06:14 -05:00
|
|
|
}
|
2017-04-06 21:41:21 -04:00
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function userExists(string $user): bool {
|
|
|
|
if (!Arsse::$user->authorize($user, __FUNCTION__)) {
|
|
|
|
throw new ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $user]);
|
|
|
|
}
|
2017-02-26 12:09:44 -05:00
|
|
|
return parent::userExists($user);
|
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function userAdd(string $user, string $password = null): string {
|
|
|
|
if (!Arsse::$user->authorize($user, __FUNCTION__)) {
|
|
|
|
throw new ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $user]);
|
|
|
|
}
|
|
|
|
if ($this->userExists($user)) {
|
|
|
|
throw new Exception("alreadyExists", ["action" => __FUNCTION__, "user" => $user]);
|
|
|
|
}
|
|
|
|
if ($password===null) {
|
|
|
|
$password = (new PassGen)->length(Arsse::$conf->userTempPasswordLength)->get();
|
|
|
|
}
|
2017-02-26 12:09:44 -05:00
|
|
|
return parent::userAdd($user, $password);
|
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function userRemove(string $user): bool {
|
|
|
|
if (!Arsse::$user->authorize($user, __FUNCTION__)) {
|
|
|
|
throw new ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $user]);
|
|
|
|
}
|
|
|
|
if (!$this->userExists($user)) {
|
|
|
|
throw new Exception("doesNotExist", ["action" => __FUNCTION__, "user" => $user]);
|
|
|
|
}
|
2017-02-26 12:09:44 -05:00
|
|
|
return parent::userRemove($user);
|
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function userList(string $domain = null): array {
|
|
|
|
if ($domain===null) {
|
|
|
|
if (!Arsse::$user->authorize("", __FUNCTION__)) {
|
|
|
|
throw new ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => "global"]);
|
|
|
|
}
|
2017-02-26 12:09:44 -05:00
|
|
|
return parent::userList();
|
|
|
|
} else {
|
|
|
|
$suffix = '@'.$domain;
|
2017-08-29 10:50:31 -04:00
|
|
|
if (!Arsse::$user->authorize($suffix, __FUNCTION__)) {
|
|
|
|
throw new ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $domain]);
|
|
|
|
}
|
2017-02-26 12:09:44 -05:00
|
|
|
return parent::userList($domain);
|
|
|
|
}
|
|
|
|
}
|
2017-04-06 21:41:21 -04:00
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function userPasswordSet(string $user, string $newPassword = null, string $oldPassword = null): string {
|
|
|
|
if (!Arsse::$user->authorize($user, __FUNCTION__)) {
|
|
|
|
throw new ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $user]);
|
|
|
|
}
|
|
|
|
if (!$this->userExists($user)) {
|
|
|
|
throw new Exception("doesNotExist", ["action" => __FUNCTION__, "user" => $user]);
|
|
|
|
}
|
|
|
|
if ($newPassword===null) {
|
|
|
|
$newPassword = (new PassGen)->length(Arsse::$conf->userTempPasswordLength)->get();
|
|
|
|
}
|
2017-02-26 12:09:44 -05:00
|
|
|
return parent::userPasswordSet($user, $newPassword);
|
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function userPropertiesGet(string $user): array {
|
|
|
|
if (!Arsse::$user->authorize($user, __FUNCTION__)) {
|
|
|
|
throw new ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $user]);
|
|
|
|
}
|
|
|
|
if (!$this->userExists($user)) {
|
|
|
|
throw new Exception("doesNotExist", ["action" => __FUNCTION__, "user" => $user]);
|
|
|
|
}
|
2017-02-26 12:09:44 -05:00
|
|
|
$out = parent::userPropertiesGet($user);
|
|
|
|
unset($out['password']);
|
|
|
|
return $out;
|
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function userPropertiesSet(string $user, array $properties): array {
|
|
|
|
if (!Arsse::$user->authorize($user, __FUNCTION__)) {
|
|
|
|
throw new ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $user]);
|
|
|
|
}
|
|
|
|
if (!$this->userExists($user)) {
|
|
|
|
throw new Exception("doesNotExist", ["action" => __FUNCTION__, "user" => $user]);
|
|
|
|
}
|
2017-02-26 12:09:44 -05:00
|
|
|
parent::userPropertiesSet($user, $properties);
|
|
|
|
return $this->userPropertiesGet($user);
|
|
|
|
}
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function userRightsGet(string $user): int {
|
|
|
|
if (!Arsse::$user->authorize($user, __FUNCTION__)) {
|
|
|
|
throw new ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $user]);
|
|
|
|
}
|
|
|
|
if (!$this->userExists($user)) {
|
|
|
|
throw new Exception("doesNotExist", ["action" => __FUNCTION__, "user" => $user]);
|
|
|
|
}
|
2017-02-26 12:09:44 -05:00
|
|
|
return parent::userRightsGet($user);
|
|
|
|
}
|
2017-04-06 21:41:21 -04:00
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function userRightsSet(string $user, int $level): bool {
|
|
|
|
if (!Arsse::$user->authorize($user, __FUNCTION__)) {
|
|
|
|
throw new ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $user]);
|
|
|
|
}
|
|
|
|
if (!$this->userExists($user)) {
|
|
|
|
throw new Exception("doesNotExist", ["action" => __FUNCTION__, "user" => $user]);
|
|
|
|
}
|
2017-02-26 12:09:44 -05:00
|
|
|
return parent::userRightsSet($user, $level);
|
|
|
|
}
|
2017-03-02 20:47:00 -05:00
|
|
|
|
|
|
|
// specific to mock database
|
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
public function userPasswordGet(string $user): string {
|
|
|
|
if (!Arsse::$user->authorize($user, __FUNCTION__)) {
|
|
|
|
throw new ExceptionAuthz("notAuthorized", ["action" => __FUNCTION__, "user" => $user]);
|
|
|
|
}
|
|
|
|
if (!$this->userExists($user)) {
|
|
|
|
throw new Exception("doesNotExist", ["action" => __FUNCTION__, "user" => $user]);
|
|
|
|
}
|
2017-03-02 20:47:00 -05:00
|
|
|
return $this->db[$user]['password'];
|
|
|
|
}
|
2017-08-29 10:50:31 -04:00
|
|
|
}
|