Cobra CLI tool for fuzzy-finding and navigating around git repos from multiple remotes
|
||
---|---|---|
.gitea/workflows | ||
.vscode | ||
cmd | ||
contrib | ||
docs | ||
internal | ||
.gitignore | ||
go.mod | ||
go.sum | ||
LICENSE | ||
main.go | ||
Makefile | ||
README.md |
GitLab Project Manager
Purpose
The goal of this utility is to provide a fuzzy-find method of locating, cloning, and using GitLab projects -- along with your preferred aliases, autocompletion, and shortcuts.
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
(orpadd
if 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
pgo
func 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 add
orgpm 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
Installing
- Install into your go path by running
go install .
- Copy
contrib/gpm_func_omz.zsh
into your~/.oh-my-zsh/custom/
path, or just source from your bashrc/zshrc - Generate config file:
gpm config gen --write
- You can run this any time to update settings
- It will only add one GitLab, so update the file for multiple
- Run
gpm cache load
(if aliases is in-place, otherwisegitlab-project-manager cache load
)
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
--remote
flag 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
% gitlab-project-manager cache -h
Contains sub-commands for managing project cache.
The project cache keeps this speedy, without smashing against the GitLab
API every time a new project is added / searched for
Usage:
gitlab-project-manager cache [command]
Aliases:
cache, a, ln
Available Commands:
clear Clear GitLab Project Cache
dump Dump GitLab project cache
load Load GitLab Project Cache
unlock unlock GitLab 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/gitlab-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 "gitlab-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 -f
optionally filtering with--remote
flags
TODO
- Don't check remote up unless necessary (project list shouldn't require it)
- Rename to git-project-manager
- Move module from gitlab.sweetwater.com to github.com/rdmcguire
- Add flag for clone timeout for large repos
- Add
gpm cache prune
command - 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 gitlab 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 show
with 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