All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.mangoo.routing.handlers.ExceptionHandler Maven / Gradle / Ivy

The newest version!
package io.mangoo.routing.handlers;

import com.google.common.net.MediaType;
import io.mangoo.constants.Header;
import io.mangoo.constants.Template;
import io.mangoo.core.Application;
import io.mangoo.core.Server;
import io.mangoo.templating.TemplateEngine;
import io.undertow.server.HttpHandler;
import io.undertow.server.HttpServerExchange;
import io.undertow.util.StatusCodes;
import org.apache.commons.lang3.StringUtils;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;

public class ExceptionHandler implements HttpHandler {
    private static final Logger LOG = LogManager.getLogger(ExceptionHandler.class);
    
    @Override
    public void handleRequest(HttpServerExchange exchange) throws Exception {
        Throwable throwable = exchange.getAttachment(io.undertow.server.handlers.ExceptionHandler.THROWABLE);
        if (throwable != null) {
            LOG.error("Internal Server Exception", throwable);
        }
        
        try {
            Server.headers()
                .entrySet()
                .stream()
                .filter(entry -> StringUtils.isNotBlank(entry.getValue()))
                .forEach(entry -> exchange.getResponseHeaders().add(entry.getKey(), entry.getValue()));

            exchange.getResponseHeaders().put(Header.CONTENT_TYPE, MediaType.HTML_UTF_8.withoutParameters().toString());
            exchange.setStatusCode(StatusCodes.INTERNAL_SERVER_ERROR);

            if (Application.inDevMode()) {
                var templateEngine = new TemplateEngine();
                if (throwable == null) {
                    exchange.getResponseSender().send(Template.internalServerError());
                } else if (throwable.getCause() == null) {
                    exchange.getResponseSender().send(templateEngine.renderException(exchange, throwable, true));
                } else {
                    exchange.getResponseSender().send(templateEngine.renderException(exchange, throwable.getCause(), false));
                }
            } else {
                exchange.getResponseSender().send(Template.internalServerError());
            }
        } catch (Exception e) { // NOSONAR Intentionally catching Exception
            LOG.error("Failed to pass an exception to the frontend", e); 
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy