From c5dfd60d174a9841e64e4097cecab5aea5c422d0 Mon Sep 17 00:00:00 2001
From: James Moger <james.moger@gitblit.com>
Date: Sat, 12 Apr 2014 12:26:17 -0400
Subject: [PATCH] Documentation

---
 src/main/java/com/gitblit/wicket/pages/RootPage.java |   97 ++++++++++++++++++++++++------------------------
 1 files changed, 48 insertions(+), 49 deletions(-)

diff --git a/src/main/java/com/gitblit/wicket/pages/RootPage.java b/src/main/java/com/gitblit/wicket/pages/RootPage.java
index ec4e9b4..5ccc3a4 100644
--- a/src/main/java/com/gitblit/wicket/pages/RootPage.java
+++ b/src/main/java/com/gitblit/wicket/pages/RootPage.java
@@ -46,7 +46,6 @@
 import org.apache.wicket.protocol.http.WebResponse;
 
 import com.gitblit.Constants;
-import com.gitblit.GitBlit;
 import com.gitblit.Keys;
 import com.gitblit.models.RepositoryModel;
 import com.gitblit.models.TeamModel;
@@ -65,9 +64,9 @@
 /**
  * Root page is a topbar, navigable page like Repositories, Users, or
  * Federation.
- * 
+ *
  * @author James Moger
- * 
+ *
  */
 public abstract class RootPage extends BasePage {
 
@@ -92,26 +91,27 @@
 		add(new HeaderContributor(new IHeaderContributor() {
 			private static final long serialVersionUID = 1L;
 
+			@Override
 			public void renderHead(IHeaderResponse response) {
 				StringBuilder buffer = new StringBuilder();
 				buffer.append("<style type=\"text/css\">\n");
 				buffer.append(".navbar-inner {\n");
-				final String headerBackground = GitBlit.getString(Keys.web.headerBackgroundColor, null);
+				final String headerBackground = app().settings().getString(Keys.web.headerBackgroundColor, null);
 				if (!StringUtils.isEmpty(headerBackground)) {
 					buffer.append(MessageFormat.format("background-color: {0};\n", headerBackground));
 				}
-				final String headerBorder = GitBlit.getString(Keys.web.headerBorderColor, null);
+				final String headerBorder = app().settings().getString(Keys.web.headerBorderColor, null);
 				if (!StringUtils.isEmpty(headerBorder)) {
 					buffer.append(MessageFormat.format("border-bottom: 1px solid {0} !important;\n", headerBorder));
 				}
 				buffer.append("}\n");
-				final String headerBorderFocus = GitBlit.getString(Keys.web.headerBorderFocusColor, null);
+				final String headerBorderFocus = app().settings().getString(Keys.web.headerBorderFocusColor, null);
 				if (!StringUtils.isEmpty(headerBorderFocus)) {
 					buffer.append(".navbar ul li:focus, .navbar .active {\n");
 					buffer.append(MessageFormat.format("border-bottom: 4px solid {0};\n", headerBorderFocus));
 					buffer.append("}\n");
 				}
-				final String headerForeground = GitBlit.getString(Keys.web.headerForegroundColor, null);
+				final String headerForeground = app().settings().getString(Keys.web.headerForegroundColor, null);
 				if (!StringUtils.isEmpty(headerForeground)) {
 					buffer.append(".navbar ul.nav li a {\n");
 					buffer.append(MessageFormat.format("color: {0};\n", headerForeground));
@@ -120,7 +120,7 @@
 					buffer.append(MessageFormat.format("color: {0};\n", headerForeground));
 					buffer.append("}\n");
 				}
-				final String headerHover = GitBlit.getString(Keys.web.headerHoverColor, null);
+				final String headerHover = app().settings().getString(Keys.web.headerHoverColor, null);
 				if (!StringUtils.isEmpty(headerHover)) {
 					buffer.append(".navbar ul.nav li a:hover {\n");
 					buffer.append(MessageFormat.format("color: {0} !important;\n", headerHover));
@@ -130,10 +130,10 @@
 				response.renderString(buffer.toString());
 				}
 			}));
-		
-		boolean authenticateView = GitBlit.getBoolean(Keys.web.authenticateViewPages, false);
-		boolean authenticateAdmin = GitBlit.getBoolean(Keys.web.authenticateAdminPages, true);
-		boolean allowAdmin = GitBlit.getBoolean(Keys.web.allowAdministration, true);
+
+		boolean authenticateView = app().settings().getBoolean(Keys.web.authenticateViewPages, false);
+		boolean authenticateAdmin = app().settings().getBoolean(Keys.web.authenticateAdminPages, true);
+		boolean allowAdmin = app().settings().getBoolean(Keys.web.allowAdministration, true);
 
 		if (authenticateAdmin) {
 			showAdmin = allowAdmin && GitBlitWebSession.get().canAdmin();
@@ -149,7 +149,7 @@
 				setStatelessHint(true);
 			}
 		}
-		
+
 		if (authenticateView || authenticateAdmin) {
 			if (GitBlitWebSession.get().isLoggedIn()) {
 				UserMenu userFragment = new UserMenu("userPanel", "userMenuFragment", RootPage.this);
@@ -161,9 +161,9 @@
 		} else {
 			add(new Label("userPanel").setVisible(false));
 		}
-		
-		boolean showRegistrations = GitBlit.canFederate()
-				&& GitBlit.getBoolean(Keys.web.showFederationRegistrations, false);
+
+		boolean showRegistrations = app().federation().canFederate()
+				&& app().settings().getBoolean(Keys.web.showFederationRegistrations, false);
 
 		// navigation links
 		List<PageRegistration> pages = new ArrayList<PageRegistration>();
@@ -173,7 +173,7 @@
 			pages.add(new PageRegistration("gb.repositories", RepositoriesPage.class,
 					getRootPageParameters()));
 			pages.add(new PageRegistration("gb.activity", ActivityPage.class, getRootPageParameters()));
-			if (GitBlit.getBoolean(Keys.web.allowLuceneIndexing, true)) {
+			if (app().settings().getBoolean(Keys.web.allowLuceneIndexing, true)) {
 				pages.add(new PageRegistration("gb.search", LuceneSearchPage.class));
 			}
 			if (showAdmin) {
@@ -187,7 +187,7 @@
 				addDropDownMenus(pages);
 			}
 		}
-		
+
 		NavigationPanel navPanel = new NavigationPanel("navPanel", getRootNavPageClass(), pages);
 		add(navPanel);
 
@@ -196,7 +196,7 @@
 		if (!StringUtils.isEmpty(cachedMessage)) {
 			error(cachedMessage);
 		} else if (showAdmin) {
-			int pendingProposals = GitBlit.self().getPendingFederationProposals().size();
+			int pendingProposals = app().federation().getPendingFederationProposals().size();
 			if (pendingProposals == 1) {
 				info(getString("gb.OneProposalToReview"));
 			} else if (pendingProposals > 1) {
@@ -207,7 +207,7 @@
 
 		super.setupPage(repositoryName, pageName);
 	}
-	
+
 	protected Class<? extends BasePage> getRootNavPageClass() {
 		return getClass();
 	}
@@ -228,11 +228,11 @@
 
 				// remove days back parameter if it is the default value
 				if (params.containsKey("db")
-						&& params.getInt("db") == GitBlit.getInteger(Keys.web.activityDuration, 7)) {
+						&& params.getInt("db") == app().settings().getInteger(Keys.web.activityDuration, 7)) {
 					params.remove("db");
 				}
 				return params;
-			}			
+			}
 		}
 		return null;
 	}
