CVEReports
CVEReports

Automated vulnerability intelligence platform. Comprehensive reports for high-severity CVEs generated by AI.

Product

  • Home
  • Sitemap
  • RSS Feed

Company

  • About
  • Contact
  • Privacy Policy
  • Terms of Service

© 2026 CVEReports. All rights reserved.

Made with love by Amit Schendel & Alon Barad



CVE-2026-27836

Unauthenticated Account Creation in phpMyFAQ WebAuthn Interface

Amit Schendel
Amit Schendel
Senior Security Researcher

Feb 28, 2026·4 min read·26 visits

Executive Summary (TL;DR)

Unauthenticated attackers can bypass registration restrictions and create active accounts via the WebAuthn API endpoint in phpMyFAQ versions < 4.0.18.

A critical authorization bypass vulnerability exists in the WebAuthn implementation of phpMyFAQ prior to version 4.0.18. The flaw allows unauthenticated attackers to create active user accounts even when public registration is explicitly disabled in the system configuration. This occurs due to missing configuration checks and CSRF validation in the `/api/webauthn/prepare` endpoint.

Vulnerability Overview

phpMyFAQ, a widely used open-source FAQ content management system, contains a logic flaw in its WebAuthn authentication flow. The vulnerability, identified as CVE-2026-27836, resides in the WebAuthnController class responsible for handling WebAuthn registration and authentication requests.

Normally, user registration is governed by global configuration settings (security.enableRegistration) and requires specific authorization checks. However, the prepare method in the API endpoint /api/webauthn/prepare failed to consult these configuration settings. Furthermore, it lacked Cross-Site Request Forgery (CSRF) protection, creating a direct path for unauthenticated actors to interact with the user creation logic.

The consequence is a complete bypass of the application's registration gates. An attacker can create valid, active user accounts regardless of administrative intent to close registration, potentially expanding the attack surface for further exploitation.

Root Cause Analysis

The root cause of this vulnerability is CWE-862: Missing Authorization. Specifically, the prepare method in src/phpMyFAQ/Controller/Frontend/WebAuthnController.php did not enforce the application's security policy before processing input.

In the vulnerable implementation, the controller directly processed JSON payloads containing a username field. Upon receiving this request, the application would:

  1. Skip Configuration Checks: It did not verify if security.enableWebAuthnSupport or security.enableRegistration were set to true.
  2. Skip CSRF Validation: It did not validate the anti-CSRF token usually required for state-changing operations.
  3. Improper State Initialization: It invoked $this->user->createUser($username) and immediately followed it with $this->user->setStatus('active'). This explicitly set the new user's status to active, bypassing any manual approval workflows or email verification steps that might otherwise apply.

This sequence meant that the mere presence of the code path was sufficient to allow account creation, irrespective of the system's runtime configuration.

Code Analysis

The patch provided in commit f2ab673f0668753cd0f7c7c8bc7fd2304dcf5cb1 introduces strict guards at the beginning of the prepare method. Below is a comparative analysis of the logic flow.

Vulnerable Logic

Prior to the fix, the method accepted the request and processed the user creation immediately:

public function prepare(Request $request): JsonResponse
{
    // ... (Payload decoding)
    $username = $data->username;
    // DIRECT CREATION WITHOUT CHECKS
    if (!$this->user->getUserByLogin($username, false)) {
        $this->user->createUser($username);
        $this->user->setStatus('active'); // Account is immediately usable
        // ...
    }
}

Patched Logic

The fix introduces three critical layers of defense: configuration verification, CSRF validation, and safe default status.

public function prepare(Request $request): JsonResponse
{
    // 1. Configuration Gates
    if (!$this->configuration->get('security.enableWebAuthnSupport')) {
        return $this->json(['error' => 'WebAuthn support is disabled.'], Response::HTTP_FORBIDDEN);
    }
    if (!$this->configuration->get('security.enableRegistration')) {
        return $this->json(['error' => 'Registration is disabled.'], Response::HTTP_FORBIDDEN);
    }
 
    // ... (Payload decoding)
 
    // 2. CSRF Validation
    $csrfToken = Filter::filterVar($data->csrf, FILTER_SANITIZE_SPECIAL_CHARS);
    if (!Token::getInstance()->verifyToken('webauthn-prepare', $csrfToken)) {
        return $this->json(['error' => Translation::get('ad_msg_noauth')], Response::HTTP_UNAUTHORIZED);
    }
 
    // 3. Safe Default Status
    if (!$this->user->getUserByLogin($username, false)) {
        $this->user->createUser($username);
        $this->user->setStatus('blocked'); // Account created but disabled by default
    }
}

Exploitation

Exploitation of CVE-2026-27836 is trivial and requires no authentication or special tooling. An attacker simply needs to send a crafted HTTP POST request to the target server. This can be performed via curl, Burp Suite, or any HTTP client.

Prerequisites:

  • Network access to the phpMyFAQ instance.
  • The phpMyFAQ version must be < 4.0.18.

Attack Vector:

POST /api/webauthn/prepare HTTP/1.1
Host: target-phpmyfaq.com
Content-Type: application/json
 
{
    "username": "malicious_user"
}

Outcome: If successful, the server responds with a 200 OK status (or similar success indicator related to WebAuthn challenge generation). A new user with the login malicious_user is created in the database with active status. The attacker has successfully bypassed the "Registration Disabled" setting.

