They slowly started locking down the platform for people without accounts and it has been really annoying to use the website since. First it was not possible to search for code, then even searching for issues got more and more difficult with it randomly failing, and now it’s gotten to the point where I can’t search for a fucking project anymore!

Github’s search is becoming as bad as reddit’s, where if you want to find anything, a secondary service like SourceGraph, GrepApp, or even a dumb search engine is better. Sometimes those haven’t indexed what I need (especially code search), so I have to download the bloody tarball and rg for whatever the fuck it is I was looking for. Sometimes it will also block the VPN I’m using, so I have to proxy to a non-VPNed machine. The world could do without these unnecessary roadblocks.

What also grinds my gears is requiring an account to contribute. There is no way to send in a patch, raise an issue, or anything without an account there, so by if a project being on github, you have no choice but to give Microsoft your data to participate in opensource. Don’t get me wrong, mailing-lists are filth, but and I’d rather claw my eyes out than participate in any project demanding their use, but Microsoft being the “lesser evil” is not a good look.

Please, for the love of opensource, get your project off of github, please. It’s a monopoly at this point and doing microsoft things. This isn’t the end and they’ll probably do more stuff to see how far they can push it. We’ll all be the boiled frogs.

Yes, I know they have a CI and some other features, but if all you’re doing is hosting your code, please consider an alternative.

Possible alternatives in alphabetic order:

  • Codeberg (could have federation in the future)
  • Gitlab (has CI)
  • OneDev (no git SSH clone but feature-rich) not an instance for the public
  • Radicle (no CI, but federated)
  • Sourcehut (minimalist, but fast as fuck)

