|
@@ -81,6 +81,7 @@ namespace MediaBrowser.Providers.Plugins.Tmdb.TV
|
|
|
public async Task<MetadataResult<Episode>> GetMetadata(EpisodeInfo info, CancellationToken cancellationToken)
|
|
|
{
|
|
|
var metadataResult = new MetadataResult<Episode>();
|
|
|
+ var config = Plugin.Instance.Configuration;
|
|
|
|
|
|
// Allowing this will dramatically increase scan times
|
|
|
if (info.IsMissingEpisode)
|
|
@@ -206,52 +207,106 @@ namespace MediaBrowser.Providers.Plugins.Tmdb.TV
|
|
|
|
|
|
if (credits?.Cast is not null)
|
|
|
{
|
|
|
- foreach (var actor in credits.Cast.OrderBy(a => a.Order).Take(Plugin.Instance.Configuration.MaxCastMembers))
|
|
|
+ var castQuery = config.HideMissingCastMembers
|
|
|
+ ? credits.Cast.Where(a => !string.IsNullOrEmpty(a.ProfilePath)).OrderBy(a => a.Order)
|
|
|
+ : credits.Cast.OrderBy(a => a.Order);
|
|
|
+
|
|
|
+ foreach (var actor in castQuery.Take(config.MaxCastMembers))
|
|
|
{
|
|
|
- metadataResult.AddPerson(new PersonInfo
|
|
|
+ if (string.IsNullOrWhiteSpace(actor.Name))
|
|
|
+ {
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+
|
|
|
+ var personInfo = new PersonInfo
|
|
|
{
|
|
|
Name = actor.Name.Trim(),
|
|
|
- Role = actor.Character.Trim(),
|
|
|
+ Role = actor.Character?.Trim() ?? string.Empty,
|
|
|
Type = PersonKind.Actor,
|
|
|
- SortOrder = actor.Order
|
|
|
- });
|
|
|
+ SortOrder = actor.Order,
|
|
|
+ ImageUrl = _tmdbClientManager.GetProfileUrl(actor.ProfilePath)
|
|
|
+ };
|
|
|
+
|
|
|
+ if (actor.Id > 0)
|
|
|
+ {
|
|
|
+ personInfo.SetProviderId(MetadataProvider.Tmdb, actor.Id.ToString(CultureInfo.InvariantCulture));
|
|
|
+ }
|
|
|
+
|
|
|
+ metadataResult.AddPerson(personInfo);
|
|
|
}
|
|
|
}
|
|
|
|
|
|
if (credits?.GuestStars is not null)
|
|
|
{
|
|
|
- foreach (var guest in credits.GuestStars.OrderBy(a => a.Order).Take(Plugin.Instance.Configuration.MaxCastMembers))
|
|
|
+ var guestQuery = config.HideMissingCastMembers
|
|
|
+ ? credits.GuestStars.Where(a => !string.IsNullOrEmpty(a.ProfilePath)).OrderBy(a => a.Order)
|
|
|
+ : credits.GuestStars.OrderBy(a => a.Order);
|
|
|
+
|
|
|
+ foreach (var guest in guestQuery.Take(config.MaxCastMembers))
|
|
|
{
|
|
|
- metadataResult.AddPerson(new PersonInfo
|
|
|
+ if (string.IsNullOrWhiteSpace(guest.Name))
|
|
|
+ {
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+
|
|
|
+ var personInfo = new PersonInfo
|
|
|
{
|
|
|
Name = guest.Name.Trim(),
|
|
|
- Role = guest.Character.Trim(),
|
|
|
+ Role = guest.Character?.Trim() ?? string.Empty,
|
|
|
Type = PersonKind.GuestStar,
|
|
|
- SortOrder = guest.Order
|
|
|
- });
|
|
|
+ SortOrder = guest.Order,
|
|
|
+ ImageUrl = _tmdbClientManager.GetProfileUrl(guest.ProfilePath)
|
|
|
+ };
|
|
|
+
|
|
|
+ if (guest.Id > 0)
|
|
|
+ {
|
|
|
+ personInfo.SetProviderId(MetadataProvider.Tmdb, guest.Id.ToString(CultureInfo.InvariantCulture));
|
|
|
+ }
|
|
|
+
|
|
|
+ metadataResult.AddPerson(personInfo);
|
|
|
}
|
|
|
}
|
|
|
|
|
|
- // and the rest from crew
|
|
|
if (credits?.Crew is not null)
|
|
|
{
|
|
|
- foreach (var person in credits.Crew)
|
|
|
+ var crewQuery = credits.Crew
|
|
|
+ .Select(crewMember => new
|
|
|
+ {
|
|
|
+ CrewMember = crewMember,
|
|
|
+ PersonType = TmdbUtils.MapCrewToPersonType(crewMember)
|
|
|
+ })
|
|
|
+ .Where(entry =>
|
|
|
+ TmdbUtils.WantedCrewKinds.Contains(entry.PersonType) ||
|
|
|
+ TmdbUtils.WantedCrewTypes.Contains(entry.CrewMember.Job ?? string.Empty, StringComparison.OrdinalIgnoreCase));
|
|
|
+
|
|
|
+ if (config.HideMissingCrewMembers)
|
|
|
+ {
|
|
|
+ crewQuery = crewQuery.Where(entry => !string.IsNullOrEmpty(entry.CrewMember.ProfilePath));
|
|
|
+ }
|
|
|
+
|
|
|
+ foreach (var entry in crewQuery.Take(config.MaxCrewMembers))
|
|
|
{
|
|
|
- // Normalize this
|
|
|
- var type = TmdbUtils.MapCrewToPersonType(person);
|
|
|
+ var crewMember = entry.CrewMember;
|
|
|
|
|
|
- if (!TmdbUtils.WantedCrewKinds.Contains(type)
|
|
|
- && !TmdbUtils.WantedCrewTypes.Contains(person.Job ?? string.Empty, StringComparison.OrdinalIgnoreCase))
|
|
|
+ if (string.IsNullOrWhiteSpace(crewMember.Name))
|
|
|
{
|
|
|
continue;
|
|
|
}
|
|
|
|
|
|
- metadataResult.AddPerson(new PersonInfo
|
|
|
+ var personInfo = new PersonInfo
|
|
|
{
|
|
|
- Name = person.Name.Trim(),
|
|
|
- Role = person.Job?.Trim(),
|
|
|
- Type = type
|
|
|
- });
|
|
|
+ Name = crewMember.Name.Trim(),
|
|
|
+ Role = crewMember.Job?.Trim() ?? string.Empty,
|
|
|
+ Type = entry.PersonType,
|
|
|
+ ImageUrl = _tmdbClientManager.GetProfileUrl(crewMember.ProfilePath)
|
|
|
+ };
|
|
|
+
|
|
|
+ if (crewMember.Id > 0)
|
|
|
+ {
|
|
|
+ personInfo.SetProviderId(MetadataProvider.Tmdb, crewMember.Id.ToString(CultureInfo.InvariantCulture));
|
|
|
+ }
|
|
|
+
|
|
|
+ metadataResult.AddPerson(personInfo);
|
|
|
}
|
|
|
}
|
|
|
|