Path: blob/main/install/installer/pkg/components/docker-registry/rolebinding.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 dockerregistry56import (7"fmt"8"github.com/gitpod-io/gitpod/installer/pkg/common"9rbacv1 "k8s.io/api/rbac/v1"10metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"11"k8s.io/apimachinery/pkg/runtime"12"k8s.io/utils/pointer"13)1415func rolebinding(ctx *common.RenderContext) ([]runtime.Object, error) {16if !pointer.BoolDeref(ctx.Config.ContainerRegistry.InCluster, false) {17return nil, nil18}1920return []runtime.Object{21&rbacv1.RoleBinding{22TypeMeta: common.TypeMetaRoleBinding,23ObjectMeta: metav1.ObjectMeta{24Name: Component,25Namespace: ctx.Namespace,26Labels: common.DefaultLabels(Component),27},28RoleRef: rbacv1.RoleRef{29Kind: "ClusterRole",30Name: fmt.Sprintf("%s-ns-psp:restricted-root-user", ctx.Namespace),31APIGroup: "rbac.authorization.k8s.io",32},33Subjects: []rbacv1.Subject{34{35Kind: "ServiceAccount",36Name: Component,37},38},39},40}, nil41}424344