All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.databricks.sdk.service.compute.ClusterPoliciesAPI Maven / Gradle / Ivy

The newest version!
// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT.
package com.databricks.sdk.service.compute;

import com.databricks.sdk.core.ApiClient;
import com.databricks.sdk.support.Generated;
import com.databricks.sdk.support.Paginator;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * You can use cluster policies to control users' ability to configure clusters based on a set of
 * rules. These rules specify which attributes or attribute values can be used during cluster
 * creation. Cluster policies have ACLs that limit their use to specific users and groups.
 *
 * 

With cluster policies, you can: - Auto-install cluster libraries on the next restart by * listing them in the policy's "libraries" field (Public Preview). - Limit users to creating * clusters with the prescribed settings. - Simplify the user interface, enabling more users to * create clusters, by fixing and hiding some fields. - Manage costs by setting limits on attributes * that impact the hourly rate. * *

Cluster policy permissions limit which policies a user can select in the Policy drop-down when * the user creates a cluster: - A user who has unrestricted cluster create permission can select * the Unrestricted policy and create fully-configurable clusters. - A user who has both * unrestricted cluster create permission and access to cluster policies can select the Unrestricted * policy and policies they have access to. - A user that has access to only cluster policies, can * select the policies they have access to. * *

If no policies exist in the workspace, the Policy drop-down doesn't appear. Only admin users * can create, edit, and delete policies. Admin users also have access to all policies. */ @Generated public class ClusterPoliciesAPI { private static final Logger LOG = LoggerFactory.getLogger(ClusterPoliciesAPI.class); private final ClusterPoliciesService impl; /** Regular-use constructor */ public ClusterPoliciesAPI(ApiClient apiClient) { impl = new ClusterPoliciesImpl(apiClient); } /** Constructor for mocks */ public ClusterPoliciesAPI(ClusterPoliciesService mock) { impl = mock; } /** * Create a new policy. * *

Creates a new policy with prescribed settings. */ public CreatePolicyResponse create(CreatePolicy request) { return impl.create(request); } public void delete(String policyId) { delete(new DeletePolicy().setPolicyId(policyId)); } /** * Delete a cluster policy. * *

Delete a policy for a cluster. Clusters governed by this policy can still run, but cannot be * edited. */ public void delete(DeletePolicy request) { impl.delete(request); } public void edit(String policyId) { edit(new EditPolicy().setPolicyId(policyId)); } /** * Update a cluster policy. * *

Update an existing policy for cluster. This operation may make some clusters governed by the * previous policy invalid. */ public void edit(EditPolicy request) { impl.edit(request); } public Policy get(String policyId) { return get(new GetClusterPolicyRequest().setPolicyId(policyId)); } /** * Get a cluster policy. * *

Get a cluster policy entity. Creation and editing is available to admins only. */ public Policy get(GetClusterPolicyRequest request) { return impl.get(request); } public GetClusterPolicyPermissionLevelsResponse getPermissionLevels(String clusterPolicyId) { return getPermissionLevels( new GetClusterPolicyPermissionLevelsRequest().setClusterPolicyId(clusterPolicyId)); } /** * Get cluster policy permission levels. * *

Gets the permission levels that a user can have on an object. */ public GetClusterPolicyPermissionLevelsResponse getPermissionLevels( GetClusterPolicyPermissionLevelsRequest request) { return impl.getPermissionLevels(request); } public ClusterPolicyPermissions getPermissions(String clusterPolicyId) { return getPermissions( new GetClusterPolicyPermissionsRequest().setClusterPolicyId(clusterPolicyId)); } /** * Get cluster policy permissions. * *

Gets the permissions of a cluster policy. Cluster policies can inherit permissions from * their root object. */ public ClusterPolicyPermissions getPermissions(GetClusterPolicyPermissionsRequest request) { return impl.getPermissions(request); } /** * List cluster policies. * *

Returns a list of policies accessible by the requesting user. */ public Iterable list(ListClusterPoliciesRequest request) { return new Paginator<>( request, impl::list, ListPoliciesResponse::getPolicies, response -> null); } public ClusterPolicyPermissions setPermissions(String clusterPolicyId) { return setPermissions( new ClusterPolicyPermissionsRequest().setClusterPolicyId(clusterPolicyId)); } /** * Set cluster policy permissions. * *

Sets permissions on an object, replacing existing permissions if they exist. Deletes all * direct permissions if none are specified. Objects can inherit permissions from their root * object. */ public ClusterPolicyPermissions setPermissions(ClusterPolicyPermissionsRequest request) { return impl.setPermissions(request); } public ClusterPolicyPermissions updatePermissions(String clusterPolicyId) { return updatePermissions( new ClusterPolicyPermissionsRequest().setClusterPolicyId(clusterPolicyId)); } /** * Update cluster policy permissions. * *

Updates the permissions on a cluster policy. Cluster policies can inherit permissions from * their root object. */ public ClusterPolicyPermissions updatePermissions(ClusterPolicyPermissionsRequest request) { return impl.updatePermissions(request); } public ClusterPoliciesService impl() { return impl; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy