*/
#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/deny.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;
}