view src/goodjava/webserver/handlers/SafeHandler.java @ 1515:78d937870762

Thread.synchronized
author Franklin Schmidt <fschmidt@gmail.com>
date Sat, 30 May 2020 17:58:35 -0600
parents 27efb1fcbcb5
children fa066aaa068c
line wrap: on
line source

package goodjava.webserver.handlers;

import java.io.Writer;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.io.IOException;
import goodjava.logging.Logger;
import goodjava.logging.LoggerFactory;
import goodjava.webserver.Handler;
import goodjava.webserver.Request;
import goodjava.webserver.Response;
import goodjava.webserver.ResponseOutputStream;
import goodjava.webserver.Status;


public final class SafeHandler implements Handler {
	private static final Logger logger = LoggerFactory.getLogger(SafeHandler.class);

	private final Handler handler;

	public SafeHandler(Handler handler) {
		this.handler = handler;
	}

	public Response handle(Request request) {
		try {
			Response response = handler.handle(request);
			if( response != null )
				return response;
		} catch(RuntimeException e) {
			logger.error("",e);
			Response response = new Response();
			response.status = Status.INTERNAL_SERVER_ERROR;
			response.headers.put( "content-type", "text/plain; charset=utf-8" );
			PrintWriter writer = new PrintWriter( new ResponseOutputStream(response) );
			writer.write( "Internel Server Error\n\n" );
			e.printStackTrace(writer);
			writer.close();
			return response;
		}
		return Response.errorResponse( Status.NOT_FOUND, request.path+" not found\n" );
	}

}