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

io.getstream.core.StreamReactions Maven / Gradle / Ivy

package io.getstream.core;

import static com.google.common.base.MoreObjects.firstNonNull;
import static com.google.common.base.Preconditions.checkArgument;
import static com.google.common.base.Preconditions.checkNotNull;
import static io.getstream.core.utils.Request.*;
import static io.getstream.core.utils.Routes.buildReactionsURL;
import static io.getstream.core.utils.Serialization.*;

import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.core.type.TypeReference;
import com.google.common.collect.ImmutableMap;
import io.getstream.core.exceptions.StreamException;
import io.getstream.core.http.HTTPClient;
import io.getstream.core.http.Request;
import io.getstream.core.http.Token;
import io.getstream.core.models.FeedID;
import io.getstream.core.models.Paginated;
import io.getstream.core.models.Reaction;
import io.getstream.core.options.CustomQueryParameter;
import io.getstream.core.options.Filter;
import io.getstream.core.options.Limit;
import io.getstream.core.options.RequestOption;
import java.io.IOException;
import java.net.MalformedURLException;
import java.net.URISyntaxException;
import java.net.URL;
import java.util.List;
import java.util.Map;
import java8.util.J8Arrays;
import java8.util.concurrent.CompletableFuture;
import java8.util.concurrent.CompletionException;

public final class StreamReactions {
  private final String key;
  private final URL baseURL;
  private final HTTPClient httpClient;

  StreamReactions(String key, URL baseURL, HTTPClient httpClient) {
    this.key = key;
    this.baseURL = baseURL;
    this.httpClient = httpClient;
  }

  public CompletableFuture get(Token token, String id) throws StreamException {
    checkNotNull(id, "Reaction id can't be null");
    checkArgument(!id.isEmpty(), "Reaction id can't be empty");

    try {
      final URL url = buildReactionsURL(baseURL, id + '/');
      return httpClient
          .execute(buildGet(url, key, token))
          .thenApply(
              response -> {
                try {
                  return deserialize(response, Reaction.class);
                } catch (StreamException | IOException e) {
                  throw new CompletionException(e);
                }
              });
    } catch (MalformedURLException | URISyntaxException e) {
      throw new StreamException(e);
    }
  }

  public CompletableFuture getPaginated(Token token, String id) throws StreamException {
    checkNotNull(id, "Reaction id can't be null");
    checkArgument(!id.isEmpty(), "Reaction id can't be empty");

    try {
      final URL url = buildReactionsURL(baseURL, id + '/');
      return httpClient
          .execute(buildGet(url, key, token))
          .thenApply(
              response -> {
                try {
                  return deserialize(response, Paginated.class);
                } catch (StreamException | IOException e) {
                  throw new CompletionException(e);
                }
              });
    } catch (MalformedURLException | URISyntaxException e) {
      throw new StreamException(e);
    }
  }

  public CompletableFuture> filter(
      Token token, LookupKind lookup, String id, Filter filter, Limit limit, String kind)
      throws StreamException {
    return filter(token, lookup, id, filter, limit, kind, null);
  }

  public CompletableFuture> filter(
      Token token,
      LookupKind lookup,
      String id,
      Filter filter,
      Limit limit,
      String kind,
      Boolean withOwnChildren)
      throws StreamException {
    checkNotNull(lookup, "Lookup kind can't be null");
    checkNotNull(id, "Reaction ID can't be null");
    checkArgument(!id.isEmpty(), "Reaction ID can't be empty");
    checkNotNull(filter, "Filter can't be null");
    checkNotNull(kind, "Kind can't be null");

    try {
      final URL url = buildReactionsURL(baseURL, lookup.getKind() + '/' + id + '/' + kind);
      RequestOption withActivityData =
          new CustomQueryParameter(
              "with_activity_data", Boolean.toString(lookup == LookupKind.ACTIVITY_WITH_DATA));
      RequestOption ownChildren =
          new CustomQueryParameter(
              "withOwnChildren", Boolean.toString(withOwnChildren != null && withOwnChildren));
      return httpClient
          .execute(buildGet(url, key, token, filter, limit, withActivityData, ownChildren))
          .thenApply(
              response -> {
                try {
                  return deserializeContainer(response, Reaction.class);
                } catch (StreamException | IOException e) {
                  throw new CompletionException(e);
                }
              });
    } catch (MalformedURLException | URISyntaxException e) {
      throw new StreamException(e);
    }
  }

