@pepr/keycloak-authsvc v0.6.0
Pepr Module for Keycloak and Authservice
This is a Pepr Module intended to be imported into your own Pepr Module. Pepr is a Kubernetes transformation system written in Typescript.
This repo has two capabilities in it that can be imported separately, or used together.
- Keycloak capability communicates with the keycloak deployed in cluster to generate a new client secret that will be picked up by the authservice module.
- Authservice capability reads from secrets created by the Keycloak module or manually and updates authservice's config.
These capability working together are designed to automate the manual steps required to integrate new applications into the Big Bang IdAM Solution. If you wish to use this capability with the open source charts/images for this, there will be some changes that will need to be made: 1. authservice does not have a public chart, only an example. Changes will need to be made to make this work. You should start with the bigbang docs to help with the implementation 2. There are assumptions that the Keycloak capability makes that are specific to work with the bigbang keycloak chart. This code can function with some minor changes to work with other keycloak charts. Mostly around where the keycloak chart stores the local admin kubernetes secret which the capability uses to communicate with keycloak.
Installation To use this module:
- run npm i @pepr/keycloak-authsvc.
- Update your pepr.ts to look like this, or add additional capabilities to your module.
import { PeprModule } from "pepr";
import { Keycloak } from "@pepr/keycloak-authsvc";
import { AuthService } from "@pepr/keycloak-authsvc";
import cfg from "./package.json";
new PeprModule(cfg, [Keycloak, AuthService]);Pre-reqs for Keycloak capability
- for CAC auth, keycloak needs to be installed per BigBang, and accessible via an ingress gateway that is configured to passthrough into keycloak for TLS termination in keycloak.
- if CAC auth is not required, the ingress gateway can perform TLS termination.
- Keycloak must be resolvable via https://keycloak.${domain}from within and outside of the cluster.
Pre-reqs for Authservice capability
- Istio must be setup with Authservice per the configuration from the BigBang chart (all the authn, authz stuff is covered in there)
- AuthService must have the istio sidecar running
- The IDP (IE: Keycloak) must be resolvable via from within and outside of the cluster.
Keycloak setup:
- Must be resolvable via https://keycloak.${domain} (or whatever domain you setup) inside the cluster, authservice requires TLS even with MTLS.
- The admin user and password must be stored in a secret in namespace keycloak, objectkeycloak-env
- pepr does not need special access to this namespace beyond the mutating webhook.
Authservice setup:
- must be in namespace authservice
- must have a secret called authservice that contains the config.json
- pepr needs needs access to this namespace- full access to secrets (to read/write the client secrets, and update the authservice config).
- will roll the authservice deployment via a checksum label (patch)
 
Istio setup:
- must have it's mesh aware of authservice (in the istio-systemnamespace, configmapistio)
- Istio objects must be created by the istio setup- peerauthentications.security.istio.io
- authorizationpolicies.security.istio.io (authz)
- requestauthentications.security.istio.io (authn)
 
Realm setup:
The realm should be created by the bigbang package, but if not, the Keycloak capability provides this. The best way to do this:
1. Export configuration without clients to a JSON file
2. Verify the JSON file has the configuration you want
3. rename the JSON file to realmJson
4. Follow the procedure below to create a configmap with the realm configuration. Since there should be no secrets in the realm configuration, it's safe to use a configmap.
    kubectl create configmap configrealm -n keycloak --from-file=realmJson --from-literal=domain=bigbang.dev
    kubectl label configmap configrealm -n keycloak  pepr.dev/keycloak=createrealmNOTE: Multiple realms have not been tested!
Setting up an application to be secured with Keycloak/Authservice
- This assumes the application is secured with istio's sidecar, has a virtual service and a gateway. It should be accessible from outside the cluster without authenication.
- To protect this application with Keycloak, you can add the following to the deployment (or possibly a statefulset). This should result in a 'Permission Denied' message when attempting to access the application.
The modifications to the deployment will look like this:
spec:
  template:
    metadata:
      labels:
        protect: keycloakHere's a command that will perform that patch on an example application (podinfo in namespace podinfo)
kubectl patch deployment podinfo -n podinfo -p '{"spec":{"template":{"metadata":{"labels":{"protect":"keycloak"}}}}}'- To start the process for creation of the secret from keycloak:
kubectl create secret generic configclient -n podinfo \
  --from-literal=realm=baby-yoda \
  --from-literal=id=podinfo \
  --from-literal=name=podinfo \
  --from-literal=domain=bigbang.dev \
  --dry-run=client -o yaml | kubectl label --local -f - pepr.dev/keycloak=createclient -o yaml | kubectl apply -f -This performs the same action:
kubectl create secret generic configclient -n podinfo --from-literal=realm=baby-yoda --from-literal=id=podinfo --from-literal=name=podinfo --from-literal=domain=bigbang.dev
kubectl label secret configclient -n podinfo  pepr.dev/keycloak=createclientDid it work? If this command:
kubectl get secret podinfo-client -n podinfo -o yamlreturns the following, then the Keycloak capability functioned properly. (NOTE: the clientSecret will be generated by keycloak so will not look the same)
apiVersion: v1
kind: Secret
type: Opaque
metadata:
  labels:
    pepr.dev/keycloak: oidcconfig
  name: podinfo-client
  namespace: podinfo
data:
  clientSecret: WlJUWjNDcW9MMEpHaHRKZVdqcVNHdGoxVVEwbHBwZEY=
  domain: YmlnYmFuZy5kZXY=
  id: ZGV2XzAwZWI4OTA0LTViODgtNGM2OC1hZDY3LWNlYzBkMmUwN2FhNl9wb2RpbmZv
  name: cG9kaW5mbw==
  realm: YmFieS15b2Rh
  redirectUri: aHR0cHM6Ly9wb2RpbmZvLmJpZ2JhbmcuZGV2L2xvZ2luIf the following is in the secret, then the AuthService capability also ran correctly.
  annotations:
    e4a35052-c138-55e4-94a7-bb942b1cddc7.pepr.dev/AuthService: succeeded- Verifying the application now requires authentication. What initially allowed no authentication after step 1, then access denied after step 2, should now properly authenicate a user (NOTE: you'll need a user in the realm to test it).
Troubleshooting
If you got to step 4 above and the authentication flow is not properly working, here are things to test: 1. Can you login to the keycloak admin console? 2. Did you create a user in the realm? Can that user login to keycloak as well? 3. Does keycloak and authservice have the sidecar container running with it? 4. Is authservice running properly? 5. is the new chain in authservice's secret there? 6. Did authservice properly restart? 7. Is the authn/authz stuff in istio properly setup?