From 6adf56bb13227afac2c37871b3443fb5354d132c Mon Sep 17 00:00:00 2001 From: James Moger <james.moger@gitblit.com> Date: Thu, 02 Aug 2012 00:27:02 -0400 Subject: [PATCH] Per-repository authorization control: AUTHENTICATED and NAMED (issue 117) --- src/com/gitblit/models/UserModel.java | 8 +++++++- 1 files changed, 7 insertions(+), 1 deletions(-) diff --git a/src/com/gitblit/models/UserModel.java b/src/com/gitblit/models/UserModel.java index 6632c61..8349bab 100644 --- a/src/com/gitblit/models/UserModel.java +++ b/src/com/gitblit/models/UserModel.java @@ -20,6 +20,7 @@ import java.util.HashSet; import java.util.Set; +import com.gitblit.Constants.AuthorizationControl; import com.gitblit.utils.StringUtils; /** @@ -45,8 +46,12 @@ public final Set<String> repositories = new HashSet<String>(); public final Set<TeamModel> teams = new HashSet<TeamModel>(); + // non-persisted fields + public boolean isAuthenticated; + public UserModel(String username) { this.username = username; + this.isAuthenticated = true; } /** @@ -65,8 +70,9 @@ public boolean canAccessRepository(RepositoryModel repository) { boolean isOwner = !StringUtils.isEmpty(repository.owner) && repository.owner.equals(username); + boolean allowAuthenticated = isAuthenticated && AuthorizationControl.AUTHENTICATED.equals(repository.authorizationControl); return canAdmin || isOwner || repositories.contains(repository.name.toLowerCase()) - || hasTeamAccess(repository.name); + || hasTeamAccess(repository.name) || allowAuthenticated; } public boolean hasTeamAccess(String repositoryName) { -- Gitblit v1.9.1