mirror of
https://github.com/morgan9e/systemd
synced 2026-04-14 00:14:32 +09:00
pam-systemd: modernize export_legacy_dbus_address() a bit
Let's log about unexpected access() failures among other things
This commit is contained in:
@@ -370,14 +370,14 @@ static int export_legacy_dbus_address(
|
||||
pam_handle_t *handle,
|
||||
const char *runtime) {
|
||||
|
||||
const char *s;
|
||||
_cleanup_free_ char *t = NULL;
|
||||
int r = PAM_BUF_ERR;
|
||||
int r;
|
||||
|
||||
assert(handle);
|
||||
|
||||
/* We need to export $DBUS_SESSION_BUS_ADDRESS because various applications will not connect
|
||||
* correctly to the bus without it. This setting matches what dbus.socket does for the user
|
||||
* session using 'systemctl --user set-environment'. We want to have the same configuration
|
||||
* in processes started from the PAM session.
|
||||
* correctly to the bus without it. This setting matches what dbus.socket does for the user session
|
||||
* using 'systemctl --user set-environment'. We want to have the same configuration in processes
|
||||
* started from the PAM session.
|
||||
*
|
||||
* The setting of the address is guarded by the access() check because it is also possible to compile
|
||||
* dbus without --enable-user-session, in which case this socket is not used, and
|
||||
@@ -386,14 +386,22 @@ static int export_legacy_dbus_address(
|
||||
* expect the socket to be present by the time we do this check, so we can just as well check once
|
||||
* here. */
|
||||
|
||||
s = strjoina(runtime, "/bus");
|
||||
if (access(s, F_OK) < 0)
|
||||
if (!runtime)
|
||||
return PAM_SUCCESS;
|
||||
|
||||
const char *s = strjoina(runtime, "/bus");
|
||||
if (access(s, F_OK) < 0) {
|
||||
if (errno != ENOENT)
|
||||
pam_syslog_errno(handle, LOG_WARNING, errno, "Failed to check if %s/bus exists, ignoring: %m", runtime);
|
||||
|
||||
return PAM_SUCCESS;
|
||||
}
|
||||
|
||||
_cleanup_free_ char *t = NULL;
|
||||
if (asprintf(&t, DEFAULT_USER_BUS_ADDRESS_FMT, runtime) < 0)
|
||||
return pam_log_oom(handle);
|
||||
|
||||
r = pam_misc_setenv(handle, "DBUS_SESSION_BUS_ADDRESS", t, 0);
|
||||
r = pam_misc_setenv(handle, "DBUS_SESSION_BUS_ADDRESS", t, /* readonly= */ false);
|
||||
if (r != PAM_SUCCESS)
|
||||
return pam_syslog_pam_error(handle, LOG_ERR, r, "Failed to set bus variable: @PAMERR@");
|
||||
|
||||
|
||||
Reference in New Issue
Block a user