
org.janusgraph.diskstorage.cassandra.CassandraTransaction Maven / Gradle / Ivy
The newest version!
// Copyright 2017 JanusGraph Authors
//
// 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 org.janusgraph.diskstorage.cassandra;
import static org.janusgraph.diskstorage.cassandra.AbstractCassandraStoreManager.CASSANDRA_READ_CONSISTENCY;
import static org.janusgraph.diskstorage.cassandra.AbstractCassandraStoreManager.CASSANDRA_WRITE_CONSISTENCY;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.google.common.base.Preconditions;
import org.janusgraph.diskstorage.BaseTransactionConfig;
import org.janusgraph.diskstorage.common.AbstractStoreTransaction;
import org.janusgraph.diskstorage.keycolumnvalue.StoreTransaction;
public class CassandraTransaction extends AbstractStoreTransaction {
private static final Logger log = LoggerFactory.getLogger(CassandraTransaction.class);
private final CLevel read;
private final CLevel write;
public CassandraTransaction(BaseTransactionConfig c) {
super(c);
read = CLevel.parse(getConfiguration().getCustomOption(CASSANDRA_READ_CONSISTENCY));
write = CLevel.parse(getConfiguration().getCustomOption(CASSANDRA_WRITE_CONSISTENCY));
log.debug("Created {}", this.toString());
}
public CLevel getReadConsistencyLevel() {
return read;
}
public CLevel getWriteConsistencyLevel() {
return write;
}
public static CassandraTransaction getTx(StoreTransaction txh) {
Preconditions.checkArgument(txh != null);
Preconditions.checkArgument(txh instanceof CassandraTransaction, "Unexpected transaction type %s", txh.getClass().getName());
return (CassandraTransaction) txh;
}
public String toString() {
return "CassandraTransaction@" + Integer.toHexString(hashCode()) + "[read=" + read + ",write=" + write + "]";
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy