-
Notifications
You must be signed in to change notification settings - Fork 117
/
zz_publicvirtualinterface_types.go
executable file
·136 lines (105 loc) · 5.46 KB
/
zz_publicvirtualinterface_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
/*
Copyright 2022 Upbound Inc.
*/
// 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 PublicVirtualInterfaceObservation struct {
AmazonSideAsn *string `json:"amazonSideAsn,omitempty" tf:"amazon_side_asn,omitempty"`
// The ARN of the virtual interface.
Arn *string `json:"arn,omitempty" tf:"arn,omitempty"`
// The Direct Connect endpoint on which the virtual interface terminates.
AwsDevice *string `json:"awsDevice,omitempty" tf:"aws_device,omitempty"`
// The ID of the virtual interface.
ID *string `json:"id,omitempty" tf:"id,omitempty"`
// A map of tags assigned to the resource, including those inherited from the provider default_tags configuration block.
TagsAll map[string]*string `json:"tagsAll,omitempty" tf:"tags_all,omitempty"`
}
type PublicVirtualInterfaceParameters struct {
// The address family for the BGP peer. ipv4 or ipv6.
// +kubebuilder:validation:Required
AddressFamily *string `json:"addressFamily" tf:"address_family,omitempty"`
// The IPv4 CIDR address to use to send traffic to Amazon. Required for IPv4 BGP peers.
// +kubebuilder:validation:Optional
AmazonAddress *string `json:"amazonAddress,omitempty" tf:"amazon_address,omitempty"`
// The autonomous system (AS) number for Border Gateway Protocol (BGP) configuration.
// +kubebuilder:validation:Required
BGPAsn *float64 `json:"bgpAsn" tf:"bgp_asn,omitempty"`
// The authentication key for BGP configuration.
// +kubebuilder:validation:Optional
BGPAuthKey *string `json:"bgpAuthKey,omitempty" tf:"bgp_auth_key,omitempty"`
// The ID of the Direct Connect connection (or LAG) on which to create the virtual interface.
// +crossplane:generate:reference:type=Connection
// +kubebuilder:validation:Optional
ConnectionID *string `json:"connectionId,omitempty" tf:"connection_id,omitempty"`
// Reference to a Connection to populate connectionId.
// +kubebuilder:validation:Optional
ConnectionIDRef *v1.Reference `json:"connectionIdRef,omitempty" tf:"-"`
// Selector for a Connection to populate connectionId.
// +kubebuilder:validation:Optional
ConnectionIDSelector *v1.Selector `json:"connectionIdSelector,omitempty" tf:"-"`
// The IPv4 CIDR destination address to which Amazon should send traffic. Required for IPv4 BGP peers.
// +kubebuilder:validation:Optional
CustomerAddress *string `json:"customerAddress,omitempty" tf:"customer_address,omitempty"`
// The name for the virtual interface.
// +kubebuilder:validation:Required
Name *string `json:"name" tf:"name,omitempty"`
// Region is the region you'd like your resource to be created in.
// +upjet:crd:field:TFTag=-
// +kubebuilder:validation:Required
Region *string `json:"region" tf:"-"`
// A list of routes to be advertised to the AWS network in this region.
// +kubebuilder:validation:Required
RouteFilterPrefixes []*string `json:"routeFilterPrefixes" tf:"route_filter_prefixes,omitempty"`
// Key-value map of resource tags.
// +kubebuilder:validation:Optional
Tags map[string]*string `json:"tags,omitempty" tf:"tags,omitempty"`
// The VLAN ID.
// +kubebuilder:validation:Required
Vlan *float64 `json:"vlan" tf:"vlan,omitempty"`
}
// PublicVirtualInterfaceSpec defines the desired state of PublicVirtualInterface
type PublicVirtualInterfaceSpec struct {
v1.ResourceSpec `json:",inline"`
ForProvider PublicVirtualInterfaceParameters `json:"forProvider"`
}
// PublicVirtualInterfaceStatus defines the observed state of PublicVirtualInterface.
type PublicVirtualInterfaceStatus struct {
v1.ResourceStatus `json:",inline"`
AtProvider PublicVirtualInterfaceObservation `json:"atProvider,omitempty"`
}
// +kubebuilder:object:root=true
// PublicVirtualInterface is the Schema for the PublicVirtualInterfaces API. Provides a Direct Connect public virtual interface resource.
// +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,aws}
type PublicVirtualInterface struct {
metav1.TypeMeta `json:",inline"`
metav1.ObjectMeta `json:"metadata,omitempty"`
Spec PublicVirtualInterfaceSpec `json:"spec"`
Status PublicVirtualInterfaceStatus `json:"status,omitempty"`
}
// +kubebuilder:object:root=true
// PublicVirtualInterfaceList contains a list of PublicVirtualInterfaces
type PublicVirtualInterfaceList struct {
metav1.TypeMeta `json:",inline"`
metav1.ListMeta `json:"metadata,omitempty"`
Items []PublicVirtualInterface `json:"items"`
}
// Repository type metadata.
var (
PublicVirtualInterface_Kind = "PublicVirtualInterface"
PublicVirtualInterface_GroupKind = schema.GroupKind{Group: CRDGroup, Kind: PublicVirtualInterface_Kind}.String()
PublicVirtualInterface_KindAPIVersion = PublicVirtualInterface_Kind + "." + CRDGroupVersion.String()
PublicVirtualInterface_GroupVersionKind = CRDGroupVersion.WithKind(PublicVirtualInterface_Kind)
)
func init() {
SchemeBuilder.Register(&PublicVirtualInterface{}, &PublicVirtualInterfaceList{})
}