summaryrefslogtreecommitdiffstats
path: root/gerrit-server/src/main/java/com/google/gerrit/server/change/DeleteVote.java
diff options
context:
space:
mode:
Diffstat (limited to 'gerrit-server/src/main/java/com/google/gerrit/server/change/DeleteVote.java')
-rw-r--r--gerrit-server/src/main/java/com/google/gerrit/server/change/DeleteVote.java264
1 files changed, 0 insertions, 264 deletions
diff --git a/gerrit-server/src/main/java/com/google/gerrit/server/change/DeleteVote.java b/gerrit-server/src/main/java/com/google/gerrit/server/change/DeleteVote.java
deleted file mode 100644
index 8c6c3ccefc..0000000000
--- a/gerrit-server/src/main/java/com/google/gerrit/server/change/DeleteVote.java
+++ /dev/null
@@ -1,264 +0,0 @@
-// 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.server.change;
-
-import static com.google.common.base.Preconditions.checkNotNull;
-
-import com.google.gerrit.common.TimeUtil;
-import com.google.gerrit.common.data.LabelTypes;
-import com.google.gerrit.extensions.api.changes.DeleteVoteInput;
-import com.google.gerrit.extensions.api.changes.NotifyHandling;
-import com.google.gerrit.extensions.restapi.AuthException;
-import com.google.gerrit.extensions.restapi.BadRequestException;
-import com.google.gerrit.extensions.restapi.MethodNotAllowedException;
-import com.google.gerrit.extensions.restapi.ResourceNotFoundException;
-import com.google.gerrit.extensions.restapi.Response;
-import com.google.gerrit.extensions.restapi.RestApiException;
-import com.google.gerrit.reviewdb.client.Account;
-import com.google.gerrit.reviewdb.client.Change;
-import com.google.gerrit.reviewdb.client.ChangeMessage;
-import com.google.gerrit.reviewdb.client.LabelId;
-import com.google.gerrit.reviewdb.client.PatchSet;
-import com.google.gerrit.reviewdb.client.PatchSetApproval;
-import com.google.gerrit.reviewdb.server.ReviewDb;
-import com.google.gerrit.server.ApprovalsUtil;
-import com.google.gerrit.server.ChangeMessagesUtil;
-import com.google.gerrit.server.IdentifiedUser;
-import com.google.gerrit.server.PatchSetUtil;
-import com.google.gerrit.server.extensions.events.VoteDeleted;
-import com.google.gerrit.server.mail.send.DeleteVoteSender;
-import com.google.gerrit.server.mail.send.ReplyToChangeSender;
-import com.google.gerrit.server.permissions.PermissionBackendException;
-import com.google.gerrit.server.project.NoSuchProjectException;
-import com.google.gerrit.server.project.ProjectCache;
-import com.google.gerrit.server.project.ProjectState;
-import com.google.gerrit.server.project.RemoveReviewerControl;
-import com.google.gerrit.server.update.BatchUpdate;
-import com.google.gerrit.server.update.BatchUpdateOp;
-import com.google.gerrit.server.update.ChangeContext;
-import com.google.gerrit.server.update.Context;
-import com.google.gerrit.server.update.RetryHelper;
-import com.google.gerrit.server.update.RetryingRestModifyView;
-import com.google.gerrit.server.update.UpdateException;
-import com.google.gerrit.server.util.LabelVote;
-import com.google.gwtorm.server.OrmException;
-import com.google.inject.Inject;
-import com.google.inject.Provider;
-import com.google.inject.Singleton;
-import java.io.IOException;
-import java.util.Collections;
-import java.util.HashMap;
-import java.util.Map;
-import org.slf4j.Logger;
-import org.slf4j.LoggerFactory;
-
-@Singleton
-public class DeleteVote extends RetryingRestModifyView<VoteResource, DeleteVoteInput, Response<?>> {
- private static final Logger log = LoggerFactory.getLogger(DeleteVote.class);
-
- private final Provider<ReviewDb> db;
- private final ApprovalsUtil approvalsUtil;
- private final PatchSetUtil psUtil;
- private final ChangeMessagesUtil cmUtil;
- private final IdentifiedUser.GenericFactory userFactory;
- private final VoteDeleted voteDeleted;
- private final DeleteVoteSender.Factory deleteVoteSenderFactory;
- private final NotifyUtil notifyUtil;
- private final RemoveReviewerControl removeReviewerControl;
- private final ProjectCache projectCache;
-
- @Inject
- DeleteVote(
- Provider<ReviewDb> db,
- RetryHelper retryHelper,
- ApprovalsUtil approvalsUtil,
- PatchSetUtil psUtil,
- ChangeMessagesUtil cmUtil,
- IdentifiedUser.GenericFactory userFactory,
- VoteDeleted voteDeleted,
- DeleteVoteSender.Factory deleteVoteSenderFactory,
- NotifyUtil notifyUtil,
- RemoveReviewerControl removeReviewerControl,
- ProjectCache projectCache) {
- super(retryHelper);
- this.db = db;
- this.approvalsUtil = approvalsUtil;
- this.psUtil = psUtil;
- this.cmUtil = cmUtil;
- this.userFactory = userFactory;
- this.voteDeleted = voteDeleted;
- this.deleteVoteSenderFactory = deleteVoteSenderFactory;
- this.notifyUtil = notifyUtil;
- this.removeReviewerControl = removeReviewerControl;
- this.projectCache = projectCache;
- }
-
- @Override
- protected Response<?> applyImpl(
- BatchUpdate.Factory updateFactory, VoteResource rsrc, DeleteVoteInput input)
- throws RestApiException, UpdateException, IOException {
- if (input == null) {
- input = new DeleteVoteInput();
- }
- if (input.label != null && !rsrc.getLabel().equals(input.label)) {
- throw new BadRequestException("label must match URL");
- }
- if (input.notify == null) {
- input.notify = NotifyHandling.ALL;
- }
- ReviewerResource r = rsrc.getReviewer();
- Change change = r.getChange();
-
- if (r.getRevisionResource() != null && !r.getRevisionResource().isCurrent()) {
- throw new MethodNotAllowedException("Cannot delete vote on non-current patch set");
- }
-
- try (BatchUpdate bu =
- updateFactory.create(
- db.get(), change.getProject(), r.getChangeResource().getUser(), TimeUtil.nowTs())) {
- bu.addOp(
- change.getId(),
- new Op(
- projectCache.checkedGet(r.getChange().getProject()),
- r.getReviewerUser().getAccount(),
- rsrc.getLabel(),
- input));
- bu.execute();
- }
-
- return Response.none();
- }
-
- private class Op implements BatchUpdateOp {
- private final ProjectState projectState;
- private final Account account;
- private final String label;
- private final DeleteVoteInput input;
-
- private ChangeMessage changeMessage;
- private Change change;
- private PatchSet ps;
- private Map<String, Short> newApprovals = new HashMap<>();
- private Map<String, Short> oldApprovals = new HashMap<>();
-
- private Op(ProjectState projectState, Account account, String label, DeleteVoteInput input) {
- this.projectState = projectState;
- this.account = account;
- this.label = label;
- this.input = input;
- }
-
- @Override
- public boolean updateChange(ChangeContext ctx)
- throws OrmException, AuthException, ResourceNotFoundException, IOException,
- PermissionBackendException, NoSuchProjectException {
- change = ctx.getChange();
- PatchSet.Id psId = change.currentPatchSetId();
- ps = psUtil.current(db.get(), ctx.getNotes());
-
- boolean found = false;
- LabelTypes labelTypes = projectState.getLabelTypes(ctx.getNotes(), ctx.getUser());
-
- for (PatchSetApproval a :
- approvalsUtil.byPatchSetUser(
- ctx.getDb(),
- ctx.getNotes(),
- ctx.getUser(),
- psId,
- account.getId(),
- ctx.getRevWalk(),
- ctx.getRepoView().getConfig())) {
- if (labelTypes.byLabel(a.getLabelId()) == null) {
- continue; // Ignore undefined labels.
- } else if (!a.getLabel().equals(label)) {
- // Populate map for non-matching labels, needed by VoteDeleted.
- newApprovals.put(a.getLabel(), a.getValue());
- continue;
- } else {
- try {
- removeReviewerControl.checkRemoveReviewer(ctx.getNotes(), ctx.getUser(), a);
- } catch (AuthException e) {
- throw new AuthException("delete vote not permitted", e);
- }
- }
- // Set the approval to 0 if vote is being removed.
- newApprovals.put(a.getLabel(), (short) 0);
- found = true;
-
- // Set old value, as required by VoteDeleted.
- oldApprovals.put(a.getLabel(), a.getValue());
- break;
- }
- if (!found) {
- throw new ResourceNotFoundException();
- }
-
- ctx.getUpdate(psId).removeApprovalFor(account.getId(), label);
- ctx.getDb().patchSetApprovals().upsert(Collections.singleton(deletedApproval(ctx)));
-
- StringBuilder msg = new StringBuilder();
- msg.append("Removed ");
- LabelVote.appendTo(msg, label, checkNotNull(oldApprovals.get(label)));
- msg.append(" by ").append(userFactory.create(account.getId()).getNameEmail()).append("\n");
- changeMessage =
- ChangeMessagesUtil.newMessage(ctx, msg.toString(), ChangeMessagesUtil.TAG_DELETE_VOTE);
- cmUtil.addChangeMessage(ctx.getDb(), ctx.getUpdate(psId), changeMessage);
-
- return true;
- }
-
- private PatchSetApproval deletedApproval(ChangeContext ctx) {
- // Set the effective user to the account we're trying to remove, and don't
- // set the real user; this preserves the calling user as the NoteDb
- // committer.
- return new PatchSetApproval(
- new PatchSetApproval.Key(ps.getId(), account.getId(), new LabelId(label)),
- (short) 0,
- ctx.getWhen());
- }
-
- @Override
- public void postUpdate(Context ctx) {
- if (changeMessage == null) {
- return;
- }
-
- IdentifiedUser user = ctx.getIdentifiedUser();
- if (NotifyUtil.shouldNotify(input.notify, input.notifyDetails)) {
- try {
- ReplyToChangeSender cm = deleteVoteSenderFactory.create(ctx.getProject(), change.getId());
- cm.setFrom(user.getAccountId());
- cm.setChangeMessage(changeMessage.getMessage(), ctx.getWhen());
- cm.setNotify(input.notify);
- cm.setAccountsToNotify(notifyUtil.resolveAccounts(input.notifyDetails));
- cm.send();
- } catch (Exception e) {
- log.error("Cannot email update for change " + change.getId(), e);
- }
- }
-
- voteDeleted.fire(
- change,
- ps,
- account,
- newApprovals,
- oldApprovals,
- input.notify,
- changeMessage.getMessage(),
- user.getAccount(),
- ctx.getWhen());
- }
- }
-}