com.databricks.sdk.service.catalog.ExternalLocationsService Maven / Gradle / Ivy
// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT.
package com.databricks.sdk.service.catalog;
import com.databricks.sdk.support.Generated;
/**
* An external location is an object that combines a cloud storage path with a storage credential
* that authorizes access to the cloud storage path. Each external location is subject to Unity
* Catalog access-control policies that control which users and groups can access the credential. If
* a user does not have access to an external location in Unity Catalog, the request fails and Unity
* Catalog does not attempt to authenticate to your cloud tenant on the user’s behalf.
*
* Databricks recommends using external locations rather than using storage credentials directly.
*
*
To create external locations, you must be a metastore admin or a user with the
* **CREATE_EXTERNAL_LOCATION** privilege.
*
*
This is the high-level interface, that contains generated methods.
*
*
Evolving: this interface is under development. Method signatures may change.
*/
@Generated
public interface ExternalLocationsService {
/**
* Create an external location.
*
*
Creates a new external location entry in the metastore. The caller must be a metastore admin
* or have the **CREATE_EXTERNAL_LOCATION** privilege on both the metastore and the associated
* storage credential.
*/
ExternalLocationInfo create(CreateExternalLocation createExternalLocation);
/**
* Delete an external location.
*
*
Deletes the specified external location from the metastore. The caller must be the owner of
* the external location.
*/
void delete(DeleteExternalLocationRequest deleteExternalLocationRequest);
/**
* Get an external location.
*
*
Gets an external location from the metastore. The caller must be either a metastore admin,
* the owner of the external location, or a user that has some privilege on the external location.
*/
ExternalLocationInfo get(GetExternalLocationRequest getExternalLocationRequest);
/**
* List external locations.
*
*
Gets an array of external locations (__ExternalLocationInfo__ objects) from the metastore.
* The caller must be a metastore admin, the owner of the external location, or a user that has
* some privilege on the external location. For unpaginated request, there is no guarantee of a
* specific ordering of the elements in the array. For paginated request, elements are ordered by
* their name.
*/
ListExternalLocationsResponse list(ListExternalLocationsRequest listExternalLocationsRequest);
/**
* Update an external location.
*
*
Updates an external location in the metastore. The caller must be the owner of the external
* location, or be a metastore admin. In the second case, the admin can only update the name of
* the external location.
*/
ExternalLocationInfo update(UpdateExternalLocation updateExternalLocation);
}