/* * Copyright 2011 gitblit.com. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.gitblit.models; import java.io.Serializable; import java.util.ArrayList; import java.util.Collection; import java.util.Collections; import java.util.Date; import java.util.HashMap; import java.util.LinkedHashSet; import java.util.List; import java.util.Map; import java.util.Set; import java.util.TreeSet; import org.eclipse.jgit.revwalk.RevCommit; import com.gitblit.utils.StringUtils; import com.gitblit.utils.TimeUtils; /** * Model class to represent the commit activity across many repositories. This * class is used by the Activity page. * * @author James Moger */ public class Activity implements Serializable, Comparable { private static final long serialVersionUID = 1L; public final Date startDate; public final Date endDate; private final Set commits; private final Map authorMetrics; private final Map repositoryMetrics; private final Set authorExclusions; /** * Constructor for one day of activity. * * @param date */ public Activity(Date date) { this(date, TimeUtils.ONEDAY - 1); } /** * Constructor for specified duration of activity from start date. * * @param date * the start date of the activity * @param duration * the duration of the period in milliseconds */ public Activity(Date date, long duration) { startDate = date; endDate = new Date(date.getTime() + duration); commits = new LinkedHashSet(); authorMetrics = new HashMap(); repositoryMetrics = new HashMap(); authorExclusions = new TreeSet(); } /** * Exclude the specified authors from the metrics. * * @param authors */ public void excludeAuthors(Collection authors) { for (String author : authors) { authorExclusions.add(author.toLowerCase()); } } /** * Adds a commit to the activity object as long as the commit is not a * duplicate. * * @param repository * @param branch * @param commit * @return a RepositoryCommit, if one was added. Null if this is duplicate * commit */ public RepositoryCommit addCommit(String repository, String branch, RevCommit commit) { RepositoryCommit commitModel = new RepositoryCommit(repository, branch, commit); return addCommit(commitModel); } /** * Adds a commit to the activity object as long as the commit is not a * duplicate. * * @param repository * @param branch * @param commit * @return a RepositoryCommit, if one was added. Null if this is duplicate * commit */ public RepositoryCommit addCommit(RepositoryCommit commitModel) { if (commits.add(commitModel)) { String author = StringUtils.removeNewlines(commitModel.getAuthorIdent().getName()); String authorName = author.toLowerCase(); String authorEmail = StringUtils.removeNewlines(commitModel.getAuthorIdent().getEmailAddress()).toLowerCase(); if (!repositoryMetrics.containsKey(commitModel.repository)) { repositoryMetrics.put(commitModel.repository, new Metric(commitModel.repository)); } repositoryMetrics.get(commitModel.repository).count++; if (!authorExclusions.contains(authorName) && !authorExclusions.contains(authorEmail)) { if (!authorMetrics.containsKey(author)) { authorMetrics.put(author, new Metric(author)); } authorMetrics.get(author).count++; } return commitModel; } return null; } public int getCommitCount() { return commits.size(); } public List getCommits() { List list = new ArrayList(commits); Collections.sort(list); return list; } public Map getAuthorMetrics() { return authorMetrics; } public Map getRepositoryMetrics() { return repositoryMetrics; } @Override public int compareTo(Activity o) { // reverse chronological order return o.startDate.compareTo(startDate); } }