Informationen zu Dependabot
Dependabot hilft Ihnen, ihre Abhängigkeitsökosysteme im Überblick zu behalten. Mit Dependabot können Sie die Abhängigkeiten, die Sie verwenden, auf dem neuesten Stand halten, um potenzielle Sicherheitsprobleme in Ihrer Lieferkette zu beheben.
Dependabot besteht aus drei verschiedenen Features, mit denen du Abhängigkeiten verwalten kannst:
- Dependabot alerts informiert dich über Sicherheitsrisiken in den Abhängigkeiten, die du in deinem Repository verwendest.
- Dependabot security updates löst automatisch Pull Requests aus, um von dir verwendete Abhängigkeiten zu aktualisieren, die bekannte Sicherheitsrisiken aufweisen.
- Dependabot version updates löst automatisch Pull Requests aus, um deine Abhängigkeiten auf dem neuesten Stand zu halten.
Weitere Informationen zu Dependabot findest du unter Schnellstartanleitung für Dependabot.
In diesem Artikel können Sie sehen, welche Ökosysteme und Repositorys unterstützt werden.
Unterstützte Repositorys und Ökosysteme
Sie können Updates für Repositorys konfigurieren, die ein Abhängigkeitsmanifest oder eine Sperrdatei für einen der unterstützten Paketmanager enthalten. Für einige Paketmanager kannst du auch Vendoring für Abhängigkeiten konfigurieren. Weitere Informationen finden Sie unter vendor
.
Dependabot unterstützt auch Abhängigkeiten in privaten Registrierungen. Weitere Informationen finden Sie unter Konfigurieren des Zugriffs auf private Registrierungen für Dependabot.
Note
Um sicherzustellen, dass GitHub Enterprise Server Dependabot updates für die aktuellen unterstützten Ökosystemversionen unterstützt, muss dein Unternehmensbesitzender die aktuellste Version der Dependabot-Aktion herunterladen. Weitere Informationen zur Aktion und Anweisungen zum Herunterladen der aktuellen Version findest du unter Verwenden der neuesten Version der offiziellen gebündelten Aktionen.
Note
- Bei der Durchführung von Sicherheits- oder Versionsupdates müssen einige Ökosysteme in der Lage sein, alle Abhängigkeiten von der jeweiligen Quelle aufzulösen, um zu überprüfen, ob die Updates erfolgreich waren. Wenn deine Manifest- oder Sperrdateien private Abhängigkeiten enthalten, muss Dependabot auf den Speicherort zugreifen können, an dem diese Abhängigkeiten gehostet werden. Organisationsbesitzer können Dependabot Zugriff auf private Repositorys gewähren, die Abhängigkeiten für ein Projekt innerhalb derselben Organisation enthalten. Weitere Informationen finden Sie unter Verwalten von Sicherheits- und Analyseeinstellungen für deine Organisation. Du kannst den Zugriff auf private Registrierungen in der Konfigurationsdatei
dependabot.yml
eines Repositorys konfigurieren. Weitere Informationen finden Sie unter Konfigurieren des Zugriffs auf private Registrierungen für Dependabot. - Dependabot unterstützt keine privaten GitHub-Abhängigkeiten für alle Paketmanager. Weitere Informationen findest du in der folgenden Tabelle.
Wenn dein Repository bereits eine Integration für die Abhängigkeitsverwaltung verwendet, musst du dies deaktivieren, bevor du Dependabot aktivierst.
Paket-Manager | YAML-Wert | Unterstützte Versionen | Versionsupdates | Sicherheitsupdates | Private Repositorys | Private Registrierungen | Vendoring |
---|---|---|---|---|---|---|---|
Bundler | bundler | v1, v2 | |||||
Cargo | cargo | v1 | (Git only) | ||||
Composer | composer | v1, v2 | |||||
Docker | docker | v1 | Nicht zutreffend | ||||
Hex | mix | v1 | |||||
elm-package | elm | v0.19 | |||||
Git-Submodul | gitsubmodule | Nicht verfügbar | Nicht verfügbar | ||||
GitHub Actions | github-actions | Nicht verfügbar | Nicht verfügbar | ||||
Go-Module | gomod | v1 | |||||
Gradle | gradle | Nicht verfügbar | |||||
Maven | maven | Nicht verfügbar | |||||
npm | npm | v6, v7, v8, v9 | |||||
NuGet | nuget | <= 6.7.0 | |||||
pip | pip | v21.1.2 | |||||
pipenv | pip | <= 2021-05-29 | |||||
pip-compile | pip | 6.1.0 | |||||
pnpm | npm | v7, v8, v9 | (v7 and v8 only) | ||||
Poetry | pip | v1 | |||||
pub | pub | V2 | |||||
Swift | swift | v5 | (Nur Git) | ||||
Terraform | terraform | >= 0.13, <= 1.10.x | Nicht zutreffend | ||||
yarn | npm | v1, v2, v3 |
Tip
Für Paket-Manager wie pipenv
und poetry
musst du den YAML-Wert pip
verwenden. Wenn Sie Ihre Python-Abhängigkeiten z. B. mit poetry
verwalten und Ihre Abhängigkeitsmanifestdatei mit Dependabot für neue Versionen überwachen möchten, nutzen Sie package-ecosystem: "pip"
in Ihrer dependabot.yml
-Datei.
Weitere Informationen zur Ökosystemunterstützung für Dependabot security updates findest du auch unter Abhängigkeitsdiagramm unterstützte Paket-Ökosysteme.
Cargo
Die Unterstützung für private Registrierungen gilt für Git-Registrierungen, jedoch nicht für Cargo-Registrierungen.
Docker
Für Versionsupdates kann Dependabot Pull Requests Metadaten aus Docker-Images hinzufügen. Die Metadaten enthalten Versionshinweise, Änderungsprotokolle und den Commitverlauf. Repositoryadministratoren können die Metadaten verwenden, um das Stabilitätsrisiko des Abhängigkeitsupdates schnell auszuwerten.
Damit Dependabot Docker-Metadaten abrufen kann, müssen Verwalter von Docker-Images die org.opencontainers.image.source
-Bezeichnung ihrer Dockerfile-Datei hinzufügen und die URL des Quellrepositorys einschließen. Darüber hinaus müssen Verwalter das Repository mit den gleichen Tags versehen wie die veröffentlichten Docker-Images. Ein Beispiel dafür finden Sie im dependabot-fixtures/docker-with-source
-Repository. Weitere Informationen zu Docker-Bezeichnungen finden Sie unter Erweiterungsimagebezeichnungen und BUILDX_GIT_LABELS in der Docker-Dokumentation.
Dependabot kann Docker-Imagetags in Kubernetes-Manifesten aktualisieren. Fügen Sie dem Docker-Element package-ecosystem
Ihrer Datei vom Typ dependabot.yml
für jedes Verzeichnis, das ein Kubernetes-Manifest enthält, das auf Docker-Imagetags verweist, einen Eintrag hinzu. Kubernetes-Manifeste können YAML-Dateien oder Helm-Diagramme für die Kubernetes-Bereitstellung sein. Informationen zum Konfigurieren deiner dependabot.yml
-Datei für docker
findest du unter package-ecosystem
in Referenz zu Dependabot-Optionen.
Dependabot unterstützt sowohl öffentliche als auch private Docker-Registrierungen. Eine Liste der unterstützten Registrierungen findest du unter docker-registry
in Konfigurieren des Zugriffs auf private Registrierungen für Dependabot.
Dependabot untersucht Docker-Imagetags auf die semantische Versionierung (SemVer). Wenn Dependabot ein Tag mit einer Vorabversion erkennt, schlägt es nur ein Update auf die aktuelle Version mit einer übereinstimmenden Vorabversion vor und keine neuere Version mit einer anderen Vorabversion. Weitere Informationen finden Sie in der dependabot-docker
-README.md-Datei im dependabot/dependabot-core
-Repository.
GitHub Actions
Dependabot unterstützt Versionsupdates für GitHub Actions mit den folgenden Einschränkungen.
- Dependabot unterstützt nur Updates für GitHub Actions über die GitHub-Repository-Syntax, z. B.
actions/checkout@v4
. Dependabot ignoriert Aktionen oder wiederverwendbare Workflows, auf die lokal verwiesen wird (z. B../.github/actions/foo.yml
. ). - Docker Hub und GitHub Packages Container registry-URLs werden derzeit nicht unterstützt. Beispielsweise werden Verweise auf Docker-Containeraktionen mit
docker://
-Syntax nicht unterstützt. - Dependabot unterstützt sowohl öffentliche als auch private Repositorys für GitHub Actions. Informationen zu Konfigurationsoptionen für private Registrierungen findest du unter
git
in Referenz zu Dependabot-Optionen.
Weitere Informationen zum Verwenden von Dependabot version updates mithilfe von GitHub Actions findest du unter Verwenden der Sicherheitsfeatures von GitHub zum Sichern Ihrer Verwendung von GitHub-Aktionen.
Gradle
Dependabot führt Gradle nicht aus, unterstützt jedoch Updates folgender Dateien:
build.gradle
,build.gradle.kts
(für Kotlin-Projekte)gradle/libs.versions.toml
(für Projekte, die einen Gradle-Standardversionskatalog verwenden)- Dateien, die über die
apply
-Deklaration eingefügt wurden, diedependencies
im Dateinamen enthalten. Beachten Sie, dassapply
wederapply to
, Rekursion noch erweiterte Syntax – z. B.apply
mitmapOf
bei Kotlin oder durch Eigenschaften definierte Dateinamen – unterstützt.
Dependabot verwendet Informationen aus der pom.xml
-Datei von Abhängigkeiten, um Verknüpfungen zu Releaseinformationen in Update-Pull-Requests hinzuzufügen. Wenn die Informationen nicht in der pom.xml
-Datei enthalten sind, können sie nicht in Dependabot-Pull Requests aufgenommen werden. Weitere Informationen dazu findest du unter Optimieren von Java-Paketen für Dependabot-Updates.
Für Dependabot security updates ist Gradle-Unterstützung auf manuelle Uploads der Abhängigkeitsdiagrammdaten mit der Abhängigkeitsübermittlungs-API beschränkt. Weitere Informationen zu Abhängigkeitsübermittlungs-API findest du unter Verwenden der Abhängigkeitsübermittlungs-API.
Note
- Wenn Sie Gradle-Abhängigkeiten mithilfe der Abhängigkeitsübermittlungs-API in das Abhängigkeitsdiagramm hochladen, werden alle Projektabhängigkeiten hochgeladen, auch transitive Abhängigkeiten, die in keiner Abhängigkeitsdatei explizit erwähnt werden. Wenn eine Warnung in einer transitiven Abhängigkeit erkannt wird, können Dependabot die anfällige Abhängigkeit im Repository nicht finden und daher kein Sicherheitsupdate für diese Warnung erstellen.
- Dependabot version updates erstellt jedoch Pull Requests, wenn die übergeordnete Abhängigkeit in der Manifestdatei des Projekts explizit als direkte Abhängigkeit deklariert ist.
Maven
Dependabot führt Maven nicht aus, unterstützt jedoch Updates von pom.xml
-Dateien.
Dependabot verwendet Informationen aus der pom.xml
-Datei von Abhängigkeiten, um Verknüpfungen zu Releaseinformationen in Update-Pull-Requests hinzuzufügen. Wenn die Informationen nicht in der pom.xml
-Datei enthalten sind, können sie nicht in Dependabot-Pull Requests aufgenommen werden. Weitere Informationen dazu findest du unter Optimieren von Java-Paketen für Dependabot-Updates.
NuGet CLI
Dependabot führt die NuGet-CLI nicht aus, unterstützt aber die meisten Features bis Version 6.7.0.
pip und pip-compile
Zusätzlich zur Unterstützung von Updates von requirements.txt
-Dateien unterstützt Dependabot Updates von pyproject.toml
-Dateien, wenn sie dem PEP 621-Standard entsprechen.
pnpm
pnpm is supported for Dependabot version updates (on v7, v8, and v9) and Dependabot security updates (on v7 and v8 only).
pub
Dependabot führt kein Update für pub
aus, wenn die Version, für die ein Update durchgeführt werden soll, ignoriert wird. Dies gilt auch dann, wenn eine frühere Version verfügbar ist.
Swift
Die Unterstützung für private Registrierungen gilt nur für Git-Registrierungen. Swift-Registrierungen werden nicht unterstützt. Nicht deklarative Manifeste werden nicht unterstützt. Weitere Informationen zu nicht deklarativen Manifesten finden Sie in der Swift Evolution-Dokumentation unter Bearbeiten nicht deklarativer Manifeste.
Terraform
Terraform-Unterstützung umfasst:
- Module, die auf Terraform Registry oder einem öffentlich zugänglichen Git-Repository gehostet werden.
- Terraform-Anbieter
- Privates Terraform-Registry Sie können den Zugriff für private Git-Repositorys konfigurieren, indem Sie eine Git-Registrierung in Ihrer
dependabot.yml
-Datei voraussetzen. Weitere Informationen finden Sie untergit
.
yarn
Dependabot unterstützt Anbieterabhängigkeiten ab Version 2.