Default Constraints
Default Constraints allow admins to conveniently apply policies to all OPA enabled clusters
This would allow admins an easier way to make sure all user clusters are following some policies (for example security), instead of the current way in which Constraints need to be created for each cluster separately.
Kubermatic operator/admin creates a Constraint in the admin panel, it gets propagated to seed clusters and user clusters with OPA-integration
Create Default Constraint
In the Admin view navigate to the OPA menu and then to Default Constraints.
To add a new default constraint click on the +Add Default Constraint
icon on the right. A new dialog will appear, where you can specify the name, the constraint template and the spec:
data:image/s3,"s3://crabby-images/8ce2f/8ce2f2828c61cf2573a9d832e252d8b151882820" alt="Create Default Constraint Create Default Constraint"
constraintType: K8sPSPAllowPrivilegeEscalationContainer
match:
kinds:
- kinds:
- Pod
apiGroups:
- ''
labelSelector: {}
namespaceSelector: {}
selector:
labelSelector: {}
data:image/s3,"s3://crabby-images/73bad/73bad2639652ba0358be69ff5cb3b3500ba365ac" alt="Created Default Constraint Created Default Constraint"
The Default Constraint created will also show up in the applied cluster view with Admin Constraint
label
data:image/s3,"s3://crabby-images/c06c5/c06c5aeaf6d3169654b401adecdf0777c2b50cce" alt="Created Default Constraint on the Cluster Created Default Constraint on the Cluster"
Edit Default Constraint
Editing Default Constraint will sync the changes to all the respective constraints on the user clusters.
To edit the constraint click on edit button on the right that appears when hovering over one of the rows.
data:image/s3,"s3://crabby-images/c2fd8/c2fd8173fd4378d8bb954d6ae17ca45190ca8606" alt="Edit Default Constraint Edit Default Constraint"
In the appearing dialog you can now edit the Default Constraint.
data:image/s3,"s3://crabby-images/97f2f/97f2f03611e87970d3bc35b7b610e05515ad13bb" alt="Edit Constraint Dialog Edit Constraint Dialog"
Filtering Clusters on Default Constraints
Filter Clusters feature enables Admin to filter User Clusters where Default Constraint is applied using with Cloud Provider and Label Selector filters.
In case of no filtering applied Default Constraints are synced to all User Clusters which can be verified by the Applies To
field as shown here:
data:image/s3,"s3://crabby-images/73bad/73bad2639652ba0358be69ff5cb3b3500ba365ac" alt="Default Constraint Applies To Default Constraint Applies To"
for example, Admin wants to apply a policy only on clusters with the provider as aws
and label selector as filtered:true
To enable this add the following selectors in the constraint spec for the above use case.
selector:
providers:
- aws
labelSelector:
matchLabels:
filtered: 'true'
data:image/s3,"s3://crabby-images/0e8c2/0e8c2b249eeb6ffd02c4016b715ba12cf92fa1fe" alt="Default Constraint Filters Default Constraint Filters"
Constraints then can only be seen in the clusters which satisfy the filters.
for example, for the above use case Default Constraints will be applied to Cluster blissful-stallman
with Provider aws
and filter filtered: 'true'
and not on the Cluster zen-knuth
with Provider gcp
data:image/s3,"s3://crabby-images/84963/849630b0c38ad406cf72983bf0f5f906dd45c949" alt="Clusters Clusters"
data:image/s3,"s3://crabby-images/d95cd/d95cd6a74adb4cfcd1670cf880380057e621279c" alt="Filtered Cluster with Default Constraint Filtered Cluster with Default Constraint"
Disable Default Constraints
In Admin View to disable Default Constraints, click on the green button under On/Off
data:image/s3,"s3://crabby-images/9943d/9943da77c827037092c6a34dacb53440a6a7a957" alt="Disable Default Constraint Disable Default Constraint"
Kubermatic adds a label disabled: true
to the Disabled Constraint
data:image/s3,"s3://crabby-images/479a8/479a8aa5155dd40e077fdfa6bf7b102c10cc9b3c" alt="Disabled Default Constraint Disabled Default Constraint"
Disabled Constraint in the Applied cluster View
disabled-default-constraint-cluster-view.png
data:image/s3,"s3://crabby-images/b6ec3/b6ec3a25ec63c2017a042bbd0808715681f3f5a4" alt="Disabled Default Constraint Disabled Default Constraint"
Enable the constraint by clicking the same button
data:image/s3,"s3://crabby-images/6d9ac/6d9ac32559f3e9e7143a8a3daadb23ee0f432e9d" alt="Enable Default Constraint Enable Default Constraint"
Delete Default Constraint
Deleting Default Constraint causes all related Constraints on the user clusters to be deleted as well.
To delete the constraint click on delete button on the right that appears when hovering over one of the rows.
data:image/s3,"s3://crabby-images/c2fd8/c2fd8173fd4378d8bb954d6ae17ca45190ca8606" alt="Delete Default Constraint Delete Default Constraint"