// Testing CollectionCertStore generation from List
List certList = new ArrayList();
certList.add(rootCert);
certList.add(interCert);
certList.add(finalCert);
X509CollectionStoreParameters ccsp = new X509CollectionStoreParameters(certList);
X509Store certStore = X509Store.getInstance("Certificate/Collection", ccsp, "BC");
// set default to be the same as for SUN X500 name
X509Principal.DefaultReverse = true;
// Searching for rootCert by subjectDN
X509CertStoreSelector targetConstraints = new X509CertStoreSelector();
targetConstraints.setSubject(PrincipalUtil.getSubjectX509Principal(rootCert).getEncoded());
Collection certs = certStore.getMatches(targetConstraints);
if (certs.size() != 1 || !certs.contains(rootCert))
{
fail("rootCert not found by subjectDN");
}
// Searching for rootCert by subjectDN encoded as byte
targetConstraints = new X509CertStoreSelector();
targetConstraints.setSubject(PrincipalUtil.getSubjectX509Principal(rootCert).getEncoded());
certs = certStore.getMatches(targetConstraints);
if (certs.size() != 1 || !certs.contains(rootCert))
{
fail("rootCert not found by encoded subjectDN");
}
X509Principal.DefaultReverse = false;
// Searching for rootCert by public key encoded as byte
targetConstraints = new X509CertStoreSelector();
targetConstraints.setSubjectPublicKey(rootCert.getPublicKey().getEncoded());
certs = certStore.getMatches(targetConstraints);
if (certs.size() != 1 || !certs.contains(rootCert))
{
fail("rootCert not found by encoded public key");
}
// Searching for interCert by issuerDN
targetConstraints = new X509CertStoreSelector();
targetConstraints.setIssuer(PrincipalUtil.getSubjectX509Principal(rootCert).getEncoded());
certs = certStore.getMatches(targetConstraints);
if (certs.size() != 2)
{
fail("did not found 2 certs");
}
if (!certs.contains(rootCert))
{
fail("rootCert not found");
}
if (!certs.contains(interCert))
{
fail("interCert not found");
}
// Searching for rootCrl by issuerDN
List crlList = new ArrayList();
crlList.add(rootCrl);
crlList.add(interCrl);
ccsp = new X509CollectionStoreParameters(crlList);
X509Store store = X509Store.getInstance("CRL/Collection", ccsp, "BC");
X509CRLStoreSelector targetConstraintsCRL = new X509CRLStoreSelector();
targetConstraintsCRL.setIssuers(Collections.singleton(rootCrl.getIssuerX500Principal()));
Collection crls = store.getMatches(targetConstraintsCRL);
if (crls.size() != 1 || !crls.contains(rootCrl))
{
fail("rootCrl not found");
}
crls = certStore.getMatches(targetConstraintsCRL);
if (crls.size() != 0)
{
fail("error using wrong selector (CRL)");
}
certs = store.getMatches(targetConstraints);
if (certs.size() != 0)
{
fail("error using wrong selector (certs)");
}
// Searching for attribute certificates
X509V2AttributeCertificate attrCert = new X509V2AttributeCertificate(AttrCertTest.attrCert);
X509AttributeCertificate attrCert2 = new X509V2AttributeCertificate(AttrCertTest.certWithBaseCertificateID);
List attrList = new ArrayList();
attrList.add(attrCert);
attrList.add(attrCert2);
ccsp = new X509CollectionStoreParameters(attrList);
store = X509Store.getInstance("AttributeCertificate/Collection", ccsp, "BC");
X509AttributeCertStoreSelector attrSelector = new X509AttributeCertStoreSelector();
attrSelector.setHolder(attrCert.getHolder());
if (!attrSelector.getHolder().equals(attrCert.getHolder()))
{