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

com.databricks.sdk.service.provisioning.EncryptionKeysAPI Maven / Gradle / Ivy

There is a newer version: 0.38.0
Show newest version
// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT.
package com.databricks.sdk.service.provisioning;

import com.databricks.sdk.core.ApiClient;
import com.databricks.sdk.support.Generated;
import java.util.Collection;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * These APIs manage encryption key configurations for this workspace (optional). A key
 * configuration encapsulates the AWS KMS key information and some information about how the key
 * configuration can be used. There are two possible uses for key configurations:
 *
 * 

* Managed services: A key configuration can be used to encrypt a workspace's notebook and * secret data in the control plane, as well as Databricks SQL queries and query history. * Storage: * A key configuration can be used to encrypt a workspace's DBFS and EBS data in the data plane. * *

In both of these cases, the key configuration's ID is used when creating a new workspace. This * Preview feature is available if your account is on the E2 version of the platform. Updating a * running workspace with workspace storage encryption requires that the workspace is on the E2 * version of the platform. If you have an older workspace, it might not be on the E2 version of the * platform. If you are not sure, contact your Databricks representative. */ @Generated public class EncryptionKeysAPI { private static final Logger LOG = LoggerFactory.getLogger(EncryptionKeysAPI.class); private final EncryptionKeysService impl; /** Regular-use constructor */ public EncryptionKeysAPI(ApiClient apiClient) { impl = new EncryptionKeysImpl(apiClient); } /** Constructor for mocks */ public EncryptionKeysAPI(EncryptionKeysService mock) { impl = mock; } public CustomerManagedKey create(Collection useCases) { return create(new CreateCustomerManagedKeyRequest().setUseCases(useCases)); } /** * Create encryption key configuration. * *

Creates a customer-managed key configuration object for an account, specified by ID. This * operation uploads a reference to a customer-managed key to Databricks. If the key is assigned * as a workspace's customer-managed key for managed services, Databricks uses the key to encrypt * the workspaces notebooks and secrets in the control plane, in addition to Databricks SQL * queries and query history. If it is specified as a workspace's customer-managed key for * workspace storage, the key encrypts the workspace's root S3 bucket (which contains the * workspace's root DBFS and system data) and, optionally, cluster EBS volume data. * *

**Important**: Customer-managed keys are supported only for some deployment types, * subscription types, and AWS regions that currently support creation of Databricks workspaces. * *

This operation is available only if your account is on the E2 version of the platform or on * a select custom plan that allows multiple workspaces per account. */ public CustomerManagedKey create(CreateCustomerManagedKeyRequest request) { return impl.create(request); } public void delete(String customerManagedKeyId) { delete(new DeleteEncryptionKeyRequest().setCustomerManagedKeyId(customerManagedKeyId)); } /** * Delete encryption key configuration. * *

Deletes a customer-managed key configuration object for an account. You cannot delete a * configuration that is associated with a running workspace. */ public void delete(DeleteEncryptionKeyRequest request) { impl.delete(request); } public CustomerManagedKey get(String customerManagedKeyId) { return get(new GetEncryptionKeyRequest().setCustomerManagedKeyId(customerManagedKeyId)); } /** * Get encryption key configuration. * *

Gets a customer-managed key configuration object for an account, specified by ID. This * operation uploads a reference to a customer-managed key to Databricks. If assigned as a * workspace's customer-managed key for managed services, Databricks uses the key to encrypt the * workspaces notebooks and secrets in the control plane, in addition to Databricks SQL queries * and query history. If it is specified as a workspace's customer-managed key for storage, the * key encrypts the workspace's root S3 bucket (which contains the workspace's root DBFS and * system data) and, optionally, cluster EBS volume data. * *

**Important**: Customer-managed keys are supported only for some deployment types, * subscription types, and AWS regions. * *

This operation is available only if your account is on the E2 version of the platform.", */ public CustomerManagedKey get(GetEncryptionKeyRequest request) { return impl.get(request); } /** * Get all encryption key configurations. * *

Gets all customer-managed key configuration objects for an account. If the key is specified * as a workspace's managed services customer-managed key, Databricks uses the key to encrypt the * workspace's notebooks and secrets in the control plane, in addition to Databricks SQL queries * and query history. If the key is specified as a workspace's storage customer-managed key, the * key is used to encrypt the workspace's root S3 bucket and optionally can encrypt cluster EBS * volumes data in the data plane. * *

**Important**: Customer-managed keys are supported only for some deployment types, * subscription types, and AWS regions. * *

This operation is available only if your account is on the E2 version of the platform. */ public Iterable list() { return impl.list(); } public EncryptionKeysService impl() { return impl; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy