Open Indie

Writing about open & equitable product development

Three months ago I submitted a post to the Rust sub-reddit called Building a better /r/rust together. It quickly rose to the top and garnered 230 comments before the sub went dark along with the bulk of mainline Reddit during the blackout protest.

My call-to-action hailed Lemmy as a fitting successor:

I really love the /r/rust community. As a community manager it's my main portal into the latest happenings of the Rust ecosystem from a high-level point of view primarily focused on project updates rather than technical discourse. This is the only Reddit community I engage directly with; my daily fix of the Reddit frontpage happens strictly via login-less browsing on Apollo, which will soon come to an abrupt end.

This moment in time presents a unique opportunity for this space to claim its independence as a wholly community-owned operation.

Soft-forking Lemmy (...) Given Lemmy's controversial culture, I think it's safest to approach it with a soft-fork mindset. But the degree to which any divergence will actually happen in the code comes down to how amenable the Lemmy team is to upstream changes. I'd love for this to be an exercise in building bridges rather than moats.

In the months since, Lemmy has grown immensely, both in scale and culture:

  • After Mastodon and Misskey, Lemmy has shot up to become the third most popular ActivityPub software in the fediverse: https://fedidb.org
  • The “threadiverse” (Lemmy + Kbin) counts 100k monthly active users.
  • lemmy.ml, the canonical instance run by the Lemmy core devs, has become more diverse and less extreme on the fringes.
  • lemmy.world is by far the biggest instance, providing a healthy counter-balance in the cultural melting pot of the global Lemmy community.
  • The Lemmy devs have welcomed many new contributors on GitHub, demonstrating a highly collaborative disposition.
  • In a recent AMA (sort by Top or read this summary) the pair of core devs lead with openness and alluded to a fairly hands-off approach with regards to the Lemmy/threadiverse community & network at large.
  • Lemmy frontend alternatives are popping off. The excellent Photon recently reached full feature-parity with the official lemmy-ui.

I'm happy to report that a soft-forking initiative seems completely unwarranted at this time. The Lemmy ecosystem is thriving 🌈

From Age of Coordination:

A month after the Reddit exodus, Gizmodo boldly claimed “Reddit won”, because Reddit is still left standing. Similar stories have been written about Twitter vs Mastodon.

This type of analysis repeatedly fails to recognize two crucial factors:

  1. Platforms die with a whimper, not a bang. Digg, the precursor to Reddit, is still around today, it's just not relevant. You can even visit MySpace right now if you'd like, but you won't. Twitter/X may still be operational, but its status as the internet's public square has long since been lost (not that it ever deserved it).

  2. Twitter and Reddit may have only lost a few million users to Mastodon and Lemmy so far, but these are nation-sized numbers, comparable to what Scandinavia is to the United States of America. The incumbents have allowed the fediverse to reach critical mass. It's only gonna get bigger, but it already works well enough that I've no need for any other social network. It's nicer here.

Charting a path for a federated /rust

During the Reddit blackout, a handful of different alternatives to /r/rust gained traction:

So which one should Reddit migrants move to? This is a common predicament and was the 2nd most upvoted question in the aforementioned AMA. Also discussed recently in We should have something like federated communities.

The problem that needs solving was succinctly put in a discussion on Community Grouping:

As a user, I recently wanted to post to AskLemmy. Almost every single instance has their own separate AskLemmy implementation. Naturally, I'd tend to post to the one with the most users. But inherently, I'm missing the majority of users by only being able to post to one. I.E., I posted to AskLemmy@lemmy.ml (which had 3k users), but by doing that, I'm missing out on the users from lemm.ee, behaw, lemmy.world which in total are far more than 3k.

No one wants to individually subscribe to 5 different versions of AskLemmy, nor do they want to cross post 5 separate times.

This problem will intensify once Groups are supported in Mastodon, Pixelfed and FireFish.

Community Grouping Redux

There are several feature discussions about different forms of community grouping on the Lemmy GitHub. The problem is each discussion has diverged into talking about several distinctly different implementations, making consensus impossible.

To my eye there are three key proposals in play. They are not in opposition to one another and solve different problems.

Client-side group collections

https://github.com/LemmyNet/lemmy/issues/818

This is the type of grouping Redditors will already be familiar with as 'multireddits'. It's simply a mashup of multiple subs into one stream, like so:

https://www.reddit.com/r/NoStupidQuestions+explainlikeimfive

Useful for people who want to curate their own stream-combos, but it doesn't solve for a fragmented Rust stream.

Server-side group syndicates

There's no canonical proposal for this yet, but the general idea is to build some type of consensus mechanism for several subs of a similar flavor to opt into a shared hub. There's a proposal to group by tags, reminiscent of repo tags on GitHub. Another is Sibling Communities.

These are novel ideas worth exploring, but they all present major coordination challenges. The absence of coordination is what brought us to the current state of multiple “competing” Rust subs.

I've talked to some Lemmy-Rust admins and they are in fact eager to coordinate more, but anything that involves advanced administrative procedures is a non-starter.

Group-to-Group following 🌟

At long last, we've arrived at what I firmly believe is the solution for decentralized common-purpose communities like a /rust, /AskFedi or /montreal:

Let ActivityPub groups (Lemmy 'community' or Kbin 'magazine') follow other groups.

The idea appears to have been around for years, but we never had a mainstream use case for it until the threadiverse became a thing. Now we do, and it feels like we're finally about to make use of the untapped superpowers of the ActivityPub protocol! A centralized app like Reddit just couldn't do this.

If groups can opt to effectively federate directly with other groups, they abide by the same network dynamics as the fediverse at large, I.e. cross-network self-moderation by means of (de)federation. No consensus management needed beyond what different instances on the fediverse are already used to, just on a more granular level.

This feature been explained in detail here.

It also exists as a spec draft: FEP-d36d: Sharing Content Across Federated Forums.

And with that, we have a new call-to-action for any fedi-curious Rust developer out there: Implement FEP-d36d for Lemmy. If anyone wants to step up, I recommend centering the discussion about this in the FEP discussion forum where there's less ambiguity about the job to be done, and it'll also be easier to coordinate with parallel implementations in the likes of Kbin.

I can be found on the SocialHub forum, on Mastodon, or on the Discord we originally set up to coordinate 'better /r/rust'. Hopefully there's someone out there who shares my excitement for what can be made possible here!

