com.databricks.sdk.service.sharing.RecipientsAPI Maven / Gradle / Ivy
// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT.
package com.databricks.sdk.service.sharing;
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;
/**
* A recipient is an object you create using :method:recipients/create to represent an organization
* which you want to allow access shares. The way how sharing works differs depending on whether or
* not your recipient has access to a Databricks workspace that is enabled for Unity Catalog:
*
* - For recipients with access to a Databricks workspace that is enabled for Unity Catalog, you
* can create a recipient object along with a unique sharing identifier you get from the recipient.
* The sharing identifier is the key identifier that enables the secure connection. This sharing
* mode is called **Databricks-to-Databricks sharing**.
*
*
- For recipients without access to a Databricks workspace that is enabled for Unity Catalog,
* when you create a recipient object, Databricks generates an activation link you can send to the
* recipient. The recipient follows the activation link to download the credential file, and then
* uses the credential file to establish a secure connection to receive the shared data. This
* sharing mode is called **open sharing**.
*/
@Generated
public class RecipientsAPI {
private static final Logger LOG = LoggerFactory.getLogger(RecipientsAPI.class);
private final RecipientsService impl;
/** Regular-use constructor */
public RecipientsAPI(ApiClient apiClient) {
impl = new RecipientsImpl(apiClient);
}
/** Constructor for mocks */
public RecipientsAPI(RecipientsService mock) {
impl = mock;
}
public RecipientInfo create(String name, AuthenticationType authenticationType) {
return create(new CreateRecipient().setName(name).setAuthenticationType(authenticationType));
}
/**
* Create a share recipient.
*
*
Creates a new recipient with the delta sharing authentication type in the metastore. The
* caller must be a metastore admin or has the **CREATE_RECIPIENT** privilege on the metastore.
*/
public RecipientInfo create(CreateRecipient request) {
return impl.create(request);
}
public void delete(String name) {
delete(new DeleteRecipientRequest().setName(name));
}
/**
* Delete a share recipient.
*
*
Deletes the specified recipient from the metastore. The caller must be the owner of the
* recipient.
*/
public void delete(DeleteRecipientRequest request) {
impl.delete(request);
}
public RecipientInfo get(String name) {
return get(new GetRecipientRequest().setName(name));
}
/**
* Get a share recipient.
*
*
Gets a share recipient from the metastore if:
*
*
* the caller is the owner of the share recipient, or: * is a metastore admin
*/
public RecipientInfo get(GetRecipientRequest request) {
return impl.get(request);
}
/**
* List share recipients.
*
*
Gets an array of all share recipients within the current metastore where:
*
*
* the caller is a metastore admin, or * the caller is the owner. There is no guarantee of a
* specific ordering of the elements in the array.
*/
public Iterable list(ListRecipientsRequest request) {
return new Paginator<>(
request,
impl::list,
ListRecipientsResponse::getRecipients,
response -> {
String token = response.getNextPageToken();
if (token == null || token.isEmpty()) {
return null;
}
return request.setPageToken(token);
});
}
public RecipientInfo rotateToken(String name, long existingTokenExpireInSeconds) {
return rotateToken(
new RotateRecipientToken()
.setName(name)
.setExistingTokenExpireInSeconds(existingTokenExpireInSeconds));
}
/**
* Rotate a token.
*
* Refreshes the specified recipient's delta sharing authentication token with the provided
* token info. The caller must be the owner of the recipient.
*/
public RecipientInfo rotateToken(RotateRecipientToken request) {
return impl.rotateToken(request);
}
public GetRecipientSharePermissionsResponse sharePermissions(String name) {
return sharePermissions(new SharePermissionsRequest().setName(name));
}
/**
* Get recipient share permissions.
*
*
Gets the share permissions for the specified Recipient. The caller must be a metastore admin
* or the owner of the Recipient.
*/
public GetRecipientSharePermissionsResponse sharePermissions(SharePermissionsRequest request) {
return impl.sharePermissions(request);
}
public void update(String name) {
update(new UpdateRecipient().setName(name));
}
/**
* Update a share recipient.
*
*
Updates an existing recipient in the metastore. The caller must be a metastore admin or the
* owner of the recipient. If the recipient name will be updated, the user must be both a
* metastore admin and the owner of the recipient.
*/
public void update(UpdateRecipient request) {
impl.update(request);
}
public RecipientsService impl() {
return impl;
}
}