Bitcoin Implementation in Scala
Go to file
2021-11-11 15:22:45 -06:00
.github Initial c-lightning rpc support (#3755) 2021-10-19 10:58:29 -05:00
app Improve app server validation error handling (#3796) 2021-11-05 10:03:16 -05:00
app-commons Add clightning listtransactions func (#3797) 2021-11-05 08:31:24 -05:00
app-commons-test/src/test/scala/org/bitcoins/commons Give funding txid in DLC Signed state (#3640) 2021-09-02 08:17:20 -05:00
async-utils/src/main/scala/org/bitcoins/asyncutil Add FutureUtil tests (#3126) 2021-06-28 14:44:08 -05:00
async-utils-test/src/test/scala/org/bitcoins/asyncutil Add FutureUtil tests (#3126) 2021-06-28 14:44:08 -05:00
bench Update scalafmt (#2619) 2021-02-03 16:37:12 -06:00
bitcoin-s-docs Remove previous stable version usage for windows builds as for some reason it doesn't work when setting up dev envs for the first time (#3292) 2021-06-18 09:18:54 -05:00
bitcoind-rpc Overridable Tor config (#3780) 2021-10-27 12:57:10 -05:00
bitcoind-rpc-test Try to fix race condition when shutting down bitcoind connection pool (#3665) 2021-09-14 15:14:20 -05:00
chain Improve filter header verification (#3566) 2021-08-18 06:57:01 -05:00
chain-test/src/test Improve filter header verification (#3566) 2021-08-18 06:57:01 -05:00
clightning-rpc Add clightning listtransactions func (#3797) 2021-11-05 08:31:24 -05:00
clightning-rpc-test Add clightning listtransactions func (#3797) 2021-11-05 08:31:24 -05:00
core Remove scientific notation from Bitcoins.toString() (#3811) 2021-11-10 12:55:44 -06:00
core-test Remove scientific notation from Bitcoins.toString() (#3811) 2021-11-10 12:55:44 -06:00
crypto Implement ability to provide external entropy to bitcoin-s (#3672) 2021-09-18 09:49:11 -05:00
crypto-test Implement ability to provide external entropy to bitcoin-s (#3672) 2021-09-18 09:49:11 -05:00
db-commons Decide which coin selection solution to use based on waste metric (#3646) 2021-10-19 09:47:28 -05:00
db-commons-test/src/test Store oracle name in the database (#3748) 2021-10-14 09:35:11 -05:00
dlc-node Overridable Tor config (#3780) 2021-10-27 12:57:10 -05:00
dlc-node-test/src/test/scala/org/bitcoins/dlc/node Tor in Testkit (#3484) 2021-08-23 13:06:14 -05:00
dlc-oracle/src/main Store oracle name in the database (#3748) 2021-10-14 09:35:11 -05:00
dlc-oracle-test/src/test/scala/org/bitcoins/dlc/oracle Store oracle name in the database (#3748) 2021-10-14 09:35:11 -05:00
dlc-test/src/test/scala/org/bitcoins/dlc 2021 11 03 protocol version (#3793) 2021-11-03 15:13:19 -05:00
dlc-wallet/src/main 2021 11 03 protocol version (#3793) 2021-11-03 15:13:19 -05:00
dlc-wallet-test/src/test/scala/org/bitcoins/dlc Make sure exception is caught by Future inside of UtxoHandling.unmarkUTXOsAsReserved() (#3816) 2021-11-11 15:22:45 -06:00
docs 2021 11 03 protocol version (#3793) 2021-11-03 15:13:19 -05:00
eclair-rpc Support Eclair v0.6.2 (#3765) 2021-10-19 11:46:54 -05:00
eclair-rpc-test Support Eclair v0.6.2 (#3765) 2021-10-19 11:46:54 -05:00
fee-provider/src/main/scala/org/bitcoins/feeprovider Tor support for all sub-projects (#3506) 2021-08-10 08:07:12 -05:00
fee-provider-test/src/test/scala/org/bitcoins/feeprovider Tor support for all sub-projects (#3506) 2021-08-10 08:07:12 -05:00
key-manager Implement MasterXPubDAO (#3451) 2021-09-21 08:05:23 -05:00
key-manager-test/src/test/scala/org/bitcoins/keymanager Implement MasterXPubDAO (#3451) 2021-09-21 08:05:23 -05:00
lnd-rpc update lnd to v0.13.3 (#3720) 2021-10-04 12:12:10 -05:00
lnd-rpc-test/src/test/scala/org/bitcoins/lnd/rpc Add LndInstanceRemote (#3710) 2021-10-02 16:15:40 -05:00
node Overridable Tor config (#3780) 2021-10-27 12:57:10 -05:00
node-test/src/test/scala/org/bitcoins/node Decide which coin selection solution to use based on waste metric (#3646) 2021-10-19 09:47:28 -05:00
oracle-explorer-client/src update oracle explorer client to use v2 of the API (#3747) 2021-10-12 15:43:27 -05:00
project Update akka-grpc-runtime_2.12, ... to 2.1.1 (#3809) 2021-11-11 12:26:11 -06:00
release-notes Update release notes with latest commits (#3761) 2021-10-17 08:32:41 -05:00
secp256k1-zkp@6dd724b72b Add Schnorr and Adaptor Secp Bindings and Update Adaptor (#2885) 2021-04-21 09:42:43 -05:00
secp256k1jni update osx64 secp256k1 binaries (#3531) 2021-08-12 07:08:11 -05:00
testkit 2021 11 03 protocol version (#3793) 2021-11-03 15:13:19 -05:00
testkit-core Added WitnessScriptPubKeyV1 for sending to Taproot addresses (#3737) 2021-11-05 12:35:52 -05:00
tor Overridable Tor config (#3780) 2021-10-27 12:57:10 -05:00
tor-test/src/test/scala/org/bitcoins/tor Use random ports for pre-packaged Tor daemon (#3604) 2021-08-26 13:02:49 -05:00
wallet Make sure exception is caught by Future inside of UtxoHandling.unmarkUTXOsAsReserved() (#3816) 2021-11-11 15:22:45 -06:00
wallet-test/src/test Decide which coin selection solution to use based on waste metric (#3646) 2021-10-19 09:47:28 -05:00
website Add missing markdown files (#3779) 2021-10-25 08:16:23 -05:00
zmq CI fixes (#3597) 2021-08-25 15:07:27 -05:00
.dockerignore WIP: Docusaurus website (#465) 2019-05-14 18:05:14 -05:00
.gitignore Remove request rejection duplication in ServerRoute (#3010) 2021-05-04 12:17:50 -05:00
.gitmodules Update .gitmodules (#3390) 2021-07-11 08:46:54 -05:00
.scalafmt.conf Update scalafmt (#2619) 2021-02-03 16:37:12 -06:00
build.sbt Make clightning tests execute async (#3768) 2021-10-19 12:18:04 -05:00
CONTRIBUTING.md WIP: Docusaurus website (#465) 2019-05-14 18:05:14 -05:00
docker-compose.yml Docs: removes blog from website 2019-06-11 12:59:58 +02:00
Dockerfile WIP: Docusaurus website (#465) 2019-05-14 18:05:14 -05:00
inThisBuild.sbt Update scala-library to 2.12.15 (#3668) 2021-09-14 18:02:13 -05:00
LICENSE Update LICENSE year (#2474) 2021-01-06 06:41:18 -06:00
README.md Update website to 1.8 and bump various versions on README and node agent version (#3762) 2021-10-17 12:24:30 -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

What is bitcoin-s?

Bitcoin-S is a loosely coupled set of cryptocurrency libraries for the JVM. They work well together, but also can be used independently.

This project's goal is NOT to be a full node implementation, rather a set of scalable cryptocurrency libraries that use industry standard tools (rather than esoteric tech often found in cryptocurrency) where possible to make the lives of professional software engineers, security engineers, devops engineers and accountants easier.

We are rapidly iterating on development with the goal of getting to a set of stable APIs that only change when the underlying bitcoin protocol changes.

If you are a professional working a cryptocurrency business and have feedback on how to make your lives easier, please reach out on slack or twitter!

Is bitcoin-s production ready?

Please see our latest releases here.

Warning! While we try out best to test every pull request in master, this branch may not be stable! Bad things can happen to your node! Beware!

Can I trust the code in bitcoin-s?

Please audit and verify any and all code in this toolkit for its suitability and validity. This includes reviewing any and all dependencies.

Getting started (non-developers)

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

This link is intended for individuals who are just interested in installing bitcoin-s rather than developing. If you are interested in development, see Getting setup below.

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.8.0, here is how you can use the dependencies in your projects:

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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.