Summary
A security vulnerability has been identified in the GitHub CLI that could leak authentication tokens when cloning repositories containing git
submodules hosted outside of github.com and ghe.com.
Details
This vulnerability stems from several gh
commands used to clone a repository with submodules from a non-GitHub host including gh repo clone
, gh repo fork
, gh pr checkout
. These GitHub CLI commands invoke git
with instructions to retrieve authentication tokens using the credential.helper
configuration variable for any host encountered.
Prior to 2.63.0
, hosts other than github.com and ghe.com are treated as GitHub Enterprise Server hosts and have tokens sourced from the following environment variables before falling back to host-specific tokens stored within system-specific secured storage:
GITHUB_ENTERPRISE_TOKEN
GH_ENTERPRISE_TOKEN
GITHUB_TOKEN
when CODESPACES
environment variable is set
The result being git
sending authentication tokens when cloning submodules.
In 2.63.0
, these GitHub CLI commands will limit the hosts for which gh
acts as a credential helper to source authentication tokens. Additionally, GITHUB_TOKEN
will only be used for github.com and ghe.com.
Impact
Successful exploitation could lead to a third-party using leaked authentication tokens to access privileged resources.
Remediation and mitigation
- Upgrade
gh
to 2.63.0
- Revoke authentication tokens used with the GitHub CLI:
- Review your personal security log and any relevant audit logs for actions associated with your account or enterprise
References
Summary
A security vulnerability has been identified in the GitHub CLI that could leak authentication tokens when cloning repositories containing
git
submodules hosted outside of github.com and ghe.com.Details
This vulnerability stems from several
gh
commands used to clone a repository with submodules from a non-GitHub host includinggh repo clone
,gh repo fork
,gh pr checkout
. These GitHub CLI commands invokegit
with instructions to retrieve authentication tokens using thecredential.helper
configuration variable for any host encountered.Prior to
2.63.0
, hosts other than github.com and ghe.com are treated as GitHub Enterprise Server hosts and have tokens sourced from the following environment variables before falling back to host-specific tokens stored within system-specific secured storage:GITHUB_ENTERPRISE_TOKEN
GH_ENTERPRISE_TOKEN
GITHUB_TOKEN
whenCODESPACES
environment variable is setThe result being
git
sending authentication tokens when cloning submodules.In
2.63.0
, these GitHub CLI commands will limit the hosts for whichgh
acts as a credential helper to source authentication tokens. Additionally,GITHUB_TOKEN
will only be used for github.com and ghe.com.Impact
Successful exploitation could lead to a third-party using leaked authentication tokens to access privileged resources.
Remediation and mitigation
gh
to2.63.0
References