mirror of
https://github.com/JamesTurland/JimsGarage.git
synced 2025-10-02 16:36:17 +00:00
add-kubernetes
This commit is contained in:
16
Vaultwarden/Kubernetes/default-headers.yaml
Normal file
16
Vaultwarden/Kubernetes/default-headers.yaml
Normal 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
|
53
Vaultwarden/Kubernetes/deployment.yaml
Normal file
53
Vaultwarden/Kubernetes/deployment.yaml
Normal 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
|
27
Vaultwarden/Kubernetes/ingress.yaml
Normal file
27
Vaultwarden/Kubernetes/ingress.yaml
Normal 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
|
11
Vaultwarden/Kubernetes/ipwhitelist.yaml
Normal file
11
Vaultwarden/Kubernetes/ipwhitelist.yaml
Normal 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
|
35
Vaultwarden/Kubernetes/networkpolicy.yaml
Normal file
35
Vaultwarden/Kubernetes/networkpolicy.yaml
Normal 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"
|
Reference in New Issue
Block a user