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

org.apache.openejb.jee.EjbLocalRef 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.adapters.CollapsedStringAdapter;
import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
import java.util.ArrayList;
import java.util.List;


/**
 * The ejb-local-refType is used by ejb-local-ref elements for
 * the declaration of a reference to an enterprise bean's local
 * home or to the local business interface of a 3.0 bean.
 * The declaration consists of:
 * 

* - an optional description * - the EJB reference name used in the code of the Deployment * Component that's referencing the enterprise bean. * - the optional expected type of the referenced enterprise bean * - the optional expected local interface of the referenced * enterprise bean or the local business interface of the * referenced enterprise bean. * - the optional expected local home interface of the referenced * enterprise bean. Not applicable if this ejb-local-ref refers * to the local business interface of a 3.0 bean. * - optional ejb-link information, used to specify the * referenced enterprise bean * - optional elements to define injection of the named enterprise * bean into a component field or property. */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "ejb-local-refType", propOrder = { "description", "ejbRefName", "ejbRefType", "localHome", "local", "ejbLink", "mappedName", "injectionTarget" }) public class EjbLocalRef implements EjbReference { @XmlElement(required = true) protected List description; @XmlElement(name = "ejb-ref-name", required = true) protected String ejbRefName; @XmlElement(name = "ejb-ref-type") protected EjbRefType ejbRefType; @XmlElement(name = "local-home") protected String localHome; protected String local; @XmlElement(name = "ejb-link") protected String ejbLink; @XmlElement(name = "mapped-name") protected String mappedName; @XmlElement(name = "injection-target", required = true) protected List injectionTarget; @XmlAttribute @XmlJavaTypeAdapter(CollapsedStringAdapter.class) @XmlID protected String id; public EjbLocalRef() { } public EjbLocalRef(String ejbRefName, String ejbLink) { this.ejbRefName = ejbRefName; this.ejbLink = ejbLink; } public EjbLocalRef(EjbReference ref) { this.ejbRefName = ref.getName(); this.ejbRefType = ref.getEjbRefType(); this.ejbLink = ref.getEjbLink(); this.mappedName = ref.getMappedName(); this.description = ref.getDescription(); this.injectionTarget = ref.getInjectionTarget(); this.local = ref.getInterface(); this.localHome = ref.getHome(); } public String getName() { return getEjbRefName(); } public String getKey() { return getName(); } public String getType() { return getEjbRefType().name(); } public void setName(String name) { setEjbRefName(name); } public void setType(String type) { } public List getDescription() { if (description == null) { description = new ArrayList(); } return this.description; } public String getEjbRefName() { return ejbRefName; } /** * The ejb-ref-name element contains the name of an EJB * reference. The EJB reference is an entry in the * Deployment Component's environment and is relative to the * java:comp/env context. The name must be unique within the * Deployment Component. *

* It is recommended that name is prefixed with "ejb/". *

* Example: *

* ejb/Payroll */ public void setEjbRefName(String value) { this.ejbRefName = value; } public EjbRefType getEjbRefType() { return ejbRefType; } public void setEjbRefType(EjbRefType value) { this.ejbRefType = value; } public String getLocalHome() { return localHome; } public String getHome() { return getLocalHome(); } public String getInterface() { return getLocal(); } public Type getRefType() { return Type.LOCAL; } public void setRefType(Type refType) { } public void setLocalHome(String value) { this.localHome = value; } public String getLocal() { return local; } public void setLocal(String value) { this.local = value; } public String getEjbLink() { return ejbLink; } /** * The value of the ejb-link element must be the ejb-name of an * enterprise bean in the same ejb-jar file or in another ejb-jar * file in the same Java EE application unit. *

* Alternatively, the name in the ejb-link element may be * composed of a path name specifying the ejb-jar containing the * referenced enterprise bean with the ejb-name of the target * bean appended and separated from the path name by "#". The * path name is relative to the Deployment File containing * Deployment Component that is referencing the enterprise * bean. This allows multiple enterprise beans with the same * ejb-name to be uniquely identified. *

* Examples: *

* EmployeeRecord *

* ../products/product.jar#ProductEJB */ public void setEjbLink(String value) { this.ejbLink = value; } public String getMappedName() { return mappedName; } public void setMappedName(String value) { this.mappedName = value; } public List getInjectionTarget() { if (injectionTarget == null) { injectionTarget = new ArrayList(); } return this.injectionTarget; } public String getId() { return id; } public void setId(String value) { this.id = value; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy