| | |
| | | import java.text.MessageFormat; |
| | | import java.text.SimpleDateFormat; |
| | | import java.util.ArrayList; |
| | | import java.util.Arrays; |
| | | import java.util.Collection; |
| | | import java.util.Collections; |
| | | import java.util.Date; |
| | |
| | | import org.eclipse.jgit.lib.ObjectId; |
| | | import org.eclipse.jgit.lib.ObjectInserter; |
| | | import org.eclipse.jgit.lib.PersonIdent; |
| | | import org.eclipse.jgit.lib.Ref; |
| | | import org.eclipse.jgit.lib.RefRename; |
| | | import org.eclipse.jgit.lib.RefUpdate; |
| | | import org.eclipse.jgit.lib.RefUpdate.Result; |
| | |
| | | parameters.add(0, repository.getDirectory().getAbsolutePath()); |
| | | } |
| | | LOGGER.error(MessageFormat.format(pattern, parameters.toArray()), t); |
| | | } |
| | | |
| | | /** |
| | | * Returns true if the repository has a reflog branch. |
| | | * |
| | | * @param repository |
| | | * @return true if the repository has a reflog branch |
| | | */ |
| | | public static boolean hasRefLogBranch(Repository repository) { |
| | | try { |
| | | return repository.getRef(GB_REFLOG) != null; |
| | | } catch(Exception e) { |
| | | LOGGER.error("failed to determine hasRefLogBranch", e); |
| | | } |
| | | return false; |
| | | } |
| | | |
| | | /** |
| | |
| | | } |
| | | |
| | | /** |
| | | * Logs a ref deletion. |
| | | * |
| | | * @param user |
| | | * @param repository |
| | | * @param ref |
| | | * @return true, if the update was successful |
| | | */ |
| | | public static boolean deleteRef(UserModel user, Repository repository, String ref) { |
| | | try { |
| | | Ref refObj = repository.getRef(ref); |
| | | if (refObj == null && !ref.startsWith(Constants.R_HEADS) && ref.startsWith(Constants.R_TAGS)) { |
| | | // find fully qualified ref |
| | | refObj = repository.getRef(Constants.R_HEADS + ref); |
| | | if (refObj == null) { |
| | | refObj = repository.getRef(Constants.R_TAGS + ref); |
| | | } |
| | | } |
| | | |
| | | if (refObj == null) { |
| | | return false; |
| | | } |
| | | |
| | | ReceiveCommand cmd = new ReceiveCommand(refObj.getObjectId(), ObjectId.zeroId(), refObj.getName()); |
| | | return updateRefLog(user, repository, Arrays.asList(cmd)); |
| | | } catch (Throwable t) { |
| | | error(t, repository, "Failed to commit reflog entry to {0}"); |
| | | } |
| | | return false; |
| | | } |
| | | |
| | | /** |
| | | * Updates the reflog with the received commands. |
| | | * |
| | | * @param user |
| | |
| | | PersonIdent ident; |
| | | if (UserModel.ANONYMOUS.equals(user)) { |
| | | // anonymous push |
| | | ident = new PersonIdent("anonymous", "anonymous"); |
| | | ident = new PersonIdent(user.username + "/" + user.username, user.username); |
| | | } else { |
| | | // construct real pushing account |
| | | ident = new PersonIdent(MessageFormat.format("{0}/{1}", user.getDisplayName(), user.username), |
| | |
| | | Map<String, DailyLogEntry> dailydigests = new HashMap<String, DailyLogEntry>(); |
| | | String linearParent = null; |
| | | for (RefModel local : JGitUtils.getLocalBranches(repository, true, -1)) { |
| | | if (!local.getDate().after(minimumDate)) { |
| | | // branch not recently updated |
| | | continue; |
| | | } |
| | | String branch = local.getName(); |
| | | List<RevCommit> commits = JGitUtils.getRevLog(repository, branch, minimumDate); |
| | | for (RevCommit commit : commits) { |
| | | List<RepositoryCommit> commits = CommitCache.instance().getCommits(repositoryName, repository, branch, minimumDate); |
| | | linearParent = null; |
| | | for (RepositoryCommit commit : commits) { |
| | | if (linearParent != null) { |
| | | if (!commit.getName().equals(linearParent)) { |
| | | // only follow linear branch commits |
| | | continue; |
| | | } |
| | | } |
| | | Date date = JGitUtils.getCommitDate(commit); |
| | | Date date = commit.getCommitDate(); |
| | | String dateStr = df.format(date); |
| | | if (!dailydigests.containsKey(dateStr)) { |
| | | dailydigests.put(dateStr, new DailyLogEntry(repositoryName, date)); |
| | |
| | | digest.updateRef(branch, ReceiveCommand.Type.UPDATE, linearParent, commit.getName()); |
| | | } |
| | | |
| | | RepositoryCommit repoCommit = digest.addCommit(branch, commit); |
| | | RepositoryCommit repoCommit = digest.addCommit(commit); |
| | | if (repoCommit != null) { |
| | | List<RefModel> matchedRefs = allRefs.get(commit.getId()); |
| | | repoCommit.setRefs(matchedRefs); |
| | |
| | | } |
| | | RefLogEntry tagEntry = tags.get(dateStr); |
| | | tagEntry.updateRef(ref.getName(), ReceiveCommand.Type.CREATE); |
| | | tagEntry.addCommit(ref.getName(), commit); |
| | | RepositoryCommit rc = repoCommit.clone(ref.getName()); |
| | | tagEntry.addCommit(rc); |
| | | } else if (ref.getName().startsWith(Constants.R_PULL)) { |
| | | // treat pull requests as special events in the log |
| | | if (!pulls.containsKey(dateStr)) { |
| | |
| | | } |
| | | RefLogEntry pullEntry = pulls.get(dateStr); |
| | | pullEntry.updateRef(ref.getName(), ReceiveCommand.Type.CREATE); |
| | | pullEntry.addCommit(ref.getName(), commit); |
| | | RepositoryCommit rc = repoCommit.clone(ref.getName()); |
| | | pullEntry.addCommit(rc); |
| | | } |
| | | } |
| | | } |