Trying to figure this out as in the recent threads a few people said that Bluesky was federated, but it didn’t seem to actually be the case.

https://bsky.social/about/blog/02-22-2024-open-social-web in February announced that Bluesky would allow federated servers

The Bluesky documentation on the topic isn’t very clear. They mention Bluesky.social a lot, as if it’s supposed to be the one central server other PDS need to federate with:

Bluesky runs many PDSs. Each PDS runs as a completely separate service in the network with its own identity. They federate with the rest of the network in the exact same manner that a non-Bluesky PDS would. These PDSs have hostnames such as morel.us-east.host.bsky.network.

However, the user-facing concept for Bluesky’s “PDS Service” is simply bsky.social. This is reflected in the provided subdomain that users on a Bluesky PDS have access to (i.e. their default handle suffix), as well as the hostname that they may provide at login in order to route their login request to the correct service. A user should not be expected to understand or remember the specific host that their account is on.

To enable this, we introduced a PDS Entryway service. This service is used to orchestrate account management across Bluesky PDSs and to provide an interface for interacting with bsky.social accounts.

https://docs.bsky.app/docs/advanced-guides/entryway#account-management

Self-hosting a Bluesky PDS means running your own Personal Data Server that is capable of federating with the wider Bluesky social network.

https://github.com/bluesky-social/pds?tab=readme-ov-file#what-is-the-current-status-of-federation

The custom domain name is still something else, and does not seem to require a PDS: https://bsky.social/about/blog/4-28-2023-domain-handle-tutorial

