org.codehaus.mojo.keytool.GenerateCertificateMojo Maven / Gradle / Ivy
package org.codehaus.mojo.keytool;
/*
* Copyright 2005-2013 The Codehaus
*
* 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.
*/
import org.apache.maven.plugin.MojoExecutionException;
import org.apache.maven.plugins.annotations.Mojo;
import org.apache.maven.plugins.annotations.Parameter;
import org.apache.maven.shared.utils.cli.Commandline;
import org.codehaus.mojo.keytool.requests.KeyToolGenerateCertificateRequest;
import org.codehaus.plexus.util.StringUtils;
import java.io.File;
import java.util.List;
/**
* To generate certificate from a certificate request from a keystore.
*
* Implemented as a wrapper around the SDK {@code keytool -gencert} command.
*
* Note This operation was not implemented by the keytool before jdk 1.7.
*
* See keystore documentation.
*
* @author tchemit
* @since 1.2
*/
@Mojo( name = "generateCertificate", requiresProject = true )
public class GenerateCertificateMojo
extends AbstractKeyToolRequestWithKeyStoreAndAliasParametersMojo
{
/**
* Key password.
*
* See options.
*
* @since 1.2
*/
@Parameter
private String keypass;
/**
* Output in RFC style.
*
* See options.
*
* @since 1.2
*/
@Parameter
private boolean rfc;
/**
* input file name.
*
* See options.
*
* @since 1.2
*/
@Parameter
private File infile;
/**
* output file name.
*
* See options.
*
* @since 1.2
*/
@Parameter
private File outfile;
/**
* Signature algorithm name.
*
* See options.
*
* @since 1.2
*/
@Parameter
private String sigalg;
/**
* Distinguished name.
*
* See options.
*
* @since 1.2
*/
@Parameter
private String dname;
/**
* Certificate validity start date/time.
*
* See options.
*
* @since 1.2
*/
@Parameter
private String startdate;
/**
* X.509 extension.
*
* See options.
*
* @since 1.2
*
* @deprecated Use {@link #exts instead}.
*/
@Deprecated
@Parameter
private String ext;
/**
* X.509 extension.
*
* See options.
*
* @since 1.6
*/
@Parameter
private List exts;
/**
* Validity number of days.
*
* See options.
*
* @since 1.2
*/
@Parameter
private String validity;
/**
* Default contructor.
*/
public GenerateCertificateMojo()
{
super( KeyToolGenerateCertificateRequest.class );
}
@Override
public void execute() throws MojoExecutionException {
createParentDirIfNecessary(this.outfile.getPath());
super.execute();
}
/**
* {@inheritDoc}
*/
@Override
protected KeyToolGenerateCertificateRequest createKeytoolRequest()
{
KeyToolGenerateCertificateRequest request = super.createKeytoolRequest();
request.setKeypass( this.keypass );
request.setRfc( this.rfc );
request.setInfile( this.infile );
request.setOutfile( this.outfile );
request.setSigalg( this.sigalg );
request.setDname( this.dname );
request.setStartdate( this.startdate );
if (this.exts != null && !this.exts.isEmpty()) {
request.setExts(exts);
} else {
request.setExt(ext);
}
request.setValidity( this.validity );
return request;
}
/**
* {@inheritDoc}
*/
@Override
protected String getCommandlineInfo( Commandline commandLine )
{
String commandLineInfo = super.getCommandlineInfo( commandLine );
commandLineInfo = StringUtils.replace( commandLineInfo, this.keypass, "'*****'" );
return commandLineInfo;
}
}