Gh: Difference between revisions

From NovaOrdis Knowledge Base
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=
==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:
<syntaxhighlight lang='bash'>
gh auth setup-git [--hostname enterprise.internal]
</syntaxhighlight>
==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/