mirror of
https://github.com/mitb-archive/filebot
synced 2025-01-11 13:58:16 -05:00
Expire auth token after 1 hour
This commit is contained in:
parent
7a823835fb
commit
23f2d4e609
@ -15,6 +15,7 @@ import java.net.URI;
|
|||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.nio.ByteBuffer;
|
import java.nio.ByteBuffer;
|
||||||
import java.time.Duration;
|
import java.time.Duration;
|
||||||
|
import java.time.Instant;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.LinkedHashMap;
|
import java.util.LinkedHashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@ -79,18 +80,23 @@ public class TheTVDBClient2 extends AbstractEpisodeListProvider implements Artwo
|
|||||||
}
|
}
|
||||||
|
|
||||||
private String token = null;
|
private String token = null;
|
||||||
|
private Instant tokenExpireInstant = null;
|
||||||
|
private Duration tokenExpireDuration = Duration.ofHours(1);
|
||||||
|
|
||||||
private synchronized String getAuthorizationToken() {
|
private String getAuthorizationToken() {
|
||||||
// curl -v -X GET --header 'Accept: application/json' --header 'Authorization: Bearer TOKEN' 'https://api.thetvdb.com/languages'
|
synchronized (tokenExpireDuration) {
|
||||||
if (token == null) {
|
System.out.println("EXPIRE: " + tokenExpireInstant);
|
||||||
try {
|
if (token == null || (tokenExpireInstant != null && Instant.now().isAfter(tokenExpireInstant))) {
|
||||||
Object json = requestJson("login", singletonMap("apikey", apikey));
|
try {
|
||||||
token = getString(json, "token");
|
Object json = requestJson("login", singletonMap("apikey", apikey));
|
||||||
} catch (Exception e) {
|
token = getString(json, "token");
|
||||||
throw new IllegalStateException("Failed to retrieve authorization token: " + e.getMessage(), e);
|
tokenExpireInstant = Instant.now().plus(tokenExpireDuration);
|
||||||
|
} catch (Exception e) {
|
||||||
|
throw new IllegalStateException("Failed to retrieve authorization token: " + e.getMessage(), e);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
return token;
|
||||||
}
|
}
|
||||||
return token;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected String[] languages() throws Exception {
|
protected String[] languages() throws Exception {
|
||||||
|
@ -10,7 +10,7 @@ import org.junit.Test;
|
|||||||
|
|
||||||
public class TheTVDBClient2Test {
|
public class TheTVDBClient2Test {
|
||||||
|
|
||||||
TheTVDBClient2 thetvdb = new TheTVDBClient2("BA864DEE427E384A");
|
static TheTVDBClient2 thetvdb = new TheTVDBClient2("BA864DEE427E384A");
|
||||||
|
|
||||||
SearchResult buffy = new SearchResult(70327, "Buffy the Vampire Slayer");
|
SearchResult buffy = new SearchResult(70327, "Buffy the Vampire Slayer");
|
||||||
SearchResult wonderfalls = new SearchResult(78845, "Wonderfalls");
|
SearchResult wonderfalls = new SearchResult(78845, "Wonderfalls");
|
||||||
@ -123,15 +123,11 @@ public class TheTVDBClient2Test {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getSeriesInfo() throws Exception {
|
public void getSeriesInfo() throws Exception {
|
||||||
TheTVDBSeriesInfo it = (TheTVDBSeriesInfo) thetvdb.getSeriesInfo(80348, Locale.ENGLISH);
|
SeriesInfo it = thetvdb.getSeriesInfo(80348, Locale.ENGLISH);
|
||||||
|
|
||||||
assertEquals(80348, it.getId(), 0);
|
assertEquals(80348, it.getId(), 0);
|
||||||
assertEquals("TV-PG", it.getContentRating());
|
|
||||||
assertEquals("2007-09-24", it.getFirstAired().toString());
|
|
||||||
assertEquals("Action", it.getGenres().get(0));
|
assertEquals("Action", it.getGenres().get(0));
|
||||||
assertEquals("tt0934814", it.getImdbId());
|
|
||||||
assertEquals("en", it.getLanguage());
|
assertEquals("en", it.getLanguage());
|
||||||
assertEquals(987, it.getOverview().length());
|
|
||||||
assertEquals("45", it.getRuntime().toString());
|
assertEquals("45", it.getRuntime().toString());
|
||||||
assertEquals("Chuck", it.getName());
|
assertEquals("Chuck", it.getName());
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user