mirror of
https://github.com/gyurix1968/guacamole-client.git
synced 2025-09-06 13:17:41 +00:00
GUACAMOLE-529: Apply database-specific account restrictions depending on context.
This commit is contained in:
@@ -85,15 +85,21 @@ public class JDBCAuthenticationProviderService implements AuthenticationProvider
|
|||||||
public ModeledUserContext getUserContext(AuthenticationProvider authenticationProvider,
|
public ModeledUserContext getUserContext(AuthenticationProvider authenticationProvider,
|
||||||
AuthenticatedUser authenticatedUser) throws GuacamoleException {
|
AuthenticatedUser authenticatedUser) throws GuacamoleException {
|
||||||
|
|
||||||
|
// Always allow but provide no data for users authenticated via our own
|
||||||
|
// connection sharing links
|
||||||
|
if (authenticatedUser instanceof SharedAuthenticatedUser)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
// Set semantic flags based on context
|
||||||
|
boolean databaseCredentialsUsed = (authenticatedUser instanceof ModeledAuthenticatedUser);
|
||||||
|
boolean databaseRestrictionsApplicable = (databaseCredentialsUsed || environment.isUserRequired());
|
||||||
|
|
||||||
// Retrieve user account for already-authenticated user
|
// Retrieve user account for already-authenticated user
|
||||||
ModeledUser user = userService.retrieveUser(authenticationProvider, authenticatedUser);
|
ModeledUser user = userService.retrieveUser(authenticationProvider, authenticatedUser);
|
||||||
if (user != null && !user.isDisabled()) {
|
if (user != null && !user.isDisabled()) {
|
||||||
|
|
||||||
// Account restrictions specific to this extension apply if this
|
// Enforce applicable account restrictions
|
||||||
// extension authenticated the user OR if an account from this
|
if (databaseRestrictionsApplicable) {
|
||||||
// extension is explicitly required
|
|
||||||
if (authenticatedUser instanceof ModeledAuthenticatedUser
|
|
||||||
|| environment.isUserRequired()) {
|
|
||||||
|
|
||||||
// Verify user account is still valid as of today
|
// Verify user account is still valid as of today
|
||||||
if (!user.isAccountValid())
|
if (!user.isAccountValid())
|
||||||
@@ -103,32 +109,33 @@ public class JDBCAuthenticationProviderService implements AuthenticationProvider
|
|||||||
if (!user.isAccountAccessible())
|
if (!user.isAccountAccessible())
|
||||||
throw new GuacamoleClientException("LOGIN.ERROR_NOT_ACCESSIBLE");
|
throw new GuacamoleClientException("LOGIN.ERROR_NOT_ACCESSIBLE");
|
||||||
|
|
||||||
// Update password if password is expired
|
|
||||||
if (user.isExpired() || passwordPolicyService.isPasswordExpired(user))
|
|
||||||
userService.resetExpiredPassword(user, authenticatedUser.getCredentials());
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Link to user context
|
// Update password if password is expired AND the password was
|
||||||
|
// actually involved in the authentication process
|
||||||
|
if (databaseCredentialsUsed) {
|
||||||
|
if (user.isExpired() || passwordPolicyService.isPasswordExpired(user))
|
||||||
|
userService.resetExpiredPassword(user, authenticatedUser.getCredentials());
|
||||||
|
}
|
||||||
|
|
||||||
|
// Return all data associated with the authenticated user
|
||||||
ModeledUserContext context = userContextProvider.get();
|
ModeledUserContext context = userContextProvider.get();
|
||||||
context.init(user.getCurrentUser());
|
context.init(user.getCurrentUser());
|
||||||
return context;
|
return context;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Do not invalidate the authentication result of users who were
|
// Veto authentication result only if database-specific account
|
||||||
// authenticated via our own connection sharing links
|
// restrictions apply in this situation
|
||||||
if (authenticatedUser instanceof SharedAuthenticatedUser)
|
if (databaseRestrictionsApplicable)
|
||||||
return null;
|
throw new GuacamoleInvalidCredentialsException("Invalid login",
|
||||||
|
CredentialsInfo.USERNAME_PASSWORD);
|
||||||
|
|
||||||
// Simply return no data if a database user account is not required
|
// There is no data to be returned for the user, either because they do
|
||||||
if (!environment.isUserRequired())
|
// not exist or because restrictions prevent their data from being
|
||||||
return null;
|
// retrieved, but no restrictions apply which should prevent the user
|
||||||
|
// from authenticating entirely
|
||||||
// Otherwise, invalidate the authentication result, as database user
|
return null;
|
||||||
// accounts are absolutely required
|
|
||||||
throw new GuacamoleInvalidCredentialsException("Invalid login",
|
|
||||||
CredentialsInfo.USERNAME_PASSWORD);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user