add-kubernetes

This commit is contained in:
James Turland
2024-07-08 11:19:54 +01:00
parent 0cd8339e6e
commit ef6ba4bd22
42 changed files with 1375 additions and 0 deletions

View File

@@ -0,0 +1,16 @@
apiVersion: traefik.io/v1alpha1
kind: Middleware
metadata:
name: default-headers
namespace: vaultwarden
spec:
headers:
browserXssFilter: true
contentTypeNosniff: true
forceSTSHeader: true
stsIncludeSubdomains: true
stsPreload: true
stsSeconds: 15552000
customFrameOptionsValue: SAMEORIGIN
customRequestHeaders:
X-Forwarded-Proto: https

View File

@@ -0,0 +1,53 @@
---
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: vaultwarden
app.kubernetes.io/instance: vaultwarden
name: vaultwarden
namespace: vaultwarden
spec:
replicas: 1
selector:
matchLabels:
app: vaultwarden
template:
metadata:
labels:
app: vaultwarden
app.kubernetes.io/name: vaultwarden
spec:
nodeSelector:
worker: "true"
containers:
- image: vaultwarden/server:latest
imagePullPolicy: Always
name: vaultwarden
ports:
- containerPort: 80
name: web
protocol: TCP
volumeMounts:
- mountPath: /data/
name: vaultwarden
volumes:
- name: vaultwarden
persistentVolumeClaim:
claimName: vaultwarden
---
apiVersion: v1
kind: Service
metadata:
labels:
app: vaultwarden
name: vaultwarden
namespace: vaultwarden
spec:
ports:
- name: web-tcp
port: 80
protocol: TCP
targetPort: 80
selector:
app: vaultwarden

View File

@@ -0,0 +1,27 @@
---
apiVersion: traefik.io/v1alpha1
kind: IngressRoute
metadata:
name: vaultwarden
namespace: vaultwarden
annotations:
kubernetes.io/ingress.class: traefik-external
spec:
entryPoints:
- websecure
routes:
- match: Host(`www.vaultwarden.yourdomain.co.uk`)
kind: Rule
services:
- name: vaultwarden
port: 80
- match: Host(`vaultwarden.yourdomain.co.uk`)
kind: Rule
services:
- name: vaultwarden
port: 80
middlewares:
- name: default-headers
- name: local-ipwhitelist
tls:
secretName: yourdomain-tls

View File

@@ -0,0 +1,11 @@
apiVersion: traefik.io/v1alpha1
kind: Middleware
metadata:
name: local-ipwhitelist
namespace: vaultwarden
spec:
ipWhiteList:
sourceRange:
- 10.0.0.0/8
- 172.16.0.0/12
- 192.168.0.0/16

View File

@@ -0,0 +1,35 @@
kind: NetworkPolicy
apiVersion: networking.k8s.io/v1
metadata:
name: allow-internet-only
namespace: vaultwarden
spec:
podSelector: {}
policyTypes:
- Egress
- Ingress
egress:
- to:
- ipBlock:
cidr: "0.0.0.0/0"
except:
- "10.0.0.0/8"
- "172.16.0.0/12"
- "192.168.0.0/16"
- to:
- namespaceSelector:
matchLabels:
kubernetes.io/metadata.name: "kube-system"
- podSelector:
matchLabels:
k8s-app: "kube-dns"
ingress:
- from:
- ipBlock:
cidr: "10.0.0.0/8"
- from:
- ipBlock:
cidr: "172.16.0.0/12"
- from:
- ipBlock:
cidr: "192.168.0.0/16"