2022-05-01 07:48:57 -03:00
NIP-03
======
OpenTimestamps Attestations for Events
--------------------------------------
2023-11-15 21:42:51 -03:00
`draft` `optional`
2022-05-01 07:48:57 -03:00
2023-10-11 10:17:43 -03:00
This NIP defines an event with `kind:1040` that can contain an [OpenTimestamps ](https://opentimestamps.org/ ) proof for any other event:
2022-05-01 07:48:57 -03:00
2023-10-11 10:17:43 -03:00
```json
2022-05-01 07:48:57 -03:00
{
2023-10-11 10:17:43 -03:00
"kind": 1040
"tags": [
["e", < event-id > , < relay-url > ],
["alt", "opentimestamps attestation"]
],
"content": < base64-encoded OTS file data >
2022-05-01 07:48:57 -03:00
}
```
2023-10-11 10:17:43 -03:00
- The OpenTimestamps proof MUST prove the referenced `e` event id as its digest.
2023-11-18 08:22:42 -03:00
- The `content` MUST be the full content of an `.ots` file containing at least one Bitcoin attestation. This file SHOULD contain a **single** Bitcoin attestation (as not more than one valid attestation is necessary and less bytes is better than more) and no reference to "pending" attestations since they are useless in this context.
2023-10-11 10:17:43 -03:00
### Example OpenTimestamps proof verification flow
2022-05-01 07:48:57 -03:00
2023-10-11 10:17:43 -03:00
Using [`nak` ](https://github.com/fiatjaf/nak ), [`jq` ](https://jqlang.github.io/jq/ ) and [`ots` ](https://github.com/fiatjaf/ots ):
```bash
~> nak req -i e71c6ea722987debdb60f81f9ea4f604b5ac0664120dd64fb9d23abc4ec7c323 wss://nostr-pub.wellorder.net | jq -r .content | ots verify
> using an esplora server at https://blockstream.info/api
- sequence ending on block 810391 is valid
timestamp validated at block [810391]
```