Bitcoin Implementation in Scala
Go to file
Chris Stewart 777743989a
Remove PeerHandler as it isn't used in src (#5075)
* Remove PeerHandler as it isn't used in src

* Fix rebase
2023-05-22 11:11:03 -05:00
.github
app Fix getpeers -> getconnectioncount in cli (#5052) 2023-04-21 05:47:47 -05:00
app-commons Update Eclair RPC to v0.8.0 (#4994) 2023-03-04 09:02:36 -06:00
app-commons-test/src/test/scala/org/bitcoins/commons
async-utils/src/main/scala/org/bitcoins/asyncutil
async-utils-test/src/test/scala/org/bitcoins/asyncutil
bench
bitcoin-s-docs
bitcoind-rpc Implement getconnectioncount rpc (#5048) 2023-04-19 16:47:54 -05:00
bitcoind-rpc-test
chain Fix bug where compact filters weren't being processed in order of block height during IBD (#5041) 2023-04-10 16:42:48 -05:00
chain-test Fix bug where compact filters weren't being processed in order of block height during IBD (#5041) 2023-04-10 16:42:48 -05:00
clightning-rpc Bump clightning version to v23.02.2 (#5025) 2023-03-26 06:26:46 -05:00
clightning-rpc-test
core Implement batchAndParallelExecute with Future.traverse rather than Future.sequence (#5051) 2023-04-20 17:59:09 -05:00
core-test 2023 03 24 is tip stale (#5024) 2023-03-26 08:20:27 -05:00
crypto
crypto-test
db-commons
db-commons-test/src/test
dlc-node
dlc-node-test
dlc-oracle/src/main
dlc-oracle-test/src/test/scala/org/bitcoins/dlc/oracle
dlc-wallet/src/main
dlc-wallet-test
docs Implement getconnectioncount rpc (#5048) 2023-04-19 16:47:54 -05:00
eclair-rpc Update Eclair RPC to v0.8.0 (#4994) 2023-03-04 09:02:36 -06:00
eclair-rpc-test Update Eclair RPC to v0.8.0 (#4994) 2023-03-04 09:02:36 -06:00
esplora/src/main/scala/org/bitcoins/esplora
esplora-test/src/test/scala/org/bitcoins/esplora
fee-provider/src/main/scala/org/bitcoins/feeprovider
fee-provider-test/src/test/scala/org/bitcoins/feeprovider
key-manager
key-manager-test/src/test/scala/org/bitcoins/keymanager
lnd-rpc Lnd 0.16.0 rpc (#5005) 2023-03-30 14:43:26 -05:00
lnd-rpc-test
lnurl/src/main/scala/org/bitcoins/lnurl
lnurl-test/src/test/scala/org/bitcoins/lnurl
node Remove PeerHandler as it isn't used in src (#5075) 2023-05-22 11:11:03 -05:00
node-test Remove PeerHandler as it isn't used in src (#5075) 2023-05-22 11:11:03 -05:00
oracle-explorer-client/src
project Fix build by ignoring junit transitive dep (#5071) 2023-05-15 13:52:40 -05:00
release-notes
secp256k1-zkp@9dd53912dc
secp256k1jni
testkit Remove PeerHandler as it isn't used in src (#5075) 2023-05-22 11:11:03 -05:00
testkit-core 2023 03 24 is tip stale (#5024) 2023-03-26 08:20:27 -05:00
tor Drop support for Tor v2 (#4864) 2022-10-30 16:50:16 -05:00
tor-test/src/test/scala/org/bitcoins/tor
wallet Fix bug where compact filters weren't being processed in order of block height during IBD (#5041) 2023-04-10 16:42:48 -05:00
wallet-test Fix bug where bip39Password was not passed as param in test case (#5040) 2023-04-08 22:19:13 -05:00
website
zmq
.dockerignore
.gitignore
.gitmodules
.scalafmt.conf Configure scalafmt to preserve line endings (#4638) 2022-08-21 16:07:48 -05:00
build.sbt
CONTRIBUTING.md
docker-compose.yml
Dockerfile
flyway.conf
inThisBuild.sbt
LICENSE
README.md
try-bitcoin-s.sh

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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.