Bitcoin Implementation in Scala
Go to file
2022-06-18 18:42:08 -05:00
.github LnURL Module (#4295) 2022-05-14 16:11:35 -05:00
app Default to suredbits node if peers field is left empty (#4404) 2022-06-18 18:40:53 -05:00
app-commons Add TaprootWitness, new methods to XOnlyPubKey (#4394) 2022-06-14 20:27:01 -05:00
app-commons-test/src/test/scala/org/bitcoins/commons DLC <-> contact mapping (#4346) 2022-06-14 08:14:28 -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 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 Add HashType to ECDigitalSignature API (#4320) 2022-05-29 18:25:22 -05:00
bitcoind-rpc-test Add TaprootWitness, new methods to XOnlyPubKey (#4394) 2022-06-14 20:27:01 -05:00
chain Make logging to file async, remove neverBlock configuration so that we are guaranteed to capture logs (#4305) 2022-05-01 06:45:33 -05:00
chain-test 2022 01 24 rm appconfig varargs (#4011) 2022-01-25 07:25:05 -06:00
clightning-rpc Add clightning sendcustommsg (#3883) 2021-12-08 10:13:20 -06:00
clightning-rpc-test Automatically download binaries if they are used in test suite (#4005) 2022-01-23 17:43:30 -06:00
core Add TaprootWitness, new methods to XOnlyPubKey (#4394) 2022-06-14 20:27:01 -05:00
core-test Add TaprootWitness, new methods to XOnlyPubKey (#4394) 2022-06-14 20:27:01 -05:00
crypto Add hmac256 to CryptoUtil (#4395) 2022-06-15 07:32:17 -05:00
crypto-test Add hmac256 to CryptoUtil (#4395) 2022-06-15 07:32:17 -05:00
db-commons Default to suredbits node if peers field is left empty (#4404) 2022-06-18 18:40:53 -05:00
db-commons-test/src/test DLC <-> contact mapping (#4346) 2022-06-14 08:14:28 -05:00
dlc-node DLC <-> contact mapping (#4346) 2022-06-14 08:14:28 -05:00
dlc-node-test DLC <-> contact mapping (#4346) 2022-06-14 08:14:28 -05:00
dlc-oracle/src/main Make CRUD.run and CRUD.runVec transactional (#4059) 2022-02-07 17:42:48 -06: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 Add TLVs defined in BOLT 4 (#4380) 2022-06-13 11:58:11 -05:00
dlc-wallet/src/main Add TaprootWitness, new methods to XOnlyPubKey (#4394) 2022-06-14 20:27:01 -05:00
dlc-wallet-test DLC <-> contact mapping (#4346) 2022-06-14 08:14:28 -05:00
docs sports betting example (#4397) 2022-06-16 13:55:47 -05:00
eclair-rpc Upgrade Eclair to v0.7.0 (#4308) 2022-05-02 09:04:56 -05:00
eclair-rpc-test Upgrade Eclair to v0.7.0 (#4308) 2022-05-02 09:04:56 -05:00
esplora/src/main/scala/org/bitcoins/esplora Add basic esplora client (#4018) 2022-01-28 15:48:44 -06:00
esplora-test/src/test/scala/org/bitcoins/esplora Add basic esplora client (#4018) 2022-01-28 15:48:44 -06:00
fee-provider/src/main/scala/org/bitcoins/feeprovider 2022 02 26 dynamic fee gui (#4135) 2022-02-27 07:14:52 -06:00
fee-provider-test/src/test/scala/org/bitcoins/feeprovider Create FallbackFeeRateApi (#3974) 2022-01-13 05:43:05 -06:00
key-manager Validate bitcoin-s.wallet.walletName config option (#4336) 2022-05-17 10:29:17 -05:00
key-manager-test/src/test/scala/org/bitcoins/keymanager Validate bitcoin-s.wallet.walletName config option (#4336) 2022-05-17 10:29:17 -05:00
lnd-rpc Add peers rpc to lnd (#4403) 2022-06-18 18:42:08 -05:00
lnd-rpc-test Add test/example on how to use the channel acceptor (#4375) 2022-06-13 14:53:10 -05:00
lnurl/src/main/scala/org/bitcoins/lnurl LnURL Module (#4295) 2022-05-14 16:11:35 -05:00
lnurl-test/src/test/scala/org/bitcoins/lnurl LnURL Module (#4295) 2022-05-14 16:11:35 -05:00
node Default to suredbits node if peers field is left empty (#4404) 2022-06-18 18:40:53 -05:00
node-test Remove Spv code (#4356) 2022-05-30 07:57:31 -05:00
oracle-explorer-client/src Tor endpoints for the oracle explorer client (#4314) 2022-05-06 07:21:33 -05:00
project Add platform specific name to bitcoin-s artifacts (#4401) 2022-06-16 17:08:06 -05:00
release-notes Add some summaries (#4399) 2022-06-16 14:26:37 -05:00
secp256k1-zkp@9dd53912dc Update secp256k1-zkp (#3856) 2021-12-03 09:49:07 -06:00
secp256k1jni Update secp256k1-zkp (#3856) 2021-12-03 09:49:07 -06:00
testkit Allow for custom channel sizes in LndRpcTestUtil.createNodePair (#4398) 2022-06-16 19:36:03 -05:00
testkit-core 2022 06 13 taprootspk xonlypubkey (#4388) 2022-06-13 18:43:43 -05:00
tor Tor v0.4.6.10 (#4331) 2022-05-17 12:06:17 -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 Remove Spv code (#4356) 2022-05-30 07:57:31 -05:00
wallet-test Added Compute Contract Id test Vectors (#4385) 2022-06-13 14:13:48 -05:00
website Add sports betting examples to 1.9.2 website (#4400) 2022-06-16 14:53:17 -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 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 Update scalafmt (#2619) 2021-02-03 16:37:12 -06:00
build.sbt Fix lnurl module name to have bitcoin-s prefix (#4392) 2022-06-14 12:37:39 -05:00
CONTRIBUTING.md WIP: Docusaurus website (#465) 2019-05-14 18:05:14 -05:00
docker-compose.yml Fix peer configuration for docker-compose (#4225) 2022-03-29 14:28:57 -05:00
Dockerfile WIP: Docusaurus website (#465) 2019-05-14 18:05:14 -05:00
inThisBuild.sbt Upgrade to Scala 2.13.8 (#3789) 2022-01-13 10:17:11 -06:00
LICENSE Update LICENSE year (#2474) 2021-01-06 06:41:18 -06:00
README.md Fix typo (#4365) 2022-06-04 07:56:10 -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

You have three options to run bitcoin-s. Here are the instructions.

We recommend using the web frontend for beginners.

  1. Web frontend
  2. Desktop GUI
  3. Headless backend

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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.