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