Skip to content

Unobtrusive disk-buffered analytics for CLI tools powered by Segment

License

Notifications You must be signed in to change notification settings

tj/go-cli-analytics

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 

Repository files navigation

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

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages