From 09d433160ab75f06de44c5705433dadb3b144d83 Mon Sep 17 00:00:00 2001
From: shayaantx <5449086+shayaantx@users.noreply.github.com>
Date: Sun, 27 Feb 2022 21:19:36 -0500
Subject: [PATCH] Fix bug where lidarr cache doesn't cache artist names
properly + make timeout configurable (#60)
---
.gitignore | 2 ++
README.md | 4 ++--
docker/entrypoint.sh | 1 +
src/main/java/com/botdarr/Config.java | 19 ++++++++++++++++++-
.../com/botdarr/api/lidarr/LidarrCache.java | 5 +++--
.../botdarr/connections/ConnectionHelper.java | 2 +-
src/main/resources/version.txt | 2 +-
7 files changed, 28 insertions(+), 7 deletions(-)
diff --git a/.gitignore b/.gitignore
index b24a21e..3aebb7a 100644
--- a/.gitignore
+++ b/.gitignore
@@ -34,3 +34,5 @@ properties*
dependency-reduced-pom.xml
*.jar
*.db
+
+*.zip
diff --git a/README.md b/README.md
index c60fe38..364df83 100644
--- a/README.md
+++ b/README.md
@@ -176,8 +176,8 @@ botdarr:
| MAX_DOWNLOADS_TO_SHOW | The max number of downloads to show. If you set this to any value less than or equal to 0, no downloads will show | yes | 20 |
| MAX_RESULTS_TO_SHOW | The max number of results to show per search command. If you set this to any value less than 0, the bot won't startup | yes | 20 |
| COMMAND_PREFIX | The command prefix (default is !). Any prefix is allowed (but I haven't tested every single prefix in every client) | yes | ! |
-| STATUS_ENDPOINTS | Endpoints that can be used to return statuses via !status command. The endpoints are separated by a comma and each endpoint is in the following format - name:hostname:port | no | |
-
+| STATUS_ENDPOINTS | Endpoints that can be used to return statuses via !status command. The endpoints are separated by a comma and each endpoint is in the following format - name:hostname:port | no | |
+| TIMEOUT | The connection/read timeout value (in milliseconds) for all outbound requests | no | 5000 |
## Usage
diff --git a/docker/entrypoint.sh b/docker/entrypoint.sh
index f5ff9e0..6b0998b 100644
--- a/docker/entrypoint.sh
+++ b/docker/entrypoint.sh
@@ -58,6 +58,7 @@ if [ ! -e "$propertiesFile" ]; then
addConfiguration "max-downloads-to-show" "${MAX_DOWNLOADS_TO_SHOW:-20}" "${propertiesFile}"
addConfiguration "max-results-to-show" "${MAX_RESULTS_TO_SHOW:-20}" "${propertiesFile}"
addConfiguration "command-prefix" "${COMMAND_PREFIX:-!}" "${propertiesFile}"
+ addConfiguration "timeout" "${TIMEOUT:-5000}" "${propertiesFile}"
fi
exec "$@"
\ No newline at end of file
diff --git a/src/main/java/com/botdarr/Config.java b/src/main/java/com/botdarr/Config.java
index 9072e67..8072650 100644
--- a/src/main/java/com/botdarr/Config.java
+++ b/src/main/java/com/botdarr/Config.java
@@ -159,6 +159,18 @@ public static List getStatusEndpoints() {
return statusEndPoints;
}
+ /**
+ * @return The connection/read timeouts for all outbound requests (in ms)
+ */
+ public static int getTimeout() {
+ try {
+ return Integer.parseInt(Config.getProperty(Config.Constants.TIMEOUT));
+ } catch (NumberFormatException e) {
+ LOGGER.error("Error parsing timeout", e);
+ }
+ return 5000;
+ }
+
private static StatusEndPoint getDomain(String constant, String name) {
try {
URI uri = new URI(getProperty(constant));
@@ -343,7 +355,7 @@ public static final class Constants {
public static final String MAX_SHOW_REQUESTS_PER_USER = "max-show-requests-per-user";
/**
- * TODO: doc
+ * The max of artist requests per user per configured threshold
*/
public static final String MAX_ARTIST_REQUESTS_PER_USER = "max-artist-requests-per-user";
@@ -376,6 +388,11 @@ public static final class Constants {
* The additional status endpoints to check
*/
public static final String STATUS_ENDPOINTS = "status-endpoints";
+
+ /**
+ * Connection/read timeouts for all outbound requests
+ */
+ public static final String TIMEOUT = "timeout";
}
private static String propertiesPath = "config/properties";
diff --git a/src/main/java/com/botdarr/api/lidarr/LidarrCache.java b/src/main/java/com/botdarr/api/lidarr/LidarrCache.java
index 24fe7d0..c8f54c8 100644
--- a/src/main/java/com/botdarr/api/lidarr/LidarrCache.java
+++ b/src/main/java/com/botdarr/api/lidarr/LidarrCache.java
@@ -1,6 +1,7 @@
package com.botdarr.api.lidarr;
import java.util.List;
+import java.util.Locale;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
@@ -12,7 +13,7 @@ public boolean doesArtistExist(LidarrArtist content) {
public void addArtist(LidarrArtist artist) {
existingForeignArtistIdToArtist.put(artist.getForeignArtistId(), artist);
- existingArtistNamesToIds.put(artist.getArtistName(), artist.getForeignArtistId());
+ existingArtistNamesToIds.put(artist.getArtistName().toLowerCase(), artist.getForeignArtistId());
}
public void addQualityProfile(LidarrQualityProfile lidarrQualityProfile) {
@@ -44,7 +45,7 @@ public void removeDeletedMetadataProfiles(List addUpdatedProfiles) {
}
public void removeDeletedArtists(List addUpdatedArtists) {
- existingArtistNamesToIds.keySet().retainAll(addUpdatedArtists);
+ existingArtistNamesToIds.values().retainAll(addUpdatedArtists);
existingForeignArtistIdToArtist.keySet().retainAll(addUpdatedArtists);
}
diff --git a/src/main/java/com/botdarr/connections/ConnectionHelper.java b/src/main/java/com/botdarr/connections/ConnectionHelper.java
index d557d92..9f999a2 100644
--- a/src/main/java/com/botdarr/connections/ConnectionHelper.java
+++ b/src/main/java/com/botdarr/connections/ConnectionHelper.java
@@ -42,7 +42,7 @@ public boolean turnOnTimeouts() {
public static T makeRequest(RequestHandler requestHandler, ResponseHandler responseHandler) {
RequestConfig.Builder requestConfigBuilder = RequestConfig.custom();
if (requestHandler.turnOnTimeouts()) {
- int timeout = 5000;
+ int timeout = Config.getTimeout();
requestConfigBuilder.setConnectTimeout(timeout);
requestConfigBuilder.setSocketTimeout(timeout);
requestConfigBuilder.setConnectionRequestTimeout(timeout);
diff --git a/src/main/resources/version.txt b/src/main/resources/version.txt
index fb467b1..fff6bf3 100644
--- a/src/main/resources/version.txt
+++ b/src/main/resources/version.txt
@@ -1 +1 @@
-5.2.2
\ No newline at end of file
+5.2.3
\ No newline at end of file