Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/arunanshub/git-credential-netconf

Git credentials management made easy.
https://github.com/arunanshub/git-credential-netconf

git git-credential-helper

Last synced: 2 months ago
JSON representation

Git credentials management made easy.

Awesome Lists containing this project

README

        

# git-credential-netconf

[![Upload Python Package](https://github.com/arunanshub/git-credential-netconf/actions/workflows/python-publish.yml/badge.svg)](https://github.com/arunanshub/git-credential-netconf/actions/workflows/python-publish.yml)

Git credentials management made easy.

# Installation

Use `pip` or `pip3` to install `git-credential-netconf`

```bash
pip install git-credential-netconf
```

or

```bash
pip3 install git-credential-netconf
```

# Introduction

Credential management in Git should not be difficult to use or configure, but
(unfortunately) looking at the existing tools, it is difficult to even think
about it, let alone configure them without errors.

**NOT. ANY. MORE!**

Presenting `git-credential-netconf`, an easy yet powerful way to manage your
Git credentials by harnessing the power of **GnuPG!**

# Usage Overview

The following guide assumes you have a GPG key and you have installed `git-credential-netconf`.

1. Create a `.netconf` file in your home directory.

```bash
touch ~/.netconf
```

2. Start by filling in your username and password:

```ini
[conf]
login = yourname
password = very-secret-password
```

**The `.netconf` file uses configuration file format.**

[Read more about `.netconf` file.](#about-netconf-file)

3. Encrypt your `.netconf` file with `gpg`

```bash
gpg --recipient [email protected] --output ~/.netconf.gpg --encrypt \
--sign ~/.netconf
```

1. And remove your original `.netconf` for security:

```bash
shred -u ~/.netconf
```

4. Tell Git to use it

**⚠️ Make sure that `~/.local/bin` is in `$PATH`**

```bash
git config --global credential.helper 'netconf --debug'
```

[Read more about flags for `git-credential-netconf` here.](#usage-details)

5. Now use git without hassle!

```bash
git push
```

This will prompt `git-credential-netconf` to decrypt the `~/.netconf` file
using `GPG` and fetch the `username` and `password`, among other values.

You'll be asked for the password to `GPG` private key when decrypting.

# Usage Details

```none
usage: git-credential-netconf [-h] [-g GPG] [-d] [-f FILE] [-q]
{get,store,erase} ...

Easy credential management using GPG.

positional arguments:
{get,store,erase} The credential operation to use.

optional arguments:
-h, --help show this help message and exit
-g GPG, --gpg GPG The `gpg` program to use.
-d, --debug Show output of `gpg` (it prints into `stderr`).
-f FILE, --file FILE The `.netconf.gpg` file to use.
-q, --quit-on-failure
Do not let Git consult any more helpers if an error is
encountered while decryption.

git-credential-netconf is licensed under MIT license. Visit
for more info.
```

# About `.netconf` file

`.netconf` can be used as a direct replacement for `.netrc` file, with the
advantage of being more convenient to use.

## The section name

You can use any name for the section name, but using `conf` is the convention.

## The keys

This table shows the equivalent values for `.netconf`, `.netrc` and
`git-credential` keys:

| `.netconf` | `.netrc` like | `git-credential` |
| ------------------------------ | ------------- | ---------------- |
| `login`, `user`, `username` | `login` | `username` |
| `machine`, `host` | `machine` | `host` |
| `path` | | `path` |
| `password` | `password` | `password` |
| `port`1, `protocol` | | `protocol` |

1: If `port` is an integer, it is used as a `host:port` format.

# Why another tool?

- All other tools are very hard to configure properly.
- Using `Perl` is as clear as mud.
- Python is easy to use, maintain and is very portable.

# License

[MIT](https://choosealicense.com/licenses/mit/)