/* * Copyright 2004-2015 the original author or authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * 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 org.springframework.faces.security; import java.io.IOException; /** * This class provides static methods that are registered as EL functions and available for use in Unified EL * expressions in standard Facelets views. * * @author Rossen Stoyanchev * @since 2.2.0 */ public abstract class FaceletsAuthorizeTagUtils { /** * Returns true if the user has all of of the given authorities. * * @param authorities a comma-separated list of user authorities. */ public static boolean areAllGranted(String authorities) throws IOException { FaceletsAuthorizeTag authorizeTag = new FaceletsAuthorizeTag(); authorizeTag.setIfAllGranted(authorities); return authorizeTag.authorize(); } /** * Returns true if the user has any of the given authorities. * * @param authorities a comma-separated list of user authorities. */ public static boolean areAnyGranted(String authorities) throws IOException { FaceletsAuthorizeTag authorizeTag = new FaceletsAuthorizeTag(); authorizeTag.setIfAnyGranted(authorities); return authorizeTag.authorize(); } /** * Returns true if the user does not have any of the given authorities. * * @param authorities a comma-separated list of user authorities. */ public static boolean areNotGranted(String authorities) throws IOException { FaceletsAuthorizeTag authorizeTag = new FaceletsAuthorizeTag(); authorizeTag.setIfNotGranted(authorities); return authorizeTag.authorize(); } /** * Returns true if the user is allowed to access the given URL and HTTP method combination. The HTTP method is * optional and case insensitive. */ public static boolean isAllowed(String url, String method) throws IOException { FaceletsAuthorizeTag authorizeTag = new FaceletsAuthorizeTag(); authorizeTag.setUrl(url); authorizeTag.setMethod(method); return authorizeTag.authorizeUsingUrlCheck(); } }