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

io.neow3j.protocol.Neow3jService Maven / Gradle / Ivy

package io.neow3j.protocol;

import io.neow3j.protocol.core.Request;
import io.neow3j.protocol.core.Response;
import io.neow3j.protocol.notifications.Notification;
import io.reactivex.Observable;

import java.io.IOException;
import java.util.concurrent.CompletableFuture;

/**
 * Services API.
 */
public interface Neow3jService {

    /**
     * Performs a synchronous JSON-RPC request.
     *
     * @param request      request to perform
     * @param responseType class of a data item returned by the request
     * @param           type of a data item returned by the request
     * @return deserialized JSON-RPC response
     * @throws IOException thrown if failed to perform a request
     */
     T send(
            Request request, Class responseType) throws IOException;

    /**
     * Performs an asynchronous JSON-RPC request.
     *
     * @param request      request to perform
     * @param responseType class of a data item returned by the request
     * @param           type of a data item returned by the request
     * @return CompletableFuture that will be completed when a result is returned or if a
     * request has failed
     */
     CompletableFuture sendAsync(
            Request request, Class responseType);

    /**
     * 

Subscribe to a stream of notifications. A stream of notifications is opened by * by performing a specified JSON-RPC request and is closed by calling * the unsubscribe method. Different WebSocket implementations use different pair of * subscribe/unsubscribe methods.

*
*

This method creates an Observable that can be used to subscribe to new notifications. * When a client unsubscribes from this Observable the service unsubscribes from * the underlying stream of events.

* * @param request JSON-RPC request that will be send to subscribe to a stream of * events * @param unsubscribeMethod method that will be called to unsubscribe from a * stream of notifications * @param responseType class of incoming events objects in a stream * @param type of incoming event objects * @return Observable that emits incoming events */ > Observable subscribe( Request request, String unsubscribeMethod, Class responseType); /** * Closes resources used by the service. * * @throws IOException thrown if a service failed to close all resources */ void close() throws IOException; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy