mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-25 18:38:00 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			61 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| ** Setup **
 | |
| SET @global_automatic_sp_privileges = @@GLOBAL.automatic_sp_privileges;
 | |
| CREATE TABLE t1 (a varchar(200));
 | |
| INSERT INTO t1 VALUES('Procedure Executed.');
 | |
| CREATE USER 'userTest'@'localhost';
 | |
| CREATE USER 'userTest1'@'localhost';
 | |
| connection default;
 | |
| SET GLOBAL automatic_sp_privileges = TRUE;
 | |
| connect  conUser,localhost,userTest,,;
 | |
| connection conUser;
 | |
| CREATE PROCEDURE testProc ()
 | |
| BEGIN
 | |
| SELECT * FROM t1;
 | |
| END;|
 | |
| CALL testProc();
 | |
| a
 | |
| Procedure Executed.
 | |
| Expecting SELECT executed
 | |
| connection default;
 | |
| SET GLOBAL automatic_sp_privileges = FALSE;
 | |
| connect  conUser1,localhost,userTest1,,;
 | |
| connection conUser1;
 | |
| CREATE PROCEDURE testProc1 ()
 | |
| BEGIN
 | |
| SELECT * FROM t1;
 | |
| END;|
 | |
| 
 | |
| Expected error access denied
 | |
| CALL testProc1();
 | |
| ERROR 42000: execute command denied to user 'userTest1'@'localhost' for routine 'test.testProc1'
 | |
| 
 | |
| Expected error access denied
 | |
| ALTER PROCEDURE testProc1 COMMENT 'My Comment';
 | |
| ERROR 42000: alter routine command denied to user 'userTest1'@'localhost' for routine 'test.testProc1'
 | |
| 
 | |
| Expected error access denied
 | |
| DROP PROCEDURE testProc1;
 | |
| ERROR 42000: alter routine command denied to user 'userTest1'@'localhost' for routine 'test.testProc1'
 | |
| connection default;
 | |
| GRANT EXECUTE, ALTER ROUTINE ON PROCEDURE testProc1 TO 'userTest1'@'localhost';
 | |
| connection conUser1;
 | |
| CALL testProc1();
 | |
| a
 | |
| Procedure Executed.
 | |
| Expecting seelect executed
 | |
| ALTER PROCEDURE testProc1 COMMENT 'My Comment';
 | |
| 
 | |
| ** Cleanup **
 | |
| connection default;
 | |
| disconnect conUser;
 | |
| disconnect conUser1;
 | |
| SET GLOBAL automatic_sp_privileges = @global_automatic_sp_privileges;
 | |
| REVOKE EXECUTE, ALTER ROUTINE ON PROCEDURE testProc FROM 'userTest'@'localhost';
 | |
| REVOKE ALL PRIVILEGES, GRANT OPTION FROM 'userTest'@'localhost';
 | |
| REVOKE ALL PRIVILEGES, GRANT OPTION FROM 'userTest1'@'localhost';
 | |
| DROP PROCEDURE testProc;
 | |
| DROP PROCEDURE testProc1;
 | |
| DROP USER 'userTest'@'localhost';
 | |
| DROP USER 'userTest1'@'localhost';
 | |
| DROP TABLE t1;
 |