···
+
, SUBSYSTEM=="usb", TAG+="uaccess", TAG+="udev-acl", SYMLINK+="dbb%n", ATTRS{idVendor}=="03eb", ATTRS{idProduct}=="2402"
+
, KERNEL=="hidraw*", SUBSYSTEM=="hidraw", ATTRS{idVendor}=="03eb", ATTRS{idProduct}=="2402", TAG+="uaccess", TAG+="udev-acl", SYMLINK+="dbbf%n"
+
# Enabling the digitalbitbox program
+
# programs.digitalbitbox.enable = true;
+
# will install the digitalbitbox package and enable the corresponding hardware
+
# module and is by far the easiest way to get started with the Digital Bitbox on
+
# In case you install the package only, please be aware that you may need to
+
# apply some udev rules to allow the application to identify and access your
+
# wallet. In a nixos-configuration, one may accomplish this by enabling the
+
# digitalbitbox hardware module
+
# hardware.digitalbitbox.enable = true;
+
# or by adding the digitalbitbox package to system.udev.packages
+
# system.udev.packages = [ pkgs.digitalbitbox ];
+
# See https://digitalbitbox.com/start_linux for more information.
+
copyUdevRuleToOutput = name: rule:
+
"cp ${writeText name rule} $out/etc/udev/rules.d/${name}";
+
in stdenv.mkDerivation rec {
+
name = "digitalbitbox-${version}";
+
src = fetchFromGitHub {
+
owner = "digitalbitbox";
+
sha256 = "1r77fvqrlaryzij5dfbnigzhvg1d12g96qb2gp8dy3xph1j0k3s1";
+
nativeBuildInputs = with stdenv.lib; [
+
buildInputs = with stdenv.lib; [
+
LUPDATE="${qttools.dev}/bin/lupdate";
+
LRELEASE="${qttools.dev}/bin/lrelease";
+
MOC="${qtbase.dev}/bin/moc";
+
RCC="${qtbase.dev}/bin/rcc";
+
UIC="${qtbase.dev}/bin/uic";
+
cp src/libbtc/.libs/*.so* $out/lib
+
cp src/libbtc/src/secp256k1/.libs/*.so* $out/lib
+
cp src/hidapi/libusb/.libs/*.so* $out/lib
+
cp src/univalue/.libs/*.so* $out/lib
+
# [RPATH][patchelf] Avoid forbidden reference error
+
wrapProgram "$out/bin/dbb-cli" --prefix LD_LIBRARY_PATH : "$out/lib"
+
wrapProgram "$out/bin/dbb-app" --prefix LD_LIBRARY_PATH : "$out/lib"
+
# Provide udev rules as documented in https://digitalbitbox.com/start_linux
+
mkdir -p "$out/etc/udev/rules.d"
+
${copyUdevRuleToOutput "51-hid-digitalbox.rules" udevRule51}
+
${copyUdevRuleToOutput "52-hid-digitalbox.rules" udevRule52}
+
meta = with stdenv.lib; {
+
description = "A QT based application for the Digital Bitbox hardware wallet";
+
Digital Bitbox provides dbb-app, a GUI tool, and dbb-cli, a CLI tool, to manage Digital Bitbox devices.
+
This package will only install the dbb-app and dbb-cli, however; in order for these applications to identify and access Digital Bitbox devices, one may want to enable the digitalbitbox hardware module by adding
+
hardware.digitalbitbox.enable = true;
+
to the configuration which is equivalent to adding this package to the udev.packages list.
+
The easiest way to use the digitalbitbox package in NixOS is by adding
+
programs.digitalbitbox.enable = true;
+
to the configuration which installs the package and enables the hardware module.
+
homepage = "https://digitalbitbox.com/";
+
license = licenses.mit;
+
maintainers = with maintainers; [
+
platforms = platforms.linux;