When a new version is available upstream, the program downloads the tarball without user interaction, attempts to update itself on quit and fails to unlink /usr/bin/ledger-live due to a permission error. Reproducible: Always Steps to Reproduce: 1. emerge '=app-misc/ledger-live-2.83.0' 2. Run ledger-live in terminal and quit upon reaching the start screen 3. Observe output on terminal Actual Results: $ ledger-live Ledger Live 2.83.0 Ledger Live version: 2.83.0 { type: 'system-info' } Logs console display setup (main process): {"everyLogs":false,"filters":[]} [18459:0805/135718.320095:ERROR:object_proxy.cc(576)] Failed to call method: org.freedesktop.DBus.Properties.Get: object_path= /org/freedesktop/portal/desktop: org.freedesktop.DBus.Error.InvalidArgs: No such interface “org.freedesktop.portal.FileChooser” [18459:0805/135718.320131:ERROR:select_file_dialog_linux_portal.cc(286)] Failed to read portal version property spawned internal process 18543 init Checking for update Found version 2.84.1 (url: ledger-live-desktop-2.84.1-linux-x86_64.AppImage) Downloading update from ledger-live-desktop-2.84.1-linux-x86_64.AppImage updater cache dir: /home/queenie/.cache/ledger-live-desktop-updater Update has already been downloaded to /home/queenie/.cache/ledger-live-desktop-updater/pending/ledger-live-desktop-2.84.1-linux-x86_64.AppImage). ending process 18543 ... internal process 18543 gracefully exited with code 0 Auto install update on quit Install: isSilent: true, isForceRunAfter: false Error: Error: EACCES: permission denied, unlink '/usr/bin/ledger-live' at unlinkSync (node:fs:1878:11) at xV.doInstall (/tmp/.mount_ledgeryEvYdq/resources/app.asar/.webpack/main.bundle.js:106:14450) at xV.install (/tmp/.mount_ledgeryEvYdq/resources/app.asar/.webpack/main.bundle.js:102:18091) at /tmp/.mount_ledgeryEvYdq/resources/app.asar/.webpack/main.bundle.js:102:18799 at App.<anonymous> (/tmp/.mount_ledgeryEvYdq/resources/app.asar/.webpack/main.bundle.js:100:24507) at Object.onceWrapper (node:events:633:26) at App.emit (node:events:530:35) at App.emit (node:domain:488:12) at n.emit (/tmp/.mount_ledgeryEvYdq/resources/app.asar/.webpack/main.bundle.js:36:212578) at /tmp/.mount_ledgeryEvYdq/resources/app.asar/.webpack/main.bundle.js:37:12859 Error: EACCES: permission denied, unlink '/usr/bin/ledger-live' at unlinkSync (node:fs:1878:11) at xV.doInstall (/tmp/.mount_ledgeryEvYdq/resources/app.asar/.webpack/main.bundle.js:106:14450) at xV.install (/tmp/.mount_ledgeryEvYdq/resources/app.asar/.webpack/main.bundle.js:102:18091) at /tmp/.mount_ledgeryEvYdq/resources/app.asar/.webpack/main.bundle.js:102:18799 at App.<anonymous> (/tmp/.mount_ledgeryEvYdq/resources/app.asar/.webpack/main.bundle.js:100:24507) at Object.onceWrapper (node:events:633:26) at App.emit (node:events:530:35) at App.emit (node:domain:488:12) at n.emit (/tmp/.mount_ledgeryEvYdq/resources/app.asar/.webpack/main.bundle.js:36:212578) at /tmp/.mount_ledgeryEvYdq/resources/app.asar/.webpack/main.bundle.js:37:12859 { errno: -13, code: 'EACCES', syscall: 'unlink', path: '/usr/bin/ledger-live' } Expected Results: The program neither downloads the new version's tarball, nor does it attempt to update itself on quit. Portage 3.0.65 (python 3.12.3-final-0, default/linux/amd64/23.0/split-usr/hardened/selinux, gcc-13, glibc-2.39-r6, 6.6.21-gentoo-x86_64 x86_64) ================================================================= System Settings ================================================================= System uname: Linux-6.6.21-gentoo-x86_64-x86_64-Intel-R-_Core-TM-_i5-6600K_CPU_@_3.50GHz-with-glibc2.39 KiB Mem: 16336432 total, 5633208 free KiB Swap: 33554428 total, 33553916 free Timestamp of repository gentoo: Mon, 05 Aug 2024 09:35:00 +0000 Head commit of repository gentoo: e547dbaa235081ec3a6951defbd8d6608a7276e7 Timestamp of repository gentoo-zh: Sun, 04 Aug 2024 07:50:56 +0000 Head commit of repository gentoo-zh: add924f1fdcb0a45e1218537700c32a434c60a6e Timestamp of repository guru: Mon, 05 Aug 2024 05:34:32 +0000 Head commit of repository guru: dd4523d4c743e4c363fb3c934ccec71d72736026 Timestamp of repository steam-overlay: Sun, 04 Aug 2024 15:35:35 +0000 Head commit of repository steam-overlay: d42cd55eec067eff2427f64409c2ac827ce744a6 sh bash 5.2_p26-r6 ld GNU ld (Gentoo 2.42 p3) 2.42.0 app-misc/pax-utils: 1.3.7::gentoo app-shells/bash: 5.2_p26-r6::gentoo dev-build/autoconf: 2.13-r8::gentoo, 2.71-r7::gentoo dev-build/automake: 1.16.5-r2::gentoo dev-build/cmake: 3.28.5::gentoo dev-build/libtool: 2.4.7-r4::gentoo dev-build/make: 4.4.1-r1::gentoo dev-build/meson: 1.4.1::gentoo dev-java/java-config: 2.3.4::gentoo dev-lang/perl: 5.38.2-r3::gentoo dev-lang/python: 3.11.9-r1::gentoo, 3.12.3-r1::gentoo dev-lang/rust-bin: 1.79.0::gentoo sec-policy/selinux-base: 2.20240226-r2::gentoo sys-apps/baselayout: 2.15::gentoo sys-apps/openrc: 0.54.2::gentoo sys-apps/sandbox: 2.38::gentoo sys-devel/binutils: 2.42-r1::gentoo sys-devel/binutils-config: 5.5::gentoo sys-devel/clang: 17.0.6::gentoo, 18.1.8::gentoo sys-devel/gcc: 13.3.1_p20240614::gentoo sys-devel/gcc-config: 2.11::gentoo sys-devel/lld: 17.0.6::gentoo, 18.1.8::gentoo sys-devel/llvm: 17.0.6::gentoo, 18.1.8-r1::gentoo sys-kernel/linux-headers: 6.6-r1::gentoo (virtual/os-headers) sys-libs/glibc: 2.39-r6::gentoo sys-libs/libselinux: 3.6-r1::gentoo Repositories: gentoo location: /var/db/repos/gentoo sync-type: rsync sync-uri: rsync://rsync.gentoo.org/gentoo-portage priority: -1000 volatile: False sync-rsync-verify-max-age: 24 sync-rsync-verify-metamanifest: yes sync-rsync-verify-jobs: 1 sync-rsync-extra-opts: gentoo-zh location: /var/db/repos/gentoo-zh sync-type: git sync-uri: https://github.com/gentoo-mirror/gentoo-zh.git masters: gentoo priority: -1 volatile: False guru location: /var/db/repos/guru sync-type: git sync-uri: https://github.com/gentoo-mirror/guru.git masters: gentoo volatile: False local location: /var/db/repos/local masters: guru gentoo volatile: True steam-overlay location: /var/db/repos/steam-overlay sync-type: git sync-uri: https://github.com/gentoo-mirror/steam-overlay.git masters: gentoo volatile: False Installed sets: @gentoodev, @optdeps, @uni ACCEPT_KEYWORDS="amd64" ACCEPT_LICENSE="@FREE" CBUILD="x86_64-pc-linux-gnu" CFLAGS="-march=native -O2 -pipe -flto -Werror=odr -Werror=lto-type-mismatch -Werror=strict-aliasing" CHOST="x86_64-pc-linux-gnu" CONFIG_PROTECT="/etc /usr/share/config /usr/share/gnupg/qualified.txt" CONFIG_PROTECT_MASK="/etc/ca-certificates.conf /etc/dconf /etc/env.d /etc/fonts/fonts.conf /etc/gconf /etc/gentoo-release /etc/revdep-rebuild /etc/sandbox.d /etc/terminfo /etc/texmf/language.dat.d /etc/texmf/language.def.d /etc/texmf/updmap.d /etc/texmf/web2c" CXXFLAGS="-march=native -O2 -pipe -flto -Werror=odr -Werror=lto-type-mismatch -Werror=strict-aliasing" DISTDIR="/var/cache/distfiles" EMERGE_DEFAULT_OPTS="--quiet-build" ENV_UNSET="CARGO_HOME DBUS_SESSION_BUS_ADDRESS DISPLAY GDK_PIXBUF_MODULE_FILE GOBIN GOPATH PERL5LIB PERL5OPT PERLPREFIX PERL_CORE PERL_MB_OPT PERL_MM_OPT XAUTHORITY XDG_CACHE_HOME XDG_CONFIG_HOME XDG_DATA_HOME XDG_RUNTIME_DIR XDG_STATE_HOME" FCFLAGS="-march=native -O2 -pipe -flto -Werror=odr -Werror=lto-type-mismatch -Werror=strict-aliasing" FEATURES="assume-digests binpkg-docompress binpkg-dostrip binpkg-logs buildpkg-live config-protect-if-modified distlocks ebuild-locks fixlafiles ipc-sandbox merge-sync merge-wait multilib-strict network-sandbox news parallel-fetch pkgdir-index-trusted preserve-libs protect-owned qa-unresolved-soname-deps sandbox selinux sesandbox sfperms strict unknown-features-warn unmerge-logs unmerge-orphans userfetch userpriv usersandbox usersync xattr" FFLAGS="-march=native -O2 -pipe -flto -Werror=odr -Werror=lto-type-mismatch -Werror=strict-aliasing" GENTOO_MIRRORS="https://mirror.init7.net/gentoo/ https://ftp-stud.hs-esslingen.de/pub/Mirrors/gentoo/ https://mirror.leaseweb.com/gentoo/ https://mirror.eu.oneandone.net/linux/distributions/gentoo/gentoo/" LANG="en_US.UTF-8" LDFLAGS="-Wl,-O1 -Wl,--as-needed -Wl,-z,pack-relative-relocs" LEX="flex" MAKEOPTS="-j4" PKGDIR="/home/queenie/Downloads/repos/gentoo/containers/binpkgs" PORTAGE_CONFIGROOT="/" PORTAGE_RSYNC_OPTS="--recursive --links --safe-links --perms --times --omit-dir-times --compress --force --whole-file --delete --stats --human-readable --timeout=180 --exclude=/distfiles --exclude=/local --exclude=/packages --exclude=/.git" PORTAGE_TMPDIR="/var/tmp" RUSTFLAGS="-C target-cpu=native" SHELL="/bin/bash" USE="X acl amd64 audit bzip2 caps clang crypt dbus elogind emacs gdbm hardened iconv ipv6 jpeg libtirpc lto man matroska metric multilib ncurses openmp pam pcre pgo pic pie png policykit pulseaudio readline seccomp selinux split-usr ssl ssp test-rust unicode xattr xtpax zlib" ABI_X86="64" ADA_TARGET="gcc_12" APACHE2_MODULES="authn_core authz_core socache_shmcb unixd actions alias auth_basic authn_anon authn_dbm authn_file authz_dbm authz_groupfile authz_host authz_owner authz_user autoindex cache cgi cgid dav dav_fs dav_lock deflate dir env expires ext_filter file_cache filter headers include info log_config logio mime mime_magic negotiation rewrite setenvif speling status unique_id userdir usertrack vhost_alias" CALLIGRA_FEATURES="karbon sheets words" COLLECTD_PLUGINS="df interface irq load memory rrdtool swap syslog" CPU_FLAGS_X86="aes avx avx2 f16c fma3 mmx mmxext pclmul popcnt rdrand sse sse2 sse3 sse4_1 sse4_2 ssse3" ELIBC="glibc" GPSD_PROTOCOLS="ashtech aivdm earthmate evermore fv18 garmin garmintxt gpsclock greis isync itrax mtk3301 ntrip navcom oceanserver oncore rtcm104v2 rtcm104v3 sirf skytraq superstar2 tsip tripmate tnt ublox" GRUB_PLATFORMS="efi-64" INPUT_DEVICES="libinput wacom" KERNEL="linux" LCD_DEVICES="bayrad cfontz glk hd44780 lb216 lcdm001 mtxorb text" LLVM_TARGETS="NVPTX" LUA_SINGLE_TARGET="lua5-1" LUA_TARGETS="lua5-1" OFFICE_IMPLEMENTATION="libreoffice" PHP_TARGETS="php8-2" POSTGRES_TARGETS="postgres15" PYTHON_SINGLE_TARGET="python3_12" PYTHON_TARGETS="python3_12" RUBY_TARGETS="ruby31 ruby32" VIDEO_CARDS="nvidia" XTABLES_ADDONS="quota2 psd pknock lscan length2 ipv4options ipp2p iface geoip fuzzy condition tarpit sysrq proto logmark ipmark dhcpmac delude chaos account" Unset: ADDR2LINE, AR, ARFLAGS, AS, ASFLAGS, CC, CCLD, CONFIG_SHELL, CPP, CPPFLAGS, CTARGET, CXX, CXXFILT, ELFEDIT, EXTRA_ECONF, F77FLAGS, FC, GCOV, GPROF, INSTALL_MASK, LC_ALL, LD, LFLAGS, LIBTOOL, LINGUAS, MAKE, MAKEFLAGS, NM, OBJCOPY, OBJDUMP, PORTAGE_BINHOST, PORTAGE_BUNZIP2_COMMAND, PORTAGE_COMPRESS, PORTAGE_COMPRESS_FLAGS, PORTAGE_RSYNC_EXTRA_OPTS, PYTHONPATH, RANLIB, READELF, SIZE, STRINGS, STRIP, YACC, YFLAGS ================================================================= Package Settings ================================================================= app-misc/ledger-live-2.83.0::guru was built with the following: USE="" ABI_X86="(64)"
The bug has been closed via the following commit(s): https://gitweb.gentoo.org/repo/proj/guru.git/commit/?id=f4a782fc997f5657d57d0f87215f9d888f936110 commit f4a782fc997f5657d57d0f87215f9d888f936110 Author: Lucio Sauer <watermanpaint@posteo.net> AuthorDate: 2024-08-06 01:30:07 +0000 Commit: Lucio Sauer <watermanpaint@posteo.net> CommitDate: 2024-08-06 02:11:40 +0000 app-misc/ledger-live-bin: disable automatic updates Installing the desktop file fixes another runtime issue where it previously was impossible to close the Ledger Recover screen due to /usr/bin/ledger-live not being the default handler for the x-scheme-handler/ledgerlive MIME type. Instead, the default-url-scheme-handler tried and failed to handle ledgerlive://myledger. Bug: https://github.com/LedgerHQ/ledger-live/issues/6785 Closes: https://bugs.gentoo.org/937379 Signed-off-by: Lucio Sauer <watermanpaint@posteo.net> .../ledger-live-bin-2.79.1-r1.ebuild | 34 ++++++++++++++++++---- .../ledger-live-bin-2.81.2-r1.ebuild | 34 ++++++++++++++++++---- .../ledger-live-bin-2.83.0-r1.ebuild | 34 ++++++++++++++++++---- 3 files changed, 87 insertions(+), 15 deletions(-)