mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
fbc375a282
You can get a free OpenID from http://www.myopenid.com (merged from branches/gsoc) git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@41785 467b73ca-7a2a-4603-9d3b-597d59a354a9
60 lines
1.6 KiB
PHP
60 lines
1.6 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Member authenticator
|
|
*
|
|
* @author Markus Lanthaler <markus@silverstripe.com>
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
* Authenticator for the default "member" method
|
|
*
|
|
* @author Markus Lanthaler <markus@silverstripe.com>
|
|
*/
|
|
class MemberAuthenticator extends Authenticator {
|
|
|
|
/**
|
|
* Method to authenticate an user
|
|
*
|
|
* @param array $RAW_data Raw data to authenticate the user
|
|
* @param Form $form Optional: If passed, better error messages can be
|
|
* produced by using
|
|
* {@link Form::sessionMessage()}
|
|
* @return bool|Member Returns FALSE if authentication fails, otherwise
|
|
* the member object
|
|
*/
|
|
public function authenticate(array $RAW_data, Form $form = null) {
|
|
$SQL_user = Convert::raw2sql($RAW_data['Email']);
|
|
$SQL_password = Convert::raw2sql($RAW_data['Password']);
|
|
|
|
$member = DataObject::get_one(
|
|
"Member", "Email = '$SQL_user' AND Password = '$SQL_password'");
|
|
|
|
if($member) {
|
|
Session::clear("BackURL");
|
|
} else if(!is_null($form)) {
|
|
$form->sessionMessage(
|
|
"That doesn't seem to be the right email address or password. Please try again.",
|
|
"bad");
|
|
}
|
|
|
|
return $member;
|
|
}
|
|
|
|
|
|
/**
|
|
* Method that creates the login form for this authentication method
|
|
*
|
|
* @param Controller The parent controller, necessary to create the
|
|
* appropriate form action tag
|
|
* @return Form Returns the login form to use with this authentication
|
|
* method
|
|
*/
|
|
public static function getLoginForm(Controller $controller) {
|
|
return Object::create("MemberLoginForm", $controller, "LoginForm");
|
|
}
|
|
}
|
|
|
|
?>
|