com.github.robozonky.internal.api.ToStringBuilder Maven / Gradle / Ivy
/*
* Copyright 2017 The RoboZonky Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.github.robozonky.internal.api;
import java.lang.reflect.Field;
import java.lang.reflect.Modifier;
import java.util.Arrays;
import java.util.List;
import java.util.Objects;
import java.util.stream.Stream;
import org.apache.commons.lang3.builder.ReflectionToStringBuilder;
import org.slf4j.Logger;
public class ToStringBuilder {
private final ReflectionToStringBuilder builder;
public ToStringBuilder(final Object o, final String... excludeFields) {
final String[] fieldExclusions = Stream.concat(Stream.of("password", "toStringIgnoredFields"),
Arrays.stream(excludeFields))
.distinct()
.toArray(String[]::new);
this.builder = new ToStringBuilder.CustomReflectionToStringBuilder(o)
.setExcludeFieldNames(fieldExclusions);
}
@Override
public String toString() {
return this.builder.toString();
}
private static class CustomReflectionToStringBuilder extends ReflectionToStringBuilder {
private static final int MAX_STRING_LENGTH = 70;
// ignore passwords and loggers
private static final List> IGNORED_TYPES = Arrays.asList(char[].class, Logger.class);
public CustomReflectionToStringBuilder(final Object o) {
super(o);
}
@Override
protected boolean accept(final Field field) {
return super.accept(field) && !Modifier.isStatic(field.getModifiers()) &&
IGNORED_TYPES.stream().noneMatch(type -> Objects.equals(field.getType(), type));
}
@Override
protected Object getValue(final Field field) throws IllegalAccessException {
final Object value = super.getValue(field);
if (value != null && Objects.equals(field.getType(), String.class)) { // long strings will get truncated
final String stringValue = (String) value;
final int length = ToStringBuilder.CustomReflectionToStringBuilder.MAX_STRING_LENGTH;
if (stringValue.length() > length) {
return stringValue.substring(0, length) + "...";
}
}
return value;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy