com.foreach.across.modules.user.business.GroupedPrincipal Maven / Gradle / Ivy
/*
* Copyright 2014 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 com.foreach.across.modules.user.business;
import com.foreach.across.modules.hibernate.business.SettableIdBasedEntity;
import com.foreach.across.modules.spring.security.infrastructure.business.SecurityPrincipal;
import com.foreach.across.modules.spring.security.infrastructure.business.SecurityPrincipalHierarchy;
import com.foreach.across.modules.user.config.UserSchemaConfiguration;
import org.hibernate.annotations.BatchSize;
import org.hibernate.annotations.CacheConcurrencyStrategy;
import org.springframework.security.core.GrantedAuthority;
import javax.annotation.concurrent.NotThreadSafe;
import javax.persistence.*;
import java.util.*;
/**
* Extension to {@link BasicSecurityPrincipal}
* that allows being a member of one or more principal groups.
*
* @author Arne Vandamme
*/
@NotThreadSafe
@MappedSuperclass
@Access(AccessType.FIELD)
public abstract class GroupedPrincipal>
extends BasicSecurityPrincipal
implements SecurityPrincipalHierarchy
{
@org.hibernate.annotations.Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
@ManyToMany(fetch = FetchType.EAGER)
@BatchSize(size = 50)
@JoinTable(
name = UserSchemaConfiguration.TABLE_PRINCIPAL_GROUP,
joinColumns = @JoinColumn(name = "principal_id"),
inverseJoinColumns = @JoinColumn(name = "group_id"))
private Set groups = new TreeSet<>();
public Set getGroups() {
return groups;
}
public void setGroups( Collection groups ) {
getGroups().clear();
if ( groups != null ) {
getGroups().addAll( groups );
}
}
public boolean isMemberOf( Group group ) {
return getGroups().contains( group );
}
public void addGroup( Group group ) {
getGroups().add( group );
}
public void removeGroup( Group group ) {
getGroups().remove( group );
}
@Override
public boolean hasPermission( Permission permission ) {
if ( super.hasPermission( permission ) ) {
return true;
}
for ( Group group : getGroups() ) {
if ( group.hasPermission( permission ) ) {
return true;
}
}
return false;
}
@Override
protected void buildAuthoritySet( Set authorities ) {
super.buildAuthoritySet( authorities );
for ( Group group : getGroups() ) {
authorities.add( group.asGrantedAuthority() );
authorities.addAll( group.getAuthorities() );
}
}
@Override
public Collection getParentPrincipals() {
return groups == null || groups.isEmpty()
? Collections.emptyList()
: new ArrayList<>( groups );
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy