com.sun.enterprise.deployment.node.EntityManagerReferenceNode Maven / Gradle / Ivy
/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
*
* Copyright (c) 1997-2013 Oracle and/or its affiliates. All rights reserved.
*
* The contents of this file are subject to the terms of either the GNU
* General Public License Version 2 only ("GPL") or the Common Development
* and Distribution License("CDDL") (collectively, the "License"). You
* may not use this file except in compliance with the License. You can
* obtain a copy of the License at
* https://glassfish.dev.java.net/public/CDDL+GPL_1_1.html
* or packager/legal/LICENSE.txt. See the License for the specific
* language governing permissions and limitations under the License.
*
* When distributing the software, include this License Header Notice in each
* file and include the License file at packager/legal/LICENSE.txt.
*
* GPL Classpath Exception:
* Oracle designates this particular file as subject to the "Classpath"
* exception as provided by Oracle in the GPL Version 2 section of the License
* file that accompanied this code.
*
* Modifications:
* If applicable, add the following below the License Header, with the fields
* enclosed by brackets [] replaced by your own identifying information:
* "Portions Copyright [year] [name of copyright owner]"
*
* Contributor(s):
* If you wish your version of this file to be governed by only the CDDL or
* only the GPL Version 2, indicate your decision by adding "[Contributor]
* elects to include this software in this distribution under the [CDDL or GPL
* Version 2] license." If you don't indicate a single choice of license, a
* recipient has the option to distribute your version of this file under
* either the CDDL, the GPL Version 2 or to extend the choice of license to
* its licensees as provided above. However, if you add GPL Version 2 code
* and therefore, elected the GPL Version 2 license, then the option applies
* only if the new code is made subject to such option by the copyright
* holder.
*/
package com.sun.enterprise.deployment.node;
import com.sun.enterprise.deployment.EntityManagerReferenceDescriptor;
import com.sun.enterprise.deployment.InjectionTarget;
import com.sun.enterprise.deployment.xml.TagNames;
import org.w3c.dom.Node;
import javax.persistence.PersistenceContextType;
import javax.persistence.SynchronizationType;
import java.util.Map;
/**
* This node handles all persistence-context-ref xml tag elements
*
* @author Shing Wai Chan
* @version
*/
public class EntityManagerReferenceNode extends DeploymentDescriptorNode {
private static final String TRANSACTION = "Transaction";
private static final String EXTENDED = "Extended";
private static final String SYNCHRONIZED = "Synchronized";
private static final String UNSYNCHRONIZED = "Unsynchronized";
// Holds property name during name/value processing.
private String propertyName = null;
public EntityManagerReferenceNode() {
super();
registerElementHandler(new XMLElement(TagNames.INJECTION_TARGET),
InjectionTargetNode.class, "addInjectionTarget");
}
/**
* all sub-implementation of this class can use a dispatch table to map
* xml element to method name on the descriptor class for setting
* the element value.
*
* @return the map with the element name as a key, the setter method as
* a value
*/
protected Map getDispatchTable() {
// no need to be synchronized for now
Map table = super.getDispatchTable();
table.put(TagNames.PERSISTENCE_CONTEXT_REF_NAME, "setName");
table.put(TagNames.PERSISTENCE_UNIT_NAME, "setUnitName");
return table;
}
/**
* receives notiification of the value for a particular tag
*
* @param element the xml element
* @param value it's associated value
*/
public void setElementValue(XMLElement element, String value) {
if (TagNames.PERSISTENCE_CONTEXT_TYPE.equals(element.getQName())) {
EntityManagerReferenceDescriptor entityMgrReferenceDescriptor =
(EntityManagerReferenceDescriptor)getDescriptor();
PersistenceContextType contextType = null;
if (EXTENDED.equals(value)) {
contextType = PersistenceContextType.EXTENDED;
} else if (TRANSACTION.equals(value)) {
contextType = PersistenceContextType.TRANSACTION;
} else {
throw new IllegalArgumentException(localStrings.getLocalString(
"enterprise.deployment.node.invalidvalue",
"Invalid value for a tag under {0} : {1}",
new Object[] {TagNames.PERSISTENCE_CONTEXT_TYPE, value}));
}
entityMgrReferenceDescriptor.setPersistenceContextType(contextType);
} else if (TagNames.PERSISTENCE_CONTEXT_SYNCHRONIZATION_TYPE.equals(element.getQName() ) ) {
EntityManagerReferenceDescriptor entityMgrReferenceDescriptor =
(EntityManagerReferenceDescriptor)getDescriptor();
SynchronizationType synchronizationType;
if (SYNCHRONIZED.equals(value)) {
synchronizationType = SynchronizationType.SYNCHRONIZED;
} else if (UNSYNCHRONIZED.equals(value)) {
synchronizationType = SynchronizationType.UNSYNCHRONIZED;
} else {
throw new IllegalArgumentException(localStrings.getLocalString(
"enterprise.deployment.node.invalidvalue",
"Invalid value for a tag under {0} : {1}",
new Object[] {TagNames.PERSISTENCE_CONTEXT_SYNCHRONIZATION_TYPE, value}));
}
entityMgrReferenceDescriptor.setSynchronizationType(synchronizationType);
} else if (TagNames.NAME_VALUE_PAIR_NAME.equals(element.getQName())) {
propertyName = value;
} else if (TagNames.NAME_VALUE_PAIR_VALUE.equals(element.getQName())) {
EntityManagerReferenceDescriptor entityMgrReferenceDescriptor =
(EntityManagerReferenceDescriptor)getDescriptor();
entityMgrReferenceDescriptor.addProperty(propertyName, value);
propertyName = null;
} else {
super.setElementValue(element, value);
}
}
/**
* write the descriptor class to a DOM tree and return it
*
* @param parent node in the DOM tree
* @param nodeName name for the root element of this xml fragment
* @param descriptor descriptor to write
* @return the DOM tree top node
*/
public Node writeDescriptor(Node parent, String nodeName, EntityManagerReferenceDescriptor descriptor) {
Node entityMgrRefNode = appendChild(parent, nodeName);
writeLocalizedDescriptions(entityMgrRefNode, descriptor);
appendTextChild(entityMgrRefNode, TagNames.PERSISTENCE_CONTEXT_REF_NAME, descriptor.getName());
appendTextChild(entityMgrRefNode, TagNames.PERSISTENCE_UNIT_NAME, descriptor.getUnitName());
PersistenceContextType contextType = descriptor.getPersistenceContextType();
String contextTypeString = (contextType != null &&
PersistenceContextType.EXTENDED.equals(contextType)) ?
EXTENDED : TRANSACTION;
appendTextChild(entityMgrRefNode, TagNames.PERSISTENCE_CONTEXT_TYPE,
contextTypeString);
for(Map.Entry property :
descriptor.getProperties().entrySet()) {
Node propertyNode = appendChild(entityMgrRefNode,
TagNames.PERSISTENCE_PROPERTY);
appendTextChild(propertyNode, TagNames.NAME_VALUE_PAIR_NAME,
property.getKey());
appendTextChild(propertyNode, TagNames.NAME_VALUE_PAIR_VALUE,
property.getValue());
}
if( descriptor.isInjectable() ) {
InjectionTargetNode ijNode = new InjectionTargetNode();
for (InjectionTarget target : descriptor.getInjectionTargets()) {
ijNode.writeDescriptor(entityMgrRefNode, TagNames.INJECTION_TARGET, target);
}
}
return entityMgrRefNode;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy