James Moger
2012-04-25 0aa8cf8606600d628b2c491e52e9e3c901f9cc80
src/com/gitblit/LdapUserService.java
@@ -106,6 +106,29 @@
   }
   
   /**
    * If no displayName pattern is defined then Gitblit can manage the display name.
    *
    * @return true if Gitblit can manage the user display name
    * @since 1.0.0
    */
   @Override
   public boolean supportsDisplayNameChanges() {
      return StringUtils.isEmpty(settings.getString(Keys.realm.ldap.displayName, ""));
   }
   /**
    * If no email pattern is defined then Gitblit can manage the email address.
    *
    * @return true if Gitblit can manage the user email address
    * @since 1.0.0
    */
   @Override
   public boolean supportsEmailAddressChanges() {
      return StringUtils.isEmpty(settings.getString(Keys.realm.ldap.email, ""));
   }
   /**
    * If the LDAP server will maintain team memberships then LdapUserService
    * will not allow team membership changes.  In this scenario all team
    * changes must be made on the LDAP server by the LDAP administrator.
@@ -194,10 +217,9 @@
      // Don't want visibility into the real password, make up a dummy
      user.password = "StoredInLDAP";
      
      // Get Attributes for full name / email
      String displayName = settings.getString(Keys.realm.ldap.displayName, "displayName");
      String email = settings.getString(Keys.realm.ldap.email, "email");
      // Get full name Attribute
      String displayName = settings.getString(Keys.realm.ldap.displayName, "");
      if (!StringUtils.isEmpty(displayName)) {
      // Replace embedded ${} with attributes
      if (displayName.contains("${")) {
         for (Attribute userAttribute : userEntry.getAttributes())
@@ -207,7 +229,11 @@
      } else {
         user.displayName = userEntry.getAttribute(displayName).getValue();
      }
      }
      
      // Get email address Attribute
      String email = settings.getString(Keys.realm.ldap.email, "");
      if (!StringUtils.isEmpty(email)) {
      if (email.contains("${")) {
         for (Attribute userAttribute : userEntry.getAttributes())
            email = StringUtils.replace(email, "${" + userAttribute.getName() + "}", userAttribute.getValue());
@@ -217,6 +243,7 @@
         user.emailAddress = userEntry.getAttribute(email).getValue();
      }
   }
   }
   private void getTeamsFromLdap(LDAPConnection ldapConnection, String simpleUsername, SearchResultEntry loggingInUser, UserModel user) {
      String loggingInUserDN = loggingInUser.getDN();