Ivan Yonchovski ae844ec4c5
Restore coverage (#74)
* Restore coverage
* use nimble setup for now
* Update codecov.yml
* fix lcov
* re-add nim binary to lockfile

---------

Co-authored-by: Jaremy Creechley <creechley@gmail.com>
2023-07-17 15:32:55 -07:00
2023-07-17 15:32:55 -07:00
2023-07-12 14:57:26 -07:00
2023-07-17 12:43:14 -07:00
2023-07-11 15:19:45 -07:00
2023-07-17 12:43:14 -07:00
2023-07-11 17:44:54 -07:00
2023-07-17 15:32:55 -07:00
2023-07-12 14:58:29 -07:00
2023-07-17 12:43:14 -07:00
2023-07-17 12:43:14 -07:00
2023-07-10 15:50:06 +03:00
2023-07-17 12:43:14 -07:00

A DHT implementation for Codex

License: Apache License: MIT Stability: experimental CI (GitHub Actions) codecov

This DHT implementation is aiming to provide a DHT for Codex with the following properties

  • flexible secure transport usage with
    • fast UDP based operation
    • eventual fallback to TCP-based operation (maybe though libp2p)
    • eventually support operation on top of libp2p
  • flexible message encoding that plays well with the above transports
  • provide node lookup, content storage/lookup, and provider storage/lookup operations

Current implementation is based on nim-eth's Discovery v5 implementation.

Base files were copied from status-im/nim-eth@779d767b024175a51cf74c79ec7513301ebe2f46

Building

This repo is setup to use Nimble lockfiles. This requires Nimble 0.14+ which isn't installed by default when this was written. If nimble -v reports 0.13.x then you will need to install Nimble 0.14. Note that using Nimble 0.14 changes how Nimble behaves!

Nimble 0.14 can be install by:

nimble install nimble@0.14.2

After this you can setup your Nimble environment. Note that this will build the pinned version of Nim! The first run can take ~15 minutes.

nimble setup # creates a nimble.paths used for rest of Nimble commands
nimble testAll

You can also run tasks directly:

nim testAll
Description
A DHT based on Discv5 with libp2p provider records support
Readme
Languages
Nim 100%