-
Epic
-
Resolution: Unresolved
-
Critical
-
None
-
None
-
Develop a Security Model
-
BU Product Work
-
8
-
False
-
None
-
False
-
Green
-
To Do
-
OCPSTRAT-134 - Gateway API using Istio for Cluster Ingress - GA
-
OCPSTRAT-134Gateway API using Istio for Cluster Ingress - GA
-
83% To Do, 17% In Progress, 0% Done
-
M
-
0
-
0.000
Develop an initial security model, including any RBAC we need, as we uncover customer requirements.
- Determine in which namespaces admins may create Gateways, at a minimum.
- Which namespaces are allowed by default?
- Which roles (cluster-admin, project-admin, project-editor, etc.) are allowed to do which operations (get, create, delete, etc) on which objects (gatewayclass, gateway, xRoute etc)?
- Do we want Istio to watch all namespace and rely on RBAC to control who can create what?
- Does istio-operator configure RBAC?
See https://issues.redhat.com/browse/OSSM-2221 and answer the question about whether it's ok to inject pods into the control plane namespace.
Deliverables:
- Document a default RBAC policy.
- Document answers for the open questions below, and customizations allowed by the user
Open Questions
- Do we allow project admins (or other users) to create Gateway objects in arbitrary namespaces?
- Pro: The only way to configure custom certificates is to do so on the Gateway.
- Con: Complicates the security model.
- To do: Research listener collapsing (
NE-1000) - To do: Research Istio's conflict resolution.
- To do: Research listener collapsing (
- Con: Increases the attack surface.
- To do: Research whether users are restricted from modifying automatic deployments or reading certificates etc. that Istio injects, and what kind of attack surface these automatic deployments add.
- To do: Research whether users are allowed to create LoadBalancer-type services by default (how did we restrict this on OpenShift Starter/Online?).
- To do: Research how Service Mesh dealt with PodSecurityConstraints, and whether the existing solution is sufficient for automatic deployments in arbitrary namespaces.
- Con: Complicates DNS management.
- Maybe not really an issue—if the project admin wants a DNS record for a custom domain, then OpenShift cannot create the DNS record anyway since OpenShift doesn't own the hosted zone.
- Possible solution: Allow automatic deployments, but only manage DNS for Gateways in the openshift-ingress namespace.