It’s excruciatingly obnoxious to have to rely on third party sources for what should be a first-party feature.

Like, I select all and then search a query. “Oh no, nobody on your server used a third party service to find it, so you won’t see it here.”

Like, how short-sighted is that, really? If I search for a string in the ‘all’ servers, I should have a list of ‘all’ the servers containing that string.

It’s a really simple concept. Not sure why this post even has to be made, but I’m wondering if there’s something I can do to make these ‘features’ more intuitive.

  • bobman@unilem.orgOP
    link
    fedilink
    arrow-up
    0
    arrow-down
    2
    ·
    1 year ago

    since anyone can start an instance, when you search “all”, where should it search?

    Easy! It should search all the servers your server is federated with! Servers should contain a list of their community names that can be easily and quickly queried by other servers.

    • Zalack@startrek.website
      link
      fedilink
      arrow-up
      2
      ·
      1 year ago

      Federation isn’t opt-in though. It would be VERY easy to spin up a bunch of instances with millions or billions of fake communities and use them to DDOS a server’s search function.

      Searching current active subscriptions helps mitigate that vector a little.

      • bobman@unilem.orgOP
        link
        fedilink
        arrow-up
        0
        arrow-down
        1
        ·
        1 year ago

        I… don’t think you know what ddossing means but okay.

        Would it really be very easy? Especially considering once instances find your doing that, they just block you? Would it be worth people’s time?

        Is there any way around this, perhaps querying a global repository of federated instances and sorting them by popularity?

        In all honesty, you don’t have a point. If you did, third-party services already wouldn’t offer this. Seeing as they can, it’s clearly possible.

        • Zalack@startrek.website
          link
          fedilink
          arrow-up
          3
          ·
          edit-2
          1 year ago

          Sorry you’re right that I wasn’t being precise with my terminology. It’s not a DDOS but it could be used to slow down targeted features, take up some HTTP connections, inflate the target’s DB, and waste CPU cycles, so it shares some characteristics of one.

          In general, you want to be very very careful of implementing features that allow untrusted parties to supply potentially unbounded resources to your server.

          And yeah, it would be trivial to write a set of scripts that pretend to be a lemmy instance and supply an endless number of fake communities to the target server. The nice thing about this attack vector is that it’s also not bound by the normal rate limiting since it’s the target server making the requests. There are definitely a bunch of ways lemmy could mitigate such an attack, but the current approach of “list communities current users are subscribed to” seems like a decent first approach.