|
| 1 | +# |
| 2 | +# Testing MYSQL_NO_LOGIN authentication plugin. |
| 3 | +# |
| 4 | +--source include/have_mysql_no_login_plugin.inc |
| 5 | + |
| 6 | +--replace_regex /\.dll/.so/ |
| 7 | +eval INSTALL PLUGIN mysql_no_login SONAME '$MYSQL_NO_LOGIN'; |
| 8 | + |
| 9 | +query_vertical SELECT PLUGIN_NAME, PLUGIN_STATUS, PLUGIN_TYPE, PLUGIN_DESCRIPTION |
| 10 | + FROM INFORMATION_SCHEMA.PLUGINS WHERE PLUGIN_NAME LIKE 'mysql_no_login'; |
| 11 | + |
| 12 | +--disable_query_log |
| 13 | +CREATE DATABASE noauthdb; |
| 14 | +CREATE TABLE noauthdb.t1 (a INT); |
| 15 | +CREATE TABLE noauthdb.t2 (a INT); |
| 16 | +INSERT INTO noauthdb.t1 VALUES (1), (2); |
| 17 | +INSERT INTO noauthdb.t2 VALUES (3), (4); |
| 18 | + |
| 19 | +--echo Creating users noauth, otheruser |
| 20 | +CREATE USER noauth@localhost IDENTIFIED WITH 'mysql_no_login'; |
| 21 | +CREATE USER otheruser@localhost; |
| 22 | +GRANT SELECT, UPDATE, INSERT ON noauthdb.* TO noauth@localhost; |
| 23 | + |
| 24 | +--echo Creating view, procedure, function |
| 25 | +CREATE DEFINER = noauth@localhost SQL SECURITY DEFINER VIEW noauthdb.v1 AS SELECT * FROM noauthdb.t1 WHERE a % 2 = 0; |
| 26 | +CREATE DEFINER = noauth@localhost PROCEDURE noauthdb.p1 () CONTAINS SQL SQL SECURITY DEFINER UPDATE noauthdb.t2 SET a = 5 WHERE a = 3; |
| 27 | +delimiter //; |
| 28 | +CREATE DEFINER = noauth@localhost FUNCTION noauthdb.f1() RETURNS INT CONTAINS SQL SQL SECURITY DEFINER |
| 29 | +BEGIN |
| 30 | +DECLARE outp INT DEFAULT NULL; |
| 31 | +SELECT MAX(a) INTO outp FROM noauthdb.t2; |
| 32 | +RETURN outp; |
| 33 | +END// |
| 34 | +delimiter ;// |
| 35 | + |
| 36 | +GRANT SELECT ON noauthdb.v1 TO otheruser@localhost; |
| 37 | +GRANT EXECUTE ON noauthdb.* TO otheruser@localhost; |
| 38 | +GRANT EXECUTE ON noauthdb.* TO noauth@localhost; |
| 39 | + |
| 40 | +--enable_query_log |
| 41 | + |
| 42 | +--echo # Connect as otheruser - should succeed. |
| 43 | +--exec $MYSQL --user=otheruser -e "select user(), current_user(), @@proxy_user; SELECT * FROM noauthdb.v1; CALL noauthdb.p1(); SELECT noauthdb.f1();" |
| 44 | + |
| 45 | +--echo # Attempt to access underlying tables directly using otheruser - should fail. |
| 46 | +--error 1, ER_TABLEACCESS_DENIED_ERROR |
| 47 | +--exec $MYSQL --user=otheruser -e "SELECT * FROM noauthdb.t1;" |
| 48 | + |
| 49 | +--echo # Connect as noauth - should fail. |
| 50 | +--error 1, ER_ACCESS_DENIED_ERROR |
| 51 | +--exec $MYSQL --user=noauth -e "select user(), current_user(), @@proxy_user" |
| 52 | + |
| 53 | +--echo #try to set password of this plugin user with password function - should warn |
| 54 | +SET PASSWORD FOR noauth@localhost = password(''); |
| 55 | + |
| 56 | +--echo #try to set password of this plugin user with password hash - should warn |
| 57 | +grant all on *.* to noauth@localhost identified by password '*94BDCEBE19083CE2A1F959FD02F964C7AF4CFC29'; |
| 58 | + |
| 59 | +--echo #try to expire password of this plugin user - should warn |
| 60 | +--error ER_CANNOT_USER |
| 61 | +alter user noauth@localhost password expire; |
| 62 | + |
| 63 | +--echo #uninstall plugin and try to login with this plugin user - should return error |
| 64 | +uninstall plugin mysql_no_login; |
| 65 | +--echo # Connect as noauth - should fail. |
| 66 | +--error 1, ER_PLUGIN_IS_NOT_LOADED |
| 67 | +--exec $MYSQL --user=noauth -e "select user(), current_user(), @@proxy_user" |
| 68 | + |
| 69 | +# Cleanup |
| 70 | +--disable_query_log |
| 71 | + |
| 72 | +DROP DATABASE noauthdb; |
| 73 | +DROP USER noauth@localhost; |
| 74 | +DROP USER otheruser@localhost; |
| 75 | + |
| 76 | +--enable_query_log |
| 77 | +##proxy related scenario |
| 78 | +--replace_regex /\.dll/.so/ |
| 79 | +eval INSTALL PLUGIN mysql_no_login SONAME '$MYSQL_NO_LOGIN'; |
| 80 | +--disable_query_log |
| 81 | +CREATE DATABASE noauthdb; |
| 82 | +CREATE TABLE noauthdb.t1 (a INT); |
| 83 | +CREATE TABLE noauthdb.t2 (a INT); |
| 84 | +INSERT INTO noauthdb.t1 VALUES (1), (2); |
| 85 | +INSERT INTO noauthdb.t2 VALUES (3), (4); |
| 86 | + |
| 87 | +--echo Creating users noauth, otheruser |
| 88 | +CREATE USER noauth@localhost IDENTIFIED WITH 'mysql_no_login'; |
| 89 | +CREATE USER otheruser@localhost; |
| 90 | +GRANT PROXY ON 'noauth'@'localhost' TO 'otheruser'@'localhost'; |
| 91 | +GRANT SELECT, UPDATE, INSERT ON noauthdb.* TO noauth@localhost; |
| 92 | + |
| 93 | +--echo Creating view, procedure, function |
| 94 | +CREATE DEFINER = noauth@localhost SQL SECURITY DEFINER VIEW noauthdb.v1 AS SELECT * FROM noauthdb.t1 WHERE a % 2 = 0; |
| 95 | +CREATE DEFINER = noauth@localhost PROCEDURE noauthdb.p1 () CONTAINS SQL SQL SECURITY DEFINER UPDATE noauthdb.t2 SET a = 5 WHERE a = 3; |
| 96 | +delimiter //; |
| 97 | +CREATE DEFINER = noauth@localhost FUNCTION noauthdb.f1() RETURNS INT CONTAINS SQL SQL SECURITY DEFINER |
| 98 | +BEGIN |
| 99 | +DECLARE outp INT DEFAULT NULL; |
| 100 | +SELECT MAX(a) INTO outp FROM noauthdb.t2; |
| 101 | +RETURN outp; |
| 102 | +END// |
| 103 | +delimiter ;// |
| 104 | + |
| 105 | +GRANT SELECT ON noauthdb.v1 TO otheruser@localhost; |
| 106 | +GRANT EXECUTE ON noauthdb.* TO otheruser@localhost; |
| 107 | +GRANT EXECUTE ON noauthdb.* TO noauth@localhost; |
| 108 | + |
| 109 | +--enable_query_log |
| 110 | + |
| 111 | +--echo # Connect as otheruser - should succeed. |
| 112 | +--exec $MYSQL --user=otheruser -e "select user(), current_user(), @@proxy_user; SELECT * FROM noauthdb.v1; CALL noauthdb.p1(); SELECT noauthdb.f1();" |
| 113 | + |
| 114 | +--echo # Attempt to access underlying tables directly using otheruser - should fail. |
| 115 | +--error 1, ER_TABLEACCESS_DENIED_ERROR |
| 116 | +--exec $MYSQL --user=otheruser -e "SELECT * FROM noauthdb.t1;" |
| 117 | + |
| 118 | +# Cleanup |
| 119 | + --disable_query_log |
| 120 | + |
| 121 | + DROP DATABASE noauthdb; |
| 122 | + DROP USER noauth@localhost; |
| 123 | + DROP USER otheruser@localhost; |
| 124 | + |
| 125 | + #UNINSTALL PLUGIN mysql_no_auth; |
| 126 | + --enable_query_log |
| 127 | +--exit |
0 commit comments