rbac.yaml 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481
  1. {{- if .Values.rbac.create -}}
  2. apiVersion: rbac.authorization.k8s.io/v1
  3. {{- if .Values.scopedRBAC }}
  4. kind: Role
  5. {{- else }}
  6. kind: ClusterRole
  7. {{- end }}
  8. metadata:
  9. name: {{ include "external-secrets.fullname" . }}-controller
  10. {{- if .Values.scopedRBAC }}
  11. namespace: {{ .Values.scopedNamespace | default .Release.Namespace | 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. - "cloudsmithaccesstokens"
  100. {{- if .Values.processClusterGenerator }}
  101. - "clustergenerators"
  102. {{- end }}
  103. - "ecrauthorizationtokens"
  104. - "fakes"
  105. - "gcraccesstokens"
  106. - "githubaccesstokens"
  107. - "quayaccesstokens"
  108. - "passwords"
  109. - "sshkeys"
  110. - "stssessiontokens"
  111. - "uuids"
  112. - "vaultdynamicsecrets"
  113. - "webhooks"
  114. - "grafanas"
  115. - "mfas"
  116. - "beyondtrustworkloadcredentialsdynamicsecrets"
  117. verbs:
  118. - "get"
  119. - "list"
  120. - "watch"
  121. - apiGroups:
  122. - ""
  123. resources:
  124. - "serviceaccounts"
  125. - "namespaces"
  126. verbs:
  127. - "get"
  128. - "list"
  129. - "watch"
  130. {{- if .Values.processClusterExternalSecret }}
  131. - apiGroups:
  132. - ""
  133. resources:
  134. - "namespaces"
  135. verbs:
  136. - "update"
  137. - "patch"
  138. {{- end }}
  139. - apiGroups:
  140. - ""
  141. resources:
  142. - "configmaps"
  143. verbs:
  144. - "get"
  145. - "list"
  146. - "watch"
  147. - apiGroups:
  148. - ""
  149. resources:
  150. - "secrets"
  151. verbs:
  152. - "get"
  153. - "list"
  154. - "watch"
  155. - "create"
  156. - "update"
  157. - "delete"
  158. - "patch"
  159. {{- if .Values.genericTargets.enabled }}
  160. # Generic target permissions (ConfigMaps)
  161. - apiGroups:
  162. - ""
  163. resources:
  164. - "configmaps"
  165. verbs:
  166. - "create"
  167. - "update"
  168. - "delete"
  169. - "patch"
  170. {{- range .Values.genericTargets.resources }}
  171. # Custom resource permissions for non-Secret targets
  172. - apiGroups:
  173. - {{ .apiGroup | quote }}
  174. resources:
  175. {{- range .resources }}
  176. - {{ . | quote }}
  177. {{- end }}
  178. verbs:
  179. {{- range .verbs }}
  180. - {{ . | quote }}
  181. {{- end }}
  182. {{- end }}
  183. {{- end }}
  184. {{- if .Values.rbac.serviceAccountTokenCreate }}
  185. - apiGroups:
  186. - ""
  187. resources:
  188. - "serviceaccounts/token"
  189. verbs:
  190. - "create"
  191. {{- end }}
  192. - apiGroups:
  193. - ""
  194. resources:
  195. - "events"
  196. verbs:
  197. - "create"
  198. - "patch"
  199. {{- if .Values.processClusterExternalSecret }}
  200. - apiGroups:
  201. - "external-secrets.io"
  202. resources:
  203. - "externalsecrets"
  204. verbs:
  205. - "create"
  206. - "update"
  207. - "delete"
  208. {{- end }}
  209. {{- if .Values.processPushSecret }}
  210. - apiGroups:
  211. - "external-secrets.io"
  212. resources:
  213. - "pushsecrets"
  214. verbs:
  215. - "create"
  216. - "update"
  217. - "delete"
  218. {{- end }}
  219. {{- if .Values.metrics.listen.auth.enabled }}
  220. - apiGroups:
  221. - "authentication.k8s.io"
  222. resources:
  223. - "tokenreviews"
  224. verbs:
  225. - "create"
  226. - apiGroups:
  227. - "authorization.k8s.io"
  228. resources:
  229. - "subjectaccessreviews"
  230. verbs:
  231. - "create"
  232. {{- end }}
  233. ---
  234. apiVersion: rbac.authorization.k8s.io/v1
  235. {{- if .Values.scopedRBAC }}
  236. kind: Role
  237. {{- else }}
  238. kind: ClusterRole
  239. {{- end }}
  240. metadata:
  241. name: {{ include "external-secrets.fullname" . }}-view
  242. {{- if .Values.scopedRBAC }}
  243. namespace: {{ .Values.scopedNamespace | default .Release.Namespace | quote }}
  244. {{- end }}
  245. labels:
  246. {{- include "external-secrets.labels" . | nindent 4 }}
  247. {{- if .Values.rbac.aggregateToView }}
  248. rbac.authorization.k8s.io/aggregate-to-view: "true"
  249. {{- end }}
  250. {{- if .Values.rbac.aggregateToEdit }}
  251. rbac.authorization.k8s.io/aggregate-to-edit: "true"
  252. {{- end }}
  253. rbac.authorization.k8s.io/aggregate-to-admin: "true"
  254. rules:
  255. - apiGroups:
  256. - "external-secrets.io"
  257. resources:
  258. - "externalsecrets"
  259. - "secretstores"
  260. {{- if .Values.processClusterStore }}
  261. - "clustersecretstores"
  262. {{- end }}
  263. {{- if .Values.processPushSecret }}
  264. - "pushsecrets"
  265. {{- end }}
  266. {{- if .Values.processClusterPushSecret }}
  267. - "clusterpushsecrets"
  268. {{- end }}
  269. verbs:
  270. - "get"
  271. - "watch"
  272. - "list"
  273. - apiGroups:
  274. - "generators.external-secrets.io"
  275. resources:
  276. - "acraccesstokens"
  277. - "beyondtrustworkloadcredentialsdynamicsecrets"
  278. - "cloudsmithaccesstokens"
  279. {{- if .Values.processClusterGenerator }}
  280. - "clustergenerators"
  281. {{- end }}
  282. - "ecrauthorizationtokens"
  283. - "fakes"
  284. - "gcraccesstokens"
  285. - "githubaccesstokens"
  286. - "quayaccesstokens"
  287. - "passwords"
  288. - "sshkeys"
  289. - "vaultdynamicsecrets"
  290. - "webhooks"
  291. - "grafanas"
  292. - "generatorstates"
  293. - "mfas"
  294. - "uuids"
  295. verbs:
  296. - "get"
  297. - "watch"
  298. - "list"
  299. ---
  300. apiVersion: rbac.authorization.k8s.io/v1
  301. {{- if .Values.scopedRBAC }}
  302. kind: Role
  303. {{- else }}
  304. kind: ClusterRole
  305. {{- end }}
  306. metadata:
  307. name: {{ include "external-secrets.fullname" . }}-edit
  308. {{- if .Values.scopedRBAC }}
  309. namespace: {{ .Values.scopedNamespace | default .Release.Namespace | quote }}
  310. {{- end }}
  311. labels:
  312. {{- include "external-secrets.labels" . | nindent 4 }}
  313. {{- if .Values.rbac.aggregateToEdit }}
  314. rbac.authorization.k8s.io/aggregate-to-edit: "true"
  315. {{- end }}
  316. rbac.authorization.k8s.io/aggregate-to-admin: "true"
  317. rules:
  318. - apiGroups:
  319. - "external-secrets.io"
  320. resources:
  321. - "externalsecrets"
  322. - "secretstores"
  323. {{- if .Values.processClusterStore }}
  324. - "clustersecretstores"
  325. {{- end }}
  326. {{- if .Values.processPushSecret }}
  327. - "pushsecrets"
  328. {{- end }}
  329. {{- if .Values.processClusterPushSecret }}
  330. - "clusterpushsecrets"
  331. {{- end }}
  332. verbs:
  333. - "create"
  334. - "delete"
  335. - "deletecollection"
  336. - "patch"
  337. - "update"
  338. - apiGroups:
  339. - "generators.external-secrets.io"
  340. resources:
  341. - "acraccesstokens"
  342. - "cloudsmithaccesstokens"
  343. {{- if .Values.processClusterGenerator }}
  344. - "clustergenerators"
  345. {{- end }}
  346. - "ecrauthorizationtokens"
  347. - "fakes"
  348. - "gcraccesstokens"
  349. - "githubaccesstokens"
  350. - "quayaccesstokens"
  351. - "passwords"
  352. - "sshkeys"
  353. - "vaultdynamicsecrets"
  354. - "webhooks"
  355. - "grafanas"
  356. - "generatorstates"
  357. - "mfas"
  358. - "beyondtrustworkloadcredentialsdynamicsecrets"
  359. - "uuids"
  360. verbs:
  361. - "create"
  362. - "delete"
  363. - "deletecollection"
  364. - "patch"
  365. - "update"
  366. ---
  367. apiVersion: rbac.authorization.k8s.io/v1
  368. {{- if .Values.scopedRBAC }}
  369. kind: RoleBinding
  370. {{- else }}
  371. kind: ClusterRoleBinding
  372. {{- end }}
  373. metadata:
  374. name: {{ include "external-secrets.fullname" . }}-controller
  375. {{- if .Values.scopedRBAC }}
  376. namespace: {{ .Values.scopedNamespace | default .Release.Namespace | quote }}
  377. {{- end }}
  378. labels:
  379. {{- include "external-secrets.labels" . | nindent 4 }}
  380. roleRef:
  381. apiGroup: rbac.authorization.k8s.io
  382. {{- if .Values.scopedRBAC }}
  383. kind: Role
  384. {{- else }}
  385. kind: ClusterRole
  386. {{- end }}
  387. name: {{ include "external-secrets.fullname" . }}-controller
  388. subjects:
  389. - name: {{ include "external-secrets.serviceAccountName" . }}
  390. namespace: {{ template "external-secrets.namespace" . }}
  391. kind: ServiceAccount
  392. ---
  393. apiVersion: rbac.authorization.k8s.io/v1
  394. kind: Role
  395. metadata:
  396. name: {{ include "external-secrets.fullname" . }}-leaderelection
  397. namespace: {{ template "external-secrets.namespace" . }}
  398. labels:
  399. {{- include "external-secrets.labels" . | nindent 4 }}
  400. rules:
  401. - apiGroups:
  402. - ""
  403. resources:
  404. - "configmaps"
  405. resourceNames:
  406. - {{ default "external-secrets-controller" .Values.leaderElectionID | quote }}
  407. verbs:
  408. - "get"
  409. - "update"
  410. - "patch"
  411. - apiGroups:
  412. - ""
  413. resources:
  414. - "configmaps"
  415. verbs:
  416. - "create"
  417. - apiGroups:
  418. - "coordination.k8s.io"
  419. resources:
  420. - "leases"
  421. verbs:
  422. - "get"
  423. - "create"
  424. - "update"
  425. - "patch"
  426. ---
  427. apiVersion: rbac.authorization.k8s.io/v1
  428. kind: RoleBinding
  429. metadata:
  430. name: {{ include "external-secrets.fullname" . }}-leaderelection
  431. namespace: {{ template "external-secrets.namespace" . }}
  432. labels:
  433. {{- include "external-secrets.labels" . | nindent 4 }}
  434. roleRef:
  435. apiGroup: rbac.authorization.k8s.io
  436. kind: Role
  437. name: {{ include "external-secrets.fullname" . }}-leaderelection
  438. subjects:
  439. - kind: ServiceAccount
  440. name: {{ include "external-secrets.serviceAccountName" . }}
  441. namespace: {{ template "external-secrets.namespace" . }}
  442. {{- if .Values.rbac.servicebindings.create }}
  443. ---
  444. apiVersion: rbac.authorization.k8s.io/v1
  445. kind: ClusterRole
  446. metadata:
  447. name: {{ include "external-secrets.fullname" . }}-servicebindings
  448. labels:
  449. servicebinding.io/controller: "true"
  450. {{- include "external-secrets.labels" . | nindent 4 }}
  451. rules:
  452. - apiGroups:
  453. - "external-secrets.io"
  454. resources:
  455. - "externalsecrets"
  456. {{- if .Values.processPushSecret }}
  457. - "pushsecrets"
  458. {{- end }}
  459. verbs:
  460. - "get"
  461. - "list"
  462. - "watch"
  463. {{- end }}
  464. {{- end }}
  465. {{- if .Values.systemAuthDelegator }}
  466. ---
  467. apiVersion: rbac.authorization.k8s.io/v1
  468. kind: ClusterRoleBinding
  469. metadata:
  470. name: {{ include "external-secrets.fullname" . }}-auth-delegator
  471. labels:
  472. {{- include "external-secrets.labels" . | nindent 4 }}
  473. roleRef:
  474. apiGroup: rbac.authorization.k8s.io
  475. kind: ClusterRole
  476. name: system:auth-delegator
  477. subjects:
  478. - kind: ServiceAccount
  479. name: {{ include "external-secrets.serviceAccountName" . }}
  480. namespace: {{ template "external-secrets.namespace" . }}
  481. {{- end }}