2023-04-17 16:45:47 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								---
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								title: Keycloak SSO for Kubernetes
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								slug: /deployment/security/keycloak/kubernetes
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								---
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# Keycloak SSO for Kubernetes
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Check the Helm information [here ](https://artifacthub.io/packages/search?repo=open-metadata ).
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Once the `Client Id`  and `Client Secret`  are generated, see the snippet below for an example of where to
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								place the client id value and update the authorizer configurations in the `values.yaml` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-06-14 19:51:57 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  Create a secret in kubernetes with the client secret: 
						 
					
						
							
								
									
										
										
										
											2023-04-17 16:45:47 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```shell
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								kubectl create secret generic custom-oidc-key-secret --namespace=dev-open-metadata --from-literal=custom-oidc-key-secret=< change-for-your-secret > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
									
										
										
										
											2023-06-14 19:51:57 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  Update `initialAdmins`  Make sure you configure the name from email, example: xyz@helloworld .com, initialAdmins username will be ```xyz` `` 
						 
					
						
							
								
									
										
										
										
											2023-04-17 16:45:47 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-06-14 19:51:57 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  Update the `principalDomain`  to your company domain name. Example from above, principalDomain should be ```helloworld.com` `` 
						 
					
						
							
								
									
										
										
										
											2023-04-17 16:45:47 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-06-14 19:51:57 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{% note noteType="Warning" %}
							 
						 
					
						
							
								
									
										
										
										
											2023-04-17 16:45:47 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-06-14 19:51:57 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								It is important to leave the publicKeys configuration to have both Keycloak public keys URL and OpenMetadata public keys URL. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								1.  Keycloak Public Keys are used to authenticate User's login 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								2.  OpenMetadata JWT keys are used to authenticate Bot's login 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								3.  Important to update the URLs documented in below configuration. The below config reflects a setup where all dependencies are hosted in a single host. Example openmetadata:8585 might not be the same domain you may be using in your installation. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								4.  OpenMetadata ships default public/private key, These must be changed in your production deployment to avoid any security issues. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-12-20 10:30:23 +05:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								For more details, follow [Enabling JWT Authentication ](deployment/security/enable-jwt-tokens )
							 
						 
					
						
							
								
									
										
										
										
											2023-06-14 19:51:57 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{% /note %}
							 
						 
					
						
							
								
									
										
										
										
											2023-04-17 16:45:47 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```yaml
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								global:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  authorizer:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    className: "org.openmetadata.service.security.DefaultAuthorizer"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    containerRequestFilter: "org.openmetadata.service.security.JwtFilter"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    initialAdmins:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								      -  "admin-user"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    principalDomain: "open-metadata.org"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  authentication:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    provider: "custom-oidc"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    publicKeys:
							 
						 
					
						
							
								
									
										
										
										
											2023-06-14 19:51:57 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    -  "http://openmetadata:8585/api/v1/system/config/jwks"
							 
						 
					
						
							
								
									
										
										
										
											2023-04-17 16:45:47 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    -  "http://localhost:8081/auth/realms/data-sec/protocol/openid-connect/certs"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    authority: "http://localhost:8081/auth/realms/data-sec"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    clientId: "{Client ID}"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    callbackUrl: "http://localhost:8585/callback"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-06-14 19:51:57 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{% note noteType="Tip" %}
							 
						 
					
						
							
								
									
										
										
										
											2023-12-23 03:02:47 +05:30 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 Follow [this guide ](/how-to-guides/admin-guide/bots ) to configure the `ingestion-bot`  credentials for ingesting data using Connectors.
							 
						 
					
						
							
								
									
										
										
										
											2023-06-14 19:51:57 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{% /note %}