Client side implementation for TREZOR-compatible Bitcoin hardware wallets.
See http://bitcointrezor.com for more information.
(Run with sudo if not running in superuser mode under Linux)
pip install trezor
On Linux you might need to run these commands first:
also found in tools/helloworld.py
#!/usr/bin/env pythonfromtrezorlib.clientimportTrezorClientfromtrezorlib.transport_hidimportHidTransportdefmain(): # List all connected TREZORs on USBdevices=HidTransport.enumerate() # Check whether we found anyiflen(devices) ==0: print('No TREZOR found') return# Use first connected devicetransport=HidTransport(devices[0]) # Creates object for manipulating TREZORclient=TrezorClient(transport) # Print out TREZOR's features and settingsprint(client.features) # Get the first address of first BIP44 account# (should be the same address as shown in mytrezor.com)bip32_path=client.expand_path("44'/0'/0'/0/0") address=client.get_address('Bitcoin', bip32_path) print('Bitcoin address:', address) client.close() if__name__=='__main__': main()When you are asked for PIN, you have to enter scrambled PIN. Follow the numbers shown on TREZOR display and enter the their positions using the numeric keyboard mapping:
| 7 | 8 | 9 |
| 4 | 5 | 6 |
| 1 | 2 | 3 |
Example: your PIN is 1234 and TREZOR is displaying the following:
| 2 | 8 | 3 |
| 5 | 4 | 6 |
| 7 | 9 | 1 |
You have to enter: 3795