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/c262e/c262ee0b9339bddf161d4e0853c5e95b0b22e633" alt=""
JSONPath in SpaceConstraint CRD:
spec.displayName (type: string)
Kubernetes Name
data:image/s3,"s3://crabby-images/7aa0d/7aa0de2c6fed776ca0a49768bc21d463b25bdebd" alt=""
JSONPath in SpaceConstraint CRD:
metadata.name (type: string)
Description
data:image/s3,"s3://crabby-images/a99e4/a99e4018461dd75bf6021ba4335430853ae0e924" alt=""
JSONPath in SpaceConstraint CRD:
spec.description (type: string)
Labels
data:image/s3,"s3://crabby-images/0bd3d/0bd3d06c4d0047cbc03e05960d7467e45d49dff6" alt=""
JSONPath in SpaceConstraint CRD:
metadata.labels (type: map[string]string)
Annotations
data:image/s3,"s3://crabby-images/502e9/502e968c4114014e166e70132c250360c71357ff" alt=""
JSONPath in SpaceConstraint CRD:
metadata.annotations (type: map[string]string)
Enforce Resources
data:image/s3,"s3://crabby-images/bfd99/bfd994c90079711b118245d3a9aa673a52ad254b" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.spec.spaceTemplate.objects (type: {})
Enforce Sleep Mode
Inactivity Timeout
data:image/s3,"s3://crabby-images/3de98/3de980aaada4dd7cb0fadfd2f7b97068c8d6d2eb" 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/1e0e1/1e0e1b7ac77a3c82271c3e7d756d7b83ed25ca29" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.metadata.annotations["sleepmode.loft.sh/delete-after"] (type: string)
Sleep Schedule
data:image/s3,"s3://crabby-images/62d0b/62d0bfb9c5d66807c329d28a833270b508532a7d" 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/62d0b/62d0bfb9c5d66807c329d28a833270b508532a7d" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.metadata.annotations["sleepmode.loft.sh/wakeup-schedule"] (type: string)
Scheduling Timezone
data:image/s3,"s3://crabby-images/f505d/f505d52b604ffc3f0c654ae81e95d597725feb30" 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/b0f98/b0f9887989412b98aa8cbc90d2c24d1a4545f5dd" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.metadata.labels (type: map[string]string)
Annotations
data:image/s3,"s3://crabby-images/3904a/3904a2c079c0cbf805bdbad19011c4d172f47b34" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.metadata.annotations (type: map[string]string)
Advanced Options
Clusters
data:image/s3,"s3://crabby-images/1d66a/1d66a2159ccef5e707aa450a537a0a074a127ff4" alt=""
JSONPath in SpaceConstraint CRD:
spec.clusters (type: string[])
Sync Constraint Changes
data:image/s3,"s3://crabby-images/cdfdc/cdfdc9bf4eba7fd75532d8cfac3f84879ee6c469" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.spec.sync (type: string)
Owner's Cluster Role
data:image/s3,"s3://crabby-images/c2a67/c2a67cd3623d18440767b826af9b796d931ee580" alt=""
JSONPath in SpaceConstraint CRD:
spec.localSpaceConstraintTemplate.spec.spaceTemplate.clusterRole (type: map[string]string)
Access To Space Constraints
data:image/s3,"s3://crabby-images/267f8/267f867f87cf6c5c4cfe072b9e37d37d10e550ed" alt=""
JSONPath in SpaceConstraint CRD:
spec.access (type: Access[])