-
Notifications
You must be signed in to change notification settings - Fork 90
/
hive_table.go
74 lines (57 loc) · 2.49 KB
/
hive_table.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
package v1
import (
meta "k8s.io/apimachinery/pkg/apis/meta/v1"
"github.com/operator-framework/operator-metering/pkg/hive"
)
var HiveTableGVK = SchemeGroupVersion.WithKind("HiveTable")
// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
type HiveTableList struct {
meta.TypeMeta `json:",inline"`
meta.ListMeta `json:"metadata,omitempty"`
Items []*HiveTable `json:"items"`
}
// +genclient
// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
type HiveTable struct {
meta.TypeMeta `json:",inline"`
meta.ObjectMeta `json:"metadata,omitempty"`
Spec HiveTableSpec `json:"spec"`
Status HiveTableStatus `json:"status"`
}
type HiveTablePartition hive.TablePartition
type HiveColumn hive.Column
type SortColumn struct {
Name string `json:"name"`
Decending *bool `json:"decending,omitempty"`
}
type HiveTableSpec struct {
DatabaseName string `json:"databaseName,omitempty"`
TableName string `json:"tableName"`
Columns []hive.Column `json:"columns"`
PartitionedBy []hive.Column `json:"partitionedBy,omitempty"`
ClusteredBy []string `json:"clusteredBy,omitempty"`
SortedBy []SortColumn `json:"sortedBy,omitempty"`
NumBuckets int `json:"numBuckets,omitempty"`
Location string `json:"location,omitempty"`
RowFormat string `json:"rowFormat,omitempty"`
FileFormat string `json:"fileFormat,omitempty"`
TableProperties map[string]string `json:"tableProperties,omitempty"`
External bool `json:"external,omitempty"`
ManagePartitions bool `json:"managePartitions"`
Partitions []HiveTablePartition `json:"partitions,omitempty"`
}
type HiveTableStatus struct {
DatabaseName string `json:"databaseName,omitempty"`
TableName string `json:"tableName"`
Columns []hive.Column `json:"columns"`
PartitionedBy []hive.Column `json:"partitionedBy,omitempty"`
ClusteredBy []string `json:"clusteredBy,omitempty"`
SortedBy []SortColumn `json:"sortedBy,omitempty"`
NumBuckets int `json:"numBuckets,omitempty"`
Location string `json:"location,omitempty"`
RowFormat string `json:"rowFormat,omitempty"`
FileFormat string `json:"fileFormat,omitempty"`
TableProperties map[string]string `json:"tableProperties,omitempty"`
External bool `json:"external,omitempty"`
Partitions []HiveTablePartition `json:"partitions"`
}