Skip to content

Commit

Permalink
refactor: move scrubbing logger to logx
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. 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. 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 committed Sep 27, 2023
1 parent 36d2bec commit 5967764
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 5967764

Please sign in to comment.