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

io.castle.client.internal.backend.RestApi Maven / Gradle / Ivy

Go to download

Castle adds real-time monitoring of your authentication stack, instantly notifying you and your users on potential account hijacks.

There is a newer version: 2.4.3
Show newest version
package io.castle.client.internal.backend;

import com.google.gson.JsonElement;
import com.google.gson.JsonObject;
import io.castle.client.model.AsyncCallbackHandler;
import io.castle.client.model.Review;
import io.castle.client.model.Verdict;

public interface RestApi {

    /**
     * Send a async track request and provide a callback that inform if the request success or fail.
     *
     * @param event                event name
     * @param userId               unique userId
     * @param contextPayload       context json
     * @param propertiesPayload    properties json
     * @param asyncCallbackHandler callback to inform if request is correctly send
     */
    void sendTrackRequest(String event, String userId, JsonElement contextPayload, JsonElement propertiesPayload, AsyncCallbackHandler asyncCallbackHandler);

    /**
     * Sync call to the authenticate endpoint.
     * 

* This method will block the current thread until the response is obtained. * * @param event event name * @param userId unique userId * @param contextPayload context json * @param propertiesPayload properties json * @param traitsPayload traits json * @return AuthenticateAction enum value to be used on login logic */ Verdict sendAuthenticateSync(String event, String userId, JsonElement contextPayload, JsonElement propertiesPayload, JsonElement traitsPayload); /** * Async version of the authentication endpoint. *

* This method will return immediately and the response will be passed to the asyncCallbackHandler in the future. * * @param event event name * @param userId unique userId * @param contextPayload context json * @param propertiesPayload properties json * @param traitsPayload traits json * @param asyncCallbackHandler callback to pass the AuthenticateAction enum value to be used on login logic */ void sendAuthenticateAsync(String event, String userId, JsonElement contextPayload, JsonElement propertiesPayload, JsonElement traitsPayload, AsyncCallbackHandler asyncCallbackHandler); /** * Async call to the identify endpoint, returning immediately. * * @param userId unique userId * @param contextJson context json * @param active is this call realized as part of a active session of the user * @param traitsJson additional trait json */ void sendIdentifyRequest(String userId, JsonObject contextJson, boolean active, JsonElement traitsJson); /** * Sync call to the review endpoint. * * @param reviewId string representing the id to be reviewed * @return a {@code review} with metadata contained in the body of the response */ Review sendReviewRequestSync(String reviewId); /** * Async call to the review endpoint, returning immediately. * * @param reviewId string representing the id to be reviewed * @param callbackHandler callback to handle the Review value returned by the API */ void sendReviewRequestAsync(String reviewId, AsyncCallbackHandler callbackHandler); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy