From e396f4b14d73e558bce1a772decbcda8443c54cc Mon Sep 17 00:00:00 2001 From: Echo Stretch <98502641+EchoStretch@users.noreply.github.com> Date: Mon, 19 Feb 2024 19:16:40 -0700 Subject: [PATCH] Implemented automatic firmware detection. --- config.mjs | 56 +++++++++++++++---------------------- exploit.mjs | 80 +++++++++++++++++------------------------------------ index.html | 27 ++++++++++++++++++ 3 files changed, 75 insertions(+), 88 deletions(-) diff --git a/config.mjs b/config.mjs index 5a14482..1977925 100644 --- a/config.mjs +++ b/config.mjs @@ -57,44 +57,32 @@ export function set_target(value) { target = value; } -function DetectFirmwareVersion() //function by kameleon :) -{ +function DetectFirmwareVersion() { //function by kameleon :) +if (navigator.userAgent.includes('PlayStation 4')) { var UA = navigator.userAgent.substring(navigator.userAgent.indexOf('5.0 (') + 19, navigator.userAgent.indexOf(') Apple')).replace("PlayStation 4/",""); - - if (UA == "6.00" || UA == "6.02" || UA == "6.10" || UA == "6.20") - { + if (["6.00", "6.02", "6.10", "6.20"].includes(UA)) { return ps4_6_00; + } else if (["6.50", "6.70", "6.71", "6.72"].includes(UA)) { + return ps4_6_50; + } else if (["7.01", "7.02", "7.50", "7.51", "7.55", "8.00", "8.01", "8.03"].includes(UA)) { + return ps4_8_03; + } else { + var UA = navigator.userAgent.substring(navigator.userAgent.indexOf('5.0 (') + 18, navigator.userAgent.indexOf(') Apple')).replace("PlayStation 4/",""); + if (["8.50", "8.51"].includes(UA)) { + return ps4_8_03; + } else { + var UA = navigator.userAgent.substring(navigator.userAgent.indexOf('5.0 (') + 18, navigator.userAgent.indexOf(') Apple')).replace("PlayStation 4/",""); + if (["9.00", "9.03", "9.04", "9.50", "9.51", "9.60"].includes(UA)) { + return ps4_9_00; + } + } } - - if (UA == "6.50" || UA == "6.70" || UA == "6.71" || UA == "6.72") - { - return ps4_6_50; +} else if (navigator.userAgent.includes('PlayStation 5')) { + var UA = navigator.userAgent.substring(navigator.userAgent.indexOf('5.0 (') + 32, navigator.userAgent.indexOf(') Apple')).replace("PlayStation 5/",""); + if (["1.00", "1.01", "1.02", "1.05", "1.12", "1.14", "2.00", "2.10", "2.20", "2.25", "2.26", "2.30", "2.50", "2.70", "3.00", "3.10", "3.20", "3.21", "4.00", "4.02", "4.03", "4.50", "4.51", "5.00", "5.02", "5.10", "5.50"].includes(UA)) { + return ps5_5_00; } - - if (UA == "7.01" || UA == "7.02" || UA == "7.50" || UA == "7.51" || UA == "7.55" || UA == "8.00" || UA == "8.01" || UA == "8.03" || UA == "8.50" || UA == "8.51") - { - return ps4_8_03; - } - - //on 9.00 Fw deection changed to laystation insead of regular Playstation - UA = navigator.userAgent.substring(navigator.userAgent.indexOf('5.0 (') + 19, navigator.userAgent.indexOf(') Apple')).replace("layStation 4/",""); - - - if (UA == "9.00" || UA == "9.03" || UA == "9.04" || UA == "9.50" || UA == "9.51" || UA == "9.60") - { - return ps4_9_00; - } - - //get user agent for PS5 (taken from PS5 Specter Exploit Host) - const supportedFirmwares = ["1.00","1.01","1.02","1.05","1.12","1.14","2.00","2.10","2.20","2.25","2.26","2.30","2.50","2.70","3.00","3.10","3.20","3.21","4.00", "4.02", "4.03", "4.50", "4.51","5.00","5.02","5.10","5.50"]; - const fw_idx = navigator.userAgent.indexOf('PlayStation; PlayStation 5/') + 27; - const fw_str = navigator.userAgent.substring(fw_idx, fw_idx + 4); - - if (supportedFirmwares.includes(fw_str)) - { - return ps5_5_00; - } - + } } export let target = DetectFirmwareVersion(); diff --git a/exploit.mjs b/exploit.mjs index 1993551..512414d 100644 --- a/exploit.mjs +++ b/exploit.mjs @@ -676,63 +676,35 @@ async function get_ready() { } //load per firmware Rop Test function by kameleon.. -function ExecRopByFw() -{ +function ExecRopByFw() { var UA = navigator.userAgent.substring(navigator.userAgent.indexOf('5.0 (') + 19, navigator.userAgent.indexOf(') Apple')).replace("PlayStation 4/",""); - if (UA == "6.00" || UA == "6.02" || UA == "6.10" || UA == "6.20") - { - alert("No ROP implemented"); + if (navigator.userAgent.includes('PlayStation 4')) { + if (["6.00", "6.02", "6.10", "6.20"].includes(UA)) { + alert("No ROP implemented"); + } else if (["6.50", "6.70", "6.71", "6.72"].includes(UA)) { + alert("No ROP implemented"); + } else if (["7.01", "7.02", "7.50", "7.51", "7.55"].includes(UA)) { + import('./send.mjs'); + } else if (["8.00", "8.01", "8.03"].includes(UA)) { + import('./rop/800.mjs'); + } else { + var UA = navigator.userAgent.substring(navigator.userAgent.indexOf('5.0 (') + 18, navigator.userAgent.indexOf(') Apple')).replace("PlayStation 4/",""); + if (["8.50", "8.51"].includes(UA)) { + import('./rop/850.mjs'); + } else { + var UA = navigator.userAgent.substring(navigator.userAgent.indexOf('5.0 (') + 18, navigator.userAgent.indexOf(') Apple')).replace("PlayStation 4/",""); + if (["9.00", "9.03", "9.04", "9.50", "9.51", "9.60"].includes(UA)) { + import('./rop/900.mjs'); + } + } + } + } else if (navigator.userAgent.includes('PlayStation 5')) { + var UA = navigator.userAgent.substring(navigator.userAgent.indexOf('5.0 (') + 32, navigator.userAgent.indexOf(') Apple')).replace("PlayStation 5/",""); + if (["1.00", "1.01", "1.02", "1.05", "1.12", "1.14", "2.00", "2.10", "2.20", "2.25", "2.26", "2.30", "2.50", "2.70", "3.00", "3.10", "3.20", "3.21", "4.00", "4.02", "4.03", "4.50", "4.51", "5.00", "5.02", "5.10", "5.50"].includes(UA)) { + alert("No ROP implemented"); + } } - - if (UA == "6.50" || UA == "6.70" || UA == "6.71" || UA == "6.72") - { - alert("No ROP implemented"); - } - - if (UA == "7.01" || UA == "7.02" || UA == "7.50" || UA == "7.51" || UA == "7.55") - { - import('./send.mjs'); - } - - if (UA == "8.00" || UA == "8.01") - { - alert("No ROP implemented"); - } - - if (UA == "8.03") - { - import('./rop/800.mjs'); - } - - if (UA == "8.50" || UA == "8.51") - { - import('./rop/850.mjs'); - } - - //on 9.00 Fw detection changed to laystation insead of regular Playstation - UA = navigator.userAgent.substring(navigator.userAgent.indexOf('5.0 (') + 19, navigator.userAgent.indexOf(') Apple')).replace("layStation 4/",""); - - if (UA == "9.00" || UA == "9.03" || UA == "9.04") - { - import('./rop/900.mjs'); - } - - if (UA == "9.50" || UA == "9.51" || UA == "9.60") - { - import('./rop/950.mjs'); - } - - //get user agent for PS5 (taken from PS5 Specter Exploit Host) - const supportedFirmwares = ["1.00","1.01","1.02","1.05","1.12","1.14","2.00","2.10","2.20","2.25","2.26","2.30","2.50","2.70","3.00","3.10","3.20","3.21","4.00", "4.02", "4.03", "4.50", "4.51","5.00","5.02","5.10","5.50"]; - const fw_idx = navigator.userAgent.indexOf('PlayStation; PlayStation 5/') + 27; - const fw_str = navigator.userAgent.substring(fw_idx, fw_idx + 4); - - if (supportedFirmwares.includes(fw_str)) - { - alert("No ROP implemented"); - } - } async function run() { diff --git a/index.html b/index.html index b2aef8f..e04eb0e 100644 --- a/index.html +++ b/index.html @@ -15,6 +15,33 @@ GNU Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with this program. If not, see . --> +