Este guia explica como usar o método
delete()
no recurso Membership
da API Google Chat para remover membros de um
espaço, também conhecido como exclusão de uma associação. Os administradores não podem ser removidos se forem os únicos administradores de um espaço. Atribua outro usuário como administrador do espaço antes de remover essas associações.
Se você for administrador do Google Workspace, poderá remover usuários, grupos do Google ou apps do Chat de qualquer espaço na sua organização do Google Workspace.
O
recurso Membership
representa se um usuário humano ou um app do Google Chat foi convidado para um espaço,
faz parte dele ou não está presente.
Pré-requisitos
Node.js
- Uma conta do Google Workspace Business ou Enterprise com acesso ao Google Chat.
- Configure seu ambiente:
- Crie um projeto do Google Cloud.
- Configure a tela de permissão OAuth.
- Ative e configure a API Google Chat com um nome, um ícone e uma descrição para seu app do Chat.
- Instale a biblioteca de cliente do Cloud do Node.js.
- Crie credenciais de acesso com base na forma como você quer fazer a autenticação na solicitação da API Google Chat:
- Para autenticar como um usuário do Chat,
crie credenciais de ID do cliente OAuth e salve-as como um arquivo JSON chamado
credentials.json
no seu diretório local. - Para autenticar como o app Chat,
crie credenciais de
conta de serviço e salve-as como um arquivo JSON chamado
credentials.json
.
- Para autenticar como um usuário do Chat,
crie credenciais de ID do cliente OAuth e salve-as como um arquivo JSON chamado
- Escolha um escopo de autorização com base em se você quer autenticar como um usuário ou o app Chat.
- Um espaço do Google Chat. Para criar um usando a API Google Chat, consulte Criar um espaço. Para criar um no Chat, acesse a documentação da Central de Ajuda.
Remover um participante de um espaço como usuário
Para remover um usuário, um grupo do Google ou um app do Chat de um espaço com autenticação de usuário, transmita o seguinte na sua solicitação:
- Especifique o escopo de autorização
chat.memberships
. O usuário autorizador precisa ter permissão para remover o usuário ou o grupo do Google do espaço. Para remover um app do Chat, especifique o escopo de autorizaçãochat.memberships.app
. Os apps só podem excluir a própria associação, não a de outros apps. Como prática recomendada, escolha o escopo mais restritivo que ainda permita o funcionamento do app. - Chame o método
DeleteMembership()
. - Transmita o
name
da assinatura a ser excluída. Se a participação pertencer ao único administrador de um espaço, atribua outro usuário como administrador antes de excluir a participação.
Saiba como excluir uma assinatura com autenticação do usuário:
Node.js
Para executar esta amostra, substitua o seguinte:
SPACE_NAME
: o ID doname
do espaço. Você pode conseguir o ID chamando o métodoListSpaces()
ou no URL do espaço.MEMBER_NAME
: o ID doname
do membro. Para conseguir o ID, chame o métodoListMemberships()
.
Se a solicitação for bem-sucedida, o corpo da resposta vai retornar a associação com
'state': 'NOT_A_MEMBER'
, indicando que o membro não está mais no espaço.
{ "name": "spaces/SPACE_NAME/members/MEMBER_NAME", "state": "NOT_A_MEMBER" }
Remover um participante de um espaço como um app do Chat
A autenticação do app exige uma única aprovação do administrador.
Para remover um usuário, um grupo do Google ou um app do Chat de um espaço com autenticação de app, transmita o seguinte na sua solicitação:
- Especifique o escopo de autorização
chat.app.memberships
. A exclusão da participação de um administrador do espaço só é compatível com espaços criados por apps do Chat. - Chame o método
delete
no recursomembership
. - Transmita o
name
da assinatura a ser excluída. Se a participação pertencer ao único administrador de um espaço, atribua outro usuário como administrador antes de excluir a participação.
Escrever um script que chama a API Chat
Veja como excluir uma assinatura com autenticação do app:
Python
- No diretório de trabalho, crie um arquivo chamado
chat_membership_delete_app.py
. Inclua o seguinte código em
chat_membership_delete_app.py
:from google.oauth2 import service_account from apiclient.discovery import build # Define your app's authorization scopes. # When modifying these scopes, delete the file token.json, if it exists. SCOPES = ["https://www.googleapis.com/auth/chat.app.memberships"] def main(): ''' Authenticates with Chat API using app authentication, then deletes the specified membership. ''' # Specify service account details. creds = ( service_account.Credentials.from_service_account_file('credentials.json') .with_scopes(SCOPES) ) # Build a service endpoint for Chat API. chat = build('chat', 'v1', credentials=creds) # Use the service endpoint to call Chat API. result = chat.spaces().members().delete( # The membership to delete. # # Replace SPACE with a space name. # Obtain the space name from the spaces resource of Chat API, # or from a space's URL. # # Replace MEMBER with a membership name. # Obtain the membership name from the memberships resource of # Chat API. To delete a Chat app's membership, replace MEMBER # with app; an alias for the app calling the API. name='spaces/SPACE/members/MEMBER' ).execute() # Print Chat API's response in your command line interface. # When deleting a membership, the response body is empty. print(result) if __name__ == '__main__': main()
No código, substitua o seguinte:
SPACE
: o nome de um espaço, que pode ser obtido com o métodospaces.list
na API Chat ou no URL de um espaço.MEMBER
: um nome de assinatura, que pode ser obtido com o métodospaces.members.list
na API Chat. Para excluir a assinatura de um app, substituaMEMBER
porapp
.
No diretório de trabalho, crie e execute a amostra:
python3 chat_membership_delete_app.py
Se a solicitação for bem-sucedida, o corpo da resposta vai retornar a associação com
'state': 'NOT_A_MEMBER'
, indicando que o membro não está mais no espaço.
{ "name": "spaces/SPACE/members/MEMBER", "state": "NOT_A_MEMBER" }
Remover usuários ou Grupos do Google de um espaço como administrador do Google Workspace
Se você for um administrador do Google Workspace, poderá chamar o método
DeleteMembership()
para remover usuários, Grupos do Google ou
apps do Chat de qualquer espaço na sua organização do Google Workspace.
Para chamar esse método como administrador do Google Workspace, faça o seguinte:
- Chame o método usando a autenticação do usuário e especifique um escopo de autorização que permita chamar o método usando privilégios de administrador.
- Na solicitação, especifique o parâmetro de consulta
useAdminAccess
comotrue
.
Para mais informações e exemplos, consulte Gerenciar espaços do Google Chat como administrador do Google Workspace.
Limitações e considerações
- Com a autenticação de app, um app do Chat pode remover usuários, mas não Grupos do Google ou apps do Chat.
Temas relacionados
- Receba detalhes sobre a assinatura de um usuário ou app do Chat.
- Listar participantes em um espaço.
- Atualizar a associação de um usuário a um espaço do Google Chat.
- Convide ou adicione um usuário ou app do Chat a um espaço.