summaryrefslogtreecommitdiff
path: root/liblogfs/group.c
diff options
context:
space:
mode:
authorCharles.Forsyth <devnull@localhost>2006-12-22 17:07:39 +0000
committerCharles.Forsyth <devnull@localhost>2006-12-22 17:07:39 +0000
commit37da2899f40661e3e9631e497da8dc59b971cbd0 (patch)
treecbc6d4680e347d906f5fa7fca73214418741df72 /liblogfs/group.c
parent54bc8ff236ac10b3eaa928fd6bcfc0cdb2ba46ae (diff)
20060303a
Diffstat (limited to 'liblogfs/group.c')
-rw-r--r--liblogfs/group.c93
1 files changed, 93 insertions, 0 deletions
diff --git a/liblogfs/group.c b/liblogfs/group.c
new file mode 100644
index 00000000..7e187e63
--- /dev/null
+++ b/liblogfs/group.c
@@ -0,0 +1,93 @@
+#include "lib9.h"
+#include "logfs.h"
+#include "local.h"
+
+enum {
+ GROUPMOD = 127
+};
+
+static int
+groupcompare(Group *g, char *uid)
+{
+ return g->uid == uid;
+}
+
+static int
+unamecompare(Uname *u, char *uname)
+{
+ return u->uname == uname;
+}
+
+static int
+groupallocsize(void *key)
+{
+ USED(key);
+ return sizeof(Group);
+}
+
+static int
+unameallocsize(void *key)
+{
+ USED(key);
+ return sizeof(Uname);
+}
+
+char *
+logfsgroupmapnew(GroupMap **groupmapp, UnameMap **unamemapp)
+{
+ char *errmsg;
+ errmsg = logfsmapnew(GROUPMOD, logfshashulong, (int (*)(void *, void *))groupcompare,
+ groupallocsize, nil, groupmapp);
+ if(errmsg)
+ return errmsg;
+ errmsg = logfsmapnew(GROUPMOD, logfshashulong, (int (*)(void *, void *))unamecompare,
+ unameallocsize, nil, unamemapp);
+ if(errmsg)
+ logfsmapfree(groupmapp);
+ return errmsg;
+}
+
+char *
+logfsgroupmapnewentry(GroupMap *gm, UnameMap *um, char *uid, char *uname, Group **groupp, Uname **unamep)
+{
+ char *errmsg;
+ errmsg = logfsmapnewentry(gm, uid, groupp);
+ if(errmsg)
+ return errmsg;
+ errmsg = logfsgroupsetnew(&(*groupp)->members);
+ if(errmsg) {
+ logfsmapdeleteentry(gm, uid);
+ return errmsg;
+ }
+ errmsg = logfsmapnewentry(um, uname, unamep);
+ if(errmsg) {
+ logfsgroupsetfree(&(*groupp)->members);
+ logfsmapdeleteentry(gm, uid);
+ return errmsg;
+ }
+ (*groupp)->uid = uid;
+ (*groupp)->uname = uname;
+ (*unamep)->uname = uname;
+ (*unamep)->g = *groupp;
+ return nil;
+}
+
+char *
+logfsgroupmapfinduname(GroupMap *m, char *uid)
+{
+ Group *g;
+ g = logfsgroupmapfindentry(m, uid);
+ if(g)
+ return g->uname;
+ return nil;
+}
+
+char *
+logfsunamemapfinduid(UnameMap *m, char *uname)
+{
+ Uname *u;
+ u = logfsunamemapfindentry(m, uname);
+ if(u)
+ return u->g->uid;
+ return nil;
+}