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.
- What is bitcoin-s?
- Is bitcoin-s production ready?
- Can I trust the code in bitcoin-s?
- Getting started (non-developers)
- Getting setup (developers)
- Adding bitcoin-s to your library
- Docker images
- Contributing
- Good first issues
- License
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!
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!
Please audit and verify any and all code in this toolkit for its suitability and validity. This includes reviewing any and all dependencies.
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.
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.
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"
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 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.
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.
Bitcoin-s is MIT licensed, as found in the LICENSE file.