/
metering_client.go
103 lines (85 loc) · 2.73 KB
/
metering_client.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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
// Code generated by client-gen. DO NOT EDIT.
package v1
import (
v1 "github.com/operator-framework/operator-metering/pkg/apis/metering/v1"
"github.com/operator-framework/operator-metering/pkg/generated/clientset/versioned/scheme"
rest "k8s.io/client-go/rest"
)
type MeteringV1Interface interface {
RESTClient() rest.Interface
HiveTablesGetter
MeteringConfigsGetter
PrestoTablesGetter
ReportsGetter
ReportDataSourcesGetter
ReportQueriesGetter
StorageLocationsGetter
}
// MeteringV1Client is used to interact with features provided by the metering.openshift.io group.
type MeteringV1Client struct {
restClient rest.Interface
}
func (c *MeteringV1Client) HiveTables(namespace string) HiveTableInterface {
return newHiveTables(c, namespace)
}
func (c *MeteringV1Client) MeteringConfigs(namespace string) MeteringConfigInterface {
return newMeteringConfigs(c, namespace)
}
func (c *MeteringV1Client) PrestoTables(namespace string) PrestoTableInterface {
return newPrestoTables(c, namespace)
}
func (c *MeteringV1Client) Reports(namespace string) ReportInterface {
return newReports(c, namespace)
}
func (c *MeteringV1Client) ReportDataSources(namespace string) ReportDataSourceInterface {
return newReportDataSources(c, namespace)
}
func (c *MeteringV1Client) ReportQueries(namespace string) ReportQueryInterface {
return newReportQueries(c, namespace)
}
func (c *MeteringV1Client) StorageLocations(namespace string) StorageLocationInterface {
return newStorageLocations(c, namespace)
}
// NewForConfig creates a new MeteringV1Client for the given config.
func NewForConfig(c *rest.Config) (*MeteringV1Client, error) {
config := *c
if err := setConfigDefaults(&config); err != nil {
return nil, err
}
client, err := rest.RESTClientFor(&config)
if err != nil {
return nil, err
}
return &MeteringV1Client{client}, nil
}
// NewForConfigOrDie creates a new MeteringV1Client for the given config and
// panics if there is an error in the config.
func NewForConfigOrDie(c *rest.Config) *MeteringV1Client {
client, err := NewForConfig(c)
if err != nil {
panic(err)
}
return client
}
// New creates a new MeteringV1Client for the given RESTClient.
func New(c rest.Interface) *MeteringV1Client {
return &MeteringV1Client{c}
}
func setConfigDefaults(config *rest.Config) error {
gv := v1.SchemeGroupVersion
config.GroupVersion = &gv
config.APIPath = "/apis"
config.NegotiatedSerializer = scheme.Codecs.WithoutConversion()
if config.UserAgent == "" {
config.UserAgent = rest.DefaultKubernetesUserAgent()
}
return nil
}
// RESTClient returns a RESTClient that is used to communicate
// with API server by this client implementation.
func (c *MeteringV1Client) RESTClient() rest.Interface {
if c == nil {
return nil
}
return c.restClient
}