this post was submitted on 20 Aug 2024
160 points (90.4% liked)

Selfhosted

40329 readers
431 users here now

A place to share alternatives to popular online services that can be self-hosted without giving up privacy or locking you into a service you don't control.

Rules:

  1. Be civil: we're here to support and learn from one another. Insults won't be tolerated. Flame wars are frowned upon.

  2. No spam posting.

  3. Posts have to be centered around self-hosting. There are other communities for discussing hardware or home computing. If it's not obvious why your post topic revolves around selfhosting, please include details to make it clear.

  4. Don't duplicate the full text of your blog or github here. Just post the link for folks to click.

  5. Submission headline should match the article title (don’t cherry-pick information from the title to fit your agenda).

  6. No trolling.

Resources:

Any issues on the community? Report it using the report flag.

Questions? DM the mods!

founded 1 year ago
MODERATORS
 

I've recently set up my own Gitea instance and I figured I'd share a simple guide on how to do it yourself. Hopefully this will be helpful to anyone looking to get started.

If you have any feedback please feel free to comment it bellow.

top 36 comments
sorted by: hot top controversial new old
[–] [email protected] 147 points 3 months ago* (last edited 3 months ago) (3 children)

I'll be that guy: Use forgejo instead, its main contributor is a Non-Profit compared to Gitea's For-Profit owners

[–] [email protected] 19 points 3 months ago (3 children)

Silly question but what is the problem with gitea being for profit?

[–] [email protected] 65 points 3 months ago

I guess out of fear that we get another gitlab situation, where the open source offering has a load of key features eventually kept behind a paywall

[–] [email protected] 37 points 3 months ago

At some point they will do a Redis or Terraform and say no more open source, pay us to use it.

All contributions are now owned by us and not by the person who wrote it.

[–] [email protected] 19 points 3 months ago

As the other commenter already said it's an abundance of caution. GItea is already moving in the direction of SaaS and an easily self-hostable solution runs counter to that plan (Gitea is already offering a managed Cloud so this is not a hypothetical). One thing that has already happened is Gitea introducing a Contributor License Agreement, effectively allowing them to change the license of the code at any time.

[–] [email protected] 9 points 3 months ago* (last edited 3 months ago) (2 children)

Thanks, I always keep forgetting what this ones called. I use a build of gitea from before it became shit but I keep telling myself I need to change to "that better one".

[–] [email protected] 3 points 3 months ago (1 children)

If it helps, it's supposed to be a drop-in replacement.

[–] [email protected] 1 points 3 months ago

It's a hard fork by now, but the switch should still be pretty painless.

[–] [email protected] 2 points 3 months ago

Same. It’s been on my list for too long.

[–] [email protected] 5 points 3 months ago (1 children)

Well I learned something new today.. maybe its time to plan a migration

[–] [email protected] 8 points 3 months ago (1 children)

I think for now Forgejo is a drop-in replacement. However since they are a hard-fork, at some point in the future they will diverge enough to be mutually incompatible, so the clock is ticking on migrating.

[–] [email protected] 4 points 3 months ago

From what I have read on the FAQ they already did a hard fork from Gitea version 1.21.11 on, which was earlier this year

https://forgejo.org/faq/#im-sold-are-migrations-from-gitea-to-forgejo-possible

[–] [email protected] 133 points 3 months ago (2 children)

There's been a hostile takeover at Gitea and it's now run / owned by a for-profit company. The developers forked the project under the name Forgejo and are continuing the work under a non-profit. See also: Their introduction post and a page comparing the two projects. Feel free to look up more, since I haven't familiarized myself with the incident all that much myself. Either way though, maybe consider using Forgejo instead of Gitea.

[–] [email protected] 31 points 3 months ago* (last edited 3 months ago) (1 children)

Hostile not quite, as it was a group of core developers. But still a shitty move, especially how it was done in secrecy and disregarding other devs and the larger community.

[–] [email protected] 10 points 3 months ago* (last edited 3 months ago)

Perhaps not a takeover so much as a betrayal, a backstabbing? Certainly hostile to the community.

[–] [email protected] -1 points 3 months ago (1 children)

That's not what happened at all.

Forgejo is actually the one in the wrong. It's an hostile fork that exist only because 3 devs were mad that they weren't hired by the company created so that the core devs of Gitea could do it full time.

You're just repeating their lies.

The Forgejo people never "owned" Gitea.

[–] [email protected] 3 points 3 months ago* (last edited 3 months ago)

Could you please provide some sources for that? I'd like to know more.

First of all though, there is no such thing as a "hostile fork". Being able to fork a project, for any reason, is the entire point of open source. And to be fair, not wanting to continue working for a for-profit company for free is a very good reason.

And yeah, when you suddenly turn a FOSS project that's been developed with the help of a bunch of contributors, into a for-profit company, without making a big fuss about it beforehand and allow the contributors and community to weigh in, then yeah, that's a hostile takeover of sorts, at least in my opinion. Developers gotta make money, but they could've done that by creating a new brand instead of taking over that of a previously completely FOSS project. Forgejo is preventing that exact thing from happening by joining Codeberg (a non-profit).

