76999cc40e
This makes the command ‘nix-env -qa -f. --arg config '{skipAliases = true;}'’ work in Nixpkgs. Misc... - qtikz: use libsForQt5.callPackage This ensures we get the right poppler. - rewrites: docbook5_xsl -> docbook_xsl_ns docbook_xml_xslt -> docbook_xsl diffpdf: fixup
146 lines
3.9 KiB
Nix
146 lines
3.9 KiB
Nix
{ stdenv
|
|
, autoreconfHook
|
|
, curl
|
|
, fetchFromGitHub
|
|
, git
|
|
, libcap
|
|
, libevent
|
|
, libtool
|
|
, libqrencode
|
|
, udev
|
|
, libusb
|
|
, makeWrapper
|
|
, pkgconfig
|
|
, qtbase
|
|
, qttools
|
|
, qtwebsockets
|
|
, qtmultimedia
|
|
, udevRule51 ? ''
|
|
, SUBSYSTEM=="usb", TAG+="uaccess", TAG+="udev-acl", SYMLINK+="dbb%n", ATTRS{idVendor}=="03eb", ATTRS{idProduct}=="2402"
|
|
, ''
|
|
, udevRule52 ? ''
|
|
, KERNEL=="hidraw*", SUBSYSTEM=="hidraw", ATTRS{idVendor}=="03eb", ATTRS{idProduct}=="2402", TAG+="uaccess", TAG+="udev-acl", SYMLINK+="dbbf%n"
|
|
, ''
|
|
, writeText
|
|
}:
|
|
|
|
# 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
|
|
# NixOS.
|
|
|
|
# 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.
|
|
let
|
|
copyUdevRuleToOutput = name: rule:
|
|
"cp ${writeText name rule} $out/etc/udev/rules.d/${name}";
|
|
in stdenv.mkDerivation rec {
|
|
name = "digitalbitbox-${version}";
|
|
version = "2.2.2";
|
|
|
|
src = fetchFromGitHub {
|
|
owner = "digitalbitbox";
|
|
repo = "dbb-app";
|
|
rev = "v${version}";
|
|
sha256 = "1r77fvqrlaryzij5dfbnigzhvg1d12g96qb2gp8dy3xph1j0k3s1";
|
|
};
|
|
|
|
nativeBuildInputs = with stdenv.lib; [
|
|
autoreconfHook
|
|
curl
|
|
git
|
|
makeWrapper
|
|
pkgconfig
|
|
qttools
|
|
];
|
|
|
|
buildInputs = [
|
|
# TODO: remove libcap when pruneLibtoolFiles applies to pulseaudio.
|
|
libcap
|
|
libevent
|
|
libtool
|
|
udev
|
|
libusb
|
|
libqrencode
|
|
|
|
qtbase
|
|
qtwebsockets
|
|
qtmultimedia
|
|
];
|
|
|
|
LUPDATE="${qttools.dev}/bin/lupdate";
|
|
LRELEASE="${qttools.dev}/bin/lrelease";
|
|
MOC="${qtbase.dev}/bin/moc";
|
|
QTDIR="${qtbase.dev}";
|
|
RCC="${qtbase.dev}/bin/rcc";
|
|
UIC="${qtbase.dev}/bin/uic";
|
|
|
|
configureFlags = [
|
|
"--enable-libusb"
|
|
];
|
|
|
|
hardeningDisable = [
|
|
"format"
|
|
];
|
|
|
|
postInstall = ''
|
|
mkdir -p "$out/lib"
|
|
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
|
|
rm -rf $PWD
|
|
|
|
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}
|
|
'';
|
|
|
|
enableParallelBuilding = true;
|
|
|
|
meta = with stdenv.lib; {
|
|
description = "A QT based application for the Digital Bitbox hardware wallet";
|
|
longDescription = ''
|
|
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; [
|
|
vidbina
|
|
];
|
|
platforms = platforms.linux;
|
|
};
|
|
}
|