com.databricks.sdk.service.catalog.LakehouseMonitorsAPI Maven / Gradle / Ivy
// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT.
package com.databricks.sdk.service.catalog;
import com.databricks.sdk.core.ApiClient;
import com.databricks.sdk.support.Generated;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* 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**).
*/
@Generated
public class LakehouseMonitorsAPI {
private static final Logger LOG = LoggerFactory.getLogger(LakehouseMonitorsAPI.class);
private final LakehouseMonitorsService impl;
/** Regular-use constructor */
public LakehouseMonitorsAPI(ApiClient apiClient) {
impl = new LakehouseMonitorsImpl(apiClient);
}
/** Constructor for mocks */
public LakehouseMonitorsAPI(LakehouseMonitorsService mock) {
impl = mock;
}
public void cancelRefresh(String fullName, String refreshId) {
cancelRefresh(new CancelRefreshRequest().setFullName(fullName).setRefreshId(refreshId));
}
/**
* Cancel refresh.
*
*
Cancel an active monitor refresh for the given refresh ID.
*
*
The caller must either: 1. be an owner of the table's parent catalog 2. have **USE_CATALOG**
* on the table's parent catalog and be an owner of the table's parent schema 3. have the
* following permissions: - **USE_CATALOG** on the table's parent catalog - **USE_SCHEMA** on the
* table's parent schema - be an owner of the table
*
*
Additionally, the call must be made from the workspace where the monitor was created.
*/
public void cancelRefresh(CancelRefreshRequest request) {
impl.cancelRefresh(request);
}
public MonitorInfo create(String fullName, String assetsDir, String outputSchemaName) {
return create(
new CreateMonitor()
.setFullName(fullName)
.setAssetsDir(assetsDir)
.setOutputSchemaName(outputSchemaName));
}
/**
* Create a table monitor.
*
*
Creates a new monitor for the specified table.
*
*
The caller must either: 1. be an owner of the table's parent catalog, have **USE_SCHEMA** on
* the table's parent schema, and have **SELECT** access on the table 2. have **USE_CATALOG** on
* the table's parent catalog, be an owner of the table's parent schema, and have **SELECT**
* access on the table. 3. have the following permissions: - **USE_CATALOG** on the table's parent
* catalog - **USE_SCHEMA** on the table's parent schema - be an owner of the table.
*
*
Workspace assets, such as the dashboard, will be created in the workspace where this call
* was made.
*/
public MonitorInfo create(CreateMonitor request) {
return impl.create(request);
}
public void delete(String fullName) {
delete(new DeleteLakehouseMonitorRequest().setFullName(fullName));
}
/**
* Delete a table monitor.
*
*
Deletes a monitor for the specified table.
*
*
The caller must either: 1. be an owner of the table's parent catalog 2. have **USE_CATALOG**
* on the table's parent catalog and be an owner of the table's parent schema 3. have the
* following permissions: - **USE_CATALOG** on the table's parent catalog - **USE_SCHEMA** on the
* table's parent schema - be an owner of the table.
*
*
Additionally, the call must be made from the workspace where the monitor was created.
*
*
Note that the metric tables and dashboard will not be deleted as part of this call; those
* assets must be manually cleaned up (if desired).
*/
public void delete(DeleteLakehouseMonitorRequest request) {
impl.delete(request);
}
public MonitorInfo get(String fullName) {
return get(new GetLakehouseMonitorRequest().setFullName(fullName));
}
/**
* Get a table monitor.
*
*
Gets a monitor for the specified table.
*
*
The caller must either: 1. be an owner of the table's parent catalog 2. have **USE_CATALOG**
* on the table's parent catalog and be an owner of the table's parent schema. 3. have the
* following permissions: - **USE_CATALOG** on the table's parent catalog - **USE_SCHEMA** on the
* table's parent schema - **SELECT** privilege on the table.
*
*
The returned information includes configuration values, as well as information on assets
* created by the monitor. Some information (e.g., dashboard) may be filtered out if the caller is
* in a different workspace than where the monitor was created.
*/
public MonitorInfo get(GetLakehouseMonitorRequest request) {
return impl.get(request);
}
public MonitorRefreshInfo getRefresh(String fullName, String refreshId) {
return getRefresh(new GetRefreshRequest().setFullName(fullName).setRefreshId(refreshId));
}
/**
* Get refresh.
*
*
Gets info about a specific monitor refresh using the given refresh ID.
*
*
The caller must either: 1. be an owner of the table's parent catalog 2. have **USE_CATALOG**
* on the table's parent catalog and be an owner of the table's parent schema 3. have the
* following permissions: - **USE_CATALOG** on the table's parent catalog - **USE_SCHEMA** on the
* table's parent schema - **SELECT** privilege on the table.
*
*
Additionally, the call must be made from the workspace where the monitor was created.
*/
public MonitorRefreshInfo getRefresh(GetRefreshRequest request) {
return impl.getRefresh(request);
}
public Iterable listRefreshes(String fullName) {
return listRefreshes(new ListRefreshesRequest().setFullName(fullName));
}
/**
* List refreshes.
*
* Gets an array containing the history of the most recent refreshes (up to 25) for this table.
*
*
The caller must either: 1. be an owner of the table's parent catalog 2. have **USE_CATALOG**
* on the table's parent catalog and be an owner of the table's parent schema 3. have the
* following permissions: - **USE_CATALOG** on the table's parent catalog - **USE_SCHEMA** on the
* table's parent schema - **SELECT** privilege on the table.
*
*
Additionally, the call must be made from the workspace where the monitor was created.
*/
public Iterable listRefreshes(ListRefreshesRequest request) {
return impl.listRefreshes(request);
}
public MonitorRefreshInfo runRefresh(String fullName) {
return runRefresh(new RunRefreshRequest().setFullName(fullName));
}
/**
* Queue a metric refresh for a monitor.
*
* Queues a metric refresh on the monitor for the specified table. The refresh will execute in
* the background.
*
*
The caller must either: 1. be an owner of the table's parent catalog 2. have **USE_CATALOG**
* on the table's parent catalog and be an owner of the table's parent schema 3. have the
* following permissions: - **USE_CATALOG** on the table's parent catalog - **USE_SCHEMA** on the
* table's parent schema - be an owner of the table
*
*
Additionally, the call must be made from the workspace where the monitor was created.
*/
public MonitorRefreshInfo runRefresh(RunRefreshRequest request) {
return impl.runRefresh(request);
}
public MonitorInfo update(String fullName, String assetsDir, String outputSchemaName) {
return update(
new UpdateMonitor()
.setFullName(fullName)
.setAssetsDir(assetsDir)
.setOutputSchemaName(outputSchemaName));
}
/**
* Update a table monitor.
*
*
Updates a monitor for the specified table.
*
*
The caller must either: 1. be an owner of the table's parent catalog 2. have **USE_CATALOG**
* on the table's parent catalog and be an owner of the table's parent schema 3. have the
* following permissions: - **USE_CATALOG** on the table's parent catalog - **USE_SCHEMA** on the
* table's parent schema - be an owner of the table.
*
*
Additionally, the call must be made from the workspace where the monitor was created, and
* the caller must be the original creator of the monitor.
*
*
Certain configuration fields, such as output asset identifiers, cannot be updated.
*/
public MonitorInfo update(UpdateMonitor request) {
return impl.update(request);
}
public LakehouseMonitorsService impl() {
return impl;
}
}