Path: blob/main/install/installer/pkg/components/openvsx-proxy/networkpolicy.go
2501 views
// Copyright (c) 2021 Gitpod GmbH. All rights reserved.1// Licensed under the GNU Affero General Public License (AGPL).2// See License.AGPL.txt in the project root for license information.34package openvsx_proxy56import (7"github.com/gitpod-io/gitpod/installer/pkg/common"8networkingv1 "k8s.io/api/networking/v1"9metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"10"k8s.io/apimachinery/pkg/runtime"11"k8s.io/apimachinery/pkg/util/intstr"12)1314func networkpolicy(ctx *common.RenderContext) ([]runtime.Object, error) {15labels := common.DefaultLabels(Component)1617return []runtime.Object{&networkingv1.NetworkPolicy{18TypeMeta: common.TypeMetaNetworkPolicy,19ObjectMeta: metav1.ObjectMeta{20Name: Component,21Namespace: ctx.Namespace,22Labels: labels,23},24Spec: networkingv1.NetworkPolicySpec{25PodSelector: metav1.LabelSelector{MatchLabels: labels},26PolicyTypes: []networkingv1.PolicyType{"Ingress"},27Ingress: []networkingv1.NetworkPolicyIngressRule{{28Ports: []networkingv1.NetworkPolicyPort{{29Protocol: common.TCPProtocol,30Port: &intstr.IntOrString{IntVal: ContainerPort},31}},32}, {33Ports: []networkingv1.NetworkPolicyPort{{34Protocol: common.TCPProtocol,35Port: &intstr.IntOrString{IntVal: ContainerPort},36}},37From: []networkingv1.NetworkPolicyPeer{{38NamespaceSelector: &metav1.LabelSelector{MatchLabels: map[string]string{39"chart": common.MonitoringChart,40}},41PodSelector: &metav1.LabelSelector{MatchLabels: map[string]string{42"component": common.ServerComponent,43}},44}},45}},46},47}}, nil48}495051