#355 override toString to log properties
This commit is contained in:
@ -8,31 +8,42 @@ import java.util.stream.Stream;
|
|||||||
|
|
||||||
public abstract class AbstractDocument implements Document {
|
public abstract class AbstractDocument implements Document {
|
||||||
|
|
||||||
private final Map<String, Object> properties;
|
private final Map<String, Object> properties;
|
||||||
|
|
||||||
protected AbstractDocument(Map<String, Object> properties) {
|
protected AbstractDocument(Map<String, Object> properties) {
|
||||||
Objects.requireNonNull(properties, "properties map is required");
|
Objects.requireNonNull(properties, "properties map is required");
|
||||||
this.properties = properties;
|
this.properties = properties;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Void put(String key, Object value) {
|
public Void put(String key, Object value) {
|
||||||
properties.put(key, value);
|
properties.put(key, value);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object get(String key) {
|
public Object get(String key) {
|
||||||
return properties.get(key);
|
return properties.get(key);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public <T> Stream<T> children(String key, Function<Map<String, Object>, T> constructor) {
|
public <T> Stream<T> children(String key, Function<Map<String, Object>, T> constructor) {
|
||||||
return Stream.of(get(key))
|
return Stream.of(get(key))
|
||||||
.filter(el -> el != null)
|
.filter(el -> el != null)
|
||||||
.map(el -> (List<Map<String, Object>>) el)
|
.map(el -> (List<Map<String, Object>>) el)
|
||||||
.findFirst().get().stream()
|
.findAny().get().stream()
|
||||||
.map(constructor);
|
.map(constructor);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
final StringBuilder builder = new StringBuilder();
|
||||||
|
builder.append(getClass().getName()).append("[");
|
||||||
|
properties.entrySet().forEach(e ->
|
||||||
|
builder.append("[").append(e.getKey()).append(" : ").append(e.getValue()).append("]")
|
||||||
|
);
|
||||||
|
builder.append("]");
|
||||||
|
return builder.toString();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user