aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVitaly Litvak <vitavaque@gmail.com>2016-01-04 10:19:36 +0300
committerVitaly Litvak <vitavaque@gmail.com>2016-01-04 10:19:36 +0300
commit03e0bd66a3a322e09b6f4cdbec7ec0fb266e0113 (patch)
tree000ffbb9a9bb50a938d1f636c777fe16dff60dfb
parent1f1e3f227304bae09596fb511d6210438f394ca4 (diff)
downloadtrackermap-server-03e0bd66a3a322e09b6f4cdbec7ec0fb266e0113.tar.gz
trackermap-server-03e0bd66a3a322e09b6f4cdbec7ec0fb266e0113.tar.bz2
trackermap-server-03e0bd66a3a322e09b6f4cdbec7ec0fb266e0113.zip
For #1606 - share HTTP sessions between all web applications
-rw-r--r--src/org/traccar/web/WebServer.java7
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/*");