diff options
author | unknown <msvensson@neptunus.(none)> | 2006-01-09 10:31:07 +0100 |
---|---|---|
committer | unknown <msvensson@neptunus.(none)> | 2006-01-09 10:31:07 +0100 |
commit | 16257e8b356c105fcc9fa8c8851338da60ece8f2 (patch) | |
tree | 788f8e7da96bac419a2f9810c1c6b3ffd55af3ca /sql/sql_acl.cc | |
parent | c2ac089167ac158aff1318cdb94c55a48fae34a5 (diff) | |
download | mariadb-git-16257e8b356c105fcc9fa8c8851338da60ece8f2.tar.gz |
Bug #15598 Server crashes in specific case during setting new password
- When acl_user->host.hostname is NULL compare it as ""
mysql-test/r/grant.result:
Test user with host ''
mysql-test/t/grant.test:
Test user with host ''
sql/sql_acl.cc:
If acl_user->host.hostname is NULL compare it as ""
Diffstat (limited to 'sql/sql_acl.cc')
-rw-r--r-- | sql/sql_acl.cc | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/sql/sql_acl.cc b/sql/sql_acl.cc index 1ade6ce3064..119952eeda9 100644 --- a/sql/sql_acl.cc +++ b/sql/sql_acl.cc @@ -1371,7 +1371,8 @@ find_acl_user(const char *host, const char *user, my_bool exact) acl_user->user && !strcmp(user,acl_user->user)) { if (exact ? !my_strcasecmp(&my_charset_latin1, host, - acl_user->host.hostname) : + acl_user->host.hostname ? + acl_user->host.hostname : "") : compare_hostname(&acl_user->host,host,host)) { DBUG_RETURN(acl_user); @@ -3604,7 +3605,7 @@ ACL_USER *check_acl_user(LEX_USER *user_name, if (!(user=acl_user->user)) user= ""; if (!(host=acl_user->host.hostname)) - host= "%"; + host= ""; if (!strcmp(user_name->user.str,user) && !my_strcasecmp(system_charset_info, user_name->host.str, host)) break; |