Files
linux-packaging-mono/external/aspnetwebstack/src/System.Web.Mvc/HttpHandlerUtil.cs
Jo Shields a575963da9 Imported Upstream version 3.6.0
Former-commit-id: da6be194a6b1221998fc28233f2503bd61dd9d14
2014-08-13 10:39:27 +01:00

94 lines
3.3 KiB
C#

// Copyright (c) Microsoft Corporation. All rights reserved. See License.txt in the project root for license information.
using System.Diagnostics.CodeAnalysis;
using System.Web.Mvc.Properties;
using System.Web.UI;
namespace System.Web.Mvc
{
internal static class HttpHandlerUtil
{
[SuppressMessage("Microsoft.Reliability", "CA2000:Dispose objects before losing scope", Justification = "The Dispose on Page doesn't do anything by default, and we control both of these internal types.")]
public static IHttpHandler WrapForServerExecute(IHttpHandler httpHandler)
{
// Since Server.Execute() doesn't propagate HttpExceptions where the status code is
// anything other than 500, we need to wrap these exceptions ourselves.
IHttpAsyncHandler asyncHandler = httpHandler as IHttpAsyncHandler;
return (asyncHandler != null) ? new ServerExecuteHttpHandlerAsyncWrapper(asyncHandler) : new ServerExecuteHttpHandlerWrapper(httpHandler);
}
private sealed class ServerExecuteHttpHandlerAsyncWrapper : ServerExecuteHttpHandlerWrapper, IHttpAsyncHandler
{
private readonly IHttpAsyncHandler _httpHandler;
public ServerExecuteHttpHandlerAsyncWrapper(IHttpAsyncHandler httpHandler)
: base(httpHandler)
{
_httpHandler = httpHandler;
}
public IAsyncResult BeginProcessRequest(HttpContext context, AsyncCallback cb, object extraData)
{
return Wrap(() => _httpHandler.BeginProcessRequest(context, cb, extraData));
}
public void EndProcessRequest(IAsyncResult result)
{
Wrap(() => _httpHandler.EndProcessRequest(result));
}
}
/// <remarks>
/// Server.Execute() requires that the provided IHttpHandler subclass Page.
/// </remarks>
internal class ServerExecuteHttpHandlerWrapper : Page
{
private readonly IHttpHandler _httpHandler;
public ServerExecuteHttpHandlerWrapper(IHttpHandler httpHandler)
{
_httpHandler = httpHandler;
}
internal IHttpHandler InnerHandler
{
get { return _httpHandler; }
}
public override void ProcessRequest(HttpContext context)
{
Wrap(() => _httpHandler.ProcessRequest(context));
}
protected static void Wrap(Action action)
{
Wrap(delegate
{
action();
return (object)null;
});
}
protected static TResult Wrap<TResult>(Func<TResult> func)
{
try
{
return func();
}
catch (HttpException he)
{
if (he.GetHttpCode() == 500)
{
throw; // doesn't need to be wrapped
}
else
{
HttpException newHe = new HttpException(500, MvcResources.ViewPageHttpHandlerWrapper_ExceptionOccurred, he);
throw newHe;
}
}
}
}
}
}