You are viewing a single thread.
View all comments View context
0 points

It would be a fundamental change, but communities should be global and not tied to instances. This would allow for the necessary centralization and reduce duplication. It could also be used to ensure communities survive a in instance going down scenario.

permalink
report
parent
reply
2 points

How would that even work? Imagine you spin up a brand new instance and create a new user and want to subscribe to a community. Because there is no one source of truth does the new instance simply not have the posts and comments that were made before the instance was created? If it’s supposed to get historic data as well from where is it getting from? Does it pick a random instance and pull all the posts and comments from that instance?

What if that instance is defederated from another instance with the same community and doesn’t contain the posts and comments from the defederated instance? Does your new instance have to go ask all the posts and comments from all the other instances to rebuild the community dataset on your instance? What if these two instances that are defederated both create the same post with the exact same content? Is that one or two posts?

What if user on one instance changes the name of the post but there’s some weird bug that allows only half the instances to register that change. Did that change actually happen or not? How do you solve the data inconsistencies if there’s no central source of truth?

What about moderation? There’s no central authority to define moderators or moderation policies. How do you verify who is actually a moderator and not someone trying to impersonate a moderator? What if different instances have different moderation policies, how would communities agree on a moderation policy if in essence both instances can claim authority over the community?

And these are still pretty high level questions. It would get more complex if we were to dig deeper into a possible solution. Even if it’s all technically solvable I think the solution would probably be so complex that it becomes unmaintainable which means it becomes unusable.

permalink
report
parent
reply
1 point

Setting up a new instance wouldn’t be significantly different than today. The difference would be instead of asking each instance individually for what communities they have you would use a distributed ledger to contain a list of communities with their primary and secondary instances. This would create the sigle source of truth for communities. As communities still have to physically exist somewhere, the designated primary instance would have the master record for the community and you could designate secondary instances for resilience and possibly spread out pulling that information.

Moderation doesn’t change significantly, primary instance admins would still be the fallback, but they could designate any user to be a moderator.

Defederation would be a little messy, but not a ton more than it is now. The primary would be the source of truth, if they don’t accept writes from an instance, then those posts and comments wouldn’t exist, (this is basically the same as one way federation now). If an instance wants to read from a community it’s on that instance to drop anything from instances they don’t federate with from the response from the primary.

As above, the primary instance is the source of truth, if a change doesn’t get there. There could be an eventually consistent cache on other instances for usability.

The difficult part would be how to handle changing the primary instance, or designating the primary for a newly created instance.

permalink
report
parent
reply
1 point

But that’s effectively what we’ll have right now. You can create multiple communities of the same name but one will eventually become the main community that people will visit. And we could already create “backup” communities because I’m pretty sure the data from the main community is already sent to all the instances that have users who are subscribed to said community. The data is already in other instances, it’s just a matter of reusing the data.

So the only crux of your solution is how the possible instance for the community would be chosen. And that’s a whole can of worms. It can’t be the same instance the community creator is a part of because that’s the solution we have right now. It can’t be completely random because I’m pretty sure there are instances that legally can’t have porn or piracy on their instance, or maybe the instance owner simply doesn’t want that on their instance. If there’s supposed to be distributed ledger that effectively prevents creating duplicate communities and that ledger is the same for all instances, then there must be a possibility that the new community ends up in an instance the community creators instance might be defederated from, otherwise a “pariah” instance (who are pretty much defederated from the majority of Lemmy) can reserve community names by defederating everyone and then creating communities. So that decision starts to have a lot factors which lets instances influence the decision. And in some ways there’s even an incentive to influence the decision because the more communities one instance has the more power they have over the entire lemmy side of the fediverse. If they defederate from another instance that instance can’t create those communities for the people on that instance (unless you go down the reddit route of having gaming vs games vs truegames).

And that’s just the decision of the primary source. There’s a whole other bucket of questions about the distributed ledger. For example how does the ledger change? If one community needs to be moved to a different instance who makes that decision? If it’s the primary source instance then how do other instances verify the ledger? If you have Instances A, B, C and C and instances A and B are defederated from C. Instance A has a community that gets assigned to instance D. Instance A sends a ledger change to instances B and D and then instance D send the change to C, but how does instance C know that the sent data is correct? Instance D could send the message that instance A set the community to instance B and there’s no way for instance C to verify that message. In fact most of my questions in my previous comment apply to the ledger as well because the ledger would have to exists on every instance.

And then there are other factors like what if Mbin sets up a community/magazine? Mbin doesn’t care about any ledger. Will we turn Lemmy into a walled garden and prevent Mbin from participating because they don’t want our ledger?

permalink
report
parent
reply
1 point

lol I’m trying to follow along with all your comments but it just feels like you’re trying to recreate reddit but with some type of block-chain servers handling the load instead of centralized servers.

Like, I get it. When you break it down, what’s the difference between reddit and Lemmy? You don’t like c/Games@lemmy.world, you can make c/Games@sh.itdoesnt.work. On reddit if you don’t like r/games, you can make r/games! or some other bullshit.

Only 2 big differences for me is 1. the hope that just having different instances gets people away from the “Main Hub” communities, 2. multiple instances means less chance of corporation enshittification. Your solution would just promote the eventual lose of both of the reasons I’m on Lemmy to begin with.

I do heavily encourage cross-posting though. Would love some sort of “tag” or something where it’s easier to cross-post to all of the communities that opt-in to be tagged in that category. Could have it so you can filter multi-posts using this feature so you’re not blanketed with the post if you’re subscribed to multiple communities in that category (could even choose a default like only the one with the most comments or your most active community gets highlighted while blocking all the rest, while still having the links in the post like how crosspost currently displays).

permalink
report
parent
reply
2 points

This would allow for the necessary centralization

The fediverse is a collection of community-owned, ad-free, decentralised, and privacy-centric social networks.

permalink
report
parent
reply
1 point

It’s still decentralized control, but the content becomes more searchable.

permalink
report
parent
reply
1 point

I would recommend a button thar switches between local and all for a community. So people can look at it with their particular rule set in play if they wish.

permalink
report
parent
reply
1 point

That doesn’t solve the three different news communities, or the 5 dead communities that could have been one small one.

permalink
report
parent
reply
1 point

. . . And how would moderation work?

permalink
report
parent
reply
1 point

The same way it does now, maybe more open as users could be from any instance. Instance admins could still have control of communities they are the primary for.

permalink
report
parent
reply

memes

!memes@lemmy.world

Create post

Community rules

1. Be civil

No trolling, bigotry or other insulting / annoying behaviour

2. No politics

This is non-politics community. For political memes please go to !politicalmemes@lemmy.world

3. No recent reposts

Check for reposts when posting a meme, you can only repost after 1 month

4. No bots

No bots without the express approval of the mods or the admins

5. No Spam/Ads

No advertisements or spam. This is an instance rule and the only way to live.

Sister communities

Community stats

  • 10K

    Monthly active users

  • 3.4K

    Posts

  • 79K

    Comments