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;
}
}