Waku node and protocol.
Go to file
Gabriel mermelstein 467d030b8f
re-inserting chronicles
2024-04-12 09:54:06 +03:00
.github chore: switch wakuv2 to waku fleet (#2519) 2024-03-20 16:28:00 +01:00
.sv4git/templates feat: add release-notes target (#1734) 2023-05-18 14:45:45 +02:00
apps fixing networkmonitor compilation error 2024-04-08 09:47:10 +03:00
ci chore(ci): use git describe for image version 2024-02-29 10:40:14 +01:00
docker/binaries Add utils to Dockerfile (#1991) 2023-09-05 15:50:54 +02:00
docs chore: switch wakuv2 to waku fleet (#2519) 2024-03-20 16:28:00 +01:00
examples fixing compilation errors in examples 2024-04-08 09:29:54 +03:00
library fix(c-bindings): rln credential path key (#2564) 2024-04-04 02:41:14 -04:00
metrics chore: switch wakuv2 to waku fleet (#2519) 2024-03-20 16:28:00 +01:00
migrations
scripts chore(rln-relay): use anvil instead of ganache in onchain tests (#2449) 2024-02-22 16:59:13 +05:30
tests fix: fix regresion + remove deprecated flag (#2556) 2024-03-26 19:44:55 +01:00
tools Generic re-style with nph 0.5.1 (#2396) 2024-03-16 00:08:47 +01:00
vendor updating nim-chronicles 2024-04-09 10:35:58 +03:00
waku re-inserting chronicles 2024-04-12 09:54:06 +03:00
.dockerignore
.editorconfig chore: add editorconfig file 2022-11-21 09:31:03 +01:00
.gitignore
.gitmodules
.sv4git.yml
CHANGELOG.md
Dockerfile
LICENSE-APACHEv2
LICENSE-MIT Fix name in licence (#517) 2021-04-28 20:00:45 +10:00
Makefile
README.md
config.nims
env.sh
shell.nix
waku.nimble

README.md

Nwaku

Introduction

The nwaku repository implements Waku, and provides tools related to it.

  • A Nim implementation of the Waku (v2) protocol.
  • CLI application wakunode2 that allows you to run a Waku node.
  • Examples of Waku usage.
  • Various tests of above.

For more details see the source code

How to Build & Run

These instructions are generic. For more detailed instructions, see the Waku source code above.

Prerequisites

The standard developer tools, including a C compiler, GNU Make, Bash, and Git. More information on these installations can be found here.

Wakunode

# The first `make` invocation will update all Git submodules.
# You'll run `make update` after each `git pull` in the future to keep those submodules updated.
make wakunode2

# Build with custom compilation flags. Do not use NIM_PARAMS unless you know what you are doing.
# Replace with your own flags
make wakunode2 NIMFLAGS="-d:chronicles_colors:none -d:disableMarchNative"

# Run with DNS bootstrapping
./build/wakunode2 --dns-discovery --dns-discovery-url=DNS_BOOTSTRAP_NODE_URL

# See available command line options
./build/wakunode2 --help

To join the network, you need to know the address of at least one bootstrap node. Please refer to the Waku README for more information.

For more on how to run wakunode2, refer to:

Issues

WSL

If you encounter difficulties building the project on WSL, consider placing the project within WSL's filesystem, avoiding the /mnt/ directory.

Developing

Nim Runtime

This repository is bundled with a Nim runtime that includes the necessary dependencies for the project.

Before you can utilise the runtime you'll need to build the project, as detailed in a previous section. This will generate a vendor directory containing various dependencies, including the nimbus-build-system which has the bundled nim runtime.

After successfully building the project, you may bring the bundled runtime into scope by running:

source env.sh

If everything went well, you should see your prompt suffixed with [Nimbus env]$. Now you can run nim commands as usual.

Waku Protocol Test Suite

# Run all the Waku tests
make test

Examples

Examples can be found in the examples folder. This includes a fully featured chat example.

Tools

Different tools and their corresponding how-to guides can be found in the tools folder.

Bugs, Questions & Features

For an inquiry, or if you would like to propose new features, feel free to open a general issue.

For bug reports, please tag your issue with the bug label.

If you believe the reported issue requires critical attention, please use the critical label to assist with triaging.

To get help, or participate in the conversation, join the Waku Discord server.

Docs