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/75a4f/75a4f33eba643551646890fe3664defe7f6b74c1" alt=""
JSONPath in SpaceConstraint CRD:
spec.displayName (type: string)
Kubernetes Name
data:image/s3,"s3://crabby-images/bde02/bde02029df2d749da4ba6d1438f88c4027624e4f" alt=""
JSONPath in SpaceConstraint CRD:
metadata.name (type: string)
Description
data:image/s3,"s3://crabby-images/71912/71912f083280f4a20824c86e9e012dc7fb6ae2e1" alt=""
JSONPath in SpaceConstraint CRD:
spec.description (type: string)
Labels
data:image/s3,"s3://crabby-images/34122/34122e82c307ddb89343bf2bba2d5aa845ff6f5c" alt=""
JSONPath in SpaceConstraint CRD:
metadata.labels (type: map[string]string)
Annotations
data:image/s3,"s3://crabby-images/54c81/54c81703349a312798450c2c1743f79a0eaa391a" alt=""
JSONPath in SpaceConstraint CRD:
metadata.annotations (type: map[string]string)
Enforce Resources
data:image/s3,"s3://crabby-images/232d4/232d4a270f52e51314d3be96cf0918462b71b46e" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.spec.spaceTemplate.objects (type: {})
Enforce Sleep Mode
Inactivity Timeout
data:image/s3,"s3://crabby-images/7ec51/7ec518dc1b5d06baceed0fb4fec526c7e6a90678" 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/e699a/e699a5aa8c0a0032216a2b42c63310c5e36cd3d6" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.metadata.annotations["sleepmode.loft.sh/delete-after"] (type: string)
Sleep Schedule
data:image/s3,"s3://crabby-images/47cb1/47cb1bab56ee5f8cafaea6568711c3c87f01946f" 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/47cb1/47cb1bab56ee5f8cafaea6568711c3c87f01946f" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.metadata.annotations["sleepmode.loft.sh/wakeup-schedule"] (type: string)
Scheduling Timezone
data:image/s3,"s3://crabby-images/4eba6/4eba6f92e71c02175464aa957aaaa56901493c64" 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/10b3c/10b3c6892b3ea93c24c2de72b07013c65cb05285" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.metadata.labels (type: map[string]string)
Annotations
data:image/s3,"s3://crabby-images/7cb51/7cb51297702c6d915ad0d0782b63dd7b79ffdf6c" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.metadata.annotations (type: map[string]string)
Advanced Options
Clusters
data:image/s3,"s3://crabby-images/dc9b8/dc9b80cf98d772af68d77466a4e304f9e19420c3" alt=""
JSONPath in SpaceConstraint CRD:
spec.clusters (type: string[])
Sync Constraint Changes
data:image/s3,"s3://crabby-images/b4c8b/b4c8b41cf9df54b9e3ac98558ac3873dcb413849" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.spec.sync (type: string)
Owner's Cluster Role
data:image/s3,"s3://crabby-images/ff460/ff46071f4f971924da084f1fcd383c3cd0f1e11e" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.spec.spaceTemplate.clusterRole (type: map[string]string)
Access To Space Constraints
data:image/s3,"s3://crabby-images/430d7/430d747fa570e7242c467e71fb6df641c1c1ce89" alt=""
JSONPath in SpaceConstraint CRD:
spec.access (type: Access[])