blob: d8d29f87cb44ded546aaf1a9dc3b812846f6b164 [file] [log] [blame]
package org.apache.maven.plugin.deploy;
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.
*/
import java.util.Collection;
import java.util.Map;
import org.apache.maven.artifact.Artifact;
import org.apache.maven.artifact.factory.ArtifactFactory;
import org.apache.maven.artifact.repository.ArtifactRepository;
import org.apache.maven.artifact.repository.ArtifactRepositoryPolicy;
import org.apache.maven.artifact.repository.MavenArtifactRepository;
import org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout;
import org.apache.maven.execution.MavenSession;
import org.apache.maven.plugin.AbstractMojo;
import org.apache.maven.plugin.MojoExecutionException;
import org.apache.maven.plugin.MojoFailureException;
import org.apache.maven.plugins.annotations.Component;
import org.apache.maven.plugins.annotations.Parameter;
import org.apache.maven.shared.artifact.deploy.ArtifactDeployer;
import org.apache.maven.shared.artifact.deploy.ArtifactDeployerException;
/**
* @version $Id$
*/
public abstract class AbstractDeployMojo
extends AbstractMojo
{
/**
*/
@Component
private ArtifactDeployer deployer;
/**
* Component used to create an artifact.
*/
@Component
protected ArtifactFactory artifactFactory;
/**
* Map that contains the layouts.
*/
@Component( role = ArtifactRepositoryLayout.class )
private Map<String, ArtifactRepositoryLayout> repositoryLayouts;
/**
*/
@Parameter( defaultValue = "${localRepository}", required = true, readonly = true )
private ArtifactRepository localRepository;
/**
* Flag whether Maven is currently in online/offline mode.
*/
@Parameter( defaultValue = "${settings.offline}", readonly = true )
private boolean offline;
/**
* Parameter used to update the metadata to make the artifact as release.
*/
@Parameter( property = "updateReleaseInfo", defaultValue = "false" )
protected boolean updateReleaseInfo;
/**
* Parameter used to control how many times a failed deployment will be retried before giving up and failing. If a
* value outside the range 1-10 is specified it will be pulled to the nearest value within the range 1-10.
*
* @since 2.7
*/
@Parameter( property = "retryFailedDeploymentCount", defaultValue = "1" )
private int retryFailedDeploymentCount;
@Parameter( defaultValue = "${session}", readonly = true, required = true )
private MavenSession session;
/* Setters and Getters */
public ArtifactDeployer getDeployer()
{
return deployer;
}
public void setDeployer( ArtifactDeployer deployer )
{
this.deployer = deployer;
}
public ArtifactRepository getLocalRepository()
{
return localRepository;
}
public void setLocalRepository( ArtifactRepository localRepository )
{
this.localRepository = localRepository;
}
void failIfOffline()
throws MojoFailureException
{
if ( offline )
{
throw new MojoFailureException( "Cannot deploy artifacts when Maven is in offline mode" );
}
}
ArtifactRepositoryLayout getLayout( String id )
throws MojoExecutionException
{
ArtifactRepositoryLayout layout = repositoryLayouts.get( id );
if ( layout == null )
{
throw new MojoExecutionException( "Invalid repository layout: " + id );
}
return layout;
}
boolean isUpdateReleaseInfo()
{
return updateReleaseInfo;
}
int getRetryFailedDeploymentCount()
{
return retryFailedDeploymentCount;
}
/**
* Deploy an artifact from a particular file.
* @param artifacts the artifact definitions
* @param deploymentRepository the repository to deploy to
* @param localRepository the local repository to install into
* @param retryFailedDeploymentCount TODO
*
* @throws ArtifactDeployerException if an error occurred deploying the artifact
*/
protected void deploy( Collection<Artifact> artifacts, ArtifactRepository deploymentRepository,
ArtifactRepository localRepository, int retryFailedDeploymentCount )
throws ArtifactDeployerException
{
// for now retry means redeploy the complete artifacts collection
int retryFailedDeploymentCounter = Math.max( 1, Math.min( 10, retryFailedDeploymentCount ) );
ArtifactDeployerException exception = null;
for ( int count = 0; count < retryFailedDeploymentCounter; count++ )
{
try
{
if ( count > 0 )
{
getLog().info( "Retrying deployment attempt " + ( count + 1 ) + " of "
+ retryFailedDeploymentCounter );
}
getDeployer().deploy( session.getProjectBuildingRequest(), artifacts );
exception = null;
break;
}
catch ( ArtifactDeployerException e )
{
if ( count + 1 < retryFailedDeploymentCounter )
{
getLog().warn( "Encountered issue during deployment: " + e.getLocalizedMessage() );
getLog().debug( e );
}
if ( exception == null )
{
exception = e;
}
}
}
if ( exception != null )
{
throw exception;
}
}
protected ArtifactRepository createDeploymentArtifactRepository( String id, String url,
ArtifactRepositoryLayout layout,
boolean uniqueVersion2 )
{
return new MavenArtifactRepository( id, url, layout, new ArtifactRepositoryPolicy(),
new ArtifactRepositoryPolicy() );
}
}