GHSA-xx95-62h6-h7v3

Suggest an improvement
Source
https://github.com/advisories/GHSA-xx95-62h6-h7v3
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2024/12/GHSA-xx95-62h6-h7v3/GHSA-xx95-62h6-h7v3.json
JSON Data
https://api.test.osv.dev/v1/vulns/GHSA-xx95-62h6-h7v3
Aliases
Published
2024-12-26T20:20:12Z
Modified
2024-12-27T00:39:04.499534Z
Summary
lgsl Stored Cross-Site Scripting vulnerability
Details

Summary

A stored cross-site scripting (XSS) vulnerability was identified in lgsl. The issue arises from improper sanitation of user input. Everyone who accesses this page will be affected by this attack.

Details

The function lgsl_query_40 in lgsl_protocol.php has implemented an HTTP crawler. This function makes a request to the registered game server, and upon crawling the malicious /info endpoint with our payload, will render our javascript on the info page. This information is being displayed via lgsl_details.php

Affected Code:

      foreach ($server['e'] as $field => $value) {
        $value = preg_replace('/((https*:\/\/|https*:\/\/www\.|www\.)[\w\d\.\-\/=$?​]*)/i', "<a href='$1' target='_blank'>$1</a>", html_entity_decode($value));
        $output .= "
        <tr><td> {$field} </td><td> {$value} </td></tr>";
      }

PoC

  1. Create a game server with type eco and set the target host and port accordingly to your ttack server. I have crafted this json payload that is being parsed according to the schema and being served on /info

  2. Serve the following JSON payload at /info on your handler

    {
      "Animals": "1",
      "EconomyDesc": "<img src=x onerror=prompt(1)>"
    }
    
  3. Access the corresponding server info page at /s?=. Upon refreshing & crawling our server, it should execute our javascript.
Database specific
{
    "cwe_ids": [
        "CWE-79"
    ],
    "severity": "HIGH",
    "nvd_published_at": "2024-12-26T22:15:19Z",
    "github_reviewed": true,
    "github_reviewed_at": "2024-12-26T20:20:12Z"
}
References

Affected packages

Packagist / tltneon/lgsl

Package

Name
tltneon/lgsl
Purl
pkg:composer/tltneon/lgsl

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
7.0.0

Affected versions

v5.*
v5.10.0
v5.10.1
v5.10.2
v5.10.3
v6.*
v6.0.0
v6.0.1
v6.1.0
v6.1.1
v6.2.0
v6.2.1

Database specific

source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2024/12/GHSA-xx95-62h6-h7v3/GHSA-xx95-62h6-h7v3.json"