Class BasicKeyChain
- java.lang.Object
- 
- org.bitcoinj.wallet.BasicKeyChain
 
- 
- All Implemented Interfaces:
- EncryptableKeyChain,- KeyChain
 
 public class BasicKeyChain extends java.lang.Object implements EncryptableKeyChain AKeyChainthat implements the simplest model possible: it can have keys imported into it, and just acts as a dumb bag of keys. It will, left to its own devices, always return the same key for usage by the wallet, although it will automatically add one to itself if it's empty or if encryption is requested.
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classBasicKeyChain.StateWhether this basic key chain is empty, full of regular (usable for signing) keys, or full of watching keys.- 
Nested classes/interfaces inherited from interface org.bitcoinj.wallet.KeyChainKeyChain.KeyPurpose
 
- 
 - 
Constructor SummaryConstructors Constructor Description BasicKeyChain()BasicKeyChain(KeyCrypter crypter)
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddEventListener(KeyChainEventListener listener)Adds a listener for events that are run when keys are added, on the user thread.voidaddEventListener(KeyChainEventListener listener, java.util.concurrent.Executor executor)Adds a listener for events that are run when keys are added, on the given executor.booleancheckAESKey(org.bouncycastle.crypto.params.KeyParameter aesKey)Check whether the AES key can decrypt the first encrypted key in the wallet.booleancheckPassword(java.lang.CharSequence password)Returns whether the given password is correct for this key chain.ECKeyfindKeyFromPubHash(byte[] pubKeyHash)ECKeyfindKeyFromPubKey(byte[] pubKey)java.util.List<ECKey>findKeysBefore(long timeSecs)Returns a list of all ECKeys created after the given UNIX time.ECKeyfindOldestKeyAfter(long timeSecs)Returns the first ECKey created after the given UNIX time, or null if there is none.static BasicKeyChainfromProtobufEncrypted(java.util.List<Protos.Key> keys, KeyCrypter crypter)Returns a new BasicKeyChain that contains all basic, ORIGINAL type keys and also any encrypted keys extracted from the list.static BasicKeyChainfromProtobufUnencrypted(java.util.List<Protos.Key> keys)Returns a new BasicKeyChain that contains all basic, ORIGINAL type keys extracted from the list.longgetEarliestKeyCreationTime()Returns the earliest creation time of keys in this chain, in seconds since the epoch.BloomFiltergetFilter(int size, double falsePositiveRate, long tweak)Gets a bloom filter that contains all of the public keys from this chain, and which will provide the given false-positive rate if it has size elements.ECKeygetKey(KeyChain.KeyPurpose ignored)Obtains a key intended for the given purpose.KeyCryptergetKeyCrypter()Returns theKeyCrypterin use or null if the key chain is not encrypted.java.util.List<ECKey>getKeys()Returns a copy of the list of keys that this chain is managing.java.util.List<ECKey>getKeys(KeyChain.KeyPurpose purpose, int numberOfKeys)Obtains a number of key/s intended for the given purpose.java.util.List<ListenerRegistration<KeyChainEventListener>>getListeners()booleanhasKey(ECKey key)Returns true if the given key is in the chain.voidimportKey(ECKey key)Imports a key to the key chain.intimportKeys(java.util.List<? extends ECKey> keys)intimportKeys(ECKey... keys)BasicKeyChain.StateisWatching()Returns whether this chain consists of pubkey only (watching) keys, regular keys (usable for signing), or has no keys in it yet at all (thus we cannot tell).intnumBloomFilterEntries()Returns the number of elements this chain wishes to insert into the Bloom filter.intnumKeys()Returns the number of keys this key chain manages.booleanremoveEventListener(KeyChainEventListener listener)Removes a listener for events that are run when keys are added.booleanremoveKey(ECKey key)Removes the given key from the keychain.java.util.List<Protos.Key>serializeToProtobuf()Returns a list of keys serialized to the bitcoinj protobuf format.BasicKeyChaintoDecrypted(java.lang.CharSequence password)Decrypts the key chain with the given password.BasicKeyChaintoDecrypted(org.bouncycastle.crypto.params.KeyParameter aesKey)Decrypt the key chain with the given AES key and whateverKeyCrypteris already set.BasicKeyChaintoEncrypted(java.lang.CharSequence password)Convenience wrapper aroundtoEncrypted(KeyCrypter, org.bouncycastle.crypto.params.KeyParameter)which uses the default Scrypt key derivation algorithm and parameters, derives a key from the given password and returns the created key.BasicKeyChaintoEncrypted(KeyCrypter keyCrypter, org.bouncycastle.crypto.params.KeyParameter aesKey)Encrypt the wallet using the KeyCrypter and the AES key.java.lang.StringtoString(boolean includePrivateKeys, org.bouncycastle.crypto.params.KeyParameter aesKey, NetworkParameters params)
 
