package org.bouncycastle.cms.jcajce;
import java.security.cert.CertificateEncodingException;
import java.security.cert.X509Certificate;
import org.bouncycastle.asn1.x500.X500Name;
import org.bouncycastle.cms.KeyTransRecipientId;
import org.bouncycastle.jce.PrincipalUtil;
import org.bouncycastle.jce.X509Principal;
public class JceKeyTransRecipientId
extends KeyTransRecipientId
{
public JceKeyTransRecipientId(X509Certificate certificate)
{
super(X500Name.getInstance(extractIssuer(certificate)), certificate.getSerialNumber());
}
private static X509Principal extractIssuer(X509Certificate certificate)
{
try
{
return PrincipalUtil.getIssuerX509Principal(certificate);
}
catch (CertificateEncodingException e)
{
throw new IllegalStateException("can't extract issuer");
}
}
}