Pular al contenido

Referencia de control de acceso

Capgo uses Ajustes de seguridad para administrar qué puede hacer cada miembro del equipo. Los roles se organizan por ámbito — desde la organización completa hasta un solo paquete.

Para una guía visual de la gestión de miembros en la consola, consulte Organización.


Cada rol pertenece a un ámbito que determina qué recurso concede acceso.

ÁmbitoAplica aUso de ejemplo
OrganizaciónLa organización completa y todas sus aplicacionesTu cofundador obtiene Super Administrador; tu contable obtiene Administrador de Facturación
AplicaciónUna sola aplicación y sus canalesUn contratista que trabaja en una aplicación obtiene Desarrollador de Aplicación
CanalUn canal individual dentro de una aplicaciónUn ingeniero de pruebas solo gestiona el staging canal
PaqueteUna versión de paquete individualUn revisor necesita acceso de lectura a una versión de lanzamiento específica

A un miembro se le puede asignar un rol por ámbito objetivo — por ejemplo, un rol de organización, un rol en App A, y un rol diferente en App B.


Estos roles se asignan cuando se invita a un miembro. Otorgan acceso a toda la organización.

RolNombre internoDescripción
Administrador principalorg_super_adminEquivalente a propietario. Control total incluyendo la eliminación de la org, la gestión de facturación y la transferencia de aplicaciones. Se asigna automáticamente al creador de la org.
__CAPGO_KEEP_0__org_adminAdministración completa — gestione miembros, aplicaciones, canales. No se puede eliminar la organización, actualizar facturación, transferir aplicaciones o promover usuarios a Super Administrador.
Administrador de facturaciónorg_billing_adminAcceso solo a facturación: ver y actualizar información de facturación, facturas e historial de auditoría de facturación. Sin acceso a aplicaciones o miembros.
Miembroorg_memberAcceso de solo lectura a la organización y a todas sus aplicaciones.
PermisoDescripciónSuper AdministradorAdministradorAdministrador de facturaciónMiembro
org.readVer la organización
org.update_settingsEditar nombre de la organización, logo y correo electrónico de administración
org.deleteEliminar la organización permanentemente
org.read_membersVer la lista de miembros
org.invite_userInvitar nuevos miembros
org.update_user_rolesCambiar roles de miembros (El administrador no puede promover a Super Administrador — bloqueado por jerarquía de roles)
org.read_billingVer información de facturación y plan actual
org.update_billingActualizar método de pago y plan
org.read_invoicesVer facturas
org.read_auditVer registro de actividad de la organización
org.read_billing_auditVer registro de auditoría específico de facturación

Limitado a una sola aplicación. Utilícelos cuando un miembro del equipo solo debe trabajar en una aplicación, no en toda la organización.

RolNombre internoDescripción
Administrador de Aplicaciónapp_adminControl total de una aplicación — canales, dispositivos, roles de usuario para la aplicación. No se puede eliminar o transferir la aplicación (esas son operaciones de nivel de organización).
Desarrollador de Aplicaciónapp_developerSubir paquetes, gestionar dispositivos, desencadenar compilaciones nativas, actualizar configuraciones de canal. Sin eliminación, sin cambios en la configuración de la aplicación, sin creación de canales.
Subidor de Aplicaciónapp_uploaderAcceso de lectura + subir nuevas versiones de paquetes.
Lector de Aplicaciónapp_readerSolo lectura — estadísticas, paquetes, canales, registros, dispositivos.

Matriz de permisos de la aplicación

Matriz de permisos de la aplicación
PermisoDescripciónAdministrador de la aplicaciónDesarrollador de la aplicaciónSubidor de la aplicaciónLector de la aplicación
app.readVer detalles de la aplicación, estadísticas y metadatos
app.update_settingsEditar ajustes de la aplicación
app.read_bundlesVer la lista de paquetes subidos
app.upload_bundleSubir una nueva versión de paquete
app.create_channelCrear un nuevo canal
app.read_channelsVer canales
app.read_logsVer registros de entrega de actualizaciones
app.manage_devicesAsignar, sobreescribir o desvincular dispositivos
app.read_devicesVer lista de dispositivos
app.build_nativeDesencadenar una compilación nativa en la nube
app.read_auditVer registro de actividad de nivel de aplicación
app.update_user_rolesAdministrar asignaciones de roles de nivel de aplicación
bundle.deleteEliminar una paquete

