Path: blob/main/install/installer/pkg/components/public-api-server/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 public_api_server56import (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{18&networkingv1.NetworkPolicy{19TypeMeta: common.TypeMetaNetworkPolicy,20ObjectMeta: metav1.ObjectMeta{21Name: Component,22Namespace: ctx.Namespace,23Labels: labels,24},25Spec: networkingv1.NetworkPolicySpec{26PodSelector: metav1.LabelSelector{MatchLabels: labels},27PolicyTypes: []networkingv1.PolicyType{"Ingress"},28Ingress: []networkingv1.NetworkPolicyIngressRule{29{30Ports: []networkingv1.NetworkPolicyPort{31{32Protocol: common.TCPProtocol,33Port: &intstr.IntOrString{IntVal: GRPCContainerPort},34},35{36Protocol: common.TCPProtocol,37Port: &intstr.IntOrString{IntVal: HTTPContainerPort},38},39},40From: []networkingv1.NetworkPolicyPeer{41{42PodSelector: &metav1.LabelSelector{43MatchLabels: map[string]string{44"component": common.ProxyComponent,45},46},47},48},49},50},51},52},53}, nil54}555657