org.neo4j.gds.compat.BoltTransactionRunner Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of neo4j-kernel-adapter-api Show documentation
Show all versions of neo4j-kernel-adapter-api Show documentation
Neo4j Graph Data Science :: Neo4j Kernel Adapter API
/*
* Copyright (c) "Neo4j"
* Neo4j Sweden AB [http://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.gds.compat;
import org.neo4j.bolt.dbapi.BoltGraphDatabaseServiceSPI;
import org.neo4j.bolt.dbapi.BoltTransaction;
import org.neo4j.bolt.protocol.common.message.AccessMode;
import org.neo4j.bolt.protocol.common.message.request.connection.RoutingContext;
import org.neo4j.bolt.tx.statement.StatementQuerySubscriber;
import org.neo4j.exceptions.KernelException;
import org.neo4j.graphdb.QueryStatistics;
import org.neo4j.internal.kernel.api.connectioninfo.ClientConnectionInfo;
import org.neo4j.internal.kernel.api.security.LoginContext;
import org.neo4j.kernel.api.KernelTransaction;
import org.neo4j.kernel.impl.query.QueryExecutionConfiguration;
import org.neo4j.values.virtual.MapValue;
import java.time.Duration;
import java.util.List;
import java.util.Map;
import java.util.function.Function;
public final class BoltTransactionRunner {
public int runQuery(
String query,
MapValue parameters,
BoltTransaction boltTransaction,
Function statExtractor
) throws KernelException {
var subscriber = new StatementQuerySubscriber();
executeQuery(boltTransaction, query, parameters, subscriber);
subscriber.assertSuccess();
boltTransaction.commit();
return statExtractor.apply(subscriber.getStatistics());
}
public BoltTransaction beginBoltWriteTransaction(
BoltGraphDatabaseServiceSPI fabricDb,
LoginContext loginContext
) {
return beginBoltWriteTransaction(
fabricDb,
loginContext,
KernelTransaction.Type.IMPLICIT,
ClientConnectionInfo.EMBEDDED_CONNECTION,
List.of(),
Duration.ZERO, Map.of()
);
}
private void executeQuery(
BoltTransaction boltTransaction,
String query,
MapValue parameters,
StatementQuerySubscriber querySubscriber
) {
try {
boltTransaction.executeQuery(query, parameters, true, querySubscriber)
.queryExecution() // This fella here is quite lazy
.consumeAll(); // We need to do this in order to trigger the query execution.
} catch (Exception e) {
throw new RuntimeException(e);
}
}
private BoltTransaction beginBoltWriteTransaction(
BoltGraphDatabaseServiceSPI fabricDb,
LoginContext loginContext,
KernelTransaction.Type kernelTransactionType,
ClientConnectionInfo clientConnectionInfo,
List bookmarks,
Duration txTimeout,
Map txMetadata
) {
return fabricDb.beginTransaction(
kernelTransactionType,
loginContext,
clientConnectionInfo,
bookmarks,
txTimeout,
AccessMode.WRITE,
txMetadata,
new RoutingContext(true, Map.of()),
QueryExecutionConfiguration.DEFAULT_CONFIG
);
}
}