AP Extensions¶
Actor endpoints¶
The following endpoints are additionally present into our actors.
oauthRegistrationEndpoint(http://litepub.social/ns#oauthRegistrationEndpoint)
oauthRegistrationEndpoint¶
Points to MastodonAPI /api/v1/apps for now.
See https://docs.joinmastodon.org/methods/apps/
Emoji reactions¶
Emoji reactions are implemented as a new activity type EmojiReact.
A single user is allowed to react multiple times with different emoji to the
same post. However, they may only react at most once with the same emoji.
Repeated reaction from the same user with the same emoji are to be ignored.
Emoji reactions are also distinct from Like activities and a user may both
Like and react to a post.
Note
Misskey also supports emoji reactions, but the implementations differs. It equates likes and reactions and only allows a single reaction per post.
The emoji is placed in the content field of the activity
and the object property points to the note reacting to.
Emoji can either be any Unicode emoji sequence or a custom emoji.
The latter must place their shortcode, including enclosing colons,
into content and put the emoji object inside the tag property.
The tag property MAY be omitted for Unicode emoji.
An example reaction with a Unicode emoji:
{
"@context": [
"https://www.w3.org/ns/activitystreams",
"https://example.org/schemas/litepub-0.1.jsonld",
{
"@language": "und"
}
],
"type": "EmojiReact",
"id": "https://example.org/activities/23143872a0346141",
"actor": "https://example.org/users/akko",
"nickname": "akko",
"to": ["https://remote.example/users/diana", "https://example.org/users/akko/followers"],
"cc": ["https://www.w3.org/ns/activitystreams#Public"],
"content": "🧡",
"object": "https://remote.example/objects/9f0e93499d8314a9"
}
An example reaction with a custom emoji:
{
"@context": [
"https://www.w3.org/ns/activitystreams",
"https://example.org/schemas/litepub-0.1.jsonld",
{
"@language": "und"
}
],
"type": "EmojiReact",
"id": "https://example.org/activities/d75586dec0541650",
"actor": "https://example.org/users/akko",
"nickname": "akko",
"to": ["https://remote.example/users/diana", "https://example.org/users/akko/followers"],
"cc": ["https://www.w3.org/ns/activitystreams#Public"],
"content": ":mouse:",
"object": "https://remote.example/objects/9f0e93499d8314a9",
"tag": [{
"type": "Emoji",
"id": null,
"name": "mouse",
"icon": {
"type": "Image",
"url": "https://example.org/emoji/mouse/mouse.png"
}
}]
}
Note
Although an emoji reaction can only contain a single emoji, for compatibility with older versions of Pleroma and Akkoma, it is recommended to wrap the emoji object in a single-element array.
When reacting with a remote custom emoji do not include the remote domain in content’s shortcode
(unlike in our REST API which needs the domain):
{
"@context": [
"https://www.w3.org/ns/activitystreams",
"https://example.org/schemas/litepub-0.1.jsonld",
{
"@language": "und"
}
],
"type": "EmojiReact",
"id": "https://example.org/activities/7993dcae98d8d5ec",
"actor": "https://example.org/users/akko",
"nickname": "akko",
"to": ["https://remote.example/users/diana", "https://example.org/users/akko/followers"],
"cc": ["https://www.w3.org/ns/activitystreams#Public"],
"content": ":hug:",
"object": "https://remote.example/objects/9f0e93499d8314a9",
"tag": [{
"type": "Emoji",
"id": "https://other.example/emojis/hug",
"name": "hug",
"icon": {
"type": "Image",
"url": "https://other.example/files/b71cea432b3fad67.webp"
}
}]
}
Emoji reactions can be retracted using a standard Undo activity:
{
"@context": [
"https://www.w3.org/ns/activitystreams",
"http://example.org/schemas/litepub-0.1.jsonld",
{
"@language": "und"
}
],
"type": "Undo",
"id": "http://example.org/activities/4685792e-efb6-4309-b508-ae4f355dd695",
"actor": "https://example.org/users/akko",
"to": ["https://remote.example/users/diana", "https://example.org/users/akko/followers"],
"cc": ["https://www.w3.org/ns/activitystreams#Public"],
"object": "https://example.org/activities/23143872a0346141"
}
User profile backgrounds¶
Akkoma federates user profile backgrounds the same way as Sharkey.
An actors ActivityPub representation contains an additional
backgroundUrl property containing an Image object. This property
belongs to the "sharkey": "https://joinsharkey.org/ns#" namespace.
Quote Posts¶
Akkoma allows referencing a single other note as a quote, which will be prominently displayed in the interface.
The quoted post is referenced by its ActivityPub id in the quoteUri property.
Note
Old Misskey only understood and modern Misskey still prefers
the _misskey_quote property for this. Similar some other older
software used quoteUrl or quoteURL.
All current implementations with quote support understand quoteUri.
Example:
{
"@context": [
"https://www.w3.org/ns/activitystreams",
"https://example.org/schemas/litepub-0.1.jsonld",
{
"@language": "und"
}
],
"type": "Note",
"id": "https://example.org/activities/85717e587f95d5c0",
"actor": "https://example.org/users/akko",
"to": ["https://remote.example/users/diana", "https://example.org/users/akko/followers"],
"cc": ["https://www.w3.org/ns/activitystreams#Public"],
"context": "https://example.org/contexts/1",
"content": "Look at that!",
"quoteUri": "http://remote.example/status/85717e587f95d5c0",
"contentMap": {
"en": "Look at that!"
},
"source": {
"content": "Look at that!",
"mediaType": "text/plain"
},
"published": "2024-04-06T23:40:28Z",
"updated": "2024-04-06T23:40:28Z",
"attachemnt": [],
"tag": []
}
Threads¶
Akkoma assigns all posts of the same thread the same context. This is a
standard ActivityPub property but its meaning is left vague. Akkoma will
always treat posts with identical context as part of the same thread.
context must not be assumed to hold any meaning or be dereferencable.
Incoming posts without context will be assigned a new context.
Note
Mastodon uses the non-standard conversation property for the same purpose
(named after an older OStatus property). For incoming posts without
context but with converstions Akkoma will use the value from
conversations to fill in context.
For outgoing posts Akkoma will duplicate the context into conversation.
Post Source¶
Unlike Mastodon, Akkoma supports drafting posts in multiple source formats
besides plaintext, like Markdown or MFM. The original input is preserved
in the standard ActivityPub source property (not supported by Mastodon).
Still, content will always be present and contain the prerendered HTML form.
Supported mediaType include:
- text/plain
- text/markdown
- text/bbcode
- text/x.misskeymarkdown
Post Language¶
Note
This is also supported in and compatible with Mastodon, but since joinmastodon.org doesn’t document it yet it is included here. GoToSocial has a more refined version of this which can correctly deal with multiple language entries.
A post can indicate its language by including a contentMap object
which contains a sub key named after the language’s ISO 639-1 code
and it’s content identical to the post’s content field.
Currently Akkoma, just like Mastodon, only properly supports a single language entry,
in case of multiple entries a random language will be picked.
Furthermore, Akkoma currently only reads the content field
and never the value from contentMap.
Local post scope¶
Post using this scope will never federate to other servers but for the sake of completeness it is listed here.
In addition to the usual scopes (public, unlisted, followers-only, direct)
Akkoma supports an “unlisted” post scope. Such posts will not federate to
other instances and only be shown to logged-in users on the same instance.
It is included into the local timeline.
This may be useful to discuss or announce instance-specific policies and topics.
A post is addressed to the local scope by including <base url of instance>/#Public
in its to field. E.g. if the instance is on https://example.org it would use
https://example.org/#Public.
An implementation creating a new post MUST NOT address both the local and
general public scope as:Public at the same time. A post addressing the local
scope MUST NOT be sent to other instances or be possible to fetch by other
instances regardless of potential other listed addressees.
When receiving a remote post addressing both the public scope and what appears to be a local-scope identifier, the post SHOULD be treated without assigning any special meaning to the potential local-scope identifier.
Note
Misskey-derivatives have a similar concept of non-federated posts, however those are also shown publicly on the local web interface and are thus visible to non-members.
List post scope¶
Messages originally addressed to a custom list will contain
a listMessage field with an unresolvable pseudo ActivityPub id.
Deprecated and Removed Extensions¶
The following extensions were used in the past but have been dropped. Documentation is retained here as a reference and since old objects might still contains related fields.
Actor endpoints¶
The following endpoints used to be present:
uploadMedia(https://www.w3.org/ns/activitystreams#uploadMedia)
uploadMedia¶
Inspired by https://www.w3.org/wiki/SocialCG/ActivityPub/MediaUpload, it is part of the ActivityStreams namespace because it used to be part of the ActivityPub specification and got removed from it.
Content-Type: multipart/form-data
Parameters:
- (required) file: The file being uploaded
- (optional) description: A plain-text description of the media, for accessibility purposes.
Response: HTTP 201 Created with the object into the body, no Location header provided as it doesn't have an id
The object given in the response should then be inserted into an Object's attachment field.