mirror of
https://github.com/jellyfin/jellyfin.git
synced 2025-07-09 03:04:24 -04:00
Apply review suggestions
This commit is contained in:
parent
08c68eb8dc
commit
2ac095d8cd
@ -90,7 +90,7 @@ namespace MediaBrowser.Providers.Music
|
|||||||
.Select(g => g.Key)
|
.Select(g => g.Key)
|
||||||
.ToArray();
|
.ToArray();
|
||||||
|
|
||||||
updateType |= setProviderIdFromSongs(item, songs, MetadataProvider.MusicBrainzAlbumArtist);
|
updateType |= SetProviderIdFromSongs(item, songs, MetadataProvider.MusicBrainzAlbumArtist);
|
||||||
|
|
||||||
if (!item.AlbumArtists.SequenceEqual(albumArtists, StringComparer.OrdinalIgnoreCase))
|
if (!item.AlbumArtists.SequenceEqual(albumArtists, StringComparer.OrdinalIgnoreCase))
|
||||||
{
|
{
|
||||||
@ -125,12 +125,48 @@ namespace MediaBrowser.Providers.Music
|
|||||||
{
|
{
|
||||||
var updateType = ItemUpdateType.None;
|
var updateType = ItemUpdateType.None;
|
||||||
|
|
||||||
updateType |= setProviderIdFromSongs(item, songs, MetadataProvider.MusicBrainzAlbum);
|
updateType |= SetProviderIdFromSongs(item, songs, MetadataProvider.MusicBrainzAlbum);
|
||||||
updateType |= setProviderIdFromSongs(item, songs, MetadataProvider.MusicBrainzReleaseGroup);
|
updateType |= SetProviderIdFromSongs(item, songs, MetadataProvider.MusicBrainzReleaseGroup);
|
||||||
|
|
||||||
return updateType;
|
return updateType;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private ItemUpdateType SetProviderIdFromSongs(BaseItem item, IReadOnlyList<Audio> songs, MetadataProvider provider)
|
||||||
|
{
|
||||||
|
var ids = songs
|
||||||
|
.Select(i => i.GetProviderId(provider))
|
||||||
|
.GroupBy(i => i)
|
||||||
|
.OrderByDescending(g => g.Count())
|
||||||
|
.Select(g => g.Key)
|
||||||
|
.ToArray();
|
||||||
|
|
||||||
|
var id = item.GetProviderId(provider);
|
||||||
|
if (ids.Any())
|
||||||
|
{
|
||||||
|
var firstId = ids[0];
|
||||||
|
if (!string.IsNullOrEmpty(firstId)
|
||||||
|
&& (string.IsNullOrEmpty(id)
|
||||||
|
|| !id.Equals(firstId, StringComparison.OrdinalIgnoreCase)))
|
||||||
|
{
|
||||||
|
item.SetProviderId(provider, firstId);
|
||||||
|
return ItemUpdateType.MetadataEdit;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return ItemUpdateType.None;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SetProviderId(MusicAlbum sourceItem, MusicAlbum targetItem, MetadataProvider provider)
|
||||||
|
{
|
||||||
|
var source = sourceItem.GetProviderId(provider);
|
||||||
|
var target = targetItem.GetProviderId(provider);
|
||||||
|
if (!string.IsNullOrEmpty(source)
|
||||||
|
&& (string.IsNullOrEmpty(target)
|
||||||
|
|| !target.Equals(source, StringComparison.Ordinal)))
|
||||||
|
{
|
||||||
|
targetItem.SetProviderId(provider, source);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private ItemUpdateType SetPeople(MusicAlbum item)
|
private ItemUpdateType SetPeople(MusicAlbum item)
|
||||||
{
|
{
|
||||||
var updateType = ItemUpdateType.None;
|
var updateType = ItemUpdateType.None;
|
||||||
@ -184,54 +220,18 @@ namespace MediaBrowser.Providers.Music
|
|||||||
|
|
||||||
if (replaceData || string.IsNullOrEmpty(targetItem.GetProviderId(MetadataProvider.MusicBrainzAlbumArtist)))
|
if (replaceData || string.IsNullOrEmpty(targetItem.GetProviderId(MetadataProvider.MusicBrainzAlbumArtist)))
|
||||||
{
|
{
|
||||||
setProviderId(sourceItem, targetItem, MetadataProvider.MusicBrainzAlbumArtist);
|
SetProviderId(sourceItem, targetItem, MetadataProvider.MusicBrainzAlbumArtist);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (replaceData || string.IsNullOrEmpty(targetItem.GetProviderId(MetadataProvider.MusicBrainzAlbum)))
|
if (replaceData || string.IsNullOrEmpty(targetItem.GetProviderId(MetadataProvider.MusicBrainzAlbum)))
|
||||||
{
|
{
|
||||||
setProviderId(sourceItem, targetItem, MetadataProvider.MusicBrainzAlbum);
|
SetProviderId(sourceItem, targetItem, MetadataProvider.MusicBrainzAlbum);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (replaceData || string.IsNullOrEmpty(targetItem.GetProviderId(MetadataProvider.MusicBrainzReleaseGroup)))
|
if (replaceData || string.IsNullOrEmpty(targetItem.GetProviderId(MetadataProvider.MusicBrainzReleaseGroup)))
|
||||||
{
|
{
|
||||||
setProviderId(sourceItem, targetItem, MetadataProvider.MusicBrainzReleaseGroup);
|
SetProviderId(sourceItem, targetItem, MetadataProvider.MusicBrainzReleaseGroup);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setProviderId(MusicAlbum sourceItem, MusicAlbum targetItem, MetadataProvider provider)
|
|
||||||
{
|
|
||||||
var source = sourceItem.GetProviderId(provider);
|
|
||||||
var target = targetItem.GetProviderId(provider);
|
|
||||||
if (!string.IsNullOrEmpty(source)
|
|
||||||
&& (string.IsNullOrEmpty(target)
|
|
||||||
|| !target.Equals(source, StringComparison.Ordinal)))
|
|
||||||
{
|
|
||||||
targetItem.SetProviderId(provider, source);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private ItemUpdateType setProviderIdFromSongs(BaseItem item, IReadOnlyList<Audio> songs, MetadataProvider provider)
|
|
||||||
{
|
|
||||||
var ids = songs
|
|
||||||
.Select(i => i.GetProviderId(provider))
|
|
||||||
.GroupBy(i => i)
|
|
||||||
.OrderByDescending(g => g.Count())
|
|
||||||
.Select(g => g.Key)
|
|
||||||
.ToArray();
|
|
||||||
|
|
||||||
var id = item.GetProviderId(provider);
|
|
||||||
if (ids.Any())
|
|
||||||
{
|
|
||||||
var firstId = ids[0];
|
|
||||||
if (!string.IsNullOrEmpty(firstId)
|
|
||||||
&& (string.IsNullOrEmpty(id)
|
|
||||||
|| !id.Equals(firstId, StringComparison.OrdinalIgnoreCase)))
|
|
||||||
{
|
|
||||||
item.SetProviderId(provider, firstId);
|
|
||||||
return ItemUpdateType.MetadataEdit;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return ItemUpdateType.None;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user