org.xwiki.crypto.pkix.internal.BcX509v3CertificateGenerator Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of xwiki-commons-crypto-pkix Show documentation
Show all versions of xwiki-commons-crypto-pkix Show documentation
Provides X.509 certificates management
/*
* See the NOTICE file distributed with this work for additional
* information regarding copyright ownership.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.xwiki.crypto.pkix.internal;
import java.io.IOException;
import java.security.SecureRandom;
import org.xwiki.crypto.params.cipher.asymmetric.PublicKeyParameters;
import org.xwiki.crypto.pkix.params.CertifiedPublicKey;
import org.xwiki.crypto.pkix.params.PrincipalIndentifier;
import org.xwiki.crypto.pkix.params.x509certificate.X509CertificateGenerationParameters;
import org.xwiki.crypto.pkix.params.x509certificate.X509CertificateParameters;
import org.xwiki.crypto.pkix.params.x509certificate.extension.X509Extensions;
import org.xwiki.crypto.signer.Signer;
import org.xwiki.crypto.signer.SignerFactory;
/**
* Bouncy Castle based X.509 version 3 certificate generator.
*
* @version $Id: 94ccaa743c756bac6d7b4b295ac02ab0e0cfd8b1 $
* @since 5.4
*/
public class BcX509v3CertificateGenerator extends AbstractBcX509CertificateGenerator
{
private final X509Extensions extensions;
/**
* Create a initialized certificate generator.
*
* @param signer a certifying signer initialized with the certified key pair of the issuer
* or a signer initialized with the private key of the subject for creating a self sign certificate.
* @param parameters the common parameters for all certificate generated by this generator.
* @param signerFactory the signer factory to be used by the certificate to verify signature.
* @param random a random source.
*/
public BcX509v3CertificateGenerator(Signer signer, X509CertificateGenerationParameters parameters,
SignerFactory signerFactory, SecureRandom random)
{
super(signer, parameters, signerFactory, random);
this.extensions = parameters.getExtensions();
}
@Override
protected BcX509TBSCertificateBuilder getTBSCertificateBuilder()
{
return new BcX509v3TBSCertificateBuilder();
}
@Override
protected void extendsTBSCertificate(BcX509TBSCertificateBuilder builder, CertifiedPublicKey issuer,
PrincipalIndentifier subjectName, PublicKeyParameters subject, X509CertificateParameters parameters)
throws IOException
{
BcX509v3TBSCertificateBuilder bld = (BcX509v3TBSCertificateBuilder) builder;
if (issuer != null) {
bld.setExtensions(issuer, subject, this.extensions, parameters.getExtensions());
} else {
// Self signed certificate
bld.setExtensions(subject, this.extensions, parameters.getExtensions());
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy