Compartir a través de


Creación de hardwareOathTokenAuthenticationMethodDevice

Espacio de nombres: microsoft.graph

Importante

Las API de la versión /beta de Microsoft Graph están sujetas a cambios. No se admite el uso de estas API en aplicaciones de producción. Para determinar si una API está disponible en la versión 1.0, use el selector de Versión.

Cree un nuevo objeto hardwareOathTokenAuthenticationMethodDevice . Esta API admite dos escenarios:

  • Cree el nuevo token de hardware sin asignarlo a un usuario. A continuación, puede asignar a un usuario.
  • Cree y asigne un token de hardware a un usuario en la misma solicitud.

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) Policy.ReadWrite.AuthenticationMethod No disponible.
Delegado (cuenta personal de Microsoft) No admitida. No admitida.
Aplicación Policy.ReadWrite.AuthenticationMethod No disponible.

Importante

Cuando se usan permisos delegados con cuentas profesionales o educativas, el usuario que ha iniciado sesión debe tener un rol de Microsoft Entra adecuado o un rol personalizado con los permisos necesarios. El rol integrado con privilegios mínimos necesario para esta operación es Administrador de directivas de autenticación.

Para crear y asignar un token oath de hardware a un usuario en una sola solicitud, el usuario que inició sesión también debe tener:

  • Permiso delegado UserAuthenticationMethod.ReadWrite.All .
  • Rol Administrador de autenticación (rol con privilegios mínimos para asignar tokens de hardware a usuarios que no son administradores) o Administrador de autenticación con privilegios (rol con privilegios mínimos para asignar tokens de hardware a usuarios administradores).

Solicitud HTTP

POST /directory/authenticationMethodDevices/hardwareOathDevices

Encabezados de solicitud

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

Cuerpo de la solicitud

En el cuerpo de la solicitud, proporcione una representación JSON del objeto hardwareOathTokenAuthenticationMethodDevice .

Puede especificar las siguientes propiedades al crear un hardwareOathTokenAuthenticationMethodDevice.

Propiedad Tipo Descripción
serialNumber Cadena Número de serie del token de hardware específico, que a menudo se encuentra en la parte posterior del dispositivo. Obligatorio.
manufacturer Cadena Nombre del fabricante del token de hardware. Obligatorio.
model Cadena Nombre del modelo del token de hardware. Obligatorio.
secretKey Cadena Clave secreta del token de hardware específico, proporcionado por el proveedor. Obligatorio.
timeIntervalInSeconds Int32 Intervalo de actualización del código de verificación de seis dígitos, en segundos. Los valores posibles son: 30 o 60. Obligatorio.
hashFunction hardwareOathTokenHashFunction Función hash del token de hardware. Los valores posibles son: hmacsha1 o hmacsha256. El valor predeterminado es: hmacsha1. Opcional.
assignTo identity Id. de usuario si desea asignar directamente el token a un usuario. Opcional.
displayName Cadena Nombre que se puede proporcionar al token oath de hardware. Opcional.

Respuesta

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

Ejemplos

Ejemplo 1: Creación de un token sin asignación de usuario

Solicitud

En el ejemplo siguiente se muestra la solicitud.

POST https://graph.microsoft.com/beta/directory/authenticationMethodDevices/hardwareOathDevices
Content-Type: application/json

{
  "displayName": "Token 1",
  "serialNumber": "TOTP123456",
  "manufacturer": "Contoso",
  "model": "Hardware Token 1000",
  "secretKey": "6PJ4UKIW33NNXYZAEHQNFUFTZF7WFTFB",
  "timeIntervalInSeconds": 30,
  "hashFunction": "hmacsha1"
}

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.type": "#microsoft.graph.hardwareOathTokenAuthenticationMethodDevice",
  "id": "9b037532-f999-1ed9-13fd-849ffb995e11",
  "displayName": "Token 1",
  "serialNumber": "TOTP123456",
  "manufacturer": "Contoso",
  "model": "Hardware Token 1000",
  "secretKey": null,
  "timeIntervalInSeconds": 30,
  "status": "available",
  "lastUsedDateTime": null,
  "assignedTo": null,
  "hashFunction": "hmacsha1"
}

Ejemplo 2: Crear un token y asignarlo a un usuario

Solicitud

En el ejemplo siguiente se muestra la solicitud.

POST https://graph.microsoft.com/beta/directory/authenticationMethodDevices/hardwareOathDevices
Content-Type: application/json

{
  "displayName": "Token 1",
  "serialNumber": "TOTP123456",
  "manufacturer": "Contoso",
  "model": "Hardware Token 1000",
  "secretKey": "6PJ4UKIW33NNXYZAEHQNFUFTZF7WFTFB",
  "timeIntervalInSeconds": 30,
  "hashFunction": "hmacsha1",
  "assignTo": {
    "id": "0cadbf92-####-####-####-############"
    }
}

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.type": "#microsoft.graph.hardwareOathTokenAuthenticationMethodDevice",
  "id": "9b037532-f999-1ed9-13fd-849ffb995e11",
  "displayName": "Token 1",
  "serialNumber": "TOTP123456",
  "manufacturer": "Contoso",
  "model": "Hardware Token 1000",
  "secretKey": null,
  "timeIntervalInSeconds": 30,
  "status": "assigned",
  "lastUsedDateTime": null,
  "assignedTo": null,
  "hashFunction": "hmacsha1",
  "assignedTo": {
    "id": "0cadbf92-####-####-####-############",
    "displayName": "Amy Masters"
    }
}