]> granicus.if.org Git - uw-imap/commitdiff
add files for 2006-08-31T01:36:02Z
authorUnknown <>
Thu, 31 Aug 2006 01:36:02 +0000 (01:36 +0000)
committerNathan Wagner <nw@hydaspes.if.org>
Fri, 7 Sep 2018 00:02:32 +0000 (00:02 +0000)
src/osdep/unix/ckp_svo.c [new file with mode: 0644]

diff --git a/src/osdep/unix/ckp_svo.c b/src/osdep/unix/ckp_svo.c
new file mode 100644 (file)
index 0000000..ffb19a6
--- /dev/null
@@ -0,0 +1,89 @@
+/* ========================================================================
+ * Copyright 1988-2006 University of Washington
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *     http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * 
+ * ========================================================================
+ */
+
+/*
+ * Program:    Old SVR4 check password
+ *
+ * Author:     Mark Crispin
+ *             Networks and Distributed Computing
+ *             Computing & Communications
+ *             University of Washington
+ *             Administration Building, AG-44
+ *             Seattle, WA  98195
+ *             Internet: MRC@CAC.Washington.EDU
+ *
+ * Date:       1 August 1988
+ * Last Edited:        30 August 2006
+ */
+\f
+/* Check password
+ * Accepts: login passwd struct
+ *         password string
+ *         argument count
+ *         argument vector
+ * Returns: passwd struct if password validated, NIL otherwise
+ */
+
+struct passwd *checkpw (struct passwd *pw,char *pass,int argc,char *argv[])
+{
+  char tmp[MAILTMPLEN];
+  struct spwd *sp = NIL;
+  time_t left;
+  time_t now = time (0);
+  struct tm *t = gmtime (&now);
+  int zone = t->tm_hour * 60 + t->tm_min;
+  int julian = t->tm_yday;
+  t = localtime (&now);                /* get local time now */
+                               /* minus UTC minutes since midnight */
+  zone = t->tm_hour * 60 + t->tm_min - zone;
+  /* julian can be one of:
+   *  36x  local time is December 31, UTC is January 1, offset -24 hours
+   *    1  local time is 1 day ahead of UTC, offset +24 hours
+   *    0  local time is same day as UTC, no offset
+   *   -1  local time is 1 day behind UTC, offset -24 hours
+   * -36x  local time is January 1, UTC is December 31, offset +24 hours
+   */
+  if (julian = t->tm_yday -julian)
+    zone += ((julian < 0) == (abs (julian) == 1)) ? -24*60 : 24*60;
+                               /* days since 1/1/1970 local time */
+  now = ((now /60) + zone) / (60*24);
+                               /* non-shadow authentication */
+  if (!pw->pw_passwd || !pw->pw_passwd[0] || !pw->pw_passwd[1] ||
+      strcmp (pw->pw_passwd,(char *) crypt (pass,pw->pw_passwd))) {
+    /* As far as I've been able to determine, here is how the expiration
+     * fields in the shadow authentication data work:
+     *  lstchg last password change date if non-negative.  If zero, the
+     *         user can not log in without changing password.
+     *  max    number of days a password is valid if positive
+     * The expiration day is the *last* day that the password is valid.
+     */
+                               /* shadow authentication */
+    if ((sp = getspnam (pw->pw_name)) && sp->sp_lstchg &&
+       ((sp->sp_lstchg < 0) || (sp->sp_max <= 0) ||
+        ((sp->sp_lstchg + sp->sp_max) >= now)) &&
+       sp->sp_pwdp && sp->sp_pwdp[0] && sp->sp_pwdp[1] &&
+       !strcmp (sp->sp_pwdp,(char *) crypt (pass,sp->sp_pwdp))) {
+      if ((sp->sp_lstchg > 0) && (sp->sp_max > 0) &&
+         ((left = (sp->sp_lstchg + sp->sp_max) - now) <= 28)) {
+       if (left) {
+         sprintf (tmp,"[ALERT] Password expires in %ld day(s)",(long) left);
+         mm_notify (NIL,tmp,NIL);
+       }
+       else mm_notify (NIL,"[ALERT] Password expires today!",WARN);
+      }
+      endspent ();             /* don't need shadow password data any more */
+    }
+    else pw = NIL;             /* password failed */
+  }
+  return pw;
+}