Bitcoin Implementation in Scala
Find a file
Chris Stewart 0fa3be37dd
2024 04 08 Descriptors (#5525)
* Add DescriptorType, OutputDescriptor

* Get unit test passing for a descriptor with a xpub and bip32 path

* WIP: Implement checksum algo

* WIP: Implement polyMod

* Get checksum unit test case passing

* Get basic serialization test case passing

* Revert Bech32.scala

* WIP: Implement KeyExpression

* WIP: KeyOriginExpression

* Get basic KeyExpression test case passing

* Get basic unit tests workign for parsing Private/Public key descriptor expressions

* Add examples

* Get all key expression unit tests passing

* Get negative test vectors passing

* WIP: Get P2WPKHDescriptor tests working

* Get all serizliation tests passing for non-derivation path BIP382 descrioptors

* Get BIP382 derivation test cases passing

* Implement BIP382 failure test cases

* Get BIP381 test vectors passing

* Split key expressions into SingleKeyExpression,MultisigKeyExpression

* WIP: Multisig descriptors

* Remove custom building of scripts now that we have #5502

* Get BIP383 test vectors passing

* Get BIP384 test vectors passing

* Fix bug in runFailTest()

* Add RawSPKScriptExpression, use it with P2WSHExpression to ensure underlying spk is a RawScriptPubKey

* Get all negative test vectors working after fixing bug in runFailTest()

* Implement BIP385 raw() test vectors, skip addr() descriptor

* Get everything working up to dealing with taproot pubkey types

* Begin working on type hierarchy for different pubkeys

* Get things to the point of needing a custom pubkey type

* Get things compiling w/ PubKeyTypeExpression

* Get tr(WIF) example working

* WIP: Key reworking type hierachy to be PublicKey type specific

* WIP: Taproot helpers

* Get taproot descriptor working with both keypath and single level scriptpath

* Get recursive tapscript tree test vector working

* Implement negative test vectors for BIP386

* Add BIP386 derivation test

* Get extkey tr() descriptor test working

* Rename InternalPublicKeyExpression -> RawPublicXOnlyPublicKeyExpression

* Fix keyOrigin for tr() descriptors

* Cleanup comments

* Add comments

* Move leafVersion TapscriptControlBlock -> TapLeaf
2024-04-15 19:09:46 -05:00
.github Make ECPublicKey return bytes that were passed as a parameter (#5502) 2024-04-05 09:21:53 -05:00
app 2024 03 24 v21 rpc refactor (#5494) 2024-03-26 13:04:26 -05:00
app-commons Delete directory using Files.delete() (#5518) 2024-04-10 17:08:14 -05:00
app-commons-test/src/test/scala/org/bitcoins/commons Add signature ordering to ClaimedDLCStatus.oracleSigs (#4804) 2022-09-27 09:43:37 -05:00
async-utils/src/main/scala/org/bitcoins/asyncutil Improve bitcoind connection retry logic (#4386) 2022-06-14 08:40:04 -05:00
async-utils-test/src/test/scala/org/bitcoins/asyncutil 2023 12 19 compiler opts (#5330) 2023-12-20 05:42:01 -06:00
bench 2023 02 21 pekko (#5413) 2024-02-22 10:26:21 -06:00
bitcoin-s-docs Update sbt-bloop to 1.5.11 (#5226) 2023-10-31 06:55:25 -05:00
bitcoind-rpc 2024 03 24 v21 rpc refactor (#5494) 2024-03-26 13:04:26 -05:00
bitcoind-rpc-test 2023 02 21 pekko (#5413) 2024-02-22 10:26:21 -06:00
chain Remove different versions of Blockchain.scala now that we don't support scalac 2.12 (#5519) 2024-04-12 09:53:30 -05:00
chain-test 2024 03 24 v21 rpc refactor (#5494) 2024-03-26 13:04:26 -05:00
clightning-rpc Remove grizzled.sl4fj was its no longer maintained (#5482) 2024-03-18 16:48:58 -05:00
clightning-rpc-test Add generate helper function for bitcoind (#4852) 2022-10-19 14:22:30 -05:00
core 2024 04 08 Descriptors (#5525) 2024-04-15 19:09:46 -05:00
core-test 2024 04 08 Descriptors (#5525) 2024-04-15 19:09:46 -05:00
crypto TapscriptTree, TapBranch, TapLeaf (#5520) 2024-04-12 11:16:14 -05:00
crypto-test Make ECPublicKey return bytes that were passed as a parameter (#5502) 2024-04-05 09:21:53 -05:00
db-commons Add bitcoin-s.node.connection-attempt-cool-down-period (#5489) 2024-03-22 13:16:45 -05:00
db-commons-test/src/test 2023 12 19 compiler opts (#5330) 2023-12-20 05:42:01 -06:00
dlc-node Remove grizzled.sl4fj was its no longer maintained (#5482) 2024-03-18 16:48:58 -05:00
dlc-node-test 2023 02 21 pekko (#5413) 2024-02-22 10:26:21 -06:00
dlc-oracle/src/main Remove grizzled.sl4fj was its no longer maintained (#5482) 2024-03-18 16:48:58 -05:00
dlc-oracle-test/src/test/scala/org/bitcoins/dlc/oracle 2022 09 29 handle unordered sigs (#4807) 2022-09-29 11:43:50 -05:00
dlc-wallet/src/main Remove grizzled.sl4fj was its no longer maintained (#5482) 2024-03-18 16:48:58 -05:00
dlc-wallet-test 2023 10 16 Implement WalletCallbackStreamManager, DLCWalletCallbackStreamManager (#5263) 2023-10-19 11:52:07 -05:00
docs Bump max connected peers default to 2 (#5515) 2024-04-08 09:14:28 -05:00
eclair-rpc 2023 02 21 pekko (#5413) 2024-02-22 10:26:21 -06:00
eclair-rpc-test 2023 02 21 pekko (#5413) 2024-02-22 10:26:21 -06:00
esplora/src/main/scala/org/bitcoins/esplora 2023 02 21 pekko (#5413) 2024-02-22 10:26:21 -06:00
esplora-test/src/test/scala/org/bitcoins/esplora Move Socks5ProxyParams, Credentials into core (#5138) 2023-07-08 13:57:44 -05:00
fee-provider/src/main/scala/org/bitcoins/feeprovider Remove grizzled.sl4fj was its no longer maintained (#5482) 2024-03-18 16:48:58 -05:00
fee-provider-test/src/test/scala/org/bitcoins/feeprovider Ignore invs while in IBD rather than when syncing (#5433) 2024-02-28 13:30:08 -06:00
key-manager Remove grizzled.sl4fj was its no longer maintained (#5482) 2024-03-18 16:48:58 -05:00
key-manager-test/src/test/scala/org/bitcoins/keymanager PostgreSQL friendly wallet names (#4571) 2022-08-04 08:54:33 -05:00
lnd-rpc Remove grizzled.sl4fj was its no longer maintained (#5482) 2024-03-18 16:48:58 -05:00
lnd-rpc-test 2023 02 21 pekko (#5413) 2024-02-22 10:26:21 -06:00
lnurl/src/main/scala/org/bitcoins/lnurl Remove grizzled.sl4fj was its no longer maintained (#5482) 2024-03-18 16:48:58 -05:00
lnurl-test/src/test/scala/org/bitcoins/lnurl Add ability to add arbitrary query string params for lnurl pays (#4995) 2023-02-22 16:22:23 -06:00
node Bump max connected peers default to 2 (#5515) 2024-04-08 09:14:28 -05:00
node-test refactor: Use 'peerWithServicesDataMap' name consistently across NodeState and PeerManager (#5478) 2024-03-17 16:30:52 -05:00
project Update sbt-native-packager to 1.10.0 (#5522) 2024-04-15 08:49:51 -05:00
release-notes init 1.9.8 release notes (#5281) 2024-03-25 09:10:25 -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 2024 03 24 v21 rpc refactor (#5494) 2024-03-26 13:04:26 -05:00
testkit-core Tighten P2WSHWitnessSPKV0.apply() to only take RawScriptPubKey (#5509) 2024-04-06 16:57:21 -05:00
tor Remove grizzled.sl4fj was its no longer maintained (#5482) 2024-03-18 16:48:58 -05:00
tor-test/src/test/scala/org/bitcoins/tor 2023 02 21 pekko (#5413) 2024-02-22 10:26:21 -06:00
wallet Remove grizzled.sl4fj was its no longer maintained (#5482) 2024-03-18 16:48:58 -05:00
wallet-test 2024 03 24 v21 rpc refactor (#5494) 2024-03-26 13:04:26 -05:00
website Run yarn upgrade to update website deps (#5495) 2024-03-26 14:35:27 -05:00
zmq Remove grizzled.sl4fj was its no longer maintained (#5482) 2024-03-18 16:48:58 -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
.scalafmt.conf Configure scalafmt to preserve line endings (#4638) 2022-08-21 16:07:48 -05:00
build.sbt Remove grizzled.sl4fj was its no longer maintained (#5482) 2024-03-18 16:48:58 -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 Upgrade to scala 2.13.13, fix compiler errors (#5428) 2024-02-27 10:21:39 -06:00
LICENSE Update license to latest year (#4525) 2022-07-20 16:36:06 -05:00
README.md Bump versions to 1.9.8, add 1.9.8 version of website (#5280) 2024-03-25 09:06:31 -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.8, here is how you can use the dependencies in your projects:

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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.