Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: add wiz manifests #8679

Open
wants to merge 47 commits into
base: dev
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 45 commits
Commits
Show all changes
47 commits
Select commit Hold shift + click to select a range
ec72710
feat: add wiz manifests
Dec 19, 2024
de2a398
feat: update permissions for sensor
Dec 19, 2024
a5b89dc
feat: add wiz manifests
Dec 19, 2024
c307aaf
feat: add wiz manifests
Dec 19, 2024
0cdad7a
Update secrets namespace + cleanup trailing curly brackets
zaklawrencea Dec 19, 2024
500acb7
fix: minor changes
Dec 20, 2024
38944d1
Merge branch 'vthupili' of https://github.com/zalando-incubator/kuber…
Dec 20, 2024
4fda53d
fix: minor changes
Dec 20, 2024
a65b322
enable wiz to exclude from node ready event
Dec 20, 2024
eb25c7f
Fix typos
katyanna Dec 20, 2024
ebb156a
Fix missing }
katyanna Dec 20, 2024
3630e94
Update cluster/manifests/deletions.yaml
demonCoder95 Dec 23, 2024
dfdffc5
Minor fixes
Jan 2, 2025
aa8ddc6
Minor fixes
Jan 3, 2025
38e467d
Minor fixes
Jan 3, 2025
63ca7d7
Merge branch 'dev' into vthupili
Jan 3, 2025
e773b9a
restructure
Jan 3, 2025
9854e09
Merge branch 'dev' into vthupili
Jan 3, 2025
73ce47e
remove imagepull secrets
Jan 3, 2025
a2aef3f
remove imagepull secrets
Jan 3, 2025
9e6fc8b
add limits for broker
Jan 3, 2025
b8f3a59
add limits for broker
Jan 3, 2025
6b0b73e
restructure
Jan 3, 2025
c176b5b
update image Tags
Jan 3, 2025
0dc9cbe
update image Tags
Jan 3, 2025
24babce
minor fix to secret
Jan 6, 2025
a800342
minor
Jan 6, 2025
711cb87
Merge branch 'dev' into vthupili
Jan 6, 2025
2bdfaa1
minor fix secret
Jan 6, 2025
c20f7af
minor
Jan 6, 2025
026d2fe
rename sensor ds file name
Jan 7, 2025
0e919db
add nodeselector to all worker nodes
Jan 7, 2025
fe51b45
update DS tolerations
Jan 7, 2025
02fd3fa
update tolerations
Jan 7, 2025
af52b16
update tolerations
Jan 7, 2025
8967144
Merge branch 'dev' into vthupili
Jan 7, 2025
8770794
reorder the wiz resources in deletions.yaml
Jan 8, 2025
41affbb
update image tags
Jan 9, 2025
b5ec8ec
Merge branch 'dev' into vthupili
Jan 9, 2025
1393086
update Image registry
Jan 10, 2025
3bcafa0
feat: Split WIZ components
Jan 13, 2025
d305ae9
update deletions
Jan 14, 2025
ec55592
update deletions
Jan 14, 2025
4ff27c3
Update Manifests
Jan 16, 2025
65d128b
minor fixes
Jan 24, 2025
e2dfb30
minor fixes to config
Jan 24, 2025
0962b83
rmove extra :"
Jan 24, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
15 changes: 15 additions & 0 deletions cluster/config-defaults.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -1202,3 +1202,18 @@ role_sync_controller_enabled: "true"
{{ else }}
role_sync_controller_enabled: "false"
{{ end }}

#Wiz Configs
# When wiz_enable_runtime_sensor and wiz_enable_runtime_connector are set to true,
# this enables WIZ runtime monitoring. A DaemonSet called Sensor and a Deployment
# called Connector will be deployed into the cluster.
wiz_enable_runtime_sensor: "false"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

please describe with 1-2 lines in a comment what these configs do. See how we do it in the rest of this file.

memory/cpu config-items don't need much description, those are obvious, but the others e.g. like wiz_node_feature_rollout does need a bit of description how to use it.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

updated 🙌

