this post was submitted on 27 Jul 2023
85 points (94.7% liked)

Fediverse

29028 readers
1902 users here now

A community to talk about the Fediverse and all it's related services using ActivityPub (Mastodon, Lemmy, KBin, etc).

If you wanted to get help with moderating your own community then head over to !moderators@lemmy.world!

Rules

Learn more at these websites: Join The Fediverse Wiki, Fediverse.info, Wikipedia Page, The Federation Info (Stats), FediDB (Stats), Sub Rehab (Reddit Migration), Search Lemmy

founded 2 years ago
MODERATORS
 

Is there a reason why all the services, that use the ActivityPub protocol don't have a unified API?

None of the mastodon apps allow me to log in with a lemmy/kbin account.

Also none of the lemmy apps allow me to log in with a kbin account.

Even though kbin has both mastodon (microblogging) and lemmy (threads, communities) functionality.

Also, Pixelfed recently introduced "login with Mastodon", but all it really does is just create a new user on it's instance and copy over the mastodon followers and profile info.

Why can't we just have one account to rule them all?

top 31 comments
sorted by: hot top controversial new old
[–] CombatWombatEsq@lemmy.world 67 points 2 years ago (1 children)

We're working on it! Here's the spec-in-progress: https://www.w3.org/TR/did-core/

These things take time. We'll get there.

[–] Wats0ns@sh.itjust.works 12 points 2 years ago

Barely understood it, but thanks for your work!

[–] Steve@compuverse.uk 31 points 2 years ago (2 children)

A unified API and a single login, are two separate things.

A single federated authentication could be a good idea. But the various federated services are different enough that they should have different APIs.

[–] masterspace@lemmy.ca 5 points 2 years ago* (last edited 2 years ago)

OP is just asking why they a third party mastodon app can't login to a Lemmy or kbin server, which is a valid question.

From an authentication standpoint there's no reason for their auth flows to be at all different or use different endpoints relative to their domain.

The returned profile or account object might have different fields which could cause an app to crash, but there's no reason for every fediverse app to not use some of the same basic schemas and endpoints.

[–] Tatters 2 points 2 years ago

Yes, they are completely different things.

[–] Crul@lemmy.world 21 points 2 years ago* (last edited 2 years ago) (1 children)

I'm not an expert, those who know more, please correct me.

Regarding logging-in with one account into another instance, I think that's not how it's intended to work. But I'm oot sure I understand what you're asking.

Regarding the unified client API, 2 days ago Manton Reece (Creator of Micro.blog) wrote a response to Dave Winer's open voicemail in where he says:

There is a lot of work to do, even outside of ActivityPub. As Dave mentions, we also need a common posting API. The most popular Mastodon client apps do not support either ActivityPub or Micropub. But a lot of progress can be made focusing on interoperability for the server-to-server part of the API. That should be the top priority with Threads set to join the fediverse.

[–] adonis@kbin.social 2 points 2 years ago* (last edited 2 years ago) (3 children)

logging in with one account into another instance

I'd imagine a OAuth/JWT-like workflow, where pixelfed.social can ask a kbin-API whether my user exists on kbin.social.

If it does, I should be able to post images on the pixelfed app that show my username as @adonis.

Edit: by @adonis, I mean adonis @ kbin.social

[–] Crul@lemmy.world 6 points 2 years ago* (last edited 2 years ago) (1 children)

If it does, I should be able to post images on the pixelfed app that show my username as @adonis.

It cannot work as stated because there could be another @adonis accounts in other instances and the only way to prevent that would be to centralize all the signups which goes against the whole idea of decentralization. That's why the user must be @adonis1@kbin.whatever as it is shown now.

Regarding the OAuth/JWT, again... not an expert, but what I understand is that that kind of integration is much stronger than the current system. AFAIK, it could work as you say, but that would make things much more complex for the servers; you usually provide OAuth authentication for a few services, I don't know how well that scales with ... hundreds / thousands (?) of authentication provders. But, who knows, maybe in the future it's implemented in one way or another.

We should take into account that this technology is fairly new and people are still building on it.

[–] adonis@kbin.social 1 points 2 years ago* (last edited 2 years ago)

Sorry but the autoformatting miscommunicated my statement... by @adonis I meant adonis @ kbin.social.

And the domain is always part of the actual userhandle. Hence, there can only be one.

Regarding OAuth/JWT, these aren't new concepts. They've been around for while, if not decades.

[–] DoomBot5@lemmy.world 20 points 2 years ago (2 children)
[–] joel_feila@lemmy.world 4 points 2 years ago

Fine ill go make my own standard but with black jackc and hookers

[–] cupcakezealot@lemmy.blahaj.zone 3 points 1 year ago* (last edited 1 year ago) (1 children)

Pixelfed actually got a sign in with Mastodon account working:

https://mastodon.social/@pixelfed/110727848627479712

[–] adonis@kbin.social 2 points 1 year ago

yeah... and all it really does is create a new pixelfed account, while copying over the mastodon bio and followers.

[–] ShittyKopper@lemmy.blahaj.zone 3 points 2 years ago* (last edited 2 years ago)

ActivityPub has a C2S (client to server) API in addition to the S2S (server to server) API, it's just that nobody cared about it to implement it. And because nobody implemented it nobody iterated upon it so now it sits as this underspecified (and unusable) state.

[–] shrugal@lemm.ee 2 points 2 years ago (1 children)

Because they are still different apps with different needs, architectures and formats. They just synchronize most of their content between each other.

[–] adonis@kbin.social 1 points 2 years ago (1 children)

they just synchronize

But to be able to sync with each other, they still have to agree upon a standard, right?

[–] shrugal@lemm.ee 2 points 2 years ago* (last edited 2 years ago)

Yea, but that's just a lowest common denominator (e.g. it doesn't include things like lemmy community sidebars), and also generally not appropriate for a client application. ActivityPub transmitts all events that are happening (posts, likes ...) between servers, and they are supposed to index and aggregate things (e.g. sum up votes, sort posts). It's just not feasible to expect the same from a mobile app for example, you'd have to at least create another standard for that.

So services end up implementing their own client APIs to fit their needs. And imo that's actually a good thing, because it allows them to try out features and specialize on different use cases. But afaik the ActivityPub people are working on another standard for client APIs, at least it's on their radar.

[–] melroy@kbin.melroy.org 1 points 1 year ago

Only if W3C people thought about all this.. before releasing ActivityPub protocol to the public.

load more comments
view more: next ›