You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
744 lines
28 KiB
744 lines
28 KiB
create table mysql.db_copy as select * from mysql.db;
|
|
delete from mysql.db where host='%';
|
|
flush privileges;
|
|
set @orig_sql_mode_session= @@SESSION.sql_mode;
|
|
set @orig_sql_mode_global= @@GLOBAL.sql_mode;
|
|
set @orig_partial_revokes = @@global.partial_revokes;
|
|
SET GLOBAL partial_revokes= OFF;
|
|
use test;
|
|
create user user1@localhost;
|
|
create user ''@'%';
|
|
create user user1;
|
|
delete from mysql.db;
|
|
insert into mysql.db select * from mysql.db_copy;
|
|
flush privileges;
|
|
drop table if exists t1;
|
|
drop database if exists db1_secret;
|
|
create database db1_secret;
|
|
create procedure db1_secret.dummy() begin end;
|
|
drop procedure db1_secret.dummy;
|
|
use db1_secret;
|
|
create table t1 ( u varchar(64), i int );
|
|
insert into t1 values('test', 0);
|
|
create procedure stamp(i int)
|
|
insert into db1_secret.t1 values (user(), i);
|
|
show procedure status like 'stamp';
|
|
Db Name Type Definer Modified Created Security_type Comment character_set_client collation_connection Database Collation
|
|
db1_secret stamp PROCEDURE root@localhost 0000-00-00 00:00:00 0000-00-00 00:00:00 DEFINER utf8mb4 utf8mb4_0900_ai_ci utf8mb4_0900_ai_ci
|
|
create function db() returns varchar(64)
|
|
begin
|
|
declare v varchar(64);
|
|
select u into v from t1 limit 1;
|
|
return v;
|
|
end|
|
|
show function status like 'db';
|
|
Db Name Type Definer Modified Created Security_type Comment character_set_client collation_connection Database Collation
|
|
db1_secret db FUNCTION root@localhost 0000-00-00 00:00:00 0000-00-00 00:00:00 DEFINER utf8mb4 utf8mb4_0900_ai_ci utf8mb4_0900_ai_ci
|
|
call stamp(1);
|
|
select * from t1;
|
|
u i
|
|
test 0
|
|
root@localhost 1
|
|
select db();
|
|
db()
|
|
test
|
|
grant execute on procedure db1_secret.stamp to user1@'%';
|
|
grant execute on function db1_secret.db to user1@'%';
|
|
grant execute on procedure db1_secret.stamp to ''@'%';
|
|
grant execute on function db1_secret.db to ''@'%';
|
|
call db1_secret.stamp(2);
|
|
select db1_secret.db();
|
|
db1_secret.db()
|
|
test
|
|
select * from db1_secret.t1;
|
|
ERROR 42000: SELECT command denied to user 'user1'@'localhost' for table 't1'
|
|
create procedure db1_secret.dummy() begin end;
|
|
ERROR 42000: Access denied for user 'user1'@'localhost' to database 'db1_secret'
|
|
drop procedure db1_secret.dummy;
|
|
ERROR 42000: alter routine command denied to user 'user1'@'localhost' for routine 'db1_secret.dummy'
|
|
drop procedure db1_secret.stamp;
|
|
ERROR 42000: alter routine command denied to user 'user1'@'localhost' for routine 'db1_secret.stamp'
|
|
drop function db1_secret.db;
|
|
ERROR 42000: alter routine command denied to user 'user1'@'localhost' for routine 'db1_secret.db'
|
|
call db1_secret.stamp(3);
|
|
select db1_secret.db();
|
|
db1_secret.db()
|
|
test
|
|
select * from db1_secret.t1;
|
|
ERROR 42000: SELECT command denied to user ''@'localhost' for table 't1'
|
|
create procedure db1_secret.dummy() begin end;
|
|
ERROR 42000: Access denied for user ''@'%' to database 'db1_secret'
|
|
drop procedure db1_secret.dummy;
|
|
ERROR 42000: alter routine command denied to user ''@'%' for routine 'db1_secret.dummy'
|
|
drop procedure db1_secret.stamp;
|
|
ERROR 42000: alter routine command denied to user ''@'%' for routine 'db1_secret.stamp'
|
|
drop function db1_secret.db;
|
|
ERROR 42000: alter routine command denied to user ''@'%' for routine 'db1_secret.db'
|
|
select * from t1;
|
|
u i
|
|
test 0
|
|
root@localhost 1
|
|
user1@localhost 2
|
|
anon@localhost 3
|
|
alter procedure stamp sql security invoker;
|
|
show procedure status like 'stamp';
|
|
Db Name Type Definer Modified Created Security_type Comment character_set_client collation_connection Database Collation
|
|
db1_secret stamp PROCEDURE root@localhost 0000-00-00 00:00:00 0000-00-00 00:00:00 INVOKER utf8mb4 utf8mb4_0900_ai_ci utf8mb4_0900_ai_ci
|
|
alter function db sql security invoker;
|
|
show function status like 'db';
|
|
Db Name Type Definer Modified Created Security_type Comment character_set_client collation_connection Database Collation
|
|
db1_secret db FUNCTION root@localhost 0000-00-00 00:00:00 0000-00-00 00:00:00 INVOKER utf8mb4 utf8mb4_0900_ai_ci utf8mb4_0900_ai_ci
|
|
call stamp(4);
|
|
select * from t1;
|
|
u i
|
|
test 0
|
|
root@localhost 1
|
|
user1@localhost 2
|
|
anon@localhost 3
|
|
root@localhost 4
|
|
select db();
|
|
db()
|
|
test
|
|
call db1_secret.stamp(5);
|
|
ERROR 42000: INSERT command denied to user 'user1'@'localhost' for table 't1'
|
|
select db1_secret.db();
|
|
ERROR 42000: SELECT command denied to user 'user1'@'localhost' for table 't1'
|
|
call db1_secret.stamp(6);
|
|
ERROR 42000: INSERT command denied to user ''@'localhost' for table 't1'
|
|
select db1_secret.db();
|
|
ERROR 42000: SELECT command denied to user ''@'localhost' for table 't1'
|
|
drop database if exists db2;
|
|
create database db2;
|
|
use db2;
|
|
create table t2 (s1 int);
|
|
insert into t2 values (0);
|
|
create user user2@localhost;
|
|
grant usage on db2.* to user1@localhost;
|
|
grant select on db2.* to user1@localhost;
|
|
grant usage on db2.* to user2@localhost;
|
|
grant select,insert,update,delete,create routine on db2.* to user2@localhost;
|
|
grant create routine on db2.* to user1@localhost;
|
|
flush privileges;
|
|
use db2;
|
|
create procedure p () insert into t2 values (1);
|
|
call p();
|
|
ERROR 42000: INSERT command denied to user 'user1'@'localhost' for table 't2'
|
|
use db2;
|
|
call p();
|
|
ERROR 42000: execute command denied to user 'user2'@'localhost' for routine 'db2.p'
|
|
select * from t2;
|
|
s1
|
|
0
|
|
create procedure q () insert into t2 values (2);
|
|
call q();
|
|
select * from t2;
|
|
s1
|
|
0
|
|
2
|
|
grant usage on procedure db2.q to user2@localhost with grant option;
|
|
grant execute on procedure db2.q to user1@localhost;
|
|
use db2;
|
|
call q();
|
|
select * from t2;
|
|
s1
|
|
0
|
|
2
|
|
2
|
|
alter procedure p modifies sql data;
|
|
drop procedure p;
|
|
alter procedure q modifies sql data;
|
|
ERROR 42000: alter routine command denied to user 'user1'@'localhost' for routine 'db2.q'
|
|
drop procedure q;
|
|
ERROR 42000: alter routine command denied to user 'user1'@'localhost' for routine 'db2.q'
|
|
use db2;
|
|
alter procedure q modifies sql data;
|
|
drop procedure q;
|
|
use test;
|
|
select routine_type, routine_schema, routine_name
|
|
from information_schema.routines where routine_schema like 'db%'
|
|
order by routine_type, routine_name;
|
|
ROUTINE_TYPE ROUTINE_SCHEMA ROUTINE_NAME
|
|
FUNCTION db1_secret db
|
|
PROCEDURE db1_secret stamp
|
|
drop database db1_secret;
|
|
drop database db2;
|
|
select routine_type, routine_schema, routine_name
|
|
from information_schema.routines where routine_schema like 'db%';
|
|
ROUTINE_TYPE ROUTINE_SCHEMA ROUTINE_NAME
|
|
delete from mysql.user where user='user1' or user='user2';
|
|
delete from mysql.user where user='' and host='%';
|
|
delete from mysql.procs_priv where user='user1' or user='user2';
|
|
delete from mysql.procs_priv where user='' and host='%';
|
|
delete from mysql.db where user='user1' or user='user2';
|
|
flush privileges;
|
|
create user usera@localhost;
|
|
create user userb@localhost;
|
|
create user userc@localhost;
|
|
create database sptest;
|
|
create table t1 ( u varchar(64), i int );
|
|
create procedure sptest.p1(i int) insert into test.t1 values (user(), i);
|
|
grant insert on t1 to usera@localhost;
|
|
grant execute on procedure sptest.p1 to usera@localhost;
|
|
show grants for usera@localhost;
|
|
Grants for usera@localhost
|
|
GRANT USAGE ON *.* TO `usera`@`localhost`
|
|
GRANT INSERT ON `test`.`t1` TO `usera`@`localhost`
|
|
GRANT EXECUTE ON PROCEDURE `sptest`.`p1` TO `usera`@`localhost`
|
|
grant execute on procedure sptest.p1 to userc@localhost with grant option;
|
|
show grants for userc@localhost;
|
|
Grants for userc@localhost
|
|
GRANT USAGE ON *.* TO `userc`@`localhost`
|
|
GRANT EXECUTE ON PROCEDURE `sptest`.`p1` TO `userc`@`localhost` WITH GRANT OPTION
|
|
call sptest.p1(1);
|
|
grant execute on procedure sptest.p1 to userb@localhost;
|
|
ERROR 42000: grant command denied to user 'usera'@'localhost' for routine 'sptest.p1'
|
|
drop procedure sptest.p1;
|
|
ERROR 42000: alter routine command denied to user 'usera'@'localhost' for routine 'sptest.p1'
|
|
call sptest.p1(2);
|
|
ERROR 42000: execute command denied to user 'userb'@'localhost' for routine 'sptest.p1'
|
|
grant execute on procedure sptest.p1 to userb@localhost;
|
|
ERROR 42000: execute command denied to user 'userb'@'localhost' for routine 'sptest.p1'
|
|
drop procedure sptest.p1;
|
|
ERROR 42000: alter routine command denied to user 'userb'@'localhost' for routine 'sptest.p1'
|
|
call sptest.p1(3);
|
|
grant execute on procedure sptest.p1 to userb@localhost;
|
|
drop procedure sptest.p1;
|
|
ERROR 42000: alter routine command denied to user 'userc'@'localhost' for routine 'sptest.p1'
|
|
call sptest.p1(4);
|
|
grant execute on procedure sptest.p1 to userb@localhost;
|
|
ERROR 42000: grant command denied to user 'userb'@'localhost' for routine 'sptest.p1'
|
|
drop procedure sptest.p1;
|
|
ERROR 42000: alter routine command denied to user 'userb'@'localhost' for routine 'sptest.p1'
|
|
select * from t1;
|
|
u i
|
|
usera@localhost 1
|
|
userc@localhost 3
|
|
userb@localhost 4
|
|
grant all privileges on procedure sptest.p1 to userc@localhost;
|
|
show grants for userc@localhost;
|
|
Grants for userc@localhost
|
|
GRANT USAGE ON *.* TO `userc`@`localhost`
|
|
GRANT EXECUTE, ALTER ROUTINE ON PROCEDURE `sptest`.`p1` TO `userc`@`localhost` WITH GRANT OPTION
|
|
show grants for userb@localhost;
|
|
Grants for userb@localhost
|
|
GRANT USAGE ON *.* TO `userb`@`localhost`
|
|
GRANT EXECUTE ON PROCEDURE `sptest`.`p1` TO `userb`@`localhost`
|
|
revoke all privileges on procedure sptest.p1 from userb@localhost;
|
|
show grants for userb@localhost;
|
|
Grants for userb@localhost
|
|
GRANT USAGE ON *.* TO `userb`@`localhost`
|
|
use test;
|
|
drop database sptest;
|
|
delete from mysql.user where user='usera' or user='userb' or user='userc';
|
|
delete from mysql.procs_priv where user='usera' or user='userb' or user='userc';
|
|
delete from mysql.tables_priv where user='usera';
|
|
flush privileges;
|
|
drop table t1;
|
|
create user user1@localhost;
|
|
drop function if exists bug_9503;
|
|
create database mysqltest//
|
|
use mysqltest//
|
|
create table t1 (s1 int)//
|
|
grant select on t1 to user1@localhost//
|
|
create function bug_9503 () returns int sql security invoker begin declare v int;
|
|
select min(s1) into v from t1; return v; end//
|
|
use mysqltest;
|
|
select bug_9503();
|
|
ERROR 42000: execute command denied to user 'user1'@'localhost' for routine 'mysqltest.bug_9503'
|
|
grant execute on function bug_9503 to user1@localhost;
|
|
do 1;
|
|
use test;
|
|
REVOKE ALL PRIVILEGES, GRANT OPTION FROM user1@localhost;
|
|
drop function bug_9503;
|
|
use test;
|
|
drop database mysqltest;
|
|
use test;
|
|
select current_user();
|
|
current_user()
|
|
root@localhost
|
|
select user();
|
|
user()
|
|
root@localhost
|
|
create procedure bug7291_0 () sql security invoker select current_user(), user();
|
|
create procedure bug7291_1 () sql security definer call bug7291_0();
|
|
create procedure bug7291_2 () sql security invoker call bug7291_0();
|
|
grant execute on procedure bug7291_0 to user1@localhost;
|
|
grant execute on procedure bug7291_1 to user1@localhost;
|
|
grant execute on procedure bug7291_2 to user1@localhost;
|
|
call bug7291_2();
|
|
current_user() user()
|
|
user1@localhost user1@localhost
|
|
call bug7291_1();
|
|
current_user() user()
|
|
root@localhost user1@localhost
|
|
drop procedure bug7291_1;
|
|
drop procedure bug7291_2;
|
|
drop procedure bug7291_0;
|
|
REVOKE ALL PRIVILEGES, GRANT OPTION FROM user1@localhost;
|
|
drop user user1@localhost;
|
|
drop database if exists mysqltest_1;
|
|
create database mysqltest_1;
|
|
create procedure mysqltest_1.p1()
|
|
begin
|
|
select 1 from dual;
|
|
end//
|
|
create user mysqltest_1@localhost;
|
|
call mysqltest_1.p1();
|
|
ERROR 42000: execute command denied to user 'mysqltest_1'@'localhost' for routine 'mysqltest_1.p1'
|
|
call mysqltest_1.p1();
|
|
ERROR 42000: execute command denied to user 'mysqltest_1'@'localhost' for routine 'mysqltest_1.p1'
|
|
drop procedure mysqltest_1.p1;
|
|
drop database mysqltest_1;
|
|
revoke usage on *.* from mysqltest_1@localhost;
|
|
drop user mysqltest_1@localhost;
|
|
drop function if exists bug12812|
|
|
create function bug12812() returns char(2)
|
|
begin
|
|
return 'ok';
|
|
end;
|
|
create user user_bug12812@localhost IDENTIFIED BY 'ABC'|
|
|
SELECT test.bug12812()|
|
|
ERROR 42000: execute command denied to user 'user_bug12812'@'localhost' for routine 'test.bug12812'
|
|
CREATE VIEW v1 AS SELECT test.bug12812()|
|
|
ERROR 42000: execute command denied to user 'user_bug12812'@'localhost' for routine 'test.bug12812'
|
|
DROP USER user_bug12812@localhost|
|
|
drop function bug12812|
|
|
create database db_bug14834;
|
|
create user user1_bug14834@localhost identified by '';
|
|
grant all on `db\_bug14834`.* to user1_bug14834@localhost;
|
|
create user user2_bug14834@localhost identified by '';
|
|
grant all on `db\_bug14834`.* to user2_bug14834@localhost;
|
|
create user user3_bug14834@localhost identified by '';
|
|
grant all on `db__ug14834`.* to user3_bug14834@localhost;
|
|
create procedure p_bug14834() select user(), current_user();
|
|
call p_bug14834();
|
|
user() current_user()
|
|
user1_bug14834@localhost user1_bug14834@localhost
|
|
call p_bug14834();
|
|
user() current_user()
|
|
user2_bug14834@localhost user1_bug14834@localhost
|
|
call p_bug14834();
|
|
user() current_user()
|
|
user3_bug14834@localhost user1_bug14834@localhost
|
|
drop user user1_bug14834@localhost;
|
|
drop user user2_bug14834@localhost;
|
|
drop user user3_bug14834@localhost;
|
|
drop database db_bug14834;
|
|
create database db_bug14533;
|
|
use db_bug14533;
|
|
create table t1 (id int);
|
|
create user user_bug14533@localhost identified by '';
|
|
create procedure bug14533_1()
|
|
sql security definer
|
|
desc db_bug14533.t1;
|
|
create procedure bug14533_2()
|
|
sql security definer
|
|
select * from db_bug14533.t1;
|
|
grant execute on procedure db_bug14533.bug14533_1 to user_bug14533@localhost;
|
|
grant execute on procedure db_bug14533.bug14533_2 to user_bug14533@localhost;
|
|
call db_bug14533.bug14533_1();
|
|
Field Type Null Key Default Extra
|
|
id int(11) YES NULL
|
|
call db_bug14533.bug14533_2();
|
|
id
|
|
desc db_bug14533.t1;
|
|
ERROR 42000: SELECT command denied to user 'user_bug14533'@'localhost' for table 't1'
|
|
select * from db_bug14533.t1;
|
|
ERROR 42000: SELECT command denied to user 'user_bug14533'@'localhost' for table 't1'
|
|
drop user user_bug14533@localhost;
|
|
drop database db_bug14533;
|
|
|
|
---> connection: root
|
|
DROP DATABASE IF EXISTS mysqltest;
|
|
CREATE DATABASE mysqltest;
|
|
CREATE USER mysqltest_1@localhost;
|
|
GRANT ALL PRIVILEGES ON mysqltest.* TO mysqltest_1@localhost;
|
|
CREATE USER mysqltest_2@localhost;
|
|
GRANT SUPER ON *.* TO mysqltest_2@localhost;
|
|
Warnings:
|
|
Warning 1287 The SUPER privilege identifier is deprecated
|
|
GRANT ALL PRIVILEGES ON mysqltest.* TO mysqltest_2@localhost;
|
|
|
|
---> connection: mysqltest_2_con
|
|
USE mysqltest;
|
|
CREATE PROCEDURE wl2897_p1() SELECT 1;
|
|
CREATE FUNCTION wl2897_f1() RETURNS INT RETURN 1;
|
|
|
|
---> connection: mysqltest_1_con
|
|
USE mysqltest;
|
|
CREATE DEFINER=root@localhost PROCEDURE wl2897_p2() SELECT 2;
|
|
ERROR 42000: Access denied; you need (at least one of) the SUPER or SET_USER_ID privilege(s) for this operation
|
|
CREATE DEFINER=root@localhost FUNCTION wl2897_f2() RETURNS INT RETURN 2;
|
|
ERROR 42000: Access denied; you need (at least one of) the SUPER or SET_USER_ID privilege(s) for this operation
|
|
|
|
---> connection: mysqltest_2_con
|
|
use mysqltest;
|
|
CREATE DEFINER='a @ b @ c'@localhost PROCEDURE wl2897_p3() SELECT 3;
|
|
Warnings:
|
|
Note 1449 The user specified as a definer ('a @ b @ c'@'localhost') does not exist
|
|
CREATE DEFINER='a @ b @ c'@localhost FUNCTION wl2897_f3() RETURNS INT RETURN 3;
|
|
Warnings:
|
|
Note 1449 The user specified as a definer ('a @ b @ c'@'localhost') does not exist
|
|
|
|
---> connection: con1root
|
|
USE mysqltest;
|
|
SHOW CREATE PROCEDURE wl2897_p1;
|
|
Procedure sql_mode Create Procedure character_set_client collation_connection Database Collation
|
|
wl2897_p1 ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION CREATE DEFINER=`mysqltest_2`@`localhost` PROCEDURE `wl2897_p1`()
|
|
SELECT 1 utf8mb4 utf8mb4_0900_ai_ci utf8mb4_0900_ai_ci
|
|
SHOW CREATE PROCEDURE wl2897_p3;
|
|
Procedure sql_mode Create Procedure character_set_client collation_connection Database Collation
|
|
wl2897_p3 ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION CREATE DEFINER=`a @ b @ c`@`localhost` PROCEDURE `wl2897_p3`()
|
|
SELECT 3 utf8mb4 utf8mb4_0900_ai_ci utf8mb4_0900_ai_ci
|
|
SHOW CREATE FUNCTION wl2897_f1;
|
|
Function sql_mode Create Function character_set_client collation_connection Database Collation
|
|
wl2897_f1 ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION CREATE DEFINER=`mysqltest_2`@`localhost` FUNCTION `wl2897_f1`() RETURNS int(11)
|
|
RETURN 1 utf8mb4 utf8mb4_0900_ai_ci utf8mb4_0900_ai_ci
|
|
SHOW CREATE FUNCTION wl2897_f3;
|
|
Function sql_mode Create Function character_set_client collation_connection Database Collation
|
|
wl2897_f3 ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION CREATE DEFINER=`a @ b @ c`@`localhost` FUNCTION `wl2897_f3`() RETURNS int(11)
|
|
RETURN 3 utf8mb4 utf8mb4_0900_ai_ci utf8mb4_0900_ai_ci
|
|
DROP USER mysqltest_1@localhost;
|
|
DROP USER mysqltest_2@localhost;
|
|
DROP DATABASE mysqltest;
|
|
|
|
---> connection: root
|
|
DROP DATABASE IF EXISTS mysqltest;
|
|
CREATE DATABASE mysqltest;
|
|
CREATE USER mysqltest_1@localhost;
|
|
GRANT ALL PRIVILEGES ON mysqltest.* TO mysqltest_1@localhost;
|
|
CREATE USER mysqltest_2@localhost;
|
|
GRANT ALL PRIVILEGES ON mysqltest.* TO mysqltest_2@localhost;
|
|
|
|
---> connection: mysqltest_1_con
|
|
USE mysqltest;
|
|
CREATE PROCEDURE bug13198_p1()
|
|
SELECT 1;
|
|
CREATE FUNCTION bug13198_f1() RETURNS INT
|
|
RETURN 1;
|
|
CALL bug13198_p1();
|
|
1
|
|
1
|
|
SELECT bug13198_f1();
|
|
bug13198_f1()
|
|
1
|
|
|
|
---> connection: mysqltest_2_con
|
|
USE mysqltest;
|
|
CALL bug13198_p1();
|
|
1
|
|
1
|
|
SELECT bug13198_f1();
|
|
bug13198_f1()
|
|
1
|
|
|
|
---> connection: root
|
|
DROP USER mysqltest_1@localhost;
|
|
|
|
---> connection: mysqltest_2_con
|
|
USE mysqltest;
|
|
CALL bug13198_p1();
|
|
ERROR HY000: The user specified as a definer ('mysqltest_1'@'localhost') does not exist
|
|
SELECT bug13198_f1();
|
|
ERROR HY000: The user specified as a definer ('mysqltest_1'@'localhost') does not exist
|
|
|
|
---> connection: root
|
|
DROP USER mysqltest_2@localhost;
|
|
DROP DATABASE mysqltest;
|
|
CREATE USER user19857@localhost IDENTIFIED BY 'meow';
|
|
GRANT SELECT, INSERT, UPDATE, DELETE, CREATE ROUTINE, ALTER ROUTINE ON test.* TO
|
|
user19857@localhost;
|
|
SELECT Host,User FROM mysql.user WHERE User='user19857';
|
|
Host User
|
|
localhost user19857
|
|
|
|
---> connection: mysqltest_2_con
|
|
USE test;
|
|
CREATE PROCEDURE sp19857() DETERMINISTIC
|
|
BEGIN
|
|
DECLARE a INT;
|
|
SET a=1;
|
|
SELECT a;
|
|
END //
|
|
SHOW CREATE PROCEDURE test.sp19857;
|
|
Procedure sql_mode Create Procedure character_set_client collation_connection Database Collation
|
|
sp19857 ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION CREATE DEFINER=`user19857`@`localhost` PROCEDURE `sp19857`()
|
|
DETERMINISTIC
|
|
BEGIN
|
|
DECLARE a INT;
|
|
SET a=1;
|
|
SELECT a;
|
|
END utf8mb4 utf8mb4_0900_ai_ci utf8mb4_0900_ai_ci
|
|
DROP PROCEDURE IF EXISTS test.sp19857;
|
|
|
|
---> connection: root
|
|
SELECT Host,User FROM mysql.user WHERE User='user19857';
|
|
Host User
|
|
localhost user19857
|
|
DROP USER user19857@localhost;
|
|
use test;
|
|
DROP TABLE IF EXISTS t1;
|
|
DROP VIEW IF EXISTS v1;
|
|
DROP FUNCTION IF EXISTS f_suid;
|
|
DROP PROCEDURE IF EXISTS p_suid;
|
|
DROP FUNCTION IF EXISTS f_evil;
|
|
DELETE FROM mysql.user WHERE user LIKE 'mysqltest\_%';
|
|
DELETE FROM mysql.db WHERE user LIKE 'mysqltest\_%';
|
|
DELETE FROM mysql.tables_priv WHERE user LIKE 'mysqltest\_%';
|
|
DELETE FROM mysql.columns_priv WHERE user LIKE 'mysqltest\_%';
|
|
FLUSH PRIVILEGES;
|
|
CREATE TABLE t1 (i INT);
|
|
CREATE FUNCTION f_suid(i INT) RETURNS INT SQL SECURITY DEFINER RETURN 0;
|
|
CREATE PROCEDURE p_suid(IN i INT) SQL SECURITY DEFINER SET @c:= 0;
|
|
CREATE USER mysqltest_u1@localhost;
|
|
GRANT EXECUTE ON test.* TO mysqltest_u1@localhost;
|
|
CREATE DEFINER=mysqltest_u1@localhost FUNCTION f_evil () RETURNS INT
|
|
SQL SECURITY INVOKER
|
|
BEGIN
|
|
SET @a:= CURRENT_USER();
|
|
SET @b:= (SELECT COUNT(*) FROM t1);
|
|
RETURN @b;
|
|
END|
|
|
CREATE SQL SECURITY INVOKER VIEW v1 AS SELECT f_evil();
|
|
SELECT COUNT(*) FROM t1;
|
|
ERROR 42000: SELECT command denied to user 'mysqltest_u1'@'localhost' for table 't1'
|
|
SELECT f_evil();
|
|
ERROR 42000: SELECT command denied to user 'mysqltest_u1'@'localhost' for table 't1'
|
|
SELECT @a, @b;
|
|
@a @b
|
|
mysqltest_u1@localhost NULL
|
|
SELECT f_suid(f_evil());
|
|
ERROR 42000: SELECT command denied to user 'mysqltest_u1'@'localhost' for table 't1'
|
|
SELECT @a, @b;
|
|
@a @b
|
|
mysqltest_u1@localhost NULL
|
|
CALL p_suid(f_evil());
|
|
ERROR 42000: SELECT command denied to user 'mysqltest_u1'@'localhost' for table 't1'
|
|
SELECT @a, @b;
|
|
@a @b
|
|
mysqltest_u1@localhost NULL
|
|
SELECT * FROM v1;
|
|
ERROR 42000: SELECT command denied to user 'mysqltest_u1'@'localhost' for table 'v1'
|
|
SELECT @a, @b;
|
|
@a @b
|
|
mysqltest_u1@localhost NULL
|
|
DROP VIEW v1;
|
|
DROP FUNCTION f_evil;
|
|
DROP USER mysqltest_u1@localhost;
|
|
DROP PROCEDURE p_suid;
|
|
DROP FUNCTION f_suid;
|
|
DROP TABLE t1;
|
|
#
|
|
# Bug #48872 : Privileges for stored functions ignored if function name
|
|
# is mixed case
|
|
#
|
|
CREATE DATABASE B48872;
|
|
USE B48872;
|
|
CREATE TABLE `TestTab` (id INT);
|
|
INSERT INTO `TestTab` VALUES (1),(2);
|
|
CREATE FUNCTION `f_Test`() RETURNS INT RETURN 123;
|
|
CREATE FUNCTION `f_Test_denied`() RETURNS INT RETURN 123;
|
|
CREATE USER 'tester';
|
|
CREATE USER 'Tester';
|
|
GRANT SELECT ON TABLE `TestTab` TO 'tester';
|
|
GRANT EXECUTE ON FUNCTION `f_Test` TO 'tester';
|
|
GRANT EXECUTE ON FUNCTION `f_Test_denied` TO 'Tester';
|
|
SELECT f_Test();
|
|
f_Test()
|
|
123
|
|
SELECT * FROM TestTab;
|
|
id
|
|
1
|
|
2
|
|
SELECT * FROM TestTab;
|
|
id
|
|
1
|
|
2
|
|
SELECT `f_Test`();
|
|
`f_Test`()
|
|
123
|
|
SELECT `F_TEST`();
|
|
`F_TEST`()
|
|
123
|
|
SELECT f_Test();
|
|
f_Test()
|
|
123
|
|
SELECT F_TEST();
|
|
F_TEST()
|
|
123
|
|
SELECT * FROM TestTab;
|
|
SELECT `f_Test`();
|
|
SELECT `F_TEST`();
|
|
SELECT f_Test();
|
|
SELECT F_TEST();
|
|
SELECT `f_Test_denied`();
|
|
`f_Test_denied`()
|
|
123
|
|
SELECT `F_TEST_DENIED`();
|
|
`F_TEST_DENIED`()
|
|
123
|
|
DROP TABLE `TestTab`;
|
|
DROP FUNCTION `f_Test`;
|
|
DROP FUNCTION `f_Test_denied`;
|
|
USE test;
|
|
DROP USER 'tester';
|
|
DROP USER 'Tester';
|
|
DROP DATABASE B48872;
|
|
End of 5.0 tests.
|
|
#
|
|
# Test for bug#57061 "User without privilege on routine can discover
|
|
# its existence."
|
|
#
|
|
drop database if exists mysqltest_db;
|
|
create database mysqltest_db;
|
|
# Create user with no privileges on mysqltest_db database.
|
|
create user bug57061_user@localhost;
|
|
create function mysqltest_db.f1() returns int return 0;
|
|
create procedure mysqltest_db.p1() begin end;
|
|
# Connect as user 'bug57061_user@localhost'
|
|
# Attempt to drop routine on which user doesn't have privileges
|
|
# should result in the same 'access denied' type of error whether
|
|
# routine exists or not.
|
|
drop function if exists mysqltest_db.f_does_not_exist;
|
|
ERROR 42000: alter routine command denied to user 'bug57061_user'@'localhost' for routine 'mysqltest_db.f_does_not_exist'
|
|
drop procedure if exists mysqltest_db.p_does_not_exist;
|
|
ERROR 42000: alter routine command denied to user 'bug57061_user'@'localhost' for routine 'mysqltest_db.p_does_not_exist'
|
|
drop function if exists mysqltest_db.f1;
|
|
ERROR 42000: alter routine command denied to user 'bug57061_user'@'localhost' for routine 'mysqltest_db.f1'
|
|
drop procedure if exists mysqltest_db.p1;
|
|
ERROR 42000: alter routine command denied to user 'bug57061_user'@'localhost' for routine 'mysqltest_db.p1'
|
|
# Connection 'default'.
|
|
drop user bug57061_user@localhost;
|
|
drop database mysqltest_db;
|
|
#
|
|
# Test for bug#12602983 - User without privilege on routine can discover
|
|
# its existence by executing "select non_existing_func();" or by
|
|
# "call non_existing_proc()";
|
|
#
|
|
drop database if exists mysqltest_db;
|
|
create database mysqltest_db;
|
|
create function mysqltest_db.f1() returns int return 0;
|
|
create procedure mysqltest_db.p1() begin end;
|
|
# Create user with no privileges on mysqltest_db database.
|
|
create user bug12602983_user@localhost;
|
|
# Connect as user 'bug12602983_user@localhost'
|
|
# Attempt to execute routine on which user doesn't have privileges
|
|
# should result in the same 'access denied' error whether
|
|
# routine exists or not.
|
|
select mysqltest_db.f_does_not_exist();
|
|
ERROR 42000: execute command denied to user 'bug12602983_user'@'localhost' for routine 'mysqltest_db.f_does_not_exist'
|
|
call mysqltest_db.p_does_not_exist();
|
|
ERROR 42000: execute command denied to user 'bug12602983_user'@'localhost' for routine 'mysqltest_db.p_does_not_exist'
|
|
select mysqltest_db.f1();
|
|
ERROR 42000: execute command denied to user 'bug12602983_user'@'localhost' for routine 'mysqltest_db.f1'
|
|
call mysqltest_db.p1();
|
|
ERROR 42000: execute command denied to user 'bug12602983_user'@'localhost' for routine 'mysqltest_db.p1'
|
|
create view bug12602983_v1 as select mysqltest_db.f_does_not_exist();
|
|
ERROR 42000: execute command denied to user 'bug12602983_user'@'localhost' for routine 'mysqltest_db.f_does_not_exist'
|
|
create view bug12602983_v1 as select mysqltest_db.f1();
|
|
ERROR 42000: execute command denied to user 'bug12602983_user'@'localhost' for routine 'mysqltest_db.f1'
|
|
# Connection 'default'.
|
|
drop user bug12602983_user@localhost;
|
|
drop database mysqltest_db;
|
|
#
|
|
# WL#7897 Use DD API for Stored Routines.
|
|
# Test case to verify I_S.ROUTINES and I_S.PARAMETERS result set when
|
|
# user has NO/ROUTINE LEVEL/GLOBAL SELECT Privilege(s).
|
|
#
|
|
CREATE DATABASE mysqltest_db;
|
|
CREATE PROCEDURE mysqltest_db.p1(IN f1 INT) SELECT 1;
|
|
# Create user with no privileges on mysqltest_db database.
|
|
CREATE USER user@localhost;
|
|
# Connect as user 'user@localhost'.
|
|
connect conn1, localhost, user,,;
|
|
# I_S.Routine and I_S.parameters shows empty result set for
|
|
# user@localhost as user does not have any privileges.
|
|
SELECT routine_schema, routine_name, routine_type
|
|
FROM INFORMATION_SCHEMA.ROUTINES WHERE routine_schema = 'mysqltest_db';
|
|
ROUTINE_SCHEMA ROUTINE_NAME ROUTINE_TYPE
|
|
SELECT specific_schema, specific_name, parameter_name
|
|
FROM INFORMATION_SCHEMA.PARAMETERS WHERE specific_schema = 'mysqltest_db';
|
|
SPECIFIC_SCHEMA SPECIFIC_NAME PARAMETER_NAME
|
|
# Grant procedure execute privilege to user@localhost.
|
|
connection default;
|
|
GRANT EXECUTE ON PROCEDURE mysqltest_db.p1 TO user@localhost;
|
|
# I_S.Routine and I_S.parameters shows result set
|
|
# for user@localhost as user has routine level privilege.
|
|
connection conn1;
|
|
SELECT routine_schema, routine_name, routine_type
|
|
FROM INFORMATION_SCHEMA.ROUTINES WHERE routine_schema = 'mysqltest_db';
|
|
ROUTINE_SCHEMA ROUTINE_NAME ROUTINE_TYPE
|
|
mysqltest_db p1 PROCEDURE
|
|
SELECT specific_schema, specific_name, parameter_name
|
|
FROM INFORMATION_SCHEMA.PARAMETERS WHERE specific_schema = 'mysqltest_db';
|
|
SPECIFIC_SCHEMA SPECIFIC_NAME PARAMETER_NAME
|
|
mysqltest_db p1 f1
|
|
# Revoke procedure execute privilege from user@localhost.
|
|
connection default;
|
|
REVOKE EXECUTE ON PROCEDURE mysqltest_db.p1 FROM user@localhost;
|
|
# I_S.Routine and I_S.parameters shows empty result set for
|
|
# user@localhost as user does not have any privileges.
|
|
connection conn1;
|
|
SELECT routine_schema, routine_name, routine_type
|
|
FROM INFORMATION_SCHEMA.ROUTINES WHERE routine_schema = 'mysqltest_db';
|
|
ROUTINE_SCHEMA ROUTINE_NAME ROUTINE_TYPE
|
|
SELECT specific_schema, specific_name, parameter_name
|
|
FROM INFORMATION_SCHEMA.PARAMETERS WHERE specific_schema = 'mysqltest_db';
|
|
SPECIFIC_SCHEMA SPECIFIC_NAME PARAMETER_NAME
|
|
# Grant GLOBAL SELECT privilege to user@localhost.
|
|
connection default;
|
|
GRANT SELECT ON *.* TO user@localhost;
|
|
# I_S.Routine and I_S.parameters shows result set for
|
|
# user@localhost as user has global select privilege.
|
|
connect conn2, localhost, user,,;
|
|
SELECT routine_schema, routine_name, routine_type
|
|
FROM INFORMATION_SCHEMA.ROUTINES WHERE routine_schema = 'mysqltest_db';
|
|
ROUTINE_SCHEMA ROUTINE_NAME ROUTINE_TYPE
|
|
mysqltest_db p1 PROCEDURE
|
|
SELECT specific_schema, specific_name, parameter_name
|
|
FROM INFORMATION_SCHEMA.PARAMETERS WHERE specific_schema = 'mysqltest_db';
|
|
SPECIFIC_SCHEMA SPECIFIC_NAME PARAMETER_NAME
|
|
mysqltest_db p1 f1
|
|
#
|
|
# Wl8131 DYNAMIC PRIVILEGS
|
|
# SET_USER_ID is a replacement for SUPER which enable a user to
|
|
# create a definer routine executing as some other user.
|
|
# This privielge can be used for privilege escalation.
|
|
connection default;
|
|
CREATE USER u1@localhost IDENTIFIED BY 'foo';
|
|
GRANT SYSTEM_USER,SET_USER_ID, EXECUTE ON *.* TO u1@localhost;
|
|
connect con1,localhost,u1,foo,;
|
|
CREATE DEFINER=root@localhost PROCEDURE p1() SELECT current_user();
|
|
CALL p1();
|
|
current_user()
|
|
root@localhost
|
|
SELECT CURRENT_USER();
|
|
CURRENT_USER()
|
|
u1@localhost
|
|
connection default;
|
|
disconnect con1;
|
|
DROP PROCEDURE p1;
|
|
DROP USER u1@localhost;
|
|
connection default;
|
|
disconnect conn1;
|
|
disconnect conn2;
|
|
DROP USER user@localhost;
|
|
DROP DATABASE mysqltest_db;
|
|
#
|
|
# PASSWORD EXPIRATION CHECKED FOR LOCKED ACCOUNTS USED AS SP DEFINERS
|
|
#
|
|
CREATE ROLE r1;
|
|
GRANT EXECUTE, SELECT ON *.* TO r1;
|
|
CREATE DEFINER=r1 PROCEDURE p1() SELECT current_user();
|
|
CALL p1();
|
|
current_user()
|
|
r1@%
|
|
DROP PROCEDURE p1;
|
|
DROP ROLE r1;
|
|
delete from mysql.db;
|
|
insert into mysql.db select * from mysql.db_copy;
|
|
flush privileges;
|
|
drop table mysql.db_copy;
|
|
SET GLOBAL sql_mode= @orig_sql_mode_global;
|
|
SET SESSION sql_mode= @orig_sql_mode_session;
|
|
SET GLOBAL partial_revokes = @orig_partial_revokes;
|
|
|