mirror of
				https://github.com/open-metadata/OpenMetadata.git
				synced 2025-10-25 15:55:15 +00:00 
			
		
		
		
	
		
			
				
	
	
	
		
			4.1 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	
			4.1 KiB
		
	
	
	
	
	
	
	
| title | slug | 
|---|---|
| Keycloak SSO | /deployment/security/keycloak | 
Keycloak SSO
Follow the sections in this guide to set up Keycloak SSO.
Create Server Credentials
Step 1: Access the Keycloak Admin Console
- You need an administrator account. If you don't have, see Creating the first administrator.
- Go to the URL for the Admin Console. For example, for localhost, use this URL: http://localhost:8080/admin/
 
- Enter the username and password you created.
Step 2: Change Realm selected
- The Keycloak use Realms as the primary form of organization, we can't use the realm "master" for new clients (apps), only for administration, so change for your specific realm or create a new.
- In this example we are used an existing one called "Data-sec".
 
Step 3: Create OpenMetadata as a new Client
- Click on Clientsin the menu.
- Click on Createbutton.
- Enter the Client ID and Protocol as the image.
- Click on Savebutton.
 
Step 4: Edit settings of the client
- Change "Acess Type" value from "public" to "confidential".
- Change "implicit flow" and "service accounts" to enabled.
 
- At the bottom of the same settings page, change the configurations to the openmetadata address.
- The image below shows different possibilities, such as running locally or with a custom domain.
 
- Click on Savebutton.
Step 5: Where to Find the Credentials
- Navigate to the Credentialstab.
- You will find your Client Secretrelated to the Client id "open-metadata"
 
- Navigate to the Service Account Rolestab.
- You will find your service account id related to the Client id "open-metadata"
 
After the applying these steps, the users in your realm are able to login in the openmetadata, as a suggestion create a user called "admin-user". Now you can update the configuration of your deployment:
Configure Keycloak SSO for your Docker Deployment. Configure Keycloak SSO for your Bare Metal Deployment. Configure Keycloak SSO for your Kubernetes Deployment.Configure Ingestion
After everything has been set up, you will need to configure your workflows if you are running them via the
metadata CLI or with any custom scheduler.
Note that KeyCloak SSO is a layer on top of Custom OIDC.
When setting up the YAML config for the connector, update the workflowConfig as follows:
workflowConfig:
  openMetadataServerConfig:
    hostPort: 'http://localhost:8585/api'
    authProvider: custom-oidc
    securityConfig:
      clientId: '{your_client_id}'
      secretKey: '{your_client_secret}'
      tokenEndpoint: '{your_token_endpoint}' # e.g. http://localhost:8081/realms/data-sec/protocol/openid-connect/token
