errorUBL 2.1

UBL-CR-661:A UBL invoice should not include the PaymentMeansCode listID

UBL 2.1 Invoice schema does not include `cbc:PaymentMeansCode/@listID`. This element must be removed for EN 16931 compliance.

Severity
Fatal
Rule set
UBL 2.1
Country
All EU
Fix type
AUTO-FIX
Confidence
90%
Category
structural

Engine Classification

Remove disallowed UBL attribute per EN16931 specification

Confidence: 90% · Applied automatically in pipeline

What is UBL-CR-661?

UBL-CR-661 is a fatal validation rule defined in the UBL 2.1 specification. It validates the @listID element in the UBL invoice XML.

When this rule fires, the invoice is non-compliant and will be rejected by Peppol access points and national validation services. The sending system receives a rejection response and the invoice does not reach the buyer.

Target path: //cbc:PaymentMeansCode/@listID

Why This Error Matters

Invoice will be rejected by EN16931 validators. These conformance rules prohibit UBL attributes and element combinations not in the EN16931 e-invoicing profile. Remove the disallowed attribute or restructure the element.

UBL-CR-661 is a hard failure. Invoices that trigger this rule are rejected at the access point and never reach the recipient. In Peppol networks, this means your sending system receives an MLR (Message Level Response) with a rejection status. The invoice must be corrected and re-sent, adding delay to your payment cycle.

Invoice Navigator can automatically correct this error in your pipeline. The fix is applied with full audit evidence, so your compliance trail remains intact.

Validator Behavior

  • ·Causes invoice rejection
  • ·Fails UBL schema validation
  • ·Error returned: UBL-CR-661
  • ·Specification: UBL 2.1

Before / After

Failing XML
<cbc:PaymentMeansCode>
  <@listID>value</@listID>
</cbc:PaymentMeansCode>
Corrected XML
<cbc:PaymentMeansCode>
  <!-- @listID removed for EN 16931 compliance -->
</cbc:PaymentMeansCode>

Technical Reference

XPath//cbc:PaymentMeansCode/@listID
SpecUBL 2.1
Operationremove_attribute
StrategyRemove disallowed UBL attribute per EN16931 specification

Common Causes

  • ·PaymentMeansCode contains listID attribute
  • ·cbc:PaymentMeansCode/@listID not in EN16931
  • ·List identifier on payment code not permitted
  • ·UNTDID 4461 code list reference not needed
  • ·ERP exports list ID attribute on payment means

Seeing this in production? The API handles UBL-CR-661 automatically. See the fix response →

See Also

Last updated: 27 February 2026

Share this guide:

Handle UBL-CR-661 Automatically in Your Pipeline

The compliance engine auto-remediates this error with controlled safety policies and evidence pack generation.