Skip to content

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.