rbac.yaml 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432
  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. {{- if .Values.processClusterStore }}
  21. - "clustersecretstores"
  22. {{- end }}
  23. - "externalsecrets"
  24. {{- if .Values.processClusterExternalSecret }}
  25. - "clusterexternalsecrets"
  26. {{- end }}
  27. {{- if .Values.processPushSecret }}
  28. - "pushsecrets"
  29. {{- end }}
  30. {{- if .Values.processClusterPushSecret }}
  31. - "clusterpushsecrets"
  32. {{- end }}
  33. verbs:
  34. - "get"
  35. - "list"
  36. - "watch"
  37. - apiGroups:
  38. - "external-secrets.io"
  39. resources:
  40. - "externalsecrets"
  41. - "externalsecrets/status"
  42. {{- if .Values.openshiftFinalizers }}
  43. - "externalsecrets/finalizers"
  44. {{- end }}
  45. - "secretstores"
  46. - "secretstores/status"
  47. {{- if .Values.openshiftFinalizers }}
  48. - "secretstores/finalizers"
  49. {{- end }}
  50. {{- if .Values.processClusterStore }}
  51. - "clustersecretstores"
  52. - "clustersecretstores/status"
  53. {{- if .Values.openshiftFinalizers }}
  54. - "clustersecretstores/finalizers"
  55. {{- end }}
  56. {{- end }}
  57. {{- if .Values.processClusterExternalSecret }}
  58. - "clusterexternalsecrets"
  59. - "clusterexternalsecrets/status"
  60. {{- if .Values.openshiftFinalizers }}
  61. - "clusterexternalsecrets/finalizers"
  62. {{- end }}
  63. {{- end }}
  64. {{- if .Values.processPushSecret }}
  65. - "pushsecrets"
  66. - "pushsecrets/status"
  67. {{- if .Values.openshiftFinalizers }}
  68. - "pushsecrets/finalizers"
  69. {{- end }}
  70. {{- end }}
  71. {{- if .Values.processClusterPushSecret }}
  72. - "clusterpushsecrets"
  73. - "clusterpushsecrets/status"
  74. {{- if .Values.openshiftFinalizers }}
  75. - "clusterpushsecrets/finalizers"
  76. {{- end }}
  77. {{- end }}
  78. verbs:
  79. - "get"
  80. - "update"
  81. - "patch"
  82. - apiGroups:
  83. - "generators.external-secrets.io"
  84. resources:
  85. - "generatorstates"
  86. verbs:
  87. - "get"
  88. - "list"
  89. - "watch"
  90. - "create"
  91. - "update"
  92. - "patch"
  93. - "delete"
  94. - "deletecollection"
  95. - apiGroups:
  96. - "generators.external-secrets.io"
  97. resources:
  98. - "acraccesstokens"
  99. {{- if .Values.processClusterGenerator }}
  100. - "clustergenerators"
  101. {{- end }}
  102. - "ecrauthorizationtokens"
  103. - "fakes"
  104. - "gcraccesstokens"
  105. - "githubaccesstokens"
  106. - "quayaccesstokens"
  107. - "passwords"
  108. - "sshkeys"
  109. - "stssessiontokens"
  110. - "uuids"
  111. - "vaultdynamicsecrets"
  112. - "webhooks"
  113. - "grafanas"
  114. - "mfas"
  115. verbs:
  116. - "get"
  117. - "list"
  118. - "watch"
  119. - apiGroups:
  120. - ""
  121. resources:
  122. - "serviceaccounts"
  123. - "namespaces"
  124. verbs:
  125. - "get"
  126. - "list"
  127. - "watch"
  128. {{- if .Values.processClusterExternalSecret }}
  129. - apiGroups:
  130. - ""
  131. resources:
  132. - "namespaces"
  133. verbs:
  134. - "update"
  135. - "patch"
  136. {{- end }}
  137. - apiGroups:
  138. - ""
  139. resources:
  140. - "configmaps"
  141. verbs:
  142. - "get"
  143. - "list"
  144. - "watch"
  145. - apiGroups:
  146. - ""
  147. resources:
  148. - "secrets"
  149. verbs:
  150. - "get"
  151. - "list"
  152. - "watch"
  153. - "create"
  154. - "update"
  155. - "delete"
  156. - "patch"
  157. - apiGroups:
  158. - ""
  159. resources:
  160. - "serviceaccounts/token"
  161. verbs:
  162. - "create"
  163. - apiGroups:
  164. - ""
  165. resources:
  166. - "events"
  167. verbs:
  168. - "create"
  169. - "patch"
  170. - apiGroups:
  171. - "external-secrets.io"
  172. resources:
  173. - "externalsecrets"
  174. verbs:
  175. - "create"
  176. - "update"
  177. - "delete"
  178. {{- if .Values.processPushSecret }}
  179. - apiGroups:
  180. - "external-secrets.io"
  181. resources:
  182. - "pushsecrets"
  183. verbs:
  184. - "create"
  185. - "update"
  186. - "delete"
  187. {{- end }}
  188. ---
  189. apiVersion: rbac.authorization.k8s.io/v1
  190. {{- if and .Values.scopedNamespace .Values.scopedRBAC }}
  191. kind: Role
  192. {{- else }}
  193. kind: ClusterRole
  194. {{- end }}
  195. metadata:
  196. name: {{ include "external-secrets.fullname" . }}-view
  197. {{- if and .Values.scopedNamespace .Values.scopedRBAC }}
  198. namespace: {{ .Values.scopedNamespace | quote }}
  199. {{- end }}
  200. labels:
  201. {{- include "external-secrets.labels" . | nindent 4 }}
  202. {{- if .Values.rbac.aggregateToView }}
  203. rbac.authorization.k8s.io/aggregate-to-view: "true"
  204. {{- end }}
  205. {{- if .Values.rbac.aggregateToEdit }}
  206. rbac.authorization.k8s.io/aggregate-to-edit: "true"
  207. {{- end }}
  208. rbac.authorization.k8s.io/aggregate-to-admin: "true"
  209. rules:
  210. - apiGroups:
  211. - "external-secrets.io"
  212. resources:
  213. - "externalsecrets"
  214. - "secretstores"
  215. {{- if .Values.processClusterStore }}
  216. - "clustersecretstores"
  217. {{- end }}
  218. {{- if .Values.processPushSecret }}
  219. - "pushsecrets"
  220. {{- end }}
  221. {{- if .Values.processClusterPushSecret }}
  222. - "clusterpushsecrets"
  223. {{- end }}
  224. verbs:
  225. - "get"
  226. - "watch"
  227. - "list"
  228. - apiGroups:
  229. - "generators.external-secrets.io"
  230. resources:
  231. - "acraccesstokens"
  232. {{- if .Values.processClusterGenerator }}
  233. - "clustergenerators"
  234. {{- end }}
  235. - "ecrauthorizationtokens"
  236. - "fakes"
  237. - "gcraccesstokens"
  238. - "githubaccesstokens"
  239. - "quayaccesstokens"
  240. - "passwords"
  241. - "sshkeys"
  242. - "vaultdynamicsecrets"
  243. - "webhooks"
  244. - "grafanas"
  245. - "generatorstates"
  246. - "mfas"
  247. - "uuids"
  248. verbs:
  249. - "get"
  250. - "watch"
  251. - "list"
  252. ---
  253. apiVersion: rbac.authorization.k8s.io/v1
  254. {{- if and .Values.scopedNamespace .Values.scopedRBAC }}
  255. kind: Role
  256. {{- else }}
  257. kind: ClusterRole
  258. {{- end }}
  259. metadata:
  260. name: {{ include "external-secrets.fullname" . }}-edit
  261. {{- if and .Values.scopedNamespace .Values.scopedRBAC }}
  262. namespace: {{ .Values.scopedNamespace | quote }}
  263. {{- end }}
  264. labels:
  265. {{- include "external-secrets.labels" . | nindent 4 }}
  266. {{- if .Values.rbac.aggregateToEdit }}
  267. rbac.authorization.k8s.io/aggregate-to-edit: "true"
  268. {{- end }}
  269. rbac.authorization.k8s.io/aggregate-to-admin: "true"
  270. rules:
  271. - apiGroups:
  272. - "external-secrets.io"
  273. resources:
  274. - "externalsecrets"
  275. - "secretstores"
  276. {{- if .Values.processClusterStore }}
  277. - "clustersecretstores"
  278. {{- end }}
  279. {{- if .Values.processPushSecret }}
  280. - "pushsecrets"
  281. {{- end }}
  282. {{- if .Values.processClusterPushSecret }}
  283. - "clusterpushsecrets"
  284. {{- end }}
  285. verbs:
  286. - "create"
  287. - "delete"
  288. - "deletecollection"
  289. - "patch"
  290. - "update"
  291. - apiGroups:
  292. - "generators.external-secrets.io"
  293. resources:
  294. - "acraccesstokens"
  295. {{- if .Values.processClusterGenerator }}
  296. - "clustergenerators"
  297. {{- end }}
  298. - "ecrauthorizationtokens"
  299. - "fakes"
  300. - "gcraccesstokens"
  301. - "githubaccesstokens"
  302. - "quayaccesstokens"
  303. - "passwords"
  304. - "sshkeys"
  305. - "vaultdynamicsecrets"
  306. - "webhooks"
  307. - "grafanas"
  308. - "generatorstates"
  309. - "mfas"
  310. - "uuids"
  311. verbs:
  312. - "create"
  313. - "delete"
  314. - "deletecollection"
  315. - "patch"
  316. - "update"
  317. ---
  318. apiVersion: rbac.authorization.k8s.io/v1
  319. {{- if and .Values.scopedNamespace .Values.scopedRBAC }}
  320. kind: RoleBinding
  321. {{- else }}
  322. kind: ClusterRoleBinding
  323. {{- end }}
  324. metadata:
  325. name: {{ include "external-secrets.fullname" . }}-controller
  326. {{- if and .Values.scopedNamespace .Values.scopedRBAC }}
  327. namespace: {{ .Values.scopedNamespace | quote }}
  328. {{- end }}
  329. labels:
  330. {{- include "external-secrets.labels" . | nindent 4 }}
  331. roleRef:
  332. apiGroup: rbac.authorization.k8s.io
  333. {{- if and .Values.scopedNamespace .Values.scopedRBAC }}
  334. kind: Role
  335. {{- else }}
  336. kind: ClusterRole
  337. {{- end }}
  338. name: {{ include "external-secrets.fullname" . }}-controller
  339. subjects:
  340. - name: {{ include "external-secrets.serviceAccountName" . }}
  341. namespace: {{ template "external-secrets.namespace" . }}
  342. kind: ServiceAccount
  343. ---
  344. apiVersion: rbac.authorization.k8s.io/v1
  345. kind: Role
  346. metadata:
  347. name: {{ include "external-secrets.fullname" . }}-leaderelection
  348. namespace: {{ template "external-secrets.namespace" . }}
  349. labels:
  350. {{- include "external-secrets.labels" . | nindent 4 }}
  351. rules:
  352. - apiGroups:
  353. - ""
  354. resources:
  355. - "configmaps"
  356. resourceNames:
  357. - "external-secrets-controller"
  358. verbs:
  359. - "get"
  360. - "update"
  361. - "patch"
  362. - apiGroups:
  363. - ""
  364. resources:
  365. - "configmaps"
  366. verbs:
  367. - "create"
  368. - apiGroups:
  369. - "coordination.k8s.io"
  370. resources:
  371. - "leases"
  372. verbs:
  373. - "get"
  374. - "create"
  375. - "update"
  376. - "patch"
  377. ---
  378. apiVersion: rbac.authorization.k8s.io/v1
  379. kind: RoleBinding
  380. metadata:
  381. name: {{ include "external-secrets.fullname" . }}-leaderelection
  382. namespace: {{ template "external-secrets.namespace" . }}
  383. labels:
  384. {{- include "external-secrets.labels" . | nindent 4 }}
  385. roleRef:
  386. apiGroup: rbac.authorization.k8s.io
  387. kind: Role
  388. name: {{ include "external-secrets.fullname" . }}-leaderelection
  389. subjects:
  390. - kind: ServiceAccount
  391. name: {{ include "external-secrets.serviceAccountName" . }}
  392. namespace: {{ template "external-secrets.namespace" . }}
  393. {{- if .Values.rbac.servicebindings.create }}
  394. ---
  395. apiVersion: rbac.authorization.k8s.io/v1
  396. kind: ClusterRole
  397. metadata:
  398. name: {{ include "external-secrets.fullname" . }}-servicebindings
  399. labels:
  400. servicebinding.io/controller: "true"
  401. {{- include "external-secrets.labels" . | nindent 4 }}
  402. rules:
  403. - apiGroups:
  404. - "external-secrets.io"
  405. resources:
  406. - "externalsecrets"
  407. {{- if .Values.processPushSecret }}
  408. - "pushsecrets"
  409. {{- end }}
  410. verbs:
  411. - "get"
  412. - "list"
  413. - "watch"
  414. {{- end }}
  415. {{- end }}
  416. {{- if .Values.systemAuthDelegator }}
  417. ---
  418. apiVersion: rbac.authorization.k8s.io/v1
  419. kind: ClusterRoleBinding
  420. metadata:
  421. name: {{ include "external-secrets.fullname" . }}-auth-delegator
  422. labels:
  423. {{- include "external-secrets.labels" . | nindent 4 }}
  424. roleRef:
  425. apiGroup: rbac.authorization.k8s.io
  426. kind: ClusterRole
  427. name: system:auth-delegator
  428. subjects:
  429. - kind: ServiceAccount
  430. name: {{ include "external-secrets.serviceAccountName" . }}
  431. namespace: {{ template "external-secrets.namespace" . }}
  432. {{- end }}