summaryrefslogtreecommitdiffstats
path: root/src/providers/data_provider_req.c
diff options
context:
space:
mode:
authorPetr Cech <pcech@redhat.com>2015-08-18 06:59:31 -0400
committerJakub Hrozek <jhrozek@redhat.com>2015-09-14 16:00:49 +0200
commit376eaf187c13c2a1eaea0ffbdd970b6b563ab74c (patch)
tree0b4829b53497f0020d22385ef4e65c883ea8e5e2 /src/providers/data_provider_req.c
parentb3074dca3acebd91437ef13d3329d6d65d655215 (diff)
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 <preichl@redhat.com>
Diffstat (limited to 'src/providers/data_provider_req.c')
-rw-r--r--src/providers/data_provider_req.c58
1 files changed, 58 insertions, 0 deletions
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 <pcech@redhat.com> 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 <http://www.gnu.org/licenses/>.
+*/
+
+#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";
+}