1
0
mirror of https://github.com/mitb-archive/filebot synced 2025-01-12 22:38:11 -05:00

* make it easier to reference the original database in the format expression

This commit is contained in:
Reinhard Pointner 2014-01-04 20:18:47 +00:00
parent 54854d3098
commit 7d814d7b77
3 changed files with 68 additions and 57 deletions

View File

@ -21,11 +21,13 @@ import java.util.logging.Logger;
import net.sourceforge.filebot.web.AcoustID; import net.sourceforge.filebot.web.AcoustID;
import net.sourceforge.filebot.web.AnidbClient; import net.sourceforge.filebot.web.AnidbClient;
import net.sourceforge.filebot.web.AnidbSearchResult; import net.sourceforge.filebot.web.AnidbSearchResult;
import net.sourceforge.filebot.web.AudioTrack;
import net.sourceforge.filebot.web.EpisodeListProvider; import net.sourceforge.filebot.web.EpisodeListProvider;
import net.sourceforge.filebot.web.FanartTV; import net.sourceforge.filebot.web.FanartTV;
import net.sourceforge.filebot.web.ID3Lookup; import net.sourceforge.filebot.web.ID3Lookup;
import net.sourceforge.filebot.web.IMDbClient; import net.sourceforge.filebot.web.IMDbClient;
import net.sourceforge.filebot.web.LocalSearch; import net.sourceforge.filebot.web.LocalSearch;
import net.sourceforge.filebot.web.Movie;
import net.sourceforge.filebot.web.MovieIdentificationService; import net.sourceforge.filebot.web.MovieIdentificationService;
import net.sourceforge.filebot.web.MusicIdentificationService; import net.sourceforge.filebot.web.MusicIdentificationService;
import net.sourceforge.filebot.web.OpenSubtitlesClient; import net.sourceforge.filebot.web.OpenSubtitlesClient;
@ -34,6 +36,7 @@ import net.sourceforge.filebot.web.SerienjunkiesClient;
import net.sourceforge.filebot.web.SubtitleProvider; import net.sourceforge.filebot.web.SubtitleProvider;
import net.sourceforge.filebot.web.TMDbClient; import net.sourceforge.filebot.web.TMDbClient;
import net.sourceforge.filebot.web.TVRageClient; import net.sourceforge.filebot.web.TVRageClient;
import net.sourceforge.filebot.web.TVRageSearchResult;
import net.sourceforge.filebot.web.TheTVDBClient; import net.sourceforge.filebot.web.TheTVDBClient;
import net.sourceforge.filebot.web.TheTVDBSearchResult; import net.sourceforge.filebot.web.TheTVDBSearchResult;
import net.sourceforge.filebot.web.VideoHashSubtitleService; import net.sourceforge.filebot.web.VideoHashSubtitleService;
@ -109,6 +112,21 @@ public final class WebServices {
return null; // default return null; // default
} }
public static Object getServiceBySearchResult(Object r) {
if (r instanceof TheTVDBSearchResult)
return WebServices.TheTVDB;
if (r instanceof AnidbSearchResult)
return WebServices.AniDB;
if (r instanceof TVRageSearchResult)
return WebServices.TVRage;
if (r instanceof Movie)
return WebServices.TMDb;
if (r instanceof AudioTrack)
return WebServices.AcoustID;
return null;
}
public static class TheTVDBClientWithLocalSearch extends TheTVDBClient { public static class TheTVDBClientWithLocalSearch extends TheTVDBClient {
public TheTVDBClientWithLocalSearch(String apikey) { public TheTVDBClientWithLocalSearch(String apikey) {

View File

@ -41,10 +41,12 @@ import net.sourceforge.filebot.web.AnidbSearchResult;
import net.sourceforge.filebot.web.AudioTrack; import net.sourceforge.filebot.web.AudioTrack;
import net.sourceforge.filebot.web.Date; import net.sourceforge.filebot.web.Date;
import net.sourceforge.filebot.web.Episode; import net.sourceforge.filebot.web.Episode;
import net.sourceforge.filebot.web.EpisodeListProvider;
import net.sourceforge.filebot.web.Movie; import net.sourceforge.filebot.web.Movie;
import net.sourceforge.filebot.web.MoviePart; import net.sourceforge.filebot.web.MoviePart;
import net.sourceforge.filebot.web.MultiEpisode; import net.sourceforge.filebot.web.MultiEpisode;
import net.sourceforge.filebot.web.SearchResult; import net.sourceforge.filebot.web.SearchResult;
import net.sourceforge.filebot.web.SortOrder;
import net.sourceforge.filebot.web.TheTVDBSearchResult; import net.sourceforge.filebot.web.TheTVDBSearchResult;
import net.sourceforge.tuned.FileUtilities; import net.sourceforge.tuned.FileUtilities;
import net.sourceforge.tuned.FileUtilities.ExtensionFileFilter; import net.sourceforge.tuned.FileUtilities.ExtensionFileFilter;
@ -521,13 +523,21 @@ public class MediaBindingBean {
@Define("episodelist") @Define("episodelist")
public Object getEpisodeList() throws Exception { public Object getEpisodeList() throws Exception {
if (getSeriesObject() instanceof TheTVDBSearchResult) { return ((EpisodeListProvider) getDatabase()).getEpisodeList(getSeriesObject(), SortOrder.Airdate, Locale.ENGLISH);
return WebServices.TheTVDB.getEpisodeList(getSeriesObject()); }
@Define("database")
public Object getDatabase() {
if (infoObject instanceof Episode) {
return WebServices.getServiceBySearchResult(getSeriesObject());
} }
if (getSeriesObject() instanceof AnidbSearchResult) { if (infoObject instanceof Movie) {
return WebServices.AniDB.getEpisodeList(getSeriesObject()); return WebServices.getServiceBySearchResult(getMovie());
} }
return null; // default to original search result if (infoObject instanceof AudioTrack) {
return WebServices.getServiceBySearchResult(getMusic());
}
return null;
} }
@Define("duration") @Define("duration")

View File

@ -1,7 +1,5 @@
package net.sourceforge.filebot.web; package net.sourceforge.filebot.web;
import java.util.Arrays; import java.util.Arrays;
import java.util.List; import java.util.List;
import java.util.Locale; import java.util.Locale;
@ -11,32 +9,26 @@ import java.util.logging.Logger;
import net.sourceforge.filebot.Cache; import net.sourceforge.filebot.Cache;
import net.sourceforge.filebot.Cache.Key; import net.sourceforge.filebot.Cache.Key;
public abstract class AbstractEpisodeListProvider implements EpisodeListProvider { public abstract class AbstractEpisodeListProvider implements EpisodeListProvider {
@Override @Override
public boolean hasSingleSeasonSupport() { public boolean hasSingleSeasonSupport() {
return true; return true;
} }
@Override @Override
public boolean hasLocaleSupport() { public boolean hasLocaleSupport() {
return false; return false;
} }
protected abstract List<SearchResult> fetchSearchResult(String query, Locale locale) throws Exception; protected abstract List<SearchResult> fetchSearchResult(String query, Locale locale) throws Exception;
protected abstract List<Episode> fetchEpisodeList(SearchResult searchResult, SortOrder sortOrder, Locale locale) throws Exception; protected abstract List<Episode> fetchEpisodeList(SearchResult searchResult, SortOrder sortOrder, Locale locale) throws Exception;
public List<SearchResult> search(String query) throws Exception { public List<SearchResult> search(String query) throws Exception {
return search(query, getDefaultLocale()); return search(query, getDefaultLocale());
} }
@Override @Override
public List<SearchResult> search(String query, Locale locale) throws Exception { public List<SearchResult> search(String query, Locale locale) throws Exception {
ResultCache cache = getCache(); ResultCache cache = getCache();
@ -44,20 +36,22 @@ public abstract class AbstractEpisodeListProvider implements EpisodeListProvider
if (results != null) { if (results != null) {
return results; return results;
} }
// perform actual search // perform actual search
results = fetchSearchResult(query, locale); results = fetchSearchResult(query, locale);
// cache results and return // cache results and return
return (cache != null) ? cache.putSearchResult(query, locale, results) : results; return (cache != null) ? cache.putSearchResult(query, locale, results) : results;
} }
public List<Episode> getEpisodeList(SearchResult searchResult, String sortOrder, String locale) throws Exception {
return getEpisodeList(searchResult, sortOrder == null ? SortOrder.Airdate : SortOrder.forName(sortOrder), new Locale(locale));
}
public List<Episode> getEpisodeList(SearchResult searchResult) throws Exception { public List<Episode> getEpisodeList(SearchResult searchResult) throws Exception {
return getEpisodeList(searchResult, SortOrder.Airdate, getDefaultLocale()); return getEpisodeList(searchResult, SortOrder.Airdate, getDefaultLocale());
} }
@Override @Override
public List<Episode> getEpisodeList(SearchResult searchResult, SortOrder sortOrder, Locale locale) throws Exception { public List<Episode> getEpisodeList(SearchResult searchResult, SortOrder sortOrder, Locale locale) throws Exception {
ResultCache cache = getCache(); ResultCache cache = getCache();
@ -65,53 +59,46 @@ public abstract class AbstractEpisodeListProvider implements EpisodeListProvider
if (episodes != null) { if (episodes != null) {
return episodes; return episodes;
} }
// perform actual search // perform actual search
episodes = fetchEpisodeList(searchResult, sortOrder, locale); episodes = fetchEpisodeList(searchResult, sortOrder, locale);
// cache results and return // cache results and return
return (cache != null) ? cache.putEpisodeList(searchResult, sortOrder, locale, episodes) : episodes; return (cache != null) ? cache.putEpisodeList(searchResult, sortOrder, locale, episodes) : episodes;
} }
public Locale getDefaultLocale() { public Locale getDefaultLocale() {
return Locale.ENGLISH; return Locale.ENGLISH;
} }
public ResultCache getCache() { public ResultCache getCache() {
return null; return null;
} }
protected static class ResultCache { protected static class ResultCache {
private final String id; private final String id;
private final Cache cache; private final Cache cache;
public ResultCache(String id, Cache cache) { public ResultCache(String id, Cache cache) {
this.id = id; this.id = id;
this.cache = cache; this.cache = cache;
} }
protected String normalize(String query) { protected String normalize(String query) {
return query == null ? null : query.trim().toLowerCase(); return query == null ? null : query.trim().toLowerCase();
} }
public <T extends SearchResult> List<T> putSearchResult(String query, Locale locale, List<T> value) { public <T extends SearchResult> List<T> putSearchResult(String query, Locale locale, List<T> value) {
try { try {
cache.put(new Key(id, normalize(query), locale), value.toArray(new SearchResult[0])); cache.put(new Key(id, normalize(query), locale), value.toArray(new SearchResult[0]));
} catch (Exception e) { } catch (Exception e) {
Logger.getLogger(AbstractEpisodeListProvider.class.getName()).log(Level.WARNING, e.getMessage()); Logger.getLogger(AbstractEpisodeListProvider.class.getName()).log(Level.WARNING, e.getMessage());
} }
return value; return value;
} }
public List<SearchResult> getSearchResult(String query, Locale locale) { public List<SearchResult> getSearchResult(String query, Locale locale) {
try { try {
SearchResult[] results = cache.get(new Key(id, normalize(query), locale), SearchResult[].class); SearchResult[] results = cache.get(new Key(id, normalize(query), locale), SearchResult[].class);
@ -121,22 +108,20 @@ public abstract class AbstractEpisodeListProvider implements EpisodeListProvider
} catch (Exception e) { } catch (Exception e) {
Logger.getLogger(AbstractEpisodeListProvider.class.getName()).log(Level.WARNING, e.getMessage(), e); Logger.getLogger(AbstractEpisodeListProvider.class.getName()).log(Level.WARNING, e.getMessage(), e);
} }
return null; return null;
} }
public List<Episode> putEpisodeList(SearchResult key, SortOrder sortOrder, Locale locale, List<Episode> episodes) { public List<Episode> putEpisodeList(SearchResult key, SortOrder sortOrder, Locale locale, List<Episode> episodes) {
try { try {
cache.put(new Key(id, key, sortOrder, locale), episodes.toArray(new Episode[0])); cache.put(new Key(id, key, sortOrder, locale), episodes.toArray(new Episode[0]));
} catch (Exception e) { } catch (Exception e) {
Logger.getLogger(AbstractEpisodeListProvider.class.getName()).log(Level.WARNING, e.getMessage()); Logger.getLogger(AbstractEpisodeListProvider.class.getName()).log(Level.WARNING, e.getMessage());
} }
return episodes; return episodes;
} }
public List<Episode> getEpisodeList(SearchResult key, SortOrder sortOrder, Locale locale) { public List<Episode> getEpisodeList(SearchResult key, SortOrder sortOrder, Locale locale) {
try { try {
Episode[] episodes = cache.get(new Key(id, key, sortOrder, locale), Episode[].class); Episode[] episodes = cache.get(new Key(id, key, sortOrder, locale), Episode[].class);
@ -146,11 +131,10 @@ public abstract class AbstractEpisodeListProvider implements EpisodeListProvider
} catch (Exception e) { } catch (Exception e) {
Logger.getLogger(AbstractEpisodeListProvider.class.getName()).log(Level.WARNING, e.getMessage(), e); Logger.getLogger(AbstractEpisodeListProvider.class.getName()).log(Level.WARNING, e.getMessage(), e);
} }
return null; return null;
} }
public void putData(Object category, Object key, Locale locale, Object object) { public void putData(Object category, Object key, Locale locale, Object object) {
try { try {
cache.put(new Key(id, category, locale, key), object); cache.put(new Key(id, category, locale, key), object);
@ -158,8 +142,7 @@ public abstract class AbstractEpisodeListProvider implements EpisodeListProvider
Logger.getLogger(AbstractEpisodeListProvider.class.getName()).log(Level.WARNING, e.getMessage()); Logger.getLogger(AbstractEpisodeListProvider.class.getName()).log(Level.WARNING, e.getMessage());
} }
} }
public <T> T getData(Object category, Object key, Locale locale, Class<T> type) { public <T> T getData(Object category, Object key, Locale locale, Class<T> type) {
try { try {
T value = cache.get(new Key(id, category, locale, key), type); T value = cache.get(new Key(id, category, locale, key), type);
@ -169,10 +152,10 @@ public abstract class AbstractEpisodeListProvider implements EpisodeListProvider
} catch (Exception e) { } catch (Exception e) {
Logger.getLogger(AbstractEpisodeListProvider.class.getName()).log(Level.WARNING, e.getMessage(), e); Logger.getLogger(AbstractEpisodeListProvider.class.getName()).log(Level.WARNING, e.getMessage(), e);
} }
return null; return null;
} }
} }
} }