Limitado a un canal en particular. Útil para dar acceso objetivo a un canal de liberación específico.

RolNombre internoDescripción
Administrador de canalchannel_adminControl total de un canal: configuración, promoción/retorno de paquetes, gestión de dispositivos forzados.
Vista de canalchannel_readerLeer solo — paquete actual, historia, dispositivos forzados, registro de auditoría.
PermisoDescripciónAdministrador de canalVista de canal
channel.readVer el canal y su paquete actual
channel.update_settingsEditar ajustes del canal (toggler de plataforma, política de actualización…)
channel.deleteEliminar el canal
channel.read_historyVer historial de asignación de paquetes
channel.promote_bundleEstablecer el paquete activo en el canal
channel.rollback_bundleVolver a un paquete anterior
channel.manage_forced_devicesForzar dispositivos específicos a este canal
channel.read_forced_devicesVer lista de dispositivos forzados
channel.read_auditVer registro de actividad del canal

Limitado a una versión de paquete única. Rara vez es necesario — la mayoría de los equipos utilizan roles de nivel de aplicación en su lugar.

RolNombre internoDescripción
Administrador de paquetebundle_adminLeer, actualizar metadatos y eliminar un paquete específico.
Vista de paquetebundle_readerAcceso de solo lectura a un paquete específico.

En el panel de control, el acceso a los canales se determina por defecto por el rol de la aplicación del usuario. Para un control más detallado, puede sobreescribir permisos de canal específicos por usuario o grupo sin cambiar su rol de aplicación.

Las sobrescripciones se configuran desde la pestaña Acceso del panel de configuración del app, haciendo clic en el botón de permisos de canal (ícono de escudo) junto a un usuario. Consulte Organización — Sobreescribiendo permisos de canal para una guía visual.

PermisoDescripciónComportamiento por defecto
LecturaVer el canal y su paquete actualHerencia del rol de la aplicación
HistorialVer el historial de asignación de paquetesHerencia del rol de la aplicación
Asociar paqueteEstablecer o cambiar el paquete activo en el canalHerencia del rol de la aplicación

Cada permiso se puede configurar para:

  • Predeterminado — heredar del rol de la aplicación (por defecto)
  • Permitir — otorgar explícitamente, sin importar el rol de la aplicación
  • Denegar — bloquear explícitamente, sin importar el rol de la aplicación

Esto te permite, por ejemplo, dar a un lector de aplicaciones la capacidad de asociar paquetes en el staging canal sin promoverlos a desarrollador de aplicaciones.


Estructura de roles

Jerarquía de roles

Los roles forman una jerarquía. Un rol padre hereda todos los permisos de sus hijos. Esto significa que un org_admin puede hacer todo lo que un app_admin puede, lo que a su vez puede hacer todo lo que un channel_admin puede, y así sucesivamente.

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)

¿Cómo funciona en la práctica:

  • Un Administrador a nivel de organización puede hacer todo lo que un App Admin puede, en cada aplicación de la organización.
  • Un App Admin en una aplicación específica puede hacer todo lo que un Administrador de Canal puede, en cada canal de esa aplicación.
  • Un Desarrollador de Aplicación puede hacer todo lo que un Subidor de Aplicación puede, más aún.

La jerarquía solo fluye hacia abajo — un channel_admin nunca obtiene permisos de nivel de organización, incluso si también tienen un rol de nivel de aplicación.


