• Café
  • Automatisiertes Paketupgrade

tuxnix
Hallo
Danke für Deine Mühe.
Auf dem Pc läuft KDE Plasma 6
Deine neue Version kann ich erst ab 10.8 Testen, bin ab morgen mit den Enkeln wandern.
Danach werde ich berichten.

10 Tage später

Hallo
Ein kurzer Status Bericht, für mich sieht es jetzt gut aus.
Das Auto Update wird dann wohl am 15.8.24 starten.
Hier noch eine Zusammenfassung der journalctl Daten.

Start am 13.08.2024 um 14:13

Die 1. Meldung, wenn diese nicht gelöscht wird, wird die Anzeige der Zeit(min) weiter aktualisiert zb. von "Vor 1 min" bis die Startzeit hier 14:13 angezeigt wird.
notify-send
6 upgrades, run: pacman -Syu

systemctl list-timers
NEXT                             LEFT LAST                           PASSED UNIT                             ACTIVA>
Tue 2024-08-13 14:21:25 CEST       6s Tue 2024-08-13 14:11:36 CEST 9min ago ureminder.timer                  uremin>

Die 2. Meldung, wenn diese nicht gelöscht wird, wird die Anzeige der Zeit(min) weiter aktualisiert zb. von "Vor 1 min" bis die Startzeit hier 14:21 angezeigt wird.
notify-send
6 upgrades, run: pacman -Syu

Bis jetzt erfolgte noch kein Auto Update
date
Di 13. Aug 20:05:51 CEST 2024
uname -a
Linux rk-7072 6.10.3-arch1-2 #1 SMP PREEMPT_DYNAMIC Tue, 06 Aug 2024 07:21:19 +0000 x86_64 GNU/Linux


journalctl | grep ureminder
Aug 11 17:58:25 rk-7072 dolphin[1868]: kf.kio.workers.file: copy() QUrl("file:///run/media/ralf/D7DC-D7BD/neu/ureminder") to QUrl("file:///home/ralf/neu/ureminder") mode= 420
Aug 11 17:58:25 rk-7072 dolphin[1868]: kf.kio.workers.file: copy() QUrl("file:///run/media/ralf/D7DC-D7BD/neu/ureminder.service") to QUrl("file:///home/ralf/neu/ureminder.service") mode= 420
Aug 11 17:58:25 rk-7072 dolphin[1868]: kf.kio.workers.file: copy() QUrl("file:///run/media/ralf/D7DC-D7BD/neu/ureminder.timer") to QUrl("file:///home/ralf/neu/ureminder.timer") mode= 420
Aug 11 17:58:25 rk-7072 dolphin[1868]: kf.kio.workers.file: copy() QUrl("file:///run/media/ralf/D7DC-D7BD/neu/ureminder.txt") to QUrl("file:///home/ralf/neu/ureminder.txt") mode= 420
Aug 11 18:32:18 rk-7072 systemd[1]: Started ureminder.timer.
Aug 11 18:32:18 rk-7072 systemd[1]: Started ureminder.service.
Aug 11 18:32:19 rk-7072 ureminder[13020]: :: Paketdatenbanken werden synchronisiert …
Aug 11 18:32:19 rk-7072 ureminder[13020]:  endeavouros wird heruntergeladen …
Aug 11 18:32:19 rk-7072 ureminder[13020]:  core wird heruntergeladen …
Aug 11 18:32:19 rk-7072 ureminder[13020]:  extra wird heruntergeladen …
Aug 11 18:32:19 rk-7072 ureminder[13020]:  multilib wird heruntergeladen …
Aug 11 18:32:19 rk-7072 ureminder[13020]: :: Vollständige Systemaktualisierung wird gestartet …
Aug 11 18:32:19 rk-7072 ureminder[13020]:  Es gibt nichts zu tun
Aug 11 18:32:20 rk-7072 ureminder[13028]: ==> no candidate packages found for pruning
Aug 11 18:32:20 rk-7072 ureminder[13037]: ==> no candidate packages found for pruning
Aug 11 18:32:20 rk-7072 systemd[1]: ureminder.service: Deactivated successfully.
Aug 11 18:32:20 rk-7072 systemd[1]: ureminder.service: Consumed 1.305s CPU time, 40.5M memory peak.
Aug 11 19:34:23 rk-7072 systemd[1]: ureminder.timer: Deactivated successfully.
Aug 11 19:34:23 rk-7072 systemd[1]: Stopped ureminder.timer.
Aug 11 19:34:54 rk-7072 systemd[1]: Started ureminder.timer.
Aug 11 19:45:05 rk-7072 systemd[1]: Started ureminder.service.
Aug 11 19:45:06 rk-7072 ureminder[1562]: :: Paketdatenbanken werden synchronisiert …
Aug 11 19:46:06 rk-7072 ureminder[1562]:  endeavouros wird heruntergeladen …
Aug 11 19:46:06 rk-7072 ureminder[1562]:  core wird heruntergeladen …
Aug 11 19:46:06 rk-7072 ureminder[1562]:  extra wird heruntergeladen …
Aug 11 19:46:06 rk-7072 ureminder[1562]:  multilib wird heruntergeladen …
Aug 11 19:46:06 rk-7072 ureminder[1562]: :: Vollständige Systemaktualisierung wird gestartet …
Aug 11 19:46:07 rk-7072 ureminder[1562]: Abhängigkeiten werden aufgelöst …
Aug 11 19:46:23 rk-7072 ureminder[1562]: Paket (1)            Alte Version  Neue Version  Netto-Veränderung  Größe des Downloads
Aug 11 19:46:23 rk-7072 ureminder[1562]: extra/python-orjson  3.10.6-1      3.10.7-1               0,00 MiB             0,26 MiB
Aug 11 19:46:23 rk-7072 ureminder[1562]: Gesamtgröße des Downloads:  0,26 MiB
Aug 11 19:46:23 rk-7072 ureminder[1562]: :: Download fortsetzen? [J/n]
Aug 11 19:46:23 rk-7072 ureminder[1562]: :: Pakete werden empfangen …
Aug 11 19:46:24 rk-7072 ureminder[1562]:  python-orjson-3.10.7-1-x86_64 wird heruntergeladen …
Aug 11 19:46:24 rk-7072 ureminder[1562]: Schlüsselbund wird geprüft …
Aug 11 19:46:25 rk-7072 ureminder[1562]: Paketintegrität wird geprüft …
Aug 11 19:46:25 rk-7072 ureminder[1624]: ==> no candidate packages found for pruning
Aug 11 19:46:25 rk-7072 ureminder[1634]: ==> no candidate packages found for pruning
Aug 11 19:46:26 rk-7072 systemd[1]: ureminder.service: Deactivated successfully.
Aug 11 19:46:26 rk-7072 systemd[1]: ureminder.service: Consumed 2.044s CPU time, 66.3M memory peak.
Aug 11 20:53:24 rk-7072 systemd[1]: ureminder.timer: Deactivated successfully.
Aug 11 20:53:24 rk-7072 systemd[1]: Stopped ureminder.timer.
Aug 13 14:11:36 rk-7072 systemd[1]: Started ureminder.timer.
Aug 13 14:11:47 rk-7072 systemd[1]: Started ureminder.service.
Aug 13 14:11:49 rk-7072 ureminder[618]: :: Paketdatenbanken werden synchronisiert …
Aug 13 14:11:51 rk-7072 ureminder[618]:  endeavouros wird heruntergeladen …
Aug 13 14:11:51 rk-7072 ureminder[618]:  core wird heruntergeladen …
Aug 13 14:11:51 rk-7072 ureminder[618]:  extra wird heruntergeladen …
Aug 13 14:11:51 rk-7072 ureminder[618]:  multilib wird heruntergeladen …
Aug 13 14:11:51 rk-7072 ureminder[618]: :: Vollständige Systemaktualisierung wird gestartet …
Aug 13 14:11:52 rk-7072 ureminder[618]: Abhängigkeiten werden aufgelöst …
Aug 13 14:12:20 rk-7072 ureminder[618]: Paket (6)            Alte Version    Neue Version    Netto-Veränderung  Größe des Downloads
Aug 13 14:12:20 rk-7072 ureminder[618]: extra/libei          1.2.1-1         1.3.0-1                 -0,01 MiB             0,09 MiB
Aug 13 14:12:20 rk-7072 ureminder[618]: core/linux           6.10.3.arch1-2  6.10.4.arch2-1           0,04 MiB           135,48 MiB
Aug 13 14:12:20 rk-7072 ureminder[618]: core/linux-headers   6.10.3.arch1-2  6.10.4.arch2-1           0,00 MiB            25,92 MiB
Aug 13 14:12:20 rk-7072 ureminder[618]: extra/mesa           1:24.1.5-1      1:24.1.5-2               0,00 MiB            17,70 MiB
Aug 13 14:12:20 rk-7072 ureminder[618]: extra/polkit         124-2           125-1                   -0,01 MiB             0,39 MiB
Aug 13 14:12:20 rk-7072 ureminder[618]: extra/python-orjson  3.10.6-1        3.10.7-1                 0,00 MiB
Aug 13 14:12:20 rk-7072 ureminder[618]: Gesamtgröße des Downloads:  179,59 MiB
Aug 13 14:12:20 rk-7072 ureminder[618]: :: Download fortsetzen? [J/n]
Aug 13 14:12:20 rk-7072 ureminder[618]: :: Pakete werden empfangen …
Aug 13 14:12:41 rk-7072 ureminder[618]:  linux-6.10.4.arch2-1-x86_64 wird heruntergeladen …
Aug 13 14:12:41 rk-7072 ureminder[618]:  linux-headers-6.10.4.arch2-1-x86_64 wird heruntergeladen …
Aug 13 14:12:41 rk-7072 ureminder[618]:  mesa-1:24.1.5-2-x86_64 wird heruntergeladen …
Aug 13 14:12:41 rk-7072 ureminder[618]:  polkit-125-1-x86_64 wird heruntergeladen …
Aug 13 14:12:41 rk-7072 ureminder[618]:  libei-1.3.0-1-x86_64 wird heruntergeladen …
Aug 13 14:12:41 rk-7072 ureminder[618]: Schlüsselbund wird geprüft …
Aug 13 14:12:43 rk-7072 ureminder[618]: Paketintegrität wird geprüft …
Aug 13 14:13:00 rk-7072 ureminder[1278]: ==> no candidate packages found for pruning
Aug 13 14:13:00 rk-7072 ureminder[1289]: ==> finished: 3 packages removed (disk space saved: 178.85 MiB)
Aug 13 14:13:00 rk-7072 systemd[1]: ureminder.service: Deactivated successfully.
Aug 13 14:13:00 rk-7072 systemd[1]: ureminder.service: Consumed 6.509s CPU time, 264.6M memory peak.
Aug 13 14:21:39 rk-7072 systemd[1]: Started ureminder.service.
Aug 13 14:21:39 rk-7072 ureminder[1468]: :: Paketdatenbanken werden synchronisiert …
Aug 13 14:21:40 rk-7072 ureminder[1468]:  endeavouros wird heruntergeladen …
Aug 13 14:21:40 rk-7072 ureminder[1468]:  core wird heruntergeladen …
Aug 13 14:21:40 rk-7072 ureminder[1468]:  extra wird heruntergeladen …
Aug 13 14:21:40 rk-7072 ureminder[1468]:  multilib wird heruntergeladen …
Aug 13 14:21:40 rk-7072 ureminder[1468]: :: Vollständige Systemaktualisierung wird gestartet …
Aug 13 14:21:40 rk-7072 ureminder[1468]: Abhängigkeiten werden aufgelöst …
Aug 13 14:21:40 rk-7072 ureminder[1468]: Paket (6)            Alte Version    Neue Version    Netto-Veränderung
Aug 13 14:21:40 rk-7072 ureminder[1468]: extra/libei          1.2.1-1         1.3.0-1                 -0,01 MiB
Aug 13 14:21:40 rk-7072 ureminder[1468]: core/linux           6.10.3.arch1-2  6.10.4.arch2-1           0,04 MiB
Aug 13 14:21:40 rk-7072 ureminder[1468]: core/linux-headers   6.10.3.arch1-2  6.10.4.arch2-1           0,00 MiB
Aug 13 14:21:40 rk-7072 ureminder[1468]: extra/mesa           1:24.1.5-1      1:24.1.5-2               0,00 MiB
Aug 13 14:21:40 rk-7072 ureminder[1468]: extra/polkit         124-2           125-1                   -0,01 MiB
Aug 13 14:21:40 rk-7072 ureminder[1468]: extra/python-orjson  3.10.6-1        3.10.7-1                 0,00 MiB
Aug 13 14:21:40 rk-7072 ureminder[1468]: Gesamtgröße des Downloads:  0,00 MiB
Aug 13 14:21:40 rk-7072 ureminder[1468]: :: Download fortsetzen? [J/n]
Aug 13 14:21:40 rk-7072 ureminder[1468]: Schlüsselbund wird geprüft …
Aug 13 14:21:40 rk-7072 ureminder[1468]: Paketintegrität wird geprüft …
Aug 13 14:21:41 rk-7072 ureminder[1555]: ==> no candidate packages found for pruning
Aug 13 14:21:41 rk-7072 ureminder[1565]: ==> no candidate packages found for pruning
Aug 13 14:21:41 rk-7072 systemd[1]: ureminder.service: Deactivated successfully.
Aug 13 14:21:41 rk-7072 systemd[1]: ureminder.service: Consumed 2.598s CPU time, 48.8M memory peak.
  • tuxnix hat auf diesen Beitrag geantwortet.

    md_39118

    Ja, timer/service läuft und löst das skript aus!
    Ja, wenn Days=4 im Skript gesetzt ist und das letzte Paket von dir am 11.8 erneuert wurde und du zwischendurch kein pacman -Syu tätigst, dann sollte am 15.08. ein auto-ugrade erfolgen. 😉

    Erscheint denn auch alle 4 h eine Nachricht auf dem Desktop bzw. wenn du ein sudo ureminder ausführst? Dort werden auch die Namen der zum Upgrade stehenden Pakete angezeigt.
    Ich habe mal ein Screenshot gemacht wie das auf sway aussieht.
    Und welches Plasma läuft bei dir Plasma (X11) oder Plasma (Wayland) ?

    • md_39118 hat auf diesen Beitrag geantwortet.

      tuxnix
      Hallo
      Das Endeavour läuft mit Plasma (X11)
      Mit Wayland gibt es nach der User Anmeldung nur einen schwarzen Monitor keine Konsole nichts.
      Die 1 Nachricht kommt gleich nach dem Anmelden, die 2 Nachricht nach 7 Minuten.
      Beide Nachrichten zeigen die anstehenden Pakete. Nach 4 Stunden ist keine Nachricht erfolgt.
      Das werde ich nochmal Kontrollieren.
      Eigentlich wollte ich noch ein Bildschirm Foto anhängen, aber wie, ist ja sehr umständlich hier im Forum.

      • tuxnix hat auf diesen Beitrag geantwortet.

        md_39118

        Falls du Plasma mit Wayland ausprobieren möchtest wäre es für dich empfehlenswert das Gruppenpaket plasma noch einmal zu installieren. Da sind in letzter Zeit wohl noch ein paar Kleinigkeiten dazugekommen die man sonst nicht auf dem Rechner hat, wenn man nur aktualisiert. Das musst du aber nicht, wenn plasma X11 zu deiner Zufriedenheit läuft.

        Ich habe gestern selbst mal geschaut. Plasma zeigt Meldungen mit geringer Priorität nur sehr kurz an. Ich habe das Skript jetzt auf GNOME und Plasma angepasst, noch ein klein wenig erweitert und wenn die Tests gut verlaufen, dann gibt es am Wochenende eine verbesserte ureminder Version.

        Ein Bild anhängen ist hier recht einfach. Screenshot erzeugen, den Button mit der Landschaft drücken und das Bild hochladen. 😉

        • md_39118 hat auf diesen Beitrag geantwortet.

          tuxnix
          Hallo
          Die Meldungen 1 und 2 bleiben die ganze Zeit auf dem Desktop stehen, nach 4 Stunden kommt keine Meldung.
          X11 läuft recht gut, Plasma mit Wayland wird nochmal getestet.

          • tuxnix hat auf diesen Beitrag geantwortet.

            md_39118
            Das war auch so von mir gedacht, dass man die Paket-Meldung stehen bleibt bis man sie selbst wegklickt. 😉
            Der Timer sieht bei mir so aus:

            # systemctl list-timers
            NEXT                           LEFT   LAST                           PASSED         UNIT 
            Thu 2024-08-15 01:01:17 CEST   49min  Wed 2024-08-14 21:01:17 CEST   3h 10min ago   ureminder.timer

            Mit dem Befehl hast immer den Überblick.
            Oder den Befehl hier:

            # systemctl status ureminder.timer
            ● ureminder.timer
                 Loaded: loaded (/usr/lib/systemd/system/ureminder.timer; enabled; preset: disabled)
                 Active: active (waiting) since Wed 2024-08-14 06:56:25 CEST; 17h ago
             Invocation: 82e3264d089248f0a3979f0d5f3b99ed
                Trigger: Thu 2024-08-15 01:01:17 CEST; 47min left
               Triggers: ● ureminder.service
            
            Aug 14 06:56:25 leno1 systemd[1]: Started ureminder.timer.

            Edit\:
            Bei der Abfrage von journalctl -b | grep ureminder hast du dann jeweils bevor das script ureminder ausgeführt wurde ein 'Started ureminder.service' und dahinter ein 'ureminder.service: Deactivated successfully' stehen.

            Damit du nach dem Hochfahren vom Rechner nicht zwei Meldungen auf's display bekommst, kannst du das persistans=true aus dem timer nehmen. Und vielleicht ihn auch gleich auf daily umstellen:

            #file->/usr/lib/systemd/system/ureminder.service
            
            [Unit]
            Description=ureminder.timer
            
            [Timer]
            OnStartupSec=5min
            OnUnitActiveSec=daily
            
            [Install]
            WantedBy=basic.target
            • md_39118 hat auf diesen Beitrag geantwortet.

              tuxnix
              Hallo
              Das Auto Update ist heute noch nicht gelaufen, es wurden noch ca. 68 Pakete geladen.
              Nach 4 Stunden kommt nichts mehr. Den Timer ändere ich mit der neuen Version von ureminder
              Im Journal steht es genauso wie Du geschrieben hast.

              Aug 15 13:53:32 rk-7072 ureminder[622]:  kded-6.5.0-1-x86_64 wird heruntergeladen …
              Aug 15 13:53:32 rk-7072 ureminder[622]:  bubblewrap-0.10.0-1-x86_64 wird heruntergeladen …
              Aug 15 13:53:32 rk-7072 ureminder[622]: Schlüsselbund wird geprüft …
              Aug 15 13:53:35 rk-7072 ureminder[622]: Paketintegrität wird geprüft …
              Aug 15 13:54:08 rk-7072 ureminder[1749]: ==> no candidate packages found for pruning
              Aug 15 13:54:08 rk-7072 ureminder[1759]: ==> finished: 67 packages removed (disk space saved: 98.57 MiB)
              Aug 15 13:54:08 rk-7072 systemd[1]: ureminder.service: Deactivated successfully.
              Aug 15 13:54:08 rk-7072 systemd[1]: ureminder.service: Consumed 11.574s CPU time, 677.6M memory peak.
              Aug 15 14:02:41 rk-7072 systemd[1]: Started ureminder.service.
              
              Aug 15 14:02:42 rk-7072 ureminder[1882]: Gesamtgröße des Downloads:  0,00 MiB
              Aug 15 14:02:42 rk-7072 ureminder[1882]: :: Download fortsetzen? [J/n]
              Aug 15 14:02:42 rk-7072 ureminder[1882]: Schlüsselbund wird geprüft …
              Aug 15 14:02:42 rk-7072 ureminder[1882]: Paketintegrität wird geprüft …
              Aug 15 14:02:46 rk-7072 ureminder[2443]: ==> no candidate packages found for pruning
              Aug 15 14:02:46 rk-7072 ureminder[2453]: ==> no candidate packages found for pruning
              Aug 15 14:02:46 rk-7072 systemd[1]: ureminder.service: Deactivated successfully.
              Aug 15 14:02:46 rk-7072 systemd[1]: ureminder.service: Consumed 7.337s CPU time, 58.6M memory peak.

              Das Bild dazu

              Mach einfach mal ein sudo pacman -Syu ich hab momentan wenig Zeit. ich schau da in ein paar Tagen nochmal genauer rein, wenn die neue Version steht. 😉

              Das upgrade wird zwar auch vom Timer ausgelößt, richtet sich aber nach dem Zeitpunt wann das letzten Paketupgrade vorgenommen wurde.
              awk '/upgraded/ { print $1 }' /var/log/pacman.log | tail -1
              Bei Days=4 exakt 3 Tage und 23 Stunden später bis die Automatik bei dir zuschlagen kann.

              Dein Timer löst auf jeden Fall schon mal aus. Das ist o.K. Allerdings zweimal hintereinander ich nehme an, beim Rechnerstart, wenn er länger als 4 Stunden aus war. In dem Fall ist dann 10m nach systemd start und persistend doppelt gemoppelt. 😉

              • md_39118 hat auf diesen Beitrag geantwortet.

                tuxnix
                Der Pc wird morgen wieder gestartet dann sollte die Zeitspanne ja passen.

                Hallo
                Das Update ist am Freitag korrekt durchgelaufen.
                Im ureminder.timer ist der Eintrag OnUnitActiveSec=daily nicht OK, ob (days, day, d) muß ich noch Testen.

                journalctl -b | grep ureminder
                Aug 16 17:05:24 rk-7072 systemd[1]: /usr/lib/systemd/system/ureminder.timer:8: Failed to parse timer value, ignoring: daily
                Aug 16 17:05:30 rk-7072 systemd[1]: Started ureminder.timer.
                • tuxnix hat auf diesen Beitrag geantwortet.

                  md_39118
                  Sorry, habe in der Eile nicht richtig hingeguckt.
                  Es muss selbstvertändlich OnCalendar=daily lauten
                  Aber warte besser bis morgen damit, dann kommt alles neu und besser.

                  Hier die aktuelle Version:

                  Das ureminder Skript

                  • Den skript-code markieren und mit strg+c in die Zwischenablage kopieren.

                  • sudo nano /usr/local/bin/ureminder - aufrufen mit strg+v die Zwischenablage einfügen, mit Strg+o return speichern und mit strg+x schließen.

                  • chmod +x /usr/local/bin/ureminder - Das script ausführbar machen.

                  • pacman -Syu libnotify reflector pacman-contrib - abhängige Pakete installieren

                  • sudo /usr/local/bin/ureminder - testen ob das skript läuft und kein Fehler auswirft!

                    #!/bin/bash
                    #file-> /usr/local/bin/ureminder
                    
                    TEXTDOMAIN=ureminder
                    TEXTDOMAINDIR=/usr/share/locale
                    version="ureminder version 8.0"
                    
                    # (Default) Days between auto upgrades
                    days="7"
                    
                    # Send user a notify-send meeage from root
                    send() {
                    TUSER=$(who -T | awk '/+/{print $1}' | head -1)
                    sudo -u $TUSER DISPLAY=$DISPLAY DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/$(id -u $TUSER)/bus notify-send "$@"
                    }
                    
                    # Display Help
                    Help() {
                    echo
                    echo $"Reminds to upgrade and does it if user does not"
                    echo
                    echo $"Usage: ureminder [-s|a|t|b|h|v|u|d]"
                    echo $"Options:"
                    echo $"s      Display message: Save your Documents & pacman -Syu"
                    echo $"a      Display message: After upgrade: Do.."
                    echo $"t      Display message: Auto upgrade in x h y m (only with [u|d])"
                    echo $"b      Debug mode"
                    echo $"h      Print this help"
                    echo $"v      Print version"
                    echo $"u      Auto upgrade ON. (Or set option d)"
                    echo $"d num  Days between upgrades (default: d 7)"
                    echo
                    echo $"Example: ureminder -tasd 14"
                    echo
                    }
                    
                    # Get options
                    while getopts ":abd:hstuv" option; do
                       case $option in
                          a) # after Upgrade:messages
                             afterdo=1
                             echo $"Display message: After upgrade: Do.. - ON";;
                          b) # debug mode
                             set -vx
                             echo $"Debug mode activated";;
                          d) # Enter days
                             re='^[0-9]+$'
                             if ! [[ $OPTARG =~ $re ]]; then
                                echo $"Error: $OPTARG is not a number!" >&2; exit 1
                             elif [ $OPTARG -lt 1 ]; then
                                echo $"d needs a positiv number as argument!"; exit 1
                             else
                                days=$OPTARG
                                upgrade=1
                                echo $"Auto upgrade - days=$days - ON"
                             fi;;
                          h) # Display Help
                             Help
                             exit 0;;
                          s) # save documents and pacman -Syu messages
                             savesyu=1
                             echo $"Display message: Save your Documents & pacman -Syu - ON";;
                          t) # Message till auto upgrade
                             time=1
                             echo $"Display message: Next upgrade in x hours - ON";;
                          u) # Auto Upgrade
                             upgrade=1
                             echo $"Auto upgrade - days=$days - ON";;
                          v) # Display Version
                             echo $version
                             exit 0;;
                          ?) # Invalid option
                             echo $"Usage: ureminder [-s|a|t|b|h|v|u|d argument]"
                             echo $"Display help: ureminder -h"
                             exit 1;;
                       esac
                    done
                    
                    # error db.lck
                    if [ -f /var/lib/pacman/db.lck ] && [ ! $(pgrep pacman) ]; then
                        send $"Error: Pacman database locked" "<a href='https://wiki.archlinux.org/title/Pacman#%22Failed_to_init_transaction_(unable_to_lock_database)%22_error'>How to solve the problem</a>" -t 0 -u critical
                        exit 1
                    fi
                    
                    # update mirrors
                    reflector --age 1 --delay 0.25 --protocol https --latest 5 --save /etc/pacman.d/mirrorlist || Error="reflector --age 1 --delay 0.25 --protocol https --latest 5"
                    
                    # del PKGS from cache which are not installed anymore
                    paccache -ruk0 || Error="paccache -ruk0"
                    
                    # keep current package and last for downgrade purpose
                    paccache -rk2 || Error="paccache -rk2"
                    
                    # list all installed packages
                    pacman -Qqe > /var/pkg.lst || Error="pacman -Qqe"
                    
                    # download new packages
                    pacman -Syuw --noconfirm || Error="# pacman -Syuw"
                    
                    # check for PKGS upgrades available
                    PKGS=($(pacman -Qu | awk '{print $1}')) || Error="pacman -Qu"
                    
                    Nr=0
                    for PKG in ${PKGS[@]}; do
                      Nr=$(($Nr+1))
                      PK+=("$Nr.$PKG")
                    done
                    
                    # KERNEL upgrade
                    KERNEL=$(cat /proc/version | awk '{ print $4}'| sed -e 's/(//' -e 's/@.*//')
                    for i in ${PKGS[*]}; do
                      if [[ $KERNEL == $i ]]; then
                        RKERNEL=$i
                      fi
                    done
                    
                    # GUI upgrade
                    GUIs=('awesome' 'budgie-session' 'cinnamon-desktop' 'deepin-daemon' 'gnome-shell' 'i3' 'lxsession' 'lxqt-session' 'mate-desktop' 'plasma-desktop' 'sway' 'xfce4-session')
                    for j in ${GUIs[@]}; do
                      if [ $(pgrep -fc $j) -gt "0" ]; then
                        for l in ${PKGS[@]}; do
                          if [[ $l == $j ]]; then
                            GUI=$j
                          fi
                        done
                      fi
                    done
                    
                    # wich of these often used applications is runnig now
                    APPS=('firefox' 'librewolf' 'chromium' 'dolphin' 'nautilus' 'kmail' 'kontact' 'kate' 'vim' 'libreoffice' 'gimp' 'inkscape' 'kdenlive')
                    for k in ${APPS[@]}; do
                      if [ $(pgrep -fc $k) -eq "0" ]; then
                        APPS=("${APPS[@]/$k}")
                      fi
                    done
                    
                    # Exchange app-name with pkg-name
                    if [[ "${APPS[@]/libreoffice/}" != "${APPS[@]}" ]]; then
                        APPS=("${APPS[@]/libreoffice}")
                        APPS+=("libreoffice-fresh")
                        APPS+=("libreoffice-still")
                    fi
                    
                    # wich of these runnig applicatins get's upgrades
                    for m in ${PKGS[*]}; do
                      for n in ${APPS[*]};do
                        if [[ "$m" == "$n" ]]; then
                          UAPPS+=($n)
                        fi
                      done
                    done
                    
                    # Exchange pkg-name with app-name
                    if [[ "${UAPPS[@]/libreoffice-still/}" != "${UAPPS[@]}" ]]; then
                        UAPPS=("${UAPPS[@]/libreoffice-still}")
                        UAPPS+=("libreoffice")
                    elif [[ "${UAPPS[@]/libreoffice-fresh/}" != "${UAPPS[@]}" ]]; then
                        UAPPS=("${UAPPS[@]/libreoffice-fresh}")
                        UAPPS+=("libreoffice")
                    fi
                    
                    #messages
                    SAVE=$"Save open documents!\n"
                    SYU=$"Run # pacman -Syu on terminal!\n"
                    AFTER=$"After upgrading:\n"
                    UPGRADE=$"Auto upgrade in $HOURS h $MINUTES m\n"
                    PKMESS=$"${#PKGS[*]} package(s): ${PK[*]}"
                    if [[ $GUI != "" ]] && [[ "$RKERNEL" != "" ]]; then
                        MESS=$"GUI and kernel upgrade:"
                        DO=$"Reboot your system!"
                    elif [[ $GUI != "" ]]; then
                        MESS=$"$GUI upgrade:"
                        DO=$"Restart your usersesson!\n"
                    elif [[ $RKERNEL != "" ]] && [ ${#UAPPS[*]} -gt "0" ]; then
                        MESS=$"Application and kernel upgrade:"
                        DO=$"Restart ${UAPPS[*]} and other applikations you are working with! New $RKERNEL version will run after your next system boot.\n"
                    elif [[ $RKERNEL != "" ]]; then
                        MESS=$"Kernel upgrade:"
                        DO=$"New $RKERNEL version will run after your next system boot.\n"
                    elif [ ${#UAPPS[*]} -gt "0" ]; then
                        MESS=$"Application upgrade:"
                        DO=$"Restart${UAPPS[*]} and other applikations!\n"
                    else
                        MESS=$"Upgrade successfull:"
                        DO=$"Restart applikations in use!\n"
                    fi
                    
                    # time till auto upgrade (Unix seconds)
                    NOW=$(date --date='now' +%s)
                    UPAC=$(date -d $(awk '/upgraded/ { print $1 }' /var/log/pacman.log | tail -1 | sed -e 's/\[//' -e 's/\]//') +%s)
                    NTIMER=$(date -d $(systemctl list-timers ureminder.timer | awk 'NR>1 && NR<3{print $2,$3}' | sed -e 's/ /T/') +%s)
                    LTIMER=$(date -d $(systemctl list-timers ureminder.timer | awk 'NR>1 && NR<3{print $7,$8}' | sed -e 's/ /T/') +%s)
                    NEXT=$((days*86400+UPAC-NOW))
                    PERIOD=$((NTIMER-LTIMER))
                    COUNTS=$((NEXT/PERIOD))
                    HOURS=$(( (NOW-LTIMER+PERIOD*COUNTS) / 3600))
                    REST=$(( (NOW-LTIMER+PERIOD*COUNTS) % 3600))
                    MINUTES=$(( (3600-REST) / 60))
                    #if [[ "$LTIMER x" == " x" ]]; then HOURS=$((NEXT/3600)); MINUTES=30; fi
                    echo $"Next upgrade in $HOURS h $MINUTES m"
                    
                    # Abitity to auto upgrade all 86400sec-600sec=85600sec=23 hous and 50 minutes
                    if [ "$(((NOW-UPAC)/days))" -ge "85600" ] && [ "${#PKGS[*]}" -gt "0" ] && [ $upgrade ]; then
                      NID=$(send  $"Upgrade starts in 1 minute:" $"$SAVE" -t 0 -u normal -p)
                      sleep 60
                      NID=$(send $"Upgrading:" $"Keep system running!" -t 0  -u critical -r $NID -p)
                      pacman -Su --noconfirm || Error="# pacman -Su"
                      send "$MESS" "$DO" -t 0 -u normal -r $NID
                    
                    elif [ "${#PKGS[*]}" -gt "0" ]; then
                      if [ $savesyu ] && [ $afterdo ] && [ $time ] && [ $upgrade ]
                        then  send "$PKMESS" "$SAVE$SYU$AFTER$DO$UPGRADE" -t 0 -u normal
                      elif [ $savesyu ] && [ $time ] && [ $upgrade ]; then  send "$PKMESS" "$SAVE$SYU$UPGRADE" -t 0 -u normal
                      elif [ $afterdo ] && [ $time ] && [ $upgrade ]; then  send "$PKMESS" "$AFTER$DO$UPGRADE" -t 0 -u normal
                      elif [ $savesyu ] && [ $afterdo ]; then  send "$PKMESS" "$SAVE$SYU$AFTER$DO" -t 0 -u normal
                      elif [ $savesyu ] && [ $afterdo ]; then  send "$PKMESS" "$SAVE$SYU$AFTER$DO" -t 0 -u normal
                    
                      elif [ $time ] && [ $upgrade ]; then  send "$PKMESS" "$UPGRADE" -t 0 -u normal
                      elif [ $savesyu ];then send "$PKMESS" "$SAVE$SYU" -t 0 -u normal
                      elif [ $afterdo ]; then  send "$PKMESS" "$AFTER$DO" -t 0 -u normal
                      else  send "$PKMESS" -t 0 -u normal
                      fi
                    fi
                    
                    # error message
                    if  [ "$Error" != "" ]; then
                      send $"Error: $Error" $"To analyse run this command on terminal!" -t 0 -u critical
                    fi
                    
                    # TODO:
                    # GUI- und APP-Messiges noch um weite Pakete ergänzen und weiter testen.
                    # Für APP - Messige Ablauf umdrehen. Zuerst pkgs upgrades testen spart eine Namenswandlung für libreoffice ein.
                    # Arch Linux News anzeigen.
                    # In Plasma und GNOME die Notiz Meldung größer darstellen lassen damit eine lange Paket-Upgrade-Liste komplett angezeigt wird.
                    
                    #Know issues:
                    # 'pacman -Qu' does not list new added dependencies of package upgrades. This is not very importent for ureminder script - Fix would need a feature request to pacman devs.

                  Der ureminder.service

                  • Den code markieren und mit strg+c in die Zwischenablage kopieren.
                  • sudo nano /usr/lib/systemd/system/ureminder.service - aufrufen mit strg+v die Zwischenablage einfügen, mit Strg+o return speichern und mit strg+x schließen.
                  
                  #file->/usr/lib/systemd/system/ureminder.service
                  
                  [Unit]
                  Description=ureminder.service
                  After=network-online.target
                  Wants=network-online.target
                  
                  [Service]
                  ExecStart=/usr/local/bin/ureminder -astu
                  
                  [Install]
                  WantedBy=basic.target

                  Der ureminder.timer

                  • Code markieren und mit strg+c in die Zwischenablage kopieren
                  • sudo nano /usr/lib/systemd/system/ureminder.timermit strg+v einfügen strg+o return speichern, strg+x schließen
                  • sudo systemctl enable --now ureminder.timer - anschließend den timer aktivieren
                  #file->/usr/lib/systemd/system/ureminder.timer
                  
                  [Unit]
                  Description=ureminder.timer
                  
                  [Timer]
                  OnCalendar=daily
                  Persistent=true
                  
                  [Install]
                  WantedBy=basic.target

                  7.8.2024 changelog:

                  • Erkennt den jeweils laufenden kernel und die laufende GUI und gibt nach einem upgrade vom kernel bzw. der GUI entsprechende Mitteilungen aus.

                  18.8.2024 changelog:

                  • Erkennt wenn eine laufende Anwendung ein upgrade erfahren hat und fordert auf sie neu zu starten. (Nur für sehr häufig genutzte Anwendungen)
                  • Option --days --verboste --help eingeführt (DAYS=7 default)
                  • Den Timer auf täglich eingestellt.
                  • Konsolenmeldung ab wann ein autoupgrade möglich ist.
                  • reflector auf internationalen Gebrauch eingestellt
                  • Funktion send überarbeitet
                  • Nummerrierung der verfügbaren upgrades damit eine eventuell abgeschnittene Meldung keine Vollständigkeit vortäucht. (Plasma zeigte bisher nur ca. 60 Pkgs namentlich an, obwohl das eine mal 82 upgrades anstanden.)

                  22.8.2024 changelog:

                  • Zeile 127 PRAPPS+=('$n')->PRAPPS+=($n)
                  • Zeile 138: $PRAPPS->${PRAPPS[*]}
                  • Skript für Übersetzungen eingerichtet und eine deutsche ureminder.mo erstellt.

                  27.8.2024 changelog:

                  • Skript-Code an meheren Stellen geändert und Rihenfolge umgestellt.
                  • Gibt schon bei der Upgade-Aufforderung Hinweise was danach zu tun ist.

                  29.8.2024 changelog:

                  • Bezieht die Timer Einstellung mit ein und zeigt jetzt präzise den Zeitpunkt des Auto-Upgrade an.
                  • Optionen neu gestaltet. Die verschiedenen Mitteilungen und das Autoupdate müssen jetzt explizit ausgewählt werden.

                  @md_39118 Viel Spaß damit. 😉

                  @GerBra
                  Das Autoupgrade lässt sich jetzt bequem per Option z.B. von
                  ureminder --days 30 für fast NIE bis --days 30000 NIEmals einstellen. 😉
                  Das käme wohl auch deiner Arbeitsweise entgegen, denn die fälligen Pkgs upgrades werden dir dann automatisch angezeigt.
                  Zusätzlich wäre es möglich Vorwarnungen einzubauen wenn upgrades anstehen, die bei dir sensibel sind.
                  Vielen Dank für das ausführliche Brainstorming, deine Argumente waren mir sehr hilfreich.

                    tuxnix
                    Hallo
                    Der erste Test bringt einen Fehler. Der Timer ist noch inaktiv
                    Kann der service und timer auch unter /etc/systemd/system/ liegen ?
                    Wird im Wiki als Ort für eigene Dateien angegeben.

                    sudo ureminder
                    ==> no candidate packages found for pruning
                    ==> no candidate packages found for pruning
                    :: Paketdatenbanken werden synchronisiert …
                     endeavouros ist aktuell
                     core ist aktuell
                     extra ist aktuell
                     multilib ist aktuell
                    :: Vollständige Systemaktualisierung wird gestartet …
                    Abhängigkeiten werden aufgelöst …
                    
                    Paket (11)                   Alte Version      Neue Version      Netto-Veränderung
                    
                    core/btrfs-progs             6.10-1            6.10.1-1                  -0,05 MiB
                    core/fakeroot                1.35.1-1          1.36-1                     0,00 MiB
                    extra/gtk-update-icon-cache  1:4.14.4-2        1:4.14.5-1                 0,00 MiB
                    extra/gtk4                   1:4.14.4-2        1:4.14.5-1                 0,21 MiB
                    extra/librsvg                2:2.58.2-1        2:2.58.3-1                -0,06 MiB
                    extra/libssh                 0.11.0-1          0.11.0-2                   0,00 MiB
                    extra/luajit                 2.1.1720049189-1  2.1.1723675123-1           0,01 MiB
                    core/systemd                 256.4-1           256.5-1                    0,01 MiB
                    core/systemd-libs            256.4-1           256.5-1                    0,00 MiB
                    core/systemd-resolvconf      256.4-1           256.5-1                    0,00 MiB
                    core/systemd-sysvcompat      256.4-1           256.5-1                    0,00 MiB
                    
                    Gesamtgröße des Downloads:  0,00 MiB
                    
                    :: Download fortsetzen? [J/n]
                    (11/11) Schlüssel im Schlüsselbund werden geprüft                                                                                             [---------------------------------------------------------------------------------------] 100%
                    (11/11) Paket-Integrität wird überprüft                                                                                                       [---------------------------------------------------------------------------------------] 100%
                    With Days=7. Next automated packgage upgrade when runnig uriminder in 113 hour(s)
                    Verbindung ist gescheitert: Datei oder Verzeichnis nicht gefunden
                    • tuxnix hat auf diesen Beitrag geantwortet.

                      md_39118
                      Man kann den timer und den service alternativ auch unter /etc/systemd/system/ abspeichern. Das macht funktionell keinen Unterschied. Für den Paketbau wird allerdings /usr/lib/systemd/system/ als Speicherort dafür vorgeschrieben. ureminder wird, falls es sich bewähren sollte als AUR Paket angeboten werden.
                      Ohnehin löst der timer, wenn du alles so wie ich es vorgegeben habe gemacht hast , zum aller ersten mal um 00:00:00 aus und holt das, falls der Rechner zu dem Zeitpunkt ausgeschaltet ist beim nächsten Start nach (persistend=true) .
                      Gutes Nächtle

                      md_39118

                      Der Fehler war im Skript bei der Funktion 'send' ich hab es oben korrigiert.

                      • md_39118 hat auf diesen Beitrag geantwortet.

                        tuxnix
                        Hallo
                        Mit der Änderung sieht es gut aus.
                        In der "ureminder-fg" habe ich die Meldungen auf DE eingetragen und die Rechte geändert.

                        sudo chmod go-x /usr/local/bin/ureminder-fg
                        ls -la /usr/local/bin/
                        -rwxr--r--  1 root root 7757 19. Aug 15:42 ureminder-fg
                        
                        journalctl -b | grep ureminder-fg
                        Aug 19 15:39:15 rk-7072 dolphin[1188]: kf.kio.workers.file: copy() QUrl("file:///run/media/ralf/D7DC-D7BD/version-3/ureminder-fg") to QUrl("file:///home/ralf/version-3/ureminder-fg") mode= 420
                        Aug 19 15:41:10 rk-7072 sudo[1328]:     ralf : TTY=pts/1 ; PWD=/home/ralf ; USER=root ; COMMAND=/usr/bin/nano /usr/local/bin/ureminder-fg
                        Aug 19 15:44:52 rk-7072 sudo[1402]:     ralf : TTY=pts/1 ; PWD=/home/ralf ; USER=root ; COMMAND=/usr/bin/chmod go-x /usr/local/bin/ureminder-fg
                        Aug 19 15:48:36 rk-7072 sudo[1449]:     ralf : TTY=pts/1 ; PWD=/home/ralf ; USER=root ; COMMAND=/usr/local/bin/ureminder-fg -h
                        Aug 19 15:49:38 rk-7072 sudo[1462]:     ralf : TTY=pts/1 ; PWD=/home/ralf ; USER=root ; COMMAND=/usr/local/bin/ureminder-fg
                        Aug 19 15:55:14 rk-7072 ureminder-fg[1838]: ==> no candidate packages found for pruning
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1847]: ==> finished: 1 packages removed (disk space saved: 81.2 KiB)
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]: :: Paketdatenbanken werden synchronisiert …
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]:  endeavouros wird heruntergeladen …
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]:  core wird heruntergeladen …
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]:  extra wird heruntergeladen …
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]:  multilib wird heruntergeladen …
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]: :: Vollständige Systemaktualisierung wird gestartet …
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]: Abhängigkeiten werden aufgelöst …
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]: Paket (13)                   Alte Version      Neue Version      Netto-Veränderung
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]: core/btrfs-progs             6.10-1            6.10.1-1                  -0,05 MiB
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]: core/fakeroot                1.35.1-1          1.36-1                     0,00 MiB
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]: extra/gtk-update-icon-cache  1:4.14.4-2        1:4.14.5-1                 0,00 MiB
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]: extra/gtk4                   1:4.14.4-2        1:4.14.5-1                 0,21 MiB
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]: extra/libinput               1.26.1-1          1.26.2-1                   0,00 MiB
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]: extra/librsvg                2:2.58.2-1        2:2.58.3-1                -0,06 MiB
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]: extra/libssh                 0.11.0-1          0.11.0-2                   0,00 MiB
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]: extra/luajit                 2.1.1720049189-1  2.1.1723675123-1           0,01 MiB
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]: extra/pv                     1.8.12-1          1.8.13-1                   0,00 MiB
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]: core/systemd                 256.4-1           256.5-1                    0,01 MiB
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]: core/systemd-libs            256.4-1           256.5-1                    0,00 MiB
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]: core/systemd-resolvconf      256.4-1           256.5-1                    0,00 MiB
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]: core/systemd-sysvcompat      256.4-1           256.5-1                    0,00 MiB
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]: Gesamtgröße des Downloads:  0,00 MiB
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]: :: Download fortsetzen? [J/n]
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]: Schlüsselbund wird geprüft …
                        Aug 19 15:55:15 rk-7072 ureminder-fg[1866]: Paketintegrität wird geprüft …
                        Aug 19 15:55:16 rk-7072 ureminder-fg[1830]: With Days=7. Nächstes automatisches Package-Upgrade bei der Ausführung von ureminder in 95 hour(s)

                        Ist das schon der erste fork?
                        Schön wenn du damit kreativ umgehst, das Skript an deine Bedürfnisse anpasst und ausprobierst. Genau deshalb sind Skripte ja auch so wertvoll. 😉

                        Bei den Änderung der Rechte hätte ich es an deiner Stelle bevorzugt, die Datei der Gruppe users mit Schreibrechten zuzuordnen. Der Besitzer root muss weiterhin ausführen können, aber wenn ralf Mitglied in der Gruppe users ist, dann kann er danach das Skript bearbeiten ohne sudo und dann kann er auch einen editor wie z.B. kate viel einfacher benutzen.
                        Ungefähr so:

                        id ralf
                        chown root:users ureminder-fg
                        chmod g+w ureminder-fg

                        • md_39118 hat auf diesen Beitrag geantwortet.

                          tuxnix
                          Hallo
                          Der Pc soll bei zwei Freunden als Linux Test und Spielwiese neben Ihren Window Pc stehen.
                          Mit den original Meldungen würde ich beiden(Ü70) keine Freude machen, deshalb eher eine Notwendigkeit als ein fork.
                          Die Änderung an den Rechten gefällt mir auch gut, das werden ich noch ändern.
                          Für den Einsatz bei den Freunden kommt mir das AutoUpdate Script sehr gelegen.
                          Danke für Deine Arbeit.

                          • tuxnix hat auf diesen Beitrag geantwortet.

                            md_39118
                            Das ist genau das angedachte Einsatzszenario für das Skript.
                            Es führt dazu hin was man tun soll und teilt mit was passiert.
                            Nimm doch mal das Original Arch Linux dafür. 😉
                            Mit den Spickern ist das schneller per konsole installiert als der Calamares Installer von Endeverous durchgeklickt ist.
                            O.k. erst beim zweiten mal 😉

                            Als GUi würde ich dir sway vorschlagen. Ich habe da was altengerechtes, sehr einfach und intuitiv zu bedienendes konfiguriert, mit dem auch mein 80 jähriger Onkel auf Anhieb zurechtkommt. Plasma hat so viele Knöpfe die am Anfang irritieren können. Aber vor allem schnurrt selbst ein schwacher Rechner wieder wie am ersten Tag damit.
                            Sag Bescheid wenn du soweit bist.