All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.openejb.jee.MethodPermission Maven / Gradle / Ivy

The newest version!
/**
 *
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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.apache.openejb.jee;

import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlAttribute;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlID;
import javax.xml.bind.annotation.XmlType;
import javax.xml.bind.annotation.XmlTransient;
import javax.xml.bind.annotation.adapters.CollapsedStringAdapter;
import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
import java.util.ArrayList;
import java.util.List;


/**
 * The method-permissionType specifies that one or more
 * security roles are allowed to invoke one or more enterprise
 * bean methods. The method-permissionType consists of an
 * optional description, a list of security role names or an
 * indicator to state that the method is unchecked for
 * authorization, and a list of method elements.
 * 

* The security roles used in the method-permissionType * must be defined in the security-role elements of the * deployment descriptor, and the methods must be methods * defined in the enterprise bean's business, home, component * and/or web service endpoint interfaces. */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "method-permissionType", propOrder = { "descriptions", "roleName", "unchecked", "method" }) public class MethodPermission { @XmlElement(name = "role-name", required = true) protected List roleName; protected EmptyType unchecked; @XmlElement(required = true) protected List method; @XmlAttribute @XmlJavaTypeAdapter(CollapsedStringAdapter.class) @XmlID protected String id; @XmlTransient protected TextMap description = new TextMap(); public MethodPermission() { } public MethodPermission(String className, String ejbName, String methodName, String... roles) { this(new Method(ejbName, className, methodName), roles); } public MethodPermission(String ejbName, java.lang.reflect.Method method, String... roles) { this(new Method(ejbName, method), roles); } public MethodPermission(Method method, String... roles) { getMethod().add(method); for (String role : roles) { getRoleName().add(role); } } public MethodPermission setUnchecked() { this.unchecked = new EmptyType(); return this; } @XmlElement(name = "description", required = true) public Text[] getDescriptions() { return description.toArray(); } public void setDescriptions(Text[] text) { description.set(text); } public String getDescription() { return description.get(); } public List getRoleName() { if (roleName == null) { roleName = new ArrayList(); } return this.roleName; } public boolean getUnchecked() { return unchecked != null; } public void setUnchecked(boolean b) { this.unchecked = (b) ? new EmptyType() : null; } public List getMethod() { if (method == null) { method = new ArrayList(); } return this.method; } public String getId() { return id; } public void setId(String value) { this.id = value; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy