2018-02-13 10:48:46 +01:00
|
|
|
package nettests
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/apex/log"
|
|
|
|
"github.com/measurement-kit/go-measurement-kit"
|
|
|
|
ooni "github.com/openobservatory/gooni"
|
2018-02-13 16:16:23 +01:00
|
|
|
"github.com/openobservatory/gooni/internal/cli/version"
|
2018-02-21 16:06:30 +01:00
|
|
|
"github.com/openobservatory/gooni/internal/database"
|
2018-02-13 10:48:46 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
// Nettest interface. Every Nettest should implement this.
|
|
|
|
type Nettest interface {
|
|
|
|
Run(*Controller) error
|
2018-02-13 16:16:23 +01:00
|
|
|
Summary(map[string]interface{}) interface{}
|
2018-02-13 10:48:46 +01:00
|
|
|
LogSummary(string) error
|
|
|
|
}
|
|
|
|
|
|
|
|
// NettestGroup base structure
|
|
|
|
type NettestGroup struct {
|
|
|
|
Label string
|
|
|
|
Nettests []Nettest
|
|
|
|
Summary func(s string) string
|
|
|
|
}
|
|
|
|
|
2018-02-13 16:16:23 +01:00
|
|
|
// NewController creates a nettest controller
|
2018-02-21 16:06:30 +01:00
|
|
|
func NewController(ctx *ooni.Context, res *database.Result) *Controller {
|
2018-02-13 10:48:46 +01:00
|
|
|
return &Controller{
|
|
|
|
ctx,
|
2018-02-21 16:06:30 +01:00
|
|
|
res,
|
2018-02-13 10:48:46 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-02-13 16:16:23 +01:00
|
|
|
// Controller is passed to the run method of every Nettest
|
|
|
|
type Controller struct {
|
|
|
|
ctx *ooni.Context
|
2018-02-21 16:06:30 +01:00
|
|
|
res *database.Result
|
2018-02-13 16:16:23 +01:00
|
|
|
}
|
|
|
|
|
2018-02-13 10:48:46 +01:00
|
|
|
// Init should be called once to initialise the nettest
|
|
|
|
func (c *Controller) Init(nt *mk.Nettest) {
|
|
|
|
log.Debugf("Init: %s", nt)
|
2018-02-13 16:16:23 +01:00
|
|
|
nt.Options = mk.NettestOptions{
|
|
|
|
IncludeIP: c.ctx.Config.Sharing.IncludeIP,
|
|
|
|
IncludeASN: c.ctx.Config.Sharing.IncludeASN,
|
|
|
|
IncludeCountry: c.ctx.Config.Advanced.IncludeCountry,
|
|
|
|
DisableCollector: false,
|
|
|
|
SoftwareName: "ooniprobe",
|
|
|
|
SoftwareVersion: version.Version,
|
|
|
|
|
|
|
|
// XXX
|
|
|
|
GeoIPCountryPath: "",
|
|
|
|
GeoASNPath: "",
|
|
|
|
OutputPath: "",
|
|
|
|
CaBundlePath: "",
|
|
|
|
}
|
|
|
|
nt.RegisterEventHandler(func(event interface{}) {
|
2018-02-21 16:06:30 +01:00
|
|
|
e := event.(map[string]interface{})
|
|
|
|
if e["type"].(string) == "LOG" {
|
|
|
|
msg := e["message"].(string)
|
|
|
|
switch level := e["verbosity"].(string); level {
|
|
|
|
case "ERROR":
|
|
|
|
log.Error(msg)
|
|
|
|
case "INFO":
|
|
|
|
log.Info(msg)
|
|
|
|
default:
|
|
|
|
log.Debug(msg)
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
log.WithFields(log.Fields{
|
|
|
|
"key": "event",
|
|
|
|
"value": e,
|
|
|
|
}).Info("got event")
|
|
|
|
}
|
2018-02-13 16:16:23 +01:00
|
|
|
})
|
2018-02-13 10:48:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// OnProgress should be called when a new progress event is available.
|
|
|
|
func (c *Controller) OnProgress(perc float32, msg string) {
|
|
|
|
log.Debugf("OnProgress: %f - %s", perc, msg)
|
|
|
|
}
|
|
|
|
|
|
|
|
// OnEntry should be called every time there is a new entry
|
|
|
|
func (c *Controller) OnEntry(entry string) {
|
|
|
|
log.Debugf("OnEntry: %s", entry)
|
|
|
|
}
|
|
|
|
|
|
|
|
// MKStart is the interface for the mk.Nettest Start() function
|
|
|
|
type MKStart func(name string) (chan bool, error)
|
|
|
|
|
2018-02-21 16:06:30 +01:00
|
|
|
// Start should be called to start the test
|
2018-02-13 10:48:46 +01:00
|
|
|
func (c *Controller) Start(f MKStart) {
|
|
|
|
log.Debugf("MKStart: %s", f)
|
|
|
|
}
|