strolch/websocket/src/main/java/li/strolch/websocket/WebSocketFilter.java

35 lines
983 B
Java

package li.strolch.websocket;
import static li.strolch.rest.helper.RestfulHelper.getRemoteIp;
import jakarta.servlet.annotation.WebFilter;
import jakarta.servlet.*;
import jakarta.servlet.http.HttpServletRequest;
import java.io.IOException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@WebFilter("/websocket/*")
public class WebSocketFilter implements Filter {
private static final Logger logger = LoggerFactory.getLogger(WebSocketFilter.class);
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException {
HttpServletRequest httpRequest = (HttpServletRequest) request;
String remoteIp = getRemoteIp(httpRequest);
logger.info("Remote IP: " + remoteIp + ": " + httpRequest.getMethod() + " " + httpRequest.getRequestURI());
WebSocketRemoteIp.set(remoteIp);
chain.doFilter(request, response);
}
public void init(FilterConfig config) {
}
public void destroy() {
}
}