From 4e84166db5c5538e3984d9d2d6bb1f9902e65ee0 Mon Sep 17 00:00:00 2001 From: James Moger <james.moger@gitblit.com> Date: Tue, 04 Nov 2014 17:38:17 -0500 Subject: [PATCH] Merged #217 "Exclude SSLv3 from Gitblit GO https protocols" --- src/main/java/com/gitblit/wicket/pages/DocsPage.java | 31 ++++++++++++++++++++----------- 1 files changed, 20 insertions(+), 11 deletions(-) diff --git a/src/main/java/com/gitblit/wicket/pages/DocsPage.java b/src/main/java/com/gitblit/wicket/pages/DocsPage.java index 907dd6e..8be9a57 100644 --- a/src/main/java/com/gitblit/wicket/pages/DocsPage.java +++ b/src/main/java/com/gitblit/wicket/pages/DocsPage.java @@ -31,6 +31,7 @@ import org.eclipse.jgit.revwalk.RevCommit; import com.gitblit.models.PathModel; +import com.gitblit.servlet.RawServlet; import com.gitblit.utils.ByteFormat; import com.gitblit.utils.JGitUtils; import com.gitblit.utils.StringUtils; @@ -48,11 +49,14 @@ public DocsPage(PageParameters params) { super(params); - MarkupProcessor processor = new MarkupProcessor(app().settings()); + String objectId = WicketUtils.getObject(params); + + MarkupProcessor processor = new MarkupProcessor(app().settings(), app().xssFilter()); Repository r = getRepository(); - RevCommit head = JGitUtils.getCommit(r, null); + RevCommit head = JGitUtils.getCommit(r, objectId); final String commitId = getBestCommitId(head); + List<String> extensions = processor.getAllExtensions(); List<PathModel> paths = JGitUtils.getDocuments(r, extensions); @@ -103,8 +107,8 @@ WicketUtils.newPathParameter(repositoryName, commitId, doc.documentPath))); item.add(new BookmarkablePageLink<Void>("historyLink", HistoryPage.class, WicketUtils.newPathParameter(repositoryName, commitId, doc.documentPath))); - item.add(new BookmarkablePageLink<Void>("rawLink", RawPage.class, WicketUtils.newPathParameter( - repositoryName, commitId, doc.documentPath))); + String rawUrl = RawServlet.asLink(getContextUrl(), repositoryName, commitId, doc.documentPath); + item.add(new ExternalLink("rawLink", rawUrl)); // document content String file = StringUtils.getLastPathElement(doc.documentPath); @@ -126,7 +130,6 @@ } // document list - final String id = getBestCommitId(head); final ByteFormat byteFormat = new ByteFormat(); Fragment docs = new Fragment("documents", "documentsFragment", this); ListDataProvider<PathModel> pathsDp = new ListDataProvider<PathModel>(paths); @@ -140,17 +143,17 @@ item.add(WicketUtils.newImage("docIcon", "file_world_16x16.png")); item.add(new Label("docSize", byteFormat.format(entry.size))); item.add(new LinkPanel("docName", "list", StringUtils.stripFileExtension(entry.name), - DocPage.class, WicketUtils.newPathParameter(repositoryName, id, entry.path))); + DocPage.class, WicketUtils.newPathParameter(repositoryName, commitId, entry.path))); // links item.add(new BookmarkablePageLink<Void>("view", DocPage.class, WicketUtils - .newPathParameter(repositoryName, id, entry.path))); - item.add(new BookmarkablePageLink<Void>("raw", RawPage.class, WicketUtils - .newPathParameter(repositoryName, id, entry.path))); + .newPathParameter(repositoryName, commitId, entry.path))); + String rawUrl = RawServlet.asLink(getContextUrl(), repositoryName, commitId, entry.path); + item.add(new ExternalLink("raw", rawUrl)); item.add(new BookmarkablePageLink<Void>("blame", BlamePage.class, WicketUtils - .newPathParameter(repositoryName, id, entry.path))); + .newPathParameter(repositoryName, commitId, entry.path))); item.add(new BookmarkablePageLink<Void>("history", HistoryPage.class, WicketUtils - .newPathParameter(repositoryName, id, entry.path))); + .newPathParameter(repositoryName, commitId, entry.path))); WicketUtils.setAlternatingBackground(item, counter); counter++; } @@ -164,4 +167,10 @@ protected String getPageName() { return getString("gb.docs"); } + + @Override + protected boolean isCommitPage() { + return true; + } + } -- Gitblit v1.9.1