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

hudson.maven.RedeployPublisher Maven / Gradle / Ivy

Go to download

This plug-in is needed if you have legacy maven 2 job type. Preferred way to use maven in Hudson is by using maven as a builder in your Free Style job, which is provided by Maven 3 plugin. Version 3.0.1 of this plugin requires Hudson Version 3.1.2 or later.

There is a newer version: 3.0.2
Show newest version
/*
 * The MIT License
 * 
 * Copyright (c) 2004-2010, Sun Microsystems, Inc., Kohsuke Kawaguchi, id:cactusman, Seiji Sogabe
 * 
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 * 
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 * 
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */
package hudson.maven;

import hudson.Extension;
import hudson.Launcher;
import hudson.Util;
import hudson.maven.reporters.MavenAbstractArtifactRecord;
import hudson.model.AbstractBuild;
import hudson.model.AbstractProject;
import hudson.model.BuildListener;
import hudson.model.Result;
import hudson.tasks.BuildStepDescriptor;
import hudson.tasks.BuildStepMonitor;
import hudson.tasks.Publisher;
import hudson.tasks.Recorder;
import hudson.util.FormValidation;

import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import java.util.Map.Entry;

import net.sf.json.JSONObject;

import org.apache.maven.artifact.Artifact;
import org.apache.maven.artifact.deployer.ArtifactDeploymentException;
import org.apache.maven.artifact.metadata.ArtifactMetadata;
import org.apache.maven.artifact.repository.ArtifactRepository;
import org.apache.maven.artifact.repository.ArtifactRepositoryFactory;
import org.apache.maven.artifact.repository.ArtifactRepositoryPolicy;
import org.apache.maven.artifact.repository.Authentication;
import org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout;
import org.apache.maven.repository.Proxy;
import org.codehaus.plexus.component.repository.exception.ComponentLookupException;
import org.kohsuke.stapler.DataBoundConstructor;
import org.kohsuke.stapler.QueryParameter;
import org.kohsuke.stapler.StaplerRequest;

/**
 * {@link Publisher} for {@link MavenModuleSetBuild} to deploy artifacts
 * after a build is fully succeeded. 
 *
 * @author Kohsuke Kawaguchi
 * @since 1.191
 */
public class RedeployPublisher extends Recorder {
    /**
     * Repository ID. This is matched up with ~/.m2/settings.xml for authentication related information.
     */
    public final String id;
    /**
     * Repository URL to deploy artifacts to.
     */
    public final String url;
    public final boolean uniqueVersion;
    public final boolean evenIfUnstable;

    /**
     * For backward compatibility
     */
    public RedeployPublisher(String id, String url, boolean uniqueVersion) {
    	this(id, url, uniqueVersion, false);
    }
    
    /**
     * @since 1.347
     */
    @DataBoundConstructor
    public RedeployPublisher(String id, String url, boolean uniqueVersion, boolean evenIfUnstable) {
        this.id = id;
        this.url = Util.fixEmptyAndTrim(url);
        this.uniqueVersion = uniqueVersion;
        this.evenIfUnstable = evenIfUnstable;
    }

