diff options
author | Anton Tananaev <anton.tananaev@gmail.com> | 2015-12-02 16:04:06 +1300 |
---|---|---|
committer | Anton Tananaev <anton.tananaev@gmail.com> | 2015-12-02 16:04:06 +1300 |
commit | 3249d852b5427a57e4f930c9f415f632fe367894 (patch) | |
tree | 916ba628a7ced7739f4eb7360bd9252ec96eb83c /src/org/traccar/web | |
parent | a05daf7d491e72a6272b2562f5bd21325795c3ab (diff) | |
download | trackermap-server-3249d852b5427a57e4f930c9f415f632fe367894.tar.gz trackermap-server-3249d852b5427a57e4f930c9f415f632fe367894.tar.bz2 trackermap-server-3249d852b5427a57e4f930c9f415f632fe367894.zip |
Implement error handling for REST API
Diffstat (limited to 'src/org/traccar/web')
-rw-r--r-- | src/org/traccar/web/WebServer.java | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/src/org/traccar/web/WebServer.java b/src/org/traccar/web/WebServer.java index d172a5331..63d80a7f3 100644 --- a/src/org/traccar/web/WebServer.java +++ b/src/org/traccar/web/WebServer.java @@ -15,10 +15,18 @@ */ package org.traccar.web; +import java.io.IOException; +import java.io.Writer; import java.net.InetSocketAddress; import javax.naming.InitialContext; +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; import javax.sql.DataSource; + +import org.eclipse.jetty.http.HttpStatus; +import org.eclipse.jetty.server.Request; import org.eclipse.jetty.server.Server; +import org.eclipse.jetty.server.handler.ErrorHandler; import org.eclipse.jetty.server.handler.HandlerList; import org.eclipse.jetty.server.handler.ResourceHandler; import org.eclipse.jetty.servlet.ServletContextHandler; @@ -28,6 +36,7 @@ import org.glassfish.jersey.server.ResourceConfig; import org.glassfish.jersey.servlet.ServletContainer; import org.traccar.Config; import org.traccar.api.CorsResponseFilter; +import org.traccar.api.ResourceErrorHandler; import org.traccar.api.SecurityRequestFilter; import org.traccar.api.resource.DeviceResource; import org.traccar.api.resource.PositionResource; @@ -76,6 +85,15 @@ public class WebServer { break; } server.setHandler(handlers); + + server.addBean(new ErrorHandler() { + @Override + protected void handleErrorPage( + HttpServletRequest request, Writer writer, int code, String message) throws IOException { + writer.write("<!DOCTYPE<html><head><title>Error</title></head><html><body>" + + code + " - " + HttpStatus.getMessage(code) + "</body></html>"); + } + }); } private void initWebApp() { @@ -108,6 +126,7 @@ public class WebServer { servletHandler.setContextPath("/api"); if (initRest) { ResourceConfig resourceConfig = new ResourceConfig(); + resourceConfig.register(ResourceErrorHandler.class); resourceConfig.register(SecurityRequestFilter.class); resourceConfig.register(CorsResponseFilter.class); resourceConfig.registerClasses(ServerResource.class, SessionResource.class, |