about summary refs log tree commit diff
diff options
context:
space:
mode:
authorPavol Rusnak <pavol@rusnak.io>2023-04-24 22:30:56 +0200
committerGitHub <noreply@github.com>2023-04-24 22:30:56 +0200
commitd15bd5c53bda4c190e02431bda5d9c9c2b71a230 (patch)
treeff9ea5c3fa326faf3a667d23fb1c91f375b69727
parent90a8b9e3febfc1e615ff8308ed2418d48ba4eb6a (diff)
parent51b96d8e85a27800a6c710cc63189ca8dd6651b8 (diff)
Merge pull request #227894 from divanorama/electrum_new_ledger_protocol
electrum: fix ledger devices support
-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 5d124af9813b2..7517b55ec3f99 100644
--- a/pkgs/top-level/python-packages.nix
+++ b/pkgs/top-level/python-packages.nix
@@ -5428,8 +5428,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;
   };