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 Br7 implements BusinessRule {
    private static final Logger logger = Logger.getLogger(Br7.class);

    public String getId() { return "BR-7"; }
    public String getDescription() { return "Račun mora sadržavati ime Kupca (BT-44)"; }

    public RuleResult validate(Document doc) {
        try {
            boolean ok = Bt.customerName(doc).trim().length() > 0;
            String msg = ok ? "OK" : "Nedostaje ime Kupca (BT-44).";
            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());
        }
    }
}
