You've already forked linux-packaging-mono
							
							
		
			
	
	
		
			249 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
		
		
			
		
	
	
			249 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
|   | //------------------------------------------------------------------------------ | ||
|  | // <copyright file="events.cs" company="Microsoft"> | ||
|  | //     Copyright (c) Microsoft Corporation.  All rights reserved. | ||
|  | // </copyright>                                                                 | ||
|  | //------------------------------------------------------------------------------ | ||
|  | 
 | ||
|  | namespace System.Web.Management { | ||
|  |     using System.Configuration.Provider; | ||
|  |     using System.Collections.Specialized; | ||
|  |     using System.Web.Util; | ||
|  |     using System.Security.Principal; | ||
|  |     using System.Configuration; | ||
|  |     using System.Text; | ||
|  |     using System; | ||
|  |     using System.Globalization; | ||
|  |     using System.Web.UI; | ||
|  |     using System.Security.Permissions; | ||
|  | 
 | ||
|  |     //////////// | ||
|  |     // Events | ||
|  |     //////////// | ||
|  | 
 | ||
|  |     public class WmiWebEventProvider : WebEventProvider { | ||
|  |          | ||
|  |         public override void Initialize(string name, NameValueCollection config) | ||
|  |         { | ||
|  |             Debug.Trace("WmiWebEventProvider", "Initializing: name=" + name); | ||
|  | 
 | ||
|  |             int         hr; | ||
|  |              | ||
|  |             hr = UnsafeNativeMethods.InitializeWmiManager(); | ||
|  |             if (hr != 0) { | ||
|  |                 throw new ConfigurationErrorsException( | ||
|  |                     SR.GetString(SR.Wmi_provider_cant_initialize, "0x" + hr.ToString("X8", CultureInfo.CurrentCulture))); | ||
|  |             } | ||
|  |              | ||
|  |             base.Initialize(name, config); | ||
|  |              | ||
|  |             ProviderUtil.CheckUnrecognizedAttributes(config, name); | ||
|  |         } | ||
|  | 
 | ||
|  |         string WmiFormatTime(DateTime dt) { | ||
|  |             // CIM DATETIME has this format: | ||
|  |             // yyyymmddHHMMSS.mmmmmmsUUU | ||
|  |             // where    s = [+|-} | ||
|  |             //          UUU = Three-digit offset indicating the number of minutes that the  | ||
|  |             //                originating time zone deviates from UTC. | ||
|  | 
 | ||
|  |             StringBuilder sb = new StringBuilder(26); | ||
|  | 
 | ||
|  |             sb.Append(dt.ToString("yyyyMMddHHmmss.ffffff", CultureInfo.InstalledUICulture)); | ||
|  |             double offset = TimeZone.CurrentTimeZone.GetUtcOffset(dt).TotalMinutes; | ||
|  |             if (offset >= 0) { | ||
|  |                 sb.Append('+'); | ||
|  |             } | ||
|  |             sb.Append(offset); | ||
|  | 
 | ||
|  |             return sb.ToString(); | ||
|  |         } | ||
|  | 
 | ||
|  |         void FillBasicWmiDataFields(ref UnsafeNativeMethods.WmiData wmiData, WebBaseEvent eventRaised) { | ||
|  |             WebApplicationInformation       appInfo = WebBaseEvent.ApplicationInformation; | ||
|  |              | ||
|  |             wmiData.eventType = (int)WebBaseEvent.WebEventTypeFromWebEvent(eventRaised); | ||
|  | 
 | ||
|  |             // Note: WMI sint64 requires a string param | ||
|  |              | ||
|  |             // Data contained in WebBaseEvent | ||
|  |             wmiData.eventCode = eventRaised.EventCode; | ||
|  |             wmiData.eventDetailCode = eventRaised.EventDetailCode; | ||
|  |             wmiData.eventTime = WmiFormatTime(eventRaised.EventTime); | ||
|  |             wmiData.eventMessage = eventRaised.Message; | ||
|  |             wmiData.sequenceNumber = eventRaised.EventSequence.ToString(CultureInfo.InstalledUICulture);    | ||
|  |             wmiData.occurrence = eventRaised.EventOccurrence.ToString(CultureInfo.InstalledUICulture);    | ||
|  |             wmiData.eventId = eventRaised.EventID.ToString("N", CultureInfo.InstalledUICulture);    | ||
|  |          | ||
|  |             wmiData.appDomain = appInfo.ApplicationDomain; | ||
|  |             wmiData.trustLevel = appInfo.TrustLevel; | ||
|  |             wmiData.appVirtualPath = appInfo.ApplicationVirtualPath; | ||
|  |             wmiData.appPath = appInfo.ApplicationPath; | ||
|  |             wmiData.machineName = appInfo.MachineName; | ||
|  | 
 | ||
|  |             if (eventRaised.IsSystemEvent) { | ||
|  |                 wmiData.details = String.Empty; | ||
|  |             } | ||
|  |             else { | ||
|  |                 WebEventFormatter   formatter = new WebEventFormatter(); | ||
|  |                 eventRaised.FormatCustomEventDetails(formatter); | ||
|  |                 wmiData.details = formatter.ToString(); | ||
|  |             } | ||
|  |         } | ||
|  | 
 | ||
|  |         void FillRequestWmiDataFields(ref UnsafeNativeMethods.WmiData wmiData, WebRequestInformation reqInfo) { | ||
|  |             string      user; | ||
|  |             string      authType; | ||
|  |             bool        authed; | ||
|  |             IPrincipal  iprincipal = reqInfo.Principal; | ||
|  |              | ||
|  |             if (iprincipal == null) { | ||
|  |                 user = String.Empty; | ||
|  |                 authType = String.Empty; | ||
|  |                 authed = false; | ||
|  |             } | ||
|  |             else { | ||
|  |                 IIdentity    id = iprincipal.Identity; | ||
|  |              | ||
|  |                 user = id.Name; | ||
|  |                 authed = id.IsAuthenticated; | ||
|  |                 authType = id.AuthenticationType; | ||
|  |             } | ||
|  |              | ||
|  |             wmiData.requestUrl = reqInfo.RequestUrl; | ||
|  |             wmiData.requestPath = reqInfo.RequestPath; | ||
|  |             wmiData.userHostAddress = reqInfo.UserHostAddress; | ||
|  |             wmiData.userName = user; | ||
|  |             wmiData.userAuthenticated = authed; | ||
|  |             wmiData.userAuthenticationType = authType; | ||
|  |             wmiData.requestThreadAccountName = reqInfo.ThreadAccountName; | ||
|  |         } | ||
|  | 
 | ||
|  |         void FillErrorWmiDataFields(ref UnsafeNativeMethods.WmiData wmiData, WebThreadInformation threadInfo) { | ||
|  |             wmiData.threadId = threadInfo.ThreadID; | ||
|  |             wmiData.threadAccountName = threadInfo.ThreadAccountName; | ||
|  |             wmiData.stackTrace = threadInfo.StackTrace; | ||
|  |             wmiData.isImpersonating = threadInfo.IsImpersonating; | ||
|  | 
 | ||
|  |         } | ||
|  |          | ||
|  |         public override void ProcessEvent(WebBaseEvent eventRaised) | ||
|  |         { | ||
|  |             Debug.Trace("WmiWebEventProvider", "ProcessEvent: event=" + eventRaised.GetType().Name); | ||
|  |             UnsafeNativeMethods.WmiData     wmiData = new UnsafeNativeMethods.WmiData(); | ||
|  |              | ||
|  |             // Note: WMI sint64 requires a string param | ||
|  |              | ||
|  |             FillBasicWmiDataFields(ref wmiData, eventRaised); | ||
|  |              | ||
|  |             if (eventRaised is WebApplicationLifetimeEvent) { | ||
|  |                 // Nothing special for this class. | ||
|  |             } | ||
|  | 
 | ||
|  |             if (eventRaised is WebManagementEvent) { | ||
|  |                 WebProcessInformation       processEventInfo = ((WebManagementEvent)eventRaised).ProcessInformation; | ||
|  |                  | ||
|  |                 wmiData.processId = processEventInfo.ProcessID; | ||
|  |                 wmiData.processName = processEventInfo.ProcessName; | ||
|  |                 wmiData.accountName = processEventInfo.AccountName; | ||
|  |             } | ||
|  |              | ||
|  |             if (eventRaised is WebRequestEvent) { | ||
|  |                 FillRequestWmiDataFields(ref wmiData, ((WebRequestEvent)eventRaised).RequestInformation); | ||
|  |             } | ||
|  |              | ||
|  |             if (eventRaised is WebAuditEvent) { | ||
|  |                 FillRequestWmiDataFields(ref wmiData, ((WebAuditEvent)eventRaised).RequestInformation); | ||
|  |             } | ||
|  | 
 | ||
|  |             if (eventRaised is WebAuthenticationSuccessAuditEvent) { | ||
|  |                 wmiData.nameToAuthenticate = ((WebAuthenticationSuccessAuditEvent)eventRaised).NameToAuthenticate; | ||
|  |             } | ||
|  |              | ||
|  |             if (eventRaised is WebAuthenticationFailureAuditEvent) { | ||
|  |                 wmiData.nameToAuthenticate = ((WebAuthenticationFailureAuditEvent)eventRaised).NameToAuthenticate; | ||
|  |             } | ||
|  | 
 | ||
|  |             if (eventRaised is WebViewStateFailureAuditEvent) { | ||
|  |                 ViewStateException  vse = ((WebViewStateFailureAuditEvent)eventRaised).ViewStateException; | ||
|  |                 wmiData.exceptionMessage = SR.GetString(vse.ShortMessage); | ||
|  |                 wmiData.remoteAddress = vse.RemoteAddress; | ||
|  |                 wmiData.remotePort = vse.RemotePort; | ||
|  |                 wmiData.userAgent = vse.UserAgent; | ||
|  |                 wmiData.persistedState = vse.PersistedState; | ||
|  |                 wmiData.referer = vse.Referer; | ||
|  |                 wmiData.path = vse.Path; | ||
|  |             } | ||
|  |              | ||
|  |             if (eventRaised is WebHeartbeatEvent) { | ||
|  | #if DBG             | ||
|  |                 try { | ||
|  | #endif                 | ||
|  |                 WebHeartbeatEvent       hbEvent = eventRaised as WebHeartbeatEvent; | ||
|  |                 WebProcessStatistics    procStats = hbEvent.ProcessStatistics; | ||
|  | 
 | ||
|  |                 wmiData.processStartTime = WmiFormatTime(procStats.ProcessStartTime); | ||
|  |                 wmiData.threadCount = procStats.ThreadCount; | ||
|  |                 wmiData.workingSet = procStats.WorkingSet.ToString(CultureInfo.InstalledUICulture); | ||
|  |                 wmiData.peakWorkingSet = procStats.PeakWorkingSet.ToString(CultureInfo.InstalledUICulture); | ||
|  |                 wmiData.managedHeapSize = procStats.ManagedHeapSize.ToString(CultureInfo.InstalledUICulture); | ||
|  |                 wmiData.appdomainCount = procStats.AppDomainCount; | ||
|  |                 wmiData.requestsExecuting = procStats.RequestsExecuting; | ||
|  |                 wmiData.requestsQueued = procStats.RequestsQueued; | ||
|  |                 wmiData.requestsRejected = procStats.RequestsRejected; | ||
|  | #if DBG             | ||
|  |                 } | ||
|  |                 catch (Exception e) { | ||
|  |                     Debug.Trace("WmiWebEventProvider", e.ToString()); | ||
|  |                     throw; | ||
|  |                 } | ||
|  | #endif                 | ||
|  |             } | ||
|  | 
 | ||
|  |             if (eventRaised is WebBaseErrorEvent) { | ||
|  |                 Exception   exception = ((WebBaseErrorEvent)eventRaised).ErrorException; | ||
|  |                 if (exception == null) { | ||
|  |                     wmiData.exceptionType = String.Empty; | ||
|  |                     wmiData.exceptionMessage = String.Empty; | ||
|  |                 } | ||
|  |                 else { | ||
|  |                     wmiData.exceptionType = exception.GetType().Name; | ||
|  |                     wmiData.exceptionMessage = exception.Message; | ||
|  |                 } | ||
|  |             } | ||
|  |              | ||
|  |             if (eventRaised is WebRequestErrorEvent) { | ||
|  |                 WebRequestErrorEvent    reEvent = eventRaised as WebRequestErrorEvent; | ||
|  |                 WebRequestInformation   reqInfo = reEvent.RequestInformation; | ||
|  |                 WebThreadInformation    threadInfo = reEvent.ThreadInformation; | ||
|  | 
 | ||
|  |                 FillRequestWmiDataFields(ref wmiData, reqInfo); | ||
|  |                 FillErrorWmiDataFields(ref wmiData, threadInfo); | ||
|  |             } | ||
|  |              | ||
|  |             if (eventRaised is WebErrorEvent) { | ||
|  |                 WebErrorEvent           eEvent = eventRaised as WebErrorEvent; | ||
|  |                 WebRequestInformation   reqInfo = eEvent.RequestInformation; | ||
|  |                 WebThreadInformation    threadInfo = eEvent.ThreadInformation; | ||
|  |              | ||
|  |                 FillRequestWmiDataFields(ref wmiData, reqInfo); | ||
|  |                 FillErrorWmiDataFields(ref wmiData, threadInfo); | ||
|  |             } | ||
|  | 
 | ||
|  |             int hr = UnsafeNativeMethods.RaiseWmiEvent(ref wmiData, AspCompatApplicationStep.IsInAspCompatMode); | ||
|  |             if (hr != 0) { | ||
|  |                 throw new HttpException(SR.GetString(SR.Wmi_provider_error, "0x" + hr.ToString("X8", CultureInfo.InstalledUICulture))); | ||
|  |             } | ||
|  |              | ||
|  |         } | ||
|  |          | ||
|  | 
 | ||
|  |         public override void Flush() { | ||
|  |         } | ||
|  | 
 | ||
|  | 
 | ||
|  |         public override void Shutdown() { | ||
|  |         } | ||
|  |     } | ||
|  | } | ||
|  | 
 |