2024-08-13 02:25:38 +05:30 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								---
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 12:00:46 +05:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								title: SAML AZURE SSO
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 02:25:38 +05:30 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								slug: /deployment/security/saml/azure
							 
						 
					
						
							
								
									
										
										
										
											2024-09-05 10:30:31 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								collate: false
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 02:25:38 +05:30 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								---
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# SAML AZURE SSO
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Follow the sections in this guide to set up Azure SSO using SAML.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{% 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 ](/deployment/security/enable-jwt-tokens ) in case it is enabled. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{% /note %}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Create OpenMetadata application
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Step 1: Configure a new Application in Microsoft Entra ID
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Login to [Azure Portal ](https://portal.azure.com ) as an administrator and search for Microsoft Entra ID. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 12:00:46 +05:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{% image src="/images/v1.5/deployment/security/saml/azure/saml-azure-1.png" alt="EnterpriseApplications" /%}
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 02:25:38 +05:30 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Click on `Enterprise Applications`  and then ` + New Application `  . 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 12:00:46 +05:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{% image src="/images/v1.5/deployment/security/saml/azure/saml-azure-2.png" alt="new-application" /%}
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 02:25:38 +05:30 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  After that a new window will appear with different applications, click on `Create your own application` . 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 12:00:46 +05:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{% image src="/images/v1.5/deployment/security/saml/azure/saml-azure-3.png" alt="create-own-application" /%}
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 02:25:38 +05:30 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Give your application a name and select `Integrate any other application you don't find in the gallery`  and then click `Create` . 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 12:00:46 +05:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{% image src="/images/v1.5/deployment/security/saml/azure/saml-azure-4.png" alt="name-application-create" /%}
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 02:25:38 +05:30 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Once you have the application created, open the app from list , and then click on `Single Sign-On`  and then `SAML` . 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 12:00:46 +05:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{% image src="/images/v1.5/deployment/security/saml/azure/saml-azure-5.png" alt="saml-create-single-sign-On" /%}
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 02:25:38 +05:30 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Edit `Basic SAML Configuration`  and populate the values as shown below for `EntityId`  and `Assertion Consumer Service Url` . These value should match the one configured with Openmetadata Server side for `samlConfiguration.sp.entityId`  and `samlConfiguration.sp.acs`  respectively. After this click `Save` . 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 12:00:46 +05:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{% image src="/images/v1.5/deployment/security/saml/azure/saml-azure-6.png" alt="edit-basic-saml-configuration" /%}
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 02:25:38 +05:30 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Click on `Attributes and Claims`  and click on the `Required Claim (NameId)` . 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 12:00:46 +05:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{% image src="/images/v1.5/deployment/security/saml/azure/saml-azure-7.png" alt="edit-claims" /%}
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 02:25:38 +05:30 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  You will see the values as below image, we need to set the value `Source Attribute`  to a user mail value claim from the IDP. Click on `Edit`  and then select the `Source Attribute`  as `user.mail`  or `user.userprincipalname`  (in some cases this is also a mail) and then click `Save` . 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 12:00:46 +05:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{% image src="/images/v1.5/deployment/security/saml/azure/saml-azure-8.png" alt="edit-claim-value" /%}
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 02:25:38 +05:30 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  To Confirm the claim value we can navigate to user page and check the value of the user. In my case as you can see User Princpal Name is a my mail which i want to use for Openmetadata , so for me `user.userprincipalname`  would be correct claim. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 12:00:46 +05:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{% image src="/images/v1.5/deployment/security/saml/azure/saml-azure-9.png" alt="user-claim-value" /%}
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 02:25:38 +05:30 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{% note %}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Security requirements for your **production**  environment:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  You must always communicate via signed Request for both request from SP to IDP and response from IDP to SP. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  To do so we need to add SP certificate to IDP , so that IDP can validate the signed Auth Request coming from SP. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Generate the certificate using below command and then upload the certificate to IDP.  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```shell
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								openssl req -new -x509 -days 365 -nodes -sha256 -out saml.crt -keyout saml.pem
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								openssl x509 -in saml.crt -out samlCER.cer -outform DER
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Under `Single Sign-On`  you will see SAML Certificates, click on `Verification Certificates` . 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 12:18:45 +05:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{% image src="/images/v1.5/deployment/security/saml/azure/saml-azure-11.png" alt="verification-certificate" /%}
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 02:25:38 +05:30 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  You can then check the `Require Verification Certificates`  and import the certification with .cer format we generated previously. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{% /note %}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Step 2: Setup `OpenMetadata Server` 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Open the downloaded metadata xml file, and populate the following properties in `openmetadata.yml`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  samlConfiguration:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    debugMode: ${SAML_DEBUG_MODE:-false}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    idp:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      entityId: ${SAML_IDP_ENTITY_ID:-"https://mocksaml.com/api/saml/sso"}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      ssoLoginUrl: ${SAML_IDP_SSO_LOGIN_URL:-"https://saml.example.com/entityid"}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      idpX509Certificate: ${SAML_IDP_CERTIFICATE:-""}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      authorityUrl: ${SAML_AUTHORITY_URL:-"http://localhost:8585/api/v1/saml/login"}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      nameId: ${SAML_IDP_NAME_ID:-"urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress"}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    sp:
							 
						 
					
						
							
								
									
										
										
										
											2024-09-12 20:46:44 +05:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								      entityId: ${SAML_SP_ENTITY_ID:-"http://localhost:8585/api/v1/saml/acs"}
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 02:25:38 +05:30 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								      acs: ${SAML_SP_ACS:-"http://localhost:8585/api/v1/saml/acs"}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      spX509Certificate: ${SAML_SP_CERTIFICATE:-""}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      callback: ${SAML_SP_CALLBACK:-"http://localhost:8585/saml/callback"}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    security:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      strictMode: ${SAML_STRICT_MODE:-false}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      tokenValidity: ${SAML_SP_TOKEN_VALIDITY:-"3600"}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      sendEncryptedNameId: ${SAML_SEND_ENCRYPTED_NAME_ID:-false}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      sendSignedAuthRequest: ${SAML_SEND_SIGNED_AUTH_REQUEST:-false}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      signSpMetadata: ${SAML_SIGNED_SP_METADATA:-false}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      wantMessagesSigned: ${SAML_WANT_MESSAGE_SIGNED:-false}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      wantAssertionsSigned: ${SAML_WANT_ASSERTION_SIGNED:-false}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      wantAssertionEncrypted: ${SAML_WANT_ASSERTION_ENCRYPTED:-false}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      wantNameIdEncrypted: ${SAML_WANT_NAME_ID_ENCRYPTED:-false}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      keyStoreFilePath: ${SAML_KEYSTORE_FILE_PATH:-""}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      keyStoreAlias: ${SAML_KEYSTORE_ALIAS:-""}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      keyStorePassword: ${SAML_KEYSTORE_PASSWORD:-""}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Populate the above config from xml metadata 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  IDP Config          
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    `entityID`  -> Populate it from Metadata XML Entity ID
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    `HTTP-Redirect SSO Login URL`  -> always select HTTP-Redirect Url for SSO Login Url
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    `X509 Certificate`  -> This is also available in the IDP XML.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    `NameIDFormat`  -> from MetadataXML NameIDFormat
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    `authorityUrl`  -> set as {http}/{https}://{domain}:{port}/api/v1/saml/login
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  SP Config 
						 
					
						
							
								
									
										
										
										
											2024-09-12 20:46:44 +05:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  `entityId`  -> -> set as {http}/{https}://{domain}:{port}/api/v1/saml/acs
							 
						 
					
						
							
								
									
										
										
										
											2024-08-13 02:25:38 +05:30 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								  `acs`  -> Assertion Consumer Url , set as {http}/{https}://{domain}:{port}/api/v1/saml/acs
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  `spX509Certificate`  -> set to your X509 Signing Key
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  `callback`  -> set as {http}/{https}://{domain}/api/v1/saml/callback
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{% note %}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Security Parameters can be configured in case we want to have signed or encrypted or both assertions. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  In any case we decided to use above config for security then it is mandatory to provide keystore config,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  from where the system can load the signing certificate or Private Key for encryption.  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  For **production**  environment , it is always suggested to keep these true 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      sendSignedAuthRequest: ${SAML_SEND_SIGNED_AUTH_REQUEST:-true}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      wantMessagesSigned: ${SAML_WANT_MESSAGE_SIGNED:-true}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      wantAssertionsSigned: ${SAML_WANT_ASSERTION_SIGNED:-true}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{% /note %}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Step 3: Setup JWT Configuration
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Follow the guide here for JWT Configuration [Enable JWT Token ](/deployment/security/enable-jwt-tokens ). 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{% note %}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Security requirements for your **production**  environment:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  **UPDATE** the Private / Public keys used for the [JWT Tokens ](/deployment/security/enable-jwt-tokens ) the ones shipped with OM are for POC only. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{% /note %}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Step 4: Start the server
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  Set up for SAML is done, you should be routed to your IDP on trying to Sign-in.