summaryrefslogtreecommitdiffstats
path: root/server/util/usertools.c
diff options
context:
space:
mode:
authorStephen Gallagher <sgallagh@redhat.com>2009-02-24 12:02:05 -0500
committerSimo Sorce <idra@samba.org>2009-02-24 13:47:47 -0500
commitc14486feb47672a3562989ddb00653f58357e368 (patch)
tree92fe193ae916c95ae95654a55a7bdce45587aeac /server/util/usertools.c
parent795e12d8315c4f7f0d4b2abb77fb49e0417e362a (diff)
downloadsssd-c14486feb47672a3562989ddb00653f58357e368.tar.gz
sssd-c14486feb47672a3562989ddb00653f58357e368.tar.xz
sssd-c14486feb47672a3562989ddb00653f58357e368.zip
Adding support for CheckPermissions to InfoPipe.
CheckPermissions will currently return unrestricted access to the root user, and no access to any other user. Once we decide on an ACL mechanism, this will be easy to change. I have also added very basic tests for the Introspect and CheckPermissions methods.
Diffstat (limited to 'server/util/usertools.c')
-rw-r--r--server/util/usertools.c35
1 files changed, 35 insertions, 0 deletions
diff --git a/server/util/usertools.c b/server/util/usertools.c
new file mode 100644
index 000000000..079306134
--- /dev/null
+++ b/server/util/usertools.c
@@ -0,0 +1,35 @@
+/*
+ SSSD
+
+ User tools
+
+ Copyright (C) Stephen Gallagher <sgallagh@redhat.com> 2009
+
+ 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 <pwd.h>
+#include <talloc.h>
+
+char *get_username_from_uid(TALLOC_CTX *mem_ctx, uid_t uid)
+{
+ char *username;
+ struct passwd *pwd;
+
+ pwd = getpwuid(uid);
+ if (!pwd) return NULL;
+
+ username = talloc_strdup(mem_ctx, pwd->pw_name);
+ return username;
+}