com.scalar.db.transaction.rpc.GrpcTwoPhaseCommitTransaction Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of scalardb Show documentation
Show all versions of scalardb Show documentation
A universal transaction manager that achieves database-agnostic transactions and distributed transactions that span multiple databases
package com.scalar.db.transaction.rpc;
import com.scalar.db.api.Delete;
import com.scalar.db.api.Get;
import com.scalar.db.api.Mutation;
import com.scalar.db.api.Put;
import com.scalar.db.api.Result;
import com.scalar.db.api.Scan;
import com.scalar.db.common.AbstractTwoPhaseCommitTransaction;
import com.scalar.db.exception.transaction.AbortException;
import com.scalar.db.exception.transaction.CommitException;
import com.scalar.db.exception.transaction.CrudException;
import com.scalar.db.exception.transaction.PreparationException;
import com.scalar.db.exception.transaction.RollbackException;
import com.scalar.db.exception.transaction.UnknownTransactionStatusException;
import com.scalar.db.exception.transaction.ValidationException;
import java.util.List;
import java.util.Optional;
import javax.annotation.concurrent.NotThreadSafe;
@NotThreadSafe
public class GrpcTwoPhaseCommitTransaction extends AbstractTwoPhaseCommitTransaction {
private final String txId;
private final GrpcTwoPhaseCommitTransactionOnBidirectionalStream stream;
public GrpcTwoPhaseCommitTransaction(
String txId, GrpcTwoPhaseCommitTransactionOnBidirectionalStream stream) {
this.txId = txId;
this.stream = stream;
}
@Override
public String getId() {
return txId;
}
@Override
public Optional get(Get get) throws CrudException {
get = copyAndSetTargetToIfNot(get);
return stream.get(get);
}
@Override
public List scan(Scan scan) throws CrudException {
scan = copyAndSetTargetToIfNot(scan);
return stream.scan(scan);
}
@Override
public void put(Put put) throws CrudException {
put = copyAndSetTargetToIfNot(put);
stream.mutate(put);
}
@Override
public void put(List puts) throws CrudException {
mutate(puts);
}
@Override
public void delete(Delete delete) throws CrudException {
delete = copyAndSetTargetToIfNot(delete);
stream.mutate(delete);
}
@Override
public void delete(List deletes) throws CrudException {
mutate(deletes);
}
@Override
public void mutate(List extends Mutation> mutations) throws CrudException {
mutations = copyAndSetTargetToIfNot(mutations);
stream.mutate(mutations);
}
@Override
public void prepare() throws PreparationException {
stream.prepare();
}
@Override
public void validate() throws ValidationException {
stream.validate();
}
@Override
public void commit() throws CommitException, UnknownTransactionStatusException {
stream.commit();
}
@Override
public void rollback() throws RollbackException {
stream.rollback();
}
@Override
public void abort() throws AbortException {
stream.abort();
}
}