diff options
author | Vitaly Litvak <vitavaque@gmail.com> | 2016-01-04 10:19:36 +0300 |
---|---|---|
committer | Vitaly Litvak <vitavaque@gmail.com> | 2016-01-04 10:19:36 +0300 |
commit | 03e0bd66a3a322e09b6f4cdbec7ec0fb266e0113 (patch) | |
tree | 000ffbb9a9bb50a938d1f636c777fe16dff60dfb /src/org/traccar/web | |
parent | 1f1e3f227304bae09596fb511d6210438f394ca4 (diff) | |
download | trackermap-server-03e0bd66a3a322e09b6f4cdbec7ec0fb266e0113.tar.gz trackermap-server-03e0bd66a3a322e09b6f4cdbec7ec0fb266e0113.tar.bz2 trackermap-server-03e0bd66a3a322e09b6f4cdbec7ec0fb266e0113.zip |
For #1606 - share HTTP sessions between all web applications
Diffstat (limited to 'src/org/traccar/web')
-rw-r--r-- | src/org/traccar/web/WebServer.java | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/src/org/traccar/web/WebServer.java b/src/org/traccar/web/WebServer.java index 58f4c7f29..85cc5f75c 100644 --- a/src/org/traccar/web/WebServer.java +++ b/src/org/traccar/web/WebServer.java @@ -24,9 +24,11 @@ import javax.sql.DataSource; import org.eclipse.jetty.http.HttpStatus; import org.eclipse.jetty.server.Server; +import org.eclipse.jetty.server.SessionManager; 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.server.session.HashSessionManager; import org.eclipse.jetty.servlet.ServletContextHandler; import org.eclipse.jetty.servlet.ServletHolder; import org.eclipse.jetty.webapp.WebAppContext; @@ -53,6 +55,7 @@ public class WebServer { private final Config config; private final DataSource dataSource; private final HandlerList handlers = new HandlerList(); + private final SessionManager sessionManager = new HashSessionManager(); private void initServer() { @@ -119,6 +122,7 @@ public class WebServer { WebAppContext app = new WebAppContext(); app.setContextPath("/"); + app.getSessionHandler().setSessionManager(sessionManager); app.setWar(config.getString("web.application")); handlers.addHandler(app); } @@ -126,6 +130,7 @@ public class WebServer { private void initApi() { ServletContextHandler servletHandler = new ServletContextHandler(ServletContextHandler.SESSIONS); servletHandler.setContextPath("/api"); + servletHandler.getSessionHandler().setSessionManager(sessionManager); servletHandler.addServlet(new ServletHolder(new AsyncSocketServlet()), "/socket"); @@ -144,6 +149,8 @@ public class WebServer { private void initOldApi() { ServletContextHandler servletHandler = new ServletContextHandler(ServletContextHandler.SESSIONS); servletHandler.setContextPath("/api"); + servletHandler.getSessionHandler().setSessionManager(sessionManager); + servletHandler.addServlet(new ServletHolder(new AsyncServlet()), "/async/*"); servletHandler.addServlet(new ServletHolder(new ServerServlet()), "/server/*"); servletHandler.addServlet(new ServletHolder(new UserServlet()), "/user/*"); |