pam_systemd_homesystemdpam_systemd_home8pam_systemd_homeAutomatically mount home directories managed by systemd-homed.service on
login, and unmount them on logoutpam_systemd_home.soDescriptionpam_systemd_home ensures that home directories managed by
systemd-homed.service8
are automatically activated (mounted) on user login, and are deactivated (unmounted) when the last
session of the user ends.OptionsThe following options are understood:suspend=Takes a boolean argument. If true, the home directory of the user will be suspended
automatically during system suspend; if false it will remain active. Automatic suspending of the home
directory improves security substantially as secret key material is automatically removed from memory
before the system is put to sleep and must be re-acquired (through user re-authentication) when
coming back from suspend. It is recommended to set this parameter for all PAM applications that have
support for automatically re-authenticating via PAM on system resume. If multiple sessions of the
same user are open in parallel the user's home directory will be left unsuspended on system suspend
as long as at least one of the sessions does not set this parameter to on. Defaults to
off.Note that TTY logins generally do not support re-authentication on system resume.
Re-authentication on system resume is primarily a concept implementable in graphical environments, in
the form of lock screens brought up automatically when the system goes to sleep. This means that if a
user concurrently uses graphical login sessions that implement the required re-authentication
mechanism and console logins that do not, the home directory is not locked during suspend, due to the
logic explained above. That said, it is possible to set this field for TTY logins too, ignoring the
fact that TTY logins actually don't support the re-authentication mechanism. In that case the TTY
sessions will appear hung until the user logs in on another virtual terminal (regardless if via
another TTY session or graphically) which will resume the home directory and unblock the original TTY
session. (Do note that lack of screen locking on TTY sessions means even though the TTY session
appears hung, keypresses can still be queued into it, and the existing screen contents be read
without re-authentication; this limitation is unrelated to the home directory management
pam_systemd_home and systemd-homed.service implement.)Turning this option on by default is highly recommended for all sessions, but only if the
service managing these sessions correctly implements the aforementioned re-authentication. Note that
the re-authentication must take place from a component running outside of the user's context, so that
it does not require access to the user's home directory for operation. Traditionally, most desktop
environments do not implement screen locking this way, and need to be updated
accordingly.debug=Takes an optional boolean argument. If yes or without the argument, the module will log
debugging information as it operates.Module Types ProvidedThe module provides all four management operations: , ,
, .EnvironmentThe following environment variables are initialized by the module and available to the processes of the
user's session:$SYSTEMD_HOME=1Indicates that the user's home directory is managed by systemd-homed.service.ExampleHere's an example PAM configuration fragment that permits users managed by
systemd-homed.service to log in:#%PAM-1.0
auth sufficient pam_unix.so
-auth sufficient pam_systemd_home.so
auth required pam_deny.so
account required pam_nologin.so
-account sufficient pam_systemd_home.so
account sufficient pam_unix.so
account required pam_permit.so
-password sufficient pam_systemd_home.so
password sufficient pam_unix.so sha512 shadow try_first_pass try_authtok
password required pam_deny.so
-session optional pam_keyinit.so revoke
-session optional pam_loginuid.so
-session optional pam_systemd_home.so
-session optional pam_systemd.so
session required pam_unix.soSee Alsosystemd1,
systemd-homed.service8,
homed.conf5,
homectl1,
pam_systemd8,
pam.conf5,
pam.d5,
pam8