@@ -250,9 +250,9 @@
 			session.setUser(user);
 
 			// Set Cookie
-			if (GitBlit.getBoolean(Keys.web.allowCookieAuthentication, false)) {
+			if (app().settings().getBoolean(Keys.web.allowCookieAuthentication, false)) {
 				WebResponse response = (WebResponse) getRequestCycle().getResponse();
-				GitBlit.self().setCookie(response, user);
+				app().authentication().setCookie(response.getHttpServletResponse(), user);
 			}
 
 			if (!session.continueRequest()) {
@@ -269,11 +269,11 @@
 			}
 		}
 	}
-	
+
 	protected List<RepositoryModel> getRepositoryModels() {
 		if (repositoryModels.isEmpty()) {
 			final UserModel user = GitBlitWebSession.get().getUser();
-			List<RepositoryModel> repositories = GitBlit.self().getRepositoryModels(user);
+			List<RepositoryModel> repositories = app().repositories().getRepositoryModels(user);
 			repositoryModels.addAll(repositories);
 			Collections.sort(repositoryModels);
 		}
@@ -325,7 +325,7 @@
 		}
 
 		// custom filters
-		String customFilters = GitBlit.getString(Keys.web.customFilters, null);
+		String customFilters = app().settings().getString(Keys.web.customFilters, null);
 		if (!StringUtils.isEmpty(customFilters)) {
 			boolean addedExpression = false;
 			List<String> expressions = StringUtils.getStringsFromValue(customFilters, "!!!");
@@ -345,8 +345,8 @@
 
 	protected List<DropDownMenuItem> getTimeFilterItems(PageParameters params) {
 		// days back choices - additive parameters
-		int daysBack = GitBlit.getInteger(Keys.web.activityDuration, 7);
-		int maxDaysBack = GitBlit.getInteger(Keys.web.activityDurationMaximum, 30);
+		int daysBack = app().settings().getInteger(Keys.web.activityDuration, 7);
+		int maxDaysBack = app().settings().getInteger(Keys.web.activityDurationMaximum, 30);
 		if (daysBack < 1) {
 			daysBack = 7;
 		}
@@ -359,13 +359,13 @@
 		} else {
 			clonedParams = new PageParameters(params);
 		}
-		
+
 		if (!clonedParams.containsKey("db")) {
 			clonedParams.put("db",  daysBack);
 		}
-		
+
 		List<DropDownMenuItem> items = new ArrayList<DropDownMenuItem>();
-		Set<Integer> choicesSet = new TreeSet<Integer>(GitBlit.getIntegers(Keys.web.activityDurationChoices));
+		Set<Integer> choicesSet = new TreeSet<Integer>(app().settings().getIntegers(Keys.web.activityDurationChoices));
 		if (choicesSet.isEmpty()) {
 			 choicesSet.addAll(Arrays.asList(1, 3, 7, 14, 21, 28));
 		}
@@ -402,7 +402,7 @@
 		String regex = WicketUtils.getRegEx(params);
 		String team = WicketUtils.getTeam(params);
 		int daysBack = params.getInt("db", 0);
-		int maxDaysBack = GitBlit.getInteger(Keys.web.activityDurationMaximum, 30);
+		int maxDaysBack = app().settings().getInteger(Keys.web.activityDurationMaximum, 30);
 
 		List<RepositoryModel> availableModels = getRepositoryModels();
 		Set<RepositoryModel> models = new HashSet<RepositoryModel>();
@@ -420,8 +420,8 @@
 
 		if (!StringUtils.isEmpty(projectName)) {
 			// try named project
-			hasParameter = true;			
-			if (projectName.equalsIgnoreCase(GitBlit.getString(Keys.web.repositoryRootGroupName, "main"))) {
+			hasParameter = true;
+			if (projectName.equalsIgnoreCase(app().settings().getString(Keys.web.repositoryRootGroupName, "main"))) {
 				// root project/group
 				for (RepositoryModel model : availableModels) {
 					if (model.name.indexOf('/') == -1) {
@@ -471,7 +471,7 @@
 			// need TeamModels first
 			List<TeamModel> teamModels = new ArrayList<TeamModel>();
 			for (String name : teams) {
-				TeamModel teamModel = GitBlit.self().getTeamModel(name);
+				TeamModel teamModel = app().users().getTeamModel(name);
 				if (teamModel != null) {
 					teamModels.add(teamModel);
 				}
@@ -511,14 +511,14 @@
 			}
 			models = timeFiltered;
 		}
-		
+
 		List<RepositoryModel> list = new ArrayList<RepositoryModel>(models);
 		Collections.sort(list);
 		return list;
 	}
-	
+
 	/**
-	 * Inline login form. 
+	 * Inline login form.
 	 */
 	private class LoginForm extends Fragment {
 		private static final long serialVersionUID = 1L;
@@ -536,7 +536,7 @@
 					String username = RootPage.this.username.getObject();
 					char[] password = RootPage.this.password.getObject().toCharArray();
 
-					UserModel user = GitBlit.self().authenticate(username, password);
+					UserModel user = app().authentication().authenticate(username, password);
 					if (user == null) {
 						error(getString("gb.invalidUsernameOrPassword"));
 					} else if (user.username.equals(Constants.FEDERATION_USER)) {
@@ -558,11 +558,11 @@
 			add(loginForm);
 		}
 	}
-	
+
 	/**
 	 * Menu for the authenticated user.
 	 */
-	static class UserMenu extends Fragment {
+	class UserMenu extends Fragment {
 
 		private static final long serialVersionUID = 1L;
 
@@ -572,12 +572,11 @@
 
 			GitBlitWebSession session = GitBlitWebSession.get();
 			UserModel user = session.getUser();
-			boolean editCredentials = GitBlit.self().supportsCredentialChanges(user);
+			boolean editCredentials = app().authentication().supportsCredentialChanges(user);
 			boolean standardLogin = session.authenticationType.isStandard();
 
-			if (GitBlit.getBoolean(Keys.web.allowGravatar, true)) {
-				add(new GravatarImage("username", user.getDisplayName(),
-						user.emailAddress, "navbarGravatar", 20, false, false));
+			if (app().settings().getBoolean(Keys.web.allowGravatar, true)) {
+				add(new GravatarImage("username", user, "navbarGravatar", 20, false));
 			} else {
 				add(new Label("username", user.getDisplayName()));
 			}
@@ -587,12 +586,12 @@
 			add(new BookmarkablePageLink<Void>("newRepository",
 					EditRepositoryPage.class).setVisible(user.canAdmin() || user.canCreate()));
 
-			add(new BookmarkablePageLink<Void>("myProfile", 
+			add(new BookmarkablePageLink<Void>("myProfile",
 					UserPage.class, WicketUtils.newUsernameParameter(user.username)));
 
-			add(new BookmarkablePageLink<Void>("changePassword", 
+			add(new BookmarkablePageLink<Void>("changePassword",
 					ChangePasswordPage.class).setVisible(editCredentials));
-			
+
 			add(new BookmarkablePageLink<Void>("logout",
 					LogoutPage.class).setVisible(standardLogin));
 		}

--
Gitblit v1.9.1