  public CompletableFuture> paginatedFilter(
      Token token, LookupKind lookup, String id, Filter filter, Limit limit, String kind)
      throws StreamException {
    return paginatedFilter(token, lookup, id, filter, limit, kind, null);
  }

  public CompletableFuture> paginatedFilter(
      Token token,
      LookupKind lookup,
      String id,
      Filter filter,
      Limit limit,
      String kind,
      Boolean withOwnChildren)
      throws StreamException {
    checkNotNull(lookup, "Lookup kind can't be null");
    checkNotNull(id, "Reaction ID can't be null");
    checkArgument(!id.isEmpty(), "Reaction ID can't be empty");
    checkNotNull(filter, "Filter can't be null");
    checkNotNull(kind, "Kind can't be null");

    try {
      final URL url = buildReactionsURL(baseURL, lookup.getKind() + '/' + id + '/' + kind);
      RequestOption withActivityData =
          new CustomQueryParameter(
              "with_activity_data", Boolean.toString(lookup == LookupKind.ACTIVITY_WITH_DATA));
      RequestOption ownChildren =
          new CustomQueryParameter(
              "withOwnChildren", Boolean.toString(withOwnChildren != null && withOwnChildren));

      return httpClient
          .execute(buildGet(url, key, token, filter, limit, withActivityData, ownChildren))
          .thenApply(
              response -> {
                try {
                  return deserialize(response, new TypeReference>() {});
                } catch (StreamException | IOException e) {
                  throw new CompletionException(e);
                }
              });
    } catch (MalformedURLException | URISyntaxException e) {
      throw new StreamException(e);
    }
  }

  public CompletableFuture> paginatedFilter(Token token, String next)
      throws StreamException {
    checkNotNull(next, "next can't be null");
    checkArgument(!next.trim().isEmpty(), "next can't be empty");

    try {
      final URL url = new URL(baseURL, next);
      return httpClient
          .execute(buildGet(url, key, token))
          .thenApply(
              response -> {
                try {
                  return deserialize(response, new TypeReference>() {});
                } catch (StreamException | IOException e) {
                  throw new CompletionException(e);
                }
              });
    } catch (MalformedURLException | URISyntaxException e) {
      throw new StreamException(e);
    }
  }

  public CompletableFuture add(
      Token token, String userID, Reaction reaction, FeedID... targetFeeds) throws StreamException {
    checkNotNull(reaction, "Reaction can't be null");
    checkArgument(
        reaction.getActivityID() != null || reaction.getParent() != null,
        "Reaction has to either have and activity ID or parent");
    checkArgument(
        reaction.getActivityID() == null || reaction.getParent() == null,
        "Reaction can't have both activity ID and parent");
    if (reaction.getActivityID() != null) {
      checkArgument(!reaction.getActivityID().isEmpty(), "Reaction activity ID can't be empty");
    }
    if (reaction.getParent() != null) {
      checkArgument(!reaction.getParent().isEmpty(), "Reaction parent can't be empty");
    }
    checkNotNull(reaction.getKind(), "Reaction kind can't be null");
    checkArgument(!reaction.getKind().isEmpty(), "Reaction kind can't be empty");

    String[] targetFeedIDs =
        J8Arrays.stream(targetFeeds).map(feed -> feed.toString()).toArray(String[]::new);

    try {
      ImmutableMap.Builder payloadBuilder = ImmutableMap.builder();
      payloadBuilder.put("kind", reaction.getKind());
      payloadBuilder.put("target_feeds", targetFeedIDs);
      if (reaction.getActivityID() != null) {
        payloadBuilder.put("activity_id", reaction.getActivityID());
      }
      if (userID != null || reaction.getUserID() != null) {
        payloadBuilder.put("user_id", firstNonNull(userID, reaction.getUserID()));
      }
      if (reaction.getParent() != null) {
        payloadBuilder.put("parent", reaction.getParent());
      }
      if (reaction.getId() != null) {
        payloadBuilder.put("id", reaction.getId());
      }
      if (reaction.getExtra() != null) {
        payloadBuilder.put("data", reaction.getExtra());
      }
      if (reaction.getModerationTemplate() != null) {
        payloadBuilder.put("moderation_template", reaction.getModerationTemplate());
      }
      final byte[] payload = toJSON(payloadBuilder.build());
      final URL url = buildReactionsURL(baseURL);
      return httpClient
          .execute(buildPost(url, key, token, payload))
          .thenApply(
              response -> {
                try {
                  return deserialize(response, Reaction.class);
                } catch (StreamException | IOException e) {
                  throw new CompletionException(e);
                }
              });
    } catch (JsonProcessingException | MalformedURLException | URISyntaxException e) {
      throw new StreamException(e);
    }
  }

  public CompletableFuture update(Token token, Reaction reaction, FeedID... targetFeeds)
      throws StreamException {
    checkNotNull(reaction, "Reaction can't be null");
    checkNotNull(reaction.getId(), "Reaction id can't be null");
    checkArgument(!reaction.getId().isEmpty(), "Reaction id can't be empty");

    String[] targetFeedIDs =
        J8Arrays.stream(targetFeeds).map(feed -> feed.toString()).toArray(String[]::new);

    try {
      final byte[] payload =
          toJSON(
              new Object() {
                public final Map data = reaction.getExtra();
                public final String[] target_feeds = targetFeedIDs;
              });
      final URL url = buildReactionsURL(baseURL, reaction.getId() + '/');
      return httpClient
          .execute(buildPut(url, key, token, payload))
          .thenApply(
              response -> {
                try {
                  return deserializeError(response);
                } catch (StreamException | IOException e) {
                  throw new CompletionException(e);
                }
              });
    } catch (JsonProcessingException | MalformedURLException | URISyntaxException e) {
      throw new StreamException(e);
    }
  }

  public CompletableFuture delete(Token token, String id, Boolean soft)
      throws StreamException {
    checkNotNull(id, "Reaction id can't be null");
    checkArgument(!id.isEmpty(), "Reaction id can't be empty");

    try {
      final URL url = buildReactionsURL(baseURL, id + '/');

      final Request deleteRequest =
          soft
              ? buildDelete(url, key, token, new CustomQueryParameter("soft", "true"))
              : buildDelete(url, key, token);

      return httpClient
          .execute(deleteRequest)
          .thenApply(
              response -> {
                try {
                  return deserializeError(response);
                } catch (StreamException | IOException e) {
                  throw new CompletionException(e);
                }
              });
    } catch (MalformedURLException | URISyntaxException e) {
      throw new StreamException(e);
    }
  }

  public CompletableFuture restore(Token token, String id) throws StreamException {
    checkNotNull(id, "Reaction id can't be null");
    checkArgument(!id.isEmpty(), "Reaction id can't be empty");

    try {
      final URL url = buildReactionsURL(baseURL, id + "/restore/");
      byte[] payload = new byte[0];
      return httpClient
          .execute(buildPut(url, key, token, payload))
          .thenApply(
              response -> {
                try {
                  return deserializeError(response);
                } catch (StreamException | IOException e) {
                  throw new CompletionException(e);
                }
              });
    } catch (MalformedURLException | URISyntaxException e) {
      throw new StreamException(e);
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy