nips/63.md

54 lines
1.7 KiB
Markdown
Raw Normal View History

2024-03-30 16:57:37 -04:00
NIP-63
======
2024-03-30 17:02:13 -04:00
Signed Filters
--------------
2024-03-30 16:57:37 -04:00
`draft` `optional`
2024-03-31 11:19:41 -04:00
Event kind `33012` is used to represent one or more Nostr filters.
2024-03-30 16:57:37 -04:00
The `d` tag represents the subscription id and the `filter` tag contains the JSON-stringified [NIP-01](01.md) filter.
2024-03-30 16:57:37 -04:00
The optional `relay` tag lists the authorized relays the filter can download events from.
2024-03-31 11:33:12 -04:00
The optional `authorized` tag lists the pubkeys that are authorized to receive authed events on behalf of the user.
2024-03-31 11:33:12 -04:00
```js
2024-03-30 16:57:37 -04:00
{
"kind": 33012,
"tags": [
["d", "<subscription_id>"],
["filter", "<filter1>"],
["filter", "<filter2>"],
2024-03-31 11:33:12 -04:00
["authorized", "<32-bytes lowercase hex of a pubkey>"],
["relay", "<relay1>"],
["relay", "<relay2>"],
["expiration", "<unix timestamp>"],
2024-03-30 16:57:37 -04:00
],
"content": "",
// ...other fields
2024-03-30 16:57:37 -04:00
}
```
They are submitted to supporting relays via `SREQ` command, with the following format:
```js
2024-03-31 11:33:12 -04:00
["SREQ", <kind-33012>, <kind-33012>, ...]
```
2024-03-31 11:19:41 -04:00
Supporting relays interpret the `filter` tags in the same way they do with `REQ` while automatically authenticating the signer.
2024-03-31 11:43:16 -04:00
Relays MUST authenticate the `authorized` key if present.
2024-03-31 11:33:12 -04:00
Relays MUST verify if they are included in the `relay` tag list if present.
2024-03-31 11:43:16 -04:00
Relays MUST comply with the `expiration` to limit the reuse of the filter.
## Motivation
2024-03-31 11:33:12 -04:00
Push Notification servers can use these events to query private relays on behalf of users and push events down to mobile phones.
2024-03-30 16:57:37 -04:00
2024-03-31 11:33:12 -04:00
The goal is to be able to support `AUTH` from multiple users in the same connection. As a side effect, this approach removes the user `AUTH` round trip (but not the delegation `AUTH`).
2024-03-30 16:57:37 -04:00
2024-03-31 11:33:12 -04:00
Trusted proxies can use these event types to query relays on behalf of the user.