Home

Description

The Xendit Payment plugin for WordPress is vulnerable to unauthorized order status manipulation in all versions up to, and including, 6.0.2. This is due to the plugin exposing a publicly accessible WooCommerce API callback endpoint (`wc_xendit_callback`) that processes payment callbacks without any authentication or cryptographic verification that the requests originate from Xendit's payment gateway. This makes it possible for unauthenticated attackers to mark any WooCommerce order as paid by sending a crafted POST request to the callback URL with a JSON body containing an `external_id` matching the order ID pattern and a `status` of 'PAID' or 'SETTLED', granted they can enumerate order IDs (which are sequential integers). This leads to orders being fraudulently marked as completed without any actual payment, resulting in financial loss and inventory depletion.

PUBLISHED Reserved 2025-12-10 | Published 2026-02-04 | Updated 2026-02-04 | Assigner Wordfence




MEDIUM: 5.3CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:L/A:N

Problem types

CWE-862 Missing Authorization

Product status

Default status
unaffected

* (semver)
affected

Timeline

2026-02-03:Disclosed

Credits

Md. Moniruzzaman Prodhan finder

References

www.wordfence.com/...-9101-4484-a352-0e4d2ce04e5d?source=cve

plugins.trac.wordpress.org/...runk/woocommerce-xendit-pg.php

plugins.trac.wordpress.org/....0.2/woocommerce-xendit-pg.php

cve.org (CVE-2025-14461)

nvd.nist.gov (CVE-2025-14461)

Download JSON