VDB
EN
HIGH 8.7

GHSA-6r35-46g8-jcw9

protobuf.js: Code injection in pbjs static output from crafted schema names

상세

## Summary

`pbjs` static code generation could emit unsafe JavaScript identifiers derived from schema-controlled names. When generating static JavaScript from a crafted schema or JSON descriptor, certain namespace, enum, service, or derived full names could be written into the generated output without sufficient sanitization.

## Impact

An attacker who can provide or influence schemas passed to `pbjs` may be able to cause generated JavaScript output to contain attacker-controlled code. The injected code would run if the generated file is later executed or imported by the application or build process.

This affects the protobufjs CLI static code generation path. Applications that only use trusted schemas, or that do not execute generated output from untrusted schemas, are not directly affected.

## Preconditions

- The application or build process must run `pbjs` static code generation on a schema or JSON descriptor influenced by an attacker. - The attacker-controlled input must contain crafted schema names that reach generated JavaScript output. - The generated JavaScript file must subsequently be executed, imported, or otherwise evaluated.

## Workarounds

Do not run affected versions of `pbjs` static code generation on untrusted schemas or descriptors. If untrusted schemas must be accepted, validate schema names before code generation and run generation in an isolated environment.

이 버전이 영향받나요?

사용 중인 패키지 버전을 입력하면 즉시 평가합니다.

영향 패키지

npm / protobufjs-cli
최초 영향 버전: 0 수정 버전: 1.2.1
수정 npm install protobufjs-cli@1.2.1
npm / protobufjs-cli
최초 영향 버전: 2.0.0 수정 버전: 2.0.2
수정 npm install protobufjs-cli@2.0.2

참고