aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLuke Pulverenti <luke.pulverenti@gmail.com>2014-10-22 01:06:19 -0400
committerLuke Pulverenti <luke.pulverenti@gmail.com>2014-10-22 01:06:19 -0400
commit35f40993b2b85efc6fbb677d373b337aebfe0465 (patch)
treeda64de85c41a850021320dbd17e9686944047507
parent9f3891d418729b9cc1dbdf4e48013f5a0a57639a (diff)
update http server
-rw-r--r--MediaBrowser.Dlna/Profiles/XboxOneProfile.cs2
-rw-r--r--MediaBrowser.Server.Implementations/HttpServer/HttpListenerHost.cs4
-rw-r--r--MediaBrowser.Server.Implementations/HttpServer/RangeRequestWriter.cs59
-rw-r--r--MediaBrowser.Server.Implementations/HttpServer/StreamWriter.cs8
4 files changed, 62 insertions, 11 deletions
diff --git a/MediaBrowser.Dlna/Profiles/XboxOneProfile.cs b/MediaBrowser.Dlna/Profiles/XboxOneProfile.cs
index 8d480e539..fea65438a 100644
--- a/MediaBrowser.Dlna/Profiles/XboxOneProfile.cs
+++ b/MediaBrowser.Dlna/Profiles/XboxOneProfile.cs
@@ -12,8 +12,6 @@ namespace MediaBrowser.Dlna.Profiles
Name = "Xbox One";
TimelineOffsetSeconds = 40;
- RequiresPlainFolders = true;
- RequiresPlainVideoItems = true;
Identification = new DeviceIdentification
{
diff --git a/MediaBrowser.Server.Implementations/HttpServer/HttpListenerHost.cs b/MediaBrowser.Server.Implementations/HttpServer/HttpListenerHost.cs
index 98f895616..0e297816d 100644
--- a/MediaBrowser.Server.Implementations/HttpServer/HttpListenerHost.cs
+++ b/MediaBrowser.Server.Implementations/HttpServer/HttpListenerHost.cs
@@ -205,8 +205,8 @@ namespace MediaBrowser.Server.Implementations.HttpServer
HostContext.Config.HandlerFactoryPath = ListenerRequest.GetHandlerPathIfAny(UrlPrefixes.First());
_listener = _supportsNativeWebSocket && NativeWebSocket.IsSupported
- ? _listener = new HttpListenerServer(_logger, OnRequestReceived)
- //? _listener = new WebSocketSharpListener(_logger, OnRequestReceived)
+ //? _listener = new HttpListenerServer(_logger, OnRequestReceived)
+ ? _listener = new WebSocketSharpListener(_logger, OnRequestReceived)
: _listener = new WebSocketSharpListener(_logger, OnRequestReceived);
_listener.WebSocketHandler = WebSocketHandler;
diff --git a/MediaBrowser.Server.Implementations/HttpServer/RangeRequestWriter.cs b/MediaBrowser.Server.Implementations/HttpServer/RangeRequestWriter.cs
index 7a143c8d9..cdd4c6d7c 100644
--- a/MediaBrowser.Server.Implementations/HttpServer/RangeRequestWriter.cs
+++ b/MediaBrowser.Server.Implementations/HttpServer/RangeRequestWriter.cs
@@ -173,9 +173,64 @@ namespace MediaBrowser.Server.Implementations.HttpServer
ThrottleCallback = ThrottleCallback
};
}
- var task = WriteToAsync(responseStream);
+ WriteToInternal(responseStream);
+ }
+
+ /// <summary>
+ /// Writes to async.
+ /// </summary>
+ /// <param name="responseStream">The response stream.</param>
+ /// <returns>Task.</returns>
+ private void WriteToInternal(Stream responseStream)
+ {
+ try
+ {
+ // Headers only
+ if (IsHeadRequest)
+ {
+ return;
+ }
+
+ using (var source = SourceStream)
+ {
+ // If the requested range is "0-", we can optimize by just doing a stream copy
+ if (RangeEnd >= TotalContentLength - 1)
+ {
+ source.CopyTo(responseStream);
+ }
+ else
+ {
+ CopyToInternal(source, responseStream, Convert.ToInt32(RangeLength));
+ }
+ }
+ }
+ finally
+ {
+ if (OnComplete != null)
+ {
+ OnComplete();
+ }
+ }
+ }
- Task.WaitAll(task);
+ private void CopyToInternal(Stream source, Stream destination, int copyLength)
+ {
+ const int bufferSize = 81920;
+ var array = new byte[bufferSize];
+ int count;
+ while ((count = source.Read(array, 0, array.Length)) != 0)
+ {
+ var bytesToCopy = Math.Min(count, copyLength);
+
+ destination.Write(array, 0, bytesToCopy);
+
+ copyLength -= bytesToCopy;
+
+ if (copyLength <= 0)
+ {
+ break;
+ }
+ }
}
/// <summary>
diff --git a/MediaBrowser.Server.Implementations/HttpServer/StreamWriter.cs b/MediaBrowser.Server.Implementations/HttpServer/StreamWriter.cs
index 1ca5f1204..29b703e25 100644
--- a/MediaBrowser.Server.Implementations/HttpServer/StreamWriter.cs
+++ b/MediaBrowser.Server.Implementations/HttpServer/StreamWriter.cs
@@ -91,9 +91,7 @@ namespace MediaBrowser.Server.Implementations.HttpServer
ThrottleCallback = ThrottleCallback
};
}
- var task = WriteToAsync(responseStream);
-
- Task.WaitAll(task);
+ WriteToAsync(responseStream);
}
/// <summary>
@@ -101,13 +99,13 @@ namespace MediaBrowser.Server.Implementations.HttpServer
/// </summary>
/// <param name="responseStream">The response stream.</param>
/// <returns>Task.</returns>
- private async Task WriteToAsync(Stream responseStream)
+ private void WriteToAsync(Stream responseStream)
{
try
{
using (var src = SourceStream)
{
- await src.CopyToAsync(responseStream).ConfigureAwait(false);
+ src.CopyTo(responseStream);
}
}
catch (Exception ex)