diff --git a/docs/index.md b/docs/index.md index a5f411d35..ffcb79c89 100644 --- a/docs/index.md +++ b/docs/index.md @@ -31,6 +31,7 @@ docs ├── ingress-hostnames.md ├── multiple-tenants.md ├── network-policies.md + ├── node-ports.md ├── nodes-pool.md ├── onboarding.md ├── overview.md diff --git a/docs/operator/use-cases/node-ports.md b/docs/operator/use-cases/node-ports.md new file mode 100644 index 000000000..f94ac6a81 --- /dev/null +++ b/docs/operator/use-cases/node-ports.md @@ -0,0 +1,24 @@ +# Disabling NodePort Services per Tenant + +When dealing with a _shared multi-tenant_ scenario, _NodePort_ services can start becoming cumbersome to manage. + +Reason behind this could be related to the overlapping needs by the Tenant owners, since a _NodePort_ is going to be open on all nodes and, when using `hostNetwork=true`, accessible to any _Pod_ although any specific `NetworkPolicy`. + +Actually, Capsule doesn't block by default the creation of `NodePort` services. + +Although this behavior is not yet manageable using a CRD key, if you need to prevent a Tenant from creating `NodePort` Services, the annotation `capsule.clastix.io/enable-node-ports` can be used as follows. + +```yaml +apiVersion: capsule.clastix.io/v1alpha1 +kind: Tenant +metadata: + name: oil + annotations: + capsule.clastix.io/enable-node-ports: "false" +spec: + owner: + kind: User + name: alice +``` + +With the said configuration, any Namespace owned by the Tenant will not be able to get a Service of type `NodePort` since the creation will be denied by the validation webhook. diff --git a/docs/operator/use-cases/overview.md b/docs/operator/use-cases/overview.md index 12c33e865..dc4f63777 100644 --- a/docs/operator/use-cases/overview.md +++ b/docs/operator/use-cases/overview.md @@ -30,6 +30,7 @@ Bill, at Acme Corp. can use Capsule to address any of the following scenarios: * [Assign Ingress Classes](./ingress-classes.md) * [Assign Ingress Hostnames](./ingress-hostnames.md) * [Assign Storage Classes](./storage-classes.md) +* [Disable NodePort Services](./node-ports.md) * [Assign Network Policies](./network-policies.md) * [Assign Trusted Images Registries](./images-registries.md) * [Assign Pod Security Policies](./pod-security-policies.md)