add validating admission controller for argo events

This commit is contained in:
2024-08-28 01:40:59 +10:00
parent d76202ebb0
commit 3a25bbbf24
6 changed files with 127 additions and 3 deletions

View File

@@ -11,3 +11,16 @@ subjects:
- kind: ServiceAccount
name: argo-events-sa
namespace: argo-events
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
name: argo-events-webhook-binding
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: argo-events-webhook
subjects:
- kind: ServiceAccount
name: argo-events-webhook-sa
namespace: argo-events

View File

@@ -166,3 +166,65 @@ rules:
- update
- patch
- delete
---
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
name: argo-events-webhook
rules:
- apiGroups:
- ""
resources:
- secrets
verbs:
- get
- list
- create
- update
- delete
- patch
- watch
- apiGroups:
- ""
resources:
- configmaps
verbs:
- get
- list
- watch
- apiGroups:
- apps
resources:
- deployments
verbs:
- get
- list
- apiGroups:
- admissionregistration.k8s.io
resources:
- validatingwebhookconfigurations
verbs:
- get
- list
- create
- update
- delete
- patch
- watch
- apiGroups:
- argoproj.io
resources:
- eventbus
- eventsources
- sensors
verbs:
- get
- list
- watch
- apiGroups:
- rbac.authorization.k8s.io
resources:
- clusterroles
verbs:
- get
- list

View File

@@ -50,3 +50,33 @@ spec:
- configMap:
name: argo-events-controller-config
name: controller-config-volume
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: events-webhook
namespace: argo-events
spec:
replicas: 1
selector:
matchLabels:
app: events-webhook
template:
metadata:
labels:
app: events-webhook
spec:
containers:
- args:
- webhook-service
env:
- name: NAMESPACE
valueFrom:
fieldRef:
fieldPath: metadata.namespace
- name: PORT
value: "443"
image: quay.io/argoproj/argo-events:v1.9.2
imagePullPolicy: Always
name: webhook
serviceAccountName: argo-events-webhook-sa

View File

@@ -7,3 +7,4 @@ resources:
- ./cluster-role-binding.yaml
- ./configmap.yaml
- ./deployment.yaml
- ./service.yaml

View File

@@ -4,3 +4,9 @@ kind: ServiceAccount
metadata:
name: argo-events-sa
namespace: argo-events
---
apiVersion: v1
kind: ServiceAccount
metadata:
name: argo-events-webhook-sa
namespace: argo-events

View File

@@ -0,0 +1,12 @@
---
apiVersion: v1
kind: Service
metadata:
name: events-webhook
namespace: argo-events
spec:
ports:
- port: 443
targetPort: 443
selector:
app: events-webhook