// Copyright (c) 2021 Gitpod GmbH. All rights reserved. // Licensed under the GNU Affero General Public License (AGPL). // See License.AGPL.txt in the project root for license information. package server import ( "fmt" "github.com/gitpod-io/gitpod/installer/pkg/common" rbacv1 "k8s.io/api/rbac/v1" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/runtime" ) func Rolebinding(ctx *common.RenderContext, component string) ([]runtime.Object, error) { labels := common.DefaultLabels(component) return []runtime.Object{ &rbacv1.RoleBinding{ TypeMeta: common.TypeMetaRoleBinding, ObjectMeta: metav1.ObjectMeta{ Name: component, Namespace: ctx.Namespace, Labels: labels, }, RoleRef: rbacv1.RoleRef{ Kind: "Role", Name: component, APIGroup: "rbac.authorization.k8s.io", }, Subjects: []rbacv1.Subject{{ Kind: "ServiceAccount", Name: component, }}, }, &rbacv1.ClusterRoleBinding{ TypeMeta: common.TypeMetaClusterRoleBinding, ObjectMeta: metav1.ObjectMeta{ Name: fmt.Sprintf("%s-%s-rb-kube-rbac-proxy", ctx.Namespace, component), Labels: labels, }, RoleRef: rbacv1.RoleRef{ Kind: "ClusterRole", Name: fmt.Sprintf("%s-kube-rbac-proxy", ctx.Namespace), APIGroup: "rbac.authorization.k8s.io", }, Subjects: []rbacv1.Subject{{ Kind: "ServiceAccount", Name: component, Namespace: ctx.Namespace, }}, }, &rbacv1.RoleBinding{ TypeMeta: common.TypeMetaRoleBinding, ObjectMeta: metav1.ObjectMeta{ Name: fmt.Sprintf("%s-unprivileged", component), Namespace: ctx.Namespace, Labels: labels, }, RoleRef: rbacv1.RoleRef{ Kind: "ClusterRole", Name: fmt.Sprintf("%s-ns-psp:unprivileged", ctx.Namespace), APIGroup: "rbac.authorization.k8s.io", }, Subjects: []rbacv1.Subject{{ Kind: "ServiceAccount", Name: component, }}, }, }, nil }