*/ interface Authenticator { const LOGIN = 1; const LOGOUT = 2; const CHANGE_PASSWORD = 4; const RESET_PASSWORD = 8; const CMS_LOGIN = 16; /** * Returns the services supported by this authenticator * * The number should be a bitwise-OR of 1 or more of the following constants: * Authenticator::LOGIN, Authenticator::LOGOUT, Authenticator::CHANGE_PASSWORD, * Authenticator::RESET_PASSWORD, or Authenticator::CMS_LOGIN * * @return int */ public function supportedServices(); /** * Return RequestHandler to manage the log-in process. * * The default URL of the RequetHandler should return the initial log-in form, any other * URL may be added for other steps & processing. * * URL-handling methods may return an array [ "Form" => (form-object) ] which can then * be merged into a default controller. * * @param string $link The base link to use for this RequestHnadler */ public function getLoginHandler($link); /** * Return RequestHandler to manage the change-password process. * * The default URL of the RequetHandler should return the initial change-password form, * any other URL may be added for other steps & processing. * * URL-handling methods may return an array [ "Form" => (form-object) ] which can then * be merged into a default controller. * * @param string $link The base link to use for this RequestHnadler */ public function getChangePasswordHandler($link); /** * @todo */ public function getLostPasswordHandler($link); /** * Method to authenticate an user. * * @param array $data Raw data to authenticate the user. * @param string $message A variable to return an error message if authentication fails * @return Member The matched member, or null if the authentication fails */ public function authenticate($data, &$message); /** * Return the keys that should be passed to authenticate() * @return array */ // public function getAuthenticateFields(); /** * Log the member out of this Authentication method. * * @param Member $member by reference, to allow for multiple actions on the member with a single write * @return boolean|Member if logout was unsuccessfull, return true, otherwise, the member is returned */ public function doLogOut(&$member); }