bitcoin-s/eclair-rpc/eclair-rpc.sbt

76 lines
2.2 KiB
Plaintext
Raw Normal View History

import java.nio.file._
import java.security.MessageDigest
import scala.util.Properties
name := "bitcoin-s-eclair-rpc"
libraryDependencies ++= Deps.eclairRpc
CommonSettings.prodSettings
TaskKeys.downloadEclair := {
val logger = streams.value.log
import scala.sys.process._
val binaryDir = CommonSettings.binariesPath.resolve("eclair")
if (Files.notExists(binaryDir)) {
logger.info(s"Creating directory for Eclair binaires: $binaryDir")
Files.createDirectories(binaryDir)
}
val version = "0.10.0"
val commit = "a63d2c2"
logger.debug(s"(Maybe) downloading Eclair binaries for version: $version")
val versionDir = binaryDir resolve version
val location =
s"https://github.com/ACINQ/eclair/releases/download/v$version/eclair-node-$version-$commit-bin.zip"
if (Files.exists(versionDir)) {
logger.debug(
s"Directory $versionDir already exists, skipping download of Eclair $version")
} else {
logger.info(s"Creating directory $version")
Files.createDirectories(versionDir)
val archiveLocation = versionDir resolve s"eclair-node-$version-$commit.zip"
logger.info(
s"Downloading Eclair $version from location: $location, to destination: $archiveLocation")
(url(location) #> archiveLocation.toFile).!!
val bytes = Files.readAllBytes(archiveLocation)
val hash = MessageDigest
.getInstance("SHA-256")
.digest(bytes)
.map("%02x" format _)
.mkString
val expectedHash =
"ee221cac0f3f8379fcac3eb7b558690de92b417365cc005524da2a6305d41e03"
val success = hash.equalsIgnoreCase(expectedHash)
if (success) {
logger.info(s"Download complete and verified, unzipping result")
val extractCommand = s"unzip $archiveLocation -d $versionDir"
logger.info(s"Extracting archive with command: $extractCommand")
extractCommand.!!
} else {
Files.deleteIfExists(versionDir)
logger.error(
s"Downloaded invalid version of eclair, got $hash, expected $expectedHash")
}
logger.info(s"Deleting archive")
Files.delete(archiveLocation)
if (!success) {
throw new RuntimeException(s"Failed to download eclair v$version")
}
logger.info(s"Download complete")
}
}