 34fbe5d64c
			
		
	
	
		34fbe5d64c
		
			
		
	
	
	
	
		
			
			* DOCS - Prepare 1.7 Release and 1.8 SNAPSHOT * DOCS - Prepare 1.7 Release and 1.8 SNAPSHOT
		
			
				
	
	
	
		
			4.0 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	| title | slug | collate | 
|---|---|---|
| SAML SSO | /deployment/security/saml | false | 
SAML SSO
{% note %}
Security requirements for your production environment:
- DELETE the admin default account shipped by OM.
- UPDATE the Private / Public keys used for the JWT Tokens in case it is enabled.
{% /note %}
Configuring Identity Provider and Service Provider
Identity Provide (IDP) Configuration
- Every IDP will have the following information
- EntityId/Authority -> Same as IDP Openmetadata has an Entity Id
- SignOn Url -> Service Provider SignOn Url
- X509 Certificate -> In case the SP expects (wantAuthnRequestSigned) then provide certificate for validating.
- Authority Url -> We just need to update the domain localhost.
- NameID: This is sent as part of request and is provided by the IDP.
Every IDP provides this information, we can download the XML Metadata and configure the OM taking the values from the XML.
Service Provider (SP) Configuration
- Openmetadata is the service provider, we just update the localhostto the hosted URI.
- EntityId/Authority -> Normally a Url providing info about the provider.
- SignOn Url -> Url to be used for signing purpose.
- X509 Certificate -> In case the SP expects a signed response from IDP, the IDP can be configured with Signing Certificate given by SP.
- Private Key -> In case SP expects a encrypted response from the IDP , the IDP can be configured with SPs public key for encryption and the Private Key can be used for SP for decrypting.
{% note %}
When configuring the Private Key for the Service Provider, ensure you use the actual key content enclosed within the -----BEGIN PRIVATE KEY----- and -----END PRIVATE KEY----- block. Avoid using the Base64-encoded format of the key, as this is not the expected value.
idp:
      entityId: ${SAML_IDP_ENTITY_ID:-"<ID>"}
      ssoLoginUrl: ${SAML_IDP_SSO_LOGIN_URL:-"<SSO_LOGIN_URL"}
      idpX509Certificate: ${SAML_IDP_CERTIFICATE:-"-----BEGIN PRIVATE KEY-----<Certificate>-----END PRIVATE KEY-----"}
      authorityUrl: ${SAML_AUTHORITY_URL:-"http://localhost:8585/api/v1/saml/login"}
      nameId: ${SAML_IDP_NAME_ID:-"urn:oasis:names:tc:SAML:2.0:nameid-format:emailAddress"}
{% /note %}
{% note %}
To add a private key, you need to include it in the keystore and update the configuration details accordingly here.
  security:
    keyStoreFilePath: ${SAML_KEYSTORE_FILE_PATH:-"/path/to/keystore.jks"}
    keyStoreAlias: ${SAML_KEYSTORE_ALIAS:-"myKeystoreAlias"}
    keyStorePassword: ${SAML_KEYSTORE_PASSWORD:-"myKeystorePassword"}
{% /note %}
SP Metadata XML is available at "http://localhost:8585/api/v1/saml/acs", localhost needs to be updated with the correct URI.
Security Configuration
Security Configuration controls the SP requirement for the Security related aspects. The SP can be configured to send signed or encrypted or both request , and in return can also expect signed or encrypted or both responses from the IDP.
Setup JWT Configuration
Jwt Configuration is mandatory for Saml SSO.
- Follow the guide here for JWT Configuration Enable JWT Token.
{% note %}
Security requirements for your production environment:
- UPDATE the Private / Public keys used for the JWT Tokens the ones shipped with OM are for POC only.
{% /note %}
More specific details on different IDPs can be found below:
{% inlineCalloutContainer %} {% inlineCallout color="violet-70" icon="celebration" bold="AWS Saml" href="/deployment/security/saml/aws" %} Configure AWS as IDP. {% /inlineCallout %} {% /inlineCalloutContainer %}
{% inlineCalloutContainer %} {% inlineCallout color="violet-70" icon="celebration" bold="Azure Saml" href="/deployment/security/saml/azure" %} Configure AWS as IDP. {% /inlineCallout %} {% /inlineCalloutContainer %}
{% partial file="/v1.8/deployment/configure-ingestion.md" /%}