From 376eaf187c13c2a1eaea0ffbdd970b6b563ab74c Mon Sep 17 00:00:00 2001 From: Petr Cech Date: Tue, 18 Aug 2015 06:59:31 -0400 Subject: DATA_PROVIDER: BE_REQ as string in log message Add be_req2str() for translation BE_REQ to string. So we will have || Got request for [0x1001][FAST BE_REQ_USER][1][name=celestian] instead of || Got request for [0x1001][1][name=celestian] Function be_req2str() is used in data provider and in responder too. So this patch create new header file data_provider_req.h which delivers function be_req2str() and definitions of BE_REQ_*. Resolves: https://fedorahosted.org/sssd/ticket/2708 Reviewed-by: Pavel Reichl --- src/providers/data_provider_req.c | 58 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 58 insertions(+) create mode 100644 src/providers/data_provider_req.c (limited to 'src/providers/data_provider_req.c') diff --git a/src/providers/data_provider_req.c b/src/providers/data_provider_req.c new file mode 100644 index 00000000..94aacb67 --- /dev/null +++ b/src/providers/data_provider_req.c @@ -0,0 +1,58 @@ +/* + SSSD + + Data Provider -- backend request + + Copyright (C) Petr Cech 2015 + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see . +*/ + +#include "providers/data_provider_req.h" + +#define be_req_to_str(req_type, be_req_t) \ + ((req_type) & BE_REQ_FAST) ? "FAST " #be_req_t : #be_req_t + +const char *be_req2str(dbus_uint32_t req_type) +{ + switch (req_type & BE_REQ_TYPE_MASK) { + case BE_REQ_USER: + return be_req_to_str(req_type, BE_REQ_USER); + case BE_REQ_GROUP: + return be_req_to_str(req_type, BE_REQ_GROUP); + case BE_REQ_INITGROUPS: + return be_req_to_str(req_type, BE_REQ_INITGROUPS); + case BE_REQ_NETGROUP: + return be_req_to_str(req_type, BE_REQ_NETGROUP); + case BE_REQ_SERVICES: + return be_req_to_str(req_type, BE_REQ_SERVICES); + case BE_REQ_SUDO_FULL: + return be_req_to_str(req_type, BE_REQ_SUDO_FULL); + case BE_REQ_SUDO_RULES: + return be_req_to_str(req_type, BE_REQ_SUDO_RULES); + case BE_REQ_AUTOFS: + return be_req_to_str(req_type, BE_REQ_AUTOFS); + case BE_REQ_HOST: + return be_req_to_str(req_type, BE_REQ_HOST); + case BE_REQ_BY_SECID: + return be_req_to_str(req_type, BE_REQ_BY_SECID); + case BE_REQ_USER_AND_GROUP: + return be_req_to_str(req_type, BE_REQ_USER_AND_GROUP); + case BE_REQ_BY_UUID: + return be_req_to_str(req_type, BE_REQ_BY_UUID); + case BE_REQ_BY_CERT: + return be_req_to_str(req_type, BE_REQ_BY_CERT); + } + return "UNKNOWN_REQ"; +} -- cgit