Skip to content

Commit

Permalink
Add support for public IP tags
Browse files Browse the repository at this point in the history
  • Loading branch information
Cecile Robert-Michon committed Jun 24, 2022
1 parent 70a94ec commit 0a2ea7d
Show file tree
Hide file tree
Showing 13 changed files with 366 additions and 19 deletions.
14 changes: 14 additions & 0 deletions api/v1alpha3/azurecluster_conversion.go
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,15 @@ func (src *AzureCluster) ConvertTo(dstRaw conversion.Hub) error {

dst.Spec.NetworkSpec.APIServerLB.FrontendIPsCount = restored.Spec.NetworkSpec.APIServerLB.FrontendIPsCount
dst.Spec.NetworkSpec.APIServerLB.IdleTimeoutInMinutes = restored.Spec.NetworkSpec.APIServerLB.IdleTimeoutInMinutes

for _, restoredFrontendIP := range restored.Spec.NetworkSpec.APIServerLB.FrontendIPs {
for i, dstFrontendIP := range dst.Spec.NetworkSpec.APIServerLB.FrontendIPs {
if restoredFrontendIP.Name == dstFrontendIP.Name && restoredFrontendIP.PublicIP != nil {
dstFrontendIP.PublicIP.IPTags = restored.Spec.NetworkSpec.APIServerLB.FrontendIPs[i].PublicIP.IPTags
}
}
}

dst.Spec.CloudProviderConfigOverrides = restored.Spec.CloudProviderConfigOverrides
dst.Spec.BastionSpec = restored.Spec.BastionSpec

Expand Down Expand Up @@ -407,3 +416,8 @@ func Convert_v1beta1_FrontendIP_To_v1alpha3_FrontendIP(in *infrav1beta1.Frontend

return nil
}

// Convert_v1beta1_PublicIPSpec_To_v1alpha3_PublicIPSpec is an autogenerated conversion function.
func Convert_v1beta1_PublicIPSpec_To_v1alpha3_PublicIPSpec(in *infrav1beta1.PublicIPSpec, out *PublicIPSpec, s apiconversion.Scope) error {
return autoConvert_v1beta1_PublicIPSpec_To_v1alpha3_PublicIPSpec(in, out, s)
}
26 changes: 19 additions & 7 deletions api/v1alpha3/zz_generated.conversion.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

53 changes: 53 additions & 0 deletions api/v1alpha4/azurecluster_conversion.go
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,54 @@ func (src *AzureCluster) ConvertTo(dstRaw conversion.Hub) error {
// Restore list of virtual network peerings
dst.Spec.NetworkSpec.Vnet.Peerings = restored.Spec.NetworkSpec.Vnet.Peerings

// Restore API Server LB IP tags.
for _, restoredFrontendIP := range restored.Spec.NetworkSpec.APIServerLB.FrontendIPs {
for i, dstFrontendIP := range dst.Spec.NetworkSpec.APIServerLB.FrontendIPs {
if restoredFrontendIP.Name == dstFrontendIP.Name && restoredFrontendIP.PublicIP != nil {
dstFrontendIP.PublicIP.IPTags = restored.Spec.NetworkSpec.APIServerLB.FrontendIPs[i].PublicIP.IPTags
}
}
}

// Restore outbound LB IP tags.
if restored.Spec.NetworkSpec.ControlPlaneOutboundLB != nil {
for _, restoredFrontendIP := range restored.Spec.NetworkSpec.ControlPlaneOutboundLB.FrontendIPs {
for i, dstFrontendIP := range dst.Spec.NetworkSpec.ControlPlaneOutboundLB.FrontendIPs {
if restoredFrontendIP.Name == dstFrontendIP.Name && restoredFrontendIP.PublicIP != nil {
dstFrontendIP.PublicIP.IPTags = restored.Spec.NetworkSpec.ControlPlaneOutboundLB.FrontendIPs[i].PublicIP.IPTags
}
}
}
}
if restored.Spec.NetworkSpec.NodeOutboundLB != nil {
for _, restoredFrontendIP := range restored.Spec.NetworkSpec.NodeOutboundLB.FrontendIPs {
for i, dstFrontendIP := range dst.Spec.NetworkSpec.NodeOutboundLB.FrontendIPs {
if restoredFrontendIP.Name == dstFrontendIP.Name && restoredFrontendIP.PublicIP != nil {
dstFrontendIP.PublicIP.IPTags = restored.Spec.NetworkSpec.NodeOutboundLB.FrontendIPs[i].PublicIP.IPTags
}
}
}
}

// Restore NAT Gateway IP tags.
for _, restoredSubnet := range restored.Spec.NetworkSpec.Subnets {
for i, dstSubnet := range dst.Spec.NetworkSpec.Subnets {
if dstSubnet.Name == restoredSubnet.Name {
dst.Spec.NetworkSpec.Subnets[i].NatGateway.NatGatewayIP.IPTags = restoredSubnet.NatGateway.NatGatewayIP.IPTags
}
}
}

// Restore Azure Bastion IP tags.
if restored.Spec.BastionSpec.AzureBastion != nil && dst.Spec.BastionSpec.AzureBastion != nil {
if restored.Spec.BastionSpec.AzureBastion.PublicIP.Name == dst.Spec.BastionSpec.AzureBastion.PublicIP.Name {
dst.Spec.BastionSpec.AzureBastion.PublicIP.IPTags = restored.Spec.BastionSpec.AzureBastion.PublicIP.IPTags
}
if restored.Spec.BastionSpec.AzureBastion.Subnet.NatGateway.NatGatewayIP.Name == dst.Spec.BastionSpec.AzureBastion.Subnet.NatGateway.NatGatewayIP.Name {
dst.Spec.BastionSpec.AzureBastion.Subnet.NatGateway.NatGatewayIP.IPTags = restored.Spec.BastionSpec.AzureBastion.Subnet.NatGateway.NatGatewayIP.IPTags
}
}

return nil
}

Expand Down Expand Up @@ -299,3 +347,8 @@ func Convert_v1beta1_NatGateway_To_v1alpha4_NatGateway(in *infrav1beta1.NatGatew
out.Name = in.Name
return nil
}

// Convert_v1beta1_PublicIPSpec_To_v1alpha4_PublicIPSpec is an autogenerated conversion function.
func Convert_v1beta1_PublicIPSpec_To_v1alpha4_PublicIPSpec(in *infrav1beta1.PublicIPSpec, out *PublicIPSpec, s apiconversion.Scope) error {
return autoConvert_v1beta1_PublicIPSpec_To_v1alpha4_PublicIPSpec(in, out, s)
}
26 changes: 19 additions & 7 deletions api/v1alpha4/zz_generated.conversion.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion api/v1beta1/azurecluster_validation.go
Original file line number Diff line number Diff line change
Expand Up @@ -391,7 +391,7 @@ func validateNodeOutboundLB(lb *LoadBalancerSpec, old *LoadBalancerSpec, apiserv
if len(old.FrontendIPs) == len(lb.FrontendIPs) {
for i, frontEndIP := range lb.FrontendIPs {
oldFrontendIP := old.FrontendIPs[i]
if oldFrontendIP.Name != frontEndIP.Name || *oldFrontendIP.PublicIP != *frontEndIP.PublicIP {
if oldFrontendIP.Name != frontEndIP.Name || !reflect.DeepEqual(*oldFrontendIP.PublicIP, *frontEndIP.PublicIP) {
allErrs = append(allErrs, field.Forbidden(fldPath.Child("frontendIPs").Index(i),
"Node outbound load balancer FrontendIPs cannot be modified after AzureCluster creation."))
}
Expand Down
10 changes: 10 additions & 0 deletions api/v1beta1/types.go
Original file line number Diff line number Diff line change
Expand Up @@ -280,6 +280,16 @@ type PublicIPSpec struct {
Name string `json:"name"`
// +optional
DNSName string `json:"dnsName,omitempty"`
// +optional
IPTags []IPTag `json:"ipTags,omitempty"`
}

// IPTag contains the IpTag associated with the object.
type IPTag struct {
// Type specifies the IP tag type. Example: FirstPartyUsage.
Type string `json:"type"`
// Tag specifies the value of the IP tag associated with the public IP. Example: SQL.
Tag string `json:"tag"`
}

// VMState describes the state of an Azure virtual machine.
Expand Down
28 changes: 24 additions & 4 deletions api/v1beta1/zz_generated.deepcopy.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

38 changes: 38 additions & 0 deletions azure/converters/publicips.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
/*
Copyright 2022 The Kubernetes 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.
*/

package converters

import (
"github.com/Azure/azure-sdk-for-go/services/network/mgmt/2021-02-01/network"
"github.com/Azure/go-autorest/autorest/to"
infrav1 "sigs.k8s.io/cluster-api-provider-azure/api/v1beta1"
)

// IPTagsToSDK converts a CAPZ IP tag to an Azure SDK IP tag.
func IPTagsToSDK(ipTags []infrav1.IPTag) *[]network.IPTag {
if len(ipTags) == 0 {
return nil
}
skdIPTags := make([]network.IPTag, len(ipTags))
for i, ipTag := range ipTags {
skdIPTags[i] = network.IPTag{
IPTagType: to.StringPtr(ipTag.Type),
Tag: to.StringPtr(ipTag.Tag),
}
}
return &skdIPTags
}
70 changes: 70 additions & 0 deletions azure/converters/publicips_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
/*
Copyright 2022 The Kubernetes 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.
*/

package converters

import (
"reflect"
"testing"

"github.com/Azure/azure-sdk-for-go/services/network/mgmt/2021-02-01/network"
"github.com/Azure/go-autorest/autorest/to"
infrav1 "sigs.k8s.io/cluster-api-provider-azure/api/v1beta1"
)

func TestIPTagsToSDK(t *testing.T) {
tests := []struct {
name string
ipTags []infrav1.IPTag
want *[]network.IPTag
}{
{
name: "empty",
ipTags: []infrav1.IPTag{},
want: nil,
},
{
name: "list of tags",
ipTags: []infrav1.IPTag{
{
Type: "tag",
Tag: "value",
},
{
Type: "internal",
Tag: "foo",
},
},
want: &[]network.IPTag{
{
IPTagType: to.StringPtr("tag"),
Tag: to.StringPtr("value"),
},
{
IPTagType: to.StringPtr("internal"),
Tag: to.StringPtr("foo"),
},
},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := IPTagsToSDK(tt.ipTags); !reflect.DeepEqual(got, tt.want) {
t.Errorf("IPTagsToSDK() = %v, want %v", got, tt.want)
}
})
}
}
Loading

0 comments on commit 0a2ea7d

Please sign in to comment.