From 82a87be243ca15ecef8ab8f9ccecc00d159e99ae Mon Sep 17 00:00:00 2001 From: Ruben Rodriguez <ruben@trisquel.info> Date: Mon, 1 May 2023 23:22:25 -0400 Subject: [PATCH] update-notifier: multiple upgrades to privacy and usability --- helpers/DATA/update-notifier/apt_check.py | 4 +- .../check_updates_with_update_manager.patch | 61 +++++++++++++++++ .../improve_responsiveness.patch | 67 +++++++++++++++++++ helpers/make-update-notifier | 16 ++++- 4 files changed, 145 insertions(+), 3 deletions(-) create mode 100644 helpers/DATA/update-notifier/check_updates_with_update_manager.patch create mode 100644 helpers/DATA/update-notifier/improve_responsiveness.patch diff --git a/helpers/DATA/update-notifier/apt_check.py b/helpers/DATA/update-notifier/apt_check.py index 05334fa4..67d2b4db 100644 --- a/helpers/DATA/update-notifier/apt_check.py +++ b/helpers/DATA/update-notifier/apt_check.py @@ -52,7 +52,7 @@ def _get_output_from_lsb_release(lsb_option): def get_distro(): " get distro name " try: - return _get_info_from_os_release(key="UBUNTU_CODENAME") + return _get_info_from_os_release(key="RELEASE_CODENAME") except Exception: # If the system does not have os-release file or does not have the # required entry in it, we will get the distro name from lsb_release @@ -101,7 +101,7 @@ def saveDistUpgrade(cache, depcache): def isSecurityUpgrade(ver): " check if the given version is a security update (or masks one) " security_pockets = [("Ubuntu", "%s-security" % DISTRO), - ("gNewSense", "%s-security" % DISTRO), + ("Trisquel", "%s-security" % DISTRO), ("Debian", "%s-updates" % DISTRO)] for (file, index) in ver.file_list: for origin, archive in security_pockets: diff --git a/helpers/DATA/update-notifier/check_updates_with_update_manager.patch b/helpers/DATA/update-notifier/check_updates_with_update_manager.patch new file mode 100644 index 00000000..0fb9721e --- /dev/null +++ b/helpers/DATA/update-notifier/check_updates_with_update_manager.patch @@ -0,0 +1,61 @@ +diff -ru source.bak/data/backend_helper.py source/data/backend_helper.py +--- source.bak/data/backend_helper.py 2023-04-30 21:20:07.986410268 -0400 ++++ source/data/backend_helper.py 2023-04-30 21:35:59.442841302 -0400 +@@ -58,35 +58,14 @@ + return _install_all_updates_synaptic() + + +-# check updates +-def _check_updates_aptdaemon(): +- from gi.repository import Gtk +- from aptdaemon import client, enums +- from aptdaemon.gtk3widgets import AptProgressDialog +- client = client.AptClient() +- trans = client.update_cache() +- dia = AptProgressDialog(trans) +- dia.connect("finished", Gtk.main_quit) +- dia.run() +- Gtk.main() +- return trans.exit == enums.EXIT_SUCCESS +- +- +-def _check_updates_gtk(): +- cmd = ["/usr/bin/synaptic-pkexec", +- "--update-at-startup", +- "--non-interactive", +- "--hide-main-window", +- ] +- subprocess.call(cmd) +- +- + def check_updates(): +- """ check for updates either with aptdaemon or synaptic """ +- if HAVE_APTDAEMON: +- return _check_updates_aptdaemon() ++ """ check and show updates using update-manager """ ++ if os.path.exists("/usr/bin/update-manager"): ++ cmd = ["update-manager", "--no-check-screen"] ++ res = subprocess.call(cmd) ++ return (res == 0) + else: +- return _check_updates_gtk() ++ logging.error("update-manager is not installed") + + + # start packagemanager +diff -ru source.orig/data/backend_helper.py source/data/backend_helper.py +--- source.orig/data/backend_helper.py 2023-05-01 10:18:12.941023681 -0400 ++++ source/data/backend_helper.py 2023-05-01 10:27:12.724396819 -0400 +@@ -53,9 +53,10 @@ + def install_all_updates(): + """ install all updates either with synaptic or aptdaemon """ + if HAVE_APTDAEMON: +- return _install_all_updates_aptdaemon() ++ _install_all_updates_aptdaemon() + else: +- return _install_all_updates_synaptic() ++ _install_all_updates_synaptic() ++ return show_updates() + + + def check_updates(): diff --git a/helpers/DATA/update-notifier/improve_responsiveness.patch b/helpers/DATA/update-notifier/improve_responsiveness.patch new file mode 100644 index 00000000..ba9d251d --- /dev/null +++ b/helpers/DATA/update-notifier/improve_responsiveness.patch @@ -0,0 +1,67 @@ +diff -ru source.orig/src/update-notifier.c source/src/update-notifier.c +--- source.orig/src/update-notifier.c 2023-05-01 12:24:36.171054235 -0400 ++++ source/src/update-notifier.c 2023-05-01 13:54:27.833304128 -0400 +@@ -53,7 +53,7 @@ + gboolean update_timer_finished(gpointer data); + + // the time when we check for fam events, in seconds +-#define TIMEOUT_FAM 180 ++#define TIMEOUT_FAM 30 + + // the timeout (in sec) when a further activity from dpkg/apt + // causes the applet to "ungray" +@@ -388,10 +388,9 @@ + + // monitor these dirs + static const char *monitor_dirs[] = { +- "/var/lib/apt/lists/", "/var/lib/apt/lists/partial/", +- "/var/cache/apt/archives/", "/var/cache/apt/archives/partial/", ++ "/var/lib/apt/lists/", ++ "/var/cache/apt/archives/", + HOOKS_DIR, +- CRASHREPORT_DIR, + NULL}; + for(i=0;monitor_dirs[i] != NULL;i++) { + if (getenv("UPSTART_SESSION") && monitor_dirs[i] == CRASHREPORT_DIR) { +@@ -411,7 +410,6 @@ + "/var/lib/dpkg/status", + "/var/lib/update-notifier/dpkg-run-stamp", + "/var/lib/apt/periodic/update-success-stamp", +- LIVEPATCH_FILE, + NULL}; + for(i=0;monitor_files[i] != NULL;i++) { + GError *error = NULL; +diff -ru source.orig/src/update.c source/src/update.c +--- source.orig/src/update.c 2023-05-01 14:30:39.889778059 -0400 ++++ source/src/update.c 2023-05-01 18:05:21.754318730 -0400 +@@ -547,7 +547,7 @@ + return; + } + +- g_spawn_command_line_async("nice ionice -c3 update-manager " ++ g_spawn_command_line_async("sleep 5; nice ionice -c3 update-manager " + "--no-update --no-focus-on-map", NULL); + } + +@@ -702,7 +702,8 @@ + + // show the notification with some delay. otherwise on a login + // the origin of the window is 0,0 and that looks ugly +- g_timeout_add_seconds(5, show_notification, ta); ++ if (priv->num_upgrades != 0) ++ g_timeout_add_seconds(5, show_notification, ta); + + return TRUE; + } +diff -ru source.orig/src/update.c source/src/update.c +--- source.orig/src/update.c 2023-05-01 14:30:39.889778059 -0400 ++++ source/src/update.c 2023-05-01 20:45:14.717390627 -0400 +@@ -251,7 +251,7 @@ + GTK_STOCK_DIALOG_INFO, 48,0,NULL); + notify_notification_set_icon_from_pixbuf (n, pix); + g_object_unref(pix); +- notify_notification_set_timeout (n, 60*1000); ++ notify_notification_set_timeout (n, 10*1000); + notify_notification_show(n, NULL); + // save the notification handle + if (priv->active_notification) diff --git a/helpers/make-update-notifier b/helpers/make-update-notifier index 68c98957..6d84d4b1 100644 --- a/helpers/make-update-notifier +++ b/helpers/make-update-notifier @@ -18,11 +18,25 @@ # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA # -VERSION=9 +VERSION=10 COMPONENT=main . ./config +# Don't show the connection check screen when listing available updates +sed '/update-manager/s/--no-update/--no-update", "--no-check-screen/' -i data/backend_helper.py +# Actually install all upgrades in "Install all upgrades" menu entry +sed '/client.upgrade_system/s/safe_mode=True/safe_mode=False/' -i data/backend_helper.py +# Check updates with update-notifier instead of aptdaemon +patch -p1 < $DATA/check_updates_with_update_manager.patch +# Shorter check times for apt task ending +sed '/TIMEOUT_APT_RUN/s/600/60/g' -i src/update-notifier.c +# Use update-manager to checks for dist-upgrades +sed '/RELEASE_UPGRADE_CHECKER/s|/usr/lib/ubuntu-release-upgrader/check-new-release-gtk|sleep 5; nice ionice -c3 /usr/bin/update-manager --check-dist-upgrades --no-update --no-focus-on-map|' -i src/update-notifier.h + +# Reduce the timeout to refresh the status of the tray icon +patch -p1 < $DATA/improve_responsiveness.patch + #Use custom apt-check to fix motd update notification by striping esm stuff. cp $DATA/apt_check.py data/apt_check.py sed -i '/test_motd.py/d' debian/rules -- GitLab