refactor: Improve request/response body logging

pull/201/head
Robert Dailey 2 years ago
parent 9bdb5f364c
commit efd1863efd

@ -14,7 +14,7 @@ public static class FlurlLogging
{ {
var url = urlInterceptor(call.Request.Url.Clone()); var url = urlInterceptor(call.Request.Url.Clone());
log.Debug("HTTP Request: {Method} {Url}", call.HttpRequestMessage.Method, url); log.Debug("HTTP Request: {Method} {Url}", call.HttpRequestMessage.Method, url);
LogBody(log, url, call.RequestBody); LogBody(log, url, "Request", call.HttpRequestMessage.Method, call.RequestBody);
}; };
settings.AfterCallAsync = async call => settings.AfterCallAsync = async call =>
@ -26,7 +26,7 @@ public static class FlurlLogging
var content = call.Response?.ResponseMessage.Content; var content = call.Response?.ResponseMessage.Content;
if (content is not null) if (content is not null)
{ {
LogBody(log, url, await content.ReadAsStringAsync()); LogBody(log, url, "Response", call.HttpRequestMessage.Method, await content.ReadAsStringAsync());
} }
}; };
@ -42,15 +42,23 @@ public static class FlurlLogging
}; };
} }
private static void LogBody(ILogger log, Url url, string? body) private static void LogBody(ILogger log, Url url, string direction, HttpMethod method, string? body)
{ {
if (body is null) if (body is null)
{ {
return; return;
} }
body = JsonConvert.SerializeObject(JsonConvert.DeserializeObject(body)); try
log.Verbose("HTTP Body: {Url} {Body}", url, body); {
body = JsonConvert.SerializeObject(JsonConvert.DeserializeObject(body));
}
catch (JsonException)
{
// Ignore failures here because we'll log the body anyway.
}
log.Verbose("HTTP {Direction} Body: {Method} {Url} {Body}", direction, method, url, body);
} }
public static Url SanitizeUrl(Url url) public static Url SanitizeUrl(Url url)

Loading…
Cancel
Save