or maybe others will suggest more.

  • yogsototh@programming.dev
    link
    fedilink
    arrow-up
    3
    ·
    6 days ago

    I selfhost using forgejo (the same project codeberg is using) and I only clone on github.

    This should be a good first step to decentralize.

  • For a small project I recently switched to fossil from git. It’s also distributed version control, but includes a bug tracker, wiki, and other stuff as well. It’s minimalist, but hosting yourself is super easy.

    Default git over ssh is often enough as well. Combine with any bug tracker and CI you like. You don’t need to use an all in one tool like GitHub.

  • eronth@lemmy.world
    link
    fedilink
    arrow-up
    1
    arrow-down
    1
    ·
    7 days ago

    I would be pretty interested in reading a more robust analysis between the alternatives you list and GitHub itself. Going to each one and giving them a glance really doesn’t show me much other than “yup, it’s similar to GitHub”.

  • fxomt@lemm.ee
    link
    fedilink
    English
    arrow-up
    150
    ·
    8 days ago

    Codeberg is criminally underrated. The UI is great, it’s 100% open source, it has CI, and it will have federation in the future. It’s a shame more people don’t use it. Piefed/river and a bunch of cool niche projects are on it though :D

    The lemmy developers should seriously think of moving lemmy to codeberg, it’d be in line with lemmy’s anti-corporate stance.

    • kabi@lemm.ee
      link
      fedilink
      arrow-up
      65
      arrow-down
      2
      ·
      8 days ago

      The choice every developer has to make is between having a potentially successful project, with contributors and community engagement, or hosting their stuff on an open platform. PeerTube even has a GitLab of their own, and yet they host their main software on GitHub, because they simply have to.

      • fxomt@lemm.ee
        link
        fedilink
        English
        arrow-up
        44
        ·
        edit-2
        8 days ago

        Yep, codeberg is great for personal/hobby or small projects, but beyond that it’s not ideal. The worst part is git is a decentralized protocol; yet github has centralized it, basically forcing developers to use it if they want their projects to live, or get a job. It’s a vicious cycle.

        But i still think developers should migrate to codeberg, if all of us just wait for codeberg to get big to use it, there’d be no users in the first place. Even if you put your project as a mirror, it’s still a step, or even better: vice versa, see river.

      • 0x0@programming.dev
        link
        fedilink
        arrow-up
        31
        arrow-down
        12
        ·
        8 days ago

        That’s BS, if the software’s good people (i.e. devs) will find the source, unless all they do is spent their day on the github website.
        Most fine software i find is through social media and websites, i then proceed to checkout the code.

        • kabi@lemm.ee
          link
          fedilink
          arrow-up
          18
          ·
          8 days ago

          I get that, and I even made an account on PeerTube’s GitLab just to submit a tiny fix on a secondary project of theirs, but do you think an average issue submitter would bother? I do not. And it’s not as simple as this process separating the wheat from the chaff, either.

        • mesamune@lemmy.world
          link
          fedilink
          English
          arrow-up
          12
          ·
          8 days ago

          I am seeing a LOT of the emulation crowd over at codeberg and other type of sites. Its gaining some popularity which is nice.

        • Kissaki@programming.dev
          link
          fedilink
          English
          arrow-up
          5
          ·
          7 days ago

          You picked one concern of multiple: Code discoverability of an already known project.

          Multiple times I have found project sources on their own platforms, and when I would have contributed tickets or code, I did not because of requiring yet another account on yet another platform, with whatever yet unknown signup workflow.

          And there is man other concerns, some of which the comment you are replied to mentioned.

          • 0x0@programming.dev
            link
            fedilink
            arrow-up
            3
            arrow-down
            3
            ·
            7 days ago

            For yet another account i use a password manager and an email address i only use for crap. It’s a one time process.
            If that’s too much for you then perhaps you’re not that interested in contributing to <project>?

            • Kissaki@programming.dev
              link
              fedilink
              English
              arrow-up
              6
              ·
              7 days ago

              Exactly. It’s a matter of barrier and interest. Signup requirements are a barrier to drive-by improvements and reports, and them as entry points to further contributions.

      • JustEnoughDucks@feddit.nl
        link
        fedilink
        arrow-up
        9
        arrow-down
        1
        ·
        8 days ago

        I really don’t understand it.

        It is 5 minutes to create an account and you can even use the same SSH key everywhere technically.

        Then just put a bit config per website and it literally requires nearly 0 additional work ever. You can commit to all the different places practically simultaneously.

        I guess you have to go to different websites for issues and I don’t know if codeberg specifically has CI/CD tools, but I don’t get why devs refuse to work on things outside github.

        • ReversalHatchery@beehaw.org
          link
          fedilink
          English
          arrow-up
          5
          ·
          7 days ago

          the actual problem is not that you need an additional account, but as OP said, the terms. with an account they can tie all your searches, what repos have you visited and how often, and other non-public activities to you. basically the same data mining that youtube, facebook and others do, just in an earlier stage

        • 0x0@programming.dev
          link
          fedilink
          arrow-up
          4
          ·
          7 days ago

          I don’t get why devs refuse to work on things outside github.

          Herd mentality, it affects devs too.

        • Kissaki@programming.dev
          link
          fedilink
          English
          arrow-up
          2
          ·
          7 days ago

          Pushing commits is just one of many concerns.

          Do you want to suggest synchronizing issue tickets as well?

          • JustEnoughDucks@feddit.nl
            link
            fedilink
            arrow-up
            3
            ·
            edit-2
            7 days ago

            I am not talking about federated git repos. You are right, that is a huge undertaking with many issues to overcome.

            I am simply talking about dev’s willingness to work only within X Y or Z website’s ecosystem even if another project they want to contribute to exists on another ecosystem (for example KiCAD which exists on their own gitlab instance and needs a separate account or gadgetbridge on Codeberg). It is enough to stop many people from contributing.

      • mox@lemmy.sdf.org
        link
        fedilink
        arrow-up
        8
        arrow-down
        4
        ·
        7 days ago

        Only if they measure their success in terms of traffic on a Microsoft web site.

        Successful projects predate GitHub.

      • fxomt@lemm.ee
        link
        fedilink
        English
        arrow-up
        11
        ·
        8 days ago

        I didn’t know, thanks. But last commit was 8 months ago :(

    • Valmond@lemmy.world
      link
      fedilink
      arrow-up
      13
      ·
      8 days ago

      I never sat foot on github, but moved from some shady place to Codeberg and it’s just fantastic. It just works.

      Only thing missing is some 5/10€ monthly plan where you get a golden leaf or something :-p

      On a more serious note, gotta check out how to support them in some meaningful way.

        • Valmond@lemmy.world
          link
          fedilink
          arrow-up
          4
          ·
          7 days ago

          Yeah, figuring to go member, it’s only 24€ a year (FYI 12€ if you can’t shell out that sum) and this is one of the first projects that I’d really like to see take off.

  • Modern_medicine_isnt@lemmy.world
    link
    fedilink
    arrow-up
    70
    ·
    8 days ago

    While I agree about most of your gripes. I don’t think requiring an account to contribute is unreasonable. I can underdtand not wanting to create an account and give them personal info and such. But if that is your stance, stop using them entirely. Giving them code is even worse.

  • communism@lemmy.ml
    link
    fedilink
    arrow-up
    70
    arrow-down
    1
    ·
    edit-2
    8 days ago

    I support moving off GH but

    There is no way to send in a patch, raise an issue, or anything without an account there

    Currently this is the case everywhere? With the exception of projects that take email patches, currently all the options are centralised/not federated, and even if e.g. Forgejo finished adding ActivityPub integration you’d still need an account on some Forgejo instance to contribute. Same for email patches; they still require having an email address. If it’s specifically about giving MS your data, sure, although iirc the only data they actually require is an email address. You can use duckduckgo’s duck addresses to get one that’s relatively anonymous (i.e. can be deanonymised by duckduckgo but I doubt anyone’s conspiring that hard to deanonymise a random github user).

    • kautau@lemmy.world
      link
      fedilink
      arrow-up
      26
      ·
      8 days ago

      Yeah and that makes sense. There’s plenty of examples of open source projects that have had their issue trackers flooded with politics rather than real issues and they have to then spend all their time policing and cleaning that up and that’s using GitHub’s user reg system and basic protections against spam accounts. Without requiring any sort of auth or user reg that would be impossible

    • Deckweiss@lemmy.world
      link
      fedilink
      arrow-up
      6
      ·
      8 days ago

      If you look at a project on sourcehut while not logged in, you will see instructions on the side how to create a patchset and mail it directly to the maintainer, no account needed.

    • mac@lemm.ee
      link
      fedilink
      arrow-up
      3
      ·
      7 days ago

      Pretty sure gitlab requires you to enter a CC to make an account as well, which turned me off from submitting a bug report a few weeks or so back

  • Phoenix3875@lemmy.world
    link
    fedilink
    arrow-up
    33
    ·
    7 days ago

    Specifically for the rate limit issue, a lot of nix’s derivations are hosted on GitHub and now and then the rate limit problem comes up when I rebuilds a dev environment.

    Nixos.org is kind enough to host gigabytes of cache, but to get a ~40MiB tarball, we need to beg at the door of M$. Path dependency is really a trap.

    • onlinepersona@programming.devOP
      link
      fedilink
      arrow-up
      4
      arrow-down
      2
      ·
      edit-2
      7 days ago

      Yeah, nix is utterly dependent on github and there have been many discussions about it. The majority of the community is very against migrating and refuses investing in anything else.

      I remember a project abused github as their CDN, and github shut that down. Can’t remember the name but it was something plant-related (the name). Pods or something. If nix ever scales up massively, github just might rate limit the repo.

      Anti Commercial-AI license

  • atzanteol@sh.itjust.works
    link
    fedilink
    English
    arrow-up
    34
    arrow-down
    3
    ·
    8 days ago

    Yes, I know they have a CI and some other features

    Github actions are terrible - fight me.

    commit: actions
    commit: actions
    commit: actions
    commit: actions
    commit: actions
    commit: actions
    commit: actions
    commit: actions
    commit: actions
    commit: actions
    commit: Another actions fix
    commit: Fixing actions
    commit: Fixed issue with actions
    commit: Actions not logging in properly
    commit: typo in actions
    commit: Created GH actions!
    
    • svtdragon@lemmy.world
      link
      fedilink
      arrow-up
      2
      ·
      edit-2
      7 days ago

      As the primary author of my previous org’s GHAs (not GH Enterprise, just the team tier) I found some feature gaps compared to org[n-2]'s Jenkins but they were fairly quickly filled.

      I was initially skeptical but it wasn’t more than a month or two before I was just glad to be off Jenkins. And now that I’m back to a big org with a big Jenkins footprint, I really miss GHA.

      Having everything be contextual in the same place is a huge value add for me.

    • sirdorius@programming.dev
      link
      fedilink
      arrow-up
      21
      arrow-down
      1
      ·
      8 days ago

      Just commit to a different branch, and then rebase to main. If you’re putting this shit into main, it’s not the tool’s fault.

      • atzanteol@sh.itjust.works
        link
        fedilink
        English
        arrow-up
        4
        ·
        8 days ago

        It’s an interesting idea - but I’ve not been able to get it to work. Some of that is due to us using “GitHub Enterprise” which is somehow MUCH worse than the normal hosted GitHub - but we get to pay more for it! I haven’t tried it with “normal” github.com actions yet - does it deal well with shared workflows and custom builders?

        • thesmokingman@programming.dev
          link
          fedilink
          arrow-up
          2
          ·
          8 days ago

          It does with some hoops IIRC. I used act a couple of years ago to test a very distributed flow for enterprise IaC projects. I can’t remember all of the things we had to do and I think I’m conflating some of the podman issues we had on macOS with act issues. AWS credentials were an annoyance, I think, but we worked around it with some community code. Our primary purpose for act was to be the local testing for enterprise action deployment so I’d guess it’s close to yours. I think our conclusion was to distribute the actions to each repo rather than use the central .github repo for actions because of how GitHub handles overrides. My memory is really fuzzy.

          If you’re going to believe this internet stranger, start with a very simple set of demos to vet me. I remember being very happy; I do not remember how the team solved it. M

          • atzanteol@sh.itjust.works
            link
            fedilink
            English
            arrow-up
            3
            ·
            8 days ago

            As with all things GH Actions related - “it kinda works if you struggle with it for a while”. If I get some spare time I may tinker with it a bit then - knowing things are “possible” is a good start. ;-)

            It’s my biggest complaint with GH Actions - death by a thousand paper-cuts. It’s not that it does any one thing wrong (though the way “shared workflows” work is pretty abysmal) it’s that everything hurts a little to work with. At least if you’re not building an open source project freely shared on github.com and using all public actions.

            • thesmokingman@programming.dev
              link
              fedilink
              arrow-up
              2
              ·
              8 days ago

              Totally agree. I’m glad you read between the lines there. It’s out there if you have the resources to throw at it.

              Like most DevOps things, it’s all about the opinionated ecosystem you hop in. It has most things and does most of the stuff you want until you decide to adapt the pattern to your use case and holy fucking shit is it hard to adapt opinionated ecosystems. That’s why I continue to have jobs.

        • mesamune@lemmy.world
          link
          fedilink
          English
          arrow-up
          2
          ·
          edit-2
          8 days ago

          I know because of security, people jumped off circleci but their local tool was amazing in what it did. No messing around, it worked just like their own platform. Being able to ssh into the box that was failing was a great feeling. Sometimes you just have to get into the box in order to see what is going wrong, and they allowed that.

          Ive had to fight act quite a bit to get the same functionality. Things would go to GH Actions only to do something slightly different and I would have to make a fix. Over time, it gets tiring. Ive worked with CI/CD platforms for over a decade and Actions are…ok. Still feels beta in how much is reliant upon the community which drops scripts from time to time.

          • atzanteol@sh.itjust.works
            link
            fedilink
            English
            arrow-up
            2
            arrow-down
            1
            ·
            8 days ago

            I still like Jenkins… Yeah it looks like early “Web 2.0” still but it’s much easier to use.

            • slowcakes@programming.dev
              link
              fedilink
              arrow-up
              2
              ·
              7 days ago

              We recently migrated our code base to GH and from Jenkins to GH actions. And I can’t say that it’s any better, just more confusing. Shit was much more simpler on bitbucket server with Jenkins. Never realized GitHub was slow until today, loading pages takes like a second.

              My favorite code repository in terms of layout (not functionality) is still gitblit. Looks simpel and easy to read the commit log because that is the first you are shown when navigating in a repository, no PR support though.

    • Ephera@lemmy.ml
      link
      fedilink
      English
      arrow-up
      1
      ·
      8 days ago

      Whenever I need to fix something with them, I go onto a separate branch, write a sane commit message once and suffix it with a “1”. Then the next time, I just grab the same git commit command from my history and change the “1” to a “2”, then to a “3” etc…

      • Eager Eagle@lemmy.world
        link
        fedilink
        English
        arrow-up
        3
        ·
        7 days ago

        I’m sure you can just --amend it and push with --force-with-lease (safer than just --force). That’ll prevent the 78343 commits.

        • Ephera@lemmy.ml
          link
          fedilink
          English
          arrow-up
          1
          ·
          7 days ago

          Oh yeah, you can, but it makes it pretty much impossible to discern between commits in the action run overview. So, if something broke between one change and the other, then you’d have to just kind of know what that change was.
          That is obviously doable, if you make a singular change, then wait for the result before you make the next change. But I often had the problem that I would get interrupted or that I had to continue on the next day, so when I wasn’t quite as clear anymore what lines I changed precisely. Or what also often happened, is that I would get bored while I’m waiting for the action run to complete, so I start making the next change before I know whether the previous change was successful (I guess, this only really starts to become a problem, if it takes 30+ minutes for the run to complete).

          But yeah, I put them onto a separate branch, so I can easily squash them into one commit before putting them back onto the proper branch.

    • flubba86@lemmy.world
      link
      fedilink
      arrow-up
      23
      ·
      7 days ago

      I use Codeberg and even paid to be a member, because it goes directly to support the development of forgejo.

    • onlinepersona@programming.devOP
      link
      fedilink
      arrow-up
      2
      arrow-down
      2
      ·
      7 days ago

      I don’t know if they need more funding or contributors or something, but that has been on the roadmap for years now. I think all they can federate now are stars.

      But I do hope that it’ll arrive soon. Github needs a federated alternative and gitlab isn’t going to give it to us. Radicle already has federation, but only within its network, so not exactly optimal.

      Anti Commercial-AI license

    • Gamma@beehaw.org
      link
      fedilink
      English
      arrow-up
      10
      arrow-down
      1
      ·
      8 days ago

      You’re not okay with anonymous malicious prs? How prude! /s

    • mox@lemmy.sdf.org
      link
      fedilink
      arrow-up
      8
      arrow-down
      1
      ·
      7 days ago

      I read it as needing a Microsoft account, and having to accept Microsft’s terms and conditions, in order to contribute to an unrelated (and probably open-source) project. That’s a valid complaint.

    • Ephera@lemmy.ml
      link
      fedilink
      English
      arrow-up
      5
      arrow-down
      1
      ·
      8 days ago

      The problem is that you end up using software that’s hosted on GitHub and then you’d like to report a bug or contribute a fix. You also don’t want to give your data to Microsoft. Both can be true, because the projects on GitHub don’t exist in isolation there.

      • Azzu@lemm.ee
        link
        fedilink
        arrow-up
        10
        ·
        8 days ago

        idk, the only “personal data” GitHub requires is an email address… If you don’t have a throwaway one not associated to your identity yet, what are you even doing on the internet :D

  • Thorry84@feddit.nl
    link
    fedilink
    arrow-up
    22
    ·
    8 days ago

    I see projects move over to Gitlab a lot lately, but without porting over the issues. That means a huge amount of history and discussions are lost. If you want to find out why something is the way it is, old issues would be a goldmine. Sometimes they are still up on archived GitHub, but not always.

    • StrikeForceZero@programming.dev
      link
      fedilink
      arrow-up
      9
      ·
      7 days ago

      It’s a shame because how gitlab is basically begging to be bought out and hides a lot of useful features behind subscriptions… I remember when it was originally just a GitHub clone way back when.

  • blind3rdeye@lemm.ee
    link
    fedilink
    arrow-up
    20
    arrow-down
    1
    ·
    7 days ago

    I’ve stopped using github because I hate advertising and nags. Probably most people don’t care much about it, but for me github nagging and ‘reminding’ me about copilot is just so off-putting that I immediately want to leave the site. I don’t want my attention stolen like that.

  • oce 🐆@jlai.lu
    link
    fedilink
    arrow-up
    18
    ·
    edit-2
    8 days ago

    It was easy enough to introduce Git with a self hosted Gitea at my work place 4 years ago. I see Codeberg is based on a fork of Gitea called Forgejo, so I guess it is also good.

    • mesamune@lemmy.world
      link
      fedilink
      English
      arrow-up
      5
      ·
      8 days ago

      It’s basically the same even the same plugins mostly work. I believe the biggest changes are on time to market (PRS are quicker but more experimental). And they are doing heavy work on federation.

    • Gamma@beehaw.org
      link
      fedilink
      English
      arrow-up
      4
      ·
      edit-2
      8 days ago

      They forked gitea when the gitea devs created an Ltd to help fund development of the platform. I also remember some noise around the same time when gitea took an extra day to release a security patch.

      They’ve got about half of the activity of gitea which is pretty impressive considering they’re entirely off github, even if they have 1/4 of the contributors in the same time (9 vs 38)