Einleitung
Copilot CLI verfügt über mehrere Konfigurationsoptionen, die steuern, auf was sie zugreifen und in Ihrem Auftrag tun kann.
In diesem Artikel erfahren Sie, wie Sie vertrauenswürdige Verzeichnisse festlegen, den Zugriff für Tools konfigurieren und Berechtigungen für Dateipfade und URLs erteilen.
Voraussetzungen
- Installieren Sie Copilot CLI. Weitere Informationen findest du unter Installieren von GitHub Copilot CLI.
Festlegen vertrauenswürdiger Verzeichnisse
Vertrauenswürdige Verzeichnisse kontrollieren, wo Copilot CLI Dateien lesen, ändern und ausführen kann. Das Vertrauen in ein Verzeichnis hat Sicherheitsauswirkungen, siehe Sicherheitsüberlegungen.
Vertrauen in ein Verzeichnis
Wenn Sie eine GitHub Copilot-CLI Sitzung starten, werden Sie aufgefordert, zu bestätigen, dass Sie den Dateien vertrauen, die sich in dem Verzeichnis befinden, aus dem Sie die CLI gestartet haben, sowie in dessen Unterverzeichnissen.
Du kannst das aktuelle Verzeichnis für Folgendes als vertrauenswürdig festlegen:
- Nur die aktuell ausgeführte Sitzung
- Diese und zukünftige Sitzungen
Wenn du das Verzeichnis für zukünftige Sitzungen als vertrauenswürdig festlegst, wird der Prompt nicht mehr für das vertrauenswürdige Verzeichnis angezeigt. Sie sollten diese zweite Option nur auswählen, wenn Sie sicher sind, dass dieser Standort immer ein sicherer Ort für Copilot den Betrieb ist.
Bearbeiten vertrauenswürdiger Verzeichnisse
Sie können die Liste der dauerhaft vertrauenswürdigen Verzeichnisse bearbeiten.
-
Öffnen Sie die CLI-Datei
config.json. Standardmäßig wird sie in einem.copilotOrdner unter Ihrem Startverzeichnis gespeichert:-
**macOS/Linux**: `~/.copilot/config.json` -
**Windows**: `$HOME\.copilot\config.json`
-
Sie können den Konfigurationsspeicherort ändern, indem Sie die COPILOT_HOME Umgebungsvariable festlegen.
- Bearbeiten Sie den Inhalt des
trusted_foldersArrays.
Festlegen zulässiger Tools
Sie können steuern, welche Tools Copilot CLI verwendet werden können, indem Sie entweder auf Genehmigungsaufforderungen reagieren, wenn Copilot versucht wird, ein Tool zu verwenden, oder indem Sie Berechtigungen über Befehlszeilenkennzeichnungen angeben.
Beachten Sie, dass das Zulassen des Toolzugriffs sicherheitsrelevante Auswirkungen hat, siehe Sicherheitsüberlegungen.
In diesem Abschnitt erfahren Sie, wie Sie:
-
[Ein Tool zum ersten Mal zulassen](#allowing-a-tool-for-the-first-time) -
[Zulassen, dass Tools ohne manuelle Genehmigung verwendet werden](#allowing-tools-to-be-used-without-manual-approval) -
[Geben Sie an, welches Tool Sie zulassen oder verweigern möchten.](#specifying-which-tool-you-want-to-allow-or-deny) -
[Zulassen einiger Tools beim Verweigern anderer Tools](#allowing-some-tools-while-denying-others) -
[Einschränken verfügbarer Tools](#limiting-available-tools)
Die erstmalige Zulassung eines Werkzeugs
Zum ersten Mal, wenn Copilot ein Tool verwenden muss, das möglicherweise eine Genehmigung erfordert—zum Beispiel Beispiel: touch, chmod, node oder sed—werden Sie gefragt, ob Sie die Ausführung zulassen möchten. Ob Sie dazu aufgefordert werden, hängt vom Tool und deren Verwendung ab (z. B. die bereitgestellten Argumente oder ob das Tool zuvor genehmigt wurde).
-
Aufforderung Copilot zum Ausführen einer Aufgabe, die ein Tool erfordert. Beispiel:
copilot -p "Create a new file called README.md with a project description" -
Wählen Sie aus einer der drei Optionen aus:
-
1. YesWählen Sie diese Option aus, damit Copilot diesen bestimmten Befehl nur dieses Mal ausführen kann. Wenn dieses Tool das nächste Mal verwendet werden muss, wirst du erneut gefragt.
-
2. Yes, and approve TOOL for the rest of the running sessionWählen Sie diese Option aus, um Copilot das Tool während der laufenden Sitzung zu verwenden. Dabei wirst du in neuen Sitzungen oder beim Fortsetzen der aktuellen Sitzung in Zukunft erneut um deine Genehmigung gebeten. Wenn Sie diese Option auswählen, erlauben Sie Copilot, dieses Tool auf jede geeignete Weise zu verwenden.
Wenn es vorkommt, dass Copilot Sie auffordert, den Befehl
rm ./this-file.txtauszuführen, und Sie Option 2 wählen, dann kann Copilot während des aktuellen Ablaufs dieser Sitzung jeden beliebigenrm-Befehl (z.B.rm -rf ./*) ausführen, ohne Ihre Genehmigung einzuholen. -
3. No, and tell Copilot what to do differently (Esc)Wählen Sie diese Option aus, um den vorgeschlagenen Befehl abzubrechen, und weisen Sie an Copilot , einen anderen Ansatz zu versuchen.
-
Zulassen der Verwendung von Tools ohne manuelle Genehmigung
Sie können Befehlszeilen-Flags verwenden, um Tools festzulegen, die Copilot ohne um Ihre Zustimmung zu bitten, verwendet werden können.
Alle Werkzeuge zulassen
Verwenden Sie --allow-all-tools, um Copilot zu gestatten, jedes Tool zu verwenden, ohne Ihre Genehmigung einzuholen.
-
Beispiel:
copilot -p "Revert the last commit" --allow-all-tools
Ein Tool verweigern
Verwenden Sie --deny-tool, um zu verhindern, dass Copilot ein bestimmtes Tool verwendet.
-
Beispiel:
copilot --deny-tool='shell(git push)'
Diese Option hat Vorrang vor den Optionen --allow-all-tools und --allow-tool.
Ein Tool zulassen
Verwenden Sie --allow-tool, damit Copilot ein bestimmtes Tool verwenden kann, ohne Ihre Genehmigung einzuholen.
-
Beispiel:
copilot --allow-tool='shell'
Angeben des Tools, das Sie zulassen oder verweigern möchten
Um die --deny-tool Optionen --allow-tool zu verwenden, müssen Sie angeben, welche Art von Tool Sie zulassen oder verweigern möchten:
-
[Shellbefehle](#allowing-or-denying-shell-commands) -
[Tools zum Schreiben](#allowing-or-denying-write-tools) -
[MCP-Servertools](#allowing-or-denying-mcp-server-tools)
Zulassen oder Verweigern von Shellbefehlen
`shell(COMMAND)` wird verwendet, um einen bestimmten Shell-Befehl zuzulassen oder zu verweigern.
-
Um beispielsweise zu verhindern, dass Copilot einen beliebigen
rm-Befehl verwendet, gehen Sie wie folgt vor:copilot --deny-tool='shell(rm)'
Geben Sie für git und gh Befehle einen bestimmten Unterbefehl der ersten Ebene an, um den Befehl zuzulassen oder zu verweigern.
-
Um zu verhindern, dass Copilot
git pushverwendet, nutzen Sie:copilot --deny-tool='shell(git push)'
Die Angabe des Tools ist optional. Indem es copilot --allow-tool='shell' erlaubt, Copilot beliebige Shell-Befehle ohne individuelle Genehmigung zu verwenden.
Zulassen oder Verweigern von 'write' Tools
Verwenden Sie 'write', um anderen Tools als Shell-Befehlen die Erlaubnis zu erteilen oder zu verweigern, Dateien zu ändern.
-
Um z. B. Copilot Dateien ohne Ihre individuelle Genehmigung bearbeiten zu können, verwenden Sie:
copilot --allow-tool='write'
Zulassen oder Verweigern von MCP-Servertools
Verwenden Sie 'MCP_SERVER_NAME', um ein bestimmtes Tool vom angegebenen MCP-Server zuzulassen oder zu verweigern.
-
Um beispielsweise zu verhindern, dass Copilot das Tool
My-MCP-Server, genannttool_name, vom MCP-Server verwendet, verwenden Sie Folgendes:copilot --deny-tool='My-MCP-Server(tool_name)'`MCP_SERVER_NAME` ist der Name eines MCP-Servers, den Sie konfiguriert haben.
Tools vom Server werden in Klammern angegeben, wobei der Toolname verwendet wird, der beim MCP-Server registriert ist.
Wenn du den Servernamen verwendest, ohne ein Tool anzugeben, werden alle Tools dieses Servers zugelassen oder verweigert.
Sie können den Namen eines MCP-Servers finden, indem Sie /mcp im interaktiven Modus von Copilot CLI eingeben und den Server aus der angezeigten Liste auswählen.
Zulassen einiger Tools beim Verweigern anderer Tools
Um genau zu bestimmen, welche Tools Copilot verwendet werden können, ohne ihre Genehmigung zu verlangen, können Sie eine Kombination aus Genehmigungsoptionen verwenden. Beispiel:
-
Um die Verwendung der Befehle
rmundgit pushzu verhindern, aber alle anderen Tools automatisch zuzulassen, verwenden Sie Folgendes:copilot --allow-all-tools --deny-tool='shell(rm)' --deny-tool='shell(git push)' -
Um zu verhindern, dass Copilot das Tool
tool_namevom MCP-Server mit dem NamenMy-MCP-Serververwendet wird, aber alle anderen Tools von diesem Server ohne individuelle Genehmigung verwendet werden können, verwenden Sie:copilot --allow-tool='My-MCP-Server' --deny-tool='My-MCP-Server(tool_name)'
Einschränken der verfügbaren Tools
Um auf eine bestimmte Gruppe von Tools zu beschränken Copilot , verwenden Sie --available-tools.
Tools, die in dieser Liste nicht enthalten sind, werden nicht zur CopilotVerfügung stehen.
Festlegen von Pfadberechtigungen
Pfadberechtigungen steuern, auf welche Verzeichnisse und Dateien Copilot zugreifen kann.
Standardmäßig kann Copilot CLI auf das aktuelle Arbeitsverzeichnis, seine Unterverzeichnisse und das Systemtemp-Verzeichnis zugreifen.
Pfadberechtigungen gelten für Shell-Befehle, Dateivorgänge (erstellen, bearbeiten, anzeigen) und Suchtools (wie z. B. grep und Glob-Muster). Bei Shellbefehlen werden Pfade heuristisch extrahiert, indem Befehlstext tokenisiert und Token identifiziert werden, die wie Pfade aussehen.
Warnung
Die Pfaderkennung für Shellbefehle hat Einschränkungen:
- Pfade, die in komplexe Shellkonstrukte eingebettet sind, werden möglicherweise nicht erkannt.
- Nur eine bestimmte Gruppe von Umgebungsvariablen wird erweitert (
HOME,TMPDIR, undPWDähnlich). Benutzerdefinierte Variablen wie$MY_PROJECT_DIRwerden nicht erweitert und möglicherweise nicht korrekt validiert. - Symlinks werden für vorhandene Dateien aufgelöst, aber nicht für Dateien, die erstellt werden.
Zugriff auf alle Pfade zulassen
Um die Pfadüberprüfung zu deaktivieren und den Zugriff auf einen beliebigen Pfad zuzulassen, verwenden Sie das --allow-all-paths Kennzeichen beim Starten Copilot CLI.
Zugriff auf das temporäre Verzeichnis aufheben
Um den Zugriff auf das temporäre Verzeichnis zu verbieten, verwenden Sie --disallow-temp-dir.
Festlegen von URL-Berechtigungen
URL-Berechtigungen steuern, auf welche externen URLs Copilot zugreifen darf. Standardmäßig erfordern alle URLs eine Genehmigung, bevor der Zugriff gewährt wird.
URL-Berechtigungen gelten für das web_fetch Tool und eine kuratierte Liste von Shellbefehlen, die auf das Netzwerk zugreifen (z. B. curl, wget und fetch). Für Shellbefehle werden URLs mithilfe von regex-Mustern extrahiert.
Warnung
Die URL-Erkennung für Shellbefehle hat Einschränkungen:
- URLs in Dateiinhalten, Konfigurationsdateien oder Umgebungsvariablen, die von Befehlen gelesen werden, werden nicht erkannt.
- Verschleierte URLs (z. B. geteilte Zeichenfolgen oder Escapesequenzen) werden möglicherweise nicht erkannt.
- HTTP und HTTPS werden als unterschiedliche Protokolle behandelt und erfordern eine separate Genehmigung.
URL-Berechtigungen können für die Sitzung oder dauerhaft beibehalten werden.
Deaktivieren der URL-Überprüfung
Um die URL-Überprüfung zu deaktivieren, verwenden Sie das --allow-all-urls Flag.
Vorabgenehmigung bestimmter Domänen
Um bestimmte Domänen vorab zu genehmigen, verwenden Sie --allow-url=DOMAIN.
- Beispiel:
--allow-url=github.com.
Verweigern bestimmter Domänen
Um bestimmte Domänen zu verweigern, verwenden Sie --deny-url=DOMAIN.
- Beispiel:
--deny-url=github.com.
Alle Tools, Pfade und URLs zulassen
Um alle Tools, Pfade und URLs zuzulassen, verwenden Sie --allow-all oder dessen Alias --yolo.
Dieses Kennzeichen kombiniert:
*
--allow-all-tools (Toolgenehmigung überspringen).
*
--allow-all-paths (Pfadüberprüfung deaktivieren).
*
--allow-all-urls (deaktiviert die URL-Überprüfung).
Tipp
Während einer interaktiven Sitzung können Sie auch alle Berechtigungen mit den Schrägstrichbefehlen /allow-all oder /yolo aktivieren.
Weiterführende Lektüre
-
[AUTOTITLE](/copilot/how-tos/copilot-cli/customize-copilot) -
[AUTOTITLE](/copilot/reference/copilot-cli-reference/cli-config-dir-reference)