Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dmfutcher/git-profile
Simple identity switching for git
https://github.com/dmfutcher/git-profile
git git-profile
Last synced: 2 months ago
JSON representation
Simple identity switching for git
- Host: GitHub
- URL: https://github.com/dmfutcher/git-profile
- Owner: dmfutcher
- License: mit
- Created: 2019-10-27T16:26:43.000Z (about 5 years ago)
- Default Branch: main
- Last Pushed: 2022-03-01T15:44:01.000Z (almost 3 years ago)
- Last Synced: 2024-09-17T18:46:36.408Z (4 months ago)
- Topics: git, git-profile
- Language: Rust
- Homepage:
- Size: 34.2 KB
- Stars: 49
- Watchers: 2
- Forks: 2
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG
- License: LICENSE
Awesome Lists containing this project
- awesome-starred - dmfutcher/git-profile - Simple identity switching for git (git)
README
# git-profile
*git-profile* is a simple user profile manager for *git*. It lets you set-up multiple user profiles for git & switch
between them, generate remote URLs and more. If you ever have to manage multiple identities with git, *git-profile* can make
your life easier.## Install
If you have Cargo installed, run `cargo install git-profile`. You can also grab a pre-built (Mac) binaries from the releases page.
It should be installed on your path as `git-profile`. The `git-` prefix allows it to be called like any other git command.## Usage
### Create a profile
At a minimum you need a profile name (best to keep this quite short), your author name and author email.
`git profile new github 'Full Name' '[email protected]'`
Create a profile with a custom URL scheme:
`git profile new github-work 'Full Name' '[email protected]' --username CompanyName --remote '[email protected]:{{username}}/{{project}}.git'`
### Switch profiles
The `use` command switches you between profiles. This sets the profile for the repository in your current working directory.
`git profile use github-work`
`git profile use open-source`
### List profiles
List all the profiles. An asterisk will appear next to the currently enabled profile.
`git profile ls`
### Use with ssh config
If your different profiles each have different ssh key-pairs set-up,
you can configure git-profile to use them via shared ssh-hosts and usernames:`~/.ssh/config`:
```ini
# WORK GITHUB SSH CONFIG
Host work.github.com
HostName github.com
IdentityFile ~/.ssh/work_github_rsa
PreferredAuthentications publickey
IdentitiesOnly yes# OPEN SOURCE GITHUB SSH CONFIG
Host oss.github.com
Hostname github.com
IdentityFile ~/.ssh/oss_github_rsa
PreferredAuthentications publickey
IdentitiesOnly yes
````~/.git_profiles`:
```toml
[gh-work]
author = 'Full Name (at work)'
email = '[email protected]'
username = 'MyWorkGithubOrganization'
url = '[email protected]:{{username}}/{{project}}.git'[open-source]
author = 'Full Name'
email = '[email protected]'
username = 'my-oss-github-account'
url = '[email protected]:{{username}}/{{project}}.git'
```You can then `git clone ...` from using the correc key like ...
### Generate remote URL
git-profile can be used to generate remote URLs for your repos. This can be helpful if you have a complicated SSH
set-up that uses custom domains to use the right keys. Or just to save you having to navigate around GitHub Web
and copy and paste remote URLs.Generate a URL for a given project name:
`git profile url project-name`
Use `-p ` to generate using a different profile.
`git profile url -p github-work your-project`
This is particularly handy when used in a sub-shell and combined with `git-remote`:
`git remote add origin $(git profile url -p github-work my-work-project)`
### Generate author string
`git profile author` => 'Full Name \'
Can be used to easily fix commits when you've committed under the wrong profile:
```sh
git commit -m "Committing with the wrong user"
git profile use github-work
git commit --amend --author $(git profile author)
```### Edit profiles
`git profile edit` opens your `.git_profiles` in `$EDITOR`. Defaults to `vim` if you don't have `$EDITOR` set.
## Status
*git-profile is in early development*. It's solves most of my major issues with using multiple identities with git, but it's by no means perfect.
If you run into a bug or have a feature request, please open an issue. It should work fine on Mac & Linux, it probably won't work as-is on Windows.## License
MIT license, see `./LICENSE`.