GHSA-9237-rg5p-rhfw

Suggest an improvement
Source
https://github.com/advisories/GHSA-9237-rg5p-rhfw
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/04/GHSA-9237-rg5p-rhfw/GHSA-9237-rg5p-rhfw.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-9237-rg5p-rhfw
Published
2026-04-22T14:31:34Z
Modified
2026-04-22T14:58:32.498203Z
Severity
  • 8.7 (High) CVSS_V4 - CVSS:4.0/AV:N/AC:L/AT:N/PR:L/UI:N/VC:H/VI:H/VA:L/SC:N/SI:N/SA:N CVSS Calculator
Summary
@saltcorn/data: Tenant user role is used for tenant creation role check
Details

Summary

When a tenant admin is logged out of the root domain (e.g., saltcorn.com) but logged in to their own tenant space as admin, they can simply append /tenant/create to their tenant URL. The system reads the role from the tenant context (admin), and a new tenant is created on the root domain (in PUBLIC SCHEMA > _sc_tenants), rather than in the tenant's own _sc_tenants table.

If the same logic applies to other routes, a tenant admin effectively gains admin rights on the root domain.

PoC

A tenant-created subtenant appears under the Saltcorn public schema instead of the tenant's own schema.

  • Even when role_id=1 is required for tenant creation on saltcorn.com (only admin can create tenants), existing tenant admins can still create new tenants because their local role_id:1 is evaluated against the root domain.
  • Even when role_to_create_tenant is set to 0 in the tenant's _sc_config schema, or removed entirely, the tenant admin can still create sub-tenants on the root domain — suggesting role_to_create_tenant is not being read at all.

Impact

Tenant admins gain unauthorized admin-level access to the root domain. Any authenticated tenant admin can perform privileged operations (e.g., creating tenants) on the root domain by exploiting the role context mismatch.

Database specific
{
    "nvd_published_at": null,
    "cwe_ids": [
        "CWE-863"
    ],
    "severity": "HIGH",
    "github_reviewed": true,
    "github_reviewed_at": "2026-04-22T14:31:34Z"
}
References

Affected packages

npm / @saltcorn/data

Package

Name
@saltcorn/data
View open source insights on deps.dev
Purl
pkg:npm/%40saltcorn/data

Affected ranges

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

Database specific

source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/04/GHSA-9237-rg5p-rhfw/GHSA-9237-rg5p-rhfw.json"

npm / @saltcorn/data

Package

Name
@saltcorn/data
View open source insights on deps.dev
Purl
pkg:npm/%40saltcorn/data

Affected ranges

Type
SEMVER
Events
Introduced
1.5.0-beta.0
Fixed
1.5.2

Database specific

source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/04/GHSA-9237-rg5p-rhfw/GHSA-9237-rg5p-rhfw.json"

npm / @saltcorn/data

Package

Name
@saltcorn/data
View open source insights on deps.dev
Purl
pkg:npm/%40saltcorn/data

Affected ranges

Type
SEMVER
Events
Introduced
1.6.0-alpha.0
Fixed
1.6.0-beta.2

Database specific

source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/04/GHSA-9237-rg5p-rhfw/GHSA-9237-rg5p-rhfw.json"