From 9bdb91ea80119121791271819f2c1fbf07bf5591 Mon Sep 17 00:00:00 2001 From: James Moger <james.moger@gitblit.com> Date: Thu, 03 Nov 2011 17:09:35 -0400 Subject: [PATCH] RSS search parameters. Include refs as categories in RSS entries. --- src/com/gitblit/SyndicationServlet.java | 59 +++++++++++++++++++++++++++++++++++++++++++++++++++++------ 1 files changed, 53 insertions(+), 6 deletions(-) diff --git a/src/com/gitblit/SyndicationServlet.java b/src/com/gitblit/SyndicationServlet.java index 694b9cc..af0fab7 100644 --- a/src/com/gitblit/SyndicationServlet.java +++ b/src/com/gitblit/SyndicationServlet.java @@ -18,22 +18,24 @@ import java.text.MessageFormat; import java.util.ArrayList; import java.util.List; +import java.util.Map; import javax.servlet.http.HttpServlet; +import org.eclipse.jgit.lib.ObjectId; import org.eclipse.jgit.lib.Repository; import org.eclipse.jgit.revwalk.RevCommit; import org.slf4j.Logger; import org.slf4j.LoggerFactory; +import com.gitblit.models.RefModel; import com.gitblit.models.RepositoryModel; import com.gitblit.models.SyndicatedEntryModel; import com.gitblit.utils.HttpUtils; import com.gitblit.utils.JGitUtils; +import com.gitblit.utils.JGitUtils.SearchType; import com.gitblit.utils.StringUtils; import com.gitblit.utils.SyndicationUtils; -import com.sun.syndication.feed.synd.SyndContent; -import com.sun.syndication.feed.synd.SyndContentImpl; /** * SyndicationServlet generates RSS 2.0 feeds and feed links. @@ -128,6 +130,14 @@ String repositoryName = url; String objectId = request.getParameter("h"); String l = request.getParameter("l"); + String searchString = request.getParameter("s"); + SearchType searchType = SearchType.COMMIT; + if (!StringUtils.isEmpty(request.getParameter("st"))) { + SearchType type = SearchType.forName(request.getParameter("st")); + if (type != null) { + searchType = type; + } + } int length = GitBlit.getInteger(Keys.web.syndicationEntries, 25); if (StringUtils.isEmpty(objectId)) { objectId = org.eclipse.jgit.lib.Constants.HEAD; @@ -142,27 +152,64 @@ response.setContentType("application/rss+xml; charset=UTF-8"); Repository repository = GitBlit.self().getRepository(repositoryName); RepositoryModel model = GitBlit.self().getRepositoryModel(repositoryName); - List<RevCommit> commits = JGitUtils.getRevLog(repository, objectId, 0, length); + List<RevCommit> commits; + if (StringUtils.isEmpty(searchString)) { + // standard log/history lookup + commits = JGitUtils.getRevLog(repository, objectId, 0, length); + } else { + // repository search + commits = JGitUtils.searchRevlogs(repository, objectId, searchString, searchType, 0, + length); + } + Map<ObjectId, List<RefModel>> allRefs = JGitUtils.getAllRefs(repository); List<SyndicatedEntryModel> entries = new ArrayList<SyndicatedEntryModel>(); + boolean mountParameters = GitBlit.getBoolean(Keys.web.mountParameters, true); + String urlPattern; + if (mountParameters) { + // mounted parameters + urlPattern = "{0}/commit/{1}/{2}"; + } else { + // parameterized parameters + urlPattern = "{0}/commit/?r={1}&h={2}"; + } String gitblitUrl = HttpUtils.getGitblitURL(request); // convert RevCommit to SyndicatedEntryModel for (RevCommit commit : commits) { SyndicatedEntryModel entry = new SyndicatedEntryModel(); entry.title = commit.getShortMessage(); entry.author = commit.getAuthorIdent().getName(); - entry.link = MessageFormat.format("{0}/commit/{1}/{2}", gitblitUrl, + entry.link = MessageFormat.format(urlPattern, gitblitUrl, StringUtils.encodeURL(model.name), commit.getName()); entry.published = commit.getCommitterIdent().getWhen(); entry.contentType = "text/plain"; entry.content = commit.getFullMessage(); entry.repository = model.name; entry.branch = objectId; + List<RefModel> refs = allRefs.get(commit.getId()); + if (refs != null && refs.size() > 0) { + List<String> tags = new ArrayList<String>(); + for (RefModel ref : refs) { + tags.add(ref.getName()); + } + entry.tags = tags; + } entries.add(entry); } + String feedLink; + if (mountParameters) { + // mounted url + feedLink = MessageFormat.format("{0}/summary/{1}", gitblitUrl, + StringUtils.encodeURL(model.name)); + } else { + // parameterized url + feedLink = MessageFormat.format("{0}/summary/?r={1}", gitblitUrl, + StringUtils.encodeURL(model.name)); + } + try { - SyndicationUtils.toRSS(gitblitUrl, getTitle(model.name, objectId), model.description, - model.name, entries, response.getOutputStream()); + SyndicationUtils.toRSS(gitblitUrl, feedLink, getTitle(model.name, objectId), + model.description, model.name, entries, response.getOutputStream()); } catch (Exception e) { logger.error("An error occurred during feed generation", e); } -- Gitblit v1.9.1