blob: 76241da1ceae3a9df8a1582aeb8d34e785e078ab [file] [log] [blame]
Giorgi Lekveishvilicb64b162023-06-16 11:51:00 +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
Giorgi Lekveishvili2c1253c2023-06-13 12:06:42 +040014---
Giorgi Lekveishvili81ba75e2023-06-15 21:14:21 +040015apiVersion: headscale.dodo.cloud/v1
16kind: HeadscaleUser
17metadata:
18 name: {{ .Values.username }}
19 namespace: {{ .Release.Namespace }}
20spec:
Giorgi Lekveishvili2a1c3522023-06-21 14:15:08 +040021 headscaleAddress: {{ .Values.apiServer }}
Giorgi Lekveishvili81ba75e2023-06-15 21:14:21 +040022 name: {{ .Values.username }}
23 preAuthKey:
24 enabled: true
25 secretName: {{ .Values.preAuthKeySecret }}
26---
Giorgi Lekveishvili2c1253c2023-06-13 12:06:42 +040027apiVersion: 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:
Giorgi Lekveishvilicb64b162023-06-16 11:51:00 +040042 # volumes:
43 # - name: tailscale
44 # persistentVolumeClaim:
45 # claimName: tailscale
Giorgi Lekveishvili2c1253c2023-06-13 12:06:42 +040046 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
Giorgi Lekveishvilicb64b162023-06-16 11:51:00 +040057 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
Giorgi Lekveishvili81ba75e2023-06-15 21:14:21 +040065 - name: TS_HOSTNAME
66 value: {{ .Values.hostname }}
67 - name: TS_ROUTES
68 value: {{ .Values.ipSubnet }}
Giorgi Lekveishvili2c1253c2023-06-13 12:06:42 +040069 - name: TS_EXTRA_ARGS
Giorgi Lekveishvili117694a2023-06-16 11:35:07 +040070 value: --login-server={{ .Values.loginServer }}
Giorgi Lekveishvilicb64b162023-06-16 11:51:00 +040071 # volumeMounts:
72 # - name: tailscale
73 # mountPath: /tailscale-state
Giorgi Lekveishvili488ac3b2023-06-16 12:14:11 +040074---
75apiVersion: rbac.authorization.k8s.io/v1
76kind: Role
77metadata:
78 name: secrets
79 namespace: {{ .Release.Namespace }}
80rules:
81- apiGroups: [""]
82 resources: ["secrets"]
Giorgi Lekveishvili89212972023-06-16 12:32:06 +040083 verbs: ["get", "watch", "list", "patch", "update"]
Giorgi Lekveishvili488ac3b2023-06-16 12:14:11 +040084---
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