summaryrefslogtreecommitdiffstats
path: root/pcp/pcpdauth.c
diff options
context:
space:
mode:
authorSam Varshavchik2013-08-19 16:39:41 -0400
committerSam Varshavchik2013-08-25 14:43:51 -0400
commit9c45d9ad13fdf439d44d7443ae75da15ea0223ed (patch)
tree7a81a04cb51efb078ee350859a64be2ebc6b8813 /pcp/pcpdauth.c
parenta9520698b770168d1f33d6301463bb70a19655ec (diff)
downloadcourier-libs-9c45d9ad13fdf439d44d7443ae75da15ea0223ed.tar.bz2
Initial checkin
Imported from subversion report, converted to git. Updated all paths in scripts and makefiles, reflecting the new directory hierarchy.
Diffstat (limited to 'pcp/pcpdauth.c')
-rw-r--r--pcp/pcpdauth.c148
1 files changed, 148 insertions, 0 deletions
diff --git a/pcp/pcpdauth.c b/pcp/pcpdauth.c
new file mode 100644
index 0000000..16ce0e3
--- /dev/null
+++ b/pcp/pcpdauth.c
@@ -0,0 +1,148 @@
+/*
+** Copyright 2001-2004 Double Precision, Inc. See COPYING for
+** distribution information.
+*/
+
+
+/*
+*/
+
+#include "config.h"
+
+#if HAVE_SYS_STAT_H
+#include <sys/stat.h>
+#endif
+#if HAVE_SYS_WAIT_H
+#include <sys/wait.h>
+#endif
+
+#if HAVE_UNISTD_H
+#include <unistd.h>
+#endif
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <ctype.h>
+#include <pwd.h>
+#if HAVE_UNISTD_H
+#include <unistd.h>
+#endif
+#include <string.h>
+#include <errno.h>
+#include <sysconfdir.h>
+
+#include "courierauth.h"
+
+#include "pcpdauth.h"
+#include "calendardir.h"
+
+char *auth_choplocalhost(const char *u)
+{
+ const char *p;
+ char *s;
+
+ p=strrchr(u, '@');
+ if (p && strcasecmp(p+1, auth_myhostname()) == 0)
+ {
+ s=malloc(p-u+1);
+ if (s)
+ {
+ memcpy(s, u, p-u);
+ s[p-u]=0;
+ }
+ }
+ else
+ s=strdup(u);
+
+ if (!s)
+ fprintf(stderr, "ALERT: malloc failed.\n");
+ return (s);
+}
+
+static int badstr(const char *p)
+{
+ while (*p)
+ {
+ if ((int)(unsigned char)*p < ' '
+ || *p == '\\' || *p == '\'' || *p == '"')
+ {
+ errno=EIO;
+ return (1);
+ }
+ ++p;
+ }
+ return (0);
+}
+
+static int callback_userid(struct authinfo *a, void *vp)
+{
+ struct userid_callback *uid=(struct userid_callback *)vp;
+
+ uid->homedir=a->homedir;
+ uid->maildir=a->maildir;
+
+ if (a->sysuserid)
+ uid->uid= *a->sysuserid;
+ else if (!a->sysusername)
+ return (-1);
+ else
+ {
+ struct passwd *pw=getpwnam(a->sysusername);
+
+ if (!pw)
+ return (-1);
+ uid->uid=pw->pw_uid;
+ }
+ return ( (*uid->callback_func)(uid, uid->callback_arg));
+}
+
+int authpcp_userid(const char *u, int (*func)(struct userid_callback *, void *),
+ void *funcarg)
+{
+ char *s=NULL;
+ int rc;
+ struct userid_callback uinfo;
+
+ if (badstr(u))
+ return (-1);
+
+ s=auth_choplocalhost(u);
+ if (!s)
+ return (1);
+
+ memset(&uinfo, 0, sizeof(uinfo));
+ uinfo.userid=s;
+ uinfo.callback_func=func;
+ uinfo.callback_arg=funcarg;
+
+ rc=auth_getuserinfo("calendar", s, callback_userid, &uinfo);
+
+ free(s);
+ return (rc);
+}
+
+
+/*
+** The returned mailboxid is of the form user.authdriver
+**
+** authdriver is included so that we can find the same authentication module
+** quickly, for each request. authdriver is appended, rather than prepended,
+** because the logincache hashes on the first couple of characters of the id.
+*/
+
+int authpcp_login(const char *uid, const char *pass,
+ int (*func)(struct userid_callback *, void *),
+ void *arg)
+{
+ struct userid_callback uinfo;
+
+ memset(&uinfo, 0, sizeof(uinfo));
+ uinfo.callback_func=func;
+ uinfo.callback_arg=arg;
+
+ if (badstr(uid) || badstr(pass))
+ return (-1);
+
+
+ return (auth_login("calendar", uid, pass, callback_userid, &uinfo));
+}