mkapnick / go-cli-analytics

Unobtrusive disk-buffered analytics for CLI tools powered by Segment

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

go-cli-analytics

Disk-buffered analytics for CLI tools powered by Segment. Analytics for CLI tools can help determine which aspects of your tool are most valued by users, and where improvements could be made. Track command or flag usage, errors, latencies, or others, just don't be sketchy!

How

Pass your Segemnt write key, and specify a directory name which will reside in HOME.

a := analytics.New(&analytics.Config{
  WriteKey: "<write key>",
  Dir:      ".myprogram",
})

This package will create three files:

  • ~/DIR/id – pseudo user id
  • ~/DIR/events – buffered events
  • ~/DIR/last_flush – state for previous flush

Track events like this:

a.Track("More Something", map[string]interface{}{
  "other":    "stuff",
  "whatever": "else here",
})

Flush events at random, based on the previous duration time, or based on size. Note that flushing on every command will introduce ~500ms of latency, so don't do this.

lastFlush, _ := a.LastFlush()
n, _ := a.Size()

switch {
case n >= 15:
  fmt.Printf("  flush due to size\n")
  a.Flush()
case time.Now().Sub(lastFlush) >= time.Minute:
  fmt.Printf("  flush due to duration\n")
  a.Flush()
default:
  fmt.Printf("  close\n")
  a.Close()
}

Notes

Note that there is no file-level locking at the moment for concurrent executions of your program. This may be added in the future if necessary.

Badges

GoDoc


tjholowaychuk.com  ·  GitHub @tj  ·  Twitter @tjholowaychuk

About

Unobtrusive disk-buffered analytics for CLI tools powered by Segment

License:MIT License


Languages

Language:Go 100.0%