4.1 KiB
| title | name | category | tags | editor | contributors | |
|---|---|---|---|---|---|---|
| WAKU-APP-QAKU | Waku App Qaku | Standards Track | waku |
|
Abstract
The document describes the functions of a Waku Web application Qaku. The use of Waku protocols in the Qaku questions and answers web application allow for a secure , trustless environment.
Background
Waku is a family of robust, censorship-resistant communication protocols designed to enable privacy-focused messaging for web3 apps. Qaku is a questions and answers Waku web application. It allows the user to create a Q&A board, share a link and let users post questions. Users can upvote questions which move to the top of the list on the board.
Specification
The key words “MUST”, “MUST NOT”, “REQUIRED”, “SHALL”, “SHALL NOT”, “SHOULD”, “SHOULD NOT”, “RECOMMENDED”, “NOT RECOMMENDED”, “MAY”, and “OPTIONAL” in this document are to be interpreted as described in RFC 2119.
The Q&A board is created and maintained by an owner, who SHOULD support an accessible interface for its users.
Identity
- Users and an owner MUST generate a private key
- The owner MUST generate a private key to before becoming the owner of the Q&A board.
- The owner address, derived from the public key, SHOULD be made public as the owner of Qaku.
- A
paaswordSHOULD be used to encrypt the private key
The public key is used to sign and verify messages. The owner MUST be able to enable and disable questions added to the board.
Node
The Qaku application SHOULD connect to the default Waku pubsub_topic.
When a user accesses the Qaku app,
the user joins a new session that SHOULD create a new content_topic.
When the user exits the Qaku app,
the session ends but the content_topic remians available on the Waku network for other users to connect to.
Qaku uses the following 10/WAKU protocols:
- the 19/WAKU2-LIGHTPUSH to push a message type to the Waku network.
- the 12/WAKU2-FILTER to subscribe to Waku
content_topicand listen to messages published to that topic. - the 13/WAKU-STORE to query and load old messages from the Waku network for users.
- A new
content_topicis created when a new Q&A board is created. - All questions and answer are pushed to the content_topic
Messages
The Waku network processes real-time message updates, which enables new questions and
answers to be acceisble quickly.
A conec ulti
Messages are sent to a content_topic that are identified as a message_type.
The 13/WAKU-STORE nodes provide historical storage of the Qaku messages.
The following message_types used in Qaku include:
- Question Message
- Answered Message
- Control Message
- Upvote Message
- Moderation Message
- Poll messag
Question Message
The QuestionMessage type is generated by any user asking a new question on a Qaku board.
{
"QuestionMessage" : [
"question": string,
"timestamp": number,
"author?": identity,
"delegationInfo?": delegationInfo
]
}
Answered Message
The AnswerMessage type is generated by any sending an answer to the Qaku board.
{
"AnswerMessage" : [
hash: string,
text: string,
timestamp: number,
delegationInfo?: delegationInfo
]
}
Control Message
{
"ControlMessage" : [
title: string,
id: string,
enabled: boolean,
timestamp: number,
owner: string,
admins: string[],
moderation: boolean,
description: string,
updated: number,
startDate: number,
endDate?: number,
allowsParticipantsReplies: number,
delegationInfo?: DelegationInfo
]
}
Upvote Message
{
"UpVoteMessage" : [
questionId: string,
hash: string,
type: UpvoteType,
timestamp: number,
delegationInfo?: DelegationInfo;
]
}
When a new question is created, the interface SHOULD lis
Copyright
Copyright and related rights waived via CC0.