blob: 76241da1ceae3a9df8a1582aeb8d34e785e078ab [file] [log] [blame]
Giorgi Lekveishvili4ec4c022024-08-17 15:09:24 +04001# apiVersion: v1
2# kind: PersistentVolumeClaim
3# metadata:
4# name: tailscale
5# namespace: {{ .Release.Namespace }}
6# annotations:
7# helm.sh/resource-policy: keep
8# spec:
9# accessModes:
10# - ReadWriteOnce
11# resources:
12# requests:
13# storage: 1Gi
14---
15apiVersion: headscale.dodo.cloud/v1
16kind: HeadscaleUser
17metadata:
18 name: {{ .Values.username }}
19 namespace: {{ .Release.Namespace }}
20spec:
21 headscaleAddress: {{ .Values.apiServer }}
22 name: {{ .Values.username }}
23 preAuthKey:
24 enabled: true
25 secretName: {{ .Values.preAuthKeySecret }}
26---
27apiVersion: apps/v1
28kind: Deployment
29metadata:
30 name: tailscale
31 namespace: {{ .Release.Namespace }}
32spec:
33 selector:
34 matchLabels:
35 app: tailscale
36 replicas: 1
37 template:
38 metadata:
39 labels:
40 app: tailscale
41 spec:
42 # volumes:
43 # - name: tailscale
44 # persistentVolumeClaim:
45 # claimName: tailscale
46 containers:
47 - name: tailscale
48 image: {{ .Values.image.repository }}:{{ .Values.image.tag }}
49 imagePullPolicy: {{ .Values.image.pullPolicy }}
50 securityContext:
51 privileged: true
52 capabilities:
53 add:
54 - NET_ADMIN
55 env:
56 - name: TS_KUBE_SECRET
57 value: {{ .Values.preAuthKeySecret }}
58 # - name: TS_STATE_DIR
59 # value: /tailscale-state
60 # - name: TS_AUTHKEY
61 # valueFrom:
62 # secretKeyRef:
63 # name: {{ .Values.preAuthKeySecret }}
64 # key: key
65 - name: TS_HOSTNAME
66 value: {{ .Values.hostname }}
67 - name: TS_ROUTES
68 value: {{ .Values.ipSubnet }}
69 - name: TS_EXTRA_ARGS
70 value: --login-server={{ .Values.loginServer }}
71 # volumeMounts:
72 # - name: tailscale
73 # mountPath: /tailscale-state
74---
75apiVersion: rbac.authorization.k8s.io/v1
76kind: Role
77metadata:
78 name: secrets
79 namespace: {{ .Release.Namespace }}
80rules:
81- apiGroups: [""]
82 resources: ["secrets"]
83 verbs: ["get", "watch", "list", "patch", "update"]
84---
85apiVersion: rbac.authorization.k8s.io/v1
86kind: RoleBinding
87metadata:
88 name: secrets
89 namespace: {{ .Release.Namespace }}
90subjects:
91- kind: ServiceAccount
92 name: default
93 namespace: {{ .Release.Namespace }}
94roleRef:
95 kind: Role
96 name: secrets
97 apiGroup: rbac.authorization.k8s.io