package hr.com.port.ips.eracun.validation.rules;

import hr.com.port.ips.eracun.validation.BusinessRule;
import hr.com.port.ips.eracun.validation.RuleResult;
import hr.com.port.ips.eracun.validation.XmlEval;
import hr.com.port.ips.eracun.validation.Bt;
import org.w3c.dom.Document;
import org.apache.log4j.Logger;
import hr.com.port.functions.Functions;

public final class HrBr9 implements BusinessRule {
    private static final Logger logger = Logger.getLogger(HrBr9.class);

    public String getId() { return "HR-BR-9"; }
    public String getDescription() { return "Račun mora sadržavati OIB operatera (HR-BT-5)"; }

    public RuleResult validate(Document doc) {
        try {
            boolean ok = Bt.has(doc, "HR-BT-5");
            String msg = ok ? "OK" : "Nedostaje OIB operatera (HR-BT-5).";
            return new RuleResult(getId(), ok, msg);
        } catch (Exception ex) {
            logger.error(new Functions().logging(ex));
            return new RuleResult(getId(), false, "Greška u provjeri: " + ex.getMessage());
        }
    }
}