En lugar de asignar roles a cada usuario individualmente, puede crear grupos y asignar roles al grupo. Cada miembro del grupo hereda automáticamente esos roles.

  • Un grupo pertenece a Una organización — no puede abarcar varias organizaciones. Los grupos pueden contener vinculaciones de rol en
  • any scope : organización, aplicación, canal o paquete. Por ejemplo, un grupo puede asignarse elDesarrollador de Aplicación rol en la aplicación A y el Administrador de Canal rol en el canal de la aplicación B. staging Cuando se evalúan los permisos de un usuario, todas sus pertenencias de grupo se resuelven de manera transparente. Si alguno de sus grupos concede el permiso requerido, se permite el acceso.
  • Un usuario puede pertenecer a
  • __CAPGO_KEEP_0__ grupos múltiplesy permisos de todos los grupos son acumulativos.
  • Los permisos basados en grupos solo se aplican a principales de usuario — las API claves no heredan roles de grupo.
EscenarioSin gruposCon grupos
5 ingenieros de pruebas necesitan acceso de Desarrollador a 3 aplicaciones15 vinculaciones de roles individuales1 grupo + 3 vinculaciones de rol
Alguien se une al equipo de QAAgregar 3 vinculaciones de rol manualmenteAgregarlos al grupo
Alguien deja el equipo de QAEliminar 3 vinculaciones de rol manualmenteEliminarlos del grupo

Todas las endpoints de grupo requieren autenticación y se sirven bajo /private/groups.

Ventana del terminal
curl -X GET "https://api.capgo.app/private/groups/<ORG_ID>" \
-H "authorization: <API_KEY>"

Requiere org.read_members permiso.

Ventana del terminal
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"
}'

Requiere org.update_user_roles permiso (Administrador Super o Administrador).

Ventana de terminal
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"
}'
Ventana de terminal
curl -X DELETE "https://api.capgo.app/private/groups/<GROUP_ID>" \
-H "authorization: <API_KEY>"

Eliminar un grupo también elimina todas sus vinculaciones de rol. Los miembros no se eliminan de la organización.

Ventana del terminal
curl -X GET "https://api.capgo.app/private/groups/<GROUP_ID>/members" \
-H "authorization: <API_KEY>"
Ventana del terminal
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>" }'

El usuario debe ya ser miembro de la organización. Agregar un miembro existente es una operación sin efecto.

Ventana del terminal
curl -X DELETE "https://api.capgo.app/private/groups/<GROUP_ID>/members/<USER_UUID>" \
-H "authorization: <API_KEY>"

Ventana de terminal
curl -X GET "https://api.capgo.app/organization/members" \
-H "authorization: <API_KEY>" \
-H "Content-Type: application/json" \
-d '{ "orgId": "<ORG_ID>" }'

Respuesta:

[
{
"uid": "user-uuid",
"email": "alice@example.com",
"image_url": "https://...",
"role": "org_admin",
"is_tmp": false
}
]
Ventana de terminal
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"
}'

Valores aceptados para invite_type:

ValorRol asignado
org_super_adminAdministrador Super
org_adminAdministrador
org_billing_adminGerente de facturación
org_memberMiembro
Ventana de terminal
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"
}'

Ventana de terminal
npx @capgo/cli organization list --apikey <API_KEY>
Ventana de terminal
npx @capgo/cli organization members <ORG_ID> --apikey <API_KEY>

Los roles incorporados cubren la mayoría de las estructuras de equipo. La creación de roles personalizados está en nuestra ruta de desarrollo — si este es algo que necesita su equipo, háganos llegar. Su caso de uso ayudará directamente a priorizar esta función.

Siga adelante desde la Referencia de Control de Acceso

Sección titulada “Siga adelante desde la Referencia de Control de Acceso”

Si está utilizando Referencia de Control de Acceso para planificar la consola y las operaciones API, conecte con API Vista General para los detalles de implementación en API Vista General, Introducción para los detalles de implementación en Introducción, API Claves para los detalles de implementación en API Claves, Dispositivos para los detalles de implementación en Dispositivos, y Paquetes para los detalles de implementación en Paquetes.