about summary refs log tree commit diff
diff options
context:
space:
mode:
authorDmitry Ivankov <divanorama@gmail.com>2023-04-24 01:14:35 +0200
committerDmitry Ivankov <divanorama@gmail.com>2023-04-24 19:32:21 +0200
commit51b96d8e85a27800a6c710cc63189ca8dd6651b8 (patch)
tree9a98375f72f5401e6efcaf36622263d7de3dc43b
parent5b04692dc270a50b6bce7dfe175364ac912db254 (diff)
electrum: fix ledger devices support
New Ledger protocol needs a new dependency to work
https://github.com/spesmilo/electrum/pull/8041
-rw-r--r--pkgs/applications/misc/electrum/default.nix1
-rw-r--r--pkgs/development/python-modules/ledger-bitcoin/default.nix40
-rw-r--r--pkgs/development/python-modules/ledgercomm/default.nix30
-rw-r--r--pkgs/top-level/python-packages.nix4
4 files changed, 75 insertions, 0 deletions
diff --git a/pkgs/applications/misc/electrum/default.nix b/pkgs/applications/misc/electrum/default.nix
index 08d887f7e9269..ca8001760a2df 100644
--- a/pkgs/applications/misc/electrum/default.nix
+++ b/pkgs/applications/misc/electrum/default.nix
@@ -72,6 +72,7 @@ python3.pkgs.buildPythonApplication {
     tlslite-ng
     # plugins
     btchip-python
+    ledger-bitcoin
     ckcc-protocol
     keepkey
     trezor
diff --git a/pkgs/development/python-modules/ledger-bitcoin/default.nix b/pkgs/development/python-modules/ledger-bitcoin/default.nix
new file mode 100644
index 0000000000000..edfc9c7f22f2b
--- /dev/null
+++ b/pkgs/development/python-modules/ledger-bitcoin/default.nix
@@ -0,0 +1,40 @@
+{ lib
+, buildPythonPackage
+, fetchPypi
+, setuptools
+, ledgercomm
+, packaging
+, typing-extensions
+ }:
+
+buildPythonPackage rec {
+  pname = "ledger-bitcoin";
+  version = "0.2.1";
+  format = "pyproject";
+
+  src = fetchPypi {
+    inherit version;
+    pname = "ledger_bitcoin";
+    hash = "sha256-AWl/q2MzzspNIo6yf30S92PgM/Ygsb+1lJsg7Asztso=";
+  };
+
+  nativeBuildInputs = [
+    setuptools
+  ];
+
+  propagatedBuildInputs = [
+    ledgercomm
+    packaging
+    typing-extensions
+  ];
+
+  pythonImportsCheck = [
+    "ledger_bitcoin"
+  ];
+
+  meta = with lib; {
+    description = "Client library for Ledger Bitcoin application.";
+    homepage = "https://github.com/LedgerHQ/app-bitcoin-new/tree/develop/bitcoin_client/ledger_bitcoin";
+    license = licenses.asl20;
+  };
+}
diff --git a/pkgs/development/python-modules/ledgercomm/default.nix b/pkgs/development/python-modules/ledgercomm/default.nix
new file mode 100644
index 0000000000000..092378a142b8f
--- /dev/null
+++ b/pkgs/development/python-modules/ledgercomm/default.nix
@@ -0,0 +1,30 @@
+{ lib
+, buildPythonPackage
+, fetchPypi
+, setuptools
+ }:
+
+buildPythonPackage rec {
+  pname = "ledgercomm";
+  version = "1.1.2";
+  format = "pyproject";
+
+  src = fetchPypi {
+    inherit pname version;
+    hash = "sha256-izOPbwv+34Xq8mpq9+QRIGhd+z4pVnGJSMnYOktRVbs=";
+  };
+
+  nativeBuildInputs = [
+    setuptools
+  ];
+
+  pythonImportsCheck = [
+    "ledgercomm"
+  ];
+
+  meta = with lib; {
+    description = "Python library to send and receive APDU through HID or TCP socket. It can be used with a Ledger Nano S/X or with the Speculos emulator.";
+    homepage = "https://github.com/LedgerHQ/ledgercomm";
+    license = licenses.mit;
+  };
+}
diff --git a/pkgs/top-level/python-packages.nix b/pkgs/top-level/python-packages.nix
index f6af5c709edb6..cc465f603dcbc 100644
--- a/pkgs/top-level/python-packages.nix
+++ b/pkgs/top-level/python-packages.nix
@@ -5426,8 +5426,12 @@ self: super: with self; {
 
   ledger_agent = callPackage ../development/python-modules/ledger_agent { };
 
+  ledger-bitcoin = callPackage ../development/python-modules/ledger-bitcoin { };
+
   ledgerblue = callPackage ../development/python-modules/ledgerblue { };
 
+  ledgercomm = callPackage ../development/python-modules/ledgercomm { };
+
   ledgerwallet = callPackage ../development/python-modules/ledgerwallet {
     inherit (pkgs.darwin.apple_sdk.frameworks) AppKit;
   };