So, to come back to the title question, do people know of an example of PDS that can be used to access Bluesky without being on the main server?

  • BeAware :fediverse:@social.beaware.live
    link
    fedilink
    arrow-up
    19
    ·
    11 days ago

    @Blaze

    Long winded, nuanced answer, ready your eyeballs:

    It’s a bit complicated, but since we’re on Fediverse and at least somewhat familiar with how things work here, I’ll try to explain with that comparison in mind.

    On Fediverse, instances are in control of the user data directly. To “migrate” your account, you’d be switching instances and admins entirely.

    BlueSky splits things up quite a bit more.

    There, you can host your own “PDS” or Personal Data Server. That hosts your account and post info only.

    Then, there’s the “AppView”. In comparison to Fediverse, these are like Lemmy, Mastodon, Mbin, etc. Right now, there’s VERY few Appviews to choose from.

    Then, there’s the “relay”. Which to Fediverse, the only thing similar is also relays, but they work differently. On BlueSky, they relay every post and interactions of all the PDS data that connect to AppViews. I do not think there’s a choice on *what* is relayed, just a huge firehose. That being said, they’re not optional like Fediverse. To complete the network, relays are required on ATProto and apparently could be expensive to host, so right now, it appears the only relay is hosted by BlueSky the company. Which makes things slightly centralized.

    Now, that we have those definitions out of the way, this is where things get a bit muddy and a bit of purposeful corporate created confusion for purpose of selfishness is quite apparent.

    Right now, there’s very few AppViews. The ones I’m aware of are, BlueSky itself, Whitewind, and Frontpage.xyz.

    The confusion happens because BlueSky, the company, doesn’t separate the fact that accounts hosted on self-hosted PDS, aren’t technically Bluesky accounts, they’re ATproto accounts. Everywhere you look to login, it says “login using your BlueSky account”. I can only assume they’re doing this on purpose so that anyone who tries to make an Appview, host a PDS, AND a relay, can’t have their own “identity” like different instances and platforms have here on Fedi.

    That will confuse people and make them think *everything* is just hosted by BlueSky the company. However, as we’ve now established, there’s definitely a separation of “Bluesky” the company, “BlueSky” the AppView that you can login to using your “BlueSky” account, which doesnt technically have to be hosted by anything related to BlueSky.

    I hope this all makes sense and you can tell that *technically* things are decentralized for the most part. It’s just that BlueSky is purposefully muddying their own definitions of things so that anyone that tries to build on ATproto, has a hard time making themselves known as *not* bluesky due to the way they conflate all these definitions.

    Sorry for the huge post and hope it makes sense in some way.

    Thanks for reading.😁👍

    @fediverse

    • mark@programming.dev
      link
      fedilink
      English
      arrow-up
      5
      ·
      11 days ago

      Damn. This needs to be a blog article and saved somewhere! No need to apologize. You’ve done a great job explaining a very technical topic in a simple and relatable way.

      • BeAware :fediverse:@social.beaware.live
        link
        fedilink
        arrow-up
        2
        ·
        edit-2
        11 days ago

        @mark thank you for the compliment and assurance friend.

        I am always self conscious about my long winded replies because sometimes even I wouldn’t wanna read a post that long.

        Though, with topics like this that I’m very passionate about, I feel it’s very important to lay out all the information and knowledge I have so that others can make informed decisions themselves based on the most important details.

        I discuss Fediverse and networks like it, literally constantly and there’s LOTS of nuances with these systems that need lots of explanations.

        @fediverse

        • ᴇᴍᴘᴇʀᴏʀ 帝@feddit.uk
          link
          fedilink
          English
          arrow-up
          1
          ·
          11 days ago

          I am always self conscious about my long winded replies because sometimes even I wouldn’t wanna read a post that long.

          No need to be self-conscious - that’s a concise account of a complicated issue, which is going to go long. Long posts become an issue when they are rambling and unfocused.

    • timconspicuous@lemmy.ml
      link
      fedilink
      English
      arrow-up
      3
      ·
      10 days ago

      To complete the network, relays are required on ATProto and apparently could be expensive to host, so right now, it appears the only relay is hosted by BlueSky the company. Which makes things slightly centralized.

      A number I’ve seen quoted multiple times now is ~$150 per month to host a relay (Source). Which explains why Whitewind, Smokesignal and Frontpage don’t host one, they are mostly still small projects by individual talented devs, but imo if that number is true, it really doesn’t seem too outlandish that someone might go for it.

        • poVoq@slrpnk.net
          cake
          link
          fedilink
          English
          arrow-up
          7
          ·
          10 days ago

          Lemmy.world used to cost that much, but I think they downscaled a bit recently, or are at least planning to as the current growth of the userbase has slowed down.

          I was actually surprised by that 150 figure when I first read it, as it is much cheaper than what the BlueSky documentation makes it sound.

          It is certainly possible to collect that much in monthly donations, but then again… how do you build a loyal base of supporters for running a mostly hidden piece of infrastructure? People always complain about the instance focussed nature of the fediverse, but the ability to build communities around them and get people actually emotionally invested in their home instance is IMHO rather a strength of it. That is also why I am slightly sceptic of easy account migration tools, as it devalues the instance as yourhome base to a certain extend.

          • Blaze@feddit.orgOP
            link
            fedilink
            English
            arrow-up
            4
            ·
            10 days ago

            Yeah, the instance-focus aspect of the Fediverse is a good thing. You are a good example with slrpnk.net, but dbzer0, all the language/country-based instances (feddit.org, jlai.lu, aussie.zone, lemmy.ca, feddit.uk) also have their own culture and feeling. That’s cool to see.

            as it devalues the instance as yourhome base to a certain extend.

            That’s definitely a thing for generalist instances. I don’t really think there is much of a lemm.ee culture for instance. Which is also okay, some people just want access to Lemmy without a strong instance identity.

    • blue_berry@lemmy.world
      link
      fedilink
      English
      arrow-up
      3
      ·
      edit-2
      11 days ago

      Thanks for the explanation. Didn’t realize Bluesky/AT is more like a fedi-washed version of ActivityPub rather than a real alternative …

      I’m not sure; on the one hand, I think the fact that federation has become a unique selling point in micro-blogging is indicating a positive trend; so even if people join Bluesky its good for the Fediverse. On the other hand, if federated just becomes another buzz word that means nothing at all, while places where the real innovation is happening are drowned out, the window of opportunity could just close.

      • BeAware :fediverse:@social.beaware.live
        link
        fedilink
        arrow-up
        3
        ·
        11 days ago

        @blue_berry TBH I think our biggest strength here is decentralization, but every day we’re inching closer and closer to centralization here in many ways and most don’t care.

        Mastodon controls how 73% of users interact with Fediverse. Threads, if it fully federates will completely take that over, but then we have 2 corporate entities in charge here and there’s nothing any of us are doing about it.

        They will be able to enact change in AP that most other softwares can’t and effectively completely change Fedi as we know it.

        @fediverse

    • XNX@slrpnk.net
      link
      fedilink
      English
      arrow-up
      1
      ·
      11 days ago

      Frontpage.xyz doesnt seem to exist do you know the correct domain?

    • tengkuizdihar@programming.dev
      link
      fedilink
      English
      arrow-up
      0
      arrow-down
      2
      ·
      11 days ago

      So its activitypub, but worse because its designed from the ground up to be difficult to federate? Bro just use twitter at this point.

      • Jo Miran@lemmy.ml
        link
        fedilink
        English
        arrow-up
        4
        ·
        11 days ago

        Bro just use twitter at this point.

        That’s like choosing gangrene on your foot because you can’t decide which shoe to wear and tying the laces seems like a pain in the ass.

      • BeAware :fediverse:@social.beaware.live
        link
        fedilink
        arrow-up
        2
        ·
        11 days ago

        @tengkuizdihar well, it’s not difficult to federate, it’s difficult to seperate your identity from BlueSky itself, if you’re trying to create something on ATproto.

        I doubt you’ll see big news about a service using ATproto, the way Fedi platforms do, besides BlueSky because they really don’t want you to differentiate that way.🤦‍♂️

        @fediverse

        • XNX@slrpnk.net
          link
          fedilink
          English
          arrow-up
          2
          ·
          11 days ago

          Or maybe they do it because it would be very confusing for 99% of users to read “sign in with your atproto account” when no one knows what that is. Its a good thing theyre keeping things simple for now instead of getting the mastodon “its too complicated” issue and having non tech users not use it.

          Mastodon and the activitypub culture is very much either “its too complicated” or “how do you not understand its so simple maybe you’re just dumb and shouldnt be here” energy and its why 99% of topics here are just tech and politics. Almost no artists use it and the few that use it are on mastodon.art which defederates from so many instances.

  • ByteMe@lemmy.world
    link
    fedilink
    English
    arrow-up
    5
    ·
    11 days ago

    I think they do but they use AT protocol (theirs) instead of ActivityPub so that’s why you don’t see them in mastodon and they don’t have many servers in federation

    • Blaze@feddit.orgOP
      link
      fedilink
      English
      arrow-up
      3
      ·
      11 days ago

      Indeed, but I’m a bit surprised there isn’t any list of alternatives servers.

      I would have to look more into the protocol specification, but it seems like this isn’t really federation, alternative servers are still relying on the central server, and that’s why nobody bothers with setting one up

      • hoshikarakitaridia@lemmy.world
        link
        fedilink
        English
        arrow-up
        1
        ·
        edit-2
        11 days ago

        That sounds like a really dumb design idea. Why make a federating protocol if you still rely on the server? I don’t even get why they did it at all then.

        That’s indeed very interesting and peculiar.

        • Blaze@feddit.orgOP
          link
          fedilink
          English
          arrow-up
          1
          arrow-down
          1
          ·
          11 days ago

          They could pretend to be federated while they’re not.

          Might show them in a more positive light to the general public

      • Ada@lemmy.blahaj.zone
        link
        fedilink
        English
        arrow-up
        1
        ·
        edit-2
        11 days ago

        Why would someone host a server and pay for it out of their own pocket, when the protocol just turns in to an invisible piece of infrastructure that people don’t even know exists?

        AP instances allow for communities and identity to build around them, so there is a non monetary incentive to running them, but what’s the incentive to run an equivalent on bluesky and make it public?

  • Ruud@lemmy.worldM
    link
    fedilink
    English
    arrow-up
    1
    ·
    edit-2
    11 days ago

    I have setup bskysocial.world to test that (there’s no web interface, just select this domain when logging in or signing up via the app or https://bsky.app)

    Note: This is for testing only, I can’t promise it will remain running.

    (I am @ruud.bskysocial.world)

    • Blaze@feddit.orgOP
      link
      fedilink
      English
      arrow-up
      0
      ·
      11 days ago

      Thank you Ruud!

      If I understand correctly, using a custom domain name still makes you use the central Bluesky server, right?

      • /usr/libexec/ccoremapd@mstdn.social
        link
        fedilink
        arrow-up
        1
        ·
        9 days ago

        @Blaze @ruud

        No, it doesn’t have to. Custom domain does not tied to any instances (PDS) you reside in. The way custom domain handle works is for the verification itself.

        The first time you’ve created your account to that instance, you’ve been given to a specific instance name to your handle. For example “user.bskysocial.world”. With the “user” acts as a subdomain and “bskysocial.world” as a PDS name.

        You can learn more of how the handles work in ATProto here:
        https://atproto.com/specs/handle

        • /usr/libexec/ccoremapd@mstdn.social
          link
          fedilink
          arrow-up
          2
          ·
          9 days ago

          @Blaze @ruud

          You can still change your handle to however you’d like without having to migrate it to another PDS using your own domain name.

          Every component in the ATProto (Handles, PDS, AppView, Relays, etc) are separated from each other and can be run individually, without having to cause massive interference to one another. I kind of think of it as a “Microservices” in ATProto, whilst ActivityPub is more like a “Monolithic” one.

  • haui@lemmy.giftedmc.com
    link
    fedilink
    English
    arrow-up
    0
    ·
    11 days ago

    So, from up close it seems like people can have their own servers (i checked wurzelmann.at which is currently on the frontpage) but they do not seem to have their own frontend.

    This indeed makes it so that for people to actually SEE your content you must federate with one entity and are controlled by them.

    Imo this is very bad because it takes the freedom out of federation. Yes, you dont need to login to an app but if they ban you or defederate or delete your post, nobody will see it, right?

    Please someone who has tried and gets the technical details shed light on this.

    • flamingos-cant@feddit.uk
      link
      fedilink
      English
      arrow-up
      1
      ·
      11 days ago

      Their app is open source, but it doesn’t give any instructions on how to self-host it, in fact it seems to not have been designed with self-hosting in mind given the forking section of the ReadMe:

      You have our blessing 🪄✨ to fork this application! However, it’s very important to be clear to users when you’re giving them a fork.

      Please be sure to:

      • Change all branding in the repository and UI to clearly differentiate from Bluesky.
      • Change any support links (feedback, email, terms of service, etc) to your own systems.
      • Replace any analytics or error-collection systems with your own so we don’t get super confused.

      The impression I get from Bluesky is that it doesn’t view federation as a core feature of its platform, just a nice technical oddity. I’m no expert on the AT protocol, but from a quick skim of the quickstart, their view of federation seems to be having disparate data repositories (Personal Data Servers) app developers can put their app data into. It doesn’t really seems to be about different software communicating with each other.

      In contrast, ActivityPub is about passing JSON between servers in a somewhat standard format so different software can reasonably understand what that JSON represents and act on it in a way that makes sense for that software.

      (But again, I’m don’t know anything about the AT protocol, I could be completely wrong here)