Skip to content

Commit 9a2b67a

Browse files
committed
fixup! feat: Define ServiceLoadBalancer Configuration API
- Accept IPv4 only - Add Required validation
1 parent df5addb commit 9a2b67a

File tree

1 file changed

+6
-8
lines changed

1 file changed

+6
-8
lines changed

api/v1alpha1/addon_types.go

Lines changed: 6 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -264,22 +264,20 @@ type ServiceLoadBalancer struct {
264264
}
265265

266266
type ServiceLoadBalancerConfiguration struct {
267-
// AddressRanges is a list of IPv4 or IPv6 address ranges from which
268-
// the provider can choose a load balancer address.
267+
// AddressRanges is a list of IPv4 address ranges the
268+
// provider uses to choose an address for a load balancer.
269+
// +kubebuilder:validation:Required
269270
// +kubebuilder:validation:MinItems=1
270271
AddressRanges []AddressRange `json:"addressRanges"`
271272
}
272273

273-
// AddressRange defines an IPv4 or IPv6 range.
274+
// AddressRange defines an IPv4 range.
274275
type AddressRange struct {
275-
// FIXME Both start and end should be of the same type (IPv4 or IPv6).
276-
// Because the pattern accepts either type, start and end can be of different
277-
// types.
278276
// Source: https://github.com/metal3-io/ip-address-manager/blob/b4f7c2a/api/v1alpha1/common_types.go#L19
279277

280-
// +kubebuilder:validation:Pattern="((^((([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\\.){3}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5]))$)|(^(([0-9a-fA-F]{1,4}:){7,7}[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,7}:|([0-9a-fA-F]{1,4}:){1,6}:[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,5}(:[0-9a-fA-F]{1,4}){1,2}|([0-9a-fA-F]{1,4}:){1,4}(:[0-9a-fA-F]{1,4}){1,3}|([0-9a-fA-F]{1,4}:){1,3}(:[0-9a-fA-F]{1,4}){1,4}|([0-9a-fA-F]{1,4}:){1,2}(:[0-9a-fA-F]{1,4}){1,5}|[0-9a-fA-F]{1,4}:((:[0-9a-fA-F]{1,4}){1,6})|:((:[0-9a-fA-F]{1,4}){1,7}|:))$))"
278+
// +kubebuilder:validation:Pattern="^((([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\\.){3}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5]))$"
281279
Start string `json:"start"`
282280

283-
// +kubebuilder:validation:Pattern="((^((([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\\.){3}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5]))$)|(^(([0-9a-fA-F]{1,4}:){7,7}[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,7}:|([0-9a-fA-F]{1,4}:){1,6}:[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,5}(:[0-9a-fA-F]{1,4}){1,2}|([0-9a-fA-F]{1,4}:){1,4}(:[0-9a-fA-F]{1,4}){1,3}|([0-9a-fA-F]{1,4}:){1,3}(:[0-9a-fA-F]{1,4}){1,4}|([0-9a-fA-F]{1,4}:){1,2}(:[0-9a-fA-F]{1,4}){1,5}|[0-9a-fA-F]{1,4}:((:[0-9a-fA-F]{1,4}){1,6})|:((:[0-9a-fA-F]{1,4}){1,7}|:))$))"
281+
// +kubebuilder:validation:Pattern="^((([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\\.){3}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5]))$"
284282
End string `json:"end"`
285283
}

0 commit comments

Comments
 (0)