From c2e98951e444495677c31a5fa08015858c85053b Mon Sep 17 00:00:00 2001 From: takeshitakenji <47hasbegun@gmail.com> Date: Fri, 7 Oct 2022 02:18:56 -0700 Subject: [PATCH] Added TwitterClient.stopFilteredStream() variant with a timeout. (#406) --- .../redouane59/twitter/ITwitterClientV2.java | 15 +++++++++++-- .../redouane59/twitter/TwitterClient.java | 22 +++++++++++++++---- 2 files changed, 31 insertions(+), 6 deletions(-) diff --git a/src/main/java/io/github/redouane59/twitter/ITwitterClientV2.java b/src/main/java/io/github/redouane59/twitter/ITwitterClientV2.java index d9f10818..0bf33ad3 100644 --- a/src/main/java/io/github/redouane59/twitter/ITwitterClientV2.java +++ b/src/main/java/io/github/redouane59/twitter/ITwitterClientV2.java @@ -23,6 +23,7 @@ import io.github.redouane59.twitter.dto.user.UserList; import java.util.List; import java.util.concurrent.Future; +import java.util.concurrent.TimeUnit; import java.util.function.Consumer; public interface ITwitterClientV2 { @@ -172,10 +173,20 @@ public interface ITwitterClientV2 { */ Future startFilteredStream(IAPIEventListener listener, int backfillMinutes); + /** + * Stops the filtered stream with the result of the startFilteredStream. It'll wait a maximum of timeout + * before giving up and returning false. If timeout isn't hit, it'll close the socket opened. + * + * @param responseFuture Future given by startFilteredStream + * @param timeout long How long to wait + * @param unit TimeUnit Units for timeout + */ + boolean stopFilteredStream(Future response, long timeout, TimeUnit unit); + /** * Stops the filtered stream with the result of the startFilteredStream. It'll close the socket opened. * - * @param response Future given by startFilteredStream + * @param responseFuture Future given by startFilteredStream */ boolean stopFilteredStream(Future response); @@ -641,4 +652,4 @@ public interface ITwitterClientV2 { boolean deleteTweet(String tweetId); -} \ No newline at end of file +} diff --git a/src/main/java/io/github/redouane59/twitter/TwitterClient.java b/src/main/java/io/github/redouane59/twitter/TwitterClient.java index 5f73103b..3e5ac084 100644 --- a/src/main/java/io/github/redouane59/twitter/TwitterClient.java +++ b/src/main/java/io/github/redouane59/twitter/TwitterClient.java @@ -82,6 +82,8 @@ import java.util.Optional; import java.util.concurrent.ExecutionException; import java.util.concurrent.Future; +import java.util.concurrent.TimeUnit; +import java.util.concurrent.TimeoutException; import java.util.concurrent.atomic.AtomicInteger; import java.util.function.Consumer; import java.util.stream.Collectors; @@ -1044,20 +1046,32 @@ public Future startFilteredStream(IAPIEventListener listener, int back } @Override - public boolean stopFilteredStream(Future response) { + public boolean stopFilteredStream(Future responseFuture, long timeout, TimeUnit unit) { try { - if (response.get() == null) { + Response response; + if (timeout > 0 && unit != null) { + response = responseFuture.get(timeout, unit); + } else { + response = responseFuture.get(); + } + + if (response == null) { return false; } - response.get().getStream().close(); + response.getStream().close(); return true; - } catch (IOException | InterruptedException | ExecutionException e) { + } catch (IOException | InterruptedException | ExecutionException | TimeoutException e) { LOGGER.error("Couldn't stopFilteredstream ", e); Thread.currentThread().interrupt(); } return false; } + @Override + public boolean stopFilteredStream(Future responseFuture) { + return stopFilteredStream(responseFuture, 0, null); + } + @Override public List retrieveFilteredStreamRules() { String url = urlHelper.getFilteredStreamRulesUrl();