databricks-sdk-golang/aws/libraries.go

84 lines
2.6 KiB
Go
Raw Permalink Normal View History

2019-05-27 21:29:27 +00:00
package aws
2019-05-27 20:42:37 +00:00
2019-05-29 01:16:26 +00:00
import (
"encoding/json"
"net/http"
2021-04-07 14:01:52 +00:00
"github.com/FlipsideCrypto/databricks-sdk-golang/aws/models"
2019-05-29 01:16:26 +00:00
)
2019-05-27 20:42:37 +00:00
// LibrariesAPI exposes the Libraries API
type LibrariesAPI struct {
2019-05-29 00:33:54 +00:00
Client DBClient
2019-05-27 20:42:37 +00:00
}
2019-05-29 00:33:54 +00:00
func (a LibrariesAPI) init(client DBClient) LibrariesAPI {
a.Client = client
return a
}
2019-05-29 01:16:26 +00:00
// AllClusterStatuses gets the status of all libraries on all clusters
func (a LibrariesAPI) AllClusterStatuses() ([]models.ClusterLibraryStatuses, error) {
2019-05-29 02:00:58 +00:00
var allClusterStatusesResponse struct {
Statuses []models.ClusterLibraryStatuses `json:"statuses,omitempty" url:"statuses,omitempty"`
}
2019-05-29 01:16:26 +00:00
resp, err := a.Client.performQuery(http.MethodGet, "/libraries/all-cluster-statuses", nil, nil)
if err != nil {
return allClusterStatusesResponse.Statuses, err
}
err = json.Unmarshal(resp, &allClusterStatusesResponse)
return allClusterStatusesResponse.Statuses, err
}
// LibrariesClusterStatusResponse is a response from AllClusterStatuses
type LibrariesClusterStatusResponse struct {
ClusterID string `json:"cluster_id,omitempty" url:"cluster_id,omitempty"`
LibraryStatuses []models.LibraryFullStatus `json:"library_statuses,omitempty" url:"library_statuses,omitempty"`
}
// ClusterStatus get the status of libraries on a cluster
func (a LibrariesAPI) ClusterStatus(clusterID string) (LibrariesClusterStatusResponse, error) {
var clusterStatusResponse LibrariesClusterStatusResponse
data := struct {
ClusterID string `json:"cluster_id,omitempty" url:"cluster_id,omitempty"`
}{
clusterID,
}
resp, err := a.Client.performQuery(http.MethodGet, "/libraries/cluster-status", data, nil)
if err != nil {
return clusterStatusResponse, err
}
err = json.Unmarshal(resp, &clusterStatusResponse)
return clusterStatusResponse, err
}
// Install installs libraries on a cluster
func (a LibrariesAPI) Install(clusterID string, libraries []models.Library) error {
data := struct {
ClusterID string `json:"cluster_id,omitempty" url:"cluster_id,omitempty"`
Libraries []models.Library `json:"libraries,omitempty" url:"libraries,omitempty"`
}{
clusterID,
libraries,
}
_, err := a.Client.performQuery(http.MethodPost, "/libraries/install", data, nil)
return err
}
// Uninstall sets libraries to be uninstalled on a cluster
func (a LibrariesAPI) Uninstall(clusterID string, libraries []models.Library) error {
data := struct {
ClusterID string `json:"cluster_id,omitempty" url:"cluster_id,omitempty"`
Libraries []models.Library `json:"libraries,omitempty" url:"libraries,omitempty"`
}{
clusterID,
libraries,
}
_, err := a.Client.performQuery(http.MethodPost, "/libraries/uninstall", data, nil)
return err
}