cn.wanghaomiao.maven.plugin.seimi.SeimiMojo Maven / Gradle / Ivy
package cn.wanghaomiao.maven.plugin.seimi;
/*
* Apache License Version2.0
*/
import org.apache.maven.archiver.MavenArchiver;
import org.apache.maven.artifact.Artifact;
import org.apache.maven.artifact.DependencyResolutionRequiredException;
import org.apache.maven.plugin.MojoExecutionException;
import org.apache.maven.plugin.MojoFailureException;
import cn.wanghaomiao.maven.plugin.seimi.util.ClassesPackager;
import org.apache.maven.plugins.annotations.Component;
import org.apache.maven.plugins.annotations.LifecyclePhase;
import org.apache.maven.plugins.annotations.Mojo;
import org.apache.maven.plugins.annotations.Parameter;
import org.apache.maven.plugins.annotations.ResolutionScope;
import org.apache.maven.project.MavenProjectHelper;
import org.codehaus.plexus.archiver.Archiver;
import org.codehaus.plexus.archiver.ArchiverException;
import org.codehaus.plexus.archiver.jar.ManifestException;
import org.codehaus.plexus.archiver.war.WarArchiver;
import org.codehaus.plexus.util.FileUtils;
import org.codehaus.plexus.util.StringUtils;
import java.io.File;
import java.io.IOException;
import java.util.Arrays;
@Mojo(name = "build", defaultPhase = LifecyclePhase.PACKAGE, threadSafe = true, requiresDependencyResolution = ResolutionScope.RUNTIME)
public class SeimiMojo extends AbstractWarMojo {
/**
* The directory for build.
*/
@Parameter(defaultValue = "${project.build.directory}", required = true)
private String outputDirectory;
/**
* The name of the final package.
*/
@Parameter(defaultValue = "${project.build.finalName}", property = "war.warName", required = true)
private String pkgName;
/**
* Classifier to add to the generated WAR. If given, the artifact will be an attachment instead. The classifier will
* not be applied to the JAR file of the project - only to the WAR file.
*/
@Parameter
private String classifier;
/**
* The comma separated list of tokens to exclude from the WAR before packaging. This option may be used to implement
* the skinny WAR use case. Note that you can use the Java Regular Expressions engine to include and exclude
* specific pattern using the expression %regex[]. Hint: read the about (?!Pattern).
*
* @since 2.1-alpha-2
*/
@Parameter
private String packagingExcludes;
/**
* The comma separated list of tokens to include in the WAR before packaging. By default everything is included.
* This option may be used to implement the skinny WAR use case. Note that you can use the Java Regular Expressions
* engine to include and exclude specific pattern using the expression %regex[].
*
* @since 2.1-beta-1
*/
@Parameter
private String packagingIncludes;
/**
* The WAR archiver.
*/
@Component(role = Archiver.class, hint = "war")
private WarArchiver warArchiver;
/**
*/
@Component
private MavenProjectHelper projectHelper;
private boolean primaryArtifact = true;
private boolean failOnMissingWebXml = false;
/**
* Whether classes (that is the content of the WEB-INF/classes directory) should be attached to the project as an
* additional artifact.
*
* By default the classifier for the additional artifact is 'classes'. You can change it with the
* someclassifier]]>
parameter.
*
*
* If this parameter true, another project can depend on the classes by writing something like:
*
*
*
* myGroup
* myArtifact
* myVersion
* classes
* ]]>
*
*
*
*
* @since 2.1-alpha-2
*/
@Parameter(defaultValue = "false")
private boolean attachClasses = false;
/**
* The classifier to use for the attached classes artifact.
*
* @since 2.1-alpha-2
*/
@Parameter(defaultValue = "classes")
private String classesClassifier = "classes";
// ----------------------------------------------------------------------
// Implementation
// ----------------------------------------------------------------------
/**
* Executes the WarMojo on the current project.
*
* @throws MojoExecutionException if an error occurred while building the webapp
* @throws MojoFailureException if an error.
*/
public void execute()
throws MojoExecutionException, MojoFailureException {
File warFile = getTargetWarFile();
try {
performPackaging(warFile);
} catch (DependencyResolutionRequiredException e) {
throw new MojoExecutionException("Error assembling WAR: " + e.getMessage(), e);
} catch (ManifestException e) {
throw new MojoExecutionException("Error assembling WAR", e);
} catch (IOException e) {
throw new MojoExecutionException("Error assembling WAR", e);
} catch (ArchiverException e) {
throw new MojoExecutionException("Error assembling WAR: " + e.getMessage(), e);
}
}
/**
* Generates the webapp according to the mode attribute.
*
* @param warFile the target WAR file
* @throws IOException if an error occurred while copying files
* @throws ArchiverException if the archive could not be created
* @throws ManifestException if the manifest could not be created
* @throws DependencyResolutionRequiredException if an error occurred while resolving the dependencies
* @throws MojoExecutionException if the execution failed
* @throws MojoFailureException if a fatal exception occurred
*/
private void performPackaging(File warFile)
throws IOException, ManifestException, DependencyResolutionRequiredException, MojoExecutionException,
MojoFailureException {
getLog().info("Packaging app");
buildExplodedWebapp(getWebappDirectory());
TemplateTask templateTask = new TemplateTask(getWebappDirectory(),getLog());
templateTask.createBinFile();
MavenArchiver archiver = new MavenArchiver();
archiver.setArchiver(warArchiver);
archiver.setOutputFile(warFile);
// CHECKSTYLE_OFF: LineLength
getLog().debug("Excluding " + Arrays.asList(getPackagingExcludes()) + " from the generated app archive.");
getLog().debug("Including " + Arrays.asList(getPackagingIncludes()) + " in the generated app archive.");
// CHECKSTYLE_ON: LineLength
warArchiver.addDirectory(getWebappDirectory(), getPackagingIncludes(), getPackagingExcludes());
// final File webXmlFile = new File(getWebappDirectory(), "WEB-INF/web.xml");
// if (webXmlFile.exists()) {
// warArchiver.setWebxml(webXmlFile);
// }
warArchiver.setRecompressAddedZips(isRecompressZippedFiles());
warArchiver.setIncludeEmptyDirs(isIncludeEmptyDirectories());
if (!failOnMissingWebXml) {
getLog().debug("Build won't fail if web.xml file is missing.");
warArchiver.setExpectWebXml(false);
}
// create archive
archiver.createArchive(getSession(), getProject(), getArchive());
// create the classes to be attached if necessary
if (isAttachClasses()) {
if (isArchiveClasses() && getJarArchiver().getDestFile() != null) {
// special handling in case of archived classes: MWAR-240
File targetClassesFile = getTargetClassesFile();
FileUtils.copyFile(getJarArchiver().getDestFile(), targetClassesFile);
projectHelper.attachArtifact(getProject(), "jar", getClassesClassifier(), targetClassesFile);
} else {
ClassesPackager packager = new ClassesPackager();
final File classesDirectory = packager.getClassesDirectory(getWebappDirectory());
if (classesDirectory.exists()) {
getLog().info("Packaging classes");
packager.packageClasses(classesDirectory, getTargetClassesFile(), getJarArchiver(), getSession(),
getProject(), getArchive());
projectHelper.attachArtifact(getProject(), "jar", getClassesClassifier(), getTargetClassesFile());
}
}
}
if (this.classifier != null) {
projectHelper.attachArtifact(getProject(), "war", this.classifier, warFile);
} else {
Artifact artifact = getProject().getArtifact();
if (primaryArtifact) {
artifact.setFile(warFile);
} else if (artifact.getFile() == null || artifact.getFile().isDirectory()) {
artifact.setFile(warFile);
}
}
}
/**
* @param basedir The basedir
* @param finalName The finalName
* @param classifier The classifier.
* @param type The type.
* @return {@link File}
*/
protected static File getTargetFile(File basedir, String finalName, String classifier, String type) {
if (classifier == null) {
classifier = "";
} else if (classifier.trim().length() > 0 && !classifier.startsWith("-")) {
classifier = "-" + classifier;
}
return new File(basedir, finalName + classifier + "." + type);
}
/**
* @return The war {@link File}
*/
protected File getTargetWarFile() {
return getTargetFile(new File(getOutputDirectory()), getPkgName(), getClassifier(), "zip");
}
/**
* @return The target class {@link File}
*/
protected File getTargetClassesFile() {
return getTargetFile(new File(getOutputDirectory()), getPkgName(), getClassesClassifier(), "jar");
}
// Getters and Setters
/**
* @return {@link #classifier}
*/
public String getClassifier() {
return classifier;
}
/**
* @param classifier {@link #classifier}
*/
public void setClassifier(String classifier) {
this.classifier = classifier;
}
/**
* @return The package excludes.
*/
public String[] getPackagingExcludes() {
if (StringUtils.isEmpty(packagingExcludes)) {
return new String[0];
} else {
return StringUtils.split(packagingExcludes, ",");
}
}
/**
* @param packagingExcludes {@link #packagingExcludes}
*/
public void setPackagingExcludes(String packagingExcludes) {
this.packagingExcludes = packagingExcludes;
}
/**
* @return The packaging includes.
*/
public String[] getPackagingIncludes() {
if (StringUtils.isEmpty(packagingIncludes)) {
return new String[]{"**"};
} else {
return StringUtils.split(packagingIncludes, ",");
}
}
/**
* @param packagingIncludes {@link #packagingIncludes}
*/
public void setPackagingIncludes(String packagingIncludes) {
this.packagingIncludes = packagingIncludes;
}
/**
* @return {@link #outputDirectory}
*/
public String getOutputDirectory() {
return outputDirectory;
}
/**
* @param outputDirectory {@link #outputDirectory}
*/
public void setOutputDirectory(String outputDirectory) {
this.outputDirectory = outputDirectory;
}
/**
* @return {@link #pkgName}
*/
public String getPkgName() {
return pkgName;
}
/**
* @param pkgName {@link #pkgName}
*/
public void setPkgName(String pkgName) {
this.pkgName = pkgName;
}
/**
* @return {@link #warArchiver}
*/
public WarArchiver getWarArchiver() {
return warArchiver;
}
/**
* @param warArchiver {@link #warArchiver}
*/
public void setWarArchiver(WarArchiver warArchiver) {
this.warArchiver = warArchiver;
}
/**
* @return {@link #projectHelper}
*/
public MavenProjectHelper getProjectHelper() {
return projectHelper;
}
/**
* @param projectHelper {@link #projectHelper}
*/
public void setProjectHelper(MavenProjectHelper projectHelper) {
this.projectHelper = projectHelper;
}
/**
* @return {@link #primaryArtifact}
*/
public boolean isPrimaryArtifact() {
return primaryArtifact;
}
/**
* @param primaryArtifact {@link #primaryArtifact}
*/
public void setPrimaryArtifact(boolean primaryArtifact) {
this.primaryArtifact = primaryArtifact;
}
/**
* @return {@link #attachClasses}
*/
public boolean isAttachClasses() {
return attachClasses;
}
/**
* @param attachClasses {@link #attachClasses}
*/
public void setAttachClasses(boolean attachClasses) {
this.attachClasses = attachClasses;
}
/**
* @return {@link #classesClassifier}
*/
public String getClassesClassifier() {
return classesClassifier;
}
/**
* @param classesClassifier {@link #classesClassifier}
*/
public void setClassesClassifier(String classesClassifier) {
this.classesClassifier = classesClassifier;
}
/**
* @return {@link #failOnMissingWebXml}
*/
public boolean isFailOnMissingWebXml() {
return failOnMissingWebXml;
}
/**
* @param failOnMissingWebXml {@link #failOnMissingWebXml}
*/
public void setFailOnMissingWebXml(boolean failOnMissingWebXml) {
this.failOnMissingWebXml = failOnMissingWebXml;
}
}