--- /dev/null
+/*
+** Copyright 1998 - 1999 Double Precision, Inc. See COPYING for
+** distribution information.
+*/
+
+#if HAVE_CONFIG_H
+#include "courier_auth_config.h"
+#endif
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <errno.h>
+#include <pwd.h>
+#if HAVE_UNISTD_H
+#include <unistd.h>
+#endif
+
+#include "auth.h"
+#include "authsqlite.h"
+
+int auth_sqlite_pre(const char *user, const char *service,
+ int (*callback)(struct authinfo *, void *), void *arg)
+{
+ struct authsqliteuserinfo *authinfo;
+ struct authinfo aa;
+
+ authinfo=auth_sqlite_getuserinfo(user, service);
+
+ if (!authinfo) /* Fatal error - such as Sqlite being down */
+ return (1);
+
+ if (!authinfo->home) /* User not found */
+ return (-1);
+
+ memset(&aa, 0, sizeof(aa));
+
+ /*aa.sysusername=user;*/
+ aa.sysuserid= &authinfo->uid;
+ aa.sysgroupid= authinfo->gid;
+ aa.homedir=authinfo->home;
+ aa.maildir=authinfo->maildir && authinfo->maildir[0] ?
+ authinfo->maildir:0;
+ aa.address=authinfo->username;
+ aa.passwd=authinfo->cryptpw;
+ aa.clearpasswd=authinfo->clearpw;
+ aa.fullname=authinfo->fullname;
+ aa.quota=authinfo->quota && authinfo->quota[0] ?
+ authinfo->quota:0;
+ aa.options=authinfo->options;
+ return ((*callback)(&aa, arg));
+}