2017-05-08 07:11:00 +12:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace SilverStripe\Security;
|
|
|
|
|
|
|
|
use SilverStripe\Control\HTTPRequest;
|
|
|
|
use SilverStripe\Control\HTTPResponse;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Represents an authentication handler that can have identities logged into & out of it.
|
|
|
|
* For example, SessionAuthenticationHandler is an IdentityStore (as we can write a new member to it)
|
|
|
|
* but BasicAuthAuthenticationHandler is not (as it's up to the browser to handle log-in / log-out)
|
|
|
|
*/
|
|
|
|
interface IdentityStore
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Log the given member into this identity store.
|
|
|
|
*
|
2017-05-20 16:32:25 +12:00
|
|
|
* @param Member $member The member to log in.
|
|
|
|
* @param Boolean $persistent boolean If set to true, the login may persist beyond the current session.
|
|
|
|
* @param HTTPRequest $request The request of the visitor that is logging in, to get, for example, cookies.
|
2017-05-08 07:11:00 +12:00
|
|
|
*/
|
2017-05-30 19:42:00 +12:00
|
|
|
public function logIn(Member $member, $persistent = false, HTTPRequest $request = null);
|
2017-05-08 07:11:00 +12:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Log any logged-in member out of this identity store.
|
|
|
|
*
|
2017-05-20 16:32:25 +12:00
|
|
|
* @param HTTPRequest $request The request of the visitor that is logging out, to get, for example, cookies.
|
2017-05-08 07:11:00 +12:00
|
|
|
*/
|
2017-05-30 19:42:00 +12:00
|
|
|
public function logOut(HTTPRequest $request = null);
|
2017-05-08 07:11:00 +12:00
|
|
|
}
|