GHSA-x4hh-vjm7-g2jv

Suggest an improvement
Source
https://github.com/advisories/GHSA-x4hh-vjm7-g2jv
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2023/09/GHSA-x4hh-vjm7-g2jv/GHSA-x4hh-vjm7-g2jv.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-x4hh-vjm7-g2jv
Aliases
Related
Published
2023-09-20T22:51:09Z
Modified
2024-08-21T14:56:42.891668Z
Severity
  • 7.5 (High) CVSS_V3 - CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H CVSS Calculator
Summary
Faktory Web Dashboard can lead to denial of service(DOS) via malicious user input
Details

Summary

Faktory web dashboard can suffer from denial of service by a crafted malicious url query param days.

Details

The vulnerability is related to how the backend reads the days URL query parameter in the Faktory web dashboard. The value is used directly without any checks to create a string slice. If a very large value is provided, the backend server ends up using a significant amount of memory and causing it to crash.

PoC

To reproduce this vulnerability, please follow these steps:

Start the Faktory Docker and limit memory usage to 512 megabytes for better demonstration:

$ docker run --rm -it -m 512m \
  -p 127.0.0.1:7419:7419 \
  -p 127.0.0.1:7420:7420 \
  contribsys/faktory:latest

Send the following request. The Faktory server will exit after a few seconds due to out of memory:

$ curl 'http://localhost:7420/?days=922337'

Impact

Server Availability: The vulnerability can crash the Faktory server, affecting its availability. Denial of Service Risk: Given that the Faktory web dashboard does not require authorization, any entity with internet access to the dashboard could potentially exploit this vulnerability. This unchecked access opens up the potential for a Denial of Service (DoS) attack, which could disrupt service availability without any conditional barriers to the attacker.

Database specific
{
    "nvd_published_at": "2023-09-20T22:15:13Z",
    "cwe_ids": [
        "CWE-770",
        "CWE-789"
    ],
    "severity": "HIGH",
    "github_reviewed": true,
    "github_reviewed_at": "2023-09-20T22:51:09Z"
}
References

Affected packages

Go / github.com/contribsys/faktory

Package

Name
github.com/contribsys/faktory
View open source insights on deps.dev
Purl
pkg:golang/github.com/contribsys/faktory

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
1.8.0