Open ID Connect (OIDC)
This page documents and guides you through setting up Open ID Connect (OIDC) for Zipline. For now the only documented OIDC provider is Authentik, but you can use any OIDC provider that supports the OIDC standard. Zipline has only been tested with Authentik, so if you encounter any issues with other providers, please open an issue.
Authentik
This will guide you through setting up an application and provider.
- Head over to your Authentik Admin Dashboard, and click on "Applications" in the sidebar.
- Click "Create with Wizard" to create a new application as well as a new provider. If this option is not available, you can create a new application and provider separately. The guide will assume you are using the wizard.
data:image/s3,"s3://crabby-images/99f7b/99f7bdbec041affdd6b5754f582c390f0dfcd5d8" alt="authentik create application"
- Enter a name for your application, and click "Next".
data:image/s3,"s3://crabby-images/a806a/a806acee0aa58fd804cede80a30afe2c4ae337b8" alt="authentik application name"
- Select the "OAuth2/OIDC (Open Authorization/OpenID Connect)" option, and click "Next".
data:image/s3,"s3://crabby-images/cb08f/cb08f8a00be0a872f3f95c9d3ebcd6b1ce9ce22d" alt="authentik application type"
- Give the provider a name like "Zipline", and then select a Authorization Flow. You can select "default-provider-authorization-explicit-consent" for the default flow.
data:image/s3,"s3://crabby-images/76c97/76c97de190a0801ba2651cf16c8e991e4fe6e00f" alt="authentik provider name"
- Copy the "Client ID" and "Client Secret" from the "Protocol Settings" section, and save them for later.
- Fill out the "Redirect URIs" with the following URI:
http(s)://<your domain>/api/auth/oauth/oidc
.
data:image/s3,"s3://crabby-images/b1fd0/b1fd0123e868e219929f14045e93029334866068" alt="authentik redirect uri"
When clicking the "Login with OIDC" button, or linking your OIDC account, the
host that Zipline uses for the redirect URL will be the same as the host that
you accessed Zipline from. If you access Zipline from http://localhost:3000
,
the redirect URL will be http://localhost:3000/api/auth/oauth/oidc
. If you
are encountering issues with the redirect URL, you can set a custom redirect
URL in the settings dashboard. This MUST have the /api/auth/oauth/oidc
path at the end.
- Next, scroll down further and click on the "Advanced Protocol Settings" collapsible to expand it.
- Next to scopes enable the
offline_access
scope. In order to do this you may have to hold control and click on theoffline_access
scope. Theemail
,openid
, andprofile
scopes are also required.
data:image/s3,"s3://crabby-images/9e751/9e7517a72e62bcbdcfd4162cff367c87ed1cadbb" alt="authentik scopes"
- Click "Submit", and close out of the modal.
Configure Zipline
- Navigate to your Zipline instance and go to the settings dashboard, scroll down to the "OAuth" section.
- Paste the "Client ID" and "Client Secret" into the respective fields within the OIDC section.
For the OIDC Authorize URL: https://<authentik domain>/application/o/authorize/
For the OIDC Token URL: https://<authentik domain>/application/o/token/
For the OIDC User Info URL: https://<authentik domain>/application/o/userinfo/
data:image/s3,"s3://crabby-images/55cf3/55cf329412e700c1fe5e8e5868c34a7c1a94c63e" alt="zipline settings oauth oidc"
After these fields are filled out (click Save to save your changes), you should see a "Login with OIDC" button on the login page, as well as the option to link your OIDC account in the manage account page.
Other OIDC Providers
The guide above is specific to Authentik and may require modifications for other OIDC providers. While the overall steps and URL names will be similar, some details may differ.
If you're using a different OIDC provider, refer to their documentation to obtain the necessary details for configuring the Zipline settings dashboard.