All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.neo4j.kernel.impl.transaction.log.TransactionCommitment Maven / Gradle / Ivy

Go to download

Neo4j kernel is a lightweight, embedded Java database designed to store data structured as graphs rather than tables. For more information, see http://neo4j.org.

There is a newer version: 5.25.1
Show newest version
/*
 * Copyright (c) "Neo4j"
 * Neo4j Sweden AB [https://neo4j.com]
 *
 * This file is part of Neo4j.
 *
 * Neo4j is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see .
 */
package org.neo4j.kernel.impl.transaction.log;

import org.neo4j.kernel.KernelVersion;
import org.neo4j.storageengine.api.Commitment;
import org.neo4j.storageengine.api.TransactionIdStore;

public class TransactionCommitment implements Commitment {

    private final TransactionIdStore transactionIdStore;
    private boolean committed;
    private long transactionId;
    private long appendIndex;
    private int checksum;
    private long consensusIndex;
    private KernelVersion kernelVersion;
    private LogPosition logPositionAfterCommit;
    private long transactionCommitTimestamp;

    TransactionCommitment(TransactionIdStore transactionIdStore) {
        this.transactionIdStore = transactionIdStore;
    }

    @Override
    public void commit(
            long transactionId,
            long appendIndex,
            KernelVersion kernelVersion,
            LogPosition logPositionAfterCommit,
            int checksum,
            long consensusIndex) {
        this.transactionId = transactionId;
        this.kernelVersion = kernelVersion;
        this.logPositionAfterCommit = logPositionAfterCommit;
        this.checksum = checksum;
        this.consensusIndex = consensusIndex;
        transactionIdStore.appendBatch(appendIndex, logPositionAfterCommit);
    }

    @Override
    public void publishAsCommitted(long transactionCommitTimestamp, long appendIndex) {
        this.committed = true;
        this.appendIndex = appendIndex;
        this.transactionCommitTimestamp = transactionCommitTimestamp;
        transactionIdStore.transactionCommitted(
                transactionId, appendIndex, kernelVersion, checksum, transactionCommitTimestamp, consensusIndex);
    }

    @Override
    public void publishAsClosed() {
        if (committed) {
            transactionIdStore.transactionClosed(
                    transactionId,
                    appendIndex,
                    kernelVersion,
                    logPositionAfterCommit.getLogVersion(),
                    logPositionAfterCommit.getByteOffset(),
                    checksum,
                    transactionCommitTimestamp,
                    consensusIndex);
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy