Space Constraints in Loft
Space Constraints allow you to define restrictions for namespaces such as enforced resources that will be deployed to each new namespace a user creates (e.g. NetworkPolicies) or other enforced settings such as mandatory labels, annotations, or any sleep mode configurations.
Working with Space Constraints
1. Create Space Constraints
- Go to the Clusters view using the menu on the left
- Switch to the Space Constraints tab
- Click the button to create a new space constraints object
- In the drawer that appears on the right, use the field Display Name to specify a Name for your space constraints object
- Expand the section to specify manifests that should be deployed to and enforced in each namespace that is affected by these space constraints
- Expand the section to specify other space settings such as sleep mode, auto-delete, labels and annotations that should be enforced for each namespace that is affected by these space constraints
- On the very bottom, click on the button to create this space constraints object
2. Enforce Space Constraints For Users & Teams
- Go to the Clusters view using the menu on the left
- Switch to the Cluster Access tab
- Hover over the cluster access that you want to apply these space constraints to and click on the button to Edit the cluster access
- In the drawer that appears on the right, expand the section
- Use the Enforce Space Constraints field to select the Space Constraint that you want to enforce for all spaces created using this cluster access
- On the very bottom, click on the or button to save the changes
- Switch to the Cluster Access tab
- Hover over the cluster access of the user or team that you want to configure automatic sleep mode for and click on the button to Edit the cluster access
- In the drawer that appears on the right, expand the section
- Use the Enforce Space Constraints field to select the Space Constraint you edited or created in Step 3 above
- On the very bottom, click on the button to save the changes
Test with Impersonation
After following the steps above, all spaces created using the cluster access in step 7 will now enforce these space constraints. You can test this behavior by impersonating a user that uses this cluster access.
Configuration
Metadata
Display Name
data:image/s3,"s3://crabby-images/7640f/7640fa93d7e63aa9ffac14dbdf00d37edb806d9d" alt=""
JSONPath in SpaceConstraint CRD:
spec.displayName (type: string)
Kubernetes Name
data:image/s3,"s3://crabby-images/5b0b0/5b0b0dda277c0565e6ce39a55278c3cd1f942017" alt=""
JSONPath in SpaceConstraint CRD:
metadata.name (type: string)
Description
data:image/s3,"s3://crabby-images/7ccc0/7ccc029171469a428b42bd92aef5a033fdf98e12" alt=""
JSONPath in SpaceConstraint CRD:
spec.description (type: string)
Labels
data:image/s3,"s3://crabby-images/32743/32743e47dd6a2b304ca66b0f1f2b0db91cd776b3" alt=""
JSONPath in SpaceConstraint CRD:
metadata.labels (type: map[string]string)
Annotations
data:image/s3,"s3://crabby-images/56f53/56f531d3daaace850f4a004a55cc3a487cd2a0de" alt=""
JSONPath in SpaceConstraint CRD:
metadata.annotations (type: map[string]string)
Enforce Resources
data:image/s3,"s3://crabby-images/a0181/a018151f2574e01691b46ea64043542f0d7de6da" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.spec.spaceTemplate.objects (type: {})
Enforce Sleep Mode
Inactivity Timeout
data:image/s3,"s3://crabby-images/5dcfd/5dcfd7e84749beb441a0dd466d1c4dbfa9fae119" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.metadata.annotations["sleepmode.loft.sh/sleep-after"] (type: string)
Auto-Delete Timeout
data:image/s3,"s3://crabby-images/b7c6d/b7c6d5333bf347c6824eebf74e8f17476331ec39" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.metadata.annotations["sleepmode.loft.sh/delete-after"] (type: string)
Sleep Schedule
data:image/s3,"s3://crabby-images/655c5/655c5229f03f52f8a602459872a1fe33f07e2817" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.metadata.annotations["sleepmode.loft.sh/sleep-schedule"] (type: string)
Wake-Up Schedule
data:image/s3,"s3://crabby-images/655c5/655c5229f03f52f8a602459872a1fe33f07e2817" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.metadata.annotations["sleepmode.loft.sh/wakeup-schedule"] (type: string)
Scheduling Timezone
data:image/s3,"s3://crabby-images/e7f11/e7f118bc905d683d1e289efa3ef09a1575070d54" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.metadata.annotations["sleepmode.loft.sh/timezone"] (type: string)
Enforce Labels & Annoations
Labels
data:image/s3,"s3://crabby-images/51351/51351512b2e2a62af4f40fd4653f7596da3b5864" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.metadata.labels (type: map[string]string)
Annotations
data:image/s3,"s3://crabby-images/f630f/f630fdb61e756a681850bf472ed55d763f293e89" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.metadata.annotations (type: map[string]string)
Advanced Options
Clusters
data:image/s3,"s3://crabby-images/82157/82157c5e20c5a7403e94ef9b8cac87834d6d5721" alt=""
JSONPath in SpaceConstraint CRD:
spec.clusters (type: string[])
Sync Constraint Changes
data:image/s3,"s3://crabby-images/972d5/972d58cd5533d5ee1fc49297e06d0b7595146e82" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.spec.sync (type: string)
Owner's Cluster Role
data:image/s3,"s3://crabby-images/fbd6a/fbd6ab2a3f35d38ddc4de4b22e30c4fa874bca07" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.spec.spaceTemplate.clusterRole (type: map[string]string)
Access To Space Constraints
data:image/s3,"s3://crabby-images/6217e/6217e8bb3e5b35a62f9a440ec9e860541444d8e3" alt=""
JSONPath in SpaceConstraint CRD:
spec.access (type: Access[])