Using cgit
This is the last post in a three part series about cgit. Previously we saw how to install and configure cgit and then we saw how to make cgit pretty. This last post has to do with actually using cgit. There are a couple of tools out there to make the process of adding, removing, and modifying git repositories within cgit much simpler but we will focus here on how to do it manually and I will leave it up to you to decide which tools works best for you. cgit does not impose any special requirements for adding, removing, or modifying repositories so the entire process is based around core git functionality. Below is a workflow that works well for me.
Creating a Git User
Creating a git user that has access to/srv/git just makes good sense. To add a new user in Debian you will need to run the following commands and follow the on screen instructions to complete this process. adduser git
Adding your public key
In order to authenticate to the server and work with git it is good to add your public key to avoid working with passwords. If you do not already have a key, go ahead and create one on your local machine.ssh-keygen -b 8192 Follow the on screen instructions, and be sure to add a password to this key! Once you have create this key, copy the public key over to your git server under the git users .ssh/authorized_keysfile. scp $USER/.ssh/id_rsa.pub [email protected]:/home/git/.ssh/authorized_keys
Creating a new repository
Log into the git server as the git user and create a bare repositorycd /srv/git mkdir myrepo.git cd myrepo.git git init --bare
Push to the new repository
On your local computermkdir myrepo cd myrepo git init echo "My Awesome Repo" >> README.md git add README.md git commit -m 'initial commit' git remote add origin [email protected]:/srv/git/myrepo.git git push origin master
Add the new repository to cgit
Now that your repository is on your server, you can add it cgit by editing/etc/cgitrc and adding it as we did before.
repo.url = myrepo repo.path = /srv/git/myrepo.git repo.desc = My Awesome Repo repo.owner = Your Name
Thank you for reading! Share your thoughts with me on bluesky, mastodon, or via email.
Check out some more stuff to read down below.
Most popular posts this month
- My Custom Miniflux CSS Theme
- SQLite DB Migrations with PRAGMA user_version
- 2024
- 2023
- Ladybird on Debian Stable
Recent Favorite Blog Posts
This is a collection of the last 8 posts that I bookmarked.
- Pluralistic: AI "journalists" prove that media bosses don't give a shit (11 Mar 2026) from Pluralistic: Daily links from Cory Doctorow
- Avi Alkalay: Uniqlo T-Shirt Bash Script Easter Egg from Fedora People
- Offline 23 hours a day from Derek Sivers blog
- Pluralistic: California can stop Larry Ellison from buying Warners (28 Feb 2026) from Pluralistic: Daily links from Cory Doctorow
- On Alliances from Smashing Frames
- Acting ethically in an imperfect world from Smashing Frames
- Diffusion of Responsibility from Smashing Frames
- My AI Adoption Journey from Mitchell Hashimoto
Articles from blogs I follow around the net
Keeping sponsor lists up-to-date
Keeping sponsor lists up-to-date across multiple READMEs and websites is tedious - so I wrote a tool to automate it.
via Carlos Becker March 25, 2026Code as a Tool of Process
Steve Krouse wrote a piece that has me nodding along: Programming, like writing, is an activity, where one iteratively sharpens what they're doing as they do it. (You wouldn't believe how many drafts I've written of this essay.) There’s an incre…
via Jim Nielsen’s Blog March 24, 2026Paris's Bicycle Mayor and the Hormuz Shock
Why Energy Independence is an Enduring Antidote to Trump's Demented Chaos
via High Speed March 24, 2026Generated by openring