org.mapfish.print.output.ValuesLogger Maven / Gradle / Ivy
package org.mapfish.print.output;
import net.sf.jasperreports.engine.JRDataSource;
import net.sf.jasperreports.engine.data.JRMapCollectionDataSource;
import org.mapfish.print.PrintException;
import org.mapfish.print.config.Template;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.util.HashMap;
import java.util.Map;
/**
* Class for logging the values in a {@link org.mapfish.print.output.Values} object.
*/
public final class ValuesLogger {
private static final Logger LOGGER = LoggerFactory.getLogger(ValuesLogger.class);
private static final int STANDARD_INDENT_SIZE = 4;
private final StringBuilder builder = new StringBuilder();
private int indent = STANDARD_INDENT_SIZE;
private ValuesLogger() {
// no public constructor
}
/**
* Log the values for the provided template.
*
* @param templateName the name of the template the values came from
* @param template the template object
* @param values the resultant values
*/
public static void log(final String templateName, final Template template, final Values values) {
new ValuesLogger().doLog(templateName, template, values);
}
private void doLog(final String templateName, final Template template, final Values values) {
if (!LOGGER.isInfoEnabled()) {
return;
}
if (this.builder.length() > 0) {
this.builder.append("\n");
}
this.builder
.append("This log message details the parameters available for use in the Jasper templates ");
this.builder.append("for\n Mapfish Template: ").append(templateName).append("\n");
this.builder.append(" Jasper Template name: ").append(template.getReportTemplate()).append('\n');
this.builder.append(" The following parameters are available for use in the templates: \n");
for (Map.Entry parameter: values.asMap().entrySet()) {
boolean isTableDataKey = parameter.getKey().equals(template.getTableDataKey());
logValue(templateName, parameter, isTableDataKey);
}
LOGGER.info(this.builder.toString());
}
private void logValue(
final String templateName, final Map.Entry parameter, final boolean isTableDataKey) {
addIndent().append("* ").append(parameter.getKey());
if (isTableDataKey) {
if (parameter.getValue() instanceof JRDataSource) {
this.builder.append(" ");
} else {
final String message =
"The output value: '" + parameter.getKey() + "' is defined in the template: '" +
templateName + "' as the tableDataKey but is not a '" +
JRDataSource.class.getName() +
"' object as was expected. Instead it is " +
parameter.getValue().getClass().getName();
throw new PrintException(message);
}
}
if (parameter.getValue() == null) {
this.builder.append(" (null)\n");
} else {
this.builder.append(" (").append(parameter.getValue().getClass().getName()).append(")\n");
}
if (parameter.getValue() instanceof JRDataSource) {
String section = isTableDataKey ? "'Top-level' template" : "sub-template";
if (!isTableDataKey) {
addIndent()
.append(" - This value is a Jasper Reports DataSource and thus can be passed to a ").
append("subtemplate as a DataSource and used in the subtemplate's detail band.\n");
}
if (parameter.getValue() instanceof JRMapCollectionDataSource) {
JRMapCollectionDataSource source = (JRMapCollectionDataSource) parameter.getValue();
addIndent().append(" - This DataSource contains the "
+
"following columns (All rows are analyzed for their columns, " +
"thus each row may "
+ "only have a subset of the columns)\n");
this.indent += STANDARD_INDENT_SIZE;
Map columns = new HashMap<>();
// loop the source to get all columns of the table
for (Map row: source.getData()) {
for (Map.Entry column: row.entrySet()) {
if (!columns.containsKey(column.getKey())) {
columns.put(column.getKey(), column.getValue());
} else {
// if the value for this key is null, let's take the next value so that we
// eventually get the type of the column
if (columns.get(column.getKey()) == null) {
columns.put(column.getKey(), column.getValue());
}
}
}
}
for (Map.Entry column: columns.entrySet()) {
logValue(templateName, column, false);
}
this.indent -= STANDARD_INDENT_SIZE;
} else {
addIndent()
.append(" - This datasource is not a type that can be introspected but it can be " +
"used in"
+ " a detail section of ").
append(section).append(" if the structure is known.\n");
}
}
}
private StringBuilder addIndent() {
for (int i = 0; i < this.indent; i++) {
this.builder.append(" ");
}
return this.builder;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy