If receive returns an error report it using CLOSE event.
[cascardo/rnetproxy.git] / usermap.c
index 64c13d0..9b8cb62 100644 (file)
--- a/usermap.c
+++ b/usermap.c
 */
 
 #include <string.h>
-#include <depot.h>
+#include <gdbm.h>
 #include "usermap.h"
 
+int ACCESS_DEFAULT = ACCESS_DENY;
+
 int
 usermap_perm (char *user)
 {
-  static DEPOT* allow_dp = NULL;
-  static DEPOT* deny_dp = NULL;
-  char* allow = NULL;
-  char* deny = NULL;
-  if (allow_dp == NULL)
-    {
-      allow_dp = dpopen ("/var/lib/popproxy/allow.db", DP_OREADER, 0);
-    }
-  if (deny_dp == NULL)
+  GDBM_FILE allow_db = NULL;
+  GDBM_FILE deny_db = NULL;
+  int allow = 0;
+  int deny = 0;
+  datum key;
+  key.dptr = user;
+  key.dsize = strlen (user);
+  allow_db = gdbm_open ("/var/lib/popproxy/allow.db",
+                        0, GDBM_READER, 0, NULL);
+  deny_db = gdbm_open ("/var/lib/popproxy/deny.db",
+                       0, GDBM_READER, 0, NULL);
+  if (allow_db)
     {
-      deny_dp = dpopen ("/var/lib/popproxy/allow.db", DP_OREADER, 0);
+      allow = gdbm_exists (allow_db, key);
+      gdbm_close (allow_db);
     }
-  if (allow_dp)
-    allow = dpget (allow_dp, user, -1, 0, -1, NULL);
-  if (deny_dp)
-    deny = dpget (deny_dp, user, -1, 0, -1, NULL);
-  if (allow && deny)
+  if (deny_db)
     {
-      free (allow);
-      free (deny);
-      return ACCESS_DENY;
-    }
-  if (allow)
-    {
-      free (allow);
-      return ACCESS_ALLOW;
+      deny = gdbm_exists (deny_db, key);
+      gdbm_close (deny_db);
     }
   if (deny)
-    {
-      free (deny);
-      return ACCESS_DENY;
-    }
-  if (!allow_dp)
+    return ACCESS_DENY;
+  if (allow)
     return ACCESS_ALLOW;
-  return ACCESS_DENY;
+  return ACCESS_DEFAULT;
 }