*/ /** User authentication against SESSION */ class authsession extends auth { /** Check if there is already a session or the user can not be authenticated */ function __construct () { if (!isset ($_SESSION)) throw new Exception ("No session previously opened", 401); } /** No connection to session */ public function connect () { return TRUE; } /** Try to authenticate the email/password of the user @param string $email Email to authenticate @param string $password Password to authenticate */ public function authentication ($email, $password) { if (!isset ($_SESSION["auth"]["email"]) || !isset ($_SESSION["auth"]["password"])) throw new Exception ("No previous email in session", 401); if ($_SESSION["auth"]["email"] !== $email) throw new Exception ("Unable to authenticate user '$email'", 401); if ($_SESSION["auth"]["password"] !== $password) throw new Exception ("Bad password for '$email'", 401); } /** Return all the parameters recorded for the authenticate user */ public function getdetails () { return array ("lastname"=>$_SESSION["auth"]["lastname"], "firstname"=>$_SESSION["auth"]["firstname"], "email"=>$_SESSION["auth"]["email"]); } /** Method to change the password : unavailable in SESSION auth @param string $oldpassword The old password (to check if the user have the rights to change the password) @param string $newpassword The new password to be recorded */ public function changepassword ($oldpassword, $newpassword) { throw new Exception (dgettext("domframework", "The password can't be change for SESSION users"), 405); } }