Electron contextIsolation RCE via Electron internal code
Primer 1
"exit" događajni slušalac uvek postavljen od strane unutrašnjeg koda kada se pokrene učitavanje stranice. Ovaj događaj se emituje neposredno pre navigacije:
https://github.com/nodejs/node/blob/8a44289089a08b7b19fa3c4651b5f1f5d1edd71b/bin/events.js#L156-L231 -- Više ne postoji
Onda ide ovde:
Gde je "self" Node-ov objekat procesa:
Objekat procesa ima reference na "require" funkciju:
Kako će handler.call primiti process objekat, možemo ga prebrisati da izvršimo proizvoljan kod:
Primer 2
Dobijanje require objekta putem zagađenja prototipa. Sa https://www.youtube.com/watch?v=Tzo8ucHA5xw&list=PLH15HpR5qRsVKcKwvIl-AzGfRqKyx--zq&index=81
Leak:
Exploit:
Last updated