From b97e051fbbd0f125ef5b5e640953de5b0668ef9b Mon Sep 17 00:00:00 2001 From: Brian Stansberry Date: Sat, 28 Dec 2024 09:29:39 -0500 Subject: [PATCH] [WFCORE-7127] Replace Attachments.CLASS_PATH_ENTRIES --- .../jboss/as/server/deployment/Attachments.java | 17 +++-------------- .../org/jboss/as/server/deployment/Phase.java | 2 +- .../module/ManifestClassPathProcessor.java | 15 +++++++++++---- .../module/ModuleClassPathProcessor.java | 9 ++++----- 4 files changed, 19 insertions(+), 24 deletions(-) diff --git a/server/src/main/java/org/jboss/as/server/deployment/Attachments.java b/server/src/main/java/org/jboss/as/server/deployment/Attachments.java index 6728bb3bfa9..83aadb04b11 100644 --- a/server/src/main/java/org/jboss/as/server/deployment/Attachments.java +++ b/server/src/main/java/org/jboss/as/server/deployment/Attachments.java @@ -38,7 +38,6 @@ /** * @author David M. Lloyd */ -@SuppressWarnings("deprecation") public final class Attachments { // @@ -120,19 +119,9 @@ public final class Attachments { */ public static final AttachmentKey MANIFEST = AttachmentKey.create(Manifest.class); - /** - * Module identifiers for Class-Path information. - *

- * Note: This is only meant for use within the server kernel. - * - * @deprecated this will either be changed incompatibly (to provide a string) or removed altogether in the next WildFly Core major. - */ - @Deprecated(forRemoval = true) - public static final AttachmentKey> CLASS_PATH_ENTRIES = AttachmentKey.createList(ModuleIdentifier.class); - /** * Resource roots for additional modules referenced via Class-Path. - * + *

* These are attached to the resource root that actually defined the class path entry, and are used to transitively resolve * the annotation index for class path items. */ @@ -231,7 +220,7 @@ public final class Attachments { /** * A service target that can be used to install services outside the scope of the deployment. - * + *

* These services will not be removed automatically on undeploy, so if this is used some other strategy must be used * to handle undeployment. */ @@ -296,7 +285,7 @@ public final class Attachments { /** * Sub deployments that are visible from this deployments module loader, in the order they are accessible. - * + *

* This list includes the current deployment, which under normal circumstances will be the first item in the list */ public static final AttachmentKey> ACCESSIBLE_SUB_DEPLOYMENTS = AttachmentKey.createList(DeploymentUnit.class); diff --git a/server/src/main/java/org/jboss/as/server/deployment/Phase.java b/server/src/main/java/org/jboss/as/server/deployment/Phase.java index 1620df0dc1c..63aa8530daa 100644 --- a/server/src/main/java/org/jboss/as/server/deployment/Phase.java +++ b/server/src/main/java/org/jboss/as/server/deployment/Phase.java @@ -85,7 +85,7 @@ public enum Phase { *

* In this phase, these phase attachments may be modified: *

*

diff --git a/server/src/main/java/org/jboss/as/server/deployment/module/ManifestClassPathProcessor.java b/server/src/main/java/org/jboss/as/server/deployment/module/ManifestClassPathProcessor.java index de009d1d7cb..d09c0234c62 100644 --- a/server/src/main/java/org/jboss/as/server/deployment/module/ManifestClassPathProcessor.java +++ b/server/src/main/java/org/jboss/as/server/deployment/module/ManifestClassPathProcessor.java @@ -16,6 +16,8 @@ import java.util.jar.Attributes; import java.util.jar.Manifest; +import org.jboss.as.server.deployment.AttachmentKey; +import org.jboss.as.server.deployment.AttachmentList; import org.jboss.as.server.logging.ServerLogger; import org.jboss.as.server.deployment.Attachable; import org.jboss.as.server.deployment.Attachments; @@ -56,6 +58,11 @@ */ public final class ManifestClassPathProcessor implements DeploymentUnitProcessor { + /** + * Module identifiers for Class-Path information. + */ + static final AttachmentKey> CLASS_PATH_MODULES = AttachmentKey.createList(String.class); + private static final String[] EMPTY_STRING_ARRAY = {}; /** @@ -147,7 +154,7 @@ public synchronized void deploy(final DeploymentPhaseContext phaseContext) throw if (item.startsWith("/")) { if (externalModuleService.isValidFile(item)) { final ModuleIdentifier moduleIdentifier = externalModuleService.addExternalModule(item, phaseContext.getServiceRegistry(), externalServiceTarget); - target.addToAttachmentList(Attachments.CLASS_PATH_ENTRIES, moduleIdentifier); + target.addToAttachmentList(CLASS_PATH_MODULES, moduleIdentifier.toString()); ServerLogger.DEPLOYMENT_LOGGER.debugf("Resource %s added as external jar %s", classPathFile, resourceRoot.getRoot()); } else { ServerLogger.DEPLOYMENT_LOGGER.classPathEntryNotValid(item, resourceRoot.getRoot().getPathName()); @@ -196,16 +203,16 @@ private void handlingExistingClassPathEntry(final ArrayDeque resource } else if (additionalModules.containsKey(classPathFile)) { final AdditionalModuleSpecification moduleSpecification = additionalModules.get(classPathFile); //as class path entries are exported, transitive dependencies will also be available - target.addToAttachmentList(Attachments.CLASS_PATH_ENTRIES, moduleSpecification.getModuleIdentifier()); + target.addToAttachmentList(CLASS_PATH_MODULES, moduleSpecification.getModuleName()); } else if (subDeployments.containsKey(classPathFile)) { //now we need to calculate the sub deployment module identifier //unfortunately the sub deployment has not been setup yet, so we cannot just //get it from the sub deployment directly final ResourceRoot otherRoot = subDeployments.get(classPathFile); - target.addToAttachmentList(Attachments.CLASS_PATH_ENTRIES, ModuleIdentifierProcessor.createModuleIdentifier(otherRoot.getRootName(), otherRoot, topLevelDeployment, topLevelRoot, false)); + target.addToAttachmentList(CLASS_PATH_MODULES, ModuleIdentifierProcessor.createModuleIdentifier(otherRoot.getRootName(), otherRoot, topLevelDeployment, topLevelRoot, false).toString()); } else { ModuleIdentifier identifier = createAdditionalModule(resourceRoot, topLevelDeployment, topLevelRoot, additionalModules, classPathFile, resourceRoots); - target.addToAttachmentList(Attachments.CLASS_PATH_ENTRIES, identifier); + target.addToAttachmentList(CLASS_PATH_MODULES, identifier.toString()); } } diff --git a/server/src/main/java/org/jboss/as/server/deployment/module/ModuleClassPathProcessor.java b/server/src/main/java/org/jboss/as/server/deployment/module/ModuleClassPathProcessor.java index 9e143e21af1..756d549250c 100644 --- a/server/src/main/java/org/jboss/as/server/deployment/module/ModuleClassPathProcessor.java +++ b/server/src/main/java/org/jboss/as/server/deployment/module/ModuleClassPathProcessor.java @@ -13,7 +13,6 @@ import org.jboss.as.server.deployment.DeploymentUnit; import org.jboss.as.server.deployment.DeploymentUnitProcessingException; import org.jboss.as.server.deployment.DeploymentUnitProcessor; -import org.jboss.modules.ModuleIdentifier; import org.jboss.modules.ModuleLoader; /** @@ -29,9 +28,9 @@ public void deploy(final DeploymentPhaseContext phaseContext) throws DeploymentU final ModuleSpecification moduleSpecification = deploymentUnit.getAttachment(Attachments.MODULE_SPECIFICATION); final ModuleLoader moduleLoader = deploymentUnit.getAttachment(Attachments.SERVICE_MODULE_LOADER); - final AttachmentList entries = deploymentUnit.getAttachment(Attachments.CLASS_PATH_ENTRIES); + final AttachmentList entries = deploymentUnit.getAttachment(ManifestClassPathProcessor.CLASS_PATH_MODULES); if (entries != null) { - for (ModuleIdentifier entry : entries) { + for (String entry : entries) { //class path items are always exported to make transitive dependencies work moduleSpecification.addLocalDependency(new ModuleDependency(moduleLoader, entry, false, true, true, false)); } @@ -40,14 +39,14 @@ public void deploy(final DeploymentPhaseContext phaseContext) throws DeploymentU final List additionalModules = deploymentUnit.getAttachment(Attachments.ADDITIONAL_MODULES); if (additionalModules != null) { for (AdditionalModuleSpecification additionalModule : additionalModules) { - final AttachmentList dependencies = additionalModule.getAttachment(Attachments.CLASS_PATH_ENTRIES); + final AttachmentList dependencies = additionalModule.getAttachment(ManifestClassPathProcessor.CLASS_PATH_MODULES); if (dependencies == null || dependencies.isEmpty()) { continue; } // additional modules export any class-path entries // this means that a module that references the additional module // gets access to the transitive closure of its call-path entries - for (ModuleIdentifier entry : dependencies) { + for (String entry : dependencies) { additionalModule.addLocalDependency(new ModuleDependency(moduleLoader, entry, false, true, true, false)); } // add a dependency on the top ear itself for good measure