-
Notifications
You must be signed in to change notification settings - Fork 1.3k
/
Copy pathHttpTaskAsyncHandler.cs
48 lines (39 loc) · 1.85 KB
/
HttpTaskAsyncHandler.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
//------------------------------------------------------------------------------
// <copyright file="HttpTaskAsyncHandler.cs" company="Microsoft">
// Copyright (c) Microsoft Corporation. All rights reserved.
// </copyright>
//------------------------------------------------------------------------------
/*
* Assists in converting an HTTP Handler written using the Task Asynchronous Pattern to an IHttpAsyncHandler.
*
* Copyright (c) 2010 Microsoft Corporation
*/
namespace System.Web {
using System;
using System.ComponentModel;
using System.Threading.Tasks;
public abstract class HttpTaskAsyncHandler : IHttpAsyncHandler {
public virtual bool IsReusable {
get {
// Default implementation - can be overridden by developer.
return false;
}
}
[EditorBrowsable(EditorBrowsableState.Never)]
public virtual void ProcessRequest(HttpContext context) {
// Default implementation is that this isn't synchronously callable - can be overridden by developer.
string errorMessage = SR.GetString(SR.HttpTaskAsyncHandler_CannotExecuteSynchronously, GetType());
throw new NotSupportedException(errorMessage);
}
// This is the method we actually expect developers to override.
public abstract Task ProcessRequestAsync(HttpContext context);
#region IHttpAsyncHandler methods
IAsyncResult IHttpAsyncHandler.BeginProcessRequest(HttpContext context, AsyncCallback cb, object extraData) {
return TaskAsyncHelper.BeginTask(() => ProcessRequestAsync(context), cb, extraData);
}
void IHttpAsyncHandler.EndProcessRequest(IAsyncResult result) {
TaskAsyncHelper.EndTask(result);
}
#endregion
}
}