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

org.xipki.security.speed.p12.P12DSASignLoadTest Maven / Gradle / Ivy

There is a newer version: 3.0.0
Show newest version
/*
 *
 * Copyright (c) 2013 - 2017 Lijun Liao
 *
 * 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.
 */

package org.xipki.security.speed.p12;

import java.security.SecureRandom;

import org.xipki.security.SecurityFactory;
import org.xipki.security.pkcs12.KeystoreGenerationParameters;
import org.xipki.security.pkcs12.P12KeyGenerationResult;
import org.xipki.security.pkcs12.P12KeyGenerator;

/**
 * @author Lijun Liao
 * @since 2.0.0
 */
// CHECKSTYLE:SKIP
public class P12DSASignLoadTest extends P12SignLoadTest {

    public P12DSASignLoadTest(final SecurityFactory securityFactory,
            final String signatureAlgorithm, final int plength, final int qlength)
            throws Exception {
        super(securityFactory, signatureAlgorithm,
                generateKeystore(plength, qlength),
                "PKCS#12 DSA signature creation\n"
                    + "plength: " + plength + "\n"
                    + "qlength: " + qlength);
    }

    private static byte[] generateKeystore(final int plength, final int qlength) throws Exception {
        byte[] keystoreBytes = getPrecomputedDSAKeystore(plength, qlength);
        if (keystoreBytes == null) {
            KeystoreGenerationParameters params = new KeystoreGenerationParameters(
                    PASSWORD.toCharArray());
            params.setRandom(new SecureRandom());
            P12KeyGenerationResult identity = new P12KeyGenerator().generateDSAKeypair(
                    plength, qlength, params, null);
            keystoreBytes = identity.keystore();
        }
        return keystoreBytes;
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy