feat(httpx): implement optional body logging also on http error (#651)

1. we want optionally to log the body (we don't want to log the body
when we're fetching psiphon secrets or tor targets)

2. we want body logging to _also_ happen on error since this is quite
useful to debug possible errors when accessing the API

This diff adds the above functionality, which were previously
described in https://github.com/ooni/probe/issues/1951.

This diff also adds comprehensive testing.
This commit is contained in:
Simone Basso
2022-01-05 16:26:51 +01:00
committed by GitHub
parent ee0aa18616
commit dba861d262
13 changed files with 229 additions and 17 deletions
+1 -1
View File
@@ -24,7 +24,7 @@ func avastIPLookup(
HTTPClient: httpClient,
Logger: logger,
UserAgent: userAgent,
}).Build().GetJSON(ctx, "/v1/info", &v)
}).WithBodyLogging().Build().GetJSON(ctx, "/v1/info", &v)
if err != nil {
return DefaultProbeIP, err
}
+1 -1
View File
@@ -21,7 +21,7 @@ func ipConfigIPLookup(
HTTPClient: httpClient,
Logger: logger,
UserAgent: httpheader.CLIUserAgent(),
}).Build().FetchResource(ctx, "/")
}).WithBodyLogging().Build().FetchResource(ctx, "/")
if err != nil {
return DefaultProbeIP, err
}
+1 -1
View File
@@ -26,7 +26,7 @@ func ipInfoIPLookup(
HTTPClient: httpClient,
Logger: logger,
UserAgent: httpheader.CLIUserAgent(), // we must be a CLI client
}).Build().GetJSON(ctx, "/", &v)
}).WithBodyLogging().Build().GetJSON(ctx, "/", &v)
if err != nil {
return DefaultProbeIP, err
}
+1 -1
View File
@@ -25,7 +25,7 @@ func ubuntuIPLookup(
HTTPClient: httpClient,
Logger: logger,
UserAgent: userAgent,
}).Build().FetchResource(ctx, "/lookup")
}).WithBodyLogging().Build().FetchResource(ctx, "/lookup")
if err != nil {
return DefaultProbeIP, err
}