2 // System.Net.HttpListenerContext
5 // Gonzalo Paniagua Javier (gonzalo@novell.com)
7 // Copyright (c) 2005 Novell, Inc. (http://www.novell.com)
9 // Permission is hereby granted, free of charge, to any person obtaining
10 // a copy of this software and associated documentation files (the
11 // "Software"), to deal in the Software without restriction, including
12 // without limitation the rights to use, copy, modify, merge, publish,
13 // distribute, sublicense, and/or sell copies of the Software, and to
14 // permit persons to whom the Software is furnished to do so, subject to
15 // the following conditions:
17 // The above copyright notice and this permission notice shall be
18 // included in all copies or substantial portions of the Software.
20 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
21 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
22 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
23 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
24 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
25 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
26 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
29 #if NET_2_0 && SECURITY_DEP
31 using System.Collections.Specialized;
33 using System.Security.Principal;
35 namespace System.Net {
36 public sealed class HttpListenerContext {
37 HttpListenerRequest request;
38 HttpListenerResponse response;
43 internal HttpListener Listener;
45 internal HttpListenerContext (HttpConnection cnc)
48 request = new HttpListenerRequest (this);
49 response = new HttpListenerResponse (this);
52 internal int ErrorStatus {
53 get { return err_status; }
54 set { err_status = value; }
57 internal string ErrorMessage {
59 set { error = value; }
62 internal bool HaveError {
63 get { return (error != null); }
66 internal HttpConnection Connection {
70 public HttpListenerRequest Request {
71 get { return request; }
74 public HttpListenerResponse Response {
75 get { return response; }
78 public IPrincipal User {
82 internal void ParseAuthentication () {
83 // TODO: Handle NTLM/Digest modes
84 string header = request.Headers ["Authorization"];
86 if (header == null || header.Length < 2)
89 string [] authenticationData = header.Substring (header.IndexOf (':') + 1).Split (new char [] {' '});
91 if (string.Compare (authenticationData [0], "basic", true) == 0) {
92 user = ParseBasicAuthentication (authenticationData [1]);
96 internal IPrincipal ParseBasicAuthentication (string authData) {
98 // Basic AUTH Data is a formatted Base64 String
99 //string domain = null;
101 string password = null;
103 string authString = System.Text.Encoding.Default.GetString (Convert.FromBase64String (authData));
105 // The format is DOMAIN\username:password
106 // Domain is optional
108 pos = authString.IndexOf (':');
110 // parse the password off the end
111 password = authString.Substring (pos+1);
113 // discard the password
114 authString = authString.Substring (0, pos);
116 // check if there is a domain
117 pos = authString.IndexOf ('\\');
120 //domain = authString.Substring (0, pos);
121 user = authString.Substring (pos);
126 HttpListenerBasicIdentity identity = new HttpListenerBasicIdentity (user, password);
127 // TODO: What are the roles MS sets
128 return new GenericPrincipal (identity, new string [0]);
129 } catch (Exception) {
130 // Invalid auth data is swallowed silently