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.
 
 
 
JunZhang ff06110f3c
support BlueWallet (#33)
5 years ago
app support BlueWallet (#33) 5 years ago
coinlib multi watch-only-wallet support 5 years ago
encryption-core Electrum (#9) 5 years ago
gradle/wrapper genesis commit - open source 5 years ago
keystores genesis commit - open source 5 years ago
.gitignore genesis commit - open source 5 years ago
.gitmodules genesis commit - open source 5 years ago
LICENSE Initial commit 5 years ago
README.md update readme 5 years ago
build.gradle genesis commit - open source 5 years ago
gradle.properties genesis commit - open source 5 years ago
gradlew genesis commit - open source 5 years ago
gradlew.bat genesis commit - open source 5 years ago
settings.gradle genesis commit - open source 5 years ago

README.md

Cobo Vault

Cobo Vault is an air-gapped, open source hardware wallet that uses completely transparent QR code data transmissions. Visit the Cobo Vault official website to learn more about Cobo Vault.

You can also follow @Cobo Vault on Twitter.

Contents

Introduction

Cobo Vault runs as a standalone application on customized hardware and Android 8.1 Oreo (Go Edition). This app performs:

  1. Interaction with the user.
  2. Interaction with the mobile application Cobo Vault Mobile via QR code.
  3. Interaction with the Secure Element (SE) via serial port, open source SE firmware can be found at cobo-vault-se-firmware. Transaction data is signed by the Secure Element and the generated signature is sent back to the application. This signature and other necessary messages are displayed as a QR code. You can check the animation on our webpage to see the whole process. Users use their mobile or desktop application to acquire signed transaction data and broadcast it.

The hardware wallet application was programmed with Java language. The transaction related work is done by Typescript, for which open source code is available at crypto-coin-kit. The J2V8 framework is used as a bridge between Java and Typescript.

Clone

git clone git@github.com:CoboVault/cobo-vault-cold.git --recursive

Build

cd cobo-vault-cold
./gradlew assembleVault_v2Release

You can also build with IDEs, such as Android Studio,intelliJ.

Test

./gradlew test

Code Structure

Modules

app: Main application module

coinlib: Module for supported blockchains, currently included in 12 blockchains

encryption-core: Module for the Secure Element, includes commands, protocol, serialize/deserialize, serial port communication

Core Dependencies

  1. crypto-coin-message-protocol - protocol buffer of communication with the mobile application
  2. crypto-coin-kit - crypto-coin libraries
  3. cobo-vault-se-firmware - Secure Element firmware

Issues and PRs

Please submit any issues here. PRs are also welcome!

License

GPLv3 License This project is licensed under the GPL License. See the LICENSE file for details.