// Copyright Project Harbor Authors // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package project import ( "github.com/goharbor/harbor/src/common" "github.com/goharbor/harbor/src/common/rbac" "github.com/goharbor/harbor/src/pkg/permission/types" ) var ( rolePoliciesMap = map[string][]*types.Policy{ "projectAdmin": { {Resource: rbac.ResourceSelf, Action: rbac.ActionRead}, {Resource: rbac.ResourceSelf, Action: rbac.ActionUpdate}, {Resource: rbac.ResourceSelf, Action: rbac.ActionDelete}, {Resource: rbac.ResourceMember, Action: rbac.ActionCreate}, {Resource: rbac.ResourceMember, Action: rbac.ActionRead}, {Resource: rbac.ResourceMember, Action: rbac.ActionUpdate}, {Resource: rbac.ResourceMember, Action: rbac.ActionDelete}, {Resource: rbac.ResourceMember, Action: rbac.ActionList}, {Resource: rbac.ResourceMetadata, Action: rbac.ActionCreate}, {Resource: rbac.ResourceMetadata, Action: rbac.ActionRead}, {Resource: rbac.ResourceMetadata, Action: rbac.ActionUpdate}, {Resource: rbac.ResourceMetadata, Action: rbac.ActionDelete}, {Resource: rbac.ResourceLog, Action: rbac.ActionList}, {Resource: rbac.ResourceLabel, Action: rbac.ActionCreate}, {Resource: rbac.ResourceLabel, Action: rbac.ActionRead}, {Resource: rbac.ResourceLabel, Action: rbac.ActionUpdate}, {Resource: rbac.ResourceLabel, Action: rbac.ActionDelete}, {Resource: rbac.ResourceLabel, Action: rbac.ActionList}, {Resource: rbac.ResourceQuota, Action: rbac.ActionRead}, {Resource: rbac.ResourceRepository, Action: rbac.ActionCreate}, {Resource: rbac.ResourceRepository, Action: rbac.ActionRead}, {Resource: rbac.ResourceRepository, Action: rbac.ActionUpdate}, {Resource: rbac.ResourceRepository, Action: rbac.ActionDelete}, {Resource: rbac.ResourceRepository, Action: rbac.ActionList}, {Resource: rbac.ResourceRepository, Action: rbac.ActionPull}, {Resource: rbac.ResourceRepository, Action: rbac.ActionPush}, {Resource: rbac.ResourceTagRetention, Action: rbac.ActionCreate}, {Resource: rbac.ResourceTagRetention, Action: rbac.ActionRead}, {Resource: rbac.ResourceTagRetention, Action: rbac.ActionUpdate}, {Resource: rbac.ResourceTagRetention, Action: rbac.ActionDelete}, {Resource: rbac.ResourceTagRetention, Action: rbac.ActionList}, {Resource: rbac.ResourceTagRetention, Action: rbac.ActionOperate}, {Resource: rbac.ResourceImmutableTag, Action: rbac.ActionCreate}, {Resource: rbac.ResourceImmutableTag, Action: rbac.ActionUpdate}, {Resource: rbac.ResourceImmutableTag, Action: rbac.ActionDelete}, {Resource: rbac.ResourceImmutableTag, Action: rbac.ActionList}, {Resource: rbac.ResourceConfiguration, Action: rbac.ActionRead}, {Resource: rbac.ResourceConfiguration, Action: rbac.ActionUpdate}, {Resource: rbac.ResourceRobot, Action: rbac.ActionCreate}, {Resource: rbac.ResourceRobot, Action: rbac.ActionRead}, {Resource: rbac.ResourceRobot, Action: rbac.ActionUpdate}, {Resource: rbac.ResourceRobot, Action: rbac.ActionDelete}, {Resource: rbac.ResourceRobot, Action: rbac.ActionList}, {Resource: rbac.ResourceNotificationPolicy, Action: rbac.ActionCreate}, {Resource: rbac.ResourceNotificationPolicy, Action: rbac.ActionUpdate}, {Resource: rbac.ResourceNotificationPolicy, Action: rbac.ActionDelete}, {Resource: rbac.ResourceNotificationPolicy, Action: rbac.ActionList}, {Resource: rbac.ResourceNotificationPolicy, Action: rbac.ActionRead}, {Resource: rbac.ResourceScan, Action: rbac.ActionCreate}, {Resource: rbac.ResourceScan, Action: rbac.ActionRead}, {Resource: rbac.ResourceScan, Action: rbac.ActionStop}, {Resource: rbac.ResourceSBOM, Action: rbac.ActionCreate}, {Resource: rbac.ResourceSBOM, Action: rbac.ActionStop}, {Resource: rbac.ResourceSBOM, Action: rbac.ActionRead}, {Resource: rbac.ResourceScanner, Action: rbac.ActionRead}, {Resource: rbac.ResourceScanner, Action: rbac.ActionCreate}, {Resource: rbac.ResourceArtifact, Action: rbac.ActionCreate}, {Resource: rbac.ResourceArtifact, Action: rbac.ActionRead}, {Resource: rbac.ResourceArtifact, Action: rbac.ActionDelete}, {Resource: rbac.ResourceArtifact, Action: rbac.ActionList}, {Resource: rbac.ResourceArtifactAddition, Action: rbac.ActionRead}, {Resource: rbac.ResourceTag, Action: rbac.ActionList}, {Resource: rbac.ResourceTag, Action: rbac.ActionCreate}, {Resource: rbac.ResourceTag, Action: rbac.ActionDelete}, {Resource: rbac.ResourceAccessory, Action: rbac.ActionList}, {Resource: rbac.ResourceArtifactLabel, Action: rbac.ActionCreate}, {Resource: rbac.ResourceArtifactLabel, Action: rbac.ActionDelete}, {Resource: rbac.ResourcePreatPolicy, Action: rbac.ActionCreate}, {Resource: rbac.ResourcePreatPolicy, Action: rbac.ActionRead}, {Resource: rbac.ResourcePreatPolicy, Action: rbac.ActionUpdate}, {Resource: rbac.ResourcePreatPolicy, Action: rbac.ActionDelete}, {Resource: rbac.ResourcePreatPolicy, Action: rbac.ActionList}, {Resource: rbac.ResourceExportCVE, Action: rbac.ActionCreate}, {Resource: rbac.ResourceExportCVE, Action: rbac.ActionRead}, {Resource: rbac.ResourceExportCVE, Action: rbac.ActionList}, }, "maintainer": { {Resource: rbac.ResourceSelf, Action: rbac.ActionRead}, {Resource: rbac.ResourceMember, Action: rbac.ActionRead}, {Resource: rbac.ResourceMember, Action: rbac.ActionList}, {Resource: rbac.ResourceMetadata, Action: rbac.ActionCreate}, {Resource: rbac.ResourceMetadata, Action: rbac.ActionRead}, {Resource: rbac.ResourceMetadata, Action: rbac.ActionUpdate}, {Resource: rbac.ResourceMetadata, Action: rbac.ActionDelete}, {Resource: rbac.ResourceLog, Action: rbac.ActionList}, {Resource: rbac.ResourceQuota, Action: rbac.ActionRead}, {Resource: rbac.ResourceLabel, Action: rbac.ActionCreate}, {Resource: rbac.ResourceLabel, Action: rbac.ActionRead}, {Resource: rbac.ResourceLabel, Action: rbac.ActionUpdate}, {Resource: rbac.ResourceLabel, Action: rbac.ActionDelete}, {Resource: rbac.ResourceLabel, Action: rbac.ActionList}, {Resource: rbac.ResourceRepository, Action: rbac.ActionCreate}, {Resource: rbac.ResourceRepository, Action: rbac.ActionRead}, {Resource: rbac.ResourceRepository, Action: rbac.ActionUpdate}, {Resource: rbac.ResourceRepository, Action: rbac.ActionDelete}, {Resource: rbac.ResourceRepository, Action: rbac.ActionList}, {Resource: rbac.ResourceRepository, Action: rbac.ActionPush}, {Resource: rbac.ResourceRepository, Action: rbac.ActionPull}, {Resource: rbac.ResourceTagRetention, Action: rbac.ActionCreate}, {Resource: rbac.ResourceTagRetention, Action: rbac.ActionRead}, {Resource: rbac.ResourceTagRetention, Action: rbac.ActionUpdate}, {Resource: rbac.ResourceTagRetention, Action: rbac.ActionDelete}, {Resource: rbac.ResourceTagRetention, Action: rbac.ActionList}, {Resource: rbac.ResourceTagRetention, Action: rbac.ActionOperate}, {Resource: rbac.ResourceAccessory, Action: rbac.ActionList}, {Resource: rbac.ResourceImmutableTag, Action: rbac.ActionCreate}, {Resource: rbac.ResourceImmutableTag, Action: rbac.ActionUpdate}, {Resource: rbac.ResourceImmutableTag, Action: rbac.ActionDelete}, {Resource: rbac.ResourceImmutableTag, Action: rbac.ActionList}, {Resource: rbac.ResourceConfiguration, Action: rbac.ActionRead}, {Resource: rbac.ResourceRobot, Action: rbac.ActionRead}, {Resource: rbac.ResourceRobot, Action: rbac.ActionList}, {Resource: rbac.ResourceNotificationPolicy, Action: rbac.ActionList}, {Resource: rbac.ResourceScan, Action: rbac.ActionCreate}, {Resource: rbac.ResourceScan, Action: rbac.ActionRead}, {Resource: rbac.ResourceScan, Action: rbac.ActionStop}, {Resource: rbac.ResourceSBOM, Action: rbac.ActionCreate}, {Resource: rbac.ResourceSBOM, Action: rbac.ActionStop}, {Resource: rbac.ResourceSBOM, Action: rbac.ActionRead}, {Resource: rbac.ResourceScanner, Action: rbac.ActionRead}, {Resource: rbac.ResourceArtifact, Action: rbac.ActionCreate}, {Resource: rbac.ResourceArtifact, Action: rbac.ActionRead}, {Resource: rbac.ResourceArtifact, Action: rbac.ActionDelete}, {Resource: rbac.ResourceArtifact, Action: rbac.ActionList}, {Resource: rbac.ResourceArtifactAddition, Action: rbac.ActionRead}, {Resource: rbac.ResourceTag, Action: rbac.ActionList}, {Resource: rbac.ResourceTag, Action: rbac.ActionCreate}, {Resource: rbac.ResourceTag, Action: rbac.ActionDelete}, {Resource: rbac.ResourceArtifactLabel, Action: rbac.ActionCreate}, {Resource: rbac.ResourceArtifactLabel, Action: rbac.ActionDelete}, {Resource: rbac.ResourceExportCVE, Action: rbac.ActionCreate}, {Resource: rbac.ResourceExportCVE, Action: rbac.ActionRead}, {Resource: rbac.ResourceExportCVE, Action: rbac.ActionList}, }, "developer": { {Resource: rbac.ResourceSelf, Action: rbac.ActionRead}, {Resource: rbac.ResourceMember, Action: rbac.ActionRead}, {Resource: rbac.ResourceMember, Action: rbac.ActionList}, {Resource: rbac.ResourceLog, Action: rbac.ActionList}, {Resource: rbac.ResourceLabel, Action: rbac.ActionRead}, {Resource: rbac.ResourceLabel, Action: rbac.ActionList}, {Resource: rbac.ResourceQuota, Action: rbac.ActionRead}, {Resource: rbac.ResourceRepository, Action: rbac.ActionCreate}, {Resource: rbac.ResourceRepository, Action: rbac.ActionRead}, {Resource: rbac.ResourceRepository, Action: rbac.ActionUpdate}, {Resource: rbac.ResourceRepository, Action: rbac.ActionList}, {Resource: rbac.ResourceRepository, Action: rbac.ActionPush}, {Resource: rbac.ResourceRepository, Action: rbac.ActionPull}, {Resource: rbac.ResourceTagRetention, Action: rbac.ActionCreate}, {Resource: rbac.ResourceTagRetention, Action: rbac.ActionRead}, {Resource: rbac.ResourceTagRetention, Action: rbac.ActionUpdate}, {Resource: rbac.ResourceTagRetention, Action: rbac.ActionDelete}, {Resource: rbac.ResourceTagRetention, Action: rbac.ActionList}, {Resource: rbac.ResourceTagRetention, Action: rbac.ActionOperate}, {Resource: rbac.ResourceConfiguration, Action: rbac.ActionRead}, {Resource: rbac.ResourceRobot, Action: rbac.ActionRead}, {Resource: rbac.ResourceRobot, Action: rbac.ActionList}, {Resource: rbac.ResourceScan, Action: rbac.ActionRead}, {Resource: rbac.ResourceSBOM, Action: rbac.ActionRead}, {Resource: rbac.ResourceScanner, Action: rbac.ActionRead}, {Resource: rbac.ResourceArtifact, Action: rbac.ActionCreate}, {Resource: rbac.ResourceArtifact, Action: rbac.ActionRead}, {Resource: rbac.ResourceArtifact, Action: rbac.ActionList}, {Resource: rbac.ResourceArtifactAddition, Action: rbac.ActionRead}, {Resource: rbac.ResourceTag, Action: rbac.ActionList}, {Resource: rbac.ResourceTag, Action: rbac.ActionCreate}, {Resource: rbac.ResourceAccessory, Action: rbac.ActionList}, {Resource: rbac.ResourceArtifactLabel, Action: rbac.ActionCreate}, {Resource: rbac.ResourceArtifactLabel, Action: rbac.ActionDelete}, {Resource: rbac.ResourceExportCVE, Action: rbac.ActionCreate}, {Resource: rbac.ResourceExportCVE, Action: rbac.ActionRead}, {Resource: rbac.ResourceExportCVE, Action: rbac.ActionList}, }, "guest": { {Resource: rbac.ResourceSelf, Action: rbac.ActionRead}, {Resource: rbac.ResourceMember, Action: rbac.ActionRead}, {Resource: rbac.ResourceMember, Action: rbac.ActionList}, {Resource: rbac.ResourceLog, Action: rbac.ActionList}, {Resource: rbac.ResourceLabel, Action: rbac.ActionRead}, {Resource: rbac.ResourceLabel, Action: rbac.ActionList}, {Resource: rbac.ResourceQuota, Action: rbac.ActionRead}, {Resource: rbac.ResourceRepository, Action: rbac.ActionRead}, {Resource: rbac.ResourceRepository, Action: rbac.ActionList}, {Resource: rbac.ResourceRepository, Action: rbac.ActionPull}, {Resource: rbac.ResourceConfiguration, Action: rbac.ActionRead}, {Resource: rbac.ResourceRobot, Action: rbac.ActionRead}, {Resource: rbac.ResourceRobot, Action: rbac.ActionList}, {Resource: rbac.ResourceScan, Action: rbac.ActionRead}, {Resource: rbac.ResourceSBOM, Action: rbac.ActionRead}, {Resource: rbac.ResourceScanner, Action: rbac.ActionRead}, {Resource: rbac.ResourceTag, Action: rbac.ActionList}, {Resource: rbac.ResourceAccessory, Action: rbac.ActionList}, {Resource: rbac.ResourceArtifact, Action: rbac.ActionRead}, {Resource: rbac.ResourceArtifact, Action: rbac.ActionList}, {Resource: rbac.ResourceArtifactAddition, Action: rbac.ActionRead}, }, "limitedGuest": { {Resource: rbac.ResourceSelf, Action: rbac.ActionRead}, {Resource: rbac.ResourceQuota, Action: rbac.ActionRead}, {Resource: rbac.ResourceRepository, Action: rbac.ActionList}, {Resource: rbac.ResourceRepository, Action: rbac.ActionRead}, {Resource: rbac.ResourceRepository, Action: rbac.ActionPull}, {Resource: rbac.ResourceConfiguration, Action: rbac.ActionRead}, {Resource: rbac.ResourceScan, Action: rbac.ActionRead}, {Resource: rbac.ResourceSBOM, Action: rbac.ActionRead}, {Resource: rbac.ResourceScanner, Action: rbac.ActionRead}, {Resource: rbac.ResourceTag, Action: rbac.ActionList}, {Resource: rbac.ResourceAccessory, Action: rbac.ActionList}, {Resource: rbac.ResourceArtifact, Action: rbac.ActionRead}, {Resource: rbac.ResourceArtifact, Action: rbac.ActionList}, {Resource: rbac.ResourceArtifactAddition, Action: rbac.ActionRead}, }, } ) // projectRBACRole implement the RBACRole interface type projectRBACRole struct { projectID int64 roleID int } // GetRoleName returns role name for the visitor role func (role *projectRBACRole) GetRoleName() string { switch role.roleID { case common.RoleProjectAdmin: return "projectAdmin" case common.RoleMaintainer: return "maintainer" case common.RoleDeveloper: return "developer" case common.RoleGuest: return "guest" case common.RoleLimitedGuest: return "limitedGuest" default: return "" } } // GetPolicies returns policies for the visitor role func (role *projectRBACRole) GetPolicies() []*types.Policy { policies := []*types.Policy{} roleName := role.GetRoleName() if roleName == "" { return policies } namespace := NewNamespace(role.projectID) for _, policy := range rolePoliciesMap[roleName] { policies = append(policies, &types.Policy{ Resource: namespace.Resource(policy.Resource), Action: policy.Action, Effect: policy.Effect, }) } return policies }