Kubernetes Discovery and Privilege Levels Beta
Last modified on February 4, 2025
This feature is currently in closed-access beta. Functionality and documentation may change. Contact StrongDM for more information.
Automatic resource discovery and privilege levels for Kubernetes, when paired with Identity Aliases, allow you to present StrongDM admins with a list of groups discovered within the cluster and arrange for users of your cluster to get the right amount of access through those groups at the right time. This can be used in several ways:
- You can give different users various levels of standing access to the same resource through adding privilege levels to StrongDM roles.
- You can give users the ability to request various levels of temporary access to a resource through adding privilege levels to access workflows, which users can then select from when requesting access via the Admin UI, CLI, or integrations with apps such as Slack.
- You can assign various privilege levels to users connecting to the cluster through policies, based on their contextual situation.
These features solve the problem of having to add multiple resources to StrongDM using different credentials, in order to provide varying levels of access to the same cluster. They also provide a convenient way to escalate and de-escalate access within the cluster with StrongDM roles, just in time access with access workflows, and policies that allow or forbid access based on privilege levels, or are used to grant them.
This beta guide will walk you through the concept of automatic resource discovery and how to implement privilege levels when providing access to your clusters.
Resource Discovery
If a Kubernetes resource is added to StrongDM and configured with resource discovery enabled, StrongDM continuously discovers information about that Kubernetes cluster. When a user visits the Discovery tab for that cluster in the Admin UI, the latest available information is displayed.
The following items are discovered within the cluster:
- Subjects (users, groups, and service accounts)
- RoleBindings and ClusterRoleBindings
- Namespaces
- Roles and ClusterRoles
- Rules (including Labels and annotations)
This information is made available to admins in the Admin UI, by visiting Resources > Clusters and clicking the particular resource, then the Discovery tab. In the Discovery tab, admins are able to view a list of subjects that is searchable by name and kind. When a subject is selected, the panel to the right displays a list of Roles and ClusterRoles that are associated with the subject, and the details of each Role, including an option to view rules associated with that Role as well.
Discovery is very quick, usually within moments of changes being made within the cluster. If the connection to the cluster is lost due to networking issues, the discovery information is lost within a few hours, but is reacquired when the cluster becomes available again.
Configure clusters to discover resources
When a Kubernetes cluster is added as a resource to your StrongDM organization, an option can be enabled called Enable Resource Discovery. Checking this box in the Admin UI is all that is required to begin automatic discovery within the cluster. If your cluster is configured in StrongDM to use Identity Sets, you also need to add a Discovery Username to the configuration settings, which is the Kubernetes user that you wish automatic discovery to occur with. For clusters set up with leased credentials, the leased credentials are used.
Discovery also requires that you set up a ClusterRole and apply it to the Kubernetes user that is used for discovery, with the following rules:
rules:
- apiGroups: [""]
resources: ["namespaces", "serviceaccounts"]
verbs: ["list", "get", "watch"]
- apiGroups: ["rbac.authorization.k8s.io"]
resources: ["roles", "rolebindings", "clusterroles", "clusterrolebindings"]
verbs: ["list", "get", "watch"]
These rules are the minimum needed for discoverability across the cluster and could be adjusted further based on the discretion of the Kubernetes admin to add further permissions, narrow the scope to particular namespaces, or make other similar alterations.
Kubernetes discovery information
In the Admin UI, under Resources > Clusters and in the details view for the cluster you created, you can see that there is a Discovery tab. The information presented in that tab is what was able to be discovered about your cluster given the connection information and credentials for the cluster, and the discovery username you provided. In the left panel there is a list of subjects (users, groups, and service accounts). If the list of subjects is long, it can be filtered by type or searching for strings in the subject names.
When you select a subject, the Kubernetes Roles associated with that subject are presented on the right. If the list of Roles associated with that subject is too long, it can also be searched or filtered by namespace. Each Role listed has a View Rules button, which will expand a table of information about Rules from the selected Role.
Privilege Levels
When a Kubernetes resource is added to StrongDM, users of that resource have exactly the privileges afforded to the shared (leased) credential used to add the resource. If Identity Aliases are used, they are seen within the cluster as that Identity Alias instead, and they are given privileges accordingly. However, this arrangement would typically require multiple resources to be added to StrongDM if you wish to provide users with multiple options of privileges to request.
Privilege levels make this process much more practical. During discovery, clusters are scanned for Kubernetes groups and those groups are presented in a privilege level list when creating roles, access workflows, access requests, and policies. The administrator chooses what privilege levels should be added to a role or be available upon request. The user is then able to access the cluster with the privileges their Identity Alias would normally afford them, plus any extra access that granted privilege levels provide.
Access workflows
Privilege levels can be used with workflows and requests to allow users to request particular levels of access to the cluster for a set duration of time.
data:image/s3,"s3://crabby-images/944e5/944e545051c61eee5e4b0d37a2f46c5d661c5c45" alt="Privilege Level Selection While Creating an Access Workflow"
When creating an access workflow, resource discovery will provide a list of available Kubernetes groups to use as privilege levels. You can also add your own options if your configuration requires that, or if you are not using discovery. Adding privilege levels allows users to request different levels of access within the resource.
If there is ever a situation where the user could request access to a resource through multiple access rules, and one stipulates the use of privilege levels and the other does not, the privilege levels will be optional.
Access requests
data:image/s3,"s3://crabby-images/ef087/ef087484673e89e3ef4e94a0ac820a090dabede0" alt="Privilege Level Selection While Creating an Access Request"
When making access requests using this workflow, users are able to select from the provided list of privilege levels as options (or choose none to request whatever basic level of access their Identity Alias provides, if there is an access rule without privilege levels that allows this). Multiple privilege levels can be requested at once. If the user does not select privilege levels when they are required by the access rule, the user will be notified of that in the resulting error message.
Once their request is approved, the user will have access to the cluster(s) they requested through StrongDM. When they land in the cluster, they will have the Kubernetes groups that were assigned via privilege levels, in addition to whatever access their Identity Alias provides them.
In addition to the Admin UI, users can make requests involving privilege levels in Slack, Teams, or Jira (if any of those integrations are used by your organization) as well as the StrongDM CLI.
When viewing the catalog of StrongDM resources in the CLI (sdm access catalog
) users will be able to see the privileges that are available to them for a cluster. When making an access request at the CLI, with sdm access to
users can append a --k8sGroup=foo
flag to request a specific privilege level with their request.
-k8sGroup
flags can be added to a request made using the CLI to request multiple privilege levels.Roles
Privilege levels can be used with roles to provide different sets of users with different levels of standing access to the same cluster resource.
data:image/s3,"s3://crabby-images/011fe/011feb50c42cd63c56ca81adffd8385a10c83eb7" alt="Privilege Level Selection While Creating a Role"
When creating a StrongDM role to provide users with standing access to resources, resource discovery provides a list of available Kubernetes groups to use as privilege levels. You can also add your own options if your configuration requires that, or if you are not using discovery. Adding privilege levels allows different roles to have different standing access privileges on the same resource.
For example, if you have a cluster called “k8s-test-cluster”, you might create it using Kubernetes credentials that don’t give much access within the cluster at all. Then, you could create three different roles in StrongDM to give to users that grant access to this cluster: “Service”, “Engineering”, and “Admin”. Each of these StrongDM roles could then have access rules that grant users one or more corresponding groups within your cluster, providing the access those users need in the cluster. Now, The roles can be assigned to users and service accounts to give them various levels of standing access to the same cluster.
When creating the access rules for the role, upon selecting Kubernetes resources (or rules that would include Kubernetes resources) you will have the option to add privilege levels, and be presented with the discovery list. So for your “Engineering” StrongDM role, perhaps you might decide to use a rule to grant access to all development and staging Kubernetes clusters, and add the privilege levels “foo” and “bar”. Now, you can assign engineers to the “Engineering” StrongDM role, and they will be able to access all development/staging clusters through StrongDM. When they land in the cluster, they will have the groups “foo” and “bar” in addition to whatever access their Identity Alias provides them.
Policy
Privilege levels can also be added or limited with policies. See the following examples for more details.
action
statements used in policies pertaining to Kubernetes resources should be appropriately scoped. Typically, you should specify an action (action == "foo"
) rather than leaving it open-ended (action,
), particularly if they include annotations that interrupt the user, such as @justify()
. If not, every new action will result in a new challenge, which can be disruptive.Add privilege levels with policy
This example would permit a specified role to perform a specified action against a particular resource, with the added privilege levels “foo” and “bar”.
@k8s_impersonate_groups(“foo, bar”)
permit (
principal in StrongDM::Role::"r-1caa595464152e78",
action == K8s::Action::"fetchPrivileges",
resource in StrongDM::Resource::"rs-123c12d5654743g66"
);
Forbid based on privilege levels present
Forbid the “impersonate” action if the user’s privilege levels do not contain “devops”, “qa”, or “marketing”.
@error("invalid group")
forbid(
principal,
action == K8s::Action::"impersonate"
resource
) when {
context has k8s && !["devops","qa","marketing"].containsAll(context.k8s.groups)
};
Privilege level limitations
- If you use an access rule to provide access to a group of five AKS clusters, and you select the
engineering
privilege level as one of your options, but one of the five clusters does not actually have a corresponding Kubernetes group forengineering
, nothing will happen. When the user connects to any of these clusters, they will be dropped in with theengineering
group attached, and if that doesn’t exist on the particular cluster they’re connecting to, they just won’t get the expected privileges. Conversely, if an admin at some point adds theengineering
group to that fifth cluster, such an access rule will automatically grant the same users that privilege level when connecting to the cluster, resulting in the potential for unplanned privilege escalation if the Kubernetes administrator and the StrongDM administrator are not in sync. - All Kubernetes resource types that StrongDM supports support discovery and privilege levels except for the “User Impersonation” resource types.
- If privilege levels are selected in an access rule as part of an access workflow, the user is required to choose one of those privilege levels, unless there is a second access rule that applies to the same resource for which the admin did not select any privilege levels. When the admin chooses privilege levels for a resource or group of resources, they are requiring that the user make a choice from those options.