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",
"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'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're already using Trusted Publishing with the canonical pypi-publish action, you don't need to change anything: the action will generate and upload an attestation on your behalf.</p><p>we've written a blog post on some of the technical details behind PyPI'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'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're already using Trusted Publishing with the canonical pypi-publish action, you don't need to change anything: the action will generate and upload an attestation on your behalf.</p><p>we've written a blog post on some of the technical details behind PyPI'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
}
}