From 2eaa7949c4abe7d14e2b9560e8c045bf2e937c9a Mon Sep 17 00:00:00 2001 From: Jimmy Debe <91767824+jimstir@users.noreply.github.com> Date: Thu, 21 Mar 2024 10:08:40 -0400 Subject: [PATCH] Broken Links + Change Editors (#26) Fix to broken links, changed links, and added new editors to spec, 10, 12, 14, 17, 19. --- status/55/1to1-chat.md | 10 +-- status/61/community-history-service.md | 4 +- vac/25/libp2p-dns-discovery.md | 4 +- vac/32/rln-v1.md | 2 +- vac/70/eth-secpm.md | 2 +- waku/informational/23/topics.md | 4 +- waku/informational/27/peers.md | 4 +- waku/standards/application/18/swap.md | 4 +- waku/standards/application/20/toy-eth-pm.md | 16 ++--- .../application/21/fault-tolerant-store.md | 14 ++--- waku/standards/application/26/payload.md | 16 ++--- waku/standards/application/53/x3dh.md | 6 +- .../standards/application/54/x3dh-sessions.md | 6 +- waku/standards/core/10/waku2.md | 31 +++++----- waku/standards/core/13/store.md | 4 +- waku/standards/core/14/message.md | 11 ++-- waku/standards/core/16/rpc.md | 2 +- waku/standards/core/17/rln-relay.md | 62 ++++++++++--------- waku/standards/core/19/lightpush.md | 9 +-- waku/standards/core/33/discv5.md | 4 +- waku/standards/core/36/bindings-api.md | 22 +++---- waku/standards/legacy/6/waku1.md | 10 +-- waku/standards/legacy/7/data.md | 2 +- waku/standards/legacy/8/mail.md | 2 +- waku/standards/legacy/9/rpc.md | 2 +- 25 files changed, 130 insertions(+), 123 deletions(-) diff --git a/status/55/1to1-chat.md b/status/55/1to1-chat.md index a71423cbe..521c2b39c 100644 --- a/status/55/1to1-chat.md +++ b/status/55/1to1-chat.md @@ -40,7 +40,7 @@ This document describes how 2 peers communicate with each other to send messages This protocol MAY use any key-exchange mechanism previously discussed - 1. [53/WAKU2-X3DH](../../waku/standards/application/53/x3dh.md) -2. [WAKU2-NOISE](https://github.com/waku-org/specs/blob/waku-RFC/standards/core/noise.md) +2. [WAKU2-NOISE](https://github.com/waku-org/specs/blob/master/standards/application/noise.md) This protocol can provide end-to-end encryption to give peers a strong degree of privacy and security. Public chat messages are publicly readable by anyone since there's no permission model for who is participating in a public chat. @@ -67,7 +67,7 @@ It is handled by the key-exchange protocol used. For example, 1. [53/WAKU2-X3DH](../../waku/standards/application/53/x3dh.md), the session management is described in [54/WAKU2-X3DH-SESSIONS](../../waku/standards/application/54/x3dh-sessions.md) -2. [WAKU2-NOISE](https://github.com/waku-org/specs/blob/waku-RFC/standards/core/noise.md), the session management is described in [WAKU2-NOISE-SESSIONS](https://github.com/waku-org/specs/blob/waku-RFC/standards/core/noise-sessions/noise-sessions.md) +2. [WAKU2-NOISE](https://github.com/waku-org/specs/blob/master/standards/application/noise.md), the session management is described in [WAKU2-NOISE-SESSIONS](https://github.com/waku-org/specs/blob/master/standards/application/noise-sessions.md) ## Negotiation of a 1:1 chat amongst multiple participants (group chat) @@ -203,7 +203,7 @@ To change the display image of the group chat, group admins MUST use an `IMAGE_C ## Security Considerations -1. Inherits the security considerations of the key-exchange mechanism used, e.g., [53/WAKU2-X3DH](../../waku/standards/application/53/x3dh.md) or [WAKU2-NOISE](https://github.com/waku-org/specs/blob/waku-RFC/standards/core/noise.md) +1. Inherits the security considerations of the key-exchange mechanism used, e.g., [53/WAKU2-X3DH](../../waku/standards/application/53/x3dh.md) or [WAKU2-NOISE](https://github.com/waku-org/specs/blob/master/standards/application/noise.md) ## Copyright @@ -212,10 +212,10 @@ Copyright and related rights waived via [CC0](https://creativecommons.org/public ## References 1. [53/WAKU2-X3DH](../../waku/standards/application/53/x3dh.md) -2. [35/WAKU2-NOISE](https://github.com/waku-org/specs/blob/waku-RFC/standards/core/noise.md) +2. [WAKU2-NOISE](https://github.com/waku-org/specs/blob/master/standards/application/noise.md) 3. [65/STATUS-ACCOUNT](../65/account-address.md) 4. [54/WAKU2-X3DH-SESSIONS](../../waku/standards/application/54/x3dh-sessions.md) -5. [37/WAKU2-NOISE-SESSIONS](https://github.com/waku-org/specs/blob/waku-RFC/standards/core/noise-sessions/noise-sessions.md) +5. [WAKU2-NOISE-SESSIONS](https://github.com/waku-org/specs/blob/master/standards/application/noise-sessions.md) 6. [56/STATUS-COMMUNITIES](../56/communities.md) 7. [chat_message.proto](https://github.com/status-im/status-go/blob/5fd9e93e9c298ed087e6716d857a3951dbfb3c1e/protocol/protobuf/chat_message.proto#L1) 8. [emoji_reaction.proto](https://github.com/status-im/status-go/blob/5fd9e93e9c298ed087e6716d857a3951dbfb3c1e/protocol/protobuf/emoji_reaction.proto) diff --git a/status/61/community-history-service.md b/status/61/community-history-service.md index 088313436..5b853ec20 100644 --- a/status/61/community-history-service.md +++ b/status/61/community-history-service.md @@ -321,7 +321,7 @@ There are two scenarios in which member nodes can receive such a magnet link mes 2. The member node requests messages for a time range of up to 30 days from store nodes (this is the case when a new community member joins a community) ### Downloading message archives -When member nodes receive a message with a `CommunityMessageHistoryArchive` ([62/STATUS-PAYLOAD](../62/payload.md)) from the aforementioned channnel, they MUST extract the `magnet_uri` and pass it to their underlying BitTorrent client so they can fetch the latest message history archive index, which is the `index` file of the torrent (see [Creating message archive torrents](#creating-message-archive-torrents)). +When member nodes receive a message with a `CommunityMessageHistoryArchive` ([62/STATUS-PAYLOADS](../62/payloads.md)) from the aforementioned channnel, they MUST extract the `magnet_uri` and pass it to their underlying BitTorrent client so they can fetch the latest message history archive index, which is the `index` file of the torrent (see [Creating message archive torrents](#creating-message-archive-torrents)). Due to the nature of distributed systems, there's no guarantee that a received message is the "last" message. This is especially true when member nodes request historical messages from store nodes. @@ -389,4 +389,4 @@ Copyright and related rights waived via [CC0](https://creativecommons.org/public * [Extensions for Peers to Send Metadata Files](https://www.bittorrent.org/beps/bep_0009.html) * [org channels spec](../56/communities.md) * [14/WAKU2-MESSAGE](../../waku/standards/core/14/message.md) -* [62/STATUS-PAYLOAD](../62/payload.md) +* [62/STATUS-PAYLOADS](../62/payloads.md) diff --git a/vac/25/libp2p-dns-discovery.md b/vac/25/libp2p-dns-discovery.md index a15e4e2d1..08b7bed62 100644 --- a/vac/25/libp2p-dns-discovery.md +++ b/vac/25/libp2p-dns-discovery.md @@ -9,7 +9,7 @@ contributors: `25/LIBP2P-DNS-DISCOVERY` specifies a scheme to implement [`libp2p`](https://libp2p.io/) peer discovery via DNS for Waku v2. The generalised purpose is to retrieve an arbitrarily long, authenticated, updateable list of [`libp2p` peers](https://docs.libp2p.io/concepts/peer-id/) to bootstrap connection to a `libp2p` network. -Since [`10/WAKU2`](https://rfc.vac.dev/spec/10/) currently specifies use of [`libp2p` peer identities](https://docs.libp2p.io/concepts/peer-id/), +Since [`10/WAKU2`](../../waku/standards/core/10/waku2.md) currently specifies use of [`libp2p` peer identities](https://docs.libp2p.io/concepts/peer-id/), this method is suitable for a new Waku v2 node to discover other Waku v2 nodes to connect to. This specification is largely based on [EIP-1459](https://eips.ethereum.org/EIPS/eip-1459), @@ -126,7 +126,7 @@ Copyright and related rights waived via # References -1. [`10/WAKU2`](https://rfc.vac.dev/spec/10/) +1. [`10/WAKU2`](../../waku/standards/core/10/waku2.md) 1. [EIP-1459: Client Protocol](https://eips.ethereum.org/EIPS/eip-1459#client-protocol) 1. [EIP-1459: Node Discovery via DNS ](https://eips.ethereum.org/EIPS/eip-1459) 1. [`libp2p`](https://libp2p.io/) diff --git a/vac/32/rln-v1.md b/vac/32/rln-v1.md index 5f811e656..050679798 100644 --- a/vac/32/rln-v1.md +++ b/vac/32/rln-v1.md @@ -52,7 +52,7 @@ Depending on the application requirements, the registration can be implemented i - centralized registrations, by using a central server - decentralized registrations, by using a smart contract -What is important is that the users' identity commitments (explained in section [User Indetity](#user-identity)) are stored in a Merkle tree, +What is important is that the users' identity commitments (explained in section [User Identity](#user-identity)) are stored in a Merkle tree, and the users can obtain a Merkle proof proving that they are part of the group. Also depending on the application requirements, diff --git a/vac/70/eth-secpm.md b/vac/70/eth-secpm.md index 423cd9f6c..d678d3fdc 100644 --- a/vac/70/eth-secpm.md +++ b/vac/70/eth-secpm.md @@ -17,7 +17,7 @@ Therefore a decentralized approach to secure communication becomes increasingly offering a robust solution to address these challenges. This specification outlines a private messaging service using the Ethereum blockchain as authentication service. -Rooted in the existing [model](https://rfc.vac.dev/spec/20/), +Rooted in the existing [model](../../waku/standards/application/20/toy-eth-pm.md), this proposal addresses the deficiencies related to forward privacy and authentication inherent in the current framework. The specification is divided into 3 sections: diff --git a/waku/informational/23/topics.md b/waku/informational/23/topics.md index 3ad2bc054..bbd0e2f79 100644 --- a/waku/informational/23/topics.md +++ b/waku/informational/23/topics.md @@ -89,7 +89,7 @@ This is used for content based filtering. See [14/WAKU2-MESSAGE spec](../../standards/core/14/message.md) for where this is specified. Note that this doesn't impact routing of messages between relaying nodes, but it does impact how request/reply protocols such as -[12/WAKU2-FILTER](../../standards/core/14/filter.md) and [13/WAKU2-STORE](../../standards/core/13/store.md) are used. +[12/WAKU2-FILTER](../../standards/core/12/filter.md) and [13/WAKU2-STORE](../../standards/core/13/store.md) are used. This is especially useful for nodes that have limited bandwidth, and only want to pull down messages that match this given content topic. @@ -163,7 +163,7 @@ Copyright and related rights waived via * [RELAY-SHARDING](https://github.com/waku-org/specs/blob/waku-RFC/standards/core/relay-sharding.md) * [Ethereum 2 P2P spec](https://github.com/ethereum/eth2.0-specs/blob/dev/specs/phase0/p2p-interface.md#topics-and-messages) * [14/WAKU2-MESSAGE](../../standards/core/14/message.md) -* [12/WAKU2-FILTER](../../standards/core/14/filter.md) +* [12/WAKU2-FILTER](../../standards/core/12/filter.md) * [13/WAKU2-STORE](../../standards/core/13/store.md) * [6/WAKU1](../../deprecated/5/waku0.md) * [15/WAKU-BRIDGE](../../standards/core/15/bridge.md) diff --git a/waku/informational/27/peers.md b/waku/informational/27/peers.md index 0eff276e0..334428b03 100644 --- a/waku/informational/27/peers.md +++ b/waku/informational/27/peers.md @@ -74,7 +74,7 @@ This requires keeping track of the [last time each peer was disconnected](#track A Waku v2 client MAY choose to implement a keep-alive mechanism to certain peers. If a client chooses to implement keep-alive on a connection, -it SHOULD do so by sending periodic [libp2p pings](https://docs.libp2p.io/concepts/protocols/#ping) as per `10/WAKU2` [client recommendations](../../standards/core/10/WAKU2.md/#recommendations-for-clients). +it SHOULD do so by sending periodic [libp2p pings](https://docs.libp2p.io/concepts/protocols/#ping) as per `10/WAKU2` [client recommendations](../../standards/core/10/waku2.md/#recommendations-for-clients). The recommended period between pings SHOULD be _at most_ 50% of the shortest idle connection timeout for the specific client and transport. For example, idle TCP connections often times out after 10 to 15 minutes. @@ -96,4 +96,4 @@ Copyright and related rights waived via - [`18/WAKU2-SWAP`](../../standards/application/18/swap.md) - [backing off period](https://github.com/libp2p/specs/blob/master/pubsub/gossipsub/gossipsub-v1.1.md#prune-backoff-and-peer-exchange) - [libp2p pings](https://docs.libp2p.io/concepts/protocols/#ping) -- [`10/WAKU2` client recommendations](https://rfc.vac.dev/spec/10/#recommendations-for-clients) +- [`10/WAKU2` client recommendations](../../standards/core/10/waku2.md/#recommendations-for-clients) diff --git a/waku/standards/application/18/swap.md b/waku/standards/application/18/swap.md index 2380ca546..6dabc45ca 100644 --- a/waku/standards/application/18/swap.md +++ b/waku/standards/application/18/swap.md @@ -141,7 +141,7 @@ In the soft phase only accounting is performed, without consequence for the peers. No disconnect or sending of cheques is performed at this tage. SWAP protocol is performed in conjunction with another request-reply protocol to account for its usage. -It SHOULD be done for [13/WAKU2-STORE](../../standards/core/13/store.md) +It SHOULD be done for [13/WAKU2-STORE](../../core/13/store.md) and it MAY be done for other request/reply protocols. A client SHOULD log accounting state per peer @@ -173,7 +173,7 @@ Copyright and related rights waived via [CC0](https://creativecommons.org/public 1. [Prisoner's Dilemma](https://en.wikipedia.org/wiki/Prisoner%27s_dilemma) 2. [Axelrod - Evolution of Cooperation (book)](https://en.wikipedia.org/wiki/The_Evolution_of_Cooperation) 3. [Book of Swarm](https://web.archive.org/web/20210126130038/https://gateway.ethswarm.org/bzz/latest.bookofswarm.eth) -4. [13/WAKU2-STORE](../../standards/core/13/store.md) +4. [13/WAKU2-STORE](../../core/13/store.md) -# Motivation +## Motivation In open and anonymous p2p messaging networks, one big problem is spam resistance. Existing solutions, such as Whisper’s proof of work are computationally expensive hence not suitable for resource-limited nodes. Other reputation-based approaches might not be desirable, due to issues around arbitrary exclusion and privacy. -We augment the [`11/WAKU2-RELAY`](/spec/11) protocol with a novel construct of [RLN](/spec/32) to enable an efficient economic spam prevention mechanism that can be run in resource-constrained environments. +We augment the [`11/WAKU2-RELAY`](../11/relay.md) protocol with a novel construct of [RLN](../../../../vac/32/rln-v1.md) to enable an efficient economic spam prevention mechanism that can be run in resource-constrained environments. -# Flow +## Flow The messaging rate is defined by the `period` which indicates how many messages can be sent in a given period. @@ -40,12 +42,12 @@ The higher-level layers adopting `17/WAKU2-RLN-RELAY` MAY choose to enforce the -## Setup and Registration -Peers subscribed to a specific `pubsubTopic` form a [RLN group](/spec/32). +### Setup and Registration +Peers subscribed to a specific `pubsubTopic` form a [RLN group](../../../../vac/32/rln-v1.md). Peers MUST be registered to the RLN group to be able to publish messages. Registration is moderated through a smart contract deployed on the Ethereum blockchain. -Each peer has an [RLN key pair](/spec/32) denoted by `sk` and `pk`. +Each peer has an [RLN key pair](../../../../vac/32/rln-v1.md) denoted by `sk` and `pk`. The secret key `sk` is secret data and MUST be persisted securely by the peer. The state of the membership contract contains the list of registered members' public identity keys i.e., `pk`s. For the registration, a peer creates a transaction that invokes the registration function of the contract via which registers its `pk` in the group. @@ -60,9 +62,9 @@ An overview of registration is illustrated in Figure 1. ![Figure 1: Registration.](./images/rln-relay.png) -## Publishing +### Publishing -To publish at a given `epoch`, the publishing peer proceeds based on the regular [`11/WAKU2-RELAY`](/spec/11) protocol. +To publish at a given `epoch`, the publishing peer proceeds based on the regular [`11/WAKU2-RELAY`](../11/relay.md) protocol. However, to protect against spamming, each `WakuMessage` (which is wrapped inside the `data` field of a PubSub message) MUST carry a [`RateLimitProof`](##RateLimitProof) with the following fields. Section [Payload](#payloads) covers the details about the type and encoding of these fields. @@ -74,7 +76,7 @@ The `nullifier` is an internal nullifier acting as a fingerprint that allows spe The `nullifier` is a deterministic value derived from `sk` and `epoch` therefore any two messages issued by the same peer (i.e., using the same `sk`) for the same `epoch` are guaranteed to have identical `nullifier`s. The `share_x` and `share_y` can be seen as partial disclosure of peer's `sk` for the intended `epoch`. -They are derived deterministically from peer's `sk` and current `epoch` using [Shamir secret sharing scheme](/spec/32). +They are derived deterministically from peer's `sk` and current `epoch` using [Shamir secret sharing scheme](../../../../vac/32/rln-v1.md). If a peer discloses more than one such pair (`share_x`, `share_y`) for the same `epoch`, it would allow full disclosure of its `sk` and hence get access to its staked fund in the membership contract. @@ -82,13 +84,13 @@ The `proof` field is a zero-knowledge proof signifying that: 1. The message owner is the current member of the group i.e., her/his identity commitment key `pk` is part of the membership group Merkle tree with the root `merkle_root`. 2. `share_x` and `share_y` are correctly computed. 3. The `nullifier` is constructed correctly. -For more details about the proof generation check [RLN](/spec/32) +For more details about the proof generation check [RLN](../../../../vac/32/rln-v1.md) The proof generation relies on the knowledge of two pieces of private information i.e., `sk` and `authPath`. The `authPath` is a subset of Merkle tree nodes by which a peer can prove the inclusion of its `pk` in the group. The proof generation also requires a set of public inputs which are: the Merkle tree root `merkle_root`, the current `epoch`, and the message for which the proof is going to be generated. In `17/WAKU2-RLN-RELAY`, the message is the concatenation of `WakuMessage`'s `payload` filed and its `contentTopic` i.e., `payload||contentTopic`. -## Group Synchronization +### Group Synchronization Proof generation relies on the knowledge of Merkle tree root `merkle_root` and `authPath` which both require access to the membership Merkle tree. Getting access to the Merkle tree can be done in various ways. @@ -104,17 +106,17 @@ where the delay is due to mining the slashing transaction. For the group synchronization, one important security consideration is that peers MUST make sure they always use the most recent Merkle tree root in their proof generation. The reason is that using an old root can allow inference about the index of the user's `pk` in the membership tree hence compromising user privacy and breaking message unlinkability. -## Routing +### Routing -Upon the receipt of a PubSub message via [`11/WAKU2-RELAY`](/spec/11) protocol, the routing peer parses the `data` field as a `WakuMessage` and gets access to the `RateLimitProof` field. +Upon the receipt of a PubSub message via [`11/WAKU2-RELAY`](../11/relay.md) protocol, the routing peer parses the `data` field as a `WakuMessage` and gets access to the `RateLimitProof` field. The peer then validates the `RateLimitProof` as explained next. -### Epoch Validation +#### Epoch Validation If the `epoch` attached to the message is more than `max_epoch_gap` apart from the routing peer's current `epoch` then the message is discarded and considered invalid. This is to prevent a newly registered peer from spamming the system by messaging for all the past epochs. `max_epoch_gap` is a system parameter for which we provide some recommendations in section [Recommended System Parameters](#recommended-system-parameters). -### Merkle Root Validation +#### Merkle Root Validation The routing peers MUST check whether the provided Merkle root in the `RateLimitProof` is valid. It can do so by maintaining a local set of valid Merkle roots, which consist of `acceptable_root_window_size` past roots. These roots refer to the final state of the Merkle tree after a whole block consisting of group changes is processed. @@ -128,12 +130,12 @@ This also allows peers which are not well connected to the network to be able to This network delay is related to the nature of asynchronous network conditions, which means that peers see membership changes asynchronously, and therefore may have differing local Merkle trees. See [Recommended System Parameters](#recommended-system-parameters) on choosing an appropriate `acceptable_root_window_size`. -### Proof Verification +#### Proof Verification The routing peers MUST check whether the zero-knowledge proof `proof` is valid. -It does so by running the zk verification algorithm as explained in [RLN](/spec/32). +It does so by running the zk verification algorithm as explained in [RLN](../../../../vac/32/rln-v1.md). If `proof` is invalid then the message is discarded. -### Spam detection +#### Spam detection To enable local spam detection and slashing, routing peers MUST record the `nullifier`, `share_x`, and `share_y` of incoming messages which are not discarded i.e., not found spam or with invalid proof or epoch. To spot spam messages, the peer checks whether a message with an identical `nullifier` has already been relayed. 1. If such a message exists and its `share_x` and `share_y` components are different from the incoming message, then slashing takes place. @@ -151,10 +153,10 @@ An overview of the routing procedure and slashing is provided in Figure 2. ------- -# Payloads +## Payloads Payloads are protobuf messages implemented using [protocol buffers v3](https://developers.google.com/protocol-buffers/). -Nodes MAY extend the [14/WAKU2-MESSAGE](/spec/14) with a `rate_limit_proof` field to indicate that their message is not spam. +Nodes MAY extend the [14/WAKU2-MESSAGE](../14/message.md) with a `rate_limit_proof` field to indicate that their message is not spam. ```diff @@ -179,22 +181,22 @@ message WakuMessage { } ``` -## WakuMessage +### WakuMessage `rate_limit_proof` holds the information required to prove that the message owner has not exceeded the message rate limit. -## RateLimitProof +### RateLimitProof Below is the description of the fields of `RateLimitProof` and their types. | Parameter | Type | Description | | ----: | ----------- | ----------- | | `proof` | array of 256 bytes | the zkSNARK proof as explained in the [Publishing process](##Publishing) | | `merkle_root` | array of 32 bytes in little-endian order | the root of membership group Merkle tree at the time of publishing the message | -| `share_x` and `share_y`| array of 32 bytes each | Shamir secret shares of the user's secret identity key `sk` . `share_x` is the Poseidon hash of the `WakuMessage`'s `payload` concatenated with its `contentTopic` . `share_y` is calculated using [Shamir secret sharing scheme](/spec/32) | -| `nullifier` | array of 32 bytes | internal nullifier derived from `epoch` and peer's `sk` as explained in [RLN construct](/spec/32)| +| `share_x` and `share_y`| array of 32 bytes each | Shamir secret shares of the user's secret identity key `sk` . `share_x` is the Poseidon hash of the `WakuMessage`'s `payload` concatenated with its `contentTopic` . `share_y` is calculated using [Shamir secret sharing scheme](../../../../vac/32/rln-v1.md) | +| `nullifier` | array of 32 bytes | internal nullifier derived from `epoch` and peer's `sk` as explained in [RLN construct](../../../../vac/32/rln-v1.md)| -# Recommended System Parameters +## Recommended System Parameters The system parameters are summarized in the following table, and the recommended values for a subset of them are presented next. | Parameter | Description | @@ -205,14 +207,14 @@ The system parameters are summarized in the following table, and the recommended | `max_epoch_gap` | the maximum allowed gap between the `epoch` of a routing peer and the incoming message | | `acceptable_root_window_size` | The maximum number of past Merkle roots to store | -## Epoch Length +### Epoch Length A sensible value for the `period` depends on the application for which the spam protection is going to be used. For example, while the `period` of `1` second i.e., messaging rate of `1` per second, might be acceptable for a chat application, might be too low for communication among Ethereum network validators. One should look at the desired throughput of the application to decide on a proper `period` value. In the proof of concept implementation of `17/WAKU2-RLN-RELAY` protocol which is available in [nim-waku](https://github.com/status-im/nim-waku), the `period` is set to `1` second. Nevertheless, this value is also subject to change depending on user experience. -## Maximum Epoch Gap +### Maximum Epoch Gap We discussed in the [Routing](#routing) section that the gap between the epoch observed by the routing peer and the one attached to the incoming message should not exceed a threshold denoted by `max_epoch_gap` . The value of `max_epoch_gap` can be measured based on the following factors. - Network transmission delay `Network_Delay`: the maximum time that it takes for a message to be fully disseminated in the GossipSub network. @@ -235,11 +237,11 @@ The `acceptable_root_window_size` should indicate how many blocks may have been This formula represents a lower bound of the number of acceptable roots. -# Copyright +## Copyright Copyright and related rights waived via [CC0](https://creativecommons.org/publicdomain/zero/1.0/). -# References +## References 1. [RLN documentation](https://hackmd.io/tMTLMYmTR5eynw2lwK9n1w?view) 2. [Public inputs to the RLN circuit](https://hackmd.io/tMTLMYmTR5eynw2lwK9n1w?view#Public-Inputs) diff --git a/waku/standards/core/19/lightpush.md b/waku/standards/core/19/lightpush.md index 199a889b5..d5adbcabd 100644 --- a/waku/standards/core/19/lightpush.md +++ b/waku/standards/core/19/lightpush.md @@ -3,9 +3,10 @@ slug: 19 title: 19/WAKU2-LIGHTPUSH name: Waku v2 Light Push status: draft -editor: Oskar Thorén +editor: Hanno Cornelius contributors: - Daniel Kaiser + - Oskar Thorén --- **Protocol identifier**: `/vac/waku/lightpush/2.0.0-beta1` @@ -45,13 +46,13 @@ message PushRPC { Nodes that respond to `PushRequests` MUST either relay the encapsulated message via [11/WAKU2-RELAY](../11/relay.md) protocol on the specified `pubsub_topic`, -or forward the `PushRequest` via 19/LIGHTPUSH on a [44/WAKU2-DANDELION](https://github.com/waku-org/specs/blob/waku-RFC/standards/application/dandelion.md) stem. +or forward the `PushRequest` via 19/LIGHTPUSH on a [WAKU2-DANDELION](https://github.com/waku-org/specs/blob/waku-RFC/standards/application/dandelion.md) stem. If they are unable to do so for some reason, they SHOULD return an error code in `PushResponse`. ## Security Considerations Since this can introduce an amplification factor, it is RECOMMENDED for the node relaying to the rest of the network to take extra precautions. -This can be done by rate limiting via [17/WAKU2-RLN-RELAY](https://rfc.vac.dev/spec/17/). +This can be done by rate limiting via [17/WAKU2-RLN-RELAY](../17/rln-relay.md). Note that the above is currently not fully implemented. @@ -62,5 +63,5 @@ Copyright and related rights waived via [CC0](https://creativecommons.org/public ## References * [11/WAKU2-RELAY](../11/relay.md) -* [44/WAKU2-DANDELION](https://github.com/waku-org/specs/blob/waku-RFC/standards/application/dandelion.md) +* [WAKU2-DANDELION](https://github.com/waku-org/specs/blob/waku-RFC/standards/application/dandelion.md) * [17/WAKU2-RLN-RELAY](../17/rln-relay.md) diff --git a/waku/standards/core/33/discv5.md b/waku/standards/core/33/discv5.md index 4e16d426f..51c9eaa57 100644 --- a/waku/standards/core/33/discv5.md +++ b/waku/standards/core/33/discv5.md @@ -52,7 +52,7 @@ This also increases decentralization. `33/WAKU2-DISCV5` spans a discovery network isolated from the Ethereum Discovery v5 network. -Another simple solution would be taking part in the Ethereum Discovery network, and filtering Waku nodes based on whether they support [31/WAKU2-ENR](https://github.com/waku-org/specs/blob/waku-RFC/standards/core/enr.md). +Another simple solution would be taking part in the Ethereum Discovery network, and filtering Waku nodes based on whether they support [WAKU2-ENR](https://github.com/waku-org/specs/blob/waku-RFC/standards/core/enr.md). This solution is more resilient towards eclipse attacks. However, this discovery method is very inefficient for small percentages of Waku nodes (see [estimation](https://forum.vac.dev/t/waku-v2-discv5-roadmap-discussion/121/8)). It boils down to random walk discovery and does not offer a O(log(n)) hop bound. @@ -157,7 +157,7 @@ Properly protecting against eclipse attacks is challenging and raises research q 1. [10/WAKU2](../10/waku2.md) 1. [11/WAKU2-RELAY](../11/relay.md) -1. [`31/WAKU2-ENR`](https://github.com/waku-org/specs/blob/waku-RFC/standards/core/enr.md) +1. [`WAKU2-ENR`](https://github.com/waku-org/specs/blob/waku-RFC/standards/core/enr.md) 1. [Node Discovery Protocol v5 (`discv5`)](https://github.com/ethereum/devp2p/blob/master/discv5/discv5.md) 1. [`discv5` semantics](https://github.com/ethereum/devp2p/blob/master/discv5/discv5-theory.md). 1. [`discv5` wire protocol](https://github.com/ethereum/devp2p/blob/master/discv5/discv5-wire.md) diff --git a/waku/standards/core/36/bindings-api.md b/waku/standards/core/36/bindings-api.md index cc763fd0e..edaff58f1 100644 --- a/waku/standards/core/36/bindings-api.md +++ b/waku/standards/core/36/bindings-api.md @@ -697,7 +697,7 @@ This list has this format: ### `extern int waku_content_topic(char* applicationName, unsigned int applicationVersion, char* contentTopicName, char* encoding, WakuCallBack onOkCb)` -Create a content topic string according to [RFC 23](https://rfc.vac.dev/spec/23/). +Create a content topic string according to [RFC 23](../../../informational/23/topics.md). **Parameters** @@ -710,14 +710,14 @@ Create a content topic string according to [RFC 23](https://rfc.vac.dev/spec/23/ **Returns** `int` with a status code. Possible values: - - 0 - The operation was completed successfuly. `onOkCb` will receive the content topic formatted according to [RFC 23](https://rfc.vac.dev/spec/23/): `/{application-name}/{version-of-the-application}/{content-topic-name}/{encoding}` + - 0 - The operation was completed successfuly. `onOkCb` will receive the content topic formatted according to [RFC 23](../../../informational/23/topics.md): `/{application-name}/{version-of-the-application}/{content-topic-name}/{encoding}` - 1 - The operation failed for any reason. - 2 - The function is missing the `onOkCb` callback ### `extern int waku_pubsub_topic(char* name, char* encoding, WakuCallBack onOkCb)` -Create a pubsub topic string according to [RFC 23](https://rfc.vac.dev/spec/23/). +Create a pubsub topic string according to [RFC 23](../../../informational/23/topics.md). **Parameters** @@ -728,13 +728,13 @@ Create a pubsub topic string according to [RFC 23](https://rfc.vac.dev/spec/23/) **Returns** `int` with a status code. Possible values: - - 0 - The operation was completed successfuly. `onOkCb` will get populated with a pubsub topic formatted according to [RFC 23](https://rfc.vac.dev/spec/23/): `/waku/2/{topic-name}/{encoding}` + - 0 - The operation was completed successfuly. `onOkCb` will get populated with a pubsub topic formatted according to [RFC 23](../../../informational/23/topics.md): `/waku/2/{topic-name}/{encoding}` - 1 - The operation failed for any reason. - 2 - The function is missing the `onOkCb` callback ### `extern int waku_default_pubsub_topic(WakuCallBack onOkCb)` -Returns the default pubsub topic used for exchanging waku messages defined in [RFC 10](https://rfc.vac.dev/spec/10/). +Returns the default pubsub topic used for exchanging waku messages defined in [RFC 10](../10/waku2.md). **Parameters** 1. `WakuCallBack onOkCb`: callback to be executed if the function is succesful @@ -752,7 +752,7 @@ Publish a message using Waku Relay. **Parameters** -1. `char* messageJson`: JSON string containing the [Waku Message](https://rfc.vac.dev/spec/14/) as [`JsonMessage`](#jsonmessage-type). +1. `char* messageJson`: JSON string containing the [Waku Message](../14/message.md) as [`JsonMessage`](#jsonmessage-type). 2. `char* pubsubTopic`: pubsub topic on which to publish the message. If `NULL`, it uses the default pubsub topic. 3. `int timeoutMs`: Timeout value in milliseconds to execute the call. @@ -1089,7 +1089,7 @@ Publish a message using Waku Lightpush. **Parameters** -1. `char* messageJson`: JSON string containing the [Waku Message](https://rfc.vac.dev/spec/14/) as [`JsonMessage`](#jsonmessage-type). +1. `char* messageJson`: JSON string containing the [Waku Message](../14/message.md) as [`JsonMessage`](#jsonmessage-type). 2. `char* pubsubTopic`: pubsub topic on which to publish the message. If `NULL`, it uses the default pubsub topic. 3. `char* peerID`: Peer ID supporting the lightpush protocol. @@ -1177,7 +1177,7 @@ Encrypt a message using symmetric encryption and optionally sign the message **Parameters** -1. `char* messageJson`: JSON string containing the [Waku Message](https://rfc.vac.dev/spec/14/) as [`JsonMessage`](#jsonmessage-type). +1. `char* messageJson`: JSON string containing the [Waku Message](../14/message.md) as [`JsonMessage`](#jsonmessage-type). 2. `char* symmetricKey`: hex encoded secret key to be used for encryption. 3. `char* optionalSigningKey`: hex encoded private key to be used to sign the message. 4. `WakuCallBack onOkCb`: callback to be executed if the function is succesful @@ -1198,7 +1198,7 @@ Encrypt a message using asymmetric encryption and optionally sign the message **Parameters** -1. `char* messageJson`: JSON string containing the [Waku Message](https://rfc.vac.dev/spec/14/) as [`JsonMessage`](#jsonmessage-type). +1. `char* messageJson`: JSON string containing the [Waku Message](../14/message.md) as [`JsonMessage`](#jsonmessage-type). 2. `char* publicKey`: hex encoded public key to be used for encryption. 3. `char* optionalSigningKey`: hex encoded private key to be used to sign the message. 4. `WakuCallBack onOkCb`: callback to be executed if the function is succesful @@ -1221,7 +1221,7 @@ Decrypt a message using a symmetric key **Parameters** -1. `char* messageJson`: JSON string containing the [Waku Message](https://rfc.vac.dev/spec/14/) as [`JsonMessage`](#jsonmessage-type). +1. `char* messageJson`: JSON string containing the [Waku Message](../14/message.md) as [`JsonMessage`](#jsonmessage-type). 2. `char* symmetricKey`: 32 byte symmetric key hex encoded. 3. `WakuCallBack onOkCb`: callback to be executed if the function is succesful 4. `WakuCallBack onErrCb`: callback to be executed if the function fails @@ -1249,7 +1249,7 @@ Decrypt a message using a secp256k1 private key **Parameters** -1. `char* messageJson`: JSON string containing the [Waku Message](https://rfc.vac.dev/spec/14/) as [`JsonMessage`](#jsonmessage-type). +1. `char* messageJson`: JSON string containing the [Waku Message](../14/message.md) as [`JsonMessage`](#jsonmessage-type). 2. `char* privateKey`: secp256k1 private key hex encoded. 3. `WakuCallBack onOkCb`: callback to be executed if the function is succesful 4. `WakuCallBack onErrCb`: callback to be executed if the function fails diff --git a/waku/standards/legacy/6/waku1.md b/waku/standards/legacy/6/waku1.md index 57cd828ca..b29f2ed32 100644 --- a/waku/standards/legacy/6/waku1.md +++ b/waku/standards/legacy/6/waku1.md @@ -36,7 +36,7 @@ This protocol needs to advertise the `waku/1` [capability](https://ethereum.gitb ### Gossip based routing -In Whisper, envelopes are gossiped between peers. Whisper is a form of rumor-mongering protocol that works by flooding to its connected peers based on some factors. Envelopes are eligible for retransmission until their TTL expires. A node SHOULD relay envelopes to all connected nodes if an envelope matches their PoW and bloom filter settings. If a node works in light mode, it MAY choose not to forward envelopes. A node MUST NOT send expired envelopes, unless the envelopes are sent as a [8/WAKU-MAIL](../../application/8/mail.md) response. A node SHOULD NOT send an envelope to a peer that it has already sent before. +In Whisper, envelopes are gossiped between peers. Whisper is a form of rumor-mongering protocol that works by flooding to its connected peers based on some factors. Envelopes are eligible for retransmission until their TTL expires. A node SHOULD relay envelopes to all connected nodes if an envelope matches their PoW and bloom filter settings. If a node works in light mode, it MAY choose not to forward envelopes. A node MUST NOT send expired envelopes, unless the envelopes are sent as a [8/WAKU-MAIL](../8/mail.md) response. A node SHOULD NOT send an envelope to a peer that it has already sent before. ### Maximum Packet Size @@ -343,7 +343,7 @@ The drawback of sending message confirmations is that it increases the noise in #### P2P Request -This packet is used for sending Dapp-level peer-to-peer requests, e.g. Waku Mail Client requesting historic (expired) envelopes from the [Waku Mail Server](../../application/8/mail.md). +This packet is used for sending Dapp-level peer-to-peer requests, e.g. Waku Mail Client requesting historic (expired) envelopes from the [Waku Mail Server](../8/mail.md). #### P2P Message @@ -353,7 +353,7 @@ This packet is used for sending the peer-to-peer envelopes, which are not suppos This packet is used to indicate that all envelopes, requested earlier with a P2P Request packet (`0x7E`), have been sent via one or more P2P Message packets (`0x7F`). -The content of the packet is explained in the [Waku Mail Server](../../application/8/mail.md) specification. +The content of the packet is explained in the [Waku Mail Server](../8/mail.md) specification. ### Payload Encryption @@ -373,7 +373,7 @@ Packet codes `0x7E` and `0x7F` may be used to implement Waku Mail Server and Cli Waku supports multiple capabilities. These include light node, rate limiting and bridging of traffic. Here we list these capabilities, how they are identified, what properties they have and what invariants they must maintain. -Additionally there is the capability of a mailserver which is documented in its on [specification](../../application/8/mail.md). +Additionally there is the capability of a mailserver which is documented in its on [specification](../8/mail.md). ### Light node @@ -452,7 +452,7 @@ It is desirable to have a strategy for maintaining forward compatibility between ## Appendix A: Security considerations -There are several security considerations to take into account when running Waku. Chief among them are: scalability, DDoS-resistance and privacy. These also vary depending on what capabilities are used. The security considerations for extra capabilities such as [mailservers](../../application/8/mail.md#security-considerations) can be found in their respective specifications. +There are several security considerations to take into account when running Waku. Chief among them are: scalability, DDoS-resistance and privacy. These also vary depending on what capabilities are used. The security considerations for extra capabilities such as [mailservers](../8/mail.md#security-considerations) can be found in their respective specifications. ### Scalability and UX diff --git a/waku/standards/legacy/7/data.md b/waku/standards/legacy/7/data.md index b924e7ae1..d2e9f758f 100644 --- a/waku/standards/legacy/7/data.md +++ b/waku/standards/legacy/7/data.md @@ -9,7 +9,7 @@ contributors: - Kim De Mey --- -This specification describes the encryption, decryption and signing of the content in the [data field used in Waku](../../standards/core/6/waku1.md/#abnf-specification). +This specification describes the encryption, decryption and signing of the content in the [data field used in Waku](../6/waku1.md/#abnf-specification). ## Specification diff --git a/waku/standards/legacy/8/mail.md b/waku/standards/legacy/8/mail.md index f59a1b7f5..53a334935 100644 --- a/waku/standards/legacy/8/mail.md +++ b/waku/standards/legacy/8/mail.md @@ -100,7 +100,7 @@ A mailserver client fetches archival envelopes from a mailserver through a direc In this direct connection, the client discloses its IP/ID as well as the topics/ bloom filter it is interested in to the mailserver. The collection of such information allows the mailserver to link clients' IP/IDs to their topic interests and build a profile for each client over time. As such, the mailserver client has to trust the mailserver with this level of information. -A similar concern exists for the light nodes and their direct peers which is discussed in the security considerations of [6/WAKU1](/spec/7). +A similar concern exists for the light nodes and their direct peers which is discussed in the security considerations of [6/WAKU1](../6/waku1.md). **Mailserver trusted connection:** diff --git a/waku/standards/legacy/9/rpc.md b/waku/standards/legacy/9/rpc.md index 69930136a..ee72467e0 100644 --- a/waku/standards/legacy/9/rpc.md +++ b/waku/standards/legacy/9/rpc.md @@ -46,7 +46,7 @@ In this section you will find objects used throughout the JSON RPC API. #### Message -The message object represents a Waku message. Below you will find the description of the attributes contained in the message object. A message is the decrypted payload and padding of an [envelope](/spec/7) along with all of its metadata and other extra information such as the hash. +The message object represents a Waku message. Below you will find the description of the attributes contained in the message object. A message is the decrypted payload and padding of an [envelope](../7/data.md) along with all of its metadata and other extra information such as the hash. | Field | Type | Description | | ----: | :--: | ----------- |