:smiling_imp: TREZOR Communication Daemon (written in Go). https://github.com/trezor/trezord-go
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.
Pavol Rusnak cabc7c7f3a
bump version to 2.0.28
6 days ago
core core: Use idiomatic context, not struct channels 11 months ago
memorywriter debug: Trim github.com/.... from package name 1 year ago
release windows: fix last commit 9 months ago
scripts Finalized running bridge in docker 1 year ago
server whitelist SatoshiLabs dev servers 8 months ago
usb Add support for OpenBSD (#181) 1 month ago
vendor Reverted "go fmt" of vendor/ 1 year ago
wire debug: Remove manual function name from log 1 year ago
.dockerignore Added docker image 1 year ago
.gitignore macos: fix whitespace, gitignore 1 year ago
.gitlab-ci.yml Added gitlab config 1 year ago
.gometalinter travis: fix gometalinter 1 year ago
.travis.yml travis: fix gometalinter 1 year ago
CHANGELOG.md update changelog 8 months ago
COPYING add license 2 years ago
Dockerfile Finalized running bridge in docker 1 year ago
Gopkg.lock usb: move vendor/trezor/usbhid -> usb/lowlevel 1 year ago
Gopkg.toml usb: move vendor/trezor/usbhid -> usb/lowlevel 1 year ago
README.md Update README.md (#169) 8 months ago
VERSION bump version to 2.0.28 6 days ago
docker-compose.yml Finalized running bridge in docker 1 year ago
shell.nix nix: add shell.nix 1 year ago
trezord.go bump version to 2.0.28 6 days ago

README.md

trezord-go

Build Status gitter Go Report Card

Trezor Communication Daemon aka Trezor Bridge (written in Go)

Only compatible with Chrome (version 53 or later) and Firefox (version 55 or later).

status: spec Chrome Firefox Edge

Install and run from source

trezord-go requires go >= 1.6

go get github.com/trezor/trezord-go
go build github.com/trezor/trezord-go
./trezord-go -h

Update from source

go clean
go get -u github.com/trezor/trezord-go
go build -a github.com/trezor/trezord-go

On Linux don’t forget to install the udev rules if you are running from source and not using pre-built packages.

Guide to compiling packages

Prerequisites:

  • go get github.com/karalabe/xgo
  • docker pull karalabe/xgo-latest
  • make sure xgo and docker are in $PATH
  • cd release && make all; the installers are in installers

Quick guide to cross-compiling

Prerequisites:

  • go get github.com/karalabe/xgo
  • docker pull karalabe/xgo-latest

Compiling for officially supported platforms:

  • $GOPATH/bin/xgo -targets=windows/amd64,windows/386,darwin/amd64,linux/amd64,linux/386 .

Emulator support

Trezord supports emulators for both Trezor versions. However, you need to enable it manually; it is disabled by default. After enabling, services that work with emulator can work with all services that support trezord.

To enable emulator, run trezord with a parameter -e followed by port, for every emulator with an enabled port

./trezord -e 21324

If you want to run this automatically on linux, do

sudo systemctl edit --full trezord.service

and edit the service file (and maybe restart the trezord service). On mac, you will need to edit

/Library/LaunchAgents/com.bitcointrezor.trezorBridge.trezord.plist

and edit the last <string> in the plist. (And also probably restart the pc.)

You can disable all USB in order to run on some virtuaized environments, for example Travis

./trezord -e 21324 -u=false

API documentation

trezord-go starts a HTTP server on http://localhost:21325. AJAX calls are only enabled from trezor.io subdomains.

Server supports following API calls:

url
method
parameters result type description
/
POST
{version: string} Returns current version of bridge
/enumerate
POST
Array<{path: string,
session: string | null}>
Lists devices.
path uniquely defines device between more connected devices. Two different devices (or device connected and disconnected) will return different paths.
If session is null, nobody else is using the device; if it’s string, it identifies who is using it.
/listen
POST
request body: previous, as JSON like enumerate Listen to changes and returns either on change or after 30 second timeout. Compares change from previous that is sent as a parameter. “Change” is both connecting/disconnecting and session change.
/acquire/PATH/PREVIOUS
POST
PATH: path of device
PREVIOUS: previous session (or string “null”)
{session: string} Acquires the device at PATH. By “acquiring” the device, you are claiming the device for yourself.
Before acquiring, checks that the current session is PREVIOUS.
If two applications call acquire on a newly connected device at the same time, only one of them succeed.
/release/SESSION
POST
SESSION: session to release {} Releases the device with the given session.
By “releasing” the device, you claim that you don’t want to use the device anymore.
/call/SESSION
POST
SESSION: session to call

request body: hexadecimal string
hexadecimal string Both input and output are hexadecimal, encoded in following way:
first 2 bytes (4 characters in the hexadecimal) is the message type
next 4 bytes (8 in hex) is length of the data
the rest is the actual encoded protobuf data.
Protobuf messages are defined in this protobuf file and the app, calling trezord, should encode/decode it itself.
/post/SESSION
POST
SESSION: session to call

request body: hexadecimal string
0 Similar to call, just doesn’t read response back. Usable mainly for debug link.
/read/SESSION
POST
SESSION: session to call 0 Similar to call, just doesn’t post, only reads. Usable mainly for debug link.

Trezord has support for debug link.

To support an emulator with debug link, run

./trezord -ed 21324:21325 -u=false

this will detect emulator debug link on port 21325, with regular device on 21324.

To support WebUSB devices with debug link, no option is needed, just run trezord-go.

In the enumerate and listen results, there are now two new fields: debug and debugSession. debug signals that device can receive debug link messages.

Session management is separate for debug link and normal interface, so you can have two applications - one controlling trezor and one “normal”.

There are new calls:

  • /debug/acquire/PATH, which has the same path as normal acquire, and returns a SESSION
  • /debug/release/SESSION releases session
  • /debug/call/SESSION, /debug/post/SESSION, /debug/read/SESSION work as with normal interface

The session IDs for debug link start with the string “debug”.