wiz_enable_runtime_connector: "false"
wiz_sensor_cpu: "300m"
wiz_sensor_memory: "300Mi"
wiz_connector_cpu: "300m"
wiz_connector_memory: "300Mi"
# Please note when this is set to true it allows the use of the node selector feature
# to deploy the sensor and connector on specific nodes, by manually setting the node selector label on the nodes.
# This is useful when you want to deploy the sensor and connector on specific nodes.
wiz_node_feature_rollout : "false"
16 changes: 15 additions & 1 deletion cluster/manifests/01-admission-control/config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -115,6 +115,9 @@ data:
{{- range $sa := split .Cluster.ConfigItems.teapot_admission_controller_pod_security_policy_privileged_service_accounts "," }}
pod.pod-security-policy.privileged-service-accounts.{{ $sa }}: ""
{{- end}}
{{- if eq. .Cluster.ConfigItems.wiz_enable_runtime_sensor "true" }}
pod.pod-security-policy.privileged-service-accounts.wiz_wiz_sensor: ""
{{- end }}

pod.pod-security-policy.allowed-restricted-capabilities.AUDIT_WRITE: ""
pod.pod-security-policy.allowed-restricted-capabilities.CHOWN: ""
Expand All @@ -139,9 +142,20 @@ data:
pod.pod-security-policy.allowed-privileged-capabilities.{{ $cap }}: ""
{{- end}}

{{- if eq. .Cluster.ConfigItems.wiz_enable_runtime_sensor "true" }}
pod.pod-security-policy.privileged-service-accounts.wiz_wiz_sensor: ""
{{- end }}

{{- range $sysctl := split .Cluster.ConfigItems.allowed_unsafe_sysctls "," }}
pod.pod-security-policy.allowed-unsafe-sysctls.{{ $sysctl }}: ""
pod.pod-security-policy.allowed-restricted-capabilities.DAC_READ_SEARCH: ""
pod.pod-security-policy.allowed-restricted-capabilities.IPC_LOCK: ""
pod.pod-security-policy.allowed-restricted-capabilities.NET_ADMIN: ""
pod.pod-security-policy.allowed-restricted-capabilities.SYS_ADMIN: ""
pod.pod-security-policy.allowed-restricted-capabilities.SYS_MODULE: ""
pod.pod-security-policy.allowed-restricted-capabilities.SYS_PTRACE: ""
pod.pod-security-policy.allowed-restricted-capabilities.SYS_RESOURCE: ""
pod.pod-security-policy.allowed-restricted-capabilities.SYS_RAWIO: ""
pod.pod-security-policy.allowed-restricted-capabilities.SYSLOG: ""
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This change looks wrong. It removes the allowed-unsafe-sysctls.{{ $sysctl }}: "" setting and adds the capbilties based on the allowed_unsafe_sysctls config-item.

The capabilties should be behind the config-item: {{- if eq. .Cluster.ConfigItems.wiz_enable_runtime_sensor "true" }} and they should apply to the allowed-privileged-capabilities not allowed-restricted-capabilities. We only want to enable these for privileged pods.

{{- end}}

