Compartir a través de


Conceder un appRoleAssignment a una entidad de servicio

Espacio de nombres: microsoft.graph

Asignar un rol de aplicación a una entidad de servicio del cliente.

Los roles de aplicación que se asignan a entidades de servicio se conocen también como permisos de aplicación. Los permisos de aplicación se pueden conceder directamente con las asignaciones de rol de aplicación o mediante una experiencia de consentimiento.

Para conceder una asignación de roles de aplicación a una entidad de servicio del cliente, necesitará tres identificadores:

  • principalId: El id de la entidad de servicio del cliente a la que va a asignar el rol de aplicación.
  • resourceId: El id del recurso servicePrincipal (la API) que ha definido el rol de la aplicación (el permiso de la aplicación).
  • appRoleId: El id del appRole (definido en la entidad de servicio del recurso) para asignar a la entidad de servicio del cliente.

Esta API está disponible en las siguientes implementaciones nacionales de nube.

Servicio global Gobierno de EE. UU. L4 Us Government L5 (DOD) China operada por 21Vianet

Permissions

Elija el permiso o los permisos marcados como con privilegios mínimos para esta API. Use un permiso o permisos con privilegios superiores solo si la aplicación lo requiere. Para obtener más información sobre los permisos delegados y de aplicación, consulte Tipos de permisos. Para obtener más información sobre estos permisos, consulte la referencia de permisos.

Tipo de permiso Permisos con privilegios mínimos Permisos con privilegios más altos
Delegado (cuenta profesional o educativa) AppRoleAssignment.ReadWrite.All y Application.Read.All AppRoleAssignment.ReadWrite.All y Directory.Read.All
Delegado (cuenta personal de Microsoft) No admitida. No admitida.
Aplicación AppRoleAssignment.ReadWrite.All y Application.Read.All AppRoleAssignment.ReadWrite.All y Directory.Read.All

Importante

En escenarios delegados con cuentas profesionales o educativas, al usuario que ha iniciado sesión se le debe asignar un rol de Microsoft Entra compatible o un rol personalizado con un permiso de rol admitido. Se admiten los siguientes roles con privilegios mínimos para esta operación:

  • Cuentas de sincronización de directorios: para Microsoft Entra Connect y Microsoft Entra servicios de Cloud Sync
  • Escritor de directorios
  • Administrador de identidades híbridas
  • Administrador de gobernanza de identidades
  • Administrador de roles con privilegios
  • Administrador de usuarios
  • Administrador de la aplicación
  • Administrador de aplicaciones en la nube

Solicitud HTTP

Puede dirigirse a la entidad de servicio mediante su id . o appId. id y appId se conocen como id. de objeto y id. de aplicación (cliente), respectivamente, en los registros de aplicaciones en el Centro de administración Microsoft Entra.

POST /servicePrincipals/{id}/appRoleAssignments
POST /servicePrincipals(appId='{appId}')/appRoleAssignments

Nota:

Como práctica recomendada, le sugerimos crear asignaciones de roles de aplicación mediante la relación appRoleAssignedTo del recurso entidad de servicio, en lugar de la relación appRoleAssignments del usuario, grupo o entidad de servicio asignados.

Encabezados de solicitud

Nombre Descripción
Authorization {token} de portador. Obligatorio. Obtenga más información sobre la autenticación y la autorización.
Tipo de contenido application/json. Obligatorio.

Cuerpo de la solicitud

En el cuerpo de la solicitud, proporcione una representación JSON de un objeto appRoleAssignment.

Respuesta

Si se ejecuta correctamente, este método entrega un código de respuesta 201 Created y un objeto appRoleAssignment en el cuerpo de la respuesta.

Ejemplos

Solicitud

En el ejemplo siguiente se muestra la solicitud.

POST https://graph.microsoft.com/v1.0/servicePrincipals/9028d19c-26a9-4809-8e3f-20ff73e2d75e/appRoleAssignments
Content-Type: application/json

{
  "principalId": "9028d19c-26a9-4809-8e3f-20ff73e2d75e",
  "resourceId": "8fce32da-1246-437b-99cd-76d1d4677bd5",
  "appRoleId": "498476ce-e0fe-48b0-b801-37ba7e2685c6"
}

En este ejemplo, tenga en cuenta que el valor usado como id. de la entidad de servicio en la dirección URL de solicitud (9028d19c-26a9-4809-8e3f-20ff73e2d75e) es el mismo que la propiedad principalId en el cuerpo. El valor resourceId es el id. de la entidad de servicio de recursos (la API).

Respuesta

En el ejemplo siguiente se muestra la respuesta.

Nota: Se puede acortar el objeto de respuesta que se muestra aquí para mejorar la legibilidad.

HTTP/1.1 201 Created
Content-type: application/json

{
  "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#appRoleAssignments/$entity",
  "id": "2jLOj0YSe0OZzXbR1Gd71fDqFUrPM1xIgUfvWBHJ9n0",
  "createdDateTime": "2021-02-15T16:39:38.2975029Z",
  "appRoleId": "498476ce-e0fe-48b0-b801-37ba7e2685c6",
  "principalDisplayName": "Fabrikam App",
  "principalId": "9028d19c-26a9-4809-8e3f-20ff73e2d75e",
  "principalType": "ServicePrincipal",
  "resourceDisplayName": "Microsoft Graph",
  "resourceId": "8fce32da-1246-437b-99cd-76d1d4677bd5"
}