* improved caching and other refactoring
* disabled TheMovieDB hash lookup since it doesn't work anyway
This commit is contained in:
parent
208216c0e3
commit
b8c96b8fbe
@ -170,18 +170,18 @@ public abstract class AbstractEpisodeListProvider implements EpisodeListProvider
|
||||
}
|
||||
|
||||
|
||||
public void putData(Object category, Object key, Object object) {
|
||||
public void putData(Object category, Object key, Locale locale, Object object) {
|
||||
try {
|
||||
cache.put(new Element(new Key(id, category, key), object));
|
||||
cache.put(new Element(new Key(id, category, locale, key), object));
|
||||
} catch (Exception e) {
|
||||
Logger.getLogger(AbstractEpisodeListProvider.class.getName()).log(Level.WARNING, e.getMessage(), e);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
public <T> T getData(Object category, Object key, Class<T> type) {
|
||||
public <T> T getData(Object category, Object key, Locale locale, Class<T> type) {
|
||||
try {
|
||||
Element element = cache.get(new Key(id, category, key));
|
||||
Element element = cache.get(new Key(id, category, locale, key));
|
||||
if (element != null) {
|
||||
return type.cast(element.getValue());
|
||||
}
|
||||
|
@ -35,7 +35,7 @@ public abstract class CachedResource<T extends Serializable> {
|
||||
/**
|
||||
* Convert resource data into usable data
|
||||
*/
|
||||
public abstract T process(ByteBuffer data);
|
||||
public abstract T process(ByteBuffer data) throws Exception;
|
||||
|
||||
|
||||
public synchronized T get() throws IOException {
|
||||
@ -57,7 +57,11 @@ public abstract class CachedResource<T extends Serializable> {
|
||||
ByteBuffer data = fetchIfModified(new URL(resource), element != null ? lastUpdateTime : 0);
|
||||
|
||||
if (data != null) {
|
||||
element = new Element(cacheKey, process(data));
|
||||
try {
|
||||
element = new Element(cacheKey, process(data));
|
||||
} catch (Exception e) {
|
||||
throw new IOException(e);
|
||||
}
|
||||
}
|
||||
|
||||
// update cached data and last-updated time
|
||||
|
@ -5,13 +5,10 @@ package net.sourceforge.filebot.web;
|
||||
import static java.lang.Math.*;
|
||||
import static java.util.Arrays.*;
|
||||
import static net.sourceforge.filebot.web.OpenSubtitlesHasher.*;
|
||||
import static net.sourceforge.filebot.web.WebRequest.*;
|
||||
|
||||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
import java.math.BigInteger;
|
||||
import java.net.URI;
|
||||
import java.net.URL;
|
||||
import java.security.MessageDigest;
|
||||
import java.security.NoSuchAlgorithmException;
|
||||
import java.util.ArrayList;
|
||||
@ -21,12 +18,9 @@ import java.util.List;
|
||||
import java.util.Locale;
|
||||
import java.util.Map;
|
||||
import java.util.Map.Entry;
|
||||
import java.util.Scanner;
|
||||
import java.util.concurrent.TimeUnit;
|
||||
import java.util.logging.Level;
|
||||
import java.util.logging.Logger;
|
||||
import java.util.regex.Matcher;
|
||||
import java.util.regex.Pattern;
|
||||
|
||||
import javax.swing.Icon;
|
||||
|
||||
@ -344,40 +338,4 @@ public class OpenSubtitlesClient implements SubtitleProvider, VideoHashSubtitleS
|
||||
return null;
|
||||
}
|
||||
|
||||
|
||||
public List<Movie> exportMovie() throws IOException {
|
||||
Cache cache = CacheManager.getInstance().getCache("web-persistent-datasource");
|
||||
String cacheKey = getClass().getName() + ".exportMovie";
|
||||
|
||||
Element element = cache.get(cacheKey);
|
||||
if (element != null) {
|
||||
return asList((Movie[]) element.getValue());
|
||||
}
|
||||
|
||||
URL url = new URL("http://www.opensubtitles.org/addons/export_movie.php");
|
||||
Scanner in = new Scanner(getReader(url.openConnection()));
|
||||
|
||||
try {
|
||||
// e.g. IDMovie IDMovieImdb MovieName MovieYear
|
||||
Pattern linePattern = Pattern.compile("(\\d+)\\t(\\d+)\\t([^\\t]+)\\t(\\d{4})");
|
||||
List<Movie> result = new ArrayList<Movie>();
|
||||
while (in.hasNextLine()) {
|
||||
String line = in.nextLine().trim();
|
||||
Matcher matcher = linePattern.matcher(line);
|
||||
|
||||
if (matcher.matches()) {
|
||||
int idMovieImdb = Integer.parseInt(matcher.group(2));
|
||||
String movieName = matcher.group(3);
|
||||
int movieYear = Integer.parseInt(matcher.group(4));
|
||||
result.add(new Movie(movieName, movieYear, idMovieImdb));
|
||||
}
|
||||
}
|
||||
|
||||
// cache data
|
||||
cache.put(new Element(cacheKey, result.toArray(new Movie[0])));
|
||||
return result;
|
||||
} finally {
|
||||
in.close();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -146,7 +146,7 @@ public class OpenSubtitlesXmlRpc {
|
||||
|
||||
movies.add(new Movie(name, year, Integer.parseInt(imdbid)));
|
||||
} catch (Exception e) {
|
||||
Logger.getLogger(OpenSubtitlesXmlRpc.class.getName()).log(Level.WARNING, String.format("Ignore movie %s: %s", movie, e.getMessage()));
|
||||
Logger.getLogger(OpenSubtitlesXmlRpc.class.getName()).log(Level.INFO, String.format("Ignore movie %s: %s", movie, e.getMessage()));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -69,10 +69,8 @@ public class TMDbClient implements MovieIdentificationService {
|
||||
|
||||
|
||||
public List<Movie> searchMovie(File file, Locale locale) throws IOException, SAXException {
|
||||
if (file.length() < OpenSubtitlesHasher.HASH_CHUNK_SIZE)
|
||||
return emptyList();
|
||||
|
||||
return searchMovie(OpenSubtitlesHasher.computeHash(file), file.length(), locale);
|
||||
return emptyList(); // API BROKEN
|
||||
// return searchMovie(OpenSubtitlesHasher.computeHash(file), file.length(), locale);
|
||||
}
|
||||
|
||||
|
||||
|
@ -192,12 +192,20 @@ public class TheTVDBClient extends AbstractEpisodeListProvider {
|
||||
|
||||
|
||||
public TheTVDBSearchResult lookupByID(int id, Locale language) throws Exception {
|
||||
TheTVDBSearchResult cachedItem = getCache().getData("lookupByID", id, language, TheTVDBSearchResult.class);
|
||||
if (cachedItem != null) {
|
||||
return cachedItem;
|
||||
}
|
||||
|
||||
try {
|
||||
URL baseRecordLocation = getResource(MirrorType.XML, "/api/" + apikey + "/series/" + id + "/all/" + language.getLanguage() + ".xml");
|
||||
Document baseRecord = getDocument(baseRecordLocation);
|
||||
|
||||
String name = selectString("//SeriesName", baseRecord);
|
||||
return new TheTVDBSearchResult(name, id);
|
||||
|
||||
TheTVDBSearchResult series = new TheTVDBSearchResult(name, id);
|
||||
getCache().putData("lookupByID", id, language, series);
|
||||
return series;
|
||||
} catch (FileNotFoundException e) {
|
||||
// illegal series id
|
||||
Logger.getLogger(getClass().getName()).log(Level.WARNING, "Failed to retrieve base series record: " + e.getMessage());
|
||||
@ -207,6 +215,11 @@ public class TheTVDBClient extends AbstractEpisodeListProvider {
|
||||
|
||||
|
||||
public TheTVDBSearchResult lookupByIMDbID(int imdbid, Locale language) throws Exception {
|
||||
TheTVDBSearchResult cachedItem = getCache().getData("lookupByIMDbID", imdbid, language, TheTVDBSearchResult.class);
|
||||
if (cachedItem != null) {
|
||||
return cachedItem;
|
||||
}
|
||||
|
||||
URL query = getResource(null, "/api/GetSeriesByRemoteID.php?imdbid=" + imdbid + "&language=" + language.getLanguage());
|
||||
Document dom = getDocument(query);
|
||||
|
||||
@ -216,7 +229,9 @@ public class TheTVDBClient extends AbstractEpisodeListProvider {
|
||||
if (id == null || id.isEmpty() || name == null || name.isEmpty())
|
||||
return null;
|
||||
|
||||
return new TheTVDBSearchResult(name, Integer.parseInt(id));
|
||||
TheTVDBSearchResult series = new TheTVDBSearchResult(name, Integer.parseInt(id));
|
||||
getCache().putData("lookupByIMDbID", imdbid, language, series);
|
||||
return series;
|
||||
}
|
||||
|
||||
|
||||
@ -253,7 +268,7 @@ public class TheTVDBClient extends AbstractEpisodeListProvider {
|
||||
// try cache first
|
||||
try {
|
||||
@SuppressWarnings("unchecked")
|
||||
Map<MirrorType, String> cachedMirrors = (Map<MirrorType, String>) getCache().getData("mirrors", null, Map.class);
|
||||
Map<MirrorType, String> cachedMirrors = (Map<MirrorType, String>) getCache().getData("mirrors", null, null, Map.class);
|
||||
if (cachedMirrors != null) {
|
||||
mirrors.putAll(cachedMirrors);
|
||||
return mirrors.get(mirrorType);
|
||||
@ -296,7 +311,7 @@ public class TheTVDBClient extends AbstractEpisodeListProvider {
|
||||
}
|
||||
}
|
||||
|
||||
getCache().putData("mirrors", null, mirrors);
|
||||
getCache().putData("mirrors", null, null, mirrors);
|
||||
}
|
||||
|
||||
return mirrors.get(mirrorType);
|
||||
@ -385,7 +400,7 @@ public class TheTVDBClient extends AbstractEpisodeListProvider {
|
||||
|
||||
public SeriesInfo getSeriesInfo(TheTVDBSearchResult searchResult, Locale locale) throws Exception {
|
||||
// check cache first
|
||||
SeriesInfo cachedItem = getCache().getData("seriesInfo", searchResult.seriesId, SeriesInfo.class);
|
||||
SeriesInfo cachedItem = getCache().getData("seriesInfo", searchResult.seriesId, locale, SeriesInfo.class);
|
||||
if (cachedItem != null) {
|
||||
return cachedItem;
|
||||
}
|
||||
@ -407,7 +422,7 @@ public class TheTVDBClient extends AbstractEpisodeListProvider {
|
||||
}
|
||||
|
||||
SeriesInfo seriesInfo = new SeriesInfo(fields);
|
||||
getCache().putData("seriesInfo", searchResult.seriesId, seriesInfo);
|
||||
getCache().putData("seriesInfo", searchResult.seriesId, locale, seriesInfo);
|
||||
return seriesInfo;
|
||||
}
|
||||
|
||||
@ -660,7 +675,7 @@ public class TheTVDBClient extends AbstractEpisodeListProvider {
|
||||
|
||||
public List<BannerDescriptor> getBannerList(TheTVDBSearchResult series) throws Exception {
|
||||
// check cache first
|
||||
BannerDescriptor[] cachedList = getCache().getData("banners", series.seriesId, BannerDescriptor[].class);
|
||||
BannerDescriptor[] cachedList = getCache().getData("banners", series.seriesId, null, BannerDescriptor[].class);
|
||||
if (cachedList != null) {
|
||||
return asList(cachedList);
|
||||
}
|
||||
@ -692,7 +707,7 @@ public class TheTVDBClient extends AbstractEpisodeListProvider {
|
||||
}
|
||||
}
|
||||
|
||||
getCache().putData("banners", series.seriesId, banners.toArray(new BannerDescriptor[0]));
|
||||
getCache().putData("banners", series.seriesId, null, banners.toArray(new BannerDescriptor[0]));
|
||||
return banners;
|
||||
}
|
||||
|
||||
|
@ -201,15 +201,4 @@ public class OpenSubtitlesXmlRpcTest {
|
||||
xmlrpc.logout();
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
public void exportMovie() throws Exception {
|
||||
List<Movie> list = new OpenSubtitlesClient(null).exportMovie();
|
||||
Movie sample = (Movie) list.get(17);
|
||||
|
||||
// check sample entry
|
||||
assertEquals("Back to the Future", sample.getName());
|
||||
assertEquals(1985, sample.getYear());
|
||||
assertEquals(88763, sample.getImdbId());
|
||||
}
|
||||
}
|
||||
|
@ -149,6 +149,22 @@ public class TheTVDBClientTest {
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
public void lookupByID() throws Exception {
|
||||
TheTVDBSearchResult series = thetvdb.lookupByID(78874, Locale.ENGLISH);
|
||||
assertEquals("Firefly", series.getName());
|
||||
assertEquals(70726, series.getSeriesId());
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
public void lookupByIMDbID() throws Exception {
|
||||
TheTVDBSearchResult series = thetvdb.lookupByIMDbID(78874, Locale.ENGLISH);
|
||||
assertEquals("Firefly", series.getName());
|
||||
assertEquals(70726, series.getSeriesId());
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
public void getSeriesInfo() throws Exception {
|
||||
SeriesInfo it = thetvdb.getSeriesInfo(new TheTVDBSearchResult(null, 80348), Locale.ENGLISH);
|
||||
|
Loading…
Reference in New Issue
Block a user