Ein Mitglied aus einem Gruppenbereich entfernen

In diesem Leitfaden wird erläutert, wie Sie die Methode delete für die Ressource membership der Google Chat API verwenden, um ein Mitglied aus einem Bereich zu entfernen, auch als Löschung einer Mitgliedschaft bezeichnet. Administratoren von Gruppenbereichen können nicht entfernt werden, wenn sie der einzige Administrator eines Gruppenbereichs sind. Legen Sie einen anderen Nutzer als Administrator des Gruppenbereichs fest, bevor Sie diese Mitgliedschaften entfernen.

Die Ressource Membership gibt an, ob ein menschlicher Nutzer oder die Google Chat-App zu einem Gruppenbereich eingeladen wurde, ihm angehört oder nicht.

Voraussetzungen

Python

  • Python 3.6 oder höher
  • Das Paketverwaltungstool pip
  • Die neuesten Google-Clientbibliotheken für Python. Führen Sie den folgenden Befehl in der Befehlszeile aus, um sie zu installieren oder zu aktualisieren:

    pip3 install --upgrade google-api-python-client google-auth-oauthlib
    
  • Ein Google Cloud-Projekt mit aktivierter und konfigurierter Google Chat API. Eine Anleitung dazu finden Sie unter Google Chat-App erstellen.
  • Für die Chat-App konfigurierte Autorisierung. Zum Löschen einer Mitgliedschaft ist eine Nutzerauthentifizierung mit dem Autorisierungsbereich chat.memberships oder chat.memberships.app von einem Nutzer erforderlich, der die Berechtigung zum Löschen der angegebenen Mitgliedschaft hat.

Ein Mitglied aus einem Gruppenbereich entfernen

So entfernen Sie einen Nutzer, eine Google Groups-Gruppe oder eine Chat-App aus einem Gruppenbereich:

  • Geben Sie den Autorisierungsbereich chat.memberships an, um einen Nutzer oder eine Google-Gruppe zu entfernen. Wenn Sie eine Chat-App entfernen möchten, geben Sie den Autorisierungsbereich chat.memberships.app an. Apps können nur ihre eigene Mitgliedschaft löschen, nicht die anderer Apps. Wählen Sie als Best Practice den restriktivsten Bereich aus, in dem Ihre App noch funktioniert.
  • Rufen Sie die Methode delete für die Ressource membership auf.
  • Übergib die name der zu löschenden Mitgliedschaft. Wenn die Mitgliedschaft dem einzigen Administrator des Gruppenbereichs in einem Gruppenbereich gehört, weisen Sie einen anderen Nutzer als Administrator des Gruppenbereichs zu, bevor Sie diese Mitgliedschaft löschen.

So löschst du eine Mitgliedschaft:

Python

  1. Erstellen Sie in Ihrem Arbeitsverzeichnis eine Datei mit dem Namen chat_membership_delete.py.
  2. Fügen Sie den folgenden Code in chat_membership_delete.py ein:

    from google_auth_oauthlib.flow import InstalledAppFlow
    from googleapiclient.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.memberships.app"]
    
    def main():
        '''
        Authenticates with Chat API via user credentials,
        then deletes the specified membership.
        '''
    
        # Authenticate with Google Workspace
        # and get user authorization.
        flow = InstalledAppFlow.from_client_secrets_file(
                    'client_secrets.json', SCOPES)
        creds = flow.run_local_server()
    
        # 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()
    
  3. Ersetzen Sie im Code Folgendes:

    • SPACE: ein Name für den Gruppenbereich, den Sie über die Methode spaces.list in der Chat API oder über die URL eines Gruppenbereichs abrufen können.

    • MEMBER: ein Mitgliedsname, den du in der Chat API über die Methode spaces.members.list abrufen kannst. Ersetzen Sie MEMBER durch app, um die Mitgliedschaft einer App zu löschen.

  4. Erstellen Sie das Beispiel in Ihrem Arbeitsverzeichnis und führen Sie es aus:

    python3 chat_membership_delete.py
    

Wenn der Vorgang erfolgreich ist, gibt der Antworttext die Mitgliedschaft mit 'state': 'NOT_A_MEMBER' zurück, was darauf hinweist, dass sich das Mitglied nicht mehr im Gruppenbereich befindet.

{
    "name": "spaces/SPACE/members/MEMBER",
    "state": "NOT_A_MEMBER"
}