rbac.yaml 7.4 KB

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