* * @author Artur Neumann * * @license AGPL-3.0 * * This code is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License, version 3, * as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License, version 3, * along with this program. If not, see * */ namespace OCP\Authentication\Token; use OCP\Authentication\Exceptions\ExpiredTokenException; use OCP\Authentication\Exceptions\InvalidTokenException; use OCP\Authentication\Exceptions\WipeTokenException; /** * @since 24.0.8 */ interface IProvider { /** * invalidates all tokens of a specific user * if a client name is given only tokens of that client will be invalidated * * @param string $uid * @param string|null $clientName * @since 24.0.8 * @return void */ public function invalidateTokensOfUser(string $uid, ?string $clientName); /** * Get a token by token string id * * @since 28.0.0 * @throws InvalidTokenException * @throws ExpiredTokenException * @throws WipeTokenException * @return IToken */ public function getToken(string $tokenId): IToken; }