Setup the GitHub CLI
Installation
The easiest way to install the GitHub CLI (henceforth gh
) under Linux or Mac is to use Homebrew:
🚀 ~ brew install gh
Under Linux, gh
is also available via snapd
on the edge
channel (dev builds).
🚀 ~ sudo snap install --edge gh
And under Windows, we can just use the MSI Installer.
Other installation instructions and methods are available at cli.github.com/manual/installation.
Â
Authentication
Before using the gh
, first, we need to authenticate in GitHub. To do that we run the following command in the terminal:
🚀 ~ gh auth login
We see that gh
wants us to choose between the Github.com account and the Github Enterprise Server account. The first one is a regular account we use to work in GitHub. Besides this, GitHub offers enterprise services, and the Github Enterprise Server account refers to that. See the page.
data:image/s3,"s3://crabby-images/fb5d0/fb5d0a17c62677ec27bc0c5e85a8f00cf4c356a0" alt="gh auth login - q1"
For now, let’s choose a regular Github.com account. The next step requires us to choose an authentication method, either via a web browser or via an authentication token.
data:image/s3,"s3://crabby-images/5babe/5babed4b8eb08aa405dc955945ac2fcfa98c6ace" alt="gh auth login - q2"
Â
1. Login with a web browser
The first method will provide us one-time code which we should paste on the GitHub authentication page located at github.com/login/device. This will authorize our device and it will be able to access our gists, teams, and repositories.
data:image/s3,"s3://crabby-images/9312a/9312a90c0f4a4be787e924084c270c0e61fceaf2" alt="gh auth device - 1"
If everything runs smoothly, we’ll see the Authentication complete
message in the terminal.
data:image/s3,"s3://crabby-images/df21e/df21e1532520d438cfa868a4e446a9b8cbfbebb7" alt="gh auth device - 2"
2. Login with an authentication token
The second login method can be achieved by generating a personal authentication token in GitHub. To do that, we should go to github.com/settings/tokens.
data:image/s3,"s3://crabby-images/a4448/a44487cd1da07901a7d2b62c5dcbae0ccfcf7c9a" alt="gh auth token - 1"
Once we click on the “Generate new token” button, a new window will open where we should describe the token and choose the permission scopes. GitHub CLI requires us to have at minimum repo
and read:org
permission scopes.
data:image/s3,"s3://crabby-images/febe6/febe6998338928244f4230c6d359328c2a27fa38" alt="gh auth token - 3"
We can now copy our newly generated token and paste it in the terminal.
data:image/s3,"s3://crabby-images/ef414/ef414e22801469bb858ba8c86847cb1d3d4460ab" alt="gh auth token - 4"
Â
The last step: choosing a git protocol
Now, when we are authorized either via a web browser or an auth token, we can move to the last step, where we choose a Git protocol being used to interact with the GitHub host. We have two options there: HTTPS and SSH. I prefer to use SSH. If everything runs smoothly, we’ll be able to verify that we are logged in by running:
🚀 ~ gh auth status
data:image/s3,"s3://crabby-images/7edaa/7edaa735bb68856dec19d1cead3d79dbea2829a4" alt="gh auth status"
Â
Whola! The setup is finished now. Phew… 🥴