GHSA-8639-qx56-r428

Suggest an improvement
Source
https://github.com/advisories/GHSA-8639-qx56-r428
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2022/06/GHSA-8639-qx56-r428/GHSA-8639-qx56-r428.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-8639-qx56-r428
Aliases
Published
2022-06-01T20:26:37Z
Modified
2023-11-08T04:09:22.169642Z
Severity
  • 2.3 (Low) CVSS_V3 - CVSS:3.1/AV:L/AC:L/PR:H/UI:N/S:U/C:N/I:L/A:N CVSS Calculator
Summary
CSRF allows attacker to finalize/unfinalize order adjustments in solidus_backend
Details

Impact

CSRF vulnerability allowing attackers to change the state of an order's adjustments if they hold its number, and the execution happens on a store administrator's computer.

Reproduction steps: - Take an order's number. - Log in as an administrator. - Visit that order's adjustments section (Orders -> {Click on number} -> Adjustments) and check that its adjustments are finalized (closed padlock under the State column). - On another tab, visit {your_site_url}/admin/orders/{order_number}/adjustments/unfinalize. - Notice how the adjustments are unfinalized (open padlock), even if the previous was a GET request which could have been linked from any other site. - Visit {your_site_url}/admin/orders/{order_number}/adjustments/finalize. - Notice how the adjustments are again finalized.

That happened because both routes were handled as GET requests, which are skipped by Rails anti-forgery protection.

Patches

Users should upgrade to solidus_backend v3.1.6, v3.0.6, or v2.11.16, depending on the major and minor versions in use.

References

For more information

If you have any questions or comments about this advisory:

Database specific
{
    "nvd_published_at": "2022-06-01T18:15:00Z",
    "github_reviewed_at": "2022-06-01T20:26:37Z",
    "severity": "LOW",
    "github_reviewed": true,
    "cwe_ids": [
        "CWE-352"
    ]
}
References

Affected packages

RubyGems / solidus_backend

Package

Name
solidus_backend
Purl
pkg:gem/solidus_backend

Affected ranges

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

Affected versions

1.*

1.0.0.pre
1.0.0.pre2
1.0.0.pre3
1.0.0.rc1
1.0.0.rc2
1.0.0
1.0.1
1.0.2
1.0.3
1.0.4
1.0.5
1.0.6
1.0.7
1.1.0.beta1
1.1.0.pre1
1.1.0.pre2
1.1.0
1.1.1
1.1.2
1.1.3
1.1.4
1.2.0.beta1
1.2.0.rc1
1.2.0.rc2
1.2.0
1.2.1
1.2.2
1.2.3
1.3.0.beta1
1.3.0.rc1
1.3.0.rc2
1.3.0
1.3.1
1.3.2
1.4.0.beta1
1.4.0.rc1
1.4.0
1.4.1
1.4.2

2.*

2.0.0.beta1
2.0.0.rc1
2.0.0
2.0.1
2.0.2
2.0.3
2.1.0.beta1
2.1.0.rc1
2.1.0
2.1.1
2.2.0.beta1
2.2.0.rc1
2.2.0
2.2.1
2.2.2
2.3.0.beta1
2.3.0.rc1
2.3.0.rc2
2.3.0.rc3
2.3.0
2.3.1
2.4.0.beta1
2.4.0.rc1
2.4.0
2.4.1
2.4.2
2.5.0.beta1
2.5.0.beta2
2.5.0.rc1
2.5.0
2.5.1
2.5.2
2.6.0.rc1
2.6.0
2.6.1
2.6.2
2.6.3
2.6.4
2.6.5
2.6.6
2.7.0
2.7.1
2.7.2
2.7.3
2.7.4
2.8.0
2.8.1
2.8.2
2.8.3
2.8.4
2.8.5
2.8.6
2.9.0.rc.1
2.9.0
2.9.1
2.9.2
2.9.3
2.9.4
2.9.5
2.9.6
2.10.0.beta1
2.10.0
2.10.1
2.10.2
2.10.3
2.10.5
2.11.0
2.11.1
2.11.2
2.11.3
2.11.4
2.11.5
2.11.6
2.11.7
2.11.8
2.11.9
2.11.10
2.11.11
2.11.12
2.11.13
2.11.14
2.11.15

RubyGems / solidus_backend

Package

Name
solidus_backend
Purl
pkg:gem/solidus_backend

Affected ranges

Type
ECOSYSTEM
Events
Introduced
3.0.0
Fixed
3.0.6

Affected versions

3.*

3.0.0
3.0.1
3.0.2
3.0.3
3.0.4
3.0.5

RubyGems / solidus_backend

Package

Name
solidus_backend
Purl
pkg:gem/solidus_backend

Affected ranges

Type
ECOSYSTEM
Events
Introduced
3.1.0
Fixed
3.1.6

Affected versions

3.*

3.1.0
3.1.1
3.1.2
3.1.3
3.1.4
3.1.5