2 // System.Web.ServerVariablesCollection
5 // Alon Gazit (along@mainsoft.com)
6 // Miguel de Icaza (miguel@novell.com)
7 // Gonzalo Paniagua Javier (gonzalo@novell.com)
9 // (c) 2004 Mainsoft, Inc. (http://www.mainsoft.com)
10 // Copyright (C) 2005 Novell, Inc (http://www.novell.com)
12 // Permission is hereby granted, free of charge, to any person obtaining
13 // a copy of this software and associated documentation files (the
14 // "Software"), to deal in the Software without restriction, including
15 // without limitation the rights to use, copy, modify, merge, publish,
16 // distribute, sublicense, and/or sell copies of the Software, and to
17 // permit persons to whom the Software is furnished to do so, subject to
18 // the following conditions:
20 // The above copyright notice and this permission notice shall be
21 // included in all copies or substantial portions of the Software.
23 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
24 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
25 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
26 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
27 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
28 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
29 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
33 using System.Collections;
34 using System.Collections.Specialized;
35 using System.Runtime.Serialization;
36 using System.Globalization;
37 using System.Security.Permissions;
41 class ServerVariablesCollection : BaseParamsCollection
46 public ServerVariablesCollection(HttpRequest request) : base(request)
49 this.request = request;
52 void AppendKeyValue (StringBuilder sb, string key, string value, bool standard)
55 // Standard has HTTP_ prefix, everything is uppercase, has no space
56 // after colon, - is changed to _
58 // Raw is header, colon, space, values, raw.
62 sb.Append (key.ToUpper (CultureInfo.InvariantCulture).Replace ("-", "_"));
72 string Fill (HttpWorkerRequest wr, bool standard)
74 StringBuilder sb = new StringBuilder ();
76 for (int i = 0; i < HttpWorkerRequest.RequestHeaderMaximum; i++){
77 string val = wr.GetKnownRequestHeader (i);
78 if (val == null || val == "")
80 string key = HttpWorkerRequest.GetKnownRequestHeaderName (i);
81 AppendKeyValue (sb, key, val, standard);
83 string [][] other = wr.GetUnknownRequestHeaders ();
85 return sb.ToString ();
87 for (int i = other.Length; i > 0; ){
89 AppendKeyValue (sb, other [i][0], other [i][1], standard);
92 return sb.ToString ();
95 void AddHeaderVariables (HttpWorkerRequest wr)
100 // Add all known headers
101 for (int i = 0; i < HttpWorkerRequest.RequestHeaderMaximum; i++) {
102 hvalue = wr.GetKnownRequestHeader (i);
103 if (null != hvalue && hvalue.Length > 0) {
104 hname = HttpWorkerRequest.GetKnownRequestHeaderName (i);
105 if (null != hname && hname.Length > 0)
106 Add ("HTTP_" + hname.ToUpper (CultureInfo.InvariantCulture).Replace ('-', '_'), hvalue);
110 // Get all other headers
111 string [][] unknown = wr.GetUnknownRequestHeaders ();
112 if (null != unknown) {
113 for (int i = 0; i < unknown.Length; i++) {
114 hname = unknown [i][0];
117 hvalue = unknown [i][1];
118 Add ("HTTP_" + hname.ToUpper (CultureInfo.InvariantCulture).Replace ('-', '_'), hvalue);
123 private void loadServerVariablesCollection()
125 HttpWorkerRequest wr = request.WorkerRequest;
126 if (loaded || (wr == null))
131 Add("ALL_HTTP", Fill (wr, true));
132 Add("ALL_RAW", Fill (wr, false));
134 Add("APPL_MD_PATH", wr.GetServerVariable("APPL_MD_PATH"));
135 Add("APPL_PHYSICAL_PATH", wr.GetServerVariable("APPL_PHYSICAL_PATH"));
137 if (null != request.Context.User && request.Context.User.Identity.IsAuthenticated) {
138 Add ("AUTH_TYPE", request.Context.User.Identity.AuthenticationType);
139 Add ("AUTH_USER", request.Context.User.Identity.Name);
141 Add ("AUTH_TYPE", "");
142 Add ("AUTH_USER", "");
145 Add("AUTH_PASSWORD", wr.GetServerVariable("AUTH_PASSWORD"));
146 Add ("LOGON_USER", wr.GetServerVariable("LOGON_USER"));
147 Add ("REMOTE_USER", wr.GetServerVariable("REMOTE_USER"));
148 Add("CERT_COOKIE", wr.GetServerVariable("CERT_COOKIE"));
149 Add("CERT_FLAGS", wr.GetServerVariable("CERT_FLAGS"));
150 Add("CERT_ISSUER", wr.GetServerVariable("CERT_ISSUER"));
151 Add("CERT_KEYSIZE", wr.GetServerVariable("CERT_KEYSIZE"));
152 Add("CERT_SECRETKEYSIZE", wr.GetServerVariable("CERT_SECRETKEYSIZE"));
153 Add("CERT_SERIALNUMBER", wr.GetServerVariable("CERT_SERIALNUMBER"));
154 Add("CERT_SERVER_ISSUER", wr.GetServerVariable("CERT_SERVER_ISSUER"));
155 Add("CERT_SERVER_SUBJECT", wr.GetServerVariable("CERT_SERVER_SUBJECT"));
156 Add("CERT_SUBJECT", wr.GetServerVariable("CERT_SUBJECT"));
158 string sTmp = wr.GetKnownRequestHeader(HttpWorkerRequest.HeaderContentLength);
160 Add ("CONTENT_LENGTH", sTmp);
161 Add ("CONTENT_TYPE", request.ContentType);
163 Add("GATEWAY_INTERFACE", wr.GetServerVariable("GATEWAY_INTERFACE"));
164 Add("HTTPS", wr.GetServerVariable("HTTPS"));
165 Add("HTTPS_KEYSIZE", wr.GetServerVariable("HTTPS_KEYSIZE"));
166 Add("HTTPS_SECRETKEYSIZE", wr.GetServerVariable("HTTPS_SECRETKEYSIZE"));
167 Add("HTTPS_SERVER_ISSUER", wr.GetServerVariable("HTTPS_SERVER_ISSUER"));
168 Add("HTTPS_SERVER_SUBJECT", wr.GetServerVariable("HTTPS_SERVER_SUBJECT"));
169 Add("INSTANCE_ID", wr.GetServerVariable("INSTANCE_ID"));
170 Add("INSTANCE_META_PATH", wr.GetServerVariable("INSTANCE_META_PATH"));
171 Add("LOCAL_ADDR", wr.GetLocalAddress());
172 Add("PATH_INFO", request.PathInfo);
173 Add("PATH_TRANSLATED", request.PhysicalPath);
174 Add("QUERY_STRING", request.QueryStringRaw);
175 Add("REMOTE_ADDR", request.UserHostAddress);
176 Add("REMOTE_HOST", request.UserHostName);
177 Add("REMOTE_PORT", wr.GetRemotePort ().ToString ());
178 Add("REQUEST_METHOD", request.HttpMethod);
179 Add("SCRIPT_NAME", request.FilePath);
180 Add("SERVER_NAME", wr.GetServerName());
181 Add("SERVER_PORT", wr.GetLocalPort().ToString());
183 Add("SERVER_PORT_SECURE", "1");
185 Add("SERVER_PORT_SECURE", "0");
186 Add("SERVER_PROTOCOL", wr.GetHttpVersion());
187 Add("SERVER_SOFTWARE", wr.GetServerVariable("SERVER_SOFTWARE"));
188 Add ("URL", request.FilePath);
190 AddHeaderVariables (wr);
196 protected override void InsertInfo ()
198 loadServerVariablesCollection ();
201 protected override string InternalGet (string name)
203 if ((name == null) || (this._request == null))
205 name = name.ToUpper (CultureInfo.InvariantCulture);
208 if (null != _request.Context.User && _request.Context.User.Identity.IsAuthenticated)
209 return _request.Context.User.Identity.AuthenticationType;
213 if (null != _request.Context.User && _request.Context.User.Identity.IsAuthenticated)
214 return _request.Context.User.Identity.Name;
218 return this._request.QueryStringRaw;
220 return this._request.PathInfo;
221 case "PATH_TRANSLATED":
222 return this._request.PhysicalPath;
223 case "REQUEST_METHOD":
224 return this._request.HttpMethod;
226 return this._request.UserHostAddress;
228 return this._request.UserHostName;
229 case "REMOTE_ADDRESS":
230 return this._request.UserHostAddress;
232 return this._request.FilePath;
234 return this._request.WorkerRequest.GetLocalAddress ();
235 case "SERVER_PROTOCOL":
236 return _request.WorkerRequest.GetHttpVersion ();
238 return _request.ContentType;
240 return _request.WorkerRequest.GetRemotePort ().ToString ();
242 return _request.WorkerRequest.GetServerName ();
244 return _request.WorkerRequest.GetLocalPort ().ToString ();
245 case "APPL_PHYSICAL_PATH":
246 return _request.WorkerRequest.GetAppPathTranslated ();
248 return (_request.Context.User != null && _request.Context.User.Identity.IsAuthenticated) ?
249 _request.Context.User.Identity.Name :
252 return _request.FilePath;
253 case "SERVER_PORT_SECURE":
254 return (_request.WorkerRequest.IsSecure ()) ? "1" : "0";
256 return Fill (_request.WorkerRequest, true);
258 return Fill (_request.WorkerRequest, false);
259 case "SERVER_SOFTWARE":
261 case "AUTH_PASSWORD":
266 case "CERT_SECRETKEYSIZE":
267 case "CERT_SERIALNUMBER":
268 case "CERT_SERVER_ISSUER":
269 case "CERT_SERVER_SUBJECT":
270 case "GATEWAY_INTERFACE":
272 case "HTTPS_KEYSIZE":
273 case "HTTPS_SECRETKEYSIZE":
274 case "HTTPS_SERVER_ISSUER":
275 case "HTTPS_SERVER_SUBJECT":
277 case "INSTANCE_META_PATH":
281 case "HTTP_ACCEPT_LANGUAGE":
282 case "HTTP_ACCEPT_ENCODING":
283 case "HTTP_CONNECTION":
285 case "HTTP_USER_AGENT":
286 case "HTTP_SOAPACTION":
287 return _request.WorkerRequest.GetServerVariable (name);