website/integrations/infrastructure/harbor/index.md
Harbor is an open source container image registry that secures images with role-based access control, scans images for vulnerabilities, and signs images as trusted. A CNCF Graduated project, Harbor delivers compliance, performance, and interoperability to help you consistently and securely manage images across cloud native compute platforms like Kubernetes and Docker.
The following placeholders are used in this guide:
harbor.company is the FQDN of the Harbor installation.authentik.company is the FQDN of the authentik installation.:::info This documentation lists only the settings that you need to change from their default values. Be aware that any changes other than those explicitly mentioned in this guide could cause issues accessing your application. :::
To support the integration of Harbor with authentik, you need to create an application/provider pair in authentik.
Application: provide a descriptive name, an optional group for the type of application, the policy engine mode, and optional UI settings.
Choose a Provider type: select OAuth2/OpenID Connect as the provider type.
Configure the Provider: provide a name (or accept the auto-provided name), the authorization flow to use for this provider, and the following required configurations.
https://harbor.company/c/oidc/callback.authentik default OAuth Mapping: OpenID 'offline_access' to Selected Scopes.Configure Bindings (optional): you can create a binding (policy, group, or user) to manage the listing and access to applications on a user's My applications page.
To support the integration of authentik with Harbor, you need to configure OIDC authentication.
Log in to the Harbor dashboard as an admin.
Navigate to Configuration and select the Authentication tab.
In the Auth Mode dropdown, select OIDC and provide the following required configurations.
authentikhttps://authentik.company/application/o/harbor/groupsopenid,profile,email,offline_accesspreferred_usernameClick Save.
:::info
If you are experiencing redirect errors, ensure that you have set the hostname and external_url fields in your harbor.yml file and run the setup.sh script.
:::
To confirm that authentik is properly configured with Harbor, log out of Harbor, then use the "LOGIN VIA OIDC PROVIDER" button on the login page and verify that Single Sign-On succeeds.