mirror of
https://github.com/apache/cloudstack.git
synced 2025-10-26 08:42:29 +01:00
Refactoring the lockUser cmd
This commit is contained in:
parent
934173db2e
commit
58598bb0cb
@ -17,29 +17,18 @@
|
|||||||
*/
|
*/
|
||||||
package com.cloud.api.commands;
|
package com.cloud.api.commands;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
import org.apache.log4j.Logger;
|
import org.apache.log4j.Logger;
|
||||||
|
|
||||||
import com.cloud.api.BaseCmd;
|
import com.cloud.api.BaseCmd;
|
||||||
|
import com.cloud.api.Implementation;
|
||||||
import com.cloud.api.Parameter;
|
import com.cloud.api.Parameter;
|
||||||
import com.cloud.api.ServerApiException;
|
import com.cloud.api.BaseCmd.Manager;
|
||||||
import com.cloud.user.Account;
|
|
||||||
import com.cloud.user.User;
|
|
||||||
import com.cloud.utils.Pair;
|
|
||||||
|
|
||||||
|
@Implementation(method="lockUser", manager=Manager.ManagementServer)
|
||||||
public class LockUserCmd extends BaseCmd {
|
public class LockUserCmd extends BaseCmd {
|
||||||
public static final Logger s_logger = Logger.getLogger(LockUserCmd.class.getName());
|
public static final Logger s_logger = Logger.getLogger(LockUserCmd.class.getName());
|
||||||
|
|
||||||
private static final String s_name = "lockuserresponse";
|
private static final String s_name = "lockuserresponse";
|
||||||
private static final List<Pair<Enum, Boolean>> s_properties = new ArrayList<Pair<Enum, Boolean>>();
|
|
||||||
|
|
||||||
static {
|
|
||||||
s_properties.add(new Pair<Enum, Boolean>(BaseCmd.Properties.ID, Boolean.TRUE));
|
|
||||||
s_properties.add(new Pair<Enum, Boolean>(BaseCmd.Properties.ACCOUNT_OBJ, Boolean.FALSE));
|
|
||||||
}
|
|
||||||
|
|
||||||
/////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////
|
||||||
//////////////// API parameters /////////////////////
|
//////////////// API parameters /////////////////////
|
||||||
@ -63,36 +52,39 @@ public class LockUserCmd extends BaseCmd {
|
|||||||
public String getName() {
|
public String getName() {
|
||||||
return s_name;
|
return s_name;
|
||||||
}
|
}
|
||||||
public List<Pair<Enum, Boolean>> getProperties() {
|
|
||||||
return s_properties;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
// @Override
|
||||||
public List<Pair<String, Object>> execute(Map<String, Object> params) {
|
// public List<Pair<String, Object>> execute(Map<String, Object> params) {
|
||||||
Account adminAccount = (Account)params.get(BaseCmd.Properties.ACCOUNT_OBJ.getName());
|
// Account adminAccount = (Account)params.get(BaseCmd.Properties.ACCOUNT_OBJ.getName());
|
||||||
Long id = (Long)params.get(BaseCmd.Properties.ID.getName());
|
// Long id = (Long)params.get(BaseCmd.Properties.ID.getName());
|
||||||
|
//
|
||||||
|
// // Check if user with id exists in the system
|
||||||
|
// User user = getManagementServer().findUserById(id);
|
||||||
|
// if (user == null) {
|
||||||
|
// throw new ServerApiException(BaseCmd.ACCOUNT_ERROR, "Unable to find user by id");
|
||||||
|
// } else if (user.getRemoved() != null) {
|
||||||
|
// throw new ServerApiException(BaseCmd.ACCOUNT_ERROR, "Unable to find user by id");
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// // If the user is a System user, return an error. We do not allow this
|
||||||
|
// Account account = getManagementServer().findAccountById(user.getAccountId());
|
||||||
|
// if ((account != null) && (account.getId() == Account.ACCOUNT_ID_SYSTEM)) {
|
||||||
|
// throw new ServerApiException(BaseCmd.ACCOUNT_ERROR, "user id : " + id + " is a system user, locking is not allowed");
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// if ((adminAccount != null) && !getManagementServer().isChildDomain(adminAccount.getDomainId(), account.getDomainId())) {
|
||||||
|
// throw new ServerApiException(BaseCmd.ACCOUNT_ERROR, "Failed to lock user " + id + ", permission denied.");
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// boolean success = getManagementServer().lockUser(id.longValue());
|
||||||
|
// List<Pair<String, Object>> returnValues = new ArrayList<Pair<String, Object>>();
|
||||||
|
// returnValues.add(new Pair<String, Object>(BaseCmd.Properties.SUCCESS.getName(), Boolean.valueOf(success).toString()));
|
||||||
|
// return returnValues;
|
||||||
|
// }
|
||||||
|
|
||||||
// Check if user with id exists in the system
|
@Override
|
||||||
User user = getManagementServer().findUserById(id);
|
public String getResponse() {
|
||||||
if (user == null) {
|
// TODO Auto-generated method stub
|
||||||
throw new ServerApiException(BaseCmd.ACCOUNT_ERROR, "Unable to find user by id");
|
return null;
|
||||||
} else if (user.getRemoved() != null) {
|
}
|
||||||
throw new ServerApiException(BaseCmd.ACCOUNT_ERROR, "Unable to find user by id");
|
|
||||||
}
|
|
||||||
|
|
||||||
// If the user is a System user, return an error. We do not allow this
|
|
||||||
Account account = getManagementServer().findAccountById(user.getAccountId());
|
|
||||||
if ((account != null) && (account.getId() == Account.ACCOUNT_ID_SYSTEM)) {
|
|
||||||
throw new ServerApiException(BaseCmd.ACCOUNT_ERROR, "user id : " + id + " is a system user, locking is not allowed");
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((adminAccount != null) && !getManagementServer().isChildDomain(adminAccount.getDomainId(), account.getDomainId())) {
|
|
||||||
throw new ServerApiException(BaseCmd.ACCOUNT_ERROR, "Failed to lock user " + id + ", permission denied.");
|
|
||||||
}
|
|
||||||
|
|
||||||
boolean success = getManagementServer().lockUser(id.longValue());
|
|
||||||
List<Pair<String, Object>> returnValues = new ArrayList<Pair<String, Object>>();
|
|
||||||
returnValues.add(new Pair<String, Object>(BaseCmd.Properties.SUCCESS.getName(), Boolean.valueOf(success).toString()));
|
|
||||||
return returnValues;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@ -29,6 +29,7 @@ import com.cloud.api.commands.CreatePortForwardingServiceRuleCmd;
|
|||||||
import com.cloud.api.commands.EnableAccountCmd;
|
import com.cloud.api.commands.EnableAccountCmd;
|
||||||
import com.cloud.api.commands.EnableUserCmd;
|
import com.cloud.api.commands.EnableUserCmd;
|
||||||
import com.cloud.api.commands.GetCloudIdentifierCmd;
|
import com.cloud.api.commands.GetCloudIdentifierCmd;
|
||||||
|
import com.cloud.api.commands.LockUserCmd;
|
||||||
import com.cloud.api.commands.RebootSystemVmCmd;
|
import com.cloud.api.commands.RebootSystemVmCmd;
|
||||||
import com.cloud.api.commands.RegisterCmd;
|
import com.cloud.api.commands.RegisterCmd;
|
||||||
import com.cloud.api.commands.RemovePortForwardingServiceCmd;
|
import com.cloud.api.commands.RemovePortForwardingServiceCmd;
|
||||||
@ -252,7 +253,7 @@ public interface ManagementServer {
|
|||||||
* @param userId
|
* @param userId
|
||||||
* @return true if enable was successful, false otherwise
|
* @return true if enable was successful, false otherwise
|
||||||
*/
|
*/
|
||||||
boolean lockUser(long userId);
|
boolean lockUser(LockUserCmd cmd);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* registerPreallocatedLun registers a preallocated lun in our database.
|
* registerPreallocatedLun registers a preallocated lun in our database.
|
||||||
|
|||||||
@ -71,6 +71,7 @@ import com.cloud.api.commands.DeployVMCmd;
|
|||||||
import com.cloud.api.commands.EnableAccountCmd;
|
import com.cloud.api.commands.EnableAccountCmd;
|
||||||
import com.cloud.api.commands.EnableUserCmd;
|
import com.cloud.api.commands.EnableUserCmd;
|
||||||
import com.cloud.api.commands.GetCloudIdentifierCmd;
|
import com.cloud.api.commands.GetCloudIdentifierCmd;
|
||||||
|
import com.cloud.api.commands.LockUserCmd;
|
||||||
import com.cloud.api.commands.PrepareForMaintenanceCmd;
|
import com.cloud.api.commands.PrepareForMaintenanceCmd;
|
||||||
import com.cloud.api.commands.PreparePrimaryStorageForMaintenanceCmd;
|
import com.cloud.api.commands.PreparePrimaryStorageForMaintenanceCmd;
|
||||||
import com.cloud.api.commands.RebootSystemVmCmd;
|
import com.cloud.api.commands.RebootSystemVmCmd;
|
||||||
@ -1082,18 +1083,38 @@ public class ManagementServerImpl implements ManagementServer {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean lockUser(long userId) {
|
public boolean lockUser(LockUserCmd cmd) {
|
||||||
boolean success = false;
|
boolean success = false;
|
||||||
|
|
||||||
|
Account adminAccount = (Account)UserContext.current().getAccountObject();
|
||||||
|
Long id = cmd.getId();
|
||||||
|
|
||||||
|
// Check if user with id exists in the system
|
||||||
|
User user = _userDao.findById(id);
|
||||||
|
if (user == null) {
|
||||||
|
throw new ServerApiException(BaseCmd.ACCOUNT_ERROR, "Unable to find user by id");
|
||||||
|
} else if (user.getRemoved() != null) {
|
||||||
|
throw new ServerApiException(BaseCmd.ACCOUNT_ERROR, "Unable to find user by id");
|
||||||
|
}
|
||||||
|
|
||||||
|
// If the user is a System user, return an error. We do not allow this
|
||||||
|
Account account = _accountDao.findById(user.getAccountId());
|
||||||
|
if ((account != null) && (account.getId() == Account.ACCOUNT_ID_SYSTEM)) {
|
||||||
|
throw new ServerApiException(BaseCmd.ACCOUNT_ERROR, "user id : " + id + " is a system user, locking is not allowed");
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((adminAccount != null) && !_domainDao.isChildDomain(adminAccount.getDomainId(), account.getDomainId())) {
|
||||||
|
throw new ServerApiException(BaseCmd.ACCOUNT_ERROR, "Failed to lock user " + id + ", permission denied.");
|
||||||
|
}
|
||||||
|
|
||||||
// make sure the account is enabled too
|
// make sure the account is enabled too
|
||||||
UserVO user = _userDao.findById(userId);
|
|
||||||
if (user != null) {
|
if (user != null) {
|
||||||
// if the user is either locked already or disabled already, don't change state...only lock currently enabled users
|
// if the user is either locked already or disabled already, don't change state...only lock currently enabled users
|
||||||
if (user.getState().equals(Account.ACCOUNT_STATE_LOCKED)) {
|
if (user.getState().equals(Account.ACCOUNT_STATE_LOCKED)) {
|
||||||
// already locked...no-op
|
// already locked...no-op
|
||||||
return true;
|
return true;
|
||||||
} else if (user.getState().equals(Account.ACCOUNT_STATE_ENABLED)) {
|
} else if (user.getState().equals(Account.ACCOUNT_STATE_ENABLED)) {
|
||||||
success = doSetUserStatus(userId, Account.ACCOUNT_STATE_LOCKED);
|
success = doSetUserStatus(user.getId(), Account.ACCOUNT_STATE_LOCKED);
|
||||||
|
|
||||||
boolean lockAccount = true;
|
boolean lockAccount = true;
|
||||||
List<UserVO> allUsersByAccount = _userDao.listByAccount(user.getAccountId());
|
List<UserVO> allUsersByAccount = _userDao.listByAccount(user.getAccountId());
|
||||||
@ -1109,11 +1130,11 @@ public class ManagementServerImpl implements ManagementServer {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (s_logger.isInfoEnabled()) {
|
if (s_logger.isInfoEnabled()) {
|
||||||
s_logger.info("Attempting to lock a non-enabled user, current state is " + user.getState() + " (userId: " + userId + "), locking failed.");
|
s_logger.info("Attempting to lock a non-enabled user, current state is " + user.getState() + " (userId: " + user.getId() + "), locking failed.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
s_logger.warn("Unable to find user with id: " + userId);
|
s_logger.warn("Unable to find user with id: " + UserContext.current().getUserId());
|
||||||
}
|
}
|
||||||
return success;
|
return success;
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user