-
Notifications
You must be signed in to change notification settings - Fork 66
/
types_infrastructure.go
120 lines (100 loc) · 3.62 KB
/
types_infrastructure.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
// SPDX-FileCopyrightText: 2024 SAP SE or an SAP affiliate company and Gardener contributors
//
// SPDX-License-Identifier: Apache-2.0
package alicloud
import (
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
)
// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
// InfrastructureConfig infrastructure configuration resource
type InfrastructureConfig struct {
metav1.TypeMeta
// Networks specifies the networks for an infrastructure.
Networks Networks
}
// Networks specifies the networks for an infrastructure.
type Networks struct {
// VPC contains information about whether to create a new or use an existing VPC.
VPC VPC
// Zones are the network zones for an infrastructure.
Zones []Zone
}
// VPC contains information about whether to create a new or use an existing VPC.
type VPC struct {
// ID is the ID of an existing VPC.
// +optional
ID *string
// CIDR is the CIDR of a VPC to create.
// +optional
CIDR *string
// GardenerManagedNATGateway indicates whether Gardener should create NATGateway in the VPC.
// This will only take effect if VPC ID is set.
// +optional
GardenerManagedNATGateway *bool
}
// VPCStatus contains output information about the VPC.
type VPCStatus struct {
// ID is the ID of the VPC.
ID string
// VSwitches is a list of vswitches.
VSwitches []VSwitch
// SecurityGroups is a list of security groups.
SecurityGroups []SecurityGroup
}
// Purpose is a purpose of a subnet.
type Purpose string
const (
// PurposeNodes is a Purpose for nodes.
PurposeNodes Purpose = "nodes"
// PurposeInternal is a Purpose for internal use.
PurposeInternal Purpose = "internal"
)
// VSwitch contains information about a vswitch.
type VSwitch struct {
// Purpose is the purpose for which the vswitch was created.
Purpose Purpose
// ID is the id of the vswitch.
ID string
// Zone is the name of the zone.
Zone string
}
// SecurityGroup contains information about a security group.
type SecurityGroup struct {
// Purpose is the purpose for which the security group was created.
Purpose Purpose
// ID is the id of the security group.
ID string
}
// Zone is a zone with a name and worker CIDR.
type Zone struct {
// Name is the name of a zone.
Name string
// Worker specifies the worker CIDR to use.
// Deprecated - use `workers` instead.
Worker string
// Workers specifies the worker CIDR to use.
Workers string
// NatGatewayConfig specifies configuration for the NAT gateway in this zone.
NatGateway *NatGatewayConfig
}
// NatGatewayConfig specifies configuration for the NAT gateway in this zone.
type NatGatewayConfig struct {
// EIPAllocationID specifies the EIP to bind on NatGateway.
EIPAllocationID *string
}
// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
// InfrastructureStatus contains information about created infrastructure resources.
type InfrastructureStatus struct {
metav1.TypeMeta
VPC VPCStatus
// KeyPairName is the key pair name.
//
// Deprecated: the field should not be used anymore as the SSH key pair is no longer generated by terraform.
KeyPairName string
// MachineImages is a list of machine images that have been used in this infrastructure. Usually, the extension controller
// gets the mapping from name/version to the provider-specific machine image data in its componentconfig. However, if
// a version that is still in use gets removed from this componentconfig and Shoot's access to the this version is revoked,
// it cannot reconcile anymore existing `Infrastructure` resources that are still using this version. Hence, it stores
// the used versions in the provider status to ensure reconciliation is possible.
MachineImages []MachineImage
}