ORY Oathkeeper Helm Chart
The ORY Oathkeeper Helm Chart helps you deploy ORY Oathkeeper on Kubernetes using Helm.
Installation
Add the helm repository
$ helm repo add ory https://k8s.ory.sh/helm/charts
$ helm repo update
Installing ORY Oathkeeper using Helm with
$ helm install ory/oathkeeper
which sets up a very basic configuration with no access rules and no enabled authenticators, authorizers, or credentials issuers.
This Helm Chart supports a demo mode which deploys access rules for urls
- http://<oathkeeper-reverse-proxy-host>/authenticator/noop/authorizer/allow/mutator/noop
- http://<oathkeeper-reverse-proxy-host>/authenticator/anonymous/authorizer/allow/mutator/header
that point to httpbin.org. To install ORY Oathkeeper in demo-mode, run:
$ helm install --set 'demo=true' ory/oathkeeper
Be aware that this mode uses JSON Web Keys and other secrets that are publicly accessible via GitHub. These secrets are publicly known and should never be used anywhere. Do not use demo-mode for anything other than experimenting.
Configuration
You can pass your
ORY Oathkeeper configuration file
by creating a yaml file with key oathkeeper.config
# oathkeeper-config.yaml
oathkeeper:
  config:
    # e.g.:
    authenticators:
      noop:
        enabled: true
    # ...
and passing that as a value override to helm:
$ helm install -f ./path/to/oathkeeper-config.yaml ory/oathkeeper
Values such as the proxy / api port will be automatically propagated to the service and ingress definitions.
For a detailed list of configuration items look at the Configuration Reference
JSON Web Key Set for Mutator id_token
The id_token mutator requires a secret JSON Web Key Set. This helm chart
supports loading the JSON Web Key Set from disk and deploying it as a Kubernetes
Secret:
$ helm install \
    --set-file 'oathkeeper.mutatorIdTokenJWKs=./path/to/jwks.json' \
    ory/oathkeeper
Please note that any configuration values set for
oathkeeper.config.mutator.id_token.jwks_url using e.g. a configuration file
will be overwritten by this setting.
Access Rules
Instead of fetching access rules from remote locations, you can set your access
rules directly with --set-file:
$ helm install \
    --set-file 'oathkeeper.accessRules=./path/to/access-rules.json' \
    ory/oathkeeper
Please note that any configuration values set for
oathkeeper.config.access_rules.repositories using e.g. a configuration file
will be overwritten by this setting.
JSON Web Key Set for Authenticator
- Using https://, reference from here
# oathkeeper-config.yaml
oathkeeper:
  config:
    # e.g.:
    authenticators:
      jwt:
        config:
          jwks_urls:
            - https://my-website.com/.well-known/jwks.json
- Using file://(this requires that the file must existing within the container), reference from here
# oathkeeper-config.yaml
oathkeeper:
  config:
    # e.g.:
    authenticators:
      jwt:
        config:
          jwks_urls:
            - file://etc/jwks.json
- You can add secretorconfigmapand mount the secret/configmaps with the file, and pointoathkeeperto it using the file directive, by modifyingvalues.yamlfor this helm chart.
deployment:
  extraVolumes: []
  # - name: my-volume
  #   secret:
  #     secretName: my-secret
  # -- Extra volume mounts, allows mounting the extraVolumes to the container.
  extraVolumeMounts: []
  # - name: my-volume
  #   mountPath: /etc/secrets/my-secret
  #   readOnly: true
- Using storage bucket, e.g. s3://,gs://orazblob://, reference from here
Warning: this feature has not been released but it is developing.
oathkeeper:
  config:
    # e.g.:
    authenticators:
      jwt:
        config:
          jwks_urls:
            # S3 storage also supports S3-compatible endpoints served by Minio or Ceph.
            # See aws.ConfigFromURLParams (https://godoc.org/gocloud.dev/aws#ConfigFromURLParams) for more details on supported URL options for S3.
            - s3://my-bucket-name/rules.json
            - s3://my-bucket-name/rules.json?endpoint=minio.my-server.net
            - gs://gcp-bucket-name/rules.json
            - azblob://my-blob-container/rules.json
Oathkeeper-maester
This chart includes a helper chart in the form of Oathkeeper-maester, a k8s controller, which translates access rules object into a kubernetes native CustomResource. This component is disabled by default, but can be enabled by setting the proper flag:
$ helm install \
    --set 'maester.enabled=true' \
    ory/oathkeeper
Using fullnameOverride
If you use need to override the name of the oathkeeper resources such as the
deployment or services, the traditional fullnameOverride value is available.
If you use it and deploy maester as part of oathkeeper, make sure you also set
maester.oathkeeperFullnameOverride with the same value, so that the configmap
name generated by maester is properly computed with the new value.
Should you forget, helm will fail and remind you to.
Operation modes
The Oathkeeper Maester works in either of these two modes:
Controller mode In this mode, the controller is a dedicated deployment and scales independently from the Oathkeeper application. All communication with Oathkeeper is based on a configMap object, which stores the Oathkeeper configuration created based on the Rule custom resource. This mode requires giving elevated privileges to the Oathkeeper Maestercontroller to allow operations on the configMaps.
Sidecar mode In this mode, the Oathkeeper Maester controller runs as an
additional container in the Oathkeeper application Pod. All communication is
done on the local filesystem, which can be a shared tempfs, mounted directory
or a persistent volume, and the controller is scaled together with the
Oathkeeper application.
Upgrade
From 0.18.0
Since this version we support only kubernetes >= v1.18 for the ingress definition.
If you enabled ingresses you need to migrate values from:
ingress:
  proxy:
    hosts:
      - host: proxy.oathkeeper.localhost
        paths: ["/"]
  api:
    hosts:
      - host: api.oathkeeper.localhost
        paths: ["/"]
to
ingress:
  proxy:
    className: ""
    hosts:
      - host: proxy.oathkeeper.localhost
        paths:
          - path: /
            pathType: ImplementationSpecific
  api:
    className: ""
    hosts:
      - host: api.oathkeeper.localhost
        paths:
          - path: /
            pathType: ImplementationSpecific
where changes are on:
- introduce the classNameto specify the ingress class documentation that need to be used
- change pathsdefinition from an array of strings to an array of objects, where each object include thepathand thepathType(see path matching documentation)