Fediverse

The Fediverse, ActivityPub, & The IndieWeb #

If you’re as active in the same nerdy online circles I am, you’ve probably heard all three of these terms. There’s also a good chance you’re confused how they’re all related. Well, let’s fix that:

The Fediverse #

The fediverse (a portmanteau of “federation” and “universe”) is an ensemble of federated (i.e. interconnected) servers that are used for web publishing (i.e. social networking, microblogging, blogging, or websites) and file hosting, but which, while independently hosted, can communicate with each other. On different servers (instances), users can create so-called identities. These identities are able to communicate over the boundaries of the instances because the software running on the servers supports one or more communication protocols which follow an open standard. As an identity on the fediverse, users are able to post text and other media, or to follow posts by other identities.

- Wikipedia

Alright, that’s a lot to dissect, so let’s break it down.

interconnected servers […] independently hosted […] can communicate with each other

So, basically, a bunch of people are running their own servers but they can talk to one another because they’ve agreed on a standard.

[…] create so-called identities

so, make an account

These identities are able to communicate […]

but this account is recognized by other servers.

So, what this is getting is that you might have something that’s less like Twitter where everything is on one centralized network and more like email. You can have an @gmail.com, an @hotmail.com or make your own - I could (but don’t) have an @opguides.info.

Already based on that simplified explanation this has a few benefits:

  1. You can be host your own server if you really want, so you can control your data
  2. You can be a part of a server that has as tight or loose of rules as you want. Don’t want racists hanging around, then don’t let them.

There are many fediverse services. The most well known one being mastodon which is basically a Twitter clone BUT the weird thing is there are multiple instances. So, like email, you might have an account at https://merveilles.town or https://chaos.social/about or something else entirely, but regardless of what you use they can communicate.

Mastodon has many great instances - more on that in a bit. The bigger picture is that federation can be used for something like a YouTube clone (which is what PeerTube is), streaming audio (which is what Funkwhale is), being-a-better-insta-than-insta (which is what PixelFed is), event planning (see Gath.io), and quite a few other things if you go looking. The point being, for each of these, an (optionally) unified identity can be used and the server you use (or host yourself) can choose who to federate with (talk to). This means it:

  • Is censorship resistant

  • Allows you to join a community that doesn’t allow the things you like

  • Lets you control your data as much as you want to.

It’s a win-win-win. In most systems, these sound contradictory. How can something be censorship resistant, but still have communities with whatever rules they like? Well, the key word there is communities, and that it is plural. These communities are still separate, it’s just that they can federate if and only if they want to.

If a server is full of racist jerks, nobody will federate with them. They can post all they want on their server, but their reach is limited. Yes, this makes echo chambers worse (in both directions) but, it’s a hell of a lot better than the alternative.

Alright, so, this is cool but whenever somebody talks about all of this fediverse stuff, this is only part of the picture. So, next let’s talk about…

ActivityPub #

The website for ActivityPub, activitypub.rocks says:

ActivityPub is a decentralized social networking protocol based on the ActivityStreams 2.0 data format. ActivityPub is an official W3C recommended standard published by the W3C Social Web Working Group. It provides a client to server API for creating, updating and deleting content, as well as a federated server to server API for delivering notifications and subscribing to content.

Sounds exciting? Dive in!

- activitypub.rocks

Which, uh, I don’t know if sounds exciting so much as it sounds like a description of a Rockwell automation retroencabulator.

So, in English, it’s a way for services/websites to talk to each other … which is a form of the above-mentioned federation. So, basically, it’s one way that things can federate. It’s the protocol.

While not the best analogy, it’s not totally wrong to say that ActivityPub is the language things talk to each other in (usually) while the act of talking to one another is federation. So, with the fediverse being the universe of these things that are all talking together, ActivityPub is the way they (usually) talk.

Speaking of both Federation and ActivityPub, usually the IndieWeb will also get mentioned, so…

The IndieWeb #

The IndieWeb is a people-focused alternative to the “corporate web”.

- indieweb.org

Uhh, wow, that doesn’t tell us much. The website goes on to say basically everything I said about what the fediverse is in the first place. The main thing I want to point out from that website is actually this:

You are better connected #

Your articles and status messages can go to all services, not just one, allowing you to engage with everyone. Even replies and likes on other services can come back to your site so they’re all in one place.

- indieweb.org

Which is basically a fancy way of saying when you do something on your own website, it should automatically post links to all the things, and your website should automatically fetch the replies from all the things.

If you’re being pedantic, this means that this website isn’t technically part of the indieweb in full, as it doesn’t post links out automatically, it only fetches replies via webmentions using brid.gy. (1)

Along with that, clearly a big part of the indieweb is being independent, so, big corporate websites, even if they fit everything else don’t count.

Putting it all together #

Let’s go backwards then, by letting me pretend this is an FAQ between two of my characters:

Why would I want my site/service to be on the IndieWeb?


You want your site/service to be able to interact with other sites services

Why would I want my site to be able to do that?


See how at the bottom of this page reactions to it on Twitter, Lobste.rs, various mastodon services, etc. all show up? That’s using something called Webmentions which is something that’s part of the indieweb movement. It lets things be connected without me needing to post it in any one of those places directly. This means I’m still in full control of this website, you’re still in full control of your accounts, but you can talk about this website and people can see that conversation regardless of the platform you’re using (2).

