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

com.databricks.sdk.WorkspaceClient 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;

import com.databricks.sdk.core.ApiClient;
import com.databricks.sdk.core.ConfigLoader;
import com.databricks.sdk.core.DatabricksConfig;
import com.databricks.sdk.mixin.ClustersExt;
import com.databricks.sdk.mixin.DbfsExt;
import com.databricks.sdk.mixin.SecretsExt;
import com.databricks.sdk.service.catalog.ArtifactAllowlistsAPI;
import com.databricks.sdk.service.catalog.ArtifactAllowlistsService;
import com.databricks.sdk.service.catalog.CatalogsAPI;
import com.databricks.sdk.service.catalog.CatalogsService;
import com.databricks.sdk.service.catalog.ConnectionsAPI;
import com.databricks.sdk.service.catalog.ConnectionsService;
import com.databricks.sdk.service.catalog.ExternalLocationsAPI;
import com.databricks.sdk.service.catalog.ExternalLocationsService;
import com.databricks.sdk.service.catalog.FunctionsAPI;
import com.databricks.sdk.service.catalog.FunctionsService;
import com.databricks.sdk.service.catalog.GrantsAPI;
import com.databricks.sdk.service.catalog.GrantsService;
import com.databricks.sdk.service.catalog.MetastoresAPI;
import com.databricks.sdk.service.catalog.MetastoresService;
import com.databricks.sdk.service.catalog.ModelVersionsAPI;
import com.databricks.sdk.service.catalog.ModelVersionsService;
import com.databricks.sdk.service.catalog.OnlineTablesAPI;
import com.databricks.sdk.service.catalog.OnlineTablesService;
import com.databricks.sdk.service.catalog.QualityMonitorsAPI;
import com.databricks.sdk.service.catalog.QualityMonitorsService;
import com.databricks.sdk.service.catalog.RegisteredModelsAPI;
import com.databricks.sdk.service.catalog.RegisteredModelsService;
import com.databricks.sdk.service.catalog.SchemasAPI;
import com.databricks.sdk.service.catalog.SchemasService;
import com.databricks.sdk.service.catalog.StorageCredentialsAPI;
import com.databricks.sdk.service.catalog.StorageCredentialsService;
import com.databricks.sdk.service.catalog.SystemSchemasAPI;
import com.databricks.sdk.service.catalog.SystemSchemasService;
import com.databricks.sdk.service.catalog.TableConstraintsAPI;
import com.databricks.sdk.service.catalog.TableConstraintsService;
import com.databricks.sdk.service.catalog.TablesAPI;
import com.databricks.sdk.service.catalog.TablesService;
import com.databricks.sdk.service.catalog.VolumesAPI;
import com.databricks.sdk.service.catalog.VolumesService;
import com.databricks.sdk.service.catalog.WorkspaceBindingsAPI;
import com.databricks.sdk.service.catalog.WorkspaceBindingsService;
import com.databricks.sdk.service.compute.ClusterPoliciesAPI;
import com.databricks.sdk.service.compute.ClusterPoliciesService;
import com.databricks.sdk.service.compute.ClustersService;
import com.databricks.sdk.service.compute.CommandExecutionAPI;
import com.databricks.sdk.service.compute.CommandExecutionService;
import com.databricks.sdk.service.compute.GlobalInitScriptsAPI;
import com.databricks.sdk.service.compute.GlobalInitScriptsService;
import com.databricks.sdk.service.compute.InstancePoolsAPI;
import com.databricks.sdk.service.compute.InstancePoolsService;
import com.databricks.sdk.service.compute.InstanceProfilesAPI;
import com.databricks.sdk.service.compute.InstanceProfilesService;
import com.databricks.sdk.service.compute.LibrariesAPI;
import com.databricks.sdk.service.compute.LibrariesService;
import com.databricks.sdk.service.compute.PolicyFamiliesAPI;
import com.databricks.sdk.service.compute.PolicyFamiliesService;
import com.databricks.sdk.service.dashboards.LakeviewAPI;
import com.databricks.sdk.service.dashboards.LakeviewService;
import com.databricks.sdk.service.files.DbfsService;
import com.databricks.sdk.service.files.FilesAPI;
import com.databricks.sdk.service.files.FilesService;
import com.databricks.sdk.service.iam.AccountAccessControlProxyAPI;
import com.databricks.sdk.service.iam.AccountAccessControlProxyService;
import com.databricks.sdk.service.iam.CurrentUserAPI;
import com.databricks.sdk.service.iam.CurrentUserService;
import com.databricks.sdk.service.iam.GroupsAPI;
import com.databricks.sdk.service.iam.GroupsService;
import com.databricks.sdk.service.iam.PermissionMigrationAPI;
import com.databricks.sdk.service.iam.PermissionMigrationService;
import com.databricks.sdk.service.iam.PermissionsAPI;
import com.databricks.sdk.service.iam.PermissionsService;
import com.databricks.sdk.service.iam.ServicePrincipalsAPI;
import com.databricks.sdk.service.iam.ServicePrincipalsService;
import com.databricks.sdk.service.iam.UsersAPI;
import com.databricks.sdk.service.iam.UsersService;
import com.databricks.sdk.service.jobs.JobsAPI;
import com.databricks.sdk.service.jobs.JobsService;
import com.databricks.sdk.service.marketplace.ConsumerFulfillmentsAPI;
import com.databricks.sdk.service.marketplace.ConsumerFulfillmentsService;
import com.databricks.sdk.service.marketplace.ConsumerInstallationsAPI;
import com.databricks.sdk.service.marketplace.ConsumerInstallationsService;
import com.databricks.sdk.service.marketplace.ConsumerListingsAPI;
import com.databricks.sdk.service.marketplace.ConsumerListingsService;
import com.databricks.sdk.service.marketplace.ConsumerPersonalizationRequestsAPI;
import com.databricks.sdk.service.marketplace.ConsumerPersonalizationRequestsService;
import com.databricks.sdk.service.marketplace.ConsumerProvidersAPI;
import com.databricks.sdk.service.marketplace.ConsumerProvidersService;
import com.databricks.sdk.service.marketplace.ProviderExchangeFiltersAPI;
import com.databricks.sdk.service.marketplace.ProviderExchangeFiltersService;
import com.databricks.sdk.service.marketplace.ProviderExchangesAPI;
import com.databricks.sdk.service.marketplace.ProviderExchangesService;
import com.databricks.sdk.service.marketplace.ProviderFilesAPI;
import com.databricks.sdk.service.marketplace.ProviderFilesService;
import com.databricks.sdk.service.marketplace.ProviderListingsAPI;
import com.databricks.sdk.service.marketplace.ProviderListingsService;
import com.databricks.sdk.service.marketplace.ProviderPersonalizationRequestsAPI;
import com.databricks.sdk.service.marketplace.ProviderPersonalizationRequestsService;
import com.databricks.sdk.service.marketplace.ProviderProviderAnalyticsDashboardsAPI;
import com.databricks.sdk.service.marketplace.ProviderProviderAnalyticsDashboardsService;
import com.databricks.sdk.service.marketplace.ProviderProvidersAPI;
import com.databricks.sdk.service.marketplace.ProviderProvidersService;
import com.databricks.sdk.service.ml.ExperimentsAPI;
import com.databricks.sdk.service.ml.ExperimentsService;
import com.databricks.sdk.service.ml.ModelRegistryAPI;
import com.databricks.sdk.service.ml.ModelRegistryService;
import com.databricks.sdk.service.pipelines.PipelinesAPI;
import com.databricks.sdk.service.pipelines.PipelinesService;
import com.databricks.sdk.service.serving.AppsAPI;
import com.databricks.sdk.service.serving.AppsService;
import com.databricks.sdk.service.serving.ServingEndpointsAPI;
import com.databricks.sdk.service.serving.ServingEndpointsService;
import com.databricks.sdk.service.settings.CredentialsManagerAPI;
import com.databricks.sdk.service.settings.CredentialsManagerService;
import com.databricks.sdk.service.settings.IpAccessListsAPI;
import com.databricks.sdk.service.settings.IpAccessListsService;
import com.databricks.sdk.service.settings.SettingsAPI;
import com.databricks.sdk.service.settings.SettingsService;
import com.databricks.sdk.service.settings.TokenManagementAPI;
import com.databricks.sdk.service.settings.TokenManagementService;
import com.databricks.sdk.service.settings.TokensAPI;
import com.databricks.sdk.service.settings.TokensService;
import com.databricks.sdk.service.settings.WorkspaceConfAPI;
import com.databricks.sdk.service.settings.WorkspaceConfService;
import com.databricks.sdk.service.sharing.CleanRoomsAPI;
import com.databricks.sdk.service.sharing.CleanRoomsService;
import com.databricks.sdk.service.sharing.ProvidersAPI;
import com.databricks.sdk.service.sharing.ProvidersService;
import com.databricks.sdk.service.sharing.RecipientActivationAPI;
import com.databricks.sdk.service.sharing.RecipientActivationService;
import com.databricks.sdk.service.sharing.RecipientsAPI;
import com.databricks.sdk.service.sharing.RecipientsService;
import com.databricks.sdk.service.sharing.SharesAPI;
import com.databricks.sdk.service.sharing.SharesService;
import com.databricks.sdk.service.sql.AlertsAPI;
import com.databricks.sdk.service.sql.AlertsService;
import com.databricks.sdk.service.sql.DashboardWidgetsAPI;
import com.databricks.sdk.service.sql.DashboardWidgetsService;
import com.databricks.sdk.service.sql.DashboardsAPI;
import com.databricks.sdk.service.sql.DashboardsService;
import com.databricks.sdk.service.sql.DataSourcesAPI;
import com.databricks.sdk.service.sql.DataSourcesService;
import com.databricks.sdk.service.sql.DbsqlPermissionsAPI;
import com.databricks.sdk.service.sql.DbsqlPermissionsService;
import com.databricks.sdk.service.sql.QueriesAPI;
import com.databricks.sdk.service.sql.QueriesService;
import com.databricks.sdk.service.sql.QueryHistoryAPI;
import com.databricks.sdk.service.sql.QueryHistoryService;
import com.databricks.sdk.service.sql.QueryVisualizationsAPI;
import com.databricks.sdk.service.sql.QueryVisualizationsService;
import com.databricks.sdk.service.sql.StatementExecutionAPI;
import com.databricks.sdk.service.sql.StatementExecutionService;
import com.databricks.sdk.service.sql.WarehousesAPI;
import com.databricks.sdk.service.sql.WarehousesService;
import com.databricks.sdk.service.vectorsearch.VectorSearchEndpointsAPI;
import com.databricks.sdk.service.vectorsearch.VectorSearchEndpointsService;
import com.databricks.sdk.service.vectorsearch.VectorSearchIndexesAPI;
import com.databricks.sdk.service.vectorsearch.VectorSearchIndexesService;
import com.databricks.sdk.service.workspace.GitCredentialsAPI;
import com.databricks.sdk.service.workspace.GitCredentialsService;
import com.databricks.sdk.service.workspace.ReposAPI;
import com.databricks.sdk.service.workspace.ReposService;
import com.databricks.sdk.service.workspace.SecretsService;
import com.databricks.sdk.service.workspace.WorkspaceAPI;
import com.databricks.sdk.service.workspace.WorkspaceService;
import com.databricks.sdk.support.Generated;

/** Entry point for accessing Databricks workspace-level APIs */
@Generated
public class WorkspaceClient {
  private final ApiClient apiClient;
  private final DatabricksConfig config;

  private AccountAccessControlProxyAPI accountAccessControlProxyAPI;
  private AlertsAPI alertsAPI;
  private AppsAPI appsAPI;
  private ArtifactAllowlistsAPI artifactAllowlistsAPI;
  private CatalogsAPI catalogsAPI;
  private CleanRoomsAPI cleanRoomsAPI;
  private ClusterPoliciesAPI clusterPoliciesAPI;
  private ClustersExt clustersAPI;
  private CommandExecutionAPI commandExecutionAPI;
  private ConnectionsAPI connectionsAPI;
  private ConsumerFulfillmentsAPI consumerFulfillmentsAPI;
  private ConsumerInstallationsAPI consumerInstallationsAPI;
  private ConsumerListingsAPI consumerListingsAPI;
  private ConsumerPersonalizationRequestsAPI consumerPersonalizationRequestsAPI;
  private ConsumerProvidersAPI consumerProvidersAPI;
  private CredentialsManagerAPI credentialsManagerAPI;
  private CurrentUserAPI currentUserAPI;
  private DashboardWidgetsAPI dashboardWidgetsAPI;
  private DashboardsAPI dashboardsAPI;
  private DataSourcesAPI dataSourcesAPI;
  private DbfsExt dbfsAPI;
  private DbsqlPermissionsAPI dbsqlPermissionsAPI;
  private ExperimentsAPI experimentsAPI;
  private ExternalLocationsAPI externalLocationsAPI;
  private FilesAPI filesAPI;
  private FunctionsAPI functionsAPI;
  private GitCredentialsAPI gitCredentialsAPI;
  private GlobalInitScriptsAPI globalInitScriptsAPI;
  private GrantsAPI grantsAPI;
  private GroupsAPI groupsAPI;
  private InstancePoolsAPI instancePoolsAPI;
  private InstanceProfilesAPI instanceProfilesAPI;
  private IpAccessListsAPI ipAccessListsAPI;
  private JobsAPI jobsAPI;
  private LakeviewAPI lakeviewAPI;
  private LibrariesAPI librariesAPI;
  private MetastoresAPI metastoresAPI;
  private ModelRegistryAPI modelRegistryAPI;
  private ModelVersionsAPI modelVersionsAPI;
  private OnlineTablesAPI onlineTablesAPI;
  private PermissionMigrationAPI permissionMigrationAPI;
  private PermissionsAPI permissionsAPI;
  private PipelinesAPI pipelinesAPI;
  private PolicyFamiliesAPI policyFamiliesAPI;
  private ProviderExchangeFiltersAPI providerExchangeFiltersAPI;
  private ProviderExchangesAPI providerExchangesAPI;
  private ProviderFilesAPI providerFilesAPI;
  private ProviderListingsAPI providerListingsAPI;
  private ProviderPersonalizationRequestsAPI providerPersonalizationRequestsAPI;
  private ProviderProviderAnalyticsDashboardsAPI providerProviderAnalyticsDashboardsAPI;
  private ProviderProvidersAPI providerProvidersAPI;
  private ProvidersAPI providersAPI;
  private QualityMonitorsAPI qualityMonitorsAPI;
  private QueriesAPI queriesAPI;
  private QueryHistoryAPI queryHistoryAPI;
  private QueryVisualizationsAPI queryVisualizationsAPI;
  private RecipientActivationAPI recipientActivationAPI;
  private RecipientsAPI recipientsAPI;
  private RegisteredModelsAPI registeredModelsAPI;
  private ReposAPI reposAPI;
  private SchemasAPI schemasAPI;
  private SecretsExt secretsAPI;
  private ServicePrincipalsAPI servicePrincipalsAPI;
  private ServingEndpointsAPI servingEndpointsAPI;
  private SettingsAPI settingsAPI;
  private SharesAPI sharesAPI;
  private StatementExecutionAPI statementExecutionAPI;
  private StorageCredentialsAPI storageCredentialsAPI;
  private SystemSchemasAPI systemSchemasAPI;
  private TableConstraintsAPI tableConstraintsAPI;
  private TablesAPI tablesAPI;
  private TokenManagementAPI tokenManagementAPI;
  private TokensAPI tokensAPI;
  private UsersAPI usersAPI;
  private VectorSearchEndpointsAPI vectorSearchEndpointsAPI;
  private VectorSearchIndexesAPI vectorSearchIndexesAPI;
  private VolumesAPI volumesAPI;
  private WarehousesAPI warehousesAPI;
  private WorkspaceAPI workspaceAPI;
  private WorkspaceBindingsAPI workspaceBindingsAPI;
  private WorkspaceConfAPI workspaceConfAPI;

  public WorkspaceClient() {
    this(ConfigLoader.getDefault());
  }

  public WorkspaceClient(DatabricksConfig config) {
    this.config = config;
    apiClient = new ApiClient(config);

    accountAccessControlProxyAPI = new AccountAccessControlProxyAPI(apiClient);
    alertsAPI = new AlertsAPI(apiClient);
    appsAPI = new AppsAPI(apiClient);
    artifactAllowlistsAPI = new ArtifactAllowlistsAPI(apiClient);
    catalogsAPI = new CatalogsAPI(apiClient);
    cleanRoomsAPI = new CleanRoomsAPI(apiClient);
    clusterPoliciesAPI = new ClusterPoliciesAPI(apiClient);
    clustersAPI = new ClustersExt(apiClient);
    commandExecutionAPI = new CommandExecutionAPI(apiClient);
    connectionsAPI = new ConnectionsAPI(apiClient);
    consumerFulfillmentsAPI = new ConsumerFulfillmentsAPI(apiClient);
    consumerInstallationsAPI = new ConsumerInstallationsAPI(apiClient);
    consumerListingsAPI = new ConsumerListingsAPI(apiClient);
    consumerPersonalizationRequestsAPI = new ConsumerPersonalizationRequestsAPI(apiClient);
    consumerProvidersAPI = new ConsumerProvidersAPI(apiClient);
    credentialsManagerAPI = new CredentialsManagerAPI(apiClient);
    currentUserAPI = new CurrentUserAPI(apiClient);
    dashboardWidgetsAPI = new DashboardWidgetsAPI(apiClient);
    dashboardsAPI = new DashboardsAPI(apiClient);
    dataSourcesAPI = new DataSourcesAPI(apiClient);
    dbfsAPI = new DbfsExt(apiClient);
    dbsqlPermissionsAPI = new DbsqlPermissionsAPI(apiClient);
    experimentsAPI = new ExperimentsAPI(apiClient);
    externalLocationsAPI = new ExternalLocationsAPI(apiClient);
    filesAPI = new FilesAPI(apiClient);
    functionsAPI = new FunctionsAPI(apiClient);
    gitCredentialsAPI = new GitCredentialsAPI(apiClient);
    globalInitScriptsAPI = new GlobalInitScriptsAPI(apiClient);
    grantsAPI = new GrantsAPI(apiClient);
    groupsAPI = new GroupsAPI(apiClient);
    instancePoolsAPI = new InstancePoolsAPI(apiClient);
    instanceProfilesAPI = new InstanceProfilesAPI(apiClient);
    ipAccessListsAPI = new IpAccessListsAPI(apiClient);
    jobsAPI = new JobsAPI(apiClient);
    lakeviewAPI = new LakeviewAPI(apiClient);
    librariesAPI = new LibrariesAPI(apiClient);
    metastoresAPI = new MetastoresAPI(apiClient);
    modelRegistryAPI = new ModelRegistryAPI(apiClient);
    modelVersionsAPI = new ModelVersionsAPI(apiClient);
    onlineTablesAPI = new OnlineTablesAPI(apiClient);
    permissionMigrationAPI = new PermissionMigrationAPI(apiClient);
    permissionsAPI = new PermissionsAPI(apiClient);
    pipelinesAPI = new PipelinesAPI(apiClient);
    policyFamiliesAPI = new PolicyFamiliesAPI(apiClient);
    providerExchangeFiltersAPI = new ProviderExchangeFiltersAPI(apiClient);
    providerExchangesAPI = new ProviderExchangesAPI(apiClient);
    providerFilesAPI = new ProviderFilesAPI(apiClient);
    providerListingsAPI = new ProviderListingsAPI(apiClient);
    providerPersonalizationRequestsAPI = new ProviderPersonalizationRequestsAPI(apiClient);
    providerProviderAnalyticsDashboardsAPI = new ProviderProviderAnalyticsDashboardsAPI(apiClient);
    providerProvidersAPI = new ProviderProvidersAPI(apiClient);
    providersAPI = new ProvidersAPI(apiClient);
    qualityMonitorsAPI = new QualityMonitorsAPI(apiClient);
    queriesAPI = new QueriesAPI(apiClient);
    queryHistoryAPI = new QueryHistoryAPI(apiClient);
    queryVisualizationsAPI = new QueryVisualizationsAPI(apiClient);
    recipientActivationAPI = new RecipientActivationAPI(apiClient);
    recipientsAPI = new RecipientsAPI(apiClient);
    registeredModelsAPI = new RegisteredModelsAPI(apiClient);
    reposAPI = new ReposAPI(apiClient);
    schemasAPI = new SchemasAPI(apiClient);
    secretsAPI = new SecretsExt(apiClient);
    servicePrincipalsAPI = new ServicePrincipalsAPI(apiClient);
    servingEndpointsAPI = new ServingEndpointsAPI(apiClient);
    settingsAPI = new SettingsAPI(apiClient);
    sharesAPI = new SharesAPI(apiClient);
    statementExecutionAPI = new StatementExecutionAPI(apiClient);
    storageCredentialsAPI = new StorageCredentialsAPI(apiClient);
    systemSchemasAPI = new SystemSchemasAPI(apiClient);
    tableConstraintsAPI = new TableConstraintsAPI(apiClient);
    tablesAPI = new TablesAPI(apiClient);
    tokenManagementAPI = new TokenManagementAPI(apiClient);
    tokensAPI = new TokensAPI(apiClient);
    usersAPI = new UsersAPI(apiClient);
    vectorSearchEndpointsAPI = new VectorSearchEndpointsAPI(apiClient);
    vectorSearchIndexesAPI = new VectorSearchIndexesAPI(apiClient);
    volumesAPI = new VolumesAPI(apiClient);
    warehousesAPI = new WarehousesAPI(apiClient);
    workspaceAPI = new WorkspaceAPI(apiClient);
    workspaceBindingsAPI = new WorkspaceBindingsAPI(apiClient);
    workspaceConfAPI = new WorkspaceConfAPI(apiClient);
  }

  /** Constructor for mocks */
  public WorkspaceClient(boolean mock) {
    this(mock, null /* apiClient */);
  }

  /** Constructor for mocks */
  public WorkspaceClient(boolean mock, ApiClient apiClient) {
    this.apiClient = apiClient;
    this.config = null;
  }

  /**
   * These APIs manage access rules on resources in an account. Currently, only grant rules are
   * supported. A grant rule specifies a role assigned to a set of principals. A list of rules
   * attached to a resource is called a rule set. A workspace must belong to an account for these
   * APIs to work.
   */
  public AccountAccessControlProxyAPI accountAccessControlProxy() {
    return accountAccessControlProxyAPI;
  }

  /**
   * The alerts API can be used to perform CRUD operations on alerts. An alert is a Databricks SQL
   * object that periodically runs a query, evaluates a condition of its result, and notifies one or
   * more users and/or notification destinations if the condition was met. Alerts can be scheduled
   * using the `sql_task` type of the Jobs API, e.g. :method:jobs/create.
   *
   * 

**Note**: A new version of the Databricks SQL API will soon be available. [Learn more] * *

[Learn more]: * https://docs.databricks.com/en/whats-coming.html#updates-to-the-databricks-sql-api-for-managing-queries-alerts-and-data-sources */ public AlertsAPI alerts() { return alertsAPI; } /** * Apps run directly on a customer’s Databricks instance, integrate with their data, use and * extend Databricks services, and enable users to interact through single sign-on. */ public AppsAPI apps() { return appsAPI; } /** * In Databricks Runtime 13.3 and above, you can add libraries and init scripts to the `allowlist` * in UC so that users can leverage these artifacts on compute configured with shared access mode. */ public ArtifactAllowlistsAPI artifactAllowlists() { return artifactAllowlistsAPI; } /** * A catalog is the first layer of Unity Catalog’s three-level namespace. It’s used to organize * your data assets. Users can see all catalogs on which they have been assigned the USE_CATALOG * data permission. * *

In Unity Catalog, admins and data stewards manage users and their access to data centrally * across all of the workspaces in a Databricks account. Users in different workspaces can share * access to the same data, depending on privileges granted centrally in Unity Catalog. */ public CatalogsAPI catalogs() { return catalogsAPI; } /** * A clean room is a secure, privacy-protecting environment where two or more parties can share * sensitive enterprise data, including customer data, for measurements, insights, activation and * other use cases. * *

To create clean rooms, you must be a metastore admin or a user with the * **CREATE_CLEAN_ROOM** privilege. */ public CleanRoomsAPI cleanRooms() { return cleanRoomsAPI; } /** * 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. */ public ClusterPoliciesAPI clusterPolicies() { return clusterPoliciesAPI; } /** * The Clusters API allows you to create, start, edit, list, terminate, and delete clusters. * *

Databricks maps cluster node instance types to compute units known as DBUs. See the instance * type pricing page for a list of the supported instance types and their corresponding DBUs. * *

A Databricks cluster is a set of computation resources and configurations on which you run * data engineering, data science, and data analytics workloads, such as production ETL pipelines, * streaming analytics, ad-hoc analytics, and machine learning. * *

You run these workloads as a set of commands in a notebook or as an automated job. * Databricks makes a distinction between all-purpose clusters and job clusters. You use * all-purpose clusters to analyze data collaboratively using interactive notebooks. You use job * clusters to run fast and robust automated jobs. * *

You can create an all-purpose cluster using the UI, CLI, or REST API. You can manually * terminate and restart an all-purpose cluster. Multiple users can share such clusters to do * collaborative interactive analysis. * *

IMPORTANT: Databricks retains cluster configuration information for up to 200 all-purpose * clusters terminated in the last 30 days and up to 30 job clusters recently terminated by the * job scheduler. To keep an all-purpose cluster configuration even after it has been terminated * for more than 30 days, an administrator can pin a cluster to the cluster list. */ public ClustersExt clusters() { return clustersAPI; } /** * This API allows execution of Python, Scala, SQL, or R commands on running Databricks Clusters. */ public CommandExecutionAPI commandExecution() { return commandExecutionAPI; } /** * Connections allow for creating a connection to an external data source. * *

A connection is an abstraction of an external data source that can be connected from * Databricks Compute. Creating a connection object is the first step to managing external data * sources within Unity Catalog, with the second step being creating a data object (catalog, * schema, or table) using the connection. Data objects derived from a connection can be written * to or read from similar to other Unity Catalog data objects based on cloud storage. Users may * create different types of connections with each connection having a unique set of configuration * options to support credential management and other settings. */ public ConnectionsAPI connections() { return connectionsAPI; } /** Fulfillments are entities that allow consumers to preview installations. */ public ConsumerFulfillmentsAPI consumerFulfillments() { return consumerFulfillmentsAPI; } /** * Installations are entities that allow consumers to interact with Databricks Marketplace * listings. */ public ConsumerInstallationsAPI consumerInstallations() { return consumerInstallationsAPI; } /** * Listings are the core entities in the Marketplace. They represent the products that are * available for consumption. */ public ConsumerListingsAPI consumerListings() { return consumerListingsAPI; } /** * Personalization Requests allow customers to interact with the individualized Marketplace * listing flow. */ public ConsumerPersonalizationRequestsAPI consumerPersonalizationRequests() { return consumerPersonalizationRequestsAPI; } /** Providers are the entities that publish listings to the Marketplace. */ public ConsumerProvidersAPI consumerProviders() { return consumerProvidersAPI; } /** * Credentials manager interacts with with Identity Providers to to perform token exchanges using * stored credentials and refresh tokens. */ public CredentialsManagerAPI credentialsManager() { return credentialsManagerAPI; } /** * This API allows retrieving information about currently authenticated user or service principal. */ public CurrentUserAPI currentUser() { return currentUserAPI; } /** * This is an evolving API that facilitates the addition and removal of widgets from existing * dashboards within the Databricks Workspace. Data structures may change over time. */ public DashboardWidgetsAPI dashboardWidgets() { return dashboardWidgetsAPI; } /** * In general, there is little need to modify dashboards using the API. However, it can be useful * to use dashboard objects to look-up a collection of related query IDs. The API can also be used * to duplicate multiple dashboards at once since you can get a dashboard definition with a GET * request and then POST it to create a new one. Dashboards can be scheduled using the `sql_task` * type of the Jobs API, e.g. :method:jobs/create. */ public DashboardsAPI dashboards() { return dashboardsAPI; } /** * This API is provided to assist you in making new query objects. When creating a query object, * you may optionally specify a `data_source_id` for the SQL warehouse against which it will run. * If you don't already know the `data_source_id` for your desired SQL warehouse, this API will * help you find it. * *

This API does not support searches. It returns the full list of SQL warehouses in your * workspace. We advise you to use any text editor, REST client, or `grep` to search the response * from this API for the name of your SQL warehouse as it appears in Databricks SQL. * *

**Note**: A new version of the Databricks SQL API will soon be available. [Learn more] * *

[Learn more]: * https://docs.databricks.com/en/whats-coming.html#updates-to-the-databricks-sql-api-for-managing-queries-alerts-and-data-sources */ public DataSourcesAPI dataSources() { return dataSourcesAPI; } /** * DBFS API makes it simple to interact with various data sources without having to include a * users credentials every time to read a file. */ public DbfsExt dbfs() { return dbfsAPI; } /** * The SQL Permissions API is similar to the endpoints of the :method:permissions/set. However, * this exposes only one endpoint, which gets the Access Control List for a given object. You * cannot modify any permissions using this API. * *

There are three levels of permission: * *

- `CAN_VIEW`: Allows read-only access * *

- `CAN_RUN`: Allows read access and run access (superset of `CAN_VIEW`) * *

- `CAN_MANAGE`: Allows all actions: read, run, edit, delete, modify permissions (superset of * `CAN_RUN`) * *

**Note**: A new version of the Databricks SQL API will soon be available. [Learn more] * *

[Learn more]: * https://docs.databricks.com/en/whats-coming.html#updates-to-the-databricks-sql-api-for-managing-queries-alerts-and-data-sources */ public DbsqlPermissionsAPI dbsqlPermissions() { return dbsqlPermissionsAPI; } /** * Experiments are the primary unit of organization in MLflow; all MLflow runs belong to an * experiment. Each experiment lets you visualize, search, and compare runs, as well as download * run artifacts or metadata for analysis in other tools. Experiments are maintained in a * Databricks hosted MLflow tracking server. * *

Experiments are located in the workspace file tree. You manage experiments using the same * tools you use to manage other workspace objects such as folders, notebooks, and libraries. */ public ExperimentsAPI experiments() { return experimentsAPI; } /** * 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. */ public ExternalLocationsAPI externalLocations() { return externalLocationsAPI; } /** * The Files API is a standard HTTP API that allows you to read, write, list, and delete files and * directories by referring to their URI. The API makes working with file content as raw bytes * easier and more efficient. * *

The API supports [Unity Catalog volumes], where files and directories to operate on are * specified using their volume URI path, which follows the format * /Volumes/<catalog_name>/<schema_name>/<volume_name>/<path_to_file>. * *

The Files API has two distinct endpoints, one for working with files (`/fs/files`) and * another one for working with directories (`/fs/directories`). Both endpoints, use the standard * HTTP methods GET, HEAD, PUT, and DELETE to manage files and directories specified using their * URI path. The path is always absolute. * *

[Unity Catalog volumes]: https://docs.databricks.com/en/connect/unity-catalog/volumes.html */ public FilesAPI files() { return filesAPI; } /** * Functions implement User-Defined Functions (UDFs) in Unity Catalog. * *

The function implementation can be any SQL expression or Query, and it can be invoked * wherever a table reference is allowed in a query. In Unity Catalog, a function resides at the * same level as a table, so it can be referenced with the form * __catalog_name__.__schema_name__.__function_name__. */ public FunctionsAPI functions() { return functionsAPI; } /** * Registers personal access token for Databricks to do operations on behalf of the user. * *

See [more info]. * *

[more info]: https://docs.databricks.com/repos/get-access-tokens-from-git-provider.html */ public GitCredentialsAPI gitCredentials() { return gitCredentialsAPI; } /** * The Global Init Scripts API enables Workspace administrators to configure global initialization * scripts for their workspace. These scripts run on every node in every cluster in the workspace. * *

**Important:** Existing clusters must be restarted to pick up any changes made to global * init scripts. Global init scripts are run in order. If the init script returns with a bad exit * code, the Apache Spark container fails to launch and init scripts with later position are * skipped. If enough containers fail, the entire cluster fails with a * `GLOBAL_INIT_SCRIPT_FAILURE` error code. */ public GlobalInitScriptsAPI globalInitScripts() { return globalInitScriptsAPI; } /** * In Unity Catalog, data is secure by default. Initially, users have no access to data in a * metastore. Access can be granted by either a metastore admin, the owner of an object, or the * owner of the catalog or schema that contains the object. Securable objects in Unity Catalog are * hierarchical and privileges are inherited downward. * *

Securable objects in Unity Catalog are hierarchical and privileges are inherited downward. * This means that granting a privilege on the catalog automatically grants the privilege to all * current and future objects within the catalog. Similarly, privileges granted on a schema are * inherited by all current and future objects within that schema. */ public GrantsAPI grants() { return grantsAPI; } /** * Groups simplify identity management, making it easier to assign access to Databricks workspace, * data, and other securable objects. * *

It is best practice to assign access to workspaces and access-control policies in Unity * Catalog to groups, instead of to users individually. All Databricks workspace identities can be * assigned as members of groups, and members inherit permissions that are assigned to their * group. */ public GroupsAPI groups() { return groupsAPI; } /** * Instance Pools API are used to create, edit, delete and list instance pools by using * ready-to-use cloud instances which reduces a cluster start and auto-scaling times. * *

Databricks pools reduce cluster start and auto-scaling times by maintaining a set of idle, * ready-to-use instances. When a cluster is attached to a pool, cluster nodes are created using * the pool’s idle instances. If the pool has no idle instances, the pool expands by allocating a * new instance from the instance provider in order to accommodate the cluster’s request. When a * cluster releases an instance, it returns to the pool and is free for another cluster to use. * Only clusters attached to a pool can use that pool’s idle instances. * *

You can specify a different pool for the driver node and worker nodes, or use the same pool * for both. * *

Databricks does not charge DBUs while instances are idle in the pool. Instance provider * billing does apply. See pricing. */ public InstancePoolsAPI instancePools() { return instancePoolsAPI; } /** * The Instance Profiles API allows admins to add, list, and remove instance profiles that users * can launch clusters with. Regular users can list the instance profiles available to them. See * [Secure access to S3 buckets] using instance profiles for more information. * *

[Secure access to S3 buckets]: * https://docs.databricks.com/administration-guide/cloud-configurations/aws/instance-profiles.html */ public InstanceProfilesAPI instanceProfiles() { return instanceProfilesAPI; } /** * IP Access List enables admins to configure IP access lists. * *

IP access lists affect web application access and REST API access to this workspace only. If * the feature is disabled for a workspace, all access is allowed for this workspace. There is * support for allow lists (inclusion) and block lists (exclusion). * *

When a connection is attempted: 1. **First, all block lists are checked.** If the connection * IP address matches any block list, the connection is rejected. 2. **If the connection was not * rejected by block lists**, the IP address is compared with the allow lists. * *

If there is at least one allow list for the workspace, the connection is allowed only if the * IP address matches an allow list. If there are no allow lists for the workspace, all IP * addresses are allowed. * *

For all allow lists and block lists combined, the workspace supports a maximum of 1000 * IP/CIDR values, where one CIDR counts as a single value. * *

After changes to the IP access list feature, it can take a few minutes for changes to take * effect. */ public IpAccessListsAPI ipAccessLists() { return ipAccessListsAPI; } /** * The Jobs API allows you to create, edit, and delete jobs. * *

You can use a Databricks job to run a data processing or data analysis task in a Databricks * cluster with scalable resources. Your job can consist of a single task or can be a large, * multi-task workflow with complex dependencies. Databricks manages the task orchestration, * cluster management, monitoring, and error reporting for all of your jobs. You can run your jobs * immediately or periodically through an easy-to-use scheduling system. You can implement job * tasks using notebooks, JARS, Delta Live Tables pipelines, or Python, Scala, Spark submit, and * Java applications. * *

You should never hard code secrets or store them in plain text. Use the [Secrets CLI] to * manage secrets in the [Databricks CLI]. Use the [Secrets utility] to reference secrets in * notebooks and jobs. * *

[Databricks CLI]: https://docs.databricks.com/dev-tools/cli/index.html [Secrets CLI]: * https://docs.databricks.com/dev-tools/cli/secrets-cli.html [Secrets utility]: * https://docs.databricks.com/dev-tools/databricks-utils.html#dbutils-secrets */ public JobsAPI jobs() { return jobsAPI; } /** * These APIs provide specific management operations for Lakeview dashboards. Generic resource * management can be done with Workspace API (import, export, get-status, list, delete). */ public LakeviewAPI lakeview() { return lakeviewAPI; } /** * The Libraries API allows you to install and uninstall libraries and get the status of libraries * on a cluster. * *

To make third-party or custom code available to notebooks and jobs running on your clusters, * you can install a library. Libraries can be written in Python, Java, Scala, and R. You can * upload Python, Java, Scala and R libraries and point to external packages in PyPI, Maven, and * CRAN repositories. * *

Cluster libraries can be used by all notebooks running on a cluster. You can install a * cluster library directly from a public repository such as PyPI or Maven, using a previously * installed workspace library, or using an init script. * *

When you uninstall a library from a cluster, the library is removed only when you restart * the cluster. Until you restart the cluster, the status of the uninstalled library appears as * Uninstall pending restart. */ public LibrariesAPI libraries() { return librariesAPI; } /** * A metastore is the top-level container of objects in Unity Catalog. It stores data assets * (tables and views) and the permissions that govern access to them. Databricks account admins * can create metastores and assign them to Databricks workspaces to control which workloads use * each metastore. For a workspace to use Unity Catalog, it must have a Unity Catalog metastore * attached. * *

Each metastore is configured with a root storage location in a cloud storage account. This * storage location is used for metadata and managed tables data. * *

NOTE: This metastore is distinct from the metastore included in Databricks workspaces * created before Unity Catalog was released. If your workspace includes a legacy Hive metastore, * the data in that metastore is available in a catalog named hive_metastore. */ public MetastoresAPI metastores() { return metastoresAPI; } /** * Note: This API reference documents APIs for the Workspace Model Registry. Databricks recommends * using [Models in Unity Catalog](/api/workspace/registeredmodels) instead. Models in Unity * Catalog provides centralized model governance, cross-workspace access, lineage, and deployment. * Workspace Model Registry will be deprecated in the future. * *

The Workspace Model Registry is a centralized model repository and a UI and set of APIs that * enable you to manage the full lifecycle of MLflow Models. */ public ModelRegistryAPI modelRegistry() { return modelRegistryAPI; } /** * Databricks provides a hosted version of MLflow Model Registry in Unity Catalog. Models in Unity * Catalog provide centralized access control, auditing, lineage, and discovery of ML models * across Databricks workspaces. * *

This API reference documents the REST endpoints for managing model versions in Unity * Catalog. For more details, see the [registered models API * docs](/api/workspace/registeredmodels). */ public ModelVersionsAPI modelVersions() { return modelVersionsAPI; } /** Online tables provide lower latency and higher QPS access to data from Delta tables. */ public OnlineTablesAPI onlineTables() { return onlineTablesAPI; } /** * This spec contains undocumented permission migration APIs used in * https://github.com/databrickslabs/ucx. */ public PermissionMigrationAPI permissionMigration() { return permissionMigrationAPI; } /** * Permissions API are used to create read, write, edit, update and manage access for various * users on different objects and endpoints. * *

* **[Cluster permissions](:service:clusters)** — Manage which users can manage, restart, or * attach to clusters. * *

* **[Cluster policy permissions](:service:clusterpolicies)** — Manage which users can use * cluster policies. * *

* **[Delta Live Tables pipeline permissions](:service:pipelines)** — Manage which users can * view, manage, run, cancel, or own a Delta Live Tables pipeline. * *

* **[Job permissions](:service:jobs)** — Manage which users can view, manage, trigger, * cancel, or own a job. * *

* **[MLflow experiment permissions](:service:experiments)** — Manage which users can read, * edit, or manage MLflow experiments. * *

* **[MLflow registered model permissions](:service:modelregistry)** — Manage which users can * read, edit, or manage MLflow registered models. * *

* **[Password permissions](:service:users)** — Manage which users can use password login * when SSO is enabled. * *

* **[Instance Pool permissions](:service:instancepools)** — Manage which users can manage or * attach to pools. * *

* **[Repo permissions](repos)** — Manage which users can read, run, edit, or manage a repo. * *

* **[Serving endpoint permissions](:service:servingendpoints)** — Manage which users can * view, query, or manage a serving endpoint. * *

* **[SQL warehouse permissions](:service:warehouses)** — Manage which users can use or * manage SQL warehouses. * *

* **[Token permissions](:service:tokenmanagement)** — Manage which users can create or use * tokens. * *

* **[Workspace object permissions](:service:workspace)** — Manage which users can read, run, * edit, or manage directories, files, and notebooks. * *

For the mapping of the required permissions for specific actions or abilities and other * important information, see [Access Control]. * *

Note that to manage access control on service principals, use **[Account Access Control * Proxy](:service:accountaccesscontrolproxy)**. * *

[Access Control]: https://docs.databricks.com/security/auth-authz/access-control/index.html */ public PermissionsAPI permissions() { return permissionsAPI; } /** * The Delta Live Tables API allows you to create, edit, delete, start, and view details about * pipelines. * *

Delta Live Tables is a framework for building reliable, maintainable, and testable data * processing pipelines. You define the transformations to perform on your data, and Delta Live * Tables manages task orchestration, cluster management, monitoring, data quality, and error * handling. * *

Instead of defining your data pipelines using a series of separate Apache Spark tasks, Delta * Live Tables manages how your data is transformed based on a target schema you define for each * processing step. You can also enforce data quality with Delta Live Tables expectations. * Expectations allow you to define expected data quality and specify how to handle records that * fail those expectations. */ public PipelinesAPI pipelines() { return pipelinesAPI; } /** * View available policy families. A policy family contains a policy definition providing best * practices for configuring clusters for a particular use case. * *

Databricks manages and provides policy families for several common cluster use cases. You * cannot create, edit, or delete policy families. * *

Policy families cannot be used directly to create clusters. Instead, you create cluster * policies using a policy family. Cluster policies created using a policy family inherit the * policy family's policy definition. */ public PolicyFamiliesAPI policyFamilies() { return policyFamiliesAPI; } /** Marketplace exchanges filters curate which groups can access an exchange. */ public ProviderExchangeFiltersAPI providerExchangeFilters() { return providerExchangeFiltersAPI; } /** * Marketplace exchanges allow providers to share their listings with a curated set of customers. */ public ProviderExchangesAPI providerExchanges() { return providerExchangesAPI; } /** * Marketplace offers a set of file APIs for various purposes such as preview notebooks and * provider icons. */ public ProviderFilesAPI providerFiles() { return providerFilesAPI; } /** * Listings are the core entities in the Marketplace. They represent the products that are * available for consumption. */ public ProviderListingsAPI providerListings() { return providerListingsAPI; } /** * Personalization requests are an alternate to instantly available listings. Control the * lifecycle of personalized solutions. */ public ProviderPersonalizationRequestsAPI providerPersonalizationRequests() { return providerPersonalizationRequestsAPI; } /** Manage templated analytics solution for providers. */ public ProviderProviderAnalyticsDashboardsAPI providerProviderAnalyticsDashboards() { return providerProviderAnalyticsDashboardsAPI; } /** Providers are entities that manage assets in Marketplace. */ public ProviderProvidersAPI providerProviders() { return providerProvidersAPI; } /** * A data provider is an object representing the organization in the real world who shares the * data. A provider contains shares which further contain the shared data. */ public ProvidersAPI providers() { return providersAPI; } /** * A monitor computes and monitors data or model quality metrics for a table over time. It * generates metrics tables and a dashboard that you can use to monitor table health and set * alerts. * *

Most write operations require the user to be the owner of the table (or its parent schema or * parent catalog). Viewing the dashboard, computed metrics, or monitor configuration only * requires the user to have **SELECT** privileges on the table (along with **USE_SCHEMA** and * **USE_CATALOG**). */ public QualityMonitorsAPI qualityMonitors() { return qualityMonitorsAPI; } /** * These endpoints are used for CRUD operations on query definitions. Query definitions include * the target SQL warehouse, query text, name, description, tags, parameters, and visualizations. * Queries can be scheduled using the `sql_task` type of the Jobs API, e.g. :method:jobs/create. * *

**Note**: A new version of the Databricks SQL API will soon be available. [Learn more] * *

[Learn more]: * https://docs.databricks.com/en/whats-coming.html#updates-to-the-databricks-sql-api-for-managing-queries-alerts-and-data-sources */ public QueriesAPI queries() { return queriesAPI; } /** Access the history of queries through SQL warehouses. */ public QueryHistoryAPI queryHistory() { return queryHistoryAPI; } /** * This is an evolving API that facilitates the addition and removal of vizualisations from * existing queries within the Databricks Workspace. Data structures may change over time. */ public QueryVisualizationsAPI queryVisualizations() { return queryVisualizationsAPI; } /** * The Recipient Activation API is only applicable in the open sharing model where the recipient * object has the authentication type of `TOKEN`. The data recipient follows the activation link * shared by the data provider to download the credential file that includes the access token. The * recipient will then use the credential file to establish a secure connection with the provider * to receive the shared data. * *

Note that you can download the credential file only once. Recipients should treat the * downloaded credential as a secret and must not share it outside of their organization. */ public RecipientActivationAPI recipientActivation() { return recipientActivationAPI; } /** * 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**. */ public RecipientsAPI recipients() { return recipientsAPI; } /** * Databricks provides a hosted version of MLflow Model Registry in Unity Catalog. Models in Unity * Catalog provide centralized access control, auditing, lineage, and discovery of ML models * across Databricks workspaces. * *

An MLflow registered model resides in the third layer of Unity Catalog’s three-level * namespace. Registered models contain model versions, which correspond to actual ML models * (MLflow models). Creating new model versions currently requires use of the MLflow Python * client. Once model versions are created, you can load them for batch inference using MLflow * Python client APIs, or deploy them for real-time serving using Databricks Model Serving. * *

All operations on registered models and model versions require USE_CATALOG permissions on * the enclosing catalog and USE_SCHEMA permissions on the enclosing schema. In addition, the * following additional privileges are required for various operations: * *

* To create a registered model, users must additionally have the CREATE_MODEL permission on * the target schema. * To view registered model or model version metadata, model version data * files, or invoke a model version, users must additionally have the EXECUTE permission on the * registered model * To update registered model or model version tags, users must additionally * have APPLY TAG permissions on the registered model * To update other registered model or model * version metadata (comments, aliases) create a new model version, or update permissions on the * registered model, users must be owners of the registered model. * *

Note: The securable type for models is "FUNCTION". When using REST APIs (e.g. tagging, * grants) that specify a securable type, use "FUNCTION" as the securable type. */ public RegisteredModelsAPI registeredModels() { return registeredModelsAPI; } /** * The Repos API allows users to manage their git repos. Users can use the API to access all repos * that they have manage permissions on. * *

Databricks Repos is a visual Git client in Databricks. It supports common Git operations * such a cloning a repository, committing and pushing, pulling, branch management, and visual * comparison of diffs when committing. * *

Within Repos you can develop code in notebooks or other files and follow data science and * engineering code development best practices using Git for version control, collaboration, and * CI/CD. */ public ReposAPI repos() { return reposAPI; } /** * A schema (also called a database) is the second layer of Unity Catalog’s three-level namespace. * A schema organizes tables, views and functions. To access (or list) a table or view in a * schema, users must have the USE_SCHEMA data permission on the schema and its parent catalog, * and they must have the SELECT permission on the table or view. */ public SchemasAPI schemas() { return schemasAPI; } /** * The Secrets API allows you to manage secrets, secret scopes, and access permissions. * *

Sometimes accessing data requires that you authenticate to external data sources through * JDBC. Instead of directly entering your credentials into a notebook, use Databricks secrets to * store your credentials and reference them in notebooks and jobs. * *

Administrators, secret creators, and users granted permission can read Databricks secrets. * While Databricks makes an effort to redact secret values that might be displayed in notebooks, * it is not possible to prevent such users from reading secrets. */ public SecretsExt secrets() { return secretsAPI; } /** * Identities for use with jobs, automated tools, and systems such as scripts, apps, and CI/CD * platforms. Databricks recommends creating service principals to run production jobs or modify * production data. If all processes that act on production data run with service principals, * interactive users do not need any write, delete, or modify privileges in production. This * eliminates the risk of a user overwriting production data by accident. */ public ServicePrincipalsAPI servicePrincipals() { return servicePrincipalsAPI; } /** * The Serving Endpoints API allows you to create, update, and delete model serving endpoints. * *

You can use a serving endpoint to serve models from the Databricks Model Registry or from * Unity Catalog. Endpoints expose the underlying models as scalable REST API endpoints using * serverless compute. This means the endpoints and associated compute resources are fully managed * by Databricks and will not appear in your cloud account. A serving endpoint can consist of one * or more MLflow models from the Databricks Model Registry, called served entities. A serving * endpoint can have at most ten served entities. You can configure traffic settings to define how * requests should be routed to your served entities behind an endpoint. Additionally, you can * configure the scale of resources that should be applied to each served entity. */ public ServingEndpointsAPI servingEndpoints() { return servingEndpointsAPI; } /** Workspace Settings API allows users to manage settings at the workspace level. */ public SettingsAPI settings() { return settingsAPI; } /** * A share is a container instantiated with :method:shares/create. Once created you can * iteratively register a collection of existing data assets defined within the metastore using * :method:shares/update. You can register data assets under their original name, qualified by * their original schema, or provide alternate exposed names. */ public SharesAPI shares() { return sharesAPI; } /** * The Databricks SQL Statement Execution API can be used to execute SQL statements on a SQL * warehouse and fetch the result. * *

**Getting started** * *

We suggest beginning with the [Databricks SQL Statement Execution API tutorial]. * *

**Overview of statement execution and result fetching** * *

Statement execution begins by issuing a :method:statementexecution/executeStatement request * with a valid SQL statement and warehouse ID, along with optional parameters such as the data * catalog and output format. If no other parameters are specified, the server will wait for up to * 10s before returning a response. If the statement has completed within this timespan, the * response will include the result data as a JSON array and metadata. Otherwise, if no result is * available after the 10s timeout expired, the response will provide the statement ID that can be * used to poll for results by using a :method:statementexecution/getStatement request. * *

You can specify whether the call should behave synchronously, asynchronously or start * synchronously with a fallback to asynchronous execution. This is controlled with the * `wait_timeout` and `on_wait_timeout` settings. If `wait_timeout` is set between 5-50 seconds * (default: 10s), the call waits for results up to the specified timeout; when set to `0s`, the * call is asynchronous and responds immediately with a statement ID. The `on_wait_timeout` * setting specifies what should happen when the timeout is reached while the statement execution * has not yet finished. This can be set to either `CONTINUE`, to fallback to asynchronous mode, * or it can be set to `CANCEL`, which cancels the statement. * *

In summary: - Synchronous mode - `wait_timeout=30s` and `on_wait_timeout=CANCEL` - The call * waits up to 30 seconds; if the statement execution finishes within this time, the result data * is returned directly in the response. If the execution takes longer than 30 seconds, the * execution is canceled and the call returns with a `CANCELED` state. - Asynchronous mode - * `wait_timeout=0s` (`on_wait_timeout` is ignored) - The call doesn't wait for the statement to * finish but returns directly with a statement ID. The status of the statement execution can be * polled by issuing :method:statementexecution/getStatement with the statement ID. Once the * execution has succeeded, this call also returns the result and metadata in the response. - * Hybrid mode (default) - `wait_timeout=10s` and `on_wait_timeout=CONTINUE` - The call waits for * up to 10 seconds; if the statement execution finishes within this time, the result data is * returned directly in the response. If the execution takes longer than 10 seconds, a statement * ID is returned. The statement ID can be used to fetch status and results in the same way as in * the asynchronous mode. * *

Depending on the size, the result can be split into multiple chunks. If the statement * execution is successful, the statement response contains a manifest and the first chunk of the * result. The manifest contains schema information and provides metadata for each chunk in the * result. Result chunks can be retrieved by index with * :method:statementexecution/getStatementResultChunkN which may be called in any order and in * parallel. For sequential fetching, each chunk, apart from the last, also contains a * `next_chunk_index` and `next_chunk_internal_link` that point to the next chunk. * *

A statement can be canceled with :method:statementexecution/cancelExecution. * *

**Fetching result data: format and disposition** * *

To specify the format of the result data, use the `format` field, which can be set to one of * the following options: `JSON_ARRAY` (JSON), `ARROW_STREAM` ([Apache Arrow Columnar]), or `CSV`. * *

There are two ways to receive statement results, controlled by the `disposition` setting, * which can be either `INLINE` or `EXTERNAL_LINKS`: * *

- `INLINE`: In this mode, the result data is directly included in the response. It's best * suited for smaller results. This mode can only be used with the `JSON_ARRAY` format. * *

- `EXTERNAL_LINKS`: In this mode, the response provides links that can be used to download * the result data in chunks separately. This approach is ideal for larger results and offers * higher throughput. This mode can be used with all the formats: `JSON_ARRAY`, `ARROW_STREAM`, * and `CSV`. * *

By default, the API uses `format=JSON_ARRAY` and `disposition=INLINE`. * *

**Limits and limitations** * *

Note: The byte limit for INLINE disposition is based on internal storage metrics and will * not exactly match the byte count of the actual payload. * *

- Statements with `disposition=INLINE` are limited to 25 MiB and will fail when this limit * is exceeded. - Statements with `disposition=EXTERNAL_LINKS` are limited to 100 GiB. Result sets * larger than this limit will be truncated. Truncation is indicated by the `truncated` field in * the result manifest. - The maximum query text size is 16 MiB. - Cancelation might silently * fail. A successful response from a cancel request indicates that the cancel request was * successfully received and sent to the processing engine. However, an outstanding statement * might have already completed execution when the cancel request arrives. Polling for status * until a terminal state is reached is a reliable way to determine the final state. - Wait * timeouts are approximate, occur server-side, and cannot account for things such as caller * delays and network latency from caller to service. - The system will auto-close a statement * after one hour if the client stops polling and thus you must poll at least once an hour. - The * results are only available for one hour after success; polling does not extend this. * *

[Apache Arrow Columnar]: https://arrow.apache.org/overview/ [Databricks SQL Statement * Execution API tutorial]: https://docs.databricks.com/sql/api/sql-execution-tutorial.html */ public StatementExecutionAPI statementExecution() { return statementExecutionAPI; } /** * A storage credential represents an authentication and authorization mechanism for accessing * data stored on your cloud tenant. Each storage credential 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 a storage credential 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 storage credentials, you must be a Databricks account admin. The account admin who * creates the storage credential can delegate ownership to another user or group to manage * permissions on it. */ public StorageCredentialsAPI storageCredentials() { return storageCredentialsAPI; } /** * A system schema is a schema that lives within the system catalog. A system schema may contain * information about customer usage of Unity Catalog such as audit-logs, billing-logs, lineage * information, etc. */ public SystemSchemasAPI systemSchemas() { return systemSchemasAPI; } /** * Primary key and foreign key constraints encode relationships between fields in tables. * *

Primary and foreign keys are informational only and are not enforced. Foreign keys must * reference a primary key in another table. This primary key is the parent constraint of the * foreign key and the table this primary key is on is the parent table of the foreign key. * Similarly, the foreign key is the child constraint of its referenced primary key; the table of * the foreign key is the child table of the primary key. * *

You can declare primary keys and foreign keys as part of the table specification during * table creation. You can also add or drop constraints on existing tables. */ public TableConstraintsAPI tableConstraints() { return tableConstraintsAPI; } /** * A table resides in the third layer of Unity Catalog’s three-level namespace. It contains rows * of data. To create a table, users must have CREATE_TABLE and USE_SCHEMA permissions on the * schema, and they must have the USE_CATALOG permission on its parent catalog. To query a table, * users must have the SELECT permission on the table, and they must have the USE_CATALOG * permission on its parent catalog and the USE_SCHEMA permission on its parent schema. * *

A table can be managed or external. From an API perspective, a __VIEW__ is a particular kind * of table (rather than a managed or external table). */ public TablesAPI tables() { return tablesAPI; } /** * Enables administrators to get all tokens and delete tokens for other users. Admins can either * get every token, get a specific token by ID, or get all tokens for a particular user. */ public TokenManagementAPI tokenManagement() { return tokenManagementAPI; } /** * The Token API allows you to create, list, and revoke tokens that can be used to authenticate * and access Databricks REST APIs. */ public TokensAPI tokens() { return tokensAPI; } /** * User identities recognized by Databricks and represented by email addresses. * *

Databricks recommends using SCIM provisioning to sync users and groups automatically from * your identity provider to your Databricks workspace. SCIM streamlines onboarding a new employee * or team by using your identity provider to create users and groups in Databricks workspace and * give them the proper level of access. When a user leaves your organization or no longer needs * access to Databricks workspace, admins can terminate the user in your identity provider and * that user’s account will also be removed from Databricks workspace. This ensures a consistent * offboarding process and prevents unauthorized users from accessing sensitive data. */ public UsersAPI users() { return usersAPI; } /** **Endpoint**: Represents the compute resources to host vector search indexes. */ public VectorSearchEndpointsAPI vectorSearchEndpoints() { return vectorSearchEndpointsAPI; } /** * **Index**: An efficient representation of your embedding vectors that supports real-time and * efficient approximate nearest neighbor (ANN) search queries. * *

There are 2 types of Vector Search indexes: * **Delta Sync Index**: An index that * automatically syncs with a source Delta Table, automatically and incrementally updating the * index as the underlying data in the Delta Table changes. * **Direct Vector Access Index**: An * index that supports direct read and write of vectors and metadata through our REST and SDK * APIs. With this model, the user manages index updates. */ public VectorSearchIndexesAPI vectorSearchIndexes() { return vectorSearchIndexesAPI; } /** * Volumes are a Unity Catalog (UC) capability for accessing, storing, governing, organizing and * processing files. Use cases include running machine learning on unstructured data such as * image, audio, video, or PDF files, organizing data sets during the data exploration stages in * data science, working with libraries that require access to the local file system on cluster * machines, storing library and config files of arbitrary formats such as .whl or .txt centrally * and providing secure access across workspaces to it, or transforming and querying non-tabular * data files in ETL. */ public VolumesAPI volumes() { return volumesAPI; } /** * A SQL warehouse is a compute resource that lets you run SQL commands on data objects within * Databricks SQL. Compute resources are infrastructure resources that provide processing * capabilities in the cloud. */ public WarehousesAPI warehouses() { return warehousesAPI; } /** * The Workspace API allows you to list, import, export, and delete notebooks and folders. * *

A notebook is a web-based interface to a document that contains runnable code, * visualizations, and explanatory text. */ public WorkspaceAPI workspace() { return workspaceAPI; } /** * A securable in Databricks can be configured as __OPEN__ or __ISOLATED__. An __OPEN__ securable * can be accessed from any workspace, while an __ISOLATED__ securable can only be accessed from a * configured list of workspaces. This API allows you to configure (bind) securables to * workspaces. * *

NOTE: The __isolation_mode__ is configured for the securable itself (using its Update * method) and the workspace bindings are only consulted when the securable's __isolation_mode__ * is set to __ISOLATED__. * *

A securable's workspace bindings can be configured by a metastore admin or the owner of the * securable. * *

The original path (/api/2.1/unity-catalog/workspace-bindings/catalogs/{name}) is deprecated. * Please use the new path (/api/2.1/unity-catalog/bindings/{securable_type}/{securable_name}) * which introduces the ability to bind a securable in READ_ONLY mode (catalogs only). * *

Securables that support binding: - catalog */ public WorkspaceBindingsAPI workspaceBindings() { return workspaceBindingsAPI; } /** This API allows updating known workspace settings for advanced users. */ public WorkspaceConfAPI workspaceConf() { return workspaceConfAPI; } /** Replace the default AccountAccessControlProxyService with a custom implementation. */ public WorkspaceClient withAccountAccessControlProxyImpl( AccountAccessControlProxyService accountAccessControlProxy) { return this.withAccountAccessControlProxyAPI( new AccountAccessControlProxyAPI(accountAccessControlProxy)); } /** Replace the default AccountAccessControlProxyAPI with a custom implementation. */ public WorkspaceClient withAccountAccessControlProxyAPI( AccountAccessControlProxyAPI accountAccessControlProxy) { this.accountAccessControlProxyAPI = accountAccessControlProxy; return this; } /** Replace the default AlertsService with a custom implementation. */ public WorkspaceClient withAlertsImpl(AlertsService alerts) { return this.withAlertsAPI(new AlertsAPI(alerts)); } /** Replace the default AlertsAPI with a custom implementation. */ public WorkspaceClient withAlertsAPI(AlertsAPI alerts) { this.alertsAPI = alerts; return this; } /** Replace the default AppsService with a custom implementation. */ public WorkspaceClient withAppsImpl(AppsService apps) { return this.withAppsAPI(new AppsAPI(apps)); } /** Replace the default AppsAPI with a custom implementation. */ public WorkspaceClient withAppsAPI(AppsAPI apps) { this.appsAPI = apps; return this; } /** Replace the default ArtifactAllowlistsService with a custom implementation. */ public WorkspaceClient withArtifactAllowlistsImpl(ArtifactAllowlistsService artifactAllowlists) { return this.withArtifactAllowlistsAPI(new ArtifactAllowlistsAPI(artifactAllowlists)); } /** Replace the default ArtifactAllowlistsAPI with a custom implementation. */ public WorkspaceClient withArtifactAllowlistsAPI(ArtifactAllowlistsAPI artifactAllowlists) { this.artifactAllowlistsAPI = artifactAllowlists; return this; } /** Replace the default CatalogsService with a custom implementation. */ public WorkspaceClient withCatalogsImpl(CatalogsService catalogs) { return this.withCatalogsAPI(new CatalogsAPI(catalogs)); } /** Replace the default CatalogsAPI with a custom implementation. */ public WorkspaceClient withCatalogsAPI(CatalogsAPI catalogs) { this.catalogsAPI = catalogs; return this; } /** Replace the default CleanRoomsService with a custom implementation. */ public WorkspaceClient withCleanRoomsImpl(CleanRoomsService cleanRooms) { return this.withCleanRoomsAPI(new CleanRoomsAPI(cleanRooms)); } /** Replace the default CleanRoomsAPI with a custom implementation. */ public WorkspaceClient withCleanRoomsAPI(CleanRoomsAPI cleanRooms) { this.cleanRoomsAPI = cleanRooms; return this; } /** Replace the default ClusterPoliciesService with a custom implementation. */ public WorkspaceClient withClusterPoliciesImpl(ClusterPoliciesService clusterPolicies) { return this.withClusterPoliciesAPI(new ClusterPoliciesAPI(clusterPolicies)); } /** Replace the default ClusterPoliciesAPI with a custom implementation. */ public WorkspaceClient withClusterPoliciesAPI(ClusterPoliciesAPI clusterPolicies) { this.clusterPoliciesAPI = clusterPolicies; return this; } /** Replace the default ClustersService with a custom implementation. */ public WorkspaceClient withClustersImpl(ClustersService clusters) { return this.withClustersAPI(new ClustersExt(clusters)); } /** Replace the default ClustersAPI with a custom implementation. */ public WorkspaceClient withClustersAPI(ClustersExt clusters) { this.clustersAPI = clusters; return this; } /** Replace the default CommandExecutionService with a custom implementation. */ public WorkspaceClient withCommandExecutionImpl(CommandExecutionService commandExecution) { return this.withCommandExecutionAPI(new CommandExecutionAPI(commandExecution)); } /** Replace the default CommandExecutionAPI with a custom implementation. */ public WorkspaceClient withCommandExecutionAPI(CommandExecutionAPI commandExecution) { this.commandExecutionAPI = commandExecution; return this; } /** Replace the default ConnectionsService with a custom implementation. */ public WorkspaceClient withConnectionsImpl(ConnectionsService connections) { return this.withConnectionsAPI(new ConnectionsAPI(connections)); } /** Replace the default ConnectionsAPI with a custom implementation. */ public WorkspaceClient withConnectionsAPI(ConnectionsAPI connections) { this.connectionsAPI = connections; return this; } /** Replace the default ConsumerFulfillmentsService with a custom implementation. */ public WorkspaceClient withConsumerFulfillmentsImpl( ConsumerFulfillmentsService consumerFulfillments) { return this.withConsumerFulfillmentsAPI(new ConsumerFulfillmentsAPI(consumerFulfillments)); } /** Replace the default ConsumerFulfillmentsAPI with a custom implementation. */ public WorkspaceClient withConsumerFulfillmentsAPI(ConsumerFulfillmentsAPI consumerFulfillments) { this.consumerFulfillmentsAPI = consumerFulfillments; return this; } /** Replace the default ConsumerInstallationsService with a custom implementation. */ public WorkspaceClient withConsumerInstallationsImpl( ConsumerInstallationsService consumerInstallations) { return this.withConsumerInstallationsAPI(new ConsumerInstallationsAPI(consumerInstallations)); } /** Replace the default ConsumerInstallationsAPI with a custom implementation. */ public WorkspaceClient withConsumerInstallationsAPI( ConsumerInstallationsAPI consumerInstallations) { this.consumerInstallationsAPI = consumerInstallations; return this; } /** Replace the default ConsumerListingsService with a custom implementation. */ public WorkspaceClient withConsumerListingsImpl(ConsumerListingsService consumerListings) { return this.withConsumerListingsAPI(new ConsumerListingsAPI(consumerListings)); } /** Replace the default ConsumerListingsAPI with a custom implementation. */ public WorkspaceClient withConsumerListingsAPI(ConsumerListingsAPI consumerListings) { this.consumerListingsAPI = consumerListings; return this; } /** Replace the default ConsumerPersonalizationRequestsService with a custom implementation. */ public WorkspaceClient withConsumerPersonalizationRequestsImpl( ConsumerPersonalizationRequestsService consumerPersonalizationRequests) { return this.withConsumerPersonalizationRequestsAPI( new ConsumerPersonalizationRequestsAPI(consumerPersonalizationRequests)); } /** Replace the default ConsumerPersonalizationRequestsAPI with a custom implementation. */ public WorkspaceClient withConsumerPersonalizationRequestsAPI( ConsumerPersonalizationRequestsAPI consumerPersonalizationRequests) { this.consumerPersonalizationRequestsAPI = consumerPersonalizationRequests; return this; } /** Replace the default ConsumerProvidersService with a custom implementation. */ public WorkspaceClient withConsumerProvidersImpl(ConsumerProvidersService consumerProviders) { return this.withConsumerProvidersAPI(new ConsumerProvidersAPI(consumerProviders)); } /** Replace the default ConsumerProvidersAPI with a custom implementation. */ public WorkspaceClient withConsumerProvidersAPI(ConsumerProvidersAPI consumerProviders) { this.consumerProvidersAPI = consumerProviders; return this; } /** Replace the default CredentialsManagerService with a custom implementation. */ public WorkspaceClient withCredentialsManagerImpl(CredentialsManagerService credentialsManager) { return this.withCredentialsManagerAPI(new CredentialsManagerAPI(credentialsManager)); } /** Replace the default CredentialsManagerAPI with a custom implementation. */ public WorkspaceClient withCredentialsManagerAPI(CredentialsManagerAPI credentialsManager) { this.credentialsManagerAPI = credentialsManager; return this; } /** Replace the default CurrentUserService with a custom implementation. */ public WorkspaceClient withCurrentUserImpl(CurrentUserService currentUser) { return this.withCurrentUserAPI(new CurrentUserAPI(currentUser)); } /** Replace the default CurrentUserAPI with a custom implementation. */ public WorkspaceClient withCurrentUserAPI(CurrentUserAPI currentUser) { this.currentUserAPI = currentUser; return this; } /** Replace the default DashboardWidgetsService with a custom implementation. */ public WorkspaceClient withDashboardWidgetsImpl(DashboardWidgetsService dashboardWidgets) { return this.withDashboardWidgetsAPI(new DashboardWidgetsAPI(dashboardWidgets)); } /** Replace the default DashboardWidgetsAPI with a custom implementation. */ public WorkspaceClient withDashboardWidgetsAPI(DashboardWidgetsAPI dashboardWidgets) { this.dashboardWidgetsAPI = dashboardWidgets; return this; } /** Replace the default DashboardsService with a custom implementation. */ public WorkspaceClient withDashboardsImpl(DashboardsService dashboards) { return this.withDashboardsAPI(new DashboardsAPI(dashboards)); } /** Replace the default DashboardsAPI with a custom implementation. */ public WorkspaceClient withDashboardsAPI(DashboardsAPI dashboards) { this.dashboardsAPI = dashboards; return this; } /** Replace the default DataSourcesService with a custom implementation. */ public WorkspaceClient withDataSourcesImpl(DataSourcesService dataSources) { return this.withDataSourcesAPI(new DataSourcesAPI(dataSources)); } /** Replace the default DataSourcesAPI with a custom implementation. */ public WorkspaceClient withDataSourcesAPI(DataSourcesAPI dataSources) { this.dataSourcesAPI = dataSources; return this; } /** Replace the default DbfsService with a custom implementation. */ public WorkspaceClient withDbfsImpl(DbfsService dbfs) { return this.withDbfsAPI(new DbfsExt(dbfs)); } /** Replace the default DbfsAPI with a custom implementation. */ public WorkspaceClient withDbfsAPI(DbfsExt dbfs) { this.dbfsAPI = dbfs; return this; } /** Replace the default DbsqlPermissionsService with a custom implementation. */ public WorkspaceClient withDbsqlPermissionsImpl(DbsqlPermissionsService dbsqlPermissions) { return this.withDbsqlPermissionsAPI(new DbsqlPermissionsAPI(dbsqlPermissions)); } /** Replace the default DbsqlPermissionsAPI with a custom implementation. */ public WorkspaceClient withDbsqlPermissionsAPI(DbsqlPermissionsAPI dbsqlPermissions) { this.dbsqlPermissionsAPI = dbsqlPermissions; return this; } /** Replace the default ExperimentsService with a custom implementation. */ public WorkspaceClient withExperimentsImpl(ExperimentsService experiments) { return this.withExperimentsAPI(new ExperimentsAPI(experiments)); } /** Replace the default ExperimentsAPI with a custom implementation. */ public WorkspaceClient withExperimentsAPI(ExperimentsAPI experiments) { this.experimentsAPI = experiments; return this; } /** Replace the default ExternalLocationsService with a custom implementation. */ public WorkspaceClient withExternalLocationsImpl(ExternalLocationsService externalLocations) { return this.withExternalLocationsAPI(new ExternalLocationsAPI(externalLocations)); } /** Replace the default ExternalLocationsAPI with a custom implementation. */ public WorkspaceClient withExternalLocationsAPI(ExternalLocationsAPI externalLocations) { this.externalLocationsAPI = externalLocations; return this; } /** Replace the default FilesService with a custom implementation. */ public WorkspaceClient withFilesImpl(FilesService files) { return this.withFilesAPI(new FilesAPI(files)); } /** Replace the default FilesAPI with a custom implementation. */ public WorkspaceClient withFilesAPI(FilesAPI files) { this.filesAPI = files; return this; } /** Replace the default FunctionsService with a custom implementation. */ public WorkspaceClient withFunctionsImpl(FunctionsService functions) { return this.withFunctionsAPI(new FunctionsAPI(functions)); } /** Replace the default FunctionsAPI with a custom implementation. */ public WorkspaceClient withFunctionsAPI(FunctionsAPI functions) { this.functionsAPI = functions; return this; } /** Replace the default GitCredentialsService with a custom implementation. */ public WorkspaceClient withGitCredentialsImpl(GitCredentialsService gitCredentials) { return this.withGitCredentialsAPI(new GitCredentialsAPI(gitCredentials)); } /** Replace the default GitCredentialsAPI with a custom implementation. */ public WorkspaceClient withGitCredentialsAPI(GitCredentialsAPI gitCredentials) { this.gitCredentialsAPI = gitCredentials; return this; } /** Replace the default GlobalInitScriptsService with a custom implementation. */ public WorkspaceClient withGlobalInitScriptsImpl(GlobalInitScriptsService globalInitScripts) { return this.withGlobalInitScriptsAPI(new GlobalInitScriptsAPI(globalInitScripts)); } /** Replace the default GlobalInitScriptsAPI with a custom implementation. */ public WorkspaceClient withGlobalInitScriptsAPI(GlobalInitScriptsAPI globalInitScripts) { this.globalInitScriptsAPI = globalInitScripts; return this; } /** Replace the default GrantsService with a custom implementation. */ public WorkspaceClient withGrantsImpl(GrantsService grants) { return this.withGrantsAPI(new GrantsAPI(grants)); } /** Replace the default GrantsAPI with a custom implementation. */ public WorkspaceClient withGrantsAPI(GrantsAPI grants) { this.grantsAPI = grants; return this; } /** Replace the default GroupsService with a custom implementation. */ public WorkspaceClient withGroupsImpl(GroupsService groups) { return this.withGroupsAPI(new GroupsAPI(groups)); } /** Replace the default GroupsAPI with a custom implementation. */ public WorkspaceClient withGroupsAPI(GroupsAPI groups) { this.groupsAPI = groups; return this; } /** Replace the default InstancePoolsService with a custom implementation. */ public WorkspaceClient withInstancePoolsImpl(InstancePoolsService instancePools) { return this.withInstancePoolsAPI(new InstancePoolsAPI(instancePools)); } /** Replace the default InstancePoolsAPI with a custom implementation. */ public WorkspaceClient withInstancePoolsAPI(InstancePoolsAPI instancePools) { this.instancePoolsAPI = instancePools; return this; } /** Replace the default InstanceProfilesService with a custom implementation. */ public WorkspaceClient withInstanceProfilesImpl(InstanceProfilesService instanceProfiles) { return this.withInstanceProfilesAPI(new InstanceProfilesAPI(instanceProfiles)); } /** Replace the default InstanceProfilesAPI with a custom implementation. */ public WorkspaceClient withInstanceProfilesAPI(InstanceProfilesAPI instanceProfiles) { this.instanceProfilesAPI = instanceProfiles; return this; } /** Replace the default IpAccessListsService with a custom implementation. */ public WorkspaceClient withIpAccessListsImpl(IpAccessListsService ipAccessLists) { return this.withIpAccessListsAPI(new IpAccessListsAPI(ipAccessLists)); } /** Replace the default IpAccessListsAPI with a custom implementation. */ public WorkspaceClient withIpAccessListsAPI(IpAccessListsAPI ipAccessLists) { this.ipAccessListsAPI = ipAccessLists; return this; } /** Replace the default JobsService with a custom implementation. */ public WorkspaceClient withJobsImpl(JobsService jobs) { return this.withJobsAPI(new JobsAPI(jobs)); } /** Replace the default JobsAPI with a custom implementation. */ public WorkspaceClient withJobsAPI(JobsAPI jobs) { this.jobsAPI = jobs; return this; } /** Replace the default LakeviewService with a custom implementation. */ public WorkspaceClient withLakeviewImpl(LakeviewService lakeview) { return this.withLakeviewAPI(new LakeviewAPI(lakeview)); } /** Replace the default LakeviewAPI with a custom implementation. */ public WorkspaceClient withLakeviewAPI(LakeviewAPI lakeview) { this.lakeviewAPI = lakeview; return this; } /** Replace the default LibrariesService with a custom implementation. */ public WorkspaceClient withLibrariesImpl(LibrariesService libraries) { return this.withLibrariesAPI(new LibrariesAPI(libraries)); } /** Replace the default LibrariesAPI with a custom implementation. */ public WorkspaceClient withLibrariesAPI(LibrariesAPI libraries) { this.librariesAPI = libraries; return this; } /** Replace the default MetastoresService with a custom implementation. */ public WorkspaceClient withMetastoresImpl(MetastoresService metastores) { return this.withMetastoresAPI(new MetastoresAPI(metastores)); } /** Replace the default MetastoresAPI with a custom implementation. */ public WorkspaceClient withMetastoresAPI(MetastoresAPI metastores) { this.metastoresAPI = metastores; return this; } /** Replace the default ModelRegistryService with a custom implementation. */ public WorkspaceClient withModelRegistryImpl(ModelRegistryService modelRegistry) { return this.withModelRegistryAPI(new ModelRegistryAPI(modelRegistry)); } /** Replace the default ModelRegistryAPI with a custom implementation. */ public WorkspaceClient withModelRegistryAPI(ModelRegistryAPI modelRegistry) { this.modelRegistryAPI = modelRegistry; return this; } /** Replace the default ModelVersionsService with a custom implementation. */ public WorkspaceClient withModelVersionsImpl(ModelVersionsService modelVersions) { return this.withModelVersionsAPI(new ModelVersionsAPI(modelVersions)); } /** Replace the default ModelVersionsAPI with a custom implementation. */ public WorkspaceClient withModelVersionsAPI(ModelVersionsAPI modelVersions) { this.modelVersionsAPI = modelVersions; return this; } /** Replace the default OnlineTablesService with a custom implementation. */ public WorkspaceClient withOnlineTablesImpl(OnlineTablesService onlineTables) { return this.withOnlineTablesAPI(new OnlineTablesAPI(onlineTables)); } /** Replace the default OnlineTablesAPI with a custom implementation. */ public WorkspaceClient withOnlineTablesAPI(OnlineTablesAPI onlineTables) { this.onlineTablesAPI = onlineTables; return this; } /** Replace the default PermissionMigrationService with a custom implementation. */ public WorkspaceClient withPermissionMigrationImpl( PermissionMigrationService permissionMigration) { return this.withPermissionMigrationAPI(new PermissionMigrationAPI(permissionMigration)); } /** Replace the default PermissionMigrationAPI with a custom implementation. */ public WorkspaceClient withPermissionMigrationAPI(PermissionMigrationAPI permissionMigration) { this.permissionMigrationAPI = permissionMigration; return this; } /** Replace the default PermissionsService with a custom implementation. */ public WorkspaceClient withPermissionsImpl(PermissionsService permissions) { return this.withPermissionsAPI(new PermissionsAPI(permissions)); } /** Replace the default PermissionsAPI with a custom implementation. */ public WorkspaceClient withPermissionsAPI(PermissionsAPI permissions) { this.permissionsAPI = permissions; return this; } /** Replace the default PipelinesService with a custom implementation. */ public WorkspaceClient withPipelinesImpl(PipelinesService pipelines) { return this.withPipelinesAPI(new PipelinesAPI(pipelines)); } /** Replace the default PipelinesAPI with a custom implementation. */ public WorkspaceClient withPipelinesAPI(PipelinesAPI pipelines) { this.pipelinesAPI = pipelines; return this; } /** Replace the default PolicyFamiliesService with a custom implementation. */ public WorkspaceClient withPolicyFamiliesImpl(PolicyFamiliesService policyFamilies) { return this.withPolicyFamiliesAPI(new PolicyFamiliesAPI(policyFamilies)); } /** Replace the default PolicyFamiliesAPI with a custom implementation. */ public WorkspaceClient withPolicyFamiliesAPI(PolicyFamiliesAPI policyFamilies) { this.policyFamiliesAPI = policyFamilies; return this; } /** Replace the default ProviderExchangeFiltersService with a custom implementation. */ public WorkspaceClient withProviderExchangeFiltersImpl( ProviderExchangeFiltersService providerExchangeFilters) { return this.withProviderExchangeFiltersAPI( new ProviderExchangeFiltersAPI(providerExchangeFilters)); } /** Replace the default ProviderExchangeFiltersAPI with a custom implementation. */ public WorkspaceClient withProviderExchangeFiltersAPI( ProviderExchangeFiltersAPI providerExchangeFilters) { this.providerExchangeFiltersAPI = providerExchangeFilters; return this; } /** Replace the default ProviderExchangesService with a custom implementation. */ public WorkspaceClient withProviderExchangesImpl(ProviderExchangesService providerExchanges) { return this.withProviderExchangesAPI(new ProviderExchangesAPI(providerExchanges)); } /** Replace the default ProviderExchangesAPI with a custom implementation. */ public WorkspaceClient withProviderExchangesAPI(ProviderExchangesAPI providerExchanges) { this.providerExchangesAPI = providerExchanges; return this; } /** Replace the default ProviderFilesService with a custom implementation. */ public WorkspaceClient withProviderFilesImpl(ProviderFilesService providerFiles) { return this.withProviderFilesAPI(new ProviderFilesAPI(providerFiles)); } /** Replace the default ProviderFilesAPI with a custom implementation. */ public WorkspaceClient withProviderFilesAPI(ProviderFilesAPI providerFiles) { this.providerFilesAPI = providerFiles; return this; } /** Replace the default ProviderListingsService with a custom implementation. */ public WorkspaceClient withProviderListingsImpl(ProviderListingsService providerListings) { return this.withProviderListingsAPI(new ProviderListingsAPI(providerListings)); } /** Replace the default ProviderListingsAPI with a custom implementation. */ public WorkspaceClient withProviderListingsAPI(ProviderListingsAPI providerListings) { this.providerListingsAPI = providerListings; return this; } /** Replace the default ProviderPersonalizationRequestsService with a custom implementation. */ public WorkspaceClient withProviderPersonalizationRequestsImpl( ProviderPersonalizationRequestsService providerPersonalizationRequests) { return this.withProviderPersonalizationRequestsAPI( new ProviderPersonalizationRequestsAPI(providerPersonalizationRequests)); } /** Replace the default ProviderPersonalizationRequestsAPI with a custom implementation. */ public WorkspaceClient withProviderPersonalizationRequestsAPI( ProviderPersonalizationRequestsAPI providerPersonalizationRequests) { this.providerPersonalizationRequestsAPI = providerPersonalizationRequests; return this; } /** * Replace the default ProviderProviderAnalyticsDashboardsService with a custom implementation. */ public WorkspaceClient withProviderProviderAnalyticsDashboardsImpl( ProviderProviderAnalyticsDashboardsService providerProviderAnalyticsDashboards) { return this.withProviderProviderAnalyticsDashboardsAPI( new ProviderProviderAnalyticsDashboardsAPI(providerProviderAnalyticsDashboards)); } /** Replace the default ProviderProviderAnalyticsDashboardsAPI with a custom implementation. */ public WorkspaceClient withProviderProviderAnalyticsDashboardsAPI( ProviderProviderAnalyticsDashboardsAPI providerProviderAnalyticsDashboards) { this.providerProviderAnalyticsDashboardsAPI = providerProviderAnalyticsDashboards; return this; } /** Replace the default ProviderProvidersService with a custom implementation. */ public WorkspaceClient withProviderProvidersImpl(ProviderProvidersService providerProviders) { return this.withProviderProvidersAPI(new ProviderProvidersAPI(providerProviders)); } /** Replace the default ProviderProvidersAPI with a custom implementation. */ public WorkspaceClient withProviderProvidersAPI(ProviderProvidersAPI providerProviders) { this.providerProvidersAPI = providerProviders; return this; } /** Replace the default ProvidersService with a custom implementation. */ public WorkspaceClient withProvidersImpl(ProvidersService providers) { return this.withProvidersAPI(new ProvidersAPI(providers)); } /** Replace the default ProvidersAPI with a custom implementation. */ public WorkspaceClient withProvidersAPI(ProvidersAPI providers) { this.providersAPI = providers; return this; } /** Replace the default QualityMonitorsService with a custom implementation. */ public WorkspaceClient withQualityMonitorsImpl(QualityMonitorsService qualityMonitors) { return this.withQualityMonitorsAPI(new QualityMonitorsAPI(qualityMonitors)); } /** Replace the default QualityMonitorsAPI with a custom implementation. */ public WorkspaceClient withQualityMonitorsAPI(QualityMonitorsAPI qualityMonitors) { this.qualityMonitorsAPI = qualityMonitors; return this; } /** Replace the default QueriesService with a custom implementation. */ public WorkspaceClient withQueriesImpl(QueriesService queries) { return this.withQueriesAPI(new QueriesAPI(queries)); } /** Replace the default QueriesAPI with a custom implementation. */ public WorkspaceClient withQueriesAPI(QueriesAPI queries) { this.queriesAPI = queries; return this; } /** Replace the default QueryHistoryService with a custom implementation. */ public WorkspaceClient withQueryHistoryImpl(QueryHistoryService queryHistory) { return this.withQueryHistoryAPI(new QueryHistoryAPI(queryHistory)); } /** Replace the default QueryHistoryAPI with a custom implementation. */ public WorkspaceClient withQueryHistoryAPI(QueryHistoryAPI queryHistory) { this.queryHistoryAPI = queryHistory; return this; } /** Replace the default QueryVisualizationsService with a custom implementation. */ public WorkspaceClient withQueryVisualizationsImpl( QueryVisualizationsService queryVisualizations) { return this.withQueryVisualizationsAPI(new QueryVisualizationsAPI(queryVisualizations)); } /** Replace the default QueryVisualizationsAPI with a custom implementation. */ public WorkspaceClient withQueryVisualizationsAPI(QueryVisualizationsAPI queryVisualizations) { this.queryVisualizationsAPI = queryVisualizations; return this; } /** Replace the default RecipientActivationService with a custom implementation. */ public WorkspaceClient withRecipientActivationImpl( RecipientActivationService recipientActivation) { return this.withRecipientActivationAPI(new RecipientActivationAPI(recipientActivation)); } /** Replace the default RecipientActivationAPI with a custom implementation. */ public WorkspaceClient withRecipientActivationAPI(RecipientActivationAPI recipientActivation) { this.recipientActivationAPI = recipientActivation; return this; } /** Replace the default RecipientsService with a custom implementation. */ public WorkspaceClient withRecipientsImpl(RecipientsService recipients) { return this.withRecipientsAPI(new RecipientsAPI(recipients)); } /** Replace the default RecipientsAPI with a custom implementation. */ public WorkspaceClient withRecipientsAPI(RecipientsAPI recipients) { this.recipientsAPI = recipients; return this; } /** Replace the default RegisteredModelsService with a custom implementation. */ public WorkspaceClient withRegisteredModelsImpl(RegisteredModelsService registeredModels) { return this.withRegisteredModelsAPI(new RegisteredModelsAPI(registeredModels)); } /** Replace the default RegisteredModelsAPI with a custom implementation. */ public WorkspaceClient withRegisteredModelsAPI(RegisteredModelsAPI registeredModels) { this.registeredModelsAPI = registeredModels; return this; } /** Replace the default ReposService with a custom implementation. */ public WorkspaceClient withReposImpl(ReposService repos) { return this.withReposAPI(new ReposAPI(repos)); } /** Replace the default ReposAPI with a custom implementation. */ public WorkspaceClient withReposAPI(ReposAPI repos) { this.reposAPI = repos; return this; } /** Replace the default SchemasService with a custom implementation. */ public WorkspaceClient withSchemasImpl(SchemasService schemas) { return this.withSchemasAPI(new SchemasAPI(schemas)); } /** Replace the default SchemasAPI with a custom implementation. */ public WorkspaceClient withSchemasAPI(SchemasAPI schemas) { this.schemasAPI = schemas; return this; } /** Replace the default SecretsService with a custom implementation. */ public WorkspaceClient withSecretsImpl(SecretsService secrets) { return this.withSecretsAPI(new SecretsExt(secrets)); } /** Replace the default SecretsAPI with a custom implementation. */ public WorkspaceClient withSecretsAPI(SecretsExt secrets) { this.secretsAPI = secrets; return this; } /** Replace the default ServicePrincipalsService with a custom implementation. */ public WorkspaceClient withServicePrincipalsImpl(ServicePrincipalsService servicePrincipals) { return this.withServicePrincipalsAPI(new ServicePrincipalsAPI(servicePrincipals)); } /** Replace the default ServicePrincipalsAPI with a custom implementation. */ public WorkspaceClient withServicePrincipalsAPI(ServicePrincipalsAPI servicePrincipals) { this.servicePrincipalsAPI = servicePrincipals; return this; } /** Replace the default ServingEndpointsService with a custom implementation. */ public WorkspaceClient withServingEndpointsImpl(ServingEndpointsService servingEndpoints) { return this.withServingEndpointsAPI(new ServingEndpointsAPI(servingEndpoints)); } /** Replace the default ServingEndpointsAPI with a custom implementation. */ public WorkspaceClient withServingEndpointsAPI(ServingEndpointsAPI servingEndpoints) { this.servingEndpointsAPI = servingEndpoints; return this; } /** Replace the default SettingsService with a custom implementation. */ public WorkspaceClient withSettingsImpl(SettingsService settings) { return this.withSettingsAPI(new SettingsAPI(settings)); } /** Replace the default SettingsAPI with a custom implementation. */ public WorkspaceClient withSettingsAPI(SettingsAPI settings) { this.settingsAPI = settings; return this; } /** Replace the default SharesService with a custom implementation. */ public WorkspaceClient withSharesImpl(SharesService shares) { return this.withSharesAPI(new SharesAPI(shares)); } /** Replace the default SharesAPI with a custom implementation. */ public WorkspaceClient withSharesAPI(SharesAPI shares) { this.sharesAPI = shares; return this; } /** Replace the default StatementExecutionService with a custom implementation. */ public WorkspaceClient withStatementExecutionImpl(StatementExecutionService statementExecution) { return this.withStatementExecutionAPI(new StatementExecutionAPI(statementExecution)); } /** Replace the default StatementExecutionAPI with a custom implementation. */ public WorkspaceClient withStatementExecutionAPI(StatementExecutionAPI statementExecution) { this.statementExecutionAPI = statementExecution; return this; } /** Replace the default StorageCredentialsService with a custom implementation. */ public WorkspaceClient withStorageCredentialsImpl(StorageCredentialsService storageCredentials) { return this.withStorageCredentialsAPI(new StorageCredentialsAPI(storageCredentials)); } /** Replace the default StorageCredentialsAPI with a custom implementation. */ public WorkspaceClient withStorageCredentialsAPI(StorageCredentialsAPI storageCredentials) { this.storageCredentialsAPI = storageCredentials; return this; } /** Replace the default SystemSchemasService with a custom implementation. */ public WorkspaceClient withSystemSchemasImpl(SystemSchemasService systemSchemas) { return this.withSystemSchemasAPI(new SystemSchemasAPI(systemSchemas)); } /** Replace the default SystemSchemasAPI with a custom implementation. */ public WorkspaceClient withSystemSchemasAPI(SystemSchemasAPI systemSchemas) { this.systemSchemasAPI = systemSchemas; return this; } /** Replace the default TableConstraintsService with a custom implementation. */ public WorkspaceClient withTableConstraintsImpl(TableConstraintsService tableConstraints) { return this.withTableConstraintsAPI(new TableConstraintsAPI(tableConstraints)); } /** Replace the default TableConstraintsAPI with a custom implementation. */ public WorkspaceClient withTableConstraintsAPI(TableConstraintsAPI tableConstraints) { this.tableConstraintsAPI = tableConstraints; return this; } /** Replace the default TablesService with a custom implementation. */ public WorkspaceClient withTablesImpl(TablesService tables) { return this.withTablesAPI(new TablesAPI(tables)); } /** Replace the default TablesAPI with a custom implementation. */ public WorkspaceClient withTablesAPI(TablesAPI tables) { this.tablesAPI = tables; return this; } /** Replace the default TokenManagementService with a custom implementation. */ public WorkspaceClient withTokenManagementImpl(TokenManagementService tokenManagement) { return this.withTokenManagementAPI(new TokenManagementAPI(tokenManagement)); } /** Replace the default TokenManagementAPI with a custom implementation. */ public WorkspaceClient withTokenManagementAPI(TokenManagementAPI tokenManagement) { this.tokenManagementAPI = tokenManagement; return this; } /** Replace the default TokensService with a custom implementation. */ public WorkspaceClient withTokensImpl(TokensService tokens) { return this.withTokensAPI(new TokensAPI(tokens)); } /** Replace the default TokensAPI with a custom implementation. */ public WorkspaceClient withTokensAPI(TokensAPI tokens) { this.tokensAPI = tokens; return this; } /** Replace the default UsersService with a custom implementation. */ public WorkspaceClient withUsersImpl(UsersService users) { return this.withUsersAPI(new UsersAPI(users)); } /** Replace the default UsersAPI with a custom implementation. */ public WorkspaceClient withUsersAPI(UsersAPI users) { this.usersAPI = users; return this; } /** Replace the default VectorSearchEndpointsService with a custom implementation. */ public WorkspaceClient withVectorSearchEndpointsImpl( VectorSearchEndpointsService vectorSearchEndpoints) { return this.withVectorSearchEndpointsAPI(new VectorSearchEndpointsAPI(vectorSearchEndpoints)); } /** Replace the default VectorSearchEndpointsAPI with a custom implementation. */ public WorkspaceClient withVectorSearchEndpointsAPI( VectorSearchEndpointsAPI vectorSearchEndpoints) { this.vectorSearchEndpointsAPI = vectorSearchEndpoints; return this; } /** Replace the default VectorSearchIndexesService with a custom implementation. */ public WorkspaceClient withVectorSearchIndexesImpl( VectorSearchIndexesService vectorSearchIndexes) { return this.withVectorSearchIndexesAPI(new VectorSearchIndexesAPI(vectorSearchIndexes)); } /** Replace the default VectorSearchIndexesAPI with a custom implementation. */ public WorkspaceClient withVectorSearchIndexesAPI(VectorSearchIndexesAPI vectorSearchIndexes) { this.vectorSearchIndexesAPI = vectorSearchIndexes; return this; } /** Replace the default VolumesService with a custom implementation. */ public WorkspaceClient withVolumesImpl(VolumesService volumes) { return this.withVolumesAPI(new VolumesAPI(volumes)); } /** Replace the default VolumesAPI with a custom implementation. */ public WorkspaceClient withVolumesAPI(VolumesAPI volumes) { this.volumesAPI = volumes; return this; } /** Replace the default WarehousesService with a custom implementation. */ public WorkspaceClient withWarehousesImpl(WarehousesService warehouses) { return this.withWarehousesAPI(new WarehousesAPI(warehouses)); } /** Replace the default WarehousesAPI with a custom implementation. */ public WorkspaceClient withWarehousesAPI(WarehousesAPI warehouses) { this.warehousesAPI = warehouses; return this; } /** Replace the default WorkspaceService with a custom implementation. */ public WorkspaceClient withWorkspaceImpl(WorkspaceService workspace) { return this.withWorkspaceAPI(new WorkspaceAPI(workspace)); } /** Replace the default WorkspaceAPI with a custom implementation. */ public WorkspaceClient withWorkspaceAPI(WorkspaceAPI workspace) { this.workspaceAPI = workspace; return this; } /** Replace the default WorkspaceBindingsService with a custom implementation. */ public WorkspaceClient withWorkspaceBindingsImpl(WorkspaceBindingsService workspaceBindings) { return this.withWorkspaceBindingsAPI(new WorkspaceBindingsAPI(workspaceBindings)); } /** Replace the default WorkspaceBindingsAPI with a custom implementation. */ public WorkspaceClient withWorkspaceBindingsAPI(WorkspaceBindingsAPI workspaceBindings) { this.workspaceBindingsAPI = workspaceBindings; return this; } /** Replace the default WorkspaceConfService with a custom implementation. */ public WorkspaceClient withWorkspaceConfImpl(WorkspaceConfService workspaceConf) { return this.withWorkspaceConfAPI(new WorkspaceConfAPI(workspaceConf)); } /** Replace the default WorkspaceConfAPI with a custom implementation. */ public WorkspaceClient withWorkspaceConfAPI(WorkspaceConfAPI workspaceConf) { this.workspaceConfAPI = workspaceConf; return this; } public ApiClient apiClient() { return apiClient; } public DatabricksConfig config() { return config; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy