// 
// Decompiled by Procyon v0.6.0
// 

package io.netty.handler.ssl.util;

import io.netty.pkitesting.X509Bundle;
import java.security.SecureRandom;
import java.util.Date;
import java.time.Instant;
import io.netty.pkitesting.CertificateBuilder;

final class CertificateBuilderCertGenerator
{
    private CertificateBuilderCertGenerator() {
    }
    
    static boolean isAvailable() {
        try {
            new CertificateBuilder();
            return true;
        }
        catch (final Throwable ignore) {
            return false;
        }
    }
    
    static void generate(final SelfSignedCertificate.Builder config) throws Exception {
        final String fqdn = config.fqdn;
        final Date notBefore = config.notBefore;
        final Date notAfter = config.notAfter;
        final String algorithm = config.algorithm;
        final SecureRandom random = config.random;
        final int bits = config.bits;
        final CertificateBuilder builder = new CertificateBuilder();
        builder.setIsCertificateAuthority(true);
        if (fqdn.contains("=")) {
            builder.subject(fqdn);
        }
        else {
            builder.subject("CN=" + fqdn);
        }
        builder.notBefore(Instant.ofEpochMilli(notBefore.getTime()));
        builder.notAfter(Instant.ofEpochMilli(notAfter.getTime()));
        if (random != null) {
            builder.secureRandom(random);
        }
        if ("RSA".equals(algorithm)) {
            CertificateBuilder.Algorithm alg = null;
            switch (bits) {
                case 2048: {
                    alg = CertificateBuilder.Algorithm.rsa2048;
                    break;
                }
                case 3072: {
                    alg = CertificateBuilder.Algorithm.rsa3072;
                    break;
                }
                case 4096: {
                    alg = CertificateBuilder.Algorithm.rsa4096;
                    break;
                }
                case 8192: {
                    alg = CertificateBuilder.Algorithm.rsa8192;
                    break;
                }
                default: {
                    throw new IllegalArgumentException("Unsupported RSA bit-width: " + bits);
                }
            }
            builder.algorithm(alg);
        }
        else if ("EC".equals(algorithm)) {
            if (bits == 256) {
                builder.algorithm(CertificateBuilder.Algorithm.ecp256);
            }
            else {
                if (bits != 384) {
                    throw new IllegalArgumentException("Unsupported EC-P bit-width: " + bits);
                }
                builder.algorithm(CertificateBuilder.Algorithm.ecp384);
            }
        }
        final X509Bundle bundle = builder.buildSelfSigned();
        config.paths = SelfSignedCertificate.newSelfSignedCertificate(fqdn, bundle.getKeyPair().getPrivate(), bundle.getCertificate());
        config.keypair = bundle.getKeyPair();
        config.privateKey = bundle.getKeyPair().getPrivate();
    }
}
