Lookup for vulnerable packages by Package URL.

Purlpkg:gem/turbo_boost-commands@0.2.2
Typegem
Namespace
Nameturbo_boost-commands
Version0.2.2
Qualifiers
Subpath
Is_vulnerablefalse
Next_non_vulnerable_version0.1.3
Latest_non_vulnerable_version0.2.2
Affected_by_vulnerabilities
Fixing_vulnerabilities
0
url VCID-kza3-e4r2-zba9
vulnerability_id VCID-kza3-e4r2-zba9
summary
TurboBoost Commands vulnerable to arbitrary method invocation
### 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](https://www.npmjs.com/package/@turbo-boost/commands/v/0.1.3)
  - [Ruby GEM](https://rubygems.org/gems/turbo_boost-commands/versions/0.1.3)
- 0.2.2
  - [NPM Package](https://www.npmjs.com/package/@turbo-boost/commands/v/0.2.2)
  - [Ruby GEM](https://rubygems.org/gems/turbo_boost-commands/versions/0.2.2)


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

```ruby
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
```
references
0
reference_url https://github.com/hopsoft/turbo_boost-commands
reference_id
reference_type
scores
url https://github.com/hopsoft/turbo_boost-commands
1
reference_url https://github.com/hopsoft/turbo_boost-commands/commit/337cda7d9222f1f449905454a7374222017a7477
reference_id
reference_type
scores
url https://github.com/hopsoft/turbo_boost-commands/commit/337cda7d9222f1f449905454a7374222017a7477
2
reference_url https://github.com/hopsoft/turbo_boost-commands/commit/88af4fc0ac39cc1799d16c49fab52f6dfbcec9ba
reference_id
reference_type
scores
url https://github.com/hopsoft/turbo_boost-commands/commit/88af4fc0ac39cc1799d16c49fab52f6dfbcec9ba
3
reference_url https://nvd.nist.gov/vuln/detail/CVE-2024-28181
reference_id CVE-2024-28181
reference_type
scores
url https://nvd.nist.gov/vuln/detail/CVE-2024-28181
4
reference_url https://github.com/advisories/GHSA-mp76-7w5v-pr75
reference_id GHSA-mp76-7w5v-pr75
reference_type
scores
url https://github.com/advisories/GHSA-mp76-7w5v-pr75
5
reference_url https://github.com/hopsoft/turbo_boost-commands/security/advisories/GHSA-mp76-7w5v-pr75
reference_id GHSA-mp76-7w5v-pr75
reference_type
scores
url https://github.com/hopsoft/turbo_boost-commands/security/advisories/GHSA-mp76-7w5v-pr75
fixed_packages
0
url pkg:gem/turbo_boost-commands@0.1.3
purl pkg:gem/turbo_boost-commands@0.1.3
is_vulnerable false
affected_by_vulnerabilities
resource_url http://public2.vulnerablecode.io/packages/pkg:gem/turbo_boost-commands@0.1.3
1
url pkg:gem/turbo_boost-commands@0.2.2
purl pkg:gem/turbo_boost-commands@0.2.2
is_vulnerable false
affected_by_vulnerabilities
resource_url http://public2.vulnerablecode.io/packages/pkg:gem/turbo_boost-commands@0.2.2
aliases CVE-2024-28181, GHSA-mp76-7w5v-pr75
risk_score null
exploitability null
weighted_severity null
resource_url http://public2.vulnerablecode.io/vulnerabilities/VCID-kza3-e4r2-zba9
Risk_scorenull
Resource_urlhttp://public2.vulnerablecode.io/packages/pkg:gem/turbo_boost-commands@0.2.2