Path: blob/main/install/installer/pkg/components/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 proxy56import (7"fmt"89"github.com/gitpod-io/gitpod/common-go/baseserver"10"github.com/gitpod-io/gitpod/installer/pkg/common"1112networkingv1 "k8s.io/api/networking/v1"13metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"14"k8s.io/apimachinery/pkg/runtime"15"k8s.io/apimachinery/pkg/util/intstr"16)1718func networkpolicy(ctx *common.RenderContext) ([]runtime.Object, error) {19labels := common.DefaultLabels(Component)2021return []runtime.Object{&networkingv1.NetworkPolicy{22TypeMeta: common.TypeMetaNetworkPolicy,23ObjectMeta: metav1.ObjectMeta{24Name: fmt.Sprintf("%s-deny-all-allow-explicit", Component),25Namespace: ctx.Namespace,26Labels: labels,27},28Spec: networkingv1.NetworkPolicySpec{29PodSelector: metav1.LabelSelector{MatchLabels: labels},30PolicyTypes: []networkingv1.PolicyType{"Ingress"},31Ingress: []networkingv1.NetworkPolicyIngressRule{{32Ports: []networkingv1.NetworkPolicyPort{{33Protocol: common.TCPProtocol,34Port: &intstr.IntOrString{IntVal: ContainerHTTPPort},35}, {36Protocol: common.TCPProtocol,37Port: &intstr.IntOrString{IntVal: ContainerHTTPSPort},38}, {39Protocol: common.TCPProtocol,40Port: &intstr.IntOrString{IntVal: ContainerSSHPort},41}},42}, {43Ports: []networkingv1.NetworkPolicyPort{{44Protocol: common.TCPProtocol,45Port: &intstr.IntOrString{IntVal: baseserver.BuiltinMetricsPort},46}},47From: []networkingv1.NetworkPolicyPeer{{48NamespaceSelector: &metav1.LabelSelector{MatchLabels: map[string]string{49"chart": common.MonitoringChart,50}},51PodSelector: &metav1.LabelSelector{MatchLabels: map[string]string{52"component": common.ServerComponent,53}},54}},55}, {56Ports: []networkingv1.NetworkPolicyPort{{57Protocol: common.TCPProtocol,58Port: &intstr.IntOrString{IntVal: ContainerAnalyticsPort},59}},60From: []networkingv1.NetworkPolicyPeer{{61PodSelector: &metav1.LabelSelector{MatchLabels: map[string]string{62"component": common.ServerComponent,63}},64}, {65PodSelector: &metav1.LabelSelector{MatchLabels: map[string]string{66"component": common.WSManagerBridgeComponent,67}},68}, {69PodSelector: &metav1.LabelSelector{MatchLabels: map[string]string{70"component": common.WSProxyComponent,71}},72}},73}, {74Ports: []networkingv1.NetworkPolicyPort{{75Protocol: common.TCPProtocol,76Port: &intstr.IntOrString{IntVal: ContainerConfigcatPort},77}},78From: []networkingv1.NetworkPolicyPeer{{79PodSelector: &metav1.LabelSelector{MatchLabels: map[string]string{80"component": common.ServerComponent,81}},82}, {83PodSelector: &metav1.LabelSelector{MatchLabels: map[string]string{84"component": common.WSManagerBridgeComponent,85}},86}, {87PodSelector: &metav1.LabelSelector{MatchLabels: map[string]string{88"component": common.IDEServiceComponent,89}},90}, {91PodSelector: &metav1.LabelSelector{MatchLabels: map[string]string{92"component": common.PublicApiComponent,93}},94}, {95PodSelector: &metav1.LabelSelector{MatchLabels: map[string]string{96"component": common.UsageComponent,97}},98}, {99PodSelector: &metav1.LabelSelector{MatchLabels: map[string]string{100"component": common.OpenVSXProxyComponent,101}},102}, {103PodSelector: &metav1.LabelSelector{MatchLabels: map[string]string{104"component": common.DashboardComponent,105}},106}},107}},108},109}}, nil110}111112113