87 lines
2.9 KiB
Django/Jinja
87 lines
2.9 KiB
Django/Jinja
kind: ServiceAccount
|
|
apiVersion: v1
|
|
metadata:
|
|
name: vsphere-csi-controller
|
|
namespace: "{{ vsphere_csi_namespace }}"
|
|
---
|
|
kind: ClusterRole
|
|
apiVersion: rbac.authorization.k8s.io/v1
|
|
metadata:
|
|
name: vsphere-csi-controller-role
|
|
rules:
|
|
- apiGroups: [""]
|
|
resources: ["nodes", "pods", "configmaps"]
|
|
verbs: ["get", "list", "watch"]
|
|
- apiGroups: [""]
|
|
resources: ["persistentvolumeclaims"]
|
|
verbs: ["get", "list", "watch", "update"]
|
|
{% if external_vsphere_version >= "7.0" %}
|
|
- apiGroups: [""]
|
|
resources: ["persistentvolumeclaims/status"]
|
|
{% if external_vsphere_version >= "7.0u1" %}
|
|
verbs: ["patch"]
|
|
{% else %}
|
|
verbs: ["update", "patch"]
|
|
{% endif %}
|
|
{% endif %}
|
|
- apiGroups: [""]
|
|
resources: ["persistentvolumes"]
|
|
verbs: ["get", "list", "watch", "create", "update", "delete", "patch"]
|
|
- apiGroups: [""]
|
|
resources: ["events"]
|
|
verbs: ["get", "list", "watch", "create", "update", "patch"]
|
|
{% if vsphere_csi_controller is version('v2.0.0', '>=') %}
|
|
- apiGroups: ["coordination.k8s.io"]
|
|
resources: ["leases"]
|
|
verbs: ["get", "watch", "list", "delete", "update", "create"]
|
|
{% endif %}
|
|
- apiGroups: ["storage.k8s.io"]
|
|
resources: ["storageclasses","csinodes"]
|
|
verbs: ["get", "list", "watch"]
|
|
- apiGroups: ["storage.k8s.io"]
|
|
resources: ["volumeattachments"]
|
|
verbs: ["get", "list", "watch", "patch", "update"]
|
|
- apiGroups: ["cns.vmware.com"]
|
|
resources: ["triggercsifullsyncs"]
|
|
verbs: ["create", "get", "update", "watch", "list"]
|
|
- apiGroups: ["cns.vmware.com"]
|
|
resources: ["cnsvspherevolumemigrations"]
|
|
verbs: ["create", "get", "list", "watch", "update", "delete"]
|
|
- apiGroups: ["apiextensions.k8s.io"]
|
|
resources: ["customresourcedefinitions"]
|
|
verbs: ["get", "create", "update"]
|
|
- apiGroups: ["cns.vmware.com"]
|
|
resources: ["cnsvolumeoperationrequests"]
|
|
verbs: ["create", "get", "list", "update", "delete"]
|
|
- apiGroups: [ "cns.vmware.com" ]
|
|
resources: [ "csinodetopologies" ]
|
|
verbs: ["get", "update", "watch", "list"]
|
|
- apiGroups: ["storage.k8s.io"]
|
|
resources: ["volumeattachments/status"]
|
|
verbs: ["patch"]
|
|
- apiGroups: [ "snapshot.storage.k8s.io" ]
|
|
resources: [ "volumesnapshots" ]
|
|
verbs: [ "get", "list" ]
|
|
- apiGroups: [ "snapshot.storage.k8s.io" ]
|
|
resources: [ "volumesnapshotclasses" ]
|
|
verbs: [ "watch", "get", "list" ]
|
|
- apiGroups: [ "snapshot.storage.k8s.io" ]
|
|
resources: [ "volumesnapshotcontents" ]
|
|
verbs: [ "create", "get", "list", "watch", "update", "delete", "patch" ]
|
|
- apiGroups: [ "snapshot.storage.k8s.io" ]
|
|
resources: [ "volumesnapshotcontents/status" ]
|
|
verbs: [ "update", "patch" ]
|
|
---
|
|
kind: ClusterRoleBinding
|
|
apiVersion: rbac.authorization.k8s.io/v1
|
|
metadata:
|
|
name: vsphere-csi-controller-binding
|
|
subjects:
|
|
- kind: ServiceAccount
|
|
name: vsphere-csi-controller
|
|
namespace: "{{ vsphere_csi_namespace }}"
|
|
roleRef:
|
|
kind: ClusterRole
|
|
name: vsphere-csi-controller-role
|
|
apiGroup: rbac.authorization.k8s.io
|