| 
					
				 | 
			
			
				@@ -105,7 +105,7 @@ namespace MediaBrowser.Api.HttpHandlers 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         /// <summary>
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         /// Creates arguments to pass to ffmpeg
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         /// </summary>
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-        private string GetAudioArguments()
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        protected override string GetCommandLineArguments()
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         {
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				             List<string> audioTranscodeParams = new List<string>();
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 
 
			 | 
		
	
	
		
			
				| 
					
				 | 
			
			
				@@ -132,40 +132,6 @@ namespace MediaBrowser.Api.HttpHandlers 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				             return "-i \"" + LibraryItem.Path + "\" -vn " + string.Join(" ", audioTranscodeParams.ToArray()) + " -";
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-        protected async override Task WriteResponseToOutputStream(Stream stream)
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-        {
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            ProcessStartInfo startInfo = new ProcessStartInfo();
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            startInfo.CreateNoWindow = true;
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            startInfo.UseShellExecute = false;
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            startInfo.RedirectStandardOutput = true;
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            startInfo.FileName = ApiService.FFMpegPath;
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            startInfo.WorkingDirectory = ApiService.FFMpegDirectory;
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            startInfo.Arguments = GetAudioArguments();
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            Logger.LogInfo(startInfo.FileName + " " + startInfo.Arguments);
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            Process process = new Process();
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            process.StartInfo = startInfo;
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            try
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            {
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-                process.Start();
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-                await process.StandardOutput.BaseStream.CopyToAsync(stream);
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            catch (Exception ex)
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            {
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-                Logger.LogException(ex);
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            finally
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            {
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-                process.Dispose();
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-            }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				-        }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				     }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				     public abstract class BaseMediaHandler<T> : BaseHandler
 
			 | 
		
	
	
		
			
				| 
					
				 | 
			
			
				@@ -252,7 +218,48 @@ namespace MediaBrowser.Api.HttpHandlers 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				             base.ProcessRequest(ctx);
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        protected abstract string GetCommandLineArguments();
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         protected abstract string GetOutputFormat();
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				         protected abstract bool RequiresConversion();
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        protected async override Task WriteResponseToOutputStream(Stream stream)
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        {
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            ProcessStartInfo startInfo = new ProcessStartInfo();
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            startInfo.CreateNoWindow = true;
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            startInfo.UseShellExecute = false;
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            startInfo.RedirectStandardOutput = true;
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            startInfo.RedirectStandardError = true;
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            startInfo.FileName = ApiService.FFMpegPath;
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            startInfo.WorkingDirectory = ApiService.FFMpegDirectory;
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            startInfo.Arguments = GetCommandLineArguments();
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            Logger.LogInfo(startInfo.FileName + " " + startInfo.Arguments);
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            Process process = new Process();
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            process.StartInfo = startInfo;
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            try
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            {
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                process.Start();
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                // MUST read both stdout and stderr asynchronously or a deadlock may occurr
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                process.BeginErrorReadLine();
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                await process.StandardOutput.BaseStream.CopyToAsync(stream);
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                process.WaitForExit();
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            catch (Exception ex)
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            {
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                Logger.LogException(ex);
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            finally
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            {
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+                process.Dispose();
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+            }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				+        }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				     }
 
			 | 
		
	
		
			
				 | 
				 | 
			
			
				 }
 
			 |