From 825f8ca725a8c4e7fad241b63fb54989547d4482 Mon Sep 17 00:00:00 2001 From: Damiano Donati Date: Wed, 22 May 2024 14:13:28 +0200 Subject: [PATCH] fix: check for nil matching subnet when publicIP is set --- pkg/cloud/services/ec2/instances.go | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/pkg/cloud/services/ec2/instances.go b/pkg/cloud/services/ec2/instances.go index b943a493ba..a3efbea726 100644 --- a/pkg/cloud/services/ec2/instances.go +++ b/pkg/cloud/services/ec2/instances.go @@ -352,9 +352,17 @@ func (s *Service) findSubnet(scope *scope.MachineScope) (string, error) { *subnet.SubnetId, *subnet.AvailabilityZone, *failureDomain) continue } - if scope.AWSMachine.Spec.PublicIP != nil && *scope.AWSMachine.Spec.PublicIP && !s.scope.Subnets().FindByID(*subnet.SubnetId).IsPublic { - errMessage += fmt.Sprintf(" subnet %q is a private subnet.", *subnet.SubnetId) - continue + + if ptr.Deref(scope.AWSMachine.Spec.PublicIP, false) { + matchingSubnet := s.scope.Subnets().FindByID(*subnet.SubnetId) + if matchingSubnet == nil { + errMessage += fmt.Sprintf(" unable to find subnet %q among the AWSCluster subnets.", *subnet.SubnetId) + continue + } + if !matchingSubnet.IsPublic { + errMessage += fmt.Sprintf(" subnet %q is a private subnet.", *subnet.SubnetId) + continue + } } filtered = append(filtered, subnet) }