| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197 | 
							- using MediaBrowser.Controller.Library;
 
- using MediaBrowser.Controller.MediaEncoding;
 
- using MediaBrowser.Model.Dlna;
 
- using MediaBrowser.Model.Drawing;
 
- using MediaBrowser.Model.Dto;
 
- using MediaBrowser.Model.Entities;
 
- using MediaBrowser.Model.IO;
 
- using MediaBrowser.Model.Logging;
 
- using MediaBrowser.Model.MediaInfo;
 
- using MediaBrowser.Model.Net;
 
- using System;
 
- using System.Collections.Generic;
 
- using System.IO;
 
- using System.Linq;
 
- using System.Threading;
 
- using System.Threading.Tasks;
 
- namespace MediaBrowser.MediaEncoding.Encoder
 
- {
 
-     public class EncodingJob : EncodingJobInfo, IDisposable
 
-     {
 
-         public bool HasExited { get; internal set; }
 
-         public bool IsCancelled { get; internal set; }
 
-         public Stream LogFileStream { get; set; }
 
-         public IProgress<double> Progress { get; set; }
 
-         public TaskCompletionSource<bool> TaskCompletionSource;
 
-         public EncodingJobOptions Options
 
-         {
 
-             get { return (EncodingJobOptions) BaseRequest; }
 
-             set { BaseRequest = value; }
 
-         }
 
-         public string Id { get; set; }
 
-         public string MimeType { get; set; }
 
-         public bool EstimateContentLength { get; set; }
 
-         public TranscodeSeekInfo TranscodeSeekInfo { get; set; }
 
-         public long? EncodingDurationTicks { get; set; }
 
-         public string ItemType { get; set; }
 
-         public string GetMimeType(string outputPath)
 
-         {
 
-             if (!string.IsNullOrEmpty(MimeType))
 
-             {
 
-                 return MimeType;
 
-             }
 
-             return MimeTypes.GetMimeType(outputPath);
 
-         }
 
-         private readonly ILogger _logger;
 
-         private readonly IMediaSourceManager _mediaSourceManager;
 
-         public EncodingJob(ILogger logger, IMediaSourceManager mediaSourceManager) : 
 
-             base(logger, TranscodingJobType.Progressive)
 
-         {
 
-             _logger = logger;
 
-             _mediaSourceManager = mediaSourceManager;
 
-             Id = Guid.NewGuid().ToString("N");
 
-             _logger = logger;
 
-             TaskCompletionSource = new TaskCompletionSource<bool>();
 
-         }
 
-         public void Dispose()
 
-         {
 
-             DisposeLiveStream();
 
-             DisposeLogStream();
 
-             DisposeIsoMount();
 
-         }
 
-         private void DisposeLogStream()
 
-         {
 
-             if (LogFileStream != null)
 
-             {
 
-                 try
 
-                 {
 
-                     LogFileStream.Dispose();
 
-                 }
 
-                 catch (Exception ex)
 
-                 {
 
-                     _logger.ErrorException("Error disposing log stream", ex);
 
-                 }
 
-                 LogFileStream = null;
 
-             }
 
-         }
 
-         private async void DisposeLiveStream()
 
-         {
 
-             if (MediaSource.RequiresClosing && string.IsNullOrWhiteSpace(Options.LiveStreamId) && !string.IsNullOrWhiteSpace(MediaSource.LiveStreamId))
 
-             {
 
-                 try
 
-                 {
 
-                     await _mediaSourceManager.CloseLiveStream(MediaSource.LiveStreamId).ConfigureAwait(false);
 
-                 }
 
-                 catch (Exception ex)
 
-                 {
 
-                     _logger.ErrorException("Error closing media source", ex);
 
-                 }
 
-             }
 
-         }
 
-         public string OutputFilePath { get; set; }
 
-         public string ActualOutputVideoCodec
 
-         {
 
-             get
 
-             {
 
-                 var codec = OutputVideoCodec;
 
-                 if (string.Equals(codec, "copy", StringComparison.OrdinalIgnoreCase))
 
-                 {
 
-                     var stream = VideoStream;
 
-                     if (stream != null)
 
-                     {
 
-                         return stream.Codec;
 
-                     }
 
-                     return null;
 
-                 }
 
-                 return codec;
 
-             }
 
-         }
 
-         public string ActualOutputAudioCodec
 
-         {
 
-             get
 
-             {
 
-                 var codec = OutputAudioCodec;
 
-                 if (string.Equals(codec, "copy", StringComparison.OrdinalIgnoreCase))
 
-                 {
 
-                     var stream = AudioStream;
 
-                     if (stream != null)
 
-                     {
 
-                         return stream.Codec;
 
-                     }
 
-                     return null;
 
-                 }
 
-                 return codec;
 
-             }
 
-         }
 
-         public override void ReportTranscodingProgress(TimeSpan? transcodingPosition, float? framerate, double? percentComplete, long? bytesTranscoded, int? bitRate)
 
-         {
 
-             var ticks = transcodingPosition.HasValue ? transcodingPosition.Value.Ticks : (long?)null;
 
-             //    job.Framerate = framerate;
 
-             if (!percentComplete.HasValue && ticks.HasValue && RunTimeTicks.HasValue)
 
-             {
 
-                 var pct = ticks.Value / RunTimeTicks.Value;
 
-                 percentComplete = pct * 100;
 
-             }
 
-             if (percentComplete.HasValue)
 
-             {
 
-                 Progress.Report(percentComplete.Value);
 
-             }
 
-             //    job.TranscodingPositionTicks = ticks;
 
-             //    job.BytesTranscoded = bytesTranscoded;
 
-             var deviceId = Options.DeviceId;
 
-             if (!string.IsNullOrWhiteSpace(deviceId))
 
-             {
 
-                 var audioCodec = ActualOutputVideoCodec;
 
-                 var videoCodec = ActualOutputVideoCodec;
 
-                 //    SessionManager.ReportTranscodingInfo(deviceId, new TranscodingInfo
 
-                 //    {
 
-                 //        Bitrate = job.TotalOutputBitrate,
 
-                 //        AudioCodec = audioCodec,
 
-                 //        VideoCodec = videoCodec,
 
-                 //        Container = job.Options.OutputContainer,
 
-                 //        Framerate = framerate,
 
-                 //        CompletionPercentage = percentComplete,
 
-                 //        Width = job.OutputWidth,
 
-                 //        Height = job.OutputHeight,
 
-                 //        AudioChannels = job.OutputAudioChannels,
 
-                 //        IsAudioDirect = string.Equals(job.OutputAudioCodec, "copy", StringComparison.OrdinalIgnoreCase),
 
-                 //        IsVideoDirect = string.Equals(job.OutputVideoCodec, "copy", StringComparison.OrdinalIgnoreCase)
 
-                 //    });
 
-             }
 
-         }
 
-     }
 
- }
 
 
  |