com.databricks.sdk.service.sql.DashboardsAPI Maven / Gradle / Ivy
// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT.
package com.databricks.sdk.service.sql;
import com.databricks.sdk.core.ApiClient;
import com.databricks.sdk.support.Generated;
import com.databricks.sdk.support.Paginator;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* 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.
*/
@Generated
public class DashboardsAPI {
private static final Logger LOG = LoggerFactory.getLogger(DashboardsAPI.class);
private final DashboardsService impl;
/** Regular-use constructor */
public DashboardsAPI(ApiClient apiClient) {
impl = new DashboardsImpl(apiClient);
}
/** Constructor for mocks */
public DashboardsAPI(DashboardsService mock) {
impl = mock;
}
public Dashboard create(String name) {
return create(new DashboardPostContent().setName(name));
}
/** Create a dashboard object. */
public Dashboard create(DashboardPostContent request) {
return impl.create(request);
}
public void delete(String dashboardId) {
delete(new DeleteDashboardRequest().setDashboardId(dashboardId));
}
/**
* Remove a dashboard.
*
* Moves a dashboard to the trash. Trashed dashboards do not appear in list views or searches,
* and cannot be shared.
*/
public void delete(DeleteDashboardRequest request) {
impl.delete(request);
}
public Dashboard get(String dashboardId) {
return get(new GetDashboardRequest().setDashboardId(dashboardId));
}
/**
* Retrieve a definition.
*
*
Returns a JSON representation of a dashboard object, including its visualization and query
* objects.
*/
public Dashboard get(GetDashboardRequest request) {
return impl.get(request);
}
/**
* Get dashboard objects.
*
*
Fetch a paginated list of dashboard objects.
*
*
**Warning**: Calling this API concurrently 10 or more times could result in throttling,
* service degradation, or a temporary ban.
*/
public Iterable list(ListDashboardsRequest request) {
request.setPage(1L);
return new Paginator<>(
request,
impl::list,
ListResponse::getResults,
response -> {
Long page = request.getPage();
if (page == null) {
page = 1L; // redash uses 1-based pagination
}
return request.setPage(page + 1L);
})
.withDedupe(Dashboard::getId);
}
public void restore(String dashboardId) {
restore(new RestoreDashboardRequest().setDashboardId(dashboardId));
}
/**
* Restore a dashboard.
*
* A restored dashboard appears in list views and searches and can be shared.
*/
public void restore(RestoreDashboardRequest request) {
impl.restore(request);
}
public Dashboard update(String dashboardId) {
return update(new DashboardEditContent().setDashboardId(dashboardId));
}
/**
* Change a dashboard definition.
*
*
Modify this dashboard definition. This operation only affects attributes of the dashboard
* object. It does not add, modify, or remove widgets.
*
*
**Note**: You cannot undo this operation.
*/
public Dashboard update(DashboardEditContent request) {
return impl.update(request);
}
public DashboardsService impl() {
return impl;
}
}