1
0
mirror of https://github.com/ACINQ/eclair.git synced 2024-11-19 18:10:42 +01:00

use hash of block #0 as chain hash

This commit is contained in:
sstone 2017-04-28 16:19:52 +02:00 committed by Pierre-Marie Padiou
parent 4c6f8695cb
commit cadf0bf4e9

View File

@ -12,7 +12,7 @@ import ch.qos.logback.classic.spi.ILoggingEvent
import ch.qos.logback.classic.{Logger, LoggerContext} import ch.qos.logback.classic.{Logger, LoggerContext}
import ch.qos.logback.core.FileAppender import ch.qos.logback.core.FileAppender
import com.sun.javafx.application.LauncherImpl import com.sun.javafx.application.LauncherImpl
import fr.acinq.bitcoin.{Base58Check, Block, OP_CHECKSIG, OP_DUP, OP_EQUALVERIFY, OP_HASH160, OP_PUSHDATA, Script} import fr.acinq.bitcoin.{Base58Check, BinaryData, Block, OP_CHECKSIG, OP_DUP, OP_EQUALVERIFY, OP_HASH160, OP_PUSHDATA, Script}
import fr.acinq.eclair.api.Service import fr.acinq.eclair.api.Service
import fr.acinq.eclair.blockchain.rpc.BitcoinJsonRPCClient import fr.acinq.eclair.blockchain.rpc.BitcoinJsonRPCClient
import fr.acinq.eclair.blockchain.zmq.ZMQActor import fr.acinq.eclair.blockchain.zmq.ZMQActor
@ -79,11 +79,18 @@ class Setup(datadir: String, actorSystemName: String = "default") extends Loggin
implicit val formats = org.json4s.DefaultFormats implicit val formats = org.json4s.DefaultFormats
implicit val ec = ExecutionContext.Implicits.global implicit val ec = ExecutionContext.Implicits.global
val (chain, blockCount, progress) = Try(Await.result(bitcoinClient.client.invoke("getblockchaininfo").map(json => ((json \ "chain").extract[String], (json \ "blocks").extract[Long], (json \ "verificationprogress").extract[Double])), 10 seconds)).recover { case _ => throw BitcoinRPCConnectionException }.get
logger.info(s"using chain=$chain") val future = for {
val chainHash = chain match { json <- bitcoinClient.client.invoke("getblockchaininfo")
case "test" => Block.TestnetGenesisBlock.blockId chain = (json \ "chain").extract[String]
case "regtest" => Block.RegtestGenesisBlock.blockId blockCount = (json \ "blocks").extract[Long]
progress = (json \ "verificationprogress").extract[Double]
chainHash <- bitcoinClient.client.invoke("getblockhash", 0).map(_.extract[String])
} yield (chain, blockCount, progress, chainHash)
val (chain, blockCount, progress, chainHash) = Try(Await.result(future, 10 seconds)).recover { case _ => throw BitcoinRPCConnectionException }.get
logger.info(s"using chain=$chain chainHash=$chainHash")
chain match {
case "test" | "regtest" => ()
case _ => throw new RuntimeException("only regtest and testnet are supported for now") case _ => throw new RuntimeException("only regtest and testnet are supported for now")
} }
val nodeParams = NodeParams.makeNodeParams(new File(datadir), config, chainHash) val nodeParams = NodeParams.makeNodeParams(new File(datadir), config, chainHash)