Informationen zur GitHub Actions Authentifizierung
Wenn Sie in einem GitHub Actions-Workflow authentifizierte API-Anfragen stellen müssen oder eine benutzerdefinierte Aktion ausführen müssen, die ein Token erfordert, sollten Sie nach Möglichkeit die integrierte GITHUB_TOKEN verwenden. Das GITHUB_TOKEN kann jedoch nur auf die Ressourcen im Repository des Workflows zugreifen. Wenn Sie auf zusätzliche Ressourcen zugreifen müssen, z. B. auf Ressourcen in einer Organisation oder in einem anderen Repository, können Sie ein GitHub App verwenden. Weitere Informationen dazu, warum Sie GitHub App anstelle von personal access token verwenden könnten, finden Sie unter Informationen zum Erstellen von GitHub Apps.
Authentifizieren mit einem GitHub App
Um mit einem GitHub App authentifizierte API-Anfragen zu stellen, müssen Sie ein GitHub App registrieren, die Anmeldeinformationen Ihrer App speichern und Ihre App installieren. Sobald dies erfolgt ist, können Sie ihre App verwenden, um ein Installationszugriffstoken zu erstellen, mit dem authentifizierte API-Anforderungen in einem GitHub Actions Workflow vorgenommen werden können. Du kannst das Installationszugriffstoken auch an eine benutzerdefinierte Aktion übergeben, für die ein Token benötigt wird.
-
Registrieren Sie ein GitHub App. Geben Sie Ihrer GitHub App Registrierung die erforderlichen Berechtigungen zum Zugriff auf die gewünschten Ressourcen. Weitere Informationen findest du unter Registrieren einer GitHub-App und Auswählen von Berechtigungen für eine GitHub App.
-
Speichern Sie die Client-ID Ihrer GitHub App als GitHub Actions Konfigurationsvariable. Du findest die Client-ID auf der Einstellungsseite deiner App. Die Client-ID unterscheidet sich von der App-ID. Weitere Informationen zum Navigieren zur Einstellungsseite für Ihr GitHub Appfinden Sie unter Ändern einer GitHub App-Registrierung. Weitere Informationen zum Speichern von Konfigurationsvariablen findest du unter Speichern von Informationen in Variablen.
-
Generiere einen privaten Schlüssel für deine App. Speichere den Inhalt der resultierenden Datei als Geheimnis. Speichere den gesamten Inhalt der Datei, einschließlich
-----BEGIN RSA PRIVATE KEY-----und-----END RSA PRIVATE KEY-----. Weitere Informationen findest du unter Verwalten privater Schlüssel für GitHub Apps. Weitere Informationen zum Speichern von Geheimnissen findest du unter Verwenden von Geheimnissen in GitHub-Aktionen. -
Installieren Sie GitHub App im richtigen Konto und gewähren Sie ihm Berechtigungen und Zugriff auf alle Repositorys, auf die Ihr Workflow zugreifen soll. Weitere Informationen finden Sie unter Installieren Ihrer eigenen GitHub App.
-
Erstellen Sie in Ihrem GitHub Actions Workflow ein Installationszugriffstoken, mit dem Sie API-Anforderungen durchführen können.
Dazu können Sie eine GitHub-eigene Aktion verwenden, wie im folgenden Beispiel gezeigt. Wenn Sie diese Aktion nicht verwenden möchten, können Sie die
actions/create-github-app-tokenAktion forken und bearbeiten oder ein Skript schreiben, damit Ihrr Workflow manuell ein Installationstoken erstellt. Weitere Informationen finden Sie unter Authentifizieren als GitHub App-Installation.Der folgende Beispielworkflow verwendet die
actions/create-github-app-token-Aktion, um ein Installationszugriffstoken zu generieren. Anschließend verwendet der Workflow das Token, um über die GitHub CLI eine API-Anfrage zu stellen.Ersetzen
APP_CLIENT_IDSie im folgenden Workflow durch den Namen der Konfigurationsvariable, in der Sie Ihre Client-ID gespeichert haben. ErsetzeAPP_PRIVATE_KEYdurch den Namen des Geheimnisses, in dem der private Schlüssel der App gespeichert ist.
on:
workflow_dispatch:
jobs:
demo_app_authentication:
runs-on: ubuntu-latest
steps:
- name: Generate a token
id: generate-token
uses: actions/create-github-app-token@v3
with:
client-id: ${{ vars.APP_CLIENT_ID }}
private-key: ${{ secrets.APP_PRIVATE_KEY }}
- name: Use the token
env:
GH_TOKEN: ${{ steps.generate-token.outputs.token }}
run: |
gh api octocat
on:
workflow_dispatch:
jobs:
demo_app_authentication:
runs-on: ubuntu-latest
steps:
- name: Generate a token
id: generate-token
uses: actions/create-github-app-token@v3
with:
client-id: ${{ vars.APP_CLIENT_ID }}
private-key: ${{ secrets.APP_PRIVATE_KEY }}
- name: Use the token
env:
GH_TOKEN: ${{ steps.generate-token.outputs.token }}
run: |
gh api octocat