/
solacescalable_types.go
99 lines (82 loc) · 3.22 KB
/
solacescalable_types.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
/*
Copyright 2022.
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 v1alpha1
import (
corev1 "k8s.io/api/core/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
)
// EDIT THIS FILE! THIS IS SCAFFOLDING FOR YOU TO OWN!
// NOTE: json tags are required. Any new fields you add must have json tags for the fields to be serialized.
// SolaceScalableSpec defines the desired state of SolaceScalable
type Container struct {
Image string `json:"image,omitempty"`
Name string `json:"name,omitempty"`
Env []corev1.EnvVar `json:"env,omitempty"`
Volume Volume `json:"volume,omitempty"`
}
type Volume struct {
Name string `json:"name,omitempty"`
Size string `json:"size,omitempty"`
HostPath string `json:"hostPath,omitempty"`
ReclaimPolicy string `json:"reclaimPolicy,omitempty"`
}
type SolaceScalableSpec struct {
// INSERT ADDITIONAL SPEC FIELDS - desired state of cluster
// Important: Run "make" to regenerate code after modifying this file
// Foo is an example field of SolaceScalable. Edit solacescalable_types.go to remove/update
Container Container `json:"container,omitempty"`
Replicas int32 `json:"replicas,omitempty"`
ClusterUrl string `json:"clusterUrl,omitempty"`
Haproxy Haproxy `json:"haproxy,omitempty"`
PvClass string `json:"pvClass,omitempty"`
NetWork Network `json:"network,omitempty"`
}
// SolaceScalableStatus defines the observed state of SolaceScalable
type SolaceScalableStatus struct {
// INSERT ADDITIONAL STATUS FIELD - define observed state of cluster
// Important: Run "make" to regenerate code after modifying this file
SolaceStatus string `json:"solaceStatus,omitempty"`
}
//+kubebuilder:object:root=true
//+kubebuilder:subresource:status
// SolaceScalable is the Schema for the solacescalables API
type SolaceScalable struct {
metav1.TypeMeta `json:",inline"`
metav1.ObjectMeta `json:"metadata,omitempty"`
Spec SolaceScalableSpec `json:"spec,omitempty"`
Status SolaceScalableStatus `json:"status,omitempty"`
}
type Haproxy struct {
Namespace string `json:"namespace,omitempty"`
Publish Publish `json:"publish,omitempty"`
Subscribe Subscribe `json:"subscribe,omitempty"`
}
type Publish struct {
ServiceName string `json:"serviceName,omitempty"`
}
type Subscribe struct {
ServiceName string `json:"serviceName,omitempty"`
}
type Network struct {
StartingAvailablePorts int32 `json:"startingAvailablePorts,omitempty"`
}
//+kubebuilder:object:root=true
// SolaceScalableList contains a list of SolaceScalable
type SolaceScalableList struct {
metav1.TypeMeta `json:",inline"`
metav1.ListMeta `json:"metadata,omitempty"`
Items []SolaceScalable `json:"items"`
}
func init() {
SchemeBuilder.Register(&SolaceScalable{}, &SolaceScalableList{})
}