AccountSecurity: Remove unused enterAgreement method
Change-Id: I4741f039bde46030179c850d00e78c586f8e6a64
This commit is contained in:

committed by
Edwin Kempin

parent
240e2c6d2f
commit
b8fe7ffe1c
@@ -21,7 +21,6 @@ import com.google.gwtjsonrpc.common.AsyncCallback;
|
|||||||
import com.google.gwtjsonrpc.common.RemoteJsonService;
|
import com.google.gwtjsonrpc.common.RemoteJsonService;
|
||||||
import com.google.gwtjsonrpc.common.RpcImpl;
|
import com.google.gwtjsonrpc.common.RpcImpl;
|
||||||
import com.google.gwtjsonrpc.common.RpcImpl.Version;
|
import com.google.gwtjsonrpc.common.RpcImpl.Version;
|
||||||
import com.google.gwtjsonrpc.common.VoidResult;
|
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
@@ -35,9 +34,4 @@ public interface AccountSecurity extends RemoteJsonService {
|
|||||||
@SignInRequired
|
@SignInRequired
|
||||||
void deleteExternalIds(Set<AccountExternalId.Key> keys,
|
void deleteExternalIds(Set<AccountExternalId.Key> keys,
|
||||||
AsyncCallback<Set<AccountExternalId.Key>> callback);
|
AsyncCallback<Set<AccountExternalId.Key>> callback);
|
||||||
|
|
||||||
@Audit
|
|
||||||
@SignInRequired
|
|
||||||
void enterAgreement(String agreementName,
|
|
||||||
AsyncCallback<VoidResult> callback);
|
|
||||||
}
|
}
|
||||||
|
@@ -14,66 +14,31 @@
|
|||||||
|
|
||||||
package com.google.gerrit.httpd.rpc.account;
|
package com.google.gerrit.httpd.rpc.account;
|
||||||
|
|
||||||
import com.google.gerrit.audit.AuditService;
|
|
||||||
import com.google.gerrit.common.data.AccountSecurity;
|
import com.google.gerrit.common.data.AccountSecurity;
|
||||||
import com.google.gerrit.common.data.ContributorAgreement;
|
|
||||||
import com.google.gerrit.common.errors.NoSuchEntityException;
|
|
||||||
import com.google.gerrit.httpd.rpc.BaseServiceImplementation;
|
import com.google.gerrit.httpd.rpc.BaseServiceImplementation;
|
||||||
import com.google.gerrit.reviewdb.client.Account;
|
|
||||||
import com.google.gerrit.reviewdb.client.AccountExternalId;
|
import com.google.gerrit.reviewdb.client.AccountExternalId;
|
||||||
import com.google.gerrit.reviewdb.client.AccountGroup;
|
|
||||||
import com.google.gerrit.reviewdb.client.AccountGroupMember;
|
|
||||||
import com.google.gerrit.reviewdb.server.ReviewDb;
|
import com.google.gerrit.reviewdb.server.ReviewDb;
|
||||||
import com.google.gerrit.server.CurrentUser;
|
import com.google.gerrit.server.CurrentUser;
|
||||||
import com.google.gerrit.server.IdentifiedUser;
|
|
||||||
import com.google.gerrit.server.account.AccountCache;
|
|
||||||
import com.google.gerrit.server.account.GroupCache;
|
|
||||||
import com.google.gerrit.server.extensions.events.AgreementSignup;
|
|
||||||
import com.google.gerrit.server.project.ProjectCache;
|
|
||||||
import com.google.gwtjsonrpc.common.AsyncCallback;
|
import com.google.gwtjsonrpc.common.AsyncCallback;
|
||||||
import com.google.gwtjsonrpc.common.VoidResult;
|
|
||||||
import com.google.gwtorm.server.OrmException;
|
|
||||||
import com.google.inject.Inject;
|
import com.google.inject.Inject;
|
||||||
import com.google.inject.Provider;
|
import com.google.inject.Provider;
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
class AccountSecurityImpl extends BaseServiceImplementation implements
|
class AccountSecurityImpl extends BaseServiceImplementation implements
|
||||||
AccountSecurity {
|
AccountSecurity {
|
||||||
private final ProjectCache projectCache;
|
|
||||||
private final Provider<IdentifiedUser> user;
|
|
||||||
private final AccountCache accountCache;
|
|
||||||
|
|
||||||
private final DeleteExternalIds.Factory deleteExternalIdsFactory;
|
private final DeleteExternalIds.Factory deleteExternalIdsFactory;
|
||||||
private final ExternalIdDetailFactory.Factory externalIdDetailFactory;
|
private final ExternalIdDetailFactory.Factory externalIdDetailFactory;
|
||||||
|
|
||||||
private final GroupCache groupCache;
|
|
||||||
private final AuditService auditService;
|
|
||||||
private final AgreementSignup agreementSignup;
|
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
AccountSecurityImpl(final Provider<ReviewDb> schema,
|
AccountSecurityImpl(final Provider<ReviewDb> schema,
|
||||||
final Provider<CurrentUser> currentUser,
|
final Provider<CurrentUser> currentUser,
|
||||||
final Provider<IdentifiedUser> u,
|
|
||||||
final ProjectCache pc,
|
|
||||||
final AccountCache uac,
|
|
||||||
final DeleteExternalIds.Factory deleteExternalIdsFactory,
|
final DeleteExternalIds.Factory deleteExternalIdsFactory,
|
||||||
final ExternalIdDetailFactory.Factory externalIdDetailFactory,
|
final ExternalIdDetailFactory.Factory externalIdDetailFactory) {
|
||||||
final GroupCache groupCache,
|
|
||||||
final AuditService auditService,
|
|
||||||
AgreementSignup agreementSignup) {
|
|
||||||
super(schema, currentUser);
|
super(schema, currentUser);
|
||||||
user = u;
|
|
||||||
projectCache = pc;
|
|
||||||
accountCache = uac;
|
|
||||||
this.auditService = auditService;
|
|
||||||
this.deleteExternalIdsFactory = deleteExternalIdsFactory;
|
this.deleteExternalIdsFactory = deleteExternalIdsFactory;
|
||||||
this.externalIdDetailFactory = externalIdDetailFactory;
|
this.externalIdDetailFactory = externalIdDetailFactory;
|
||||||
this.groupCache = groupCache;
|
|
||||||
this.agreementSignup = agreementSignup;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -86,48 +51,4 @@ class AccountSecurityImpl extends BaseServiceImplementation implements
|
|||||||
final AsyncCallback<Set<AccountExternalId.Key>> callback) {
|
final AsyncCallback<Set<AccountExternalId.Key>> callback) {
|
||||||
deleteExternalIdsFactory.create(keys).to(callback);
|
deleteExternalIdsFactory.create(keys).to(callback);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void enterAgreement(final String agreementName,
|
|
||||||
final AsyncCallback<VoidResult> callback) {
|
|
||||||
run(callback, new Action<VoidResult>() {
|
|
||||||
@Override
|
|
||||||
public VoidResult run(final ReviewDb db)
|
|
||||||
throws OrmException, Failure, IOException {
|
|
||||||
ContributorAgreement ca = projectCache.getAllProjects().getConfig()
|
|
||||||
.getContributorAgreement(agreementName);
|
|
||||||
if (ca == null) {
|
|
||||||
throw new Failure(new NoSuchEntityException());
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ca.getAutoVerify() == null) {
|
|
||||||
throw new Failure(new IllegalStateException(
|
|
||||||
"cannot enter a non-autoVerify agreement"));
|
|
||||||
} else if (ca.getAutoVerify().getUUID() == null) {
|
|
||||||
throw new Failure(new NoSuchEntityException());
|
|
||||||
}
|
|
||||||
|
|
||||||
AccountGroup group = groupCache.get(ca.getAutoVerify().getUUID());
|
|
||||||
if (group == null) {
|
|
||||||
throw new Failure(new NoSuchEntityException());
|
|
||||||
}
|
|
||||||
|
|
||||||
Account account = user.get().getAccount();
|
|
||||||
agreementSignup.fire(account, ca.getName());
|
|
||||||
|
|
||||||
final AccountGroupMember.Key key =
|
|
||||||
new AccountGroupMember.Key(account.getId(), group.getId());
|
|
||||||
AccountGroupMember m = db.accountGroupMembers().get(key);
|
|
||||||
if (m == null) {
|
|
||||||
m = new AccountGroupMember(key);
|
|
||||||
auditService.dispatchAddAccountsToGroup(account.getId(), Collections
|
|
||||||
.singleton(m));
|
|
||||||
db.accountGroupMembers().insert(Collections.singleton(m));
|
|
||||||
accountCache.evict(m.getAccountId());
|
|
||||||
}
|
|
||||||
|
|
||||||
return VoidResult.INSTANCE;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user