package eu.europa.esig.dss.validation.process.bbb.xcv.sub.checks; import eu.europa.esig.dss.jaxb.detailedreport.XmlSubXCV; import eu.europa.esig.dss.validation.policy.rules.Indication; import eu.europa.esig.dss.validation.policy.rules.SubIndication; import eu.europa.esig.dss.validation.process.CertificatePolicyIdentifiers; import eu.europa.esig.dss.validation.process.ChainItem; import eu.europa.esig.dss.validation.process.MessageTag; import eu.europa.esig.dss.validation.reports.wrapper.CertificateWrapper; import eu.europa.esig.jaxb.policy.LevelConstraint; public class CertificateIssuedToLegalPersonCheck extends ChainItem<XmlSubXCV> { private final CertificateWrapper certificate; public CertificateIssuedToLegalPersonCheck(XmlSubXCV result, CertificateWrapper certificate, LevelConstraint constraint) { super(result, constraint); this.certificate = certificate; } @Override protected boolean process() { // This check only uses the certificate (not the TL) return CertificatePolicyIdentifiers.isLegal(certificate); } @Override protected MessageTag getMessageTag() { return MessageTag.BBB_XCV_CMDCIITLP; } @Override protected MessageTag getErrorMessageTag() { return MessageTag.BBB_XCV_CMDCIITLP_ANS; } @Override protected Indication getFailedIndicationForConclusion() { return Indication.FAILED; } @Override protected SubIndication getFailedSubIndicationForConclusion() { return SubIndication.CHAIN_CONSTRAINTS_FAILURE; } }