Select Git revision
-
Steinwender, Tamara authoredSteinwender, Tamara authored
UserSessionInterface.php 1.52 KiB
<?php
declare(strict_types=1);
namespace Dbp\Relay\CoreBundle\API;
interface UserSessionInterface
{
/**
* The unique identifier of the authenticated user. Or null in case it is called
* before the user is known or if the user is a system.
*/
public function getUserIdentifier(): ?string;
/**
* Returns an ID represents a "session" of a user which can be used for logging. It should not be possible to
* figure out which user is behind the ID based on the ID itself and the ID should change regularly.
* This is useful for connecting various requests together for logging while not exposing details about the user.
*/
public function getSessionLoggingId(): string;
/**
* @deprecated
*/
public function getUserRoles(): array;
/**
* Returns a unique caching key that can be used to cache metadata related to the current user session like
* any user metadata, authorization related information etc.
* It should not be possible to figure out which user is behind the ID based on the ID itself and the ID should
* change regularly (after a logout/login or a key refresh for example).
*/
public function getSessionCacheKey(): string;
/**
* Returns the duration the session is valid (as a whole, not from now) in seconds.
* After the specified amount of time has passed the logging ID and the caching key should have changed.
*
* This is mostly useful for limiting the cache.
*/
public function getSessionTTL(): int;
}