跳过内容

Access Control Reference

Capgo uses 使用 AI 设置提示 管理每个团队成员可以做什么。角色按 范围 — 从整个组织到单个捆绑包的整个组织。

有关在仪表板中管理成员的可视化教程,请参见 组织.


每个角色都属于一个范围,该范围确定它可以访问的资源。

范围适用范围示例用例
组织__CAPGO_KEEP_0____CAPGO_KEEP_0__
__CAPGO_KEEP_0____CAPGO_KEEP_0____CAPGO_KEEP_0__
__CAPGO_KEEP_0____CAPGO_KEEP_0____CAPGO_KEEP_0__ staging __CAPGO_KEEP_0__
__CAPGO_KEEP_0____CAPGO_KEEP_0____CAPGO_KEEP_0__

A member can hold __CAPGO_KEEP_0__ role per scope target 例如,一个组织角色,一个 App A 角色,和一个 App B 角色。 组织角色


角色

内部名称描述超级管理员
拥有者等同。包括删除组织、管理账单和转移应用的完全控制。自动授予组织创建者。org_super_admin__CAPGO_KEEP_1__
__CAPGO_KEEP_2__org_admin全局管理 — 管理成员、应用、频道。无法删除组织、更新账单、转移应用或将用户提升为超级管理员。
账单管理员org_billing_admin仅限账单访问:查看和更新账单信息、发票和账单审计日志。无应用或成员访问权限。
成员org_member对组织和所有应用的只读访问。

组织权限矩阵

权限
描述超级管理员管理员账单管理员组织权限配置成员
org.read查看组织
org.update_settings编辑组织名称、Logo、管理邮箱
org.delete永久删除组织
org.read_members查看成员列表
org.invite_user邀请新成员
org.update_user_roles修改成员角色(管理员无法提升为超级管理员 — 角色层级阻止)
org.read_billing查看账单信息和当前计划
org.update_billing更新支付方式和计划
org.read_invoices查看发票
org.read_audit查看组织活动日志
org.read_billing_audit查看账单相关审计日志

仅限于一个应用。使用这些角色时,团队成员只应在一个应用中工作,而不是整个组织。

角色内部名称描述
应用管理员app_admin对一个应用有完全控制权 — 通道、设备、应用用户角色。无法删除或转移应用(这些是组织级别的操作)。
应用开发者app_developer上传捆绑包、管理设备、触发本机构建、更新通道设置。无删除、无应用设置更改、无通道创建。
应用上传者app_uploader读取访问权 + 上传新捆绑包版本。
应用读者app_reader只读 — 统计、捆绑包、通道、日志、设备。

应用权限矩阵

应用权限矩阵
权限描述应用管理员应用开发者应用上传者应用读者
app.read查看应用详细信息、统计和元数据
app.update_settings编辑应用设置
app.read_bundles查看已上传的包列表
app.upload_bundle上传新包版本
app.create_channel创建新频道
app.read_channels查看频道
app.read_logs查看更新分发日志
app.manage_devices分配、覆盖或解除绑定设备
app.read_devices查看设备列表
app.build_native触发本地云构建
app.read_audit查看应用级活动日志
app.update_user_roles管理应用范围角色分配
bundle.delete删除一个捆绑包

注意

角色内部名称描述
频道管理员channel_admin对一个频道有完全控制权:设置、推广/回滚包、管理强制设备。
频道浏览器channel_reader只读 — 当前包、历史记录、强制设备、审计日志。

频道权限矩阵

频道权限矩阵
权限描述频道管理员频道浏览者
channel.read查看频道及其当前包
channel.update_settings编辑频道设置(平台开关,更新策略…)
channel.delete删除频道
channel.read_history查看包分配历史
channel.promote_bundle在频道上设置活动包
channel.rollback_bundle回滚到之前的包
channel.manage_forced_devices强制特定设备使用此频道
channel.read_forced_devices查看强制设备列表
channel.read_audit查看频道活动日志

仅限于一个版本的包。很少需要 — 大多数团队使用应用级别的角色代替。

内部名称描述包管理员
读取、更新元数据和删除特定包。bundle_admin__CAPGO_KEEP_0__
Bundle Viewerbundle_reader只读访问特定捆绑包。

渠道权限覆盖 (控制台)

渠道权限覆盖 (控制台) 部分

在控制台中,渠道访问由用户的应用角色确定。为了更细致的控制,您可以 覆盖特定渠道权限 按用户或组覆盖

覆盖配置在应用的 访问 选项卡中,通过点击渠道权限按钮(shield图标)来覆盖一个用户的渠道权限。请参阅 组织 — 覆盖渠道权限 了解更多信息。

__CAPGO_KEEP_0__

__CAPGO_KEEP_1__
__CAPGO_KEEP_2____CAPGO_KEEP_3____CAPGO_KEEP_4__
查看频道和当前包从应用角色继承__CAPGO_KEEP_5__
查看包分配历史从应用角色继承__CAPGO_KEEP_6__
__CAPGO_KEEP_7__在频道上设置或更改活动包从应用角色继承

每个权限可以设置为:

  • 默认 — 从应用角色继承(默认)
  • 允许 — 明确授予,忽略应用角色
  • 拒绝 — 明确阻止,忽略应用角色

这让您可以,例如,向 App Reader 提供将包关联到频道的能力,而不将其提升为 App Developer。 staging 角色层次结构


例如,

角色层级

角色形成层级结构。父角色 继承其子角色 的所有权限。这样一个 org_admin 可以做任何一个 app_admin 可以做的任何事情, channel_admin 而一个

