2025-07-29 13:48:43 -04:00

4.1 KiB

title name category tags editor contributors
WAKU-APP-QAKU Waku App Qaku Standards Track waku
Jimmy Debe <jimmy@status.im>

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 paasword SHOULD 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_topic and 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_topic is 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 and related rights waived via CC0.

References