2023-04-17 12:31:18 -04:00
# NIP-07
2022-05-06 19:54:45 -04:00
2023-04-17 12:31:18 -04:00
## `window.nostr` capability for web browsers
2022-05-06 19:54:45 -04:00
`draft` `optional` `author:fiatjaf`
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.
That object must define the following methods:
2023-04-17 12:31:18 -04:00
```javascript
2022-05-06 19:54:45 -04:00
async window.nostr.getPublicKey(): string // returns a public key as hex
2023-01-15 13:37:42 -05:00
async window.nostr.signEvent(event: Event): Event // takes an event object, adds `id` , `pubkey` and `sig` and returns it
2022-12-18 04:35:30 -05:00
```
Aside from these two basic above, the following functions can also be implemented optionally:
2023-04-17 12:31:18 -04:00
```javascript
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
async window.nostr.nip04.encrypt(pubkey, plaintext): string // returns ciphertext and iv as specified in nip-04
async window.nostr.nip04.decrypt(pubkey, ciphertext): string // takes ciphertext and iv as specified in nip-04
2022-05-06 19:54:45 -04:00
```
2022-11-27 10:03:46 -05:00
### Implementation
2022-05-06 19:54:45 -04:00
2023-03-13 16:31:25 -04:00
- [horse ](https://github.com/fiatjaf/horse ) (Chrome and derivatives)
2023-02-25 06:23:46 -05:00
- [nos2x ](https://github.com/fiatjaf/nos2x ) (Chrome and derivatives)
- [Alby ](https://getalby.com ) (Chrome and derivatives, Firefox, Safari)
- [Blockcore ](https://www.blockcore.net/wallet ) (Chrome and derivatives)
- [nos2x-fox ](https://diegogurpegui.com/nos2x-fox/ ) (Firefox)
2023-02-28 18:36:21 -05:00
- [Flamingo ](https://www.getflamingo.org/ ) (Chrome and derivatives)