diff options
Diffstat (limited to 'MediaBrowser.Api/HttpHandlers/MediaHandler.cs')
| -rw-r--r-- | MediaBrowser.Api/HttpHandlers/MediaHandler.cs | 105 |
1 files changed, 105 insertions, 0 deletions
diff --git a/MediaBrowser.Api/HttpHandlers/MediaHandler.cs b/MediaBrowser.Api/HttpHandlers/MediaHandler.cs new file mode 100644 index 000000000..d04ff2199 --- /dev/null +++ b/MediaBrowser.Api/HttpHandlers/MediaHandler.cs @@ -0,0 +1,105 @@ +using System;
+using System.IO;
+using System.IO.Compression;
+using MediaBrowser.Common.Net;
+using MediaBrowser.Model.Entities;
+
+namespace MediaBrowser.Api.HttpHandlers
+{
+ class MediaHandler : Response
+ {
+ public MediaHandler(RequestContext ctx)
+ : base(ctx)
+ {
+ WriteStream = s =>
+ {
+ WriteReponse(s);
+ s.Close();
+ };
+ }
+
+ private string _MediaPath = string.Empty;
+ private string MediaPath
+ {
+ get
+ {
+ if (string.IsNullOrEmpty(_MediaPath))
+ {
+ _MediaPath = GetMediaPath();
+ }
+
+ return _MediaPath;
+ }
+ }
+
+ private string GetMediaPath()
+ {
+ string path = QueryString["path"] ?? string.Empty;
+
+ if (!string.IsNullOrEmpty(path))
+ {
+ return path;
+ }
+
+ BaseItem item = ApiService.GetItemById(QueryString["id"]);
+
+ return item.Path;
+ }
+
+ public override string ContentType
+ {
+ get
+ {
+ // http://www.codingcereal.com/2011/10/an-array-of-45-video-mime-types/
+
+ string extension = Path.GetExtension(MediaPath);
+
+ if (extension.EndsWith("mkv", StringComparison.OrdinalIgnoreCase))
+ {
+ return "video/x-matroska";
+ }
+ else if (extension.EndsWith("avi", StringComparison.OrdinalIgnoreCase))
+ {
+ return "video/avi";
+ }
+ else if (extension.EndsWith("wmv", StringComparison.OrdinalIgnoreCase))
+ {
+ return "video/wmv";
+ }
+ else if (extension.EndsWith("m4v", StringComparison.OrdinalIgnoreCase))
+ {
+ return "video/m4v";
+ }
+ else if (extension.EndsWith("flv", StringComparison.OrdinalIgnoreCase))
+ {
+ return "video/flv";
+ }
+ else if (extension.EndsWith("mov", StringComparison.OrdinalIgnoreCase))
+ {
+ return "video/quicktime";
+ }
+ else if (extension.EndsWith("mp4", StringComparison.OrdinalIgnoreCase))
+ {
+ return "video/mp4";
+ }
+
+ return "video/x-matroska";
+ }
+ }
+
+ private void WriteReponse(Stream stream)
+ {
+ try
+ {
+ using (Stream input = File.OpenRead(MediaPath))
+ {
+ input.CopyTo(stream);
+ }
+ }
+ catch
+ {
+ }
+ }
+
+ }
+}
|
