2022-05-06 19:54:45 -04:00
NIP-07
======
`window.nostr` capability for web browsers
------------------------------------------
2023-11-15 19:42:51 -05:00
`draft` `optional`
2022-05-06 19:54:45 -04:00
The `window.nostr` object may be made available by web browsers or extensions and websites or web-apps may make use of it after checking its availability.
2024-11-22 12:48:36 -05:00
That object must define the following:
2022-05-06 19:54:45 -04:00
```
2024-11-22 12:48:36 -05:00
window.nostr.pubkey: string | null // variable set on page load to a public key or null if none authorized
async window.nostr.getPublicKey(): string // returns a public key as hex, sets `window.nostr.pubkey` , too.
2023-10-20 16:56:29 -04:00
async window.nostr.signEvent(event: { created_at: number, kind: number, tags: string[][], content: string }): Event // takes an event object, adds `id` , `pubkey` and `sig` and returns it
2022-12-18 04:35:30 -05:00
```
2024-11-22 12:48:36 -05:00
Aside from these three basic above, the following functions can also be implemented optionally:
2022-12-18 04:35:30 -05:00
```
async window.nostr.getRelays(): { [url: string]: {read: boolean, write: boolean} } // returns a basic map of relay urls to relay policies
2023-12-20 07:22:02 -05:00
async window.nostr.nip04.encrypt(pubkey, plaintext): string // returns ciphertext and iv as specified in nip-04 (deprecated)
async window.nostr.nip04.decrypt(pubkey, ciphertext): string // takes ciphertext and iv as specified in nip-04 (deprecated)
2024-02-20 13:09:40 -05:00
async window.nostr.nip44.encrypt(pubkey, plaintext): string // returns ciphertext as specified in nip-44
async window.nostr.nip44.decrypt(pubkey, ciphertext): string // takes ciphertext as specified in nip-44
2022-05-06 19:54:45 -04:00
```
2024-07-15 11:11:56 -04:00
### Recommendation to Extension Authors
To make sure that the `window.nostr` is available to nostr clients on page load, the authors who create Chromium and Firefox extensions should load their scripts by specifying `"run_at": "document_end"` in the extension's manifest.
2023-05-11 11:09:40 -04:00
2022-11-27 10:03:46 -05:00
### Implementation
2022-05-06 19:54:45 -04:00
2023-12-27 05:37:20 -05:00
See https://github.com/aljazceru/awesome-nostr#nip-07-browser-extensions.