1
1
Fork 0
mirror of https://code.mensbeam.com/MensBeam/Arsse.git synced 2025-01-25 12:30:34 +00:00
Arsse/lib/User/Driver.php

43 lines
2.3 KiB
PHP
Raw Normal View History

<?php
declare(strict_types=1);
2017-03-27 23:12:12 -05:00
namespace JKingWeb\Arsse\User;
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;
const RIGHTS_NONE = 0; // normal user
const RIGHTS_DOMAIN_MANAGER = 25; // able to act for any normal users on same domain; cannot elevate other users
const RIGHTS_DOMAIN_ADMIN = 50; // able to act for any users on same domain not above themselves; may elevate users on same domain to domain manager or domain admin
const RIGHTS_GLOBAL_MANAGER = 75; // able to act for any normal users on any domain; cannot elevate other users
const RIGHTS_GLOBAL_ADMIN = 100; // is completely unrestricted
// returns an instance of a class implementing this interface.
2017-08-29 10:50:31 -04:00
public function __construct();
// 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;
// returns an array (or single queried member of same) of methods defined by this interface and whether the class implements the internal function or a custom version
2017-08-29 10:50:31 -04:00
public function driverFunctions(string $function = null);
// authenticates a user against their name and password
2017-08-29 10:50:31 -04:00
public function auth(string $user, string $password): bool;
// checks whether a user exists
2017-08-29 10:50:31 -04:00
public function userExists(string $user): bool;
// adds a user
2017-08-29 10:50:31 -04:00
public function userAdd(string $user, string $password = null): string;
// removes a user
2017-08-29 10:50:31 -04:00
public function userRemove(string $user): bool;
// lists all users
2017-08-29 10:50:31 -04:00
public function userList(string $domain = null): array;
// sets a user's password; if the driver does not require the old password, it may be ignored
2017-08-29 10:50:31 -04:00
public function userPasswordSet(string $user, string $newPassword = null, string $oldPassword = null): string;
// gets user metadata (currently not useful)
2017-08-29 10:50:31 -04:00
public function userPropertiesGet(string $user): array;
// sets user metadata (currently not useful)
2017-08-29 10:50:31 -04:00
public function userPropertiesSet(string $user, array $properties): array;
// returns a user's access level according to RIGHTS_* constants (or some custom semantics, if using custom implementation of authorize())
2017-08-29 10:50:31 -04:00
public function userRightsGet(string $user): int;
// sets a user's access level
2017-08-29 10:50:31 -04:00
public function userRightsSet(string $user, int $level): bool;
}