From dfbf5fc9fa3209b0a6e76b3fcb60e13d15390c26 Mon Sep 17 00:00:00 2001 From: Claus Vium Date: Tue, 12 Feb 2019 21:04:45 +0100 Subject: [PATCH] Add generic key generation function --- .../TV/TheTVDB/TvDbClientManager.cs | 37 +++++++++---------- 1 file changed, 17 insertions(+), 20 deletions(-) diff --git a/MediaBrowser.Providers/TV/TheTVDB/TvDbClientManager.cs b/MediaBrowser.Providers/TV/TheTVDB/TvDbClientManager.cs index 9d63b83731..a3979bf422 100644 --- a/MediaBrowser.Providers/TV/TheTVDB/TvDbClientManager.cs +++ b/MediaBrowser.Providers/TV/TheTVDB/TvDbClientManager.cs @@ -80,19 +80,22 @@ namespace MediaBrowser.Providers.TV.TheTVDB public Task> GetSeriesByNameAsync(string name, string language, CancellationToken cancellationToken) { - return TryGetValue("series" + name, language,() => TvDbClient.Search.SearchSeriesByNameAsync(name, cancellationToken)); + var cacheKey = GenerateKey("series", name, language); + return TryGetValue(cacheKey, language,() => TvDbClient.Search.SearchSeriesByNameAsync(name, cancellationToken)); } public Task> GetSeriesByIdAsync(int tvdbId, string language, CancellationToken cancellationToken) { - return TryGetValue("series" + tvdbId, language,() => TvDbClient.Series.GetAsync(tvdbId, cancellationToken)); + var cacheKey = GenerateKey("series", tvdbId, language); + return TryGetValue(cacheKey, language,() => TvDbClient.Series.GetAsync(tvdbId, cancellationToken)); } public Task> GetEpisodesAsync(int episodeTvdbId, string language, CancellationToken cancellationToken) { - return TryGetValue("episode" + episodeTvdbId, language,() => TvDbClient.Episodes.GetAsync(episodeTvdbId, cancellationToken)); + var cacheKey = GenerateKey("episode", episodeTvdbId, language); + return TryGetValue(cacheKey, language,() => TvDbClient.Episodes.GetAsync(episodeTvdbId, cancellationToken)); } public async Task> GetAllEpisodesAsync(int tvdbId, string language, @@ -122,24 +125,27 @@ namespace MediaBrowser.Providers.TV.TheTVDB public Task> GetSeriesByImdbIdAsync(string imdbId, string language, CancellationToken cancellationToken) { - return TryGetValue("series" + imdbId, language,() => TvDbClient.Search.SearchSeriesByImdbIdAsync(imdbId, cancellationToken)); + var cacheKey = GenerateKey("series", imdbId, language); + return TryGetValue(cacheKey, language,() => TvDbClient.Search.SearchSeriesByImdbIdAsync(imdbId, cancellationToken)); } public Task> GetSeriesByZap2ItIdAsync(string zap2ItId, string language, CancellationToken cancellationToken) { - return TryGetValue("series" + zap2ItId, language,() => TvDbClient.Search.SearchSeriesByZap2ItIdAsync(zap2ItId, cancellationToken)); + var cacheKey = GenerateKey("series", zap2ItId, language); + return TryGetValue( cacheKey, language,() => TvDbClient.Search.SearchSeriesByZap2ItIdAsync(zap2ItId, cancellationToken)); } public Task> GetActorsAsync(int tvdbId, string language, CancellationToken cancellationToken) { - return TryGetValue("actors" + tvdbId, language,() => TvDbClient.Series.GetActorsAsync(tvdbId, cancellationToken)); + var cacheKey = GenerateKey("actors", tvdbId, language); + return TryGetValue(cacheKey, language,() => TvDbClient.Series.GetActorsAsync(tvdbId, cancellationToken)); } public Task> GetImagesAsync(int tvdbId, ImagesQuery imageQuery, string language, CancellationToken cancellationToken) { - var cacheKey = "images" + tvdbId + "keytype" + imageQuery.KeyType + "subkey" + imageQuery.SubKey; + var cacheKey = GenerateKey("images", tvdbId, language, imageQuery); return TryGetValue(cacheKey, language,() => TvDbClient.Series.GetImagesAsync(tvdbId, imageQuery, cancellationToken)); } @@ -151,23 +157,15 @@ namespace MediaBrowser.Providers.TV.TheTVDB public Task> GetSeriesEpisodeSummaryAsync(int tvdbId, string language, CancellationToken cancellationToken) { - return TryGetValue("seriesepisodesummary" + tvdbId, language, + var cacheKey = GenerateKey("seriesepisodesummary", tvdbId, language); + return TryGetValue(cacheKey, language, () => TvDbClient.Series.GetEpisodesSummaryAsync(tvdbId, cancellationToken)); } public Task> GetEpisodesPageAsync(int tvdbId, int page, EpisodeQuery episodeQuery, string language, CancellationToken cancellationToken) { - // Not quite as dynamic as it could be - var cacheKey = "episodespage" + tvdbId + "page" + page; - if (episodeQuery.AiredSeason.HasValue) - { - cacheKey += "airedseason" + episodeQuery.AiredSeason.Value; - } - if (episodeQuery.AiredEpisode.HasValue) - { - cacheKey += "airedepisode" + episodeQuery.AiredEpisode.Value; - } + var cacheKey = GenerateKey(language, tvdbId, episodeQuery); return TryGetValue(cacheKey, language, () => TvDbClient.Series.GetEpisodesAsync(tvdbId, page, episodeQuery, cancellationToken)); @@ -235,13 +233,12 @@ namespace MediaBrowser.Providers.TV.TheTVDB } } - private static string GenerateKey(object[] objects) + private static string GenerateKey(params object[] objects) { var key = string.Empty; foreach (var obj in objects) { - key += nameof(obj); var objType = obj.GetType(); if (objType.IsPrimitive || objType == typeof(string)) {