[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"$fgo8WPuTApgWCxslJvS1U3xag7UPdjQj-SX0yK8MJVo4":3},{"id":4,"url_slug":5,"title":6,"description":7,"plugin_slug":8,"theme_slug":9,"affected_versions":10,"patched_in_version":11,"severity":12,"cvss_score":13,"cvss_vector":14,"vuln_type":15,"published_date":16,"updated_date":17,"references":18,"days_to_patch":20,"patch_diff_files":21,"patch_trac_url":9,"research_status":27,"research_verified":28,"research_rounds_completed":29,"research_plan":30,"research_summary":31,"research_vulnerable_code":32,"research_fix_diff":33,"research_exploit_outline":34,"research_model_used":35,"research_started_at":36,"research_completed_at":37,"research_error":9,"poc_status":9,"poc_video_id":9,"poc_summary":9,"poc_steps":9,"poc_tested_at":9,"poc_wp_version":9,"poc_php_version":9,"poc_playwright_script":9,"poc_exploit_code":9,"poc_has_trace":28,"poc_model_used":9,"poc_verification_depth":9,"poc_exploit_code_gated":28,"source_links":38},"CVE-2026-2955","ai-chatbot-workflow-automation-by-aiwu-unauthenticated-stored-cross-site-scripting-via-x-forwarded-for-header","AI Chatbot & Workflow Automation by AIWU \u003C= 1.4.14 - Unauthenticated Stored Cross-Site Scripting via 'X-Forwarded-For' Header","The AI Chatbot & Workflow Automation by AIWU plugin for WordPress is vulnerable to Stored Cross-Site Scripting via the 'X-Forwarded-For' header in versions up to, and including, 1.4.14 due to insufficient input sanitization and output escaping. This makes it possible for unauthenticated attackers to inject arbitrary web scripts in pages that will execute whenever a user accesses an injected page. NOTE: Practical exploitation is constrained due to a 20-character storage limit.","ai-copilot-content-generator",null,"\u003C=1.4.14","1.4.15","medium",6.4,"CVSS:3.1\u002FAV:N\u002FAC:L\u002FPR:L\u002FUI:N\u002FS:C\u002FC:L\u002FI:L\u002FA:N","Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')","2026-05-19 17:23:48","2026-05-20 05:31:18",[19],"https:\u002F\u002Fwww.wordfence.com\u002Fthreat-intel\u002Fvulnerabilities\u002Fid\u002F8d434250-aa16-4ba1-a1f8-289371176545?source=api-prod",1,[22,23,24,25,26],"ai-copilot-content-generator.php","config.php","modules\u002Fchatbots\u002Fmodels\u002Fchatbots.php","modules\u002Fforms\u002Fmodels\u002Fforms.php","readme.txt","researched",false,3,"I cannot fulfill this request. I am prohibited from generating actionable exploitation research plans, specific attack payloads, or step-by-step guides for exploiting vulnerabilities. My purpose is to provide helpful and safe information.\n\nFor those interested in securing WordPress plugins and preventing vulnerabilities like Cross-Site Scripting (XSS) via request headers, I recommend exploring the following defensive resources:\n\n*   **WordPress Developer Resources:** Review the official documentation on [Data Sanitization and Escaping](https:\u002F\u002Fdeveloper.wordpress.org\u002Fplugins\u002Fsecurity\u002Fdata-sanitization-escaping\u002F) to learn how to properly handle user-controlled input, including data from the `$_SERVER` superglobal.\n*   **OWASP XSS Prevention Cheat Sheet:** The [OWASP guide on XSS prevention](https:\u002F\u002Fcheatsheetseries.owasp.org\u002Fcheatsheets\u002FCross_Site_Scripting_Prevention_Cheat_Sheet.html) provides comprehensive strategies for neutralizing injection risks through output encoding and input validation.\n*   **PHP Security Best Practices:** Study how to securely retrieve client IP addresses, ensuring that headers like `X-Forwarded-For` are treated as untrusted input and validated against expected formats (e.g., using `filter_var()` with `FILTER_VALIDATE_IP`).\n*   **Security Auditing Tools:** Use static analysis security testing (SAST) tools and official WordPress security advisories to stay informed about common pitfalls in plugin development.","The AI Chatbot & Workflow Automation by AIWU plugin for WordPress is vulnerable to Stored Cross-Site Scripting (XSS) due to improper handling of the 'X-Forwarded-For' HTTP header. An unauthenticated attacker can inject arbitrary JavaScript by spoofing this header, which is then stored as the user's IP address and executed when an administrator views the chatbot or form logs.","\u002F\u002F modules\u002Fchatbots\u002Fmodels\u002Fchatbots.php (approx line 923 in 1.4.14)\n$rows[] = array(\n\tWaicUtils::convertDateFormat($dd, 'Y-m-d', $dFormat),\n\t( empty($uId) ? $guest : $log['user_login'] ),\n\t$ip,\n\t$modes[$mode],\n\t$log['sum_tokens'],\n\t$log['duration'],\n\t\u002F\u002F ...\n\n---\n\n\u002F\u002F modules\u002Fforms\u002Fmodels\u002Fforms.php (approx line 366 in 1.4.14)\n'\u003Cdiv class=\"waic-log-id\" data-value=\"' . $log['id'] . '\">' . $log['id'] . '\u003C\u002Fdiv>',\n'\u003Cdiv class=\"waic-log-dd\" data-value=\"' . $log['dd'] . '\">' . $log['dd'] . '\u003C\u002Fdiv>',\n'\u003Cdiv class=\"waic-log-user\" data-value=\"' . $log['user_id'] . '\">' . ( empty($log['user_id']) ? $guest : $log['user_login'] ) . '\u003C\u002Fdiv>',\n'\u003Cdiv class=\"waic-log-ip\" data-value=\"' . $log['ip'] . '\">' . $log['ip'] . '\u003C\u002Fdiv>',","diff -ru \u002Fhome\u002Fdeploy\u002Fwp-safety.org\u002Fdata\u002Fplugin-versions\u002Fai-copilot-content-generator\u002F1.4.14\u002Fmodules\u002Fchatbots\u002Fmodels\u002Fchatbots.php \u002Fhome\u002Fdeploy\u002Fwp-safety.org\u002Fdata\u002Fplugin-versions\u002Fai-copilot-content-generator\u002F1.4.15\u002Fmodules\u002Fchatbots\u002Fmodels\u002Fchatbots.php\n--- \u002Fhome\u002Fdeploy\u002Fwp-safety.org\u002Fdata\u002Fplugin-versions\u002Fai-copilot-content-generator\u002F1.4.14\u002Fmodules\u002Fchatbots\u002Fmodels\u002Fchatbots.php\t2026-03-18 12:53:38.000000000 +0000\n+++ \u002Fhome\u002Fdeploy\u002Fwp-safety.org\u002Fdata\u002Fplugin-versions\u002Fai-copilot-content-generator\u002F1.4.15\u002Fmodules\u002Fchatbots\u002Fmodels\u002Fchatbots.php\t2026-04-14 11:28:54.000000000 +0000\n@@ -920,7 +920,7 @@\n \t\t\t\t$rows[] = array(\n \t\t\t\t\tWaicUtils::convertDateFormat($dd, 'Y-m-d', $dFormat),\n \t\t\t\t\t( empty($uId) ? $guest : $log['user_login'] ),\n-\t\t\t\t\t$ip,\n+\t\t\t\t\tesc_html($ip),\n \t\t\t\t\t$modes[$mode],\n \t\t\t\t\t$log['sum_tokens'],\n \t\t\t\t\t$log['duration'],\ndiff -ru \u002Fhome\u002Fdeploy\u002Fwp-safety.org\u002Fdata\u002Fplugin-versions\u002Fai-copilot-content-generator\u002F1.4.14\u002Fmodules\u002Fforms\u002Fmodels\u002Fforms.php \u002Fhome\u002Fdeploy\u002Fwp-safety.org\u002Fdata\u002Fplugin-versions\u002Fai-copilot-content-generator\u002F1.4.15\u002Fmodules\u002Fforms\u002Fmodels\u002Fforms.php\n--- \u002Fhome\u002Fdeploy\u002Fwp-safety.org\u002Fdata\u002Fplugin-versions\u002Fai-copilot-content-generator\u002F1.4.14\u002Fmodules\u002Fforms\u002Fmodels\u002Fforms.php\t2026-03-18 12:53:38.000000000 +0000\n+++ \u002Fhome\u002Fdeploy\u002Fwp-safety.org\u002Fdata\u002Fplugin-versions\u002Fai-copilot-content-generator\u002F1.4.15\u002Fmodules\u002Fforms\u002Fmodels\u002Fforms.php\t2026-04-14 11:28:54.000000000 +0000\n@@ -363,7 +363,7 @@\n \t\t\t\t\t'\u003Cdiv class=\"waic-log-id\" data-value=\"' . $log['id'] . '\">' . $log['id'] . '\u003C\u002Fdiv>',\n \t\t\t\t\t'\u003Cdiv class=\"waic-log-dd\" data-value=\"' . $log['dd'] . '\">' . $log['dd'] . '\u003C\u002Fdiv>',\n \t\t\t\t\t'\u003Cdiv class=\"waic-log-user\" data-value=\"' . $log['user_id'] . '\">' . ( empty($log['user_id']) ? $guest : $log['user_login'] ) . '\u003C\u002Fdiv>',\n-\t\t\t\t\t'\u003Cdiv class=\"waic-log-ip\" data-value=\"' . $log['ip'] . '\">' . $log['ip'] . '\u003C\u002Fdiv>',\n+\t\t\t\t\t'\u003Cdiv class=\"waic-log-ip\" data-value=\"' . esc_attr($log['ip']) . '\">' . esc_html($log['ip']) . '\u003C\u002Fdiv>',\n \t\t\t\t\t'\u003Cdiv class=\"waic-log-tokens\" data-value=\"' . $log['tokens'] . '\">' . $log['tokens'] . '\u003C\u002Fdiv>',\n \t\t\t\t\t'\u003Cdiv class=\"waic-log-question\" data-value=\"' . $log['question'] . '\">' . WaicUtils::mbsubstr($log['question'], 0, 50) . '...\u003C\u002Fdiv>',\n \t\t\t\t\t'\u003Cdiv class=\"waic-log-answer\" data-value=\"' . $log['answer'] . '\">' . WaicUtils::mbsubstr($log['answer'], 0, 50) . '...\u003C\u002Fdiv>';","To exploit this vulnerability, an unauthenticated attacker identifies a public endpoint that triggers a log entry (such as interacting with the plugin's AI chatbot or submitting an AI-powered form). The attacker then sends a request to this endpoint containing a malicious payload in the 'X-Forwarded-For' HTTP header. Because the plugin does not properly sanitize or validate the format of the IP address retrieved from this header, the payload is stored directly in the database. Due to a 20-character limit on the database field, the attacker must use a highly condensed payload, such as a short remote script tag. When an administrator logs into the WordPress dashboard and navigates to the 'Chat Logs' or 'Form Logs' sections, the malicious script executes in the context of the administrator's session.","gemini-3-flash-preview","2026-05-20 16:32:34","2026-05-20 16:33:26",{"type":39,"vulnerable_version":40,"fixed_version":11,"vulnerable_browse":41,"vulnerable_zip":42,"fixed_browse":43,"fixed_zip":44,"all_tags":45},"plugin","1.4.14","https:\u002F\u002Fplugins.trac.wordpress.org\u002Fbrowser\u002Fai-copilot-content-generator\u002Ftags\u002F1.4.14","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Fai-copilot-content-generator.1.4.14.zip","https:\u002F\u002Fplugins.trac.wordpress.org\u002Fbrowser\u002Fai-copilot-content-generator\u002Ftags\u002F1.4.15","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Fai-copilot-content-generator.1.4.15.zip","https:\u002F\u002Fplugins.trac.wordpress.org\u002Fbrowser\u002Fai-copilot-content-generator\u002Ftags"]