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 gitAdding 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_keysCreating 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
- Lev Lazinskiy
- Lev Lazinskiy
- Lev Lazinskiy
- Terminal RSS Reader With Nom
- SQLite DB Migrations with PRAGMA user_version
Recent Favorite Blog Posts
This is a collection of the last 8 posts that I bookmarked.
- No-One Escapes the Permanent Underclass from Fernando Borretti
- Make AI Boring Again from charity.wtf
- The logical destination of LLMs from Andy Bell
- Revised rules of engineering leadership. from Irrational Exuberance
- The circus freaks of open source from Drew DeVault's blog
- Clanker: A Word For The Machine from Armin Ronacher's Thoughts and Writings
- I ran a half-marathon! from gluecko.se
- My Running Tips from Kevin Bell's Blog
Articles from blogs I follow around the net
Make the logo^H^H^H^H^H^H^H^Hsomething bigger
Speaking of breaking search, an absolutely horrendous design decision I just spotted when using Bing Search: Yep, you saw this correctly: as you scroll, the ads (already pretty much masquerading as regular search results) actually get bigger to grab your a...
via Unsung July 1, 2026Trump’s $1.4 billion crypto disclosure
The White House insists there’s no conflict of interest as Trump reports $1.4 billion in income from an industry he’s deregulated.
via Citation Needed July 1, 2026Pluralistic: Technocarcinization (01 Jul 2026)
Today's links Technocarcinization: Enshittification is the great leveler. Hey look at this: Delights to delectate. Object permanence: Grampa's backyard Disneyland; Elizabeth Warren on monopolies; Spotify v Apple (antitrust edn); Exxon lobbyist confesses; "...
via Pluralistic: Daily links from Cory Doctorow July 1, 2026Generated by openring