GitXplorerGitXplorer
K

git-gears-c

public
1 stars
0 forks
1 issues

Commits

List of commits on branch master.
Unverified
9bb2903e98209be777b704ba878af611be6fd254

add initial config check

KKageKirin committed 5 years ago
Unverified
5e7cd98ec7bf0b09482b3d8e23f265515ba59cd1

add constants for API type

KKageKirin committed 5 years ago
Unverified
b6c042d6f6190a83d06b371133940984574aa9ba

simplify gears_getGearsConfigEntryRemoteOrURL by relying on gears_parseRemoteOrUrl

KKageKirin committed 5 years ago
Unverified
92fddb92b20cb28709005b8f6db5004dfc2847ab

add gears_parseRemoteOrUrl

KKageKirin committed 5 years ago
Verified
4bca550f72d1eb86bf97233a548cc18f1503121c

Merge pull request #11 from KageKirin/adding-libs

KKageKirin committed 5 years ago
Unverified
7191f98dd251549b44f0efa8437be77cd719fef6

add curl option -L to follow redirection

KKageKirin committed 5 years ago

README

The README file for this repository.

git-gears-c

Git and git-host helper CLI tool written in C.

This project is a more-or-less port of the C# git-gears-cs to C99.

Git Gears tries to bridge the gap between a local git repository and remote git hosting services by bringing service functionality straight to the command line.

Tech

git-gears is written in C99 and compiled into a native executable.

So far, git-gears uses:

  • command line parser: TBD
  • libgit2 for Git integration
  • curl? for HTTPS
  • JSMN for JSON parsing

GraphQL and REST

Since both GitHub and GitLab expose a GraphQL interface, git-gears uses the latter, instead of multiplying the dependencies on hosting service specific libraries.

However, at the time of writing this, not all functionality exposed via the respective GraphQL APIs seems to be correctly implemented. To bridge this gap, git-gears falls back on the REST API.

In the long run, this will also allow git-gears to interface with other git hosting services that expose only a REST API.

Name

git-gears is built and named after my personal proof-of-concept Python script git-cogs.
The image is still that about dented wheels interacting in a smooth mechanical system.

Status

  • started project.

Features required for feature parity with the C# version

  • git integration with libgit2 works, config can be read.
  • GitHub proof-of-concept GraphQL connection works
  • GitLab proof-of-concept GraphQL connection works
  • GitHub get- and list- actions work.
  • GitLab get- and list- actions work, but slightly different from their GitHub counterparts.
  • create-issue works for GitHub and GitLab
  • create-pullrequest works for GitHub and GitLab, although limited to a single repository. (I.e. cross-repo-PRs (e.g. fork to upstream) are not supported yet).
  • create-gist works for GitHub and GitLab. GitLab has the option to add snippets to repos as well.
  • create-repo works for GitHub and GitLab, for the user's own namespace and optionally for organizations as well. YMMV depending on your token scope. (TODO: document which scope is required per feature).

Planned features

  • GitHub support
  • GitLab support
  • atm, support for other hosting services is not planned. I take pull requests (e.g. for BitBucket, Gogs etc).
  • pull requests:
    • git gears create-pullrequest
    • git gears close-pullrequest
    • git gears get-pullrequest
    • git gears list-pullrequests
    • git gears comment-pullrequest
    • git gears merge-pullrequest
  • issues:
    • git gears create-issue
    • git gears close-issue
    • git gears get-issue
    • git gears list-issues
    • git gears comment-issue
  • gists:
    • git gears create-gist
    • git gears remove-gist
    • git gears get-gist
    • git gears list-gists
    • git gears comment-gist
  • repos:
    • git gears create-repo
    • git gears delete-repo
    • git gears get-repo
    • git gears list-repos
    • git gears fork-repo
  • --browser option:
    • open in browser?
    • or open a local small browser window?
    • or Shell-browser (Lynx)?
  • displaying issue/pr/gist discussions in the shell.

Configuration

git-gears requires a few settings to be added to your git-config, and allows to have different settings per project. (The configuration is read in order from local -> global -> system).

  • Section [gears "my.host"]: my.host corresponds to your git service hostname, e.g. github.com.
  • token: this is your private access token generated by the service.
  • api: the API type to use, either 'github' or 'gitlab' (atm)
  • url: the service's GraphQL endpoint URL.
  • rest: the service's REST endpoint root URL.

In general, this looks like that:

[gears "my.host"]
token = <your access token>
api = <github|gitlab>
url = https://my.host/api/graphql
rest = https://my.host/api

And a more concrete use-case are the following settings:

[gears "github.com"]
token = <your github access token>
api = github
url = https://api.github.com/graphql
rest = https://api.github.com
[gears "github.enterprise.org"]
token = <your github enterprise access token>
api = github
url = https://github.enterprise.org/api/graphql
rest = https://github.enterprise.org/api
[gears "gitlab.com"]
token = <your gitlab access token>
api = gitlab
url = https://gitlab.com/api/graphql
rest = https://gitlab.com/api/v4

Technical considerations

For more details on the technical considerations of this project, please read my blog post