6.8 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	Git Project Manager
Purpose
The goal of this utility is to provide a fuzzy-find method of locating, cloning, and using Git projects -- along with your preferred aliases, autocompletion, and shortcuts.
This supports GitHub, GitLab, and Gitea remotes.
Installation
Install git-project-manager using go:
go install -v gitea.libretechconsulting.com/rmcguire/git-project-manager@latest
OR Download a pre-built binary: https://gitea.libretechconsulting.com/rmcguire/-/packages/generic/git-project-manager
Setup
Generate a new config file:
git-project-manager config generate --write
For handy aliases and shell helpers:
- Download https://gitea.libretechconsulting.com/rmcguire/git-project-manager/raw/branch/main/contrib/gpm_func_omz.zsh
- Implement however you like (e.g. copy to ~/.oh-my-zsh/custom/)
For just completion only, source completions from git-project-manager (e.g. for zsh, source <(git-project-manager completion zsh))
The following commands assume you've loaded the gpm alias and help funcs.
Index your git repos
gpm cache load
Add your first project
padd (gpm project add)
Go to your project, fuzzily
pgo
Documentation
Full documentation is available in docs/
Functionality
This program will try like hell to help you fuzzily find a project, and once you've found it, will remember your preference along with whatever crazy thing your lizard brain wants to call it.
Do you think of a project called terraform as infra-stuff? No problem, just let gpm know that and it'll remember.
The basic workflow looks like this:
- Config -- generate a config file
- Cache -- load your cache to make things super quick
- you only need to update it if there are new projects the cache is unaware of
 
- Add -- find your project, give it any extra aliases you want
- run gpm project add(orpaddif using the provided shell defaults)
 
- run 
- Go -- go to your project, fuzzy searching by alias
- clones your project if that's never been done
- the provided pgofunc makes it easy
 
- Open -- rather than simply changing directories to a project, open it in your IDE
- Manage -- fine-tune your aliases, making it easy to nail them without fuzzy stuff
- if you are lazy in your aliases, you'll be fuzzy finding a lot
- match your alias exactly (or have only one result) and you go there right away
- positive reinforcement given for solid alias behavior
- manage aliases using gpm alias addorgpm alias delete
 
- List -- get a list of your configured projects any time with plist
- Reward -- buy the author a beer, because this thing is a time saver
Config Sample
remotes:
  - host: https://github.com/rdmcguire # add user for multiple keys
    token: <your token here>
    name: github-rdmcguire
    type: "github" # github, gitlab, gitea supported
    cloneProto: ssh
logLevel: info
cache:
  ttl: 168h
  load:
    ownerOnly: false # if true, only owned projects will be indexed
Usage
Global Flags
- The --remoteflag limits all subcommands to one or more specified remotes
- The --logLevel [debug|error|info|warn]flag sets logging, but is permanent in the config file
Basic Usage
Basic usage to prepare your cache, add a project alias (or aliases), and use a project:
- gpm cache load
- gpm project add
- select with fuzzy search, add extra aliases if preferred
- gpm project [go|open] <optional-fuzzy-search-term>
- Open will launch your editor, go will change directories, cloning if necessary
Cache Management
% git-project-manager cache -h
Contains sub-commands for managing project cache.
The project cache keeps this speedy, without smashing against the Git remote's
API every time a new project is added / searched for
Usage:
  git-project-manager cache [command]
Aliases:
  cache, a, ln
Available Commands:
  clear       Clear Git Project Cache
  dump        Dump Git project cache
  load        Load Git Project Cache
  unlock      unlock Git project cache
Flags:
  -h, --help           help for cache
      --ttl duration   Duration before cache is re-built in go time.Duration format (default 48h0m0s)
Global Flags:
      --config string        config file (default is ~/.config/git-project-manager.yaml)
      --logLevel string      Default log level -- info, warn, error, debug (default "info")
      --projectPath string   Sets a path for local clones of projects
      --remote strings       Specify remotes by host for any sub-command. Provide multiple times or comma delimited.
Use "git-project-manager cache [command] --help" for more information about a command.
- To update your cache, run gpm cache load. You can also specify one or more remotes with--remote [host]either multiple times or comma delimited. Command completion works.
- To view basic cache stats, run gpm cache dump
- To dump cache projects and any aliases that are set, run gpm cache dump -foptionally filtering with--remoteflags
TODO
- Don't check remote up unless necessary (project list shouldn't require it)
- Rename to git-project-manager
- Move module to github.com/rdmcguire
- Add flag for clone timeout for large repos
- Add gpm cache prunecommand
- Fix NPE when cache is reset or project for whatever reason leaves an orphaned alias
- Add TTL check to cache load, and add -f / --force flag to re-build regardless
- Update README for shell completion, aliases, usage
- Make a Makefile
- Add git repo status to project go (up-to-date, pending commits, etc..)
- Build pipeline, and link to registry for a release binary
- Add GitHub remote
- Package for homebrew
- Make generic, this is any git remote, not just GitLab
- Add Gitea support
- Add GitHub support
- Remove separate gitlab/gitea logic and keys, stop supporting legacy keys
- Rename --gitlab flag to --remote
 
- Add option to select individual remote for gpm cache load
- Use multi-gitlab by default in config init
- Update docs for multi-gitlab
- Remove all references to old keys
- Add auto-completion helper for --gitlab flag
 
- Fix initial setup requiring project path, and set https:// as default for gitlab host
- Add config setters and getters
- For each project loaded, check if it is the same, and do nothing
- prevents clobbering cache on a partial update
- track already loaded projects to diff after load
 
- Add open command
- config should exist for editor (vim, code, etc..)
 
- Add fzf to plist/gpm projects list
- Update gpm project showwith pterm box likegpm project list
- Merge aliases together for same project when selecting
- If after merging there is only one project, go there by default