io.gravitee.am.model.PasswordSettings Maven / Gradle / Ivy
/**
* Copyright (C) 2015 The Gravitee team (http://gravitee.io)
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.gravitee.am.model;
import java.util.Optional;
/**
* @author Boualem DJELAILI (boualem.djelaili at graviteesource.com)
* @author Titouan COMPIEGNE (titouan.compiegne at graviteesource.com)
* @author GraviteeSource Team
*/
public class PasswordSettings {
/**
* See https://cheatsheetseries.owasp.org/cheatsheets/Authentication_Cheat_Sheet.html
*/
public static final int PASSWORD_MAX_LENGTH = 64;
public static final int PASSWORD_MIN_LENGTH = 8;
/**
* Account settings configuration inherited ?
*/
private boolean inherited = true;
/**
* Password min length
*/
private Integer minLength = PASSWORD_MIN_LENGTH;
/**
* Password max length
*/
private Integer maxLength = PASSWORD_MAX_LENGTH;
/**
* Must include numbers
*/
private Boolean includeNumbers;
/**
* Must include special characters
*/
private Boolean includeSpecialCharacters;
/**
* letters in mixed case
*/
private Boolean lettersInMixedCase;
/**
* Max consecutive letters
*/
private Integer maxConsecutiveLetters;
/**
* Excludes passwords contained within password dictionary
*/
private Boolean excludePasswordsInDictionary;
/**
* Excludes user profile information from password
*/
private Boolean excludeUserProfileInfoInPassword;
/**
* The Expiration duration (in days) of a password
*/
private Integer expiryDuration;
/**
* Does the password history is enabled to prevent the usage of old password
*/
private boolean passwordHistoryEnabled;
/**
* How many passwords are preserved into the history
*/
private Short oldPasswords;
public PasswordSettings() {
}
public PasswordSettings(PasswordSettings other) {
this.inherited = other.inherited;
this.minLength = other.minLength;
this.maxLength = other.maxLength;
this.includeNumbers = other.includeNumbers;
this.includeSpecialCharacters = other.includeSpecialCharacters;
this.lettersInMixedCase = other.lettersInMixedCase;
this.maxConsecutiveLetters = other.maxConsecutiveLetters;
this.excludePasswordsInDictionary = other.excludePasswordsInDictionary;
this.excludeUserProfileInfoInPassword = other.excludeUserProfileInfoInPassword;
this.expiryDuration = other.expiryDuration;
this.passwordHistoryEnabled = other.passwordHistoryEnabled;
this.oldPasswords = other.oldPasswords;
}
public Integer getMinLength() {
return minLength;
}
public void setMinLength(Integer minLength) {
this.minLength = minLength;
}
public Integer getMaxLength() {
return maxLength;
}
public void setMaxLength(Integer maxLength) {
this.maxLength = maxLength;
}
public Boolean isIncludeNumbers() {
return includeNumbers;
}
public void setIncludeNumbers(Boolean includeNumbers) {
this.includeNumbers = includeNumbers;
}
public Boolean isIncludeSpecialCharacters() {
return includeSpecialCharacters;
}
public void setIncludeSpecialCharacters(Boolean includeSpecialCharacters) {
this.includeSpecialCharacters = includeSpecialCharacters;
}
public Boolean getLettersInMixedCase() {
return lettersInMixedCase;
}
public void setLettersInMixedCase(Boolean lettersInMixedCase) {
this.lettersInMixedCase = lettersInMixedCase;
}
public Integer getMaxConsecutiveLetters() {
return maxConsecutiveLetters;
}
public void setMaxConsecutiveLetters(Integer maxConsecutiveLetters) {
this.maxConsecutiveLetters = maxConsecutiveLetters;
}
public boolean isInherited() {
return inherited;
}
public void setInherited(boolean inherited) {
this.inherited = inherited;
}
public Boolean isExcludePasswordsInDictionary() {
return excludePasswordsInDictionary;
}
public void setExcludePasswordsInDictionary(Boolean excludePasswordsInDictionary) {
this.excludePasswordsInDictionary = excludePasswordsInDictionary;
}
public Boolean isExcludeUserProfileInfoInPassword() {
return excludeUserProfileInfoInPassword;
}
public void setExcludeUserProfileInfoInPassword(Boolean excludeUserProfileInfoInPassword) {
this.excludeUserProfileInfoInPassword = excludeUserProfileInfoInPassword;
}
public Integer getExpiryDuration() {
return expiryDuration;
}
public void setExpiryDuration(Integer expiryDuration) {
this.expiryDuration = expiryDuration;
}
public boolean isPasswordHistoryEnabled() {
return passwordHistoryEnabled;
}
public void setPasswordHistoryEnabled(boolean passwordHistoryEnabled) {
this.passwordHistoryEnabled = passwordHistoryEnabled;
}
public Short getOldPasswords() {
return oldPasswords;
}
public void setOldPasswords(Short oldPasswords) {
this.oldPasswords = oldPasswords;
}
public static Optional getInstance(PasswordSettingsAware passwordSettingsAware, Domain domain) {
if (passwordSettingsAware == null) {
return Optional.ofNullable(domain.getPasswordSettings());
}
PasswordSettings passwordSettings = passwordSettingsAware.getPasswordSettings();
if (passwordSettings != null && !passwordSettings.isInherited()) {
return Optional.of(passwordSettings);
}
return Optional.ofNullable(domain.getPasswordSettings());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy