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
- 2025
- Ladybird on Debian Stable
- My Custom Miniflux CSS Theme
- Setting up ANTLR4 on Windows
- SQLite DB Migrations with PRAGMA user_version
Recent Favorite Blog Posts
This is a collection of the last 8 posts that I bookmarked.
- Pluralistic: bunnie's piggyback hack (09 Jan 2026) from Pluralistic: Daily links from Cory Doctorow
- Clicks Communicator from Chris Hannah
- A Year Of Vibes from Armin Ronacher's Thoughts and Writings
- Pluralistic: A perfect distillation of the social uselessness of finance (18 Dec 2025) from Pluralistic: Daily links from Cory Doctorow
- Moving from WordPress to Substack from charity.wtf
- Grow, Like a Tree Not a Cancer from Jim Nielsen’s Blog
- Pluralistic: All the books I reviewed in 2025 (02 Dec 2025) from Pluralistic: Daily links from Cory Doctorow
- DEP-18: A proposal for Git-based collaboration in Debian from Optimized by Otto
Articles from blogs I follow around the net
Go Read a Book
There's a lot of shitty news happening lately, and I've been having trouble holding space for it all.
via flower.codes January 24, 2026ROSCon Korea 2026 Review
After attending my first ever ROSCon in Singapore 3 months ago, I had a chance to participate in the first ever regional ROSCon in (South) Korea! Physical AI is here I had an interesting discussion with a team lead at ROBOTIS, a major Robotics company , o…
via Junwoo Hwang January 24, 2026[RIDGELINE] Eras
Ridgeline subscribers — I like “eras.” That is, named chunks of time. Japanese history tends to periodicize based on locus of power. The Tokugawa Shogunate reigned for hundreds of years, and so: Edo, where the power was, becomes the period (a big sweeping o…
via Craig Mod — Writer + Photographer January 24, 2026Generated by openring