mirror of
https://github.com/MariaDB/server.git
synced 2025-07-27 18:02:13 +03:00
MDEV-13095 Implement User Account locking
Add server support for user account locking. This patch extends the ALTER/CREATE USER statements for denying a user's subsequent login attempts: ALTER USER user [, user2] ACCOUNT [LOCK | UNLOCK] CREATE USER user [, user2] ACCOUNT [LOCK | UNLOCK] The SHOW CREATE USER statement was updated to display the locking state of an user. Closes #1006
This commit is contained in:
committed by
Sergei Golubchik
parent
d89cdfc229
commit
6c8ce999f8
134
mysql-test/main/lock_user.result
Normal file
134
mysql-test/main/lock_user.result
Normal file
@ -0,0 +1,134 @@
|
||||
create user user1@localhost;
|
||||
create user user2@localhost;
|
||||
#
|
||||
# Only privileged users should be able to lock/unlock.
|
||||
#
|
||||
alter user user1@localhost account lock;
|
||||
alter user user1@localhost account unlock;
|
||||
create user user3@localhost account lock;
|
||||
drop user user3@localhost;
|
||||
connect con1,localhost,user1;
|
||||
connection con1;
|
||||
alter user user2@localhost account lock;
|
||||
ERROR 42000: Access denied; you need (at least one of) the CREATE USER privilege(s) for this operation
|
||||
disconnect con1;
|
||||
connection default;
|
||||
#
|
||||
# ALTER USER USER1 ACCOUNT LOCK should deny the connection of user1,
|
||||
# but it should allow user2 to connect.
|
||||
#
|
||||
alter user user1@localhost account lock;
|
||||
connect(localhost,user1,,test,MYSQL_PORT,MYSQL_SOCK);
|
||||
connect con1,localhost,user1;
|
||||
ERROR HY000: Access denied, this account is locked
|
||||
connect con2,localhost,user2;
|
||||
disconnect con2;
|
||||
connection default;
|
||||
alter user user1@localhost account unlock;
|
||||
#
|
||||
# Passing an incorrect user should return an error unless
|
||||
# IF EXISTS is used
|
||||
#
|
||||
alter user inexistentUser@localhost account lock;
|
||||
ERROR HY000: Operation ALTER USER failed for 'inexistentUser'@'localhost'
|
||||
alter if exists user inexistentUser@localhost account lock;
|
||||
Warnings:
|
||||
Error 1133 Can't find any matching row in the user table
|
||||
Note 1396 Operation ALTER USER failed for 'inexistentUser'@'localhost'
|
||||
#
|
||||
# Passing an existing user to CREATE should not be allowed
|
||||
# and it should not change the locking state of the current user
|
||||
#
|
||||
show create user user1@localhost;
|
||||
CREATE USER for user1@localhost
|
||||
CREATE USER 'user1'@'localhost'
|
||||
create user user1@localhost account lock;
|
||||
ERROR HY000: Operation CREATE USER failed for 'user1'@'localhost'
|
||||
show create user user1@localhost;
|
||||
CREATE USER for user1@localhost
|
||||
CREATE USER 'user1'@'localhost'
|
||||
#
|
||||
# Passing multiple users should lock them all
|
||||
#
|
||||
alter user user1@localhost, user2@localhost account lock;
|
||||
connect(localhost,user1,,test,MYSQL_PORT,MYSQL_SOCK);
|
||||
connect con1,localhost,user1;
|
||||
ERROR HY000: Access denied, this account is locked
|
||||
connect(localhost,user2,,test,MYSQL_PORT,MYSQL_SOCK);
|
||||
connect con2,localhost,user2;
|
||||
ERROR HY000: Access denied, this account is locked
|
||||
alter user user1@localhost, user2@localhost account unlock;
|
||||
#
|
||||
# The locking state is preserved after acl reload
|
||||
#
|
||||
alter user user1@localhost account lock;
|
||||
flush privileges;
|
||||
connect(localhost,user1,,test,MYSQL_PORT,MYSQL_SOCK);
|
||||
connect con1,localhost,user1;
|
||||
ERROR HY000: Access denied, this account is locked
|
||||
alter user user1@localhost account unlock;
|
||||
#
|
||||
# JSON functions on global_priv reflect the locking state of an account
|
||||
#
|
||||
alter user user1@localhost account lock;
|
||||
select host, user, JSON_VALUE(Priv, '$.account_locked') from mysql.global_priv where user='user1';
|
||||
host user JSON_VALUE(Priv, '$.account_locked')
|
||||
localhost user1 1
|
||||
alter user user1@localhost account unlock;
|
||||
select host, user, JSON_VALUE(Priv, '$.account_locked') from mysql.global_priv where user='user1';
|
||||
host user JSON_VALUE(Priv, '$.account_locked')
|
||||
localhost user1 0
|
||||
#
|
||||
# SHOW CREATE USER correctly displays the locking state of an user
|
||||
#
|
||||
show create user user1@localhost;
|
||||
CREATE USER for user1@localhost
|
||||
CREATE USER 'user1'@'localhost'
|
||||
alter user user1@localhost account lock;
|
||||
show create user user1@localhost;
|
||||
CREATE USER for user1@localhost
|
||||
CREATE USER 'user1'@'localhost' ACCOUNT LOCK
|
||||
alter user user1@localhost account unlock;
|
||||
show create user user1@localhost;
|
||||
CREATE USER for user1@localhost
|
||||
CREATE USER 'user1'@'localhost'
|
||||
create user newuser@localhost account lock;
|
||||
show create user newuser@localhost;
|
||||
CREATE USER for newuser@localhost
|
||||
CREATE USER 'newuser'@'localhost' ACCOUNT LOCK
|
||||
drop user newuser@localhost;
|
||||
#
|
||||
# Users should be able to lock themselves
|
||||
#
|
||||
grant CREATE USER on *.* to user1@localhost;
|
||||
connect con1,localhost,user1;
|
||||
connection con1;
|
||||
alter user user1@localhost account lock;
|
||||
disconnect con1;
|
||||
connection default;
|
||||
connect(localhost,user1,,test,MYSQL_PORT,MYSQL_SOCK);
|
||||
connect con1,localhost,user1;
|
||||
ERROR HY000: Access denied, this account is locked
|
||||
alter user user1@localhost account unlock;
|
||||
#
|
||||
# Users should be able to unlock themselves if the connections
|
||||
# had been established before the accounts were locked
|
||||
#
|
||||
grant CREATE USER on *.* to user1@localhost;
|
||||
connect con1,localhost,user1;
|
||||
alter user user1@localhost account lock;
|
||||
connection con1;
|
||||
alter user user1@localhost account unlock;
|
||||
show create user user1@localhost;
|
||||
CREATE USER for user1@localhost
|
||||
CREATE USER 'user1'@'localhost'
|
||||
disconnect con1;
|
||||
connection default;
|
||||
#
|
||||
# COM_CHANGE_USER should return error if the destination
|
||||
# account is locked
|
||||
#
|
||||
alter user user1@localhost account lock;
|
||||
ERROR HY000: Access denied, this account is locked
|
||||
drop user user1@localhost;
|
||||
drop user user2@localhost;
|
Reference in New Issue
Block a user