_cleanup_(sd_bus_error_free) sd_bus_error error = SD_BUS_ERROR_NULL;
_cleanup_free_ char *generic_field = NULL, *json_copy = NULL;
- r = pam_acquire_bus_connection(handle, &bus);
+ r = pam_acquire_bus_connection(handle, "pam-systemd-home", &bus);
if (r != PAM_SUCCESS)
return r;
if (r == PAM_SUCCESS && PTR_TO_FD(home_fd_ptr) >= 0)
return PAM_SUCCESS;
- r = pam_acquire_bus_connection(handle, &bus);
+ r = pam_acquire_bus_connection(handle, "pam-systemd-home", &bus);
if (r != PAM_SUCCESS)
return r;
/* Let's release the D-Bus connection, after all the session might live quite a long time, and we are
* not going to process the bus connection in that time, so let's better close before the daemon
* kicks us off because we are not processing anything. */
- (void) pam_release_bus_connection(handle);
+ (void) pam_release_bus_connection(handle, "pam-systemd-home");
return PAM_SUCCESS;
}
if (r != PAM_SUCCESS)
return r;
- r = pam_acquire_bus_connection(handle, &bus);
+ r = pam_acquire_bus_connection(handle, "pam-systemd-home", &bus);
if (r != PAM_SUCCESS)
return r;
if (debug)
pam_syslog(handle, LOG_DEBUG, "pam-systemd-homed account management");
- r = pam_acquire_bus_connection(handle, &bus);
+ r = pam_acquire_bus_connection(handle, "pam-systemd-home", &bus);
if (r != PAM_SUCCESS)
return r;
/* Talk to logind over the message bus */
- r = pam_acquire_bus_connection(handle, &bus);
+ r = pam_acquire_bus_connection(handle, "pam-systemd", &bus);
if (r != PAM_SUCCESS)
return r;
/* Let's release the D-Bus connection, after all the session might live quite a long time, and we are
* not going to use the bus connection in that time, so let's better close before the daemon kicks us
* off because we are not processing anything. */
- (void) pam_release_bus_connection(handle);
+ (void) pam_release_bus_connection(handle, "pam-systemd");
return PAM_SUCCESS;
}
/* Before we go and close the FIFO we need to tell logind that this is a clean session
* shutdown, so that it doesn't just go and slaughter us immediately after closing the fd */
- r = pam_acquire_bus_connection(handle, &bus);
+ r = pam_acquire_bus_connection(handle, "pam-systemd", &bus);
if (r != PAM_SUCCESS)
return r;
sd_bus_flush_close_unref(data);
}
-int pam_acquire_bus_connection(pam_handle_t *handle, sd_bus **ret) {
+int pam_acquire_bus_connection(pam_handle_t *handle, const char *module_name, sd_bus **ret) {
_cleanup_(sd_bus_unrefp) sd_bus *bus = NULL;
+ _cleanup_free_ char *cache_id = NULL;
int r;
assert(handle);
+ assert(module_name);
assert(ret);
+ cache_id = strjoin("system-bus-", module_name);
+ if (!cache_id)
+ return pam_log_oom(handle);
+
/* We cache the bus connection so that we can share it between the session and the authentication hooks */
- r = pam_get_data(handle, "systemd-system-bus", (const void**) &bus);
+ r = pam_get_data(handle, cache_id, (const void**) &bus);
if (r == PAM_SUCCESS && bus) {
*ret = sd_bus_ref(TAKE_PTR(bus)); /* Increase the reference counter, so that the PAM data stays valid */
return PAM_SUCCESS;
if (r < 0)
return pam_syslog_errno(handle, LOG_ERR, r, "Failed to connect to system bus: %m");
- r = pam_set_data(handle, "systemd-system-bus", bus, cleanup_system_bus);
+ r = pam_set_data(handle, cache_id, bus, cleanup_system_bus);
if (r != PAM_SUCCESS)
return pam_syslog_pam_error(handle, LOG_ERR, r, "Failed to set PAM bus data: @PAMERR@");
return PAM_SUCCESS;
}
-int pam_release_bus_connection(pam_handle_t *handle) {
+int pam_release_bus_connection(pam_handle_t *handle, const char *module_name) {
+ _cleanup_free_ char *cache_id = NULL;
int r;
- r = pam_set_data(handle, "systemd-system-bus", NULL, NULL);
+ assert(module_name);
+
+ cache_id = strjoin("system-bus-", module_name);
+ if (!cache_id)
+ return pam_log_oom(handle);
+
+ r = pam_set_data(handle, cache_id, NULL, NULL);
if (r != PAM_SUCCESS)
return pam_syslog_pam_error(handle, LOG_ERR, r, "Failed to release PAM user record data: @PAMERR@");
return pam_syslog_errno(handle, LOG_ERR, r, "Failed to parse bus message: %m");
}
-int pam_acquire_bus_connection(pam_handle_t *handle, sd_bus **ret);
-int pam_release_bus_connection(pam_handle_t *handle);
+/* Use a different module name per different PAM module. They are all loaded in the same namespace, and this
+ * helps avoid a clash in the internal data structures of sd-bus. It will be used as key for cache items. */
+int pam_acquire_bus_connection(pam_handle_t *handle, const char *module_name, sd_bus **ret);
+int pam_release_bus_connection(pam_handle_t *handle, const char *module_name);
void pam_cleanup_free(pam_handle_t *handle, void *data, int error_status);