//Edit:

Ein script wie z.B. guest.sh im Ordner /etc/profile.d/ wird bei jedem Login ausgeführt. Das klappt sogar auch mit Loginmanager und braucht keinen zusätzlichen systemd-service.

/etc/profile.d/guest.sh

#!/bin/bash

#  UID von user guest ist bei mir 1002

if [ $EUID -eq 1002 ] ; then
	rm -rf /home/guest/*
fi
  • Andy@Arch hat auf diesen Beitrag geantwortet.

    tuxnix die Idee ist nicht schlecht, nur hätte ich das ganze gerne beim Logout. Was mir da einfällt ist trap, nur welches Signal nimmt man?

    • tuxnix hat auf diesen Beitrag geantwortet.

      Der Service sieht gut aus.
      Meine Frage wäre, ob dieser auch korrekt als User Service für den Benutzer guest installiert wurde.
      Da er in /etc/systemd/system anstatt in /etc/systemd/user liegt, nehme ich mal an, dass dies nicht der Fall ist.
      Eine Alternative zur Lösung des zugrundeliegenden Problems wäre systemd-homed mit einem tmpfs für den User.

        schard Eine Alternative zur Lösung des zugrundeliegenden Problems wäre systemd-homed mit einem tmpfs für den User.

        Genau dafür ist das doch da, oder hab ich das falsch verstanden?

        Einen solchen systemd-Service im Usercontext laufen zu lassen ist ein "Sicherheitsrisiko", da der User den Service ja einfach beenden könnte.

        schard Meine Frage wäre, ob dieser auch korrekt als User Service für den Benutzer guest installiert wurde.

        Wie sollte das denn deiner Meinung nach installiert werden?

        • Dirk hat auf diesen Beitrag geantwortet.

          Was mir gerade noch einfällt: was auch eine Möglichkeit wäre, aber schon ein bisschen böse, wäre für /home/guest ein tmpfs zu benutzen, damit wären ohne weiteres zwar nur nach einem Neustart alle Daten unwiederbringlich weg, aber eben komplett ohne dass man das Verzeichnis selbst jedes Mal anfassen müsste.

          Andy@Arch Wie sollte [der User-Service] denn deiner Meinung nach installiert werden?

          Na ja, du kannst systemd-Services ja auch im Usercontext starten. Zum Beispiel um Timer zu benutzen und nicht jedes mal erst als root was zu konfigurieren. Die Units laufen dann eben im Usercontext und haben auch das Environment des Users griffbereit, ohne groß irgendwas Konfigurieren zu müssen.

          Aber hier würde das nur bei "ehrlichen" Anwendern funktionieren, jemand mit "böser Absicht" könnte den Service im Usercontext halt einfach beenden und das hier diskutierte Setup damit zu einem gewissen Maße aushebeln.

          Andy@Arch nur hätte ich das ganze gerne beim Logout.

          Das bleibt sich im Ergebnis gleich.
          Ob ein Zimmer (Guestaccount) beim Einchecken oder beim Auschecken gereinigt wird kann dem Gast egal sein. Er betritt immer ein sauberes Zimmer. Was die Sicherheit und die Privatsphäre betrifft, so ist das auch einerlei, weil hier der Gast ohnehin darauf angewiesen ist, dem Wirt (Admin) zu vertrauen.

          Was mir da einfällt ist trap

          Trap wird nicht klappen wenn die Sitzung von einem Loginmanager und nicht von einem Skript aus gestartet wird.

          Um bei der Analogie zu bleiben: Es wäre sinnvoller das Zimmer zu reinigen bevor ein Gast kommt. Ansonsten guckt der erste in die Röhre. Das mag ein Edge Case sein, ist aber eine Überlegung wert.

          Aus Datenschutzsicht ist es zudem sinnvoll, übergebliebene Daten nach Ende der Sitzung zu löschen. Ein tmpfs erfüllt beide Anforderungen.

          Eine weitere Frage betreffend den Use Case des Themenerstellers für mich wäre, welches Verhalten erwartet wird, wenn sich GastA mit dem Benutzerkonto gast anmeldet, und sich während seiner Session ein weiterer GastB mit selbigem Benutzerkonto anmeldet.

          Das tmpfs wird doch auch beim Boot eingehangen und beim shutdown ausgehangen richtig? Oder ist es möglich das mit dem User login bzw logout zu verbinden?

          Ich werde erstmal die Lösung mit dem Script in /etc/profile.d/ nehmen. Ist zwar nicht ganz das was ich wollte, aber bisher am praktikabelsten umzusetzen.
          Zumindest solange bis ich ein zuverlässiges *.target oder *.service gefunden habe um den Logout abzupassen.
          Gibt es eine Möglichkeit sich anzeigen zulassen (Datum und Uhrzeit) wann welcher Service gestartet oder welches Target erreicht wurde? Mit system-analyze komme ich da gerade nicht mehr weiter.


          • tuxnix hat auf diesen Beitrag geantwortet.

            @Andy@Arch

            Zum Thema tmpfs:
            Man kann das Script in /etc/profile.d/ auch mit einem tmpfs
            für /home/guest kombinieren.

            Dazu wäre zusätzlich in die /etc/fstab folgendes einzutragen:
            tmpfs /home/guest tmpfs defaults 0 0

            Die Daten sind dann nur so lange vorhanden wie der Rechner läuft. Standardmäßig wird dabei für /home/guest bis zu 50% vom RAM genutzt. Bei 4G RAM hätte der user guest dann 2G für die eigenen Dateien zur Verfügung. Mit df -t tmpfskann man die aktuelle Belegung abrufen. Ob das sinnvoll ist, da kommt es wohl darauf an, was guest denn so machen möchte.
            Jedenfalls hätte es der guest-user dann selbst im Griff alle seine Spuren zu beseitigen. Er müsste den Rechner nur herunterfahren.

            Andy@Arch Gibt es eine Möglichkeit sich anzeigen zulassen (Datum und Uhrzeit) wann welcher Service gestartet oder welches Target erreicht wurde?

            journalctl |grep systemd