Accessibly <= 3.0.3 - Missing Authorization to Unauthenticated Stored Cross-Site Scripting via Widget Source Injection via REST API
Summary
| CVE | CVE-2026-3643 |
|---|---|
| State | PUBLISHED |
| Assigner | Wordfence |
| Source Priority | CVE Program / NVD first with legacy fallback |
| Published | 2026-04-15 09:16:31 UTC |
| Updated | 2026-04-22 20:23:16 UTC |
| Description | The Accessibly plugin for WordPress is vulnerable to Stored Cross-Site Scripting via the REST API in all versions up to, and including, 3.0.3. The plugin registers REST API endpoints at `/otm-ac/v1/update-widget-options` and `/otm-ac/v1/update-app-config` with the `permission_callback` set to `__return_true`, which means no authentication or authorization check is performed. The `updateWidgetOptions()` function in `AdminApi.php` accepts user-supplied JSON data and passes it directly to `AccessiblyOptions::updateAppConfig()`, which saves it to the WordPress options table via `update_option()` without any sanitization or validation. The stored `widgetSrc` value is later retrieved by `AssetsManager::enqueueFrontendScripts()` and passed directly to `wp_enqueue_script()` as the script URL, causing it to be rendered as a `<script>` tag on every front-end page. This makes it possible for unauthenticated attackers to inject arbitrary JavaScript that executes for all site visitors by changing the `widgetSrc` option to point to a malicious external script. |
Risk And Classification
Primary CVSS: v3.1 7.2 HIGH from [email protected]
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:L/I:L/A:N
EPSS: 0.000940000 probability, percentile 0.261630000 (date 2026-04-22)
Problem Types: CWE-79 | CWE-79 CWE-79 Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')
| Version | Source | Type | Score | Severity | Vector |
|---|---|---|---|---|---|
| 3.1 | [email protected] | Primary | 7.2 | HIGH | CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:L/I:L/A:N |
| 3.1 | CNA | DECLARED | 7.2 | HIGH | CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:L/I:L/A:N |
CVSS v3.1 Breakdown
Attack Vector
NetworkAttack Complexity
LowPrivileges Required
NoneUser Interaction
NoneScope
ChangedConfidentiality
LowIntegrity
LowAvailability
NoneCVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:L/I:L/A:N
Vendor Declared Affected Products
| Source | Vendor | Product | Version | Platforms |
|---|---|---|---|---|
| CNA | Onthemapmarketing | Accessibly WordPress Website Accessibility | affected 3.0.3 semver | Not specified |
References
| Reference | Source | Link | Tags |
|---|---|---|---|
| plugins.trac.wordpress.org/browser/otm-accessibly/tags/3.0.3/public/Api/BaseApiControlle... | [email protected] | plugins.trac.wordpress.org | |
| plugins.trac.wordpress.org/browser/otm-accessibly/trunk/public/Data/AccessiblyOptions.php | [email protected] | plugins.trac.wordpress.org | |
| plugins.trac.wordpress.org/browser/otm-accessibly/trunk/public/admin/AdminApi.php | [email protected] | plugins.trac.wordpress.org | |
| plugins.trac.wordpress.org/browser/otm-accessibly/tags/3.0.3/public/AssetsManager.php | [email protected] | plugins.trac.wordpress.org | |
| www.wordfence.com/threat-intel/vulnerabilities/id/f8234ea2-ff80-425f-b83d-29c42... | [email protected] | www.wordfence.com | |
| plugins.trac.wordpress.org/browser/otm-accessibly/tags/3.0.3/public/admin/AdminApi.php | [email protected] | plugins.trac.wordpress.org | |
| plugins.trac.wordpress.org/browser/otm-accessibly/trunk/public/AssetsManager.php | [email protected] | plugins.trac.wordpress.org | |
| plugins.trac.wordpress.org/browser/otm-accessibly/trunk/public/Api/BaseApiController.php | [email protected] | plugins.trac.wordpress.org | |
| plugins.trac.wordpress.org/browser/otm-accessibly/tags/3.0.3/public/Data/AccessiblyOptio... | [email protected] | plugins.trac.wordpress.org | |
| CVE Program record | CVE.ORG | www.cve.org | canonical |
| NVD vulnerability detail | NVD | nvd.nist.gov | canonical, analysis |
Vendor Comments And Credit
Discovery Credit
CNA: Yoschanin Pulsirivong (en)
CNA: Ronnachai Sretawat Na Ayutaya (en)
CNA: Ronnachai Chaipha (en)
Additional Advisory Data
| Source | Time | Event |
|---|---|---|
| CNA | 2026-04-14T19:47:46.000Z | Disclosed |
There are currently no legacy QID mappings associated with this CVE.