You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Go to file
matejcik 9a27ada067
build: more resilient setup.py build process
6 years ago
bash_completion.d add initial bash_completion script 8 years ago
docs Improve / simplify documentation 7 years ago
tools remove remaining usages of expand_path 6 years ago
trezorlib Revert "device_tests: update test_bip32_speed cache-speed ratio to 1.2x" 6 years ago
vendor vendor: update trezor-common 6 years ago
.flake8 flake8: be stricter 6 years ago
.gitignore build: preprocess messages and assets in setup.py 6 years ago
.gitmodules add submodule trezor-common 6 years ago
.travis.yml travis: set virtualenv version to restore build on py33 6 years ago
CHANGELOG.md add changelog 6 years ago
COPYING python-trezor is LGPLv3 9 years ago
MANIFEST.in build: include tools in sdist 6 years ago
README.rst docs: contributing info for the new submodule 6 years ago
requirements-dev.txt build: add flake8 to dev requirements 6 years ago
requirements-optional.txt build: move ethereum requirements to their own extra 6 years ago
requirements.txt build: require typing module for python < 3.4 6 years ago
setup.py build: more resilient setup.py build process 6 years ago
tox.ini transport: fix all_transports when required modules are missing (#232) 6 years ago
trezorctl stellar: better way to handle default path 6 years ago
trigger-travis.sh Merge branch 'master' into matejcik/refactor 6 years ago

README.rst

python-trezor
=============

.. image:: https://travis-ci.org/trezor/python-trezor.svg?branch=master
    :target: https://travis-ci.org/trezor/python-trezor

.. image:: https://badges.gitter.im/trezor/community.svg
    :target: https://gitter.im/trezor/community

Python library and commandline client for communicating with TREZOR Hardware Wallet

See https://trezor.io for more information

Install
-------

Linux requirements:

.. code::

  sudo apt-get install python3-dev cython3 libusb-1.0-0-dev libudev-dev git

Linux & Mac Python requirements:

.. code::

  sudo -H pip3 install setuptools
  sudo -H pip3 install -r requirements.txt
  sudo -H pip3 install trezor

On FreeBSD you can install the packages:

.. code::

  pkg install security/py-trezor

or build via ports:

.. code::

  cd /usr/ports/security/py-trezor
  make install clean


Commandline client (trezorctl)
---------------------------

The included ``trezorctl`` python script can perform various tasks such as changing setting in the Trezor, signing transactions, retrieving account info and addresses. See the `docs/ <docs/>`_ sub folder for detailed examples and options.

NOTE: An older version of the ``trezorctl`` command is `available for Debian Stretch <https://packages.debian.org/en/stretch/python-trezor>`_ (and comes pre-installed on `Tails OS <https://tails.boum.org/>`_).


Python Library
--------------

You can use this python library to interact with a Bitcoin Trezor and use its capabilities in your application.
See examples here in the `tools/ <tools/>`_ sub folder.


PIN Entering
------------

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**


Contributing
------------

Python-trezor pulls coins info and protobuf messages from `trezor-common <https://github.com/trezor/trezor-common>`_ repository. If you are
developing new features for Trezor, you will want to start there. Once your changes are accepted to ``trezor-common``, you can make a PR
against this repository. Don't forget to update the submodule with:

.. code::

  git submodule update --init --remote

Then, rebuild the protobuf messages and get ``coins.json`` by running:

.. code::

  python3 setup.py prebuild

To get support for BTC-like coins, these steps are enough and no further changes to the library are necessary.