<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>The Married Geek &#187; ASP.NET, jQuery, Web, JavaScript, and CSS blog &#187; event handlers</title>
	<atom:link href="http://www.marriedgeek.com/index.php/tag/event-handlers/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.marriedgeek.com</link>
	<description>My wife tolerates my home server</description>
	<lastBuildDate>Fri, 27 Aug 2010 18:25:00 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.0</generator>
		<item>
		<title>Health Monitoring in ASP.NET</title>
		<link>http://www.marriedgeek.com/index.php/2009/08/22/health-monitoring-reporting-in-asp-net/</link>
		<comments>http://www.marriedgeek.com/index.php/2009/08/22/health-monitoring-reporting-in-asp-net/#comments</comments>
		<pubDate>Sat, 22 Aug 2009 17:39:32 +0000</pubDate>
		<dc:creator>_theMarriedGeek</dc:creator>
				<category><![CDATA[ASP.NET and Web]]></category>
		<category><![CDATA[asp.net]]></category>
		<category><![CDATA[custom events]]></category>
		<category><![CDATA[development]]></category>
		<category><![CDATA[event handlers]]></category>
		<category><![CDATA[health monitoring]]></category>
		<category><![CDATA[health reporting]]></category>
		<category><![CDATA[web]]></category>

		<guid isPermaLink="false">http://www.marriedgeek.com/?p=324</guid>
		<description><![CDATA[Unless your code is perfect, you&#8217;re bound to get runtime errors. Exceptions may not get caught, connections may not get closed off, and eventually, at some point, you&#8217;ll divide by 0. While you can&#8217;t prevent them, you can be aware of them using ASP.NET&#8217;s built in health monitoring provider. Health monitoring is configured in the [...]]]></description>
			<content:encoded><![CDATA[<p>Unless your code is perfect, you&#8217;re bound to get runtime errors. Exceptions may not get caught, connections may not get closed off, and eventually, at some point, you&#8217;ll divide by 0. While you can&#8217;t prevent them, you can be aware of them using ASP.NET&#8217;s built in health monitoring provider. Health monitoring is configured in the web.config and can be set to use various types of logging, from writing to a SQL server instance or generating an email, for specific types of errors.</p>
<p>There are several pre-defined events, providers, and rules inside the root web.config file in the same directory as machine.config (not to be confused with the web.config in your application). In the <em>healthMonitoring</em> section you will see several groupings for providers, rules, profiles, and event mappings. For right now, we&#8217;ll focus on <strong>providers</strong>, <strong>rules</strong>, and <strong>eventMappings</strong>. I&#8217;ll discuss how these play into logging events.</p>
<p><strong>Providers </strong><strong>(&lt;providers&gt;)</strong> essentially tell where the log information is going. For example, the provider named <em>EventLogProvider</em> maps to the EventLogWebEventProvider class. As you&#8217;d expect, this provides all those error events you see in your Event Viewer. Similarly, the <em>SqlWebEventProvider </em>allows you to log events to the built in ASP.NET database (ASPNETDB.mdf in your app_data folder or your own SQL Server instance configured using aspnet_regsql.exe). Web can define a custom provider in your application web.config file (or in the root if you want to apply it to all your sites) to, for example, generate and send an email to a recipient containing logged event information. The <em>SimpleMailWebEventProvider</em> does just this. We will define this provider and use this provider in our example below.</p>
<p><strong>Rules</strong><strong> (&lt;rules&gt;)</strong> dictate which event type will use a provider. For example, you can have application errors write to the SQL provider or generate an email using your the email provider mentioned above. The <em>eventName</em> attribute, when adding a rule, specifies the name of the web event to use.  Basically, for each rule, you specify the eventName and the provider. Simple as that.</p>
<p><strong>Event Mappings (&lt;eventMappings&gt;) </strong>are used for mapping event names to provider classes. In the root web.config, you will notice several pre-defined provider names associated with event classes (the <em>type</em> attribute). If you are creating your own web event class (we&#8217;ll cover this in a later post), you may create a name for it and give it a type (your new class). By default, you can leave these alone, as the web events shipped with the framework cover most cases.</p>
<p>There are several event mappings listed, but there are usually one or two which, I feel, would be used in most conditions. First, the <em>All Errors</em> event mapping (using WebBaseErrorEvent) is used for all compilation, runtime, and configuration errors. I have found this to be the most handy. The second is the <em>Failure Audits</em> event (using the WebFailureAuditEvent class), which raises a an application page is accessed using improper credentials. By default, ASP.NET uses the NETWORK SERVICE account to access the file system, the registry, any databases, etc. If incorrect permissions are set in the file system, or malicious code is attempting to access the file system, this event will be raised. One other potentially useful web event is the <em>Infrastructure Error</em> mapping. This web event is raised only for compilation and configuration errors. However, I personally find it less useful, as the <em>All Errors</em> web event covers this.</p>
<p>In this post, I will create a basic health monitoring event handler using theÂ <em>SimpleMailWebEventProvider</em> class to generate an email whenever any runtime error is found on the site. The email, by default, will provide all the information I need to diagnose the error and make corrections. You may customize this email template, but that is another topic.</p>
<p>First, since we&#8217;re using an email provider, we need to configure SMTP settings in the web.config. The <em>SimpleMailWebEventProvider </em>class will use these settings for sending the email. Configure your SMTP settings as follows:</p>
<pre>&lt;configuration&gt;
    ...
    &lt;system.net&gt;
        &lt;mailSettings&gt;
            &lt;smtp deliveryMethod="Network"&gt;
                &lt;network host="<em>SERVER</em>" userName="<em>USERNAME</em>" password="<em>PASSWORD</em>" /&gt;
             &lt;/smtp&gt;
        &lt;/mailSettings&gt;
    &lt;/system.net&gt;
    ...
&lt;/configuration&gt;</pre>
<p>Once that is entered, we can begin enabling the health monitoring features and chose our provider and rules. Again, the purpose is to create an email for all site errors and send them to my email address.</p>
<pre>&lt;system.web&gt;
    ...
    &lt;healthMonitoring enabled="true"&gt;
        &lt;providers&gt;
            &lt;add name="EmailSiteErrors" type="System.Web.Management.SimpleMailWebEventProvider" to="ryan@marriedgeek.com" from="noreply@marriedgeek.com" buffer="false"/&gt;
        &lt;/providers&gt;
        &lt;rules&gt;
            &lt;add name="Email Errors" eventName="All Errors" provider="EmailSiteErrors"/&gt;
        &lt;/rules&gt;
    &lt;/healthMonitoring&gt;
    ...
&lt;/system.web&gt;</pre>
<p>That&#8217;s pretty much it. The ease of configuration and separation of providers and rules makes it a breeze to configure monitoring for your website. If you chose to use a SQL event provider, your logs will be written in the Â provider database configured in your maching.config&#8217;s connection string. You may even have both or as many provider/rule sets as you like.</p>
<p>This is an overview of how to get started with using health monitoring in ASP.NET. To read more about health monitoring, check out the following links:</p>
<ul>
<li><a href="http://forums.asp.net/t/1027461.aspx">Health Monitoring in ASP.NET 2.0</a> (forums.asp.net)</li>
<li><a href="http://msdn.microsoft.com/en-us/library/ms178703(VS.80).aspx">ASP.NET Health Monitoring Overview</a> (msdn.microsoft.com)</li>
</ul>
]]></content:encoded>
			<wfw:commentRss>http://www.marriedgeek.com/index.php/2009/08/22/health-monitoring-reporting-in-asp-net/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Create Custom Event Handlers &amp; Arguments For Controls</title>
		<link>http://www.marriedgeek.com/index.php/2009/07/28/create-custom-event-handlers-and-arguments-controls-delegate-asp-net/</link>
		<comments>http://www.marriedgeek.com/index.php/2009/07/28/create-custom-event-handlers-and-arguments-controls-delegate-asp-net/#comments</comments>
		<pubDate>Wed, 29 Jul 2009 03:37:27 +0000</pubDate>
		<dc:creator>_theMarriedGeek</dc:creator>
				<category><![CDATA[ASP.NET and Web]]></category>
		<category><![CDATA[arguments]]></category>
		<category><![CDATA[asp.net]]></category>
		<category><![CDATA[composite controls]]></category>
		<category><![CDATA[custom control]]></category>
		<category><![CDATA[custom event args]]></category>
		<category><![CDATA[delegates]]></category>
		<category><![CDATA[development]]></category>
		<category><![CDATA[event handlers]]></category>
		<category><![CDATA[web]]></category>

		<guid isPermaLink="false">http://www.marriedgeek.com/?p=275</guid>
		<description><![CDATA[I was hoping to get this post up earlier, but got distracted by a couple of things. First, I jacked up my hand trying to separate my dogs from fighting to the point I couldn&#8217;t even move my ring finger (long story about the dogs, but I love &#8216;em). Second, I started a new job [...]]]></description>
			<content:encoded><![CDATA[<p>I was hoping to get this post up earlier, but got distracted by a couple of things. First, I jacked up my hand trying to separate my dogs from fighting to the point I couldn&#8217;t even move my ring finger (long story about the dogs, but I love &#8216;em). Second, I started a new job at <a href="http://groovecommerce.com" target="_blank">Groove Commerce</a> on Monday. So far, so good. I feel it&#8217;ll keep me on my game and give me some nice challenges ahead.</p>
<p>A few entries ago we talked about custom server controls and mentioned how to structure a composite control to allow the ViewState to &#8220;pick up&#8221; on it&#8217;s post back content so that data isn&#8217;t re-binded with every call. It was a very basic composite control, but it showed how to add native WebControl objects to the Controls tree to create a basic layout without using a .ASCX design file. This type of control can be added to your <em>app_code</em> directory or manually compiled as an assembly and placed into your <em>bin </em>directory. The advantage of the latter is to feasibly add it to your Visual Studio toolbar by loading the assembly. This time, we&#8217;ll add a custom event to our control using a delegate for an event, as well as a custom event argument class to pass along with it.</p>
<p>We&#8217;ll take the code from last time, but add several things which are highlighted in green.</p>
<ul>
<li>A line to declare our event delegate variable and the delegate itself.</li>
<li>A class which will be used for our arguments.</li>
<li>A binded event for the button Click.</li>
<li>A line in the button Click handler to invoke the event delegate.</li>
</ul>
<pre>using System;
using System.Web;
using System.Web.UI.WebControls;
using System.ComponentModel;

namespace RyanControls
{
    public class MyCompositeControl : CompositeControl
    {
        public MyCompositeControl() { }

        <span style="color: #339966;">// Declare the Updating event of delegate type CustomControlUpdateHandler</span>
        <span style="color: #339966;"><strong>public event CustomControlUpdateHandler Updating;</strong></span>

        protected override void CreateChildControls()
        {
            TextBox txtMyData = new TextBox();
            DropDownList drpMyList = new DropDownList();
            Button btnUpdate = new Button() { Text = "Update!" };

            Controls.Add(drpMyList);
            Controls.Add(txtMyData);
            Controls.Add(btnUpdate);

            if (!Page.IsPostBack)
            {
                drpMyList.Items.Add(new ListItem("item 1"));
                drpMyList.Items.Add(new ListItem("item 2"));
                drpMyList.Items.Add(new ListItem("item 3"));
            }

            <span style="color: #339966;">// Add a handler for the button click to launch the Updating event</span>
            <strong><span style="color: #339966;">btnUpdate.Click += new EventHandler(FireEvent);</span></strong>
        }
<strong>
<span style="font-weight: normal;"><span style="color: #339966;">        // The method that handles the Click event from the button
        // and triggers the Updating event by calling the delegate</span></span>
        <span style="color: #339966;">protected void FireEvent(Object s, EventArgs e)
        {</span></strong><span style="color: #339966;">
</span><strong><span style="color: #339966;">            Updating(s, new CustomControlUpdateEventArgs() { SomeData = "The control was updated!" });
        }</span>
<span style="color: #000000; font-weight: normal;">    }</span></strong><span style="color: #339966;"><span style="color: #000000;">
</span><strong>
<span style="font-weight: normal;">    // Our custom event class that inherits EventArgs. You may use
    // EventArgs as the class if you don't have additional data to pass</span></strong><strong>
    public class CustomControlUpdateEventArgs : EventArgs
    {
        public CustomControlUpdateEventArgs() { }
        public String SomeData;
    }

<span style="font-weight: normal;">    // The delegate declaration (or template, as I call it) for the handler</span></strong><strong>
    public delegate void CustomControlUpdateHandler(Object s, CustomControlUpdateEventArgs e);</strong></span>
}</pre>
<p>There you have it. If you place this code into a .CS file inside your app_code directory, you&#8217;ll be able to include the control on your pages. If you compiled it into an assembly, toss it into your <em>bin</em> directory and feel free to add it to your toolbar in VS or VWD.</p>
<pre>&lt;asp:MyCompositeControl runat="server" ID="cntMyControl" OnUpdating="DisplayUpdate" /&gt;</pre>
<p>By assigning an event handler for the Updating event (the page automatically prepends the &#8220;On&#8221; for &#8220;OnUpdating&#8221;) to call a method to handle the update, you can use data contained in the CustomControlUpdateEventArgs object. In this case, there&#8217;s only a public string called <em>SomeData</em>.</p>
<pre>protected void DisplayUpdate(Object s, RyanControls.CustomControlUpdateEventArgs e)
{
    Response.Write(String.Format("&lt;div&gt;From the event handler: {0}&lt;/div&gt;", e.SomeData));
}</pre>
<p>When you run the code and click the button, the method will be invoked and the message displayed. Similarly, you can bind the handler programmaticallyÂ by adding <em>cntMyControl.Updating += new RyanControls.CustomControlUpdateHandler(DisplayUpdate)</em> in your code-behind.</p>
<p><a href="http://www.marriedgeek.com/wp-content/uploads/2009/07/custom_event.JPG"><img class="alignright size-medium wp-image-298" title="custom_event" src="http://www.marriedgeek.com/wp-content/uploads/2009/07/custom_event-300x62.jpg" alt="custom_event" width="300" height="62" /></a></p>
<p>So again, while the code isn&#8217;t really useful, it shows how to create your own event handlers and custom argument class(es) for a composite server control. The point is to be able to create one or more event handlers, as well as combine those with one or more types of event argument classes. The fields of that particular argument class should be specific to that type of event and it is best not to use one custom event args class to satisfy many types of event argsuments, unless the data being passed into your hander functions generic enough to do so.</p>
<p>Happy coding!</p>
]]></content:encoded>
			<wfw:commentRss>http://www.marriedgeek.com/index.php/2009/07/28/create-custom-event-handlers-and-arguments-controls-delegate-asp-net/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
<!-- WP Super Cache is installed but broken. The path to wp-cache-phase1.php in wp-content/advanced-cache.php must be fixed! -->