[–] [email protected] 82 points 3 months ago (2 children)
[–] [email protected] 5 points 3 months ago (1 children)
[–] [email protected] 50 points 3 months ago

In 2022, maintainers (...) founded the company Gitea Limited with the goal of offering hosting services using (proprietary) versions of Gitea. (...). The shift away from a community ownership model received some resistance from some contributors, which led to the formation of a software fork called Forgejo. From Wikipedia.

[–] [email protected] -2 points 3 months ago* (last edited 3 months ago) (2 children)

But check that it has all the features you need because it lags behind gitea in some aspects (like ci).

[–] [email protected] 5 points 3 months ago
[–] [email protected] 1 points 2 months ago

Doesn't matter if those features are doomed to be locked behind a paywall shortly

[–] [email protected] 11 points 3 months ago (2 children)

I started running my own Gitea instance because I wanted a private place to host my Obsidian notes.

I don't have the time to read the article now, but permit a question: what do you use Gitea for?

I'm holding my dotfiles on a SSH server, clone/push over SSH, and it's enough to do Git. I don't need a ticket system, or wiki or anything (I use plaintext notes).

$ cat ~/.ssh/config
Host srv
  Hostname srv.mywhatever.com

$ git clone srv:/path/to/repo
$ cd repo
$ git push
[–] [email protected] 2 points 3 months ago (1 children)

Great question

I always found setting up a git server from scratch to be quite confusing and I also like the webui that gitea offers.

But recently I have also started moving some of my github projects there so having a link (with a readme and everything) that I can share with others is important.

[–] [email protected] 4 points 3 months ago (1 children)

If you have a place to host Forgejo/Gitea, you have a place to store a Git server. Set it up like this:

$ git clone --bare myrepo myrepo.bare
$ scp -r myrepo.bare srv:
$ cd myrepo
$ git remote add origin srv:myrepo.bare
# or
$ git remote set-url origin srv:myrepo.bare

Now git push etc work similar to GitHub, but you're using your server (named srv in SSH config, as shown in my previous post) as the remote storage.

Selfhosted Gitea is a way to get a wiki, bug tracker or whatnot - collaborate, for example, but it's not necessary to have a Git server for your personal use.

[–] [email protected] 5 points 3 months ago* (last edited 3 months ago)

Selfhosted Gitea is a way to get a wiki, bug tracker or whatnot - collaborate, for example, but it's not necessary to have a Git server for your personal use.

No, but it is amazing for browsing your repos and visually seeing what you did in a past commit or a branch, while your IDE is open to your latest code. Or copying and pasting something that you need from a different repo.

For Git experts, sure they can probably do all that better inside their IDE or CLI, but for us plebs, having your own Forgejo is incredible 😍

I have mine configured to disable the wiki and issues, etc, it's just the repo browser.

[–] [email protected] 1 points 3 months ago

I'm hoping federation will allow me to get rid of my github entirely, but that's wishful thinking I fear

[–] [email protected] 6 points 3 months ago

I intentionally do not host my own git repos mostly because I need them to be available when my environment is having problems.

I make use of local runners for CI/CD though which is nice but git is one of the few things I need to not have to worry about.

[–] [email protected] 5 points 3 months ago

Sidenote: If you just want a nice web frontend for others to view your Git repositories, you can use cgit instead.

[–] [email protected] 2 points 2 months ago

cool guide love stuff like this

[–] [email protected] -2 points 3 months ago (2 children)
[–] [email protected] 2 points 3 months ago (1 children)

I spent a decade as a full time Tcl developer and even I don’t use fossil.

[–] [email protected] 2 points 3 months ago

After dealing with tcl errors trying to test sqlite, I feel I've never seen a more scathing criticism of fossil.

[–] [email protected] 1 points 2 months ago (1 children)

I made a honest effort, but in the end went back to Git for my personal projects. The advantages Fossil has over Git (wiki, bug tracker) are trivial to emulate with versioned plaintext files, and everything about Git's version control system just clicks with my head. Having years of experience breaking and unbreaking things helps too.

Tho one thing Fossil taught me is to merge by default, not rebase. Rebase when there's good justification for it, and the rest of the time, have an alias for git log --oneline --graph --first-parent (or whatever that was). --first-parent collapses a horrible branchy-mergy history into a linear overview thereof, with details available when needed.

[–] [email protected] 1 points 2 months ago

I love love love that Fossil is a single executable.

All in all, the version control wars have ended and git has won. Mercurial is another one I sort of wanna try just to see what it's like.

Re: rebasing, I think squashing / rebasing (in place of merging) is bad but I am also one of the few people I know who tries to make a good history with good commit messages prior to opening a pull request by using interactive rebasing. (This topic is confusing to talk about because I have to say "I don't rebase, instead o rebase" which can be confusing.)