diff options
| author | Petr Cech <pcech@redhat.com> | 2015-08-18 06:59:31 -0400 |
|---|---|---|
| committer | Jakub Hrozek <jhrozek@redhat.com> | 2015-09-14 16:00:49 +0200 |
| commit | 376eaf187c13c2a1eaea0ffbdd970b6b563ab74c (patch) | |
| tree | 0b4829b53497f0020d22385ef4e65c883ea8e5e2 /src/providers/data_provider_req.c | |
| parent | b3074dca3acebd91437ef13d3329d6d65d655215 (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.c | 58 |
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"; +} |
