When it come about IT, git cannot to be ignore… even for an infrastructure guys!

The bad Surprise

Few days ago, I was wondering why my commits are not counted in my Github Activity Dashboard after a good day of pushing code… After a quick investigation, I notice that in my project directory git config user.name and git config user.email are not set. I go in Github to checks my last commit, actually it’s right my push was done with the git config --global user.name. Not a big deal, but this reveal my name when I would rather appreciate to stay anonymous (just a personnal choice).

A good Solution

I developed a while ago, a tools name AnsiColt to handle the creation of Ansible Collections and manage the diverses projects that I maintain through all my repositories which are divided between Github and GitLab repositories.

One of my hassle is that I am involved in projects stored on diverse SVC as Github or Gitlab. During cloning process, I did not immediatly set the user individually for each projects, so instead of, it was reling on the global config.

Here is the joy of coding, Continously Integration and the good opportunity to kickstart my blog on some banal stories…

And an Opportunity…

Let’s make a small reminder on some basics about git! There are plenty of article, tutorials on the Net but this article is going to be my personnal notes on the topics.

Each project local or hosted have a hidden directory .git with its own .git/config but you also got in your home directory an .gitconfig which is global. So when in the .git/config of your project, it does not find the user and email, it get the global one from ~/.gitconfig or ask you to set it up. This can become relevant when you are handling a lot of projects between different repositories publics and on premise.

So usually, you will have to setup:

 1# Setup
 2cd ~/my_project
 3git config user.name "john.smith"
 4git config user.email "john.smith@example.com"
 5
 6# Check
 7git config user.name
 8git config user.email
 9
10git config --global user.name
11git config --global user.email

Git with a Github projects

As you probably know, there is three method to connect to a github project with git, SSH, HTTPS and gh.

SSH will go through port 22. This make look obvious way to go but sometime in your company and specially if you work on a VPN, the port 22 will be block to outbound network.

HTTPS have one advantage, it is that you will probably always be able to clone.

1git clone https://github.com/MozeBaltyk/mozebaltyk.github.io.git

Ok but Github.com decided to block password method. So you will need to initiate a connexion first with GH so you can get a token as describe below:

 1gh auth login 
 2
 3gh auth status -t 
 4github.com
 5  ✓ Logged in to github.com as MozeBaltyk (~/.config/gh/hosts.yml)
 6  ✓ Git operations for github.com configured to use ssh protocol.
 7  ✓ Token: gho_*******************************
 8  ✓ Token scopes: admin:public_key, gist, read:org, repo
 9
10# And give the token everytime, you want to push... (Password is not what you think, it's expecting the Token)
11git push                                                                                                                                           
12Username for 'https://github.com': MozeBaltyk
13Password for 'https://MozeBaltyk@github.com':
14Enumerating objects: 21, done.
15Counting objects: 100% (21/21), done.
16Delta compression using up to 8 threads
17Compressing objects: 100% (10/10), done.
18Writing objects: 100% (11/11), 1.44 KiB | 736.00 KiB/s, done.
19Total 11 (delta 7), reused 0 (delta 0), pack-reused 0
20remote: Resolving deltas: 100% (7/7), completed with 7 local objects.
21remote: This repository moved. Please use the new location:
22remote:   https://github.com/MozeBaltyk/mozebaltyk.github.io.git
23To https://github.com/mozebaltyk/mozebaltyk.github.io.git
24   26a5e21b..ab53b64f  main -> main

This one used to work but I think not anymore (I should try it)

1#Connect with token 
2git config --global url."https://${username}:${access_token}@github.com".insteadOf "https://github.com"

But the best is to switch to SSH (if you can) which allow you to set a ssh key. So if you need to switch from HTTPS to SSH

 1# at project level
 2git remote set-url origin git@github.com:MozeBaltyk/abc.git
 3
 4# in the project's .git/config, then you should have:
 5[remote "origin"]
 6        url = git@github.com:MozeBaltyk/mozebaltyk.github.io.git
 7
 8# at the global level
 9git config --global url.ssh://git@github.com/.insteadOf https://github.com/
10
11# or local
12cd my_project
13git config url.ssh://git@github.com/.insteadOf https://github.com/

Then configure which ssh key to use for Github in $HOME/.ssh/config (create directory/file if necessary)

1# Github
2Host github.com
3  HostName github.com
4  User git
5  IdentityFile ~/.ssh/id_ed25519
6  IdentitiesOnly yes

The top is to use gh which is the github-cli tools for handling github projects. So it’s noticable that github prefers SSH protocol over HTTPS.

 1# Cloning with GH  (usually SSH as default protocol in your ~/.config/gh/config.yml):
 2gh repo clone MozeBaltyk/MozeBaltyk
 3
 4# If you target a specific Github:
 5GH_HOST=github.example.com gh repo clone MozeBaltyk/MozeBaltyk
 6
 7# gh clone https is also possible:
 8gh repo clone https://github.com/MozeBaltyk/mozebaltyk.github.io.git
 9
10#Same as above in https
11gh repo clone git+https://github.com/MozeBaltyk/MozeBaltyk.git

The logic is exactly the same with glab-cli, the CLI version for GitLab.

Now AnsiColt

Here come the time to improve a bit AnsiColt with what I have learnt. So when I start or clone a project either in Gitlab or Github, I make sure that git config -local user.name and git config -local user.email are confgiure for the project. To do so, I need to get the info from somewhere…

  • for Github ~/.config/gh/hosts.yml:
1github.com:
2  oauth_token: gho_******************
3  user: MozeBaltyk
4  git_protocol: ssh
5  email: john@example.com
  • for Gitlab have one config file ~/.config/glab-cli/config.yml:
1hosts:
2    gitlab.example.com:
3        token: **************
4        api_host: gitlab.example.com
5        git_protocol: https
6        api_protocol: https
7        user: john
8        email: john.doe@gg.com

By default email value does not exist on those config files. so If I do not find it, I will add it. Doing this, allow me to get the settings for all future repos cloning or creations.

Bonus point

For those who read till the end, gitmoji is an Art.