]> git.joonet.de Git - adminer.git/commitdiff
Session management
authorjakubvrana <jakubvrana@7c3ca157-0c34-0410-bff1-cbf682f78f5c>
Tue, 6 Oct 2009 15:33:48 +0000 (15:33 +0000)
committerjakubvrana <jakubvrana@7c3ca157-0c34-0410-bff1-cbf682f78f5c>
Tue, 6 Oct 2009 15:33:48 +0000 (15:33 +0000)
git-svn-id: https://adminer.svn.sourceforge.net/svnroot/adminer/trunk@1173 7c3ca157-0c34-0410-bff1-cbf682f78f5c

adminer/include/auth.inc.php
adminer/include/design.inc.php
adminer/include/functions.inc.php

index e70869372470109907f549ce29d9639a0ffb38ca..d174835e115196e7b5c148e696c3e7c3b802e823 100644 (file)
@@ -1,14 +1,13 @@
 <?php
 $ignore = array("server", "username", "password");
-$session_name = session_name();
 if (isset($_POST["server"])) {
        session_regenerate_id(); // defense against session fixation
        $_SESSION["usernames"][$_POST["server"]] = $_POST["username"];
        $_SESSION["passwords"][$_POST["server"]] = $_POST["password"];
        $_SESSION["tokens"][$_POST["server"]] = rand(1, 1e6); // defense against cross-site request forgery
        if (count($_POST) == count($ignore)) {
-               $location = ((string) $_GET["server"] === $_POST["server"] ? remove_from_uri() : preg_replace('~^[^?]*/([^?]*).*~', '\\1', $_SERVER["REQUEST_URI"]) . (strlen($_POST["server"]) ? '?server=' . urlencode($_POST["server"]) : ''));
-               if (!isset($_COOKIE[$session_name])) {
+               $location = ((string) $_GET["server"] === $_POST["server"] ? remove_from_uri() : preg_replace('~^([^?]*).*~', '\\1', $_SERVER["REQUEST_URI"]) . (strlen($_POST["server"]) ? '?server=' . urlencode($_POST["server"]) : ''));
+               if (!isset($_COOKIE[session_name()])) {
                        $location .= (strpos($location, "?") === false ? "?" : "&") . SID;
                }
                redirect($location);
@@ -32,9 +31,13 @@ if (isset($_POST["server"])) {
 
 function auth_error($exception = null) {
        global $ignore, $connection, $adminer;
+       $session_name = session_name();
        $username = $_SESSION["usernames"][$_GET["server"]];
        unset($_SESSION["usernames"][$_GET["server"]]);
-       page_header(lang('Login'), (isset($username) ? h($exception ? $exception->getMessage() : (is_string($connection) ? $connection : lang('Invalid credentials.'))) : (isset($_POST["server"]) ? lang('Session support must be enabled.') : ($_POST ? lang('Session expired, please login again.') : ""))), null);
+       page_header(lang('Login'), (isset($username) ? h($exception ? $exception->getMessage() : (is_string($connection) ? $connection : lang('Invalid credentials.')))
+               : (!$_COOKIE[$session_name] && $_GET[$session_name] && ini_get("session.use_only_cookies") ? lang('Session support must be enabled.')
+               : (($_COOKIE[$session_name] || $_GET[$session_name]) && !isset($_SESSION["passwords"]) ? lang('Session expired, please login again.')
+       : ""))), null);
        echo "<form action='' method='post'>\n";
        $adminer->loginForm($username);
        echo "<p>\n";
index 76562d14798474c05f41e08e58e63d00d5818547..a17bcf2af335aefd8a8acab5d536b8070291ffd6 100644 (file)
@@ -44,6 +44,9 @@ function page_header($title, $error = "", $breadcrumb = array(), $title2 = "") {
                echo "<div class='message'>" . implode("</div>\n<div class='message'>", $_SESSION["messages"]) . "</div>\n";
                $_SESSION["messages"] = array();
        }
+       if (!$_POST && !isset($_SESSION["passwords"])) { // used in auth
+               $_SESSION["passwords"] = array();
+       }
        $databases = &$_SESSION["databases"][$_GET["server"]];
        if (strlen(DB) && $databases && !in_array(DB, $databases, true)) {
                $databases = null;
index 2556f61e261f64275e62f5d2f0a0bb6a70365c75..2b3fc3d14e6e779b6efe304a08b9401618a7e22e 100644 (file)
@@ -266,7 +266,7 @@ function queries($query = null) {
 */
 function remove_from_uri($param = "") {
        $param = "($param|" . session_name() . ")";
-       return preg_replace("~\\?$param=[^&]*&~", '?', preg_replace("~\\?$param=[^&]*\$|&$param=[^&]*~", '', $_SERVER["REQUEST_URI"]));
+       return substr(preg_replace("~([?&])$param=[^&]*&~", '\\1', "$_SERVER[REQUEST_URI]&"), 0, -1);
 }
 
 /** Generate page number for pagination