grp logo

grp feraxhp

Use this command to install grp:
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

FeatureGitHubGiteaGitLab
List🎉
Create🎉
Delete🎉
Clone🎉
Push🎉
Pull🎉

Organizations

FeatureGitHubGiteaGitLab
List🎉
Create1🎉2
Delete🎉3

Installation

  • Windows: Download the latest .exe from the releases page.
    • grp.exe is the portable version
    • grp-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 and gitlab.
  • 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.

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:

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

Versions
0.7.1
Website
License