Super Admin (org_super_admin)
└── Admin (org_admin)
└── App Admin (app_admin)
├── App Developer (app_developer)
│ └── App Uploader (app_uploader)
│ └── App Reader (app_reader)
├── Bundle Admin (bundle_admin)
│ └── Bundle Viewer (bundle_reader)
└── Channel Admin (channel_admin)
└── Channel Viewer (channel_reader)

可以做的任何事情,

  • 依此类推。 复制到剪贴板 在实际操作中: 应用管理员 可以在组织中的每个应用上进行操作。
  • 一个 应用管理员 在一个特定的应用上可以执行 频道管理员 可以在该应用中的每个频道上进行操作。
  • 一个 应用开发者 可以执行 应用上传者 可以执行的所有操作,plus 更多。

层级结构只向下流动 向下 — 从不获得组织级别的权限,即使他们也持有应用级别的角色。 channel_admin


标题为“组如何工作”的部分 一个组属于

一个组属于

一个组属于
  • 一个组属于 一个组织 —它不能跨越多个组织。
  • 组可以在 任何范围:组织、应用、频道或捆绑包。例如,一个组可以被赋予 应用开发者 角色在应用A上,并且 频道管理员 角色在应用B的频道上。 staging 当用户的权限被评估时,所有他们的组成员身份都会透明地被解析。如果他们的任何组授予所需的权限,访问将被允许。
  • 一个用户可以属于
  • 的多个组 多个组, 和所有组的权限是累积的。
  • 组权限仅适用于 用户主体 — API keys 不会继承组角色。
场景没有组有组
5 名 QA 工程师需要对 3 个应用程序拥有开发者访问权限15 个单独的角色绑定1 组 + 3 角色绑定
QA 团队有新成员加入手动添加 3 个角色绑定将他们添加到组中
QA 团队有成员离开手动删除 3 个角色绑定将他们从组中移除

通过 API 管理组

API 组管理

所有组端点都需要身份验证,并在 __CAPGO_KEEP_0__ 下提供 /private/groups.

终端窗口
curl -X GET "https://api.capgo.app/private/groups/<ORG_ID>" \
-H "authorization: <API_KEY>"

需要 org.read_members 权限。

终端窗口
curl -X POST "https://api.capgo.app/private/groups/<ORG_ID>" \
-H "authorization: <API_KEY>" \
-H "Content-Type: application/json" \
-d '{
"name": "QA Team",
"description": "Quality assurance engineers"
}'

需要 org.update_user_roles 权限(超级管理员管理).

终端窗口
curl -X PUT "https://api.capgo.app/private/groups/<GROUP_ID>" \
-H "authorization: <API_KEY>" \
-H "Content-Type: application/json" \
-d '{
"name": "QA Team",
"description": "Updated description"
}'
终端窗口
curl -X DELETE "https://api.capgo.app/private/groups/<GROUP_ID>" \
-H "authorization: <API_KEY>"

删除一个组也会移除所有其角色绑定。成员不会从组织中删除。

终端窗口
curl -X GET "https://api.capgo.app/private/groups/<GROUP_ID>/members" \
-H "authorization: <API_KEY>"

将成员添加到组

标题:添加成员到组
终端窗口
curl -X POST "https://api.capgo.app/private/groups/<GROUP_ID>/members" \
-H "authorization: <API_KEY>" \
-H "Content-Type: application/json" \
-d '{ "user_id": "<USER_UUID>" }'

用户必须已经是组织的成员。添加现有成员是无操作的。

从组中移除成员

标题:从组中移除成员
终端窗口
curl -X DELETE "https://api.capgo.app/private/groups/<GROUP_ID>/members/<USER_UUID>" \
-H "authorization: <API_KEY>"

通过 API 分配角色

标题:通过 API 分配角色
终端窗口
curl -X GET "https://api.capgo.app/organization/members" \
-H "authorization: <API_KEY>" \
-H "Content-Type: application/json" \
-d '{ "orgId": "<ORG_ID>" }'

响应:

[
{
"uid": "user-uuid",
"email": "alice@example.com",
"image_url": "https://...",
"role": "org_admin",
"is_tmp": false
}
]

邀请成员

邀请成员
终端窗口
curl -X POST "https://api.capgo.app/organization/members" \
-H "authorization: <API_KEY>" \
-H "Content-Type: application/json" \
-d '{
"orgId": "<ORG_ID>",
"email": "bob@example.com",
"invite_type": "org_admin"
}'

接受的值 invite_type:

分配的角色
org_super_admin超级管理员
org_admin管理员
org_billing_admin账单管理员
org_member成员
终端窗口
curl -X DELETE "https://api.capgo.app/organization/members" \
-H "authorization: <API_KEY>" \
-H "Content-Type: application/json" \
-d '{
"orgId": "<ORG_ID>",
"email": "bob@example.com"
}'

终端窗口
npx @capgo/cli organization list --apikey <API_KEY>
终端窗口
npx @capgo/cli organization members <ORG_ID> --apikey <API_KEY>

内置角色覆盖了大多数团队结构。自定义角色创建将在我们的路线图上 — 如果您的团队需要这个功能,请 联系我们您的用例将直接帮助我们优先考虑这个功能。

继续从访问控制参考

标题:继续从访问控制参考

如果您正在使用 访问控制参考 为了计划仪表板和API操作,连接它 API概述 为了在API概述中实现详细信息 介绍 为了在介绍中实现详细信息 API密钥 为了在API密钥中实现详细信息 设备 为了在设备中实现详细信息 捆绑包 为了在捆绑包中实现详细信息