Unsanitized user controlled input in module generation
High severity
GitHub Reviewed
Published
Aug 9, 2023
in
open-telemetry/opentelemetry-js
•
Updated Aug 18, 2023
Package
Affected versions
>= 0.40.0, < 0.41.2
Patched versions
0.41.2
Description
Published to the GitHub Advisory Database
Aug 9, 2023
Reviewed
Aug 9, 2023
Last updated
Aug 18, 2023
Impact
The
import-in-the-middle
loader used by@opentelemetry/instrumentation
works by generating a wrapper module on the fly. The wrapper uses the module specifier to load the original module and add some wrapping code. It allows for remote code execution in cases where an application passes user-supplied input directly to animport()
function.Patches
This vulnerability has been patched in
@opentelemetry/instrumentation
version0.41.2
Workarounds
import()
. Instead, verify it against a set of allowed values.@opentelemetry/instrumentation
with support for EcmaScript Modules is not needed, ensure that none of the following options are set (either via command-line or theNODE_OPTIONS
environment variable):References
References