/* * Copyright [2022] [wisemapping] * * Licensed under WiseMapping Public License, Version 1.0 (the "License"). * It is basically the Apache License, Version 2.0 (the "License") plus the * "powered by wisemapping" text requirement on every single page; * you may not use this file except in compliance with the License. * You may obtain a copy of the license at * * http://www.wisemapping.org/license * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.wisemapping.security; import org.springframework.security.web.util.matcher.RequestMatcher; import javax.servlet.http.HttpServletRequest; import java.util.Arrays; public class CSFRRequestMatcher implements RequestMatcher { private String prefix; static String[] supportedMethods = {"POST", "PUT", "GET", "DELETE", "PATCH"}; @Override public boolean matches(HttpServletRequest request) { final String requestURI = request.getRequestURI(); return Arrays.stream(supportedMethods).anyMatch(p -> request.getMethod().toUpperCase().equals(p)) && requestURI.startsWith(prefix); } public String getPrefix() { return prefix; } public void setPrefix(String prefix) { this.prefix = prefix; } }