Skip to content
This repository has been archived by the owner on Oct 4, 2024. It is now read-only.

Export and limited import of private keys

jim618 edited this page Jan 6, 2012 · 40 revisions

MultiBit private key file format

This is the proposed format of the MultiBit private key file formulated after discussion with Andreas Schildbach on the bitcoinj mailing list.

  1. Keys are saved in an ASCII encoded text file.

  2. There is one key per line (empty lines and lines starting with '#' are ignored).

  3. Format of keys:

<Base58 encoded private key>[<any number of whitespace characters>[<key createdAt in UTC format>]]

  1. The Base58 encoded private keys are the same format as produced by the Satoshi client/ sipa dumpprivkey utility. The bitcoinj class DumpedPrivateKey can be used to produce and parse these. (See: http://code.google.com/p/bitcoin-wallet/source/browse/trunk/src/com/google/bitcoin/core/DumpedPrivateKey.java?r=410 )

  2. Any number of keys may be included in the key file, one per line.

  3. If createdAt is missing this means the date of key creation is unknown. In this case the blockchain has to most likely to be rewound back to the Genesis block or a site like blockexplorer.com is queried to determine the date of the earliest transaction for the imported key and that date is used.

  4. UTC format is specified by RFC 3339/ISO 8601 e.g: 2011-12-31T16:42:00Z . (See http://www.w3.org/TR/NOTE-datetime)

Development Notes

  1. It would be a good option to be able to print out QR codes of the keys similar to bitaddress.org for wallets with small numbers of keys. Freemoney suggested adding the 'createdAt' to the QR code / key swatch to enable automatic update of a MultiBit wallet.

  2. We currently need a 'createdAt' / 'first transaction date' so that we can replay the blocks in a similar manner to 'reset blockchain and transactions' to resurrect a wallet. (See: https://github.com/jim618/multibit/blob/master/src/main/java/org/multibit/action/ResetTransactionsSubmitAction.java ). This is in a human readable form to enable people to hand craft these files if they want to import their own private keys.

  3. When saving the private key file have the default file name suggested to the user of "name of wallet file"."key" . E.g. if the wallet is called 'multibit.wallet' suggest a key file name of 'multibit.key'.

  4. Encryption will be of the whole private key file. This will use AES256 with a common standardized Password-Based Key Derivation Function that has implementations in other languages as well.