diff --git a/CHANGELOG.md b/CHANGELOG.md index 91163c9ff..f99a2c3d1 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -13,6 +13,7 @@ ### Fixes ### Docs +Added [tutorial]( ) on communicating with waku2 test fleets via the chat2 `toy-chat` application in spam-protected mode using [`17/WAKU-RLN-RELAY`](https://rfc.vac.dev/spec/17/). ## 2021-03-03 v0.8 diff --git a/docs/tutorial/rln-chat2-live-testnet.md b/docs/tutorial/rln-chat2-live-testnet.md new file mode 100644 index 000000000..ee131a40c --- /dev/null +++ b/docs/tutorial/rln-chat2-live-testnet.md @@ -0,0 +1,125 @@ +# Communicating with waku2 test fleets using chat2 application in spam-protected mode + +This document is a tutorial on how to run chat2 in spam-protected/rate-limited mode using the waku-RLN-Relay protocol on a designated content topic `/toy-chat/2/luzhou/proto`. +You will connect your chat2 client to waku2 test fleets. +Note that test fleets will not filter spam messages, they merely route messages. +Spam detection takes place at the chat2 users end. +In this setting, you should try to spam the network by violating the message rate limit i.e., +sending more than one message per epoch. +At the time of this tutorial, the epoch duration is set to `10` seconds. +You can inspect the current epoch value by checking the following [constant variable](https://github.com/status-im/nim-waku/blob/21cac6d491a6d995a7a8ba84c85fecc7817b3d8b/waku/v2/protocol/waku_rln_relay/waku_rln_relay_types.nim#L119) in the nim-waku codebase. +Your messages will be routed via test fleets and will arrive at other live chat2 clients that are running in rate-limited mode over the same content topic i.e., `/toy-chat/2/luzhou/proto`. +Your samp activity will be detected by them and a proper message will be shown on their console. + +# Set up +## Build chat2 +First, build chat2 with the RLN flag set to true. + +``` +make chat2 RLN=true +``` + +## Setup a chat2 node in rate-limited mode +Run the following command to set up your chat2 client. + +``` +./build/chat2 --content-topic:/toy-chat/2/luzhou/proto --ports-shift=1 --fleet:test --rln-relay:true --rln-relay-membership-index:your_index + +``` +In this command +- the `rln-relay` flag is set to true to enable RLN-Relay protocol for spam protection. +- the `rln-relay-membership-index` is used to pick one RLN key out of the 100 available hardcoded RLN keys. +You can pass your index using this command `--rln-relay-membership-index: your_index` e.g., `--rln-relay-membership-index:19` . +Please use the index assigned to you in the dogfooding coordination phase. +If you pick an index at random you may end up using the same key-pair as someone else, hence your messaging rate will be shared with that person(s). + + +Next, choose your nickname: +``` +Choose a nickname >> your_nick_name +``` +Wait for the chat prompt `>>` to appear. +Now your chat2 client is ready. + +You may set up more than one chat client, +just make sure that you increment the `--ports-shift` value for each new client you set up e.g., `--ports-shift=2`. + +# Run the test +Now that you have set up your client, start chatting. +Once you type a chat line and hit enter, you will see a message that indicates the epoch at which the message is sent e.g., +``` +>> Hi! +--rln epoch: 164495684 + Bob: Hi! +``` +The numerical value `164495684` indicates the epoch of the message `Hi!`. +You will see a different value than `164495684` on your screen. +If two messages sent by the same chat2 client happen to have the same RLN epoch value, then one of them will be detected as spam by the receiving chat2 clients. +At the time of this tutorial, the epoch duration is set to `10` seconds. +Thus, if you send two messages less than `10` seconds apart, they are likely to get the same `rln epoch` values. + +After sending a chat message, you may experience some delay before the next chat prompt appears. +The reason is that under the hood a zero-knowledge proof is being generated and attached to your message. + +Once you are done with the test, make sure you close all the chat2 clients by typing `/exit` command. +``` +>> /exit +quitting... +``` + +# Sample test output + +In the following sample test, two chat2 clients are set up, namely `Alice` and `Bob`. +`Bob` sends three messages i.e., `message1`, `message2`, and `message3` to the test fleets. +Test fleets will route the messages to their connections including `Alice`. +The two messages `message2` and `message3` have an identical RLN epoch value of `164504930`, so, one of them will be detected as a spam message by `Alice`. +You can check this fact by looking at the `Alice` console, where `A spam message is found and discarded : Bob: message3` is presented. + + +Bob +``` +./build/chat2 --content-topic:/toy-chat/2/luzhou/proto --ports-shift=2 --fleet:test --rln-relay:true --rln-relay-membership-index:2 +Choose a nickname >> Bob +Welcome, Bob! +Connecting to test fleet using DNS discovery... +Discovered and connecting to @[16Uiu2HAmPLe7Mzm8TsYUubgCAW1aJoeFScxrLj8ppHFivPo97bUZ, 16Uiu2HAkvWiyFsgRhuJEb9JfjYxEkoHLgnUQmr1N5mKWnYjxYRVm, 16Uiu2HAmJb2e28qLXxT5kZxVUUoJt72EMzNGXB47Rxx5hw3q4YjS] +Listening on + /ip4/75.157.120.249/tcp/60002/p2p/16Uiu2HAmKdCdP89q6CwLc6PeFDJnVR1EmM7fTgtphHiacSNBnuAz +Store enabled, but no store nodes configured. Choosing one at random from discovered peers +Connecting to storenode: 16Uiu2HAmPLe7Mzm8TsYUubgCAW1aJoeFScxrLj8ppHFivPo97bUZ +>> message1 +--rln epoch: 164504929 + Bob: message1 +>> message2 +--rln epoch: 164504930 + Bob: message2 +>> message3 +--rln epoch: 164504930 + Bob: message3 +>> message4 +--rln epoch: 164504973 + Bob: message4 +>> /exit +quitting... +``` + + +Alice +``` +./build/chat2 --content-topic:/toy-chat/2/luzhou/proto --ports-shift=1 --fleet:test --rln-relay:true --rln-relay-membership-index:1 + +Choose a nickname >> Alice +Welcome, Alice! +Connecting to test fleet using DNS discovery... +Discovered and connecting to @[16Uiu2HAmPLe7Mzm8TsYUubgCAW1aJoeFScxrLj8ppHFivPo97bUZ, 16Uiu2HAkvWiyFsgRhuJEb9JfjYxEkoHLgnUQmr1N5mKWnYjxYRVm, 16Uiu2HAmJb2e28qLXxT5kZxVUUoJt72EMzNGXB47Rxx5hw3q4YjS] +Listening on + /ip4/75.157.120.249/tcp/60001/p2p/16Uiu2HAkyTos6LeGrj1YJyA3WYzp9qKQGCsxbtvyoBRHSu9PCrQZ +Store enabled, but no store nodes configured. Choosing one at random from discovered peers +Connecting to storenode: 16Uiu2HAmPLe7Mzm8TsYUubgCAW1aJoeFScxrLj8ppHFivPo97bUZ +>> Bob: message1 +>> Bob: message2 +>> A spam message is found and discarded : Bob: message3 + Bob: message4 +>> /exit +quitting... +``` diff --git a/examples/v2/chat2.nim b/examples/v2/chat2.nim index afc0269bc..ec77ffd2a 100644 --- a/examples/v2/chat2.nim +++ b/examples/v2/chat2.nim @@ -507,6 +507,8 @@ proc processInput(rfd: AsyncFD, rng: ref BrHmacDrbgContext) {.async.} = echo "A spam message is found and discarded : ", chatLineResult.value else: echo "A spam message is found and discarded" + chat.prompt = false + showChatPrompt(chat) # set up rln relay inputs let (groupOpt, memKeyPairOpt, memIndexOpt) = rlnRelaySetUp(conf.rlnRelayMemIndex) diff --git a/vendor/nim-libbacktrace/vendor/libbacktrace-upstream/libtool b/vendor/nim-libbacktrace/vendor/libbacktrace-upstream/libtool index 1868458f7..04184e1f9 100755 --- a/vendor/nim-libbacktrace/vendor/libbacktrace-upstream/libtool +++ b/vendor/nim-libbacktrace/vendor/libbacktrace-upstream/libtool @@ -2,7 +2,7 @@ # libtool - Provide generalized library-building support services. # Generated automatically by config.status (libbacktrace) version-unused -# Libtool was configured on host fv-az193-883: +# Libtool was configured on host fv-az447-634: # NOTE: Changes made to this file will be lost: look at ltmain.sh. # # Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005,