liquibase.logging.core.BufferedLogService Maven / Gradle / Ivy
package liquibase.logging.core;
import liquibase.logging.Logger;
import liquibase.util.ISODateFormat;
import java.io.IOException;
import java.io.PrintWriter;
import java.io.StringWriter;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.logging.Level;
public class BufferedLogService extends AbstractLogService {
//
// Truncate the return value at 10MB = 10,000,000 bytes
//
public static final int MAX_LOG_LENGTH = 10000000;
private List log = new ArrayList<>();
@Override
public int getPriority() {
return PRIORITY_NOT_APPLICABLE;
}
@Override
public Logger getLog(Class clazz) {
return new BufferedLogger(clazz, this, this.filter);
}
public List getLog() {
return log;
}
public String getLogAsString(Level minimumLevel) {
StringBuilder returnLog = new StringBuilder();
for (BufferedLogMessage message : log) {
if (minimumLevel == null || minimumLevel.intValue() <= message.getLevel().intValue()) {
returnLog.append("[").append(new ISODateFormat().format(message.getTimestamp())).append("] ");
returnLog.append(message.getLevel().getName()).append(" ");
returnLog.append(message.getMessage());
returnLog.append("\n");
if (message.getThrowable() != null) {
try (final StringWriter stringWriter = new StringWriter();
final PrintWriter printWriter = new PrintWriter(stringWriter)) {
message.getThrowable().printStackTrace(printWriter);
printWriter.flush();
returnLog.append(stringWriter.toString()).append("\n");
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
if (returnLog.length() > MAX_LOG_LENGTH) {
returnLog.setLength(MAX_LOG_LENGTH);
}
return returnLog.toString();
}
public void addLog(BufferedLogMessage log) {
this.log.add(log);
}
public static class BufferedLogMessage {
private Date timestamp;
private Level level;
private Class location;
private String message;
private Throwable throwable;
public BufferedLogMessage(Level level, Class location, String message, Throwable throwable) {
this.timestamp = new Date();
this.location = location;
this.level = level;
this.message = message;
this.throwable = throwable;
}
public Date getTimestamp() {
return timestamp;
}
public Level getLevel() {
return level;
}
public Class getLocation() {
return location;
}
public String getMessage() {
return message;
}
public Throwable getThrowable() {
return throwable;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy