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

com.databricks.sdk.service.catalog.LakehouseMonitorsAPI Maven / Gradle / Ivy

There is a newer version: 0.38.0
Show newest version
// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT.
package com.databricks.sdk.service.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; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy