Gh: Difference between revisions
Jump to navigation
Jump to search
(9 intermediate revisions by the same user not shown) | |||
Line 12: | Line 12: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
==Linux== | ==Linux== | ||
===With <tt>dnf</tt>=== | |||
<syntaxhighlight lang='bash'> | <syntaxhighlight lang='bash'> | ||
sudo dnf install -y 'dnf-command(config-manager)' | sudo dnf install -y 'dnf-command(config-manager)' | ||
sudo dnf config-manager --add-repo https://cli.github.com/packages/rpm/gh-cli.repo | sudo dnf config-manager --add-repo https://cli.github.com/packages/rpm/gh-cli.repo | ||
sudo dnf install -y gh | sudo dnf install -y gh | ||
</syntaxhighlight> | |||
===Download Release Binaries=== | |||
<syntaxhighlight lang='bash'> | |||
wget https://github.com/cli/cli/releases/download/v2.9.0/gh_2.9.0_linux_amd64.rpm | |||
rpm -i gh_2.9.0_linux_amd64.rpm | |||
</syntaxhighlight> | </syntaxhighlight> | ||
=Authentication= | =Authentication= | ||
==Authentication Status== | ==Authentication Status== | ||
<syntaxhighlight lang='bash'> | <syntaxhighlight lang='bash'> | ||
Line 34: | Line 35: | ||
<syntaxhighlight lang='bash'> | <syntaxhighlight lang='bash'> | ||
gh auth login --hostname github.mycompany.com status --with-token < mytoken.txt | gh auth login --hostname github.mycompany.com status --with-token < mytoken.txt | ||
gh auth login --hostname github.mycompany.com status --with-token <<< "55...a8" | |||
</syntaxhighlight> | |||
==Configure Git to Use <tt>gh</tt> as Credential Helper== | |||
<code>gh</code> repository cloning commands, and probably others, will continue to challenge for username and password, unless <code>git</code> is configured to use <code>gh</code> as credential helper. | |||
⚠️ Note that this command must be executed '''after''' login. | |||
<syntaxhighlight lang='bash'> | |||
gh auth setup-git [--hostname enterprise.internal] | |||
</syntaxhighlight> | </syntaxhighlight> | ||
Line 44: | Line 55: | ||
<syntaxhighlight lang='bash'> | <syntaxhighlight lang='bash'> | ||
gh repo clone <org>/<repo-name> | gh repo clone <org>/<repo-name> | ||
</syntaxhighlight> | |||
==Full Sequence of Operations for Cloning, Including Authentication== | |||
<syntaxhighlight lang='bash'> | |||
gh auth login --hostname github.mycompany.com status --with-token < mytoken.txt | |||
gh auth setup-git --hostname github.mycompany.com | |||
gh repo clone <org>/<repo-name> | |||
</syntaxhighlight> | |||
==Troubleshooting== | |||
===git@github.mycompany.com: Permission denied (publickey)=== | |||
Caused by the presence of <code>~/.gitconfig</code> with the following content: | |||
<syntaxhighlight lang='text'> | |||
url "git@github.mycompany.com:"] | |||
insteadOf = https://github.mycompany.com/ | |||
</syntaxhighlight> | </syntaxhighlight> |
Latest revision as of 06:29, 3 May 2022
External
Internal
Overview
GitHub-specific CLI. Can be used to authenticate, clone repositories, etc.
Installation
Mac
brew install gh
Linux
With dnf
sudo dnf install -y 'dnf-command(config-manager)'
sudo dnf config-manager --add-repo https://cli.github.com/packages/rpm/gh-cli.repo
sudo dnf install -y gh
Download Release Binaries
wget https://github.com/cli/cli/releases/download/v2.9.0/gh_2.9.0_linux_amd64.rpm
rpm -i gh_2.9.0_linux_amd64.rpm
Authentication
Authentication Status
gh auth status --hostname enterprise.internal --show-token
Authenticate with a Personal Access Token
gh auth login --hostname enterprise.internal --with-token < mytoken.txt
gh auth login --hostname github.mycompany.com status --with-token < mytoken.txt
gh auth login --hostname github.mycompany.com status --with-token <<< "55...a8"
Configure Git to Use gh as Credential Helper
gh
repository cloning commands, and probably others, will continue to challenge for username and password, unless git
is configured to use gh
as credential helper.
⚠️ Note that this command must be executed after login.
gh auth setup-git [--hostname enterprise.internal]
Logout
gh auth --hostname github.mycompany.com logout
Clone Repository
gh repo clone <org>/<repo-name>
Full Sequence of Operations for Cloning, Including Authentication
gh auth login --hostname github.mycompany.com status --with-token < mytoken.txt
gh auth setup-git --hostname github.mycompany.com
gh repo clone <org>/<repo-name>
Troubleshooting
git@github.mycompany.com: Permission denied (publickey)
Caused by the presence of ~/.gitconfig
with the following content:
url "git@github.mycompany.com:"]
insteadOf = https://github.mycompany.com/