Compartir a través de


driveItem: invite

Espacio de nombres: microsoft.graph

Enviar una invitación de uso compartido para un driveItem. Una invitación para compartir proporciona permisos a los destinatarios y, opcionalmente, les envía un correo electrónico para notificarles que el elemento se ha compartido.

Importante

  • Los permisos no se pueden crear ni modificar en el driveItem raíz de las unidades con un driveType de personal (OneDrive para el hogar).
  • No se puede invitar a nuevos invitados mediante el acceso solo a la aplicación. Los invitados existentes se pueden invitar mediante solicitudes de solo aplicación.

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) Files.ReadWrite Files.ReadWrite.All, Sites.ReadWrite.All
Delegado (cuenta personal de Microsoft) Files.ReadWrite Files.ReadWrite.All
Aplicación Files.ReadWrite.All Sites.ReadWrite.All

Nota:

SharePoint Embedded requiere el FileStorageContainer.Selected permiso para acceder al contenido del contenedor. Este permiso es diferente de los mencionados anteriormente. Además de los permisos de Microsoft Graph, la aplicación debe tener los permisos de tipo de contenedor necesarios para llamar a esta API. Para obtener más información, vea Autenticación y autorización de SharePoint Embedded.

Solicitud HTTP

POST /drives/{drive-id}/items/{item-id}/invite
POST /groups/{group-id}/drive/items/{item-id}/invite
POST /me/drive/items/{item-id}/invite
POST /sites/{siteId}/drive/items/{itemId}/invite
POST /users/{userId}/drive/items/{itemId}/invite

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 un objeto JSON con los siguientes parámetros.

{
  "requireSignIn": false,
  "sendInvitation": false,
  "roles": [ "read | write"],
  "recipients": [
    { "@odata.type": "microsoft.graph.driveRecipient" },
    { "@odata.type": "microsoft.graph.driveRecipient" }
  ],
  "message": "string"
}
Parámetro Tipo Descripción
destinatarios colección driveRecipient Colección de destinatarios que reciben acceso y la invitación para compartir.
message String Un mensaje con formato de texto sin formato que se incluye en la invitación para uso compartido. Longitud máxima de 2000 caracteres.
requireSignIn Booleano Especifica si el destinatario de la invitación debe iniciar sesión para ver el elemento compartido.
sendInvitation Boolean Si esto es así, se envía un vínculo de uso compartido al destinatario. En caso contrario, se otorga un permiso directamente sin enviar ninguna notificación.
roles Colección de cadenas Especifica los roles que se concederán a los destinatarios de la invitación para compartir.
expirationDateTime DateTimeOffset Especifica la fecha y hora después de la cual expira el permiso. Para OneDrive para el trabajo o la escuela y SharePoint, expirationDateTime solo es aplicable para los permisos sharingLink . Disponible en OneDrive para cuentas profesionales o educativas, de SharePoint y de OneDrive personales premium.
password String Contraseña establecida en la invitación por el creador. Opcional y OneDrive solo para el hogar.
retainInheritedPermissions Booleano Opcional. Si true es (valor predeterminado), los permisos heredados existentes se conservan en el elemento compartido al compartir este elemento por primera vez. Si falsees , se quitan todos los permisos existentes al compartir por primera vez.

Respuesta

Si se ejecuta correctamente, este método devuelve un 200 OK código de respuesta y una colección de objetos de permiso en el cuerpo de la respuesta.

Para obtener más información sobre cómo se devuelven los errores, vea Respuestas de errores.

Respuesta de éxito parcial

Al invitar a varios destinatarios, es posible que la notificación se realice correctamente para algunos y que se produzca un error para otros. En este caso, el servicio devuelve una respuesta de éxito parcial con un 207 Multi-Status código de estado. Cuando se devuelve el éxito parcial, la respuesta de cada destinatario con errores contiene un objeto de error con información sobre qué se produjo un error y cómo corregirlo. Para obtener más información, consulte el ejemplo 2.

Enviar errores de notificación de invitación

En la tabla siguiente se muestran otros errores que la aplicación podría encontrar dentro de los objetos innererror anidados cuando se produce un error al enviar la notificación. Las aplicaciones no son necesarias para controlar estos errores.

Código Descripción
accountVerificationRequired La comprobación de la cuenta es necesaria para desbloquear el envío de notificaciones.
hipCheckRequired Necesita resolver hip (prevención de intrusiones de host) comprobar para desbloquear el envío de notificaciones.
exchangeInvalidUser No se encontró el buzón del usuario actual.
exchangeOutOfMailboxQuota Fuera de la cuota.
exchangeMaxRecipients Se ha superado el número máximo de destinatarios que se pueden enviar notificaciones al mismo tiempo.

