-
Notifications
You must be signed in to change notification settings - Fork 3.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
"ModuleNotFoundError: No module named 'btchip'", however, it also won't let me install 'btchip' #9370
Comments
Similar issue: #6928 . Seems also somewhat related LedgerHQ/btchip-python#42 |
Related issue pypa/setuptools#3801 with same error message as this issue :
in that case an upgrade of setuptools causing btchip to regress. |
I have tried using earlier versions of setuptools, earlier versions of python (3.10.xx as opposed the 3.12 that Ubuntu 24.04 comes with), but to no avail, and I am still unable to perform I have however been able to duplicate the this error with the suspected workflow on a different machine. I installed
The Ubuntu 24.04 installation where I got the error, I also upgraded earlier this year from Ubuntu 22.04. I have not tried yet to install |
Can confirm that also on a completely clean Ubuntu 24.04 installation What I am not sure about is that https://github.com/LedgerHQ/btchip-python has been archived on Oct 16, 2024 and is read-only, yet electrum is still requiring the btchip-python library. I will investigate with ledger further. |
Decided to leave open for a bit longer in case there are some further thoughts/feedback on this. Not being able to use ledger on electrum in Ubuntu 24.04 is not ideal. |
As it's noted here, So it might be a good time to pull the plug on HW.1! 🫡 |
I would be happy to not install
when starting up electrum would still let me access my wallet that was set up in electrum with my Ledger Nano S, but I am unable to access my wallet at all, seemingly because of that error. From your answer is seems there is no need for However, I am not clear on as to why the error message started to occur after upgrading from Ubuntu 22.04 to 24.04. I was running electrum 4.5.5 fine on Ubuntu 22.04 and then upgraded to Ubuntu 24.04 while at the same upgrading to electrum 4.5.8, when I started receiving the above error. I tried downgrading electrum back to 4.5.5, but still the same error. Wondering if anyone has thoughts on why an Ubuntu upgrade could have caused the error. |
btchip-python is unmaintained and it uses syntax in its setup.py file that is no longer understood by modern setuptools. The new ubuntu version uses newer setuptools ( |
As a temporary fix, this patch will allow diff --git a/setup.py b/setup.py
index accfe24..5ab305d 100644
--- a/setup.py
+++ b/setup.py
@@ -17,7 +17,7 @@ setup(
packages=find_packages(),
install_requires=['hidapi>=0.7.99', 'ecdsa>=0.9'],
extras_require = {
- 'smartcard': [ 'python-pyscard>=1.6.12-4build1' ]
+ 'smartcard': [ 'pyscard>=1.6.12' ]
},
include_package_data=True,
zip_safe=False, |
We can either
But yeah, maybe easiest to drop support. There has been a deprecation warning shown to users in the GUI for 2 years now: |
While it would be elegant to support this hw for another 'major' release (4.6.x), we can always point users to older electrum releases to move their coins. It doesn't make sense to put time into this if the manufacturer doesn't care, and at some point we'll have to port over anyway. |
I had posted this issue also in LedgerHQ/app-bitcoin-new#309 and manufacturer shows no opposition to drop I will attempt to further go ahead in #9426 to remove 'btchip-python', unless that is objected. Not sure if I can complete that successfully, I feel in no way experienced enough for it, but happy and excited to have a go. Any tips how to go about it are welcome. |
"manufacturer shows no opposition to incentivising users to buy their newer products" :) Not aimed at Ledger, just pointing out how it is a weird point to make. |
My apologies, I am not sure if I am following what you're pointing out. Is the point that express approval and direction from Ledger is required to amend the code? |
Nvm, it was just a casual quip. It reminded me of e.g. planned obsolescence (though not quite the same).
Of course we can decide to remove what we want.
…-------- Original Message --------
On 18/01/2025 04:30, gitaccount798 wrote:
just pointing out how it is a weird point to make.
My apologies, I am not sure if I am following what you're pointing out. Is the point that express approval and direction from Ledger is required to amend the code?
|
Environment: Ubuntu 24.04, Electrum 4.5.8
Full error message:
It won't also let me install btchip:
I have installed the following (as per https://github.com/spesmilo/electrum-docs/blob/master/hardware-linux.rst):
apt show libudev-dev
Package: libudev-dev
Version: 255.4-1ubuntu8.4
Priority: optional
Section: admin
Source: systemd
Origin: Ubuntu
Maintainer: Ubuntu Developers [email protected]
Original-Maintainer: Debian systemd Maintainers [email protected]
Bugs: https://bugs.launchpad.net/ubuntu/+filebug
Installed-Size: 197 kB
Depends: libudev1 (= 255.4-1ubuntu8.4)
Homepage: https://www.freedesktop.org/wiki/Software/systemd
Download-Size: 22.0 kB
APT-Manual-Installed: yes
APT-Sources: http://nz.archive.ubuntu.com/ubuntu noble-updates/main amd64 Packages
Description: libudev development files
This library provides APIs to introspect and enumerate devices on the local
system.
.
This package contains the files needed for developing applications that
use libudev.
N: There is 1 additional record. Please use the '-a' switch to see it
apt show libusb-1.0-0-dev
Package: libusb-1.0-0-dev
Version: 2:1.0.27-1
Priority: optional
Section: libdevel
Source: libusb-1.0
Origin: Ubuntu
Maintainer: Ubuntu Developers [email protected]
Original-Maintainer: Aurelien Jarno [email protected]
Bugs: https://bugs.launchpad.net/ubuntu/+filebug
Installed-Size: 328 kB
Depends: libusb-1.0-0 (= 2:1.0.27-1)
Recommends: libusb-1.0-doc
Homepage: http://www.libusb.info/
Download-Size: 77.7 kB
APT-Manual-Installed: yes
APT-Sources: http://nz.archive.ubuntu.com/ubuntu noble/main amd64 Packages
Description: userspace USB programming library development files
Library for programming USB applications without the knowledge
of Linux kernel internals.
.
This package contains what you need for compiling sources that
use this library in your own code.
pip show ecdsa
Name: ecdsa
Version: 0.19.0
Summary: ECDSA cryptographic signature library (pure python)
Home-page: http://github.com/tlsfuzzer/python-ecdsa
Author: Brian Warner
Author-email: [email protected]
License: MIT
Location: /home/computer/.local/lib/python3.12/site-packages
Requires: six
Required-by: trezor
pip show hidapi
Name: hidapi
Version: 0.14.0.post4
Summary: A Cython interface to the hidapi from https://github.com/libusb/hidapi
Home-page: https://github.com/trezor/cython-hidapi
Author: Pavol Rusnak
Author-email: [email protected]
License:
Location: /home/computer/.local/lib/python3.12/site-packages
Requires: setuptools
Required-by:
pip show ledger-bitcoin
Name: ledger_bitcoin
Version: 0.3.0
Summary: Client for Ledger Nano Bitcoin application
Home-page: https://github.com/LedgerHQ/app-bitcoin-new
Author: Ledger
Author-email: [email protected]
License:
Location: /home/computer/.local/lib/python3.12/site-packages
Requires: ledgercomm, packaging, typing-extensions
Required-by:
pip show setuptools
Name: setuptools
Version: 75.6.0
Summary: Easily download, build, install, upgrade, and uninstall Python packages
Home-page:
Author:
Author-email: Python Packaging Authority [email protected]
License:
Location: /home/computer/.local/lib/python3.12/site-packages
Requires:
Required-by: hidapi
The text was updated successfully, but these errors were encountered: