946289d6fe
No functional change, just importing less stuff and meddling much less with the internals of ooni/probe-engine.
54 lines
1.3 KiB
Go
54 lines
1.3 KiB
Go
package middlebox
|
|
|
|
import (
|
|
"errors"
|
|
|
|
"github.com/ooni/probe-cli/nettests"
|
|
)
|
|
|
|
// HTTPHeaderFieldManipulation test implementation
|
|
type HTTPHeaderFieldManipulation struct {
|
|
}
|
|
|
|
// Run starts the test
|
|
func (h HTTPHeaderFieldManipulation) Run(ctl *nettests.Controller) error {
|
|
builder, err := ctl.Ctx.Session.NewExperimentBuilder(
|
|
"http_header_field_manipulation",
|
|
)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if err := builder.SetOptionString("LogLevel", "INFO"); err != nil {
|
|
return err
|
|
}
|
|
return ctl.Run(builder, []string{""})
|
|
}
|
|
|
|
// HTTPHeaderFieldManipulationTestKeys for the test
|
|
type HTTPHeaderFieldManipulationTestKeys struct {
|
|
IsAnomaly bool `json:"-"`
|
|
}
|
|
|
|
// GetTestKeys returns a projection of the tests keys needed for the views
|
|
func (h HTTPHeaderFieldManipulation) GetTestKeys(tk map[string]interface{}) (interface{}, error) {
|
|
testKeys := HTTPHeaderFieldManipulationTestKeys{IsAnomaly: false}
|
|
tampering, ok := tk["tampering"].(map[string]interface{})
|
|
if !ok {
|
|
return testKeys, errors.New("tampering testkey is invalid")
|
|
}
|
|
for _, v := range tampering {
|
|
t, ok := v.(bool)
|
|
// Ignore non booleans in the tampering map
|
|
if ok && t == true {
|
|
testKeys.IsAnomaly = true
|
|
}
|
|
}
|
|
|
|
return testKeys, nil
|
|
}
|
|
|
|
// LogSummary writes the summary to the standard output
|
|
func (h HTTPHeaderFieldManipulation) LogSummary(s string) error {
|
|
return nil
|
|
}
|