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

org.neo4j.driver.reactive.RxSession Maven / Gradle / Ivy

/*
 * Copyright (c) "Neo4j"
 * Neo4j Sweden AB [http://neo4j.com]
 *
 * This file is part of Neo4j.
 *
 * 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.neo4j.driver.reactive;

import org.neo4j.driver.Query;
import org.reactivestreams.Publisher;

import java.util.Map;
import java.util.concurrent.CompletableFuture;

import org.neo4j.driver.AccessMode;
import org.neo4j.driver.Session;
import org.neo4j.driver.TransactionConfig;
import org.neo4j.driver.Values;
import org.neo4j.driver.Bookmark;

/**
 * A reactive session is the same as {@link Session} except it provides a reactive API.
 * @see Session
 * @see RxResult
 * @see RxTransaction
 * @see Publisher
 * @since 4.0
 */
public interface RxSession extends RxQueryRunner
{
    /**
     * Begin a new unmanaged {@linkplain RxTransaction transaction}. At
     * most one transaction may exist in a session at any point in time. To
     * maintain multiple concurrent transactions, use multiple concurrent
     * sessions.
     * 

* It by default is executed in a Network IO thread, as a result no blocking operation is allowed in this thread. * * @return a new {@link RxTransaction} */ Publisher beginTransaction(); /** * Begin a new unmanaged {@linkplain RxTransaction transaction} with the specified {@link TransactionConfig configuration}. * At most one transaction may exist in a session at any point in time. To * maintain multiple concurrent transactions, use multiple concurrent sessions. *

* It by default is executed in a Network IO thread, as a result no blocking operation is allowed in this thread. * * @param config configuration for the new transaction. * @return a new {@link RxTransaction} */ Publisher beginTransaction( TransactionConfig config ); /** * Execute given unit of reactive work in a {@link AccessMode#READ read} reactive transaction.

* Transaction will automatically be committed unless given unit of work fails or * {@link RxTransaction#commit() transaction commit} fails. * It will also not be committed if explicitly rolled back via {@link RxTransaction#rollback()}. *

* Returned publisher and given {@link RxTransactionWork} is completed/executed by an IO thread which should never block. * Otherwise IO operations on this and potentially other network connections might deadlock. * Please do not chain blocking operations like {@link CompletableFuture#get()} on the returned publisher and do not use them inside the * {@link RxTransactionWork}. * * @param work the {@link RxTransactionWork} to be applied to a new read transaction. * Operation executed by the given work must NOT include any blocking operation. * @param the return type of the given unit of work. * @return a {@link Publisher publisher} completed with the same result as returned by the given unit of work. * publisher can be completed exceptionally if given work or commit fails. * */ Publisher readTransaction( RxTransactionWork> work ); /** * Execute given unit of reactive work in a {@link AccessMode#READ read} reactive transaction with * the specified {@link TransactionConfig configuration}.

* Transaction will automatically be committed unless given unit of work fails or * {@link RxTransaction#commit() transaction commit} fails. * It will also not be committed if explicitly rolled back via {@link RxTransaction#rollback()}. *

* Returned publisher and given {@link RxTransactionWork} is completed/executed by an IO thread which should never block. * Otherwise IO operations on this and potentially other network connections might deadlock. * Please do not chain blocking operations like {@link CompletableFuture#get()} on the returned publisher and do not use them inside the * {@link RxTransactionWork}. * * @param work the {@link RxTransactionWork} to be applied to a new read transaction. * Operation executed by the given work must NOT include any blocking operation. * @param config the transaction configuration. * @param the return type of the given unit of work. * @return a {@link Publisher publisher} completed with the same result as returned by the given unit of work. * publisher can be completed exceptionally if given work or commit fails. * */ Publisher readTransaction( RxTransactionWork> work, TransactionConfig config ); /** * Execute given unit of reactive work in a {@link AccessMode#WRITE write} reactive transaction.

* Transaction will automatically be committed unless given unit of work fails or * {@link RxTransaction#commit() transaction commit} fails. * It will also not be committed if explicitly rolled back via {@link RxTransaction#rollback()}. *

* Returned publisher and given {@link RxTransactionWork} is completed/executed by an IO thread which should never block. * Otherwise IO operations on this and potentially other network connections might deadlock. * Please do not chain blocking operations like {@link CompletableFuture#get()} on the returned publisher and do not use them inside the * {@link RxTransactionWork}. * * @param work the {@link RxTransactionWork} to be applied to a new read transaction. * Operation executed by the given work must NOT include any blocking operation. * @param the return type of the given unit of work. * @return a {@link Publisher publisher} completed with the same result as returned by the given unit of work. * publisher can be completed exceptionally if given work or commit fails. * */ Publisher writeTransaction( RxTransactionWork> work ); /** * Execute given unit of reactive work in a {@link AccessMode#WRITE write} reactive transaction with * the specified {@link TransactionConfig configuration}.

* Transaction will automatically be committed unless given unit of work fails or * {@link RxTransaction#commit() transaction commit} fails. * It will also not be committed if explicitly rolled back via {@link RxTransaction#rollback()}. *

* Returned publisher and given {@link RxTransactionWork} is completed/executed by an IO thread which should never block. * Otherwise IO operations on this and potentially other network connections might deadlock. * Please do not chain blocking operations like {@link CompletableFuture#get()} on the returned publisher and do not use them inside the * {@link RxTransactionWork}. * * @param work the {@link RxTransactionWork} to be applied to a new read transaction. * Operation executed by the given work must NOT include any blocking operation. * @param config the transaction configuration. * @param the return type of the given unit of work. * @return a {@link Publisher publisher} completed with the same result as returned by the given unit of work. * publisher can be completed exceptionally if given work or commit fails. * */ Publisher writeTransaction( RxTransactionWork> work, TransactionConfig config ); /** * Run a query with parameters in an auto-commit transaction with specified {@link TransactionConfig} and return a reactive result stream. * The query is not executed when the reactive result is returned. * Instead, the publishers in the result will actually start the execution of the query. * * @param query text of a Neo4j query. * @param config configuration for the new transaction. * @return a reactive result. */ RxResult run(String query, TransactionConfig config ); /** * Run a query with parameters in an auto-commit transaction with specified {@link TransactionConfig} and return a reactive result stream. * The query is not executed when the reactive result is returned. * Instead, the publishers in the result will actually start the execution of the query. *

* This method takes a set of parameters that will be injected into the query by Neo4j. * Using parameters is highly encouraged, it helps avoid dangerous cypher injection attacks * and improves database performance as Neo4j can re-use query plans more often. *

* This version of run takes a {@link Map} of parameters. * The values in the map must be values that can be converted to Neo4j types. * See {@link Values#parameters(Object...)} for a list of allowed types. * *

Example

*
     * {@code
     * Map metadata = new HashMap<>();
     * metadata.put("type", "update name");
     *
     * TransactionConfig config = TransactionConfig.builder()
     *                 .withTimeout(Duration.ofSeconds(3))
     *                 .withMetadata(metadata)
     *                 .build();
     *
     * Map parameters = new HashMap<>();
     * parameters.put("myNameParam", "Bob");
     *
     * RxResult result = rxSession.run("MATCH (n) WHERE n.name = $myNameParam RETURN (n)", parameters, config);
     * }
     * 
* * @param query text of a Neo4j query. * @param parameters input data for the query. * @param config configuration for the new transaction. * @return a reactive result. */ RxResult run(String query, Map parameters, TransactionConfig config ); /** * Run a query in an auto-commit transaction with specified {@link TransactionConfig configuration} and return a reactive result stream. * The query is not executed when the reactive result is returned. * Instead, the publishers in the result will actually start the execution of the query. *

Example

*
     * {@code
     * Map metadata = new HashMap<>();
     * metadata.put("type", "update name");
     *
     * TransactionConfig config = TransactionConfig.builder()
     *                 .withTimeout(Duration.ofSeconds(3))
     *                 .withMetadata(metadata)
     *                 .build();
     *
     * Query query = new Query("MATCH (n) WHERE n.name = $myNameParam RETURN n.age");
     * RxResult result = rxSession.run(query.withParameters(Values.parameters("myNameParam", "Bob")));
     * }
     * 
* * @param query a Neo4j query. * @param config configuration for the new transaction. * @return a reactive result. */ RxResult run(Query query, TransactionConfig config ); /** * Return the bookmark received following the last completed query within this session. * The last completed query can be run in a {@linkplain RxTransaction transaction} * started using {@linkplain #beginTransaction() beginTransaction} or directly via {@link #run(Query) run}. * * @return a reference to a previous transaction. */ Bookmark lastBookmark(); /** * Signal that you are done using this session. * In the default driver usage, closing and accessing sessions is very low cost. *

* This operation is not needed if 1) all results created in the session have been fully consumed and * 2) all transactions opened by this session have been either committed or rolled back. *

* This method is a fallback if you failed to fulfill the two requirements above. * This publisher is completed when all outstanding queries in the session have completed, * meaning any writes you performed are guaranteed to be durably stored. * It might be completed exceptionally when there are unconsumed errors from previous queries or transactions. * * @param makes it easier to be chained. * @return an empty publisher that represents the reactive close. */ Publisher close(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy