mirror of
https://github.com/bitcoin-s/bitcoin-s.git
synced 2025-01-19 05:43:51 +01:00
Remove chainApi
parameter from NeutrinoNode
(#5101)
* Remove chainApi parameter from NeutrinoNode * Fix doc
This commit is contained in:
parent
e3f8eb2cc6
commit
bed670fb6f
@ -99,19 +99,11 @@ implicit val nodeConfig = appConfig.nodeConf
|
||||
|
||||
val initNodeF = nodeConfig.start()
|
||||
|
||||
//the node requires a chainHandler to store block information
|
||||
//use a helper method in our testkit to create the chain project
|
||||
val chainApiF = for {
|
||||
chainHandler <- ChainUnitTest.createChainHandler()
|
||||
} yield chainHandler
|
||||
|
||||
|
||||
//yay! All setup done, let's create a node and then start it!
|
||||
val nodeF = for {
|
||||
chainApi <- chainApiF
|
||||
peer <- peerF
|
||||
} yield {
|
||||
NeutrinoNode(chainApi = chainApi,
|
||||
NeutrinoNode(
|
||||
walletCreationTimeOpt = None, //you can set this to only sync compact filters after the timestamp
|
||||
paramPeers = Vector(peer),
|
||||
nodeConfig = nodeConfig,
|
||||
|
@ -2,6 +2,7 @@ package org.bitcoins.node
|
||||
|
||||
import akka.actor.ActorSystem
|
||||
import org.bitcoins.asyncutil.AsyncUtil
|
||||
import org.bitcoins.chain.blockchain.ChainHandler
|
||||
import org.bitcoins.chain.config.ChainAppConfig
|
||||
import org.bitcoins.chain.models.BlockHeaderDAO
|
||||
import org.bitcoins.core.api.chain.ChainApi
|
||||
@ -21,7 +22,6 @@ import java.time.Instant
|
||||
import scala.concurrent.Future
|
||||
|
||||
case class NeutrinoNode(
|
||||
chainApi: ChainApi,
|
||||
walletCreationTimeOpt: Option[Instant],
|
||||
nodeConfig: NodeAppConfig,
|
||||
chainConfig: ChainAppConfig,
|
||||
@ -83,6 +83,7 @@ case class NeutrinoNode(
|
||||
*/
|
||||
private def syncHelper(syncPeerOpt: Option[Peer]): Future[Unit] = {
|
||||
logger.info(s"Syncing with peerOpt=$syncPeerOpt")
|
||||
val chainApi: ChainApi = ChainHandler.fromDatabase()
|
||||
val blockchainsF =
|
||||
BlockHeaderDAO()(executionContext, chainConfig).getBlockchains()
|
||||
for {
|
||||
|
@ -558,7 +558,6 @@ case class PeerManager(
|
||||
(forceReconnect || connectedPeerCount == 0) && isStarted.get
|
||||
if (peers.exists(_ != peer) && syncPeerOpt.isDefined) {
|
||||
node
|
||||
.copy(chainApi = ChainHandler.fromDatabase())
|
||||
.syncFromNewPeer()
|
||||
.map(_ => ())
|
||||
} else if (syncPeerOpt.isDefined) {
|
||||
|
@ -2,14 +2,7 @@ package org.bitcoins.node.config
|
||||
|
||||
import akka.actor.ActorSystem
|
||||
import com.typesafe.config.Config
|
||||
import org.bitcoins.chain.blockchain.ChainHandlerCached
|
||||
import org.bitcoins.chain.config.ChainAppConfig
|
||||
import org.bitcoins.chain.models.{
|
||||
BlockHeaderDAO,
|
||||
ChainStateDescriptorDAO,
|
||||
CompactFilterDAO,
|
||||
CompactFilterHeaderDAO
|
||||
}
|
||||
import org.bitcoins.core.api.CallbackConfig
|
||||
import org.bitcoins.core.api.node.NodeType
|
||||
import org.bitcoins.core.config.{MainNet, RegTest, SigNet, TestNet3}
|
||||
@ -233,25 +226,15 @@ object NodeAppConfig extends AppConfigFactoryActorSystem[NodeAppConfig] {
|
||||
nodeConf: NodeAppConfig,
|
||||
chainConf: ChainAppConfig,
|
||||
system: ActorSystem): Future[Node] = {
|
||||
import system.dispatcher
|
||||
|
||||
val blockHeaderDAO = BlockHeaderDAO()
|
||||
val filterHeaderDAO = CompactFilterHeaderDAO()
|
||||
val filterDAO = CompactFilterDAO()
|
||||
val stateDAO = ChainStateDescriptorDAO()
|
||||
|
||||
val chainF = ChainHandlerCached
|
||||
.fromDatabase(blockHeaderDAO, filterHeaderDAO, filterDAO, stateDAO)
|
||||
|
||||
nodeConf.nodeType match {
|
||||
case NodeType.NeutrinoNode =>
|
||||
chainF.map(chain =>
|
||||
NeutrinoNode(chain,
|
||||
walletCreationTimeOpt,
|
||||
nodeConf,
|
||||
chainConf,
|
||||
system,
|
||||
paramPeers = peers))
|
||||
val n = NeutrinoNode(walletCreationTimeOpt,
|
||||
nodeConf,
|
||||
chainConf,
|
||||
system,
|
||||
paramPeers = peers)
|
||||
Future.successful(n)
|
||||
case NodeType.FullNode =>
|
||||
Future.failed(new RuntimeException("Not implemented"))
|
||||
case NodeType.BitcoindBackend =>
|
||||
|
@ -2,10 +2,7 @@ package org.bitcoins.testkit.node
|
||||
|
||||
import akka.actor.ActorSystem
|
||||
import org.bitcoins.asyncutil.AsyncUtil
|
||||
import org.bitcoins.chain.blockchain.ChainHandlerCached
|
||||
import org.bitcoins.chain.config.ChainAppConfig
|
||||
import org.bitcoins.chain.models._
|
||||
import org.bitcoins.core.api.chain.ChainApi
|
||||
import org.bitcoins.core.api.node.NodeType
|
||||
import org.bitcoins.node._
|
||||
import org.bitcoins.node.config.NodeAppConfig
|
||||
@ -161,22 +158,16 @@ object NodeUnitTest extends P2PLogger {
|
||||
system: ActorSystem): Future[NeutrinoNode] = {
|
||||
import system.dispatcher
|
||||
|
||||
val blockHeaderDAO = BlockHeaderDAO()
|
||||
val filterHeaderDAO = CompactFilterHeaderDAO()
|
||||
val filterDAO = CompactFilterDAO()
|
||||
val stateDAO = ChainStateDescriptorDAO()
|
||||
|
||||
val chainApiF = {
|
||||
val chainConfStartedF = {
|
||||
for {
|
||||
_ <- chainConf.start()
|
||||
chainApi <- ChainHandlerCached
|
||||
.fromDatabase(blockHeaderDAO, filterHeaderDAO, filterDAO, stateDAO)
|
||||
} yield {
|
||||
chainApi
|
||||
()
|
||||
}
|
||||
}
|
||||
|
||||
val nodeF = chainApiF.map(buildNode(peer, _, walletCreationTimeOpt))
|
||||
val nodeF =
|
||||
chainConfStartedF.map(_ => buildNeutrinoNode(peer, walletCreationTimeOpt))
|
||||
for {
|
||||
node <- nodeF
|
||||
_ <- node.nodeConfig.start()
|
||||
@ -186,41 +177,19 @@ object NodeUnitTest extends P2PLogger {
|
||||
}
|
||||
}
|
||||
|
||||
def buildNode(
|
||||
private def buildNeutrinoNode(
|
||||
peer: Peer,
|
||||
chainApi: ChainApi,
|
||||
walletCreationTimeOpt: Option[Instant])(implicit
|
||||
chainConf: ChainAppConfig,
|
||||
nodeConf: NodeAppConfig,
|
||||
system: ActorSystem): NeutrinoNode = {
|
||||
NeutrinoNode(chainApi,
|
||||
walletCreationTimeOpt,
|
||||
NeutrinoNode(walletCreationTimeOpt,
|
||||
nodeConf,
|
||||
chainConf,
|
||||
system,
|
||||
paramPeers = Vector(peer))
|
||||
}
|
||||
|
||||
def buildPeerMessageReceiver(
|
||||
chainApi: ChainApi,
|
||||
peer: Peer,
|
||||
walletCreationTimeOpt: Option[Instant])(implicit
|
||||
appConfig: BitcoinSAppConfig,
|
||||
system: ActorSystem): Future[PeerMessageReceiver] = {
|
||||
val node = buildNode(peer, chainApi, walletCreationTimeOpt)(
|
||||
appConfig.chainConf,
|
||||
appConfig.nodeConf,
|
||||
system)
|
||||
val controlMessageHandler = ControlMessageHandler(node.peerManager)(
|
||||
system.dispatcher,
|
||||
appConfig.nodeConf)
|
||||
val receiver =
|
||||
PeerMessageReceiver(controlMessageHandler = controlMessageHandler,
|
||||
queue = node.peerManager.dataMessageQueueOpt.get,
|
||||
peer = peer)(system, appConfig.nodeConf)
|
||||
Future.successful(receiver)
|
||||
}
|
||||
|
||||
def destroyNode(node: Node, appConfig: BitcoinSAppConfig)(implicit
|
||||
ec: ExecutionContext): Future[Unit] = {
|
||||
|
||||
@ -254,7 +223,7 @@ object NodeUnitTest extends P2PLogger {
|
||||
}
|
||||
|
||||
//does not destroys the bitcoinds
|
||||
def destroyNodeConnectedWithBitcoinds(
|
||||
private def destroyNodeConnectedWithBitcoinds(
|
||||
nodeConnectedWithBitcoind: NodeConnectedWithBitcoinds)(implicit
|
||||
system: ActorSystem,
|
||||
appConfig: BitcoinSAppConfig): Future[Unit] = {
|
||||
@ -273,7 +242,7 @@ object NodeUnitTest extends P2PLogger {
|
||||
}
|
||||
|
||||
/** Creates a neutrino node, a funded bitcoin-s wallet, all of which are connected to bitcoind */
|
||||
def createNeutrinoNodeFundedWalletBitcoind(
|
||||
private def createNeutrinoNodeFundedWalletBitcoind(
|
||||
versionOpt: Option[BitcoindVersion],
|
||||
walletCallbacks: WalletCallbacks)(implicit
|
||||
system: ActorSystem,
|
||||
@ -339,7 +308,7 @@ object NodeUnitTest extends P2PLogger {
|
||||
}
|
||||
}
|
||||
|
||||
def destroyNodeFundedWalletBitcoind(
|
||||
private def destroyNodeFundedWalletBitcoind(
|
||||
fundedWalletBitcoind: NodeFundedWalletBitcoind)(implicit
|
||||
system: ActorSystem,
|
||||
appConfig: BitcoinSAppConfig): Future[Unit] = {
|
||||
@ -363,20 +332,23 @@ object NodeUnitTest extends P2PLogger {
|
||||
}
|
||||
|
||||
def buildPeerMessageReceiver(
|
||||
chainApi: ChainApi,
|
||||
peer: Peer,
|
||||
walletCreationTimeOpt: Option[Instant])(implicit
|
||||
nodeAppConfig: NodeAppConfig,
|
||||
chainAppConfig: ChainAppConfig,
|
||||
system: ActorSystem): Future[PeerMessageReceiver] = {
|
||||
val node = buildNode(peer, chainApi, walletCreationTimeOpt)
|
||||
val controlMessageHandler =
|
||||
ControlMessageHandler(node.peerManager)(system.dispatcher, nodeAppConfig)
|
||||
val receiver =
|
||||
PeerMessageReceiver(controlMessageHandler = controlMessageHandler,
|
||||
queue = node.peerManager.dataMessageQueueOpt.get,
|
||||
peer = peer)
|
||||
Future.successful(receiver)
|
||||
import system.dispatcher
|
||||
val nodeF = buildNode(peer, walletCreationTimeOpt)
|
||||
for {
|
||||
node <- nodeF
|
||||
controlMessageHandler =
|
||||
ControlMessageHandler(node.peerManager)(system.dispatcher,
|
||||
nodeAppConfig)
|
||||
receiver =
|
||||
PeerMessageReceiver(controlMessageHandler = controlMessageHandler,
|
||||
queue = node.peerManager.dataMessageQueueOpt.get,
|
||||
peer = peer)
|
||||
} yield receiver
|
||||
}
|
||||
|
||||
def createPeer(bitcoind: BitcoindRpcClient)(implicit
|
||||
@ -403,17 +375,14 @@ object NodeUnitTest extends P2PLogger {
|
||||
val checkConfigF = Future {
|
||||
assert(nodeAppConfig.nodeType == NodeType.NeutrinoNode)
|
||||
}
|
||||
val chainApiF = for {
|
||||
_ <- checkConfigF
|
||||
chainHandler <- ChainUnitTest.createChainHandler()
|
||||
} yield chainHandler
|
||||
|
||||
val nodeF = for {
|
||||
_ <- checkConfigF
|
||||
_ <- chainAppConfig.start()
|
||||
_ <- nodeAppConfig.start()
|
||||
peer <- createPeer(bitcoind)
|
||||
chainApi <- chainApiF
|
||||
} yield {
|
||||
NeutrinoNode(chainApi,
|
||||
walletCreationTimeOpt,
|
||||
NeutrinoNode(walletCreationTimeOpt,
|
||||
paramPeers = Vector(peer),
|
||||
nodeConfig = nodeAppConfig,
|
||||
chainConfig = chainAppConfig,
|
||||
@ -436,16 +405,13 @@ object NodeUnitTest extends P2PLogger {
|
||||
val checkConfigF = Future {
|
||||
assert(nodeAppConfig.nodeType == NodeType.NeutrinoNode)
|
||||
}
|
||||
val chainApiF = for {
|
||||
_ <- checkConfigF
|
||||
chainHandler <- ChainUnitTest.createChainHandler()
|
||||
} yield chainHandler
|
||||
|
||||
val nodeF = for {
|
||||
_ <- checkConfigF
|
||||
_ <- chainAppConfig.start()
|
||||
_ <- nodeAppConfig.start()
|
||||
chainApi <- chainApiF
|
||||
} yield {
|
||||
NeutrinoNode(chainApi,
|
||||
walletCreationTimeOpt,
|
||||
NeutrinoNode(walletCreationTimeOpt,
|
||||
paramPeers = Vector(peer),
|
||||
nodeConfig = nodeAppConfig,
|
||||
chainConfig = chainAppConfig,
|
||||
@ -469,18 +435,15 @@ object NodeUnitTest extends P2PLogger {
|
||||
val checkConfigF = Future {
|
||||
assert(nodeAppConfig.nodeType == NodeType.NeutrinoNode)
|
||||
}
|
||||
val chainApiF = for {
|
||||
_ <- checkConfigF
|
||||
chainHandler <- ChainUnitTest.createChainHandler()
|
||||
} yield chainHandler
|
||||
val peersF = bitcoinds.map(createPeer(_))
|
||||
|
||||
val peersF = Future.traverse(bitcoinds)(createPeer(_))
|
||||
val nodeF = for {
|
||||
_ <- checkConfigF
|
||||
_ <- chainAppConfig.start()
|
||||
_ <- nodeAppConfig.start()
|
||||
chainApi <- chainApiF
|
||||
peers <- Future.sequence(peersF)
|
||||
peers <- peersF
|
||||
} yield {
|
||||
NeutrinoNode(chainApi,
|
||||
creationTimeOpt,
|
||||
NeutrinoNode(walletCreationTimeOpt = creationTimeOpt,
|
||||
paramPeers = peers,
|
||||
nodeConfig = nodeAppConfig,
|
||||
chainConfig = chainAppConfig,
|
||||
|
Loading…
Reference in New Issue
Block a user