All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.nicoulaj.maven.plugins.checksum.mojo.ArtifactsMojo Maven / Gradle / Ivy

/*
 * Copyright 2010-2016 Julien Nicoulaud 
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package net.nicoulaj.maven.plugins.checksum.mojo;

import org.apache.maven.artifact.Artifact;
import org.apache.maven.plugins.annotations.LifecyclePhase;
import org.apache.maven.plugins.annotations.Mojo;
import org.apache.maven.plugins.annotations.Parameter;

import java.util.LinkedList;
import java.util.List;

/**
 * Compute project artifacts checksum digests and store them in individual files and/or a summary file.
 *
 * @author Julien Nicoulaud
 * @since 1.0
 */
@Mojo(
    name = ArtifactsMojo.NAME,
    defaultPhase = LifecyclePhase.VERIFY,
    requiresProject = true,
    inheritByDefault = false,
    threadSafe = true )
public class ArtifactsMojo
    extends AbstractChecksumMojo
{

    /**
     * The mojo name.
     */
    public static final String NAME = "artifacts";

    /**
     * Indicates whether the build will store checksums in separate files (one file per algorithm per artifact).
     *
     * @since 1.0
     */
    @Parameter( defaultValue = "true" )
    protected boolean individualFiles;

    /**
     * The directory where output files will be stored. Leave unset to have each file next to the source file.
     *
     * @since 1.0
     */
    @Parameter
    protected String individualFilesOutputDirectory;

    /**
     * Indicates whether the build will store checksums to a single CSV summary file.
     *
     * @since 1.0
     */
    @Parameter( defaultValue = "false" )
    protected boolean csvSummary;

    /**
     * The name of the summary file created if the option is activated.
     *
     * @see #csvSummary
     * @since 1.0
     */
    @Parameter( defaultValue = "artifacts-checksums.csv" )
    protected String csvSummaryFile;

    /**
     * Indicates whether the build will store checksums to a single XML summary file.
     *
     * @since 1.0
     */
    @Parameter( defaultValue = "false" )
    protected boolean xmlSummary;

    /**
     * The name of the summary file created if the option is activated.
     *
     * @see #xmlSummary
     * @since 1.0
     */
    @Parameter( defaultValue = "artifacts-checksums.xml" )
    protected String xmlSummaryFile;

    /**
     * Indicates whether the build will store checksums to a single shasum summary file.
     *
     * @since 1.3
     */
    @Parameter( defaultValue = "false" )
    protected boolean shasumSummary;

    /**
     * The name of the summary file created if the option is activated.
     *
     * @see #shasumSummary
     * @since 1.3
     */
    @Parameter( defaultValue = "artifacts-checksums.sha" )
    protected String shasumSummaryFile;

    /**
     * Build the list of files from which digests should be generated.
     * 

*

The list is composed of the project main and attached artifacts.

* * @return the list of files that should be processed. * @see #hasValidFile(org.apache.maven.artifact.Artifact) */ @Override protected List getFilesToProcess() { List files = new LinkedList(); // Add project main artifact. if ( hasValidFile( project.getArtifact() ) ) { files.add( new ChecksumFile( "", project.getArtifact().getFile() ) ); } // Add projects attached. if ( project.getAttachedArtifacts() != null ) { for ( Artifact artifact : (List) project.getAttachedArtifacts() ) { if ( hasValidFile( artifact ) ) { files.add( new ChecksumFile( "", artifact.getFile() ) ); } } } return files; } /** * Decide whether the artifact file should be processed. *

*

Excludes the project POM file and any file outside the build directory, because this could lead to writing * files on the user local repository for example.

* * @param artifact the artifact to check. * @return true if the artifact should be included in the files to process. */ protected boolean hasValidFile( Artifact artifact ) { // Make sure the file exists. boolean hasValidFile = artifact != null && artifact.getFile() != null && artifact.getFile().exists(); // Exclude project POM file. hasValidFile = hasValidFile && !artifact.getFile().getPath().equals( project.getFile().getPath() ); // Exclude files outside of build directory. hasValidFile = hasValidFile && artifact.getFile().getPath().startsWith( project.getBuild().getDirectory() ); return hasValidFile; } /** * {@inheritDoc} */ @Override protected boolean isIndividualFiles() { return individualFiles; } /** * {@inheritDoc} */ @Override protected String getIndividualFilesOutputDirectory() { return individualFilesOutputDirectory; } /** * {@inheritDoc} */ @Override protected boolean isCsvSummary() { return csvSummary; } /** * {@inheritDoc} */ protected String getCsvSummaryFile() { return csvSummaryFile; } /** * {@inheritDoc} */ @Override protected boolean isXmlSummary() { return xmlSummary; } /** * {@inheritDoc} */ @Override protected String getXmlSummaryFile() { return xmlSummaryFile; } /** * {@inheritDoc} */ @Override protected boolean isShasumSummary() { return shasumSummary; } /** * {@inheritDoc} */ @Override protected String getShasumSummaryFile() { return shasumSummaryFile; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy