mirror of
https://github.com/MariaDB/server.git
synced 2025-08-01 03:47:19 +03:00
Merge endora.local:/Users/davi/mysql/bugs/31850-5.1
into endora.local:/Users/davi/mysql/mysql-5.1-runtime
This commit is contained in:
@ -317,17 +317,20 @@ check_user(THD *thd, enum enum_server_command command,
|
||||
{
|
||||
DBUG_ENTER("check_user");
|
||||
LEX_STRING db_str= { (char *) db, db ? strlen(db) : 0 };
|
||||
|
||||
|
||||
/*
|
||||
Clear thd->db as it points to something, that will be freed when
|
||||
connection is closed. We don't want to accidentally free a wrong
|
||||
pointer if connect failed. Also in case of 'CHANGE USER' failure,
|
||||
current database will be switched to 'no database selected'.
|
||||
*/
|
||||
thd->reset_db(NULL, 0);
|
||||
|
||||
#ifdef NO_EMBEDDED_ACCESS_CHECKS
|
||||
thd->main_security_ctx.master_access= GLOBAL_ACLS; // Full rights
|
||||
/* Change database if necessary */
|
||||
if (db && db[0])
|
||||
{
|
||||
/*
|
||||
thd->db is saved in caller and needs to be freed by caller if this
|
||||
function returns 0
|
||||
*/
|
||||
thd->reset_db(NULL, 0);
|
||||
if (mysql_change_db(thd, &db_str, FALSE))
|
||||
DBUG_RETURN(1);
|
||||
}
|
||||
@ -358,14 +361,6 @@ check_user(THD *thd, enum enum_server_command command,
|
||||
DBUG_RETURN(1);
|
||||
}
|
||||
|
||||
/*
|
||||
Clear thd->db as it points to something, that will be freed when
|
||||
connection is closed. We don't want to accidentally free a wrong pointer
|
||||
if connect failed. Also in case of 'CHANGE USER' failure, current
|
||||
database will be switched to 'no database selected'.
|
||||
*/
|
||||
thd->reset_db(NULL, 0);
|
||||
|
||||
USER_RESOURCES ur;
|
||||
int res= acl_getroot(thd, &ur, passwd, passwd_len);
|
||||
#ifndef EMBEDDED_LIBRARY
|
||||
|
Reference in New Issue
Block a user