ActivityPub Viewer

A small tool to view real-world ActivityPub objects as JSON! Enter a URL or username from Mastodon or a similar service below, and we'll send a request with the right Accept header to the server to view the underlying object.

Open in browser →
{ "@context": [ "https://www.w3.org/ns/activitystreams", { "ostatus": "http://ostatus.org#", "atomUri": "ostatus:atomUri", "inReplyToAtomUri": "ostatus:inReplyToAtomUri", "conversation": "ostatus:conversation", "sensitive": "as:sensitive", "toot": "http://joinmastodon.org/ns#", "votersCount": "toot:votersCount", "Hashtag": "as:Hashtag" } ], "id": "https://mean.engineer/users/indutny/statuses/114152472053724333", "type": "Note", "summary": null, "inReplyTo": "https://mean.engineer/users/indutny/statuses/114139450221319768", "published": "2025-03-13T01:14:52Z", "url": "https://mean.engineer/@indutny/114152472053724333", "attributedTo": "https://mean.engineer/users/indutny", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://mean.engineer/users/indutny/followers" ], "sensitive": false, "atomUri": "https://mean.engineer/users/indutny/statuses/114152472053724333", "inReplyToAtomUri": "https://mean.engineer/users/indutny/statuses/114139450221319768", "conversation": "tag:mean.engineer,2025-03-10:objectId=40569:objectType=Conversation", "content": "<p>Here it is folks <a href=\"https://github.com/signalapp/node-sqlcipher\" target=\"_blank\" rel=\"nofollow noopener noreferrer\" translate=\"no\"><span class=\"invisible\">https://</span><span class=\"ellipsis\">github.com/signalapp/node-sqlc</span><span class=\"invisible\">ipher</span></a></p><p>A sqlcipher (encrypted sqlite) npm package:</p><p>- Built on N-API so it doesn&#39;t have to be recompiled<br />- Fully synchronous so that you can write your transaction without worries, and spread the work across threads as you like<br />- A bit faster than better-sqlite3 on SELECT queries (I used a special trick 😅), and about the same on INSERTs</p><p>Bonus:</p><p>It includes a custom FTS5 tokenizer that we use for tokenizing non-english queries (think CJK)</p><p><a href=\"https://mean.engineer/tags/NodeJS\" class=\"mention hashtag\" rel=\"tag\">#<span>NodeJS</span></a></p>", "contentMap": { "en": "<p>Here it is folks <a href=\"https://github.com/signalapp/node-sqlcipher\" target=\"_blank\" rel=\"nofollow noopener noreferrer\" translate=\"no\"><span class=\"invisible\">https://</span><span class=\"ellipsis\">github.com/signalapp/node-sqlc</span><span class=\"invisible\">ipher</span></a></p><p>A sqlcipher (encrypted sqlite) npm package:</p><p>- Built on N-API so it doesn&#39;t have to be recompiled<br />- Fully synchronous so that you can write your transaction without worries, and spread the work across threads as you like<br />- A bit faster than better-sqlite3 on SELECT queries (I used a special trick 😅), and about the same on INSERTs</p><p>Bonus:</p><p>It includes a custom FTS5 tokenizer that we use for tokenizing non-english queries (think CJK)</p><p><a href=\"https://mean.engineer/tags/NodeJS\" class=\"mention hashtag\" rel=\"tag\">#<span>NodeJS</span></a></p>" }, "attachment": [], "tag": [ { "type": "Hashtag", "href": "https://mean.engineer/tags/nodejs", "name": "#nodejs" } ], "replies": { "id": "https://mean.engineer/users/indutny/statuses/114152472053724333/replies", "type": "Collection", "first": { "type": "CollectionPage", "next": "https://mean.engineer/users/indutny/statuses/114152472053724333/replies?min_id=114152489010811347&page=true", "partOf": "https://mean.engineer/users/indutny/statuses/114152472053724333/replies", "items": [ "https://mean.engineer/users/indutny/statuses/114152489010811347" ] } }, "likes": { "id": "https://mean.engineer/users/indutny/statuses/114152472053724333/likes", "type": "Collection", "totalItems": 10 }, "shares": { "id": "https://mean.engineer/users/indutny/statuses/114152472053724333/shares", "type": "Collection", "totalItems": 4 } }