权限和角色

将用户添加到项目或群组时,您可以为他们分配角色。 该角色决定他们在极狐GitLab 中可以执行的操作。

如果您将用户添加到项目的群组和项目本身中,取用户的最高角色。

极狐GitLab 管理员 拥有所有权限。

角色

可用的角色包括:

  • 访客(此角色仅适用于私有和内部项目
  • 报告者
  • 开发者
  • 维护者
  • 所有者
  • 最小权限(仅适用于顶级群组)

分配了访客角色的用户拥有最少的权限,而所有者拥有最多的权限。

默认情况下,所有用户都可以创建顶级群组并更改其用户名。极狐GitLab 管理员可以为极狐GitLab 实例更改此设置

项目成员权限

  • 引入于 14.8 版本,个人命名空间所有者在其命名空间中的新项目中显示为所有者角色。功能标志personal_project_owner_with_owner_access。默认禁用。
  • 一般可用于 14.9 版本。移除功能标志 personal_project_owner_with_owner_access

用户的角色决定了他们对项目拥有的权限。所有者角色拥有所有权限,但仅适用于:

  • 群组和项目所有者。在 14.8 及更早版本中,该角色是在群组的项目中是继承的。
  • 管理员。

对于个人命名空间所有者:

  • 在命名空间中的项目上显示为具有维护者角色,但具有与所有者角色相同的权限。
  • 在 14.9 及更高版本,对于命名空间中的新项目,显示为具有所有者角色。

有关如何管理项目成员的更多信息,请参阅项目成员

下表列出了每个角色可用的项目权限:

操作 访客 报告者 开发者 维护者 所有者
分析
查看议题分析
分析
查看价值流分析
分析
查看 DORA 指标
 
分析
查看 CI/CD 分析
 
分析
查看代码评审分析
 
分析
查看合并请求分析
 
分析
查看仓库分析
 
应用安全
查看依赖项列表中的许可证
   
应用安全
创建并运行按需 DAST 扫描
   
应用安全
管理安全策略
   
应用安全
查看依赖项列表
   
应用安全:
创建 CVE ID 请求
     
应用安全
创建或指派安全策略项目
       
应用安全:
创建、编辑、删除单个安全策略
   
Kubernetes 的极狐GitLab 代理:
查看代理
   
Kubernetes 的极狐GitLab 代理:
管理代理
     
容器镜像库
创建、编辑、删除清理策略
     
容器镜像库
将镜像推送到容器镜像库
   
容器镜像库
从容器镜像库拉取镜像
✓ (19) ✓ (19)
容器镜像库
删除容器镜像库镜像
   
极狐GitLab Pages
查看受访问控制保护的 Pages
极狐GitLab Pages
管理
     
极狐GitLab Pages
管理极狐GitLab Pages 域名和证书
     
极狐GitLab Pages
删除极狐GitLab Pages
     
事件管理
指派警报
事件管理
参加 on-call 轮换
事件管理
查看事件
事件管理:
更改警报状态
 
事件管理:
更改事件严重级别
 
事件管理
创建事件
 
事件管理:
查看警报
 
事件管理
查看 on-call 计划
 
事件管理
查看升级策略
 
事件管理:
更改事件升级状态
   
事件管理:
更改事件升级策略
   
事件管理
管理 on-call 计划
     
事件管理
管理升级策略
     
议题看板:
创建或删除列表
 
议题看板:
在列表之间移动议题
 
议题
添加标记
✓ (15)
Issues:
添加到史诗
  ✓ (22) ✓ (22) ✓ (22) ✓ (22)
议题
指派
✓ (15)
议题
创建 (17)
议题
创建私密议题
议题
查看设计管理页面
议题
查看关联议题
议题
设置权重
 
议题
创建议题时设置标记、里程碑或指派人等元数据
✓ (15)
议题
编辑元数据,例如现有议题的标记、里程碑或指派人
(15)
议题:
设置父史诗
 
议题
查看私密议题
(2)
议题
关闭/重开 (18)
 
议题
锁定主题
 
议题
管理关联议题
 
议题
管理跟踪器
 
议题
移动议题 (14)
 
议题
设置议题的时间跟踪估计和时间花费
 
议题
存档设计管理文件
   
议题
上传设计管理文件
   
议题
删除
       
许可证合规
查看允许的和拒绝的许可证
✓ (1)
许可证合规
查看许可证合规报告
✓ (1)
许可证合规
查看许可证列表
 
许可证合规
管理许可证策略
     
合并请求
指派审核人
 
合并请求
查看列表
 
合并请求
应用代码变更建议
   
合并请求
批准 (8)
   
合并请求
指派
   
合并请求
创建 (16)
   
合并请求
添加标记
   
合并请求
锁定主题
   
合并请求
管理或接受
   
合并请求
解决主题
   
合并请求
管理合并批准规则(项目设置)
     
合并请求
删除
       
软件包库
拉取软件包
✓ (1)
软件包库
发布软件包
   
软件包库
删除软件包
     
软件包库
删除与软件包关联的文件
     
项目维护
查看错误跟踪列表
 
项目维护
管理功能标志
   
项目维护
管理错误跟踪
     
项目
下载项目
✓ (1)
项目
留下评论
项目
重新定位镜像上的评论(由任何用户发布)
✓ (9) ✓ (9) ✓ (9)
项目
查看洞察
项目
查看发布
✓ (5)
项目
查看需求
项目
查看时间跟踪报告
✓ (1)
项目
查看 wiki 页面
项目
创建代码片段
 
项目
管理标记
 
项目
查看项目流量统计
 
项目
创建、编辑、删除里程碑
 
项目
创建、编辑、删除发布
    ✓ (12) ✓ (12) ✓ (12)
项目
创建、编辑 wiki 页面
   
项目
启用 Review App
   
项目
查看项目审计事件
    ✓ (10)
项目
添加部署密钥
     
项目
添加新的团队成员
     
项目
管理团队成员
      ✓ (20)
项目
变更项目功能可见性级别
      ✓ (13)
项目
配置 Webhook
     
项目
删除 wiki 页面
   
项目
编辑评论(由任何用户发布)
     
项目
编辑项目徽章
     
项目
编辑项目设置
     
项目
导出项目
     
项目
管理项目访问令牌 (11)
      ✓ (20)
项目
管理项目运行
     
项目
重命名项目
     
项目
与群组共享(邀请)项目
      ✓ (7) ✓ (7)
项目
查看成员的 2FA 状态
     
项目
将项目分配给合规框架
       
项目
归档项目
       
项目
变更项目可见性级别
       
项目
删除项目
       
项目
禁用通知电子邮件
       
项目
将项目转移到另一个命名空间
       
项目
查看使用量配额页面
     
仓库
拉取项目代码
✓ (1)
仓库
查看项目代码
✓ (1)(23)
仓库
查看提交状态
 
仓库
添加标签
   
仓库
创建新的分支
   
仓库
创建或更新提交状态
    ✓ (4)
仓库
强制推送到不受保护的分支
   
仓库
推送到不受保护的分支
   
仓库
删除不受保护的分支
   
仓库
重写或删除 Git 标签
   
仓库
启用或禁用分支保护
     
仓库
启用或禁用标签保护
     
仓库
管理推送规则
     
仓库
推送到受保护的分支 (4)
     
仓库
为开发者打开或关闭受保护的分支推送
     
仓库
删除派生关系
       
仓库
强制推送到受保护的分支 (3)
         
仓库
删除受保护的分支 (3)
         
需求管理
归档/重开
 
需求管理
创建/编辑
 
需求管理
导入/导出
 
安全看板
从漏洞发现中创建议题
   
安全看板
从漏洞发现创建漏洞
   
安全看板
忽略漏洞
   
安全看板
忽略漏洞发现
   
安全看板
解决漏洞
   
安全看板
将漏洞恢复到已检测状态
   
安全看板
使用安全看板
   
安全看板
查看漏洞看板
   
安全看板
查看依赖列表中的漏洞发现
   
任务:
创建 (17)
 
任务:
编辑
 
任务:
从议题中移除
 
任务:
删除 (21)
       
Terraform
读取 Terraform state
   
Terraform
管理 Terraform state
     
测试用例
归档
 
测试用例
创建
 
测试用例
移动
 
测试用例
重开
 
  1. 在私有化部署实例上,访客用户只能对公开和内部项目(不能对私有项目)执行此操作。外部用户必须被明确授予访问权限(至少报告者角色),即使项目是内部的。在 JihuLab.com 上具有访客角色的用户只能对公共项目执行此操作,因为内部可见性不可用。
  2. 访客用户只能查看他们自己创建或被指派的私密议题
  3. 不允许访客、报告者、开发者、维护者或所有者使用。请参阅受保护的分支
  4. 如果分支是受保护的,取决于给予开发者和维护者的访问权限。
  5. 访客用户可以访问极狐GitLab 发布来下载 assets,但不能下载源代码,也不能查看提交和发布 evidence 等仓库信息
  6. 操作仅限于用户拥有(引用)的记录。
  7. 共享群组锁定启用时,项目不能与其他组共享。它不影响具有群组共享的群组。
  8. 有关合并请求的合格审批者的信息,请参阅合格审批者
  9. 仅适用于对设计管理设计的评论。
  10. 用户只能根据他们的个人操作查看事件。
  11. 基础版及更高版本的私有化部署实例支持项目访问令牌。极狐GitLab SaaS 专业版及更高版本也支持它们(不包括试用许可证)。
  12. 如果标签是受保护的,取决于开发人员和维护人员的访问权限。
  13. 如果项目可见性设置为私有,维护者或所有者无法更改项目功能可见性级别。
  14. 即使用户没有开发者角色,附加的设计文件也会与议题一起移动。
  15. 访客用户只能在创建议题时设置元数据(例如,标签、指派人或里程碑)。他们无法更改现有议题的元数据。
  16. 在接受外部成员贡献的项目中,用户可以创建、编辑和关闭自己的合并请求。
  17. 作者和指派人即使没有报告者角色也可以修改标题和描述。
  18. 作者和指派人即使没有报告者角色也可以关闭和重新打开议题。
  19. 查看容器镜像库和拉取镜像的能力由容器镜像库的可见性权限控制。
  20. 维护者不能创建、降级或删除所有者,也不能将用户提升为所有者角色。他们也无法批准所有者角色访问请求。
  21. 任务的作者即使没有所有者角色也可以删除,但他们必须至少具有项目的访客角色。
  22. 您必须有权查看史诗
  23. 在 15.9 及更高版本中,如果管理员(私有化部署实例上)或群组所有者(JihuLab.com 上)授予这些用户权限,则具有访客角色和旗舰版许可证的用户可以查看私有仓库内容。管理员或群组所有者可以通过 API 创建自定义角色并将该角色分配给用户。

项目功能权限

有关某些项目级功能的权限的更多详细信息如下。

极狐GitLab CI/CD 权限

极狐GitLab CI/CD 某些角色的权限可以通过以下设置进行修改:

  • 公开流水线:设置为公开时,向访客项目成员提供对某些 CI/CD 功能的访问权限。
  • 流水线可见性:当设置为具有访问权限的任何人时,授予非项目成员某些 CI/CD “查看”功能的访问权限。
操作 非成员 访客 报告者 开发者 维护者 所有者
看到产物的存在 ✓ (3) ✓ (3)
查看作业列表 ✓ (1) ✓ (2)
查看并下载产物 ✓ (1) ✓ (2)
查看环境 ✓ (3) ✓ (3)
查看作业日志和作业详细信息页面 ✓ (1) ✓ (2)
查看流水线和流水线详细信息页面 ✓ (1) ✓ (2)
查看合并请求的流水线选项卡 ✓ (3) ✓ (3)
查看流水线中的漏洞   ✓ (2)
查看并下载项目级安全文件      
取消和重试作业      
创建新的环境      
删除作业日志或作业产物       ✓ (4)
运行 CI/CD 流水线      
为受保护的分支运行 CI/CD 流水线       ✓ (5) ✓ (5)
停止环境      
运行受保护环境的部署作业     ✓ (5) ✓ (6) ✓ (6)
使用 debug 日志记录查看作业      
使用流水线编辑器      
运行交互式网络终端      
将项目 runner 添加到项目中        
手动清除 runner 缓存        
在项目中启用共享 runners        
管理 CI/CD 设置        
管理作业触发器        
管理项目级 CI/CD 变量        
管理项目级安全文件        
使用环境终端        
删除流水线          
  1. 如果项目是公开的并且在 项目设置 > CI/CD 中启用了 公开流水线
  2. 如果 公开流水线项目设置 > CI/CD 中已启用。
  3. 如果项目是公开的。
  4. 仅当作业满足以下两者:
    • 由用户触发。
    • 在 13.10 及更高版本,为不受保护的分支运行。
  5. 如果用户允许合并或推送到受保护的分支

作业权限

此表显示由特定类型的用户触发的作业的授予权限:

操作 访客、报告者 开发者 维护者 管理员
运行 CI 作业  
从当前项目克隆源和 LFS  
从公开项目中克隆源和 LFS  
从内部项目中克隆源和 LFS   ✓ (1) ✓ (1)
从私有项目中克隆源和 LFS   ✓ (2) ✓ (2) ✓ (2)
从当前项目中拉取容器镜像  
从公开项目中拉取容器镜像  
从内部项目中拉取容器镜像   ✓ (1) ✓ (1)
从私有项目中拉取容器镜像   ✓ (2) ✓ (2) ✓ (2)
将容器镜像推送到当前项目  
将容器镜像推送到其他项目        
推送源和 LFS        
  1. 仅当触发用户不是外部用户时。
  2. 仅当触发用户是项目成员时。您还可以查看带有 if-not-present 拉取策略的私有 Docker 镜像的使用情况。

群组成员权限

任何用户都可以将自己从群组中移除,除非他们是群组的最后一个所有者。

下表列出了每个角色可用的群组权限:

操作 访客 报告者 开发者 维护者 所有者
添加/移除子史诗 ✓ (8)
添加议题到史诗 ✓ (7) ✓ (7) ✓ (7) ✓ (7) ✓ (7)
浏览群组
使用依赖代理拉取容器镜像
查看贡献分析
查看群组史诗
查看群组 wiki 页面 ✓ (5)
查看洞察
查看洞察图表
查看议题分析
查看价值流分析
创建/编辑群组史诗  
创建/编辑/删除史诗看板  
管理群组标记  
发布软件包    
拉取软件包  
删除软件包      
创建/编辑/删除 Maven 和通用包重复设置      
启用/禁用软件包请求转发      
拉取容器镜像库镜像 ✓ (6)
删除容器镜像库镜像    
查看群组 DevOps 采用  
查看指标看板注释  
查看效率分析  
创建和编辑群组 wiki 页面    
在群组中创建项目     ✓ (2)(4) ✓ (2) ✓ (2)
创建/编辑/删除群组里程碑  
创建/编辑/删除迭代  
创建/编辑/删除指标看板注释    
启用/禁用依赖代理      
清除群组的依赖代理        
创建/编辑/删除依赖代理清理策略      
使用安全看板    
查看群组审计事件     ✓ (6) ✓ (6)
创建子组       ✓ (1)
删除群组 wiki 页面    
编辑史诗评论(由任何用户发布)      
列出群组部署令牌      
管理群组推送规则      
查看/管理群组级 Kubernetes 集群      
创建和管理合规框架        
创建/删除群组部署令牌        
更改群组可见性级别        
删除群组        
删除群组史诗        
禁用通知电子邮件        
编辑群组设置        
编辑 SAML SSO         ✓ (3)
按 2FA 状态过滤成员        
管理群组级 CI/CD 变量        
管理群组成员        
与群组共享(邀请)群组        
查看成员的 2FA 状态        
查看报价         ✓ (3)
查看群组使用量配额页面         ✓ (3)
查看群组 runner      
管理群组 runner        
迁移群组        
管理订阅以及购买 CI/CD 分钟数和存储        
  1. 可以将群组设置为,允许所有者或具有维护者角色的所有者和用户创建子组
  2. 可以在以下位置更改默认项目创建角色:
  3. 不适用于子组。
  4. 仅当默认分支保护设置为“部分保护”或“不受保护”时,开发人员才能将提交推送到新项目的默认分支。
  5. 此外,如果您的群组是公开的或内部的,则所有可以查看该群组的用户也可以查看群组 Wiki 页面。
  6. 用户只能根据他们的个人操作查看事件。
  7. 您必须有权查看史诗并编辑议题。
  8. 您必须有权查看父史诗和子史诗。

子组权限

当您将成员添加到子组时,他们会从父组继承成员资格和权限级别。如果您在其父组中拥有成员资格,则此模型允许访问嵌套组。

要了解更多信息,请阅读有关子组成员资格的文档。

最小访问权限用户

  • 引入于 13.4 版本。
  • 支持邀请具有最小访问权限的用户于 15.9 版本。

具有最小访问权限角色的用户不能:

  • 被计为私有化部署实例的旗舰版订阅或任何 SaaS 订阅的许可席位。
  • 自动访问该根群组中的项目和子组。

所有者必须明确地将这些用户添加到特定的子组和项目中。

您可以使用最小访问权限角色为同一个成员赋予群组中的多个角色:

  1. 将成员添加到根群组,赋予最小访问权限角色。
  2. 邀请该成员作为在该群组的任何子组或项目中具有特定角色的直接成员。

由于已知问题,当具有最小访问权限角色的用户:

  • 使用标准 Web 身份验证登录,他们在访问父组时收到 404 错误。
  • 使用群组 SSO 登录,他们立即收到 404 错误,他们被重定向到父组页面。

要解决此问题,请为这些用户授予父组内任何项目或子组的访客角色或更高级别。

相关主题

自定义角色

  • 引入于极狐GitLab 15.7,功能标志customized_roles
  • 默认启用于极狐GitLab 15.9。
  • 移除功能标记于极狐GitLab 15.10。
  • 自定义角色查看漏洞报告的功能引入于极狐GitLab 16.1,功能标志custom_roles_vulnerability
  • 查看漏洞报告默认启用于极狐GitLab 16.1。
  • 功能标志 custom_roles_vulnerability 移除于极狐GitLab 16.2。
  • 使用 UI 创建和删除自定义角色引入于极狐GitLab 16.4。

自定义角色允许分配了所有者角色的群组成员创建特定于其组织需求的角色。

可以使用以下自定义角色:

  • Guest+1 角色,允许具有访客角色的用户查看代码。
  • 在 16.1及更高版本中,您可以创建自定义角色,该角色可以查看漏洞报告并更改漏洞的状态。
  • 在 16.3 及更高版本中,您可以创建可以查看依赖项列表的自定义角色。
  • 在 16.4 及更高版本中,您可以创建可以批准合并请求的自定义角色。

当您为具有访客角色的用户启用自定义角色时,该用户可以访问升级的权限,因此:

  • 在私有化部署的极狐GitLab 上被视为计费用户
  • 在 JihuLab.com 上使用席位。

不适用于 Guest+1,这是一个仅启用 read_code 权限的访客自定义角色。具有该特定自定义角色的用户不被视为计费用户,并且不使用席位。

创建自定义角色

先决条件:

  • 您必须是私有化部署实例的管理员,或者在您要在其中创建自定义角色的群组中具有所有者角色。
  • 该群组必须是旗舰版级别。
  • 您必须拥有:
    • 至少一个私有项目,这样您可以看到为具有访客角色的用户提供自定义角色的效果。该项目可以在群组本身或该群组的子组中。
    • 具有 API 范围的个人访问令牌

极狐GitLab SaaS

先决条件:

  • 您必须在要在其中创建自定义角色的群组中具有所有者角色。
  1. 在左侧边栏中,选择 搜索或转到 并找到您的群组。
  2. 选择 设置 > 角色和权限
  3. 选择 添加新角色
  4. 用作模板的基本角色 中,选择 访客
  5. 角色名称 中,输入自定义角色的标题。
  6. 选择新自定义角色的 权限
  7. 选择 创建新角色

私有化部署的极狐GitLab 实例

先决条件:

  • 您必须是要在其中创建自定义角色的私有化部署实例的管理员。
  1. 在左侧边栏中,选择 搜索或转到
  2. 选择 管理中心
  3. 选择 设置 > 角色和权限
  4. 从顶部下拉列表中,选择您要在其中创建自定义角色的群组。
  5. 选择 添加新角色
  6. 用作模板的基本角色 中,选择 访客
  7. 角色名称 中,输入自定义角色的标题。
  8. 选择新自定义角色的 权限
  9. 选择 创建新角色

要创建自定义角色,您还可以使用 API

自定义角色要求

对于每项能力,都定义了最低访问级别。为了能够创建启用某种能力的自定义角色,member_roles 表格记录必须具有关联的最低访问级别。对于所有能力,最低访问级别是访客。只有至少具有访客角色的用户才能被分配自定义角色。

某些角色和能力需要启用其他能力。例如,如果还启用了读取漏洞 (read_vulnerability),则自定义角色只能启用漏洞管理 (admin_vulnerability)。

您可以在下表中查看所需的最低访问级别和能力要求。

能力 最低访问级别 所需能力
read_code 访客 -
read_dependency 访客 -
read_vulnerability 访客 -
admin_merge_request 访客 -
admin_vulnerability 访客 read_vulnerability

将自定义角色与现有群组成员相关联

要将自定义角色与现有群组成员关联,具有所有者角色的群组成员应执行以下操作:

  1. 邀请用户作为直接成员加入根群组或子组或者以访客身份加入根群组层次结构中的项目。此时,该访客用户无法看到群组或子组中项目的任何代码。
  2. 可选。如果所有者不知道接收自定义角色的访客用户的 id,则通过发出 API 请求查找 id

  3. 使用群组和项目成员 API 端点,将群组成员与 Guest+1 角色相关联。

    # to update a project membership
    curl --request PUT --header "Content-Type: application/json" --header "Authorization: Bearer <your_access_token>" --data '{"member_role_id": '<member_role_id>', "access_level": 10}' "https://gitlab.example.com/api/v4/projects/<project_id>/members/<user_id>"
    
    # to update a group membership
    curl --request PUT --header "Content-Type: application/json" --header "Authorization: Bearer <your_access_token>" --data '{"member_role_id": '<member_role_id>', "access_level": 10}' "https://gitlab.example.com/api/v4/groups/<group_id>/members/<user_id>"
    

    其中:

    • <project_id<group_id>:与接收自定义角色的成员资格相关联的 id项目或群组的 URL 编码的路径
    • <member_role_id>:上一节中创建的成员角色的 id
    • <user_id>:接收自定义角色的用户的 id

现在,Guest+1 用户可以查看与此成员资格关联的所有项目的代码。

移除自定义角色

先决条件:

  • 您必须是管理员或在要从中移除自定义角色的群组中具有所有者角色。

仅当没有群组成员拥有该角色时,您才可以从群组中移除该角色。

为此,您可以从具有该自定义角色的所有群组成员中移除该自定义角色,或者从群组中移除这些成员。

从群组成员中移除自定义角色

要从群组成员中移除自定义角色,请使用群组和项目成员 API 端点,并传递一个空的 member_role_id 值。

# to update a project membership
curl --request PUT --header "Content-Type: application/json" --header "Authorization: Bearer <your_access_token>" --data '{"member_role_id": "", "access_level": 10}' "https://gitlab.example.com/api/v4/projects/<project_id>/members/<user_id>"

# to update a group membership
curl --request PUT --header "Content-Type: application/json" --header "Authorization: Bearer <your_access_token>" --data '{"member_role_id": "", "access_level": 10}' "https://gitlab.example.com/api/v4/groups/<group_id>/members/<user_id>"

从群组中移除具有自定义角色的群组成员

  1. 在左侧边栏中,选择 搜索或转到 并找到您的群组。
  2. 选择 管理 > 成员
  3. 在要删除的成员行上,选择垂直省略号() 并选择 删除成员
  4. 删除成员 确认对话框中,不要选中任何复选框。
  5. 选择 删除成员

删除自定义角色

在您确保没有群组成员使用该自定义角色后,删除自定义角色。

  1. 在左侧边栏中,选择 搜索或转到
  2. 仅限 JihuLab.com。选择 管理中心
  3. 选择 设置 > 角色和权限
  4. 选择 自定义角色
  5. 操作 列中,选择 删除角色 () 并确认。

要删除自定义角色,您还可以使用 API。 要使用 API,您必须知道自定义角色的 id。如果您不知道这个 id 的值,您可以发出 API 请求查找。

已知问题

  • 如果具有自定义角色的用户与群组或项目共享,则他们的自定义角色不会随他们一起转移。用户在新的群组或项目中具有常规的访客角色。
  • 您不能使用审核员用户作为自定义角色的模板。