Waku node and protocol.
Go to file
NagyZoltanPeter 7f1ea0890a
Bump nim-chornicles, nim-libp2p, nimcrypto
Bump nim-web3, nim-eth and deps - on_chain/group_manager.nim adaption
Added status-im/nim-minilru submodule required by latest nim-eth
Added nim-quic and nim-ngtcp2 as new deps of nim-libp2p
Fixing tests.

 Changes:
	modified:   .gitmodules
	modified:   tests/waku_discv5/utils.nim
	modified:   tests/waku_enr/utils.nim
	modified:   tests/waku_rln_relay/test_rln_group_manager_onchain.nim
	modified:   tests/waku_rln_relay/utils.nim
	modified:   tests/waku_rln_relay/utils_onchain.nim

        modified:   vendor/nim-chronicles
	modified:   vendor/nim-eth
	modified:   vendor/nim-http-utils
	modified:   vendor/nim-json-rpc
	modified:   vendor/nim-json-serialization
	modified:   vendor/nim-libp2p
	modified:   vendor/nim-metrics
	new file:   vendor/nim-minilru
	modified:   vendor/nim-nat-traversal
	new file:   vendor/nim-ngtcp2
	modified:   vendor/nim-presto
	new file:   vendor/nim-quic
	modified:   vendor/nim-secp256k1
	modified:   vendor/nim-serialization
	modified:   vendor/nim-stew
	modified:   vendor/nim-taskpools
	modified:   vendor/nim-testutils
	modified:   vendor/nim-toml-serialization
	modified:   vendor/nim-unicodedb
	modified:   vendor/nim-unittest2
	modified:   vendor/nim-web3
	modified:   vendor/nim-websock
	modified:   vendor/nim-zlib
	modified:   vendor/nimcrypto
	modified:   waku.nimble

        modified:   waku/common/enr/builder.nim
	modified:   waku/common/enr/typed_record.nim
	modified:   waku/common/utils/nat.nim
	modified:   waku/discovery/waku_discv5.nim
	modified:   waku/waku_rln_relay/conversion_utils.nim
	modified:   waku/waku_rln_relay/group_manager/on_chain/group_manager.nim
	modified:   waku/waku_rln_relay/rln/wrappers.nim
	modified:   waku/waku_rln_relay/rln_relay.nim
2024-10-09 01:57:51 +02:00
.github disable colors in PR docker images (#3066) 2024-09-27 15:00:55 +02:00
.sv4git/templates feat: add release-notes target (#1734) 2023-05-18 14:45:45 +02:00
apps refactor: wrap peer store (#3051) 2024-09-27 18:16:46 +05:30
ci fix(ci): use --tags to match non-annotated tags (#2814) 2024-06-19 17:54:19 +02:00
docker/binaries chore: Switch libnegentropy library build from shared to static linkage (#3041) 2024-09-18 14:34:50 +02:00
docs chore: deprecating pubsub topic (#2997) 2024-09-10 15:07:12 -06:00
examples refactor: wrap peer store (#3051) 2024-09-27 18:16:46 +05:30
library adding missing error handling in libwaku (#3084) 2024-10-03 00:13:42 +03:00
metrics Update waku-fleet-dashboard.json 2024-09-30 21:04:32 +03:00
migrations chore: delivery monitor for store v3 reliability protocol (#2977) 2024-08-27 16:49:46 +02:00
scripts chore: lock in nph version and add pre-commit hook (#2938) 2024-08-20 15:14:35 +10:00
tests Bump nim-chornicles, nim-libp2p, nimcrypto 2024-10-09 01:57:51 +02:00
tools chore: adding lint job to the CI (#2925) 2024-07-23 13:57:24 +03:00
vendor Bump nim-chornicles, nim-libp2p, nimcrypto 2024-10-09 01:57:51 +02:00
waku Bump nim-chornicles, nim-libp2p, nimcrypto 2024-10-09 01:57:51 +02:00
.dockerignore fix(dockerfile): update dockerignore and base image (#2262) 2023-12-01 11:35:50 +01:00
.editorconfig chore: add editorconfig file 2022-11-21 09:31:03 +01:00
.gitignore chore: android support (#2554) 2024-05-21 21:00:22 -04:00
.gitmodules Bump nim-chornicles, nim-libp2p, nimcrypto 2024-10-09 01:57:51 +02:00
.sv4git.yml chore(ci): extend and rename nightly workflow to support RC builds (#1784) 2023-06-08 17:13:40 +02:00
CHANGELOG.md remove dependency bumping from changelog 2024-10-02 10:31:45 +03:00
Dockerfile chore: Switch libnegentropy library build from shared to static linkage (#3041) 2024-09-18 14:34:50 +02:00
LICENSE-APACHEv2 Fix name in licence (#517) 2021-04-28 20:00:45 +10:00
LICENSE-MIT Fix name in licence (#517) 2021-04-28 20:00:45 +10:00
Makefile fix: static linking negentropy in ARM based mac (#3046) 2024-09-20 15:43:12 +03:00
README.md chore: lock in nph version and add pre-commit hook (#2938) 2024-08-20 15:14:35 +10:00
config.nims chore: adding lint job to the CI (#2925) 2024-07-23 13:57:24 +03:00
env.sh Set up repo to make use of nimbus-build-system 2020-05-01 11:29:16 +02:00
shell.nix feat(store): simplify wakunode2 configuration options 2022-10-26 17:10:30 +02:00
waku.nimble Bump nim-chornicles, nim-libp2p, nimcrypto 2024-10-09 01:57:51 +02:00

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

Building single test files

During development it is handful to build and run a single test file. To support this make has a specific target:

targets:

  • build/<relative path to your test file.nim>
  • test/<relative path to your test file.nim>

Binary will be created as <path to your test file.nim>.bin under the build directory .

# Build and run your test file separately
make test/tests/common/test_enr_builder.nim

Formatting

Nim files are expected to be formatted using the nph version present in vendor/nph.

You can easily format file with the make nph/<relative path to nim> file command. For example:

make nph/waku/waku_core.nim

A convenient git hook is provided to automatically format file at commit time. Run the following command to install it:

make install-nph

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