2 // System.Web.TraceContext
5 // Patrik Torstensson (Patrik.Torstensson@labs2.com)
6 // Jackson Harper (jackson@ximian.com)
8 // (C) 2002 2003, Patrik Torstensson
9 // Copyright (C) 2003,2005 Novell, Inc (http://www.novell.com)
11 // Permission is hereby granted, free of charge, to any person obtaining
12 // a copy of this software and associated documentation files (the
13 // "Software"), to deal in the Software without restriction, including
14 // without limitation the rights to use, copy, modify, merge, publish,
15 // distribute, sublicense, and/or sell copies of the Software, and to
16 // permit persons to whom the Software is furnished to do so, subject to
17 // the following conditions:
19 // The above copyright notice and this permission notice shall be
20 // included in all copies or substantial portions of the Software.
22 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
23 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
24 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
25 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
26 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
27 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
28 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
31 using System.Collections;
32 using System.Security.Permissions;
35 namespace System.Web {
37 // CAS - no InheritanceDemand here as the class is sealed
38 [AspNetHostingPermission (SecurityAction.LinkDemand, Level = AspNetHostingPermissionLevel.Minimal)]
39 public sealed class TraceContext {
41 TraceManager _traceManager;
47 Hashtable view_states;
50 public TraceContext (HttpContext Context)
53 _Mode = TraceMode.SortByTime;
56 internal bool HaveTrace {
62 public bool IsEnabled {
65 return TraceManager.Enabled;
70 if (value && data == null)
71 data = new TraceData ();
77 TraceManager TraceManager
81 if (_traceManager == null)
82 _traceManager = HttpRuntime.TraceManager;
88 public TraceMode TraceMode {
97 public void Warn(string msg)
99 Write (String.Empty, msg, null, true);
102 public void Warn(string category, string msg)
104 Write (category, msg, null, true);
107 public void Warn (string category, string msg, Exception error)
109 Write (category, msg, error, true);
112 public void Write (string msg)
114 Write (String.Empty, msg, null, false);
117 public void Write (string category, string msg)
119 Write (category, msg, null, false);
122 public void Write (string category, string msg, Exception error)
124 Write (category, msg, error, false);
127 void Write (string category, string msg, Exception error, bool Warning)
132 data = new TraceData ();
133 data.Write (category, msg, error, Warning);
136 public event TraceContextEventHandler TraceFinished;
138 internal void SaveData ()
141 data = new TraceData ();
142 SetRequestDetails ();
143 if (_Context.Handler is Page)
144 data.AddControlTree ((Page) _Context.Handler, view_states, sizes);
149 TraceManager.AddTraceData (data);
153 internal void SaveViewState (Control ctrl, object vs)
155 if (view_states == null)
156 view_states = new Hashtable ();
158 view_states [ctrl] = vs;
161 internal void SaveSize (Control ctrl, int size)
164 sizes = new Hashtable ();
169 internal void Render (HtmlTextWriter output)
173 data.Render (output);
176 void SetRequestDetails ()
178 data.RequestPath = _Context.Request.FilePath;
179 data.SessionID = (_Context.Session != null ? _Context.Session.SessionID : String.Empty);
180 data.RequestType = _Context.Request.RequestType;
181 data.RequestTime = _Context.Timestamp;
182 data.StatusCode = _Context.Response.StatusCode;
183 data.RequestEncoding = _Context.Request.ContentEncoding;
184 data.ResponseEncoding = _Context.Response.ContentEncoding;
189 foreach (string key in _Context.Request.Cookies.Keys)
190 data.AddCookie (key, _Context.Request.Cookies [key].Value);
195 foreach (string key in _Context.Request.Headers.Keys)
196 data.AddHeader (key, _Context.Request.Headers [key]);
199 void AddServerVars ()
201 foreach (string key in _Context.Request.ServerVariables)
202 data.AddServerVar (key, _Context.Request.ServerVariables [key]);