SubtitleDownloadFailureLogger.cs 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. using System;
  2. using System.Globalization;
  3. using System.Threading.Tasks;
  4. using Jellyfin.Database.Implementations.Entities;
  5. using MediaBrowser.Controller.Entities;
  6. using MediaBrowser.Controller.Entities.Audio;
  7. using MediaBrowser.Controller.Events;
  8. using MediaBrowser.Controller.Subtitles;
  9. using MediaBrowser.Model.Activity;
  10. using MediaBrowser.Model.Globalization;
  11. using Episode = MediaBrowser.Controller.Entities.TV.Episode;
  12. namespace Jellyfin.Server.Implementations.Events.Consumers.Library
  13. {
  14. /// <summary>
  15. /// Creates an entry in the activity log whenever a subtitle download fails.
  16. /// </summary>
  17. public class SubtitleDownloadFailureLogger : IEventConsumer<SubtitleDownloadFailureEventArgs>
  18. {
  19. private readonly ILocalizationManager _localizationManager;
  20. private readonly IActivityManager _activityManager;
  21. /// <summary>
  22. /// Initializes a new instance of the <see cref="SubtitleDownloadFailureLogger"/> class.
  23. /// </summary>
  24. /// <param name="localizationManager">The localization manager.</param>
  25. /// <param name="activityManager">The activity manager.</param>
  26. public SubtitleDownloadFailureLogger(ILocalizationManager localizationManager, IActivityManager activityManager)
  27. {
  28. _localizationManager = localizationManager;
  29. _activityManager = activityManager;
  30. }
  31. /// <inheritdoc />
  32. public async Task OnEvent(SubtitleDownloadFailureEventArgs eventArgs)
  33. {
  34. await _activityManager.CreateAsync(new ActivityLog(
  35. string.Format(
  36. CultureInfo.InvariantCulture,
  37. _localizationManager.GetLocalizedString("SubtitleDownloadFailureFromForItem"),
  38. eventArgs.Provider,
  39. GetItemName(eventArgs.Item)),
  40. "SubtitleDownloadFailure",
  41. Guid.Empty)
  42. {
  43. ItemId = eventArgs.Item.Id.ToString("N", CultureInfo.InvariantCulture),
  44. ShortOverview = eventArgs.Exception.Message
  45. }).ConfigureAwait(false);
  46. }
  47. private static string GetItemName(BaseItem item)
  48. {
  49. var name = item.Name;
  50. if (item is Episode episode)
  51. {
  52. if (episode.IndexNumber.HasValue)
  53. {
  54. name = string.Format(
  55. CultureInfo.InvariantCulture,
  56. "Ep{0} - {1}",
  57. episode.IndexNumber.Value,
  58. name);
  59. }
  60. if (episode.ParentIndexNumber.HasValue)
  61. {
  62. name = string.Format(
  63. CultureInfo.InvariantCulture,
  64. "S{0}, {1}",
  65. episode.ParentIndexNumber.Value,
  66. name);
  67. }
  68. }
  69. if (item is IHasSeries hasSeries)
  70. {
  71. name = hasSeries.SeriesName + " - " + name;
  72. }
  73. if (item is IHasAlbumArtist hasAlbumArtist)
  74. {
  75. var artists = hasAlbumArtist.AlbumArtists;
  76. if (artists.Count > 0)
  77. {
  78. name = artists[0] + " - " + name;
  79. }
  80. }
  81. else if (item is IHasArtist hasArtist)
  82. {
  83. var artists = hasArtist.Artists;
  84. if (artists.Count > 0)
  85. {
  86. name = artists[0] + " - " + name;
  87. }
  88. }
  89. return name;
  90. }
  91. }
  92. }