pod.pod-security-policy.allow-privilege-escalation: "{{ .Cluster.ConfigItems.teapot_admission_controller_pod_security_policy_privileged_allow_privilege_escalation }}"
Expand Down
59 changes: 59 additions & 0 deletions cluster/manifests/deletions.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -339,6 +339,65 @@ post_apply:
- name: kube-janitor
kind: ClusterRoleBinding
{{- end }}
{{- if ne .Cluster.ConfigItems.wiz_enable_runtime_connector "true" }}
- name: wiz-kubernetes-connector-create-connector
kind : Job
namespace: wiz
- name: wiz-kubernetes-connector-delete-connector
kind : Job
namespace: wiz
- name: wiz-connector-agent
kind : Deployment
namespace: wiz
- name: wiz-broker
kind : ServiceAccount
namespace: wiz
- name: wiz-cluster-reader
kind : ServiceAccount
namespace: wiz
- name: wiz-auto-modify-connector
kind : ServiceAccount
namespace: wiz
- name: wiz-connector-connector
kind : Secret
namespace: wiz
- name: wiz-cluster-reader-token
kind : Secret
namespace: wiz
- name: wiz-api-token
kind : Secret
namespace: wiz
- name: wiz-auto-modify-connector
kind : Role
namespace: wiz
- name: wiz-auto-modify-connector
kind : RoleBinding
namespace: wiz
- name: wiz-cluster-reader
kind : ClusterRoleBinding
namespace: wiz
{{- end }}
{{- if ne .Cluster.ConfigItems.wiz_enable_runtime_sensor "true" }}
- name: wiz-sensor
kind : DaemonSet
namespace: wiz
- name: wiz-sensor
kind: ServiceAccount
namespace: wiz
- name: wiz-sensor-apikey
kind: Secret
namespace: wiz
- name: wiz-sensor
kind : ClusterRole
namespace: wiz
- name: wiz-sensor
kind : ClusterRoleBinding
namespace: wiz
{{- end }}
mikkeloscar marked this conversation as resolved.
Show resolved Hide resolved
{{- if and (ne .Cluster.ConfigItems.wiz_enable_runtime_connector "true") (ne .Cluster.ConfigItems.wiz_enable_runtime_sensor "true") }}
- name: wiz
kind: Namespace
{{- end }}
{{- if ne .Cluster.ConfigItems.aws_efa_device_plugin_enabled "true"}}
- name: aws-efa-k8s-device-plugin
kind: DaemonSet
Expand Down
4 changes: 4 additions & 0 deletions cluster/manifests/wiz/001-namespace.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
apiVersion: v1
kind: Namespace
metadata:
name: wiz
35 changes: 35 additions & 0 deletions cluster/manifests/wiz/002-connector-serviceaccount.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
{{ if eq .Cluster.ConfigItems.wiz_enable_runtime_connector "true"}}
---
# Source: wiz-kubernetes-integration/charts/wiz-kubernetes-connector/charts/wiz-broker/templates/serviceaccount.yaml
apiVersion: v1
kind: ServiceAccount
metadata:
name: wiz-broker
namespace: "wiz"
labels:
helm.sh/chart: wiz-broker-2.1.0
application: "wiz"
component: "connector"
---
# Source: wiz-kubernetes-integration/charts/wiz-kubernetes-connector/templates/service-account-cluster-reader.yaml
apiVersion: v1
kind: ServiceAccount
metadata:
name: wiz-cluster-reader
namespace: "wiz"
labels:
helm.sh/chart: wiz-broker-2.1.0
application: "wiz"
component: "connector"
---
# Source: wiz-kubernetes-integration/charts/wiz-kubernetes-connector/templates/service-account-modify-connector.yaml
apiVersion: v1
kind: ServiceAccount
metadata:
name: wiz-auto-modify-connector
namespace: "wiz"
labels:
helm.sh/chart: wiz-broker-2.1.0
application: "wiz"
component: "connector"
{{end}}
13 changes: 13 additions & 0 deletions cluster/manifests/wiz/002-sensor-serviceaccount.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
{{ if eq .Cluster.ConfigItems.wiz_enable_runtime_sensor "true"}}
---
# Source: wiz-sensor/templates/serviceaccount.yaml
apiVersion: v1
kind: ServiceAccount
metadata:
name: wiz-sensor
namespace: wiz
labels:
helm.sh/chart: wiz-sensor-1.0.4760
application: "wiz"
component: "connector"
{{end}}
20 changes: 20 additions & 0 deletions cluster/manifests/wiz/003-connector-clusterrole.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
{{ if eq .Cluster.ConfigItems.wiz_enable_runtime_connector "true"}}
---
# Source: wiz-kubernetes-integration/charts/wiz-kubernetes-connector/templates/service-account-cluster-reader.yaml
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
name: wiz-cluster-reader
labels:
helm.sh/chart: wiz-broker-2.1.0
application: "wiz"
component: "connector"
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: readonly # readonly role created by default in out kubernetes environment
subjects:
- kind: ServiceAccount
name: wiz-cluster-reader
namespace: "wiz"
{{end}}
43 changes: 43 additions & 0 deletions cluster/manifests/wiz/003-connector-role.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
{{ if eq .Cluster.ConfigItems.wiz_enable_runtime_connector "true"}}
---
# Source: wiz-kubernetes-integration/charts/wiz-kubernetes-connector/templates/service-account-modify-connector.yaml
apiVersion: rbac.authorization.k8s.io/v1
kind: Role
metadata:
name: wiz-auto-modify-connector
namespace: "wiz"
labels:
helm.sh/chart: wiz-broker-2.1.0
application: "wiz"
component: "connector"
rules:
- apiGroups: [""]
resources: ["secrets"]
resourceNames: ["wiz-connector-connector"]
verbs: ["update", "get"]
- apiGroups: [""]
resources: ["secrets"]
resourceNames:
- "wiz-api-token"
- "wiz-cluster-reader-token"
verbs: ["get"]
---
# Source: wiz-kubernetes-integration/charts/wiz-kubernetes-connector/templates/service-account-modify-connector.yaml
apiVersion: rbac.authorization.k8s.io/v1
kind: RoleBinding
metadata:
name: wiz-auto-modify-connector
namespace: "wiz"
labels:
helm.sh/chart: wiz-broker-2.1.0
application: "wiz"
component: "connector"
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: Role
name: wiz-auto-modify-connector
subjects:
- kind: ServiceAccount
name: wiz-auto-modify-connector
namespace: "wiz"
{{end}}
42 changes: 42 additions & 0 deletions cluster/manifests/wiz/003-sensor-clusterrole.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
{{ if eq .Cluster.ConfigItems.wiz_enable_runtime_sensor "true"}}
---
# Source: wiz-sensor/templates/clusterrole.yaml
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
name: wiz-sensor
labels:
helm.sh/chart: wiz-sensor-1.0.4760
application: "wiz"
component: "sensor"
rules:
- apiGroups: [""]
resources: ["pods", "namespaces", "nodes", "replicationcontrollers", "serviceaccounts"]
verbs: ["get", "list", "watch"]

- apiGroups: ["apps"]
resources: ["daemonsets", "replicasets", "deployments", "statefulsets"]
verbs: ["get", "list", "watch"]

- apiGroups: ["batch"]
resources: ["cronjobs"]
verbs: ["get", "list", "watch"]
---
# Source: wiz-sensor/templates/clusterrolebinding.yaml
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
name: wiz-sensor
labels:
helm.sh/chart: wiz-sensor-1.0.4760
application: "wiz"
component: "sensor"
subjects:
- kind: ServiceAccount
name: wiz-sensor
namespace: wiz
roleRef:
kind: ClusterRole
name: wiz-sensor
apiGroup: rbac.authorization.k8s.io
{{end}}
45 changes: 45 additions & 0 deletions cluster/manifests/wiz/004-connector-secrets.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
{{ if eq .Cluster.ConfigItems.wiz_enable_runtime_connector "true"}}
---
# Source: wiz-kubernetes-integration/charts/wiz-kubernetes-connector/templates/secret-connector.yaml
apiVersion: v1
kind: Secret
metadata:
name: wiz-connector-connector
namespace: "wiz"
labels:
helm.sh/chart: wiz-broker-2.1.0
application: "wiz"
component: "connector"
type: Opaque
data:
connectorData: "e30="
---
# Source: wiz-kubernetes-integration/charts/wiz-kubernetes-connector/templates/service-account-cluster-reader.yaml
apiVersion: v1
kind: Secret
metadata:
name: wiz-cluster-reader-token
namespace: "wiz"
labels:
helm.sh/chart: wiz-broker-2.1.0
application: "wiz"
component: "connector"
annotations:
kubernetes.io/service-account.name: wiz-cluster-reader
type: kubernetes.io/service-account-token
---
# Source: wiz-sensor/templates/apikeysecret.yaml
apiVersion: v1
kind: Secret
metadata:
name: wiz-api-token
namespace: wiz
labels:
helm.sh/chart: wiz-broker-2.1.0
application: "wiz"
component: "connector"
type: Opaque
stringData:
clientId: "{{ .Cluster.ConfigItems.wiz_api_client_id }}"
clientToken: "{{ .Cluster.ConfigItems.wiz_api_client_token }}"
{{end}}
31 changes: 31 additions & 0 deletions cluster/manifests/wiz/004-sensor-secrets.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
{{ if eq .Cluster.ConfigItems.wiz_enable_runtime_sensor "true"}}
---
# Source: wiz-sensor/templates/apikeysecret.yaml
apiVersion: v1
kind: Secret
metadata:
name: wiz-sensor-apikey
namespace: wiz
labels:
helm.sh/chart: wiz-sensor-1.0.4760
application: "wiz"
component: "sensor"
type: Opaque
stringData:
clientId: "{{ .Cluster.ConfigItems.wiz_api_client_id }}"
clientToken: "{{ .Cluster.ConfigItems.wiz_api_client_token }}"
# ---
# # Source: wiz-sensor/templates/imagepullsecret.yaml
# apiVersion: v1
# kind: Secret
# type: kubernetes.io/dockerconfigjson
# metadata:
# name: wiz-sensor-imagepullkey
# labels:
# helm.sh/chart: wiz-sensor-1.0.4760
# application: "wiz"
# component: "sensor"
# namespace: wiz
# data:
# .dockerconfigjson: "{{ .Cluster.ConfigItems.wiz_sensor_dockerconfigjson }}"
{{end}}
Loading