From 1613f4067028b73e05544b55d45b6e136ce0238d Mon Sep 17 00:00:00 2001 From: James Moger <james.moger@gitblit.com> Date: Wed, 23 Jan 2013 07:58:51 -0500 Subject: [PATCH] Merged multiple owners (pull request #63) --- src/com/gitblit/models/RepositoryModel.java | 47 +++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 43 insertions(+), 4 deletions(-) diff --git a/src/com/gitblit/models/RepositoryModel.java b/src/com/gitblit/models/RepositoryModel.java index 022fd20..a2dab3c 100644 --- a/src/com/gitblit/models/RepositoryModel.java +++ b/src/com/gitblit/models/RepositoryModel.java @@ -17,6 +17,7 @@ import java.io.Serializable; import java.util.ArrayList; +import java.util.Collection; import java.util.Date; import java.util.List; import java.util.Map; @@ -43,7 +44,7 @@ // field names are reflectively mapped in EditRepository page public String name; public String description; - public String owner; + public List<String> owners; public Date lastChange; public boolean hasCommits; public boolean showRemoteBranches; @@ -91,13 +92,15 @@ public RepositoryModel(String name, String description, String owner, Date lastchange) { this.name = name; this.description = description; - this.owner = owner; this.lastChange = lastchange; this.accessRestriction = AccessRestrictionType.NONE; this.authorizationControl = AuthorizationControl.NAMED; this.federationSets = new ArrayList<String>(); this.federationStrategy = FederationStrategy.FEDERATE_THIS; this.projectPath = StringUtils.getFirstPathElement(name); + this.owners = new ArrayList<String>(); + + addOwner(owner); } public List<String> getLocalBranches() { @@ -162,7 +165,10 @@ } public boolean isOwner(String username) { - return owner != null && username != null && owner.equalsIgnoreCase(username); + if (StringUtils.isEmpty(username) || ArrayUtils.isEmpty(owners)) { + return false; + } + return owners.contains(username.toLowerCase()); } public boolean isPersonalRepository() { @@ -201,4 +207,37 @@ clone.sparkleshareId = sparkleshareId; return clone; } -} \ No newline at end of file + + public void addOwner(String username) { + if (!StringUtils.isEmpty(username)) { + String name = username.toLowerCase(); + // a set would be more efficient, but this complicates JSON + // deserialization so we enforce uniqueness with an arraylist + if (!owners.contains(name)) { + owners.add(name); + } + } + } + + public void removeOwner(String username) { + if (!StringUtils.isEmpty(username)) { + owners.remove(username.toLowerCase()); + } + } + + public void addOwners(Collection<String> usernames) { + if (!ArrayUtils.isEmpty(usernames)) { + for (String username : usernames) { + addOwner(username); + } + } + } + + public void removeOwners(Collection<String> usernames) { + if (!ArrayUtils.isEmpty(owners)) { + for (String username : usernames) { + removeOwner(username); + } + } + } +} -- Gitblit v1.9.1