• Stars
    star
    269
  • Rank 152,662 (Top 4 %)
  • Language
    Go
  • License
    Apache License 2.0
  • Created about 2 years ago
  • Updated about 1 year ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

A Git credential helper that securely authenticates to GitHub, GitLab and BitBucket using OAuth.

git-credential-oauth

No more passwords! No more personal access tokens! No more SSH keys!

git-credential-oauth is a Git credential helper that securely authenticates to GitHub, GitLab, BitBucket and Gerrit using OAuth.

The first time you authenticate, the helper opens a browser window to the host. Subsequent authentication within storage lifetime is non interactive.

Motivation

Git assumes users can type a password from memory, but hosts such as GitHub no longer accept passwords without two-factor authentication. Personal access tokens are easy enough to copy and paste but awkward to store securely. git-credential-cache works well for passwords but not personal access tokens because the token is lost when the cache expires. All in all, the usability is so poor that the most popular advice on StackOverflow is to insecurely save credentials in plaintext!

OAuth has multiple advantages over personal access tokens or SSH:

Advantage OAuth Personal access token SSH
Clone public repo without setup ✓ ✓ 🗙
Authenticate to popular hosts without setup ✓ 🗙 🗙
Server authenticity verified automatically ✓ ✓ 🗙
Protections against token theft1 ✓ 🗙 only if key has passphrase

Installation

Download binary from https://github.com/hickford/git-credential-oauth/releases.

Then test that Git can find the application:

git credential-oauth

If you have problems, make sure that the binary is located in the path and is executable.

Linux

Several Linux distributions include a git-credential-oauth package including Fedora, Debian and Ubuntu.

Packaging status

macOS

Homebrew

macOS users can install from Homebrew:

brew install git-credential-oauth

MacPorts

macOS users can alternatively install via MacPorts:

sudo port install git-credential-oauth

Go users

Go users can install the latest release to ~/go/bin with:

go install github.com/hickford/git-credential-oauth@latest

Configuration

As a convenience, you can run:

git credential-oauth configure

This uses the recommended config below.

How it works

Git is cleverly designed to support multiple credential helpers. To fill credentials, Git calls each helper in turn until it has the information it needs. git-credential-oauth is a read-only credential-generating helper, designed to be configured in combination with a storage helper.

To configure together with git-credential-cache:

git config --global --unset-all credential.helper
git config --global --add credential.helper "cache --timeout 7200" # two hours
git config --global --add credential.helper oauth

You may choose a different storage helper such as osxkeychain, wincred or libsecret, but git-credential-oauth must be configured last. This ensures Git checks for stored credentials before generating new credentials.

Windows users must use storage helper wincred because git-credential-cache isn't available on Windows.

Manual config

Edit your global git config ~/.gitconfig to include the following lines:

[credential]
	helper = cache --timeout 7200	# two hours
	helper = oauth

Browserless systems

On systems without a web browser, set the -device flag to authenticate on another device using OAuth device flow. Currently only GitHub supports this flow.

[credential]
	helper = cache --timeout 7200	# two hours
	helper = oauth -device

Unconfiguration

Edit ~/.gitconfig manually, or run:

git config --global --unset-all credential.helper oauth

Custom hosts

To use with a custom host, eg. gitlab.example.com:

  1. Register an OAuth application on the host. The GitLab instructions are typical.
    • Specify name git-credential-oauth
    • Specify redirect URI http://127.0.0.1.
    • Select scopes for read and write Git operations.
  2. Adjust the config commands below with the generated client id and space-separated scopes.
  3. Share the config commands with colleagues so they can skip the registration step.
git config --global credential.https://gitlab.example.com.oauthClientId <CLIENTID>
git config --global credential.https://gitlab.example.com.oauthScopes read_repository write_repository
git config --global credential.https://gitlab.example.com.oauthAuthURL /oauth/authorize
git config --global credential.https://gitlab.example.com.oauthTokenURL /oauth/token

Would you like to see universal GitLab support? *Vote for GitLab issue #374172.

Philosophy

  • Do one thing well, namely OAuth authentication.
  • Interoperate with other credential helpers.
  • Contribute upstream to improve the ecosystem.

Comparison with Git Credential Manager

Git Credential Manager (GCM) is an excellent credential helper with broader functionality. However because it's developed in .NET, GCM is prohibitively difficult for Linux distributions to package.

Git Credential Manager git-credential-oauth
Cross platform ✓ ✓
Linux arm64 support 🗙 ✓
Packaged in Linux distributions 🗙 ✓ (many)
Installation size (Linux) 82 MB 5 MB
Installation size (Windows) 4 MB 5 MB
Ships with Git for Windows ✓ 🗙
Credential storage In built Used together with any storage helper
Development .NET Go
Lines of code 40,000 400
Minimum HTTP requests 1 0
Authentication to Azure DevOps ✓ 🗙 (try git-credential-azure)
Hosts with default config 4 12

The maintainer personally uses GCM on Windows and git-credential-oauth on Linux.

Development

Install locally with go install ..

Debugging

Use the -verbose flag to print more details:

git config --global --unset-all credential.helper oauth
git config --global --add credential.helper "oauth -verbose"

You can also test git-credential-oauth in isolation:

echo host=gitlab.com\nprotocol=https | git-credential-oauth -verbose get

You can test configured helpers in combination with git credential fill, eg.

echo url=https://gitlab.com | git credential fill

To see which helpers Git calls, set export GIT_TRACE=1.

See also

Footnotes

  1. Scenario: an old disk backup is leaked. ↩

More Repositories

1

codejam

My solutions to Google Code Jam, and a library of helper functions, codejamhelpers
Python
77
star
2

libdatrie

Unofficial mirror of libdatrie from http://linux.thai.net/svn/software/datrie/
C
9
star
3

imgurgitate

Download Imgur albums to disk. Download all of a Redditor's albums to disk.
CoffeeScript
4
star
4

xkb-keyboard-layouts-for-chrome-os

Chrome OS extension to enable all XKB layouts.
Python
4
star
5

git-credential-azure

A Git credential helper for Azure Repos
Go
3
star
6

nutake

A Google Chrome extension to make it easier to download .nupkg package files from nuget.org
CoffeeScript
3
star
7

shenzhen-solitaire-solver

Backtracking solver for solitaire game in Shenzhen I/O
Python
2
star
8

codeeval-solutions

Solutions to algorithm puzzles from https://www.codeeval.com/open_challenges/
Python
2
star
9

hangman

A hangman game with an underhand AI.
Python
2
star
10

soma-cube-solver

Backtracking algorithm to solve Soma cube-style assembly puzzles
Python
2
star
11

counties-quiz

Game to learn the whereabouts of the English counties
JavaScript
2
star
12

ghost

Solver for the word game ghost
Ruby
2
star
13

Trinity-menus

Downloads hall menus from Trinity College Cambridge's Catering Department and prints the current day's meals.
Python
2
star
14

xkb_ldml

LDML keyboard mappings for XKB layouts
HTML
2
star
15

xkb-layout-explorer

xkeyboard-config layout explorer
HTML
2
star
16

debian-git

Mirror of https://repo.or.cz/git/debian.git
1
star
17

grep

Web app for searching the English dictionary
Ruby
1
star
18

undiluted

A 'hello world' app written in 100% CoffeeScript.
CoffeeScript
1
star
19

microbit-dummy-python-api

A dummy Python implementation of the microbit module for MicroPython.
Python
1
star
20

how-strong-is-my-password

A password strength estimation webpage
HTML
1
star