mirror of
https://github.com/status-im/nim-libp2p.git
synced 2025-01-19 01:12:23 +00:00
b37133ca43
Our quic effort is blocked by bearssl not supporting TLS1.3, but since Mark did most of the work to implement Quic here: https://github.com/status-im/nim-libp2p/pull/563 and on nim-quic, this PR is going to bring encryption-less Quic into nim-libp2p This allows us to test it, and make sure it doesn't bitrot. Heavily WiP: - [X] Extract code from #563 - [X] Create custom muxer & upgrader - [X] Basic E2E switch test working - [x] Update nim-quic to get address informations in libp2p (for `observed address` and port 0 resolving) - [ ] More tests - [ ] Cleanup Since encryption is not yet supported, we're not compatible with any other libp2ps, and have to rely on home made protocols to retrieve the peer's id --------- Co-authored-by: markspanbroek <mark@spanbroek.net> Co-authored-by: Diego <diego@status.im>
74 lines
2.0 KiB
Nim
74 lines
2.0 KiB
Nim
# Nim-LibP2P
|
|
# Copyright (c) 2023 Status Research & Development GmbH
|
|
# Licensed under either of
|
|
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE))
|
|
# * MIT license ([LICENSE-MIT](LICENSE-MIT))
|
|
# at your option.
|
|
# This file may not be copied, modified, or distributed except according to
|
|
# those terms.
|
|
|
|
when defined(nimdoc):
|
|
## Welcome to the nim-libp2p reference!
|
|
##
|
|
## On the left, you'll find a switch that allows you to see private
|
|
## procedures. By default, you'll only see the public one (marked with `{.public.}`)
|
|
##
|
|
## The difference between public and private procedures is that public procedure
|
|
## stay backward compatible during the Major version, whereas private ones can
|
|
## change at each new Minor version.
|
|
##
|
|
## If you're new to nim-libp2p, you can find a tutorial `here<https://status-im.github.io/nim-libp2p/docs/tutorial_1_connect/>`_
|
|
## that can help you get started.
|
|
|
|
# Import stuff for doc
|
|
import
|
|
libp2p/[
|
|
protobuf/minprotobuf,
|
|
switch,
|
|
stream/lpstream,
|
|
builders,
|
|
transports/tcptransport,
|
|
transports/wstransport,
|
|
protocols/ping,
|
|
protocols/pubsub,
|
|
peerid,
|
|
peerinfo,
|
|
peerstore,
|
|
multiaddress,
|
|
]
|
|
|
|
proc dummyPrivateProc*() =
|
|
## A private proc example
|
|
discard
|
|
|
|
else:
|
|
import
|
|
libp2p/[
|
|
protobuf/minprotobuf,
|
|
muxers/muxer,
|
|
muxers/mplex/mplex,
|
|
stream/lpstream,
|
|
stream/bufferstream,
|
|
stream/connection,
|
|
transports/transport,
|
|
transports/tcptransport,
|
|
transports/quictransport,
|
|
protocols/secure/noise,
|
|
cid,
|
|
multihash,
|
|
multicodec,
|
|
errors,
|
|
switch,
|
|
peerid,
|
|
peerinfo,
|
|
multiaddress,
|
|
builders,
|
|
crypto/crypto,
|
|
protocols/pubsub,
|
|
]
|
|
|
|
export
|
|
minprotobuf, switch, peerid, peerinfo, connection, multiaddress, crypto, lpstream,
|
|
bufferstream, muxer, mplex, transport, tcptransport, noise, errors, cid, multihash,
|
|
multicodec, builders, pubsub
|