org.wildfly.plugin.deployment.AbstractDeployment Maven / Gradle / Ivy
/*
* Copyright The WildFly Authors
* SPDX-License-Identifier: Apache-2.0
*/
package org.wildfly.plugin.deployment;
import java.io.File;
import java.io.IOException;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import org.apache.maven.plugin.MojoExecutionException;
import org.apache.maven.plugin.MojoFailureException;
import org.apache.maven.plugins.annotations.Parameter;
import org.apache.maven.project.MavenProject;
import org.jboss.as.controller.client.ModelControllerClient;
import org.wildfly.plugin.common.AbstractServerConnection;
import org.wildfly.plugin.common.PropertyNames;
import org.wildfly.plugin.tools.ContainerDescription;
import org.wildfly.plugin.tools.Deployment;
import org.wildfly.plugin.tools.DeploymentManager;
import org.wildfly.plugin.tools.DeploymentResult;
/**
* The default implementation for executing build plans on the server.
*
* @author James R. Perkins
* @author Stuart Douglas
*/
abstract class AbstractDeployment extends AbstractServerConnection {
@Parameter(defaultValue = "${project}", readonly = true, required = true)
protected MavenProject project;
/**
* The server groups the content should be deployed to.
*/
@Parameter(alias = "server-groups", property = PropertyNames.SERVER_GROUPS)
private List serverGroups;
/**
* Specifies the name used for the deployment.
*/
@Parameter(property = PropertyNames.DEPLOYMENT_NAME)
private String name;
/**
* The runtime name for the deployment.
*
* In some cases users may wish to have two deployments with the same {@code runtime-name} (e.g. two versions of
* {@code example.war}) both available in the management configuration, in which case the deployments would need to
* have distinct {@code name} values but would have the same {@code runtime-name}.
*
*/
@Parameter(alias = "runtime-name", property = PropertyNames.DEPLOYMENT_RUNTIME_NAME)
private String runtimeName;
/**
* Set to {@code true} if you want the deployment to be skipped, otherwise {@code false}.
*/
@Parameter(defaultValue = "false", property = PropertyNames.SKIP)
private boolean skip;
/**
* The archive file.
*
* @return the archive file.
*/
protected abstract File file();
/**
* The goal of the deployment.
*
* @return the goal of the deployment.
*/
public abstract String goal();
@Override
public final void execute() throws MojoExecutionException, MojoFailureException {
if (skipExecution()) {
getLog().debug(String.format("Skipping deployment of %s:%s", project.getGroupId(), project.getArtifactId()));
return;
}
try (ModelControllerClient client = createClient()) {
final boolean isDomain = ContainerDescription.lookup(client).isDomain();
validate(isDomain);
// Deploy the deployment
getLog().debug("Executing deployment");
final Deployment deployment = configureDeployment(createDeployment());
final DeploymentResult result = executeDeployment(DeploymentManager.create(client), deployment);
if (!result.successful()) {
throw new MojoExecutionException(
String.format("Failed to execute goal %s: %s", goal(), result.getFailureMessage()));
}
} catch (IOException e) {
throw new MojoFailureException(String.format("Failed to execute goal %s.", goal()), e);
}
}
protected boolean skipExecution() {
return skip;
}
protected abstract DeploymentResult executeDeployment(DeploymentManager deploymentManager, Deployment deployment)
throws IOException, MojoDeploymentException;
protected Deployment createDeployment() {
return Deployment.of(file());
}
/**
* Validates the deployment.
*
* @param isDomain {@code true} if this is a domain server, otherwise {@code false}
*
* @throws MojoDeploymentException if the deployment is invalid
*/
protected void validate(final boolean isDomain) throws MojoDeploymentException {
final boolean hasServerGroups = hasServerGroups();
if (isDomain) {
if (!hasServerGroups) {
throw new MojoDeploymentException(
"Server is running in domain mode, but no server groups have been defined.");
}
} else if (hasServerGroups) {
throw new MojoDeploymentException("Server is running in standalone mode, but server groups have been defined.");
}
}
private Deployment configureDeployment(final Deployment deployment) {
return deployment.setName(name)
.setRuntimeName(runtimeName)
.addServerGroups(getServerGroups());
}
private Collection getServerGroups() {
return serverGroups == null ? Collections.emptyList() : serverGroups;
}
private boolean hasServerGroups() {
return serverGroups != null && !serverGroups.isEmpty();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy