From 9effe1630d97039b3e01cd9b58ed07e75be1d63c Mon Sep 17 00:00:00 2001
From: James Moger <james.moger@gitblit.com>
Date: Mon, 25 Feb 2013 08:40:30 -0500
Subject: [PATCH] Merge pull request #75 from thefake/master

---
 src/com/gitblit/wicket/pages/RootSubPage.java |   61 ++++++++++++++++++++++++++++++
 1 files changed, 61 insertions(+), 0 deletions(-)

diff --git a/src/com/gitblit/wicket/pages/RootSubPage.java b/src/com/gitblit/wicket/pages/RootSubPage.java
index f7572b1..e7e12cc 100644
--- a/src/com/gitblit/wicket/pages/RootSubPage.java
+++ b/src/com/gitblit/wicket/pages/RootSubPage.java
@@ -15,9 +15,18 @@
  */
 package com.gitblit.wicket.pages;
 
+import java.util.ArrayList;
+import java.util.List;
+
 import org.apache.wicket.PageParameters;
+import org.apache.wicket.Session;
 import org.apache.wicket.markup.html.basic.Label;
 
+import com.gitblit.Constants.AccessRestrictionType;
+import com.gitblit.Constants.AuthorizationControl;
+import com.gitblit.GitBlit;
+import com.gitblit.models.RepositoryModel;
+import com.gitblit.models.UserModel;
 import com.gitblit.utils.StringUtils;
 
 /**
@@ -30,10 +39,27 @@
 
 	public RootSubPage() {
 		super();
+		createPageMapIfNeeded();
 	}
 
 	public RootSubPage(PageParameters params) {
 		super(params);
+		createPageMapIfNeeded();
+	}
+	
+	protected boolean requiresPageMap() {
+		return false;
+	}
+	
+	protected void createPageMapIfNeeded() {
+		if (requiresPageMap()) {
+			// because Gitblit strives for page-statelessness
+			// Wicket seems to get confused as to when it really should
+			// generate a page map for complex pages.  Conditionally ensure we
+			// have a page map for complex AJAX pages like the EditNNN pages.
+			Session.get().pageMapForName(null, true);
+			setVersioned(true);
+		}
 	}
 
 	@Override
@@ -45,4 +71,39 @@
 		add(new Label("pageSubName", subName));
 		super.setupPage("", pageName);
 	}
+	
+	protected List<String> getAccessRestrictedRepositoryList(boolean includeWildcards, UserModel user) {
+		// build list of access-restricted projects
+		String lastProject = null;
+		List<String> repos = new ArrayList<String>();
+		if (includeWildcards) {
+			// all repositories
+			repos.add(".*");
+			// all repositories excluding personal repositories
+			repos.add("[^~].*");
+		}
+		
+		for (String repo : GitBlit.self().getRepositoryList()) {
+			RepositoryModel repositoryModel = GitBlit.self().getRepositoryModel(repo);
+			if (repositoryModel.accessRestriction.exceeds(AccessRestrictionType.NONE)
+					&& repositoryModel.authorizationControl.equals(AuthorizationControl.NAMED)) {
+				if (user != null &&
+						(repositoryModel.isOwner(user.username) || repositoryModel.isUsersPersonalRepository(user.username))) {
+					// exclude Owner or personal repositories
+					continue;
+				}
+				if (includeWildcards) {
+					if (lastProject == null || !lastProject.equalsIgnoreCase(repositoryModel.projectPath)) {
+						lastProject = repositoryModel.projectPath.toLowerCase();
+						if (!StringUtils.isEmpty(repositoryModel.projectPath)) {
+							// regex for all repositories within a project
+							repos.add(repositoryModel.projectPath + "/.*");
+						}
+					}
+				}
+				repos.add(repo.toLowerCase());
+			}
+		}
+		return repos;
+	}
 }

--
Gitblit v1.9.1