CircleCI Security
Lerne & übe AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE) Lerne & übe GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)
Grundinformationen
CircleCI ist eine Continuous Integration-Plattform, auf der du Vorlagen definieren kannst, die angeben, was du mit einem Code tun möchtest und wann. So kannst du Tests oder Deployments direkt aus deinem Repo-Master-Branch automatisieren.
Berechtigungen
CircleCI erbt die Berechtigungen von GitHub und Bitbucket, die mit dem Konto verbunden sind, das sich anmeldet. In meinen Tests habe ich überprüft, dass du, solange du Schreibberechtigungen für das Repo in GitHub hast, in der Lage bist, die Projekteinstellungen in CircleCI zu verwalten (neue SSH-Schlüssel festzulegen, Projekt-API-Schlüssel zu erhalten, neue Branches mit neuen CircleCI-Konfigurationen zu erstellen...).
Du musst jedoch ein Repo-Administrator sein, um das Repo in ein CircleCI-Projekt umzuwandeln.
Umgebungsvariablen & Geheimnisse
Laut den Dokumenten gibt es verschiedene Möglichkeiten, Werte in Umgebungsvariablen innerhalb eines Workflows zu laden.
Eingebaute Umgebungsvariablen
Jeder von CircleCI ausgeführte Container hat immer spezifische Umgebungsvariablen, die in der Dokumentation definiert sind wie CIRCLE_PR_USERNAME
, CIRCLE_PROJECT_REPONAME
oder CIRCLE_USERNAME
.
Klartext
Du kannst sie im Klartext innerhalb eines Befehls deklarieren:
Sie können sie im Klartext innerhalb der run environment deklarieren:
Sie können sie im Klartext innerhalb der build-job environment deklarieren:
Sie können sie im Klartext innerhalb der Umgebung eines Containers deklarieren:
Projektgeheimnisse
Dies sind Geheimnisse, die nur vom Projekt (von irgendeinem Branch) zugänglich sind. Sie können sie deklariert in https://app.circleci.com/settings/project/github/<org_name>/<repo_name>/environment-variables sehen.
Die Funktionalität "Variablen importieren" ermöglicht es, Variablen aus anderen Projekten in dieses zu importieren.
Kontextgeheimnisse
Dies sind Geheimnisse, die organisationsweit sind. Standardmäßig kann jedes Repo auf jedes Geheimnis zugreifen, das hier gespeichert ist:
Beachten Sie jedoch, dass eine andere Gruppe (anstatt aller Mitglieder) ausgewählt werden kann, um den Zugriff auf die Geheimnisse nur bestimmten Personen zu gewähren. Dies ist derzeit eine der besten Möglichkeiten, um die Sicherheit der Geheimnisse zu erhöhen, indem nicht jeder Zugriff darauf hat, sondern nur einige Personen.
Angriffe
Suche nach Klartextgeheimnissen
Wenn Sie Zugriff auf das VCS (wie GitHub) haben, überprüfen Sie die Datei .circleci/config.yml
von jedem Repo in jedem Branch und suchen Sie nach potenziellen Klartextgeheimnissen, die dort gespeichert sind.
Geheim-Umgebungsvariablen & Kontextenumeration
Durch Überprüfung des Codes können Sie alle Geheimnisnamen finden, die in jeder .circleci/config.yml
-Datei verwendet werden. Sie können auch die Kontextnamen aus diesen Dateien abrufen oder sie in der Webkonsole überprüfen: https://app.circleci.com/settings/organization/github/<org_name>/contexts.
Exfiltrieren von Projektgeheimnissen
Um ALLE Projekt- und Kontext-GEHEIMNISSE zu exfiltrieren, müssen Sie nur SCHREIBZUGRIFF auf nur 1 Repo in der gesamten GitHub-Organisation haben (und Ihr Konto muss Zugriff auf die Kontexte haben, aber standardmäßig kann jeder auf jeden Kontext zugreifen).
Die Funktionalität "Variablen importieren" ermöglicht es, Variablen aus anderen Projekten in dieses zu importieren. Daher könnte ein Angreifer alle Projektvariablen aus allen Repos importieren und dann alle zusammen exfiltrieren.
Alle Projektgeheimnisse werden immer in der Umgebung der Jobs festgelegt, sodass das einfache Aufrufen von env und das Obfuskieren in base64 die Geheimnisse in der Webprotokollkonsole der Workflows exfiltriert:
Wenn Sie keinen Zugriff auf die Webkonsole haben, aber Zugriff auf das Repo haben und wissen, dass CircleCI verwendet wird, können Sie einfach einen Workflow erstellen, der jede Minute ausgelöst wird und der die Geheimnisse an eine externe Adresse exfiltriert:
Exfiltriere Kontextgeheimnisse
Du musst den Kontextnamen angeben (dies wird auch die Projektgeheimnisse exfiltrieren):
Wenn Sie keinen Zugriff auf die Webkonsole haben, aber Zugriff auf das Repository haben und wissen, dass CircleCI verwendet wird, können Sie einfach einen Workflow ändern, der jede Minute ausgelöst wird und der die Geheimnisse an eine externe Adresse exfiltriert:
Das Erstellen einer neuen .circleci/config.yml
in einem Repo reicht nicht aus, um einen CircleCI-Build auszulösen. Sie müssen es als Projekt in der CircleCI-Konsole aktivieren.
Escape to Cloud
CircleCI bietet Ihnen die Möglichkeit, Ihre Builds auf ihren Maschinen oder auf Ihren eigenen auszuführen. Standardmäßig befinden sich ihre Maschinen in GCP, und anfangs werden Sie nichts Relevantes finden können. Wenn ein Opfer jedoch die Aufgaben auf seinen eigenen Maschinen (möglicherweise in einer Cloud-Umgebung) ausführt, könnten Sie einen Cloud-Metadaten-Endpunkt mit interessanten Informationen darauf finden.
Beachten Sie, dass in den vorherigen Beispielen alles innerhalb eines Docker-Containers gestartet wurde, aber Sie können auch bitten, eine VM-Maschine zu starten (die möglicherweise unterschiedliche Cloud-Berechtigungen hat):
Oder sogar ein Docker-Container mit Zugriff auf einen Remote-Docker-Dienst:
Persistenz
Es ist möglich, Benutzertokens in CircleCI zu erstellen, um auf die API-Endpunkte mit dem Zugriff des Benutzers zuzugreifen.
https://app.circleci.com/settings/user/tokens
Es ist möglich, Projekttokens zu erstellen, um auf das Projekt mit den dem Token gegebenen Berechtigungen zuzugreifen.
https://app.circleci.com/settings/project/github/<org>/<repo>/api
Es ist möglich, SSH-Schlüssel zu den Projekten hinzuzufügen.
https://app.circleci.com/settings/project/github/<org>/<repo>/ssh
Es ist möglich, einen Cron-Job in einem versteckten Branch in einem unerwarteten Projekt zu erstellen, der jeden Tag alle Kontext-Umgebungsvariablen leakt.
Oder sogar in einem Branch zu erstellen / einen bekannten Job zu modifizieren, der jeden Tag alle Kontext- und Projektheimlichkeiten leakt.
Wenn Sie ein GitHub-Besitzer sind, können Sie unverifizierte Orbs zulassen und einen in einem Job als Hintertür konfigurieren.
Sie können eine Befehlsinjektionsanfälligkeit in einigen Aufgaben finden und Befehle über ein Geheimnis injizieren, indem Sie dessen Wert ändern.
Lernen & üben Sie AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE) Lernen & üben Sie GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)
Last updated