grp feraxhp
winget install --id=feraxhp.grp -e
A simple CLI tool to mannage platforms for git repositories
README
grp (git repository)
girep is a command line tool that helps you manage your git repositories in the cloud, for difrent platforms. It is written in Rust, and it is inspired by gcli.
Features
- New: 🎉
- Supported: ✅
- Planed support: 🟥
- On development: 🔶
Repositories
Feature | GitHub | Gitea | GitLab |
---|---|---|---|
List | ✅ | ✅ | 🎉 |
Create | ✅ | ✅ | 🎉 |
Delete | ✅ | ✅ | 🎉 |
Clone | ✅ | ✅ | 🎉 |
Push | ✅ | ✅ | 🎉 |
Pull | ✅ | ✅ | 🎉 |
Organizations
Feature | GitHub | Gitea | GitLab |
---|---|---|---|
List | ✅ | ✅ | 🎉 |
Create | ✅1 | ✅ | 🎉2 |
Delete | ✅ | ✅ | 🎉3 |
Installation
- Windows: Download the latest .exe from the releases page.
grp.exe
is the portable versiongrp-0.7.1-x86_64.msi
is the installer- Or use winget.
winget install --id feraxhp.grp
- Ubuntu: See releases page for the latest deb package.
wget -O paquete.deb
dpkg sudo dpkg -i paquete.deb
sudo apt-get install -f
- fedora: See releases page for the latest rpm package.
sudo dnf install
- Arch Linux: See build instructions below.
- Other Linux distributions: See build instructions below.
- MacOS: See build instructions below.
Configuration
The grp configurations are store in json. the first time you run grp, it will create the configurations file with the base config.
if you prefer a gide configuration use: grp config add
the location of the config folder depends on the platform
- linux:
$HOME/.config/girep/config.json
- windows
%appdata%/girep/config.json
- mac:
$HOME/Library/Application Support/girep/config.json
the basic structure looks like this:
{
"default": "",
"pconf": []
}
grp manage the platforms in objets called pcofs. in every pconf you have to add
- name: Is the name for the pconf, it is used to determine the platform.
- owner: Is the username that will use by default to request in the platform.
- token: Is a user generated token used to authenticate the request.
- type: type of the platform. currently allows
github
,gitea
andgitlab
. - endpoint: the endpoint to make the request
- examples:
"api.github.com"
: for GitHub."gitea.com"
: for Gitea."tea.example.com"
: for Gitea on custom host.localhost:3244
: for gitea on localhost.
- examples:
here is an example for a complete config file:
{
"default": "gh",
"pconf": [
{
"name": "gh",
"owner": "feraxhp",
"token": "",
"type": "github",
"endpoint": "api.github.com"
},
{
"name": "tea",
"owner": "feraxhp",
"token": "",
"type": "gitea",
"endpoint": "tea.example.com"
},
{
"name": "glab",
"owner": "feraxhp",
"token": "",
"type": "gitlab",
"endpoint": "gitlab.example.com"
}
]
}
Build and Run
Dependencies
Make sure you have the following dependencies installed on your system:
-
dependencies
- Cargo (Rust)
Build
# clone the repository
git clone https://github.com/feraxhp/grp.git
cd grp
# if you want to install it on your system
cargo install --path .
*
Jetbrains has removed access for Jetbrains space
So, is removed for the planed support.
1
Github does not allow create orgs by the API for security reasons
2
Some GitLab admins not allow create groups by the API for security reasons, however for sub-groups yes.
3
Delete for GitLab has an aditional step, so if you whant to just mark for delition something you have to add the flag --soft
Need more Functionality?
If you need more functionality, feel free to open an issue or a pull request. remember to follow the contribution guidelines