- 
- 
- 
Constructor Detail- 
BasicKeyChainpublic BasicKeyChain() 
 - 
BasicKeyChainpublic BasicKeyChain(@Nullable KeyCrypter crypter)
 
- 
 - 
Method Detail- 
getKeyCrypter@Nullable public KeyCrypter getKeyCrypter() Returns theKeyCrypterin use or null if the key chain is not encrypted.- Specified by:
- getKeyCrypterin interface- EncryptableKeyChain
 
 - 
getKeypublic ECKey getKey(@Nullable KeyChain.KeyPurpose ignored) Description copied from interface:KeyChainObtains a key intended for the given purpose. The chain may create a new key, derive one, or re-use an old one.
 - 
getKeyspublic java.util.List<ECKey> getKeys(@Nullable KeyChain.KeyPurpose purpose, int numberOfKeys) Description copied from interface:KeyChainObtains a number of key/s intended for the given purpose. The chain may create new key/s, derive, or re-use an old one.
 - 
getKeyspublic java.util.List<ECKey> getKeys() Returns a copy of the list of keys that this chain is managing.
 - 
importKeyspublic int importKeys(ECKey... keys) 
 - 
importKeyspublic int importKeys(java.util.List<? extends ECKey> keys) 
 - 
importKeypublic void importKey(ECKey key) Imports a key to the key chain. If key is present in the key chain, ignore it.
 - 
findKeyFromPubHashpublic ECKey findKeyFromPubHash(byte[] pubKeyHash) 
 - 
findKeyFromPubKeypublic ECKey findKeyFromPubKey(byte[] pubKey) 
 - 
hasKeypublic boolean hasKey(ECKey key) Description copied from interface:KeyChainReturns true if the given key is in the chain.
 - 
numKeyspublic int numKeys() Description copied from interface:KeyChainReturns the number of keys this key chain manages.
 - 
isWatchingpublic BasicKeyChain.State isWatching() Returns whether this chain consists of pubkey only (watching) keys, regular keys (usable for signing), or has no keys in it yet at all (thus we cannot tell).
 - 
removeKeypublic boolean removeKey(ECKey key) Removes the given key from the keychain. Be very careful with this - losing a private key destroys the money associated with it.- Returns:
- Whether the key was removed or not.
 
 - 
getEarliestKeyCreationTimepublic long getEarliestKeyCreationTime() Description copied from interface:KeyChainReturns the earliest creation time of keys in this chain, in seconds since the epoch. This can return zero if at least one key does not have that data (was created before key timestamping was implemented). If there are no keys in the wallet, Long.MAX_VALUEis returned.- Specified by:
- getEarliestKeyCreationTimein interface- KeyChain
 
 - 
getListenerspublic java.util.List<ListenerRegistration<KeyChainEventListener>> getListeners() 
 - 
serializeToProtobufpublic java.util.List<Protos.Key> serializeToProtobuf() Description copied from interface:KeyChainReturns a list of keys serialized to the bitcoinj protobuf format.- Specified by:
- serializeToProtobufin interface- KeyChain
 
 - 
fromProtobufUnencryptedpublic static BasicKeyChain fromProtobufUnencrypted(java.util.List<Protos.Key> keys) throws UnreadableWalletException Returns a new BasicKeyChain that contains all basic, ORIGINAL type keys extracted from the list. Unrecognised key types are ignored.- Throws:
- UnreadableWalletException
 
 - 
fromProtobufEncryptedpublic static BasicKeyChain fromProtobufEncrypted(java.util.List<Protos.Key> keys, KeyCrypter crypter) throws UnreadableWalletException Returns a new BasicKeyChain that contains all basic, ORIGINAL type keys and also any encrypted keys extracted from the list. Unrecognised key types are ignored.- Throws:
- UnreadableWalletException.BadPassword- if the password doesn't seem to match
- UnreadableWalletException- if the data structures are corrupted/inconsistent
 
 - 
addEventListenerpublic void addEventListener(KeyChainEventListener listener) Description copied from interface:KeyChainAdds a listener for events that are run when keys are added, on the user thread.- Specified by:
- addEventListenerin interface- KeyChain
 
 - 
addEventListenerpublic void addEventListener(KeyChainEventListener listener, java.util.concurrent.Executor executor) Description copied from interface:KeyChainAdds a listener for events that are run when keys are added, on the given executor.- Specified by:
- addEventListenerin interface- KeyChain
 
 - 
removeEventListenerpublic boolean removeEventListener(KeyChainEventListener listener) Description copied from interface:KeyChainRemoves a listener for events that are run when keys are added.- Specified by:
- removeEventListenerin interface- KeyChain
 
 - 
toEncryptedpublic BasicKeyChain toEncrypted(java.lang.CharSequence password) Convenience wrapper aroundtoEncrypted(KeyCrypter, org.bouncycastle.crypto.params.KeyParameter)which uses the default Scrypt key derivation algorithm and parameters, derives a key from the given password and returns the created key.- Specified by:
- toEncryptedin interface- EncryptableKeyChain
- Returns:
- The derived key, in case you wish to cache it for future use.
 
 - 
toEncryptedpublic BasicKeyChain toEncrypted(KeyCrypter keyCrypter, org.bouncycastle.crypto.params.KeyParameter aesKey) Encrypt the wallet using the KeyCrypter and the AES key. A good default KeyCrypter to use isKeyCrypterScrypt.- Specified by:
- toEncryptedin interface- EncryptableKeyChain
- Parameters:
- keyCrypter- The KeyCrypter that specifies how to encrypt/ decrypt a key
- aesKey- AES key to use (normally created using KeyCrypter#deriveKey and cached as it is time consuming to create from a password)
- Throws:
- KeyCrypterException- Thrown if the wallet encryption fails. If so, the wallet state is unchanged.
 
 - 
toDecryptedpublic BasicKeyChain toDecrypted(java.lang.CharSequence password) Description copied from interface:EncryptableKeyChainDecrypts the key chain with the given password. SeeEncryptableKeyChain.toDecrypted(KeyParameter)for details.- Specified by:
- toDecryptedin interface- EncryptableKeyChain
 
 - 
toDecryptedpublic BasicKeyChain toDecrypted(org.bouncycastle.crypto.params.KeyParameter aesKey) Description copied from interface:EncryptableKeyChainDecrypt the key chain with the given AES key and whateverKeyCrypteris already set. Note that if you just want to spend money from an encrypted wallet, don't decrypt the whole thing first. Instead, set theSendRequest.aesKeyfield before asking the wallet to build the send.- Specified by:
- toDecryptedin interface- EncryptableKeyChain
- Parameters:
- aesKey- AES key to use (normally created using KeyCrypter#deriveKey and cached as it is time consuming to create from a password)
 
 - 
checkPasswordpublic boolean checkPassword(java.lang.CharSequence password) Returns whether the given password is correct for this key chain.- Specified by:
- checkPasswordin interface- EncryptableKeyChain
- Throws:
- java.lang.IllegalStateException- if the chain is not encrypted at all.
 
 - 
checkAESKeypublic boolean checkAESKey(org.bouncycastle.crypto.params.KeyParameter aesKey) Check whether the AES key can decrypt the first encrypted key in the wallet.- Specified by:
- checkAESKeyin interface- EncryptableKeyChain
- Returns:
- true if AES key supplied can decrypt the first encrypted private key in the wallet, false otherwise.
 
 - 
getFilterpublic BloomFilter getFilter(int size, double falsePositiveRate, long tweak) Description copied from interface:KeyChainGets a bloom filter that contains all of the public keys from this chain, and which will provide the given false-positive rate if it has size elements. Keep in mind that you will get 2 elements in the bloom filter for each key in the key chain, for the public key and the hash of the public key (address form). For this reason size should be at least 2x the result of KeyChain.numKeys().This is used to generate a BloomFilterwhich can beBloomFilter.merge(BloomFilter)d with another. It could also be used if you have a specific target for the filter's size.See the docs for BloomFilter(int, double, long)for a brief explanation of anonymity when using bloom filters, and for the meaning of these parameters.
 - 
numBloomFilterEntriespublic int numBloomFilterEntries() Description copied from interface:KeyChainReturns the number of elements this chain wishes to insert into the Bloom filter. The size passed toKeyChain.getFilter(int, double, long)should be at least this large.- Specified by:
- numBloomFilterEntriesin interface- KeyChain
 
 - 
findOldestKeyAfter@Nullable public ECKey findOldestKeyAfter(long timeSecs) Returns the first ECKey created after the given UNIX time, or null if there is none.
 - 
findKeysBeforepublic java.util.List<ECKey> findKeysBefore(long timeSecs) Returns a list of all ECKeys created after the given UNIX time.
 - 
toStringpublic java.lang.String toString(boolean includePrivateKeys, @Nullable org.bouncycastle.crypto.params.KeyParameter aesKey, NetworkParameters params)
 
- 
 
-