Skip to content

Commit

Permalink
Debug log serializable objects (#1795)
Browse files Browse the repository at this point in the history
  • Loading branch information
denrase committed Nov 8, 2021
1 parent 23913ee commit ba1d4c2
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 7 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
## 6.x.x

* Ref: Bind external properties to a dedicated class. (#1750)
* Ref: Debug log serializable objects (#1795)

Breaking changes:

Expand Down
21 changes: 14 additions & 7 deletions sentry/src/main/java/io/sentry/JsonSerializer.java
Original file line number Diff line number Diff line change
Expand Up @@ -138,13 +138,11 @@ public <T> void serialize(@NotNull T entity, @NotNull Writer writer) throws IOEx
Objects.requireNonNull(writer, "The Writer object is required.");

if (options.getLogger().isEnabled(SentryLevel.DEBUG)) {
options.getLogger().log(SentryLevel.DEBUG, "Serializing object: %s", entity);
}

if (entity instanceof JsonSerializable) {
JsonObjectWriter jsonObjectWriter = new JsonObjectWriter(writer, options.getMaxDepth());
((JsonSerializable) entity).serialize(jsonObjectWriter, options.getLogger());
String serialized = serializeToString(entity, true);
options.getLogger().log(SentryLevel.DEBUG, "Serializing object: %s", serialized);
}
JsonObjectWriter jsonObjectWriter = new JsonObjectWriter(writer, options.getMaxDepth());
jsonObjectWriter.value(options.getLogger(), entity);
writer.flush();
}

Expand Down Expand Up @@ -188,9 +186,18 @@ public void serialize(@NotNull SentryEnvelope envelope, @NotNull OutputStream ou

@Override
public @NotNull String serialize(@NotNull Map<String, Object> data) throws Exception {
return serializeToString(data, false);
}

// Helper

private @NotNull String serializeToString(Object object, boolean pretty) throws IOException {
StringWriter stringWriter = new StringWriter();
JsonObjectWriter jsonObjectWriter = new JsonObjectWriter(stringWriter, options.getMaxDepth());
jsonObjectWriter.value(options.getLogger(), data);
if (pretty) {
jsonObjectWriter.setIndent("\t");
}
jsonObjectWriter.value(options.getLogger(), object);
return stringWriter.toString();
}
}

0 comments on commit ba1d4c2

Please sign in to comment.