mirror of
https://github.com/scm-manager/scm-manager.git
synced 2025-11-10 15:35:49 +01:00
added securityfilter
This commit is contained in:
@@ -19,6 +19,7 @@ import sonia.scm.filter.GZipFilter;
|
|||||||
import sonia.scm.filter.StaticResourceFilter;
|
import sonia.scm.filter.StaticResourceFilter;
|
||||||
import sonia.scm.security.Authenticator;
|
import sonia.scm.security.Authenticator;
|
||||||
import sonia.scm.security.DemoAuthenticator;
|
import sonia.scm.security.DemoAuthenticator;
|
||||||
|
import sonia.scm.security.SecurityFilter;
|
||||||
|
|
||||||
//~--- JDK imports ------------------------------------------------------------
|
//~--- JDK imports ------------------------------------------------------------
|
||||||
|
|
||||||
@@ -85,6 +86,7 @@ public class ContextListener extends GuiceServletContextListener
|
|||||||
filter(PATTERN_PAGE,
|
filter(PATTERN_PAGE,
|
||||||
PATTERN_STATIC_RESOURCES).through(StaticResourceFilter.class);
|
PATTERN_STATIC_RESOURCES).through(StaticResourceFilter.class);
|
||||||
filter(PATTERN_PAGE, PATTERN_COMPRESSABLE).through(GZipFilter.class);
|
filter(PATTERN_PAGE, PATTERN_COMPRESSABLE).through(GZipFilter.class);
|
||||||
|
filter(PATTERN_RESTAPI).through(SecurityFilter.class);
|
||||||
|
|
||||||
// jersey
|
// jersey
|
||||||
Map<String, String> params = new HashMap<String, String>();
|
Map<String, String> params = new HashMap<String, String>();
|
||||||
|
|||||||
@@ -11,6 +11,8 @@ package sonia.scm.filter;
|
|||||||
|
|
||||||
import com.google.inject.Singleton;
|
import com.google.inject.Singleton;
|
||||||
|
|
||||||
|
import sonia.scm.util.WebUtil;
|
||||||
|
|
||||||
//~--- JDK imports ------------------------------------------------------------
|
//~--- JDK imports ------------------------------------------------------------
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
@@ -44,9 +46,7 @@ public class GZipFilter extends HttpFilter
|
|||||||
HttpServletResponse response, FilterChain chain)
|
HttpServletResponse response, FilterChain chain)
|
||||||
throws IOException, ServletException
|
throws IOException, ServletException
|
||||||
{
|
{
|
||||||
String ae = request.getHeader("accept-encoding");
|
if (WebUtil.isGzipSupported(request))
|
||||||
|
|
||||||
if ((ae != null) && (ae.indexOf("gzip") != -1))
|
|
||||||
{
|
{
|
||||||
GZipResponseWrapper wrappedResponse = new GZipResponseWrapper(response);
|
GZipResponseWrapper wrappedResponse = new GZipResponseWrapper(response);
|
||||||
|
|
||||||
|
|||||||
@@ -10,7 +10,10 @@ package sonia.scm.security;
|
|||||||
//~--- non-JDK imports --------------------------------------------------------
|
//~--- non-JDK imports --------------------------------------------------------
|
||||||
|
|
||||||
import com.google.inject.Inject;
|
import com.google.inject.Inject;
|
||||||
|
import com.google.inject.Singleton;
|
||||||
|
|
||||||
import sonia.scm.User;
|
import sonia.scm.User;
|
||||||
|
import sonia.scm.filter.HttpFilter;
|
||||||
|
|
||||||
//~--- JDK imports ------------------------------------------------------------
|
//~--- JDK imports ------------------------------------------------------------
|
||||||
|
|
||||||
@@ -18,13 +21,8 @@ import java.io.IOException;
|
|||||||
|
|
||||||
import java.security.Principal;
|
import java.security.Principal;
|
||||||
|
|
||||||
|
|
||||||
import javax.servlet.Filter;
|
|
||||||
import javax.servlet.FilterChain;
|
import javax.servlet.FilterChain;
|
||||||
import javax.servlet.FilterConfig;
|
|
||||||
import javax.servlet.ServletException;
|
import javax.servlet.ServletException;
|
||||||
import javax.servlet.ServletRequest;
|
|
||||||
import javax.servlet.ServletResponse;
|
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
import javax.servlet.http.HttpServletRequestWrapper;
|
import javax.servlet.http.HttpServletRequestWrapper;
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
@@ -33,7 +31,8 @@ import javax.servlet.http.HttpServletResponse;
|
|||||||
*
|
*
|
||||||
* @author Sebastian Sdorra
|
* @author Sebastian Sdorra
|
||||||
*/
|
*/
|
||||||
public class SecurityFilter implements Filter
|
@Singleton
|
||||||
|
public class SecurityFilter extends HttpFilter
|
||||||
{
|
{
|
||||||
|
|
||||||
/** Field description */
|
/** Field description */
|
||||||
@@ -44,77 +43,41 @@ public class SecurityFilter implements Filter
|
|||||||
/**
|
/**
|
||||||
* Method description
|
* Method description
|
||||||
*
|
*
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public void destroy()
|
|
||||||
{
|
|
||||||
|
|
||||||
// do nothing
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Method description
|
|
||||||
*
|
*
|
||||||
*
|
* @param request
|
||||||
* @param req
|
* @param response
|
||||||
* @param res
|
|
||||||
* @param chain
|
* @param chain
|
||||||
*
|
*
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
* @throws ServletException
|
* @throws ServletException
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public void doFilter(ServletRequest req, ServletResponse res,
|
protected void doFilter(HttpServletRequest request,
|
||||||
FilterChain chain)
|
HttpServletResponse response, FilterChain chain)
|
||||||
throws IOException, ServletException
|
throws IOException, ServletException
|
||||||
{
|
{
|
||||||
if ((req instanceof HttpServletRequest)
|
String uri =
|
||||||
&& (res instanceof HttpServletResponse))
|
request.getRequestURI().substring(request.getContextPath().length());
|
||||||
|
|
||||||
|
if (!uri.startsWith(URL_AUTHENTICATION))
|
||||||
{
|
{
|
||||||
HttpServletRequest request = (HttpServletRequest) req;
|
User user = authenticator.getUser(request);
|
||||||
String uri =
|
|
||||||
request.getRequestURI().substring(request.getContextPath().length());
|
|
||||||
|
|
||||||
if (!uri.startsWith(URL_AUTHENTICATION))
|
if (user != null)
|
||||||
{
|
{
|
||||||
User user = authenticator.getUser(request);
|
chain.doFilter(new ScmHttpServletRequest(request, user), response);
|
||||||
|
|
||||||
if (user != null)
|
|
||||||
{
|
|
||||||
chain.doFilter(new ScmHttpServletRequest(request, user), res);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
((HttpServletResponse) res).sendError(
|
|
||||||
HttpServletResponse.SC_UNAUTHORIZED);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
chain.doFilter(req, res);
|
response.sendError(HttpServletResponse.SC_UNAUTHORIZED);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
throw new ServletException("request is not an HttpServletRequest");
|
chain.doFilter(request, response);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Method description
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* @param filterConfig
|
|
||||||
*
|
|
||||||
* @throws ServletException
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public void init(FilterConfig filterConfig) throws ServletException
|
|
||||||
{
|
|
||||||
|
|
||||||
// do nothing
|
|
||||||
}
|
|
||||||
|
|
||||||
//~--- inner classes --------------------------------------------------------
|
//~--- inner classes --------------------------------------------------------
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -39,6 +39,9 @@ public class WebUtil
|
|||||||
public static final String DATE_PREVENT_CACHE =
|
public static final String DATE_PREVENT_CACHE =
|
||||||
"Tue, 09 Apr 1985 10:00:00 GMT";
|
"Tue, 09 Apr 1985 10:00:00 GMT";
|
||||||
|
|
||||||
|
/** Field description */
|
||||||
|
public static final String HEADER_ACCEPTENCODING = "Accept-Encoding";
|
||||||
|
|
||||||
/** Field description */
|
/** Field description */
|
||||||
public static final String HEADER_CACHECONTROL = "Cache-Control";
|
public static final String HEADER_CACHECONTROL = "Cache-Control";
|
||||||
|
|
||||||
@@ -238,7 +241,7 @@ public class WebUtil
|
|||||||
*/
|
*/
|
||||||
public static boolean isGzipSupported(HttpServletRequest request)
|
public static boolean isGzipSupported(HttpServletRequest request)
|
||||||
{
|
{
|
||||||
String enc = request.getHeader("Accept-Encoding");
|
String enc = request.getHeader(HEADER_ACCEPTENCODING);
|
||||||
|
|
||||||
return (enc != null) && enc.contains("gzip");
|
return (enc != null) && enc.contains("gzip");
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user