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

org.neo4j.driver.internal.reactivestreams.InternalReactiveSession 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.internal.reactivestreams;

import java.util.HashSet;
import java.util.Set;
import java.util.concurrent.CompletionStage;
import org.neo4j.driver.AccessMode;
import org.neo4j.driver.Bookmark;
import org.neo4j.driver.Query;
import org.neo4j.driver.TransactionConfig;
import org.neo4j.driver.internal.async.NetworkSession;
import org.neo4j.driver.internal.async.UnmanagedTransaction;
import org.neo4j.driver.internal.cursor.RxResultCursor;
import org.neo4j.driver.internal.reactive.AbstractReactiveSession;
import org.neo4j.driver.internal.util.Futures;
import org.neo4j.driver.reactivestreams.ReactiveResult;
import org.neo4j.driver.reactivestreams.ReactiveSession;
import org.neo4j.driver.reactivestreams.ReactiveTransaction;
import org.neo4j.driver.reactivestreams.ReactiveTransactionCallback;
import org.reactivestreams.Publisher;
import reactor.core.publisher.Mono;

public class InternalReactiveSession extends AbstractReactiveSession
        implements ReactiveSession, BaseReactiveQueryRunner {
    public InternalReactiveSession(NetworkSession session) {
        super(session);
    }

    @Override
    public ReactiveTransaction createTransaction(UnmanagedTransaction unmanagedTransaction) {
        return new InternalReactiveTransaction(unmanagedTransaction);
    }

    @Override
    public Publisher closeTransaction(ReactiveTransaction transaction, boolean commit) {
        return ((InternalReactiveTransaction) transaction).close(commit);
    }

    @Override
    public Publisher beginTransaction(TransactionConfig config) {
        return beginTransaction(config, null);
    }

    public Publisher beginTransaction(TransactionConfig config, String txType) {
        return doBeginTransaction(config, txType);
    }

    @Override
    public  Publisher executeRead(
            ReactiveTransactionCallback> callback, TransactionConfig config) {
        return runTransaction(
                AccessMode.READ, tx -> callback.execute(new DelegatingReactiveTransactionContext(tx)), config);
    }

    @Override
    public  Publisher executeWrite(
            ReactiveTransactionCallback> callback, TransactionConfig config) {
        return runTransaction(
                AccessMode.WRITE, tx -> callback.execute(new DelegatingReactiveTransactionContext(tx)), config);
    }

    @Override
    public Publisher run(Query query) {
        return run(query, TransactionConfig.empty());
    }

    @Override
    public Publisher run(Query query, TransactionConfig config) {
        CompletionStage cursorStage;
        try {
            cursorStage = session.runRx(query, config);
        } catch (Throwable t) {
            cursorStage = Futures.failedFuture(t);
        }

        return Mono.fromCompletionStage(cursorStage)
                .onErrorResume(error -> Mono.fromCompletionStage(session.releaseConnectionAsync())
                        .onErrorMap(releaseError -> Futures.combineErrors(error, releaseError))
                        .then(Mono.error(error)))
                .flatMap(cursor -> {
                    Mono publisher;
                    Throwable runError = cursor.getRunError();
                    if (runError != null) {
                        publisher = Mono.fromCompletionStage(session.releaseConnectionAsync())
                                .onErrorMap(releaseError -> Futures.combineErrors(runError, releaseError))
                                .then(Mono.error(runError));
                    } else {
                        publisher = Mono.just(cursor);
                    }
                    return publisher;
                })
                .map(InternalReactiveResult::new);
    }

    @Override
    public Set lastBookmarks() {
        return new HashSet<>(session.lastBookmarks());
    }

    @Override
    public  Publisher close() {
        return doClose();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy