gitforgefs/README.md

116 lines
6.3 KiB
Markdown
Raw Normal View History

2024-08-14 03:45:09 +00:00
# gitforgefs
2020-12-31 21:29:25 +00:00
2024-08-14 03:45:09 +00:00
*Formerly gitlabfs*
2020-12-31 21:29:25 +00:00
2024-08-14 03:45:09 +00:00
`gitforgefs` allows you to mount and navigate git forges (Github, Gitlab, Gitea, etc.) as a [FUSE](https://github.com/libfuse/libfuse) filesystem with every groups, organization, and users represented as a folder and every repositories represented as a symlink pointing on a local clone of the project. This is helpful to automate the organization of your local clones.
To help illustrate, this is the output of `tree` in a filesystem exposing all the repositories of a github user.
2020-12-31 21:29:25 +00:00
```
2024-08-14 03:45:09 +00:00
$ tree
2020-12-31 21:29:25 +00:00
.
2024-08-14 03:45:09 +00:00
└── badjware
├── aws-cloud-gaming -> /home/marchambault/.local/share/gitforgefs/github.com/257091317
├── certbot -> /home/marchambault/.local/share/gitforgefs/github.com/122014287
├── certbot-dns-cpanel -> /home/marchambault/.local/share/gitforgefs/github.com/131224547
├── certbot-dns-ispconfig -> /home/marchambault/.local/share/gitforgefs/github.com/227005814
├── CommonLibVR -> /home/marchambault/.local/share/gitforgefs/github.com/832968971
├── community -> /home/marchambault/.local/share/gitforgefs/github.com/424689724
├── docker-postal -> /home/marchambault/.local/share/gitforgefs/github.com/132605640
├── dotfiles -> /home/marchambault/.local/share/gitforgefs/github.com/192993195
├── ecommerce-exporter -> /home/marchambault/.local/share/gitforgefs/github.com/562583906
├── FightClub5eXML -> /home/marchambault/.local/share/gitforgefs/github.com/246177579
├── gitforgefs -> /home/marchambault/.local/share/gitforgefs/github.com/324617595
├── kustomize-plugins -> /home/marchambault/.local/share/gitforgefs/github.com/263480122
├── librechat-mistral -> /home/marchambault/.local/share/gitforgefs/github.com/753193720
├── PapyrusExtenderSSE -> /home/marchambault/.local/share/gitforgefs/github.com/832969611
├── Parsec-Cloud-Preparation-Tool -> /home/marchambault/.local/share/gitforgefs/github.com/258052650
├── po3-Tweaks -> /home/marchambault/.local/share/gitforgefs/github.com/832969112
├── prometheus-ecs-discovery -> /home/marchambault/.local/share/gitforgefs/github.com/187891900
├── simplefuse -> /home/marchambault/.local/share/gitforgefs/github.com/111226611
├── tmux-continuum -> /home/marchambault/.local/share/gitforgefs/github.com/160746043
├── ttyd -> /home/marchambault/.local/share/gitforgefs/github.com/132514236
├── usb-libvirt-hotplug -> /home/marchambault/.local/share/gitforgefs/github.com/128696299
└── vfio-win10 -> /home/marchambault/.local/share/gitforgefs/github.com/388475049
24 directories, 0 files
2020-12-31 21:29:25 +00:00
```
2024-08-14 03:45:09 +00:00
## Supported forges
Currently, the following forges are supported:
| Forge | Name in configuration | API token permissions, if using an API key |
| ------------------------------- | --------------------- | ------------------------------------------------------ |
| [Gitlab](https://gitlab.com) | `gitlab` | `read_user`, `read_api` |
| [Github](https://github.com) | `github` | `repo` |
| [Gitea](https://gitea.com) | `gitea` | organization: `read`, repository: `read`, user: `read` |
| [Forgejo](https://forgejo.org/) | `gitea` | organization: `read`, repository: `read`, user: `read` |
Merge requests to add support to other forges are welcome.
2020-12-31 21:29:25 +00:00
## Install
Install [go](https://golang.org/) and run
``` sh
2024-08-15 14:47:42 +00:00
go install github.com/badjware/gitforgefs@latest
2020-12-31 21:29:25 +00:00
```
2024-08-14 03:45:09 +00:00
The executable will be in `$GOPATH/bin/gitforgefs` or `~/go/bin/gitforgefs` by default. For convenience, add `~/go/bin` in your `$PATH` if not done already.
2020-12-31 21:29:25 +00:00
## Usage
Download the [example configuration file](./config.example.yaml) and edit the default configuration to suit your needs.
2024-08-14 03:45:09 +00:00
Then, you can run gitforgefs as follows:
2020-12-31 21:29:25 +00:00
``` sh
2024-08-14 03:45:09 +00:00
gitforgefs -config config.yaml /path/to/mountpoint
2020-12-31 21:29:25 +00:00
```
2024-08-14 03:45:09 +00:00
Stopping gitforgefs will unmount the filesystem. In the event the mountpoint is stuck in a bad state (eg: due to receiving a SIGKILL), you may need to manually cleanup using `umount`:
``` sh
sudo umount /path/to/mountpoint
```
2020-12-31 21:29:25 +00:00
2021-03-22 01:52:22 +00:00
### Running automatically on user login
2024-08-14 03:45:09 +00:00
See [./contrib/systemd](contrib/systemd) for instructions on how to configure a systemd service to automatically run gitforgefs on user login.
2021-03-22 01:52:22 +00:00
2020-12-31 21:29:25 +00:00
## Caching
2024-08-14 03:45:09 +00:00
### Filesystem cache
To reduce the number of calls to the APIs and improve the responsiveness of the filesystem, gitforgefs will cache the content of the forge in memory. If a group or project is renamed, created or deleted from the forge, these change will not appear in the filesystem immediately. To force gitforgefs to refresh its cache, use `touch .refresh` in the folder to signal gitforgefs to refresh this folder.
### Local repository cache
2020-12-31 21:29:25 +00:00
2024-08-14 03:45:09 +00:00
While the filesystem lives in memory, the git repositories that are cloned are saved on disk. By default, they are saved in `$XDG_DATA_HOME/gitforgefs` or `$HOME/.local/share/gitforgefs`, if `$XDG_DATA_HOME` is unset. `gitforgefs` symlink to the local clone of that repo. The local clone is unaffected by project rename or archive/unarchive in Gitlab and a given project will always point to the correct local folder.
2020-12-31 21:29:25 +00:00
2024-08-14 03:45:09 +00:00
## Future improvements
* Cache persists forever until a manual refresh is requested. Some way to automatically refresh after a timeout would be nice.
2020-12-31 21:29:25 +00:00
2024-08-14 03:45:09 +00:00
## Building from the repo
2020-12-31 21:29:25 +00:00
Simply use `make` to create the executable. The executable will be in `bin/`.
2024-12-29 23:16:23 +00:00
See `make help` for all available targets.
## Troubleshooting
### My application claims that a file or a folder doesn't exists.
Some applications doesn't resolve symlinks properly. Try setting the `fs.use_symlinks` configuration to `false`.
### `docker` fails to run with the message _error while creating mount source path_
This happens because `docker` is running as a different user than the one who created the mount. Follow these steps to allow docker access to the mount:
1. Open the file `/etc/fuse.conf` as root.
2. Add `user_allow_other` to the file, then close and save your modifications.
3. Open your `gitforgefs` configuration.
4. Add the `allow_other` to your mountoptions. The mount option are configured in `fs.mountoptions`.
``` yaml
fs:
mountoptions: allow_other,nodev,nosuid
```
5. Restart your mount.