title | layout | permalink | article | deprecated |
---|---|---|---|---|
Howling Errors |
page |
a/howling-errors/ |
true |
true |
ELMAH ships with a module called ErrorTweetModule
that was originally designed to post brief error notifications to a Twitter account. It only made sense, in fact, for a Twitter account where updates were locked away from public view. If the account had a following then those people would receive notifications as well.
ErrorTweetModule
shipped with ELMAH before Twitter service disabled the use of Basic authentication. While ErrorTweetModule
won't work for Twitter anymore, it was developed general enough that you can still use it with custom or other notification services. It's not by chance that the module was named ErrorTweetModule
instead of ErrorTwitterModule
; tweet, in this context, meaning a brief message or update. In this article, you will see how to use ErrorTweetModule
to receive notification on an iPhone or an iPad without writing a single line of code!
ErrorTweetModule
fundamentally takes an unhandled or signaled exception and turns it into an HTTP form post to any URL. Like most other modules in ELMAH, it can be configured with a few options. Out of the box, ErrorTweetModule
is setup to post to Twitter such that all that was left to do in the past (while Twitter still supported Basic authentication) was configuring the user name and password of a Twitter account and one was good to go.
In its default state, the module is configured as if you had the following under elmah
section group in your web.config
:
{% highlight xml %} {% endhighlight %}
Following is a breif explanation of the attributes:
Attribute | Meaning |
---|---|
userName |
User name for (Basic) authentication |
password |
User password for (Basic) authentication |
statusFormat |
Template used to format the tweet, status update or notification message (hereafter referred to as simply tweet) |
maxStatusLength |
Maximum length of the tweet |
ellipsis |
The text that is appended to the tweet if it is clipped, that is, if it exceeds maxStatusLength |
url |
URL where to post the tweet |
formFormat |
Template used to format the HTTP form posted |
Let's see how configuring these attributes, you can use have ErrorTweetModule
send you nearly real-time notifications to a device such as an iPhone or an iPad.
Howl is a Growl application for iPhone and iPad. It sports a simple API using which one can emit notifications with HTTP POST and have them subequently deliviered to your device.
First, you will need to purchase the Howl application for your device:
Next, setup an account from within the application. Make sure that when you setup your account, you supply a valid e-mail address (marked optional in the application but required for posting notifications). Once your e-mail address has been verified, open the web.config
of a web application already using ELMAH. Define the following section under the <sectionGroup>
element for elmah
:
{% highlight xml %}
Next, add the following section under the <elmah>
section group:
{% highlight xml %} {% endhighlight %}
Replace USERNAME
and PASSWORD
in caps above with your Howl account user name and password. You may also want to replace example.com
or other parts of the formFormat
attribute to more meaningful values. See the Howl public notification API for more details and the meaning of the various form fields.
You will then need to register the HTTP module by adding the following element in the <httpModules>
section:
{% highlight xml %} {% endhighlight %}
If you are using IIS 7 or later then you will need the following entry in the <modules>
section:
{% highlight xml %} {% endhighlight %}
That's it! Next time you get an error, you should see a notification appear on your device, similar to screen captures below!
Note that you can also use error filtering together with ErrorTweetModule
. Just make sure that ErrorTweetModule
is registered before ErrorFilterModule
in the modules section.
You can now imagine how you can use ErrorTweetModule
to also send error notifications to a custom in-house service!