I’ll reply in the comments with a example of what lemmy sends for each thing you can do (I think I’ve thought of everything, but you can probably guess the format if not, or I can always add it).
So, the setup for these is:
Our instance is called ‘local.com’
Our user is called ‘freamon’
The other instance is called ‘remote.com’
The community on that instance is called ‘interesting’
For many of these, remote.com will receive them, and rewraps them in an Announce to send out to all the other instances with a copy of the community, so everyone stays in sync.
Sort by ‘Old’ for the best hope of these making sense.
I’ll follow this post up with a script, that can be used to send these activities from the command-line, as I think it can help to understand Lemmy if you’re using something much simpler than Lemmy to do some of things Lemmy does.
EDIT: As nutomic as mentioned, a better list is in the docs. It’s the kind of thing I should read first, I guess.
You can also find this in the documentation.
Oh. I feel daft now. That’s some nice, comprehensive documentation, that I hadn’t seen before. I’ll edit this post to point to it, and I guess people can maybe use it if they want to comment about a particular activity.
Its also good to explore for yourself. Maybe you notice something missing/outdated in the documentation and can fix it. The docs are generated from these files which are also used in the unit tests.
Yea but repetition legitimises! (A reference/joke BTW)
Seriously though @freamon@endlesstalk.org , how are you deriving all of these? From theoretical understanding of what should happen or actual observations of a test system?
Observation, mostly. Also guesswork and trial-and-error, because I never realised these were all in the docs.
The comments in here are from me running lemmy in a VM, and subscribing to a fake community on a VPS (you can mimic a community with a webfinger response and a bunch of static files). The activities sent by lemmy just went to a basic server, that dumped out the JSON files it received.
I mostly made this post so I could point to something when posting about a Ruby script that can be used to interact with lemmy from the command line. This provides the opportunity to learn about ActivityPub, separate from the more complicated applications that currently implement it.
The interesting community came with 2 posts. freamon upvotes post 1, and downvotes post 2
{
"@context": [
"https://join-lemmy.org/context.json",
"https://www.w3.org/ns/activitystreams"
],
"id": "https://local.com/activities/like/16e6a46e-b80b-4d13-8258-2f724c53ed1c",
"actor": "https://local.com/u/freamon",
"object": "https://remote.com/post/1",
"type": "Like",
"audience": "https://remote.com/c/interesting"
}
{
"@context": [
"https://join-lemmy.org/context.json",
"https://www.w3.org/ns/activitystreams"
],
"id": "https://local.com/activities/dislike/576f119f-5aa5-4f5e-ba48-a79b26f0fae3",
"actor": "https://local.com/u/freamon",
"object": "https://remote.com/post/2",
"type": "Dislike",
"audience": "https://remote.com/c/interesting"
}
freamon changes his mind about post 2, and undoes his downvote
{
"@context": [
"https://join-lemmy.org/context.json",
"https://www.w3.org/ns/activitystreams"
],
"id": "https://local.com/activities/undo/e677b1ba-caaf-4a2f-9472-681705f337a3",
"actor": "https://local.com/u/freamon",
"object": {
"actor": "https://local.com/u/freamon",
"object": "https://remote.com/post/2",
"type": "Like",
"id": "https://local.com/activities/like/70edfad8-dcbb-42cd-8fd2-f674844b8801",
"audience": "https://remote.com/c/interesting"
},
"type": "Undo",
"audience": "https://remote.com/c/interesting"
}
Note: due the expection of unique ‘id’ fields, the encapsulated object isn’t the same, so this is probably best read as ‘undo vote’
freamon subscribes to the interesting community
The subscription status changes to ‘pending’
{
"@context": [
"https://join-lemmy.org/context.json",
"https://www.w3.org/ns/activitystreams"
],
"actor": "https://local.com/u/freamon",
"to": [
"https://remote.com/c/interesting"
],
"object": "https://remote.com/c/interesting",
"type": "Follow",
"id": "https://local.com/activities/follow/5cc358b8-9eae-49ef-8b5c-05d98504bda1"
}
The interesting community accepts freamon’s subscription request
The subscription status changes to ‘joined’
{
"actor": "https://remote.com/c/interesting",
"to": "https://local.com/u/freamon",
"object": {
"actor": "https://local.com/u/freamon",
"to": null,
"object": "https://remote.com/c/interesting",
"type": "Follow",
"id": "https://local.com/activities/follow/c66515bd-6f81-44e0-8af9-c4c4ae307051"
},
"type": "Accept",
"id": "https://remote.com/activities/accept/4ca771e6-0213-478a-83ba-d957984b98c5"
}
freamon changes his mind. He doesn’t want to subscribe anymore
{
"@context": [
"https://join-lemmy.org/context.json",
"https://www.w3.org/ns/activitystreams"
],
"actor": "https://local.com/u/freamon",
"to": [
"https://remote.com/c/interesting"
],
"object": {
"actor": "https://local.com/u/freamon",
"to": [
"https://remote.com/c/interesting"
],
"object": "https://remote.com/c/interesting",
"type": "Follow",
"id": "https://local.com/activities/follow/c934a27e-0dad-4641-85f5-a83e04d672a4"
},
"type": "Undo",
"id": "https://local.com/activities/undo/a9047cfc-ed0e-49c2-86da-9a0b3dbdc463"
}
Note 1: lemmy expects these ‘id’ fields to be unique, so the encapulated ‘Follow’ isn’t the same as the one that was sent.
Note 2: lemmy also sends a Undo/Follow if you block a community
freamon creates a post in the interesting community. He adds a title, a body, links to an image, and tags it as in English.
{
"@context": [
"https://join-lemmy.org/context.json",
"https://www.w3.org/ns/activitystreams"
],
"id": "https://local.com/activities/create/37f46c10-9fc2-4228-b8ea-3803eb911485",
"actor": "https://local.com/u/freamon",
"to": [
"https://www.w3.org/ns/activitystreams#Public"
],
"object": {
"type": "Page",
"id": "https://local.com/post/3",
"attributedTo": "https://local.com/u/freamon",
"to": [
"https://remote.com/c/interesting",
"https://www.w3.org/ns/activitystreams#Public"
],
"name": "Title Text",
"cc": [],
"content": "<p>Body Text</p>\n",
"mediaType": "text/html",
"source": {
"content": "Body Text",
"mediaType": "text/markdown"
},
"attachment": [
{
"href": "https://i.imgur.com/T7Z3vUU.jpeg",
"type": "Link"
}
],
"commentsEnabled": true,
"sensitive": false,
"published": "2024-02-13T21:46:05.705099Z",
"language": {
"identifier": "en",
"name": "English"
},
"audience": "https://remote.com/c/interesting"
},
"cc": [
"https://remote.com/c/interesting"
],
"type": "Create",
"audience": "https://remote.com/c/interesting"
}
For an example of an Announce encapsulating these, I’ll use this post. The format is always the same from what I’ve seen (the ‘context’ is moved to the top level, and the original activity is placed inside as an ‘object’).
curl --header 'accept: application/activity+json' https://lemmy.ml/c/learningrustandlemmy/outbox | jq .orderedItems[3]
{
"actor": "https://lemmy.ml/c/learningrustandlemmy",
"to": [
"https://www.w3.org/ns/activitystreams#Public"
],
"object": {
"id": "https://lemmy.ml/activities/create/191df452-33a6-4861-8218-6f1702f39fe3",
"actor": "https://endlesstalk.org/u/freamon",
"to": [
"https://www.w3.org/ns/activitystreams#Public"
],
"object": {
"type": "Page",
"id": "https://endlesstalk.org/post/22923810",
"attributedTo": "https://endlesstalk.org/u/freamon",
"to": [
"https://lemmy.ml/c/learningrustandlemmy",
"https://www.w3.org/ns/activitystreams#Public"
],
"name": "Lemmy's ActivityPub activities",
"cc": [],
"content": "<p>I’ll reply in the comments with a example of what lemmy sends for each thing you can do (I think I’ve t hought of everything, but you can probably guess the format if not, or I can always add it).</p>\n<p>So, the setup for these is:<br />\nOur instance is called ‘local.com’<br />\nOur user is called ‘freamon’<br />\nThe other instance is called ‘remo te.com’<br />\nThe community on that instance is called ‘interesting’</p>\n<p>For many of these, remote.com will receive the m, and rewraps them in an Announce to send out to all the other instances with a copy of the community, so everyone stays in sync.</p>\n",
"mediaType": "text/html",
"source": {
"content": "I'll reply in the comments with a example of what lemmy sends for each thing you can do (I think I've th ought of everything, but you can probably guess the format if not, or I can always add it).\n\nSo, the setup for these is: \nOur instance is called 'local.com' \nOur user is called 'freamon' \nThe other instance is called 'remo te.com' \nThe community on that instance is called 'interesting' \n\nFor many of these, remote.com will receive them, and rewraps them in an Announce to send out to all the other instances with a copy of the community, so everyone stay s in sync.\n",
"mediaType": "text/markdown"
},
"attachment": [],
"commentsEnabled": true,
"sensitive": false,
"published": "2024-02-15T12:08:08.036884Z",
"updated": "2024-02-15T12:42:34.861055Z",
"language": {
"identifier": "en",
"name": "English"
},
"audience": "https://lemmy.ml/c/learningrustandlemmy"
},
"cc": [
"https://lemmy.ml/c/learningrustandlemmy"
],
"type": "Create",
"audience": "https://lemmy.ml/c/learningrustandlemmy"
},
"cc": [
"https://lemmy.ml/c/learningrustandlemmy/followers"
],
"type": "Announce",
"id": "https://lemmy.ml/activities/announce/create/6689f68f-1fc4-44d2-9d0a-0e200d469e48"
}