forked from dell/gopowerscale
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcluster.go
59 lines (47 loc) · 1.69 KB
/
cluster.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
/*
Copyright (c) 2019 Dell Inc, or its subsidiaries.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package goisilon
import (
"context"
apiv3 "github.com/dell/goisilon/api/v3"
)
// Stats is Isilon statistics data structure .
type Stats *apiv3.IsiStatsResp
//GetStatistics returns statistics from Isilon. Keys indicate type of statistics expected
func (c *Client) GetStatistics(
ctx context.Context,
keys []string) (Stats, error) {
stats, err := apiv3.GetIsiStats(ctx, c.API, keys)
if err != nil {
return nil, err
}
return stats, nil
}
// ClusterConfig represents the configuration of cluster in k8s (namespace API).
type ClusterConfig *apiv3.IsiClusterConfig
// GetClusterConfig returns information about the configuration of cluster
func (c *Client) GetClusterConfig(ctx context.Context) (ClusterConfig, error) {
clusterConfig, err := apiv3.GetIsiClusterConfig(ctx, c.API)
if err != nil {
return nil, err
}
return clusterConfig, nil
}
// GetLocalSerial returns the local serial which is the serial number of cluster
func (c *Client) GetLocalSerial(ctx context.Context) (string, error) {
clusterConfig, err := c.GetClusterConfig(ctx)
if err != nil {
return "", err
}
return clusterConfig.LocalSerial, nil
}