James Moger
2011-05-26 17c417dad5c7be28df4b6e1fd25ec56b484faaff
src/com/gitblit/wicket/RepositoryPage.java
@@ -1,10 +1,27 @@
/*
 * Copyright 2011 gitblit.com.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.gitblit.wicket;
import java.text.MessageFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import org.apache.wicket.Component;
import org.apache.wicket.PageParameters;
@@ -31,10 +48,11 @@
import com.gitblit.utils.JGitUtils;
import com.gitblit.utils.JGitUtils.SearchType;
import com.gitblit.utils.StringUtils;
import com.gitblit.wicket.models.RepositoryModel;
import com.gitblit.wicket.pages.BranchesPage;
import com.gitblit.wicket.pages.DocsPage;
import com.gitblit.wicket.pages.EditRepositoryPage;
import com.gitblit.wicket.pages.LogPage;
import com.gitblit.wicket.pages.RepositoriesPage;
import com.gitblit.wicket.pages.SearchPage;
import com.gitblit.wicket.pages.SummaryPage;
import com.gitblit.wicket.pages.TagsPage;
@@ -46,9 +64,10 @@
   protected final String repositoryName;
   protected final String objectId;
   protected String description;
   private transient Repository r = null;
   private transient Repository r;
   private RepositoryModel m;
   private final Logger logger = LoggerFactory.getLogger(RepositoryPage.class);
@@ -63,40 +82,61 @@
         put("tags", "gb.tags");
         put("tree", "gb.tree");
         put("tickets", "gb.tickets");
         put("edit", "gb.edit");
      }
   };
   public RepositoryPage(PageParameters params) {
      super(params);
      if (!params.containsKey("r")) {
         error("Repository not specified!");
         redirectToInterceptPage(new RepositoriesPage());
      }
      repositoryName = WicketUtils.getRepositoryName(params);
      objectId = WicketUtils.getObject(params);
      if (StringUtils.isEmpty(repositoryName)) {
         error(MessageFormat.format("Repository not specified for {0}!", getPageName()), true);
      }
      Repository r = getRepository();
      RepositoryModel model = getRepositoryModel();
      // standard page links
      add(new BookmarkablePageLink<Void>("summary", SummaryPage.class, WicketUtils.newRepositoryParameter(repositoryName)));
      add(new BookmarkablePageLink<Void>("log", LogPage.class, WicketUtils.newRepositoryParameter(repositoryName)));
      add(new BookmarkablePageLink<Void>("branches", BranchesPage.class, WicketUtils.newRepositoryParameter(repositoryName)));
      add(new BookmarkablePageLink<Void>("tags", TagsPage.class, WicketUtils.newRepositoryParameter(repositoryName)));
      add(new BookmarkablePageLink<Void>("tree", TreePage.class, WicketUtils.newRepositoryParameter(repositoryName)));
      add(new BookmarkablePageLink<Void>("summary", SummaryPage.class,
            WicketUtils.newRepositoryParameter(repositoryName)));
      add(new BookmarkablePageLink<Void>("log", LogPage.class,
            WicketUtils.newRepositoryParameter(repositoryName)));
      add(new BookmarkablePageLink<Void>("branches", BranchesPage.class,
            WicketUtils.newRepositoryParameter(repositoryName)));
      add(new BookmarkablePageLink<Void>("tags", TagsPage.class,
            WicketUtils.newRepositoryParameter(repositoryName)));
      add(new BookmarkablePageLink<Void>("tree", TreePage.class,
            WicketUtils.newRepositoryParameter(repositoryName)));
      // per-repository extra page links
      // per-repository extra page links
      List<String> extraPageLinks = new ArrayList<String>();
      // Conditionally add tickets page
      boolean checkTickets = JGitUtils.getRepositoryUseTickets(r);
      if (checkTickets && JGitUtils.getTicketsBranch(r) != null) {
      // Conditionally add tickets link
      if (model.useTickets && JGitUtils.getTicketsBranch(r) != null) {
         extraPageLinks.add("tickets");
      }
      // Conditionally add docs page
      boolean checkDocs = JGitUtils.getRepositoryUseDocs(r);
      if (checkDocs) {
      // Conditionally add docs link
      if (model.useDocs) {
         extraPageLinks.add("docs");
      }
      final boolean showAdmin;
      if (GitBlit.getBoolean(Keys.web.authenticateAdminPages, true)) {
         boolean allowAdmin = GitBlit.getBoolean(Keys.web.allowAdministration, false);
         showAdmin = allowAdmin && GitBlitWebSession.get().canAdmin();
      } else {
         showAdmin = GitBlit.getBoolean(Keys.web.allowAdministration, false);
      }
      // Conditionally add edit link
      if (showAdmin
            || GitBlitWebSession.get().isLoggedIn()
            && (model.owner != null && model.owner.equalsIgnoreCase(GitBlitWebSession.get()
                  .getUser().username))) {
         extraPageLinks.add("edit");
      }
      ListDataProvider<String> extrasDp = new ListDataProvider<String>(extraPageLinks);
@@ -107,15 +147,22 @@
            String extra = item.getModelObject();
            if (extra.equals("tickets")) {
               item.add(new Label("extraSeparator", " | "));
               item.add(new LinkPanel("extraLink", null, getString("gb.tickets"), TicketsPage.class, WicketUtils.newRepositoryParameter(repositoryName)));
               item.add(new LinkPanel("extraLink", null, getString("gb.tickets"),
                     TicketsPage.class, WicketUtils.newRepositoryParameter(repositoryName)));
            } else if (extra.equals("docs")) {
               item.add(new Label("extraSeparator", " | "));
               item.add(new LinkPanel("extraLink", null, getString("gb.docs"), DocsPage.class, WicketUtils.newRepositoryParameter(repositoryName)));
               item.add(new LinkPanel("extraLink", null, getString("gb.docs"), DocsPage.class,
                     WicketUtils.newRepositoryParameter(repositoryName)));
            } else if (extra.equals("edit")) {
               item.add(new Label("extraSeparator", " | "));
               item.add(new LinkPanel("extraLink", null, getString("gb.edit"),
                     EditRepositoryPage.class, WicketUtils
                           .newRepositoryParameter(repositoryName)));
            }
         }
      };
      add(extrasView);
      // disable current page
      disablePageLink(getPageName());
@@ -123,7 +170,7 @@
      SearchForm searchForm = new SearchForm("searchForm", repositoryName);
      add(searchForm);
      searchForm.setTranslatedAttributes();
      // set stateless page preference
      setStatelessHint(true);
   }
@@ -146,14 +193,34 @@
      if (r == null) {
         Repository r = GitBlit.self().getRepository(repositoryName);
         if (r == null) {
            error("Can not load repository " + repositoryName);
            redirectToInterceptPage(new RepositoriesPage());
            error("Can not load repository " + repositoryName, true);
            return null;
         }
         description = JGitUtils.getRepositoryDescription(r);
         this.r = r;
      }
      return r;
   }
   protected RepositoryModel getRepositoryModel() {
      if (m == null) {
         RepositoryModel model = GitBlit.self().getRepositoryModel(
               GitBlitWebSession.get().getUser(), repositoryName);
         if (model == null) {
            error("Unauthorized access for repository " + repositoryName, true);
            return null;
         }
         m = model;
      }
      return m;
   }
   protected RevCommit getCommit() {
      RevCommit commit = JGitUtils.getCommit(r, objectId);
      if (commit == null) {
         error(MessageFormat.format("Failed to find commit \"{0}\" in {1} for {2} page!",
               objectId, repositoryName, getPageName()), true);
      }
      return commit;
   }
   protected void addRefs(Repository r, RevCommit c) {
@@ -165,29 +232,32 @@
      if (substituteRegex) {
         Map<String, String> map = new HashMap<String, String>();
         // global regex keys
         if (GitBlit.self().settings().getBoolean(Keys.regex.global, false)) {
            for (String key : GitBlit.self().settings().getAllKeys(Keys.regex.global)) {
         if (GitBlit.getBoolean(Keys.regex.global, false)) {
            for (String key : GitBlit.getAllKeys(Keys.regex.global)) {
               if (!key.equals(Keys.regex.global)) {
                  String subKey = key.substring(key.lastIndexOf('.') + 1);
                  map.put(subKey, GitBlit.self().settings().getString(key, ""));
                  map.put(subKey, GitBlit.getString(key, ""));
               }
            }
         }
         // repository-specific regex keys
         List<String> keys = GitBlit.self().settings().getAllKeys(Keys.regex._ROOT + "." + repositoryName.toLowerCase());
         List<String> keys = GitBlit.getAllKeys(Keys.regex._ROOT + "."
               + repositoryName.toLowerCase());
         for (String key : keys) {
            String subKey = key.substring(key.lastIndexOf('.') + 1);
            map.put(subKey, GitBlit.self().settings().getString(key, ""));
            map.put(subKey, GitBlit.getString(key, ""));
         }
         for (String key : map.keySet()) {
            String definition = map.get(key).trim();
         for (Entry<String, String> entry : map.entrySet()) {
            String definition = entry.getValue().trim();
            String[] chunks = definition.split("!!!");
            if (chunks.length == 2) {
               html = html.replaceAll(chunks[0], chunks[1]);
            } else {
               logger.warn(key + " improperly formatted.  Use !!! to separate match from replacement: " + definition);
               logger.warn(entry.getKey()
                     + " improperly formatted.  Use !!! to separate match from replacement: "
                     + definition);
            }
         }
      }
@@ -196,9 +266,11 @@
   protected abstract String getPageName();
   protected Component createPersonPanel(String wicketId, PersonIdent identity, SearchType searchType) {
      boolean showEmail = GitBlit.self().settings().getBoolean(Keys.web.showEmailAddresses, false);
      if (!showEmail || StringUtils.isEmpty(identity.getName()) || StringUtils.isEmpty(identity.getEmailAddress())) {
   protected Component createPersonPanel(String wicketId, PersonIdent identity,
         SearchType searchType) {
      boolean showEmail = GitBlit.getBoolean(Keys.web.showEmailAddresses, false);
      if (!showEmail || StringUtils.isEmpty(identity.getName())
            || StringUtils.isEmpty(identity.getEmailAddress())) {
         String value = identity.getName();
         if (StringUtils.isEmpty(value)) {
            if (showEmail) {
@@ -208,17 +280,23 @@
            }
         }
         Fragment partial = new Fragment(wicketId, "partialPersonIdent", this);
         LinkPanel link = new LinkPanel("personName", "list", value, SearchPage.class, WicketUtils.newSearchParameter(repositoryName, objectId, value, searchType));
         LinkPanel link = new LinkPanel("personName", "list", value, SearchPage.class,
               WicketUtils.newSearchParameter(repositoryName, objectId, value, searchType));
         setPersonSearchTooltip(link, value, searchType);
         partial.add(link);
         return partial;
      } else {
         Fragment fullPerson = new Fragment(wicketId, "fullPersonIdent", this);
         LinkPanel nameLink = new LinkPanel("personName", "list", identity.getName(), SearchPage.class, WicketUtils.newSearchParameter(repositoryName, objectId, identity.getName(), searchType));
         LinkPanel nameLink = new LinkPanel("personName", "list", identity.getName(),
               SearchPage.class, WicketUtils.newSearchParameter(repositoryName, objectId,
                     identity.getName(), searchType));
         setPersonSearchTooltip(nameLink, identity.getName(), searchType);
         fullPerson.add(nameLink);
         LinkPanel addressLink = new LinkPanel("personAddress", "list", "<" + identity.getEmailAddress() + ">", SearchPage.class, WicketUtils.newSearchParameter(repositoryName, objectId, identity.getEmailAddress(), searchType));
         LinkPanel addressLink = new LinkPanel("personAddress", "list", "<"
               + identity.getEmailAddress() + ">", SearchPage.class,
               WicketUtils.newSearchParameter(repositoryName, objectId,
                     identity.getEmailAddress(), searchType));
         setPersonSearchTooltip(addressLink, identity.getEmailAddress(), searchType);
         fullPerson.add(addressLink);
         return fullPerson;
@@ -279,7 +357,7 @@
      return WicketUtils.newPathParameter(repositoryName, objectId, path);
   }
   class SearchForm extends StatelessForm<Void> {
   private static class SearchForm extends StatelessForm<Void> {
      private static final long serialVersionUID = 1L;
      private final String repositoryName;
@@ -291,17 +369,18 @@
      public SearchForm(String id, String repositoryName) {
         super(id);
         this.repositoryName = repositoryName;
         DropDownChoice<SearchType> searchType = new DropDownChoice<SearchType>("searchType", Arrays.asList(SearchType.values()));
         DropDownChoice<SearchType> searchType = new DropDownChoice<SearchType>("searchType",
               Arrays.asList(SearchType.values()));
         searchType.setModel(searchTypeModel);
         add(searchType.setVisible(GitBlit.self().settings().getBoolean(Keys.web.showSearchTypeSelection, false)));
         add(searchType.setVisible(GitBlit.getBoolean(Keys.web.showSearchTypeSelection, false)));
         TextField<String> searchBox = new TextField<String>("searchBox", searchBoxModel);
         add(searchBox);
      }
      void setTranslatedAttributes() {
      void setTranslatedAttributes() {
         WicketUtils.setHtmlTooltip(get("searchType"), getString("gb.searchTypeTooltip"));
         WicketUtils.setHtmlTooltip(get("searchBox"), getString("gb.searchTooltip"));
         WicketUtils.setInputPlaceholder(get("searchBox"), getString("gb.search"));
         WicketUtils.setInputPlaceholder(get("searchBox"), getString("gb.search"));
      }
      @Override
@@ -311,11 +390,13 @@
         for (SearchType type : SearchType.values()) {
            if (searchString.toLowerCase().startsWith(type.name().toLowerCase() + ":")) {
               searchType = type;
               searchString = searchString.substring(type.name().toLowerCase().length() + 1).trim();
               searchString = searchString.substring(type.name().toLowerCase().length() + 1)
                     .trim();
               break;
            }
         }
         setResponsePage(SearchPage.class, WicketUtils.newSearchParameter(repositoryName, null, searchString, searchType));
         setResponsePage(SearchPage.class,
               WicketUtils.newSearchParameter(repositoryName, null, searchString, searchType));
      }
   }
}