    public boolean perform(AbstractBuild build, Launcher launcher, BuildListener listener) throws InterruptedException, IOException {
        if(build.getResult().isWorseThan(getTreshold()))
            return true;    // build failed. Don't publish

        if (url==null) {
            listener.getLogger().println("No Repository URL is specified.");
            build.setResult(Result.FAILURE);
            return true;
        }

        List mars = getActions( build, listener );
        if(mars==null || mars.isEmpty()) {
            listener.getLogger().println("No artifacts are recorded. Is this a Maven project?");
            build.setResult(Result.FAILURE);
            return true;
        }

        listener.getLogger().println("Deploying artifacts to "+url);
        try {
            
            MavenEmbedder embedder = MavenUtil.createEmbedder(listener,build);
            ArtifactRepositoryLayout layout =
                (ArtifactRepositoryLayout) embedder.lookup( ArtifactRepositoryLayout.ROLE,"default");
            ArtifactRepositoryFactory factory =
                (ArtifactRepositoryFactory) embedder.lookup(ArtifactRepositoryFactory.ROLE);

            final ArtifactRepository repository = factory.createDeploymentArtifactRepository(
                    id, url, layout, uniqueVersion);
            WrappedArtifactRepository repo = new WrappedArtifactRepository(repository,uniqueVersion);
            for (MavenAbstractArtifactRecord mar : mars)
                mar.deploy(embedder,repo,listener);

            return true;
        } catch (MavenEmbedderException e) {
            e.printStackTrace(listener.error(e.getMessage()));
        } catch (ComponentLookupException e) {
            e.printStackTrace(listener.error(e.getMessage()));
        } catch (ArtifactDeploymentException e) {
            e.printStackTrace(listener.error(e.getMessage()));
        }
        // failed
        build.setResult(Result.FAILURE);
        return true;
    }


    
    /**
     * Obtains the {@link MavenAbstractArtifactRecord} that we'll work on.
     * 

* This allows promoted-builds plugin to reuse the code for delayed deployment. */ protected MavenAbstractArtifactRecord getAction(AbstractBuild build) { return build.getAction(MavenAbstractArtifactRecord.class); } protected List getActions(AbstractBuild build, BuildListener listener) { List actions = new ArrayList(); if (!(build instanceof MavenModuleSetBuild)) { return actions; } for (Entry e : ((MavenModuleSetBuild)build).getModuleLastBuilds().entrySet()) { MavenAbstractArtifactRecord a = e.getValue().getAction( MavenAbstractArtifactRecord.class ); if (a == null) { listener.getLogger().println("No artifacts are recorded for module" + e.getKey().getName() + ". Is this a Maven project?"); } else { actions.add( a ); } } return actions; } public BuildStepMonitor getRequiredMonitorService() { return BuildStepMonitor.NONE; } protected Result getTreshold() { if (evenIfUnstable) { return Result.UNSTABLE; } else { return Result.SUCCESS; } } @Extension public static class DescriptorImpl extends BuildStepDescriptor { public DescriptorImpl() { } /** * @deprecated as of 1.290 * Use the default constructor. */ protected DescriptorImpl(Class clazz) { super(clazz); } public boolean isApplicable(Class jobType) { return jobType==MavenModuleSet.class; } public RedeployPublisher newInstance(StaplerRequest req, JSONObject formData) throws FormException { return req.bindJSON(RedeployPublisher.class,formData); } public String getDisplayName() { return Messages.RedeployPublisher_getDisplayName(); } public boolean showEvenIfUnstableOption() { // little hack to avoid showing this option on the redeploy action's screen return true; } public FormValidation doCheckUrl(@QueryParameter String url) { String fixedUrl = hudson.Util.fixEmptyAndTrim(url); if (fixedUrl==null) return FormValidation.error(Messages.RedeployPublisher_RepositoryURL_Mandatory()); return FormValidation.ok(); } } //--------------------------------------------- public static class WrappedArtifactRepository implements ArtifactRepository { private ArtifactRepository artifactRepository; private boolean uniqueVersion; public WrappedArtifactRepository (ArtifactRepository artifactRepository, boolean uniqueVersion) { this.artifactRepository = artifactRepository; this.uniqueVersion = uniqueVersion; } public String pathOf( Artifact artifact ) { return artifactRepository.pathOf( artifact ); } public String pathOfRemoteRepositoryMetadata( ArtifactMetadata artifactMetadata ) { return artifactRepository.pathOfRemoteRepositoryMetadata( artifactMetadata ); } public String pathOfLocalRepositoryMetadata( ArtifactMetadata metadata, ArtifactRepository repository ) { return artifactRepository.pathOfLocalRepositoryMetadata( metadata, repository ); } public String getUrl() { return artifactRepository.getUrl(); } public void setUrl( String url ) { artifactRepository.setUrl( url ); } public String getBasedir() { return artifactRepository.getBasedir(); } public String getProtocol() { return artifactRepository.getProtocol(); } public String getId() { return artifactRepository.getId(); } public void setId( String id ) { artifactRepository.setId( id ); } public ArtifactRepositoryPolicy getSnapshots() { return artifactRepository.getSnapshots(); } public void setSnapshotUpdatePolicy( ArtifactRepositoryPolicy policy ) { artifactRepository.setSnapshotUpdatePolicy( policy ); } public ArtifactRepositoryPolicy getReleases() { return artifactRepository.getReleases(); } public void setReleaseUpdatePolicy( ArtifactRepositoryPolicy policy ) { artifactRepository.setReleaseUpdatePolicy( policy ); } public ArtifactRepositoryLayout getLayout() { return artifactRepository.getLayout(); } public void setLayout( ArtifactRepositoryLayout layout ) { artifactRepository.setLayout( layout ); } public String getKey() { return artifactRepository.getKey(); } public boolean isUniqueVersion() { return this.uniqueVersion; } public void setUniqueVersion(boolean uniqueVersion) { this.uniqueVersion = uniqueVersion; } public boolean isBlacklisted() { return artifactRepository.isBlacklisted(); } public void setBlacklisted( boolean blackListed ) { artifactRepository.setBlacklisted( blackListed ); } public Artifact find( Artifact artifact ) { return artifactRepository.find( artifact ); } public List findVersions( Artifact artifact ) { return artifactRepository.findVersions( artifact ); } public boolean isProjectAware() { return artifactRepository.isProjectAware(); } public void setAuthentication( Authentication authentication ) { artifactRepository.setAuthentication( authentication ); } public Authentication getAuthentication() { return artifactRepository.getAuthentication(); } public void setProxy( Proxy proxy ) { artifactRepository.setProxy( proxy ); } public Proxy getProxy() { return artifactRepository.getProxy(); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy