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

org.xipki.security.speed.p12.P12ECSignLoadTest 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 P12ECSignLoadTest extends P12SignLoadTest {

    public P12ECSignLoadTest(final SecurityFactory securityFactory, final String signatureAlgorithm,
            final String curveNameOrOid) throws Exception {
        super(securityFactory, signatureAlgorithm, generateKeystore(curveNameOrOid),
                "PKCS#12 EC signature creation\ncurve: " + curveNameOrOid);
    }

    private static byte[] generateKeystore(final String curveNameOrOid) throws Exception {
        byte[] keystoreBytes = getPrecomputedECKeystore(curveNameOrOid);
        if (keystoreBytes == null) {
            KeystoreGenerationParameters params = new KeystoreGenerationParameters(
                    PASSWORD.toCharArray());
            params.setRandom(new SecureRandom());
            P12KeyGenerationResult identity = new P12KeyGenerator().generateECKeypair(
                    curveNameOrOid, params, null);
            keystoreBytes = identity.keystore();
        }
        return keystoreBytes;
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy