com.cybersource.authsdk.jwt.KeyCertificateGenerator Maven / Gradle / Ivy
package com.cybersource.authsdk.jwt;
import java.io.FileInputStream;
import java.io.IOException;
import java.security.KeyStore;
import java.security.KeyStoreException;
import java.security.NoSuchAlgorithmException;
import java.security.UnrecoverableEntryException;
import java.security.KeyStore.PasswordProtection;
import java.security.KeyStore.PrivateKeyEntry;
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;
import java.security.interfaces.RSAPrivateKey;
import java.util.ArrayList;
import java.util.Enumeration;
import java.util.StringTokenizer;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import com.cybersource.authsdk.core.ConfigException;
import com.cybersource.authsdk.core.MerchantConfig;
public class KeyCertificateGenerator {
/**
* @param merchantConfig -contains merchant information.
* @return certificate which will be used to generate token.
** @throws CertificateException - if certificate is missing or wrong.
* @throws NoSuchAlgorithmException - if algorithm is not available.
* @throws IOException - if file is not found.
* @throws KeyStoreException - if file is not available in key store or
* wrong.
* @throws ConfigException - if some values is missing or wrong for
* merchant.
* @throws Exception - if some other exception will happen.
*/
public X509Certificate initializeCertificate(MerchantConfig merchantConfig) throws CertificateException,
NoSuchAlgorithmException, IOException, KeyStoreException, ConfigException, Exception {
if (merchantConfig != null && merchantConfig.getKeyAlias() != null && merchantConfig.getKeyFile() != null) {
KeyStore merchantKeyStore = KeyStore.getInstance("PKCS12", new BouncyCastleProvider());
merchantKeyStore.load(new FileInputStream(merchantConfig.getKeyFile()),
merchantConfig.getKeyPass().toCharArray());
String merchantKeyAlias = null;
Enumeration enumKeyStore = merchantKeyStore.aliases();
ArrayList array = new ArrayList();
while (enumKeyStore.hasMoreElements()) {
merchantKeyAlias = (String) enumKeyStore.nextElement();
array.add(merchantKeyAlias);
}
merchantKeyAlias = keyAliasValidator(array, merchantConfig.getKeyPass());
try {
PrivateKeyEntry e = (PrivateKeyEntry) merchantKeyStore.getEntry(merchantKeyAlias,
new PasswordProtection(merchantConfig.getKeyPass().toCharArray()));
return (X509Certificate) e.getCertificate();
} catch (UnrecoverableEntryException var5) {
return null;
}
} else {
return null;
}
}
/**
* @param array -list of keyAlias.
* @param merchantID -Id of merchant.
* @return merchantKeyalias for merchant.
*/
private static String keyAliasValidator(ArrayList array, String merchantID) {
int size = array.size();
String tempKeyAlias, merchantKeyAlias, result;
StringTokenizer str;
for (int i = 0; i < size; i++) {
merchantKeyAlias = array.get(i).toString();
str = new StringTokenizer(merchantKeyAlias, ",");
while (str.hasMoreTokens()) {
tempKeyAlias = str.nextToken();
if (tempKeyAlias.contains("CN")) {
str = new StringTokenizer(tempKeyAlias, "=");
while (str.hasMoreElements()) {
result = str.nextToken();
if (result.equalsIgnoreCase(merchantID)) {
return merchantKeyAlias;
}
}
}
}
}
return null;
}
/**
* @param merchantConfig - contains merchant information.
* @return certificate which will be used to generate token.
* @throws CertificateException if certificate is missing or wrong.
* @throws NoSuchAlgorithmException if algorithm is not available.
* @throws IOException if file is not found.
* @throws KeyStoreException if file is not available in key store or
* wrong.
* @throws ConfigException if some values is missing or wrong for
* merchant.
* @throws Exception if some other exception will happen.
*/
public RSAPrivateKey initializePrivateKey(MerchantConfig merchantConfig) throws CertificateException,
NoSuchAlgorithmException, IOException, KeyStoreException, ConfigException, Exception {
if (merchantConfig != null && merchantConfig.getKeyAlias() != null && merchantConfig.getKeyFile() != null) {
KeyStore merchantKeyStore = KeyStore.getInstance("PKCS12", new BouncyCastleProvider());
merchantKeyStore.load(new FileInputStream(merchantConfig.getKeyFile()),
merchantConfig.getKeyPass().toCharArray());
String merchantKeyAlias = null;
Enumeration enumKeyStore = merchantKeyStore.aliases();
while (enumKeyStore.hasMoreElements()) {
merchantKeyAlias = (String) enumKeyStore.nextElement();
if (merchantKeyAlias.contains(merchantConfig.getKeyAlias())) {
break;
}
}
try {
PrivateKeyEntry e = (PrivateKeyEntry) merchantKeyStore.getEntry(merchantKeyAlias,
new PasswordProtection(merchantConfig.getKeyPass().toCharArray()));
return (RSAPrivateKey) e.getPrivateKey();
} catch (UnrecoverableEntryException var5) {
return null;
}
} else {
return null;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy