f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio IPA Backend Module -- Session Management
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio Fabiano Fidêncio <fidencio@redhat.com>
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio Copyright (C) 2017 Red Hat
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio This program is free software; you can redistribute it and/or modify
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio it under the terms of the GNU General Public License as published by
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio the Free Software Foundation; either version 3 of the License, or
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio (at your option) any later version.
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio This program is distributed in the hope that it will be useful,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio but WITHOUT ANY WARRANTY; without even the implied warranty of
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio GNU General Public License for more details.
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio You should have received a copy of the GNU General Public License
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio along with this program. If not, see <http://www.gnu.org/licenses/>.
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio#include "providers/ipa/ipa_deskprofile_private.h"
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio#include "providers/ipa/ipa_deskprofile_config.h"
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio#include "providers/ipa/ipa_deskprofile_rules.h"
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio#include "providers/ipa/ipa_deskprofile_rules_util.h"
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio/* Those here are used for sending a message to the deskprofile client
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio * informing that our side is done. */
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio#define SSS_FLEETCOMMANDERCLIENT_BUS "org.freedesktop.FleetCommanderClient"
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio#define SSS_FLEETCOMMANDERCLIENT_PATH "/org/freedesktop/FleetCommanderClient"
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio#define SSS_FLEETCOMMANDERCLIENT_IFACE "org.freedesktop.FleetCommanderClient"
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidênciostatic errno_t ipa_fetch_deskprofile_retry(struct tevent_req *req);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidênciostatic void ipa_fetch_deskprofile_connect_done(struct tevent_req *subreq);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidênciostatic errno_t ipa_fetch_deskprofile_hostinfo(struct tevent_req *req);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidênciostatic void ipa_fetch_deskprofile_hostinfo_done(struct tevent_req *subreq);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidênciostatic void ipa_fetch_deskprofile_config_done(struct tevent_req *subreq);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidênciostatic void ipa_fetch_deskprofile_rules_done(struct tevent_req *subreq);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncioipa_fetch_deskprofile_send(TALLOC_CTX *mem_ctx,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio DEBUG(SSSDBG_CRIT_FAILURE, "tevent_req_create() failed\n");
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio state->ipa_options = session_ctx->ipa_options;
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio state->search_bases = session_ctx->deskprofile_search_bases;
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio state->hosts = talloc_zero(state, struct ipa_common_entries);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio state->rules = talloc_zero(state, struct ipa_common_entries);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio DEBUG(SSSDBG_CRIT_FAILURE, "No Desktop Profile search base found.\n");
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio DEBUG(SSSDBG_OP_FAILURE, "sdap_id_op_create() failed\n");
4a311702045b065a97a0c0fc0ccc7a1fc84b38cfFabiano Fidêncio request_interval = dp_opt_get_int(state->ipa_options,
4a311702045b065a97a0c0fc0ccc7a1fc84b38cfFabiano Fidêncio /* This value is in minutes ... */
4a311702045b065a97a0c0fc0ccc7a1fc84b38cfFabiano Fidêncio now < session_ctx->last_request + request_interval) {
4a311702045b065a97a0c0fc0ccc7a1fc84b38cfFabiano Fidêncio next_request = (session_ctx->last_request + request_interval - now);
4a311702045b065a97a0c0fc0ccc7a1fc84b38cfFabiano Fidêncio /* This value is in seconds ... */
4a311702045b065a97a0c0fc0ccc7a1fc84b38cfFabiano Fidêncio "No rules were found in the last request.\n"
0475a98d313b8380e7fbf98ee0821a65f8140589Sumit Bose "Next request will happen in any login after %ld minutes\n",
4a311702045b065a97a0c0fc0ccc7a1fc84b38cfFabiano Fidêncio state->session_ctx->no_rules_found = false;
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio DEBUG(SSSDBG_TRACE_ALL, "Connection status is [%s].\n",
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio refresh_interval = dp_opt_get_int(state->ipa_options,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio if (offline || now < session_ctx->last_update + refresh_interval) {
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio "Performing cached Desktop Profile evaluation\n");
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncioipa_fetch_deskprofile_retry(struct tevent_req *req)
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio state = tevent_req_data(req, struct ipa_fetch_deskprofile_state);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio subreq = sdap_id_op_connect_send(state->sdap_op, state, &ret);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio "sdap_id_op_connect_send() failed: %d (%s)\n",
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio tevent_req_set_callback(subreq, ipa_fetch_deskprofile_connect_done, req);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncioipa_fetch_deskprofile_connect_done(struct tevent_req *subreq)
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio req = tevent_req_callback_data(subreq, struct tevent_req);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio ret = sdap_id_op_connect_recv(subreq, &dp_error);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncioipa_fetch_deskprofile_hostinfo(struct tevent_req *req)
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio state = tevent_req_data(req, struct ipa_fetch_deskprofile_state);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio hostname = dp_opt_get_string(state->ipa_options, IPA_HOSTNAME);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio tevent_req_set_callback(subreq, ipa_fetch_deskprofile_hostinfo_done, req);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncioipa_fetch_deskprofile_hostinfo_done(struct tevent_req *subreq)
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio req = tevent_req_callback_data(subreq, struct tevent_req);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio state = tevent_req_data(req, struct ipa_fetch_deskprofile_state);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio state->hosts->entry_subdir = DESKPROFILE_HOSTS_SUBDIR;
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio state->hosts->group_subdir = DESKPROFILE_HOSTGROUPS_SUBDIR;
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio ret = ipa_get_host_attrs(state->ipa_options,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio DEBUG(SSSDBG_CRIT_FAILURE, "Could not locate IPA host.\n");
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio subreq = ipa_deskprofile_get_config_send(state,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio tevent_req_set_callback(subreq, ipa_fetch_deskprofile_config_done, req);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncioipa_fetch_deskprofile_config_done(struct tevent_req *subreq)
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio req = tevent_req_callback_data(subreq, struct tevent_req);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio state = tevent_req_data(req, struct ipa_fetch_deskprofile_state);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio ret = ipa_deskprofile_get_config_recv(subreq, state, &state->config);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio ret = sysdb_store_custom(state->be_ctx->domain, IPA_DESKPROFILE_PRIORITY,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio DEBUG(SSSDBG_CRIT_FAILURE, "Unable to save Desktop Profile policy\n");
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio subreq = ipa_deskprofile_rule_info_send(state,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio tevent_req_set_callback(subreq, ipa_fetch_deskprofile_rules_done, req);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncioipa_fetch_deskprofile_rules_done(struct tevent_req *subreq)
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio req = tevent_req_callback_data(subreq, struct tevent_req);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio state = tevent_req_data(req, struct ipa_fetch_deskprofile_state);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio ret = ipa_deskprofile_rule_info_recv(subreq,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio state->rules->entry_subdir = DESKPROFILE_RULES_SUBDIR;
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio /* Set ret to EOK so we can safely call sdap_id_op_done. */
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio ret = sdap_id_op_done(state->sdap_op, ret, &dp_error);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio /* For now, let's completely purge the previous stored
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio * rules before saving the new ones */
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio ret = ipa_common_purge_rules(state->be_ctx->domain,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio "Unable to remove Desktop Profile rules\n");
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio ret = ipa_common_save_rules(state->be_ctx->domain,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio DEBUG(SSSDBG_CRIT_FAILURE, "Unable to save Desktop Profile rules\n");
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncioipa_fetch_deskprofile_recv(struct tevent_req *req)
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio /* Those attributes are used for:
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio * - saving the deskprofile rules to the disk;
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio * - deleting the deskprofile rules from the disk;
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio * - contacting the deskprofile client that everything is ready;
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncioipa_pam_session_handler_get_deskprofile_user_info(
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidênciostatic void ipa_pam_session_handler_done(struct tevent_req *subreq);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncioipa_pam_session_handler_save_deskprofile_rules(
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio const char *username, /* fully-qualified */
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncioipa_pam_session_handler_notify_deskprofile_client(uid_t uid,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncioipa_pam_session_handler_send(TALLOC_CTX *mem_ctx,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio struct ipa_pam_session_handler_state *state;
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio DEBUG(SSSDBG_TRACE_FUNC, "Retrieving Desktop Profile rules\n");
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio DEBUG(SSSDBG_CRIT_FAILURE, "tevent_req_create() failed\n");
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio /* Get all the user info that will be needed in order the delete the
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio * user's deskprofile directory from the disk, create the user's directory,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio * save the fetched rules to the disk and notify the deskprofile client
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio * that this operation is done. */
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio ret = ipa_pam_session_handler_get_deskprofile_user_info(
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio "ipa_deskprofile_get_user_info() failed [%d]: %s\n",
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio /* As no proper merging mechanism has been implemented yet ...
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio * let's just remove the user directory stored in the disk as it's
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio * going to be created again in case there's any rule fetched. */
1a011c4f20e80f2bcb4d10a4d690b3a88c2fd70dFabiano Fidêncio ret = ipa_deskprofile_rules_remove_user_dir(state->user_dir,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio "ipa_deskprofile_rules_remove_user_dir() failed.\n");
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio subreq = ipa_fetch_deskprofile_send(state, state->ev, state->be_ctx,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio tevent_req_set_callback(subreq, ipa_pam_session_handler_done, req);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncioipa_pam_session_handler_done(struct tevent_req *subreq)
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio struct ipa_pam_session_handler_state *state;
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio req = tevent_req_callback_data(subreq, struct tevent_req);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio state = tevent_req_data(req, struct ipa_pam_session_handler_state);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio DEBUG(SSSDBG_IMPORTANT_INFO, "No Desktop Profile rules found\n");
4a311702045b065a97a0c0fc0ccc7a1fc84b38cfFabiano Fidêncio state->session_ctx->last_request = time(NULL);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio "Unable to fetch Desktop Profile rules [%d]: %s\n",
4a311702045b065a97a0c0fc0ccc7a1fc84b38cfFabiano Fidêncio state->session_ctx->last_request = time(NULL);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio hostname = dp_opt_get_string(state->session_ctx->ipa_options, IPA_HOSTNAME);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio ret = ipa_pam_session_handler_save_deskprofile_rules(state->be_ctx,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio state->pd->pam_status = (ret == EOK) ? PAM_SUCCESS : PAM_SESSION_ERR;
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio /* TODO For backward compatibility we always return EOK to DP now. */
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncioipa_pam_session_handler_recv(TALLOC_CTX *mem_ctx,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio struct ipa_pam_session_handler_state *state = NULL;
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio state = tevent_req_data(req, struct ipa_pam_session_handler_state);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncioipa_pam_session_handler_get_deskprofile_user_info(TALLOC_CTX *mem_ctx,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio ret = sss_parse_internal_fqname(tmp_ctx, username,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio DEBUG(SSSDBG_TRACE_FUNC, "Failed to parse \"%s\" [%d]: %s\n",
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio user_dir = talloc_asprintf(tmp_ctx, IPA_DESKPROFILE_RULES_USER_DIR"/%s/%s",
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio DEBUG(SSSDBG_CRIT_FAILURE, "talloc_asprintf() failed!\n");
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio ret = sysdb_getpwnam(tmp_ctx, domain, username, &res);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio DEBUG(SSSDBG_CRIT_FAILURE, "sysdb_getpwnam() failed [%d]: %s\n",
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio "sysdb_getpwnam() got more users than expected. "
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio "Expected [%d], got [%d]\n", 1, res->count);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio uid = ldb_msg_find_attr_as_uint64(res->msgs[0], SYSDB_UIDNUM, 0);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio gid = ldb_msg_find_attr_as_uint64(res->msgs[0], SYSDB_GIDNUM, 0);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio /* As IPA doesn't handle root users ou groups, we know for sure that's
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio * something wrong in case we get uid = 0 or gid = 0.
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio *_shortname = talloc_steal(mem_ctx, shortname);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio *_domain = talloc_steal(mem_ctx, domain_name);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio *_user_dir = talloc_steal(mem_ctx, user_dir);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncioipa_pam_session_handler_save_deskprofile_rules(
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio const char *username, /* fully-qualified */
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio /* Get Desktop Profile priority from sysdb */
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio ret = deskprofile_get_cached_priority(be_ctx->domain, &priority);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio "deskprofile_get_cached_priority() failed [%d]: %s\n",
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio /* Get Desktop Profile rules from sysdb */
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio attrs_get_cached_rules = deskprofile_get_attrs_to_get_cached_rules(tmp_ctx);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio "deskprofile_get_attrs_get_cached_rules() failed\n");
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio ret = ipa_common_get_cached_rules(tmp_ctx, be_ctx->domain,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio "Could not retrieve Desktop Profile rules from the cache\n");
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio /* Create the user directory where the rules are going to be stored */
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio ret = ipa_deskprofile_rules_create_user_dir(username, uid, gid);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio "Cannot create the user directory [%d]: %s\n",
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio /* Save the rules to the disk */
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio ret = ipa_deskprofile_rules_save_rule_to_disk(tmp_ctx,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio "Failed to save a Desktop Profile Rule to disk [%d]: %s\n",
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio /* Notify FleetCommander that our side is done */
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio ret = ipa_pam_session_handler_notify_deskprofile_client(uid,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio "ipa_pam_session_handler_notify_deskprofile_client() "
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio "failed [%d]: %s\n",
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio conn = dbus_bus_get(DBUS_BUS_SYSTEM, &error);
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio "Unable to connect to the FleetCommanderClient bus [%s]: %s\n",
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncioipa_pam_session_handler_notify_deskprofile_client(uid_t uid,
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio "ProcessSSSDFiles",
f982039c75ec064894deb676ae53ee57de868590Fabiano Fidêncio DEBUG(SSSDBG_CRIT_FAILURE, "Unable to create D-Bus Message!\n");