UX for Role-Based Access Control
Kubernetes now allows cluster admins to use to secure their clusters. Permissions are managed using the following Kubernetes Resources:
- Role
- ClusterRole
- ClusterRoleBinding
None of these are reflected in the current version of Dashboard UI. There should be a simplified, more user-friendly way to manage a cluster’s access control by abstracting these raw concepts.
Abstraction / Simplification
The only difference between Roles and ClusterRoles is that Roles apply to a specific namespace and ClusterRoles apply to all namespaces. The same is true for RoleBindings and ClusterRoleBindings. The UI should help users to understand these concepts and user flows should be designed to enforce the correct usage.
NOTE: The design proposed in this document will combine certain concepts:
- ClusterRoles will be referred to as Roles for the namespace “all namespaces”
- ClusterRoleBindings will be referred to as RoleBindings for the namespace “all namespaces”
Use Cases
- Briefly introduce the concept of roles and bindings to the user
- Create a Role
- Bind subjects to a Role
- Edit a Role’s rules
Design
The overview can be reached by selecting the “Access Control” nav item in the admin section of the left-hand nav. It shows existing Roles/Bindings, some important details for every item, and allows the user to create a new Role or Role Binding right away. Tabs at the top can be used to switch between Roles and Role Bindings.
Creating a Role
A rule is a selection of API Groups, resource types and verbs. API Groups and resource types can be arbitrary strings. Entering “*” indicates references all resource types / API groups.
Bind Subjects to a Role
Clicking “+ CREATE ROLE BINDING” will open a dialog. After selecting the target Role, adding subjects and selecting the Namespace (“All Namespaces” will create a ClusterRoleBinding), clicking “Create” will create the Role Binding and select that Role Binding from the list, displaying its details in the panel on the right.
NOTE: The existence of the subject entered by the user cannot be verified at the moment, so it is up to the user to make sure the entered information is correct.
Edit a Role
The only property of a Role that cannot be changed is its Namespace, because that determines if the Role is a ClusterRole or not. Apart from that, the user may add and remove rules.
Edit a Role Binding
Role Bindings can be edited by selecting them and selecting “EDIT”. A modal will appear that lets the user edit the Role Binding’s properties. Clicking “SAVE” will save the changes.
Open Questions
- How many Roles/Bindings can usually be found in a cluster (avg,min,max)?
Credits
of the mockups.