Skip to content

Single Sign On (SSO)💣

Big Bang has configuration for Single Sign-On (SSO) authentication using an identity provider, like Keycloak. If the package supports SSO, you will need to integrate Big Bang’s configuration with the package. If the package does not support SSO, an authentication service can be used to intercept traffic and provide SSO. This document details how to setup your package for either scenario.

Prerequisites💣

The development environment can be set up in one of three ways: 1. Two k3d clusters with keycloak in one cluster and Big Bang and all other apps in the second cluster (see this quick start guide for more information) 2. One k3d cluster using MetalLB to have Keycloak, Big Bang, and all other apps in the one cluster (see this example config for more information) 3. Use a single K3D cluster with two Public IP addresses and the -a option on the k3d-dev.sh script. This will provision two Elastic IPs, MetalLB, and two specialized k3d-proxy containers for connecting the Elastic IPs to the MetalLB IPs. This allows for both a Public and Passthrough Istio Gateway to work simultaneously, specifically to allow for x509 mTLS authentication with Keycloak. Keep in mind that keycloak.bigbang.dev will need to point to the Secondary IP in your /etc/hosts file. The k3d-dev.sh script will inform you of this and return the SecondaryIP.

Integration💣

SSO Integration💣

All package SSO Integrations within BigBang require a <package>.sso block within the BigBang chart values for your package along with an enabled flag:

<package>:
    sso:
      enabled: true

Based on the authentication protocol implemented by the package being integrated, either Security Access Markup Language (SAML) or OpenID (OIDC), follow the appropriate example below.

OIDC💣

For SSO integration using OIDC, at a minimum this usually requires sso.client_id and sso.client_secret values under the same block above. We can then reference these values further down in either the template values for your package (eg: Gitlab) or Authservice Values template if there is no built-in support for OIDC or SAML in the package. Authservice will be discussed in more detail further down.

<package>:
    sso:
      enabled: true
      client_id: "XXXXXX-XXXXXX-XXXXXX-APP" 
      client_secret: "XXXXXXXXXXXX"
  • A bigbang/chart/templates/<package>/secret-sso.yaml may need to be created in order to auto-generate secrets if required by the upstream documentation. We can see in the Gitlab documentation for SSO the configuration is handled via JSON configuration within a secret. This secret-sso.yaml can conditionally be created when <package>.sso.enabled=true within the BigBang values.

    Example: GitLab SSO Secret template

  • If configuration isn’t destined for a secret and the package supports SSO options directly via helm values we can create and reference the necessary options from the <package>.sso values block. For example, elasticsearch documentation specifies a few values required to enable and configure OIDC that we can configure and set to be conditional on <package>.sso.enabled.

    Example: ECK Values template

SAML💣

For SSO integration using SAML, review the upstream documentation specific to the package and create the necessary items to passthrough from BigBang to the package values under the <package>.sso key. For example, Sonarqube configures SSO settings through sonarProperties values, which are collected from defined values under addons.sonarqube.sso within BigBang and passed through in the sonarqube Values template.

AuthService Integration💣

If SSO is not available on the package to be integrated, Istio AuthService can be used for authentication. For AuthService integration, add <package>.sso.client_id and <package>.sso.client_secret definitions for the package within ../../chart/values.yaml. Authservice has global settings defined and any values not explicitly set in this file will be inherited from the global values (like authorization_uri, certificate_authority, jwks, etc). Review the example below below of the jaeger specific chain configured within BigBang and passed through to the authservice values.

Example: Jaeger chain in Authservice template values

In order to use Authservice, Istio injection is required and utilized to route all pod traffic through the Istio side car proxy and the associated Authentication and Authorization policies.

  1. The first step is to ensure your namespace template where you package is destined is istio injected, and the appropriate label is set in chart/templates/<package>/namespace.yaml.

    Example: Jaeger Namespace template

  2. Next is to make sure the following label is applied to the workload (pod/deployment/replicaset/daemonset/etc) that will be behind the Authservice gate:

    ...
    {{- $<package>AuthserviceKey := (dig "selector" "key" "protect" .Values.addons.authservice.values) }}
    {{- $<package>AuthserviceValue := (dig "selector" "value" "keycloak" .Values.addons.authservice.values) }}
    ...
    metadata:
      labels:
        {{ $<package>AuthserviceKey }}: {{ $<package>AuthserviceValue }}
    

This label is set in the Authservice package, and is set to protect=keycloak by default, the above logic will check if anyone overwrites these values within their BigBang installation and overwrite the label accordingly.

Example: Jaeger Values template

Validation💣

For validating package integration with Single Sign On (SSO), carry out the following basic steps:

  1. Enable the package and SSO within Big Bang through the values added in the sections above
  2. Using an internet browser, browse to your application (e.g. sonarqube.bigbang.dev)
  3. If using built-in SAML/OIDC, click the login button, confirm a redirect to the Identity Provider happens. If using Authservice, confirm a redirect to the Identity Provider happens, prompting user sign in.
  4. Sign in as a valid user
  5. Successful sign in should return you to the application page
  6. Confirm you are in the expected account within the application and that you are able to use the application

Note: An unsuccessful sign in may result in an x509 cert issues, invalid client ID/group/user error, JWKS error, or other issues.


Last update: 2023-10-02 by Christopher O'Connell