• Max-P@lemmy.max-p.me
      link
      fedilink
      English
      arrow-up
      3
      arrow-down
      2
      ·
      7 months ago

      Because if you’re on say, lemmy.world because you clicked such a link, lemmy.world has no way of knowing what your home instance is. The cookies are all sandboxed for lemmy.world’s use. So even if you used a third-party site whose sole purpose is to know your home instance, it still wouldn’t work because now third-party cookies are sandboxes based on the domain of the site you’re visiting.

      That used to be possible with a third-party. That’s how the Facebook like buttons and Login with Google used to work, and those are also the reason it’s no longer possible. You used to be able to just embed some JS from a third-party on a site, and that JS can access cookies from the third-party site while also being directly callable from the site that embedded it. So in that case, we could agree on a third-party lemmy redirector service whose sole purpose is to store the user’s home instance in a cookie and then the script can be embedded everywhere and it would be able to spit out the URL from the cookie. But that hole’s been plugged. So even if you do that, it doesn’t work anymore because of stronger cookie sandboxes. But that’s why you’d need third-party cookies to pull it off.

      So the only fix left for this is, every lemmy instance you visit, you have to set your home instance on it, which would set a cookie that the site can actually see, then it could redirect you to your home instance to view the post. But that still kinda sucks, because you have to do it for every instance you run across.

      So, cookies are useless for this.

      • AwesomeLowlander@lemmy.dbzer0.com
        link
        fedilink
        English
        arrow-up
        6
        arrow-down
        1
        ·
        7 months ago

        You’re missing the point. You should never leave your home instance. Lemmy could automatically remap links to whatever your home instance is before you ever click on them.

        • Max-P@lemmy.max-p.me
          link
          fedilink
          English
          arrow-up
          5
          ·
          edit-2
          7 months ago

          Some UIs do, I have Tesseract on mine and it rewrites the links for me.

          That doesn’t solve sharing a link on Matrix/Discord/Google or wherever. I rarely have this issue on Lemmy itself, but whenever I get a link from elsewhere, that’s when I need to be able to open it on my home instance so I can interact with it.

          Same deal with Mastodon. You’re reading some news, it links so the dev’s Mastodon, you need a way to open it in your home instance.

          There’s no fixing that.

          EDIT: test self link to this comment https://lemmy.world/comment/10561034

          • Max-P@lemmy.max-p.me
            link
            fedilink
            English
            arrow-up
            5
            ·
            7 months ago

            This is what that looks like on a good Lemmy frontend:

            I forgot the default UI didn’t do that. Both Tesseract and Boost handle those mostly just fine.

          • AwesomeLowlander@lemmy.dbzer0.com
            link
            fedilink
            English
            arrow-up
            2
            ·
            7 months ago

            Yeah, 3rd party links are a tougher nut to crack. You’d think they could at least fix the local links, though.

            I can think of a few potential solutions, but they’d all require a lot of user opt in and centralisation, which makes it unlikely to ever happen.

        • ericjmorey@discuss.online
          link
          fedilink
          English
          arrow-up
          2
          ·
          7 months ago

          I generally agree with you.

          However, I want to encourge you to consider softening up your replies to people who you don’t have a strong prior social connection with. I’ve started making an effort to do that and I’ve found that I’m having more rewarding conversations now.

      • ericjmorey@discuss.online
        link
        fedilink
        English
        arrow-up
        2
        ·
        7 months ago

        That’s very different from what I think people generally want by default, which is that when you’re on lemmy.world, it’s because that’s your home instance and any links to other instances would be automatically converted to the lenmy.world version of the post or comment by default (as long as the two instances are federated).

        Anyone that wants more could find a browser plugin or script, but every new user with an account of any instance would have an initial experience that’s much less confusing and more consistent and pleasant.

        • Max-P@lemmy.max-p.me
          link
          fedilink
          English
          arrow-up
          1
          ·
          7 months ago

          I haven’t encountered that particular one in a while. Usually it’s Lemmy links from elsewhere like Matrix or Discord or whatever that are annoying to deal with and needs redirecting.

          Most apps seems to rewrite the links already just fine, at least Tesseract does. It’s not like the default UI is known to be good. It’s functional but the UX is terrible.

          • ericjmorey@discuss.online
            link
            fedilink
            English
            arrow-up
            1
            ·
            7 months ago

            The default UI is how most new users will experience interacting with lemmy instances at first. So it’s helpful to create a better first impression. To the extent that this is built into the project itself makes it easier for other UIs to be created and maintained too.

            I believe that the Lemmy devs are working on a better url scheme for posts and comments as well. This will also make it less annoying without any browser extension, script, or other third part service.

      • mark
        link
        fedilink
        English
        arrow-up
        1
        ·
        7 months ago

        Sites can still have third-party cookies. The first party domain just needs to explicitly allow them.