Home / Class/ SystemStatusListener Class — spring-boot Architecture

SystemStatusListener Class — spring-boot Architecture

Architecture documentation for the SystemStatusListener class in SystemStatusListener.java from the spring-boot codebase.

Entity Profile

Source Code

core/spring-boot/src/main/java/org/springframework/boot/logging/logback/SystemStatusListener.java lines 39–92

final class SystemStatusListener extends OnConsoleStatusListener {

	private static final long RETROSPECTIVE_THRESHOLD = 300;

	private final boolean debug;

	private SystemStatusListener(boolean debug) {
		this.debug = debug;
		setResetResistant(false);
		setRetrospective(0);
	}

	@Override
	public void start() {
		super.start();
		retrospectivePrint();
	}

	private void retrospectivePrint() {
		if (this.context == null) {
			return;
		}
		long now = System.currentTimeMillis();
		List<Status> statusList = this.context.getStatusManager().getCopyOfStatusList();
		statusList.stream()
			.filter((status) -> getElapsedTime(status, now) < RETROSPECTIVE_THRESHOLD)
			.forEach(this::addStatusEvent);
	}

	@Override
	public void addStatusEvent(Status status) {
		if (this.debug || status.getLevel() >= Status.WARN) {
			super.addStatusEvent(status);
		}
	}

	@Override
	protected PrintStream getPrintStream() {
		return (!this.debug) ? System.err : System.out;
	}

	private static long getElapsedTime(Status status, long now) {
		return now - status.getTimestamp();
	}

	static void addTo(LoggerContext loggerContext) {
		addTo(loggerContext, false);
	}

	static void addTo(LoggerContext loggerContext, boolean debug) {
		StatusListenerConfigHelper.addOnConsoleListenerInstance(loggerContext, new SystemStatusListener(debug));
	}

}

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free