ActivityPub
Communication protocol | |
Abbreviation | AP |
---|---|
Purpose | Decentralized social networking |
Developer(s) | World Wide Web Consortium, Christine Lemmer-Webber, Evan Prodromou, et al. |
Introduction | January 23, 2018 |
Based on | ActivityStreams, JSON-LD |
Influenced | AT Protocol[1] |
Website | activitypub |
ActivityPub is a protocol and open standard for decentralized social networking. It provides a client-to-server (shortened to C2S) API for creating and modifying content, as well as a federated server-to-server (S2S) protocol for delivering notifications and content to other servers.[2] ActivityPub has become the main standard used in the fediverse, a popular network used for social networking that consists of software such as Mastodon, Pixelfed and PeerTube.[3]
ActivityPub is considered to be an update to the ActivityPump protocol used in pump.io, and the official W3C repository for ActivityPub is identified as a fork of ActivityPump.[4][5] The creation of a new standard for decentralized social networking was prompted by the complexity of OStatus, the most commonly used protocol at the time. OStatus was built using a multitude of technologies (such as Atom, Salmon, WebSub and WebFinger), a product of the infrastructure used in GNU social (the originator and largest user of the OStatus protocol), which made it difficult to implement the protocol into new software. OStatus was also only designed to work with microblogging services, with little flexibility to the types of data that it could hold.
The standard was first published by the World Wide Web Consortium (W3C) as a W3C Recommendation in January 2018 by the Social Web Working Group (SocialWG), a working group chartered to build the protocols and vocabularies needed to create a standard for social functionality.[6] Shortly after, further development was moved to the Social Web Community Group (SocialCG), the successor to the SocialWG.
Design
ActivityPub uses the ActivityStreams 2.0 format for building its content, which itself uses JSON-LD. The three main data types used in ActivityPub are Objects, Activities and Actors. Objects are the most common data type, and can be images, videos, or more abstract items such as locations or events. Activities are actions that create and modify objects, for example a Create
activity creates an object. Actors are representative of an individual, a group, an application or a service, and are the owners of objects.
Every actor type contains an inbox and outbox stream, which sends and receives activities for a user. In order to publish data (for example liking an article), a user creates an activity that declares that they liked an Article object and publishes it to their outbox, where it is then delivered by the ActivityPub server via a POST request to the inboxes listed in the activity's to
, bto
, cc
and bcc
fields. The receiving servers then accounts for the newly received activity and updates the article by adding the like action to it.
Example data
An example actor object that represents a user account:[7]
{
"@context": ["https://www.w3.org/ns/activitystreams",
{"@language": "ja"}],
"type": "Person",
"id": "https://kenzoishii.example.com/",
"following": "https://kenzoishii.example.com/following.json",
"followers": "https://kenzoishii.example.com/followers.json",
"liked": "https://kenzoishii.example.com/liked.json",
"inbox": "https://kenzoishii.example.com/inbox.json",
"outbox": "https://kenzoishii.example.com/feed.json",
"preferredUsername": "kenzoishii",
"name": "石井健蔵",
"summary": "この方はただの例です",
"icon": [
"https://kenzoishii.example.com/image/165987aklre4"
]
}
An example activity that likes an article object:
{
"@context": ["https://www.w3.org/ns/activitystreams",
{"@language": "en"}],
"type": "Like",
"actor": "https://dustycloud.org/christine/",
"summary": "Christine liked 'Minimal ActivityPub update client'",
"object": "https://rhiaro.co.uk/2016/05/minimal-activitypub",
"to": ["https://rhiaro.co.uk/#amy",
"https://dustycloud.org/followers",
"https://rhiaro.co.uk/followers/"],
"cc": "https://e14n.com/evan"
}
An example article object:
{
"@context": ["https://www.w3.org/ns/activitystreams",
{"@language": "en-GB"}],
"id": "https://rhiaro.co.uk/2016/05/minimal-activitypub",
"type": "Article",
"name": "Minimal ActivityPub update client",
"content": "Today I finished morph, a client for posting ActivityStreams2...",
"attributedTo": "https://rhiaro.co.uk/#amy",
"to": "https://rhiaro.co.uk/followers/",
"cc": "https://e14n.com/evan"
}
Project status
Lead author Christine Lemmer-Webber notes that the team predominantly identified as queer, which led to features that help users and administrators protect against "undesired interaction." She also notes that the team authoring ActivityPub had no corporate participation.[8]
The SocialCG previously organized a yearly free conference called ActivityPub Conf about the future of ActivityPub.[9][10] Triages are held regularly to review issues pertaining to the ActivityPub and ActivityStreams 2.0 specifications as part of the SocialCG.[11]
In 2023, Germany's Sovereign Tech Fund donated €152,000 to socialweb.coop with the goal of building a new suite for testing various ActivityPub implementations and their compliance with the specification.[12]
Adoption
The initial wave of adoption for ActivityPub (circa 2016-2018) came from software that was already using OStatus as their federation protocol, such as Mastodon, GNU social and Pleroma.[13] Following the acquisition of Twitter by Elon Musk in 2022, many groups of users that were critical of the acquisition migrated to Mastodon, bringing new attention to the ActivityPub protocol with it.[14] Various major social media platforms and corporations have since pledged to implement ActivityPub support, including Tumblr,[15] Flipboard[16] and Meta Platforms' Threads.[17]
Criticism
Accidental denial-of-service attacks
Poorly optimized ActivityPub implementations can cause unintentional distributed-denial-of-service attacks on other websites and servers, due to the decentralized nature of the network.[citation needed] An example would be Mastodon's implementation of OpenGraph link previews, wherein every instance that receives a post that contains a link with OpenGraph metadata will download the associated data, such as a thumbnail, in a very short timeframe, which can slow down or crash servers as a result of the sudden burst of requests.[18][19]
Account migration
ActivityPub has been criticized for not natively supporting moving accounts from one server to another, forcing implementations to build their own solutions.[20] While there has been work on building a standardized system for migrating accounts using the Move activity via the Fediverse Enhancement Proposal organization, the current proposal only allows for basic follower migration, with all other data remaining linked to the original account.[21]
Missing content and data
ActivityPub implementations have been criticized for missing replies and parts of reply threads from remote posts, and presenting outdated statistics (e.g. likes and reposts) about remote posts.[22][23] However, this isn't a problem with the ActivityPub protocol itself, but with implementations not refreshing their content for updated data when needed.[24][25][citation needed]
Username format
The username format commonly used by ActivityPub software (acct URIs with the scheme replaced by an at sign, an example being @w3c@w3c.social
) has been criticized for being too complex for most users to understand. However, ActivityPub itself supports any URI as a username, and it is a limitation of Mastodon and other ActivityPub implementations, not the protocol itself.[3][citation needed]
Software using ActivityPub
Audio hosting
Software name | Total users[26][27] | Initial ActivityPub-compatible release |
---|---|---|
Castopod | ? | 2020[28] |
Funkwhale | 11,448 | 2018[29] |
Blogging
Software name | Total users[26][27] | Initial ActivityPub-compatible release | Fork of |
---|---|---|---|
Akkoma | 18,108 | 2022[30] | Pleroma |
Epicyon | 3 | 2019[31] | |
Firefish (f. Calckey) | 19,695 | 2022[32] | Misskey |
GNU social
(f. StatusNet; orig. Laconica) |
368 | 2018[33] | |
GoToSocial | 1,919 | 2021[34] | |
Honk | 7 | 2019[35] | |
Iceshrimp | 3,096 | 2023 | Firefish |
Mastodon | 9,630,383 | 2017[36] | |
Micro.blog | 168,418 | 2021[37] | |
microblog.pub | 66 | 2022[38] | |
Misskey | 849,930 | 2018 | |
Nextcloud Social | ~50 | 2018[39] | |
Pleroma | 138,294 | 2018[40] | |
Plume[41] | 25,290 | 2018[42] | |
Sharkey | 11,061 | 2023 | Misskey |
Snac[43] | 176 | 2022[44] | |
Socialhome | 2,325 | 2016[45] | |
Takahē | 278 | 2022[46] | |
Threads | 130,000,000 (February 2024)[47] | 2023[48] | |
Wafrn[49] | 891 | 2023 | |
WordPress[50][51] | 6,000+ blogs[52] | 2023[53] | |
WriteFreely | 160,761 | 2018[54] |
Book cataloging
Software name | Total users[26][27] | Initial ActivityPub-compatible release |
---|---|---|
BookWyrm[55] | 34,351 | 2021[56] |
Inventaire.io[57] | ? | 2021 |
Social news
Software name | Total users[26][27] | Initial ActivityPub-compatible release | Fork of |
---|---|---|---|
Flipboard[58] | 145,000,000 (February 2023)[59] | 2023[60][61] | |
kbin[62] | 66,320 | 2023 | |
Lemmy[63] | 392,074 | 2019 | |
lotide[64] | 457 | 2020[65] | |
mbin[66] | 5,490 | 2023 | kbin |
Other/Multi-format
Software name | Total users[26][27] | Initial ActivityPub-compatible release | Type |
---|---|---|---|
Friendica (f. Friendika; orig. Mistpark)[67] |
20,069 | 2019 | Blogging, event management, groups, image gallery |
Gancio[68] | 1,273 | 2020[69] | Calendar, event planner |
Guppe[70] | ? | 2021[71] | Groups |
Hubzilla (f. RedMatrix; orig. Friendica-Red)[72] |
5,748 | 2017 | Blogging, event planner, file hosting, image gallery, wiki |
Libervia[73] | ? | 2022 (in beta) | Blogging, event management, file sharing, instant messaging |
Matrix (via bridges)[74] | - | 2021 | Instant messaging |
Mobilizon | 45,503 | 2020 | Event management, groups |
Owncast[75] | 240 | 2022 | Live streaming |
PeerTube[76] | 351,142 | 2018 | Video sharing |
Pixelfed[77] | 18,733 | 2018 | Image sharing |
Postmarks[78] | 29 | 2023[79] | Social bookmarking |
Streams[80] | ? | 2022[81] | Blogging, image sharing, wiki |
Zap[82] | 22 | 2019[83] | Blogging, file hosting, image gallery |
Future implementations
- GitLab, a Git forge and development platform[84]
- Ghost, a blogging platform[85][86]
- Forgejo, a Git forge and development platform[87]
- Tumblr, a microblogging platform[88][89]
See also
- AT Protocol
- Comparison of microblogging and similar services
- Comparison of software and protocols for distributed social networking
- Fediverse
- Micropub
- OStatus
References
- ^ "FAQ | AT Protocol". atproto.com. Retrieved 2024-06-20.
- ^ "W3C Recommendation 23 January 2018".
- ^ a b Pierce, David (2024-02-07). "The fediverse, explained". The Verge. Retrieved 2024-06-20.
- ^ w3c/activitypub, World Wide Web Consortium, 2024-06-20, retrieved 2024-06-22
- ^ "Sandstorm and the Social Web". zenhack.net. 29 May 2016. Archived from the original on 30 October 2020. Retrieved 23 September 2017.
- ^ "Social Web Working Group". W3C. Retrieved 2024-06-23.
- ^ "ActivityPub Specification". W3C. January 23, 2018. Retrieved June 22, 2024.
- ^ Klemmens, Ben (2023-01-02). "Mastodon—and the pros and cons of moving beyond Big Tech gatekeepers". Ars Technica. Retrieved 2023-01-18.
- ^ "ActivityPub Conf 2019".
- ^ "ActivityPub Conf 2020". Archived from the original on 2021-06-02. Retrieved 2020-08-01.
- ^ "W3C Social Web Incubator Community Group Mailing List". Retrieved March 18, 2024.
- ^ "ActivityPub Test Suite". Sovereign Tech Fund. Retrieved 2024-05-26.
- ^ "Pleroma Encyclical: ActivityPub". blog.soykaf.com. 2018-02-10. Retrieved 2024-06-23.
- ^ MacManus, Richard (2022-11-15). "Devs Are Excited by ActivityPub, Open Protocol for Mastodon". The New Stack. Retrieved 2024-06-23.
- ^ Perez, Sarah (2022-11-21). "Tumblr to add support for ActivityPub, the social protocol powering Mastodon and other apps". TechCrunch. Retrieved 2024-06-23.
- ^ McCue, Mike (2023-12-18). "Flipboard Begins to Federate". Flipboard. Retrieved 2024-06-23.
- ^ Guinness, Harry (2023-07-12). "How ActivityPub is setting the stage to weave all your social media feeds together". Popular Science. Retrieved 2024-06-23.
- ^ "Please Don't Share Our Links on Mastodon: Here's Why!". It's FOSS News. 2024-05-01. Retrieved 2024-06-18.
- ^ Balkan, Aral (2022-11-09). "Is the fediverse about to get Fryed? (Or, 'Why every toot is also a potential denial of service attack')". ar.al. Retrieved 2024-06-18.
- ^ "FAQ | AT Protocol". atproto.com. Retrieved 2024-06-20.
- ^ fediverse. "FEP-7628". Codeberg.org. Retrieved 2024-06-20.
- ^ Wave, Setsune (2023-12-17). "This is a serious problem the fediverse has..." Furries.club. Retrieved 2024-06-18.
- ^ Armando, Armando (2024-06-19). "I think one of the things that most annoy newcomers to the #Fediverse is..." Fedia.Social. Retrieved 2024-06-19.
- ^ Nedelcu, Alexandru (2022-12-21). "Missing replies · Mastodon · Discussion #22608". GitHub. Retrieved 2024-06-18.
- ^ Prodromou, Evan (2024-06-19). "All of that information is available through ActivityPub..." CoSocial. Retrieved 2024-06-19.
- ^ a b c d e "Fediverse Observer". fediverse.observer. Retrieved 2024-06-22.
- ^ a b c d e "FediDB, Fediverse Network Statistics". fedidb.org. Retrieved 2024-06-22.
- ^ "Release v1.0.0-alpha.1: chore(release): 1.0.0-alpha.1 [skip ci] · ad-aures/castopod". GitHub. Archived from the original on July 25, 2023. Retrieved July 25, 2023.
- ^ Collective, Funkwhale. "Funkwhale Blog ~ Funkwhale 0.17 is out!". blog.funkwhale.audio. Archived from the original on July 25, 2023. Retrieved July 25, 2023.
- ^ "Akkoma: A vision to refocus Pleroma". Coffee and Dreams. 24 June 2022. Archived from the original on July 1, 2023. Retrieved July 25, 2023.
- ^ "Epicyon 1.0 release | LibreServer Blog". blog.libreserver.org. Archived from the original on June 9, 2023. Retrieved July 25, 2023.
- ^ "firefish". Codeberg.org. Archived from the original on July 26, 2023. Retrieved July 26, 2023.
- ^ diogo. "diogo/gnu-social". notabug.org. Retrieved 2024-06-22.
- ^ "Release v0.1.0 · superseriousbusiness/gotosocial". GitHub. Archived from the original on July 22, 2023. Retrieved July 25, 2023.
- ^ "honk 0.1". flak.tedunangst.com. Archived from the original on July 25, 2023. Retrieved July 25, 2023.
- ^ "Release v1.6.0 · mastodon/mastodon". GitHub. Retrieved 2024-06-22.
- ^ "ℹ️ Mastodon and ActivityPub". Micro.blog Help Center. 2021-03-08. Retrieved 2024-06-22.
- ^ "Release 2.0.0-rc.1 · tsileo/microblog.pub". GitHub. Archived from the original on July 25, 2023. Retrieved July 25, 2023.
- ^ Poortvliet, Jos (10 December 2018). "Nextcloud introduces social features, joins the fediverse". Nextcloud. Archived from the original on December 10, 2018. Retrieved December 10, 2018.
- ^ "ActivityPub in Pleroma". blog.soykaf.com. 2018-03-04. Retrieved 2024-06-22.
- ^ joinplu.me. "Plume". Archived from the original on May 10, 2019. Retrieved May 2, 2019.
- ^ "Release 0.2.0 (Alpha 1) · Plume-org/Plume". GitHub. Archived from the original on July 25, 2023. Retrieved July 25, 2023.
- ^ "Snac - A simple, minimalistic ActivityPub instance written in portable C". snac2. Retrieved 2024-04-19.
- ^ grunfink. "snac2". Codeberg.org. Retrieved 2024-07-02.
- ^ "Release v0.1.1: Merge pull request #6 from jaywink/travisify · jaywink/socialhome". GitHub. Archived from the original on July 25, 2023. Retrieved July 25, 2023.
- ^ "Release 0.3.0 · jointakahe/takahe". GitHub. Archived from the original on July 25, 2023. Retrieved July 25, 2023.
- ^ Perez, Sarah (February 2024). "Threads now reaches more than 130 million monthly users, says Meta, up 30M from Q3". TechCrunch. Archived from the original on 2 February 2024. Retrieved 1 February 2024.
- ^ Davis, Wes (2023-12-13). "Threads is officially starting to test ActivityPub integration". The Verge. Retrieved 2024-06-22.
- ^ García, Gabriel Amador (2024-06-21), gabboman/wafrn, retrieved 2024-06-22
- ^ "ActivityPub for WordPress". Github. Retrieved 7 July 2023.
- ^ "Engage a Wider Audience With ActivityPub on WordPress.com". WordPress. Retrieved 2023-10-12.
- ^ Pfefferle, Matthias; Automattic. "ActivityPub". WordPress.org. Retrieved 2024-06-23.
- ^ Sato, Mia (2023-10-11). "WordPress now offers official support for ActivityPub". The Verge. Retrieved 2024-06-23.
- ^ WriteFreely (2018-11-10). "Hello, World". WriteFreely. Retrieved 2024-06-22.
- ^ bookwyrm. "Bookwyrm". Archived from the original on May 26, 2021. Retrieved May 26, 2021.
- ^ "BookWyrm (@bookwyrm@tech.lgbt)". LGBTQIA+ Tech Mastodon. 6 May 2021. Archived from the original on July 25, 2023. Retrieved July 25, 2023.
- ^ "Inventaire toot". mamot.fr. December 7, 2021. Archived from the original on August 28, 2022. Retrieved October 17, 2022.
- ^ Perez, Sarah (23 May 2023). "Flipboard becomes first app to support Bluesky, Mastodon and Pixelfed all in one place". TechCrunch. Retrieved 7 July 2023.
- ^ "Twitter, Who? Flipboard Adds Mastodon Features, Pushing Further Into Social Networking". CNET. Retrieved 2024-06-23.
- ^ "Flipboard is pivoting to ActivityPub and the fediverse". The Verge. Dec 18, 2023.
- ^ McCue, Mike (19 December 2023). "Flipboard Begins to Federate". Medium. Retrieved 2 January 2024.
- ^ "kbin.pub - Fediverse of content". kbin.pub. Archived from the original on July 25, 2023. Retrieved July 24, 2023.
- ^ "Lemmy - ActivityPub for link aggregation". nlnet.nl. Retrieved 2023-06-05.
- ^ "lotide". Archived from the original on October 31, 2020. Retrieved October 29, 2020.
- ^ "Release v0.1.1 · lotide-org/lotide". GitHub. Archived from the original on July 25, 2023. Retrieved July 25, 2023.
- ^ MbinOrg/mbin, Mbin, 2024-06-22, retrieved 2024-06-23
- ^ "Friendica 2019.01 released". Retrieved 2019-01-24.
- ^ "Home". Gancio. Archived from the original on July 24, 2023. Retrieved July 24, 2023.
- ^ "v0.21.0 · les / gancio · GitLab". GitLab. Archived from the original on July 25, 2023. Retrieved July 25, 2023.
- ^ immers-space. "Decentralized social groups for ActivityPub". GitHub. Archived from the original on November 22, 2022. Retrieved November 22, 2022.
- ^ "Release First major release · immers-space/guppe". GitHub. Archived from the original on July 25, 2023. Retrieved July 25, 2023.
- ^ "Hubzilla - Frequently asked questions". hubzilla.org. Archived from the original on July 25, 2023. Retrieved July 25, 2023.
- ^ "Libervia progress note 2022-W45". salut-a-toi.org. November 2022.
- ^ "Kazarma". kazar.ma. Archived from the original on July 27, 2023. Retrieved July 27, 2023.
- ^ "Owncast v0.0.11". March 5, 2022. Archived from the original on March 5, 2022. Retrieved March 5, 2022.
- ^ "Server-Server - ActivityPub implementation reports". Retrieved 2019-01-02.
- ^ Krasnoff, Barbara (August 2022). "Eight photo-centric social sites that are not Instagram". The Verge.
- ^ "postmarks". github.com. Archived from the original on September 15, 2023. Retrieved October 7, 2023.
- ^ "Postmarks". GitHub. Archived from the original on September 23, 2023. Retrieved October 7, 2023.
- ^ "streams". Codeberg.org. Archived from the original on July 9, 2023. Retrieved November 2, 2022.
- ^ "Official release". Mike Macgirvin. Archived from the original on December 13, 2023. Retrieved September 23, 2023.
- ^ "Zap". zotlabs.org. Archived from the original on June 20, 2023. Retrieved July 25, 2023.
- ^ "Zap". zotlabs.org. Retrieved 2024-06-23.
- ^ "Support ActivityPub for merge requests (&11247) · Epics · GitLab.org · GitLab". GitLab. Retrieved 2023-08-26.
- ^ Ahooja, Anuj (2024-04-22). "Substack Competitor Ghost Announces ActivityPub Integration". We Distribute. Retrieved 2024-04-28.
- ^ Patel, Nilay (2024-04-22). "Newsletter platform Ghost adopts ActivityPub to 'bring back the open web'". The Verge. Retrieved 2024-09-09.
- ^ "First forgejo monthly update - December 2022". forgejo.org. Retrieved 2023-08-29.
- ^ Perez, Sarah (2023-12-11). "Tumblr's 'fediverse' integration is still being worked on, says owner and Automattic CEO Matt Mullenweg". TechCrunch. Retrieved 2023-12-19.
- ^ Perez, Sarah (2022-11-21). "Tumblr to add support for ActivityPub, the social protocol powering Mastodon and other apps". TechCrunch. Retrieved 2023-12-19.