aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Api/HttpHandlers/MediaHandler.cs
diff options
context:
space:
mode:
authorLukePulverenti Luke Pulverenti luke pulverenti <LukePulverenti Luke Pulverenti luke.pulverenti@gmail.com>2012-07-14 16:45:11 -0400
committerLukePulverenti Luke Pulverenti luke pulverenti <LukePulverenti Luke Pulverenti luke.pulverenti@gmail.com>2012-07-14 16:45:11 -0400
commit2e03cb0916f69b324fe654f92f1642b21eb92005 (patch)
tree5472b527c627a079fcd1b1398cfc8fa8824c0836 /MediaBrowser.Api/HttpHandlers/MediaHandler.cs
parent5f5f2838b1931a2cf426b778755a417cc662b46f (diff)
Improved loading performance even more by switching from XmlDocument to XmlReader. Also added more api improvements.
Diffstat (limited to 'MediaBrowser.Api/HttpHandlers/MediaHandler.cs')
-rw-r--r--MediaBrowser.Api/HttpHandlers/MediaHandler.cs105
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
+ {
+ }
+ }
+
+ }
+}