Spyke
technical-discussion·Technical Discussionbyjulian

Multiple handles for Activity Intents

Hi @[email protected] I've got a question about Activity Intents!

I'm implementing it now (as you noticed) and have run into an interesting issue. The wording of 3b86 suggests that the intents are distinct between users. That is, the end user inputs their handle, the handle is queried via webfinger, and supported Intents are returned.

However, the intents themselves don't really distinguish between users.

So I could have a localStorage session with multiple handles registered (e.g. [email protected], [email protected]), etc. — this works fine.

But if I had two handles with the same domain, [email protected] and [email protected], then my intents can't be targeted, can they... I just fire off the request (or rather, I have the end user's browser navigate) to the intent URL and whatever account is logged in will be the actor.

Did I miss something, or was there a way to distinguish actors in Activity Intents?

P.S. I find it highly amusing that you had to click through to activitypub.space to read my whole post, but because I don't support Activity Intents yet, you can't reply properly :rolling_on_the_floor_laughing:

View original on activitypub.space
julianreply
activitypub.space

@[email protected] focused on it today. Mostly been working on the handle registration and integration into existing action flows for guests.

On the receiving side, I have my users' webfinger supporting the Object intent.

Here are some screenshots :eyes: and yes, I am pretending to be @[email protected] because I don't have an account on mastodon.social LOL... I think at the end of the day the handle doesn't really matter if it's open-ended like that... like you said, you end up with whichever user is "signed in".

1

@julian @pfefferle

It looks beautiful! Well done! I can't wait to try it out, as soon as you have it live :)

And, I'd love to hear how it goes - if there are things we can make easier, document better, whatever. I still need to make an implementation guide, but just haven't been able to get it to the top of my stack.

One thing I've been focused on recently is including a signup link in the workflow to help brand new people. Here's a silly demo of my latest: https://qwertylicious.dev/have-you-heard-of-qwertylicious

1
julianreply
activitypub.space

@[email protected] well, the flow does work, although Mastodon's implementation is barebones.

They support create, but only with a single argument {content}. No {inReplyTo} which severely hampers utility since any content posted will be a top-level toot. This isn't a criticism of 3b86, it is just what it is :smile:

I might just have to test NodeBB-to-NodeBB instead.

1
mastodon.social

@julian

You’re exactly right, and I don’t see it as a criticism at all. It’s an on-ramp that lets people explore slowly, then add capabilities gradually. It’s a checked-and-egg problem.

I also want a “reply” activity as well, but I’m afraid nobody would support it yet.

So I look for {inReplyTo} in the create response to see if replies are possible, then register a “synthetic” activity for the application to discover. This lets me turn buttons on and off based on your servers abilities.

1
julianreply
activitypub.space

@[email protected] "You’re exactly right" triggered :scream:

I think it's wise to be hesitant about it. I think a Create intent with inReplyTo does already mean "Reply", so right now I don't see any reason to introduce a new intent.

I had a similar thought about unvoting, which is something NodeBB does but isn't captured by ActivityStreams. We had to map it to Undo(Vote). So I was wondering if Undo would make sense in 3b86, but the Undo Intent already exists and would be more cromulent.

1
mastodon.social

@julian

I know.. agreement on the Fediverse is so rare, it’s almost scary 😉

Yeah, Undo sounds like it makes sense in your case. I didn’t think of any in the beginning, so just overlooked it.

One complicating factor is in showing the “state” of things in the remote site - we’d need a way to know that you voted for something first, so then we could undo it.

But yeah, let’s add that into 3b86 as well. What kinds of parameters would you want to pass? Or, would you just want to write a PR?

1
julianreply
activitypub.space

> @[email protected] said: > > But yeah, let’s add that into 3b86 as well. What kinds of parameters would you want to pass? Or, would you just want to write a PR?

No, I think we'd want to KISS. If you upvote something with your fediverse account, and it doesn't "show" on the site that you upvoted, I think that's ok.

The "you're exactly right" thing was an LLM joke :laughing:

Okay. One-way 3b86 support is pushed to activitypub.space. Excuse the occasional broken language string, that'll get fixed up later. NodeBB will now let you register handles and can redirect to supported Like, Dislike, Create, and Follow handlers. @[email protected] if you could give it a whirl.

The other direction, there's almost no support right now. We just expose Object intent, but I will flesh out the same intents soon, so NodeBB users can consume Activity Intents too.

1

@julian This is fantastic. You're awesome, Julian!

I'll try to take a look at this tonight/tomorrow.

Once you're at a stopping point, would it be possible for you to list out the intents you publish and receive? I'd love to include that in the Implementations section at the bottom of the document.

0

You reached the end

Multiple handles for Activity Intents | Spyke