diff options
| author | stefan <stefan@hegedues.at> | 2018-09-12 19:26:21 +0200 |
|---|---|---|
| committer | stefan <stefan@hegedues.at> | 2018-09-12 19:26:21 +0200 |
| commit | 48facb797ed912e4ea6b04b17d1ff190ac2daac4 (patch) | |
| tree | 8dae77a31670a888d733484cb17dd4077d5444e8 /SocketHttpListener/Net/HttpListenerContext.Managed.cs | |
| parent | c32d8656382a0eacb301692e0084377fc433ae9b (diff) | |
Update to 3.5.2 and .net core 2.1
Diffstat (limited to 'SocketHttpListener/Net/HttpListenerContext.Managed.cs')
| -rw-r--r-- | SocketHttpListener/Net/HttpListenerContext.Managed.cs | 100 |
1 files changed, 100 insertions, 0 deletions
diff --git a/SocketHttpListener/Net/HttpListenerContext.Managed.cs b/SocketHttpListener/Net/HttpListenerContext.Managed.cs new file mode 100644 index 000000000..db795f742 --- /dev/null +++ b/SocketHttpListener/Net/HttpListenerContext.Managed.cs @@ -0,0 +1,100 @@ +using System.ComponentModel; +using System.Security.Principal; +using System.Text; +using System.Threading.Tasks; +using System; +using MediaBrowser.Model.Text; +using SocketHttpListener.Net.WebSockets; + +namespace SocketHttpListener.Net +{ + public sealed unsafe partial class HttpListenerContext + { + private HttpConnection _connection; + + internal HttpListenerContext(HttpConnection connection, ITextEncoding textEncoding) + { + _connection = connection; + _response = new HttpListenerResponse(this, textEncoding); + Request = new HttpListenerRequest(this); + ErrorStatus = 400; + } + + internal int ErrorStatus { get; set; } + + internal string ErrorMessage { get; set; } + + internal bool HaveError => ErrorMessage != null; + + internal HttpConnection Connection => _connection; + + internal void ParseAuthentication(System.Net.AuthenticationSchemes expectedSchemes) + { + if (expectedSchemes == System.Net.AuthenticationSchemes.Anonymous) + return; + + string header = Request.Headers["Authorization"]; + if (string.IsNullOrEmpty(header)) + return; + + if (IsBasicHeader(header)) + { + _user = ParseBasicAuthentication(header.Substring(AuthenticationTypes.Basic.Length + 1)); + } + } + + internal IPrincipal ParseBasicAuthentication(string authData) => + TryParseBasicAuth(authData, out HttpStatusCode errorCode, out string username, out string password) ? + new GenericPrincipal(new HttpListenerBasicIdentity(username, password), Array.Empty<string>()) : + null; + + internal static bool IsBasicHeader(string header) => + header.Length >= 6 && + header[5] == ' ' && + string.Compare(header, 0, AuthenticationTypes.Basic, 0, 5, StringComparison.OrdinalIgnoreCase) == 0; + + internal static bool TryParseBasicAuth(string headerValue, out HttpStatusCode errorCode, out string username, out string password) + { + errorCode = HttpStatusCode.OK; + username = password = null; + try + { + if (string.IsNullOrWhiteSpace(headerValue)) + { + return false; + } + + string authString = Encoding.UTF8.GetString(Convert.FromBase64String(headerValue)); + int colonPos = authString.IndexOf(':'); + if (colonPos < 0) + { + // username must be at least 1 char + errorCode = HttpStatusCode.BadRequest; + return false; + } + + username = authString.Substring(0, colonPos); + password = authString.Substring(colonPos + 1); + return true; + } + catch + { + errorCode = HttpStatusCode.InternalServerError; + return false; + } + } + + public Task<HttpListenerWebSocketContext> AcceptWebSocketAsync(string subProtocol, int receiveBufferSize, TimeSpan keepAliveInterval) + { + return HttpWebSocket.AcceptWebSocketAsyncCore(this, subProtocol, receiveBufferSize, keepAliveInterval); + } + + [EditorBrowsable(EditorBrowsableState.Never)] + public Task<HttpListenerWebSocketContext> AcceptWebSocketAsync(string subProtocol, int receiveBufferSize, TimeSpan keepAliveInterval, ArraySegment<byte> internalBuffer) + { + WebSocketValidate.ValidateArraySegment(internalBuffer, nameof(internalBuffer)); + HttpWebSocket.ValidateOptions(subProtocol, receiveBufferSize, HttpWebSocket.MinSendBufferSize, keepAliveInterval); + return HttpWebSocket.AcceptWebSocketAsyncCore(this, subProtocol, receiveBufferSize, keepAliveInterval, internalBuffer); + } + } +} |
