list.add(new ValidationError(HierarchyCertificateValidator.VALIDATOR_NAME, "Certificate issuer '" + BouncyCastleProviderHelper.getName(issuer.getSubjectX500Principal()) + "' is not a CA"));
}
} catch (SignatureException e) {
list.add(new ValidationError(HierarchyCertificateValidator.VALIDATOR_NAME, "Certificate '" + BouncyCastleProviderHelper.getName(certificate.getSubjectX500Principal()) + "' not signed by '" + BouncyCastleProviderHelper.getName(issuer.getSubjectX500Principal()) + "'"));
} catch (Exception e) {
throw new CertificateException(e);
}
}
try {
if (ConditionUtils.isNotEmpty(this.certificates)) {
boolean requiredOk = false;
outer: for (int i = 1; i < chain.length; i++) {
X509Certificate issuer = (X509Certificate) chain[i];
for (Certificate required : this.certificates) {
X509Certificate x509Required = (X509Certificate) required;
if (Arrays.equals(issuer.getEncoded(), x509Required.getEncoded())) {
requiredOk = true;
break outer;
}
}
}
if (!requiredOk) {
list.add(new ValidationError(HierarchyCertificateValidator.VALIDATOR_NAME, "Certificate chain is invalid, a required certificate could not be found"));
}
}
} catch (CertificateEncodingException e) {
throw new CertificateException(e);
}
return CollectionUtils.toArray(list, ValidationError.class);
}