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 {
|
2020-11-09 18:14:03 -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;
|
2020-11-09 18:14:03 -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;
|
2020-11-09 18:14:03 -05:00
|
|
|
|
|
|
|
/** Adds a new user and returns their password
|
2020-11-16 10:26:14 -05:00
|
|
|
*
|
2020-11-09 18:14:03 -05:00
|
|
|
* When given no password the implementation may return null; the user
|
|
|
|
* manager will then generate a random password and try again with that
|
2020-11-16 10:26:14 -05:00
|
|
|
* password. Alternatively the implementation may generate its own
|
2020-11-09 18:14:03 -05:00
|
|
|
* password if desired
|
2020-11-16 10:26:14 -05:00
|
|
|
*
|
2020-11-09 18:14:03 -05:00
|
|
|
* @param string $user The username to create
|
|
|
|
* @param string|null $password The cleartext password to assign to the user, or null to generate a random password
|
|
|
|
*/
|
|
|
|
public function userAdd(string $user, string $password = null): ?string;
|
|
|
|
|
2020-12-25 17:47:36 -05:00
|
|
|
/** Renames a user
|
2021-01-08 15:47:19 -05:00
|
|
|
*
|
|
|
|
* The implementation must retain all user metadata as well as the
|
2020-12-25 17:47:36 -05:00
|
|
|
* user's password
|
2021-01-08 15:47:19 -05:00
|
|
|
*/
|
2020-12-25 17:47:36 -05:00
|
|
|
public function userRename(string $user, string $newName): bool;
|
|
|
|
|
2020-11-09 18:14:03 -05:00
|
|
|
/** Removes a user */
|
2017-08-29 10:50:31 -04:00
|
|
|
public function userRemove(string $user): bool;
|
2020-11-09 18:14:03 -05:00
|
|
|
|
|
|
|
/** Lists all users */
|
2018-10-28 10:59:17 -04:00
|
|
|
public function userList(): array;
|
2020-11-09 18:14:03 -05:00
|
|
|
|
2020-11-10 17:09:59 -05:00
|
|
|
/** Sets a user's password
|
2020-11-16 10:26:14 -05:00
|
|
|
*
|
2020-11-09 18:14:03 -05:00
|
|
|
* When given no password the implementation may return null; the user
|
|
|
|
* manager will then generate a random password and try again with that
|
2020-11-16 10:26:14 -05:00
|
|
|
* password. Alternatively the implementation may generate its own
|
2020-11-09 18:14:03 -05:00
|
|
|
* password if desired
|
2020-11-16 10:26:14 -05:00
|
|
|
*
|
2020-11-09 18:14:03 -05:00
|
|
|
* @param string $user The user for whom to change the password
|
|
|
|
* @param string|null $password The cleartext password to assign to the user, or null to generate a random password
|
|
|
|
* @param string|null $oldPassword The user's previous password, if known
|
|
|
|
*/
|
2020-12-25 17:47:36 -05:00
|
|
|
public function userPasswordSet(string $user, ?string $newPassword, string $oldPassword = null): ?string;
|
2020-11-09 18:14:03 -05:00
|
|
|
|
2020-11-16 10:26:14 -05:00
|
|
|
/** Removes a user's password; this makes authentication fail unconditionally
|
|
|
|
*
|
2020-11-09 18:14:03 -05:00
|
|
|
* @param string $user The user for whom to change the password
|
|
|
|
* @param string|null $oldPassword The user's previous password, if known
|
|
|
|
*/
|
2019-03-24 14:42:23 -04:00
|
|
|
public function userPasswordUnset(string $user, string $oldPassword = null): bool;
|
2020-11-10 17:09:59 -05:00
|
|
|
|
|
|
|
/** Retrieves metadata about a user
|
2020-11-16 10:26:14 -05:00
|
|
|
*
|
2020-11-10 17:09:59 -05:00
|
|
|
* Any expected keys not returned by the driver are taken from the internal
|
|
|
|
* database instead; the expected keys at this time are:
|
2020-11-16 10:26:14 -05:00
|
|
|
*
|
2020-11-10 17:09:59 -05:00
|
|
|
* - admin: A boolean denoting whether the user has administrator privileges
|
|
|
|
* - lang: A BCP 47 language tag e.g. "en", "hy-Latn-IT-arevela"
|
|
|
|
* - tz: A zoneinfo timezone e.g. "Asia/Jakarta", "America/Argentina/La_Rioja"
|
|
|
|
* - sort_asc: A boolean denoting whether the user prefers articles to be sorted oldest-first
|
2020-11-16 10:26:14 -05:00
|
|
|
*
|
2020-11-10 17:09:59 -05:00
|
|
|
* Any other keys will be ignored.
|
|
|
|
*/
|
2020-12-05 11:01:44 -05:00
|
|
|
public function userPropertiesGet(string $user, bool $includeLarge = true): array;
|
2020-11-10 17:09:59 -05:00
|
|
|
|
|
|
|
/** Sets metadata about a user
|
2020-11-16 10:26:14 -05:00
|
|
|
*
|
2020-11-10 17:09:59 -05:00
|
|
|
* Output should be the same as the input, unless input is changed prior to storage
|
|
|
|
* (if it is, for instance, normalized in some way), which which case the changes
|
|
|
|
* should be reflected in the output.
|
2020-11-16 10:26:14 -05:00
|
|
|
*
|
2020-11-10 17:09:59 -05:00
|
|
|
* @param string $user The user for which to set metadata
|
|
|
|
* @param array $data The input data; see userPropertiesGet for keys
|
|
|
|
*/
|
|
|
|
public function userPropertiesSet(string $user, array $data): array;
|
2017-08-29 10:50:31 -04:00
|
|
|
}
|