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