users[$uid])) { return false; } else { $this->users[$uid] = $password; return true; } } /** * delete a user * * @param string $uid The username of the user to delete * @return bool * * Deletes a user */ public function deleteUser($uid) { if (isset($this->users[$uid])) { unset($this->users[$uid]); return true; } else { return false; } } /** * Set password * * @param string $uid The username * @param string $password The new password * @return bool * * Change the password of a user */ public function setPassword($uid, $password) { if (isset($this->users[$uid])) { $this->users[$uid] = $password; return true; } else { return false; } } /** * Check if the password is correct * * @param string $uid The username * @param string $password The password * @return string|bool * * Check if the password is correct without logging in the user * returns the user id or false */ public function checkPassword($uid, $password) { if (isset($this->users[$uid]) && $this->users[$uid] === $password) { return $uid; } return false; } public function loginName2UserName($loginName) { if (isset($this->users[strtolower($loginName)])) { return strtolower($loginName); } return false; } /** * Get a list of all users * * @param string $search * @param null|int $limit * @param null|int $offset * @return string[] an array of all uids */ public function getUsers($search = '', $limit = null, $offset = null) { if (empty($search)) { return array_keys($this->users); } $result = []; foreach (array_keys($this->users) as $user) { if (stripos($user, $search) !== false) { $result[] = $user; } } return $result; } /** * check if a user exists * * @param string $uid the username * @return boolean */ public function userExists($uid) { return isset($this->users[$uid]); } /** * @return bool */ public function hasUserListings() { return true; } /** * counts the users in the database * * @return int|bool */ public function countUsers() { return 0; } public function setDisplayName($uid, $displayName) { $this->displayNames[$uid] = $displayName; return true; } public function getDisplayName($uid) { return $this->displayNames[$uid] ?? $uid; } /** * Backend name to be shown in user management * @return string the name of the backend to be shown */ public function getBackendName() { return 'Dummy'; } }