Skip to content

Commit

Permalink
refactor: move scrubbing logger to logx (ooni#1319)
Browse files Browse the repository at this point in the history
This diff is yak shaving for a subsequent diff that attempts to mitigate
potential IP addresses leaks caused by using happy eyeballs more
aggressively in the codebase. The general idea is that we previously had
a netxlite implementation that gave IPv4 preference over IPv6, meaning
that we would end up using IPv4 in most cases and very rarely IPv6. As
part of my work to make beacons possible, I have introduced happy
eyeballs, which means we may sometimes use IPv4 instead of IPv6 if we
adopt happy eyeballs more widely. This fact makes it more likely that we
include the IPv6 address of a probe when we know its IPv4 address or the
other way around into measurements. To mitigate this possible issue
before it actually is possible (note that I have not yet changed how we
discover the probe IP), I am going to proactively modify the
serialization of HTTP bodies and headers to scrub IP endpoints
unconditionally. However, to do this, I need to decouple the scrubber
package from model such that internal/model/archival.go can use the
scrubber package.

Part of ooni/probe#2531
  • Loading branch information
bassosimone authored and Murphy-OrangeMud committed Feb 13, 2024
1 parent 6a78f5e commit 1df748b
Show file tree
Hide file tree
Showing 5 changed files with 74 additions and 69 deletions.
3 changes: 2 additions & 1 deletion internal/experiment/tor/tor.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ import (

"github.com/ooni/probe-cli/v3/internal/legacy/measurex"
"github.com/ooni/probe-cli/v3/internal/legacy/tracex"
"github.com/ooni/probe-cli/v3/internal/logx"
"github.com/ooni/probe-cli/v3/internal/model"
"github.com/ooni/probe-cli/v3/internal/netxlite"
"github.com/ooni/probe-cli/v3/internal/runtimex"
Expand Down Expand Up @@ -320,7 +321,7 @@ func maybeScrubbingLogger(input model.Logger, kt keytarget) model.Logger {
if !kt.private() {
return input
}
return &scrubber.Logger{Logger: input}
return &logx.ScrubberLogger{Logger: input}
}

// defaultFlexibleConnect is the default implementation of the
Expand Down
6 changes: 3 additions & 3 deletions internal/experiment/tor/tor_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,9 +15,9 @@ import (
"github.com/google/go-cmp/cmp"
"github.com/ooni/probe-cli/v3/internal/legacy/measurex"
"github.com/ooni/probe-cli/v3/internal/legacy/mockable"
"github.com/ooni/probe-cli/v3/internal/logx"
"github.com/ooni/probe-cli/v3/internal/model"
"github.com/ooni/probe-cli/v3/internal/netxlite"
"github.com/ooni/probe-cli/v3/internal/scrubber"
)

func TestNewExperimentMeasurer(t *testing.T) {
Expand Down Expand Up @@ -717,7 +717,7 @@ func TestMaybeScrubbingLogger(t *testing.T) {
if out != input {
t.Fatal("not the output we expected")
}
if _, ok := out.(*scrubber.Logger); ok {
if _, ok := out.(*logx.ScrubberLogger); ok {
t.Fatal("not the output type we expected")
}
})
Expand All @@ -730,7 +730,7 @@ func TestMaybeScrubbingLogger(t *testing.T) {
if out == input {
t.Fatal("not the output value we expected")
}
if _, ok := out.(*scrubber.Logger); !ok {
if _, ok := out.(*logx.ScrubberLogger); !ok {
t.Fatal("not the output type we expected")
}
})
Expand Down
47 changes: 47 additions & 0 deletions internal/logx/scrubber.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
package logx

import (
"fmt"

"github.com/ooni/probe-cli/v3/internal/model"
"github.com/ooni/probe-cli/v3/internal/scrubber"
)

// ScrubberLogger is a [model.Logger] with scrubbing. All messages are scrubbed including the ones
// that won't be emitted. As such, this logger is less efficient than a logger without scrubbing.
//
// The zero value is invalid; please init all MANDATORY fields.
type ScrubberLogger struct {
// Logger is the MANDATORY underlying logger to use.
Logger model.Logger
}

// Debug scrubs and emits a debug message.
func (sl *ScrubberLogger) Debug(message string) {
sl.Logger.Debug(scrubber.Scrub(message))
}

// Debugf scrubs, formats, and emits a debug message.
func (sl *ScrubberLogger) Debugf(format string, v ...interface{}) {
sl.Debug(fmt.Sprintf(format, v...))
}

// Info scrubs and emits an informational message.
func (sl *ScrubberLogger) Info(message string) {
sl.Logger.Info(scrubber.Scrub(message))
}

// Infof scrubs, formats, and emits an informational message.
func (sl *ScrubberLogger) Infof(format string, v ...interface{}) {
sl.Info(fmt.Sprintf(format, v...))
}

// Warn scrubs and emits a warning message.
func (sl *ScrubberLogger) Warn(message string) {
sl.Logger.Warn(scrubber.Scrub(message))
}

// Warnf scrubs, formats, and emits a warning message.
func (sl *ScrubberLogger) Warnf(format string, v ...interface{}) {
sl.Warn(fmt.Sprintf(format, v...))
}
43 changes: 22 additions & 21 deletions internal/scrubber/logger_test.go → internal/logx/scrubber_test.go
Original file line number Diff line number Diff line change
@@ -1,47 +1,48 @@
package scrubber
package logx

import (
"fmt"
"testing"
)

type savingLogger struct {
// scrubberSavingLogger helps writing tests for [ScrubberLogger].
type scrubberSavingLogger struct {
debug []string
info []string
warn []string
}

func (sl *savingLogger) Debug(message string) {
func (sl *scrubberSavingLogger) Debug(message string) {
sl.debug = append(sl.debug, message)
}

func (sl *savingLogger) Debugf(format string, v ...interface{}) {
func (sl *scrubberSavingLogger) Debugf(format string, v ...interface{}) {
sl.Debug(fmt.Sprintf(format, v...))
}

func (sl *savingLogger) Info(message string) {
func (sl *scrubberSavingLogger) Info(message string) {
sl.info = append(sl.info, message)
}

func (sl *savingLogger) Infof(format string, v ...interface{}) {
func (sl *scrubberSavingLogger) Infof(format string, v ...interface{}) {
sl.Info(fmt.Sprintf(format, v...))
}

func (sl *savingLogger) Warn(message string) {
func (sl *scrubberSavingLogger) Warn(message string) {
sl.warn = append(sl.warn, message)
}

func (sl *savingLogger) Warnf(format string, v ...interface{}) {
func (sl *scrubberSavingLogger) Warnf(format string, v ...interface{}) {
sl.Warn(fmt.Sprintf(format, v...))
}

func TestScrubLogger(t *testing.T) {
func TestScrubberLogger(t *testing.T) {
input := "failure: 130.192.91.211:443: no route the host"
expect := "failure: [scrubbed]: no route the host"

t.Run("for debug", func(t *testing.T) {
logger := new(savingLogger)
scrubber := &Logger{Logger: logger}
logger := new(scrubberSavingLogger)
scrubber := &ScrubberLogger{Logger: logger}
scrubber.Debug(input)
if len(logger.debug) != 1 && len(logger.info) != 0 && len(logger.warn) != 0 {
t.Fatal("unexpected number of log lines written")
Expand All @@ -52,8 +53,8 @@ func TestScrubLogger(t *testing.T) {
})

t.Run("for debugf", func(t *testing.T) {
logger := new(savingLogger)
scrubber := &Logger{Logger: logger}
logger := new(scrubberSavingLogger)
scrubber := &ScrubberLogger{Logger: logger}
scrubber.Debugf("%s", input)
if len(logger.debug) != 1 && len(logger.info) != 0 && len(logger.warn) != 0 {
t.Fatal("unexpected number of log lines written")
Expand All @@ -64,8 +65,8 @@ func TestScrubLogger(t *testing.T) {
})

t.Run("for info", func(t *testing.T) {
logger := new(savingLogger)
scrubber := &Logger{Logger: logger}
logger := new(scrubberSavingLogger)
scrubber := &ScrubberLogger{Logger: logger}
scrubber.Info(input)
if len(logger.debug) != 0 && len(logger.info) != 1 && len(logger.warn) != 0 {
t.Fatal("unexpected number of log lines written")
Expand All @@ -76,8 +77,8 @@ func TestScrubLogger(t *testing.T) {
})

t.Run("for infof", func(t *testing.T) {
logger := new(savingLogger)
scrubber := &Logger{Logger: logger}
logger := new(scrubberSavingLogger)
scrubber := &ScrubberLogger{Logger: logger}
scrubber.Infof("%s", input)
if len(logger.debug) != 0 && len(logger.info) != 1 && len(logger.warn) != 0 {
t.Fatal("unexpected number of log lines written")
Expand All @@ -88,8 +89,8 @@ func TestScrubLogger(t *testing.T) {
})

t.Run("for warn", func(t *testing.T) {
logger := new(savingLogger)
scrubber := &Logger{Logger: logger}
logger := new(scrubberSavingLogger)
scrubber := &ScrubberLogger{Logger: logger}
scrubber.Warn(input)
if len(logger.debug) != 0 && len(logger.info) != 0 && len(logger.warn) != 1 {
t.Fatal("unexpected number of log lines written")
Expand All @@ -100,8 +101,8 @@ func TestScrubLogger(t *testing.T) {
})

t.Run("for warnf", func(t *testing.T) {
logger := new(savingLogger)
scrubber := &Logger{Logger: logger}
logger := new(scrubberSavingLogger)
scrubber := &ScrubberLogger{Logger: logger}
scrubber.Warnf("%s", input)
if len(logger.debug) != 0 && len(logger.info) != 0 && len(logger.warn) != 1 {
t.Fatal("unexpected number of log lines written")
Expand Down
44 changes: 0 additions & 44 deletions internal/scrubber/logger.go

This file was deleted.

0 comments on commit 1df748b

Please sign in to comment.