Nota: El servicio puede agregar nuevos códigos de error o dejar de devolver los antiguos en cualquier momento.

Ejemplos

Ejemplo 1: Envío de una invitación para compartir

En el ejemplo siguiente se muestra cómo enviar una invitación de uso compartido a un usuario con la dirección ryan@contoso.comde correo electrónico , incluido un mensaje relativo a un archivo en colaboración. La invitación concede a Ryan acceso de lectura y escritura al archivo.

Solicitud

En el ejemplo siguiente se muestra la solicitud.

POST https://graph.microsoft.com/v1.0/me/drive/items/{item-id}/invite
Content-type: application/json

{
  "recipients": [
    {
      "email": "ryan@contoso.com"
    }
  ],
  "message": "Here's the file that we're collaborating on.",
  "requireSignIn": true,
  "sendInvitation": true,
  "roles": [ "write" ],
  "password": "password123",
  "expirationDateTime": "2018-07-15T14:00:00.000Z"
}

Respuesta

En el ejemplo siguiente se muestra la respuesta.

HTTP/1.1 200 OK
Content-type: application/json

{
  "value": [
    {
      "@deprecated.GrantedTo": "GrantedTo has been deprecated. Refer to GrantedToV2",
      "grantedTo": {
        "user": {
          "displayName": "Robin Danielsen",
          "id": "42F177F1-22C0-4BE3-900D-4507125C5C20"
        }
      },
      "grantedToV2": {
        "user": {
          "id": "42F177F1-22C0-4BE3-900D-4507125C5C20",
          "displayName": "Robin Danielsen"
        },
        "siteUser": {
          "id": "1",
          "displayName": "Robin Danielsen",
          "loginName": "Robin Danielsen"
        }
      },
      "hasPassword": true,
      "id": "CCFC7CA3-7A19-4D57-8CEF-149DB9DDFA62",
      "invitation": {
        "email": "robin@contoso.com",
        "signInRequired": true
      },
      "roles": [ "write" ],
      "expirationDateTime": "2018-07-15T14:00:00.000Z"
    }
  ]
}

Ejemplo 2: Envío de una invitación de uso compartido con éxito parcial

En el ejemplo siguiente se muestra una solicitud que se realiza correctamente parcialmente.

Solicitud

En el ejemplo siguiente se muestra la solicitud.

POST https://graph.microsoft.com/v1.0/me/drive/items/{item-id}/invite
Content-type: application/json

{
  "recipients": [
    {
      "email": "helga@contoso.com"
    },
    {
      "email": "robin@contoso.com"
    }
  ],
  "message": "Here's the file that we're collaborating on.",
  "requireSignIn": true,
  "sendInvitation": true,
  "roles": [ "write" ],
  "password": "password123",
  "expirationDateTime": "2018-07-15T14:00:00.000Z"
}

Respuesta

En el ejemplo siguiente se muestra la respuesta parcial.

HTTP/1.1 207 Multi-Status
Content-type: application/json

{
  "value": [
    {
      "grantedTo": {
        "user": {
          "displayName": "Helga Hammeren",
          "id": "5D8CA5D0-FFF8-4A97-B0A6-8F5AEA339681"
        }
      },
      "id": "1EFG7CA3-7A19-4D57-8CEF-149DB9DDFA62",
      "invitation": {
        "email": "helga@contoso.com",
        "signInRequired": true
      },
      "roles": [ "write" ],
      "error": {
        "code":"notAllowed",
        "message":"Account verification needed to unblock sending emails.",
        "localizedMessage": "Kontobestätigung erforderlich, um das Senden von E-Mails zu entsperren.",
        "fixItUrl":"http://g.live.com/8SESkydrive/VerifyAccount",
        "innererror":{
          "code":"accountVerificationRequired"
        }
      }
    },
    {
      "grantedTo": {
        "user": {
          "displayName": "Robin Danielsen",
          "id": "42F177F1-22C0-4BE3-900D-4507125C5C20"
        }
      },
      "id": "CCFC7CA3-7A19-4D57-8CEF-149DB9DDFA62",
      "invitation": {
        "email": "robin@contoso.com",
        "signInRequired": true
      },
      "roles": [ "write" ],
      "expirationDateTime": "2018-07-15T14:00:00.000Z"
    }
  ]
}

Para obtener una lista de los roles disponibles, vea Roles property values (Valores de propiedad de roles).