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