mirror of
https://github.com/nostr-protocol/nips.git
synced 2025-01-07 14:52:09 -05:00
add RFC
-add poll format request for comment (RFC) pro/con lists -remove placeholding json structure
This commit is contained in:
parent
72260b273c
commit
255c4d98c5
56
69.md
56
69.md
|
@ -1,33 +1,41 @@
|
||||||
# Poll event
|
# Poll event
|
||||||
|
|
||||||
|
A poll note is a nostr event type (kind 6969) for conducting polls, containing predefined voting options, which users may vote on via zaps.
|
||||||
|
|
||||||
## Purpose
|
## Purpose
|
||||||
|
|
||||||
- define new standardized event kind for voting polls
|
* define new standardized event kind for voting polls
|
||||||
|
|
||||||
## Poll format
|
## Poll format (RFC)
|
||||||
|
|
||||||
```json
|
Should a poll be self-contained in a single event (including its voting options) or be a parent event (#0) with separate (but linked) child voting option events (#1, #2, #3, #n), each referencing the parent poll event?
|
||||||
{
|
|
||||||
"id": <32-bytes lowercase hex-encoded sha256 of the the serialized poll event data>
|
#### Self-contained poll event
|
||||||
"pubkey": <32-bytes lowercase hex-encoded public key of the poll event creator>,
|
|
||||||
"created_at": <unix timestamp in seconds>,
|
* Pros:
|
||||||
"kind": 6969,
|
* likely results in better UX by providing compact, widget-style notes immediately recognizable as unique poll type
|
||||||
"tags": [
|
* promotes more uniform implementation across clients
|
||||||
["e", <32-bytes hex of the id of another event>, <recommended relay URL>],
|
* Cons:
|
||||||
["p", <32-bytes hex of the key>, <recommended relay URL>],
|
* increased poll event complexity, owing to internally nested voting options (each necessarily containing their own zap requirements)
|
||||||
],
|
* potentially increased difficulty of client implementation
|
||||||
"content": <arbitrary string>,
|
|
||||||
"sig": <64-bytes hex of the signature of the sha256 hash of the serialized event data, which is the same as the "id" field>
|
#### Single parent poll event with linked child voting option events
|
||||||
}
|
|
||||||
```
|
* Pros:
|
||||||
|
* better alignment with existing event (specifically zap) structures
|
||||||
|
* potential for backward compatibility with clients uncompliant with polling events, i.e. non-compliant clients could handle poll event chains same as existing threads
|
||||||
|
* possibly simplifies implementation by clients?
|
||||||
|
* Cons:
|
||||||
|
* introduces possibility for fragmentation of polls, e.g. separation or loss of child voting options
|
||||||
|
* increased potential for non-uniform implementation of polling UI/UX across clients
|
||||||
|
|
||||||
## TODO
|
## TODO
|
||||||
|
|
||||||
- define basic polling features
|
* define basic polling features
|
||||||
- define basic polling format
|
* define basic polling format
|
||||||
- outline polling NIP
|
* outline polling NIP
|
||||||
- publish RFC to nostr dev community
|
* publish RFC to nostr dev community
|
||||||
- implement polls in 1 relay
|
* implement polls in 1 relay
|
||||||
- implement polls in 2 clients
|
* implement polls in 2 clients
|
||||||
- send pull request to nostr-protocol/NIPs
|
* send pull request to nostr-protocol/NIPs
|
||||||
- merge with nostr-protocol/NIPs
|
* merge with nostr-protocol/NIPs
|
||||||
|
|
Loading…
Reference in New Issue
Block a user