P.S. Other impactful but less clearly defined Lemmy enhancements include:

If you are running a new open source project that's ready to start its social media presence, I urge you to do it on Mastodon, the default entryway into the fediverse.

Joining the fediverse is a lot like installing your first Linux distro. Nothing is quite as easy as what you're used to; seemingly simple tweaks lead you down deep rabbit holes of community-curated knowledge spread across unofficial wikis and old-school bulletin boards.

But somehow it doesn't feel all that laborious. That's because you didn't install Linux to save time. You entered the world of Linux (or WordPress, Node, Python etc.) because you got the sense that something is happening over there. People who are as annoying as they are clever never seem to shut up about it. And with every obscure new hack you add to your toolbelt, there's a thrilling sense of mastery.

As with the Linux community, when you poke your head into the fediverse you will find the others; your fellow geeks and misfits. Sure, you'll also run into dogma and ignorance like anywhere else, but on the fediverse the cultural status quo isn't determined by a gated top-level management, it's an open ticket labeled 'help wanted'.

Permeating the whole experience is the deeply reassuring certainty that you are considerably more in control of your digital experience than you ever were before you took the leap.

The bird sings a different tune now

It used to be that you had to use Twitter because of its network power and consequent reach. Not so much anymore:

The majority of large open source projects today are still on Twitter/X, but that's because they've already got their audience there and the platform works very hard to keep them locked in.

That's ultimately what it all boils down to: The fediverse isn't a private prison exploiting its inmates for free labor, it's an open landscape of interconnected villages, wherein its inhabitants are free to come and go as they please. Your follows-list is yours to keep forever. You are in control, not that guy.

Shaky first steps

Mastodon is easy and fun except when it isn’t. Just like joining any other open source community for the first time, there's a trial-by-fire to overcome at the beginning as you're implicitly challenged to choose your own adventure.

So why make the effort? Because the fediverse, like open source, is a movement. It runs on the same interoperable internet protocols that enable you to view this HTML document in a standards-based web browser.

