apiVersion: v1 kind: ServiceAccount metadata: name: {{ include "freedns-webhook.fullname" . }} labels: app: {{ include "freedns-webhook.name" . }} chart: {{ include "freedns-webhook.chart" . }} release: {{ .Release.Name }} heritage: {{ .Release.Service }} --- apiVersion: rbac.authorization.k8s.io/v1 kind: Role metadata: name: {{ include "freedns-webhook.fullname" . }}:secret-read namespace: {{ .Release.Namespace }} labels: app: {{ include "freedns-webhook.name" . }} chart: {{ include "freedns-webhook.chart" . }} release: {{ .Release.Name }} heritage: {{ .Release.Service }} rules: - apiGroups: - '' resources: - 'secrets' verbs: - 'get' --- # Grant the webhook permission to read the secret apiVersion: rbac.authorization.k8s.io/v1 kind: RoleBinding metadata: name: {{ include "freedns-webhook.fullname" . }}:secret-read namespace: {{ .Release.Namespace }} labels: app: {{ include "freedns-webhook.name" . }} chart: {{ include "freedns-webhook.chart" . }} release: {{ .Release.Name }} heritage: {{ .Release.Service }} roleRef: apiGroup: rbac.authorization.k8s.io kind: Role name: {{ include "freedns-webhook.fullname" . }}:secret-read subjects: - apiGroup: "" kind: ServiceAccount name: {{ include "freedns-webhook.fullname" . }} namespace: {{ .Release.Namespace }} --- # Grant the webhook permission to read the ConfigMap containing the Kubernetes # apiserver's requestheader-ca-certificate. # This ConfigMap is automatically created by the Kubernetes apiserver. apiVersion: rbac.authorization.k8s.io/v1 kind: RoleBinding metadata: name: {{ include "freedns-webhook.fullname" . }}:webhook-authentication-reader namespace: kube-system labels: app: {{ include "freedns-webhook.name" . }} chart: {{ include "freedns-webhook.chart" . }} release: {{ .Release.Name }} heritage: {{ .Release.Service }} roleRef: apiGroup: rbac.authorization.k8s.io kind: Role name: extension-apiserver-authentication-reader subjects: - apiGroup: "" kind: ServiceAccount name: {{ include "freedns-webhook.fullname" . }} namespace: {{ .Release.Namespace }} --- # apiserver gets the auth-delegator role to delegate auth decisions to # the core apiserver apiVersion: rbac.authorization.k8s.io/v1 kind: ClusterRoleBinding metadata: name: {{ include "freedns-webhook.fullname" . }}:auth-delegator labels: app: {{ include "freedns-webhook.name" . }} chart: {{ include "freedns-webhook.chart" . }} release: {{ .Release.Name }} heritage: {{ .Release.Service }} roleRef: apiGroup: rbac.authorization.k8s.io kind: ClusterRole name: system:auth-delegator subjects: - apiGroup: "" kind: ServiceAccount name: {{ include "freedns-webhook.fullname" . }} namespace: {{ .Release.Namespace }} --- # Grant cert-manager permission to validate using our apiserver apiVersion: rbac.authorization.k8s.io/v1 kind: ClusterRole metadata: name: {{ include "freedns-webhook.fullname" . }}:domain-solver labels: app: {{ include "freedns-webhook.name" . }} chart: {{ include "freedns-webhook.chart" . }} release: {{ .Release.Name }} heritage: {{ .Release.Service }} rules: - apiGroups: - {{ .Values.groupName }} resources: - '*' verbs: - 'create' --- apiVersion: rbac.authorization.k8s.io/v1 kind: ClusterRoleBinding metadata: name: {{ include "freedns-webhook.fullname" . }}:domain-solver labels: app: {{ include "freedns-webhook.name" . }} chart: {{ include "freedns-webhook.chart" . }} release: {{ .Release.Name }} heritage: {{ .Release.Service }} roleRef: apiGroup: rbac.authorization.k8s.io kind: ClusterRole name: {{ include "freedns-webhook.fullname" . }}:domain-solver subjects: - apiGroup: "" kind: ServiceAccount name: {{ .Values.certManager.serviceAccountName }} namespace: {{ .Values.certManager.namespace }} --- # Grant pod account permission to validate using our apiserver apiVersion: rbac.authorization.k8s.io/v1 kind: ClusterRole metadata: name: {{ include "freedns-webhook.fullname" . }}:flowcontrol labels: app: {{ include "freedns-webhook.name" . }} chart: {{ include "freedns-webhook.chart" . }} release: {{ .Release.Name }} heritage: {{ .Release.Service }} rules: - apiGroups: - "flowcontrol.apiserver.k8s.io" resources: - 'prioritylevelconfigurations' - 'flowschemas' verbs: - 'list' - 'watch' --- apiVersion: rbac.authorization.k8s.io/v1 kind: ClusterRoleBinding metadata: name: {{ include "freedns-webhook.fullname" . }}:flowcontrol labels: app: {{ include "freedns-webhook.name" . }} chart: {{ include "freedns-webhook.chart" . }} release: {{ .Release.Name }} heritage: {{ .Release.Service }} roleRef: apiGroup: rbac.authorization.k8s.io kind: ClusterRole name: {{ include "freedns-webhook.fullname" . }}:flowcontrol subjects: - apiGroup: "" kind: ServiceAccount name: {{ include "freedns-webhook.fullname" . }} namespace: {{ .Release.Namespace }}