summaryrefslogtreecommitdiff
path: root/sql/sql_acl.cc
diff options
context:
space:
mode:
authorAlexander Nozdrin <alik@sun.com>2010-02-03 17:01:48 +0300
committerAlexander Nozdrin <alik@sun.com>2010-02-03 17:01:48 +0300
commitcf55cf596e33bb5287bb8336972dbe3ae35fdad4 (patch)
tree939d5c5ce926dbc17814e750c67d6ddc24765cf0 /sql/sql_acl.cc
parentdaec25c11d73e87c0f05b0d4d6cbd18a812d1995 (diff)
parent59f1be1b636e360c410c81de1c41a8c4a254077d (diff)
downloadmariadb-git-cf55cf596e33bb5287bb8336972dbe3ae35fdad4.tar.gz
Manual merge from mysql-5.1-bugteam.
Conflicts: - mysql-test/collections/default.experimental - mysql-test/suite/rpl/r/rpl_sp.result
Diffstat (limited to 'sql/sql_acl.cc')
-rw-r--r--sql/sql_acl.cc124
1 files changed, 12 insertions, 112 deletions
diff --git a/sql/sql_acl.cc b/sql/sql_acl.cc
index 2787f3d297d..ea781080a38 100644
--- a/sql/sql_acl.cc
+++ b/sql/sql_acl.cc
@@ -194,7 +194,6 @@ static bool compare_hostname(const acl_host_and_ip *host,const char *hostname,
const char *ip);
static my_bool acl_load(THD *thd, TABLE_LIST *tables);
static my_bool grant_load(THD *thd, TABLE_LIST *tables);
-static bool acl_write_bin_log(THD *thd, List <LEX_USER> &list, bool clear_error);
/*
Convert scrambled password to binary form, according to scramble type,
@@ -3229,8 +3228,7 @@ int mysql_table_grant(THD *thd, TABLE_LIST *table_list,
if (!result) /* success */
{
- if (acl_write_bin_log(thd, user_list, TRUE))
- result= -1;
+ result= write_bin_log(thd, TRUE, thd->query(), thd->query_length());
}
rw_unlock(&LOCK_grant);
@@ -3406,7 +3404,8 @@ bool mysql_routine_grant(THD *thd, TABLE_LIST *table_list, bool is_proc,
if (write_to_binlog)
{
- result|= acl_write_bin_log(thd, user_list, FALSE);
+ if (write_bin_log(thd, FALSE, thd->query(), thd->query_length()))
+ result= TRUE;
}
rw_unlock(&LOCK_grant);
@@ -3535,7 +3534,7 @@ bool mysql_grant(THD *thd, const char *db, List <LEX_USER> &list,
if (!result)
{
- result= acl_write_bin_log(thd, list, TRUE);
+ result= write_bin_log(thd, TRUE, thd->query(), thd->query_length());
}
rw_unlock(&LOCK_grant);
@@ -5777,9 +5776,9 @@ static int handle_grant_data(TABLE_LIST *tables, bool drop,
}
-static void append_user(String *str, LEX_USER *user, bool comma= TRUE)
+static void append_user(String *str, LEX_USER *user)
{
- if (comma && str->length())
+ if (str->length())
str->append(',');
str->append('\'');
str->append(user->user.str);
@@ -5788,65 +5787,6 @@ static void append_user(String *str, LEX_USER *user, bool comma= TRUE)
str->append('\'');
}
-/*
- The operations(DROP, RENAME, REVOKE, GRANT) will cause inconsistency between
- master and slave, when CURRENT_USER() is used. To solve this problem, we
- construct a new binlog statement in which CURRENT_USER() is replaced by
- the real user name and host name.
- */
-static bool acl_write_bin_log(THD *thd, List <LEX_USER> &list, bool clear_error)
-{
- String log_query;
- LEX *lex= thd->lex;
- List_iterator <LEX_USER> user_list(list);
- LEX_USER *user, *tmp_user;
-
- if (!mysql_bin_log.is_open())
- return FALSE;
-
- if (log_query.append(lex->stmt_begin, lex->stmt_user_begin - lex->stmt_begin))
- return TRUE;
- while ((tmp_user= user_list++))
- {
- if (!(user= get_current_user(thd, tmp_user)))
- continue;
-
- /*
- No User, but a password?
- They did GRANT ... TO CURRENT_USER() IDENTIFIED BY ... !
- Get the current user, and shallow-copy the new password to them!
- */
- if (!tmp_user->user.str && tmp_user->password.str)
- user->password= tmp_user->password;
-
- if (log_query.append(" ", 1))
- return TRUE;
- append_user(&log_query, user, FALSE);
- /* Only 'GRANT' have password */
- if (user->password.str)
- {
- if (log_query.append(STRING_WITH_LEN(" IDENTIFIED BY ")) ||
- log_query.append(STRING_WITH_LEN("PASSWORD ")) ||
- log_query.append("'", 1) ||
- log_query.append(user->password.str,
- user->password.length) ||
- log_query.append("'", 1))
- return TRUE;
- }
- if (log_query.append(",", 1))
- return TRUE;
- }
- /* It is binlogged only when at least one user is in the query */
- if (log_query.c_ptr()[log_query.length()-1] == ',')
- {
- log_query.length(log_query.length()-1);
- if (log_query.append(lex->stmt_user_end, lex->stmt_end - lex->stmt_user_end))
- return TRUE;
- return write_bin_log(thd, clear_error, log_query.c_ptr_safe(),
- log_query.length()) != 0;
- }
- return FALSE;
-}
/*
Create a list of users.
@@ -5953,7 +5893,6 @@ bool mysql_drop_user(THD *thd, List <LEX_USER> &list)
{
int result;
String wrong_users;
- String log_query;
LEX_USER *user_name, *tmp_user_name;
List_iterator <LEX_USER> user_list(list);
TABLE_LIST tables[GRANT_TABLES];
@@ -5983,7 +5922,6 @@ bool mysql_drop_user(THD *thd, List <LEX_USER> &list)
rw_wrlock(&LOCK_grant);
VOID(pthread_mutex_lock(&acl_cache->lock));
- log_query.append(STRING_WITH_LEN("DROP USER"));
while ((tmp_user_name= user_list++))
{
if (!(user_name= get_current_user(thd, tmp_user_name)))
@@ -5991,17 +5929,6 @@ bool mysql_drop_user(THD *thd, List <LEX_USER> &list)
result= TRUE;
continue;
}
-
- /*
- The operation will cause inconsistency between master and slave, when
- CURRENT_USER() is used. To solve this problem, we construct a new
- binlog statement in which CURRENT_USER() is replaced by the real user
- name and host name.
- */
- log_query.append(STRING_WITH_LEN(" "));
- append_user(&log_query, user_name, FALSE);
- log_query.append(STRING_WITH_LEN(","));
-
if (handle_grant_data(tables, 1, user_name, NULL) <= 0)
{
append_user(&wrong_users, user_name);
@@ -6020,13 +5947,7 @@ bool mysql_drop_user(THD *thd, List <LEX_USER> &list)
my_error(ER_CANNOT_USER, MYF(0), "DROP USER", wrong_users.c_ptr_safe());
if (some_users_deleted)
- {
- if (log_query.c_ptr()[log_query.length()-1] == ',')
- {
- log_query.length(log_query.length()-1);
- result|= write_bin_log(thd, FALSE, log_query.c_ptr_safe(), log_query.length());
- }
- }
+ result |= write_bin_log(thd, FALSE, thd->query(), thd->query_length());
rw_unlock(&LOCK_grant);
close_thread_tables(thd);
@@ -6054,7 +5975,6 @@ bool mysql_rename_user(THD *thd, List <LEX_USER> &list)
{
int result;
String wrong_users;
- String log_query;
LEX_USER *user_from, *tmp_user_from;
LEX_USER *user_to, *tmp_user_to;
List_iterator <LEX_USER> user_list(list);
@@ -6082,7 +6002,6 @@ bool mysql_rename_user(THD *thd, List <LEX_USER> &list)
rw_wrlock(&LOCK_grant);
VOID(pthread_mutex_lock(&acl_cache->lock));
- log_query.append(STRING_WITH_LEN("RENAME USER"));
while ((tmp_user_from= user_list++))
{
if (!(user_from= get_current_user(thd, tmp_user_from)))
@@ -6099,18 +6018,6 @@ bool mysql_rename_user(THD *thd, List <LEX_USER> &list)
DBUG_ASSERT(user_to != 0); /* Syntax enforces pairs of users. */
/*
- The operation will cause inconsistency between master and slave, when
- CURRENT_USER() is used. To solve this problem, we construct a new
- binlog statement in which CURRENT_USER() is replaced by the real user
- name and host name.
- */
- log_query.append(STRING_WITH_LEN(" "));
- append_user(&log_query, user_from, FALSE);
- log_query.append(STRING_WITH_LEN(" TO "));
- append_user(&log_query, user_to, FALSE);
- log_query.append(STRING_WITH_LEN(","));
-
- /*
Search all in-memory structures and grant tables
for a mention of the new user name.
*/
@@ -6131,15 +6038,9 @@ bool mysql_rename_user(THD *thd, List <LEX_USER> &list)
if (result)
my_error(ER_CANNOT_USER, MYF(0), "RENAME USER", wrong_users.c_ptr_safe());
-
- if (some_users_renamed)
- {
- if (log_query.c_ptr()[log_query.length()-1] == ',')
- {
- log_query.length(log_query.length()-1);
- result|= write_bin_log(thd, FALSE, log_query.c_ptr_safe(), log_query.length());
- }
- }
+
+ if (some_users_renamed && mysql_bin_log.is_open())
+ result |= write_bin_log(thd, FALSE, thd->query(), thd->query_length());
rw_unlock(&LOCK_grant);
close_thread_tables(thd);
@@ -6329,9 +6230,8 @@ bool mysql_revoke_all(THD *thd, List <LEX_USER> &list)
VOID(pthread_mutex_unlock(&acl_cache->lock));
- int binlog_error= 0;
- if (acl_write_bin_log(thd, list, FALSE))
- binlog_error= 1;
+ int binlog_error=
+ write_bin_log(thd, FALSE, thd->query(), thd->query_length());
rw_unlock(&LOCK_grant);
close_thread_tables(thd);