From 57afcf43ff05f407e5d19fb90186f0453a7144d5 Mon Sep 17 00:00:00 2001 From: Russell Centanni Date: Wed, 20 Nov 2024 10:52:13 -0500 Subject: [PATCH] fix: prevent vcluster crash when network policy syncing is enabled (cherry picked from commit 52df05938f83fa06c3f3d6eef571444388827cc0) --- pkg/controllers/resources/networkpolicies/syncer.go | 4 ++-- .../resources/networkpolicies/syncer_test.go | 7 ++++++- pkg/mappings/registry.go | 4 ++++ pkg/mappings/resources/networkpolicies.go | 12 ++++++++++++ pkg/mappings/resources/register.go | 1 + 5 files changed, 25 insertions(+), 3 deletions(-) create mode 100644 pkg/mappings/resources/networkpolicies.go diff --git a/pkg/controllers/resources/networkpolicies/syncer.go b/pkg/controllers/resources/networkpolicies/syncer.go index 32167efe3..75bf3eceb 100644 --- a/pkg/controllers/resources/networkpolicies/syncer.go +++ b/pkg/controllers/resources/networkpolicies/syncer.go @@ -3,7 +3,7 @@ package networkpolicies import ( "fmt" - "github.com/loft-sh/vcluster/pkg/mappings/generic" + "github.com/loft-sh/vcluster/pkg/mappings" "github.com/loft-sh/vcluster/pkg/patcher" "github.com/loft-sh/vcluster/pkg/pro" "github.com/loft-sh/vcluster/pkg/syncer" @@ -18,7 +18,7 @@ import ( ) func New(ctx *synccontext.RegisterContext) (syncertypes.Object, error) { - mapper, err := generic.NewMapper(ctx, &networkingv1.NetworkPolicy{}, translate.Default.HostName) + mapper, err := ctx.Mappings.ByGVK(mappings.NetworkingPolicies()) if err != nil { return nil, err } diff --git a/pkg/controllers/resources/networkpolicies/syncer_test.go b/pkg/controllers/resources/networkpolicies/syncer_test.go index 3942b633c..5c52314f4 100644 --- a/pkg/controllers/resources/networkpolicies/syncer_test.go +++ b/pkg/controllers/resources/networkpolicies/syncer_test.go @@ -3,8 +3,10 @@ package networkpolicies import ( "testing" + "github.com/loft-sh/vcluster/pkg/config" "github.com/loft-sh/vcluster/pkg/syncer/synccontext" syncertesting "github.com/loft-sh/vcluster/pkg/syncer/testing" + testingutil "github.com/loft-sh/vcluster/pkg/util/testing" "gotest.tools/assert" "k8s.io/utils/ptr" @@ -217,7 +219,10 @@ func TestSync(t *testing.T) { }, } - syncertesting.RunTests(t, []*syncertesting.SyncTest{ + syncertesting.RunTestsWithContext(t, func(vConfig *config.VirtualClusterConfig, pClient *testingutil.FakeIndexClient, vClient *testingutil.FakeIndexClient) *synccontext.RegisterContext { + vConfig.Sync.ToHost.NetworkPolicies.Enabled = true + return syncertesting.NewFakeRegisterContext(vConfig, pClient, vClient) + }, []*syncertesting.SyncTest{ { Name: "Create forward", InitialVirtualState: []runtime.Object{vBaseNetworkPolicy.DeepCopy()}, diff --git a/pkg/mappings/registry.go b/pkg/mappings/registry.go index 741819916..8181e07c6 100644 --- a/pkg/mappings/registry.go +++ b/pkg/mappings/registry.go @@ -129,6 +129,10 @@ func Namespaces() schema.GroupVersionKind { return corev1.SchemeGroupVersion.WithKind("Namespace") } +func NetworkingPolicies() schema.GroupVersionKind { + return networkingv1.SchemeGroupVersion.WithKind("NetworkPolicy") +} + func Ingresses() schema.GroupVersionKind { return networkingv1.SchemeGroupVersion.WithKind("Ingress") } diff --git a/pkg/mappings/resources/networkpolicies.go b/pkg/mappings/resources/networkpolicies.go new file mode 100644 index 000000000..3d9a4c5cb --- /dev/null +++ b/pkg/mappings/resources/networkpolicies.go @@ -0,0 +1,12 @@ +package resources + +import ( + "github.com/loft-sh/vcluster/pkg/mappings/generic" + "github.com/loft-sh/vcluster/pkg/syncer/synccontext" + "github.com/loft-sh/vcluster/pkg/util/translate" + networkingv1 "k8s.io/api/networking/v1" +) + +func CreateNetworkPoliciesMapper(ctx *synccontext.RegisterContext) (synccontext.Mapper, error) { + return generic.NewMapper(ctx, &networkingv1.NetworkPolicy{}, translate.Default.HostName) +} diff --git a/pkg/mappings/resources/register.go b/pkg/mappings/resources/register.go index 63e02c0f0..8ec16ef01 100644 --- a/pkg/mappings/resources/register.go +++ b/pkg/mappings/resources/register.go @@ -20,6 +20,7 @@ func getMappers(ctx *synccontext.RegisterContext) []BuildMapper { CreateEventsMapper, isEnabled(ctx.Config.Sync.ToHost.Ingresses.Enabled, CreateIngressesMapper), CreateNamespacesMapper, + isEnabled(ctx.Config.Sync.ToHost.NetworkPolicies.Enabled, CreateNetworkPoliciesMapper), CreateNodesMapper, CreatePersistentVolumeClaimsMapper, isEnabled(ctx.Config.Sync.ToHost.ServiceAccounts.Enabled, CreateServiceAccountsMapper),