-add poll format request for comment (RFC) pro/con lists
-remove placeholding json structure
This commit is contained in:
landonMutch 2023-02-27 15:04:03 +09:00 committed by GitHub
parent 72260b273c
commit 255c4d98c5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

56
69.md
View File

@ -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