• GoodEye8@lemm.ee
    link
    fedilink
    English
    arrow-up
    8
    ·
    3 days ago

    True, but the same issue happens with reddit as well, for example gaming vs games vs truegaming. Over time those communities either found their niche (gaming sub became mostly memes, games sub became news and discussions and truegaming tried to become a more serious discussing sub). Actually there were way more gaming subs but unless they found their niche they died out. So people gravitating towards specific communities is a natural occurrence.

    As for trying to automatically consolidate communities across instances, it sounds like a great idea on paper but seems like technical she moderation headache, because you won’t have a clear source of truth. Let’s say instance A and instance B both have a community called news. The same news article with the same title is posted on both communities on both instances by different users. Assuming we want to consolidate those posts into one, which instance post will be shown or in more technical terms, which instance becomes the source of truth for that post? Who makes that decision? What if there’s also instance C with the same community and the same post but that instance isn’t federated with instance A, how do we consolidate posts? Each community has its own moderators and moderation rules, who is allowed to moderate the post? What if the moderation rules contradict between instances and both instances want to apply the rules independently, are they supposed to split the post?

    Maybe there is an elegant solution to all the problems but I don’t see there being one. I’m not against the idea, the problem is you want to solve its something I have given some thought and because of that I just don’t see it working out the way you’re imagining it.

    • ryathal@sh.itjust.works
      link
      fedilink
      arrow-up
      1
      arrow-down
      1
      ·
      3 days ago

      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.

      • GoodEye8@lemm.ee
        link
        fedilink
        English
        arrow-up
        1
        ·
        3 days ago

        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.

        • ryathal@sh.itjust.works
          link
          fedilink
          arrow-up
          1
          ·
          2 days ago

          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.

          • GoodEye8@lemm.ee
            link
            fedilink
            English
            arrow-up
            1
            ·
            2 days ago

            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?

            • ryathal@sh.itjust.works
              link
              fedilink
              arrow-up
              1
              ·
              2 days ago

              Backup communities don’t really exist right now. There are copies of things on other servers l, but they can’t become functioning communities. This has caused some communities to disappear when their instance went down. The biggest I remember is movies and TV related things.

              Having a ledger helps with discovery, because instances now don’t know about other communities by default, it requires extra effort to seek them out until someone else has found them and subscribed. It’s not a big deal for established communities, but it does hurt building a new one.

              I don’t have a great solution for admin of creation/movement of communities, but this isn’t meant to be a 100% solution. Distributed consensus is a concept that exists though. There’s no reason a community can’t go on a users instance as default, it just enables a community to potentially migrate for various reasons.

              This doesn’t necessarily create a walled garden, as no one owns the walls. It does encourage everyone within Lemmy to maximally federate. I can’t say it significantly changes integration with other implementations as they were never very robust in the first place.

              • GoodEye8@lemm.ee
                link
                fedilink
                English
                arrow-up
                1
                ·
                2 days ago

                I think you’re now suggesting things that have nothing to do with consolidating communities.

                Backup communities don’t really exist right now. There are copies of things on other servers l, but they can’t become functioning communities. This has caused some communities to disappear when their instance went down. The biggest I remember is movies and TV related things.

                They don’t exists right now, but the foundation is there. I checked the old kbin.social communities that users from lemm.ee had subscribed to. All the posts seem to be there right until kbin.social got shut down. The data exists on your instance even if the original instance went down. It’s just a matter of figuring out and creating a new functionality to revive those communities on a new instance. This suggestion has nothing to do with consolidation, it’s just a backup solution that can already be done.

                Having a ledger helps with discovery, because instances now don’t know about other communities by default, it requires extra effort to seek them out until someone else has found them and subscribed. It’s not a big deal for established communities, but it does hurt building a new one.

                I don’t see how that specifically requires a ledger but I guess we can call it a ledger. The solution itself is fairly simple, each instance publishes whenever a new community is created or deleted and federated instances can store that data on their side to have a list of all the communities to search for. For already existing we can create a “publish all existing communities” so each instance can update their lists accordingly. That’s effectively a ledger but once again, it has nothing to do with consolidating communities.

                I don’t have a great solution for admin of creation/movement of communities, but this isn’t meant to be a 100% solution. Distributed consensus is a concept that exists though.

                Distributed consensus is a concept but is such complexity necessary? Especially when the end result isn’t that much different to what we already have.

                There’s no reason a community can’t go on a users instance as default, it just enables a community to potentially migrate for various reasons.

                It can, but it doesn’t really matter because that’s exactly how the current system works. As for migrations, if we solve the “backup community” problem then that functionality can just as well be used for migrations because right now we can just duplicate data. If you want to add the one community restriction that migration actually gets harder to implement.

                This doesn’t necessarily create a walled garden, as no one owns the walls. It does encourage everyone within Lemmy to maximally federate. I can’t say it significantly changes integration with other implementations as they were never very robust in the first place.

                Kbin/Mbin integrations with Lemmy worked pretty well, but if you force all Lemmy instances to use a solution unique to Lemmy then you’re pretty much building a wall because integrations with other similar implementations become less likely. Nobody owns the wall but it would create an “in” group and an “out” group. We already kinda have that with Lemmygrad and Hexbear and the rest of Lemmy, but those two instances can exists independently from the rest of Lemmy so the “in” and “out” groups can easily coexists. But if you force communities across instances you’re going to also force friction between the “in” and “out” groups. There can only be one “c/europe” but there’s one on Lemmygrad and there’s also one on feddit. If you keep the feddit one then Lemmygrad and Hexbear can’t have c/europe and if you let Lemmygrad have c/europe then the rest of Lemmy can’t have c/europe. It’s unnecessary friction.

                I guess it would work if Lemmygrad and Hexbear were federated with the rest of Lemmy, but that’s not happening.

        • ryathal@sh.itjust.works
          link
          fedilink
          arrow-up
          1
          ·
          2 days ago

          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.