#!ipxe # Script: live/infosec/parrotos/main.ipxe # ID: 1e41ae3c-1a61-4649-b39c-38cc65a33c7a # For more information, see: # https://ipxe.org/ # https://ipxe.org/scripting ################################# # Script-wide/global variables. # ################################# :set_script_vars isset ${do_debug} || set do_debug 0 isset ${do_serial} || set do_serial 0 set base_url https://boot.netfire.com/ set http_base_url http://boot.netfire.com/ :set_bg iseq ${bg_set} 1 && goto skip_set_bg || echo Setting up menus... # Try different backgrounds sequentially until we find one that works. console --keep --picture ${base_url}bg.png && set bg_set 1 && goto skip_set_bg || console --keep --picture ${base_url}bg_lores.png && set bg_set 1 && goto skip_set_bg || console --keep --picture ${base_url}bg.pnm && set bg_set 1 && goto skip_set_bg || console --keep --picture ${base_url}bg_lores.pnm && set bg_set 1 && goto skip_set_bg || # Finally, fall back to text-only mode. echo Failed to use graphical console; reverting to text-only. console --x 1024 --y 768 || # "Red" xformed to a brighter/robust red) colour --rgb 0xb52a3d 1 || # "Green" xformed to orange) colour --rgb 0xcf6245 2 || # "Yellow" xformed to more of a gold) colour --rgb 0xc7a34d 3 || # "Magenta" xformed to a light purple) colour --rgb 0x6139a9 5 || # "Cyan" xformed to dark blue) colour --rgb 0x000120 6 || ## cpair --foreground 7 --background 5 0 || cpair --foreground 7 --background 6 1 || cpair --foreground 3 --background 6 2 || cpair --foreground 7 --background 6 3 || cpair --foreground 1 --background 6 4 || cpair --foreground 6 --background 1 5 || cpair --foreground 7 --background 6 6 || cpair --foreground 7 --background 6 7 || set bg_set 1 || :skip_set_bg set script_path ${base_url}live/infosec/parrotos/main.ipxe || # If 1e41ae3c-1a61-4649-b39c-38cc65a33c7a/prev (this script) is not set, assume this is the entry script. isset ${1e41ae3c-1a61-4649-b39c-38cc65a33c7a/prev} || set 1e41ae3c-1a61-4649-b39c-38cc65a33c7a/prev ${script_path} isset ${entry_script} && goto skip_set_entry || set entry_script ${script_path} || :skip_set_entry # Since we are at the beginning of a script, we need to set this to "true". set prev_is_script 1 || ##################################### # End script-wide/global variables. # ##################################### :skip_script_vars ############################################ # Set hardware architecture and # # bitness strings for use in templating. # # Note: # # (U)EFI vs. BIOS can be determined by # # the ${platform} iPXE builtin. # # More information: # # https://ipxe.org/cfg/platform # ############################################ # bits: 64, 32 # # arch0: x86_64, i386, arm64, arm32 # # arch0u: X86_64, I386, ARM64, ARM32 # # arch1: x86_64, x86, arm64, arm32 # # arch1u: X86_64, X86, ARM64, ARM32 # # arch2: amd64, i686, arm64, arm32 # # arch2u: AMD64, I686, ARM64, ARM32 # # ${buildarch}: x86_64, i386, arm64, arm32 # # ${platform}: efi, pcbios, linux # ############################################ :setarch isset ${bits} && goto skiparch || set arch0 ${buildarch} goto setarch-${arch0} || goto exiterr :setarch-i386 # If true, it's a 32-bit build but a 64-bit CPU, so... cpuid --ext 29 && goto setarch-x86_64 || # Otherwise definitely 32-bit. set bits 32 set arch0u I386 set arch1 x86 set arch1u X86 set arch2 i686 set arch2u I686 goto skiparch :setarch-x86_64 iseq ${arch0} i386 && set arch0 x86_64 || set bits 64 set arch0u X86_64 set arch1 x86_64 set arch1u ${arch0u} set arch2 amd64 set arch2u AMD64 goto skiparch :setarch-arm32 set bits 32 set arch0u ARM32 set arch1 arm32 set arch1u ${arch0u} set arch2 ${arch1} set arch2u ${arch0u} goto skiparch :setarch-arm64 set bits 64 set arch0u ARM64 set arch1 arm64 set arch1u ${arch0u} set arch2 ${arch1} set arch2u ${arch0u} goto skiparch ########################################## # End hardware architecture and bitness. # ########################################## :skiparch ######################### # Convenience variables # ######################### :setconvenience isset ${esc} && goto skipconvenience || set esc:hex 1b set cls ${esc:string}[2J ############################# # End convenience variables # ############################# :skipconvenience ############################################### # Boot options for all (supported) MenuItems. # ############################################### :getbootopts # Bootopts for Standard ## "Live"/Active isset ${fb743beb-ce6a-4875-8b6f-ffef0ac1be45/bootopts} || set fb743beb-ce6a-4875-8b6f-ffef0ac1be45/bootopts boot=live components fetch=${base_url}loop/parrotos/security/live/filesystem.squashfs splash initrd=initrd.img quiet ssh encpasswd=$6$rounds=1000000$8Lpa7wUSlsEfUDEe$xl/0km886Pujmp2w00IbxT81ekvZljED1Fe2FProldQiO/OzpT6urmUeXZ4liDMwhULlha66jYrljy5oHOiaq0 ## Original set fb743beb-ce6a-4875-8b6f-ffef0ac1be45/orig_bootopts boot=live components fetch=${base_url}loop/parrotos/security/live/filesystem.squashfs splash initrd=initrd.img quiet ssh encpasswd=$6$rounds=1000000$8Lpa7wUSlsEfUDEe$xl/0km886Pujmp2w00IbxT81ekvZljED1Fe2FProldQiO/OzpT6urmUeXZ4liDMwhULlha66jYrljy5oHOiaq0 # Bootopts for Fail-Safe ## "Live"/Active isset ${094072b4-28c4-443a-a269-6ee66314077f/bootopts} || set 094072b4-28c4-443a-a269-6ee66314077f/bootopts boot=live components fetch=${base_url}loop/parrotos/security/live/filesystem.squashfs initrd=initrd.img ssh encpasswd=$6$rounds=1000000$8Lpa7wUSlsEfUDEe$xl/0km886Pujmp2w00IbxT81ekvZljED1Fe2FProldQiO/OzpT6urmUeXZ4liDMwhULlha66jYrljy5oHOiaq0 memtest noapic noapm nodma nomce nolapic nomodeset nosmp nosplash ## Original set 094072b4-28c4-443a-a269-6ee66314077f/orig_bootopts boot=live components fetch=${base_url}loop/parrotos/security/live/filesystem.squashfs initrd=initrd.img ssh encpasswd=$6$rounds=1000000$8Lpa7wUSlsEfUDEe$xl/0km886Pujmp2w00IbxT81ekvZljED1Fe2FProldQiO/OzpT6urmUeXZ4liDMwhULlha66jYrljy5oHOiaq0 memtest noapic noapm nodma nomce nolapic nomodeset nosmp nosplash # Bootopts for Forensic Mode ## "Live"/Active isset ${d89d6487-8a44-4df0-ad02-c1cbdb04ef67/bootopts} || set d89d6487-8a44-4df0-ad02-c1cbdb04ef67/bootopts boot=live components fetch=${base_url}loop/parrotos/security/live/filesystem.squashfs splash initrd=initrd.img quiet ssh encpasswd=$6$rounds=1000000$8Lpa7wUSlsEfUDEe$xl/0km886Pujmp2w00IbxT81ekvZljED1Fe2FProldQiO/OzpT6urmUeXZ4liDMwhULlha66jYrljy5oHOiaq0 noswap noautomount ## Original set d89d6487-8a44-4df0-ad02-c1cbdb04ef67/orig_bootopts boot=live components fetch=${base_url}loop/parrotos/security/live/filesystem.squashfs splash initrd=initrd.img quiet ssh encpasswd=$6$rounds=1000000$8Lpa7wUSlsEfUDEe$xl/0km886Pujmp2w00IbxT81ekvZljED1Fe2FProldQiO/OzpT6urmUeXZ4liDMwhULlha66jYrljy5oHOiaq0 noswap noautomount # Bootopts for Persistent Mode ## "Live"/Active isset ${fe612436-8ee2-4ddf-ae78-e8e422f990fa/bootopts} || set fe612436-8ee2-4ddf-ae78-e8e422f990fa/bootopts boot=live components fetch=${base_url}loop/parrotos/security/live/filesystem.squashfs splash initrd=initrd.img quiet ssh encpasswd=$6$rounds=1000000$8Lpa7wUSlsEfUDEe$xl/0km886Pujmp2w00IbxT81ekvZljED1Fe2FProldQiO/OzpT6urmUeXZ4liDMwhULlha66jYrljy5oHOiaq0 persistence ## Original set fe612436-8ee2-4ddf-ae78-e8e422f990fa/orig_bootopts boot=live components fetch=${base_url}loop/parrotos/security/live/filesystem.squashfs splash initrd=initrd.img quiet ssh encpasswd=$6$rounds=1000000$8Lpa7wUSlsEfUDEe$xl/0km886Pujmp2w00IbxT81ekvZljED1Fe2FProldQiO/OzpT6urmUeXZ4liDMwhULlha66jYrljy5oHOiaq0 persistence # Bootopts for Encrypted Persistent Mode ## "Live"/Active isset ${0587b715-ee39-4d17-ba5f-2a4eae441cf2/bootopts} || set 0587b715-ee39-4d17-ba5f-2a4eae441cf2/bootopts boot=live components fetch=${base_url}loop/parrotos/security/live/filesystem.squashfs splash initrd=initrd.img quiet ssh encpasswd=$6$rounds=1000000$8Lpa7wUSlsEfUDEe$xl/0km886Pujmp2w00IbxT81ekvZljED1Fe2FProldQiO/OzpT6urmUeXZ4liDMwhULlha66jYrljy5oHOiaq0 persistent=cryptsetup persistence-encryption=luks ## Original set 0587b715-ee39-4d17-ba5f-2a4eae441cf2/orig_bootopts boot=live components fetch=${base_url}loop/parrotos/security/live/filesystem.squashfs splash initrd=initrd.img quiet ssh encpasswd=$6$rounds=1000000$8Lpa7wUSlsEfUDEe$xl/0km886Pujmp2w00IbxT81ekvZljED1Fe2FProldQiO/OzpT6urmUeXZ4liDMwhULlha66jYrljy5oHOiaq0 persistent=cryptsetup persistence-encryption=luks ##################### # End boot options. # ##################### :skipgetbootopts ########################## # Target Selection/flow. # ########################## :findtarget # If we previously loaded (and left/attempted to leave) a menu within this script, # ${1e41ae3c-1a61-4649-b39c-38cc65a33c7a/tgt} will be set to that menu's label. # It will be unset/null (${} -- `isset ${foo} == false` is the same as `iseq ${foo} == ${}` if it is unset.) # if this is the first time loading this script. isset ${1e41ae3c-1a61-4649-b39c-38cc65a33c7a/tgt} && goto ${1e41ae3c-1a61-4649-b39c-38cc65a33c7a/tgt} || ######################## # End Target Selection # ######################## :skipfindtarget ##################### # Menu definitions. # ##################### :menudefs ############## # BEGIN MENU # ############## :367b317b-2748-4452-b00f-4af160d1fc56 # Menu: "ParrotOS Security" # Label: 367b317b-2748-4452-b00f-4af160d1fc56 set prev_menu 367b317b-2748-4452-b00f-4af160d1fc56 set 1e41ae3c-1a61-4649-b39c-38cc65a33c7a/tgt 367b317b-2748-4452-b00f-4af160d1fc56 # Script main/default menu. set prev_is_script 1 menu ParrotOS Security item --key s fb743beb-ce6a-4875-8b6f-ffef0ac1be45 (s) Standard set fb743beb-ce6a-4875-8b6f-ffef0ac1be45/prev 367b317b-2748-4452-b00f-4af160d1fc56 item --key f 094072b4-28c4-443a-a269-6ee66314077f (f) Fail-Safe set 094072b4-28c4-443a-a269-6ee66314077f/prev 367b317b-2748-4452-b00f-4af160d1fc56 item --key F d89d6487-8a44-4df0-ad02-c1cbdb04ef67 (F) Forensic Mode set d89d6487-8a44-4df0-ad02-c1cbdb04ef67/prev 367b317b-2748-4452-b00f-4af160d1fc56 item --key p fe612436-8ee2-4ddf-ae78-e8e422f990fa (p) Persistent Mode set fe612436-8ee2-4ddf-ae78-e8e422f990fa/prev 367b317b-2748-4452-b00f-4af160d1fc56 item --key e 0587b715-ee39-4d17-ba5f-2a4eae441cf2 (e) Encrypted Persistent Mode set 0587b715-ee39-4d17-ba5f-2a4eae441cf2/prev 367b317b-2748-4452-b00f-4af160d1fc56 item --gap item --key 0x147e 367b317b-2748-4452-b00f-4af160d1fc56_help (F8) Help > set 367b317b-2748-4452-b00f-4af160d1fc56_help/prev 367b317b-2748-4452-b00f-4af160d1fc56 item --key 0x157e 367b317b-2748-4452-b00f-4af160d1fc56_cfg (F9) Configure boot options for item(s) above set 367b317b-2748-4452-b00f-4af160d1fc56_cfg/prev 367b317b-2748-4452-b00f-4af160d1fc56 item --key 0x1b previous (ESC) Previous menu item --key 0x167e main_menu (F10) Main Menu ... choose --default fb743beb-ce6a-4875-8b6f-ffef0ac1be45 target || goto ${target} || goto ${367b317b-2748-4452-b00f-4af160d1fc56/prev} || goto previous ############ # END MENU # ############ ###################### # BEGIN SUBMENU HELP # ###################### # Menu: "ParrotOS Security" (HELP) # Label: 367b317b-2748-4452-b00f-4af160d1fc56 :367b317b-2748-4452-b00f-4af160d1fc56_help set prev_menu 367b317b-2748-4452-b00f-4af160d1fc56_help set 1e41ae3c-1a61-4649-b39c-38cc65a33c7a/tgt 367b317b-2748-4452-b00f-4af160d1fc56_help menu ParrotOS Security Help item fb743beb-ce6a-4875-8b6f-ffef0ac1be45_help Standard > set fb743beb-ce6a-4875-8b6f-ffef0ac1be45/prev 367b317b-2748-4452-b00f-4af160d1fc56_help item 094072b4-28c4-443a-a269-6ee66314077f_help Fail-Safe > set 094072b4-28c4-443a-a269-6ee66314077f/prev 367b317b-2748-4452-b00f-4af160d1fc56_help item d89d6487-8a44-4df0-ad02-c1cbdb04ef67_help Forensic Mode > set d89d6487-8a44-4df0-ad02-c1cbdb04ef67/prev 367b317b-2748-4452-b00f-4af160d1fc56_help item fe612436-8ee2-4ddf-ae78-e8e422f990fa_help Persistent Mode > set fe612436-8ee2-4ddf-ae78-e8e422f990fa/prev 367b317b-2748-4452-b00f-4af160d1fc56_help item 0587b715-ee39-4d17-ba5f-2a4eae441cf2_help Encrypted Persistent Mode > set 0587b715-ee39-4d17-ba5f-2a4eae441cf2/prev 367b317b-2748-4452-b00f-4af160d1fc56_help item --gap item --key 0x1b previous (ESC) Previous menu item --key 0x167e main_menu (F10) Main Menu ... choose target || goto ${target} || goto ${367b317b-2748-4452-b00f-4af160d1fc56_help/prev} || goto previous #################### # END SUBMENU HELP # #################### ######################## # BEGIN SUBMENU CONFIG # ######################## # Menu: "ParrotOS Security" (CONFIGURATION) # Label: 367b317b-2748-4452-b00f-4af160d1fc56 :367b317b-2748-4452-b00f-4af160d1fc56_cfg set prev_menu 367b317b-2748-4452-b00f-4af160d1fc56_cfg set 1e41ae3c-1a61-4649-b39c-38cc65a33c7a/tgt 367b317b-2748-4452-b00f-4af160d1fc56_cfg menu ParrotOS Security Configuration item fb743beb-ce6a-4875-8b6f-ffef0ac1be45_cfg Standard > set fb743beb-ce6a-4875-8b6f-ffef0ac1be45/prev 367b317b-2748-4452-b00f-4af160d1fc56_cfg item 094072b4-28c4-443a-a269-6ee66314077f_cfg Fail-Safe > set 094072b4-28c4-443a-a269-6ee66314077f/prev 367b317b-2748-4452-b00f-4af160d1fc56_cfg item d89d6487-8a44-4df0-ad02-c1cbdb04ef67_cfg Forensic Mode > set d89d6487-8a44-4df0-ad02-c1cbdb04ef67/prev 367b317b-2748-4452-b00f-4af160d1fc56_cfg item fe612436-8ee2-4ddf-ae78-e8e422f990fa_cfg Persistent Mode > set fe612436-8ee2-4ddf-ae78-e8e422f990fa/prev 367b317b-2748-4452-b00f-4af160d1fc56_cfg item 0587b715-ee39-4d17-ba5f-2a4eae441cf2_cfg Encrypted Persistent Mode > set 0587b715-ee39-4d17-ba5f-2a4eae441cf2/prev 367b317b-2748-4452-b00f-4af160d1fc56_cfg item --gap item --key 0x1b previous (ESC) Previous menu item --key 0x167e main_menu (F10) Main Menu ... choose target || goto ${target} || goto ${367b317b-2748-4452-b00f-4af160d1fc56_cfg/prev} || goto previous ###################### # END SUBMENU CONFIG # ###################### ################# # BEGIN ENTRIES # ################# # Entries for menu "ParrotOS Security" (367b317b-2748-4452-b00f-4af160d1fc56) ############### # BEGIN ENTRY # ############### # Entry: "Standard" # Label: fb743beb-ce6a-4875-8b6f-ffef0ac1be45 # Type: ItemTypeKernel # https://parrotsec.org/ # Kali Standard mode options. :fb743beb-ce6a-4875-8b6f-ffef0ac1be45 set prev_is_script 0 iseq ${do_serial} 1 && kernel ${base_url}loop/parrotos/security/live/vmlinuz ${fb743beb-ce6a-4875-8b6f-ffef0ac1be45/bootopts} console=tty1 console=ttyS0,9600n8 noquick || kernel ${base_url}loop/parrotos/security/live/vmlinuz ${fb743beb-ce6a-4875-8b6f-ffef0ac1be45/bootopts} || goto previous initrd ${base_url}loop/parrotos/security/live/initrd.img || goto previous boot || goto ${fb743beb-ce6a-4875-8b6f-ffef0ac1be45/prev} || goto previous ############# # END ENTRY # ############# #################### # BEGIN ENTRY HELP # #################### # Entry: "Standard" (HELP) # Label: fb743beb-ce6a-4875-8b6f-ffef0ac1be45 # Type: ItemTypeKernel # https://parrotsec.org/ # Kali Standard mode options. :fb743beb-ce6a-4875-8b6f-ffef0ac1be45_help set prev_is_script 0 set fb743beb-ce6a-4875-8b6f-ffef0ac1be45_help/prev fb743beb-ce6a-4875-8b6f-ffef0ac1be45 echo Standard: echo Kali Standard mode options. prompt (Press any key to exit) goto ${fb743beb-ce6a-4875-8b6f-ffef0ac1be45/prev} || goto previous ################## # END ENTRY HELP # ################## ###################### # BEGIN ENTRY CONFIG # ###################### # Entry: "Standard" (CONFIGURATION) # Label: fb743beb-ce6a-4875-8b6f-ffef0ac1be45 # Type: ItemTypeKernel # https://parrotsec.org/ # Kali Standard mode options. :fb743beb-ce6a-4875-8b6f-ffef0ac1be45_cfg set prev_is_script 0 echo Set custom boot options for Standard below. echo Leave blank to use the currently configured options. echo Use the string "%DEFAULT%" (without quotes) to reset to the default. echo echo CURRENT: echo ${fb743beb-ce6a-4875-8b6f-ffef0ac1be45/bootopts} echo echo DEFAULT: echo ${fb743beb-ce6a-4875-8b6f-ffef0ac1be45/orig_bootopts} echo echo -n Boot options: ${} && read user_bootopts || goto prev_menu_fb743beb-ce6a-4875-8b6f-ffef0ac1be45_cfg iseq ${user_bootopts} ${} && goto prev_menu_fb743beb-ce6a-4875-8b6f-ffef0ac1be45_cfg || iseq ${user_bootopts} %DEFAULT% && set fb743beb-ce6a-4875-8b6f-ffef0ac1be45/bootopts ${fb743beb-ce6a-4875-8b6f-ffef0ac1be45/orig_bootopts} && goto prev_menu_fb743beb-ce6a-4875-8b6f-ffef0ac1be45_cfg || set fb743beb-ce6a-4875-8b6f-ffef0ac1be45/bootopts ${user_bootopts} && goto ${fb743beb-ce6a-4875-8b6f-ffef0ac1be45/prev} || goto previous #################### # END ENTRY CONFIG # #################### ############### # BEGIN ENTRY # ############### # Entry: "Fail-Safe" # Label: 094072b4-28c4-443a-a269-6ee66314077f # Type: ItemTypeKernel # https://parrotsec.org/ # Kali Fail-Safe mode options - this may have a better chance of working if the host has issues booting Standard. :094072b4-28c4-443a-a269-6ee66314077f set prev_is_script 0 iseq ${do_serial} 1 && kernel ${base_url}loop/parrotos/security/live/vmlinuz ${094072b4-28c4-443a-a269-6ee66314077f/bootopts} console=tty1 console=ttyS0,9600n8 noquick || kernel ${base_url}loop/parrotos/security/live/vmlinuz ${094072b4-28c4-443a-a269-6ee66314077f/bootopts} || goto previous initrd ${base_url}loop/parrotos/security/live/initrd.img || goto previous boot || goto ${094072b4-28c4-443a-a269-6ee66314077f/prev} || goto previous ############# # END ENTRY # ############# #################### # BEGIN ENTRY HELP # #################### # Entry: "Fail-Safe" (HELP) # Label: 094072b4-28c4-443a-a269-6ee66314077f # Type: ItemTypeKernel # https://parrotsec.org/ # Kali Fail-Safe mode options - this may have a better chance of working if the host has issues booting Standard. :094072b4-28c4-443a-a269-6ee66314077f_help set prev_is_script 0 set 094072b4-28c4-443a-a269-6ee66314077f_help/prev 094072b4-28c4-443a-a269-6ee66314077f echo Fail-Safe: echo Kali Fail-Safe mode options - this may have a better chance of working if the host has issues booting Standard. prompt (Press any key to exit) goto ${094072b4-28c4-443a-a269-6ee66314077f/prev} || goto previous ################## # END ENTRY HELP # ################## ###################### # BEGIN ENTRY CONFIG # ###################### # Entry: "Fail-Safe" (CONFIGURATION) # Label: 094072b4-28c4-443a-a269-6ee66314077f # Type: ItemTypeKernel # https://parrotsec.org/ # Kali Fail-Safe mode options - this may have a better chance of working if the host has issues booting Standard. :094072b4-28c4-443a-a269-6ee66314077f_cfg set prev_is_script 0 echo Set custom boot options for Fail-Safe below. echo Leave blank to use the currently configured options. echo Use the string "%DEFAULT%" (without quotes) to reset to the default. echo echo CURRENT: echo ${094072b4-28c4-443a-a269-6ee66314077f/bootopts} echo echo DEFAULT: echo ${094072b4-28c4-443a-a269-6ee66314077f/orig_bootopts} echo echo -n Boot options: ${} && read user_bootopts || goto prev_menu_094072b4-28c4-443a-a269-6ee66314077f_cfg iseq ${user_bootopts} ${} && goto prev_menu_094072b4-28c4-443a-a269-6ee66314077f_cfg || iseq ${user_bootopts} %DEFAULT% && set 094072b4-28c4-443a-a269-6ee66314077f/bootopts ${094072b4-28c4-443a-a269-6ee66314077f/orig_bootopts} && goto prev_menu_094072b4-28c4-443a-a269-6ee66314077f_cfg || set 094072b4-28c4-443a-a269-6ee66314077f/bootopts ${user_bootopts} && goto ${094072b4-28c4-443a-a269-6ee66314077f/prev} || goto previous #################### # END ENTRY CONFIG # #################### ############### # BEGIN ENTRY # ############### # Entry: "Forensic Mode" # Label: d89d6487-8a44-4df0-ad02-c1cbdb04ef67 # Type: ItemTypeKernel # https://parrotsec.org/ # Forensic mode will not automatically touch any of the disks installed on the system (e.g. no swap or automounting). :d89d6487-8a44-4df0-ad02-c1cbdb04ef67 set prev_is_script 0 iseq ${do_serial} 1 && kernel ${base_url}loop/parrotos/security/live/vmlinuz ${d89d6487-8a44-4df0-ad02-c1cbdb04ef67/bootopts} console=tty1 console=ttyS0,9600n8 noquick || kernel ${base_url}loop/parrotos/security/live/vmlinuz ${d89d6487-8a44-4df0-ad02-c1cbdb04ef67/bootopts} || goto previous initrd ${base_url}loop/parrotos/security/live/initrd.img || goto previous boot || goto ${d89d6487-8a44-4df0-ad02-c1cbdb04ef67/prev} || goto previous ############# # END ENTRY # ############# #################### # BEGIN ENTRY HELP # #################### # Entry: "Forensic Mode" (HELP) # Label: d89d6487-8a44-4df0-ad02-c1cbdb04ef67 # Type: ItemTypeKernel # https://parrotsec.org/ # Forensic mode will not automatically touch any of the disks installed on the system (e.g. no swap or automounting). :d89d6487-8a44-4df0-ad02-c1cbdb04ef67_help set prev_is_script 0 set d89d6487-8a44-4df0-ad02-c1cbdb04ef67_help/prev d89d6487-8a44-4df0-ad02-c1cbdb04ef67 echo Forensic Mode: echo Forensic mode will not automatically touch any of the disks installed on the system (e.g. no swap or automounting). prompt (Press any key to exit) goto ${d89d6487-8a44-4df0-ad02-c1cbdb04ef67/prev} || goto previous ################## # END ENTRY HELP # ################## ###################### # BEGIN ENTRY CONFIG # ###################### # Entry: "Forensic Mode" (CONFIGURATION) # Label: d89d6487-8a44-4df0-ad02-c1cbdb04ef67 # Type: ItemTypeKernel # https://parrotsec.org/ # Forensic mode will not automatically touch any of the disks installed on the system (e.g. no swap or automounting). :d89d6487-8a44-4df0-ad02-c1cbdb04ef67_cfg set prev_is_script 0 echo Set custom boot options for Forensic Mode below. echo Leave blank to use the currently configured options. echo Use the string "%DEFAULT%" (without quotes) to reset to the default. echo echo CURRENT: echo ${d89d6487-8a44-4df0-ad02-c1cbdb04ef67/bootopts} echo echo DEFAULT: echo ${d89d6487-8a44-4df0-ad02-c1cbdb04ef67/orig_bootopts} echo echo -n Boot options: ${} && read user_bootopts || goto prev_menu_d89d6487-8a44-4df0-ad02-c1cbdb04ef67_cfg iseq ${user_bootopts} ${} && goto prev_menu_d89d6487-8a44-4df0-ad02-c1cbdb04ef67_cfg || iseq ${user_bootopts} %DEFAULT% && set d89d6487-8a44-4df0-ad02-c1cbdb04ef67/bootopts ${d89d6487-8a44-4df0-ad02-c1cbdb04ef67/orig_bootopts} && goto prev_menu_d89d6487-8a44-4df0-ad02-c1cbdb04ef67_cfg || set d89d6487-8a44-4df0-ad02-c1cbdb04ef67/bootopts ${user_bootopts} && goto ${d89d6487-8a44-4df0-ad02-c1cbdb04ef67/prev} || goto previous #################### # END ENTRY CONFIG # #################### ############### # BEGIN ENTRY # ############### # Entry: "Persistent Mode" # Label: fe612436-8ee2-4ddf-ae78-e8e422f990fa # Type: ItemTypeKernel # https://parrotsec.org/prst # Persistent mode allows for loading persistent settings, etc. from an attached disk. See https://parrotsec.org/prst for more information. :fe612436-8ee2-4ddf-ae78-e8e422f990fa set prev_is_script 0 iseq ${do_serial} 1 && kernel ${base_url}loop/parrotos/security/live/vmlinuz ${fe612436-8ee2-4ddf-ae78-e8e422f990fa/bootopts} console=tty1 console=ttyS0,9600n8 noquick || kernel ${base_url}loop/parrotos/security/live/vmlinuz ${fe612436-8ee2-4ddf-ae78-e8e422f990fa/bootopts} || goto previous initrd ${base_url}loop/parrotos/security/live/initrd.img || goto previous boot || goto ${fe612436-8ee2-4ddf-ae78-e8e422f990fa/prev} || goto previous ############# # END ENTRY # ############# #################### # BEGIN ENTRY HELP # #################### # Entry: "Persistent Mode" (HELP) # Label: fe612436-8ee2-4ddf-ae78-e8e422f990fa # Type: ItemTypeKernel # https://parrotsec.org/prst # Persistent mode allows for loading persistent settings, etc. from an attached disk. See https://parrotsec.org/prst for more information. :fe612436-8ee2-4ddf-ae78-e8e422f990fa_help set prev_is_script 0 set fe612436-8ee2-4ddf-ae78-e8e422f990fa_help/prev fe612436-8ee2-4ddf-ae78-e8e422f990fa echo Persistent Mode: echo Persistent mode allows for loading persistent settings, etc. from an attached disk. See https://parrotsec.org/prst for more information. prompt (Press any key to exit) goto ${fe612436-8ee2-4ddf-ae78-e8e422f990fa/prev} || goto previous ################## # END ENTRY HELP # ################## ###################### # BEGIN ENTRY CONFIG # ###################### # Entry: "Persistent Mode" (CONFIGURATION) # Label: fe612436-8ee2-4ddf-ae78-e8e422f990fa # Type: ItemTypeKernel # https://parrotsec.org/prst # Persistent mode allows for loading persistent settings, etc. from an attached disk. See https://parrotsec.org/prst for more information. :fe612436-8ee2-4ddf-ae78-e8e422f990fa_cfg set prev_is_script 0 echo Set custom boot options for Persistent Mode below. echo Leave blank to use the currently configured options. echo Use the string "%DEFAULT%" (without quotes) to reset to the default. echo echo CURRENT: echo ${fe612436-8ee2-4ddf-ae78-e8e422f990fa/bootopts} echo echo DEFAULT: echo ${fe612436-8ee2-4ddf-ae78-e8e422f990fa/orig_bootopts} echo echo -n Boot options: ${} && read user_bootopts || goto prev_menu_fe612436-8ee2-4ddf-ae78-e8e422f990fa_cfg iseq ${user_bootopts} ${} && goto prev_menu_fe612436-8ee2-4ddf-ae78-e8e422f990fa_cfg || iseq ${user_bootopts} %DEFAULT% && set fe612436-8ee2-4ddf-ae78-e8e422f990fa/bootopts ${fe612436-8ee2-4ddf-ae78-e8e422f990fa/orig_bootopts} && goto prev_menu_fe612436-8ee2-4ddf-ae78-e8e422f990fa_cfg || set fe612436-8ee2-4ddf-ae78-e8e422f990fa/bootopts ${user_bootopts} && goto ${fe612436-8ee2-4ddf-ae78-e8e422f990fa/prev} || goto previous #################### # END ENTRY CONFIG # #################### ############### # BEGIN ENTRY # ############### # Entry: "Encrypted Persistent Mode" # Label: 0587b715-ee39-4d17-ba5f-2a4eae441cf2 # Type: ItemTypeKernel # https://parrotsec.org/prst # Encrypted persistent mode is like persistent mode but encrypts/uses an encrypted attached storage. :0587b715-ee39-4d17-ba5f-2a4eae441cf2 set prev_is_script 0 iseq ${do_serial} 1 && kernel ${base_url}loop/parrotos/security/live/vmlinuz ${0587b715-ee39-4d17-ba5f-2a4eae441cf2/bootopts} console=tty1 console=ttyS0,9600n8 noquick || kernel ${base_url}loop/parrotos/security/live/vmlinuz ${0587b715-ee39-4d17-ba5f-2a4eae441cf2/bootopts} || goto previous initrd ${base_url}loop/parrotos/security/live/initrd.img || goto previous boot || goto ${0587b715-ee39-4d17-ba5f-2a4eae441cf2/prev} || goto previous ############# # END ENTRY # ############# #################### # BEGIN ENTRY HELP # #################### # Entry: "Encrypted Persistent Mode" (HELP) # Label: 0587b715-ee39-4d17-ba5f-2a4eae441cf2 # Type: ItemTypeKernel # https://parrotsec.org/prst # Encrypted persistent mode is like persistent mode but encrypts/uses an encrypted attached storage. :0587b715-ee39-4d17-ba5f-2a4eae441cf2_help set prev_is_script 0 set 0587b715-ee39-4d17-ba5f-2a4eae441cf2_help/prev 0587b715-ee39-4d17-ba5f-2a4eae441cf2 echo Encrypted Persistent Mode: echo Encrypted persistent mode is like persistent mode but encrypts/uses an encrypted attached storage. prompt (Press any key to exit) goto ${0587b715-ee39-4d17-ba5f-2a4eae441cf2/prev} || goto previous ################## # END ENTRY HELP # ################## ###################### # BEGIN ENTRY CONFIG # ###################### # Entry: "Encrypted Persistent Mode" (CONFIGURATION) # Label: 0587b715-ee39-4d17-ba5f-2a4eae441cf2 # Type: ItemTypeKernel # https://parrotsec.org/prst # Encrypted persistent mode is like persistent mode but encrypts/uses an encrypted attached storage. :0587b715-ee39-4d17-ba5f-2a4eae441cf2_cfg set prev_is_script 0 echo Set custom boot options for Encrypted Persistent Mode below. echo Leave blank to use the currently configured options. echo Use the string "%DEFAULT%" (without quotes) to reset to the default. echo echo CURRENT: echo ${0587b715-ee39-4d17-ba5f-2a4eae441cf2/bootopts} echo echo DEFAULT: echo ${0587b715-ee39-4d17-ba5f-2a4eae441cf2/orig_bootopts} echo echo -n Boot options: ${} && read user_bootopts || goto prev_menu_0587b715-ee39-4d17-ba5f-2a4eae441cf2_cfg iseq ${user_bootopts} ${} && goto prev_menu_0587b715-ee39-4d17-ba5f-2a4eae441cf2_cfg || iseq ${user_bootopts} %DEFAULT% && set 0587b715-ee39-4d17-ba5f-2a4eae441cf2/bootopts ${0587b715-ee39-4d17-ba5f-2a4eae441cf2/orig_bootopts} && goto prev_menu_0587b715-ee39-4d17-ba5f-2a4eae441cf2_cfg || set 0587b715-ee39-4d17-ba5f-2a4eae441cf2/bootopts ${user_bootopts} && goto ${0587b715-ee39-4d17-ba5f-2a4eae441cf2/prev} || goto previous #################### # END ENTRY CONFIG # #################### # End entries for menu "ParrotOS Security" (367b317b-2748-4452-b00f-4af160d1fc56) ############### # END ENTRIES # ############### ######################### # End menu definitions. # ######################### :skipmenudefs ###################################### # Menu navigation and exit handling. # ###################################### :previous iseq ${do_debug} 1 && goto prev_debug || goto prev_no_debug :prev_debug ## Debugging ## echo cls: ${cls} echo prev_is_script: ${prev_is_script} echo 1e41ae3c-1a61-4649-b39c-38cc65a33c7a/tgt: ${1e41ae3c-1a61-4649-b39c-38cc65a33c7a/tgt} echo main_menu: ${main_menu} echo prev_menu: ${prev_menu} echo prev_menu (dereferenced); ${prev_menu}/prev: ${${prev_menu}/prev} echo Script live/infosec/parrotos/main.ipxe (current script): # The "${} ${} " is to force two spaces. They'd be trimmed otherwise. echo ${} ${} 1e41ae3c-1a61-4649-b39c-38cc65a33c7a/prev: ${1e41ae3c-1a61-4649-b39c-38cc65a33c7a/prev} echo ${} ${} 1e41ae3c-1a61-4649-b39c-38cc65a33c7a/tgt: ${1e41ae3c-1a61-4649-b39c-38cc65a33c7a/tgt} echo Menus (local to this script) (A blank /prev tends to indicate script's default/entry menu): echo ${} ${} 367b317b-2748-4452-b00f-4af160d1fc56 ("ParrotOS Security") echo ${} ${} ${} ${} 367b317b-2748-4452-b00f-4af160d1fc56/prev: ${367b317b-2748-4452-b00f-4af160d1fc56/prev} echo ${} ${} ${} ${} 367b317b-2748-4452-b00f-4af160d1fc56/tgt: ${367b317b-2748-4452-b00f-4af160d1fc56/tgt} echo target: ${target} echo main_menu: ${main_menu} prompt (press any key to continue to arch) echo echo bits: 64, 32 echo arch0: x86_64, i386, arm64, arm32 echo arch0u: X86_64, I386, ARM64, ARM32 echo arch1: x86_64, x86, arm64, arm32 echo arch1u: X86_64, X86, ARM64, ARM32 echo arch2: amd64, i686, arm64, arm32 echo arch2u: AMD64, I686, ARM64, ARM32 echo buildarch: x86_64, i386, arm64, arm32 echo platform: efi, pcbios, linux echo echo bits, arch0, arch0u, arch1, arch1u, arch2, arch2u, buildarch, platform: echo ${bits}, ${arch0}, ${arch0u}, ${arch1}, ${arch1u}, ${arch2}, ${arch2u}, ${buildarch}, ${platform} echo # ECHO DEBUG OF PREV_NO_DEBUG HERE prompt (press any key to continue regular previous target) :prev_no_debug :prev_test0 # If prev_is_script is true and prev_1e41ae3c-1a61-4649-b39c-38cc65a33c7a is set and is this script, # assume exit (as this is probably entry_script, and "previous" dest in this logic tree is to actually exit). # Otherwise continue. iseq ${do_debug} 1 && prompt (PREVIOUS: prev_test0) || iseq ${prev_is_script} 1 && iseq ${prev_1e41ae3c-1a61-4649-b39c-38cc65a33c7a} ${script_path} && exit || :prev_test1 # If 1e41ae3c-1a61-4649-b39c-38cc65a33c7a/tgt is set and prev_is_script is false, go to menu in this script - otherwise continue. iseq ${do_debug} 1 && prompt (PREVIOUS: prev_test1) || iseq ${prev_is_script} 0 && isset ${${prev_menu}/prev} && goto ${${prev_menu}/prev} || :prev_test2 # If prev_is_script is set, continue to prev_test3. Otherwise, set to true (default for scripts) and # go to 1e41ae3c-1a61-4649-b39c-38cc65a33c7a/tgt (otherwise continue to prev_test3). # This is in case prev_test1 fails but should have succeeded. iseq ${do_debug} 1 && prompt (PREVIOUS: prev_test2) || isset ${prev_is_script} && goto prev_test3 || set prev_is_script 1 && isset ${1e41ae3c-1a61-4649-b39c-38cc65a33c7a/tgt} && goto ${1e41ae3c-1a61-4649-b39c-38cc65a33c7a/tgt} || :prev_test3 # If prev_is_script is 1 (true), our previous menu is in another script so skip to chainloading that. # Otherwise, use this script's last set target. iseq ${do_debug} 1 && prompt (PREVIOUS: prev_test3) || iseq ${prev_is_script} 1 && goto prev_last || isset ${1e41ae3c-1a61-4649-b39c-38cc65a33c7a/tgt} && goto ${1e41ae3c-1a61-4649-b39c-38cc65a33c7a/tgt} || :prev_last # If prev_is_script is true, then we need to go to ${prev_1e41ae3c-1a61-4649-b39c-38cc65a33c7a}. The target and exiterr gotos are fallbacks. iseq ${do_debug} 1 && prompt (PREVIOUS: prev_last; chain to ${1e41ae3c-1a61-4649-b39c-38cc65a33c7a/prev}) && prompt (press any key to continue) || chain ${1e41ae3c-1a61-4649-b39c-38cc65a33c7a/prev} || goto ${target} || goto exiterr :exiterr echo ERROR ENCOUNTERED iseq ${do_debug} 1 && sleep 2 || exit 1 :exitsuccess exit 0 :exit goto exit_${platform} :exit_efi # We exit 1 instead of just exit (exit with error vs. exit without error) so some broken UEFI will boot the "next" device. exit 0 :exit_pcbios # Boot the "first hard disk". Unpredictable, but so's BIOS lol. sanboot --no-describe --drive 0x80 || # TODO: https://ipxe.org/appnote/work_around_bios_halting_on_ipxe_exit ? exit 1 #exit :main_menu goto ${main_menu} || chain ${entry_script} || goto previous :clear_all # Clear dynamic session-based variables. imgfree || clear do_debug clear bg_set clear prev_is_script clear 1e41ae3c-1a61-4649-b39c-38cc65a33c7a/prev clear 1e41ae3c-1a61-4649-b39c-38cc65a33c7a/tgt clear main_menu clear ${prev_menu}/prev clear prev_menu clear 367b317b-2748-4452-b00f-4af160d1fc56/prev clear 367b317b-2748-4452-b00f-4af160d1fc56/tgt clear target clear main_menu clear bits clear arch0 clear arch0u clear arch1 clear arch1u clear arch2 clear arch2u clear esc clear cls clear fb743beb-ce6a-4875-8b6f-ffef0ac1be45/bootopts clear fb743beb-ce6a-4875-8b6f-ffef0ac1be45/orig_bootopts clear 094072b4-28c4-443a-a269-6ee66314077f/bootopts clear 094072b4-28c4-443a-a269-6ee66314077f/orig_bootopts clear d89d6487-8a44-4df0-ad02-c1cbdb04ef67/bootopts clear d89d6487-8a44-4df0-ad02-c1cbdb04ef67/orig_bootopts clear fe612436-8ee2-4ddf-ae78-e8e422f990fa/bootopts clear fe612436-8ee2-4ddf-ae78-e8e422f990fa/orig_bootopts clear 0587b715-ee39-4d17-ba5f-2a4eae441cf2/bootopts clear 0587b715-ee39-4d17-ba5f-2a4eae441cf2/orig_bootopts chain --autofree --replace ${entry_script} || goto exiterr :ipxe_shell echo ${cls} echo This is the NetFire NetBoot shell. echo Use the 'help' command for a list of possible commands. echo Exit back to the menu by executing the command 'exit'. shell || goto exiterr goto previous ###################################### # End menu navigation/exit handling. # ######################################