Skip to main content

Implements A Bitcoin Core API which querying an Electrum

Project description

Spectrum - Specter Desktop + Electrum

This is a electrum-adapter. It exposes a Bitcoin-Core style API while using an electron API in the backend. It might be useful in specific usecases, e.g. having better performance when connecting to a electrum-server via Tor. In order to do that, it needs a Database. Quite easily you can use a kind of builtin SQLite. Depending on your usecase, you might want to use an external DB.

Modes of usage

This can be used either in standalone mode or as a specter-extension. The second option is probably the main use-case.

Standalone

Get this to work with something like that:

python3 --version # Make sure you have at least 3.8. Might also work with lower versions though
virtualenv --python=python3 .env
. ./.env/bin/activate
pip3 install -e .

# If you have a electrum server running on localhost:
python3 -m cryptoadvance.spectrum server --config cryptoadvance.spectrum.config.NigiriLocalElectrumLiteConfig

# If you want to run on mainnet and use emzy's Server
python3 -m cryptoadvance.spectrum server --config cryptoadvance.spectrum.config.EmzyElectrumLiteConfig

# Using Emzy's server but with a postgres
export DB_USERNAME=bla
export DB_PASSWORD=blub
python3 -m cryptoadvance.spectrum server --config cryptoadvance.spectrum.config.EmzyElectrumPostgresConfig

Check the config.py for the env-vars which need to be exported in order to connect to something different than localhost.

Specter Extension

In order to get a development environment:

virtualenv --python=python3 .env
. ./.env/bin/activate
pip3 install -e .
pip3 install cryptoadvance.specter
python3 -m cryptoadvance.specter server --config DevelopmentConfig --debug

TODO:

  • refill keypool when address is used or new address is requested
  • flask debug=True flag creates two electrum sockets that notify twice - this causes duplications in the database
  • reconnect with electrum on disconnect
  • add support for credentials / cookie file for RPC calls

Run the Tests

pip3 install -e ".[test]"
pytest

Development

Before your create a PR, make sure to blackify all your changes. In order to automate that, there is a git pre-commit hook which you can simply install like this:

pre-commit install

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cryptoadvance_spectrum-0.7.0.tar.gz (60.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

cryptoadvance_spectrum-0.7.0-py3-none-any.whl (38.8 kB view details)

Uploaded Python 3

File details

Details for the file cryptoadvance_spectrum-0.7.0.tar.gz.

File metadata

  • Download URL: cryptoadvance_spectrum-0.7.0.tar.gz
  • Upload date:
  • Size: 60.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for cryptoadvance_spectrum-0.7.0.tar.gz
Algorithm Hash digest
SHA256 6cd8858fa07668536345ecab08b4143e28055d7524c9b27b8c885c5b98730879
MD5 5fe053b7fdcc436ae514f0a3d65f65c0
BLAKE2b-256 10761155ce3f4025f8769093bb8bbe71e0dacc256ed89d5646afc4a7bb75ec6f

See more details on using hashes here.

Provenance

The following attestation bundles were made for cryptoadvance_spectrum-0.7.0.tar.gz:

Publisher: pypi-publish.yml on cryptoadvance/spectrum

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cryptoadvance_spectrum-0.7.0-py3-none-any.whl.

File metadata

File hashes

Hashes for cryptoadvance_spectrum-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 40b31d38ad40c85438bc44d9243edb9ddbaf331c4468a48ebc0f40a109b43a62
MD5 422ed53ef5ce3b228fd184972946ea11
BLAKE2b-256 514d78e440c582b33adab22cbb91000b9875b29c0f4f70249842d764e67881a5

See more details on using hashes here.

Provenance

The following attestation bundles were made for cryptoadvance_spectrum-0.7.0-py3-none-any.whl:

Publisher: pypi-publish.yml on cryptoadvance/spectrum

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page