Published on July 3, 2022

Track user signup events via Go

Track user signup events via Go

When we are building a website or application with Go, we often require our users to sign up for an account before they can access or use our service. This is a common requirement for many services as it allows us to track usage more efficiently, monitor growth, and avoid abuse.

Unfortunately, this process has certain downsides, such as introducing additional friction to our service and making the users go through extra steps before accessing our service.

Thus, tracking user activity when visiting our service and tracking how many go through the signup process and drop off before they use our service is essential. By monitoring the signup process, we can better understand how our visitors interact with our Go service and find and fix any issues they may encounter.

LogSnag makes it easy to track events such as user registration directly within your Go code. As a result, it helps you better understand how your users interact with your product and how your product is performing.


Setting up your account

Setting up LogSnag with Go is very simple!

  1. Create a free LogSnag account.
  2. Create a new project on your dashboard.
  3. Copy your API token from the settings page.

Go code snippets

Once your LogSnag account is set up, you can use the following code snippets to track user signup events. Just replace the YOUR_API_TOKEN with your LogSnag API token and update your project name.

Using Go with Native
package main

import (
"fmt"
"strings"
"net/http"
"io/ioutil"
)

func main() {

url := "https://api.logsnag.com/v1/log"
method := "POST"

payload := strings.NewReader(`{"project":"my-saas","channel":"auth","event":"User Registered","description":"email: john@doe.com","icon":"🔥","notify":true}`)

client := &http.Client {
}
req, err := http.NewRequest(method, url, payload)

if err != nil {
fmt.Println(err)
return
}
req.Header.Add("Content-Type", "application/json")
req.Header.Add("Authorization", "Bearer YOUR_API_TOKEN")

res, err := client.Do(req)
if err != nil {
fmt.Println(err)
return
}
defer res.Body.Close()

body, err := ioutil.ReadAll(res.Body)
if err != nil {
fmt.Println(err)
return
}
fmt.Println(string(body))
}

Go integration details

LogSnag is a simple event tracking tool that works seamlessly with your Go code. With it, you can track any event within your Go application. It also allows you to create simple charts and track user journeys to help you better understand your product. LogSnag also enables you to receive real-time push notifications on your desktop and mobile devices whenever a new user creates an account on your website or application.

Other use-cases for LogSnag

  1. Monitor your CI/CD build status for your Go application
  2. Monitor your CPU usage in your Go application
  3. Monitor when database goes down in your Go application
  4. Monitor high disk usage in your Go application
  5. Monitor when a user changes their email address in your Go application
  6. Monitor failed logins in your Go application
  7. Monitor failed payments for your Go application
  8. Monitor memory usage in your Go application
  9. Monitor MySQL downtime in your Go application
  10. Monitor when a new feature is used in your Go application
  11. Monitor your Postgres downtime in your Go application
  12. Monitor Redis downtime in your Go application
  13. Monitor suspicious activity in your Go application
  14. Monitor when a user exceeds the usage limit for your Go service
  15. Monitor when a user is being rate limited in your Go application
  16. Get a notification when your Go code is done executing
  17. Send push notifications to your phone or desktop using Go
  18. Track canceled subscriptions in your Go application
  19. Track your Go cron jobs
  20. Track when a file is uploaded to your Go application
  21. Track when a form is submitted to your Go application
  22. Track payment events via Go
  23. Track user sign in events in Go
  24. Track waitlist signup events via Go
View all common use-cases with Go