Paul Martin
2016-04-30 a502d96a860456ec5e8c96761db70f7cabb74751
src/main/java/com/gitblit/wicket/pages/PatchPage.java
@@ -16,27 +16,29 @@
package com.gitblit.wicket.pages;
import org.apache.wicket.PageParameters;
import org.apache.wicket.markup.html.WebPage;
import org.apache.wicket.markup.html.basic.Label;
import org.eclipse.jgit.lib.Repository;
import org.eclipse.jgit.revwalk.RevCommit;
import com.gitblit.GitBlit;
import com.gitblit.models.RepositoryModel;
import com.gitblit.models.UserModel;
import com.gitblit.utils.DiffUtils;
import com.gitblit.utils.JGitUtils;
import com.gitblit.utils.StringUtils;
import com.gitblit.wicket.CacheControl;
import com.gitblit.wicket.CacheControl.LastModified;
import com.gitblit.wicket.GitBlitWebSession;
import com.gitblit.wicket.WicketUtils;
public class PatchPage extends WebPage {
@CacheControl(LastModified.BOOT)
public class PatchPage extends SessionPage {
   public PatchPage(PageParameters params) {
   public PatchPage(final PageParameters params) {
      super(params);
      if (!params.containsKey("r")) {
         GitBlitWebSession.get().cacheErrorMessage(getString("gb.repositoryNotSpecified"));
         error(getString("gb.repositoryNotSpecified"));
         redirectToInterceptPage(new RepositoriesPage());
         return;
      }
      final String repositoryName = WicketUtils.getRepositoryName(params);
@@ -44,9 +46,20 @@
      final String objectId = WicketUtils.getObject(params);
      final String blobPath = WicketUtils.getPath(params);
      Repository r = GitBlit.self().getRepository(repositoryName);
      GitBlitWebSession session = GitBlitWebSession.get();
      UserModel user = session.getUser();
      RepositoryModel model = app().repositories().getRepositoryModel(user, repositoryName);
      if (model == null) {
         // user does not have permission
         error(getString("gb.canNotLoadRepository") + " " + repositoryName);
         redirectToInterceptPage(new RepositoriesPage());
         return;
      }
      Repository r = app().repositories().getRepository(repositoryName);
      if (r == null) {
         GitBlitWebSession.get().cacheErrorMessage(getString("gb.canNotLoadRepository") + " " + repositoryName);
         error(getString("gb.canNotLoadRepository") + " " + repositoryName);
         redirectToInterceptPage(new RepositoriesPage());
         return;
      }
@@ -66,4 +79,5 @@
      add(new Label("patchText", patch));
      r.close();
   }
}