2016-10-28 08:27:35 -04: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 */
|
|
|
|
|
2016-10-28 08:27:35 -04:00
|
|
|
declare(strict_types=1);
|
2017-03-27 23:12:12 -05:00
|
|
|
namespace JKingWeb\Arsse\User;
|
2016-10-28 08:27:35 -04:00
|
|
|
|
2017-08-29 10:50:31 -04:00
|
|
|
interface Driver {
|
2017-02-16 14:29:42 -06:00
|
|
|
const FUNC_NOT_IMPLEMENTED = 0;
|
|
|
|
const FUNC_INTERNAL = 1;
|
|
|
|
const FUNC_EXTERNAL = 2;
|
2017-02-11 10:36:17 -06:00
|
|
|
|
2017-03-28 18:50:00 -04:00
|
|
|
// returns an instance of a class implementing this interface.
|
2017-08-29 10:50:31 -04:00
|
|
|
public function __construct();
|
2017-02-17 19:22:50 -05:00
|
|
|
// returns a human-friendly name for the driver (for display in installer, for example)
|
2017-08-29 10:50:31 -04:00
|
|
|
public static function driverName(): string;
|
2017-02-17 19:22:50 -05:00
|
|
|
// authenticates a user against their name and password
|
2017-08-29 10:50:31 -04:00
|
|
|
public function auth(string $user, string $password): bool;
|
2018-11-02 10:01:49 -04:00
|
|
|
// check whether a user is authorized to perform a certain action; not currently used and subject to change
|
|
|
|
public function authorize(string $affectedUser, string $action): bool;
|
2017-02-17 19:22:50 -05:00
|
|
|
// checks whether a user exists
|
2017-08-29 10:50:31 -04:00
|
|
|
public function userExists(string $user): bool;
|
2017-02-17 19:22:50 -05:00
|
|
|
// adds a user
|
2018-11-02 11:52:55 -04:00
|
|
|
public function userAdd(string $user, string $password = null);
|
2017-02-17 19:22:50 -05:00
|
|
|
// removes a user
|
2017-08-29 10:50:31 -04:00
|
|
|
public function userRemove(string $user): bool;
|
2017-02-17 19:22:50 -05:00
|
|
|
// lists all users
|
2018-10-28 10:59:17 -04:00
|
|
|
public function userList(): array;
|
2017-02-17 19:22:50 -05:00
|
|
|
// sets a user's password; if the driver does not require the old password, it may be ignored
|
2018-11-02 11:52:55 -04:00
|
|
|
public function userPasswordSet(string $user, string $newPassword = null, string $oldPassword = null);
|
2019-03-24 14:42:23 -04:00
|
|
|
// removes a user's password; this makes authentication fail unconditionally
|
|
|
|
public function userPasswordUnset(string $user, string $oldPassword = null): bool;
|
2017-08-29 10:50:31 -04:00
|
|
|
}
|