6e3d990
diff -up cyrus-imapd-2.3.15/lib/auth_unix.c.authid_normalize cyrus-imapd-2.3.15/lib/auth_unix.c
6e3d990
--- cyrus-imapd-2.3.15/lib/auth_unix.c.authid_normalize	2009-09-18 11:53:47.183115911 +0200
6e3d990
+++ cyrus-imapd-2.3.15/lib/auth_unix.c	2009-09-18 11:53:47.252115833 +0200
6e3d990
@@ -156,10 +156,12 @@ const char *identifier;
9e566a4
 size_t len;
9e566a4
 {
9e566a4
     static char retbuf[81];
9e566a4
+    char backup[81];
9e566a4
     struct group *grp;
9e566a4
     char sawalpha;
9e566a4
     char *p;
9e566a4
     int username_tolower = 0;
9e566a4
+    int ic,rbc;
9e566a4
 
9e566a4
     if(!len) len = strlen(identifier);
9e566a4
     if(len >= sizeof(retbuf)) return NULL;
6e3d990
@@ -211,6 +213,22 @@ size_t len;
9e566a4
     /* now we don't */
9e566a4
     /* if (!sawalpha) return NULL;  */
9e566a4
 
9e566a4
+    if( (libcyrus_config_getswitch(CYRUSOPT_NORMALIZEUID) == 1) ) {
9e566a4
+        strcpy(backup,retbuf);
9e566a4
+       /* remove leading blanks */
9e566a4
+       for(ic=0; isblank(backup[ic]); ic++);
9e566a4
+       for(rbc=0; backup[ic]; ic++) {
9e566a4
+            retbuf[rbc] = ( isalpha(backup[ic]) ?
9e566a4
+                 tolower(backup[ic]) : backup[ic] );
9e566a4
+            rbc++;
9e566a4
+       }
9e566a4
+       retbuf[rbc] = '\0';
9e566a4
+       /* remove trailing blanks */
9e566a4
+       for(--rbc; isblank(retbuf[rbc]); rbc--) {
9e566a4
+            retbuf[rbc] = '\0';
9e566a4
+       }
9e566a4
+    }
9e566a4
+
9e566a4
     return retbuf;
9e566a4
 }
9e566a4
 
6e3d990
diff -up cyrus-imapd-2.3.15/lib/imapoptions.authid_normalize cyrus-imapd-2.3.15/lib/imapoptions
6e3d990
--- cyrus-imapd-2.3.15/lib/imapoptions.authid_normalize	2009-09-18 11:53:47.244115877 +0200
6e3d990
+++ cyrus-imapd-2.3.15/lib/imapoptions	2009-09-18 11:53:47.260115873 +0200
6e3d990
@@ -1217,6 +1217,11 @@ product version in the capabilities */
9e566a4
    interface, otherwise the user is assumed to be in the default
9e566a4
    domain (if set). */
9e566a4
 
9e566a4
+{ "normalizeuid", 0, SWITCH }
9e566a4
+/* Lowercase uid and strip leading and trailing blanks. It is recommended
9e566a4
+   to set this to yes, especially if OpenLDAP is used as authentication
9e566a4
+   source. */
9e566a4
+
9e566a4
 /*
9e566a4
 .SH SEE ALSO
9e566a4
 .PP
6e3d990
diff -up cyrus-imapd-2.3.15/lib/libcyr_cfg.c.authid_normalize cyrus-imapd-2.3.15/lib/libcyr_cfg.c
6e3d990
--- cyrus-imapd-2.3.15/lib/libcyr_cfg.c.authid_normalize	2009-03-31 06:43:20.000000000 +0200
6e3d990
+++ cyrus-imapd-2.3.15/lib/libcyr_cfg.c	2009-09-18 11:55:03.436822867 +0200
6e3d990
@@ -154,6 +154,10 @@ struct cyrusopt_s cyrus_options[] = {
6e3d990
       CFGVAL(long, 1),
2bab04f
       CYRUS_OPT_SWITCH },
9e566a4
 
9e566a4
+    { CYRUSOPT_NORMALIZEUID,
9e566a4
+      CFGVAL(long, 1),
9e566a4
+      CYRUS_OPT_SWITCH },
9e566a4
+
9e566a4
     { CYRUSOPT_LAST, { NULL }, CYRUS_OPT_NOTOPT }
9e566a4
 };
9e566a4
 
6e3d990
diff -up cyrus-imapd-2.3.15/lib/libcyr_cfg.h.authid_normalize cyrus-imapd-2.3.15/lib/libcyr_cfg.h
6e3d990
--- cyrus-imapd-2.3.15/lib/libcyr_cfg.h.authid_normalize	2009-03-31 06:43:20.000000000 +0200
6e3d990
+++ cyrus-imapd-2.3.15/lib/libcyr_cfg.h	2009-09-18 11:55:33.267115989 +0200
6e3d990
@@ -114,6 +114,8 @@ enum cyrus_opt {
6e3d990
     CYRUSOPT_SQL_USESSL,
6e3d990
     /* Checkpoint after every recovery (OFF) */
6e3d990
     CYRUSOPT_SKIPLIST_ALWAYS_CHECKPOINT,
6e3d990
+    /* Lowercase uid and strip leading and trailing blanks (OFF) */
6e3d990
+    CYRUSOPT_NORMALIZEUID,
6e3d990
 
6e3d990
     CYRUSOPT_LAST
6e3d990