GHSA-mp76-7w5v-pr75

Suggest an improvement
Source
https://github.com/advisories/GHSA-mp76-7w5v-pr75
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2024/03/GHSA-mp76-7w5v-pr75/GHSA-mp76-7w5v-pr75.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-mp76-7w5v-pr75
Aliases
Published
2024-03-15T19:53:50Z
Modified
2024-03-18T17:01:02.372145Z
Severity
  • 8.1 (High) CVSS_V3 - CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H CVSS Calculator
Summary
TurboBoost Commands vulnerable to arbitrary method invocation
Details

Impact

TurboBoost Commands has existing protections in place to guarantee that only public methods on Command classes can be invoked; however, the existing checks aren't as robust as they should be. It's possible for a sophisticated attacker to invoke more methods than should be permitted depending on the the strictness of authorization checks that individual applications enforce. Being able to call some of these methods can have security implications.

Details

Commands verify that the class must be a Command and that the method requested is defined as a public method; however, this isn't robust enough to guard against all unwanted code execution. The library should more strictly enforce which methods are considered safe before allowing them to be executed.

Patches

Patched in the following versions. - 0.1.3 - NPM Package - Ruby GEM - 0.2.2 - NPM Package - Ruby GEM

Workarounds

You can add this guard to mitigate the issue if running an unpatched version of the library.

class ApplicationCommand < TurboBoost::Commands::Command
  before_command do
    method_name = params[:name].include?("#") ? params[:name].split("#").last : :perform
    ancestors = self.class.ancestors[0..self.class.ancestors.index(TurboBoost::Commands::Command) - 1]
    allowed = ancestors.any? { |a| a.public_instance_methods(false).any? method_name.to_sym }
    throw :abort unless allowed # ← blocks invocation
    # raise "Invalid Command" unless allowed # ← blocks invocation
  end
end
Database specific
{
    "nvd_published_at": "2024-03-14T18:15:07Z",
    "cwe_ids": [
        "CWE-74"
    ],
    "severity": "HIGH",
    "github_reviewed": true,
    "github_reviewed_at": "2024-03-15T19:53:50Z"
}
References

Affected packages

RubyGems / turbo_boost-commands

Package

Name
turbo_boost-commands
Purl
pkg:gem/turbo_boost-commands

Affected ranges

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

Affected versions

0.*

0.0.1
0.0.2
0.0.3
0.0.4
0.0.5
0.0.6
0.0.7
0.0.8
0.0.9
0.0.10
0.0.11
0.0.12
0.0.13
0.0.14
0.0.15
0.0.16
0.0.17
0.0.18
0.1.0
0.1.1
0.1.2

RubyGems / turbo_boost-commands

Package

Name
turbo_boost-commands
Purl
pkg:gem/turbo_boost-commands

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0.2.0
Fixed
0.2.2

Affected versions

0.*

0.2.0
0.2.1
0.2.1.1

npm / @turbo-boost/commands

Package

Name
@turbo-boost/commands
View open source insights on deps.dev
Purl
pkg:npm/%40turbo-boost/commands

Affected ranges

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

npm / @turbo-boost/commands

Package

Name
@turbo-boost/commands
View open source insights on deps.dev
Purl
pkg:npm/%40turbo-boost/commands

Affected ranges

Type
SEMVER
Events
Introduced
0.2.0
Fixed
0.2.2