TransactionInfo.java
/*
* 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.facebook.presto.transaction;
import com.facebook.drift.annotations.ThriftConstructor;
import com.facebook.drift.annotations.ThriftField;
import com.facebook.drift.annotations.ThriftStruct;
import com.facebook.presto.common.transaction.TransactionId;
import com.facebook.presto.spi.ConnectorId;
import com.facebook.presto.spi.transaction.IsolationLevel;
import com.google.common.collect.ImmutableList;
import io.airlift.units.Duration;
import java.util.List;
import java.util.Optional;
import static com.google.common.base.Preconditions.checkArgument;
import static java.util.Objects.requireNonNull;
@ThriftStruct
public class TransactionInfo
{
private final TransactionId transactionId;
private final IsolationLevel isolationLevel;
private final boolean readOnly;
private final boolean autoCommitContext;
private final long createTimeInMillis;
private final Duration idleTime;
private final List<ConnectorId> connectorIds;
private final Optional<ConnectorId> writtenConnectorId;
@ThriftConstructor
public TransactionInfo(
TransactionId transactionId,
IsolationLevel isolationLevel,
boolean readOnly,
boolean autoCommitContext,
long createTimeInMillis,
Duration idleTime,
List<ConnectorId> connectorIds,
Optional<ConnectorId> writtenConnectorId)
{
this.transactionId = requireNonNull(transactionId, "transactionId is null");
this.isolationLevel = requireNonNull(isolationLevel, "isolationLevel is null");
this.readOnly = readOnly;
this.autoCommitContext = autoCommitContext;
checkArgument(createTimeInMillis >= 0, "createTimeInMillis is negative");
this.createTimeInMillis = createTimeInMillis;
this.idleTime = requireNonNull(idleTime, "idleTime is null");
this.connectorIds = ImmutableList.copyOf(requireNonNull(connectorIds, "connectorIds is null"));
this.writtenConnectorId = requireNonNull(writtenConnectorId, "writtenConnectorId is null");
}
@ThriftField(1)
public TransactionId getTransactionId()
{
return transactionId;
}
@ThriftField(2)
public IsolationLevel getIsolationLevel()
{
return isolationLevel;
}
@ThriftField(3)
public boolean isReadOnly()
{
return readOnly;
}
@ThriftField(4)
public boolean isAutoCommitContext()
{
return autoCommitContext;
}
@ThriftField(5)
public long getCreateTimeInMillis()
{
return createTimeInMillis;
}
@ThriftField(6)
public Duration getIdleTime()
{
return idleTime;
}
@ThriftField(7)
public List<ConnectorId> getConnectorIds()
{
return connectorIds;
}
@ThriftField(8)
public Optional<ConnectorId> getWrittenConnectorId()
{
return writtenConnectorId;
}
}