forked from Sustainsys/Saml2
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathHttpRequestBaseExtensions.cs
74 lines (68 loc) · 2.91 KB
/
HttpRequestBaseExtensions.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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
using Sustainsys.Saml2.WebSso;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Security.Claims;
using System.Text;
using System.Threading.Tasks;
using System.Web;
using System.Web.Security;
namespace Sustainsys.Saml2.HttpModule
{
/// <summary>
/// Static class that hold extension methods for <see cref="HttpRequestBase"/>.
/// </summary>
public static class HttpRequestBaseExtensions
{
/// <summary>
/// Purpose string used with data protection.
/// </summary>
public const string ProtectionPurpose = "Sustainsys.Saml2";
/// <summary>
/// Extension method to convert a HttpRequestBase to a HttpRequestData.
/// </summary>
/// <param name="requestBase">The request object used to populate the <c>HttpRequestData</c>.</param>
/// <returns>The <c>HttpRequestData</c> object that has been populated by the request.</returns>
public static HttpRequestData ToHttpRequestData(this HttpRequestBase requestBase)
{
return requestBase.ToHttpRequestData(false);
}
/// <summary>
/// Extension method to convert a HttpRequestBase to a HttpRequestData.
/// </summary>
/// <param name="requestBase">The request object used to populate the <c>HttpRequestData</c>.</param>
/// <param name="ignoreCookies">Ignore cookies when extracting data.
/// This is useful for the stub idp that might see the relay state
/// and the requester's cookie, but shouldn't try to decrypt it.</param>
/// <returns>The <c>HttpRequestData</c> object that has been populated by the request.</returns>
public static HttpRequestData ToHttpRequestData(
this HttpRequestBase requestBase,
bool ignoreCookies)
{
if (requestBase == null)
{
throw new ArgumentNullException(nameof(requestBase));
}
var cookies = ignoreCookies
? Enumerable.Empty<KeyValuePair<string, string>>()
: GetCookies(requestBase);
return new HttpRequestData(
requestBase.HttpMethod,
requestBase.Url,
requestBase.ApplicationPath,
requestBase.Form.Cast<string>().Select((de, i) =>
new KeyValuePair<string, IEnumerable<string>>(de, ((string)requestBase.Form[i]).Split(','))),
cookies,
v => MachineKey.Unprotect(v, ProtectionPurpose),
ClaimsPrincipal.Current);
}
private static IEnumerable<KeyValuePair<string, string>> GetCookies(HttpRequestBase requestBase)
{
for (int i = 0; i < requestBase.Cookies.Count; i++)
{
var cookie = requestBase.Cookies[i];
yield return new KeyValuePair<string, string>(cookie.Name, cookie.Value);
}
}
}
}