| 
									
										
										
										
											2023-12-13 14:03:08 +01:00
										 |  |  | --- | 
					
						
							|  |  |  | title: Custom OIDC SSO for Bare Metal | 
					
						
							|  |  |  | slug: /deployment/security/custom-oidc/bare-metal | 
					
						
							|  |  |  | --- | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Custom OIDC SSO for Bare Metal
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ## Update conf/openmetadata.yaml
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-01 13:08:48 +05:30
										 |  |  | Once the `Client Id` is generated, add the `Client Id` in `openmetadata.yaml` file in `client_id` field. | 
					
						
							| 
									
										
										
										
											2023-12-13 14:03:08 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | Update the `providerName` config to the name you want to display in the `Sign In` button in the UI. For example, with the | 
					
						
							|  |  |  | following configuration with `providerName` set to `KeyCloak`, the users will see `Sign In with KeyCloak SSO` in the `Sign In` | 
					
						
							|  |  |  | page of the OpenMetadata UI. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ```yaml | 
					
						
							|  |  |  | authenticationConfiguration: | 
					
						
							|  |  |  |   provider: "custom-oidc" | 
					
						
							|  |  |  |   providerName: "KeyCloak" | 
					
						
							|  |  |  |   publicKeyUrls: | 
					
						
							|  |  |  |     - "http://localhost:8080/realms/myrealm/protocol/openid-connect/certs" | 
					
						
							| 
									
										
										
										
											2024-02-21 14:00:17 +05:30
										 |  |  |     - "{your domain}/api/v1/config/jwks" # Update with your Domain and Make sure this "/api/v1/config/jwks" is always configured to enable JWT tokens | 
					
						
							| 
									
										
										
										
											2023-12-13 14:03:08 +01:00
										 |  |  |   authority: "http://localhost:8080/realms/myrealm" | 
					
						
							|  |  |  |   clientId: "{client id}" | 
					
						
							|  |  |  |   callbackUrl: "http://localhost:8585/callback" | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Then,  | 
					
						
							|  |  |  | - Update `authorizerConfiguration` to add login names of the admin users in `adminPrincipals` section as shown below. | 
					
						
							|  |  |  | - Update the `principalDomain` to your company domain name. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ```yaml | 
					
						
							|  |  |  | authorizerConfiguration: | 
					
						
							|  |  |  |   className: "org.openmetadata.service.security.DefaultAuthorizer" | 
					
						
							|  |  |  |   # JWT Filter | 
					
						
							|  |  |  |   containerRequestFilter: "org.openmetadata.service.security.JwtFilter" | 
					
						
							|  |  |  |   adminPrincipals: | 
					
						
							|  |  |  |     - "user1" | 
					
						
							|  |  |  |     - "user2" | 
					
						
							|  |  |  |   principalDomain: "open-metadata.org" | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | {% partial file="/v1.3/deployment/configure-ingestion.md" /%} |