12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- {{/* RBAC Class */}}
- {{/* Call this template:
- {{ include "ix.v1.common.class.rbac" (dict "rootCtx" $ "objectData" $objectData) }}
- rootCtx: The root context of the chart.
- objectData:
- name: The name of the rbac.
- labels: The labels of the rbac.
- annotations: The annotations of the rbac.
- clusterWide: Whether the rbac is cluster wide or not.
- rules: The rules of the rbac.
- subjects: The subjects of the rbac.
- */}}
- {{- define "ix.v1.common.class.rbac" -}}
- {{- $rootCtx := .rootCtx -}}
- {{- $objectData := .objectData }}
- ---
- apiVersion: rbac.authorization.k8s.io/v1
- kind: {{ ternary "ClusterRole" "Role" $objectData.clusterWide }}
- metadata:
- name: {{ $objectData.name }}
- {{- if not $objectData.clusterWide }}
- namespace: {{ $rootCtx.Release.Namespace }}
- {{- end }}
- {{- $labels := (mustMerge ($objectData.labels | default dict) (include "ix.v1.common.lib.metadata.allLabels" $rootCtx | fromYaml)) -}}
- {{- with (include "ix.v1.common.lib.metadata.render" (dict "rootCtx" $rootCtx "labels" $labels) | trim) }}
- labels:
- {{- . | nindent 4 }}
- {{- end -}}
- {{- $annotations := (mustMerge ($objectData.annotations | default dict) (include "ix.v1.common.lib.metadata.allAnnotations" $rootCtx | fromYaml)) -}}
- {{- with (include "ix.v1.common.lib.metadata.render" (dict "rootCtx" $rootCtx "annotations" $annotations) | trim) }}
- annotations:
- {{- . | nindent 4 }}
- {{- end }}
- rules:
- {{- include "ix.v1.common.lib.rbac.rules" (dict "rootCtx" $rootCtx "objectData" $objectData) | trim | nindent 2 }}
- ---
- apiVersion: rbac.authorization.k8s.io/v1
- kind: {{ ternary "ClusterRoleBinding" "RoleBinding" $objectData.clusterWide }}
- metadata:
- name: {{ $objectData.name }}
- {{- if not $objectData.clusterWide }}
- namespace: {{ $rootCtx.Release.Namespace }}
- {{- end }}
- {{- $labels := (mustMerge ($objectData.labels | default dict) (include "ix.v1.common.lib.metadata.allLabels" $rootCtx | fromYaml)) -}}
- {{- with (include "ix.v1.common.lib.metadata.render" (dict "rootCtx" $rootCtx "labels" $labels) | trim) }}
- labels:
- {{- . | nindent 4 }}
- {{- end -}}
- {{- $annotations := (mustMerge ($objectData.annotations | default dict) (include "ix.v1.common.lib.metadata.allAnnotations" $rootCtx | fromYaml)) -}}
- {{- with (include "ix.v1.common.lib.metadata.render" (dict "rootCtx" $rootCtx "annotations" $annotations) | trim) }}
- annotations:
- {{- . | nindent 4 }}
- {{- end }}
- roleRef:
- apiGroup: rbac.authorization.k8s.io
- kind: {{ ternary "ClusterRole" "Role" $objectData.clusterWide }}
- name: {{ $objectData.name }}
- subjects:
- {{- include "ix.v1.common.lib.rbac.serviceAccount" (dict "rootCtx" $rootCtx "objectData" $objectData) | trim | nindent 2 }}
- {{- include "ix.v1.common.lib.rbac.subjects" (dict "rootCtx" $rootCtx "objectData" $objectData) | trim | nindent 2 }}
- {{- end -}}
|