{"id":14980143,"url":"https://github.com/demining/bitcoin-spring-boot-starter-google-colab","last_synced_at":"2025-10-28T20:32:39.326Z","repository":{"id":144620870,"uuid":"460512570","full_name":"demining/bitcoin-spring-boot-starter-Google-Colab","owner":"demining","description":"Write enterprise Bitcoin applications with Spring Boot. Starter projects with multiple Bitcoin related modules that you can include in your application Google Colab","archived":false,"fork":false,"pushed_at":"2022-07-02T01:19:03.000Z","size":14731,"stargazers_count":5,"open_issues_count":0,"forks_count":12,"subscribers_count":2,"default_branch":"master","last_synced_at":"2025-02-01T18:11:42.010Z","etag":null,"topics":["bitcoin","bitcoin-api","bitcoin-core","bitcoin-payment","bitcoin-transaction","bitcoin-wallet","colab","colab-notebook","colab-notebooks","colab-tutorial","colaboratory","google-colab","google-colab-notebook","google-colab-notebooks","google-colab-tutorial","google-colaboratory","google-colaboratory-notebooks"],"latest_commit_sha":null,"homepage":"","language":"Java","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"apache-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/demining.png","metadata":{"files":{"readme":"readme.md","changelog":"changelog.md","contributing":"contributing.md","funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2022-02-17T16:18:46.000Z","updated_at":"2024-08-12T20:20:42.000Z","dependencies_parsed_at":null,"dependency_job_id":"160f1254-fafb-4a1f-90cf-ee8c8ba51412","html_url":"https://github.com/demining/bitcoin-spring-boot-starter-Google-Colab","commit_stats":{"total_commits":685,"total_committers":5,"mean_commits":137.0,"dds":"0.016058394160583966","last_synced_commit":"839b747f54b5334eaef53d75bf5b2825d58e02f6"},"previous_names":[],"tags_count":3,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/demining%2Fbitcoin-spring-boot-starter-Google-Colab","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/demining%2Fbitcoin-spring-boot-starter-Google-Colab/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/demining%2Fbitcoin-spring-boot-starter-Google-Colab/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/demining%2Fbitcoin-spring-boot-starter-Google-Colab/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/demining","download_url":"https://codeload.github.com/demining/bitcoin-spring-boot-starter-Google-Colab/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":238720206,"owners_count":19519310,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["bitcoin","bitcoin-api","bitcoin-core","bitcoin-payment","bitcoin-transaction","bitcoin-wallet","colab","colab-notebook","colab-notebooks","colab-tutorial","colaboratory","google-colab","google-colab-notebook","google-colab-notebooks","google-colab-tutorial","google-colaboratory","google-colaboratory-notebooks"],"created_at":"2024-09-24T14:01:21.713Z","updated_at":"2025-10-28T20:32:29.314Z","avatar_url":"https://github.com/demining.png","language":"Java","funding_links":[],"categories":[],"sub_categories":[],"readme":"[![Build](https://github.com/theborakompanioni/bitcoin-spring-boot-starter/actions/workflows/build.yml/badge.svg)](https://github.com/theborakompanioni/bitcoin-spring-boot-starter/actions/workflows/build.yml)\n[![GitHub Release](https://img.shields.io/github/release/theborakompanioni/bitcoin-spring-boot-starter.svg?maxAge=3600)](https://github.com/theborakompanioni/bitcoin-spring-boot-starter/releases/latest)\n[![Maven Central](https://img.shields.io/maven-central/v/io.github.theborakompanioni/spring-tor-core.svg?maxAge=3600)](https://search.maven.org/#search|g%3A%22io.github.theborakompanioni%22)\n[![License](https://img.shields.io/github/license/theborakompanioni/bitcoin-spring-boot-starter.svg?maxAge=2592000)](https://github.com/theborakompanioni/bitcoin-spring-boot-starter/blob/master/LICENSE)\n\n\n\u003cp align=\"center\"\u003e\n    \u003cimg src=\"https://github.com/theborakompanioni/bitcoin-spring-boot-starter/blob/master/docs/assets/images/logo.png\" alt=\"Logo\" width=\"255\" /\u003e\n\u003c/p\u003e\n\n\n-------------------------\n### Run bitcoin-spring-boot-starter-Google-Colab\n\nhttps://colab.research.google.com/drive/1OShIMVcFZ_khsUIBOIV1lzrqAGo1gfm_?usp=sharing\n\n-------------------------\n\n**Write enterprise Bitcoin applications with Spring Boot.**\n\nSpring boot starter projects with convenient dependency descriptors for multiple Bitcoin related modules that you can \ninclude in your application. Strong focus on integration and regression testing your own application or module.\nIncluded are features for representing, transporting, and performing comprehensive calculations and tests with \nBitcoin in financial applications and computations.\n \n**Note**: Most code is still experimental - **do not use in production**.\nThis project is under active development. Pull requests and issues are welcome.\n[Look at the changelog](changelog.md) to track notable changes.\n\u003ca id=\"fun\"\u003e\u003c/a\u003eAlso, [developing this project is fun](docs/FALSEHOODS.md).\n\n\n## Table of Contents\n\n- [Install](#install)\n- [Modules](#modules)\n- [Examples](#examples)\n- [Development](#development)\n- [Contributing](#contributing)\n- [Resources](#resources)\n- [License](#license)\n\n\n## Install\n\n[Download](https://search.maven.org/#search|g%3A%22io.github.theborakompanioni%22) from Maven Central.\n\n### Gradle\n```groovy\nimplementation \"io.github.theborakompanioni:spring-tor-starter:${bitcoinSpringBootStarterVersion}\"\n```\n\n### Maven\n```xml\n\u003cdependency\u003e\n    \u003cgroupId\u003eio.github.theborakompanioni\u003c/groupId\u003e\n    \u003cartifactId\u003espring-tor-starter\u003c/artifactId\u003e\n    \u003cversion\u003e${bitcoinSpringBootStarter.version}\u003c/version\u003e\n\u003c/dependency\u003e\n```\n\nThe example above imports module `spring-tor-starter` - you can import any module by its name.\n\n\n## Modules\n\n[This project contains various modules](readme.md) that can be integrated into your project depending on your requirements.\n\nYou can find a small selection in the following table. But there is much more to discover.\n\n\n\u003c!-- there are external links on the anchor #spring-lnurl - so please do not remove it --\u003e\n| Module | Description|\n--- | --- |\n|[bitcoin-jsonrpc-client](modules.md#bitcoin-jsonrpc-client)|Connect to Bitcoin Core via [ConsensusJ](https://github.com/ConsensusJ/consensusj) Bitcoin Core JSON-RPC API client.|\n|[bitcoin-zeromq-client](modules.md#bitcoin-zeromq-client)|Connect to Bitcoin Core via ZeroMq API client.|\n|[bitcoin-regtest](modules.md#bitcoin-regtest)|Integration and regression testing your own application.|\n|[lnd-grpc-client](modules.md#lnd-grpc-client)|Connect to lnd node via [LightningJ](https://www.lightningj.org/) gRPC API client.|\n|[xchange-jsr354](modules.md#xchange-jsr354)|Exchange rates from popular Bitcoin exchanges for your application.|\n|[spring-xchange](modules.md#spring-xchange)|Automatically create and configure [XChange]( https://github.com/knowm/XChange) beans.|\n|[spring-tor](modules.md#spring-tor)|Automatically expose your application as [Tor Hidden Service](https://www.torproject.org/).|\n|\u003ca id=\"spring-lnurl\"\u003e\u003c/a\u003e[spring-lnurl](incubator/spring-lnurl)|Spring Security configurations for authentication with [lnurl-auth](https://github.com/fiatjaf/lnurl-rfc).|\n\n[See modules.md for general information](modules.md) about specific modules.\n\n\n## Examples\nBesides, that most starter modules also have their own example applications, there are also stand-alone \nexample applications showing basic usage of the functionality provided by these modules.\n\n- [x] bitcoin-autodca: [Stacking Sats on Kraken: Auto DCA example application](examples/bitcoin-autodca-example-application)\n- [x] bitcoin-exchange-rate: [Currency Conversion API example application](examples/bitcoin-exchange-rate-example-application)\n- [x] lnd-playground: [Lightning Network Playground example application](examples/lnd-playground-example-application) (using lnd)\n- [x] lnurl-auth: [Spring Security Authentication with `lnurl-auth` example application](incubator/spring-lnurl/spring-lnurl-auth-example-application)\n\nExample apps can be started with a single command, e.g.:\n```shell script\n./gradlew -p incubator/spring-lnurl/spring-lnurl-auth-example-application bootRun\n```\n\n\n## Development\n\n### Requirements\n- java \u003e=11\n- docker\n\nA Bitcoin Core Testcontainer running in regtest mode is started for most examples. \nHaving access to a Bitcoin Core node running on mainnet is quite useful if you want to try everything.\nOptional: A node should publish `rawtx` and `rawblock` messages via zmq for some features to work.\n\n### Build\n```shell script\n./gradlew build -x test\n```\n \n### Test\n```shell script\n./gradlew test integrationTest\n```\n\nTests in example application modules or modules that start a lot of docker containers \n(modules named \"*-example-application\" or \"spring-testcontainer-*\") are excluded from the\ndefault test phase and must be manually enabled if you want to run them.\nTo run all tests pass arguments `-PexampleTest` and `-PtestcontainerTest`:\n```shell script\n./gradlew test integrationTest -PtestcontainerTest -PexampleTest\n```\nBe aware this might take several minutes to complete (\u003e= 10 minutes).\n\n### Dependency Verification\nGradle is used for checksum and signature verification of dependencies.\n\n```shell script\n# write metadata for dependency verification\n./gradlew --write-verification-metadata pgp,sha256 --export-keys\n```\n\nSee [Gradle Userguide: Verifying dependencies](https://docs.gradle.org/current/userguide/dependency_verification.html)\nfor more information.\n\n### Checkstyle\n[Checkstyle](https://github.com/checkstyle/checkstyle) with adapted [google_checks](https://github.com/checkstyle/checkstyle/blob/master/src/main/resources/google_checks.xml)\nis used for checking Java source code for adherence to a Code Standard.\n\n```shell script\n# check for code standard violations with checkstyle\n./gradlew checkstyleMain\n```\n\n### SpotBugs\n[SpotBugs](https://spotbugs.github.io/) is used for static code analysis.\n\n```shell script\n# invoke static code analysis with spotbugs\n./gradlew spotbugsMain\n```\n\n\n## Contributing\nAll contributions and ideas are always welcome. For any question, bug or feature request, \nplease create an [issue](https://github.com/theborakompanioni/bitcoin-spring-boot-starter/issues). \nBefore you start, please read the [contributing guidelines](contributing.md).\n\n\n## Resources\n\n- Bitcoin: https://bitcoin.org/en/getting-started\n- Lightning Network: https://lightning.network/\n- JSR354 (GitHub): https://github.com/JavaMoney/jsr354-api\n- Spring Boot (GitHub): https://github.com/spring-projects/spring-boot\n---\n- Bitcoin Core (GitHub): https://github.com/bitcoin/bitcoin\n- lnd (GitHub): https://github.com/LightningNetwork/lnd\n- lnurl (GitHub): https://github.com/fiatjaf/lnurl-rfc\n- ElectrumX Server (GitHub): https://github.com/spesmilo/electrumx\n- Electrum Personal Server (GitHub): https://github.com/chris-belcher/electrum-personal-server\n- Electrum Client (GitHub): https://github.com/spesmilo/electrum\n- XChange (GitHub): https://github.com/knowm/XChange\n- bitcoin-kmp (GitHub): https://github.com/ACINQ/bitcoin-kmp\n- bitcoinj (GitHub): https://github.com/bitcoinj/bitcoinj\n- LightningJ (GitHub): https://github.com/lightningj-org/lightningj\n- ConsensusJ (GitHub): https://github.com/ConsensusJ/consensusj\n- JeroMq (GitHub): https://github.com/zeromq/jeromq\n- Project Reactor (GitHub): https://github.com/reactor/reactor-core\n- jMolecules (GitHub): https://github.com/xmolecules/jmolecules\n- Testcontainers (GitHub): https://github.com/testcontainers/testcontainers-java/\n- Tor: https://www.torproject.org/\n- Protocol Buffers: https://developers.google.com/protocol-buffers\n\n\n\n----\n\n|  | Donation Address |\n| --- | --- |\n| ♥ __BTC__ | 1Lw2kh9WzCActXSGHxyypGLkqQZfxDpw8v |\n| ♥ __ETH__ | 0xaBd66CF90898517573f19184b3297d651f7b90bf |\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdemining%2Fbitcoin-spring-boot-starter-google-colab","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fdemining%2Fbitcoin-spring-boot-starter-google-colab","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdemining%2Fbitcoin-spring-boot-starter-google-colab/lists"}