Skip to main content

Git Forge API Client..

Project description

GIT FORGE API CLIENTS

W.I.P. API clients for GitHub & GitLab.

INSTALLATION

pip install gitforge

CONFIGURATION

On first run you will be asked to enter a destination directory to sync to or check the status of. You will also be asked to enter your Personal Access Token.

Generate a GitHub Personal Access Token here.

Generate a GitLab Personal Access Token here.

These details will be stored in $HOME/.gitforge.cfg. You can edit this file if you want to change the default destination directory or your access token.

The configuration looks something like this:

[GitHub]
destination = /path/to/directory/to/store/repos
token = GITHUB-PERSONAL-ACCESS-TOKEN

[GitLab]
destination = /path/to/directory/to/store/repos
token = GITLAB-PERSONAL-ACCESS-TOKEN

These defaults can be overridden on the command line with the --token and --destination arguments. See below for more details.

COMMANDS

sync: Clone repositories (and groups in the case of GitLab) to destination. If they already exist in destination - update them to the latest remote commit. This is the default behaviour if no command is specified.

status: Check repositories in destination for uncommitted changes.

jobs: GitLab ONLY View the log of the last failed CI job run in repository. This will be opened in a Curses paging window.

schedules: GitLab ONLY View all CI pipeline schedules ordered by next run time.

members: GitLab ONLY View all members of groups or projects and their access level.

N.B. If no repositories or groups are specified with -r or -g, then run command against all of them... This may take a while depending on how many repositories you have in your account.

OPTIONS

GITHUB

usage: gh [-h] [-d DESTINATION] [-i] [-p {ssh,http}] [-r REPOS [REPOS ...]]
          [-t TOKEN] [-v]
          [{sync,status,jobs,schedules}]

CLI GitHub API Client

positional arguments:
  {sync,status}
                        command to run (default: sync)

optional arguments:
  -d DESTINATION, --destination DESTINATION
                        destination path (default: None)
  -h, --help            show this help message and exit
  -i, --interactive     choose repos interactively (default: False)
  -p {ssh,http}, --protocol {ssh,http}
                        protocol to use (default: ssh)
  -r REPOS [REPOS ...], --repos REPOS [REPOS ...]
                        GitHub repo names (default: None)
  -t TOKEN, --token TOKEN
                        GitHub personal access token (default: None)
  -v, --verbosity       increase verbosity (default: 0)

GITLAB

usage: gl [-h] [-d DESTINATION] [-i] [-p {ssh,http}] [-r REPOS [REPOS ...]]
          [-t TOKEN] [-v] [-g GROUPS [GROUPS ...]]
          [{sync,status,jobs,schedules}]

CLI GitLab API Client

positional arguments:
  {sync,status,jobs,schedules,members}
                        command to run (default: sync)

optional arguments:
  -d DESTINATION, --destination DESTINATION
                        destination path (default: None)
  -g GROUPS [GROUPS ...], --groups GROUPS [GROUPS ...]
                        gitlab group names (default: None)
  -h, --help            show this help message and exit
  -i, --interactive     choose repos interactively (default: False)
  -p {ssh,http}, --protocol {ssh,http}
                        protocol to use (default: ssh)
  -r REPOS [REPOS ...], --repos REPOS [REPOS ...]
                        GitLab repo names (default: None)
  -t TOKEN, --token TOKEN
                        GitLab personal access token (default: None)
  -v, --verbosity       increase verbosity (default: 0)

EXAMPLES

With all of these examples if you want more output or a better understanding of what's going on use the -v argument.

Clone or pull all repositories that you are a member of in the directory set up in your configuration file

gitlab for GitLab

github for GitHub

N.B. If you have not set up a configuration file or run the command before you will be prompted for the destination directory and your Personal Access Token.

Do the same as above but to an alternative directory, and use HTTP instead of SSH

gitlab -d ~/path/to/alternative/directory -p http

github -d ~/path/to/alternative/directory -p http

Limit this action to only the "Example-Groups" and the "Example-Repos"

gitlab -d ~/path/to/alternative/directory -g Example-Group-1 Example-Group-2 Example-Repo-1 Example-Repo-2

N.B. The group argument only works with GitLab. Also, all child groups will be included when specifiying a parent group.

Choose from a TUI menu the repositories you want to work with from the "Example-Group"

gitlab -g example-group -i

You will be presented with a TUI menu which you can use the arrow keys to navigate and the space bar to select repositories from.

View the status of all the repositories in the directory set up in your configuration

gitlab status for GitLab

github status for GitHub

View job logs of latest failed GitLab CI job from "project-1" & "project-2" repository in a pager

gitlab jobs -r project-1 project-2

View CI pipeline schedules of all projects in "group-name" group

gitlab schedules -g group-name

View all members of "group-name" and "project-name"

gitlab members -g group-name -r project-name

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

gitforge-0.2.2.tar.gz (12.5 kB view details)

Uploaded Source

Built Distribution

gitforge-0.2.2-py3-none-any.whl (13.3 kB view details)

Uploaded Python 3

File details

Details for the file gitforge-0.2.2.tar.gz.

File metadata

  • Download URL: gitforge-0.2.2.tar.gz
  • Upload date:
  • Size: 12.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.16

File hashes

Hashes for gitforge-0.2.2.tar.gz
Algorithm Hash digest
SHA256 b28fd0c34dceb9063185eb0a3e2affaa3517b524863bb8df7754fa78726f205c
MD5 befb9cb1290fcbedaa42e71d1c3a345e
BLAKE2b-256 25e4f5109a96e424f770aecc78fee6eefd0be6eb01a038dc3ba550f2beb1bcab

See more details on using hashes here.

File details

Details for the file gitforge-0.2.2-py3-none-any.whl.

File metadata

  • Download URL: gitforge-0.2.2-py3-none-any.whl
  • Upload date:
  • Size: 13.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.16

File hashes

Hashes for gitforge-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 1461d09ba741dd33d907530e1b9dc801bdada59d19e9bcfc827b91105b9d70eb
MD5 48c88e5706bc27c2c7f990eca1f23713
BLAKE2b-256 ef1cd3bd3b2f1253c573b6ee7dd5cd38bd52d1732612a7633612ad6828f22a31

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page