Skip to content

Commit

Permalink
Reimplement add a task to purge cache. Plugin now uses its own cache.
Browse files Browse the repository at this point in the history
  • Loading branch information
scampower3 committed Mar 4, 2024
1 parent 50269a4 commit 55c5c83
Show file tree
Hide file tree
Showing 2 changed files with 104 additions and 4 deletions.
65 changes: 65 additions & 0 deletions Jellyfin.Plugin.Tvdb/ScheduledTasks/PurgeCacheTask.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading;
using System.Threading.Tasks;
using MediaBrowser.Model.Tasks;
using Microsoft.Extensions.Logging;

namespace Jellyfin.Plugin.Tvdb.ScheduledTasks
{
/// <summary>
/// Task to purge TheTVDB plugin cache.
/// </summary>
public class PurgeCacheTask : IScheduledTask
{
private readonly ILogger<PurgeCacheTask> _logger;
private readonly TvdbClientManager _tvdbClientManager;

/// <summary>
/// Initializes a new instance of the <see cref="PurgeCacheTask"/> class.
/// </summary>
/// <param name="logger">Instance of the <see cref="ILogger{TvdbScheduledTask}"/> interface.</param>
/// <param name="tvdbClientManager">Instance of <see cref="TvdbClientManager"/>.</param>
public PurgeCacheTask(
ILogger<PurgeCacheTask> logger,
TvdbClientManager tvdbClientManager)
{
_logger = logger;
_tvdbClientManager = tvdbClientManager;
}

/// <inheritdoc/>
public string Name => "Purge TheTVDB plugin cache";

/// <inheritdoc/>
public string Key => "PurgeTheTVDBPluginCache";

/// <inheritdoc/>
public string Description => "Purges the TheTVDB Cache";

/// <inheritdoc/>
public string Category => "TheTVDB";

/// <inheritdoc/>
public Task ExecuteAsync(IProgress<double> progress, CancellationToken cancellationToken)
{
if (_tvdbClientManager.PurgeCache())
{
_logger.LogInformation("TheTvdb plugin cache purged successfully");
}
else
{
_logger.LogError("TheTvdb plugin cache purge failed");
}

return Task.CompletedTask;
}

/// <inheritdoc/>
public IEnumerable<TaskTriggerInfo> GetDefaultTriggers()
{
return Enumerable.Empty<TaskTriggerInfo>();
}
}
}
43 changes: 39 additions & 4 deletions Jellyfin.Plugin.Tvdb/TvdbClientManager.cs
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ namespace Jellyfin.Plugin.Tvdb;
/// <summary>
/// Tvdb client manager.
/// </summary>
public class TvdbClientManager
public class TvdbClientManager : IDisposable
{
private const string TvdbHttpClient = "TvdbHttpClient";
private const int CacheDurationInHours = 1;
Expand All @@ -36,13 +36,12 @@ public class TvdbClientManager
/// Initializes a new instance of the <see cref="TvdbClientManager"/> class.
/// </summary>
/// <param name="applicationHost">Instance of the <see cref="IApplicationHost"/> interface.</param>
/// <param name="memoryCache">Instance of the <see cref="IMemoryCache"/> interface.</param>
public TvdbClientManager(IApplicationHost applicationHost, IMemoryCache memoryCache)
public TvdbClientManager(IApplicationHost applicationHost)
{
_serviceProvider = ConfigureService(applicationHost);
_httpClientFactory = _serviceProvider.GetRequiredService<IHttpClientFactory>();
_sdkClientSettings = _serviceProvider.GetRequiredService<SdkClientSettings>();
_memoryCache = memoryCache;
_memoryCache = new MemoryCache(new MemoryCacheOptions());

_tokenUpdatedAt = DateTime.MinValue;
}
Expand Down Expand Up @@ -501,6 +500,23 @@ public async Task<IReadOnlyList<ArtworkType>> GetArtworkTypeAsync(CancellationTo
}
}

/// <summary>
/// Purge the cache.
/// </summary>
/// <returns>True if success else false.</returns>
public bool PurgeCache()
{
if (_memoryCache is MemoryCache memoryCache)
{
memoryCache.Compact(1);
return true;
}
else
{
return false;
}
}

/// <summary>
/// Create an independent ServiceProvider because registering HttpClients directly into Jellyfin
/// causes issues upstream.
Expand Down Expand Up @@ -545,4 +561,23 @@ private ServiceProvider ConfigureService(IApplicationHost applicationHost)

return services.BuildServiceProvider();
}

/// <inheritdoc/>
public void Dispose()
{
Dispose(true);
GC.SuppressFinalize(this);
}

/// <summary>
/// Releases unmanaged and - optionally - managed resources.
/// </summary>
/// <param name="disposing"><c>true</c> to release both managed and unmanaged resources; <c>false</c> to release only unmanaged resources.</param>
protected virtual void Dispose(bool disposing)
{
if (disposing)
{
_memoryCache?.Dispose();
}
}
}

0 comments on commit 55c5c83

Please sign in to comment.