Impact Assessment

The impact of this vulnerability is classified as High (CVSS 7.5) due to the complete compromise of the integrity of the user registration system.

  • Authorization Bypass: The primary impact is the ability to ignore administrative controls. Organizations often disable public registration for internal knowledge bases; this vulnerability negates that control.
  • User Enumeration: The response logic differs depending on whether a user already exists, allowing attackers to valid usernames.
  • Database Exhaustion (DoS): Because the endpoint requires no CAPTCHA or rate limiting in the vulnerable path, an attacker can script a loop to create thousands of junk accounts. This fills the database and potentially degrades performance for legitimate users.
  • Increased Attack Surface: While the created accounts do not immediately grant administrator privileges, they provide a valid footprint within the system. If other vulnerabilities exist that require a valid user context (even a low-privileged one), this bug serves as the entry point.

Official Patches

phpMyFAQOfficial GitHub Commit Fix
phpMyFAQRelease Notes for 4.0.18

Fix Analysis (1)

Technical Appendix

CVSS Score
7.5/ 10
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:H/A:N
EPSS Probability
0.04%

Affected Systems

phpMyFAQ < 4.0.18

Affected Versions Detail

Product
Affected Versions
Fixed Version
phpMyFAQ
phpMyFAQ
< 4.0.184.0.18
AttributeDetail
CWE IDCWE-862
CVSS v3.17.5 (High)
Attack VectorNetwork
Privileges RequiredNone
Exploit MaturityPoC Available
VendorphpMyFAQ

MITRE ATT&CK Mapping

T1068Exploitation for Privilege Escalation
Privilege Escalation
T1190Exploit Public-Facing Application
Initial Access
CWE-862
Missing Authorization

Vulnerability Timeline

Fix committed to main branch
2026-02-22
Public Disclosure / Advisory Published
2026-02-27

References & Sources

  • [1]GitHub Security Advisory GHSA-w22q-m2fm-x9f4
  • [2]NVD - CVE-2026-27836

More Reports

•5 days ago•CVE-2026-9354
6.9

CVE-2026-9354: Arbitrary Mass Mention Bypass in NousResearch hermes-agent Slack and Mattermost Adapters

A vulnerability in the Slack and Mattermost platform adapters for NousResearch hermes-agent permits an unauthenticated remote attacker to execute arbitrary mass mentions. By leveraging prompt injection, an attacker can bypass output sanitization logic and trigger workspace-wide notification exhaustion.

Alon Barad
Alon Barad
33 views•6 min read
•5 days ago•CVE-2026-9306
6.3

CVE-2026-9306: Unauthenticated Insecure Direct Object Reference (IDOR) in QuantumNous new-api Midjourney Relay

CVE-2026-9306 is a critical unauthenticated Insecure Direct Object Reference (IDOR) vulnerability located in the QuantumNous new-api application, affecting versions up to and including 0.12.1. The flaw is caused by improper middleware ordering combined with a lack of object-level authorization checks. This allows remote, unauthenticated attackers to retrieve sensitive Midjourney images belonging to other users by supplying a valid task identifier.

Amit Schendel
Amit Schendel
13 views•5 min read
•6 days ago•GHSA-GGXF-37HM-9WQF
6.5

GHSA-GGXF-37HM-9WQF: Session Leakage via Unsafe Challenge Path Parsing in instagrapi

The instagrapi library prior to version 2.6.9 contains an improper input validation vulnerability within its challenge handling mechanism. Maliciously crafted server responses can manipulate the client into forwarding session cookies and credentials to an external attacker-controlled domain.

Amit Schendel
Amit Schendel
21 views•6 min read
•6 days ago•GHSA-QQQM-5547-774X
9.1

GHSA-QQQM-5547-774X: Unauthenticated Path Traversal in FileBrowser Quantum PATCH Handler

GHSA-QQQM-5547-774X is a critical path traversal vulnerability in the FileBrowser Quantum application, specifically within the Go backend package. The vulnerability resides in the HTTP handler responsible for processing bulk file modifications via the public API. Unauthenticated attackers can exploit an order-of-operations flaw in the path sanitization logic to bypass intended directory restrictions. This allows adversaries to arbitrarily read, move, and overwrite files on the underlying filesystem by supplying specially crafted HTTP PATCH requests.

Alon Barad
Alon Barad
9 views•6 min read
•7 days ago•CVE-2026-8723
5.3

CVE-2026-8723: Synchronous Denial of Service in qs npm Package via TypeError

The qs query string parsing and serialization library for Node.js is vulnerable to a synchronous Denial of Service (DoS) attack. The vulnerability manifests as a process-terminating TypeError when processing arrays with null or undefined elements under specific configuration parameters.

Amit Schendel
Amit Schendel
36 views•7 min read
•7 days ago•GHSA-7M8F-HGJQ-8GC9
7.5

GHSA-7M8F-HGJQ-8GC9: Pre-Authentication Denial of Service via Insecure Deserialization Order in aiosend

The aiosend library prior to version 3.0.6 contains a pre-authentication Denial of Service (DoS) vulnerability in its webhook handling mechanism. The software processes and deserializes incoming JSON payloads before verifying the cryptographic signature, allowing unauthenticated attackers to exhaust server CPU and memory resources by sending large, complex payloads.

Amit Schendel
Amit Schendel
4 views•6 min read