com.sun.enterprise.deployment.annotation.handlers.ConcurrencyDefinitionConvertor Maven / Gradle / Ivy
The newest version!
/*
* Copyright (c) 2022, 2024 Eclipse Foundation and/or its affiliates.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0, which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* This Source Code may also be made available under the following Secondary
* Licenses when the conditions for such availability set forth in the
* Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
* version 2 with the GNU Classpath Exception, which is available at
* https://www.gnu.org/software/classpath/license.html.
*
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
*/
package com.sun.enterprise.deployment.annotation.handlers;
import com.sun.enterprise.deployment.ResourceDescriptor;
import com.sun.enterprise.deployment.annotation.context.ResourceContainerContext;
import java.lang.System.Logger;
import java.util.List;
import java.util.Objects;
import java.util.Set;
import java.util.stream.Collectors;
import org.glassfish.deployment.common.JavaEEResourceType;
import static com.sun.enterprise.deployment.ResourceDescriptor.getJavaComponentJndiName;
import static java.lang.System.Logger.Level.DEBUG;
/**
* @author David Matejcek
*/
abstract class ConcurrencyDefinitionConvertor {
private static final Logger LOG = System.getLogger(ConcurrencyDefinitionConvertor.class.getName());
private final Class descriptorClass;
private final JavaEEResourceType descriptorType;
ConcurrencyDefinitionConvertor(Class descriptorClass, JavaEEResourceType descriptorType) {
this.descriptorClass = descriptorClass;
this.descriptorType = descriptorType;
}
abstract T createDescriptor(D data);
abstract D getData(T descriptor);
abstract void merge(D annotationData, D descriptorData);
final void updateDescriptors(D data, ResourceContainerContext[] contexts) {
LOG.log(DEBUG, "updateDescriptors(data={0}, contexts.length={1})", data, contexts.length);
for (ResourceContainerContext context : contexts) {
Set descriptors = context.getResourceDescriptors(descriptorType);
List existing = getExisting(data, descriptors);
if (existing.isEmpty()) {
T descriptor = createDescriptor(data);
descriptors.add(descriptor);
LOG.log(DEBUG, () -> "Added new descriptor based on annotation: " + descriptor);
} else {
for (D existingData : existing) {
merge(data, existingData);
LOG.log(DEBUG,
() -> "Merged data " + data + " into existing descriptor data, result: " + existingData);
}
}
}
}
/**
* The XML can have a single special value (empty element) which means to override annotation
* qualifiers to an empty list.
*
* @param annotation
* @param descriptor
*/
final void mergeQualifiers(D annotation, D descriptor) {
if (descriptor.getQualifiers().size() == 1 && descriptor.getQualifiers().get(0).isEmpty()) {
descriptor.setQualifiers(List.of());
} else if (descriptor.getQualifiers().isEmpty() && !annotation.getQualifiers().isEmpty()) {
descriptor.setQualifiers(annotation.getQualifiers());
}
}
// isSameDefinition ensures it.
@SuppressWarnings("unchecked")
private List getExisting(D data, Set descriptors) {
return descriptors.stream().filter(d -> isSameDefinition(data, d)).map(d -> getData((T) d))
.collect(Collectors.toList());
}
private boolean isSameDefinition(D data, ResourceDescriptor descriptor) {
return descriptorClass.isInstance(descriptor) && Objects
.equals(getJavaComponentJndiName(descriptor.getJndiName().toString()), getJavaComponentJndiName(data.getName()));
}
}