mirror of
				https://github.com/datahub-project/datahub.git
				synced 2025-10-25 07:54:37 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			104 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			104 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
| package auth.sso;
 | |
| 
 | |
| import com.fasterxml.jackson.databind.JsonNode;
 | |
| import com.fasterxml.jackson.databind.ObjectMapper;
 | |
| 
 | |
| import static auth.AuthUtils.*;
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * Class responsible for extracting and validating top-level SSO related configurations. TODO:
 | |
|  * Refactor SsoConfigs to have OidcConfigs and other identity provider specific configs as instance
 | |
|  * variables. SSoManager should ideally not know about identity provider specific configs.
 | |
|  */
 | |
| public class SsoConfigs {
 | |
| 
 | |
|   /** Required configs */
 | |
|   private static final String AUTH_BASE_URL_CONFIG_PATH = "auth.baseUrl";
 | |
| 
 | |
|   private static final String AUTH_BASE_CALLBACK_PATH_CONFIG_PATH = "auth.baseCallbackPath";
 | |
|   private static final String AUTH_SUCCESS_REDIRECT_PATH_CONFIG_PATH = "auth.successRedirectPath";
 | |
|   public static final String OIDC_ENABLED_CONFIG_PATH = "auth.oidc.enabled";
 | |
| 
 | |
|   /** Default values */
 | |
|   private static final String DEFAULT_BASE_CALLBACK_PATH = "/callback";
 | |
| 
 | |
|   private static final String DEFAULT_SUCCESS_REDIRECT_PATH = "/";
 | |
| 
 | |
|   private final String _authBaseUrl;
 | |
|   private final String _authBaseCallbackPath;
 | |
|   private final String _authSuccessRedirectPath;
 | |
|   private final Boolean _oidcEnabled;
 | |
| 
 | |
|   public SsoConfigs(Builder<?> builder) {
 | |
|     _authBaseUrl = builder._authBaseUrl;
 | |
|     _authBaseCallbackPath = builder._authBaseCallbackPath;
 | |
|     _authSuccessRedirectPath = builder._authSuccessRedirectPath;
 | |
|     _oidcEnabled = builder._oidcEnabled;
 | |
|   }
 | |
| 
 | |
|   public String getAuthBaseUrl() {
 | |
|     return _authBaseUrl;
 | |
|   }
 | |
| 
 | |
|   public String getAuthBaseCallbackPath() {
 | |
|     return _authBaseCallbackPath;
 | |
|   }
 | |
| 
 | |
|   public String getAuthSuccessRedirectPath() {
 | |
|     return _authSuccessRedirectPath;
 | |
|   }
 | |
| 
 | |
|   public Boolean isOidcEnabled() {
 | |
|     return _oidcEnabled;
 | |
|   }
 | |
| 
 | |
|   public static class Builder<T extends Builder<T>> {
 | |
|     protected String _authBaseUrl = null;
 | |
|     private String _authBaseCallbackPath = DEFAULT_BASE_CALLBACK_PATH;
 | |
|     private String _authSuccessRedirectPath = DEFAULT_SUCCESS_REDIRECT_PATH;
 | |
|     protected Boolean _oidcEnabled = false;
 | |
|     private final ObjectMapper _objectMapper = new ObjectMapper();
 | |
|     protected JsonNode jsonNode = null;
 | |
| 
 | |
|     // No need to check if changes are made since this method is only called at start-up.
 | |
|     public Builder from(final com.typesafe.config.Config configs) {
 | |
|       if (configs.hasPath(AUTH_BASE_URL_CONFIG_PATH)) {
 | |
|         _authBaseUrl = configs.getString(AUTH_BASE_URL_CONFIG_PATH);
 | |
|       }
 | |
|       if (configs.hasPath(AUTH_BASE_CALLBACK_PATH_CONFIG_PATH)) {
 | |
|         _authBaseCallbackPath = configs.getString(AUTH_BASE_CALLBACK_PATH_CONFIG_PATH);
 | |
|       }
 | |
|       if (configs.hasPath(OIDC_ENABLED_CONFIG_PATH)) {
 | |
|         _oidcEnabled =
 | |
|             Boolean.TRUE.equals(Boolean.parseBoolean(configs.getString(OIDC_ENABLED_CONFIG_PATH)));
 | |
|       }
 | |
|       if (configs.hasPath(AUTH_SUCCESS_REDIRECT_PATH_CONFIG_PATH)) {
 | |
|         _authSuccessRedirectPath = configs.getString(AUTH_SUCCESS_REDIRECT_PATH_CONFIG_PATH);
 | |
|       }
 | |
|       return this;
 | |
|     }
 | |
| 
 | |
|     public Builder from(String ssoSettingsJsonStr) {
 | |
|       try {
 | |
|         jsonNode = _objectMapper.readTree(ssoSettingsJsonStr);
 | |
|       } catch (Exception e) {
 | |
|         throw new RuntimeException(
 | |
|             String.format("Failed to parse ssoSettingsJsonStr %s into JSON", ssoSettingsJsonStr));
 | |
|       }
 | |
|       if (jsonNode.has(BASE_URL)) {
 | |
|         _authBaseUrl = jsonNode.get(BASE_URL).asText();
 | |
|       }
 | |
|       if (jsonNode.has(OIDC_ENABLED)) {
 | |
|         _oidcEnabled = jsonNode.get(OIDC_ENABLED).asBoolean();
 | |
|       }
 | |
| 
 | |
|       return this;
 | |
|     }
 | |
| 
 | |
|     public SsoConfigs build() {
 | |
|       return new SsoConfigs(this);
 | |
|     }
 | |
|   }
 | |
| }
 | 
