< Summary - Jellyfin

Information
Class: MediaBrowser.Providers.BoxSets.BoxSetMetadataService
Assembly: MediaBrowser.Providers
File(s): /srv/git/jellyfin/MediaBrowser.Providers/BoxSets/BoxSetMetadataService.cs
Line coverage
8%
Covered lines: 2
Uncovered lines: 23
Coverable lines: 25
Total lines: 104
Line coverage: 8%
Branch coverage
0%
Covered branches: 0
Total branches: 10
Branch coverage: 0%
Method coverage

Feature is only available for sponsors

Upgrade to PRO version

Coverage history

Coverage history 0 25 50 75 100 1/23/2026 - 12:11:06 AM Line coverage: 10% (2/20) Branch coverage: 0% (0/6) Total lines: 935/4/2026 - 12:15:16 AM Line coverage: 8% (2/25) Branch coverage: 0% (0/10) Total lines: 104 1/23/2026 - 12:11:06 AM Line coverage: 10% (2/20) Branch coverage: 0% (0/6) Total lines: 935/4/2026 - 12:15:16 AM Line coverage: 8% (2/25) Branch coverage: 0% (0/10) Total lines: 104

Coverage delta

Coverage delta 2 -2

Metrics

File(s)

/srv/git/jellyfin/MediaBrowser.Providers/BoxSets/BoxSetMetadataService.cs

#LineLine coverage
 1using System;
 2using System.Collections.Generic;
 3using System.Linq;
 4using MediaBrowser.Controller.Configuration;
 5using MediaBrowser.Controller.Entities;
 6using MediaBrowser.Controller.Entities.Movies;
 7using MediaBrowser.Controller.IO;
 8using MediaBrowser.Controller.Library;
 9using MediaBrowser.Controller.Persistence;
 10using MediaBrowser.Controller.Providers;
 11using MediaBrowser.Model.Entities;
 12using MediaBrowser.Model.IO;
 13using MediaBrowser.Providers.Manager;
 14using Microsoft.Extensions.Logging;
 15
 16namespace MediaBrowser.Providers.BoxSets;
 17
 18/// <summary>
 19/// Service to manage boxset metadata.
 20/// </summary>
 21public class BoxSetMetadataService : MetadataService<BoxSet, BoxSetInfo>
 22{
 23    /// <summary>
 24    /// Initializes a new instance of the <see cref="BoxSetMetadataService"/> class.
 25    /// </summary>
 26    /// <param name="serverConfigurationManager">Instance of the <see cref="IServerConfigurationManager"/>.</param>
 27    /// <param name="logger">Instance of the <see cref="ILogger"/> interface.</param>
 28    /// <param name="providerManager">Instance of the <see cref="IProviderManager"/> interface.</param>
 29    /// <param name="fileSystem">Instance of the <see cref="IFileSystem"/> interface.</param>
 30    /// <param name="libraryManager">Instance of the <see cref="ILibraryManager"/> interface.</param>
 31    /// <param name="externalDataManager">Instance of the <see cref="IExternalDataManager"/> interface.</param>
 32    /// <param name="itemRepository">Instance of the <see cref="IItemRepository"/> interface.</param>
 33    public BoxSetMetadataService(
 34        IServerConfigurationManager serverConfigurationManager,
 35        ILogger<BoxSetMetadataService> logger,
 36        IProviderManager providerManager,
 37        IFileSystem fileSystem,
 38        ILibraryManager libraryManager,
 39        IExternalDataManager externalDataManager,
 40        IItemRepository itemRepository)
 2141        : base(serverConfigurationManager, logger, providerManager, fileSystem, libraryManager, externalDataManager, ite
 42    {
 2143    }
 44
 45    /// <inheritdoc />
 046    protected override bool EnableUpdatingGenresFromChildren => true;
 47
 48    /// <inheritdoc />
 049    protected override bool EnableUpdatingOfficialRatingFromChildren => true;
 50
 51    /// <inheritdoc />
 052    protected override bool EnableUpdatingStudiosFromChildren => true;
 53
 54    /// <inheritdoc />
 055    protected override bool EnableUpdatingPremiereDateFromChildren => true;
 56
 57    /// <inheritdoc />
 58    protected override IReadOnlyList<BaseItem> GetChildrenForMetadataUpdates(BoxSet item)
 59    {
 060        return item.GetLinkedChildren();
 61    }
 62
 63    /// <inheritdoc />
 64    protected override void MergeData(MetadataResult<BoxSet> source, MetadataResult<BoxSet> target, MetadataField[] lock
 65    {
 066        base.MergeData(source, target, lockedFields, replaceData, mergeMetadataSettings);
 67
 068        var sourceItem = source.Item;
 069        var targetItem = target.Item;
 70
 071        if (mergeMetadataSettings)
 72        {
 73            // Only merge LinkedChildren from metadata for external collections (not managed by Jellyfin).
 74            // For internal collections, the database LinkedChildren table is the source of truth.
 075            var targetPath = targetItem.Path;
 076            if (!string.IsNullOrEmpty(targetPath)
 077                && !FileSystem.ContainsSubPath(ServerConfigurationManager.ApplicationPaths.DataPath, targetPath))
 78            {
 79#pragma warning disable CS0618 // Type or member is obsolete - fallback for legacy path-based dedup
 080                targetItem.LinkedChildren = sourceItem.LinkedChildren.Concat(targetItem.LinkedChildren)
 081                    .DistinctBy(i => i.ItemId.HasValue && !i.ItemId.Value.Equals(Guid.Empty) ? i.ItemId.Value.ToString()
 082                    .ToArray();
 83#pragma warning restore CS0618
 84            }
 85        }
 086    }
 87
 88    /// <inheritdoc />
 89    protected override ItemUpdateType BeforeSaveInternal(BoxSet item, bool isFullRefresh, ItemUpdateType updateType)
 90    {
 091        var updatedType = base.BeforeSaveInternal(item, isFullRefresh, updateType);
 92
 093        var libraryFolderIds = item.GetLibraryFolderIds();
 94
 095        var itemLibraryFolderIds = item.LibraryFolderIds;
 096        if (itemLibraryFolderIds is null || !libraryFolderIds.SequenceEqual(itemLibraryFolderIds))
 97        {
 098            item.LibraryFolderIds = libraryFolderIds;
 099            updatedType |= ItemUpdateType.MetadataImport;
 100        }
 101
 0102        return updatedType;
 103    }
 104}