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", "litepub": "http://litepub.social/ns#", "directMessage": "litepub:directMessage", "Hashtag": "as:Hashtag" } ], "id": "https://infosec.exchange/users/yossarian/statuses/113481718197642220", "type": "Note", "summary": null, "inReplyTo": null, "published": "2024-11-14T14:13:20Z", "url": "https://infosec.exchange/@yossarian/113481718197642220", "attributedTo": "https://infosec.exchange/users/yossarian", "to": [ "https://www.w3.org/ns/activitystreams#Public" ], "cc": [ "https://infosec.exchange/users/yossarian/followers", "https://infosec.exchange/users/trailofbits" ], "sensitive": false, "atomUri": "https://infosec.exchange/users/yossarian/statuses/113481718197642220", "inReplyToAtomUri": null, "conversation": "tag:infosec.exchange,2024-11-14:objectId=213017590:objectType=Conversation", "content": "<p>i&#39;m really excited to share the work my team at <span class=\"h-card\" translate=\"no\"><a href=\"https://infosec.exchange/@trailofbits\" class=\"u-url mention\">@<span>trailofbits</span></a></span> has been doing for the last year: Sigstore-based attestations are now live and generally available on PyPI!</p><p>if you&#39;re already using Trusted Publishing with the canonical pypi-publish action, you don&#39;t need to change anything: the action will generate and upload an attestation on your behalf.</p><p>we&#39;ve written a blog post on some of the technical details behind PyPI&#39;s attestation features, including Sigstore and PEP 740, here: <a href=\"https://blog.trailofbits.com/2024/11/14/attestations-a-new-generation-of-signatures-on-pypi/\" target=\"_blank\" rel=\"nofollow noopener noreferrer\" translate=\"no\"><span class=\"invisible\">https://</span><span class=\"ellipsis\">blog.trailofbits.com/2024/11/1</span><span class=\"invisible\">4/attestations-a-new-generation-of-signatures-on-pypi/</span></a></p><p><a href=\"https://infosec.exchange/tags/python\" class=\"mention hashtag\" rel=\"tag\">#<span>python</span></a> <a href=\"https://infosec.exchange/tags/pypi\" class=\"mention hashtag\" rel=\"tag\">#<span>pypi</span></a> <a href=\"https://infosec.exchange/tags/security\" class=\"mention hashtag\" rel=\"tag\">#<span>security</span></a> <a href=\"https://infosec.exchange/tags/sigstore\" class=\"mention hashtag\" rel=\"tag\">#<span>sigstore</span></a></p>", "contentMap": { "en": "<p>i&#39;m really excited to share the work my team at <span class=\"h-card\" translate=\"no\"><a href=\"https://infosec.exchange/@trailofbits\" class=\"u-url mention\">@<span>trailofbits</span></a></span> has been doing for the last year: Sigstore-based attestations are now live and generally available on PyPI!</p><p>if you&#39;re already using Trusted Publishing with the canonical pypi-publish action, you don&#39;t need to change anything: the action will generate and upload an attestation on your behalf.</p><p>we&#39;ve written a blog post on some of the technical details behind PyPI&#39;s attestation features, including Sigstore and PEP 740, here: <a href=\"https://blog.trailofbits.com/2024/11/14/attestations-a-new-generation-of-signatures-on-pypi/\" target=\"_blank\" rel=\"nofollow noopener noreferrer\" translate=\"no\"><span class=\"invisible\">https://</span><span class=\"ellipsis\">blog.trailofbits.com/2024/11/1</span><span class=\"invisible\">4/attestations-a-new-generation-of-signatures-on-pypi/</span></a></p><p><a href=\"https://infosec.exchange/tags/python\" class=\"mention hashtag\" rel=\"tag\">#<span>python</span></a> <a href=\"https://infosec.exchange/tags/pypi\" class=\"mention hashtag\" rel=\"tag\">#<span>pypi</span></a> <a href=\"https://infosec.exchange/tags/security\" class=\"mention hashtag\" rel=\"tag\">#<span>security</span></a> <a href=\"https://infosec.exchange/tags/sigstore\" class=\"mention hashtag\" rel=\"tag\">#<span>sigstore</span></a></p>" }, "updated": "2024-11-14T14:50:22Z", "attachment": [], "tag": [ { "type": "Mention", "href": "https://infosec.exchange/users/trailofbits", "name": "@trailofbits" }, { "type": "Hashtag", "href": "https://infosec.exchange/tags/python", "name": "#python" }, { "type": "Hashtag", "href": "https://infosec.exchange/tags/pypi", "name": "#pypi" }, { "type": "Hashtag", "href": "https://infosec.exchange/tags/security", "name": "#security" }, { "type": "Hashtag", "href": "https://infosec.exchange/tags/sigstore", "name": "#sigstore" } ], "replies": { "id": "https://infosec.exchange/users/yossarian/statuses/113481718197642220/replies", "type": "Collection", "first": { "type": "CollectionPage", "next": "https://infosec.exchange/users/yossarian/statuses/113481718197642220/replies?min_id=113481720501127165&page=true", "partOf": "https://infosec.exchange/users/yossarian/statuses/113481718197642220/replies", "items": [ "https://infosec.exchange/users/yossarian/statuses/113481720501127165" ] } }, "likes": { "id": "https://infosec.exchange/users/yossarian/statuses/113481718197642220/likes", "type": "Collection", "totalItems": 17 }, "shares": { "id": "https://infosec.exchange/users/yossarian/statuses/113481718197642220/shares", "type": "Collection", "totalItems": 21 } }