org.jboss.as.ejb3.security.EJBSecurityMetaData Maven / Gradle / Ivy
/*
* JBoss, Home of Professional Open Source.
* Copyright 2011, Red Hat, Inc., and individual contributors
* as indicated by the @author tags. See the copyright.txt file in the
* distribution for a full listing of individual contributors.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.jboss.as.ejb3.security;
import java.util.Collection;
import java.util.Collections;
import java.util.Map;
import java.util.Set;
import org.jboss.as.ee.component.ComponentConfiguration;
import org.jboss.as.ejb3.logging.EjbLogger;
import org.jboss.as.ejb3.component.EJBComponentDescription;
import org.jboss.metadata.javaee.spec.SecurityRolesMetaData;
/**
* Holds the EJB component level security metadata.
*
* For per method specific security metadata, take a look at {@link EJBMethodSecurityAttribute}
*
* User: Jaikiran Pai
*/
public class EJBSecurityMetaData {
/**
* The security domain for this EJB component
*/
private final String securityDomain;
/**
* The run-as role (if any) for this EJB component
*/
private final String runAsRole;
/**
* The roles declared (via @DeclareRoles) on this EJB component
*/
private final Set declaredRoles;
/**
* The run-as principal (if any) for this EJB component
*/
private final String runAsPrincipal;
/**
* Roles mapped with security-role
*/
private final SecurityRolesMetaData securityRoles;
/**
* Security role links. The key is the "from" role name and the value is a collection of "to" role names of the link.
*/
private final Map> securityRoleLinks;
/**
* @param componentConfiguration Component configuration of the EJB component
*/
public EJBSecurityMetaData(final ComponentConfiguration componentConfiguration) {
if (componentConfiguration.getComponentDescription() instanceof EJBComponentDescription == false) {
throw EjbLogger.ROOT_LOGGER.invalidComponentConfiguration(componentConfiguration.getComponentName());
}
final EJBComponentDescription ejbComponentDescription = (EJBComponentDescription) componentConfiguration.getComponentDescription();
this.runAsRole = ejbComponentDescription.getRunAs();
this.securityDomain = ejbComponentDescription.getSecurityDomain();
this.runAsPrincipal = ejbComponentDescription.getRunAsPrincipal();
this.securityRoles = ejbComponentDescription.getSecurityRoles();
final Map> links = ejbComponentDescription.getSecurityRoleLinks();
// security role links configured via
this.securityRoleLinks = links == null ? Collections.>emptyMap() : Collections.unmodifiableMap(links);
// @DeclareRoles
final Set roles = ejbComponentDescription.getDeclaredRoles();
this.declaredRoles = roles == null ? Collections.emptySet() : Collections.unmodifiableSet(roles);
}
/**
* Returns the roles that have been declared by the bean. Returns an empty set if there are no declared roles.
*
* @return
*/
public Set getDeclaredRoles() {
return declaredRoles;
}
/**
* Returns the run-as role associated with this bean. Returns null if there's no run-as role associated.
*
* @return
*/
public String getRunAs() {
return this.runAsRole;
}
/**
* Returns the security domain associated with the bean
*
* @return
*/
public String getSecurityDomain() {
return this.securityDomain;
}
/**
* Returns the run-as principal associated with this bean. Returns 'anonymous' if no principal was set.
*
* @return
*/
public String getRunAsPrincipal() {
return runAsPrincipal;
}
/**
* Returns the security-role mapping.
*
* @return
*/
public SecurityRolesMetaData getSecurityRoles() {
return securityRoles;
}
/**
* Returns the security role links (configured via ) applicable for the
* EJB. Returns an empty map if no role links are configured
*
* @return
*/
public Map> getSecurityRoleLinks() {
return this.securityRoleLinks;
}
}