Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/triska/bitcoinolog
Reason about Bitcoin addresses with Prolog
https://github.com/triska/bitcoinolog
bitcoin bitcoin-wallet cryptocurrency elliptic-curves offline-capable prolog
Last synced: 3 months ago
JSON representation
Reason about Bitcoin addresses with Prolog
- Host: GitHub
- URL: https://github.com/triska/bitcoinolog
- Owner: triska
- Created: 2017-06-11T22:53:01.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-03-17T08:15:48.000Z (10 months ago)
- Last Synced: 2024-09-28T20:23:11.604Z (4 months ago)
- Topics: bitcoin, bitcoin-wallet, cryptocurrency, elliptic-curves, offline-capable, prolog
- Language: Prolog
- Homepage: https://www.metalevel.at/bitcoinolog/
- Size: 24.4 KB
- Stars: 21
- Watchers: 5
- Forks: 5
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Bitcoinolog: Reason about Bitcoin addresses with Prolog
## Offline Bitcoin wallet creation
*Bitcoinolog* uses [Prolog](https://www.metalevel.at/prolog) and the
[`crrl`](https://github.com/pornin/crrl/) crate to create Bitcoin
addresses and private keys with several nice properties:- generated keys are **cryptographically secure** to the extent that
`crrl` guarantees this property
- the Prolog code is **short** and uses **no external programs**
- keys can be generated **offline**, on a machine that has no
Internet connection.Bitcoinolog requires Scryer Prolog.
To try it, download [**`bitcoinolog.pl`**](bitcoinolog.pl)
and run:$ scryer-prolog bitcoinolog.pl
Here is an example query that you can try:
?- repeat,
new_private_key(PrivateKey),
private_key_to_public_key(PrivateKey, PublicKey),
public_key_to_address(PublicKey, Address),
private_key_to_wif(PrivateKey, WIF),
format:portray_clause((address_key(A, K) :- A=Address, K=WIF)),
false.This Prolog query *generates* Bitcoin addresses and private keys
in Wallet Import Format (WIF), yielding:address_key(A, B) :-
A="1Nis7V58Mb839kXb9RZMDzAN6ZTQbNfGC4",
B="L1T3AnvHDtaAhkr9zxKokKzqphx26cvdoU8HbEifsWH6chy4bzYS".
address_key(A, B) :-
A="1D34yFJGRtiLuW2abwPBfks4cCi1Usp9a3",
B="L5NUQyHr5zaJgG9ALbVGD1tcxodf51kUvQDANcNhpej1itV9KNLD".
address_key(A, B) :-
A="12TUkSL2yyiiAD2f4zAcGDQPev2FSQmVwF",
B="KyR4Ut96DFadt1LbdZNFzCLuJ2Hw9KSeX6wfMv2dnQwgympWZyyU".
address_key(A, B) :-
A="1HySx6JBQKZoPqjUPVnbitFASKJjdAWWzx",
B="Kxcr5G39Y7jUvsmsoDK5TnezsQ4FkTcYRVTcxzTT3uLYKnHFYiVh".For more information, visit:
[**https://www.metalevel.at/bitcoinolog/**](https://www.metalevel.at/bitcoinolog/)
**Video**: https://www.metalevel.at/prolog/videos/bitcoinolog
## Elliptic Curve Cryptography in Prolog
Bitcoinolog uses
[**`library(crypto)`**](https://github.com/mthom/scryer-prolog/blob/master/src/lib/crypto.pl)
for hashing and reasoning over *elliptic curves*.Alternatively, you can use [**`ecclog.pl`**](ecclog.pl) for reasoning
over elliptic curves *in Prolog*. Simply use the `ecc_`
predicates instead of those starting with `crypto_`:- `crypto_curve_generator/2` → `ecc_curve_generator/2`
- `crypto_curve_order/2` → `ecc_curve_order/2`
- etc.Internally, `library(ecc)` uses
[CLP(ℤ) constraints](https://www.metalevel.at/prolog/clpz)
to facilitate
[declarative debugging](https://www.metalevel.at/prolog/debugging).