3c1b70c355
* outposts/proxyv2: initial commit Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> add rs256 Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> more stuff Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> add forward auth an sign_out Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> match cookie name Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> re-add support for rs256 for backwards compat Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> add error handler Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> ensure unique user-agent is used Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> set cookie duration based on id_token expiry Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> build proxy v2 Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> add ssl Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> add basic auth and custom header support Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> add application cert loading Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> implement whitelist Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> add redis Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> migrate embedded outpost to v2 Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> remove old proxy Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> providers/proxy: make token expiration configurable Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> add metrics Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> fix tests Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * providers/proxy: only allow one redirect URI Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * fix docker build for proxy Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * remove default port offset Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * add AUTHENTIK_HOST_BROWSER Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * tests: fix e2e/integration tests not using proper tags Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * remove references of old port Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * fix user_attributes not being loaded correctly Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * cleanup dependencies Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org> * cleanup Signed-off-by: Jens Langhammer <jens.langhammer@beryju.org>
127 lines
3.5 KiB
Markdown
127 lines
3.5 KiB
Markdown
---
|
|
title: Manual Outpost deployment on Kubernetes
|
|
---
|
|
|
|
Use the following manifest, replacing all values surrounded with `__`.
|
|
|
|
Afterwards, configure the proxy provider to connect to `<service name>.<namespace>.svc.cluster.local`, and update your Ingress to connect to the `authentik-outpost` service.
|
|
|
|
```yaml
|
|
apiVersion: v1
|
|
kind: Secret
|
|
metadata:
|
|
labels:
|
|
app.kubernetes.io/instance: __OUTPOST_NAME__
|
|
app.kubernetes.io/managed-by: goauthentik.io
|
|
app.kubernetes.io/name: authentik-proxy
|
|
app.kubernetes.io/version: 2021.8.4
|
|
name: authentik-outpost-api
|
|
stringData:
|
|
authentik_host: "__AUTHENTIK_URL__"
|
|
authentik_host_insecure: "true"
|
|
token: "__AUTHENTIK_TOKEN__"
|
|
type: Opaque
|
|
---
|
|
apiVersion: v1
|
|
kind: Service
|
|
metadata:
|
|
labels:
|
|
app.kubernetes.io/instance: __OUTPOST_NAME__
|
|
app.kubernetes.io/managed-by: goauthentik.io
|
|
app.kubernetes.io/name: authentik-proxy
|
|
app.kubernetes.io/version: 2021.8.4
|
|
name: authentik-outpost
|
|
spec:
|
|
ports:
|
|
- name: http
|
|
port: 9000
|
|
protocol: TCP
|
|
targetPort: http
|
|
- name: https
|
|
port: 9443s
|
|
protocol: TCP
|
|
targetPort: https
|
|
type: ClusterIP
|
|
selector:
|
|
app.kubernetes.io/managed-by: goauthentik.io
|
|
app.kubernetes.io/name: authentik-outpost
|
|
app.kubernetes.io/instance: __OUTPOST_NAME__
|
|
---
|
|
apiVersion: apps/v1
|
|
kind: Deployment
|
|
metadata:
|
|
labels:
|
|
app.kubernetes.io/instance: __OUTPOST_NAME__
|
|
app.kubernetes.io/managed-by: goauthentik.io
|
|
app.kubernetes.io/name: authentik-proxy
|
|
app.kubernetes.io/version: 2021.8.4
|
|
name: authentik-outpost
|
|
spec:
|
|
selector:
|
|
matchLabels:
|
|
app.kubernetes.io/instance: __OUTPOST_NAME__
|
|
app.kubernetes.io/managed-by: goauthentik.io
|
|
app.kubernetes.io/name: authentik-proxy
|
|
app.kubernetes.io/version: 2021.8.4
|
|
template:
|
|
metadata:
|
|
labels:
|
|
app.kubernetes.io/instance: __OUTPOST_NAME__
|
|
app.kubernetes.io/managed-by: goauthentik.io
|
|
app.kubernetes.io/name: authentik-proxy
|
|
app.kubernetes.io/version: 2021.8.4
|
|
spec:
|
|
containers:
|
|
- env:
|
|
- name: AUTHENTIK_HOST
|
|
valueFrom:
|
|
secretKeyRef:
|
|
key: authentik_host
|
|
name: authentik-outpost-api
|
|
- name: AUTHENTIK_TOKEN
|
|
valueFrom:
|
|
secretKeyRef:
|
|
key: token
|
|
name: authentik-outpost-api
|
|
- name: AUTHENTIK_INSECURE
|
|
valueFrom:
|
|
secretKeyRef:
|
|
key: authentik_host_insecure
|
|
name: authentik-outpost-api
|
|
image: ghcr.io/goauthentik/proxy:2021.8.4
|
|
name: proxy
|
|
ports:
|
|
- containerPort: 9000
|
|
name: http
|
|
protocol: TCP
|
|
- containerPort: 9443
|
|
name: https
|
|
protocol: TCP
|
|
---
|
|
apiVersion: networking.k8s.io/v1
|
|
kind: Ingress
|
|
metadata:
|
|
annotations:
|
|
nginx.ingress.kubernetes.io/affinity: cookie
|
|
nginx.ingress.kubernetes.io/proxy-buffer-size: 16k
|
|
nginx.ingress.kubernetes.io/proxy-buffers-number: "4"
|
|
traefik.ingress.kubernetes.io/affinity: "true"
|
|
labels:
|
|
app.kubernetes.io/instance: __OUTPOST_NAME__
|
|
app.kubernetes.io/managed-by: goauthentik.io
|
|
app.kubernetes.io/name: authentik-proxy
|
|
app.kubernetes.io/version: 2021.8.4
|
|
name: authentik-outpost
|
|
spec:
|
|
rules:
|
|
- host: __EXTERNAL_HOSTNAME__
|
|
http:
|
|
paths:
|
|
- backend:
|
|
service:
|
|
name: authentik-outpost
|
|
port:
|
|
name: http
|
|
path: /
|
|
```
|