James Moger
2011-11-16 e19d3da3cdb4e3d0524e3a3ffc6a2cfa8876e927
src/com/gitblit/models/UserModel.java
@@ -17,8 +17,10 @@
import java.io.Serializable;
import java.security.Principal;
import java.util.ArrayList;
import java.util.List;
import java.util.HashSet;
import java.util.Set;
import com.gitblit.utils.StringUtils;
/**
 * UserModel is a serializable model class that represents a user and the user's
@@ -28,7 +30,7 @@
 * @author James Moger
 * 
 */
public class UserModel implements Principal, Serializable {
public class UserModel implements Principal, Serializable, Comparable<UserModel> {
   private static final long serialVersionUID = 1L;
@@ -36,14 +38,29 @@
   public String username;
   public String password;
   public boolean canAdmin;
   public final List<String> repositories = new ArrayList<String>();
   public boolean excludeFromFederation;
   public final Set<String> repositories = new HashSet<String>();
   public UserModel(String username) {
      this.username = username;
   }
   /**
    * This method does not take into consideration Ownership where the
    * administrator has not explicitly granted access to the owner.
    *
    * @param repositoryName
    * @return
    */
   @Deprecated
   public boolean canAccessRepository(String repositoryName) {
      return canAdmin || repositories.contains(repositoryName.toLowerCase());
   }
   public boolean canAccessRepository(RepositoryModel repository) {
      boolean isOwner = !StringUtils.isEmpty(repository.owner)
            && repository.owner.equals(username);
      return canAdmin || isOwner || repositories.contains(repository.name.toLowerCase());
   }
   public void addRepository(String name) {
@@ -59,4 +76,9 @@
   public String toString() {
      return username;
   }
   @Override
   public int compareTo(UserModel o) {
      return username.compareTo(o.username);
   }
}