Description
@grpc/grps-js implements the core functionality of gRPC purely in JavaScript, without a C++ addon. Prior to versions 1.10.9, 1.9.15, and 1.8.22, there are two separate code paths in which memory can be allocated per message in excess of the `grpc.max_receive_message_length` channel option: If an incoming message has a size on the wire greater than the configured limit, the entire message is buffered before it is discarded; and/or if an incoming message has a size within the limit on the wire but decompresses to a size greater than the limit, the entire message is decompressed into memory, and on the server is not discarded. This has been patched in versions 1.10.9, 1.9.15, and 1.8.22.
Problem types
CWE-789: Memory Allocation with Excessive Size Value
Product status
>= 1.9.0, < 1.9.15
< 1.8.22
References
github.com/...c-node/security/advisories/GHSA-7v5v-9h63-cj86
github.com/...ommit/08b0422dae56467ecae1007e899efe66a8c4a650
github.com/...ommit/674f4e351a619fd4532f84ae6dff96b8ee4e1ed3
github.com/...ommit/a8a020339c7eab1347a343a512ad17a4aea4bfdb