rbac.yaml 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300
  1. {{- if .Values.rbac.create -}}
  2. apiVersion: rbac.authorization.k8s.io/v1
  3. {{- if and .Values.scopedNamespace .Values.scopedRBAC }}
  4. kind: Role
  5. {{- else }}
  6. kind: ClusterRole
  7. {{- end }}
  8. metadata:
  9. name: {{ include "external-secrets.fullname" . }}-controller
  10. {{- if and .Values.scopedNamespace .Values.scopedRBAC }}
  11. namespace: {{ .Values.scopedNamespace | quote }}
  12. {{- end }}
  13. labels:
  14. {{- include "external-secrets.labels" . | nindent 4 }}
  15. rules:
  16. - apiGroups:
  17. - "external-secrets.io"
  18. resources:
  19. - "secretstores"
  20. - "clustersecretstores"
  21. - "externalsecrets"
  22. - "clusterexternalsecrets"
  23. - "pushsecrets"
  24. verbs:
  25. - "get"
  26. - "list"
  27. - "watch"
  28. - apiGroups:
  29. - "external-secrets.io"
  30. resources:
  31. - "externalsecrets"
  32. - "externalsecrets/status"
  33. - "externalsecrets/finalizers"
  34. - "secretstores"
  35. - "secretstores/status"
  36. - "secretstores/finalizers"
  37. - "clustersecretstores"
  38. - "clustersecretstores/status"
  39. - "clustersecretstores/finalizers"
  40. - "clusterexternalsecrets"
  41. - "clusterexternalsecrets/status"
  42. - "clusterexternalsecrets/finalizers"
  43. - "pushsecrets"
  44. - "pushsecrets/status"
  45. - "pushsecrets/finalizers"
  46. verbs:
  47. - "update"
  48. - "patch"
  49. - apiGroups:
  50. - "generators.external-secrets.io"
  51. resources:
  52. - "acraccesstokens"
  53. - "ecrauthorizationtokens"
  54. - "fakes"
  55. - "gcraccesstokens"
  56. - "githubaccesstokens"
  57. - "passwords"
  58. - "vaultdynamicsecrets"
  59. - "webhooks"
  60. verbs:
  61. - "get"
  62. - "list"
  63. - "watch"
  64. - apiGroups:
  65. - ""
  66. resources:
  67. - "serviceaccounts"
  68. - "namespaces"
  69. verbs:
  70. - "get"
  71. - "list"
  72. - "watch"
  73. - apiGroups:
  74. - ""
  75. resources:
  76. - "configmaps"
  77. verbs:
  78. - "get"
  79. - "list"
  80. - "watch"
  81. - apiGroups:
  82. - ""
  83. resources:
  84. - "secrets"
  85. verbs:
  86. - "get"
  87. - "list"
  88. - "watch"
  89. - "create"
  90. - "update"
  91. - "delete"
  92. - "patch"
  93. - apiGroups:
  94. - ""
  95. resources:
  96. - "serviceaccounts/token"
  97. verbs:
  98. - "create"
  99. - apiGroups:
  100. - ""
  101. resources:
  102. - "events"
  103. verbs:
  104. - "create"
  105. - "patch"
  106. - apiGroups:
  107. - "external-secrets.io"
  108. resources:
  109. - "externalsecrets"
  110. verbs:
  111. - "create"
  112. - "update"
  113. - "delete"
  114. ---
  115. apiVersion: rbac.authorization.k8s.io/v1
  116. {{- if and .Values.scopedNamespace .Values.scopedRBAC }}
  117. kind: Role
  118. {{- else }}
  119. kind: ClusterRole
  120. {{- end }}
  121. metadata:
  122. name: {{ include "external-secrets.fullname" . }}-view
  123. {{- if and .Values.scopedNamespace .Values.scopedRBAC }}
  124. namespace: {{ .Values.scopedNamespace | quote }}
  125. {{- end }}
  126. labels:
  127. {{- include "external-secrets.labels" . | nindent 4 }}
  128. rbac.authorization.k8s.io/aggregate-to-view: "true"
  129. rbac.authorization.k8s.io/aggregate-to-edit: "true"
  130. rbac.authorization.k8s.io/aggregate-to-admin: "true"
  131. rules:
  132. - apiGroups:
  133. - "external-secrets.io"
  134. resources:
  135. - "externalsecrets"
  136. - "secretstores"
  137. - "clustersecretstores"
  138. - "pushsecrets"
  139. verbs:
  140. - "get"
  141. - "watch"
  142. - "list"
  143. - apiGroups:
  144. - "generators.external-secrets.io"
  145. resources:
  146. - "acraccesstokens"
  147. - "ecrauthorizationtokens"
  148. - "fakes"
  149. - "gcraccesstokens"
  150. - "githubaccesstokens"
  151. - "passwords"
  152. - "vaultdynamicsecrets"
  153. - "webhooks"
  154. verbs:
  155. - "get"
  156. - "watch"
  157. - "list"
  158. ---
  159. apiVersion: rbac.authorization.k8s.io/v1
  160. {{- if and .Values.scopedNamespace .Values.scopedRBAC }}
  161. kind: Role
  162. {{- else }}
  163. kind: ClusterRole
  164. {{- end }}
  165. metadata:
  166. name: {{ include "external-secrets.fullname" . }}-edit
  167. {{- if and .Values.scopedNamespace .Values.scopedRBAC }}
  168. namespace: {{ .Values.scopedNamespace | quote }}
  169. {{- end }}
  170. labels:
  171. {{- include "external-secrets.labels" . | nindent 4 }}
  172. rbac.authorization.k8s.io/aggregate-to-edit: "true"
  173. rbac.authorization.k8s.io/aggregate-to-admin: "true"
  174. rules:
  175. - apiGroups:
  176. - "external-secrets.io"
  177. resources:
  178. - "externalsecrets"
  179. - "secretstores"
  180. - "clustersecretstores"
  181. - "pushsecrets"
  182. verbs:
  183. - "create"
  184. - "delete"
  185. - "deletecollection"
  186. - "patch"
  187. - "update"
  188. - apiGroups:
  189. - "generators.external-secrets.io"
  190. resources:
  191. - "acraccesstokens"
  192. - "ecrauthorizationtokens"
  193. - "fakes"
  194. - "gcraccesstokens"
  195. - "githubaccesstokens"
  196. - "passwords"
  197. - "vaultdynamicsecrets"
  198. - "webhooks"
  199. verbs:
  200. - "create"
  201. - "delete"
  202. - "deletecollection"
  203. - "patch"
  204. - "update"
  205. ---
  206. apiVersion: rbac.authorization.k8s.io/v1
  207. {{- if and .Values.scopedNamespace .Values.scopedRBAC }}
  208. kind: RoleBinding
  209. {{- else }}
  210. kind: ClusterRoleBinding
  211. {{- end }}
  212. metadata:
  213. name: {{ include "external-secrets.fullname" . }}-controller
  214. {{- if and .Values.scopedNamespace .Values.scopedRBAC }}
  215. namespace: {{ .Values.scopedNamespace | quote }}
  216. {{- end }}
  217. labels:
  218. {{- include "external-secrets.labels" . | nindent 4 }}
  219. roleRef:
  220. apiGroup: rbac.authorization.k8s.io
  221. {{- if and .Values.scopedNamespace .Values.scopedRBAC }}
  222. kind: Role
  223. {{- else }}
  224. kind: ClusterRole
  225. {{- end }}
  226. name: {{ include "external-secrets.fullname" . }}-controller
  227. subjects:
  228. - name: {{ include "external-secrets.serviceAccountName" . }}
  229. namespace: {{ template "external-secrets.namespace" . }}
  230. kind: ServiceAccount
  231. ---
  232. apiVersion: rbac.authorization.k8s.io/v1
  233. kind: Role
  234. metadata:
  235. name: {{ include "external-secrets.fullname" . }}-leaderelection
  236. namespace: {{ template "external-secrets.namespace" . }}
  237. labels:
  238. {{- include "external-secrets.labels" . | nindent 4 }}
  239. rules:
  240. - apiGroups:
  241. - ""
  242. resources:
  243. - "configmaps"
  244. resourceNames:
  245. - "external-secrets-controller"
  246. verbs:
  247. - "get"
  248. - "update"
  249. - "patch"
  250. - apiGroups:
  251. - ""
  252. resources:
  253. - "configmaps"
  254. verbs:
  255. - "create"
  256. - apiGroups:
  257. - "coordination.k8s.io"
  258. resources:
  259. - "leases"
  260. verbs:
  261. - "get"
  262. - "create"
  263. - "update"
  264. - "patch"
  265. ---
  266. apiVersion: rbac.authorization.k8s.io/v1
  267. kind: RoleBinding
  268. metadata:
  269. name: {{ include "external-secrets.fullname" . }}-leaderelection
  270. namespace: {{ template "external-secrets.namespace" . }}
  271. labels:
  272. {{- include "external-secrets.labels" . | nindent 4 }}
  273. roleRef:
  274. apiGroup: rbac.authorization.k8s.io
  275. kind: Role
  276. name: {{ include "external-secrets.fullname" . }}-leaderelection
  277. subjects:
  278. - kind: ServiceAccount
  279. name: {{ include "external-secrets.serviceAccountName" . }}
  280. namespace: {{ template "external-secrets.namespace" . }}
  281. {{- if .Values.rbac.servicebindings.create }}
  282. ---
  283. apiVersion: rbac.authorization.k8s.io/v1
  284. kind: ClusterRole
  285. metadata:
  286. name: {{ include "external-secrets.fullname" . }}-servicebindings
  287. labels:
  288. servicebinding.io/controller: "true"
  289. {{- include "external-secrets.labels" . | nindent 4 }}
  290. rules:
  291. - apiGroups:
  292. - "external-secrets.io"
  293. resources:
  294. - "externalsecrets"
  295. verbs:
  296. - "get"
  297. - "list"
  298. - "watch"
  299. {{- end }}
  300. {{- end }}