James Moger
2012-10-30 a4231d30c4d2765c80f57df79cd1d4d39a9795ea
src/com/gitblit/wicket/pages/RepositoryPage.java
@@ -92,19 +92,6 @@
      }
      objectId = WicketUtils.getObject(params);
      
      if (objectId != null) {
         RefModel branch = null;
         if ((branch = JGitUtils.getBranch(getRepository(), objectId)) != null) {
            boolean canAccess = GitBlitWebSession
                  .get()
                  .getUser()
                  .hasBranchPermission(getRepositoryModel().name,
                        branch.reference.getName());
            if (!canAccess) {
               error("Access denied", true);
            }
         }
      }
      if (StringUtils.isEmpty(repositoryName)) {
         error(MessageFormat.format(getString("gb.repositoryNotSpecifiedFor"), getPageName()), true);
      }
@@ -112,6 +99,26 @@
      if (!getRepositoryModel().hasCommits) {
         setResponsePage(EmptyRepositoryPage.class, params);
      }
      if (getRepositoryModel().isCollectingGarbage) {
         error(MessageFormat.format(getString("gb.busyCollectingGarbage"), getRepositoryModel().name), true);
      }
      if (objectId != null) {
         RefModel branch = null;
         if ((branch = JGitUtils.getBranch(getRepository(), objectId)) != null) {
            UserModel user = GitBlitWebSession.get().getUser();
            if (user == null) {
               // workaround until get().getUser() is reviewed throughout the app
               user = UserModel.ANONYMOUS;
            }
            boolean canAccess = user.hasBranchPermission(repositoryName,
                        branch.reference.getName());
            if (!canAccess) {
               error(getString("gb.accessDeined"), true);
            }
         }
      }
      // register the available page links for this page and user
      registeredPages = registerPages();