rbac.yaml 7.0 KB

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