Follow this document to build the application on your platform
Qt libraries and Qt Creator
Download the Qt for your platform Qt offline installer and install it.
For Windows, download Visual studio 2017 or 2019.
Notes:
Qt version 5.12 or higher is recommended
Windows: Select compiler MSCV 2017 (or 2019) 64 - bit (or 32 bit depends on your OS)
Linux: Compiler GCC 64 or 32
MAC: Compiler GCC 64 or 32 (macOS)
Setup
Clone project and fetch submodules
git clone https://gitlab.com/nunchuck/nunchuck-qt
cd nunchuck-qt
git submodule update --init --recursive
wget http://download.oracle.com/berkeley-db/db-4.8.30.zip
unzip db-4.8.30.zip
cd db-4.8.30
cd build_unix/
../dist/configure --prefix=/usr/local --enable-cxx
make
make install
apt-get install -y libssl-dev
Build contrib/libnunchuk
Build Bitcoin Core (details)
cd contrib/libnunchuk/contrib/bitcoin
./autogen.sh
./configure --without-gui --disable-zmq --with-miniupnpc=no --with-incompatible-bdb --disable-bench --disable-tests -enable-module-ecdh # important
make -j8
cd ..
Build Sqlcipher (details)
cd libnunchuk/contrib/sqlcipher
./configure --enable-tempstore=yes CFLAGS="-DSQLITE_HAS_CODEC" LDFLAGS="-lcrypto"
make -j8
popd
cd ..
Build nunchuck-client-qt
Open Qt Creator
Open nunchuck-client-qt project via CMakeLists.txt
Select your Kit (include compiler) : Desktop Qt %{Qt:Version} GCC 64bit, (such as Desktop Qt 5.12.8 GCC 64bit)
Run qmake
Build
...
Run the application
udev rules
This directory contains all of the udev rules for the supported devices as retrieved from vendor websites and repositories.
These are necessary for the devices to be reachable on Linux environments.
References
(All rules): https://github.com/bitcoin-core/HWI/tree/master/hwilib/udev
Usage Apply these rules by copying them to
/etc/udev/rules.d/
and notifyingudevadm
.Your user will need to be added to the
plugdev
group, which needs to be created if it does not already exist. Commands:curl -OL https://raw.githubusercontent.com/bitcoin-core/HWI/master/hwilib/udev/20-hw1.rules curl -OL https://raw.githubusercontent.com/bitcoin-core/HWI/master/hwilib/udev/51-coinkite.rules curl -OL https://raw.githubusercontent.com/bitcoin-core/HWI/master/hwilib/udev/51-hid-digitalbitbox.rules curl -OL https://raw.githubusercontent.com/bitcoin-core/HWI/master/hwilib/udev/51-trezor.rules curl -OL https://raw.githubusercontent.com/bitcoin-core/HWI/master/hwilib/udev/51-usb-keepkey.rules curl -OL https://raw.githubusercontent.com/bitcoin-core/HWI/master/hwilib/udev/52-hid-digitalbitbox.rules curl -OL https://raw.githubusercontent.com/bitcoin-core/HWI/master/hwilib/udev/53-hid-bitbox02.rules curl -OL https://raw.githubusercontent.com/bitcoin-core/HWI/master/hwilib/udev/54-hid-bitbox02.rules curl -OL https://raw.githubusercontent.com/bitcoin-core/HWI/master/hwilib/udev/55-usb-jade.rules sudo cp *.rules /etc/udev/rules.d/ && \ sudo udevadm trigger && \ sudo udevadm control --reload-rules && \ sudo groupadd plugdev && \ sudo usermod -aG plugdev `whoami`
Run environment
In certain versions of Linux, Nunchuk may not be able to run. Here are a few tips:
-
There is no libfuse2 package by default. The AppImage distribution (and more generally, all existing AppImages) are built expecting libfuse2 support. This means that the AppImage will not run on Ubuntu 22.04 by default. You can try installing libfuse2 manually before running nunchuk:
sudo apt install libfuse2*
-
Certain Linux version needs to update their SSL package.
libssl1.1
is recommended. Try running the AppImage from the terminal withLD_DEBUG=libs
and see what libraries it complains about before the segfault.(Suggestion by a Nunchuk user)
-
Ubuntu update, should keep all the old repositories (end of the update process, when prompted to delete old repositories, files or keep them, just clicked no, keep old files)
(Suggestion by a Nunchuk user)
Prerequisites
Python 3, libusb are required.
Commands:
brew install libusb
brew install python