Concerning reach, I could point to how networks of (invariably) 100 million users like Tumblr and Threads are committed to federating with the fedi-net (at least the instances that'll allow them to), but I will argue that the 10+ million people already on the fediverse are actually the exact group of nerdy open culture enthusiasts you wanna be reaching out to. As the common startup advice goes (which I can attest also holds true for community building), this is where you'll find the first 10-100 people who love your project.

Twitter might have 20x as many total users, but the number of open software techies on either network feels increasingly even and will keep shifting in favor of Mastodon & friends as the prison-platforms continue to enshittify.

Ride the mammut

The hardest part about entering the fediverse is (1) joining an instance and (2) finding people to follow.

In spite of what some might tell you, which instance you choose does matter. Crucially you do always have the ability to move, even though it's not pain-free. Like the whole ecosystem it's a work-in-progress, and will get easier.

As an open source practitioner I trust you know how to do your own research, but if the prospect of that arduous first step is preventing you from jumping on, just go ahead and join hachyderm.io right now.

Operated by the Nivenly foundation, Hachyderm checks all the boxes most OSS folks should care about:

  • Strong track record of uptime and robust infrastructure.
  • Well-funded org with high degree of transparency (i.e. unlikely to go poof).
  • Diverse leadership and community.
  • Tech-leaning but open to all.
  • Highly safety-minded, as most recently evidenced by their Federation Safety Enhancement Project.

As for who to follow, there are a number of things you could do, but I will simply suggest the following: Browse through the #opensource tag and follow 50-100 people therein which you find remotely interesting. That should be enough to get you started. And by favoriting/boosting these people's posts, they'll be made aware of your existence as well. That's the empty timeline problem taken care of.

There's no time like the present; hop on!

§ Article Discussion

Preamble: This is a meandering piece! It's a mashup of ideas revolving around interoperability that will be a lot easier to understand if you've already read Web of the People and Assembling Community OS.


In his article “Memex is already here, it’s just not evenly distributed”, Filip Hráček writes:

Here’s the thing. If I’m being honest, most of my experiments with the different memex descendants mentioned above just kind of faded after a few weeks or months. And the reason is not just habit. If they were such a huge boon to my productivity, I’d change my habit the same way I changed it for better IDEs, better social media consumption strategies, or better terminal defaults.

No, the reason those shiny new apps don’t stick is interoperability.

This is where the Noosphere approach of being protocol-first is fundamentally different. Protocols are interoperability frameworks, and we are witnessing a sea-change in protocol convergence for the internet's communication infrastructure.

Stefan Lesser chimed in on this proclamation:

I’m glad that protocols are exciting again, which just means agreeing on stuff is exciting again.

But then agreeing on stuff comes with consequences. It means limiting your freedom. You can’t just do what you want. You can’t just try something new. You can’t just go it alone.

A lot of technology we still use today came from agreeing on stuff. But then agreeing on stuff fell out of favor and companies pushed hard to be first, best, or cheapest. And that brought us a lot of other technology, often deteriorating and short-lived.

I’m unconvinced that we suddenly changed our collective mind and worry that many people still only like agreeing on stuff as long as it means “others agree with me”.

We're now living in the mess of what everyone just doing whatever they want to do gets us. The past two decades have been the age of disruption; move fast and externalize the costs.

The Silicon Valley VC mindset doesn't understand collectivism. Rather than solving problems in the best way possible, the disrupters relentlessly race to be first to market with a minimum-viable solution that allows them to monopolize a problem space for their own enrichment. It's all about value capture for an elite few, instead of value creation for the global commons.

In the collective model of open source development, value creation/capture dynamics are fundamentally different:

Open software generates greater value overall, to the benefit of more stakeholders. Protocol development is a radical form of openness practice, concerning itself first and foremost with wide reaching coordination challenges as opposed to technical problem solving for narrow boundary goals.

Belly of the Beast

Software has indeed eaten the world, but we've been consumed by the wrong type of software leviathan. Instead of building our digital frontier on the back of a benevolent world turtle in a symbiotic co-existence, we're trapped in the belly of a domineering cloud-whale whose primary function is control rather than autonomy.

In the closed-cloud paradigm, it's only the rent-seeking infrastructure landlords who get to do what they want, while the rest of us have to build according to their strict specifications. That's not an environment conducive to emergent co-evolution.

According to Joseph Campbell's timeless monomyth of a Hero's journey, our current state of entrapment is merely the end of Act 1:

The belly of the whale represents the final separation from the hero's known world and self. By entering this stage, the person shows a willingness to undergo a metamorphosis.

“The idea that the passage of the magical threshold is a transit into a sphere of rebirth is symbolized in the worldwide womb image of the belly of the whale. The hero, instead of conquering or conciliating the power of the threshold, is swallowed into the unknown and would appear to have died. ... This popular motif gives emphasis to the lesson that the passage of the threshold is a form of self-annihilation. ... Instead of passing outward, beyond the confines of the visible world, the hero goes inward, to be born again”

Thus the stage is set for a reclamation of our digital selves. It's time for Act 2!

Federated Coordi-Nations

In his book The Network State, Balaji Srinivasan posits that a startup society – the initiating precursor of a network state – can begin with the formation of any online community, like a Facebook Group or a Discord server.

Balaji can be faulted for many things, but I can only commend him for trying to imagine what greenfield state building might look like in a status quo that considers this to be impossible.

By default I don’t trust Balaji's personal motivations, on account of his billionaire status. So when he invokes ideas like collective action, rather than trying to deconstruct what he actually means, I just make note of that fact that he felt compelled to make that invocation. Even if he doesn’t fully embody the idea, he acknowledges its power.

For an in-depth critique I recommend The Blockchain Socialist's 'Overthrowing The Network State' series. Their work has recently culminated in an alternative model of the network state concept: The Rise of Coordi-Nations.

Coordi-Nations are voluntary interwoven networks of communities, with aligned values and a shared identity. They mutualise resources to redistribute them within the network to engage in collective action, through participatory governance and interdependency between nodes.

This is a remarkably fitting description of the community-owned instances that make up the fediverse.

While legacy networks like Twitter, Facebook, Reddit and Discord are startup societies of the monolithic nation-state variety, Mastodon, Firefish, Lemmy and Commune represent the new world of borderless coordi-nations, i.e. protocol-derived platforms for cooperative network states. What they lack in size they make up for in the collective power of their interoperability and common purpose.

Playing co-op games

A month after the Reddit exodus, Gizmodo boldly claimed “Reddit won”, because Reddit is still left standing. Similar stories have been written about Twitter vs Mastodon.

This type of analysis repeatedly fails to recognize two crucial factors:

  1. Platforms die with a whimper, not a bang. Digg, the precursor to Reddit, is still around today, it's just not relevant. You can even visit MySpace right now if you'd like, but you won't. Twitter/X may still be operational, but its status as the internet's public square has long since been lost (not that it ever deserved it).

  2. Twitter and Reddit may have only lost a few million users to Mastodon and Lemmy so far, but these are nation-sized numbers, comparable to what Scandinavia is to the United States of America. The incumbents have allowed the fediverse to reach critical mass. It's only gonna get bigger, but it already works well enough that I've no need for any other social network. It's nicer here.

Like one Lemmy user commented:

The way I see it, all of us who migrated here won. Enshittification is eventually going to kill Reddit, the only question is when.

I really do think a brain drain is happening. Occasionally looking over the fence, it appears the people still active on Reddit are a tad more complacent and nihilistic. Gone are the early movers and enthusiastic pioneers who still (or once more) believe in a Web of the People.

Mastodon, Lemmy and their many peers are all uniquely part of the same interoperable network of loosely coordinated builders, intrinsically motivated by the daily experiencing of their self-made spaces. Far better than your regular social-engagement network, the fediverse is a movement. And unlike the walled silos whose only metrics are captive users & clicks, the success of a movement is measured in its ability to inspire change and drive coordinated action.

Generative AI (LLMs) hasn't worked for me yet, especially not as a digital assistant with a conversational interface.

But I can see such a thing working exceptionally well as a translation layer between me and the most prevalent algorithms of my daily life.

I'd love to have a conversation with my Spotify algorithm:

  • Chill it down by about 20%
  • Prioritize this artist higher
  • Create a new playlist with songs I've never heard before based on these two playlists
  • More oomph!

The DJ-assistant doesn't need to be perfect, it just needs to make a change, and explain basically how that was done. As long as you can continuously tweak your sorting algorithms in a non-destructive (i.e. fearless) manner, your 'algorithmic literacy' will keep improving.

Conversational AI gives the general public a plain language way to understand and interface with algorithms that are otherwise only understandable to <1% of the population.

Of course, Spotify won't open up their algorithms to make this possible to do with anything outside of their self-biased control. Nor will Twitter or Reddit, but thankfully we've got open alternatives like Mastodon or Lemmy to freely tinker with, and at least the latter is starting to embrace more advanced sorting algorithms that could be worth re-tweaking for fun and (knowledge-) profit.

Another good candidate for prototyping this thing might be Tumblr, which recently open sourced the majority of their algorithms.

I dunno, maybe there's something there. If you see it, please feel free to make this idea your own!

Oh, and I'd only trust an open source and local-first AI assistant to insert itself between me and my most used applications, obviously.

Online community platforms are assembly-kits for large, communal bonfires, designed to draw people towards the light and into the warm togetherness of community. I think the primary function of bonfire software is to create space for group-scale discourse.

campfire_by_nozomi_m_db62vkk-fullview 'Campfire' by nozomi-M

Riffing on thoughts about healthy information consumption, Tom Critchlow described his personal campfire thusly:

https://tomcritchlow.com/2018/10/10/of-gardens-and-wikis/

Campfires – mostly blogging for me, though I know some folks gather around private slack groups too. My blog functions as a digital campfire (or a series of campfires) that are slower burn but fade relatively quickly over the timeframe of years. Connection forming, thinking out loud and self referencing. This builds muscle, helps me articulate my thinking and is the connective tissue between ideas, people and more. While I’m not a daily blogger I’ve been blogging on and off for 10+ years.

Blogs however are only good bonfires insofar as a blog has a chatty audience. Even when they're talkative, blogs are a one-to-many medium, as opposed to the many-to-many connectivity you can easily imagine if you draw lines between five or more people gathered around a central flame.

Group chat is the epitome of this dynamic. Get five people with a shared interest into a chat room together and you've just started a community!

aside: Discord, the reigning king of group chat, was apparently even going to be named 'Bonfire' in its nascent stages. Gotta say I'm very happy to still have bonfire as a term belonging to the public commons.

Chat has its limits though. For information to be synthesized into knowledge, the rate of messaging needs to be slowed down to make room for less reactive, more deliberate, long-form expression.

Forums, with their boards and threaded messages, serve this function. The bonfire's contribution to the digital garden happens through threads, aka topics. Specifically, threads with hyperlinks, so they can point to one another. That’s the essence of it.

Notes [aka threads] are conversations across time Thought Legos (threads as cards)

Today the book is already (…) an outdated mediation between two different filing systems. For everything that matters is to be found in the card box of the researcher who wrote it, and the scholar studying it assimilates it into his own card index. – Walter Benjamin

Making a garden-minded community platform

Five years at Discourse taught me a lot about the interplay between 'chatrooms' and 'forums' as two different modes of conversation.

While chat is immediate and primarily synchronous, communication in Discourse is gradual and asynchronous. We've seen far too many community managers treat these two modes of communication as competitors. Quite on the contrary, chat and forum communities can complement one another beautifully

Group chat is great for..

  • Minimum-viable community building
  • Real-time or same-day resolutions
  • Urgent notifications
  • Socialising in the moment
  • Surface-area problem solving

Forum discussion is great for..

  • All-inclusive dialogue The asynchronous nature of a forum community effectively lowers the bar about as far down as it can go. You’ll get a much greater diversity of input if you solicit feedback from anyone who’s available some time in the next 24, 72 or 168 hours as opposed to right now.

  • Communities of scale Similar to what version control did for code and wikis did for encyclopaedias, forums have long since solved the “too many chefs” problem for discussion at scale. Hundreds or even thousands of people can discuss an equal amount of topics simultaneously on a forum because (1) discussions are broken up into logical topic blobs and (2) long-form input is strongly encouraged over rapid-fire back-and-forth debating.

  • Knowledge synthesis, storage & distribution The permanence and discoverability (web-readable links) of a forum topic makes it an excellent storage of knowledge.

  • Slow deliberation Rapid chatter should be reserved for matters of true urgency. The vast majority of communication can happen asynchronously, leaving ample space for deliberation and global participation. Ironically, slowing down our conversations enables us to reach good resolutions faster.

  • Civilized discussion If you hold someone’s comment for moderation in chat, that’s incredibly frustrating because the norm is live discussion. On a forum on the other hand the expectation is that you’ll get a reply within a few hours or even days after posting, so if your post gets flagged? No biggie, you can wait, and maybe even reflect a bit on what you've said in the meantime.

Duality of (A)synchronicity

Left unsaid in that article was my newfound conviction that synchronous vs asynchronous was a false duality as far as any community platform is concerned. Both modes are required for good conversation to arise and thrive.

As separate apps you can still mash the two discussion mediums together, but it has some flaws. You end up with:

  • Duplicate user directories
  • Competing forms of private messaging
  • “Where does this message belong?” uncertainty
  • Poorly integrated tools for content gardening

Most open source projects don't have a dedicated forum, but the ones that do almost certainly also have a group chat. My last stint at Discourse was an attempt to merge the two modes together, with the introduction of Discourse Chat.

I'm really proud of that MVP (which has since graduated into core), but the direction I wanted to go from there was understandably incompatible with the Discourse project's DNA as a traditional forum: I proposed we make chat the lead of our community experience. Community begins in the chat rooms, I thought. Discourse thought not, so we amicably parted ways.

Years later, my position remains unchanged. 'Group chat' and 'forum' ought to mean roughly the same thing. That's in fact the direction we seem to be headed in, since Discord, ruler of our community lands, now supports a variety of threads & boards features that fit neatly into the forum paradigm.

Mainstream forum software

Discord today is equal parts group chat and forum. I wish I could say “problem solved!”, but there are some critical failures in Discord's makeup:

  • Discord is not web-readable and thus only minimally linkable. I doubt they ever will be, because it weakens their anti-competitive moats. In other words, they're not interested in participating in the great knowledge commons of the open internet.

  • Discord mixes different thread concepts (chat-channel threads vs forum-channel threads) instead of building a unified forum interface for threads as a progressive information artifact that can evolve from simple to complex in a lossless manner. (I can explain more of what I mean by that in an addendum.)

  • Discord's finances are dubious. They've taken a billion dollars in investment. Watch what happens when they try to 100x that. Enshittification ensues.

  • Discord is closed source. Communications software is critical infrastructure; its basic functions and inner workings should always be freely available to the public.

If Discord isn't the answer, what is?

The Contenders

Mattermost, Rocket.Chat, Discourse, Zulip, Linen; These are all great open source alternatives to Discord as a group messenger. But Discord is the superior community platform by being the one thing these other alternatives are not: A network.

As the ongoing mass-migrations from Twitter to Mastodon and Reddit to Lemmy/kbin have shown, internet users have become better informed about the dangers of centralization and networking effects. When the incumbent platforms fully enshittified, users didn't flock to just any other app for an easy fix. Instead of continuing the vicious cycle of identity lock-in and data harvesting, we sought out the open networks.

Even the rising Twitter-killer Threads – under pressure from a savvier internet populace and impending EU regulations – openly acknowledges the value of network independence and ones right-to-exit.

ActivityPub is already the official protocol for social networking on the internet, albeit not widely known as such. If Meta follows through on their commitment to support ActivityPub, the protocol will be elevated from niche internet standard to mainstream internet default.

When Discord inevitably implodes, there's only one clear contender for migrants in search of an open messaging network:

Matrix, “an open network for secure, decentralised communication”. It's a foundational assembly-kit for networked chat applications. As a pretty big bonus it's also encrypted by default and thus signs everything, which facilitates socialized proof of work. (This stringent commitment to security however does come with some usability concessions that I'll address another time.)

The Matrix protocol is a major accomplishment. Still, having been made by people who care first and foremost about how messages are sent (securely, reliably, quickly etc.), there are gaps to be filled by people who care instead about how messages are written, displayed and organized as part of an ever-evolving knowledge mosaic.

Information into Knowledge

It bears repeating: Communications software is critical infrastructure. In the absence of communication, conflict resolution becomes either stagnant or outright violent.

Messages are transfers of thought. One mind's idea transmitted to another, through whichever medium of transport is best suited for the job. We share our inner thoughts with external peers to construct a shared reality. How we collectively view the world is downstream of our individual ability to convey our personal experiences.

Our collective power and agency in this world is only as strong as our freedom for individual expression; our capacity for pro-social change can be measured in how freely we may exchange messages with one another.

Evolutionary Communication Protocols

In pre-literate society, our communication protocols were hardly different from wolves, whales or magpies:

  • Thinking; inner voice
  • Conversing; communal discourse
  • Gossip & speeches; word-of-mouth broadcasting
  • Singing; educational storytelling

As we evolved into a proto-literal society, our ancient comms protocols were layered on top of technologies for stored language:

  • Thinking transcribed into a private diary: personal messaging
  • Conversing across time and space by sending letters: interpersonal messaging
  • Large-scale gossip by distribution of pamphlets/newspapers: broadcasted knowledge
  • Songs & folklore transcribed & elaborated into epics, shared as books: organized knowledge

Our capacity for thinking and knowledge accumulation has grown exponentially ever since, and this trend shows no signs of stopping in the digital age. With an overwhelming flood of information surging through our society's digital pipes, we need valves to regulate the flow.

Life of a digital message

Messages are living information artifacts. As content blobs they can morph through many different forms, from ephemeral musings to everlasting tomes of shared understandings.

Let's consider the lifecycle of a message as contained and transferred through digital mediums.

message-progression

At first there's just a thought. Let's say this one isn't even written down anywhere. It just exists as some vague idea in someone's head.

Once a message is expressed in a chat room it has taken on its initial form for the purpose of storage & transmission. After some back-and-forth the core of the message will become evident as a recurring topic of discussion.

A series of related messages can then be glued together to make a thread. By synthesizing multiple chatty idea fragments into a cohesive micro-thesis, the flow of discussion can be focused towards an end-goal. In the context of a thread, comments are written in response to the opening thesis, as opposed to in a chatty context where you're generally responding to any message immediately preceding yours.

With a draft thesis sufficiently scrutinized and supplemented, a final synthesis brings it all together into a carefully edited article; a fully grown knowledge artifact. And at every stage of our message exchange, each new bit of information feeds back into our collective minds to form new thoughts.

Not every message takes this exact path, but the above is a common example of how community software acts as a seeding ground for ideas to go from noisy information blobs to restful knowledge gardens. For current messaging software, and Matrix in particular, this is the gap that needs filling.

Outward notes, inward notes Unconscious R&D

Commune

Today we're pre-releasing Commune, our first foundational step towards a community platform built specifically for alignment with digital gardens. Cyber-ecological messaging anyone?!

It's an evolving piece of software serving as the primary bonfire component of the Community OS concept.

It currently exists as two different but complementary entities:

Commune app

Commune is an open source community-building application built on top of the Matrix protocol. The app consists of a server-backend and a client-frontend.

While in v0.x_pre-alpha it is essentially Linen (or Discourse Bot Kit), but for Matrix instead of Discord/Slack. Hook your existing Matrix instances up with Commune to give your channels web-public threading superpowers.

The app aims to eventually reach relative feature parity (not symmetry) with Discord as well as Reddit, by building on top of the Matrix and ActivityPub protocols. Commune is protocol-first software.

Easy self-hosting is a top priority, but can only happen downstream of improvements to Matrix (and to a lesser extent, ActivityPub) server software like Synapse and Conduit. Until Commune-app is more mature, the recommended way to use it is via Shpong.

Shpong dot com – powered by Commune

Our first flagship instance built with Commune is shpong.com

Screenshot 2023-07-12 at 20 22 48

It's a Reddit-like site that operates a network of sub-communities. We've gone through so many iterations with the Commune software, but our collaboration has been happening ever since @ChurchOfTheSubgenius revealed Hummingbard, the first iteration of what is now Shpong.

Screenshot 2023-07-12 at 21 17 57

A few real world calamities got in our way, but we're still in motion. Reinvigorated by the gross mismanagement of the world's leading community spaces and the inspiring response of the fediverse as a protocol-driven alternative to the broken status quo, we're officially throwing our hats in the ring.

Today's subtle announcement at the tail-end of a 2000 word essay is not our grand reveal of Commune. This one's addressed to our fellow comms nerds who can pick up on what we're putting out while the software remains half-baked. Let's talk!

Matrix: https://matrix.to/#/#commune:matrix.org Discord: https://discord.gg/BkEpMzzh38

The official lemmy-ui works fine, but it has never been a top priority for the Lemmy project; understandably so, as they've been focused on pioneering an ActivityPub-enabled forum backend.

Thankfully the UI side is now receiving a ton of updates, but alternatives are still much needed:

  • lemmy-ui is styled like legacy Reddit, which isn't everyone's preference. (I personally have no need for the sidebar.)
  • Inferno is a rather niche framework that raises the bar-to-entry for some prospective contributors.
  • Alt-frontends make for a healthier app ecosystem.

I like to go on the occasional GitHub safari by searching within a trending area of interest. Today I simply looked up the most recently updated repositories containing the keyword 'lemmy' and I'm thrilled to report that if you're in the market for a new Lemmy frontend, you've got plenty of promising options in the making!

The following are my handpicked examples and not an exhaustive list. I'm only including frontends that are already usable or close to it. I'm sure there are others to be found on indie and self-hosted code hosts out there as well (I did have a look through Codeberg and sr.ht), but afaik there's no good search tool to discover those repos.

edit: this list is more comprehensive.

Svelte – Web

Slemmy

https://github.com/diamondburned/slemmy

sx-lemmy

https://github.com/sheodox/sx-lemmy

https://github.com/ando818/lemmy-ui-svelte (Mobile support via Capacitor)

React Native – Web/Mobile

https://github.com/aeharding/wefwef

https://github.com/gkasdorf/memmy

Flutter – iOS/Android

https://github.com/liftoff-app/liftoff

https://github.com/hjiangsu/thunder

Swift – iOS

https://github.com/mormaer/Mlem

Kotlin – Android

https://github.com/dessalines/jerboa

GTK – Linux

https://github.com/lemmygtk/lemoa

Sync – Android

Though my focus here is on open source apps, Sync for Lemmy deserves an honorable mention as the first major app to “pull an Ivory” by abandoning the enshittified Reddit platform and pivoting over to the open source Lemmy (perhaps also kbin et.al.) ecosystem. Bravo!

Opportunities for collaboration

There are two takeaways I'd like to highlight from these findings:

Developers, you've got friends out there! Divergence is a necessary component of innovation, but at some point the pendulum needs to swing back in favor of convergence and shared foundations.

“If you want to go fast, go alone. If you want to go far, go together.”

Projects that are built with the same framework are great candidates for collaborative efforts. Sure, you might have different UX preferences, but that's what theme systems are for. Start by looking at your commonalities rather than your differences and there's a good chance you'll find the pros of working together far outweigh the cons.

Sysadmins, consider officially adopting an alt-frontend, effectively as a mutually beneficial partnership.

  • Gives your instance a unique identity.
  • More agency over instance interface features.
  • Lends legitimacy to the alt-frontend(s) of your choice.
  • Directs developers who are aligned with your community towards that open source project.

Bonus side-quest: The join-lemmy site would greatly benefit from the equivalent of Mastodon's app directory.

As these fresh new frontends mature, we march ever closer to a new UI paradigm of multi-modal Juicy Clients, capable of rendering our multi-faceted fediverse in all of its splendor through one seamless interface.

p.s. If you're a client-side Rust developer, I've started discussing the prospect of a juicy client with Ebou, a Mastodon frontend made in Dioxus.


Discuss:https://writing.exchange/@erlend/110616473377954593 – Lemmy (link pending)

There’s an increasing obsession with “humanness” these days:

While necessary in some contexts, it’s a limited solution to a contrived problem. There’s always gonna be a need for anonymity and permissionless identity on the web; it’s how disadvantaged minorities can put forth counter-cultural ideas to be judged on their intellectual merit alone, decoupled from personal identifications at risk of discrimination and censorship.

As an alternative to proof-of-humanity, I’m toying around with proof-of-work in a practical sense of social networking, completely unrelated (but not in opposition) to blockchain.

Outside of making a personal connection, I don’t need to know the identifications of the person on the other end of the line in my online interactions so long as they’re doing good things that align with my values. If something of value can be created through our interaction, my anonymous co-conspirator can be three raccoons in a trench coat for all I care.

Faced with a new prospective collaborator, rather than looking for proof of humanity I look for proof of positive intent. In contexts of cheap oversight, like a 1:1 exchange or a document for which I alone can authorize external contributions, intent can be easily determined from the contribution that I'm being asked to receive.

For entry into larger communities and spaces of shared purpose, some form of gating is needed to keep out bad actors, without clogging the flow of good will. In a many-to-many context, reviewing individual contributions doesn't scale. Instead, general intent can be surmised from a record of positive-sum work.

Having a record of work, especially open source contributions, builds trust in an increasingly untrustworthy web.

"Green Wall" of contributions on GitHub

Computer programmers have had their record of work represented in flashy “green walls” on GitHub for a decade and a half. Meanwhile most of the work I do as a community advocate, product manager and open source strategist is largely unlogged.

Having a recorded proof-of-work, especially for ones open source contributions, builds trust in an increasingly untrustworthy web. Every component of the emerging Community OS stack helps me document my work as an internet-native knowledge worker:

You don’t see a lot of spam commits on GitHub, because it’s a platform with very strong incentives for constructive, ‘real’ content. Once the incoming content is of legitimate value, whether or not it's being sent by a human or some other “untouchable” is largely irrelevant.

If I learned today that someone who contributed something to a project of mine turned out to be a violent criminal, I wouldn’t revoke that contribution. The bad actions of that person can’t cancel out their good actions, and vice versa. Rather, I'd be happy to have made space for an otherwise harmful individual to put some good into the world.

Similarly, it won't be such a bad thing that our World Wide Web gets overrun with autonomous bots so long as they’re doing good stuff. Point being, I care first and foremost about discerning good contributions from bad ones, not a prospective contributors' humanness.

I want to make a place where anyone who’s willing to share their work, however nascent, is welcome. Doesn’t matter if the the person behind a profile is one person, multiple persons or not technically a person at all; a proper profile weaving together the web of an online identity represents a body of work. That online record is the proof of that internet actor's existence, not some retina scan and a government issued passport.


Fediverse Discussion

A companion-piece for our Kickstarter's first update.

At Spicy Lobster studio there are very few things we consider ourselves against. If forced to imagine a sworn enemy, what comes to mind is loneliness. I touched on the subject last year in a longform message on our team chat: Musings on death and loneliness.

my mother never really left. Her body is gone, but her embodiment of kindness is forever in the hearts and minds of anyone lucky enough to have been a recipient of her love. As one of her children I received it in abundance.

This community I am co-creating with all of you fine people is deeply informed by the practice of kindness passed down to me by my mother, which she imparted through actions more so than words. Simple acts of kindness speak volumes. The ceaseless current of kindness connects us together, making us less alone.

What we are battling against is the unnecessary kind of loneliness. Quiet solitude can be nourishing, but the deafening void of separateness is a killer. The poet David Whyte describes this duality beautifully.

LONELINESS is the doorway to unspecified desire. In the bodily pain of aloneness is the first step to understanding how far we are from a real friendship, from a proper work or a long sought love. Loneliness can be a prison, a place from which we look out at a world we cannot inhabit; loneliness can be a bodily ache and a penance, but loneliness fully inhabited also becomes the voice that asks and calls for that great, unknown someone or something else we want to call our own.

Loneliness is the very state that births the courage to continue calling, and when fully lived can undergo its own beautiful reversal, becoming in its consummation, the far horizon that answers back.

In the grand scale of things, loneliness is a privilege. Human beings may have the ability to feel aloneness as no other creature can; with a power magnified by intelligence and imagination. Animals may feel alone in an instinctual way, moving naturally and affectionately toward others of their kind, but human beings may be the only beings that can articulate, imagine or call for a specific life they feel they might be missing.

Loneliness is the substrate and foundation of belonging, the gravitational field that draws us home and in the beautiful essence of its isolation, the hand reaching out for togetherness. To allow ourselves to feel fully alone is to allow ourselves to understand the particular nature of our solitary incarnation, to make aloneness a friend is to apprentice ourselves to the foundation from which we make our invitation to others.

To feel alone is to face the truth of our irremediable and unutterable singularity, but a singularity that can kiss, create a conversation, make a vow or forge a shared life. In the world, or community, this essential singularity joins with others through vision, intellect and ideas to make a society.

Loneliness is not a concept, it is the body constellating, attempting to become proximate and even join with other bodies, through physical touch, through conversation or the mediation of the intellect and the imagination. Loneliness is the place from which we pay real attention to voices other than our own; being alone allows us to find the healing power in the other. The shortest line in the briefest e-mail can heal, embolden, welcome home and enliven the most isolated identity.

Lonely human beings are lonely exactly because they are made to belong. Loneliness is the single malt taste of the very essentiality that makes conscious belonging possible. The doorway is closer than we think.

I am alone; therefore I belong.

‘LONELINESS’ from CONSOLATIONS: The Solace, Nourishment and Underlying Meaning of Everyday Words. © David Whyte & Many Rivers Press

Everyone craves human connection, now more than ever. We may be alone in our minds, but there is belonging to be found in being alone together. To survive we need to find the others and become proximate with them. For that we need a common meeting ground founded in mutual good-faith.

The world of Fish Folk is being created to provide such a place. A place where we hold off on connecting with our words and just play together like the primal apes (or pre-primate fish) that we are.

Non-verbal play is an arguably safer starting point for social connection than literate conversation, at least given our current communication tools which are designed for outrage rather than understanding.

Our literal reality, shaped by words, has grown so complex and contested that the meanings of words can be interpreted very differently by two or more people, to such an extent that physical neighbors can seem to live on different planets.

Too many words only sow confusion when their meanings become fragmented. We need our words, but they do us no good once they diverge too far from a common, universal interpretation.

To attain a shared vocabulary as human beings the conversation must be started anew, from the first-principles of playful interbeing. In time we’ll exchange words in ever greater quantities. But first, let’s just play together.

Perhaps all the literacy we need to begin with are these five magic words:

👋 Hi, 😊 wanna play a game?

I've previously written about the multi-app platform of my dreams as a community professional: The Community OS stack.

While undeniably ambitious, it's a vision firmly grounded in practicality. Thanks to the compounding value of open source and standard web protocols, the path to digital discourse nirvana can be mapped out with a fair amount of detail.

The notion of a 'Community OS' grew out of an expanded vision of Commune-chat. The use of the term “operating system” for what I'm describing will undoubtedly be contested, but if we can define operating systems for computer hardware, I truly don't see why we shouldn't also have equivalent operating systems for digital communications.

I will even go so far as to argue that part of the reason why our comms tooling has failed us so drastically in the 21st century is because we never looked at digital communications through the holistic lens of a modular yet interoperable whole.

Instead of hardware as the common denominator, the conceptual Community OS is standardized by modern-day web protocols:

Identity – Conduit of flows

Your identity (ID) inhabits the places and behaviors which the Bonfire, Stream and Garden (see below) symbolize, simultaneously experiencing and expressing itself through those outlets.

Examples: Google, Facebook, Apple, Microsoft, Email, Phone numbers

Bonfires – Discursive, omnidirectional flow

Examples: Chat (Discord, Slack), forum (Discourse, StackOverFlow, Reddit), Mailing lists.

Streams – Declarative, linear flow

Microblogging (Twitter, Tumblr, Mastodon), Television (TikTok, YouTube), Everything-app (Facebook, WeChat).

Gardens – Contemplative, bottom-up flow

Wikis (Wikipedia, Fandom), Networked notes (Notion, Roam), Blogs (WordPress, Medium, Substack)

Overlapping boundaries

There are no strict boundaries in the Stream/Garden/Bonfire trio. A blog for instance can behave like a bonfire when it is more discursive through its comment sections, it can be consumed in stream-form via an RSS reader, and it takes the shape of a garden when it's deeply interlinked and less concerned with chronology.

Likewise, Reddit's individual threads are bonfires, its frontpage feed is a stream and its 'best of last week/month/year' is an organically structured garden. But these multi-faceted applications still tend to be grounded in one particular core function.

Comms Analogues

As laid out in the stack post, I prefer to group the building blocks for online communications tooling into four distinct components:

  • Identity = Conduit of flows.
  • Bonfires = Discursive, omnidirectional flow.
  • Streams = Declarative, linear flow.
  • Garden = Contemplative, bottom-up flow.

digital-metaphors By Lise

To broaden our perspective, we can retrofit those four components for different time periods.

Comms protocols in pre-literate society

  • Voice: personal spoken-word expression
  • Conversation: communal discourse
  • Gossip: word-of-mouth broadcasting
  • Songs: transgenerational storytelling

With pre-literate protocols it's also a lot easier to see the similarities between ourselves and social animals such as wolves, whales or magpies.

Comms protocols in proto-literal society

  • Private diary: personal ideation
  • Sending letters: interpersonal ideation
  • Distributing pamphlets: broadcasted knowledge
  • Sharing Books: synthesized knowledge

In the proto-literal era we adopt technological aids external to our own bodies, already closely resembling their future digital counterparts.

The Predicament

You'll notice that the vast majority of the real world examples of applications listed above (Google, Discord, Twitter..) are part of a closed platform offering, which is a problem:

Identity prison

And therein lies my predicament: Ever since I first logged on to the internet, I've never had legitimate ownership of my own digital identity. My digital expression has always been mediated through some higher power. Sadly not of the paternal kind that intends to lift my spirit up until I can stand on my own.

No, for as long as I've lived my digital identity has been in the hands of an opaque and authoritarian power that intends to capitalize on my innate desire for expression by means of identity lock-in. The powers-that-be have been fairly benevolent, sure, but my independence is and never was their end-game.

But all hope is not lost. An open social web is possible, and it is in no way an understatement to say that our interpersonal relationships as well as democratic institutions will be far better off for it.

Digital autonomy begets individual freedom begets fairness & equality.

The hopeful possibility of this moment lies in the open-social web protocols which make up the foundations of a comms & coordination ecosystem owned and operated by the general public.

We have yet to bring these components together into one cohesive communications product, wherein messages and knowledge artifacts can move seamlessly from one flow-mode to the next and your identity remains the same throughout. Yet this ideal is closer to becoming reified than you might think.

Here's how I intend to do it, with a little lot of help from my friends.

Part 1: Weird Identity

Before I can interact with other netizens, I need an online persona to make my digital self presentable and increasingly trustworthy. That's what Weird is all about. Most basically it's an open source equivalent to Linktree, supercharged by self-sovereign identity.

Weird will aggregate your fragmented persona into a single unified view. Establish your little slice of home on the internet without getting stuck in the content-production imperative of a custom website or a blog.

Then, thanks to the commodification of ID tech steered by the OIDC standard, Weird can grow up to become a full-fledged identity provider by standing on the sturdy shoulders of rauthy. Meaning, you can 'Login with Weird' and use it as a kind of Gravatar on steroids. This will enable seamless login to all of the additional services we want to plug into our community stack.

Part 2: Communal Bonfires

Next, we need a place for people to congregate. Group chat is the best way to seed a grassroots community: Get two or more people with a shared interest together in a room and watch the magic of minimum-viable sociality bloom!

'Online community platforms' are assembly-kits for large, communal bonfires, designed to draw people towards the light and into the warm togetherness of community. I think the primary function of bonfire software is to create space for group-scale discourse.

Part 3: Gentle streams of Kitsune

With our safe spaces set up for baseline networking and greenfield content generation, we can move on to broadcasting.

Chat rooms are information silos. Forum threads can crack through the walls of the silo as linkable, search-friendly message exports. But for certain types of content, like an announcement, it's not enough to just be discoverable; you want reach. Rather than waiting to be found, broadcasted content calls out so it may be heard far and wide. That's where the viral properties of ActivityPub and its fedi-friends come into play, plugged into our stack with Kitsune.

Kitsune is protocol-centric, made explicitly to interoperate with Mastodon and other AP applications.

Superpowers:

Part 4: Noospheric Gardens

By now we've got:

  1. a home base.
  2. a shared place for nascent social activity to emerge and mix.
  3. a broadcasting antenna to distribute select messages past the confines of our local community.

This is already a healthy environment for social connection and information to thrive. Communities in which ephemeral togetherness is the goal will be well covered by these three components.

But if you're engaged in building a product of growing complexity you need a way to glue information fragments together into cohesive artifacts of knowledge, otherwise the abundance of information will increasingly turn into disorganized noise; a form of informational tech debt.

To help us continuously convert messy noise into an orderly signal (like a song), we need a protocol for thought: Noosphere.

Noosphere is a massively-multiplayer knowledge graph. The technical pillars that Noosphere builds upon are:

Above this substructure, Noosphere gives users:

  • Entry to a zero-trust, decentralized network of self-sovereign nodes
  • Human-readable names for peers and their public content
  • Local-first authoring and offline-available content with conflict-free synchronization
  • A complete, space-efficient revision history for any content
  • Coherence and compatibility with the hypertext web

You can think of it like a world-wide Wiki.

Basically GDocs/Notion meets Git: made for knowledge connectivity and cross-pollination as opposed to disparate content silos. It’s also the final and most complete form of what I call ‘socialized proof of work’.

Beyond the foundational building blocks mentioned here, countless sub-components can be added to our stack as 3rd party integrations or bundled add-ons.

Weird can be extended with lightweight blog and inline CMS functionality.

Streams & Gardens are greatly enhanced by read-it-later apps and RSS readers.

All of Identity, Bonfire and Stream can be deeply complemented by Stalwart Mail Server; with a slightly different framing the email protocol would have been listed as another top-level component.


An immense amount of work has already gone into the communications infrastructure of the world wide web. All the essential tech we need is already made. What’s missing is a coordinated effort to point our collective innovations in the same direction, towards digital emancipation as our final destination.

There’s no good reason for our global nation of netizens to remain beholden to the corporate conglomerates who co-opted our digital commons to sell it back to us.

When you’re able, if only for a moment, stop building for survival and begin building for liberty.


The Great Untangling:

Elk client

The “juicy client” is not just rich in flavor and thick in texture; it is fluid. It adapts to the presentation needs of the data it receives.

Its fluidity is enabled by a helpful constraint: The loose confines of ActivityPub (plus extensions) provides a cohesive specification to scope & guide different UI implementations co-existing as part of the greater whole of an omni-interface.

If I'm peeking into an ActivityPub instance, show me its preferred UI form. ..on mastodon.social, show me the Mastodon UI. ..on calckey.social, show me the Calckey UI. ..on bookwyrm.social, show me the Bookwyrm UI. ..on mitra.social, show me the Mitra UI. ..on pixelfed.social, show me the Pixelfed UI. (..on bluesky.social, show me the Bluesky UI.)

This is a continuation of 'Sense-making in federated discourse' and 'Feed Overload'


Elk as an omniclient https://writing.exchange/@erlend/110286022480202952

Elk is currently furthest along on the track to becoming a juicy client. It's being developed by developers from the core team of Vue/Nuxt, which is a reasonably well-resourced crew. Additional capacity was unlocked recently since Nuxt was accepted into GitHub Accelerator! 🎉

It also comes with a desktop & mobile(soon) app distribution, based on Tauri. Being cross-platform makes it a strong unifier since both desktop and mobile UI enthusiasts can participate in the product shaping without splitting up into platform-native specializations.

Mitra and Pixelfed are already using Vue for their frontend. In my humble opinion, they'd be better off doing like Takahe and deferring to Elk as a default/recommended frontend. There's bound to be several other standalone Vue frontends for AP/Mastodon out there that likewise ought to consider this line of reasoning.

In any case, the custom UI features of these ActivityPub distributions can be re-implemented by someone in Elk as part of a juicy client strategy. I hope this product design & development strategy will appeal to enough Elk/Vue/JS/UI devs out there that we can turn this into an increasingly concerted effort.


Another promising alternative in this space is Gobo. It has been explicitly designed as a juicy client, or as they put it, a loyal client.

At the Initiative for Digital Public Infrastructure, we believe that a truly sustainable and resilient digital public sphere is possible and is actively being created. We envision a public sphere supported by these three legs:

  1. Consists of many different platforms with a wide variety of scales and purposes;
  2. Users can navigate with a loyal client that aggregates, cross-posts, and curates;
  3. Is all supported by cross-cutting services rooted in interoperable data.

It's made in Svelte, Cloudfront on the frontend. Python, Postgres, and Docker on the backend. A prototype is tentatively going public (and open source?) some time this May.

We believe Gobo needs to allow users to:

  1. Read and post to multiple social networks from one open source client.
  2. Pick and choose between algorithms for filtering and sorting the posts from all these networks.
  3. Design (and potentially share) different algorithms for filtering and sorting.
  4. Use third-party services to assist in filtering and sorting.
  5. Audit the performance of these different algorithms as well as the third party services.

If this work inspires you, I wholeheartedly urge you to reach out to the projects above and lend them a hand! 🙌

You can find me as erlend#1111 on the Elk discord.

Discuss/share this article via writing.exchange