James Moger
2012-08-25 832aa2a6f35b70da370e2f25060132150c91d220
src/com/gitblit/wicket/pages/RootPage.java
@@ -64,6 +64,7 @@
   IModel<String> username = new Model<String>("");
   IModel<String> password = new Model<String>("");
   List<RepositoryModel> repositoryModels = new ArrayList<RepositoryModel>();
   public RootPage() {
      super();
@@ -101,7 +102,9 @@
      pages.add(new PageRegistration("gb.repositories", RepositoriesPage.class,
            getRootPageParameters()));
      pages.add(new PageRegistration("gb.activity", ActivityPage.class, getRootPageParameters()));
      pages.add(new PageRegistration("gb.search", LuceneSearchPage.class));
      if (GitBlit.getBoolean(Keys.web.allowLuceneIndexing, true)) {
         pages.add(new PageRegistration("gb.search", LuceneSearchPage.class));
      }
      if (showAdmin) {
         pages.add(new PageRegistration("gb.users", UsersPage.class));
      }
@@ -128,11 +131,11 @@
            UserModel user = GitBlit.self().authenticate(username, password);
            if (user == null) {
               error("Invalid username or password!");
               error(getString("gb.invalidUsernameOrPassword"));
            } else if (user.username.equals(Constants.FEDERATION_USER)) {
               // disallow the federation user from logging in via the
               // web ui
               error("Invalid username or password!");
               error(getString("gb.invalidUsernameOrPassword"));
               user = null;
            } else {
               loginUser(user);
@@ -160,9 +163,9 @@
      } else if (showAdmin) {
         int pendingProposals = GitBlit.self().getPendingFederationProposals().size();
         if (pendingProposals == 1) {
            info("There is 1 federation proposal awaiting review.");
            info(getString("gb.OneProposalToReview"));
         } else if (pendingProposals > 1) {
            info(MessageFormat.format("There are {0} federation proposals awaiting review.",
            info(MessageFormat.format(getString("gb.nFederationProposalsToReview"),
                  pendingProposals));
         }
      }
@@ -207,7 +210,7 @@
            GitBlit.self().setCookie(response, user);
         }
         if (!continueToOriginalDestination()) {
         if (!session.continueRequest()) {
            PageParameters params = getPageParameters();
            if (params == null) {
               // redirect to this page
@@ -221,6 +224,15 @@
         }
      }
   }
   protected List<RepositoryModel> getRepositoryModels() {
      if (repositoryModels.isEmpty()) {
         final UserModel user = GitBlitWebSession.get().getUser();
         List<RepositoryModel> repositories = GitBlit.self().getRepositoryModels(user);
         repositoryModels.addAll(repositories);
      }
      return repositoryModels;
   }
   protected void addDropDownMenus(List<PageRegistration> pages) {
@@ -229,7 +241,7 @@
   protected List<DropDownMenuItem> getRepositoryFilterItems(PageParameters params) {
      final UserModel user = GitBlitWebSession.get().getUser();
      Set<DropDownMenuItem> filters = new LinkedHashSet<DropDownMenuItem>();
      List<RepositoryModel> repositories = GitBlit.self().getRepositoryModels(user);
      List<RepositoryModel> repositories = getRepositoryModels();
      // accessible repositories by federation set
      Map<String, AtomicInteger> setMap = new HashMap<String, AtomicInteger>();
@@ -295,8 +307,9 @@
      Set<Integer> choicesSet = new HashSet<Integer>(Arrays.asList(daysBack, 14, 28, 60, 90, 180));
      List<Integer> choices = new ArrayList<Integer>(choicesSet);
      Collections.sort(choices);
      String lastDaysPattern = getString("gb.lastNDays");
      for (Integer db : choices) {
         String txt = "last " + db + (db.intValue() > 1 ? " days" : "day");
         String txt = MessageFormat.format(lastDaysPattern, db);
         items.add(new DropDownMenuItem(txt, "db", db.toString(), params));
      }
      items.add(new DropDownMenuItem());
@@ -304,9 +317,8 @@
   }
   protected List<RepositoryModel> getRepositories(PageParameters params) {
      final UserModel user = GitBlitWebSession.get().getUser();
      if (params == null) {
         return GitBlit.self().getRepositoryModels(user);
         return getRepositoryModels();
      }
      boolean hasParameter = false;
@@ -316,7 +328,7 @@
      String team = WicketUtils.getTeam(params);
      int daysBack = params.getInt("db", 0);
      List<RepositoryModel> availableModels = GitBlit.self().getRepositoryModels(user);
      List<RepositoryModel> availableModels = getRepositoryModels();
      Set<RepositoryModel> models = new HashSet<RepositoryModel>();
      if (!StringUtils.isEmpty(repositoryName)) {