Merge branch 'stable-2.9'
* stable-2.9: Fix rejection of banned commits Update gwtorm to 1.13 Change-Id: I4180a7010475e2fc80a54e73d8845c615c1c7cff
This commit is contained in:
commit
41df0f56e6
@ -0,0 +1,52 @@
|
|||||||
|
// Copyright (C) 2014 The Android Open Source Project
|
||||||
|
//
|
||||||
|
// 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.google.gerrit.acceptance.ssh;
|
||||||
|
|
||||||
|
import static com.google.gerrit.acceptance.GitUtil.add;
|
||||||
|
import static com.google.gerrit.acceptance.GitUtil.createCommit;
|
||||||
|
import static com.google.gerrit.acceptance.GitUtil.pushHead;
|
||||||
|
import static org.junit.Assert.assertFalse;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
|
import com.google.gerrit.acceptance.AbstractDaemonTest;
|
||||||
|
import com.google.gerrit.acceptance.GitUtil.Commit;
|
||||||
|
|
||||||
|
import com.jcraft.jsch.JSchException;
|
||||||
|
|
||||||
|
import org.eclipse.jgit.api.errors.GitAPIException;
|
||||||
|
import org.eclipse.jgit.transport.PushResult;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.Locale;
|
||||||
|
|
||||||
|
public class BanCommitIT extends AbstractDaemonTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void banCommit() throws IOException, GitAPIException, JSchException {
|
||||||
|
add(git, "a.txt", "some content");
|
||||||
|
Commit c = createCommit(git, admin.getIdent(), "subject");
|
||||||
|
|
||||||
|
String response =
|
||||||
|
sshSession.exec("gerrit ban-commit " + project.get() + " "
|
||||||
|
+ c.getCommit().getName());
|
||||||
|
assertFalse(sshSession.hasError());
|
||||||
|
assertFalse(response, response.toLowerCase(Locale.US).contains("error"));
|
||||||
|
|
||||||
|
PushResult pushResult = pushHead(git, "refs/heads/master", false);
|
||||||
|
assertTrue(pushResult.getRemoteUpdate("refs/heads/master").getMessage()
|
||||||
|
.startsWith("contains banned commit"));
|
||||||
|
}
|
||||||
|
}
|
@ -18,6 +18,7 @@ import static com.google.gerrit.reviewdb.client.RefNames.REFS_REJECT_COMMITS;
|
|||||||
|
|
||||||
import com.google.gerrit.common.errors.PermissionDeniedException;
|
import com.google.gerrit.common.errors.PermissionDeniedException;
|
||||||
import com.google.gerrit.reviewdb.client.Project;
|
import com.google.gerrit.reviewdb.client.Project;
|
||||||
|
import com.google.gerrit.reviewdb.client.RefNames;
|
||||||
import com.google.gerrit.server.GerritPersonIdent;
|
import com.google.gerrit.server.GerritPersonIdent;
|
||||||
import com.google.gerrit.server.IdentifiedUser;
|
import com.google.gerrit.server.IdentifiedUser;
|
||||||
import com.google.gerrit.server.project.ProjectControl;
|
import com.google.gerrit.server.project.ProjectControl;
|
||||||
@ -31,9 +32,11 @@ import org.eclipse.jgit.lib.Constants;
|
|||||||
import org.eclipse.jgit.lib.ObjectId;
|
import org.eclipse.jgit.lib.ObjectId;
|
||||||
import org.eclipse.jgit.lib.ObjectInserter;
|
import org.eclipse.jgit.lib.ObjectInserter;
|
||||||
import org.eclipse.jgit.lib.PersonIdent;
|
import org.eclipse.jgit.lib.PersonIdent;
|
||||||
|
import org.eclipse.jgit.lib.Ref;
|
||||||
import org.eclipse.jgit.lib.Repository;
|
import org.eclipse.jgit.lib.Repository;
|
||||||
import org.eclipse.jgit.notes.Note;
|
import org.eclipse.jgit.notes.Note;
|
||||||
import org.eclipse.jgit.notes.NoteMap;
|
import org.eclipse.jgit.notes.NoteMap;
|
||||||
|
import org.eclipse.jgit.revwalk.RevCommit;
|
||||||
import org.eclipse.jgit.revwalk.RevWalk;
|
import org.eclipse.jgit.revwalk.RevWalk;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
@ -47,6 +50,34 @@ public class BanCommit {
|
|||||||
BanCommit create();
|
BanCommit create();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Loads a list of commits to reject from {@code refs/meta/reject-commits}.
|
||||||
|
*
|
||||||
|
* @param repo repository from which the rejected commits should be loaded
|
||||||
|
* @return NoteMap of commits to be rejected, null if there are none.
|
||||||
|
* @throws IOException the map cannot be loaded.
|
||||||
|
*/
|
||||||
|
public static NoteMap loadRejectCommitsMap(Repository repo)
|
||||||
|
throws IOException {
|
||||||
|
try {
|
||||||
|
Ref ref = repo.getRef(RefNames.REFS_REJECT_COMMITS);
|
||||||
|
if (ref == null) {
|
||||||
|
return NoteMap.newEmptyMap();
|
||||||
|
}
|
||||||
|
|
||||||
|
RevWalk rw = new RevWalk(repo);
|
||||||
|
try {
|
||||||
|
RevCommit map = rw.parseCommit(ref.getObjectId());
|
||||||
|
return NoteMap.read(rw.getObjectReader(), map);
|
||||||
|
} finally {
|
||||||
|
rw.release();
|
||||||
|
}
|
||||||
|
} catch (IOException badMap) {
|
||||||
|
throw new IOException("Cannot load "
|
||||||
|
+ RefNames.REFS_REJECT_COMMITS, badMap);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private final Provider<IdentifiedUser> currentUser;
|
private final Provider<IdentifiedUser> currentUser;
|
||||||
private final GitRepositoryManager repoManager;
|
private final GitRepositoryManager repoManager;
|
||||||
private final PersonIdent gerritIdent;
|
private final PersonIdent gerritIdent;
|
||||||
|
@ -415,7 +415,7 @@ public class ReceiveCommits {
|
|||||||
this.project = projectControl.getProject();
|
this.project = projectControl.getProject();
|
||||||
this.repo = repo;
|
this.repo = repo;
|
||||||
this.rp = new ReceivePack(repo);
|
this.rp = new ReceivePack(repo);
|
||||||
this.rejectCommits = loadRejectCommitsMap();
|
this.rejectCommits = BanCommit.loadRejectCommitsMap(repo);
|
||||||
|
|
||||||
this.subOpFactory = subOpFactory;
|
this.subOpFactory = subOpFactory;
|
||||||
this.submitProvider = submitProvider;
|
this.submitProvider = submitProvider;
|
||||||
@ -1343,28 +1343,6 @@ public class ReceiveCommits {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Loads a list of commits to reject from {@code refs/meta/reject-commits}.
|
|
||||||
*
|
|
||||||
* @return NoteMap of commits to be rejected, null if there are none.
|
|
||||||
* @throws IOException the map cannot be loaded.
|
|
||||||
*/
|
|
||||||
private NoteMap loadRejectCommitsMap() throws IOException {
|
|
||||||
try {
|
|
||||||
Ref ref = repo.getRef(RefNames.REFS_REJECT_COMMITS);
|
|
||||||
if (ref == null) {
|
|
||||||
return NoteMap.newEmptyMap();
|
|
||||||
}
|
|
||||||
|
|
||||||
RevWalk rw = rp.getRevWalk();
|
|
||||||
RevCommit map = rw.parseCommit(ref.getObjectId());
|
|
||||||
return NoteMap.read(rw.getObjectReader(), map);
|
|
||||||
} catch (IOException badMap) {
|
|
||||||
throw new IOException("Cannot load "
|
|
||||||
+ RefNames.REFS_REJECT_COMMITS, badMap);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void parseReplaceCommand(final ReceiveCommand cmd,
|
private void parseReplaceCommand(final ReceiveCommand cmd,
|
||||||
final Change.Id changeId) {
|
final Change.Id changeId) {
|
||||||
if (cmd.getType() != ReceiveCommand.Type.CREATE) {
|
if (cmd.getType() != ReceiveCommand.Type.CREATE) {
|
||||||
|
@ -24,6 +24,7 @@ import com.google.gerrit.server.IdentifiedUser;
|
|||||||
import com.google.gerrit.server.config.CanonicalWebUrl;
|
import com.google.gerrit.server.config.CanonicalWebUrl;
|
||||||
import com.google.gerrit.server.config.GerritServerConfig;
|
import com.google.gerrit.server.config.GerritServerConfig;
|
||||||
import com.google.gerrit.server.events.CommitReceivedEvent;
|
import com.google.gerrit.server.events.CommitReceivedEvent;
|
||||||
|
import com.google.gerrit.server.git.BanCommit;
|
||||||
import com.google.gerrit.server.git.ProjectConfig;
|
import com.google.gerrit.server.git.ProjectConfig;
|
||||||
import com.google.gerrit.server.git.ReceiveCommits;
|
import com.google.gerrit.server.git.ReceiveCommits;
|
||||||
import com.google.gerrit.server.git.ValidationError;
|
import com.google.gerrit.server.git.ValidationError;
|
||||||
@ -40,6 +41,7 @@ import org.eclipse.jgit.errors.ConfigInvalidException;
|
|||||||
import org.eclipse.jgit.lib.Config;
|
import org.eclipse.jgit.lib.Config;
|
||||||
import org.eclipse.jgit.lib.PersonIdent;
|
import org.eclipse.jgit.lib.PersonIdent;
|
||||||
import org.eclipse.jgit.lib.Repository;
|
import org.eclipse.jgit.lib.Repository;
|
||||||
|
import org.eclipse.jgit.notes.NoteMap;
|
||||||
import org.eclipse.jgit.revwalk.FooterKey;
|
import org.eclipse.jgit.revwalk.FooterKey;
|
||||||
import org.eclipse.jgit.revwalk.FooterLine;
|
import org.eclipse.jgit.revwalk.FooterLine;
|
||||||
import org.eclipse.jgit.revwalk.RevCommit;
|
import org.eclipse.jgit.revwalk.RevCommit;
|
||||||
@ -47,6 +49,7 @@ import org.eclipse.jgit.util.SystemReader;
|
|||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
import java.net.MalformedURLException;
|
import java.net.MalformedURLException;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
@ -107,6 +110,7 @@ public class CommitValidators {
|
|||||||
installCommitMsgHookCommand, sshInfo));
|
installCommitMsgHookCommand, sshInfo));
|
||||||
}
|
}
|
||||||
validators.add(new ConfigValidator(refControl, repo));
|
validators.add(new ConfigValidator(refControl, repo));
|
||||||
|
validators.add(new BannedCommitsValidator(repo));
|
||||||
validators.add(new PluginCommitValidationListener(commitValidationListeners));
|
validators.add(new PluginCommitValidationListener(commitValidationListeners));
|
||||||
|
|
||||||
List<CommitValidationMessage> messages = new LinkedList<>();
|
List<CommitValidationMessage> messages = new LinkedList<>();
|
||||||
@ -515,6 +519,31 @@ public class CommitValidators {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Reject banned commits. */
|
||||||
|
public static class BannedCommitsValidator implements
|
||||||
|
CommitValidationListener {
|
||||||
|
private final Repository repo;
|
||||||
|
|
||||||
|
public BannedCommitsValidator(Repository repo) {
|
||||||
|
this.repo = repo;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<CommitValidationMessage> onCommitReceived(
|
||||||
|
CommitReceivedEvent receiveEvent) throws CommitValidationException {
|
||||||
|
try {
|
||||||
|
NoteMap rejectCommits = BanCommit.loadRejectCommitsMap(repo);
|
||||||
|
if (rejectCommits.contains(receiveEvent.commit)) {
|
||||||
|
throw new CommitValidationException("contains banned commit "
|
||||||
|
+ receiveEvent.commit.getName());
|
||||||
|
}
|
||||||
|
return Collections.emptyList();
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new CommitValidationException(e.getMessage(), e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private static CommitValidationMessage getInvalidEmailError(RevCommit c, String type,
|
private static CommitValidationMessage getInvalidEmailError(RevCommit c, String type,
|
||||||
PersonIdent who, IdentifiedUser currentUser, String canonicalWebUrl) {
|
PersonIdent who, IdentifiedUser currentUser, String canonicalWebUrl) {
|
||||||
StringBuilder sb = new StringBuilder();
|
StringBuilder sb = new StringBuilder();
|
||||||
|
6
lib/BUCK
6
lib/BUCK
@ -25,9 +25,9 @@ define_license(name = 'DO_NOT_DISTRIBUTE')
|
|||||||
|
|
||||||
maven_jar(
|
maven_jar(
|
||||||
name = 'gwtorm',
|
name = 'gwtorm',
|
||||||
id = 'gwtorm:gwtorm:1.11',
|
id = 'com.google.gerrit:gwtorm:1.13',
|
||||||
bin_sha1 = '526c98e8a200c5b3b34dcee69ccf6bc95daf84db',
|
bin_sha1 = 'f522e05ca280335f8f8ba63c9c3e1b36be6ca7c2',
|
||||||
src_sha1 = 'fd07a195026be40709feece4483b48349c58cfe3',
|
src_sha1 = '81bd99d55be872cd2fc52611f92cf5f3a64ffe8b',
|
||||||
license = 'Apache2.0',
|
license = 'Apache2.0',
|
||||||
deps = [':protobuf'],
|
deps = [':protobuf'],
|
||||||
repository = GERRIT,
|
repository = GERRIT,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user