blob: ff0920c7718b48804cf8521971c37f3ec7acd190 [file] [log] [blame]
/*
* 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<Activity> {
private static final long serialVersionUID = 1L;
public final Date startDate;
public final Date endDate;
private final Set<RepositoryCommit> commits;
private final Map<String, Metric> authorMetrics;
private final Map<String, Metric> repositoryMetrics;
private final Set<String> 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<RepositoryCommit>();
authorMetrics = new HashMap<String, Metric>();
repositoryMetrics = new HashMap<String, Metric>();
authorExclusions = new TreeSet<String>();
}
/**
* Exclude the specified authors from the metrics.
*
* @param authors
*/
public void excludeAuthors(Collection<String> 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<RepositoryCommit> getCommits() {
List<RepositoryCommit> list = new ArrayList<RepositoryCommit>(commits);
Collections.sort(list);
return list;
}
public Map<String, Metric> getAuthorMetrics() {
return authorMetrics;
}
public Map<String, Metric> getRepositoryMetrics() {
return repositoryMetrics;
}
@Override
public int compareTo(Activity o) {
// reverse chronological order
return o.startDate.compareTo(startDate);
}
}