GHSA-27vg-33gh-4hwg

Suggest an improvement
Source
https://github.com/advisories/GHSA-27vg-33gh-4hwg
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/03/GHSA-27vg-33gh-4hwg/GHSA-27vg-33gh-4hwg.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-27vg-33gh-4hwg
Aliases
  • CVE-2026-3089
Published
2026-03-10T01:02:15Z
Modified
2026-03-10T01:16:21.504294Z
Severity
  • 5.3 (Medium) CVSS_V4 - CVSS:4.0/AV:N/AC:L/AT:N/PR:L/UI:N/VC:N/VI:L/VA:N/SC:N/SI:N/SA:N CVSS Calculator
Summary
Actual Sync Server has an Authenticated Path Traversal
Details

Description

Actual Sync Server allows authenticated users to upload files through POST /sync/upload-user-file. In versions prior to 26.3.0, improper validation of the user-controlled x-actual-file-id header means that traversal segments (../) can escape the intended directory and write files outside userFiles.

Mitigations

The vulnerability can be mitigated in prior versions by running the sync server in a filesystem sandbox.

Database specific
{
    "github_reviewed": true,
    "severity": "MODERATE",
    "github_reviewed_at": "2026-03-10T01:02:15Z",
    "cwe_ids": [
        "CWE-22"
    ],
    "nvd_published_at": "2026-03-09T14:16:10Z"
}
References

Affected packages

npm / @actual-app/sync-server

Package

Name
@actual-app/sync-server
View open source insights on deps.dev
Purl
pkg:npm/%40actual-app/sync-server

Affected ranges

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

Database specific

last_known_affected_version_range
"<= 26.2.0"
source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/03/GHSA-27vg-33gh-4hwg/GHSA-27vg-33gh-4hwg.json"