mirror of
https://github.com/bitcoin-s/bitcoin-s.git
synced 2025-01-19 05:43:51 +01:00
7ed2b8801a
* Fix open, audit commands for v0.10.0 * Get all unit tests passing * Add logger.error() to try to debug channel state * Try adding delay to see if dual funding process can complete before we generate blocks * scalafmt * Try bumping number of blocks generated * Try disabling dual funding * Cleanup
108 lines
3.8 KiB
Scala
108 lines
3.8 KiB
Scala
import java.nio.file._
|
|
import java.security.MessageDigest
|
|
import scala.util.Properties
|
|
|
|
name := "bitcoin-s-lnd-rpc"
|
|
|
|
libraryDependencies ++= Deps.lndRpc
|
|
|
|
CommonSettings.prodSettings
|
|
|
|
enablePlugins(PekkoGrpcPlugin)
|
|
|
|
// Disable deprecation and unused imports warning otherwise generated files will cause errors
|
|
Compile / scalacOptions ++= Seq(
|
|
"-Wconf:cat=deprecation:site=lnrpc\\..*:silent",
|
|
"-Wconf:cat=deprecation:site=signrpc\\..*:silent",
|
|
"-Wconf:cat=deprecation:site=walletrpc\\..*:silent",
|
|
"-Wconf:cat=deprecation:site=routerrpc\\..*:silent",
|
|
"-Wconf:cat=deprecation:site=invoicesrpc\\..*:silent",
|
|
"-Wconf:cat=deprecation:site=peersrpc\\..*:silent",
|
|
"-Wconf:cat=deprecation:site=chainrpc\\..*:silent",
|
|
"-Wconf:cat=deprecation:site=wtclientrpc\\..*:silent",
|
|
"-Wconf:cat=unused-imports:site=lnrpc:silent",
|
|
"-Wconf:cat=unused-imports:site=signrpc:silent",
|
|
"-Wconf:cat=unused-imports:site=walletrpc:silent",
|
|
"-Wconf:cat=unused-imports:site=routerrpc:silent",
|
|
"-Wconf:cat=unused-imports:site=invoicesrpc:silent",
|
|
"-Wconf:cat=unused-imports:site=peersrpc:silent",
|
|
"-Wconf:cat=unused-imports:site=chainrpc:silent"
|
|
)
|
|
|
|
TaskKeys.downloadLnd := {
|
|
val logger = streams.value.log
|
|
import scala.sys.process._
|
|
|
|
val binaryDir = CommonSettings.binariesPath.resolve("lnd")
|
|
|
|
if (Files.notExists(binaryDir)) {
|
|
logger.info(s"Creating directory for lnd binaries: $binaryDir")
|
|
Files.createDirectories(binaryDir)
|
|
}
|
|
|
|
val version = "0.17.5-beta"
|
|
|
|
val (platform, suffix) =
|
|
if (Properties.isLinux) ("linux-amd64", "tar.gz")
|
|
else if (Properties.isMac && System.getProperty("os.arch") == "aarch64")
|
|
("darwin-arm64", "tar.gz")
|
|
else if (Properties.isMac) ("darwin-amd64", "tar.gz")
|
|
else if (Properties.isWin) ("windows-amd64", "zip")
|
|
else sys.error(s"Unsupported OS: ${Properties.osName}")
|
|
|
|
logger.debug(s"(Maybe) downloading lnd binaries for version: $version")
|
|
|
|
val versionDir = binaryDir resolve s"lnd-$platform-v$version"
|
|
val location =
|
|
s"https://github.com/lightningnetwork/lnd/releases/download/v$version/lnd-$platform-v$version.$suffix"
|
|
|
|
if (Files.exists(versionDir)) {
|
|
logger.debug(
|
|
s"Directory $versionDir already exists, skipping download of lnd $version")
|
|
} else {
|
|
val archiveLocation = binaryDir resolve s"$version.$suffix"
|
|
logger.info(s"Downloading lnd version $version from location: $location")
|
|
logger.info(s"Placing the file in $archiveLocation")
|
|
val downloadCommand = url(location) #> archiveLocation.toFile
|
|
downloadCommand.!!
|
|
|
|
val bytes = Files.readAllBytes(archiveLocation)
|
|
val hash = MessageDigest
|
|
.getInstance("SHA-256")
|
|
.digest(bytes)
|
|
.map("%02x" format _)
|
|
.mkString
|
|
|
|
val expectedHash =
|
|
if (Properties.isLinux)
|
|
"c06d96222990ecb240affba44c92413c26481057d9448657b18b6f0ab6a56d47"
|
|
else if (Properties.isMac && System.getProperty("os.arch") == "aarch64")
|
|
"fa88dc3e05605f71ec4a8c1cf608bc3b0d166caa5e0bbe2213e35c62346b31fd"
|
|
else if (Properties.isMac)
|
|
"71ec034b2e62a6db29c88d941f8e8902fa6070ce45e1b3c22d529313ae5fd0ce"
|
|
else if (Properties.isWin)
|
|
"9b6f0ada7910d5beddc44d6eef3a92206d3f7f06c19e9e3dcc412dd6a0d6182d"
|
|
else sys.error(s"Unsupported OS: ${Properties.osName}")
|
|
|
|
val success = hash.equalsIgnoreCase(expectedHash)
|
|
if (success) {
|
|
logger.info(s"Download complete and verified, unzipping result")
|
|
|
|
val extractCommand = s"tar -xzf $archiveLocation --directory $binaryDir"
|
|
logger.info(s"Extracting archive with command: $extractCommand")
|
|
extractCommand.!!
|
|
} else {
|
|
Files.delete(versionDir)
|
|
logger.error(
|
|
s"Downloaded invalid version of lnd, got $hash, expected $expectedHash")
|
|
}
|
|
|
|
logger.info(s"Deleting archive")
|
|
Files.delete(archiveLocation)
|
|
|
|
if (!success) {
|
|
throw new RuntimeException(s"Failed to download lnd v$version")
|
|
}
|
|
}
|
|
}
|