-
Notifications
You must be signed in to change notification settings - Fork 59
/
zz_targethttpsproxy_types.go
executable file
·196 lines (155 loc) · 8.77 KB
/
zz_targethttpsproxy_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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
/*
Copyright 2021 The Crossplane Authors.
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.
*/
// Code generated by upjet. DO NOT EDIT.
package v1beta1
import (
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/runtime/schema"
v1 "github.com/crossplane/crossplane-runtime/apis/common/v1"
)
type TargetHTTPSProxyObservation struct {
// A reference to the CertificateMap resource uri that identifies a certificate map
// associated with the given target proxy. This field can only be set for global target proxies.
// Accepted format is //certificatemanager.googleapis.com/projects/{project}/locations/{location}/certificateMaps/{resourceName}.
CertificateMap *string `json:"certificateMap,omitempty" tf:"certificate_map,omitempty"`
// Creation timestamp in RFC3339 text format.
CreationTimestamp *string `json:"creationTimestamp,omitempty" tf:"creation_timestamp,omitempty"`
// An optional description of this resource.
Description *string `json:"description,omitempty" tf:"description,omitempty"`
// an identifier for the resource with format projects/{{project}}/global/targetHttpsProxies/{{name}}
ID *string `json:"id,omitempty" tf:"id,omitempty"`
// The ID of the project in which the resource belongs.
// If it is not provided, the provider project is used.
Project *string `json:"project,omitempty" tf:"project,omitempty"`
// This field only applies when the forwarding rule that references
// this target proxy has a loadBalancingScheme set to INTERNAL_SELF_MANAGED.
ProxyBind *bool `json:"proxyBind,omitempty" tf:"proxy_bind,omitempty"`
// The unique identifier for the resource.
ProxyID *float64 `json:"proxyId,omitempty" tf:"proxy_id,omitempty"`
// Specifies the QUIC override policy for this resource. This determines
// whether the load balancer will attempt to negotiate QUIC with clients
// or not. Can specify one of NONE, ENABLE, or DISABLE. If NONE is
// specified, Google manages whether QUIC is used.
// Default value is NONE.
// Possible values are: NONE, ENABLE, DISABLE.
QuicOverride *string `json:"quicOverride,omitempty" tf:"quic_override,omitempty"`
// A list of SslCertificate resources that are used to authenticate
// connections between users and the load balancer. At least one SSL
// certificate must be specified.
SSLCertificates []*string `json:"sslCertificates,omitempty" tf:"ssl_certificates,omitempty"`
// A reference to the SslPolicy resource that will be associated with
// the TargetHttpsProxy resource. If not set, the TargetHttpsProxy
// resource will not have any SSL policy configured.
SSLPolicy *string `json:"sslPolicy,omitempty" tf:"ssl_policy,omitempty"`
// The URI of the created resource.
SelfLink *string `json:"selfLink,omitempty" tf:"self_link,omitempty"`
// A reference to the UrlMap resource that defines the mapping from URL
// to the BackendService.
URLMap *string `json:"urlMap,omitempty" tf:"url_map,omitempty"`
}
type TargetHTTPSProxyParameters struct {
// A reference to the CertificateMap resource uri that identifies a certificate map
// associated with the given target proxy. This field can only be set for global target proxies.
// Accepted format is //certificatemanager.googleapis.com/projects/{project}/locations/{location}/certificateMaps/{resourceName}.
// +kubebuilder:validation:Optional
CertificateMap *string `json:"certificateMap,omitempty" tf:"certificate_map,omitempty"`
// An optional description of this resource.
// +kubebuilder:validation:Optional
Description *string `json:"description,omitempty" tf:"description,omitempty"`
// The ID of the project in which the resource belongs.
// If it is not provided, the provider project is used.
// +kubebuilder:validation:Optional
Project *string `json:"project,omitempty" tf:"project,omitempty"`
// This field only applies when the forwarding rule that references
// this target proxy has a loadBalancingScheme set to INTERNAL_SELF_MANAGED.
// +kubebuilder:validation:Optional
ProxyBind *bool `json:"proxyBind,omitempty" tf:"proxy_bind,omitempty"`
// Specifies the QUIC override policy for this resource. This determines
// whether the load balancer will attempt to negotiate QUIC with clients
// or not. Can specify one of NONE, ENABLE, or DISABLE. If NONE is
// specified, Google manages whether QUIC is used.
// Default value is NONE.
// Possible values are: NONE, ENABLE, DISABLE.
// +kubebuilder:validation:Optional
QuicOverride *string `json:"quicOverride,omitempty" tf:"quic_override,omitempty"`
// A list of SslCertificate resources that are used to authenticate
// connections between users and the load balancer. At least one SSL
// certificate must be specified.
// +crossplane:generate:reference:type=SSLCertificate
// +kubebuilder:validation:Optional
SSLCertificates []*string `json:"sslCertificates,omitempty" tf:"ssl_certificates,omitempty"`
// References to SSLCertificate to populate sslCertificates.
// +kubebuilder:validation:Optional
SSLCertificatesRefs []v1.Reference `json:"sslCertificatesRefs,omitempty" tf:"-"`
// Selector for a list of SSLCertificate to populate sslCertificates.
// +kubebuilder:validation:Optional
SSLCertificatesSelector *v1.Selector `json:"sslCertificatesSelector,omitempty" tf:"-"`
// A reference to the SslPolicy resource that will be associated with
// the TargetHttpsProxy resource. If not set, the TargetHttpsProxy
// resource will not have any SSL policy configured.
// +kubebuilder:validation:Optional
SSLPolicy *string `json:"sslPolicy,omitempty" tf:"ssl_policy,omitempty"`
// A reference to the UrlMap resource that defines the mapping from URL
// to the BackendService.
// +crossplane:generate:reference:type=github.com/upbound/provider-gcp/apis/compute/v1beta1.URLMap
// +crossplane:generate:reference:extractor=github.com/upbound/upjet/pkg/resource.ExtractResourceID()
// +kubebuilder:validation:Optional
URLMap *string `json:"urlMap,omitempty" tf:"url_map,omitempty"`
// Reference to a URLMap in compute to populate urlMap.
// +kubebuilder:validation:Optional
URLMapRef *v1.Reference `json:"urlMapRef,omitempty" tf:"-"`
// Selector for a URLMap in compute to populate urlMap.
// +kubebuilder:validation:Optional
URLMapSelector *v1.Selector `json:"urlMapSelector,omitempty" tf:"-"`
}
// TargetHTTPSProxySpec defines the desired state of TargetHTTPSProxy
type TargetHTTPSProxySpec struct {
v1.ResourceSpec `json:",inline"`
ForProvider TargetHTTPSProxyParameters `json:"forProvider"`
}
// TargetHTTPSProxyStatus defines the observed state of TargetHTTPSProxy.
type TargetHTTPSProxyStatus struct {
v1.ResourceStatus `json:",inline"`
AtProvider TargetHTTPSProxyObservation `json:"atProvider,omitempty"`
}
// +kubebuilder:object:root=true
// TargetHTTPSProxy is the Schema for the TargetHTTPSProxys API. Represents a TargetHttpsProxy resource, which is used by one or more global forwarding rule to route incoming HTTPS requests to a URL map.
// +kubebuilder:printcolumn:name="READY",type="string",JSONPath=".status.conditions[?(@.type=='Ready')].status"
// +kubebuilder:printcolumn:name="SYNCED",type="string",JSONPath=".status.conditions[?(@.type=='Synced')].status"
// +kubebuilder:printcolumn:name="EXTERNAL-NAME",type="string",JSONPath=".metadata.annotations.crossplane\\.io/external-name"
// +kubebuilder:printcolumn:name="AGE",type="date",JSONPath=".metadata.creationTimestamp"
// +kubebuilder:subresource:status
// +kubebuilder:resource:scope=Cluster,categories={crossplane,managed,gcp}
type TargetHTTPSProxy struct {
metav1.TypeMeta `json:",inline"`
metav1.ObjectMeta `json:"metadata,omitempty"`
Spec TargetHTTPSProxySpec `json:"spec"`
Status TargetHTTPSProxyStatus `json:"status,omitempty"`
}
// +kubebuilder:object:root=true
// TargetHTTPSProxyList contains a list of TargetHTTPSProxys
type TargetHTTPSProxyList struct {
metav1.TypeMeta `json:",inline"`
metav1.ListMeta `json:"metadata,omitempty"`
Items []TargetHTTPSProxy `json:"items"`
}
// Repository type metadata.
var (
TargetHTTPSProxy_Kind = "TargetHTTPSProxy"
TargetHTTPSProxy_GroupKind = schema.GroupKind{Group: CRDGroup, Kind: TargetHTTPSProxy_Kind}.String()
TargetHTTPSProxy_KindAPIVersion = TargetHTTPSProxy_Kind + "." + CRDGroupVersion.String()
TargetHTTPSProxy_GroupVersionKind = CRDGroupVersion.WithKind(TargetHTTPSProxy_Kind)
)
func init() {
SchemeBuilder.Register(&TargetHTTPSProxy{}, &TargetHTTPSProxyList{})
}