com.capitalone.dashboard.settings.AuthProperties Maven / Gradle / Ivy
package com.capitalone.dashboard.settings;
import com.capitalone.dashboard.model.AuthType;
import com.google.common.collect.Lists;
import org.apache.commons.collections.CollectionUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.stereotype.Component;
import javax.annotation.PostConstruct;
import java.util.List;
import java.util.UUID;
@Component
@EnableConfigurationProperties
@ConfigurationProperties(prefix = "auth")
public class AuthProperties {
private static final Logger LOGGER = LoggerFactory.getLogger(AuthProperties.class);
private Long expirationTime;
private String secret;
private String ldapUserDnPattern;
private String ldapServerUrl;
private List authenticationProviders = Lists.newArrayList();
private String openIdClientId;
private String openIdClientSecret;
private String openIdServerHost;
private String openIdRedirectUri;
private String openIdGrantType;
private String openIdScope;
private String adDomain;
private String adRootDn;
private String adUserRootDn;
private String adSvcRootDn;
private String adUrl;
private String ldapBindUser;
private String ldapBindPass;
private boolean ldapDisableGroupAuthorization = false;
/**
* The LDAP filter used to search for users (optional). For example "(&(objectClass=user)(sAMAccountName={0}))". The
* substituted parameter is the user's login name.
**/
private String ldapUserSearchFilter;
/**
* Username (DN) of the "manager" user identity (i.e. "uid=admin,ou=system") which
* will be used to authenticate to a (non-embedded) LDAP server. If omitted,
* anonymous access will be used.
**/
private String ldapManagerDn;
/**
* The password for the manager DN. This is required if the ldapManagerDn is
* specified.
**/
private String ldapManagerPassword;
// -- SSO properties
private String userEid;
private String userEmail;
private String userFirstName;
private String userLastName;
private String userMiddelInitials;
private String userDisplayName;
//-- end SSO properties
public Long getExpirationTime() {
return expirationTime;
}
public void setExpirationTime(Long expirationTime) {
this.expirationTime = expirationTime;
}
public String getSecret() {
return secret;
}
public void setSecret(String secret) {
this.secret = secret;
}
public String getLdapUserDnPattern() {
return ldapUserDnPattern;
}
public void setLdapUserDnPattern(String ldapUserDnPattern) {
this.ldapUserDnPattern = ldapUserDnPattern;
}
public String getLdapServerUrl() {
return ldapServerUrl;
}
public void setLdapServerUrl(String ldapServerUrl) {
this.ldapServerUrl = ldapServerUrl;
}
public List getAuthenticationProviders() {
return authenticationProviders;
}
public void setAuthenticationProviders(List authenticationProviders) {
this.authenticationProviders = authenticationProviders;
}
public String getAdDomain() {
return adDomain;
}
public void setAdDomain(String adDomain) {
this.adDomain = adDomain;
}
public String getAdRootDn() {
return adRootDn;
}
public void setAdRootDn(String adRootDn) {
this.adRootDn = adRootDn;
}
public String getAdUserRootDn() {
return adUserRootDn;
}
public void setAdUserRootDn(String adUserRootDn) {
this.adUserRootDn = adUserRootDn;
}
public String getAdSvcRootDn() {
return adSvcRootDn;
}
public void setAdSvcRootDn(String adSvcRootDn) {
this.adSvcRootDn = adSvcRootDn;
}
public String getAdUrl() {
return adUrl;
}
public void setAdUrl(String adUrl) {
this.adUrl = adUrl;
}
public String getLdapBindUser() {
return ldapBindUser;
}
public void setLdapBindUser(String ldapBindUser) {
this.ldapBindUser = ldapBindUser;
}
public String getLdapBindPass() {
return ldapBindPass;
}
public void setLdapBindPass(String ldapBindPass) {
this.ldapBindPass = ldapBindPass;
}
public boolean isLdapDisableGroupAuthorization() {
return ldapDisableGroupAuthorization;
}
public void setLdapDisableGroupAuthorization(boolean ldapDisableGroupAuthorization) {
this.ldapDisableGroupAuthorization = ldapDisableGroupAuthorization;
}
public String getLdapUserSearchFilter() {
return ldapUserSearchFilter;
}
public void setLdapUserSearchFilter(String ldapUserSearchFilter) {
this.ldapUserSearchFilter = ldapUserSearchFilter;
}
public String getLdapManagerDn() {
return ldapManagerDn;
}
public void setLdapManagerDn(String ldapManagerDn) {
this.ldapManagerDn = ldapManagerDn;
}
public String getLdapManagerPassword() {
return ldapManagerPassword;
}
public void setLdapManagerPassword(String ldapManagerPassword) {
this.ldapManagerPassword = ldapManagerPassword;
}
@PostConstruct
public void applyDefaultsIfNeeded() {
if (getSecret() == null) {
LOGGER.info("No JWT secret found in configuration, generating random secret by default.");
setSecret(UUID.randomUUID().toString().replace("-", ""));
}
if (getExpirationTime() == null) {
LOGGER.info("No JWT expiration time found in configuration, setting to 30 minutes.");
setExpirationTime((long) 1000 * 60 * 30);
}
if (CollectionUtils.isEmpty(authenticationProviders)) {
authenticationProviders.add(AuthType.STANDARD);
}
}
public String getUserEid() {
return userEid;
}
public void setUserEid(String userEid) {
this.userEid = userEid;
}
public String getUserEmail() {
return userEmail;
}
public void setUserEmail(String userEmail) {
this.userEmail = userEmail;
}
public String getUserFirstName() {
return userFirstName;
}
public void setUserFirstName(String userFirstName) {
this.userFirstName = userFirstName;
}
public String getUserLastName() {
return userLastName;
}
public void setUserLastName(String userLastName) {
this.userLastName = userLastName;
}
public String getUserMiddelInitials() {
return userMiddelInitials;
}
public void setUserMiddelInitials(String userMiddelInitials) {
this.userMiddelInitials = userMiddelInitials;
}
public String getUserDisplayName() {
return userDisplayName;
}
public void setUserDisplayName(String userDisplayName) {
this.userDisplayName = userDisplayName;
}
public String getOpenIdServerHost() {
return openIdServerHost;
}
public void setOpenIdServerHost(String openIdServerHost) {
this.openIdServerHost = openIdServerHost;
}
public String getOpenIdClientId() {
return openIdClientId;
}
public void setOpenIdClientId(String openIdClientId) {
this.openIdClientId = openIdClientId;
}
public String getOpenIdClientSecret() {
return openIdClientSecret;
}
public void setOpenIdClientSecret(String openIdClientSecret) {
this.openIdClientSecret = openIdClientSecret;
}
public String getOpenIdRedirectUri() {
return openIdRedirectUri;
}
public void setOpenIdRedirectUri(String openIdRedirectUri) {
this.openIdRedirectUri = openIdRedirectUri;
}
public String getOpenIdGrantType() {
return openIdGrantType;
}
public void setOpenIdGrantType(String openIdGrantType) {
this.openIdGrantType = openIdGrantType;
}
public String getOpenIdScope() {
return openIdScope;
}
public void setOpenIdScope(String openIdScope) {
this.openIdScope = openIdScope;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy