org.springmodules.validation.valang.functions.InRoleFunction Maven / Gradle / Ivy
/*
* Copyright 2004-2005 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.springmodules.validation.valang.functions;
import org.acegisecurity.Authentication;
import org.acegisecurity.GrantedAuthority;
import org.acegisecurity.context.SecurityContextHolder;
/**
* A function that accepts a one string argument that indicates a security role. This function
* returns a true
if the current user is in the passed in role, and false
* otherwise.
*
* This method uses Acegi's SecurityContextHolder.getContext().getAuthentication()
to
* get the current user.
*
* This function may be used to apply different validation rules based on the logged in user roles.
*
* @author Uri Boness
* @since May 25, 2006
*/
public class InRoleFunction extends AbstractFunction {
public InRoleFunction(Function[] arguments, int line, int column) {
super(arguments, line, column);
definedExactNumberOfArguments(1);
}
protected Object doGetResult(Object target) {
Object role = getArguments()[0].getResult(target);
Authentication authentication = SecurityContextHolder.getContext().getAuthentication();
if (authentication == null) {
return Boolean.FALSE;
}
GrantedAuthority[] authorities = authentication.getAuthorities();
for (int i = 0; i < authorities.length; i++) {
if (authorities[i].getAuthority().equals(role)) {
return Boolean.TRUE;
}
}
return Boolean.FALSE;
}
}