mailgun-to-posthog
📬 A simple Google Cloud Function in Go to capture Mailgun webhook events as PostHog custom events.
This project is still under development, and it does not handle many cases. It has been tested with the Go 1.13 runtime.
Why is this needed?
This project helps you feed Mailgun events into PostHog, providing a consolidated view of your product analytics, and allowing you to understand your customers' end-to-end journey better.
For example, you may want to know the % of your customers engaging with a specific e-mail you send after an action(s). You may also be curious to know what cohort of your customers are more likely to engage versus others or what sort of events precedes the engagement.
It is extra useful for your product / engineering / design team if they do not have access to Mailgun.
What properties are captured?
As much as Mailgun provides. Varies depending on the event (e.g. the URL for "Clicked" event).
It can also capture additional "User Variables" specified when sending the message, see .env.sample.yaml
.
How does it correlate the user?
A message is correlated with a PostHog user through a custom user ID defined in the "User Variables". You need to include this when sending the message. In Mailgun's Go SDK, you can attach the user ID like so:
message.AddVariable("user_id", "user-id-123")
You can configure the user ID key (user_id
by default) used, see .env.sample.yaml
.
What events are currently supported?
Getting Started
Prerequisites
- Ensure you have
gcloud
installed:
- Ensure you have authenticated with Google Cloud:
gcloud init
- (Optional) Set your current working project:
gcloud config set project <project>
Deployment
- Clone / download a copy of this repository
- Copy
.env.sample.yaml
to .env.yaml
, and modify the environment variables declared in the file
- Run
./deploy.sh
- Ensure you have tracking set-up, and enabled in Mailgun,
https://app.mailgun.com/app/sending/domains/<your domain>/settings
- Configure Mailgun webhooks in
https://app.mailgun.com/app/sending/domains/<your domain>/webhooks