Why would I care if I don’t have a website/server?


Even if you’re not making your own content on your own platform, it still means you can interact with other people’s content without needing to use their platform, that you can join a community that better suits you, and that you don’t have to miss out on anything or be discussing things in a bubble.

Huh?


You like Twitter but not that side of Twitter? Then you can use Mastodon. Mastodon is part of the fediverse, which is made up of indieweb servers, which all federate with each other. You could join a server like eldritch.cafe which is

For queer people, feminists, anarchists and their sympathizers. Mainly French, but other languages welcome

or sunny.garden which is

[…] a community for indie creators who draw, paint, sculpt, write, design, program, play, sing or build, their friends and family, and anyone else who thinks that sounds like a nice place to be.

But whatever server/community/instance you join, you can interact with users on another, unless they block one-another, like if there were a wowireallylovebeingracist.club, the servers can choose not to work with them.

Same concept, different target for the other things listed in the first part of this page, or even me with this IndieWeb site choosing to ignore certain websites for displaying reactions.

Wait, you just talked about the indieweb and the fediverse, but not activity pub.


Yep. That’s because it (usually) doesn’t matter to a user. Yes, a good-portion of the time the fediverse works using ActivityPub, but this is transparent to the user.

Then why bring it up?


Because ActivityPub and Federation are becoming synonymous. So, if you see a site/platform say it supports ActivityPub that’s probably the same thing as supporting federation. Basically, it’s because people will talk about it and if you don’t know you’ll just be confused.

Why is this terminology so confusing?


Feckin’ hell, right? In short, if you’re using Mastodon, you are:

  • On one of many websites that is interconnected in a way that is refereed to as being federated, where all of these federated sites together are called the fediverse.
  • Using Activity Pub behind the scenes when your mastodon instance talks to another. This happens all the time as your toot (the equivalent of a tweet) propagates though all the federated instances.

If, while using Mastodon, you talk about a site like mine, which is (arguably) part of the Indieweb this site will pick up on it and show your comment automatically.

If you then go to use a PeerTube instance like …

The following link is to a specific PeerTube instance. From what I can tell, most PeerTube instances have an abundance of NSFW and unsavory content. My experience with Mastodon has been great, peertube… ehhhhhhh.

video.qoto.org you can use that mastodon identity to follow a channel on PeerTube. Of course, you could also just make a second account on video.qoto.org or any other peertube instance, but you can just use the one you have from mastodon because federation.

I’m still confused.


Reading An Introduction to the IndieWeb (Chris Aldrich) and Why ActivityPub is the future (blog.joinmastodon.org) may help you gronk some of it, but, yeah, it’s a bit confusing, especially since it’s a pretty radical change in the entire way we thing about the internet working.

But wait, there’s more! #

While this article is supposed to be about the fediverse, activity pub, and the indieweb, it would be incomplete without mentioning the overall point of all of this: trying to return to a time when the internet wasn’t dominated by monolithic, global-scale systems. These are good for some things, sure, but they’re really suck for others. A few other things are helping with this:

Webrings #

A webring (or web ring) is a collection of websites linked together in a circular structure, and usually organized around a specific theme, often educational or social. They were popular in the 1990s and early 2000s, particularly among amateur websites.

To be a part of the webring, each site has a common navigation bar; it contains links to the previous and next site. By selecting next (or previous) repeatedly, the user will eventually reach the site they started at; this is the origin of the term webring.

- Wikipedia

Which, is exactly what this website is a part of. Rather than put the button to go to the next website though, I’ll just link the list: https://webring.xxiivv.com. Being a part of a webring is basically a part of having an indieweb website now.

Decentralized networking #

While it’s sure as hell taking its sweet time to get there, there’s some really neat projects that are trying to make the backbone of the internet decentralized. The idea here is that it’s a bit weird that if you were to instant message your neighbor that it has to go over your cell carrier’s or ISPs network instead of your presumably-close-enough Wi-Fi routers just … talking. It’s almost a little too obvious to the point that it sounds dumb it doesn’t work this way already.

To various degrees and in different ways, project like yggdrasil, ipfs, cjdns + hyperboria, and beaker among many, many others are trying to make this future a reality.

The not http-web #

When you go to a website and do (almost) anything, all of the content is severed over the Hypertext Transfer Protocol (or HTTPS, the secure variant). HTTP is great, it’s allowed us to make the bad as internet we have today. But, it can sometimes be a bit too freeing. That freedom is why we have a lot of websites which sucks for screen readers, are full of obnoxious ads, etc. So, there are alternatives.

The big two are Gopher and Gemini, and at risk of pissing people off by treating them like they’re the same thing, they’re both very limited. You can display text, images, etc. but the way those websites actually arrange the content and show it to you is up to your browser. The websites themselves only provide the content, they leave it up to the browser to decide how to display it. If you want to try out a browser, see Castor and noodle around. (or maybe bombadillo if you’re a TUI person)

If you want to know more in a not incorrect and at least less-simplified way, give Gopher, Gemini and The Smol Internet (Tales From The Dork Web #22, Steve Lord) a read.


If you would like to support my development of OpGuides, please consider supporting me on GitHub Sponsors or dropping me some spare change on Venmo @vegadeftwing - every little bit helps ❤️