|  | @@ -1,4 +1,5 @@
 | 
											
												
													
														|  | -using MediaBrowser.Common.Extensions;
 |  | 
 | 
											
												
													
														|  | 
 |  | +using System.Threading;
 | 
											
												
													
														|  | 
 |  | +using MediaBrowser.Common.Extensions;
 | 
											
												
													
														|  |  using MediaBrowser.Common.IO;
 |  |  using MediaBrowser.Common.IO;
 | 
											
												
													
														|  |  using MediaBrowser.Controller.Channels;
 |  |  using MediaBrowser.Controller.Channels;
 | 
											
												
													
														|  |  using MediaBrowser.Controller.Configuration;
 |  |  using MediaBrowser.Controller.Configuration;
 | 
											
										
											
												
													
														|  | @@ -919,8 +920,12 @@ namespace MediaBrowser.Server.Implementations.Dto
 | 
											
												
													
														|  |                      dto.AlbumPrimaryImageTag = GetImageCacheTag(albumParent, ImageType.Primary);
 |  |                      dto.AlbumPrimaryImageTag = GetImageCacheTag(albumParent, ImageType.Primary);
 | 
											
												
													
														|  |                  }
 |  |                  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -                dto.MediaSources = GetAudioMediaSources(audio);
 |  | 
 | 
											
												
													
														|  |                  dto.MediaSourceCount = 1;
 |  |                  dto.MediaSourceCount = 1;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +                if (fields.Contains(ItemFields.MediaSources))
 | 
											
												
													
														|  | 
 |  | +                {
 | 
											
												
													
														|  | 
 |  | +                    dto.MediaSources = GetMediaSources(audio);
 | 
											
												
													
														|  | 
 |  | +                }
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |              var album = item as MusicAlbum;
 |  |              var album = item as MusicAlbum;
 | 
											
										
											
												
													
														|  | @@ -955,7 +960,7 @@ namespace MediaBrowser.Server.Implementations.Dto
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |                  if (fields.Contains(ItemFields.MediaSources))
 |  |                  if (fields.Contains(ItemFields.MediaSources))
 | 
											
												
													
														|  |                  {
 |  |                  {
 | 
											
												
													
														|  | -                    dto.MediaSources = GetVideoMediaSources(video);
 |  | 
 | 
											
												
													
														|  | 
 |  | +                    dto.MediaSources = GetMediaSources(video);
 | 
											
												
													
														|  |                  }
 |  |                  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |                  if (fields.Contains(ItemFields.Chapters))
 |  |                  if (fields.Contains(ItemFields.Chapters))
 | 
											
										
											
												
													
														|  | @@ -1144,14 +1149,14 @@ namespace MediaBrowser.Server.Implementations.Dto
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |              if (video != null)
 |  |              if (video != null)
 | 
											
												
													
														|  |              {
 |  |              {
 | 
											
												
													
														|  | -                return GetVideoMediaSources(video);
 |  | 
 | 
											
												
													
														|  | 
 |  | +                return video.GetMediaSources(true).ToList();
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |              var audio = item as Audio;
 |  |              var audio = item as Audio;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |              if (audio != null)
 |  |              if (audio != null)
 | 
											
												
													
														|  |              {
 |  |              {
 | 
											
												
													
														|  | -                return GetAudioMediaSources(audio);
 |  | 
 | 
											
												
													
														|  | 
 |  | +                return audio.GetMediaSources(true).ToList();
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |              var result = new List<MediaSourceInfo>
 |  |              var result = new List<MediaSourceInfo>
 | 
											
										
											
												
													
														|  | @@ -1175,131 +1180,6 @@ namespace MediaBrowser.Server.Implementations.Dto
 | 
											
												
													
														|  |              return result;
 |  |              return result;
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -        private List<MediaSourceInfo> GetVideoMediaSources(Video item)
 |  | 
 | 
											
												
													
														|  | -        {
 |  | 
 | 
											
												
													
														|  | -            var result = item.GetAlternateVersions().Select(GetVersionInfo).ToList();
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -            result.Add(GetVersionInfo(item));
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -            return result.OrderBy(i =>
 |  | 
 | 
											
												
													
														|  | -            {
 |  | 
 | 
											
												
													
														|  | -                if (item.VideoType == VideoType.VideoFile)
 |  | 
 | 
											
												
													
														|  | -                {
 |  | 
 | 
											
												
													
														|  | -                    return 0;
 |  | 
 | 
											
												
													
														|  | -                }
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -                return 1;
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -            }).ThenBy(i => i.Video3DFormat.HasValue ? 1 : 0)
 |  | 
 | 
											
												
													
														|  | -            .ThenByDescending(i =>
 |  | 
 | 
											
												
													
														|  | -            {
 |  | 
 | 
											
												
													
														|  | -                var stream = i.VideoStream;
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -                return stream == null || stream.Width == null ? 0 : stream.Width.Value;
 |  | 
 | 
											
												
													
														|  | -            })
 |  | 
 | 
											
												
													
														|  | -            .ToList();
 |  | 
 | 
											
												
													
														|  | -        }
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -        private List<MediaSourceInfo> GetAudioMediaSources(Audio item)
 |  | 
 | 
											
												
													
														|  | -        {
 |  | 
 | 
											
												
													
														|  | -            var result = new List<MediaSourceInfo>
 |  | 
 | 
											
												
													
														|  | -            {
 |  | 
 | 
											
												
													
														|  | -                GetVersionInfo(item)
 |  | 
 | 
											
												
													
														|  | -            };
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -            return result;
 |  | 
 | 
											
												
													
														|  | -        }
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -        private MediaSourceInfo GetVersionInfo(Video i)
 |  | 
 | 
											
												
													
														|  | -        {
 |  | 
 | 
											
												
													
														|  | -            var mediaStreams = _itemRepo.GetMediaStreams(new MediaStreamQuery { ItemId = i.Id }).ToList();
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -            var info = new MediaSourceInfo
 |  | 
 | 
											
												
													
														|  | -            {
 |  | 
 | 
											
												
													
														|  | -                Id = i.Id.ToString("N"),
 |  | 
 | 
											
												
													
														|  | -                IsoType = i.IsoType,
 |  | 
 | 
											
												
													
														|  | -                LocationType = i.LocationType,
 |  | 
 | 
											
												
													
														|  | -                MediaStreams = mediaStreams,
 |  | 
 | 
											
												
													
														|  | -                Name = GetMediaSourceName(i, mediaStreams),
 |  | 
 | 
											
												
													
														|  | -                Path = GetMappedPath(i),
 |  | 
 | 
											
												
													
														|  | -                RunTimeTicks = i.RunTimeTicks,
 |  | 
 | 
											
												
													
														|  | -                Video3DFormat = i.Video3DFormat,
 |  | 
 | 
											
												
													
														|  | -                VideoType = i.VideoType,
 |  | 
 | 
											
												
													
														|  | -                Container = i.Container,
 |  | 
 | 
											
												
													
														|  | -                Size = i.Size,
 |  | 
 | 
											
												
													
														|  | -                Formats = (i.FormatName ?? string.Empty).Split(new[] { ',' }, StringSplitOptions.RemoveEmptyEntries).ToList(),
 |  | 
 | 
											
												
													
														|  | -                Timestamp = i.Timestamp
 |  | 
 | 
											
												
													
														|  | -            };
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -            if (string.IsNullOrEmpty(info.Container))
 |  | 
 | 
											
												
													
														|  | -            {
 |  | 
 | 
											
												
													
														|  | -                if (i.VideoType == VideoType.VideoFile || i.VideoType == VideoType.Iso)
 |  | 
 | 
											
												
													
														|  | -                {
 |  | 
 | 
											
												
													
														|  | -                    var locationType = i.LocationType;
 |  | 
 | 
											
												
													
														|  | -                    if (!string.IsNullOrWhiteSpace(i.Path) && locationType != LocationType.Remote && locationType != LocationType.Virtual)
 |  | 
 | 
											
												
													
														|  | -                    {
 |  | 
 | 
											
												
													
														|  | -                        info.Container = Path.GetExtension(i.Path).TrimStart('.');
 |  | 
 | 
											
												
													
														|  | -                    }
 |  | 
 | 
											
												
													
														|  | -                }
 |  | 
 | 
											
												
													
														|  | -            }
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -            try
 |  | 
 | 
											
												
													
														|  | -            {
 |  | 
 | 
											
												
													
														|  | -                var bitrate = i.TotalBitrate ??
 |  | 
 | 
											
												
													
														|  | -                    info.MediaStreams.Where(m => m.Type != MediaStreamType.Subtitle && !string.Equals(m.Codec, "mjpeg", StringComparison.OrdinalIgnoreCase))
 |  | 
 | 
											
												
													
														|  | -                    .Select(m => m.BitRate ?? 0)
 |  | 
 | 
											
												
													
														|  | -                    .Sum();
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -                if (bitrate > 0)
 |  | 
 | 
											
												
													
														|  | -                {
 |  | 
 | 
											
												
													
														|  | -                    info.Bitrate = bitrate;
 |  | 
 | 
											
												
													
														|  | -                }
 |  | 
 | 
											
												
													
														|  | -            }
 |  | 
 | 
											
												
													
														|  | -            catch (OverflowException ex)
 |  | 
 | 
											
												
													
														|  | -            {
 |  | 
 | 
											
												
													
														|  | -                _logger.ErrorException("Error calculating total bitrate", ex);
 |  | 
 | 
											
												
													
														|  | -            }
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -            return info;
 |  | 
 | 
											
												
													
														|  | -        }
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -        private MediaSourceInfo GetVersionInfo(Audio i)
 |  | 
 | 
											
												
													
														|  | -        {
 |  | 
 | 
											
												
													
														|  | -            var info = new MediaSourceInfo
 |  | 
 | 
											
												
													
														|  | -            {
 |  | 
 | 
											
												
													
														|  | -                Id = i.Id.ToString("N"),
 |  | 
 | 
											
												
													
														|  | -                LocationType = i.LocationType,
 |  | 
 | 
											
												
													
														|  | -                MediaStreams = _itemRepo.GetMediaStreams(new MediaStreamQuery { ItemId = i.Id }).ToList(),
 |  | 
 | 
											
												
													
														|  | -                Name = i.Name,
 |  | 
 | 
											
												
													
														|  | -                Path = GetMappedPath(i),
 |  | 
 | 
											
												
													
														|  | -                RunTimeTicks = i.RunTimeTicks,
 |  | 
 | 
											
												
													
														|  | -                Container = i.Container,
 |  | 
 | 
											
												
													
														|  | -                Size = i.Size,
 |  | 
 | 
											
												
													
														|  | -                Formats = (i.FormatName ?? string.Empty).Split(new[] { ',' }, StringSplitOptions.RemoveEmptyEntries).ToList()
 |  | 
 | 
											
												
													
														|  | -            };
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -            if (string.IsNullOrEmpty(info.Container))
 |  | 
 | 
											
												
													
														|  | -            {
 |  | 
 | 
											
												
													
														|  | -                var locationType = i.LocationType;
 |  | 
 | 
											
												
													
														|  | -                if (!string.IsNullOrWhiteSpace(i.Path) && locationType != LocationType.Remote && locationType != LocationType.Virtual)
 |  | 
 | 
											
												
													
														|  | -                {
 |  | 
 | 
											
												
													
														|  | -                    info.Container = Path.GetExtension(i.Path).TrimStart('.');
 |  | 
 | 
											
												
													
														|  | -                }
 |  | 
 | 
											
												
													
														|  | -            }
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -            var bitrate = i.TotalBitrate ??
 |  | 
 | 
											
												
													
														|  | -                info.MediaStreams.Where(m => m.Type == MediaStreamType.Audio)
 |  | 
 | 
											
												
													
														|  | -                .Select(m => m.BitRate ?? 0)
 |  | 
 | 
											
												
													
														|  | -                .Sum();
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -            if (bitrate > 0)
 |  | 
 | 
											
												
													
														|  | -            {
 |  | 
 | 
											
												
													
														|  | -                info.Bitrate = bitrate;
 |  | 
 | 
											
												
													
														|  | -            }
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -            return info;
 |  | 
 | 
											
												
													
														|  | -        }
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  |          private string GetMappedPath(IHasMetadata item)
 |  |          private string GetMappedPath(IHasMetadata item)
 | 
											
												
													
														|  |          {
 |  |          {
 | 
											
												
													
														|  |              var path = item.Path;
 |  |              var path = item.Path;
 | 
											
										
											
												
													
														|  | @@ -1317,96 +1197,6 @@ namespace MediaBrowser.Server.Implementations.Dto
 | 
											
												
													
														|  |              return path;
 |  |              return path;
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -        private string GetMediaSourceName(Video video, List<MediaStream> mediaStreams)
 |  | 
 | 
											
												
													
														|  | -        {
 |  | 
 | 
											
												
													
														|  | -            var terms = new List<string>();
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -            var videoStream = mediaStreams.FirstOrDefault(i => i.Type == MediaStreamType.Video);
 |  | 
 | 
											
												
													
														|  | -            var audioStream = mediaStreams.FirstOrDefault(i => i.Type == MediaStreamType.Audio);
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -            if (video.Video3DFormat.HasValue)
 |  | 
 | 
											
												
													
														|  | -            {
 |  | 
 | 
											
												
													
														|  | -                terms.Add("3D");
 |  | 
 | 
											
												
													
														|  | -            }
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -            if (video.VideoType == VideoType.BluRay)
 |  | 
 | 
											
												
													
														|  | -            {
 |  | 
 | 
											
												
													
														|  | -                terms.Add("Bluray");
 |  | 
 | 
											
												
													
														|  | -            }
 |  | 
 | 
											
												
													
														|  | -            else if (video.VideoType == VideoType.Dvd)
 |  | 
 | 
											
												
													
														|  | -            {
 |  | 
 | 
											
												
													
														|  | -                terms.Add("DVD");
 |  | 
 | 
											
												
													
														|  | -            }
 |  | 
 | 
											
												
													
														|  | -            else if (video.VideoType == VideoType.HdDvd)
 |  | 
 | 
											
												
													
														|  | -            {
 |  | 
 | 
											
												
													
														|  | -                terms.Add("HD-DVD");
 |  | 
 | 
											
												
													
														|  | -            }
 |  | 
 | 
											
												
													
														|  | -            else if (video.VideoType == VideoType.Iso)
 |  | 
 | 
											
												
													
														|  | -            {
 |  | 
 | 
											
												
													
														|  | -                if (video.IsoType.HasValue)
 |  | 
 | 
											
												
													
														|  | -                {
 |  | 
 | 
											
												
													
														|  | -                    if (video.IsoType.Value == IsoType.BluRay)
 |  | 
 | 
											
												
													
														|  | -                    {
 |  | 
 | 
											
												
													
														|  | -                        terms.Add("Bluray");
 |  | 
 | 
											
												
													
														|  | -                    }
 |  | 
 | 
											
												
													
														|  | -                    else if (video.IsoType.Value == IsoType.Dvd)
 |  | 
 | 
											
												
													
														|  | -                    {
 |  | 
 | 
											
												
													
														|  | -                        terms.Add("DVD");
 |  | 
 | 
											
												
													
														|  | -                    }
 |  | 
 | 
											
												
													
														|  | -                }
 |  | 
 | 
											
												
													
														|  | -                else
 |  | 
 | 
											
												
													
														|  | -                {
 |  | 
 | 
											
												
													
														|  | -                    terms.Add("ISO");
 |  | 
 | 
											
												
													
														|  | -                }
 |  | 
 | 
											
												
													
														|  | -            }
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -            if (videoStream != null)
 |  | 
 | 
											
												
													
														|  | -            {
 |  | 
 | 
											
												
													
														|  | -                if (videoStream.Width.HasValue)
 |  | 
 | 
											
												
													
														|  | -                {
 |  | 
 | 
											
												
													
														|  | -                    if (videoStream.Width.Value >= 3800)
 |  | 
 | 
											
												
													
														|  | -                    {
 |  | 
 | 
											
												
													
														|  | -                        terms.Add("4K");
 |  | 
 | 
											
												
													
														|  | -                    }
 |  | 
 | 
											
												
													
														|  | -                    else if (videoStream.Width.Value >= 1900)
 |  | 
 | 
											
												
													
														|  | -                    {
 |  | 
 | 
											
												
													
														|  | -                        terms.Add("1080P");
 |  | 
 | 
											
												
													
														|  | -                    }
 |  | 
 | 
											
												
													
														|  | -                    else if (videoStream.Width.Value >= 1270)
 |  | 
 | 
											
												
													
														|  | -                    {
 |  | 
 | 
											
												
													
														|  | -                        terms.Add("720P");
 |  | 
 | 
											
												
													
														|  | -                    }
 |  | 
 | 
											
												
													
														|  | -                    else if (videoStream.Width.Value >= 700)
 |  | 
 | 
											
												
													
														|  | -                    {
 |  | 
 | 
											
												
													
														|  | -                        terms.Add("480P");
 |  | 
 | 
											
												
													
														|  | -                    }
 |  | 
 | 
											
												
													
														|  | -                    else
 |  | 
 | 
											
												
													
														|  | -                    {
 |  | 
 | 
											
												
													
														|  | -                        terms.Add("SD");
 |  | 
 | 
											
												
													
														|  | -                    }
 |  | 
 | 
											
												
													
														|  | -                }
 |  | 
 | 
											
												
													
														|  | -            }
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -            if (videoStream != null && !string.IsNullOrWhiteSpace(videoStream.Codec))
 |  | 
 | 
											
												
													
														|  | -            {
 |  | 
 | 
											
												
													
														|  | -                terms.Add(videoStream.Codec.ToUpper());
 |  | 
 | 
											
												
													
														|  | -            }
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -            if (audioStream != null)
 |  | 
 | 
											
												
													
														|  | -            {
 |  | 
 | 
											
												
													
														|  | -                var audioCodec = string.Equals(audioStream.Codec, "dca", StringComparison.OrdinalIgnoreCase)
 |  | 
 | 
											
												
													
														|  | -                    ? audioStream.Profile
 |  | 
 | 
											
												
													
														|  | -                    : audioStream.Codec;
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -                if (!string.IsNullOrEmpty(audioCodec))
 |  | 
 | 
											
												
													
														|  | -                {
 |  | 
 | 
											
												
													
														|  | -                    terms.Add(audioCodec.ToUpper());
 |  | 
 | 
											
												
													
														|  | -                }
 |  | 
 | 
											
												
													
														|  | -            }
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -            return string.Join("/", terms.ToArray());
 |  | 
 | 
											
												
													
														|  | -        }
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  |          private void SetProductionLocations(BaseItem item, BaseItemDto dto)
 |  |          private void SetProductionLocations(BaseItem item, BaseItemDto dto)
 | 
											
												
													
														|  |          {
 |  |          {
 | 
											
												
													
														|  |              var hasProductionLocations = item as IHasProductionLocations;
 |  |              var hasProductionLocations = item as IHasProductionLocations;
 |