GRANT USAGE only on MySQL 4
SET PASSWORD only for same user REVOKE old privileges DROP confirmation Procedures absent on MySQL 4 git-svn-id: https://adminer.svn.sourceforge.net/svnroot/adminer/trunk@332 7c3ca157-0c34-0410-bff1-cbf682f78f5c
This commit is contained in:
parent
7d037717fe
commit
7d7e10be08
14
user.inc.php
14
user.inc.php
|
@ -44,7 +44,7 @@ if (isset($_GET["host"]) && ($result = $mysql->query("SHOW GRANTS FOR '" . $mysq
|
||||||
}
|
}
|
||||||
if (substr($match[2], -1) == "*") {
|
if (substr($match[2], -1) == "*") {
|
||||||
all_privileges($grants[$match[2]], $privileges["Databases"]);
|
all_privileges($grants[$match[2]], $privileges["Databases"]);
|
||||||
all_privileges($grants[$match[2]], $privileges["Procedures"]);
|
all_privileges($grants[$match[2]], (array) $privileges["Procedures"]);
|
||||||
}
|
}
|
||||||
all_privileges($grants[$match[2]], $privileges["Tables"]);
|
all_privileges($grants[$match[2]], $privileges["Tables"]);
|
||||||
} elseif (preg_match_all('~ *([^(,]*[^ ,(])( *\\([^)]+\\))?~', $match[1], $matches, PREG_SET_ORDER)) {
|
} elseif (preg_match_all('~ *([^(,]*[^ ,(])( *\\([^)]+\\))?~', $match[1], $matches, PREG_SET_ORDER)) {
|
||||||
|
@ -67,14 +67,14 @@ if ($_POST && !$error) {
|
||||||
$old_user = (isset($_GET["host"]) ? $mysql->escape_string($_GET["user"]) . "'@'" . $mysql->escape_string($_GET["host"]) : "");
|
$old_user = (isset($_GET["host"]) ? $mysql->escape_string($_GET["user"]) . "'@'" . $mysql->escape_string($_GET["host"]) : "");
|
||||||
$new_user = $mysql->escape_string($_POST["user"]) . "'@'" . $mysql->escape_string($_POST["host"]);
|
$new_user = $mysql->escape_string($_POST["user"]) . "'@'" . $mysql->escape_string($_POST["host"]);
|
||||||
$pass = $mysql->escape_string($_POST["pass"]);
|
$pass = $mysql->escape_string($_POST["pass"]);
|
||||||
$identified = " IDENTIFIED BY" . ($_POST["hashed"] ? " PASSWORD" : "") . " '$pass'";
|
|
||||||
if ($_POST["drop"]) {
|
if ($_POST["drop"]) {
|
||||||
if ($mysql->query("DROP USER '$old_user'")) {
|
if ($mysql->query("DROP USER '$old_user'")) {
|
||||||
redirect($SELF . "privileges=", lang('User has been dropped.'));
|
redirect($SELF . "privileges=", lang('User has been dropped.'));
|
||||||
}
|
}
|
||||||
} elseif ($old_user == $new_user || $mysql->server_info < 5 || $mysql->query("CREATE USER '$new_user'$identified")) {
|
} elseif ($old_user == $new_user || $mysql->query(($mysql->server_info < 5 ? "GRANT USAGE ON *.* TO" : "CREATE USER") . " '$new_user' IDENTIFIED BY" . ($_POST["hashed"] ? " PASSWORD" : "") . " '$pass'")) {
|
||||||
$mysql->query("GRANT USAGE ON *.* TO '$new_user'$identified");
|
if ($old_user == $new_user) {
|
||||||
$mysql->query("SET PASSWORD FOR '$new_user' = " . ($_POST["hashed"] ? "'$pass'" : "PASSWORD('$pass')"));
|
$mysql->query("SET PASSWORD FOR '$new_user' = " . ($_POST["hashed"] ? "'$pass'" : "PASSWORD('$pass')"));
|
||||||
|
}
|
||||||
$revoke = array();
|
$revoke = array();
|
||||||
foreach ($new_grants as $object => $grant) {
|
foreach ($new_grants as $object => $grant) {
|
||||||
if (isset($_GET["grant"])) {
|
if (isset($_GET["grant"])) {
|
||||||
|
@ -106,7 +106,7 @@ if ($_POST && !$error) {
|
||||||
} elseif (!isset($_GET["grant"])) {
|
} elseif (!isset($_GET["grant"])) {
|
||||||
foreach ($grants as $object => $revoke) {
|
foreach ($grants as $object => $revoke) {
|
||||||
if (preg_match('~^(.+)(\\(.*\\))?$~U', $object, $match)) {
|
if (preg_match('~^(.+)(\\(.*\\))?$~U', $object, $match)) {
|
||||||
$mysql->query("REVOKE " . implode("$match[2], ", $revoke) . "$match[2] ON $match[1] FROM '$new_user'");
|
$mysql->query("REVOKE " . implode("$match[2], ", array_keys($revoke)) . "$match[2] ON $match[1] FROM '$new_user'");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -189,6 +189,6 @@ foreach (array(
|
||||||
<p>
|
<p>
|
||||||
<input type="hidden" name="token" value="<?php echo $token; ?>" />
|
<input type="hidden" name="token" value="<?php echo $token; ?>" />
|
||||||
<input type="submit" value="<?php echo lang('Save'); ?>" />
|
<input type="submit" value="<?php echo lang('Save'); ?>" />
|
||||||
<?php if (isset($_GET["host"])) { ?><input type="submit" name="drop" value="<?php echo lang('Drop'); ?>" /><?php } ?>
|
<?php if (isset($_GET["host"])) { ?><input type="submit" name="drop" value="<?php echo lang('Drop'); ?>" onclick="return confirm('<?php echo lang('Are you sure?'); ?>');" /><?php } ?>
|
||||||
</p>
|
</p>
|
||||||
</form>
|
</form>
|
||||||
|
|
Loading…
Reference in a new issue