mirror of
https://github.com/codex-storage/nim-codex.git
synced 2025-01-25 20:28:52 +00:00
d3dbbc75fa
* don't force logging syncs * Add failing test * wip discovery engine * re-add chronicles sinks * wip * move network related stuff to own folder * move peer related stuff to own folder * extract discovery into it's own engine * update imports * move pending blocks into engine module * add top level exports * update imports * update import paths * update imports * support for inflight request filtering and tests * use `remove` instead of `del` * fix sorting in `selectCheapest` * re-org test file structure * fix to use discovery engine * file re-org * fix compilation * fixup discovery to use async handlers * more re-org * rework with support for discovery engine * add logging * use defaults * wip: reworking with discoveryengine * wip: more test fixes * more logging * use ordered table * use `bt` for blocktype Block * fix tests * make tests work with discovery engine * expose all node components * fix to work with discovery engine * wip * propagate cancellation in listBlocks * start/stop disc engine in blockexc engine * remove disc engine start/stop * wire up discovery engine * misc comments and imports * pass discovery to dagger node * set sleep timers * unused imports * misc * don't spawn a task, await it * don't await handlers * trace logging * reduce default sleep time Co-authored-by: Tanguy <tanguy@status.im>
147 lines
4.3 KiB
Nim
147 lines
4.3 KiB
Nim
## Nim-Dagger
|
|
## Copyright (c) 2021 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.
|
|
|
|
import std/sequtils
|
|
import std/os
|
|
import std/sugar
|
|
|
|
import pkg/chronicles
|
|
import pkg/chronos
|
|
import pkg/presto
|
|
import pkg/libp2p
|
|
import pkg/confutils
|
|
import pkg/confutils/defs
|
|
import pkg/nitro
|
|
import pkg/stew/io2
|
|
import pkg/stew/shims/net as stewnet
|
|
|
|
import ./node
|
|
import ./conf
|
|
import ./rng
|
|
import ./rest/api
|
|
import ./stores
|
|
import ./blockexchange
|
|
import ./utils/fileutils
|
|
import ./erasure
|
|
import ./discovery
|
|
import ./contracts
|
|
|
|
type
|
|
DaggerServer* = ref object
|
|
runHandle: Future[void]
|
|
config: DaggerConf
|
|
restServer: RestServerRef
|
|
daggerNode: DaggerNodeRef
|
|
|
|
proc start*(s: DaggerServer) {.async.} =
|
|
s.restServer.start()
|
|
await s.daggerNode.start()
|
|
|
|
s.runHandle = newFuture[void]()
|
|
await s.runHandle
|
|
|
|
proc stop*(s: DaggerServer) {.async.} =
|
|
await allFuturesThrowing(
|
|
s.restServer.stop(), s.daggerNode.stop())
|
|
|
|
s.runHandle.complete()
|
|
|
|
proc new*(T: type DaggerServer, config: DaggerConf): T =
|
|
|
|
const SafePermissions = {UserRead, UserWrite}
|
|
let
|
|
privateKey =
|
|
if config.netPrivKeyFile == "random":
|
|
PrivateKey.random(Rng.instance()[]).get()
|
|
else:
|
|
let path =
|
|
if config.netPrivKeyFile.isAbsolute:
|
|
config.netPrivKeyFile
|
|
else:
|
|
config.dataDir / config.netPrivKeyFile
|
|
|
|
if path.fileAccessible({AccessFlags.Find}):
|
|
info "Found a network private key"
|
|
|
|
if path.getPermissionsSet().get() != SafePermissions:
|
|
warn "The network private key file is not safe, aborting"
|
|
quit QuitFailure
|
|
|
|
PrivateKey.init(path.readAllBytes().expect("accessible private key file")).
|
|
expect("valid private key file")
|
|
else:
|
|
info "Creating a private key and saving it"
|
|
let
|
|
res = PrivateKey.random(Rng.instance()[]).get()
|
|
bytes = res.getBytes().get()
|
|
|
|
path.writeFile(bytes, SafePermissions.toInt()).expect("writing private key file")
|
|
|
|
PrivateKey.init(bytes).expect("valid key bytes")
|
|
|
|
let
|
|
addresses =
|
|
config.listenPorts.mapIt(MultiAddress.init("/ip4/" & $config.listenIp & "/tcp/" & $(it.int)).tryGet()) &
|
|
@[MultiAddress.init("/ip4/" & $config.listenIp & "/udp/" & $(config.discoveryPort.int)).tryGet()]
|
|
switch = SwitchBuilder
|
|
.new()
|
|
.withPrivateKey(privateKey)
|
|
.withAddresses(addresses)
|
|
.withRng(Rng.instance())
|
|
.withNoise()
|
|
.withMplex(5.minutes, 5.minutes)
|
|
.withMaxConnections(config.maxPeers)
|
|
.withAgentVersion(config.agentString)
|
|
.withSignedPeerRecord(true)
|
|
.withTcpTransport({ServerFlags.ReuseAddr})
|
|
.build()
|
|
|
|
let cache =
|
|
if config.cacheSize > 0:
|
|
CacheStore.new(cacheSize = config.cacheSize * MiB)
|
|
else:
|
|
CacheStore.new()
|
|
|
|
let
|
|
discoveryBootstrapNodes = config.bootstrapNodes
|
|
blockDiscovery = Discovery.new(
|
|
switch.peerInfo,
|
|
discoveryPort = config.discoveryPort,
|
|
bootstrapNodes = discoveryBootstrapNodes
|
|
)
|
|
|
|
wallet = WalletRef.new(EthPrivateKey.random())
|
|
network = BlockExcNetwork.new(switch)
|
|
localStore = FSStore.new(config.dataDir / "repo", cache = cache)
|
|
peerStore = PeerCtxStore.new()
|
|
pendingBlocks = PendingBlocksManager.new()
|
|
discovery = DiscoveryEngine.new(localStore, peerStore, network, blockDiscovery, pendingBlocks)
|
|
engine = BlockExcEngine.new(localStore, wallet, network, discovery, peerStore, pendingBlocks)
|
|
store = NetworkStore.new(engine, localStore)
|
|
erasure = Erasure.new(store, leoEncoderProvider, leoDecoderProvider)
|
|
contracts = ContractInteractions.new(
|
|
config.ethProvider,
|
|
config.ethDeployment,
|
|
config.ethAccount
|
|
)
|
|
daggerNode = DaggerNodeRef.new(switch, store, engine, erasure, blockDiscovery, contracts)
|
|
restServer = RestServerRef.new(
|
|
daggerNode.initRestApi(config),
|
|
initTAddress("127.0.0.1" , config.apiPort),
|
|
bufferSize = (1024 * 64),
|
|
maxRequestBodySize = int.high)
|
|
.tryGet()
|
|
|
|
switch.mount(network)
|
|
T(
|
|
config: config,
|
|
daggerNode: daggerNode,
|
|
restServer: restServer,
|
|
)
|