Partilhar via


Adicionar aplicativo à equipe

Namespace: microsoft.graph

Instale uma aplicação para a equipa especificada.

Esta API está disponível nas seguintes implementações de cloud nacionais.

Serviço global US Government L4 US Government L5 (DOD) China operada pela 21Vianet

Permissões

Uma das seguintes permissões é necessária para chamar esta API. Para saber mais, incluindo como escolher permissões, confira Permissões.

Tipo de permissão Permissões (da com menos para a com mais privilégios)
Delegado (conta corporativa ou de estudante) TeamsAppInstallation.ReadWriteSelfForTeam1, TeamsAppInstallation.ReadWriteForTeam1, TeamsAppInstallation.ReadWriteAndConsentSelfForTeam, Group.ReadWrite.All2, Directory.ReadWrite.All2
Delegado (conta pessoal da Microsoft) Sem suporte.
Application TeamsAppInstallation.ReadWriteSelfForTeam.All1, TeamsAppInstallation.ReadWriteForTeam.All1, TeamsAppInstallation.ReadWriteAndConsentForTeam.All, TeamsAppInstallation.ReadWriteAndConsentSelfForTeam.All, Group.ReadWrite.All2, Directory.ReadWrite.All2

Observação:
1 Estas permissões não podem ser utilizadas para instalar aplicações que requerem consentimento para permissões de consentimento específicas do recurso
2 Estas permissões são suportadas apenas para retrocompatibilidade. Recomendamos que atualize as suas soluções para utilizar uma permissão alternativa e evite utilizar estas permissões no futuro.

Solicitação HTTP

POST /teams/{team-id}/installedApps

Cabeçalhos de solicitação

Cabeçalho Valor
Autorização {token} de portador. Obrigatório. Saiba mais sobre autenticação e autorização.

Corpo da solicitação

O corpo do pedido deve incluir o ID da aplicação gerada da aplicação de catálogo. Para obter mais informações, veja teamsPropriedades da aplicação.

A tabela seguinte lista propriedades adicionais que podem ser incluídas no corpo do pedido.

Propriedade Tipo Descrição
teamsApp Cadeia de caracteres O ID da aplicação a adicionar.
consentedPermissionSet teamsAppPermissionSet O conjunto de permissões específicas de recursos que estão a ser consentidas.

Nota: as permissões consentidas durante a instalação têm de corresponder às permissões específicas do recurso especificadas no teamsAppDefinition da aplicação. Para obter a aplicação e permissões delegadas específicas de recursos, veja Exemplo 6. Se apenas forem especificadas permissões delegadas específicas de recursos no teamsAppDefinition, as permissões podem ser omitidas no corpo do pedido.

Resposta

Se tiver êxito, este método retornará um código de resposta 200 OK. Não devolve nada no corpo da resposta.

Exemplos

Exemplo 1: Instalar uma aplicação numa equipa

Solicitação

O exemplo a seguir mostra uma solicitação.

POST https://graph.microsoft.com/v1.0/teams/87654321-0abc-zqf0-321456789q/installedApps
Content-type: application/json

{
   "teamsApp@odata.bind":"https://graph.microsoft.com/v1.0/appCatalogs/teamsApps/12345678-9abc-def0-123456789a"
}

Resposta

O exemplo a seguir mostra a resposta.

HTTP/1.1 200 OK

Para obter a lista de permissões específicas de recursos exigidas pela aplicação, obtenha a aplicação a partir do appCatalog, conforme mostrado no Exemplo 6.

Solicitação

POST https://graph.microsoft.com/v1.0/teams/7023576d-9e40-47ca-9cf2-daae6838e785/installedApps
Content-Type: application/json

{
  "teamsApp@odata.bind" : "https://graph.microsoft.com/v1.0/appCatalogs/teamsApps/7023576d-9e40-47ca-9cf2-daae6838e785",
    "consentedPermissionSet": {
        "resourceSpecificPermissions": [
        {
          "permissionValue": "OnlineMeeting.ReadBasic.Chat",
          "permissionType": "delegated"
        },
        {
          "permissionValue": "ChatMessage.Read.Chat",
          "permissionType": "application"
        }]
      }
}

Resposta

HTTP/1.1 201 Created

Se a chamada resultar numa mensagem de erro que indica The required permissions have not been consented to by the caller, o corpo do pedido não especifica todas as permissões RSC exigidas pela aplicação à qual o utilizador tem de conceder consentimento. Certifique-se de que cria o pedido conforme mostrado no exemplo.