Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
2b18be14
Commit
2b18be14
authored
Nov 28, 2005
by
bar@mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge abarkov@bk-internal.mysql.com:/home/bk/mysql-4.1
into mysql.com:/usr/home/bar/mysql-4.1.b14406
parents
114cf112
63b038f2
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
87 additions
and
53 deletions
+87
-53
mysql-test/r/grant.result
mysql-test/r/grant.result
+24
-3
mysql-test/r/ps_grant.result
mysql-test/r/ps_grant.result
+3
-3
mysql-test/t/grant.test
mysql-test/t/grant.test
+12
-0
sql/sql_acl.cc
sql/sql_acl.cc
+48
-47
No files found.
mysql-test/r/grant.result
View file @
2b18be14
...
@@ -351,10 +351,10 @@ GRANT USAGE ON *.* TO 'grant_user'@'localhost'
...
@@ -351,10 +351,10 @@ GRANT USAGE ON *.* TO 'grant_user'@'localhost'
GRANT INSERT (a, d, c, b) ON `test`.`t1` TO 'grant_user'@'localhost'
GRANT INSERT (a, d, c, b) ON `test`.`t1` TO 'grant_user'@'localhost'
select Host,Db,User,Table_name,Column_name,Column_priv from mysql.columns_priv;
select Host,Db,User,Table_name,Column_name,Column_priv from mysql.columns_priv;
Host Db User Table_name Column_name Column_priv
Host Db User Table_name Column_name Column_priv
localhost test grant_user t1 c Insert
localhost test grant_user t1 b Insert
localhost test grant_user t1 b Insert
localhost test grant_user t1 a Insert
localhost test grant_user t1 d Insert
localhost test grant_user t1 d Insert
localhost test grant_user t1 a Insert
localhost test grant_user t1 c Insert
revoke ALL PRIVILEGES on t1 from grant_user@localhost;
revoke ALL PRIVILEGES on t1 from grant_user@localhost;
show grants for grant_user@localhost;
show grants for grant_user@localhost;
Grants for grant_user@localhost
Grants for grant_user@localhost
...
@@ -377,9 +377,9 @@ show grants for mysqltest_3@localhost;
...
@@ -377,9 +377,9 @@ show grants for mysqltest_3@localhost;
Grants for mysqltest_3@localhost
Grants for mysqltest_3@localhost
GRANT USAGE ON *.* TO 'mysqltest_3'@'localhost'
GRANT USAGE ON *.* TO 'mysqltest_3'@'localhost'
GRANT SELECT (b) ON `mysqltest_1`.`t2` TO 'mysqltest_3'@'localhost'
GRANT SELECT (b) ON `mysqltest_1`.`t2` TO 'mysqltest_3'@'localhost'
GRANT SELECT (c) ON `mysqltest_2`.`t1` TO 'mysqltest_3'@'localhost'
GRANT UPDATE (a) ON `mysqltest_1`.`t1` TO 'mysqltest_3'@'localhost'
GRANT UPDATE (a) ON `mysqltest_1`.`t1` TO 'mysqltest_3'@'localhost'
GRANT UPDATE (d) ON `mysqltest_2`.`t2` TO 'mysqltest_3'@'localhost'
GRANT UPDATE (d) ON `mysqltest_2`.`t2` TO 'mysqltest_3'@'localhost'
GRANT SELECT (c) ON `mysqltest_2`.`t1` TO 'mysqltest_3'@'localhost'
update mysqltest_1.t1, mysqltest_1.t2 set q=10 where b=1;
update mysqltest_1.t1, mysqltest_1.t2 set q=10 where b=1;
ERROR 42000: UPDATE command denied to user 'mysqltest_3'@'localhost' for column 'q' in table 't1'
ERROR 42000: UPDATE command denied to user 'mysqltest_3'@'localhost' for column 'q' in table 't1'
update mysqltest_1.t1, mysqltest_2.t2 set d=20 where d=1;
update mysqltest_1.t1, mysqltest_2.t2 set d=20 where d=1;
...
@@ -443,3 +443,24 @@ flush privileges;
...
@@ -443,3 +443,24 @@ flush privileges;
set @user123="non-existent";
set @user123="non-existent";
select * from mysql.db where user=@user123;
select * from mysql.db where user=@user123;
Host Db User Select_priv Insert_priv Update_priv Delete_priv Create_priv Drop_priv Grant_priv References_priv Index_priv Alter_priv Create_tmp_table_priv Lock_tables_priv
Host Db User Select_priv Insert_priv Update_priv Delete_priv Create_priv Drop_priv Grant_priv References_priv Index_priv Alter_priv Create_tmp_table_priv Lock_tables_priv
set names koi8r;
create database ;
grant select on .* to root@localhost;
select hex(Db) from mysql.db where Db='';
hex(Db)
D0B1D0B4
show grants for root@localhost;
Grants for root@localhost
GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION
GRANT SELECT ON ``.* TO 'root'@'localhost'
flush privileges;
show grants for root@localhost;
Grants for root@localhost
GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION
GRANT SELECT ON ``.* TO 'root'@'localhost'
drop database ;
revoke all privileges on .* from root@localhost;
show grants for root@localhost;
Grants for root@localhost
GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION
set names latin1;
mysql-test/r/ps_grant.result
View file @
2b18be14
...
@@ -32,19 +32,19 @@ identified by 'looser' ;
...
@@ -32,19 +32,19 @@ identified by 'looser' ;
show grants for second_user@localhost ;
show grants for second_user@localhost ;
Grants for second_user@localhost
Grants for second_user@localhost
GRANT USAGE ON *.* TO 'second_user'@'localhost' IDENTIFIED BY PASSWORD '*13843FE600B19A81E32AF50D4A6FED25875FF1F3'
GRANT USAGE ON *.* TO 'second_user'@'localhost' IDENTIFIED BY PASSWORD '*13843FE600B19A81E32AF50D4A6FED25875FF1F3'
GRANT SELECT ON `mysqltest`.`t9` TO 'second_user'@'localhost'
GRANT SELECT ON `mysqltest`.`t1` TO 'second_user'@'localhost'
GRANT SELECT ON `mysqltest`.`t1` TO 'second_user'@'localhost'
GRANT SELECT ON `mysqltest`.`t9` TO 'second_user'@'localhost'
drop table mysqltest.t9 ;
drop table mysqltest.t9 ;
show grants for second_user@localhost ;
show grants for second_user@localhost ;
Grants for second_user@localhost
Grants for second_user@localhost
GRANT USAGE ON *.* TO 'second_user'@'localhost' IDENTIFIED BY PASSWORD '*13843FE600B19A81E32AF50D4A6FED25875FF1F3'
GRANT USAGE ON *.* TO 'second_user'@'localhost' IDENTIFIED BY PASSWORD '*13843FE600B19A81E32AF50D4A6FED25875FF1F3'
GRANT SELECT ON `mysqltest`.`t9` TO 'second_user'@'localhost'
GRANT SELECT ON `mysqltest`.`t1` TO 'second_user'@'localhost'
GRANT SELECT ON `mysqltest`.`t1` TO 'second_user'@'localhost'
GRANT SELECT ON `mysqltest`.`t9` TO 'second_user'@'localhost'
show grants for second_user@localhost ;
show grants for second_user@localhost ;
Grants for second_user@localhost
Grants for second_user@localhost
GRANT USAGE ON *.* TO 'second_user'@'localhost' IDENTIFIED BY PASSWORD '*13843FE600B19A81E32AF50D4A6FED25875FF1F3'
GRANT USAGE ON *.* TO 'second_user'@'localhost' IDENTIFIED BY PASSWORD '*13843FE600B19A81E32AF50D4A6FED25875FF1F3'
GRANT SELECT ON `mysqltest`.`t9` TO 'second_user'@'localhost'
GRANT SELECT ON `mysqltest`.`t1` TO 'second_user'@'localhost'
GRANT SELECT ON `mysqltest`.`t1` TO 'second_user'@'localhost'
GRANT SELECT ON `mysqltest`.`t9` TO 'second_user'@'localhost'
prepare s_t1 from 'select a as my_col from t1' ;
prepare s_t1 from 'select a as my_col from t1' ;
execute s_t1 ;
execute s_t1 ;
my_col
my_col
...
...
mysql-test/t/grant.test
View file @
2b18be14
...
@@ -409,4 +409,16 @@ flush privileges;
...
@@ -409,4 +409,16 @@ flush privileges;
set
@
user123
=
"non-existent"
;
set
@
user123
=
"non-existent"
;
select
*
from
mysql
.
db
where
user
=@
user123
;
select
*
from
mysql
.
db
where
user
=@
user123
;
set
names
koi8r
;
create
database
;
grant
select
on
.*
to
root
@
localhost
;
select
hex
(
Db
)
from
mysql
.
db
where
Db
=
''
;
show
grants
for
root
@
localhost
;
flush
privileges
;
show
grants
for
root
@
localhost
;
drop
database
;
revoke
all
privileges
on
.*
from
root
@
localhost
;
show
grants
for
root
@
localhost
;
set
names
latin1
;
# End of 4.1 tests
# End of 4.1 tests
sql/sql_acl.cc
View file @
2b18be14
...
@@ -903,7 +903,7 @@ static void acl_update_user(const char *user, const char *host,
...
@@ -903,7 +903,7 @@ static void acl_update_user(const char *user, const char *host,
{
{
if
(
!
acl_user
->
host
.
hostname
&&
!
host
[
0
]
||
if
(
!
acl_user
->
host
.
hostname
&&
!
host
[
0
]
||
acl_user
->
host
.
hostname
&&
acl_user
->
host
.
hostname
&&
!
my_strcasecmp
(
&
my_charset_latin1
,
host
,
acl_user
->
host
.
hostname
))
!
my_strcasecmp
(
system_charset_info
,
host
,
acl_user
->
host
.
hostname
))
{
{
acl_user
->
access
=
privileges
;
acl_user
->
access
=
privileges
;
if
(
mqh
->
bits
&
1
)
if
(
mqh
->
bits
&
1
)
...
@@ -982,7 +982,7 @@ static void acl_update_db(const char *user, const char *host, const char *db,
...
@@ -982,7 +982,7 @@ static void acl_update_db(const char *user, const char *host, const char *db,
{
{
if
(
!
acl_db
->
host
.
hostname
&&
!
host
[
0
]
||
if
(
!
acl_db
->
host
.
hostname
&&
!
host
[
0
]
||
acl_db
->
host
.
hostname
&&
acl_db
->
host
.
hostname
&&
!
my_strcasecmp
(
&
my_charset_latin1
,
host
,
acl_db
->
host
.
hostname
))
!
my_strcasecmp
(
system_charset_info
,
host
,
acl_db
->
host
.
hostname
))
{
{
if
(
!
acl_db
->
db
&&
!
db
[
0
]
||
if
(
!
acl_db
->
db
&&
!
db
[
0
]
||
acl_db
->
db
&&
!
strcmp
(
db
,
acl_db
->
db
))
acl_db
->
db
&&
!
strcmp
(
db
,
acl_db
->
db
))
...
@@ -1128,7 +1128,7 @@ static void init_check_host(void)
...
@@ -1128,7 +1128,7 @@ static void init_check_host(void)
DBUG_ENTER
(
"init_check_host"
);
DBUG_ENTER
(
"init_check_host"
);
VOID
(
my_init_dynamic_array
(
&
acl_wild_hosts
,
sizeof
(
struct
acl_host_and_ip
),
VOID
(
my_init_dynamic_array
(
&
acl_wild_hosts
,
sizeof
(
struct
acl_host_and_ip
),
acl_users
.
elements
,
1
));
acl_users
.
elements
,
1
));
VOID
(
hash_init
(
&
acl_check_hosts
,
&
my_charset_latin1
,
acl_users
.
elements
,
0
,
0
,
VOID
(
hash_init
(
&
acl_check_hosts
,
system_charset_info
,
acl_users
.
elements
,
0
,
0
,
(
hash_get_key
)
check_get_key
,
0
,
0
));
(
hash_get_key
)
check_get_key
,
0
,
0
));
if
(
!
allow_all_hosts
)
if
(
!
allow_all_hosts
)
{
{
...
@@ -1144,7 +1144,7 @@ static void init_check_host(void)
...
@@ -1144,7 +1144,7 @@ static void init_check_host(void)
{
// Check if host already exists
{
// Check if host already exists
acl_host_and_ip
*
acl
=
dynamic_element
(
&
acl_wild_hosts
,
j
,
acl_host_and_ip
*
acl
=
dynamic_element
(
&
acl_wild_hosts
,
j
,
acl_host_and_ip
*
);
acl_host_and_ip
*
);
if
(
!
my_strcasecmp
(
&
my_charset_latin1
,
if
(
!
my_strcasecmp
(
system_charset_info
,
acl_user
->
host
.
hostname
,
acl
->
hostname
))
acl_user
->
host
.
hostname
,
acl
->
hostname
))
break
;
// already stored
break
;
// already stored
}
}
...
@@ -1225,7 +1225,7 @@ bool check_change_password(THD *thd, const char *host, const char *user,
...
@@ -1225,7 +1225,7 @@ bool check_change_password(THD *thd, const char *host, const char *user,
}
}
if
(
!
thd
->
slave_thread
&&
if
(
!
thd
->
slave_thread
&&
(
strcmp
(
thd
->
user
,
user
)
||
(
strcmp
(
thd
->
user
,
user
)
||
my_strcasecmp
(
&
my_charset_latin1
,
host
,
thd
->
priv_host
)))
my_strcasecmp
(
system_charset_info
,
host
,
thd
->
priv_host
)))
{
{
if
(
check_access
(
thd
,
UPDATE_ACL
,
"mysql"
,
0
,
1
,
0
))
if
(
check_access
(
thd
,
UPDATE_ACL
,
"mysql"
,
0
,
1
,
0
))
return
(
1
);
return
(
1
);
...
@@ -1434,7 +1434,7 @@ static bool compare_hostname(const acl_host_and_ip *host, const char *hostname,
...
@@ -1434,7 +1434,7 @@ static bool compare_hostname(const acl_host_and_ip *host, const char *hostname,
return
(
tmp
&
host
->
ip_mask
)
==
host
->
ip
;
return
(
tmp
&
host
->
ip_mask
)
==
host
->
ip
;
}
}
return
(
!
host
->
hostname
||
return
(
!
host
->
hostname
||
(
hostname
&&
!
wild_case_compare
(
&
my_charset_latin1
,
(
hostname
&&
!
wild_case_compare
(
system_charset_info
,
hostname
,
host
->
hostname
))
||
hostname
,
host
->
hostname
))
||
(
ip
&&
!
wild_compare
(
ip
,
host
->
hostname
,
0
)));
(
ip
&&
!
wild_compare
(
ip
,
host
->
hostname
,
0
)));
}
}
...
@@ -1447,7 +1447,7 @@ bool hostname_requires_resolving(const char *hostname)
...
@@ -1447,7 +1447,7 @@ bool hostname_requires_resolving(const char *hostname)
int
namelen
=
strlen
(
hostname
);
int
namelen
=
strlen
(
hostname
);
int
lhlen
=
strlen
(
my_localhost
);
int
lhlen
=
strlen
(
my_localhost
);
if
((
namelen
==
lhlen
)
&&
if
((
namelen
==
lhlen
)
&&
!
my_strnncoll
(
&
my_charset_latin1
,
(
const
uchar
*
)
hostname
,
namelen
,
!
my_strnncoll
(
system_charset_info
,
(
const
uchar
*
)
hostname
,
namelen
,
(
const
uchar
*
)
my_localhost
,
strlen
(
my_localhost
)))
(
const
uchar
*
)
my_localhost
,
strlen
(
my_localhost
)))
return
FALSE
;
return
FALSE
;
for
(;
(
cur
=*
hostname
);
hostname
++
)
for
(;
(
cur
=*
hostname
);
hostname
++
)
...
@@ -1481,8 +1481,8 @@ static bool update_user_table(THD *thd, TABLE *table,
...
@@ -1481,8 +1481,8 @@ static bool update_user_table(THD *thd, TABLE *table,
DBUG_ENTER
(
"update_user_table"
);
DBUG_ENTER
(
"update_user_table"
);
DBUG_PRINT
(
"enter"
,(
"user: %s host: %s"
,
user
,
host
));
DBUG_PRINT
(
"enter"
,(
"user: %s host: %s"
,
user
,
host
));
table
->
field
[
0
]
->
store
(
host
,(
uint
)
strlen
(
host
),
&
my_charset_latin1
);
table
->
field
[
0
]
->
store
(
host
,(
uint
)
strlen
(
host
),
system_charset_info
);
table
->
field
[
1
]
->
store
(
user
,(
uint
)
strlen
(
user
),
&
my_charset_latin1
);
table
->
field
[
1
]
->
store
(
user
,(
uint
)
strlen
(
user
),
system_charset_info
);
table
->
file
->
extra
(
HA_EXTRA_RETRIEVE_ALL_COLS
);
table
->
file
->
extra
(
HA_EXTRA_RETRIEVE_ALL_COLS
);
if
(
table
->
file
->
index_read_idx
(
table
->
record
[
0
],
0
,
if
(
table
->
file
->
index_read_idx
(
table
->
record
[
0
],
0
,
...
@@ -1494,7 +1494,7 @@ static bool update_user_table(THD *thd, TABLE *table,
...
@@ -1494,7 +1494,7 @@ static bool update_user_table(THD *thd, TABLE *table,
DBUG_RETURN
(
1
);
/* purecov: deadcode */
DBUG_RETURN
(
1
);
/* purecov: deadcode */
}
}
store_record
(
table
,
record
[
1
]);
store_record
(
table
,
record
[
1
]);
table
->
field
[
2
]
->
store
(
new_password
,
new_password_len
,
&
my_charset_latin1
);
table
->
field
[
2
]
->
store
(
new_password
,
new_password_len
,
system_charset_info
);
if
((
error
=
table
->
file
->
update_row
(
table
->
record
[
1
],
table
->
record
[
0
])))
if
((
error
=
table
->
file
->
update_row
(
table
->
record
[
1
],
table
->
record
[
0
])))
{
{
table
->
file
->
print_error
(
error
,
MYF
(
0
));
/* purecov: deadcode */
table
->
file
->
print_error
(
error
,
MYF
(
0
));
/* purecov: deadcode */
...
@@ -1559,8 +1559,8 @@ static int replace_user_table(THD *thd, TABLE *table, const LEX_USER &combo,
...
@@ -1559,8 +1559,8 @@ static int replace_user_table(THD *thd, TABLE *table, const LEX_USER &combo,
password
=
combo
.
password
.
str
;
password
=
combo
.
password
.
str
;
}
}
table
->
field
[
0
]
->
store
(
combo
.
host
.
str
,
combo
.
host
.
length
,
&
my_charset_latin1
);
table
->
field
[
0
]
->
store
(
combo
.
host
.
str
,
combo
.
host
.
length
,
system_charset_info
);
table
->
field
[
1
]
->
store
(
combo
.
user
.
str
,
combo
.
user
.
length
,
&
my_charset_latin1
);
table
->
field
[
1
]
->
store
(
combo
.
user
.
str
,
combo
.
user
.
length
,
system_charset_info
);
table
->
file
->
extra
(
HA_EXTRA_RETRIEVE_ALL_COLS
);
table
->
file
->
extra
(
HA_EXTRA_RETRIEVE_ALL_COLS
);
if
(
table
->
file
->
index_read_idx
(
table
->
record
[
0
],
0
,
if
(
table
->
file
->
index_read_idx
(
table
->
record
[
0
],
0
,
(
byte
*
)
table
->
field
[
0
]
->
ptr
,
(
byte
*
)
table
->
field
[
0
]
->
ptr
,
...
@@ -1579,18 +1579,18 @@ static int replace_user_table(THD *thd, TABLE *table, const LEX_USER &combo,
...
@@ -1579,18 +1579,18 @@ static int replace_user_table(THD *thd, TABLE *table, const LEX_USER &combo,
old_row_exists
=
0
;
old_row_exists
=
0
;
restore_record
(
table
,
default_values
);
// cp empty row from default_values
restore_record
(
table
,
default_values
);
// cp empty row from default_values
table
->
field
[
0
]
->
store
(
combo
.
host
.
str
,
combo
.
host
.
length
,
table
->
field
[
0
]
->
store
(
combo
.
host
.
str
,
combo
.
host
.
length
,
&
my_charset_latin1
);
system_charset_info
);
table
->
field
[
1
]
->
store
(
combo
.
user
.
str
,
combo
.
user
.
length
,
table
->
field
[
1
]
->
store
(
combo
.
user
.
str
,
combo
.
user
.
length
,
&
my_charset_latin1
);
system_charset_info
);
table
->
field
[
2
]
->
store
(
password
,
password_len
,
table
->
field
[
2
]
->
store
(
password
,
password_len
,
&
my_charset_latin1
);
system_charset_info
);
}
}
else
else
{
{
old_row_exists
=
1
;
old_row_exists
=
1
;
store_record
(
table
,
record
[
1
]);
// Save copy for update
store_record
(
table
,
record
[
1
]);
// Save copy for update
if
(
combo
.
password
.
str
)
// If password given
if
(
combo
.
password
.
str
)
// If password given
table
->
field
[
2
]
->
store
(
password
,
password_len
,
&
my_charset_latin1
);
table
->
field
[
2
]
->
store
(
password
,
password_len
,
system_charset_info
);
else
if
(
!
rights
&&
!
revoke_grant
&&
thd
->
lex
->
ssl_type
==
SSL_TYPE_NOT_SPECIFIED
&&
else
if
(
!
rights
&&
!
revoke_grant
&&
thd
->
lex
->
ssl_type
==
SSL_TYPE_NOT_SPECIFIED
&&
!
thd
->
lex
->
mqh
.
bits
)
!
thd
->
lex
->
mqh
.
bits
)
{
{
...
@@ -1637,15 +1637,15 @@ static int replace_user_table(THD *thd, TABLE *table, const LEX_USER &combo,
...
@@ -1637,15 +1637,15 @@ static int replace_user_table(THD *thd, TABLE *table, const LEX_USER &combo,
if
(
thd
->
lex
->
ssl_cipher
)
if
(
thd
->
lex
->
ssl_cipher
)
table
->
field
[
next_field
+
1
]
->
store
(
thd
->
lex
->
ssl_cipher
,
table
->
field
[
next_field
+
1
]
->
store
(
thd
->
lex
->
ssl_cipher
,
strlen
(
thd
->
lex
->
ssl_cipher
),
strlen
(
thd
->
lex
->
ssl_cipher
),
&
my_charset_latin1
);
system_charset_info
);
if
(
thd
->
lex
->
x509_issuer
)
if
(
thd
->
lex
->
x509_issuer
)
table
->
field
[
next_field
+
2
]
->
store
(
thd
->
lex
->
x509_issuer
,
table
->
field
[
next_field
+
2
]
->
store
(
thd
->
lex
->
x509_issuer
,
strlen
(
thd
->
lex
->
x509_issuer
),
strlen
(
thd
->
lex
->
x509_issuer
),
&
my_charset_latin1
);
system_charset_info
);
if
(
thd
->
lex
->
x509_subject
)
if
(
thd
->
lex
->
x509_subject
)
table
->
field
[
next_field
+
3
]
->
store
(
thd
->
lex
->
x509_subject
,
table
->
field
[
next_field
+
3
]
->
store
(
thd
->
lex
->
x509_subject
,
strlen
(
thd
->
lex
->
x509_subject
),
strlen
(
thd
->
lex
->
x509_subject
),
&
my_charset_latin1
);
system_charset_info
);
break
;
break
;
case
SSL_TYPE_NOT_SPECIFIED
:
case
SSL_TYPE_NOT_SPECIFIED
:
break
;
break
;
...
@@ -1750,9 +1750,9 @@ static int replace_db_table(TABLE *table, const char *db,
...
@@ -1750,9 +1750,9 @@ static int replace_db_table(TABLE *table, const char *db,
DBUG_RETURN
(
-
1
);
DBUG_RETURN
(
-
1
);
}
}
table
->
field
[
0
]
->
store
(
combo
.
host
.
str
,
combo
.
host
.
length
,
&
my_charset_latin1
);
table
->
field
[
0
]
->
store
(
combo
.
host
.
str
,
combo
.
host
.
length
,
system_charset_info
);
table
->
field
[
1
]
->
store
(
db
,(
uint
)
strlen
(
db
),
&
my_charset_latin1
);
table
->
field
[
1
]
->
store
(
db
,(
uint
)
strlen
(
db
),
system_charset_info
);
table
->
field
[
2
]
->
store
(
combo
.
user
.
str
,
combo
.
user
.
length
,
&
my_charset_latin1
);
table
->
field
[
2
]
->
store
(
combo
.
user
.
str
,
combo
.
user
.
length
,
system_charset_info
);
table
->
file
->
extra
(
HA_EXTRA_RETRIEVE_ALL_COLS
);
table
->
file
->
extra
(
HA_EXTRA_RETRIEVE_ALL_COLS
);
if
(
table
->
file
->
index_read_idx
(
table
->
record
[
0
],
0
,
if
(
table
->
file
->
index_read_idx
(
table
->
record
[
0
],
0
,
(
byte
*
)
table
->
field
[
0
]
->
ptr
,
(
byte
*
)
table
->
field
[
0
]
->
ptr
,
...
@@ -1766,9 +1766,9 @@ static int replace_db_table(TABLE *table, const char *db,
...
@@ -1766,9 +1766,9 @@ static int replace_db_table(TABLE *table, const char *db,
}
}
old_row_exists
=
0
;
old_row_exists
=
0
;
restore_record
(
table
,
default_values
);
// cp empty row from default_values
restore_record
(
table
,
default_values
);
// cp empty row from default_values
table
->
field
[
0
]
->
store
(
combo
.
host
.
str
,
combo
.
host
.
length
,
&
my_charset_latin1
);
table
->
field
[
0
]
->
store
(
combo
.
host
.
str
,
combo
.
host
.
length
,
system_charset_info
);
table
->
field
[
1
]
->
store
(
db
,(
uint
)
strlen
(
db
),
&
my_charset_latin1
);
table
->
field
[
1
]
->
store
(
db
,(
uint
)
strlen
(
db
),
system_charset_info
);
table
->
field
[
2
]
->
store
(
combo
.
user
.
str
,
combo
.
user
.
length
,
&
my_charset_latin1
);
table
->
field
[
2
]
->
store
(
combo
.
user
.
str
,
combo
.
user
.
length
,
system_charset_info
);
}
}
else
else
{
{
...
@@ -1880,7 +1880,7 @@ GRANT_TABLE::GRANT_TABLE(const char *h, const char *d,const char *u,
...
@@ -1880,7 +1880,7 @@ GRANT_TABLE::GRANT_TABLE(const char *h, const char *d,const char *u,
key_length
=
(
uint
)
strlen
(
d
)
+
(
uint
)
strlen
(
u
)
+
(
uint
)
strlen
(
t
)
+
3
;
key_length
=
(
uint
)
strlen
(
d
)
+
(
uint
)
strlen
(
u
)
+
(
uint
)
strlen
(
t
)
+
3
;
hash_key
=
(
char
*
)
alloc_root
(
&
memex
,
key_length
);
hash_key
=
(
char
*
)
alloc_root
(
&
memex
,
key_length
);
strmov
(
strmov
(
strmov
(
hash_key
,
user
)
+
1
,
db
)
+
1
,
tname
);
strmov
(
strmov
(
strmov
(
hash_key
,
user
)
+
1
,
db
)
+
1
,
tname
);
(
void
)
hash_init
(
&
hash_columns
,
&
my_charset_latin1
,
(
void
)
hash_init
(
&
hash_columns
,
system_charset_info
,
0
,
0
,
0
,
(
hash_get_key
)
get_key_column
,
0
,
0
);
0
,
0
,
0
,
(
hash_get_key
)
get_key_column
,
0
,
0
);
}
}
...
@@ -1916,17 +1916,17 @@ GRANT_TABLE::GRANT_TABLE(TABLE *form, TABLE *col_privs)
...
@@ -1916,17 +1916,17 @@ GRANT_TABLE::GRANT_TABLE(TABLE *form, TABLE *col_privs)
privs
=
fix_rights_for_table
(
privs
);
privs
=
fix_rights_for_table
(
privs
);
cols
=
fix_rights_for_column
(
cols
);
cols
=
fix_rights_for_column
(
cols
);
(
void
)
hash_init
(
&
hash_columns
,
&
my_charset_latin1
,
(
void
)
hash_init
(
&
hash_columns
,
system_charset_info
,
0
,
0
,
0
,
(
hash_get_key
)
get_key_column
,
0
,
0
);
0
,
0
,
0
,
(
hash_get_key
)
get_key_column
,
0
,
0
);
if
(
cols
)
if
(
cols
)
{
{
int
key_len
;
int
key_len
;
col_privs
->
field
[
0
]
->
store
(
host
.
hostname
,
col_privs
->
field
[
0
]
->
store
(
host
.
hostname
,
host
.
hostname
?
(
uint
)
strlen
(
host
.
hostname
)
:
0
,
host
.
hostname
?
(
uint
)
strlen
(
host
.
hostname
)
:
0
,
&
my_charset_latin1
);
system_charset_info
);
col_privs
->
field
[
1
]
->
store
(
db
,(
uint
)
strlen
(
db
),
&
my_charset_latin1
);
col_privs
->
field
[
1
]
->
store
(
db
,(
uint
)
strlen
(
db
),
system_charset_info
);
col_privs
->
field
[
2
]
->
store
(
user
,(
uint
)
strlen
(
user
),
&
my_charset_latin1
);
col_privs
->
field
[
2
]
->
store
(
user
,(
uint
)
strlen
(
user
),
system_charset_info
);
col_privs
->
field
[
3
]
->
store
(
tname
,(
uint
)
strlen
(
tname
),
&
my_charset_latin1
);
col_privs
->
field
[
3
]
->
store
(
tname
,(
uint
)
strlen
(
tname
),
system_charset_info
);
key_len
=
(
col_privs
->
field
[
0
]
->
pack_length
()
+
key_len
=
(
col_privs
->
field
[
0
]
->
pack_length
()
+
col_privs
->
field
[
1
]
->
pack_length
()
+
col_privs
->
field
[
1
]
->
pack_length
()
+
col_privs
->
field
[
2
]
->
pack_length
()
+
col_privs
->
field
[
2
]
->
pack_length
()
+
...
@@ -2032,10 +2032,10 @@ static int replace_column_table(GRANT_TABLE *g_t,
...
@@ -2032,10 +2032,10 @@ static int replace_column_table(GRANT_TABLE *g_t,
byte
key
[
MAX_KEY_LENGTH
];
byte
key
[
MAX_KEY_LENGTH
];
DBUG_ENTER
(
"replace_column_table"
);
DBUG_ENTER
(
"replace_column_table"
);
table
->
field
[
0
]
->
store
(
combo
.
host
.
str
,
combo
.
host
.
length
,
&
my_charset_latin1
);
table
->
field
[
0
]
->
store
(
combo
.
host
.
str
,
combo
.
host
.
length
,
system_charset_info
);
table
->
field
[
1
]
->
store
(
db
,(
uint
)
strlen
(
db
),
&
my_charset_latin1
);
table
->
field
[
1
]
->
store
(
db
,(
uint
)
strlen
(
db
),
system_charset_info
);
table
->
field
[
2
]
->
store
(
combo
.
user
.
str
,
combo
.
user
.
length
,
&
my_charset_latin1
);
table
->
field
[
2
]
->
store
(
combo
.
user
.
str
,
combo
.
user
.
length
,
system_charset_info
);
table
->
field
[
3
]
->
store
(
table_name
,(
uint
)
strlen
(
table_name
),
&
my_charset_latin1
);
table
->
field
[
3
]
->
store
(
table_name
,(
uint
)
strlen
(
table_name
),
system_charset_info
);
key_length
=
(
table
->
field
[
0
]
->
pack_length
()
+
table
->
field
[
1
]
->
pack_length
()
+
key_length
=
(
table
->
field
[
0
]
->
pack_length
()
+
table
->
field
[
1
]
->
pack_length
()
+
table
->
field
[
2
]
->
pack_length
()
+
table
->
field
[
3
]
->
pack_length
());
table
->
field
[
2
]
->
pack_length
()
+
table
->
field
[
3
]
->
pack_length
());
key_copy
(
key
,
table
,
0
,
key_length
);
key_copy
(
key
,
table
,
0
,
key_length
);
...
@@ -2053,7 +2053,7 @@ static int replace_column_table(GRANT_TABLE *g_t,
...
@@ -2053,7 +2053,7 @@ static int replace_column_table(GRANT_TABLE *g_t,
bool
old_row_exists
=
0
;
bool
old_row_exists
=
0
;
key_restore
(
table
,
key
,
0
,
key_length
);
key_restore
(
table
,
key
,
0
,
key_length
);
table
->
field
[
4
]
->
store
(
xx
->
column
.
ptr
(),
xx
->
column
.
length
(),
table
->
field
[
4
]
->
store
(
xx
->
column
.
ptr
(),
xx
->
column
.
length
(),
&
my_charset_latin1
);
system_charset_info
);
table
->
file
->
extra
(
HA_EXTRA_RETRIEVE_ALL_COLS
);
table
->
file
->
extra
(
HA_EXTRA_RETRIEVE_ALL_COLS
);
if
(
table
->
file
->
index_read
(
table
->
record
[
0
],(
byte
*
)
table
->
field
[
0
]
->
ptr
,
if
(
table
->
file
->
index_read
(
table
->
record
[
0
],(
byte
*
)
table
->
field
[
0
]
->
ptr
,
...
@@ -2071,7 +2071,7 @@ static int replace_column_table(GRANT_TABLE *g_t,
...
@@ -2071,7 +2071,7 @@ static int replace_column_table(GRANT_TABLE *g_t,
restore_record
(
table
,
default_values
);
// Get empty record
restore_record
(
table
,
default_values
);
// Get empty record
key_restore
(
table
,
key
,
0
,
key_length
);
key_restore
(
table
,
key
,
0
,
key_length
);
table
->
field
[
4
]
->
store
(
xx
->
column
.
ptr
(),
xx
->
column
.
length
(),
table
->
field
[
4
]
->
store
(
xx
->
column
.
ptr
(),
xx
->
column
.
length
(),
&
my_charset_latin1
);
system_charset_info
);
}
}
else
else
{
{
...
@@ -2143,7 +2143,8 @@ static int replace_column_table(GRANT_TABLE *g_t,
...
@@ -2143,7 +2143,8 @@ static int replace_column_table(GRANT_TABLE *g_t,
{
{
GRANT_COLUMN
*
grant_column
=
NULL
;
GRANT_COLUMN
*
grant_column
=
NULL
;
char
colum_name_buf
[
HOSTNAME_LENGTH
+
1
];
char
colum_name_buf
[
HOSTNAME_LENGTH
+
1
];
String
column_name
(
colum_name_buf
,
sizeof
(
colum_name_buf
),
&
my_charset_latin1
);
String
column_name
(
colum_name_buf
,
sizeof
(
colum_name_buf
),
system_charset_info
);
privileges
&=
~
rights
;
privileges
&=
~
rights
;
table
->
field
[
6
]
->
store
((
longlong
)
table
->
field
[
6
]
->
store
((
longlong
)
...
@@ -2213,10 +2214,10 @@ static int replace_table_table(THD *thd, GRANT_TABLE *grant_table,
...
@@ -2213,10 +2214,10 @@ static int replace_table_table(THD *thd, GRANT_TABLE *grant_table,
}
}
restore_record
(
table
,
default_values
);
// Get empty record
restore_record
(
table
,
default_values
);
// Get empty record
table
->
field
[
0
]
->
store
(
combo
.
host
.
str
,
combo
.
host
.
length
,
&
my_charset_latin1
);
table
->
field
[
0
]
->
store
(
combo
.
host
.
str
,
combo
.
host
.
length
,
system_charset_info
);
table
->
field
[
1
]
->
store
(
db
,(
uint
)
strlen
(
db
),
&
my_charset_latin1
);
table
->
field
[
1
]
->
store
(
db
,(
uint
)
strlen
(
db
),
system_charset_info
);
table
->
field
[
2
]
->
store
(
combo
.
user
.
str
,
combo
.
user
.
length
,
&
my_charset_latin1
);
table
->
field
[
2
]
->
store
(
combo
.
user
.
str
,
combo
.
user
.
length
,
system_charset_info
);
table
->
field
[
3
]
->
store
(
table_name
,(
uint
)
strlen
(
table_name
),
&
my_charset_latin1
);
table
->
field
[
3
]
->
store
(
table_name
,(
uint
)
strlen
(
table_name
),
system_charset_info
);
store_record
(
table
,
record
[
1
]);
// store at pos 1
store_record
(
table
,
record
[
1
]);
// store at pos 1
table
->
file
->
extra
(
HA_EXTRA_RETRIEVE_ALL_COLS
);
table
->
file
->
extra
(
HA_EXTRA_RETRIEVE_ALL_COLS
);
if
(
table
->
file
->
index_read_idx
(
table
->
record
[
0
],
0
,
if
(
table
->
file
->
index_read_idx
(
table
->
record
[
0
],
0
,
...
@@ -2261,7 +2262,7 @@ static int replace_table_table(THD *thd, GRANT_TABLE *grant_table,
...
@@ -2261,7 +2262,7 @@ static int replace_table_table(THD *thd, GRANT_TABLE *grant_table,
}
}
}
}
table
->
field
[
4
]
->
store
(
grantor
,(
uint
)
strlen
(
grantor
),
&
my_charset_latin1
);
table
->
field
[
4
]
->
store
(
grantor
,(
uint
)
strlen
(
grantor
),
system_charset_info
);
table
->
field
[
6
]
->
store
((
longlong
)
store_table_rights
);
table
->
field
[
6
]
->
store
((
longlong
)
store_table_rights
);
table
->
field
[
7
]
->
store
((
longlong
)
store_col_rights
);
table
->
field
[
7
]
->
store
((
longlong
)
store_col_rights
);
rights
=
fix_rights_for_table
(
store_table_rights
);
rights
=
fix_rights_for_table
(
store_table_rights
);
...
@@ -2727,7 +2728,7 @@ static my_bool grant_load(TABLE_LIST *tables)
...
@@ -2727,7 +2728,7 @@ static my_bool grant_load(TABLE_LIST *tables)
DBUG_ENTER
(
"grant_load"
);
DBUG_ENTER
(
"grant_load"
);
grant_option
=
FALSE
;
grant_option
=
FALSE
;
(
void
)
hash_init
(
&
column_priv_hash
,
&
my_charset_latin1
,
(
void
)
hash_init
(
&
column_priv_hash
,
system_charset_info
,
0
,
0
,
0
,
(
hash_get_key
)
get_grant_table
,
0
,
0
,
0
,
(
hash_get_key
)
get_grant_table
,
(
hash_free_key
)
free_grant_table
,
0
);
(
hash_free_key
)
free_grant_table
,
0
);
init_sql_alloc
(
&
memex
,
ACL_ALLOC_BLOCK_SIZE
,
0
);
init_sql_alloc
(
&
memex
,
ACL_ALLOC_BLOCK_SIZE
,
0
);
...
@@ -3206,7 +3207,7 @@ int mysql_show_grants(THD *thd,LEX_USER *lex_user)
...
@@ -3206,7 +3207,7 @@ int mysql_show_grants(THD *thd,LEX_USER *lex_user)
if
(
!
(
host
=
acl_user
->
host
.
hostname
))
if
(
!
(
host
=
acl_user
->
host
.
hostname
))
host
=
""
;
host
=
""
;
if
(
!
strcmp
(
lex_user
->
user
.
str
,
user
)
&&
if
(
!
strcmp
(
lex_user
->
user
.
str
,
user
)
&&
!
my_strcasecmp
(
&
my_charset_latin1
,
lex_user
->
host
.
str
,
host
))
!
my_strcasecmp
(
system_charset_info
,
lex_user
->
host
.
str
,
host
))
break
;
break
;
}
}
if
(
counter
==
acl_users
.
elements
)
if
(
counter
==
acl_users
.
elements
)
...
@@ -3340,7 +3341,7 @@ int mysql_show_grants(THD *thd,LEX_USER *lex_user)
...
@@ -3340,7 +3341,7 @@ int mysql_show_grants(THD *thd,LEX_USER *lex_user)
host
=
""
;
host
=
""
;
if
(
!
strcmp
(
lex_user
->
user
.
str
,
user
)
&&
if
(
!
strcmp
(
lex_user
->
user
.
str
,
user
)
&&
!
my_strcasecmp
(
&
my_charset_latin1
,
lex_user
->
host
.
str
,
host
))
!
my_strcasecmp
(
system_charset_info
,
lex_user
->
host
.
str
,
host
))
{
{
want_access
=
acl_db
->
access
;
want_access
=
acl_db
->
access
;
if
(
want_access
)
if
(
want_access
)
...
@@ -3400,7 +3401,7 @@ int mysql_show_grants(THD *thd,LEX_USER *lex_user)
...
@@ -3400,7 +3401,7 @@ int mysql_show_grants(THD *thd,LEX_USER *lex_user)
user
=
""
;
user
=
""
;
if
(
!
strcmp
(
lex_user
->
user
.
str
,
user
)
&&
if
(
!
strcmp
(
lex_user
->
user
.
str
,
user
)
&&
!
my_strcasecmp
(
&
my_charset_latin1
,
lex_user
->
host
.
str
,
!
my_strcasecmp
(
system_charset_info
,
lex_user
->
host
.
str
,
grant_table
->
host
.
hostname
))
grant_table
->
host
.
hostname
))
{
{
ulong
table_access
=
grant_table
->
privs
;
ulong
table_access
=
grant_table
->
privs
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment