Lucene search

K
rubygemsRubySecRUBY:TURBO_BOOST-COMMANDS-2024-28181
HistoryMar 14, 2024 - 9:00 p.m.

TurboBoost Commands vulnerable to arbitrary method invocation

2024-03-1421:00:00
RubySec
rubysec.com
1
turboboost commands
arbitrary method invocation
security implications
patched versions
authorization checks
unwanted code execution
library vulnerability
workarounds
guard implementation

CVSS3

8.1

Attack Vector

NETWORK

Attack Complexity

HIGH

Privileges Required

NONE

User Interaction

NONE

Scope

UNCHANGED

Confidentiality Impact

HIGH

Integrity Impact

HIGH

Availability Impact

HIGH

CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H

AI Score

7.5

Confidence

Low

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.

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

Affected configurations

Vulners
Node
rubyturbo_boost-commandsRange0.1.20.2.0
OR
rubyturbo_boost-commandsRange<0.2.2
VendorProductVersionCPE
rubyturbo_boost-commands*cpe:2.3:a:ruby:turbo_boost-commands:*:*:*:*:*:*:*:*

CVSS3

8.1

Attack Vector

NETWORK

Attack Complexity

HIGH

Privileges Required

NONE

User Interaction

NONE

Scope

UNCHANGED

Confidentiality Impact

HIGH

Integrity Impact

HIGH

Availability Impact

HIGH

CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H

AI Score

7.5

Confidence

Low

Related for RUBY:TURBO_BOOST-COMMANDS-2024-28181