From 8c9a2037b5c0fed881a3ad6dd9cff364eed603d9 Mon Sep 17 00:00:00 2001
From: James Moger <james.moger@gitblit.com>
Date: Tue, 14 Jun 2011 16:55:13 -0400
Subject: [PATCH] Added AccessRestrictionFilter and simplified authentication.

---
 src/com/gitblit/SyndicationServlet.java |   56 ++++++++++++++++++++++++++++++++++++++++++++++----------
 1 files changed, 46 insertions(+), 10 deletions(-)

diff --git a/src/com/gitblit/SyndicationServlet.java b/src/com/gitblit/SyndicationServlet.java
index d2b396e..19865fe 100644
--- a/src/com/gitblit/SyndicationServlet.java
+++ b/src/com/gitblit/SyndicationServlet.java
@@ -15,6 +15,7 @@
  */
 package com.gitblit;
 
+import java.text.MessageFormat;
 import java.util.List;
 
 import javax.servlet.http.HttpServlet;
@@ -28,6 +29,7 @@
 import com.gitblit.utils.JGitUtils;
 import com.gitblit.utils.StringUtils;
 import com.gitblit.utils.SyndicationUtils;
+import com.gitblit.wicket.WicketUtils;
 
 public class SyndicationServlet extends HttpServlet {
 
@@ -36,20 +38,55 @@
 	private transient Logger logger = LoggerFactory.getLogger(SyndicationServlet.class);
 
 	public static String asLink(String baseURL, String repository, String objectId, int length) {
-		if (baseURL.charAt(baseURL.length() - 1) == '/') {
+		if (baseURL.length() > 0 && baseURL.charAt(baseURL.length() - 1) == '/') {
 			baseURL = baseURL.substring(0, baseURL.length() - 1);
 		}
-		return baseURL + Constants.SYNDICATION_SERVLET_PATH + "?r=" + repository
-				+ (objectId == null ? "" : ("&h=" + objectId)) + (length > 0 ? "&l=" + length : "");
+		StringBuilder url = new StringBuilder();
+		url.append(baseURL);
+		url.append(Constants.SYNDICATION_SERVLET_PATH);
+		url.append(repository);
+		if (!StringUtils.isEmpty(objectId) || length > 0) {
+			StringBuilder parameters = new StringBuilder("?");
+			if (StringUtils.isEmpty(objectId)) {
+				parameters.append("l=");
+				parameters.append(length);
+			} else {
+				parameters.append("h=");
+				parameters.append(objectId);
+				if (length > 0) {
+					parameters.append("&l=");
+					parameters.append(length);
+				}
+			}
+			url.append(parameters);
+		}
+		return url.toString();
+	}
+	
+	public static String getTitle(String repository, String objectId) {
+		String id = objectId;
+		if (!StringUtils.isEmpty(id)) {
+			if (id.startsWith(org.eclipse.jgit.lib.Constants.R_HEADS)) {
+				id = id.substring(org.eclipse.jgit.lib.Constants.R_HEADS.length());
+			} else if (id.startsWith(org.eclipse.jgit.lib.Constants.R_REMOTES)) {
+				id = id.substring(org.eclipse.jgit.lib.Constants.R_REMOTES.length());
+			} else if (id.startsWith(org.eclipse.jgit.lib.Constants.R_TAGS)) {
+				id = id.substring(org.eclipse.jgit.lib.Constants.R_TAGS.length());
+			}
+		}
+		return MessageFormat.format("{0} ({1})", repository, id);
 	}
 
 	private void processRequest(javax.servlet.http.HttpServletRequest request,
 			javax.servlet.http.HttpServletResponse response) throws javax.servlet.ServletException,
 			java.io.IOException {
-		String hostUrl = request.getRequestURL().toString();
-		String servlet = request.getServletPath();
-		hostUrl = hostUrl.substring(0, hostUrl.indexOf(servlet));
-		String repositoryName = request.getParameter("r");
+
+		String hostURL = WicketUtils.getHostURL(request);
+		String url = request.getRequestURI().substring(request.getServletPath().length());
+		if (url.charAt(0) == '/' && url.length() > 1) {
+			url = url.substring(1);
+		}
+		String repositoryName = url;
 		String objectId = request.getParameter("h");
 		String l = request.getParameter("l");
 		int length = GitBlit.getInteger(Keys.web.syndicationEntries, 25);
@@ -62,14 +99,13 @@
 			} catch (NumberFormatException x) {
 			}
 		}
-		
-		// TODO confirm repository is accessible!!
 
 		Repository repository = GitBlit.self().getRepository(repositoryName);
 		RepositoryModel model = GitBlit.self().getRepositoryModel(repositoryName);
 		List<RevCommit> commits = JGitUtils.getRevLog(repository, objectId, 0, length);
 		try {
-			SyndicationUtils.toRSS(hostUrl, model.name + " " + objectId, model.description, model.name, commits, response.getOutputStream());
+			SyndicationUtils.toRSS(hostURL, getTitle(model.name, objectId), model.description,
+					model.name, commits, response.getOutputStream());
 		} catch (Exception e) {
 			logger.error("An error occurred during feed generation", e);
 		}

--
Gitblit v1.9.1