|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102 |
- title: It is important for free software to use free software infrastructure
- url: https://drewdevault.com/2022/03/29/free-software-free-infrastructure.html
- hash_url: ed7544349c2bef8c7f1bfff3ab286fd6
-
- <p><em>Disclaimer: I founded a project and a company that focuses on free software
- infrastructure. I will elect not to name them in this post, and will only
- recommend solutions I do not have a vested interest in.</em></p>
- <p>Free and open source software (FOSS) projects need infrastructure. Somewhere to
- host the code, to facilitate things like code review, end-user support, bug
- tracking, marketing, and so on. A common example of this is the “forge”
- platform: infrastructure which pitches itself as a one-stop shop for many of the
- needs of FOSS projects in one place, such as code hosting and review, bug
- tracking, discussions, and so on. Many projects will also reach for additional
- platforms to provide other kinds of infrastructure: chat rooms, forums, social
- media, and more.</p>
- <p>Many of these needs have <abbr title="Projects which do not use a license compatible with the Free Software guidelines, i.e. non-FOSS.">non-free</abbr>,
- proprietary solutions available. GitHub is a popular proprietary code forge, and
- GitLab, the biggest competitor to GitHub, is partially non-free. Some projects
- use Discord or Slack for chat rooms, Reddit as a forum, or Twitter and Facebook
- for marketing, outreach, and support; all of these are non-free. In my opinion,
- relying on these platforms to provide infrastructure for your FOSS project is a
- mistake.</p>
- <p>When your FOSS project chooses to use a non-free platform, you give it an
- official vote of confidence on behalf of your project. In other words, you lend
- some of your project’s credibility and legitimacy to the platforms you choose.
- These platforms are defined by network effects, and your choice is an investment
- in that network. I would question this investment in and of itself, the wisdom
- of offering these platforms your confidence and legitimacy, but there’s a more
- concerning consequence of this choice as well: an investment in a non-free
- platform is also a <em>divestment</em> from the free alternatives.</p>
- <p>Again, network effects are the main driver of success in these platforms. Large
- commercial platforms have a lot of advantages in this respect: large marketing
- budgets, lots of capital from investors, and the incumbency advantage. The
- larger the incumbent platform, the more difficult the task of competing with it
- becomes. Contrast this with free software platforms, which generally don’t have
- the benefit of large amounts of investment or big marketing budgets. Moreover,
- businesses are significantly more likely to play dirty to secure their foothold
- than free software projects are. If your own FOSS projects compete with
- proprietary commercial options, you should be very familiar with these
- challenges.</p>
- <p>FOSS platforms are at an inherent disadvantage, and your faith in them, or lack
- thereof, carries a lot of weight. GitHub won’t lose sleep if your project
- chooses to host its code somewhere else, but choosing <a href="https://codeberg.org">Codeberg</a>, for example,
- means a lot to them. In effect, your choice matters disproportionately to the
- free platforms: choosing GitHub hurts Codeberg much more than choosing Codeberg
- hurts GitHub. And why should a project choose to use your offering over the
- proprietary alternatives if you won’t extend them the same courtesy? FOSS
- solidarity is important for uplifting the ecosystem as a whole.</p>
- <p>However, for some projects, what ultimately matters to them has little to do
- with the benefit of the ecosystem as a whole, but instead considers only the
- potential for their project’s individual growth and popularity. Many projects
- choose to prioritize access to the established audience that large commercial
- platforms provide, in order to maximize their odds of becoming popular, and
- enjoying some of the knock-on effects of that popularity, such as more
- contributions.<sup id="fnref:1"></sup> Such projects would prefer to exacerbate the network
- effects problem rather than risk some of its social capital on a less popular
- platform.</p>
- <p>To me, this is selfish and unethical outright, though you may have different
- ethical standards. Unfortunately, arguments against most commercial platforms
- for any reasonable ethical standard are available in abundance, but they tend to
- be easily overcome by confirmation bias. Someone who may loudly object to the
- practices of the US Immigration and Customs Enforcement agency, for example, can
- quickly find some justification to continue using GitHub despite their
- collaboration with them. If this example isn’t to your tastes, there are many
- examples for each of many platforms. For projects that don’t want to move, these
- are usually swept under the rug.<sup id="fnref:2"></sup></p>
- <p>But, to be clear, I am not asking you to use inferior platforms for
- philosophical or altruistic reasons. These are only one of many factors which
- should contribute to your decision-making, and aptitude is another valid factor
- to consider. That said, many FOSS platforms are, at least in my opinion,
- functionally superior to their proprietary competition. Whether their
- differences are better for your project’s unique needs is something I must leave
- for you to research on your own, but most projects don’t bother with the
- research at all. Rest assured: these projects are not ghettos living in the
- shadow of their larger commercial counterparts, but exciting platforms in their
- own right which offer many unique advantages.</p>
- <p>What’s more, if you need them to do something differently to better suit your
- project’s needs, you are empowered to improve them. You’re not subservient to
- the whims of the commercial entity who is responsible for the code, waiting for
- them to prioritize the issue or even to care about it in the first place. If a
- problem is important to you, that’s enough for you to get it fixed on a FOSS
- platform. You might not think you have the time or expertise to do so (though
- maybe one of your collaborators does), but more importantly, this establishes a
- mentality of collective ownership and responsibility over all free software as a
- whole — popularize this philosophy and it could just as easily be you
- receiving a contribution in a similar manner tomorrow.</p>
- <p>In short, choosing non-free platforms is an individualist, short-term investment
- which prioritizes your project’s apparent access to popularity over the success
- of the FOSS ecosystem as a whole. On the other hand, choosing FOSS platforms is
- a collectivist investment in the long-term success of the FOSS ecosystem as a
- whole, driving its overall growth. Your choice matters. You can help the FOSS
- ecosystem by choosing FOSS platforms, or you can hurt the FOSS ecosystem by
- choosing non-free platforms. Please choose carefully.</p>
- <p>Here are some recommendations for free software tools that facilitate common
- needs for free software projects:</p>
-
- <p>* Self-hosted only<br>
- † Partially non-free, recommended only if no other solutions are suitable</p>
- <p>P.S. If your project is already established on non-free platforms, the easiest
- time to revisit this choice is right now. It will only ever get more difficult
- to move as your project grows and gets further established on proprietary
- platforms. Please consider moving sooner rather than later.</p>
|