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.
{
"@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'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'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
}
}