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

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; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy