Perhaps one of SendGrid’s most useful features (other than email sending, of course) is our Event Webhook. This webhook notifies you whenever an email is sent, opened, marked as spam, and clicked through, among a variety of other events. Notification is all well and good, but the real power comes in storing and analyzing the events. You can do this with third party services like Keen.io or store it yourself for slightly more power.
Our event webhook POSTs JSON documents to any URL, this sounds like a job for…
A Mongo REST Interface!
If you want to get started storing your events quickly, with minimal configuration, skip down to MongoLab.
Python (Self Hosted)
Kule is Python’s preferred Mongo/REST implementation.
Kule will accept POST requests made to Apps) to POST to your collection’s URL.(e.g. ). Once up and running, just direct our Event Notification App (found in your account under
With that, you should be good to go! However, before you get too excited, you’ll need to make sure both your target database and collection exist (otherwise you’ll get application errors). Additionally, Kule is wide open, meaning that anyone can access your database, luckily Kule is easily configurable, so you can harden your installation.
Ruby (Self Hosted)
DrowsyDromedary is the preferred REST implementation for Mongo in Ruby.
Out of the box, this interface expects POST requests to be made to(e.g. ). However it expects only one document per request (i.e. and our webhook sends multiple by default. However, a previous version of our webhook only sent one document per request, so we can get this running out of the box, by making a POST request.
With that, you should be good to go, your events will be stored in Mongo! There are some caveats though. You’ll need to make sure both your database and collection have been created, otherwise you’ll get errors and your data will not be stored. Out of the box DrowsyDromedary is wide open, exposing the whole of your Mongo instance, the project’s maintainer has a number of recommendations for locking down the installation. Additionally, this uses our old webhook, which unfortunately is deprecated. If you plan on processing much data it’s likely better to write your own wrapper (or use a third party service like Keen.IO). However, for initial data collection, this method should work great.
To get started, sign up for a MongoLab account (it’s free) and create a database. Go find and make note of your API Key (found under your Account User). Finally, direct our Event Notification App (found in your account under Apps) to the following URL, changing out the necessary parameters:
Your events will be stored from here on out! Congratulations!
No matter how you do it, storing your SendGrid Event data is highly recommended, it gives you the most granular way to analyze your event data. Even if you don’t think you’ll be using it, it’s good to store it, as you never know when that might change. Luckily, storing it will cost you next to nothing. If you opt to use Mongo, you can store a bunch of data for free using MongoHQ, or any Mongo REST Interface combined with Heroku and any of their Mongo hosts.
Get out there and start storing your data!