1
0
Fork 0
mirror of https://github.com/lidarr/Lidarr synced 2024-12-22 07:42:28 +00:00

Fixed: Refresh tags after updating autotags

(cherry picked from commit 6a332b40ac94e6e7c23217074da8e18e0ca3a319)

Closes #5093
This commit is contained in:
Bogdan 2024-09-05 14:56:36 +03:00
parent 2818f4e073
commit b2a4c75cce
3 changed files with 29 additions and 1 deletions

View file

@ -3,6 +3,7 @@
using Lidarr.Http.REST;
using Lidarr.Http.REST.Attributes;
using Microsoft.AspNetCore.Mvc;
using NzbDrone.Core.AutoTagging;
using NzbDrone.Core.Datastore.Events;
using NzbDrone.Core.Messaging.Events;
using NzbDrone.Core.Tags;
@ -11,7 +12,9 @@
namespace Lidarr.Api.V1.Tags
{
[V1ApiController]
public class TagController : RestControllerWithSignalR<TagResource, Tag>, IHandle<TagsUpdatedEvent>
public class TagController : RestControllerWithSignalR<TagResource, Tag>,
IHandle<TagsUpdatedEvent>,
IHandle<AutoTagsUpdatedEvent>
{
private readonly ITagService _tagService;
@ -60,5 +63,11 @@ public void Handle(TagsUpdatedEvent message)
{
BroadcastResourceChange(ModelAction.Sync);
}
[NonAction]
public void Handle(AutoTagsUpdatedEvent message)
{
BroadcastResourceChange(ModelAction.Sync);
}
}
}

View file

@ -2,6 +2,7 @@
using System.Linq;
using NzbDrone.Common.Cache;
using NzbDrone.Common.Extensions;
using NzbDrone.Core.Messaging.Events;
using NzbDrone.Core.Music;
using NzbDrone.Core.RootFolders;
@ -22,14 +23,18 @@ public class AutoTaggingService : IAutoTaggingService
{
private readonly IAutoTaggingRepository _repository;
private readonly RootFolderService _rootFolderService;
private readonly IEventAggregator _eventAggregator;
private readonly ICached<Dictionary<int, AutoTag>> _cache;
public AutoTaggingService(IAutoTaggingRepository repository,
RootFolderService rootFolderService,
IEventAggregator eventAggregator,
ICacheManager cacheManager)
{
_repository = repository;
_rootFolderService = rootFolderService;
_eventAggregator = eventAggregator;
_cache = cacheManager.GetCache<Dictionary<int, AutoTag>>(typeof(AutoTag), "autoTags");
}
@ -51,13 +56,17 @@ public AutoTag GetById(int id)
public void Update(AutoTag autoTag)
{
_repository.Update(autoTag);
_cache.Clear();
_eventAggregator.PublishEvent(new AutoTagsUpdatedEvent());
}
public AutoTag Insert(AutoTag autoTag)
{
var result = _repository.Insert(autoTag);
_cache.Clear();
_eventAggregator.PublishEvent(new AutoTagsUpdatedEvent());
return result;
}
@ -65,7 +74,9 @@ public AutoTag Insert(AutoTag autoTag)
public void Delete(int id)
{
_repository.Delete(id);
_cache.Clear();
_eventAggregator.PublishEvent(new AutoTagsUpdatedEvent());
}
public List<AutoTag> AllForTag(int tagId)

View file

@ -0,0 +1,8 @@
using NzbDrone.Common.Messaging;
namespace NzbDrone.Core.AutoTagging
{
public class AutoTagsUpdatedEvent : IEvent
{
}
}