c2f37335b8
* Bump Scala versions Support Scala 2.12.9 and 2.13.0. To make this easier, we delete the `scripts` project. Everything that was in here was covered by content on the website. We also delete the `doc` folder, as that was a remnant from when `scripts` was called `doc`. * Crib uPickle akka-http support while we wait for publish * Fix compiler warnings * Add note on test logging to contribution guide * Reduce duplication in Blockchain implementation * Use Scala 2.12 for website * Introduce compat package object for collections converters * Fix Either compiler warnings * Add sync-chain and create-wallet docs from deleted scripts * Fix rebase goofup |
||
---|---|---|
.. | ||
src/main/scala/org/bitcoins/wallet | ||
README.md |
wallet
This is meant to be a stand alone project that can be used as a cold storage wallet and hot wallet.
Features
- utxo storage
- key storage
- key generation
- coin selection
- transaction building
- fee calculation
Design choices
- Private key material is just stored once, as the mnemonic code used to initialize the wallet
- Addresses we hand out to users are stored with their BIP44/BIP49/BIP84 paths and script types, so that everything we need for spending the money sent to an address is derivable.
- The wallet is a "dumb" wallet that acts mostly as a database of UTXOs, transactions and
addresses, with associated operations on these.
The wallet module does very little verification of incoming data about transactions,
UTXOs and reorgs. We're aiming to write small, self contained modules, that can be
composed together into more fully fledged systems. That means the
chain
andnode
modules does the actual verification of data we receive, andwallet
just blindly acts on this. This results in a design where you can swap outnode
for a Bitcoin Core full node, use it with hardware wallets, or something else entirely. However, that also means that users ofwallet
that doesn't want to use the other modules we provide have to make sure that the data they are feeding the wallet is correct.
Database structure
We store information in the following tables:
- TXOs - Contains both the information needed to spent it as well as information related to wallet state (confirmations, spent/unspent etc)
- Addresses - must reference the account it belongs to
- Accounts
Mnemonic encryption
The mnemonic seed to the Bitcoin-S wallet is written to disk, encrypted. The file name is
$HOME/.bitcoin-s/$NETWORK/encrypted_bitcoin-s_seed.json
. We store it in a JSON object
that looks like this:
{
"iv": "initializationVector",
"cipherText": "encryptedCipherText",
"salt": "saltUsedInEncryption"
}
The parts that's relevant to this part of the wallet is WalletStorage.scala
(where we handle
the actual reading from and writing to disk), EncryptedMnemonic.scala
(where we convert an
encrypted mnemonic to a cleartext mnemonic) and AesCrypt.scala
(where do the actual
encryption/decryption).
We use AES encryption for this, block cipher mode and PKCS5 padding. The wallet password is fed
into the PBKDF2 key stretching function, using SHA512 as the HMAC function. This happens in
PBKDF2.scala
.