From f748f065a01fa984a41ca679ca05bcff97769b25 Mon Sep 17 00:00:00 2001 From: Anton Tananaev Date: Tue, 1 Dec 2015 16:28:14 +1300 Subject: Add session resource for authentication --- src/org/traccar/api/SecurityRequestFilter.java | 12 ++++++++++++ 1 file changed, 12 insertions(+) (limited to 'src/org/traccar/api/SecurityRequestFilter.java') diff --git a/src/org/traccar/api/SecurityRequestFilter.java b/src/org/traccar/api/SecurityRequestFilter.java index 63295a8b7..e6c02bfc4 100644 --- a/src/org/traccar/api/SecurityRequestFilter.java +++ b/src/org/traccar/api/SecurityRequestFilter.java @@ -16,10 +16,12 @@ package org.traccar.api; import org.traccar.Context; +import org.traccar.api.resource.SessionResource; import org.traccar.model.User; import java.nio.charset.Charset; import java.sql.SQLException; +import javax.servlet.http.HttpServletRequest; import javax.ws.rs.WebApplicationException; import javax.ws.rs.container.ContainerRequestContext; import javax.ws.rs.container.ContainerRequestFilter; @@ -41,8 +43,18 @@ public class SecurityRequestFilter implements ContainerRequestFilter { return null; } + @javax.ws.rs.core.Context + private HttpServletRequest req; + @Override public void filter(ContainerRequestContext requestContext) { + if (requestContext.getUriInfo().getPath().equals("session")) { + return; + } + + long userId = (Long) req.getSession().getAttribute(SessionResource.USER_ID_KEY); + // TODO use session + try { String[] auth = decodeBasicAuth(requestContext.getHeaderString(AUTHORIZATION_HEADER)); User user = Context.getDataManager().login(auth[0], auth[1]); -- cgit v1.2.3