Prototype Pollution leading to Remote Code Execution in superjson
        
  Critical severity
        
          GitHub Reviewed
      
        Published
          Feb 9, 2022 
          in
          
            flightcontrolhq/superjson
          
          •
          Updated Nov 1, 2023 
      
  
Description
        Published by the National Vulnerability Database
      Feb 9, 2022 
    
  
        Published to the GitHub Advisory Database
      Feb 9, 2022 
    
  
        Reviewed
      Feb 9, 2022 
    
  
        Last updated
      Nov 1, 2023 
    
  
Impact
This is critical vulnerability, as it allows to run arbitrary code on any server using superjson input, including a Blitz.js server, without prior authentication or knowledge. Attackers gain full control over the server so they could steal and manipulate data or attack further systems. The only requirement is that the server implements at least one endpoint which uses superjson during request processing. In the case of Blitz.js, it would be at least one RPC call.
Patches
This has been patched in superjson 1.8.1 and Blitz.js 0.45.3.
If you are unable to upgrade to Blitz.js 0.45.3 in a timely manner, you can instead upgrade only superjson to version 1.8.1 using yarn resolutions are similar. Blitz versions < 0.45.3 are only affected because they used superjson versions < 1.8.1.
Workarounds
None
For more information
If you have any questions or comments about this advisory:
References
References