Bitcoin Implementation in Scala
Go to file
2025-01-10 15:43:32 -06:00
.github Add .jvmopts, conslidate JVM options there (#5729) 2024-10-21 12:45:19 -05:00
app refactor: Improve bitcoind wallet polling logic (#5834) 2025-01-03 15:46:48 -06:00
app-commons 2024 11 15 partialsig typeparam (#5770) 2024-11-18 09:15:33 -06:00
app-commons-test/src/test/scala/org/bitcoins/commons Pull over simple syntax changes for scala3 libraries (#5719) 2024-10-17 13:00:33 -05:00
async-utils/src/main/scala/org/bitcoins/asyncutil Update scalafmt-core to 3.8.1 (#5501) 2024-04-20 19:55:49 -05:00
async-utils-test/src/test/scala/org/bitcoins/asyncutil Add -Xsource:3 to docs/ (#5581) 2024-05-10 12:37:02 -05:00
bench Pull over simple syntax changes for {cli,oracleServer,bench,dlcNode,dlcOracle,dlcOracleTest,eclairRpc,lndRpc,lndRpcTest} from #5713 (#5721) 2024-10-17 15:41:43 -05:00
bitcoin-s-docs rework bitcoind-rpc to take a walletName parameter that is a String (#5545) 2024-04-26 08:09:28 -05:00
bitcoind-rpc Turn on -Xlint (#5728) 2024-10-24 06:59:50 -05:00
bitcoind-rpc-test 2024 11 15 partialsig typeparam (#5770) 2024-11-18 09:15:33 -06:00
chain chore: remove redundant words in comment (#5826) 2024-12-31 11:09:52 -06:00
chain-test Pull over simple syntax changes for scala3 pt2 (#5720) 2024-10-17 14:14:32 -05:00
clightning-rpc Rework NativeProcessFactory.cmd to be Vector[String] (#5623) 2024-07-18 08:15:40 -05:00
clightning-rpc-test Upgrade clightning to 24.02.2 (#5558) 2024-05-01 13:28:12 -05:00
core wallet: Refactor {UTXOHandlingApi,AccountHandlingApi,AddressHandlingApi} to use 'get' prefix rather than 'list' prefix for method names (#5828) 2025-01-01 09:41:21 -06:00
core-test Add unit test for RescanState to test recursive rescans correctly (#5786) 2024-11-26 11:13:06 -06:00
crypto core: Fix bug where we weren't checking for valid hash types in TaprootKeyPath.isValid() (#5780) 2024-11-21 11:42:18 -06:00
crypto-test 2024 11 09 schnorrsig hashtype (#5764) 2024-11-09 12:52:45 -06:00
db-commons wallet: Remove unused wallet configurations (#5789) 2024-11-26 15:20:13 -06:00
db-commons-test/src/test Add -Xsource:3 to db-commons/ (#5585) 2024-05-11 07:24:00 -05:00
dlc-node Pull over simple syntax changes for {cli,oracleServer,bench,dlcNode,dlcOracle,dlcOracleTest,eclairRpc,lndRpc,lndRpcTest} from #5713 (#5721) 2024-10-17 15:41:43 -05:00
dlc-node-test 2024 09 30 dlcwallet has a wallet (#5692) 2024-10-01 13:29:58 -05:00
dlc-oracle/src/main Pull over simple syntax changes for {cli,oracleServer,bench,dlcNode,dlcOracle,dlcOracleTest,eclairRpc,lndRpc,lndRpcTest} from #5713 (#5721) 2024-10-17 15:41:43 -05:00
dlc-oracle-test/src/test/scala/org/bitcoins/dlc/oracle 2024 11 09 schnorrsig hashtype (#5764) 2024-11-09 12:52:45 -06:00
dlc-wallet/src/main wallet: Refactor {UTXOHandlingApi,AccountHandlingApi,AddressHandlingApi} to use 'get' prefix rather than 'list' prefix for method names (#5828) 2025-01-01 09:41:21 -06:00
dlc-wallet-test wallet: Refactor {UTXOHandlingApi,AccountHandlingApi,AddressHandlingApi} to use 'get' prefix rather than 'list' prefix for method names (#5828) 2025-01-01 09:41:21 -06:00
docs wallet: Refactor {UTXOHandlingApi,AccountHandlingApi,AddressHandlingApi} to use 'get' prefix rather than 'list' prefix for method names (#5828) 2025-01-01 09:41:21 -06:00
eclair-rpc Pull over simple syntax changes for {cli,oracleServer,bench,dlcNode,dlcOracle,dlcOracleTest,eclairRpc,lndRpc,lndRpcTest} from #5713 (#5721) 2024-10-17 15:41:43 -05:00
eclair-rpc-test 2024 04 30 upgrade eclair v0.10.0 (#5557) 2024-04-30 14:25:50 -05:00
esplora/src/main/scala/org/bitcoins/esplora Update scalafmt-core to 3.8.1 (#5501) 2024-04-20 19:55:49 -05:00
esplora-test/src/test/scala/org/bitcoins/esplora Update scalafmt-core to 3.8.1 (#5501) 2024-04-20 19:55:49 -05:00
fee-provider/src/main/scala/org/bitcoins/feeprovider Turn on -Xlint (#5728) 2024-10-24 06:59:50 -05:00
fee-provider-test/src/test/scala/org/bitcoins/feeprovider Re-enable mempool api tests (#5560) 2024-05-01 15:26:41 -05:00
key-manager config: Rename config option bitcoin-s.wallet.defaultAccountType -> bitcoin-s.wallet.purpose (#5783) 2024-11-24 08:16:18 -06:00
key-manager-test/src/test/scala/org/bitcoins/keymanager config: Rename config option bitcoin-s.wallet.defaultAccountType -> bitcoin-s.wallet.purpose (#5783) 2024-11-24 08:16:18 -06:00
lnd-rpc 2024 10 21 Replace Future.sequence() usage with Future.traverse() (#5732) 2024-10-22 16:57:23 -05:00
lnd-rpc-test Pull over simple syntax changes for {cli,oracleServer,bench,dlcNode,dlcOracle,dlcOracleTest,eclairRpc,lndRpc,lndRpcTest} from #5713 (#5721) 2024-10-17 15:41:43 -05:00
lnurl/src/main/scala/org/bitcoins/lnurl Update scalafmt-core to 3.8.1 (#5501) 2024-04-20 19:55:49 -05:00
lnurl-test/src/test/scala/org/bitcoins/lnurl Update scalafmt-core to 3.8.1 (#5501) 2024-04-20 19:55:49 -05:00
node node: Move killswitch downstream to avoid queue deadlocks (#5819) 2024-12-23 08:57:12 -06:00
node-test wallet: Refactor {UTXOHandlingApi,AccountHandlingApi,AddressHandlingApi} to use 'get' prefix rather than 'list' prefix for method names (#5828) 2025-01-01 09:41:21 -06:00
project Update logback-classic to 1.5.16 (#5837) 2025-01-10 15:43:32 -06:00
release-notes Create 1.9.9 release notes (#5596) 2024-05-15 14:23:27 -05:00
secp256k1-zkp@9dd53912dc Update secp256k1-zkp (#3856) 2021-12-03 09:49:07 -06:00
secp256k1jni Drop support for scalac 2.12.x (#4704) 2022-09-03 10:16:22 -05:00
testkit Replace Future[Wallet] -> Wallet parameter in {BitcoinSWalletTest, BitcoindRpcBackendUtil} (#5796) 2024-11-30 09:04:14 -06:00
testkit-core core: Fix bug where we weren't checking for valid hash types in TaprootKeyPath.isValid() (#5780) 2024-11-21 11:42:18 -06:00
tor node: Move killswitch downstream to avoid queue deadlocks (#5819) 2024-12-23 08:57:12 -06:00
tor-test/src/test/scala/org/bitcoins/tor Update scalafmt-core to 3.8.1 (#5501) 2024-04-20 19:55:49 -05:00
wallet wallet: Refactor {UTXOHandlingApi,AccountHandlingApi,AddressHandlingApi} to use 'get' prefix rather than 'list' prefix for method names (#5828) 2025-01-01 09:41:21 -06:00
wallet-test wallet: Refactor {UTXOHandlingApi,AccountHandlingApi,AddressHandlingApi} to use 'get' prefix rather than 'list' prefix for method names (#5828) 2025-01-01 09:41:21 -06:00
website docs: Run 'yarn upgrade' (#5830) 2025-01-01 11:38:28 -06:00
zmq Pull over simple syntax changes for scala3 pt2 (#5720) 2024-10-17 14:14:32 -05:00
.dockerignore WIP: Docusaurus website (#465) 2019-05-14 18:05:14 -05:00
.gitignore Support for Tor Docker (#4223) 2022-03-29 08:10:34 -05:00
.gitmodules Update .gitmodules (#3390) 2021-07-11 08:46:54 -05:00
.jvmopts Remove .jvmopts file comments, they do not work on ubuntu (#5730) 2024-10-22 06:25:50 -05:00
.scalafmt.conf Update dialect to scala213source3 (#5536) 2024-04-21 11:53:25 -05:00
build.sbt 2024 09 24 simplify wallet (#5685) 2024-09-27 13:40:29 -05:00
CONTRIBUTING.md WIP: Docusaurus website (#465) 2019-05-14 18:05:14 -05:00
docker-compose.yml Remove neutrino.suredbits.com:8333 from docker-compose.yml (#5492) 2024-03-24 11:03:39 -05:00
Dockerfile WIP: Docusaurus website (#465) 2019-05-14 18:05:14 -05:00
flyway.conf Upgrade dependencies (#4705) 2022-09-05 07:11:23 -05:00
inThisBuild.sbt Update scala-library to 2.13.14 (#5567) 2024-05-05 08:13:58 -05:00
LICENSE Update license to latest year (#4525) 2022-07-20 16:36:06 -05:00
README.md Docs: README (#5751) 2024-10-31 11:11:43 -05:00
try-bitcoin-s.sh Update try-bitcoin-s.sh (#1165) 2020-02-26 07:50:17 -06:00

Bitcoin-S logo Build Status Coverage Status Maven Central Gitter chat

Feature-rich toolkit for making Bitcoin and Lightning applications on the JVM.

For a complete guide on how to get started with Bitcoin-S, see our website at Bitcoin-S.org.

Contents

Running bitcoin-s

Docker

In this repo, you can just run

APP_PASSWORD=topsecret docker-compose up

which will spin up a docker environment that starts syncing the backend and will allow you to visit the web frontend of the wallet at localhost:3002

or you can build and run the electron app natively.

git clone https://github.com/bitcoin-s/bitcoin-s-ts.git
cd bitcoin-s-ts && ./build-wallet-electron.sh

Getting setup (developers)

For a complete guide on how to get setup with bitcoin-s, see our Getting setup.

This link is intended for setting up development of bitcoin-s. If you want to just install bitcoin-s rather than develop, see Getting started above.

Adding bitcoin-s to your library

The latest release of bitcoin-s is 1.9.9, here is how you can use the dependencies in your projects:

libraryDependencies += "org.bitcoin-s" % "bitcoin-s-secp256k1jni" % "1.9.9"

libraryDependencies += "org.bitcoin-s" %% "bitcoin-s-core" % "1.9.9"

libraryDependencies += "org.bitcoin-s" %% "bitcoin-s-crypto" % "1.9.9"

libraryDependencies += "org.bitcoin-s" %% "bitcoin-s-chain" % "1.9.9"

libraryDependencies += "org.bitcoin-s" %% "bitcoin-s-dlc-oracle" % "1.9.9"

libraryDependencies += "org.bitcoin-s" %% "bitcoin-s-oracle-explorer-client" % "1.9.9"

libraryDependencies += "org.bitcoin-s" %% "bitcoin-s-app-commons" % "1.9.9"

libraryDependencies += "org.bitcoin-s" %% "bitcoin-s-db-commons" % "1.9.9"

libraryDependencies += "org.bitcoin-s" %% "bitcoin-s-fee-provider" % "1.9.9"

libraryDependencies += "org.bitcoin-s" %% "bitcoin-s-bitcoind-rpc" % "1.9.9"

libraryDependencies += "org.bitcoin-s" %% "bitcoin-s-eclair-rpc" % "1.9.9"

libraryDependencies += "org.bitcoin-s" %% "bitcoin-s-lnd-rpc" % "1.9.9"

libraryDependencies += "org.bitcoin-s" %% "bitcoin-s-key-manager" % "1.9.9"

libraryDependencies += "org.bitcoin-s" %% "bitcoin-s-node" % "1.9.9"

libraryDependencies += "org.bitcoin-s" %% "bitcoin-s-dlc-node" % "1.9.9"

libraryDependencies += "org.bitcoin-s" %% "bitcoin-s-wallet" % "1.9.9"

libraryDependencies += "org.bitcoin-s" %% "bitcoin-s-dlc-wallet" % "1.9.9"

libraryDependencies += "org.bitcoin-s" %% "bitcoin-s-testkit-core" % "1.9.9"

libraryDependencies += "org.bitcoin-s" %% "bitcoin-s-testkit" % "1.9.9"

libraryDependencies += "org.bitcoin-s" %% "bitcoin-s-zmq" % "1.9.9"

libraryDependencies += "org.bitcoin-s" %% "bitcoin-s-tor" % "1.9.9"

libraryDependencies += "org.bitcoin-s" %% "bitcoin-s-cli" % "1.9.9"

Docker images

We publish docker images to docker hub on every PR merge and tag on github. You can obtain the images for both the app server and oracle server on these docker hub repos

bitcoin-s docker hub repo

oracle-server docker hub repo

Contributing

Bitcoin-S is an open source project where anyone is welcome to contribute. All contributions are encouraged and appreciated, whether that is code, testing, documentation or something else entirely.

See here for more information.

Good first issues

Here is a list of good first issues that contain bugs which have a relatively limited scope. This is a great place to get started, gain experience, and get familiar with the bitcoin-s contribution process.

License

Bitcoin-s is MIT licensed, as found in the LICENSE file.